index.js 14 KB

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