homePage.vue 43 KB

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