index.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  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 {api} = require('./api.js')
  7. const {post,pageMap,delCookie,setCookie,getCookie,focusMenuItem} = require('./utils.js');
  8. let userInfo={};
  9. $(function(){
  10. getMenu();
  11. getOwnDept();
  12. //菜单展开收起
  13. sureChangeWord()
  14. $(".main").css({
  15. height:$(window).height()-52+'px'
  16. })
  17. $(window).resize(function(){
  18. $(".main").css({
  19. height:$(window).height()-52+'px'
  20. })
  21. })
  22. $("body").on('focus',".modalAction input",function(){
  23. $(this).attr("type","password")
  24. })
  25. $(window).click(function(e){
  26. $(".userAction").css("display","none")
  27. })
  28. $("#changeWord").css("opacity",hasData('FUNC000002')?'1':'0.5').hover(function(){
  29. $(this).css("color","#777777")
  30. })
  31. // $("#contentIframe").attr("src",hasData('YH-KZT')?'console.html':hasData('YH-KZTKS')?'deptConsole.html':'console.html');
  32. });
  33. //判断有无某一权限
  34. function hasData(data,list){
  35. if(list&&list.length>0){
  36. if(list.indexOf(data)>-1){//有权限
  37. return true
  38. }
  39. return false;
  40. }
  41. let lis = JSON.parse(getCookie("codeLis"))||[]
  42. if(lis.indexOf(data)>-1){//有权限
  43. return true
  44. }
  45. return false;
  46. }
  47. function userActionHide(e){
  48. $(".userAction").css("display","none")
  49. }
  50. window.userActionHide = userActionHide
  51. function initMenu(data,userInfo){
  52. //菜单数据填充
  53. $("#menuTmpl").tmpl(data).appendTo(".menu ul");
  54. $("#miniMenuTmpl").tmpl(data).appendTo(".menu-mini ul");
  55. //用户数据填充
  56. $("#userName").text(userInfo.linkman);
  57. //初始菜单选中
  58. $(".menu .page").eq(0).addClass("active");
  59. if($(".menu .page").eq(0).is(".YH-KZT")||$(".menu .page").eq(0).is(".YH-KZTKS")){
  60. // if($(".menu .page").eq(0).is(".YH-KZT")){
  61. $(".container").addClass("console-cont");
  62. }
  63. //菜单收起展开
  64. $(".menu .list-1").on("click",function(){
  65. if($(this).is(".list-1-show")){
  66. $(this).removeClass("list-1-show")
  67. $(this).find("ul").slideToggle();
  68. return;
  69. }
  70. $(".menu .list-1-show ul").slideUp();
  71. $(".menu .list-1").removeClass("list-1-show");
  72. const ulShow = $(this).find("ul").css("display")
  73. if(ulShow == "none"){
  74. $(this).addClass("list-1-show")
  75. }
  76. $(this).find("ul").slideToggle();
  77. });
  78. //收起菜单
  79. $(".slide-hide").click(function(){
  80. $(".menu").animate({"width":"60px"},function(){
  81. $(this).hide();
  82. $(".menu-mini").show();
  83. });
  84. $(".main").animate({"margin-left":"60px"});
  85. });
  86. //展开菜单
  87. $(".slide-show").click(function(){
  88. $(".menu-mini").hide();
  89. $(".menu").show().animate({"width":"205px"},function(){
  90. });
  91. $(".main").animate({"margin-left":"205px"});
  92. });
  93. $(".menu .list-1 li").on("click",function(e){
  94. e.stopPropagation();
  95. });
  96. //右侧页面切换
  97. $(".page").on("click",function(){
  98. $(".menu .active,.menu-mini .active").removeClass('active');
  99. const code=$(this).attr("code");
  100. const mItems = $(".menu .page[code="+code+"],.menu-mini .page[code="+code+"]");
  101. mItems.addClass("active");
  102. mItems.parents(".list-1").addClass("active");
  103. let url = './'+pageMap[code];
  104. if(code === 'YH-BLZK-ZKPFGR'){
  105. url += `?doctorName=${userInfo.linkman}`
  106. }
  107. if(code === 'YH-KZT'||code === 'YH-KZTKS'){
  108. // if(code === 'YH-KZT'){
  109. $(".container").addClass("console-cont");
  110. }else{
  111. $(".container").removeClass("console-cont");
  112. }
  113. $("#contentIframe").attr("src",url);
  114. });
  115. }
  116. //获取科室列表
  117. function getOwnDept(){
  118. // if(hasData('FUNC000058')){
  119. setCookie("deptList",JSON.stringify([]))
  120. post(api.getDept,{}).then((res)=>{
  121. let data = res.data;
  122. if(data.code == 0){
  123. let result = data.data
  124. setCookie("deptList",JSON.stringify(result))
  125. }
  126. })
  127. // }
  128. }
  129. function getMenu(){
  130. post(api.getMenu).then(function(res){
  131. if(res.data.code==='0'){
  132. const data = res.data.data;
  133. initMenu(data.menuWrappers,data.userLoginDTO);
  134. userInfo = data.userLoginDTO
  135. setCookie("hospital",data.basHospitalInfoDTO.name)
  136. setCookie("hospitalid",data.basHospitalInfoDTO.id)
  137. getAllCode(data.menuWrappers);
  138. }
  139. })
  140. };
  141. function getAllCode(data){
  142. let lis = [],personCodeLis=[],deptCodeLis=[],trdObj={}
  143. for(let i = 0;i < data.length;i++){
  144. let tmpSon = data[i]
  145. lis.push(tmpSon.code)
  146. if(tmpSon.subMenuList.length > 0){//三层
  147. for(let j = 0;j<tmpSon.subMenuList.length;j++){//第二层循环
  148. let tmpGrandSon = tmpSon.subMenuList[j]
  149. let sonLis=[]
  150. lis.push(tmpGrandSon.code)
  151. for(let m = 0;m < tmpGrandSon.sysUserPermissionDTOList.length;m++){
  152. let tmpData = tmpGrandSon.sysUserPermissionDTOList[m]
  153. lis.push(tmpData.code)
  154. sonLis.push(tmpData.code)
  155. }
  156. trdObj[tmpGrandSon.code] = sonLis
  157. }
  158. }else{//两层
  159. for(let n = 0;n < tmpSon.sysUserPermissionDTOList.length;n++){
  160. let tmpData = tmpSon.sysUserPermissionDTOList[n]
  161. lis.push(tmpData.code)
  162. }
  163. }
  164. }
  165. // $("#contentIframe").attr("src",hasData('YH-KZT')?'console.html':hasData('YH-KZTKS')?'deptConsole.html':'console.html');
  166. if(hasData('YH-KZT',lis)){
  167. focusMenuItem("YH-KZT");
  168. }else if(hasData('YH-KZTKS',lis)){
  169. focusMenuItem("YH-KZTKS");
  170. }
  171. setCookie("codeLis",JSON.stringify(lis))
  172. setCookie("trdObj",JSON.stringify(trdObj))
  173. }
  174. function sureChangeWord(){
  175. $(document).on('click','.sureChange',function(){
  176. let oldword = $(".oldword").val().trim()
  177. let newword = $(".newword").val().trim()
  178. let sureword = $(".sureword").val().trim()
  179. if(!oldword){
  180. $(".modalAction .waring i").html('请输入原密码')
  181. return
  182. }else if(!newword){
  183. $(".modalAction .waring i").html('请输入新密码')
  184. return
  185. }else if(!sureword){
  186. $(".modalAction .waring i").html('请确认新密码')
  187. return
  188. }else if(newword != sureword){
  189. $(".modalAction .waring i").html('两次密码不一致')
  190. return
  191. }
  192. $(".modalAction .waring i").html('')
  193. changeWord(oldword,newword)
  194. })
  195. }
  196. function changeWord(oldword,newword){
  197. post(api.midifyPassword,{
  198. "modifyPassword": md5(newword),
  199. "password": md5(oldword)
  200. }).then(function(res){
  201. const data = res.data;
  202. if(data.code==='0'){
  203. window.location.href = './login.html'
  204. }else{
  205. $(".oldWaring").html(data.msg)
  206. return
  207. }
  208. });
  209. }
  210. //用户信息下拉事件
  211. $(".login").click(function(e){
  212. e.stopPropagation()
  213. $(".userAction").slideToggle();
  214. })
  215. //点击修改密码
  216. $("#changeWord").click(function(e){
  217. if(!hasData('FUNC000002')){
  218. return
  219. }
  220. e.stopPropagation()
  221. const status = $(".modalAction").css("display")
  222. $.alerModal({
  223. title:"修改密码",
  224. type:"modal",
  225. width:'450',
  226. time:'1000',
  227. sureText:'保存',
  228. message:`
  229. <div class="modalAction">
  230. <p><span>原密码:</span><input type="text" placeholder="请输入原密码" class="oldword" autocomplete="off"><i class="oldWaring"></i></p>
  231. <p><span>新密码:</span><input type="text" placeholder="请输入新密码" class="newword" autocomplete="off"></p>
  232. <p><span>确认新密码:</span><input type="text" placeholder="请输入新密码" class="sureword" autocomplete="off"></p>
  233. <p class="waring"><span></span><i></i></p>
  234. </div>
  235. `});
  236. $(".userAction").hide();
  237. })
  238. //推出登录
  239. $(".login-out").click(function(){
  240. delCookie('accessToken')
  241. })