index.js 20 KB

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