index.js 10 KB

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