index.js 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625
  1. var template = ''
  2. $.ajax('../../../component/statistics/LascCervical/index.html', {
  3. data: {},
  4. dataType: 'html',
  5. cache: false,
  6. timeout: 60000,
  7. async: false,
  8. error: function (res) {},
  9. success: function (res) {
  10. template = res
  11. }
  12. })
  13. Vue.component('lasc-cervical', {
  14. template: template,
  15. props: [],
  16. data: function () {
  17. return {
  18. years: [],
  19. yearType: '1',
  20. loadingTwo: false,
  21. chooseYear: null,
  22. chooseTime: null,
  23. query: {
  24. page: 1,
  25. size: 10,
  26. total: 0
  27. },
  28. rangeOptions: [
  29. { label: '区', value: '1' },
  30. { label: '机构', value: '2' },
  31. { label: '居住地', value: '3' }
  32. ],
  33. areaOptions: [
  34. { label: '思明区', value: '350203' },
  35. { label: '海沧区', value: '350205' },
  36. { label: '湖里区', value: '350206' },
  37. { label: '集美区', value: '350211' },
  38. { label: '同安区', value: '350212' },
  39. { label: '翔安区', value: '350213' }
  40. ],
  41. hospitalOptions: [],
  42. teamOptions: [],
  43. form: {
  44. range: '1'
  45. },
  46. loading: false,
  47. exportLoading: false,
  48. tableData: [],
  49. tableHeader: [],
  50. constantHeader: [
  51. { label: '下转次数', prop: 'totalTimes', width: '90' },
  52. { label: '门诊下转次数', prop: 'mzTimes', width: '110' },
  53. { label: '出院下转次数', prop: 'zyTimes', width: '110' },
  54. { label: '下转人数', prop: 'totalNum', width: '110' },
  55. { label: '门诊下转人数', prop: 'mzNum', width: '110' },
  56. { label: '出院下转人数', prop: 'zyNum', width: '110' },
  57. { label: '门诊下转已评估', prop: 'mzScreenNum', width: '120' },
  58. { label: '门诊下转未评估', prop: 'unMzScreenNum', width: '120' },
  59. { label: '出院下转已评估', prop: 'zyScreenNum', width: '120' },
  60. { label: '出院下转未评估', prop: 'unZyScreenNum', width: '120' }
  61. ],
  62. level: 0,
  63. visible: false,
  64. dataRangeOption: [],
  65. dialogTableData: [],
  66. dialogHeader: [
  67. { label: '居民姓名', prop: 'name', width: '100' },
  68. { label: '证件号码', prop: 'idcard', width: '100' },
  69. { label: '手机号', prop: 'mobile', width: '110' },
  70. { label: '年龄', prop: 'age', width: '90' },
  71. { label: '出生日期', prop: 'birthday', width: '90' },
  72. { label: '常驻地址', prop: 'address', width: '100' },
  73. { label: '个人筛查状态', prop: 'statusName', width: '100' }
  74. ],
  75. page: 1,
  76. size: 10,
  77. total: 0,
  78. messageVisible: false,
  79. messInfo: null,
  80. remind: '',
  81. dialogLoading: false,
  82. dialogExportLoading: false,
  83. statusOptions: [],
  84. rehabilitationHospital: [],
  85. archiveList: [],
  86. inviteStatus: [
  87. { value: '', label: '全部' },
  88. { value: '1', label: '门诊患者' },
  89. { value: '2', label: '出院患者' }
  90. ],
  91. communityHospitals: [],
  92. title: '',
  93. dialogVisible: false,
  94. signatoryList: [],
  95. cervicalHeaderGroups: [
  96. {
  97. label: '宫颈癌管理情况',
  98. children: [
  99. { prop: 'num2', label: '妇科检查人数' },
  100. { prop: 'assessNum', label: '线上评估人数' },
  101. { prop: 'orderNum', label: '线上预约人数' }
  102. ]
  103. },
  104. {
  105. label: '宫颈妇科检查情况',
  106. children: [
  107. { prop: 'jujueNum', label: '拒绝' },
  108. { prop: 'yicongNum', label: '依从' },
  109. { prop: 'num3', label: '检查人数' },
  110. { prop: 'waitNum', label: '待完善人数' }
  111. ]
  112. },
  113. {
  114. label: 'HPV检查情况',
  115. children: [
  116. { prop: 'hpvNum', label: '检查人数' },
  117. { prop: 'n1', label: '待完善人数' }
  118. ]
  119. },
  120. {
  121. label: '高危HPV分型检测情况',
  122. children: [
  123. { prop: 'hpvH', label: '高危HPV阳性人数' },
  124. { prop: 'hpv16', label: '16型阳性人数' },
  125. { prop: 'hpv18', label: '18型阳性人数' },
  126. { prop: 'hpv31', label: '31型阳性人数' },
  127. { prop: 'hpv33', label: '33型阳性人数' },
  128. { prop: 'hpv35', label: '35型阳性人数' },
  129. { prop: 'hpv39', label: '39型阳性人数' },
  130. { prop: 'hpv45', label: '45型阳性人数' },
  131. { prop: 'hpv51', label: '51型阳性人数' },
  132. { prop: 'hpv52', label: '52型阳性人数' },
  133. { prop: 'hpv53', label: '53型阳性人数' },
  134. { prop: 'hpv56', label: '56型阳性人数' },
  135. { prop: 'hpv58', label: '58型阳性人数' },
  136. { prop: 'hpv59', label: '59型阳性人数' },
  137. { prop: 'hpv66', label: '66型阳性人数' },
  138. { prop: 'hpv68', label: '68型阳性人数' },
  139. { prop: 'hpv73', label: '73型阳性人数' },
  140. { prop: 'hpv82', label: '82型阳性人数' }
  141. ]
  142. },
  143. {
  144. label: '低危HPV分型检测情况',
  145. children: [
  146. { prop: 'hpvL', label: '低危HPV阳性人数' },
  147. { prop: 'hpv6', label: '6型阳性人数' },
  148. { prop: 'hpv11', label: '11型阳性人数' },
  149. { prop: 'hpv42', label: '42型阳性人数' },
  150. { prop: 'hpv43', label: '43型阳性人数' },
  151. { prop: 'hpv44', label: '44型阳性人数' },
  152. { prop: 'hpv81', label: '81型阳性人数' },
  153. { prop: 'hpv83', label: '83型阳性人数' }
  154. ]
  155. },
  156. {
  157. label: '宫颈细胞学检查情况',
  158. children: [
  159. { prop: 'cytNum', label: '检查人数' },
  160. { prop: 'cytNum1', label: '检查异常人数' },
  161. { prop: 'cytNum2', label: '待完善人数' }
  162. ]
  163. },
  164. {
  165. label: '初筛结果临床评估情况',
  166. children: [
  167. { prop: 'preNum', label: '检查人数' },
  168. { prop: 'preNum1', label: '待完善人数' },
  169. { prop: 'preNum2', label: '未见异常,定期筛查' },
  170. { prop: 'preNum3', label: '异常,6-12个月复查' },
  171. { prop: 'preNum4', label: '异常,嘱进一步行阴道镜检查' }
  172. ]
  173. },
  174. {
  175. label: '阴道镜检查情况',
  176. children: [
  177. { prop: 'colNum', label: '需要阴道镜检查人数' },
  178. { prop: 'colNum1', label: '阴道镜检查人数' },
  179. { prop: 'colNum2', label: '接受检查人数' },
  180. { prop: 'colNum3', label: '拒绝检查人数' },
  181. { prop: 'colNum4', label: '未见异常人数' },
  182. { prop: 'colNum5', label: '异常人数' },
  183. { prop: 'colNum6', label: '待完善人数' }
  184. ]
  185. },
  186. {
  187. label: '阴道镜检查随访情况',
  188. children: [
  189. { prop: 'colfNum', label: '已随访人数' },
  190. { prop: 'colfNum1', label: '待随访人数' },
  191. { prop: 'colfNum2', label: '未见异常' },
  192. { prop: 'colfNum3', label: '低度病变' },
  193. { prop: 'colfNum4', label: '高度病变' },
  194. { prop: 'colfNum5', label: '可疑癌' },
  195. { prop: 'colfNum6', label: '其他' },
  196. { prop: 'colfNum7', label: '不详' }
  197. ]
  198. },
  199. {
  200. label: '组织病理学检查情况',
  201. children: [
  202. { prop: 'cpatNum', label: '需要组织病理学检查' },
  203. { prop: 'cpatNum1', label: '病理学检查人数' },
  204. { prop: 'cpatNum2', label: '接受检查人数' },
  205. { prop: 'cpatNum3', label: '拒绝检查人数' },
  206. { prop: 'cpatNum4', label: '未见异常人数' },
  207. { prop: 'cpatNum5', label: '炎症' },
  208. { prop: 'cpatNum6', label: '低级别病变(原CIN1)' },
  209. { prop: 'cpatNum7', label: '高级别病变(原CIN2及CIN3)' },
  210. { prop: 'cpatNum8', label: '宫颈原位腺癌(AIS)' },
  211. { prop: 'cpatNum9', label: '宫颈微小浸润癌(鳞癌/腺癌)' },
  212. { prop: 'cpatNum10', label: '宫颈浸润癌(鳞癌/腺癌)' }
  213. ]
  214. },
  215. {
  216. label: '组织病理学检查随访情况',
  217. children: [
  218. { prop: 'cpatfNum', label: '已随访人数' },
  219. { prop: 'cpatfNum1', label: '待随访人数' },
  220. { prop: 'cpatfNum2', label: '炎症' },
  221. { prop: 'cpatfNum3', label: '低级别病变(原CIN1)' },
  222. { prop: 'cpatfNum4', label: '高级别病变(原CIN2及CIN3)' },
  223. { prop: 'cpatfNum5', label: '宫颈原位腺癌(AIS)' },
  224. { prop: 'cpatfNum6', label: '宫颈微小浸润癌(鳞癌/腺癌)' },
  225. { prop: 'cpatfNum7', label: '宫颈浸润癌(鳞癌/腺癌)' }
  226. ]
  227. },
  228. {
  229. label: '最后诊断情况',
  230. children: [
  231. { prop: 'finNum', label: '未见异常人数' },
  232. { prop: 'finNum1', label: '炎症' },
  233. { prop: 'finNum2', label: '低级别病变(原CIN1)' },
  234. { prop: 'finNum3', label: '高级别病变(原CIN2及CIN3)' },
  235. { prop: 'finNum4', label: '宫颈原位腺癌(AIS)' },
  236. { prop: 'finNum5', label: '宫颈微小浸润癌(鳞癌/腺癌)' },
  237. { prop: 'finNum6', label: '宫颈浸润癌(鳞癌/腺癌)' },
  238. { prop: 'finNum7', label: '待完善人数' }
  239. ]
  240. },
  241. {
  242. label: '宫颈病变接受治疗情况',
  243. children: [
  244. { prop: 'finTNum1', label: '接受治疗人数' },
  245. { prop: 'finTNum2', label: '不接受治疗人数' },
  246. { prop: 'finTNum3', label: '不详人数' }
  247. ]
  248. },
  249. {
  250. label: '术后病理—接受组织病理学检查情况',
  251. children: [
  252. { prop: 'finSNum1', label: '接受检查人数' },
  253. { prop: 'finSNum2', label: '不接受检查人数' },
  254. { prop: 'finSNum3', label: '炎症' },
  255. { prop: 'finSNum4', label: '低级别病变(原CIN1)' },
  256. { prop: 'finSNum5', label: '高级别病变(原CIN2及CIN3)' },
  257. { prop: 'finSNum6', label: '宫颈微小浸润癌(鳞癌/腺癌)' },
  258. { prop: 'finSNum7', label: '宫颈浸润癌(鳞癌/腺癌)' }
  259. ]
  260. }
  261. ],
  262. currentEditData: '',
  263. serviceRecordVisable: false
  264. }
  265. },
  266. methods: {
  267. back() {
  268. this.currentEditData = ''
  269. this.serviceRecordVisable = false
  270. },
  271. gotoService(item) {
  272. this.currentEditData = item.patient
  273. this.serviceRecordVisable = true
  274. },
  275. init() {
  276. var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole'))
  277. if (selectedRole.code.indexOf('350200') > -1) {
  278. this.level = 1 // 市卫健委
  279. this.areaOptions = [
  280. { label: '厦门市', value: '' },
  281. { label: '思明区', value: '350203' },
  282. { label: '海沧区', value: '350205' },
  283. { label: '湖里区', value: '350206' },
  284. { label: '集美区', value: '350211' },
  285. { label: '同安区', value: '350212' },
  286. { label: '翔安区', value: '350213' }
  287. ]
  288. } else if (selectedRole.code.length == 6) {
  289. this.level = 2 // 区管理
  290. this.areaOptions = [{ label: selectedRole.name.substring(0, 3), value: selectedRole.code }]
  291. this.form = {
  292. range: '2',
  293. town: selectedRole.code
  294. }
  295. this.getHospital(selectedRole.code)
  296. } else {
  297. this.level = 3 // 社区管理
  298. this.rangeOptions = [{ label: '社区', value: '2' }]
  299. this.areaOptions = [{ label: selectedRole.name.substring(0, 3), value: selectedRole.code }]
  300. this.hospitalOptions = [{ name: selectedRole.name, code: selectedRole.code }]
  301. this.form = {
  302. range: '2',
  303. town: selectedRole.code.substring(0, 6),
  304. hospital: selectedRole.code
  305. }
  306. this.getTeam(selectedRole.code)
  307. }
  308. this.initTime()
  309. this.searchFn()
  310. this.hospitalsByType()
  311. },
  312. initTime() {
  313. var vm = this
  314. var now = new Date()
  315. vm.nowyear = vm.chooseYear = now.getFullYear()
  316. vm.years = []
  317. for (i = vm.nowyear; i >= 2013; i--) {
  318. vm.years.push(i)
  319. }
  320. },
  321. resetArea() {
  322. if (this.level == 1) {
  323. delete this.form.area
  324. delete this.form.hospital
  325. delete this.form.team
  326. } else if (this.level == 2) {
  327. delete this.form.hospital
  328. delete this.form.team
  329. } else {
  330. delete this.form.team
  331. }
  332. },
  333. getDictData() {},
  334. searchFn() {
  335. var vm = this
  336. this.loading = true
  337. var params = {
  338. ...this.form,
  339. page: this.page,
  340. size: this.size
  341. }
  342. vm.tableData = []
  343. if (this.chooseTime) {
  344. params.startTime = this.chooseTime[0]
  345. params.endTime = this.chooseTime[1]
  346. }
  347. httpRequest.get('/doctor/twoCancers/count/cervicalQualityCount', { data: params }).then(function (res) {
  348. if (res.status == 200) {
  349. vm.tableData = res.detailModelList
  350. vm.total = res.totalCount
  351. }
  352. console.log('22222222222222222', vm.tableData)
  353. vm.loading = false
  354. })
  355. },
  356. exportTable() {
  357. var params = {
  358. ...this.form,
  359. page: this.page,
  360. size: this.size
  361. }
  362. if (this.chooseTime) {
  363. params.startTime = this.chooseTime[0]
  364. params.endTime = this.chooseTime[1]
  365. }
  366. this.exportLoading = true
  367. var fileName = `宫颈癌质控统计表${new Date().getTime()}.xls`
  368. httpRequest.downLoadFileForAjax('doctor/twoCancers/count/exportCervicalQualityCount', fileName, params).then(function () {
  369. this.exportLoading = false
  370. })
  371. },
  372. eliminateClick() {
  373. var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole'))
  374. if (this.level == 1) {
  375. this.form = {
  376. range: '1'
  377. }
  378. } else if (this.level == 2) {
  379. this.form = {
  380. range: '1',
  381. area: selectedRole.code
  382. }
  383. this.getHospital(selectedRole.code)
  384. } else {
  385. this.form = {
  386. range: '2',
  387. area: selectedRole.code.substring(0, 6),
  388. hospital: selectedRole.code
  389. }
  390. this.getTeam(selectedRole.code)
  391. }
  392. this.chooseYear = new Date().getFullYear()
  393. this.chooseTime = null
  394. const now = new Date()
  395. // 获取当前日期
  396. const endDate = new Date()
  397. // 获取30天前的日期
  398. const startDate = new Date()
  399. startDate.setDate(endDate.getDate() - 30)
  400. this.chooseTime = [this.formatDate(startDate), this.formatDate(endDate)]
  401. this.init()
  402. this.$forceUpdate()
  403. },
  404. getHospital(code, flag = true) {
  405. var vm = this
  406. if (flag) {
  407. delete this.form.hospital
  408. delete this.form.team
  409. }
  410. var params = {
  411. type: 5,
  412. code: code
  413. }
  414. if (!code) {
  415. vm.hospitalOptions = [{ name: '全部', value: '' }]
  416. vm.teamOptions = [{ name: '全部', value: '' }]
  417. return false
  418. }
  419. httpRequest.post('common/district', { data: params }).then(function (res) {
  420. vm.hospitalOptions = res.list
  421. })
  422. },
  423. getTeam(code, flag = true) {
  424. var vm = this
  425. if (flag) {
  426. delete this.form.team
  427. }
  428. var params = {
  429. hospital: code
  430. }
  431. httpRequest.get('statisticsExport/teamList', { data: params }).then(function (res) {
  432. vm.teamOptions = res.data
  433. })
  434. },
  435. handleCurrentChange(val) {
  436. this.page = val
  437. this.searchFn()
  438. },
  439. handleSizeChange(val) {
  440. this.size = val
  441. this.searchFn()
  442. },
  443. // 获取社区医院
  444. hospitalsByType() {
  445. var vm = this
  446. // var code
  447. var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole'))
  448. if (selectedRole.code.indexOf('350200') > -1) {
  449. code = '350200' // 市卫健委
  450. } else if (selectedRole.code.length == 6) {
  451. code = selectedRole.code
  452. } else {
  453. this.level = 3 // 社区管理
  454. }
  455. if (selectedRole.code.length > 6) {
  456. this.communityHospitals = [{ label: selectedRole.name, value: selectedRole.code }]
  457. } else {
  458. var type = 1
  459. if (selectedRole.code.indexOf('350200') > -1) {
  460. type = 1 // 市卫健委
  461. } else if (selectedRole.code.length == 6) {
  462. type = 2
  463. }
  464. statisticAPI
  465. .hospitalsByType({
  466. type: type,
  467. code: selectedRole.code
  468. })
  469. .then(function (res) {
  470. if (res.status == 200) {
  471. vm.communityHospitals = [{ label: '全部', value: '' }]
  472. res.list.forEach(function (v) {
  473. vm.communityHospitals.push({
  474. value: v.code,
  475. label: v.name
  476. })
  477. })
  478. }
  479. })
  480. .catch(function (err) {
  481. console.log(err, 'Errr')
  482. })
  483. }
  484. },
  485. openDialog(row, prop) {
  486. var vm = this
  487. vm.dialogLoading = true
  488. this.query.type = 'g_' + prop
  489. this.query.orgCode = row.orgCode
  490. var params = {
  491. ...this.query,
  492. range: (this.form && this.form.range) || '',
  493. town: (this.form && this.form.town) || ''
  494. }
  495. vm.dialogTableData = []
  496. if (this.chooseTime) {
  497. params.startTime = this.chooseTime[0]
  498. params.endTime = this.chooseTime[1]
  499. }
  500. delete params.total
  501. httpRequest.get('doctor/twoCancers/count/caseDataList', { data: params }).then(function (res) {
  502. vm.dialogTableData = res.detailModelList
  503. vm.query.total = res.totalCount
  504. vm.visible = true
  505. vm.dialogLoading = false
  506. })
  507. },
  508. caseDataList() {
  509. var vm = this
  510. vm.dialogLoading = true
  511. var params = {
  512. ...this.query,
  513. range: (this.form && this.form.range) || '',
  514. town: (this.form && this.form.town) || '',
  515. hospital: (this.form && this.form.hospital) || ''
  516. }
  517. vm.dialogTableData = []
  518. if (this.chooseTime) {
  519. params.startTime = this.chooseTime[0]
  520. params.endTime = this.chooseTime[1]
  521. }
  522. delete params.total
  523. httpRequest.get('doctor/twoCancers/count/caseDataList', { data: params }).then(function (res) {
  524. vm.dialogTableData = res.detailModelList
  525. vm.query.total = res.totalCount
  526. vm.dialogLoading = false
  527. })
  528. },
  529. dialogSearchFn() {
  530. this.caseDataList()
  531. },
  532. handleCurrentChange1(val) {
  533. this.query.page = val
  534. this.caseDataList()
  535. },
  536. handleSizeChange1(val) {
  537. this.query.size = val
  538. this.caseDataList()
  539. },
  540. dialogExportFn() {
  541. var vm = this
  542. this.dialogExportLoading = true
  543. var params = {
  544. ...this.query,
  545. range: (this.form && this.form.range) || '',
  546. town: (this.form && this.form.town) || '',
  547. hospital: (this.form && this.form.hospital) || ''
  548. }
  549. if (this.chooseTime) {
  550. params.startTime = this.chooseTime[0]
  551. params.endTime = this.chooseTime[1]
  552. }
  553. var fileName = `个案数据列表${new Date().getTime()}.xls`
  554. httpRequest.downLoadFileForAjax('doctor/twoCancers/count/exportCaseDataList', fileName, params).then(function () {
  555. vm.dialogExportLoading = false
  556. })
  557. },
  558. dialogResetFn() {
  559. this.query = {
  560. page: 1,
  561. size: 10,
  562. total: 0,
  563. type:this.query.type,
  564. orgCode:this.query.orgCode,
  565. }
  566. this.caseDataList()
  567. },
  568. closeDialog() {
  569. this.visible = false
  570. },
  571. closeDialog1() {
  572. this.dialogVisible = false
  573. },
  574. getData(data) {
  575. if (data) {
  576. this.yearType = data.yearType
  577. this.form.range = data.range
  578. this.form.area = data.area
  579. this.form.hospital = data.hospital
  580. this.form.team = data.team
  581. if (this.yearType == 1) {
  582. this.chooseYear = data.time
  583. } else {
  584. this.chooseTime = data.time
  585. }
  586. if (this.form.hospital) {
  587. // 如果有社区code传过来就调社区医院列表接口
  588. this.getHospital(data.area, false)
  589. }
  590. if (this.form.team) {
  591. // 如果有团队code传过来就调团队列表接口
  592. this.getTeam(data.hospital, false)
  593. }
  594. this.searchFn()
  595. } else {
  596. this.init()
  597. }
  598. },
  599. formatDate(date) {
  600. const year = date.getFullYear()
  601. const month = String(date.getMonth() + 1).padStart(2, '0')
  602. const day = String(date.getDate()).padStart(2, '0')
  603. return `${year}-${month}-${day}`
  604. }
  605. },
  606. mounted() {
  607. const now = new Date()
  608. // 获取当前日期
  609. const endDate = new Date()
  610. // 获取30天前的日期
  611. const startDate = new Date()
  612. startDate.setDate(endDate.getDate() - 30)
  613. this.chooseTime = [this.formatDate(startDate), this.formatDate(endDate)]
  614. this.init()
  615. }
  616. })