index.js 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  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. this.$forceUpdate()
  395. },
  396. getHospital(code, flag = true) {
  397. var vm = this
  398. if (flag) {
  399. delete this.form.hospital
  400. delete this.form.team
  401. }
  402. var params = {
  403. type: 5,
  404. code: code
  405. }
  406. if (!code) {
  407. vm.hospitalOptions = [{ name: '全部', value: '' }]
  408. vm.teamOptions = [{ name: '全部', value: '' }]
  409. return false
  410. }
  411. httpRequest.post('common/district', { data: params }).then(function (res) {
  412. vm.hospitalOptions = res.list
  413. })
  414. },
  415. getTeam(code, flag = true) {
  416. var vm = this
  417. if (flag) {
  418. delete this.form.team
  419. }
  420. var params = {
  421. hospital: code
  422. }
  423. httpRequest.get('statisticsExport/teamList', { data: params }).then(function (res) {
  424. vm.teamOptions = res.data
  425. })
  426. },
  427. handleCurrentChange(val) {
  428. this.page = val
  429. this.searchFn()
  430. },
  431. handleSizeChange(val) {
  432. this.size = val
  433. this.searchFn()
  434. },
  435. // 获取社区医院
  436. hospitalsByType() {
  437. var vm = this
  438. // var code
  439. var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole'))
  440. if (selectedRole.code.indexOf('350200') > -1) {
  441. code = '350200' // 市卫健委
  442. } else if (selectedRole.code.length == 6) {
  443. code = selectedRole.code
  444. } else {
  445. this.level = 3 // 社区管理
  446. }
  447. if (selectedRole.code.length > 6) {
  448. this.communityHospitals = [{ label: selectedRole.name, value: selectedRole.code }]
  449. } else {
  450. var type = 1
  451. if (selectedRole.code.indexOf('350200') > -1) {
  452. type = 1 // 市卫健委
  453. } else if (selectedRole.code.length == 6) {
  454. type = 2
  455. }
  456. statisticAPI
  457. .hospitalsByType({
  458. type: type,
  459. code: selectedRole.code
  460. })
  461. .then(function (res) {
  462. if (res.status == 200) {
  463. vm.communityHospitals = [{ label: '全部', value: '' }]
  464. res.list.forEach(function (v) {
  465. vm.communityHospitals.push({
  466. value: v.code,
  467. label: v.name
  468. })
  469. })
  470. }
  471. })
  472. .catch(function (err) {
  473. console.log(err, 'Errr')
  474. })
  475. }
  476. },
  477. openDialog(row, prop) {
  478. var vm = this
  479. vm.dialogLoading = true
  480. this.query.type = 'g_' + prop
  481. this.query.orgCode = row.orgCode
  482. var params = {
  483. ...this.query,
  484. range: (this.form && this.form.range) || '',
  485. town: (this.form && this.form.town) || ''
  486. }
  487. vm.dialogTableData = []
  488. if (this.chooseTime) {
  489. params.startTime = this.chooseTime[0]
  490. params.endTime = this.chooseTime[1]
  491. }
  492. delete params.total
  493. httpRequest.get('doctor/twoCancers/count/caseDataList', { data: params }).then(function (res) {
  494. vm.dialogTableData = res.detailModelList
  495. vm.query.total = res.totalCount
  496. vm.visible = true
  497. vm.dialogLoading = false
  498. })
  499. },
  500. caseDataList() {
  501. var vm = this
  502. vm.dialogLoading = true
  503. var params = {
  504. ...this.query,
  505. range: (this.form && this.form.range) || '',
  506. town: (this.form && this.form.town) || '',
  507. hospital: (this.form && this.form.hospital) || ''
  508. }
  509. vm.dialogTableData = []
  510. if (this.chooseTime) {
  511. params.startTime = this.chooseTime[0]
  512. params.endTime = this.chooseTime[1]
  513. }
  514. delete params.total
  515. httpRequest.get('doctor/twoCancers/count/caseDataList', { data: params }).then(function (res) {
  516. vm.dialogTableData = res.detailModelList
  517. vm.query.total = res.totalCount
  518. vm.dialogLoading = false
  519. })
  520. },
  521. dialogSearchFn() {
  522. this.caseDataList()
  523. },
  524. handleCurrentChange1(val) {
  525. this.query.page = val
  526. this.caseDataList()
  527. },
  528. handleSizeChange1(val) {
  529. this.query.size = val
  530. this.caseDataList()
  531. },
  532. dialogExportFn() {
  533. var vm = this
  534. this.dialogExportLoading = true
  535. var params = {
  536. ...this.query,
  537. range: (this.form && this.form.range) || '',
  538. town: (this.form && this.form.town) || '',
  539. hospital: (this.form && this.form.hospital) || ''
  540. }
  541. if (this.chooseTime) {
  542. params.startTime = this.chooseTime[0]
  543. params.endTime = this.chooseTime[1]
  544. }
  545. var fileName = `个案数据列表${new Date().getTime()}.xls`
  546. httpRequest.downLoadFileForAjax('doctor/twoCancers/count/exportCaseDataList', fileName, params).then(function () {
  547. vm.dialogExportLoading = false
  548. })
  549. },
  550. dialogResetFn() {
  551. this.query = {
  552. page: 1,
  553. size: 10,
  554. total: 0
  555. }
  556. this.caseDataList()
  557. },
  558. closeDialog() {
  559. this.visible = false
  560. },
  561. closeDialog1() {
  562. this.dialogVisible = false
  563. },
  564. getData(data) {
  565. if (data) {
  566. this.yearType = data.yearType
  567. this.form.range = data.range
  568. this.form.area = data.area
  569. this.form.hospital = data.hospital
  570. this.form.team = data.team
  571. if (this.yearType == 1) {
  572. this.chooseYear = data.time
  573. } else {
  574. this.chooseTime = data.time
  575. }
  576. if (this.form.hospital) {
  577. // 如果有社区code传过来就调社区医院列表接口
  578. this.getHospital(data.area, false)
  579. }
  580. if (this.form.team) {
  581. // 如果有团队code传过来就调团队列表接口
  582. this.getTeam(data.hospital, false)
  583. }
  584. this.searchFn()
  585. } else {
  586. this.init()
  587. }
  588. }
  589. },
  590. mounted() {
  591. this.init()
  592. }
  593. })