index.js 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  1. // 慢阻肺患者档案-编辑
  2. var template = ''
  3. $.ajax('../../../component/statistics/CopdPatientRecordEdit/index.html',{
  4. data: {},
  5. dataType: 'html',
  6. cache: false,
  7. timeout: 60000,
  8. async: false,
  9. error: function(res) {
  10. },
  11. success: function(res) {
  12. template = res
  13. }
  14. })
  15. let vm
  16. Vue.component('copd-patient-record-edit', {
  17. template: template,
  18. props: ['editData'],
  19. data() {
  20. return {
  21. formData:{},
  22. nationDict:[],
  23. dicName:['jkcopd_isLive','jkcopd_first_area','jkcopd_first_org_level', 'jkcopd_marriage','jkcopd_occupation','jkcopd_smoke','jkcopd_drink','jkcopd_archivesStatus','jkcopd_disease_conversion','jkcopd_firstVisitType','jkcopd_educational','idCardType'],
  24. marriageArr:[],
  25. idCardTypeArr:[],
  26. firstAreaArr:[],
  27. isLiveArr:[],
  28. orgLevelArr:[],
  29. occupationArr:[],
  30. smokeArr:[],
  31. drinkArr:[],
  32. archivesArr:[],
  33. conversionArr:[],
  34. firstVisitTypeArr:[],
  35. educationalArr:[],
  36. copdArr:[{value:'是',code:1},{value:'否',code:0}],
  37. addressOptions:[],
  38. props: {
  39. label: 'name',
  40. value: 'code',
  41. children: 'children'
  42. },
  43. addressVal:[],
  44. resiginAddressVal:[],
  45. docInfo: JSON.parse(window.localStorage.getItem('docInfo')),
  46. }
  47. },
  48. created() {
  49. vm=this
  50. },
  51. mounted() {
  52. var vm=this
  53. this.formData=this.editData
  54. console.log('222222222222222222222222',this.formData)
  55. if(this.formData.liveStreet){
  56. this.addressVal=[this.formData.liveProvince,this.formData.liveCity,this.formData.liveTown,this.formData.liveStreet]
  57. this.getDistrict(0)
  58. }else{
  59. this.addressVal=[this.formData.liveProvince,this.formData.liveCity,this.formData.liveTown]
  60. this.getDistrict(0)
  61. }
  62. this.getNation()
  63. if(this.formData.liveStreet){
  64. this.resiginAddressVal=[this.formData.registProvince,this.formData.registCity,this.formData.registTown,this.formData.registStreet]
  65. this.getDistrict(1)
  66. console.log('999999999999999999999999999999',this.resiginAddressVal)
  67. }else{
  68. this.resiginAddressVal=[this.formData.registProvince,this.formData.registCity,this.formData.registTown]
  69. this.getDistrict(1)
  70. }
  71. this.dicName.forEach(function(item) {
  72. vm.getDictByDictName(item)
  73. });
  74. },
  75. methods: {
  76. handleItemChange(val) {
  77. // 获取地址
  78. if (val.length == 1) {
  79. // 获取市
  80. this.baseCityList(val[0])
  81. }
  82. if (val.length == 2) {
  83. // 获取区
  84. this.baseTownList(val)
  85. }
  86. if (val.length == 3) {
  87. // 获取区
  88. this.stressList(val)
  89. }
  90. },
  91. //字典
  92. getDictByDictName(value){
  93. var vm=this
  94. statisticAPI.getDictByDictName({name:value}).then(function(res){
  95. if(value=='jkcopd_marriage'){
  96. vm.marriageArr=res.list
  97. }else if(value=='jkcopd_occupation'){
  98. vm.occupationArr=res.list
  99. }else if(value=='jkcopd_smoke'){
  100. vm.smokeArr=res.list
  101. }else if(value=='jkcopd_drink'){
  102. vm.drinkArr=res.list
  103. }else if(value=='jkcopd_archivesStatus'){
  104. vm.archivesArr=res.list
  105. }else if(value=='jkcopd_disease_conversion'){
  106. vm.conversionArr=res.list
  107. }else if(value=='jkcopd_firstVisitType'){
  108. vm.firstVisitTypeArr=res.list
  109. }else if(value=='jkcopd_educational'){
  110. vm.educationalArr=res.list
  111. }else if(value=='idCardType'){
  112. vm.idCardTypeArr=res.list
  113. }else if(value=='jkcopd_first_area'){
  114. vm.firstAreaArr=res.list
  115. }else if(value=='jkcopd_first_org_level'){
  116. vm.orgLevelArr=res.list
  117. }else if(value=='jkcopd_isLive'){
  118. vm.isLiveArr=res.list
  119. }
  120. })
  121. },
  122. getNation(){
  123. var vm=this
  124. statisticAPI.getNationDict().then(function(res){
  125. vm.nationDict= res.data
  126. console.log('2222222222222222',vm.nationDict)
  127. })
  128. },
  129. getDistrict(id){
  130. var vm =this
  131. homeAPI.getDistrict({ type:1 ,code:'' }).then(function(res) {
  132. var detailModelList=res.list
  133. detailModelList.forEach(function(item){
  134. item.children = []
  135. })
  136. vm.addressOptions=detailModelList
  137. if(vm.formData.liveProvince&&id==0){
  138. vm.baseCityList(vm.formData.liveProvince,id)
  139. }
  140. if(vm.formData.registProvince&&id==1){
  141. vm.baseCityList(vm.formData.registProvince,id)
  142. }
  143. })
  144. },
  145. onClickNavLink(id) {
  146. var element = document.getElementById(id);
  147. var top = element.offsetTop;
  148. window.scrollTo({ top: top, behavior: 'smooth' });
  149. },
  150. //市
  151. baseCityList:function(code,id){
  152. var vm = this
  153. var activeIndex = null
  154. vm.addressOptions.forEach(function(item, index) {
  155. if (item.code == code) {
  156. activeIndex = index
  157. }
  158. })
  159. homeAPI.getDistrict({ type:2 ,code:code }).then(function(res) {
  160. if (res.status == 200) {
  161. var detailModelList = res.list
  162. detailModelList.forEach(item => {
  163. item.children = []
  164. })
  165. vm.addressOptions[activeIndex].children = detailModelList
  166. if(vm.addressVal.length&&id==0){
  167. vm.baseTownList([vm.addressVal[0], vm.addressVal[1]],id)
  168. }
  169. if(vm.resiginAddressVal.length&&id==1){
  170. vm.baseTownList([vm.resiginAddressVal[0], vm.resiginAddressVal[1]],id)
  171. }
  172. }
  173. })
  174. },
  175. //县
  176. baseTownList(val,id) {
  177. var vm = this
  178. var provinceIndex = null
  179. var activeIndex = null
  180. vm.addressOptions.forEach(function(item, index){
  181. if (item.code == val[0]) {
  182. var children = item.children
  183. provinceIndex = index
  184. children.forEach(function(item, idx) {
  185. if (item.code == val[1]) {
  186. activeIndex = idx
  187. }
  188. })
  189. }
  190. })
  191. homeAPI.getDistrict({ type:3,code:val[1] }).then( function(res){
  192. if (res.status == 200) {
  193. var detailModelList = res.list
  194. if(val[1]=='350200'){
  195. detailModelList.forEach(function(item){
  196. item.children = []
  197. })
  198. }
  199. if (vm.addressOptions[provinceIndex].children[activeIndex]) {
  200. vm.addressOptions[provinceIndex].children[activeIndex].children = detailModelList
  201. if(vm.addressVal.length&&id==0){
  202. vm.stressList([vm.addressVal[0], vm.addressVal[1],vm.addressVal[2]])
  203. }
  204. if(vm.resiginAddressVal.length&&id==1){
  205. vm.stressList([vm.resiginAddressVal[0], vm.resiginAddressVal[1],vm.resiginAddressVal[2]])
  206. }
  207. }
  208. }
  209. })
  210. },
  211. //街道
  212. stressList(val) {
  213. var vm = this
  214. var provinceIndex = null
  215. var activeIndex = null
  216. var xIndex=null
  217. vm.addressOptions.forEach(function(item, index) {
  218. if (item.code == val[0]) {
  219. var children = item.children
  220. provinceIndex = index
  221. children.forEach(function(item, idx) {
  222. if (item.code == val[1]) {
  223. activeIndex = idx
  224. var xItem=item.children
  225. xItem.forEach(function(item,xianIndex){
  226. if(item.code==val[2]){
  227. xIndex=xianIndex
  228. }
  229. })
  230. }
  231. })
  232. }
  233. })
  234. homeAPI.getDistrict({ type:4,code:val[2] }).then( function(res){
  235. if (res.status == 200) {
  236. var detailModelList = res.list
  237. console.log(vm.addressOptions, 'vm.addressOptions')
  238. if (vm.addressOptions[provinceIndex].children[activeIndex].children[xIndex]) {
  239. vm.addressOptions[provinceIndex].children[activeIndex].children[xIndex].children = detailModelList
  240. }
  241. }
  242. })
  243. },
  244. cancel:function(){
  245. EventBus.$emit('copd-reset-select')
  246. },
  247. updJkCopdPatient(){
  248. var vm =this
  249. if(!this.formData.mobile){
  250. this.$message.error('请填写手机号!')
  251. return false
  252. }
  253. if(this.formData.sexName=='男'){
  254. this.formData.sex=1
  255. }else{
  256. this.formData.sex=2
  257. }
  258. this.addressVal.forEach(function(item,index){
  259. if(index==0){
  260. vm.formData.liveProvince=item
  261. vm.formData.liveProvinceName=vm.$refs.cascader.currentLabels[index]
  262. }else if(index==1){
  263. vm.formData.liveCity=item
  264. vm.formData.liveCityName=vm.$refs.cascader.currentLabels[index]
  265. }else if(index==2){
  266. vm.formData.liveTown=item
  267. vm.formData.liveTownName=vm.$refs.cascader.currentLabels[index]
  268. }else if(index==3){
  269. vm.formData.liveStreet=item
  270. vm.formData.liveStreetName=vm.$refs.cascader.currentLabels[index]
  271. }
  272. })
  273. this.resiginAddressVal.forEach(function(item,index){
  274. if(index==0){
  275. vm.formData.registProvince=item
  276. vm.formData.registProvinceName=vm.$refs.cas.currentLabels[index]
  277. }else if(index==1){
  278. vm.formData.registCity=item
  279. vm.formData.registCityName=vm.$refs.cas.currentLabels[index]
  280. }else if(index==2){
  281. vm.formData.registTown=item
  282. vm.formData.registTownName=vm.$refs.cas.currentLabels[index]
  283. }else if(index==3){
  284. vm.formData.registStreet=item
  285. vm.formData.registStreetName=vm.$refs.cas.currentLabels[index]
  286. }
  287. })
  288. statisticAPI.updJkCopdPatient({jsonData:JSON.stringify(vm.formData),doctor:vm.docInfo.code}).then(
  289. function(res){
  290. if(res.status==200){
  291. EventBus.$emit('copd-reset-save')
  292. }
  293. }
  294. )
  295. }
  296. }
  297. });