index.js 17 KB

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