homePage.vue 44 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328
  1. <template>
  2. <view class="HomeItem">
  3. <view v-if="!online && online !== undefined && workSchemeType == 1">
  4. <view class="goWork" @click="GoWork()">
  5. <view class="goWork_btn_E">
  6. <view class="goWork_btn_W"> 上班 </view>
  7. </view>
  8. </view>
  9. <view class="goWork_text">
  10. <view class="goWork_text-p">上班提醒</view>
  11. <view>请点击" 上班 "开始接单!</view>
  12. </view>
  13. </view>
  14. <view v-if="!online && online !== undefined && workSchemeType == 2" class="goWorkAll">
  15. <view class="goWorkSelect combination">
  16. <view class="goWorkSelect-head">上班选择工作组合</view>
  17. <scroll-view class="goWorkSelect-list scroll" scroll-y :refresher-enabled="scroll_refresher_enabled"
  18. :refresher-triggered="triggered" @refresherrefresh="refresherrefresh" @refresherrestore="refresherrestore"
  19. @scrolltolower="scrolltolower" :scroll-top="scroll_top" @refresherabort="refresherabort" @scroll="scroll">
  20. <radio-group @change="radioChange1">
  21. <label class="goWorkSelect-item relative" v-for="item in zxzData" :key="item.str">
  22. <radio :value="item.str" :checked="item.checked" />
  23. <picker class="picker" v-if="item.ruleType == 4" @change="bindPickerChange" :value="index" :range="groups"
  24. range-key="groupName">
  25. <view>{{ item.configName }}</view>
  26. </picker>
  27. <view v-else>{{ item.configName }}</view>
  28. </label>
  29. </radio-group>
  30. </scroll-view>
  31. </view>
  32. <view class="goWorkSelect history">
  33. <view class="goWorkSelect-head"> 历史上班记录 </view>
  34. <view class="goWorkSelect-list">
  35. <radio-group @change="radioChange2">
  36. <label class="goWorkSelect-item" v-for="(item, index) in historys" :key="index">
  37. <radio :value="item.str" :checked="item.checked" />
  38. <view>{{ item.useTime }}上班记录快捷上班</view>
  39. <button @click="lock(item)">
  40. {{ item.locking == 1 ? "解锁" : "锁定" }}
  41. </button>
  42. </label>
  43. </radio-group>
  44. </view>
  45. </view>
  46. </view>
  47. <!-- APP或H5账号密码登录页面 start -->
  48. <view class="login" v-if="!workSchemeType && (isApp||isH5AndPwd)">
  49. <view class="title"> 医疗服务中心转运系统 </view>
  50. <input class="login_input" v-model="username" placeholder="请输入用户名" />
  51. <input class="login_input" password v-model="password" placeholder="请输入密码" />
  52. <input class="login_input" v-show="!isH5AndPwd" v-model="ip" placeholder="请输入域名或IP地址,如:http(s)://192.168.3.108" />
  53. <view class="savePassword">
  54. <checkbox-group @change="checkboxChange">
  55. <label>
  56. <checkbox v-for="(item,index) in savePassword" :key="item.value" color="#42b983" :value="item.value"
  57. :checked="item.checked" />记住密码
  58. </label>
  59. </checkbox-group>
  60. </view>
  61. <view class="page_item_btn" @click="login()"> 登录 </view>
  62. <view class="tips" v-show="isH5AndPwd">
  63. (此系统为服务中心及药房人员使用,其他科室人员请勿进行操作)
  64. </view>
  65. </view>
  66. <!-- APP或H5账号密码登录页面 end -->
  67. <view class="botImg" v-if="online || (!online && online !== undefined && workSchemeType == 1)">
  68. <view class="img"></view>
  69. </view>
  70. <!-- 弹窗 -->
  71. <showModel :title="models.title" :icon="models.icon" :disjunctor="models.disjunctor" :content="models.content"
  72. @ok="ok" @cancel="cancel" :operate="models.operate" :phone="models.phone" @know="know"></showModel>
  73. <!-- 锁定-弹窗 -->
  74. <showModel :title="modelsLock.title" :icon="modelsLock.icon" :disjunctor="modelsLock.disjunctor"
  75. :content="modelsLock.content" @ok="okLock" @cancel="cancelLock" :operate="modelsLock.operate" @know="knowLock">
  76. </showModel>
  77. <!-- 自选排班-科室绑定分组-弹窗 -->
  78. <showModel :title="models2.title" :icon="models2.icon" :disjunctor="models2.disjunctor" :content="models2.content"
  79. @ok="ok2" @cancel="cancel2" :operate="models2.operate">
  80. </showModel>
  81. </view>
  82. </template>
  83. <script>
  84. import {
  85. get,
  86. post,
  87. changeIP,
  88. webHandle
  89. } from "../../http/http.js";
  90. import showModel from "../../components/showModel/showModel.vue";
  91. import {
  92. AES,
  93. mode,
  94. pad,
  95. enc
  96. } from "crypto-js";
  97. export default {
  98. data() {
  99. return {
  100. //#ifdef H5
  101. type: "",
  102. //#endif
  103. //记住密码
  104. savePassword: [{
  105. value: 'savePassword',
  106. name: '记住密码',
  107. checked: true
  108. }],
  109. // 是否上班了
  110. online: undefined,
  111. // 是否是app
  112. isApp: false,
  113. // 是否是H5,账号密码登录
  114. isH5AndPwd: false,
  115. // 用户名
  116. username: "",
  117. // 密码
  118. password: "",
  119. //ip地址或域名
  120. ip: "hsms.dashitech.com",
  121. scroll_refresher_enabled: true, //是否开启自定义下拉刷新
  122. triggered: false, //下拉刷新状态
  123. freshing: false, //上拉加载开关
  124. scroll_top: 0, //距离顶部的距离
  125. //分页页码
  126. idx: 0,
  127. // 列表项总数
  128. totalNum: -1,
  129. // 上班选择工作组合列表
  130. zxzData: [],
  131. workSchemeId: "", //启动中工作分配方案id
  132. workSchemeType: "", //启动中工作分配方案类型
  133. ruleType: "", //工作分配方案规则、、例如自由抢单等
  134. // 上班历史记录列表
  135. historys: [],
  136. // 弹窗model
  137. models: {
  138. disjunctor: false,
  139. },
  140. //锁定的选项
  141. itemLock: {},
  142. // 弹窗model--锁定
  143. modelsLock: {
  144. disjunctor: false,
  145. },
  146. groups: [],
  147. index: 0,
  148. quickObj: {}, //选择的上班快捷组合
  149. // 自选排班-科室绑定分组-弹窗model
  150. models2: {
  151. disjunctor: false,
  152. },
  153. objHistory: {}
  154. };
  155. },
  156. methods: {
  157. //aes加密
  158. encryptByEnAES(data) {
  159. let Key = "dsadmin";
  160. let tmpAES = AES.encrypt(data, Key, {
  161. mode: mode.CBC,
  162. padding: pad.Pkcs7,
  163. });
  164. return tmpAES.toString();
  165. },
  166. //aes解密
  167. encryptByDeAES(data) {
  168. let Key = "dsadmin";
  169. let tmpDeAES = AES.decrypt(data, Key, {
  170. mode: mode.CBC,
  171. padding: pad.Pkcs7,
  172. });
  173. return tmpDeAES.toString(enc.Utf8);
  174. },
  175. //记住密码
  176. checkboxChange(e) {
  177. console.log(e.detail.value);
  178. let arr = e.detail.value;
  179. if (arr.length) {
  180. this.savePassword.forEach(v => {
  181. v.checked = true;
  182. })
  183. } else {
  184. this.savePassword.forEach(v => {
  185. v.checked = false;
  186. })
  187. }
  188. console.log(this.savePassword)
  189. },
  190. // 锁定
  191. lock(data) {
  192. console.log(data);
  193. // 如果不是科室绑定人员,则提示
  194. if (data.workAllocationQuick.ruleType != 3) {
  195. this.modelsLock = {
  196. disjunctor: true,
  197. title: "提示",
  198. content: `需科室绑定人员模式下才可快捷上班!`,
  199. icon: "warn",
  200. };
  201. return;
  202. }
  203. this.itemLock = data;
  204. this.modelsLock = {
  205. disjunctor: true,
  206. title: "提示",
  207. content: `是否${
  208. this.itemLock.locking == 1 ? "解锁" : "锁定"
  209. }该上班记录`,
  210. icon: "warn",
  211. operate: {
  212. ok: "确定",
  213. cancel: "取消",
  214. },
  215. };
  216. },
  217. //知道了
  218. knowLock() {
  219. this.modelsLock.disjunctor = false;
  220. let userId = uni.getStorageSync("userData").user.id;
  221. this.getHistorys(userId); //获取上班历史记录
  222. },
  223. //确定
  224. okLock() {
  225. this.modelsLock.disjunctor = false;
  226. let postData = {
  227. workConfigHistory: {
  228. id: this.itemLock.id,
  229. locking: this.itemLock.locking == 1 ? 0 : 1,
  230. },
  231. };
  232. uni.showLoading({
  233. title: "加载中",
  234. mask: true,
  235. });
  236. post("/configuration/updData/workConfigHistory", postData).then(
  237. (result) => {
  238. uni.hideLoading();
  239. if (result.status == 200) {
  240. this.modelsLock = {
  241. disjunctor: true,
  242. title: "提示",
  243. content: `${this.itemLock.locking == 0 ? "锁定" : "解锁"}成功`,
  244. icon: "success",
  245. operate: {
  246. know: "知道了",
  247. },
  248. };
  249. } else {
  250. uni.showToast({
  251. icon: "none",
  252. title: "请求失败",
  253. });
  254. }
  255. }
  256. );
  257. },
  258. //取消
  259. cancelLock() {
  260. this.modelsLock.disjunctor = false;
  261. },
  262. // 选择历史上班记录
  263. radioChange2(value) {
  264. this.objHistory = JSON.parse(value.target.value);
  265. console.log(this.objHistory);
  266. // 如果不是科室绑定人员,则提示
  267. if (this.objHistory.workAllocationQuick.ruleType != 3) {
  268. this.models = {
  269. disjunctor: true,
  270. title: "提示",
  271. content: `需科室绑定人员模式下才可快捷上班!`,
  272. icon: "warn",
  273. };
  274. return;
  275. }
  276. if (!this.objHistory.deptList) {
  277. this.objHistory.deptList = [];
  278. }
  279. let depts = this.objHistory.deptList.map((item) => item.dept).join();
  280. this.models = {
  281. disjunctor: true,
  282. title: "提示",
  283. content: `组合名称是【${this.objHistory.workAllocationQuick.configName}】;选择的科室是【${depts}】`,
  284. icon: "warn",
  285. operate: {
  286. ok: "快捷上班",
  287. cancel: "取消",
  288. },
  289. };
  290. },
  291. //知道了
  292. know() {
  293. this.models.disjunctor = false;
  294. },
  295. //确定
  296. ok() {
  297. this.models.disjunctor = false;
  298. this.ruleType = 3;
  299. uni.setStorageSync("setDepts", this.objHistory.deptList); //存科室列表
  300. uni.setStorageSync("setDeptConfg", {
  301. //存设置科室的配置信息
  302. configName: this.objHistory.workAllocationQuick.configName, //组合名称
  303. workSchemeType: 2, //方案类型
  304. ruleType: 3, //方案规则,科室绑定人员
  305. id: this.objHistory.workAllocationQuick.id, //组合id
  306. classesId: this.objHistory.classId,
  307. });
  308. this.GoWork();
  309. },
  310. //取消
  311. cancel() {
  312. this.models.disjunctor = false;
  313. let userId = uni.getStorageSync("userData").user.id;
  314. this.historys = [];
  315. this.getHistorys(userId); //获取上班历史记录
  316. },
  317. // 获取上班历史记录
  318. getHistorys(id) {
  319. let postData = {
  320. idx: 0,
  321. sum: 3,
  322. workConfigHistory: {
  323. hosId: uni.getStorageSync("userData").user.currentHospital.id,
  324. user: {
  325. id: id,
  326. },
  327. },
  328. };
  329. post("/configuration/fetchDataList/workConfigHistory", postData).then(
  330. (res) => {
  331. if (res.status == 200) {
  332. this.historys = res.list;
  333. this.historys.forEach((item) => {
  334. let d = new Date(item.useTime);
  335. let month = (d.getMonth() + 1 + "").padStart(2, "0");
  336. let day = (d.getDate() + "").padStart(2, "0");
  337. item.useTime = `${month}月${day}日`;
  338. let o = JSON.parse(JSON.stringify(item));
  339. item.str = JSON.stringify(o);
  340. item.checked = false;
  341. });
  342. } else {
  343. uni.showToast({
  344. icon: "none",
  345. title: "请求失败",
  346. });
  347. }
  348. }
  349. );
  350. },
  351. //确定
  352. ok2() {
  353. uni.setStorageSync("manager", this.groups[this.index].manager); //储存分组组长
  354. this.models2.disjunctor = false;
  355. //进入设置科室界面
  356. uni.setStorageSync("setDeptConfg", {
  357. //存设置科室的配置信息
  358. configName: this.quickObj.configName,
  359. workSchemeType: this.workSchemeType,
  360. ruleType: this.quickObj.ruleType,
  361. id: this.quickObj.id,
  362. classesId: this.quickObj.classes.id,
  363. selectGroupId: this.groups[this.index].id,
  364. });
  365. uni.navigateTo({
  366. url: `../setDept/setDept?configName=${this.quickObj.configName}&id=${this.quickObj.id}`,
  367. });
  368. },
  369. //取消
  370. cancel2() {
  371. this.models2.disjunctor = false;
  372. },
  373. //工作组合的工作模式是2(科室绑定分组)或4(绑定分组)
  374. bindPickerChange: function(e) {
  375. console.log('picker发送选择改变,携带值为', e.detail.value)
  376. this.index = e.target.value;
  377. let userId = uni.getStorageSync("userData").user.id;
  378. let groupObj = this.groups[this.index];
  379. if (groupObj.manager == userId) {
  380. //当前登陆人是该分组组长-弹窗确定
  381. this.models2 = {
  382. disjunctor: true,
  383. title: "提示",
  384. content: `请确认您选择了‘${this.quickObj.classes.name}’班次,并选择了‘${groupObj.groupName}’分组!`,
  385. icon: "warn",
  386. operate: {
  387. ok: "确定",
  388. cancel: "取消",
  389. },
  390. };
  391. } else {
  392. //当前登陆人不是该分组组长
  393. uni.setStorageSync("setDeptConfg", {
  394. //存设置科室的配置信息
  395. configName: this.quickObj.configName,
  396. workSchemeType: this.workSchemeType,
  397. ruleType: this.quickObj.ruleType,
  398. id: this.quickObj.id,
  399. classesId: this.quickObj.classes.id,
  400. });
  401. this.GoWork([groupObj]);
  402. }
  403. },
  404. // 选择上班快捷组合
  405. radioChange1(value) {
  406. let obj = JSON.parse(value.target.value);
  407. console.log(obj);
  408. this.quickObj = obj;
  409. this.ruleType = obj.ruleType;
  410. if (uni.getStorageSync("setDeptConfg")) {
  411. uni.removeStorageSync("setDeptConfg"); //清空选择的科室配置,初始化
  412. }
  413. if (obj.ruleType == 1) {
  414. uni.setStorageSync("setDeptConfg", {
  415. configName: this.quickObj.configName,
  416. workSchemeType: this.workSchemeType,
  417. ruleType: this.quickObj.ruleType,
  418. id: this.quickObj.id,
  419. classesId: this.quickObj.classes.id,
  420. });
  421. //自由抢单,直接上班
  422. this.GoWork();
  423. } else if (obj.ruleType == 3) {
  424. //科室绑定人员,进入设置科室界面
  425. uni.setStorageSync("setDeptConfg", {
  426. //存设置科室的配置信息
  427. configName: this.quickObj.configName,
  428. workSchemeType: this.workSchemeType,
  429. ruleType: this.quickObj.ruleType,
  430. id: this.quickObj.id,
  431. classesId: this.quickObj.classes.id,
  432. });
  433. uni.navigateTo({
  434. url: `../setDept/setDept?configName=${this.quickObj.configName}&id=${this.quickObj.id}`,
  435. });
  436. } else if (obj.ruleType == 2) {
  437. //绑定分组,直接上班
  438. uni.setStorageSync("setDeptConfg", {
  439. //存设置科室的配置信息
  440. configName: this.quickObj.configName,
  441. workSchemeType: this.workSchemeType,
  442. ruleType: this.quickObj.ruleType,
  443. id: this.quickObj.id,
  444. classesId: this.quickObj.classes.id,
  445. });
  446. this.GoWork(obj.groups);
  447. } else if (obj.ruleType == 4) {
  448. //科室绑定分组,弹出分组选择
  449. this.groups = obj.groups;
  450. }
  451. },
  452. // 连接上下班的websocket baba type如果是wx则是微信,app则是app;有app必有ip
  453. offWork(type, ip) {
  454. let ipp, wws;
  455. if (type == "wx") {
  456. wws = document.location.protocol === "http:" ? "ws" : "wss"; //ws协议
  457. ipp = document.domain;
  458. } else if (type == "app") {
  459. wws = ip.split(":")[0] === "http" ? "ws" : "wss"; //ws协议
  460. ipp = ip.split(":")[1];
  461. }
  462. console.log(ipp, wws);
  463. uni.connectSocket({
  464. url: `${wws}://${ipp}:8080/webSocket/message/onlineStatus`,
  465. // url: `${wws}://192.168.3.74:8080/webSocket/message/onlineStatus`,
  466. });
  467. uni.onSocketOpen(function(res) {
  468. console.log("WebSocket连接已打开!");
  469. let userid = uni.getStorageSync("userData").user.id;
  470. uni.sendSocketMessage({
  471. data: JSON.stringify({
  472. userid,
  473. }),
  474. success: function(res) {
  475. console.log(res, "传参");
  476. },
  477. fail: function(err) {
  478. console.log(err, "传参错误");
  479. },
  480. });
  481. });
  482. uni.onSocketError(function(res) {
  483. console.log("WebSocket连接打开失败,请检查!");
  484. });
  485. uni.onSocketMessage((res) => {
  486. console.log("收到服务器内容:" + res.data);
  487. if (res.data == "ok") {
  488. this.goOffWork();
  489. }
  490. });
  491. },
  492. // 下班
  493. goOffWork() {
  494. let setDeptConfg = uni.getStorageSync("setDeptConfg");
  495. if (setDeptConfg.workSchemeType == 2 && setDeptConfg.ruleType == 3) {
  496. post("/auth/onOrOffLine", {
  497. type: "off",
  498. customWorking: "off",
  499. classId: uni.getStorageSync("setDeptConfg").classesId
  500. }).then((res) => {
  501. if (res.status == 200) {
  502. if (uni.getStorageSync("setDeptConfg")) {
  503. uni.removeStorageSync("setDeptConfg"); //清空选择的科室配置,初始化
  504. }
  505. uni.showToast({
  506. icon: "none",
  507. title: "您已被强制下班!",
  508. mask: true,
  509. duration: 5000,
  510. });
  511. setTimeout(() => {
  512. uni.redirectTo({
  513. url: "../mypage/mypage",
  514. });
  515. }, 5000);
  516. } else {
  517. uni.showToast({
  518. icon: "none",
  519. title: "请求失败",
  520. });
  521. }
  522. });
  523. } else {
  524. post("/auth/onOrOffLine", {
  525. type: "off",
  526. classId: uni.getStorageSync("setDeptConfg").classesId
  527. }).then((res) => {
  528. if (res.status == 200) {
  529. if (uni.getStorageSync("setDeptConfg")) {
  530. uni.removeStorageSync("setDeptConfg"); //清空选择的科室配置,初始化
  531. }
  532. uni.showToast({
  533. icon: "none",
  534. title: "您已被强制下班!",
  535. mask: true,
  536. duration: 5000,
  537. });
  538. setTimeout(() => {
  539. uni.redirectTo({
  540. url: "../mypage/mypage",
  541. });
  542. }, 5000);
  543. } else {
  544. uni.showToast({
  545. icon: "none",
  546. title: "请求失败",
  547. });
  548. }
  549. });
  550. }
  551. },
  552. // 上班
  553. GoWork(groups) {
  554. console.log(groups)
  555. uni.showLoading({
  556. title: "加载中",
  557. mask: true,
  558. });
  559. //自选排班,科室绑定人员,科室绑定分组,绑定分组
  560. if (this.workSchemeType == 2 && (this.ruleType == 1 || this.ruleType == 2 || this.ruleType == 3 || this
  561. .ruleType == 4)) {
  562. let userId = uni.getStorageSync("userData").user.id;
  563. let setDeptConfg = uni.getStorageSync("setDeptConfg");
  564. let postData = {
  565. type: "on",
  566. customWorking: "on",
  567. userId: userId,
  568. };
  569. console.log(postData, this.objHistory)
  570. if (this.ruleType == 3 || this.ruleType == 4) {
  571. if (!this.objHistory.deptList) {
  572. this.objHistory.deptList = [];
  573. }
  574. let depts = this.objHistory.deptList.map((item) => item.id).join();
  575. postData.deptIds = depts;
  576. postData.quickId = setDeptConfg.id;
  577. postData.classId = setDeptConfg.classesId;
  578. } else if (this.ruleType == 2 || this.ruleType == 1) {
  579. postData.quickId = setDeptConfg.id;
  580. postData.classId = setDeptConfg.classesId;
  581. }
  582. console.log(postData, this.ruleType, setDeptConfg)
  583. if (groups) {
  584. postData.groupIds = groups.map(v => v.id).toString();
  585. if (this.ruleType == 4) {
  586. //科室绑定分组,并且当前登陆人不是组长
  587. delete postData.deptIds;
  588. }
  589. }
  590. post("/auth/onOrOffLine", postData).then((result) => {
  591. uni.hideLoading();
  592. if (result.status == 200) {
  593. let obj = uni.getStorageSync("userData");
  594. obj.user.online = true;
  595. uni.setStorageSync("userData", obj);
  596. uni.redirectTo({
  597. url: "../receiptpage/receiptpage",
  598. });
  599. } else if (result.status == 504) {
  600. let dept = result.department.dept;
  601. let user = result.user.name;
  602. let phone = result.user.phone;
  603. this.models = {
  604. disjunctor: true,
  605. title: "提示",
  606. content: `您选择的科室已经被使用,请换个科室,或者联系:科室[${dept}]人员[${user}]号码[${phone}] 切换科室解决`,
  607. icon: "warn",
  608. phone,
  609. operate: {
  610. know: "知道了",
  611. },
  612. };
  613. } else {
  614. uni.showToast({
  615. icon: "none",
  616. title: "请求失败",
  617. });
  618. }
  619. });
  620. } else {
  621. let postData = {
  622. type: "on",
  623. classId: uni.getStorageSync("setDeptConfg").classesId
  624. };
  625. if (groups) { //caocao
  626. postData.groupIds = groups.map(v => v.id).toString();
  627. }
  628. post("/auth/onOrOffLine", postData).then((res) => {
  629. uni.hideLoading();
  630. if (res.status == 200) {
  631. let obj = uni.getStorageSync("userData");
  632. obj.user.online = true;
  633. uni.setStorageSync("userData", obj);
  634. uni.redirectTo({
  635. url: "../receiptpage/receiptpage",
  636. });
  637. } else {
  638. uni.showToast({
  639. icon: "none",
  640. title: "请求失败",
  641. });
  642. }
  643. });
  644. }
  645. },
  646. // 登录
  647. login() {
  648. // 用户名,密码,域名(ip)不能为空
  649. if (
  650. this.username.trim() === "" ||
  651. this.password.trim() === "" ||
  652. this.ip.trim() === ""
  653. ) {
  654. uni.showToast({
  655. icon: "none",
  656. title: "请输入用户名,密码,域名或IP",
  657. });
  658. return;
  659. }
  660. // 域名ip正则验证
  661. let regUrl =
  662. /^https?:\/\/([\w-]+\.)+((com)|(net)|(org)|(gov\.cn)|(info)|(cc)|(com\.cn)|(net\.cn)|(org\.cn)|(name)|(biz)|(tv)|(cn)|(mobi)|(name)|(sh)|(ac)| (io)|(tw)|(com\.tw)|(hk)|(com\.hk)|(ws)|(travel)|(us)|(tm)|(la)|(me\.uk)|(org\.uk)|(ltd\.uk)|(plc\.uk)|(in)|(eu)|(it)|(jp))(\:([0-9]|[1-9]\d{1,3}|[1-5]\d{4}|6[0-5]{2}[0-3][0-5]))?$/;
  663. let regIp =
  664. /^https?:\/\/((25[0-5])|(2[0-4]\d)|(1\d\d)|([1-9]\d)|\d)(\.((25[0-5])|(2[0-4]\d)|(1\d\d)|([1-9]\d)|\d)){3}(\:([0-9]|[1-9]\d{1,3}|[1-5]\d{4}|6[0-5]{2}[0-3][0-5]))?$/;
  665. if (!regUrl.test(this.ip.trim()) && !regIp.test(this.ip.trim())) {
  666. uni.showToast({
  667. icon: "none",
  668. title: "请输入正确的域名或IP",
  669. });
  670. return;
  671. }
  672. if (this.savePassword[0].checked) {
  673. //记住密码
  674. uni.setStorageSync("ip", this.ip);
  675. } else {
  676. // 不记住密码
  677. uni.removeStorageSync('ip');
  678. }
  679. changeIP(this.ip);
  680. uni.showLoading({
  681. title: "登录中",
  682. mask: true,
  683. });
  684. let data = {
  685. username: this.username.trim(),
  686. password: this.password.trim(),
  687. type: 'APP'
  688. };
  689. post("/auth/login", data).then((res) => {
  690. uni.hideLoading();
  691. if (res.status == 200) {
  692. //获取角色信息
  693. let role = res.user.user.role;
  694. // 配药师和支助人员才能登录
  695. let workerFlag = role.some((item) => item.rolecode === "worker");
  696. let pharmacistFlag = role.some((item) => item.rolecode === "pharmacist");
  697. if (!workerFlag && !pharmacistFlag) {
  698. uni.showToast({
  699. icon: "none",
  700. title: "暂无权限登录!",
  701. });
  702. return;
  703. }
  704. if (this.savePassword[0].checked) {
  705. //记住密码
  706. uni.setStorageSync("username", this.encryptByEnAES(this.username)); //存储用户名
  707. uni.setStorageSync("password", this.encryptByEnAES(this.password)); //存储密码
  708. uni.setStorageSync("savePasswordTime", Date.now()); //存储当前时间戳
  709. } else {
  710. uni.removeStorageSync('username');
  711. uni.removeStorageSync('password');
  712. uni.removeStorageSync('savePasswordTime');
  713. }
  714. uni.setStorageSync("userData", res.user);
  715. this.getWorkScheme(false, res.user.user.currentHospital.id); //获取当前启动中的工作分配方案
  716. this.getHistorys(res.user.user.id); //获取上班历史记录
  717. this.offWork("app", this.ip);
  718. if (workerFlag) { //有配药师角色
  719. if (!res.user.user.online) {
  720. this.online = false;
  721. } else {
  722. this.online = true;
  723. // 建立websocket连接
  724. webHandle("receiptpage", "app", this.ip);
  725. }
  726. } else {
  727. webHandle("pharmacy", "app", this.ip);
  728. }
  729. } else if (!res.status && !res.remarks) {
  730. //如果乱填写域名或ip
  731. uni.showToast({
  732. icon: "none",
  733. title: "服务器连接失败!请检查输入的域名(IP)及端口号",
  734. });
  735. } else {
  736. uni.showToast({
  737. icon: "none",
  738. title: res.remarks ? res.remarks : "请求失败",
  739. });
  740. }
  741. });
  742. },
  743. // 微信登录公用方法
  744. // user:当前登录用户对象
  745. // type:有值的话则是从菜单访问的
  746. // workerFlag:是否有支助人员角色
  747. // pharmacistFlag:是否有配药师角色
  748. submCommon(user, type, workerFlag, pharmacistFlag) {
  749. //从药房菜单过来的
  750. if (type === "pharmacy") {
  751. //药房来
  752. // 药房才能登录
  753. if (!pharmacistFlag) {
  754. uni.showToast({
  755. icon: "none",
  756. title: "暂无权限登录!",
  757. });
  758. return;
  759. }
  760. } else if (type === "mypage") { //从我的菜单过来的
  761. if (!workerFlag) {
  762. uni.showToast({
  763. icon: "none",
  764. title: "暂无权限登录!",
  765. });
  766. return;
  767. }
  768. } else {
  769. //正常进入
  770. if (!workerFlag && !pharmacistFlag) {
  771. uni.showToast({
  772. icon: "none",
  773. title: "暂无权限登录!",
  774. });
  775. return;
  776. }
  777. }
  778. uni.setStorageSync("userData", user);
  779. this.getWorkScheme(false, user.user.currentHospital.id); //获取当前启动中的工作分配方案
  780. this.getHistorys(user.user.id); //获取上班历史记录
  781. this.offWork("wx");
  782. // uni.setStorageSync('type', '')
  783. if (type === "pharmacy") {
  784. // 建立websocket连接
  785. webHandle("pharmacy", "wx");
  786. } else if (type === "mypage") {
  787. // 建立websocket连接
  788. webHandle("mypage", "wx");
  789. } else {
  790. if (workerFlag) { //有支助人员的角色
  791. if (!user.user.online) {
  792. this.online = false;
  793. } else {
  794. this.online = true;
  795. // 建立websocket连接
  796. webHandle("receiptpage", "wx");
  797. }
  798. } else { //只有药房橘色
  799. webHandle("pharmacy", "wx");
  800. }
  801. }
  802. },
  803. //微信
  804. subm() {
  805. uni.showLoading({
  806. title: "登录中",
  807. mask: true,
  808. });
  809. var href = location.href; //获取链接地址
  810. console.log(href, "href");
  811. var href_wenhao = href.indexOf("?code="); //判断有没有问号,没有是-1
  812. var wenhaohoumian = location.href.split("?code="); //截取问号地址数组
  813. this.arr_last = wenhaohoumian[1]; //地址数组赋值
  814. if (href_wenhao == -1) {
  815. post("/auth/wxlogin").then((res) => {
  816. this.url = res.url;
  817. this.state = res.status;
  818. uni.setStorageSync("type", this.type); //存储来源type
  819. uni.hideLoading();
  820. if (this.state == "200") {
  821. //获取角色信息
  822. let role = res.user.user.role;
  823. let workerFlag = role.some((item) => item.rolecode === "worker");
  824. let pharmacistFlag = role.some((item) => item.rolecode === "pharmacist");
  825. this.submCommon(res.user, this.type, workerFlag, pharmacistFlag);
  826. } else if (this.state == "501") {
  827. uni.showModal({
  828. title: '提示',
  829. content: res.remarks,
  830. showCancel: false,
  831. confirmColor: '#49b856',
  832. success: function(res) {
  833. if (res.confirm) {
  834. console.log('用户点击确定');
  835. } else if (res.cancel) {
  836. console.log('用户点击取消');
  837. }
  838. }
  839. });
  840. } else if (this.state == "555") {
  841. // 如果需要绑定账号 并且 没有微信号
  842. if (this.type) {
  843. uni.redirectTo({
  844. url: `../bindUser/bindUser?type=${this.type}`
  845. })
  846. } else {
  847. uni.redirectTo({
  848. url: `../bindUser/bindUser`
  849. })
  850. }
  851. } else {
  852. console.log(this.url, "url");
  853. // https://open.weixin.qq.com/connect/oauth2/authorize?appid=ww2506abad3086cfab&redirect_uri=http://weixintest2.ngser.dashitech.com/app&response_type=code&scope=snsapi_base&agentid=1000013&state=STATE&connect_redirect=1#wechat_redirect
  854. location.assign(this.url);
  855. }
  856. });
  857. } else if (href_wenhao != -1) {
  858. this.arr_last = this.arr_last.split("&");
  859. this.arr_last = this.arr_last[0];
  860. post("/auth/wxlogina", {
  861. code: this.arr_last,
  862. }).then((res) => {
  863. this.state = res.status;
  864. uni.hideLoading();
  865. if (this.state == "200") {
  866. this.type = uni.getStorageSync("type"); //刷新页面后获取type
  867. console.log(this.type);
  868. //获取角色信息
  869. let role = res.user.user.role;
  870. let workerFlag = role.some((item) => item.rolecode === "worker");
  871. let pharmacistFlag = role.some((item) => item.rolecode === "pharmacist");
  872. this.submCommon(res.user, this.type, workerFlag, pharmacistFlag);
  873. } else if (this.state == "501") {
  874. uni.showModal({
  875. title: '提示',
  876. content: res.remarks,
  877. showCancel: false,
  878. confirmColor: '#49b856',
  879. success: function(res) {
  880. if (res.confirm) {
  881. console.log('用户点击确定');
  882. } else if (res.cancel) {
  883. console.log('用户点击取消');
  884. }
  885. }
  886. });
  887. } else if (this.state == "555") {
  888. this.type = uni.getStorageSync("type"); //刷新页面后获取type
  889. // 如果需要绑定账号 并且 没有微信号
  890. if (this.type) {
  891. uni.redirectTo({
  892. url: `../bindUser/bindUser?type=${this.type}`
  893. })
  894. } else {
  895. uni.redirectTo({
  896. url: `../bindUser/bindUser`
  897. })
  898. }
  899. } else {
  900. uni.showToast({
  901. icon: "none",
  902. title: "请求失败",
  903. });
  904. }
  905. });
  906. }
  907. },
  908. // 获取工作组合列表
  909. getCombinationById(idx, type) {
  910. console.log(this.type);
  911. if (this.zxzData.length == this.totalNum && !type) {
  912. uni.showToast({
  913. icon: "none",
  914. title: "没有更多数据了!",
  915. });
  916. this.freshing = true;
  917. return;
  918. }
  919. let data = {
  920. workAllocationQuickConfig: {
  921. workSchemeId: this.workSchemeId,
  922. },
  923. idx: idx,
  924. sum: 20,
  925. };
  926. uni.showLoading({
  927. title: "加载中",
  928. mask: true,
  929. });
  930. // 请求列表数据
  931. post("/configuration/fetchDataList/workAllocationQuickConfig", data).then(
  932. (res) => {
  933. uni.hideLoading();
  934. if (res.status == 200) {
  935. this.triggered = false;
  936. this.freshing = true;
  937. this.totalNum = res.totalNum;
  938. if (idx === 0) {
  939. res.list.forEach((item) => {
  940. let o = JSON.parse(JSON.stringify(item));
  941. item.str = JSON.stringify(o);
  942. item.checked = false;
  943. });
  944. this.zxzData = res.list;
  945. } else {
  946. res.list.forEach((item) => {
  947. let o = JSON.parse(JSON.stringify(item));
  948. item.str = JSON.stringify(o);
  949. item.checked = false;
  950. });
  951. this.zxzData.push(...res.list);
  952. }
  953. } else {
  954. uni.showToast({
  955. icon: "none",
  956. title: "请求失败!",
  957. });
  958. }
  959. }
  960. );
  961. },
  962. //刷新
  963. refresherrefresh() {
  964. if (this.triggered) {
  965. return;
  966. }
  967. console.log("下拉刷新");
  968. this.triggered = true;
  969. this.idx = 0;
  970. this.totalNum = -1;
  971. this.getCombinationById(0);
  972. },
  973. // 下拉刷新复位
  974. refresherrestore() {
  975. this.triggered = false;
  976. console.log("下拉刷新复位");
  977. },
  978. //下拉刷新中止
  979. refresherabort() {
  980. this.triggered = false;
  981. console.log("下拉刷新中止");
  982. },
  983. //分页,上拉加载
  984. scrolltolower() {
  985. if (this.freshing) {
  986. console.log("上拉加载");
  987. this.freshing = false;
  988. this.getCombinationById(++this.idx);
  989. }
  990. },
  991. // 滚动
  992. scroll(e) {
  993. if (e.detail.scrollTop < 20) {
  994. this.scroll_refresher_enabled = true;
  995. } else {
  996. this.scroll_refresher_enabled = false;
  997. }
  998. },
  999. // 获取启动中的工作分配方案
  1000. getWorkScheme(type, hosId) {
  1001. let postData = {
  1002. idx: 0,
  1003. workScheme: {
  1004. status: 1,
  1005. hosId
  1006. },
  1007. sum: 1,
  1008. };
  1009. post("/simple/data/fetchDataList/workScheme", postData).then((res) => {
  1010. if (res.status == 200) {
  1011. this.workSchemeId = res.list[0].id;
  1012. this.workSchemeType = res.list[0].workType;
  1013. if (type) {
  1014. if (this.workSchemeType == 2) {
  1015. this.getCombinationById(0, "no");
  1016. } else if (this.workSchemeType == 1) {
  1017. if (uni.getStorageSync("setDeptConfg")) {
  1018. uni.removeStorageSync("setDeptConfg"); //清空选择的科室配置,初始化
  1019. }
  1020. }
  1021. } else {
  1022. this.getCombinationById(0);
  1023. }
  1024. } else {
  1025. uni.showToast({
  1026. icon: "none",
  1027. title: "请求失败!",
  1028. });
  1029. }
  1030. });
  1031. },
  1032. // 阻止浏览器滑动
  1033. stop(e) {
  1034. e.preventDefault();
  1035. },
  1036. //获取查询参数
  1037. GetQueryString(name) {
  1038. var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
  1039. var r = location.search.substr(1).match(reg);
  1040. if (r != null) {
  1041. return unescape(r[2]);
  1042. }
  1043. return null;
  1044. }
  1045. },
  1046. onHide() {
  1047. this.zxzData = [];
  1048. this.historys = [];
  1049. // #ifdef H5
  1050. document.body.removeEventListener("touchmove", this.stop, {
  1051. passive: false,
  1052. });
  1053. // #endif
  1054. },
  1055. onShow() {
  1056. console.log('onShow');
  1057. // let flag = true;
  1058. if (uni.getStorageSync("userData")) {
  1059. this.online = uni.getStorageSync("userData").user.online;
  1060. }
  1061. if (!this.workSchemeType) {
  1062. return;
  1063. }
  1064. // if (this.workSchemeType == 2 && !this.online) {
  1065. // let userId = uni.getStorageSync('userData').user.id;
  1066. // this.getCombinationById(this.idx, 'no');
  1067. // this.getHistorys(userId); //获取上班历史记录
  1068. // }
  1069. let userId = uni.getStorageSync("userData").user.id;
  1070. this.getWorkScheme(true, uni.getStorageSync("userData").user.currentHospital.id);
  1071. this.getHistorys(userId); //获取上班历史记录
  1072. // #ifdef APP-PLUS
  1073. uni.closeSocket();
  1074. // #endif
  1075. // #ifdef H5
  1076. document.body.addEventListener("touchmove", this.stop, {
  1077. passive: false,
  1078. });
  1079. // #endif
  1080. },
  1081. onLoad(options) {
  1082. if (uni.getStorageSync("setDepts")) {
  1083. uni.removeStorageSync("setDepts"); //清空选择的科室,初始化
  1084. }
  1085. console.log(options);
  1086. console.log(typeof uni.getStorageSync("savePasswordTime"));
  1087. if (Date.now() - uni.getStorageSync("savePasswordTime") < 10 * 24 * 60 * 60 * 1000) {
  1088. //记住密码,10天内有效
  1089. this.ip = uni.getStorageSync("ip") || this.ip;
  1090. if (uni.getStorageSync("username")) {
  1091. this.username = this.encryptByDeAES(uni.getStorageSync("username"));
  1092. }
  1093. if (uni.getStorageSync("password")) {
  1094. this.password = this.encryptByDeAES(uni.getStorageSync("password"));
  1095. }
  1096. }
  1097. //#ifdef H5
  1098. this.isApp = false;
  1099. this.type = options.type || "";
  1100. console.log(this.type);
  1101. if (this.GetQueryString('login') === '1') {
  1102. //H5页面账号密码登录
  1103. this.isH5AndPwd = true;
  1104. this.ip = location.origin;
  1105. } else {
  1106. this.isH5AndPwd = false;
  1107. this.subm();
  1108. }
  1109. //#endif
  1110. // #ifdef APP-PLUS
  1111. this.isApp = true;
  1112. // 通知权限 start
  1113. // var main = plus.android.runtimeMainActivity();
  1114. // var pkName = main.getPackageName();
  1115. // var NotificationManagerCompat = plus.android.importClass(
  1116. // "android.support.v4.app.NotificationManagerCompat"
  1117. // );
  1118. // var packageNames = NotificationManagerCompat.from(main);
  1119. // console.log(JSON.stringify(packageNames));
  1120. // if (packageNames.areNotificationsEnabled()) {
  1121. // console.log("已开启通知权限");
  1122. // } else {
  1123. // uni.showModal({
  1124. // title: "提示",
  1125. // content: "请先打开APP通知权限",
  1126. // showCancel: true,
  1127. // success: function(res) {
  1128. // if (res.confirm) {
  1129. // var Intent = plus.android.importClass("android.content.Intent");
  1130. // var intent = new Intent(
  1131. // "android.settings.APP_NOTIFICATION_SETTINGS"
  1132. // ); //可设置表中所有Action字段
  1133. // intent.putExtra("android.provider.extra.APP_PACKAGE", pkName);
  1134. // main.startActivity(intent);
  1135. // }
  1136. // },
  1137. // });
  1138. // }
  1139. // 通知权限 end
  1140. // #endif
  1141. },
  1142. };
  1143. </script>
  1144. <style lang="less" scoped>
  1145. .HomeItem {
  1146. height: 100vh;
  1147. .login {
  1148. height: 420rpx;
  1149. padding: 0 32rpx;
  1150. padding-top: 164rpx;
  1151. position: relative;
  1152. z-index: 999;
  1153. .savePassword {
  1154. margin-top: 32rpx;
  1155. }
  1156. /deep/ uni-checkbox:not([disabled]) .uni-checkbox-input:hover {
  1157. border-color: #42b983 !important;
  1158. }
  1159. .login_input {
  1160. margin-top: 32rpx;
  1161. background-color: #ffffff;
  1162. height: 72rpx;
  1163. box-sizing: border-box;
  1164. padding: 16rpx;
  1165. }
  1166. .title {
  1167. font-size: 36rpx;
  1168. color: #42b983;
  1169. text-align: center;
  1170. }
  1171. .tips {
  1172. font-size: 28rpx;
  1173. color: red;
  1174. margin-top: 16rpx;
  1175. }
  1176. .page_item_btn {
  1177. height: 88rpx;
  1178. background-image: linear-gradient(to right, #72c172, #3bb197);
  1179. border-radius: 8rpx;
  1180. line-height: 88rpx;
  1181. color: #fff;
  1182. font-size: 36rpx;
  1183. font-weight: 700;
  1184. margin-top: 64rpx;
  1185. text-align: center;
  1186. }
  1187. }
  1188. //上班页面
  1189. .goWorkAll {
  1190. height: 100%;
  1191. display: flex;
  1192. flex-direction: column;
  1193. justify-content: space-between;
  1194. /deep/ .uni-radio-input-checked {
  1195. background-color: #42b983 !important;
  1196. border-color: #42b983 !important;
  1197. }
  1198. .goWorkSelect {
  1199. &.history {
  1200. height: 356rpx;
  1201. padding-bottom: 16rpx;
  1202. }
  1203. &.combination {
  1204. .goWorkSelect-head {
  1205. position: fixed;
  1206. top: 0;
  1207. left: 0;
  1208. width: 100%;
  1209. }
  1210. .goWorkSelect-list {
  1211. margin-top: 82rpx;
  1212. }
  1213. }
  1214. .goWorkSelect-head {
  1215. font-size: 36rpx;
  1216. padding: 16rpx 0;
  1217. color: #42b983;
  1218. border-bottom: 2rpx solid #42b983;
  1219. text-align: center;
  1220. }
  1221. .goWorkSelect-list {
  1222. &.scroll {
  1223. height: calc(100vh - 356rpx - 82rpx);
  1224. // height: calc(100vh - 82rpx);
  1225. }
  1226. .goWorkSelect-item {
  1227. height: 52rpx;
  1228. display: flex;
  1229. align-items: center;
  1230. border-bottom: 2rpx solid #e5e9ed;
  1231. padding: 16rpx;
  1232. &.relative {
  1233. position: relative;
  1234. .picker {
  1235. position: absolute;
  1236. width: 100%;
  1237. padding-left: 64rpx;
  1238. }
  1239. }
  1240. button {
  1241. font-size: 32rpx;
  1242. height: 52rpx;
  1243. line-height: 52rpx;
  1244. margin: 0;
  1245. margin-left: 16rpx;
  1246. color: rgb(7, 134, 60);
  1247. font-weight: 700;
  1248. }
  1249. }
  1250. }
  1251. }
  1252. }
  1253. .goWork {
  1254. margin: 0 auto 48rpx;
  1255. width: 240rpx;
  1256. height: 240rpx;
  1257. .goWork_btn_E {
  1258. width: 100%;
  1259. height: 100%;
  1260. background: #bee1a7;
  1261. border-radius: 30%;
  1262. .goWork_btn_W {
  1263. width: 75%;
  1264. height: 75%;
  1265. background-image: linear-gradient(to right, #72c172, #3bb197);
  1266. border-radius: 30%;
  1267. margin: 0 auto;
  1268. position: relative;
  1269. top: 12.5%;
  1270. line-height: 180rpx;
  1271. color: #fff;
  1272. font-size: 36rpx;
  1273. text-align: center;
  1274. }
  1275. }
  1276. }
  1277. .goWork_text {
  1278. width: 100%;
  1279. view {
  1280. text-align: center;
  1281. }
  1282. .goWork_text-p {
  1283. font-size: 36rpx;
  1284. margin-bottom: 48rpx;
  1285. }
  1286. }
  1287. .botImg {
  1288. height: 600rpx;
  1289. width: 100%;
  1290. position: fixed;
  1291. bottom: 0;
  1292. .img {
  1293. height: 100%;
  1294. background: url("../../static/img/BG.png") no-repeat center center;
  1295. background-size: 100% 100%;
  1296. }
  1297. }
  1298. }
  1299. </style>