appealCheck.js 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850
  1. const $ = require('jquery');
  2. require("../css/appealCheck.less");
  3. require('./modal.js');
  4. const { api } = require('./api.js')
  5. const { post, getCookie, getLocal, getUrlArgObjectNew, emptyBox, downloadExportedData, expJson, getLogoParam, listenScroll, getPickerDate, exportTimeLimit } = require('./utils.js')
  6. require('./../resource/jquery-ui/jquery-ui.min.js');
  7. require('./../resource/jquery-ui/jquery-ui.min.css');
  8. const iconCheck = require("./../images/icon_check.png")
  9. const iconUnCheck = require("./../images/icon_unchecked.png")
  10. const iconCalenBlue = require("./../images/icon_calen_blue.png")
  11. const iconCalenGrey = require("./../images/icon_calen_grey.png")
  12. const iconDown = require("./../images/arrow_down.png")
  13. const iconUp = require("./../images/arrow_up.png")
  14. const loadingImg = require("./../images/loading.gif")
  15. const arrowLeft = require("./../images/arrow_left.png")
  16. const arrowRight = require("./../images/arrow_right.png")
  17. const goUpG = require("./../images/arrow_up_grey.png")
  18. const goUpB = require("./../images/arrow_up_blue.png")
  19. const goDownG = require("./../images/arrow_down_grey.png")
  20. const goDownB = require("./../images/arrow_down_blue.png")
  21. listenScroll()
  22. let pageSet = [], pageSetCopy = [], showNum = 0, scrollTop = 0;
  23. $(".selectModular").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  24. $(".selectType").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  25. $(".selectDept").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  26. $(".fpSelectCheck").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  27. $(".qcSelectCheck").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  28. let srcUrl = $("#contentIframe", parent.document).attr("src")
  29. let statisticsType = getUrlArgObjectNew("dateType", srcUrl) || getUrlArgObjectNew("shijian", srcUrl) || ""
  30. let startDateParam = getUrlArgObjectNew("startDateParam", srcUrl) || ""
  31. let endDateParam = getUrlArgObjectNew("endDateParam", srcUrl) || ""
  32. let tabList = [], name = "", behospitalCode = "", deptName = "", deptNameTemp = "", behosDateStart = "", level = "", behosDateEnd = "", nameTemp = "", casesName = "", operationType = "",
  33. behospitalCodeTemp = "", levelTemp = "", deptId = "", deptIdTemp = "", doctorName = "", doctorNameTemp = "", doctorNum = "", doctorNumTemp = "",
  34. fpCheckStatus = "", fpCheckStatusTemp = "", fpCheckName = "", fpCheckNameTemp = "", qcCheckName = "", qcCheckNameTemp = "", qcCheckMain = "", qcCheckStatus = "", state = "",
  35. data_desc = ["leave_hospital_date"], data_asc = [];
  36. let isPlacefile = getCookie('isPlacefile') || 1
  37. $('.datapickerBox').append(`<img class="iconCalen" src=${iconCalenGrey} />`)
  38. $('.iconCalen').on("mouseenter", function (e) {
  39. $(this).attr("src", iconCalenBlue)
  40. })
  41. $('.iconCalen').on("mouseleave", function (e) {
  42. $(this).attr("src", iconCalenGrey)
  43. })
  44. $('.iconCalen').on("click", function (e) {
  45. $(this).parent().find("input").focus()
  46. })
  47. $(".menu .page", parent.document).removeClass("active")
  48. $(parent.document).find(".menu .page[code=YH-SSXX-SSSH]").addClass("active")
  49. function getTabData(activePage) {
  50. const behosDateStart = getPickerDate($("#datepicker"), 1)
  51. const behosDateEnd = getPickerDate($("#datepicker2"), 2)
  52. const param = {
  53. current: activePage,
  54. deptId: deptId.trim(),
  55. deptName: deptName == "全部" ? "" : deptName || '',
  56. casesName: casesName,
  57. operationType: operationType,
  58. state: state,
  59. size: 15,
  60. name: nameTemp,
  61. complaintDateEnd: behosDateEnd.replaceAll("/", "-"),
  62. complaintDateStart: behosDateStart.replaceAll("/", "-"),
  63. }
  64. $('.pagination').html("")
  65. $('.tbody').html(emptyBox('努力加载中...', '',))
  66. return post(api.getAppealReview, param).then(res => {
  67. if (res.data.code == '0') {
  68. tabList = res.data.data.data.records
  69. const totalPage = res.data.data.data.pages
  70. const totalNum = res.data.data.data.total
  71. renderTab(tabList)
  72. renderPagination(totalPage, Number(activePage), totalNum)
  73. if (totalPage > 1) {
  74. renderPagination(totalPage, Number(activePage), totalNum)
  75. } else {
  76. $('.pagination').html("")
  77. }
  78. } else {
  79. const token = localStorage.getItem('accessToken');
  80. if (!token && window.location.href.indexOf('login') == -1) {
  81. //alert('无token判断,跳回登录')
  82. } else {
  83. $.alerModal({ "message": res.data.msg, type: "tip", time: '1000', isFather: true, fatherWrapper: $("#mainBox", parent.document) });
  84. }
  85. }
  86. }).catch((e) => {
  87. })
  88. }
  89. $(".filter").on("click", function (e) {
  90. behosDateStart = $("#datepicker").val()
  91. behosDateEnd = $("#datepicker2").val()
  92. const behosDateStartTime = new Date(behosDateStart).getTime()
  93. const behosDateEndTime = new Date(behosDateEnd).getTime()
  94. if (behosDateStartTime > behosDateEndTime) {
  95. $.alerModal({ "message": '出院日期开始时间不能大于结束时间~', type: "tip", time: '1000', isFather: true, fatherWrapper: $("#mainBox", parent.document) });
  96. return
  97. }
  98. if (behosDateStart) {
  99. behosDateStart = behosDateStart.replace(/\//g, '-') + ' 00:00:00'
  100. }
  101. if (behosDateEnd) {
  102. behosDateEnd = behosDateEnd.replace(/\//g, '-') + ' 23:59:59'
  103. }
  104. name = nameTemp
  105. behospitalCode = behospitalCodeTemp
  106. level = levelTemp === "全部" ? "" : levelTemp
  107. deptId = deptIdTemp
  108. deptName = deptNameTemp
  109. doctorName = doctorNameTemp
  110. fpCheckName = fpCheckNameTemp
  111. qcCheckName = qcCheckNameTemp
  112. doctorNum = doctorNumTemp
  113. fpCheckStatus = fpCheckStatusTemp
  114. qcCheckStatus = state
  115. getTabData(1)
  116. })
  117. $(".abnormalClear").on("click", function (e) {
  118. tabList = [];
  119. name = "";
  120. behospitalCode = "";
  121. level = "";
  122. scoreSum = 0;
  123. nameTemp = "";
  124. behospitalCodeTemp = "";
  125. levelTemp = "";
  126. deptId = "";
  127. deptIdTemp = "";
  128. deptName = deptNameTemp = "";
  129. doctorName = "";
  130. fpCheckName = "";
  131. qcCheckName = "";
  132. qcCheckMain = "";
  133. doctorNum = "";
  134. doctorNameTemp = "";
  135. doctorNumTemp = "";
  136. fpCheckNameTemp = "";
  137. qcCheckNameTemp = "";
  138. qcCheckMainTemp = "";
  139. fpCheckStatus = "";
  140. fpCheckStatusTemp = "";
  141. qcCheckStatus = "";
  142. state = ""
  143. operationType = ""
  144. data_desc = ["leave_hospital_date"]
  145. if (isPlacefile != 1) {
  146. data_desc = ["behospital_date"]
  147. }
  148. data_asc = [];
  149. $('.patientNameInp').val('')
  150. // $('#datepicker').val('')
  151. // $('#datepicker2').val('')
  152. //默认日期为近一周
  153. $("#datepicker").datepicker({
  154. changeMonth: true,
  155. changeYear: true,
  156. dateFormat: "yy/mm/dd",
  157. }).datepicker("setDate", "-6d");
  158. $("#datepicker2").datepicker({
  159. changeMonth: true,
  160. changeYear: true,
  161. dateFormat: "yy/mm/dd"
  162. }).datepicker("setDate", new Date());
  163. $("#datepickerFp1").datepicker({
  164. changeMonth: true,
  165. changeYear: true,
  166. dateFormat: "yy/mm/dd",
  167. }).datepicker("setDate", "");
  168. $("#datepickerFp2").datepicker({
  169. changeMonth: true,
  170. changeYear: true,
  171. dateFormat: "yy/mm/dd"
  172. }).datepicker("setDate", "");
  173. $("#datepickerQc1").datepicker({
  174. changeMonth: true,
  175. changeYear: true,
  176. dateFormat: "yy/mm/dd",
  177. }).datepicker("setDate", "");
  178. $("#datepickerQc2").datepicker({
  179. changeMonth: true,
  180. changeYear: true,
  181. dateFormat: "yy/mm/dd"
  182. }).datepicker("setDate", "");
  183. $('.selectDept ').html('全部')
  184. $(".deptList").css("display", "none")
  185. $(".selectDept").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  186. // $('.selectDept ').addClass('unSelect')
  187. $('.selectModular').html('全部')
  188. $(".modularList").css("display", "none")
  189. $(".selectModular").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  190. // $('.selectModular ').addClass('unSelect')
  191. $('.fpSelectCheck').html('全部')
  192. $(".fpCheckList").css("display", "none")
  193. $(".fpSelectCheck").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  194. $('.qcSelectCheck').html('全部')
  195. $(".qcCheckList").css("display", "none")
  196. $(".qcSelectCheck").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  197. $("th[code]").removeClass("asc desc")
  198. if (isPlacefile == 1) {
  199. $(".leaveHospitalDate").addClass(" desc")
  200. } else {
  201. $(".behospitalDate").addClass(" desc")
  202. }
  203. behosDateStart = $("#datepicker").val()
  204. behosDateEnd = $("#datepicker2").val()
  205. if (behosDateStart) {
  206. behosDateStart = behosDateStart.replace(/\//g, '-') + ' 00:00:00'
  207. }
  208. if (behosDateEnd) {
  209. behosDateEnd = behosDateEnd.replace(/\//g, '-') + ' 23:59:59'
  210. }
  211. getTabData(1)
  212. })
  213. function renderTab(data) {
  214. let str = ``
  215. if (data.length === 0) {
  216. $('.tbody').html(emptyBox(null, showNum + 12))
  217. return;
  218. }
  219. for (let i = 0; i < data.length; i++) {
  220. const item = data[i]
  221. str += `
  222. <tr data-index=${i} data-doc="${item.doctorName || ""}" >
  223. <td >${item.claimantName || "-"}</td>
  224. <td >${item.behDeptName || "-"}</td>
  225. <td >${item.claimantGmtCreate}</td>
  226. <td >${item.behospitalCode}</td>
  227. <td >${item.name || "-"}</td>
  228. <td >${item.casesName || "-"}</td>
  229. <td >${item.defectContent || "-"}</td>
  230. <td >${item.checkName || "-"}</td>
  231. <td >${item.checkGmtCreate || "-"}</td>
  232. <td >${item.appealOperationType == 0 ? '删改条目' : item.appealOperationType == 1 ? '新增已有条目' : item.appealOperationType == 2 ? '新增缺失条目' : '恢复条目'}</td>
  233. <td >${item.exampleStatus == 0 ? '<span class="review"><i></i>待审核</span>' : item.exampleStatus == 1 ? '<span class="rejected"><i></i>已驳回</span>' : '<span class="approved"><i></i>审核通过</span>'}</td>
  234. <td data-id="${item.id || ""}" data-hos="${item.hospitalId || ""}" data-behospitalCode="${item.behospitalCode || ""}" data-casesEntryId="${item.casesEntryId || ""}" data-qcresultDetailId="${item.qcresultDetailId || ""}" data-appealOperationType="${item.appealOperationType || ""}">
  235. ${item.exampleStatus == 0 ? `<span class="appealBtn goExamine">审核</span><span class="appealBtn goHomeDetail1">查看</span>` : ''}
  236. ${item.exampleStatus == 1 || item.exampleStatus == 2 ? `<span class="appealBtn goHomeDetail1">查看</span>` : ''}
  237. </td>
  238. </tr>
  239. `
  240. }
  241. $('.tbody').html(str)
  242. $(".goExamine").click(function () {
  243. let id = $(this).parent().attr("data-id")
  244. let hospitalId = $(this).parent().attr("data-hos")
  245. let behospitalCode = $(this).parent().attr("data-behospitalCode")
  246. let casesEntryId = $(this).parent().attr("data-casesEntryId")
  247. let qcresultDetailId = $(this).parent().attr("data-qcresultDetailId")
  248. let appealOperationType = $(this).parent().attr("data-appealOperationType")
  249. $(parent.document).find("#contentIframe").attr("src", "appealExamine.html?id=" + id + "&hospitalId=" + hospitalId + "&behospitalCode=" + behospitalCode + "&casesEntryId=" + casesEntryId + "&qcresultDetailId=" + qcresultDetailId + "&appealOperationType=" + appealOperationType + "&form=" + 1)
  250. })
  251. $(".goHomeDetail1").click(function () {
  252. let id = $(this).parent().attr("data-id")
  253. let hospitalId = $(this).parent().attr("data-hos")
  254. let behospitalCode = $(this).parent().attr("data-behospitalCode")
  255. let casesEntryId = $(this).parent().attr("data-casesEntryId")
  256. let qcresultDetailId = $(this).parent().attr("data-qcresultDetailId")
  257. let appealOperationType = $(this).parent().attr("data-appealOperationType")
  258. $(parent.document).find("#contentIframe").attr("src", "appealExamine.html?id=" + id + "&hospitalId=" + hospitalId + "&behospitalCode=" + behospitalCode + "&casesEntryId=" + casesEntryId + "&qcresultDetailId=" + qcresultDetailId + "&appealOperationType=" + appealOperationType + "&form=" + 2)
  259. })
  260. }
  261. //选择病历等级
  262. $('.selectModular').on("click", function (e) {
  263. e.stopPropagation()
  264. $(".selectDept .arrow").attr("src", iconDown)
  265. $(".deptList").css("display", "none")
  266. $(".selectType .arrow").attr("src", iconDown)
  267. $(".typeList").css("display", "none")
  268. $(".qcSelectCheck .arrow").attr("src", iconDown)
  269. $(".qcCheckList").css("display", "none")
  270. const showList = $(".modularList ").css("display")
  271. if (showList == "none" || !showList) {
  272. $(".modularList ").css("display", "block")
  273. $(".selectModular .arrow").attr("src", iconUp)
  274. } else {
  275. $(".modularList ").css("display", "none")
  276. $(".selectModular .arrow").attr("src", iconDown)
  277. }
  278. })
  279. //操作类型
  280. $('.selectType').on("click", function (e) {
  281. e.stopPropagation()
  282. $(".selectDept .arrow").attr("src", iconDown)
  283. $(".deptList").css("display", "none")
  284. $(".selectModular .arrow").attr("src", iconDown)
  285. $(".modularList ").css("display", "none")
  286. $(".qcSelectCheck .arrow").attr("src", iconDown)
  287. $(".qcCheckList").css("display", "none")
  288. const showList = $(".typeList ").css("display")
  289. if (showList == "none" || !showList) {
  290. $(".typeList ").css("display", "block")
  291. $(".selectType .arrow").attr("src", iconUp)
  292. } else {
  293. $(".typeList ").css("display", "none")
  294. $(".selectType .arrow").attr("src", iconDown)
  295. }
  296. })
  297. //选择状态
  298. $('.qcSelectCheck').on("click", function (e) {
  299. e.stopPropagation()
  300. $(".selectDept .arrow").attr("src", iconDown)
  301. $(".deptList").css("display", "none")
  302. $(".selectModular .arrow").attr("src", iconDown)
  303. $(".modularList ").css("display", "none")
  304. $(".selectType .arrow").attr("src", iconDown)
  305. $(".typeList").css("display", "none")
  306. const showList = $(".qcCheckList ").css("display")
  307. if (showList == "none" || !showList) {
  308. $(".qcCheckList ").css("display", "block")
  309. $(".qcSelectCheck .arrow").attr("src", iconUp)
  310. } else {
  311. $(".qcCheckList ").css("display", "none")
  312. $(".qcSelectCheck .arrow").attr("src", iconDown)
  313. }
  314. })
  315. getmoduleList()
  316. //获取模块类型
  317. function getmoduleList() {
  318. post(api.getQcCasesAll).then(res => {
  319. if (res.data.code == '0') {
  320. const moduleTypeList = res.data.data
  321. renderModuleList(moduleTypeList)
  322. } else { }
  323. }).catch((e) => {
  324. })
  325. }
  326. function renderModuleList(moduleTypeList) {
  327. let str = `<li class="modularItem " data-id=" " data-name="全部">全部</li>`
  328. for (let i = 0; i < moduleTypeList.length; i++) {
  329. str += `<li class="modularItem ellipsis" title=${moduleTypeList[i].name} data-id=${moduleTypeList[i].id} data-name=${moduleTypeList[i].name}> ${moduleTypeList[i].name}</li>`
  330. }
  331. $('.modularList').html(str)
  332. bindModuleSelect()
  333. }
  334. //模块类型选择
  335. function bindModuleSelect() {
  336. $('.modularItem').on("click", function () {
  337. const modularItemName = $(this).attr("data-name")
  338. const modularItemItemId = $(this).attr("data-id")
  339. moduleName = modularItemItemId
  340. $('.selectModular').html(modularItemName)
  341. $(".modularList").css("display", "none")
  342. $(".selectModular").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  343. $('.selectModular').removeClass('unSelect')
  344. })
  345. }
  346. getAppealReviewDictionary()
  347. //获取操作类型
  348. function getAppealReviewDictionary() {
  349. post(api.getAppealReviewDictionary).then(res => {
  350. if (res.data.code == '0') {
  351. const typeList = res.data.data['操作类型']
  352. const statusList = res.data.data['状态']
  353. renderTypeList(typeList)
  354. renderStatusList(statusList)
  355. } else { }
  356. }).catch((e) => {
  357. })
  358. }
  359. function renderTypeList(data) {
  360. console.log(data);
  361. let str = `<li class="typeItem " data-id=" " data-name="全部">全部</li>`
  362. for (var i in data) {
  363. str += `<li class="typeItem ellipsis" title=${data[i]} data-id=${i} data-name=${data[i]}> ${data[i]}</li>`
  364. }
  365. $('.typeList').html(str)
  366. bindTypedSelect()
  367. }
  368. //操作类型选择
  369. function bindTypedSelect() {
  370. $('.typeItem').on("click", function () {
  371. const typeItemName = $(this).attr("data-name")
  372. const typeItemItemId = $(this).attr("data-id")
  373. operationType = typeItemItemId
  374. $('.selectType').html(typeItemName)
  375. $(".typeList").css("display", "none")
  376. $(".selectType").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  377. $('.selectType').removeClass('unSelect')
  378. })
  379. }
  380. function renderStatusList(data) {
  381. let str = `<li class="qcCheckItem " data-id=" " data-name="全部">全部</li>`
  382. for (var i in data) {
  383. str += `<li class="qcCheckItem ellipsis" title=${data[i]} data-id=${i} data-name=${data[i]}> ${data[i]}</li>`
  384. }
  385. $('.qcCheckList').html(str)
  386. bindCheckedSelectQc()
  387. }
  388. //状态
  389. function bindCheckedSelectQc() {
  390. $('.qcCheckItem').on("click", function () {
  391. const qcCheckItemName = $(this).attr("data-name")
  392. const qcCheckItemItemId = $(this).attr("data-id") || ""
  393. state = qcCheckItemItemId
  394. $('.qcSelectCheck').html(qcCheckItemName)
  395. $(".qcCheckList").css("display", "none")
  396. $(".qcSelectCheck").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  397. $('.qcSelectCheck').removeClass('unSelect')
  398. })
  399. }
  400. $('.selectDept').on("click", function (e) {
  401. e.stopPropagation()
  402. $(".selectModular .arrow").attr("src", iconDown)
  403. $(".modularList ").css("display", "none")
  404. $(".selectType .arrow").attr("src", iconDown)
  405. $(".typeList").css("display", "none")
  406. $(".qcSelectCheck .arrow").attr("src", iconDown)
  407. $(".qcCheckList").css("display", "none")
  408. const showList = $(".deptList ").css("display")
  409. if (showList == "none" || !showList) {
  410. $(".deptList ").css("display", "block")
  411. $(".selectDept .arrow").attr("src", iconUp)
  412. } else {
  413. $(".deptList ").css("display", "none")
  414. $(".selectDept .arrow").attr("src", iconDown)
  415. }
  416. })
  417. //获取科室列表
  418. getDeptList()
  419. function getDeptList() {
  420. post(api.getDeptListDept, { inputStr: "" }).then(res => {
  421. if (res.data.code == '0') {
  422. const deptList = res.data.data
  423. rendeDeptList(deptList)
  424. } else { }
  425. }).catch((e) => {
  426. })
  427. }
  428. function rendeDeptList(deptList) {
  429. let str = `<li class="deptItem ellipsis" data-id=" " data-name="全部">全部</li>`
  430. for (let i = 0; i < deptList.length; i++) {
  431. str += `<li class="deptItem ellipsis" title=${deptList[i].deptName} data-id=${deptList[i].deptId} data-name=${deptList[i].deptName}> ${deptList[i].deptName}</li>`
  432. }
  433. $('.deptList').html(str)
  434. bindDeptSelect()
  435. }
  436. //科室选择
  437. function bindDeptSelect() {
  438. $('.deptItem').on("click", function () {
  439. const deptItemName = $(this).attr("data-name")
  440. const deptItemId = $(this).attr("data-id")
  441. deptIdTemp = deptItemId
  442. deptName = deptNameTemp = deptItemName
  443. if (deptItemName.length > 10) {
  444. $('.selectDept').html(deptItemName.substring(0, 8) + '...')
  445. } else {
  446. $('.selectDept').html(deptItemName)
  447. }
  448. $('.selectDept ').attr('title', deptItemName)
  449. $(".selectDept").append(`<img class="arrow" src=${iconDown} alt="下拉">`)
  450. $('.selectDept').removeClass('unSelect')
  451. $(".deptList").css("display", "none")
  452. })
  453. }
  454. function renderColSet(list) {
  455. let pageSetList = list || pageSetCopy
  456. let allSelect = true
  457. for (let i = 0; i < pageSetList.length; i++) {
  458. if (pageSetList[i].status != 1) {
  459. allSelect = false
  460. }
  461. }
  462. let str = `<div class='colSetBox'>
  463. <div class='mask'></div>
  464. <div class='cloInfobox'>
  465. <div class='cloInfoTitle'><span class='cloInfoTitleTxt'>列显示设置</span> <img class="iconClose" src=${require('./../images/icon_close_default.png')} alt="关闭" /></div>
  466. <div class='cloInfo'></div>
  467. <div class='btnBox'><span class='defaultColSet'>恢复默认</span> <span class='cancalColSet'>取消</span> <span class='saveColSet'>保存设置</span></div>
  468. </div>
  469. </div>`
  470. let infoStr = `<div class='colTabTitle' ><span class='colOpera toggleSelectColAll' data-select=${allSelect}>${allSelect ? `<img src=${iconCheck} />` : `<img src=${iconUnCheck} />`}全选</span><span class='colName'>列名</span></div><div class='colTabInfoBox' >`
  471. for (let i = 0; i < pageSetList.length; i++) {
  472. infoStr += `<div class='colTabInfo' data-index=${i}>
  473. <span class='colOpera' data-index=${i}>${pageSetList[i].status == 1 ? `<img class="toggleSelectCol" src=${iconCheck} />` : `<img class="toggleSelectCol" src=${iconUnCheck} />`}</span>
  474. <span class='colName'>
  475. <span>${pageSetList[i].name}</span>
  476. <span class="pageOrder">
  477. <span class="pageSetUpBox">${i === 0 ? '' : `<img class="pageSetUp" src=${goUpG} />`}</span>
  478. <span class="pageSetDownBox">${i === pageSetList.length - 1 ? '' : `<img class="pageSetDown" src=${goDownG} />`}</span>
  479. </span>
  480. </span>
  481. </div>`
  482. }
  483. infoStr += "</div>"
  484. // $(".main-body").append(str)
  485. if (!$("#mainBox .colSetBox", parent.document).length) {
  486. $("#mainBox", parent.document).append(str)
  487. }
  488. $("#mainBox .colSetBox .cloInfo", parent.document).html(infoStr)
  489. $(".colTabInfoBox", parent.document).scrollTop(scrollTop)
  490. scrollTop = 0
  491. bindSelectCol()
  492. bindColOrder()
  493. bindSaveColSet()
  494. bindDefaultColset()
  495. bindCloseColSet()
  496. bindImgEnter()
  497. }
  498. function bindDefaultColset() {
  499. $('.defaultColSet', parent.document).off("hover").hover(function () {
  500. $(this).css('color', '#00A1FF')
  501. }, function () {
  502. $(this).css('color', '#777777')
  503. })
  504. $('.defaultColSet', parent.document).off("click").on('click', function () {
  505. return post(api.getDefaultPageSet, { pageType: 1 }).then(res => {
  506. if (res.data.code == '0') {
  507. pageSet = res.data.data
  508. pageSetCopy = JSON.parse(JSON.stringify(pageSet))
  509. renderColSet(pageSetCopy)
  510. } else { }
  511. }).catch((e) => {
  512. })
  513. // closeColSet()
  514. })
  515. }
  516. function bindImgEnter() {
  517. $(".pageSetUpBox img", parent.document).off("mouseenter").on("mouseenter", function () {
  518. $(this).attr('src', goUpB)
  519. })
  520. $(".pageSetDownBox img", parent.document).off("mouseenter").on("mouseenter", function () {
  521. $(this).attr('src', goDownB)
  522. })
  523. $(".pageSetUpBox img", parent.document).off("mouseout").on("mouseout", function () {
  524. $(this).attr('src', goUpG)
  525. })
  526. $(".pageSetDownBox img", parent.document).off("mouseout").on("mouseout", function () {
  527. $(this).attr('src', goDownG)
  528. })
  529. }
  530. function bindSelectCol() {
  531. $(".toggleSelectCol", parent.document).off("click").on("click", function () {
  532. const index = $(this).parent().attr("data-index")
  533. pageSetCopy[index].status = pageSetCopy[index].status == 1 ? 0 : 1
  534. scrollTop = $(".colTabInfoBox", parent.document).scrollTop()
  535. renderColSet(pageSetCopy)
  536. })
  537. $(".toggleSelectColAll", parent.document).off("click").on("click", function () {
  538. const hasSelectAll = $(this).attr("data-select")
  539. for (let i = 0; i < pageSetCopy.length; i++) {
  540. if (hasSelectAll == "true") {
  541. pageSetCopy[i].status = 0
  542. } else {
  543. pageSetCopy[i].status = 1
  544. }
  545. }
  546. scrollTop = $(".colTabInfoBox", parent.document).scrollTop()
  547. renderColSet(pageSetCopy)
  548. })
  549. }
  550. function closeColSet() {
  551. pageSetCopy = JSON.parse(JSON.stringify(pageSet))
  552. $("#mainBox .colSetBox", parent.document).remove()
  553. }
  554. function bindCloseColSet() {
  555. $(".colSetBox .iconClose", parent.document).off("click").on("click", function () {
  556. closeColSet()
  557. })
  558. $(".colSetBox .cancalColSet", parent.document).off("click").on("click", function () {
  559. closeColSet()
  560. })
  561. }
  562. function bindSaveColSet() {
  563. $(".saveColSet", parent.document).off("click").on("click", function () {
  564. let showNumSet = 0
  565. let sysUserPagesetVOList = []
  566. for (let i = 0; i < pageSetCopy.length; i++) {
  567. const item = pageSetCopy[i]
  568. sysUserPagesetVOList.push({
  569. name: item.name,
  570. orderNo: i,
  571. status: item.status,
  572. val: item.val
  573. })
  574. if (item.status == 1) {
  575. showNumSet++
  576. }
  577. }
  578. if (showNumSet === 0) {
  579. $.alerModal({ "message": '最少显示一列', type: "tip", time: '1000', isFather: true, fatherWrapper: $("#mainBox", parent.document) });
  580. return
  581. }
  582. return post(api.saveQcListPageSet, { pageType: 1, sysUserPagesetVOList: sysUserPagesetVOList }).then(res => {
  583. if (res.data.code == '0') {
  584. closeColSet()
  585. } else {
  586. $("#mainBox .colSetBox", parent.document).remove()
  587. $.alerModal({ "message": '保存失败,请重试~', type: "tip", time: '1000', isFather: true, fatherWrapper: $("#mainBox", parent.document) });
  588. }
  589. }).catch((e) => {
  590. $("#mainBox .colSetBox", parent.document).remove()
  591. $.alerModal({ "message": '保存失败,请重试~', type: "tip", time: '1000', isFather: true, fatherWrapper: $("#mainBox", parent.document) });
  592. })
  593. })
  594. }
  595. function bindColOrder() {
  596. $(".pageSetUp", parent.document).off("click").on("click", function () {
  597. const index = parseInt($(this).parent().parent().parent().parent().attr("data-index"))
  598. if (index != 0) {
  599. const upItem = pageSetCopy[index]
  600. const upItemPre = pageSetCopy[index - 1]
  601. pageSetCopy.splice(index - 1, 2, upItem, upItemPre)
  602. scrollTop = $(".colTabInfoBox", parent.document).scrollTop()
  603. renderColSet(pageSetCopy)
  604. } else {
  605. return
  606. }
  607. })
  608. $(".pageSetDown", parent.document).off("click").on("click", function () {
  609. const index = parseInt($(this).parent().parent().parent().parent().attr("data-index"))
  610. if (index == pageSetCopy.length - 1) {
  611. return
  612. } else {
  613. const downItem = pageSetCopy[index]
  614. const downItemBack = pageSetCopy[index + 1]
  615. pageSetCopy.splice(index, 2, downItemBack, downItem)
  616. scrollTop = $(".colTabInfoBox", parent.document).scrollTop()
  617. renderColSet(pageSetCopy)
  618. }
  619. })
  620. }
  621. $(".patientNameInp").on("input", function (e) {
  622. const val = $(this).val().trim()
  623. nameTemp = val
  624. })
  625. $(function () {
  626. $.datepicker.regional['zh-CN'] = {
  627. clearText: '清除',
  628. clearStatus: '清除已选e799bee5baa6e59b9ee7ad9431333361303131日期',
  629. closeText: '关闭',
  630. closeStatus: '不改变当前选择',
  631. prevText: '<上月',
  632. prevStatus: '显示上月',
  633. prevBigText: '<<',
  634. prevBigStatus: '显示上一年',
  635. nextText: '下月>',
  636. nextStatus: '显示下月',
  637. nextBigText: '>>',
  638. nextBigStatus: '显示下一年',
  639. currentText: '今天',
  640. currentStatus: '显示本月',
  641. monthNames: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'],
  642. monthNamesShort: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'],
  643. yearNamesShort: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'],
  644. monthStatus: '选择月份',
  645. yearStatus: '选择年份',
  646. weekHeader: '周',
  647. weekStatus: '年内周次',
  648. dayNames: ['星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六'],
  649. dayNamesShort: ['周日', '周一', '周二', '周三', '周四', '周五', '周六'],
  650. dayNamesMin: ['日', '一', '二', '三', '四', '五', '六'],
  651. dayStatus: '设置 DD 为一周起始',
  652. dateStatus: '选择 m月 d日, DD',
  653. dateFormat: 'yy-mm-dd',
  654. firstDay: 1,
  655. initStatus: '请选择日期',
  656. isRTL: false
  657. };
  658. $.datepicker.setDefaults($.datepicker.regional['zh-CN']);
  659. let startDate = "", endDate = new Date()
  660. let year = new Date().getFullYear()
  661. let month = new Date().getMonth() + 1
  662. if (statisticsType == '1') {
  663. startDate = new Date(`${year}-${month}-01`)
  664. } else if (statisticsType == '2') {
  665. startDate = new Date(`${year}-01-01`)
  666. } else if (statisticsType == '3') {
  667. startDate = new Date(startDateParam)
  668. endDate = new Date(endDateParam)
  669. } else {
  670. startDate = "-6d"
  671. }
  672. $("#datepicker").datepicker({
  673. changeMonth: true,
  674. changeYear: true,
  675. dateFormat: "yy/mm/dd",
  676. }).datepicker("setDate", startDate);
  677. $("#datepicker2").datepicker({
  678. changeMonth: true,
  679. changeYear: true,
  680. dateFormat: "yy/mm/dd"
  681. }).datepicker("setDate", endDate);
  682. $("#datepickerFp1").datepicker({
  683. changeMonth: true,
  684. changeYear: true,
  685. dateFormat: "yy/mm/dd"
  686. }).datepicker("setDate", "");
  687. $("#datepickerFp2").datepicker({
  688. changeMonth: true,
  689. changeYear: true,
  690. dateFormat: "yy/mm/dd"
  691. }).datepicker("setDate", "");
  692. $("#datepickerQc1").datepicker({
  693. changeMonth: true,
  694. changeYear: true,
  695. dateFormat: "yy/mm/dd"
  696. }).datepicker("setDate", "");
  697. $("#datepickerQc2").datepicker({
  698. changeMonth: true,
  699. changeYear: true,
  700. dateFormat: "yy/mm/dd"
  701. }).datepicker("setDate", "");
  702. getTabData(1)
  703. });
  704. //分页渲染
  705. function renderPagination(totalPage, activePage, totalNum) {
  706. let str = `<span class="totalSum">共${totalPage}页/${totalNum}条数据</span><span class="prePage"><img class="arrowPage" src=${arrowLeft} /></span>`
  707. if (totalPage <= 6) {
  708. for (let i = 1; i <= totalPage; i++) {
  709. str += `<span class="pageNum ${'page' + i}" data-page=${i}>${i}</span>`
  710. }
  711. } else {
  712. if (activePage <= 3) { //选中页数小于4
  713. for (let i = 1; i <= 4; i++) {
  714. str += `<span class="pageNum ${'page' + i}" data-page=${i}>${i}</span>`
  715. }
  716. str += `<span class="more" >...</span>`
  717. str += `<span class="pageNum ${'page' + totalPage}" data-page=${totalPage}>${totalPage}</span>`
  718. } else if (activePage > totalPage - 3) {
  719. str += `<span class="pageNum page1" data-page=1>1</span>`
  720. str += `<span class="more" >...</span>`
  721. str += `<span class="pageNum ${'page' + (totalPage - 3)}" data-page=${totalPage - 3}>${totalPage - 3}</span>`
  722. str += `<span class="pageNum ${'page' + (totalPage - 2)}" data-page=${totalPage - 2}>${totalPage - 2}</span>`
  723. str += `<span class="pageNum ${'page' + (totalPage - 1)}" data-page=${totalPage - 1}>${totalPage - 1}</span>`
  724. str += `<span class="pageNum ${'page' + totalPage}" data-page=${totalPage}>${totalPage}</span>`
  725. } else {
  726. str += `<span class="pageNum page1" data-page=1>1</span>`
  727. str += `<span class="more" >...</span>`
  728. str += `<span class="pageNum ${'page' + (activePage - 1)}" data-page=${activePage - 1}>${activePage - 1}</span>`
  729. str += `<span class="pageNum ${'page' + activePage}" data-page=${activePage}>${activePage}</span>`
  730. str += `<span class="pageNum ${'page' + (activePage + 1)}" data-page=${activePage + 1}>${activePage + 1}</span>`
  731. str += `<span class="more" >...</span>`
  732. str += `<span class="pageNum ${'page' + totalPage}" data-page=${totalPage}>${totalPage}</span>`
  733. }
  734. }
  735. str += `<span class="nextPage"><img class="arrowPage" src=${arrowRight} /></span>`
  736. $('.pagination').html(str)
  737. $('.page' + activePage).addClass('activePage')
  738. $(".pageNum").on("click", function (e) {
  739. const activePageNow = Number($(this).attr('data-page'))
  740. getTabData(activePageNow)
  741. // renderPagination(totalPage,activePageNow,totalNum)
  742. })
  743. $(".prePage").on("click", function (e) {
  744. let activePageNow = Number($(".activePage").attr('data-page'))
  745. if (activePageNow > 1) {
  746. activePageNow--
  747. getTabData(activePageNow)
  748. // renderPagination(totalPage,activePageNow,totalNum)
  749. }
  750. })
  751. $(".nextPage").on("click", function (e) {
  752. let activePageNow = Number($(".activePage").attr('data-page'))
  753. if (activePageNow < totalPage) {
  754. activePageNow++
  755. getTabData(activePageNow)
  756. // renderPagination(totalPage,activePageNow,totalNum)
  757. }
  758. })
  759. }
  760. $(document).on("click", function () {
  761. $(".selectDept .arrow").attr("src", iconDown)
  762. $(".deptList").css("display", "none")
  763. $(".selectModular .arrow").attr("src", iconDown)
  764. $(".modularList ").css("display", "none")
  765. $(".selectType .arrow").attr("src", iconDown)
  766. $(".typeList").css("display", "none")
  767. $(".qcSelectCheck .arrow").attr("src", iconDown)
  768. $(".qcCheckList").css("display", "none")
  769. })
  770. let radioCheck = 1;
  771. $((function ($) {
  772. $('.export').click(function () {
  773. const behosDateStartTime = new Date(behosDateStart).getTime()
  774. const behosDateEndTime = new Date(behosDateEnd).getTime()
  775. if (behosDateStartTime > behosDateEndTime) {
  776. $.alerModal({ "message": '开始时间不能大于结束时间~', type: "tip", time: '1000', isFather: true, fatherWrapper: $("#mainBox", parent.document) });
  777. return
  778. }
  779. const param = {
  780. deptId: deptId.trim(),
  781. deptName: deptName == "全部" ? "" : deptName || '',
  782. casesName: casesName,
  783. operationType: operationType,
  784. state: state,
  785. size: 15,
  786. name: nameTemp,
  787. complaintDateEnd: behosDateEnd.replaceAll("/", "-"),
  788. complaintDateStart: behosDateStart.replaceAll("/", "-"),
  789. }
  790. expJson(api.getAppealReviewExport, param).then(res => {
  791. downloadExportedData(res.data, "申述审核.xls")
  792. })
  793. })
  794. })($));