index.js 15 KB

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