index.js 16 KB

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