index.js 17 KB

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