index.js 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280
  1. var template = ''
  2. $.ajax('../../../component/statistics/LascPatient/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-patient', {
  14. template: template,
  15. props: [],
  16. data: function () {
  17. return {
  18. years: [],
  19. currentEditData: '',
  20. dialogVisible: false,
  21. showTotalTable: true,
  22. serviceRecordVisable: false,
  23. yearType: '1',
  24. chooseYear: null,
  25. chooseTime1: null,
  26. chooseTime: null,
  27. formDialogVisible: true,
  28. rangeOptions: [
  29. { label: '区', value: '1' },
  30. { label: '社区', value: '2' }
  31. ],
  32. areaOptions: [
  33. { label: '思明区', value: '350203' },
  34. { label: '海沧区', value: '350205' },
  35. { label: '湖里区', value: '350206' },
  36. { label: '集美区', value: '350211' },
  37. { label: '同安区', value: '350212' },
  38. { label: '翔安区', value: '350213' }
  39. ],
  40. hospitalOptions: [],
  41. teamOptions: [],
  42. form: {
  43. range: '1'
  44. },
  45. loading: false,
  46. exportLoading: false,
  47. tableData: [],
  48. tableHeader: [
  49. { label: '居民姓名', prop: 'name', width: '100' },
  50. { label: '证件号码', prop: 'idcard', width: '100' },
  51. { label: '手机号', prop: 'mobile', width: '110' },
  52. { label: '年龄', prop: 'age', width: '90' },
  53. { label: '出生日期', prop: 'birthday', width: '90' },
  54. { label: '常住地址', prop: 'address', width: '130' },
  55. { label: '个人筛查状态', prop: 'statusName', width: '90' },
  56. { label: '基本信息状态', prop: 'infoStatusName', width: '90' },
  57. { label: '乳腺临床检查状态', prop: 'cliStatusName', width: '90' },
  58. { label: '乳腺超声初筛时间', prop: 'cduTime', width: '150' },
  59. { label: '乳腺超声评估结果', prop: 'cduResultName', width: '130' },
  60. { label: '乳腺超声评估机构', prop: 'cduOrg', width: '110' },
  61. { label: '乳腺超声评估人', prop: 'cudUser', width: '130' },
  62. { label: '乳腺钼靶评估时间', prop: 'molTime', width: '150' },
  63. { label: '乳腺钼靶评估结果', prop: 'molResultName', width: '130' },
  64. { label: '乳腺钼靶评估状态(待随访/已完成)', prop: 'molStatusName', width: '110' },
  65. { label: '乳腺病理结果', prop: 'bpatResultName', width: '130' },
  66. { label: '乳腺病理评估机构', prop: 'bpatOrg', width: '130' },
  67. { label: '乳腺病理随访时间', prop: 'bpatTime', width: '150' },
  68. { label: '乳腺癌分期状态(术前)', prop: 'opFrontName', width: '130' },
  69. { label: '乳腺癌分期状态(术后)', prop: 'opAfterName', width: '110' },
  70. { label: '宫颈初筛时间', prop: 'gynTime', width: '130' },
  71. { label: '宫颈评估机构', prop: 'cerOrg', width: '130' },
  72. { label: '宫颈评估人', prop: 'cerUser', width: '150' },
  73. { label: '宫颈评估时间', prop: 'cerTime', width: '130' },
  74. { label: '宫颈评估状态', prop: 'cerStatusName', width: '110' },
  75. { label: '宫颈评估人群', prop: 'screenResult', width: '130' }
  76. ],
  77. page: 1,
  78. size: 10,
  79. total: 0,
  80. level: 0,
  81. FormData: {}
  82. }
  83. },
  84. methods: {
  85. init() {
  86. var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole'))
  87. if (selectedRole.code.indexOf('350200') > -1) {
  88. this.level = 1 // 市卫健委
  89. this.areaOptions = [
  90. { label: '思明区', value: '350203' },
  91. { label: '海沧区', value: '350205' },
  92. { label: '湖里区', value: '350206' },
  93. { label: '集美区', value: '350211' },
  94. { label: '同安区', value: '350212' },
  95. { label: '翔安区', value: '350213' }
  96. ]
  97. } else if (selectedRole.code.length == 6) {
  98. this.level = 2 // 区管理
  99. this.areaOptions = [{ label: selectedRole.name.substring(0, 3), value: selectedRole.code }]
  100. this.form = {
  101. range: '1',
  102. town: selectedRole.code
  103. }
  104. this.getHospital(selectedRole.code)
  105. } else {
  106. this.level = 3 // 社区管理
  107. this.rangeOptions = [{ label: '社区', value: '2' }]
  108. this.areaOptions = [{ label: selectedRole.name.substring(0, 3), value: selectedRole.code.substring(0, 6) }]
  109. this.hospitalOptions = [{ name: selectedRole.name, code: selectedRole.code }]
  110. this.form = {
  111. range: '2',
  112. town: selectedRole.code.substring(0, 6),
  113. hospital: selectedRole.code
  114. }
  115. this.getTeam(selectedRole.code)
  116. }
  117. this.initTime()
  118. this.getList()
  119. },
  120. initTime() {
  121. var vm = this
  122. var now = new Date()
  123. vm.nowyear = vm.chooseYear = now.getFullYear()
  124. vm.years = []
  125. for (i = vm.nowyear; i >= 2013; i--) {
  126. vm.years.push(i)
  127. }
  128. },
  129. resetArea() {
  130. if (this.level == 1) {
  131. delete this.form.town
  132. delete this.form.hospital
  133. delete this.form.team
  134. } else if (this.level == 2) {
  135. delete this.form.hospital
  136. delete this.form.team
  137. } else {
  138. delete this.form.team
  139. }
  140. },
  141. back() {
  142. var vm = this
  143. vm.showTotalTable = true
  144. vm.serviceRecordVisable = false
  145. },
  146. getList() {
  147. var vm = this
  148. this.loading = true
  149. var params = {
  150. ...this.form,
  151. page: this.page,
  152. size: this.size,
  153. timeType: this.yearType
  154. }
  155. console.log('11111111111111111', this)
  156. if (this.yearType && this.yearType == 1) {
  157. if (this.chooseTime) {
  158. params.startTime = this.chooseTime[0]
  159. params.endTime = this.chooseTime[1]
  160. }
  161. } else if (this.yearType && this.yearType == 2) {
  162. if (this.chooseTime1) {
  163. params.startTime = this.chooseTime1[0]
  164. params.endTime = this.chooseTime1[1]
  165. }
  166. }
  167. httpRequest.get('doctor/twoCancers/count/patientArchive', { data: params }).then(function (res) {
  168. if (res.status == 200) {
  169. vm.tableData = res.detailModelList
  170. vm.total = res.totalCount
  171. }
  172. vm.loading = false
  173. })
  174. },
  175. onClickServiceRecord(record) {
  176. this.currentEditData = record.patient
  177. this.showTotalTable = false
  178. this.serviceRecordVisable = true
  179. },
  180. queryDate() {
  181. this.page = 1
  182. this.getList()
  183. },
  184. exportTable() {
  185. var vm = this
  186. var params = {
  187. ...this.form,
  188. page: this.page,
  189. size: this.size,
  190. timeType: this.yearType
  191. }
  192. console.log('11111111111111111', this)
  193. if (this.yearType && this.yearType == 1) {
  194. if (this.chooseTime) {
  195. params.startTime = this.chooseTime[0]
  196. params.endTime = this.chooseTime[1]
  197. }
  198. } else if (this.yearType && this.yearType == 2) {
  199. if (this.chooseTime1) {
  200. params.startTime = this.chooseTime1[0]
  201. params.endTime = this.chooseTime1[1]
  202. }
  203. }
  204. this.exportLoading = true
  205. var fileName = `两癌筛查居民档案${new Date().getTime()}.xls`
  206. httpRequest.downLoadFileForAjax('doctor/twoCancers/count/exportPatientArchive', fileName, params).then(function () {
  207. vm.exportLoading = false
  208. })
  209. },
  210. eliminateClick() {
  211. var selectedRole = JSON.parse(sessionStorage.getItem('selectedRole'))
  212. if (this.level == 1) {
  213. this.form = {
  214. range: 'town'
  215. }
  216. } else if (this.level == 2) {
  217. this.form = {
  218. range: 'town',
  219. area: selectedRole.code
  220. }
  221. this.getHospital(selectedRole.code)
  222. } else {
  223. this.form = {
  224. range: 'hospital',
  225. area: selectedRole.code.substring(0, 6),
  226. hospital: selectedRole.code
  227. }
  228. this.getTeam(selectedRole.code)
  229. }
  230. this.yearType = '1'
  231. this.chooseYear = new Date().getFullYear()
  232. this.chooseTime = null
  233. this.$forceUpdate()
  234. },
  235. getHospital(code) {
  236. var vm = this
  237. delete this.form.hospital
  238. delete this.form.team
  239. var params = {
  240. type: 5,
  241. code: code
  242. }
  243. httpRequest.post('common/district', { data: params }).then(function (res) {
  244. vm.hospitalOptions = [{ code: '', name: '全部' }]
  245. vm.hospitalOptions = vm.hospitalOptions.concat(res.list)
  246. })
  247. },
  248. getTeam(code) {
  249. var vm = this
  250. delete this.form.team
  251. var params = {
  252. hospital: code,
  253. area: this.form.area
  254. }
  255. httpRequest.get('statisticsExport/teamList', { data: params }).then(function (res) {
  256. vm.teamOptions = [{ id: '', name: '全部' }]
  257. vm.teamOptions = vm.teamOptions.concat(res.data)
  258. })
  259. },
  260. handleCurrentChange(val) {
  261. this.page = val
  262. this.getList()
  263. },
  264. handleSizeChange(val) {
  265. this.size = val
  266. this.getList()
  267. },
  268. openDialog(scope) {
  269. this.dialogVisible = true
  270. }
  271. },
  272. mounted() {
  273. this.init()
  274. }
  275. })