index.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610
  1. require("../css/index.less");
  2. const $ = require('jquery');
  3. require('jquery-templates');
  4. const md5 = require('js-md5');
  5. require("./modal.js")
  6. const okIcon = require("./../images/checkOk.png")
  7. const WarningIcon = require("./../images/icon-Warning.png")
  8. const warnIcon = require("./../images/warn.png")
  9. const openEye = require("./../images/open-eye.png")
  10. const closeEye = require("./../images/close-eye.png")
  11. const adLogo = require("../images/adlogo.png")
  12. const {
  13. api
  14. } = require('./api.js')
  15. const {
  16. post,
  17. pageMap,
  18. delCookie,
  19. setCookie,
  20. setLocal,
  21. getCookie,
  22. focusMenuItem,
  23. getUrlArgObject
  24. } = require('./utils.js');
  25. let userInfo = {};
  26. let isPlacefile = getCookie('isPlacefile') || 1
  27. let passwordComplexity = getCookie('passwordComplexity')
  28. const hideLogo = getUrlArgObject("hideLg");
  29. const otherLogo = getUrlArgObject("adLg");
  30. const is3His = getUrlArgObject('is3His')
  31. console.log('我是is3His', is3His);
  32. //token判断没有跳登录
  33. const token = getCookie('accessToken') || localStorage.getItem('accessToken');
  34. if (!token) {
  35. window.location.href = '../login.html';
  36. }
  37. const modalDom = `
  38. <p class="tips"><img src=${WarningIcon} /><span>为确保账号安全,请及时修改初始密码</span></p>
  39. <div class="modalAction">
  40. <p><span class="label"><i>*</i>原密码:</span><input type="password" readonly placeholder="请输入原密码" class="oldword" id="oldWord" autocomplete="off"><img class="eye" src=${closeEye} /><p class="oldWaring warning"><img src=${warnIcon} /><b>原密码错误</b></p></p>
  41. <p><span class="label"><i>*</i>新密码:</span><input type="password" disabled readonly placeholder="请输入新密码" class="newword" id="newWord" autocomplete="off"><img class="eye" src=${closeEye} /><p class="newword warning"><img src=${warnIcon} /><b>密码最多12位</b></p></p>
  42. <p><span class="label"><i>*</i>确认新密码:</span><input type="password" disabled readonly placeholder="请确认新密码" class="sureword" id="sureWord" autocomplete="off"><img class="eye" src=${closeEye} /><p class="sureword warning"><img src=${warnIcon} /><b>两次密码输入不一致</b></p></p>
  43. </div>
  44. `;
  45. const psdChecker = `<div class="psd-checkbox">
  46. <p class="label">密码至少包含:</p>
  47. <p class="big-letter"><i></i>1个大写字母</p>
  48. <p class="small-letter"><i></i>1个小写字母</p>
  49. <p class="special-letter"><i></i>1个特殊字符</p>
  50. <p class="one-number"><i></i>1个数字</p>
  51. <p class="eight-str"><i></i>8位字符</p>
  52. </div>`;
  53. $(function () {
  54. //无logo演示隐藏logo
  55. if (hideLogo) {
  56. $(".copy-right,.logo img").remove();
  57. $(".menu-mini .logo").text("");
  58. }
  59. const otherLogo = getUrlArgObject("adLg");
  60. if (otherLogo) {
  61. $(".logo img").attr("src", adLogo);
  62. $(".menu-mini .logo").text("艾登");
  63. $(".copy-right").remove();
  64. }
  65. hideDropdown();
  66. getOwnDept();
  67. setInterval(() => {
  68. getTimeDetail()
  69. }, 1000);
  70. sureChangeWord()
  71. const token = localStorage.getItem('accessToken');
  72. if (!token) {
  73. window.location.href = '../login.html';
  74. }
  75. if (passwordComplexity !== 'null' && token) {
  76. $.alerModal({
  77. quiteBtn: true,
  78. title: "修改密码",
  79. type: "modal",
  80. width: '470',
  81. time: '1000',
  82. sureText: '保存',
  83. message: modalDom
  84. });
  85. bindModalEvent();
  86. }
  87. //菜单展开收起
  88. $(".main").css({
  89. height: $(window).height() - 52 + 'px'
  90. })
  91. $(window).resize(function () {
  92. $(".main").css({
  93. height: $(window).height() - 52 + 'px'
  94. })
  95. })
  96. $(window).click(function (e) {
  97. $(".userAction").css("display", "none")
  98. })
  99. $("#changeWord").css("opacity", hasData('FUNC000002') ? '1' : '0.5').hover(function () {
  100. $(this).css("color", "#777777")
  101. })
  102. if (isPlacefile == 0) {
  103. $(this).find('.qiehuan i').html('切换病案质控')
  104. $('.subtitle').html('AI运行质控平台')
  105. getMenu()
  106. } else if (isPlacefile == 1) {
  107. $(this).find('.qiehuan i').html('切换运行质控')
  108. $('.subtitle').html('AI病案质控平台')
  109. getMenu()
  110. }
  111. $(".header .title .qiehuan").click(function () {
  112. let txt = $(this).find('i').html()
  113. if (txt == '切换运行质控') {
  114. $(this).find('i').html('切换病案质控')
  115. $('.subtitle').html('AI运行质控平台')
  116. setCookie("isPlacefile", 0)
  117. } else {
  118. $(this).find('i').html('切换运行质控')
  119. $('.subtitle').html('AI病案质控平台')
  120. setCookie("isPlacefile", 1)
  121. }
  122. $('#contentIframe').attr('src', $('#contentIframe').attr('src'));
  123. getMenu();
  124. })
  125. $(".header .title .qiehuan").mouseenter(function () {
  126. $(this).parent().find('img').attr('src', require('../images/qiehuan1.png'))
  127. })
  128. $(".header .title .qiehuan").mouseleave(function () {
  129. $(this).parent().find('img').attr('src', require('../images/qiehuan2.png'))
  130. })
  131. });
  132. //切换密码明文
  133. function switchPwd(el) {
  134. if (!el.is(".open")) {
  135. el.attr("src", openEye).addClass("open");
  136. el.prev().attr("type", 'text');
  137. } else {
  138. el.attr("src", closeEye).removeClass("open");
  139. el.prev().attr("type", 'password');
  140. }
  141. }
  142. function toast(msg) {
  143. const toast = `<div class="toast"><img src="${okIcon}" alt=""><p>${msg}</p></div>`;
  144. $(toast).appendTo($(".alertModal"));
  145. }
  146. function hideDropdown() { //关闭下拉
  147. $(document).off("click").on("click", function (e) {
  148. $("#contentIframe").contents().find(".toggleSlide ul").hide();
  149. })
  150. }
  151. //绑定输入框事件
  152. function bindModalEvent() {
  153. $(".modalAction input").off("click").on("click", function () {
  154. $(this).removeAttr("readonly").focus()
  155. })
  156. $(".modalAction input").off("blur").on("blur", function () {
  157. $(this).attr("readonly", true)
  158. })
  159. $(".modalAction .eye").off("click").on("click", function () {
  160. switchPwd($(this))
  161. })
  162. $("#oldWord").off("input").on("input", function () {
  163. switchToPsd($(this));
  164. const text = $(this).val();
  165. $(".oldWaring.warning,.newword.warning").hide();
  166. verifyPsdPart();
  167. if (text.trim()) {
  168. $("#newWord").attr("disabled", false);
  169. }
  170. if (!$(".modalAction .warning:visible").length) {
  171. $(".alertModal .sureChange").addClass("active");
  172. }
  173. });
  174. let gl_psdOk = false;
  175. $("#newWord").off("input").on("input", function () {
  176. switchToPsd($(this));
  177. let text = $(this).val();
  178. const checker = $(".alertModal .psd-checkbox");
  179. if (/[\u4e00-\u9fa5]/g.test(text)) {
  180. $(this).val(text.replace(/[\u4e00-\u9fa5]/g, ''));
  181. }
  182. text = $(this).val();
  183. $(".newword.warning,.sureword.warning").hide();
  184. if (text.trim()) { //显示密码验证标签
  185. if (checker.length) {
  186. checker.show()
  187. } else {
  188. $(psdChecker).appendTo($(".alertModal"));
  189. }
  190. let psdsOk = verifyPsdPart();
  191. gl_psdOk = verifyPsd(text);
  192. if (gl_psdOk) {
  193. $("#sureWord").attr("disabled", false);
  194. }
  195. if (psdsOk && gl_psdOk && $("#sureWord").val().trim()) {
  196. $(".modalAction .warning").hide();
  197. //保存按钮启用
  198. $(".alertModal .sureChange").addClass("active");
  199. } else {
  200. $(".alertModal .sureChange").removeClass("active");
  201. }
  202. } else {
  203. checker.hide()
  204. }
  205. })
  206. $("#sureWord").off("input").on("input", function () {
  207. switchToPsd($(this));
  208. const text = $(this).val();
  209. $(".sureword.warning").hide();
  210. if (/[\u4e00-\u9fa5]/g.test(text)) {
  211. $(this).val(text.replace(/[\u4e00-\u9fa5]/g, ''));
  212. }
  213. if (text.trim()) {
  214. let psdsOk = verifyPsdPart();
  215. //const psdOk = verifyPsd(text);
  216. if (gl_psdOk && psdsOk) {
  217. $(".modalAction .warning").hide();
  218. //保存按钮启用
  219. $(".alertModal .sureChange").addClass("active");
  220. } else {
  221. $(".alertModal .sureChange").removeClass("active");
  222. }
  223. }
  224. })
  225. }
  226. function switchToPsd(dom) {
  227. if (!dom.val()) {
  228. dom.attr("readonly", true)
  229. setTimeout(function () {
  230. dom.removeAttr("readonly").focus()
  231. })
  232. }
  233. }
  234. //验证新密码规则
  235. function verifyPsd(text) {
  236. let pass = true;
  237. if (/(?=.*?[A-Z])/.test(text)) { //至少一个大写字母
  238. $(".big-letter").addClass("active");
  239. } else {
  240. $(".big-letter").removeClass("active");
  241. pass = false;
  242. }
  243. if (/(?=.*?[a-z])/.test(text)) { //至少一个大写字母
  244. $(".small-letter").addClass("active");
  245. } else {
  246. $(".small-letter").removeClass("active");
  247. pass = false;
  248. }
  249. if (/(?=.*?[0-9])/.test(text)) { //至少一个数字
  250. $(".one-number").addClass("active");
  251. } else {
  252. $(".one-number").removeClass("active");
  253. pass = false;
  254. }
  255. if (/(?=.*?[#?!@$,,%^&*-])/.test(text)) { //至少一个特殊字符
  256. $(".special-letter").addClass("active");
  257. } else {
  258. $(".special-letter").removeClass("active");
  259. pass = false;
  260. }
  261. if (text.length > 7) { //至少8个字符
  262. $(".eight-str").addClass("active");
  263. } else {
  264. $(".eight-str").removeClass("active");
  265. pass = false;
  266. }
  267. if (text.length > 12) {
  268. $(".newword.warning b").text("密码最多12位");
  269. $(".newword.warning").show();
  270. pass = false;
  271. } else {
  272. $(".newword.warning").hide();
  273. }
  274. //const regex = new RegExp('^(?=.*[a-z])(?=.*[A-Z])(?=.*\\d)(?=.*[$@~^·$、,,\.!#%*?&])[A-Za-z\\d$@#$\.~、,,·!%*?&]{8,12}');
  275. /*if(regex.test(text)){
  276. return true
  277. }*/
  278. return pass;
  279. }
  280. function verifyPsdPart() { //验证各密码关系规则
  281. const oldP = $("#oldWord").val();
  282. const newP = $("#newWord").val();
  283. const confirmP = $("#sureWord").val();
  284. let pass = true;
  285. if (oldP && newP && (oldP.trim() === newP.trim())) {
  286. $(".newword.warning b").text("原密码和新密码不能相同");
  287. $(".newword.warning").show();
  288. pass = false;
  289. }
  290. if (newP.length > 12) {
  291. $(".newword.warning b").text("密码最多12位");
  292. $(".newword.warning").show();
  293. pass = false;
  294. }
  295. if (confirmP.trim() && (newP.trim() !== confirmP.trim())) {
  296. $(".sureword.warning b").text("两次密码输入不一致");
  297. $(".sureword.warning").show();
  298. pass = false;
  299. }
  300. return pass;
  301. }
  302. //判断有无某一权限
  303. function hasData(data, list) {
  304. if (list && list.length > 0) {
  305. if (list.indexOf(data) > -1) { //有权限
  306. return true
  307. }
  308. return false;
  309. }
  310. let lis = JSON.parse(getCookie("codeLis")) || []
  311. if (lis.indexOf(data) > -1) { //有权限
  312. return true
  313. }
  314. return false;
  315. }
  316. function userActionHide(e) {
  317. $(".userAction").css("display", "none")
  318. }
  319. window.userActionHide = userActionHide
  320. function initMenu(data, userInfo) {
  321. console.log('===========', data, userInfo)
  322. //菜单数据填充
  323. $(".menu ul").html("");
  324. $(".menu-mini ul").html("");
  325. $("#menuTmpl").tmpl(data).appendTo(".menu ul");
  326. $("#miniMenuTmpl").tmpl(data).appendTo(".menu-mini ul");
  327. //用户数据填充
  328. $("#userName").text(userInfo.linkman);
  329. //菜单收起展开
  330. $(".menu .list-1").on("click", function () {
  331. if ($(this).is(".list-1-show")) {
  332. $(this).removeClass("list-1-show")
  333. $(this).find("ul").slideToggle();
  334. return;
  335. }
  336. $(".menu .list-1-show ul").slideUp();
  337. $(".menu .list-1").removeClass("list-1-show");
  338. const ulShow = $(this).find("ul").css("display")
  339. if (ulShow == "none") {
  340. $(this).addClass("list-1-show")
  341. }
  342. $(this).find("ul").slideToggle();
  343. // setTimeout(function(){
  344. // initScroll("menuList","Y",2)
  345. // },300)
  346. });
  347. //收起菜单
  348. $(".slide-hide").off("click").click(function () {
  349. $(".menu,.copy-right").animate({
  350. "width": "60px"
  351. }, function () {
  352. $(this).hide();
  353. $(".menu-mini").show();
  354. });
  355. $(".main").animate({
  356. "margin-left": "60px"
  357. });
  358. });
  359. //展开菜单
  360. $(".slide-show").off("click").click(function () {
  361. $(".menu-mini").hide();
  362. $(".menu,.copy-right").show().animate({
  363. "width": "205px"
  364. }, function () {});
  365. $(".main").animate({
  366. "margin-left": "205px"
  367. });
  368. });
  369. $(".menu .list-1 li").on("click", function (e) {
  370. e.stopPropagation();
  371. });
  372. //右侧页面切换
  373. $(".page").on("click", function () {
  374. $(".menu .active,.menu-mini .active").removeClass('active');
  375. console.log(222)
  376. const code = $(this).attr("code");
  377. // const code2=$(this).attr("code2");
  378. console.log('我是this', this)
  379. if (code === 'YH-KZT' || code === 'YH-KZTKS') {
  380. // if(code === 'YH-KZT'){
  381. $(".container").addClass("console-cont");
  382. $('.qiehuan').css("display", "inline-block")
  383. } else {
  384. $('.qiehuan').css("display", "none")
  385. $(".container").removeClass("console-cont");
  386. }
  387. const mItems = $(".menu .page[code=" + code + "],.menu-mini .page[code=" + code + "]");
  388. mItems.addClass("active");
  389. console.log(213)
  390. mItems.parents(".list-1").addClass("active");
  391. let url = './' + pageMap[code];
  392. if (code === 'YH-BLZK-ZKPFGR') {
  393. url += `?doctorName=${userInfo.linkman}`
  394. }
  395. $("#contentIframe").attr("src", url);
  396. setTimeout(() => {
  397. bindMenu()
  398. }, 500);
  399. });
  400. // initScroll("menuList","Y",2)
  401. }
  402. //获取科室列表
  403. function getOwnDept() {
  404. // if(hasData('FUNC000058')){
  405. setCookie("deptList", JSON.stringify([]))
  406. post(api.getDept, {}).then((res) => {
  407. let data = res.data;
  408. if (data.code == 0) {
  409. let result = data.data
  410. setCookie("deptList", JSON.stringify(result))
  411. }
  412. })
  413. // }
  414. }
  415. function getMenu() {
  416. // console.log(api.getMenu)
  417. isPlacefile = getCookie('isPlacefile') || 1
  418. post(api.getMenu).then(function (res) {
  419. console.log('我是getmenu函数的res', res)
  420. if (res.data.code === '0') {
  421. const data = res.data.data;
  422. for (let i = 0; i < data.menuWrappers.length; i++) {
  423. if (isPlacefile === '0' && data.menuWrappers[i].code === 'YH-ZKHC') {
  424. data.menuWrappers.splice(i, 1);
  425. continue;
  426. }
  427. for (let j = 0; j < data.menuWrappers[i].subMenuList.length; j++) {
  428. if (isPlacefile === '0' && is3His && (data.menuWrappers[i].subMenuList[j].code === 'YH-ZKK-BASYHGLYSZB_XQ' || data.menuWrappers[i].subMenuList[j].code === 'YH-KSZR-BASYHGLYSZB_XQ')) {
  429. data.menuWrappers[i].subMenuList.splice(j, 1);
  430. continue;
  431. }
  432. }
  433. data.menuWrappers[i].isPlacefile = isPlacefile
  434. }
  435. initMenu(data.menuWrappers, data.userLoginDTO);
  436. userInfo = data.userLoginDTO
  437. setCookie("hospital", data.basHospitalInfoDTO.name)
  438. setCookie("hospitalid", data.basHospitalInfoDTO.id)
  439. getAllCode(data.menuWrappers);
  440. }
  441. })
  442. };
  443. function getAllCode(data) {
  444. let lis = [],
  445. personCodeLis = [],
  446. deptCodeLis = [],
  447. trdObj = {}
  448. for (let i = 0; i < data.length; i++) {
  449. let tmpSon = data[i]
  450. lis.push(tmpSon.code)
  451. if (tmpSon.subMenuList.length > 0) { //三层
  452. for (let j = 0; j < tmpSon.subMenuList.length; j++) { //第二层循环
  453. let tmpGrandSon = tmpSon.subMenuList[j]
  454. let sonLis = []
  455. lis.push(tmpGrandSon.code)
  456. for (let m = 0; m < tmpGrandSon.sysUserPermissionDTOList.length; m++) {
  457. let tmpData = tmpGrandSon.sysUserPermissionDTOList[m]
  458. lis.push(tmpData.code)
  459. sonLis.push(tmpData.code)
  460. }
  461. trdObj[tmpGrandSon.code] = sonLis
  462. }
  463. } else { //两层
  464. for (let n = 0; n < tmpSon.sysUserPermissionDTOList.length; n++) {
  465. let tmpData = tmpSon.sysUserPermissionDTOList[n]
  466. lis.push(tmpData.code)
  467. }
  468. }
  469. }
  470. //初始菜单选中
  471. if (hasData('YH-KZT', lis)) {
  472. focusMenuItem("YH-KZT");
  473. } else if (hasData('YH-KZTKS', lis)) {
  474. focusMenuItem("YH-KZTKS");
  475. }
  476. console.log('我是初始选中菜单', trdObj)
  477. setCookie("codeLis", JSON.stringify(lis))
  478. setLocal("trdObj", JSON.stringify(trdObj))
  479. }
  480. function sureChangeWord() {
  481. $(document).on('click', '.sureChange.active', function () {
  482. let oldword = $(".oldword").val().trim()
  483. let newword = $(".newword").val().trim()
  484. $(".modalAction .waring i").html('')
  485. changeWord(oldword, newword)
  486. })
  487. }
  488. function changeWord(oldword, newword) {
  489. post(api.midifyPassword, {
  490. "modifyPassword": newword,
  491. "password": oldword
  492. }).then(function (res) {
  493. const data = res.data;
  494. if (data.code === '0') {
  495. setCookie('behosDateStart', '')
  496. setCookie('behosDateEnd', '')
  497. toast("密码修改成功,请重新登录");
  498. setTimeout(() => {
  499. window.location.href = './login.html'
  500. }, 1000);
  501. } else {
  502. $(".oldWaring b").text(data.msg);
  503. $(".oldWaring").show();
  504. $(".alertModal .sureChange").removeClass("active");
  505. return
  506. }
  507. });
  508. }
  509. //用户信息下拉事件
  510. $(".login").click(function (e) {
  511. e.stopPropagation()
  512. $(".userAction").slideToggle();
  513. })
  514. //点击修改密码
  515. $("#changeWord").click(function (e) {
  516. if (!hasData('FUNC000002')) {
  517. return
  518. }
  519. e.stopPropagation()
  520. const status = $(".modalAction").css("display")
  521. $.alerModal({
  522. quiteBtn: true,
  523. title: "修改密码",
  524. type: "modal",
  525. width: '470',
  526. time: '1000',
  527. sureText: '保存',
  528. message: modalDom
  529. });
  530. if (passwordComplexity === 'null') {
  531. $(".alertModal .tips").hide();
  532. }
  533. bindModalEvent();
  534. $(".userAction").hide();
  535. })
  536. //推出登录
  537. $(".login-out").click(function () {
  538. delCookie('accessToken')
  539. setCookie('behosDateStart', '')
  540. localStorage.removeItem('accessToken')
  541. setCookie('behosDateEnd', '')
  542. const otherLogoPm = otherLogo ? '?adLg=1' : '';
  543. const hideLogoPm = hideLogo ? '?hideLg=1' : '';
  544. window.location.href = 'login.html' + otherLogoPm + hideLogoPm;
  545. })
  546. //时间获取
  547. function getTimeDetail() {
  548. const d = new Date();
  549. const days = ["星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六"];
  550. let sec = d.getSeconds()
  551. let min = d.getMinutes()
  552. let hour = d.getHours()
  553. let str = `${d.getFullYear()}年${d.getMonth()+1}月${d.getDate()}日 / ${days[d.getDay()]} / ${hour>9?hour:'0'+hour}:${min>9?min:'0'+min}:${sec>9?sec:'0'+sec}`
  554. $(".dateDetail").html(str)
  555. }
  556. // 左侧菜单滚动到页面顶部
  557. function bindMenu() {
  558. $("#contentIframe").contents().find('.partTitle a').eq(0).click(function () {
  559. $(".menuList").scrollTop(0)
  560. })
  561. }
  562. window.addEventListener('message', e => {
  563. console.trace("token已清除index", e)
  564. let data = e.data
  565. if (typeof data == 'string') {
  566. data = JSON.parse(data)
  567. }
  568. if (data.iframemessage) {
  569. localStorage.removeItem('accessToken')
  570. $.alerModal({
  571. gobackBtn: true,
  572. // quiteBtn: true,
  573. title: "提示",
  574. type: "modal",
  575. width: '470',
  576. time: 1000,
  577. cancalText: '我知道了',
  578. sureBtn: false,
  579. message: data.data || '登录过期',
  580. callback: function () {
  581. //alert('跳回登录3')
  582. // localStorage.removeItem('accessToken')
  583. window.location.href = 'login.html'
  584. }
  585. });
  586. }
  587. });