pruritusAssessment.vue 15KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440
  1. <template>
  2. <div class="patient-container">
  3. <patient-sidebar :id="patientID" defaultActive="5-11" @tran-patient="tranpatient"></patient-sidebar>
  4. <div>
  5. <div class="patient-app-container advice-container app-container">
  6. <div class='content_top' style="width: 100%;margin-bottom: 20px;">
  7. <div style="font-size: 20px;">瘙痒评估表</div>
  8. <div>
  9. <el-button @click="pruritushistory">历史评分</el-button>
  10. </div>
  11. </div>
  12. <div>
  13. <table class="table" border="1" style="width: 100%;">
  14. <thead>
  15. <tr>
  16. <th style="width: 10%;">项目</th>
  17. <th style="width: 57%;">结果</th>
  18. <th style="width: 3%;">得分</th>
  19. <th style="width: 30%;">说明</th>
  20. </tr>
  21. </thead>
  22. <tbody>
  23. <tr>
  24. <td class="start">痒的部位</td>
  25. <td>
  26. <div class="jiange"><!-- v-model="item.is_check" v-model="is_check1" v-model="is_check2"-->
  27. <span v-for="item in buwei" class="rightjiange" >
  28. <label><input type="checkbox" class="check" :value="item.id" v-model="item.is_check" @click="handleCheckedCitiesChange($event,item)"/>&nbsp;{{ item.label }}</label>
  29. </span>
  30. <label ><input type="checkbox" class="check" value="其他" v-model="is_check1" @click="qita_click"/>
  31. &nbsp;其他 <el-input v-model="buwei_input" style="width: 100px;"></el-input>
  32. </label>
  33. <label >
  34. <input type="checkbox" class="checkbox" value="全身" v-model="is_check2" @click="quan_change"/>&nbsp;全身
  35. </label>
  36. </div>
  37. </td>
  38. <td class="start">{{checked_points}}</td>
  39. <td class="saoyang">瘙痒部位:计分范围1~3分一个部位瘙痒计1分,最多得3分,选全身计3分</td>
  40. </tr>
  41. <tr>
  42. <td class="start">痒的程度</td>
  43. <td>
  44. <div class="jiange">
  45. <el-radio-group v-model="radio1" @change="radiochecked">
  46. <el-radio v-for="(item,index ) in chengdu" :label="item.value" :key="index" style="color: black;font-size: 15PX;">{{ item.label }}</el-radio>
  47. </el-radio-group>
  48. </div>
  49. </td>
  50. <td class="start">{{radio1_points}}</td>
  51. <td class="saoyang">瘙痒严重程度:计分范围1~5分</td>
  52. </tr>
  53. <tr>
  54. <td class="start">痒的频率</td>
  55. <td>
  56. <div class="jiange">
  57. <el-radio-group v-model="radio2" @change="radiochecked">
  58. <el-radio v-for="(item,index ) in pinlv" :label="item.value" :key="index" style="color: black;font-size: 15PX;">{{ item.label }}</el-radio>
  59. </el-radio-group>
  60. </div>
  61. </td>
  62. <td class="start">{{radio2_points}}</td>
  63. <td class="saoyang">瘙痒频率:计分范围1~5分瘙痒有过4次,每次<10min或有1次瘙痒>10min计1分,以此类推,一直持续计5分</td>
  64. </tr>
  65. <tr>
  66. <td class="start">痒对睡眠的影响</td>
  67. <td>
  68. <div class="jiange">
  69. <el-radio-group v-model="radio3" @change="radiochecked">
  70. <el-radio v-for="(item,index ) in yingxiang" :label="item.value" :key="index" style="color: black;font-size: 15PX;">{{ item.label }}</el-radio>
  71. </el-radio-group>
  72. </div>
  73. </td>
  74. <td class="start">{{radio3_points}}</td>
  75. <td class="saoyang">
  76. 瘙痒对睡眠的影响:计分范围0~6分无影响0分,一夜痒醒1次计2分,一夜痒醒2次计4分,一夜痒醒3次以上计6分
  77. </td>
  78. </tr>
  79. </tbody>
  80. </table>
  81. </div>
  82. <p style="margin: 20px 0px 10px 0px;">备注:总分得分范围3(轻度瘙痒)~19分(最大程度瘙痒)</p>
  83. <div class="content_top" style="margin-bottom: 10px ;">
  84. <div>
  85. <div class="bottoms">
  86. <span>总分:</span>
  87. <el-input v-model="pruritus_Totalpoints" style="width: 100px;"></el-input>分
  88. </div>
  89. <div class="bottoms">
  90. <span>评估日期:</span>
  91. <el-date-picker
  92. v-model="pruritus_date"
  93. type="date"
  94. value-format="yyyy-MM-dd"
  95. placeholder="选择日期"
  96. :clearable="false"
  97. style="width: 150px;">
  98. </el-date-picker>
  99. </div>
  100. <div class="bottoms">
  101. <span>评估人:</span>
  102. <el-select v-model="pruritus_appraiser" placeholder="请选择" style="width:150px;">
  103. <el-option
  104. v-for="item in pruritus_options"
  105. :key="item.id"
  106. :label="item.label"
  107. :value="item.id"
  108. >
  109. </el-option>
  110. </el-select>
  111. </div>
  112. </div>
  113. <div style="margin:5px 10px;">
  114. <el-button type="primary" @click="pruritus_click">确认</el-button>
  115. </div>
  116. </div>
  117. </div>
  118. </div>
  119. </div>
  120. </template>
  121. <script>
  122. import PatientSidebar from '../components/PatientSidebar.vue'
  123. import { uParseTime } from '@/utils/tools'
  124. import {savePatientHpressuresore} from '@/api/fallassement'
  125. export default {
  126. components:{
  127. PatientSidebar
  128. },
  129. data(){
  130. return{
  131. patientID:0,
  132. checkList:[],
  133. radio1:'',
  134. radio2:'',
  135. radio3:'',
  136. input:'',
  137. ball:'',
  138. radio1_points:0,
  139. radio2_points:0,
  140. radio3_points:0,
  141. checked_points:0,
  142. // pruritus_options:[],
  143. pruritus_options:[{id:1,label:'寒千落'},{id:2,label:'千仞雪'},{id:3,label:'千亦雪'},],
  144. pruritus_appraiser:'',
  145. pruritus_date:this.getTime(new Date()),
  146. buwei:[{id:1,label:'躯体',is_check:false,check:0},{id:2,label:'上肢',is_check:false,check:0},{id:3,label:'下肢',is_check:false,check:0},{id:4,label:'头皮',is_check:false,check:0},],
  147. chengdu:[{value:1,label:'不要抓(1)'},{value:2,label:'要抓但没有抓痕(2)'},{value:3,label:'抓出抓痕才能止痒(3)'},{value:4,label:'经常抓出抓痕(4)'},{value:5,label:'完全坐立不安(5)'}],
  148. pinlv:[{value:1,label:'很少时候(1)'},{value:2,label:'较少时候(2)'},{value:3,label:'较多时候(3)'},{value:4,label:'很多时候(4)'},{value:5,label:'一直持续(5)'}],
  149. yingxiang:[{value:0,label:'无影响(0)'},{value:2,label:'一夜痒醒一次(2)'},{value:4,label:'一夜痒醒两次(4)'},{value:6,label:'一夜痒醒三次(6)'}],
  150. buwei_show:[],
  151. buwei_show1:[],
  152. value:'',
  153. value1:'',
  154. num:0,
  155. is_check1:false,
  156. check1:0,
  157. is_check2:false,
  158. check2:0,
  159. buwei_input:'',
  160. Patient_info:{name:'',dialysis_no:''},
  161. }
  162. },
  163. created(){
  164. const id = this.$route.params && this.$route.params.id
  165. this.patientID = parseInt(id)
  166. },
  167. methods:{
  168. // 痒的部位选项
  169. handleCheckedCitiesChange(e,item){
  170. console.log('333333',item);
  171. for(let i in this.buwei){
  172. if(item.label==this.buwei[i].label){
  173. if(item.check==0){
  174. this.buwei[i].check = 1
  175. this.buwei[i].is_check = true
  176. if(this.num <3){
  177. if(this.is_check2 == true){
  178. this.is_check2 = false
  179. this.check = 0
  180. this.checked_points = 0
  181. }
  182. console.log('1111',this.buwei[i]);
  183. this.num++
  184. this.checked_points = this.checked_points + 1
  185. }
  186. if(this.buwei_show1.length >0){
  187. for(let j in this.buwei_show1){
  188. if('全身' == this.buwei_show1[j]){
  189. let index = this.buwei_show1.indexOf(this.buwei_show1[j]);
  190. this.buwei_show1.splice(index,1)
  191. }
  192. }
  193. }
  194. this.buwei_show.push(item.id)
  195. this.buwei_show1.push(item.label)
  196. console.log('this.buwei_show',this.buwei_show);
  197. }else{
  198. this.buwei[i].check = 0
  199. this.buwei[i].is_check = false
  200. console.log('2222',this.buwei[i]);
  201. this.num--
  202. this.checked_points = this.checked_points - 1
  203. if(this.buwei_show.length >0){
  204. for(let j in this.buwei_show){
  205. if(item.id == this.buwei_show[j]){
  206. let index = this.buwei_show.indexOf(this.buwei_show[j]);
  207. this.buwei_show.splice(index,1)
  208. }
  209. }
  210. for(let j in this.buwei_show1){
  211. if(item.label == this.buwei_show1[j]){
  212. let index = this.buwei_show1.indexOf(this.buwei_show1[j]);
  213. this.buwei_show1.splice(index,1)
  214. }
  215. }
  216. }
  217. console.log('this.buwei_show2',this.buwei_show);
  218. }
  219. }
  220. }
  221. },
  222. // 痒的部位全部选项
  223. quan_change(e){
  224. const ball=e.target.value
  225. console.log(ball);
  226. if(ball=='全身'){
  227. if(this.is_check2 == false){
  228. this.check2 = 1
  229. this.is_check2 = true
  230. this.check1 = 0
  231. this.is_check1 = false
  232. this.buwei_show.length = 0
  233. this.checked_points =3
  234. this.num = 0
  235. for(let i in this.buwei){
  236. if(this.buwei[i].is_check == true){
  237. this.buwei[i].is_check =false
  238. this.buwei[i].check = 0
  239. }
  240. }
  241. this.buwei_show1.length = 0
  242. this.buwei_show1.push('全身')
  243. console.log('uuuu',this.check2,this.is_check2);
  244. }else{
  245. this.check2 = 0
  246. this.is_check2 = false
  247. this.checked_points =0
  248. this.num = 0
  249. for(let j in this.buwei_show1){
  250. if(ball == this.buwei_show1[j]){
  251. let index = this.buwei_show1.indexOf(this.buwei_show1[j]);
  252. this.buwei_show1.splice(index,1)
  253. }
  254. }
  255. console.log('iiiii',this.check2,this.is_check2);
  256. }
  257. }
  258. },
  259. // 痒的部位其它选项
  260. qita_click(e){
  261. const ball=e.target.value
  262. console.log(ball);
  263. if(ball =='其他'){
  264. console.log('this.is_check1',this.is_check1);
  265. if(this.is_check1 == false){
  266. this.check1 = 1
  267. this.is_check1 = true
  268. this.check2 = 0
  269. this.is_check2 = false
  270. if(this.num < 3){
  271. this.checked_points =this.checked_points + 1
  272. this.num++
  273. }
  274. if(this.buwei_show1.length >0){
  275. for(let j in this.buwei_show1){
  276. if('全身' == this.buwei_show1[j]){
  277. let index = this.buwei_show1.indexOf(this.buwei_show1[j]);
  278. this.buwei_show1.splice(index,1)
  279. }
  280. }
  281. }
  282. this.buwei_show1.push(ball)
  283. }else{
  284. this.check1 = 0
  285. this.is_check1 = false
  286. if(this.num < 3){
  287. this.checked_points =this.checked_points - 1
  288. this.num--
  289. }
  290. for(let j in this.buwei_show1){
  291. if(ball == this.buwei_show1[j]){
  292. let index = this.buwei_show1.indexOf(this.buwei_show1[j]);
  293. this.buwei_show1.splice(index,1)
  294. }
  295. }
  296. }
  297. }
  298. },
  299. // 单选
  300. radiochecked(e){
  301. console.log('eeeee',e);
  302. if(e == this.radio1){
  303. this.radio1_points =e
  304. this.radio1 = e
  305. }
  306. if(e == this.radio2){
  307. this.radio2_points =e
  308. this.radio2 = e
  309. }
  310. if(e == this.radio3){
  311. this.radio3_points =e
  312. this.radio3 = e
  313. }
  314. },
  315. // 确认
  316. pruritus_click(){
  317. const data={}
  318. var list = []
  319. data['radio1'] = this.radio1
  320. data['radio2'] = this.radio2
  321. data['radio3'] = this.radio3
  322. data['date'] = this.pruritus_date
  323. data['appraiser'] = this.pruritus_appraiser
  324. data['total'] = this.pruritus_Totalpoints
  325. data['buwei'] = this.buwei_show
  326. data['is_check1'] = this.is_check1
  327. data['check1'] = this.check1
  328. data['buwei_input'] = this.buwei_input
  329. data['is_check2'] = this.is_check2
  330. data['check2'] = this.check2
  331. data['num'] = this.num
  332. data['buwei1'] = this.buwei_show1
  333. data['buwei2'] =this.buwei
  334. data['checked_points'] = this.checked_points
  335. list.push(data)
  336. var params={
  337. patient_id:this.patientID,
  338. record_date:this.pruritus_date,
  339. is_type:9,
  340. list:list,
  341. }
  342. console.log('params----',params);
  343. savePatientHpressuresore(params).then(response =>{
  344. if(response.data.state == 1){
  345. const pruit = response.data.data.pedFallssessment
  346. console.log('11111',pruit)
  347. this.$message({message:'保存成功',type:'success'})
  348. }
  349. })
  350. },
  351. // 转换时间
  352. getTime(val) {
  353. if(val < 0){
  354. return ""
  355. }
  356. if(val == ""){
  357. return ""
  358. }else {
  359. return uParseTime(val, '{y}-{m}-{d}')
  360. }
  361. },
  362. // 历史
  363. pruritushistory(){
  364. this.$router.push({
  365. path: '/patients/pruritus_history',
  366. query:{patient_id:this.patientID,
  367. Patient_info:this.Patient_info}
  368. })
  369. },
  370. // 患者信息
  371. tranpatient(event){
  372. console.log('event',event);
  373. this.Patient_info={
  374. name:event.name,
  375. dialysis_no:event.dialysis_no
  376. }
  377. },
  378. },
  379. computed:{
  380. pruritus_Totalpoints(){
  381. return this.checked_points + this.radio1_points + this.radio2_points +this.radio3_points
  382. }
  383. }
  384. }
  385. </script>
  386. <style lang="scss" scoped>
  387. .content_top{
  388. display: flex;
  389. justify-content: space-between;
  390. }
  391. .table{
  392. border: 1px solid #DCDFE6;
  393. border-collapse:collapse;
  394. border-spacing: 0;
  395. thead th{
  396. background: #0077ff9f;
  397. color: white;
  398. text-align: center;
  399. height: 40px;
  400. }
  401. tbody td{
  402. height: 40px;
  403. }
  404. .start{
  405. text-align: center;
  406. }
  407. .bing{
  408. width: 150px;
  409. text-align: center;
  410. }
  411. .bg_color{
  412. background: rgb(243, 240, 240);
  413. }
  414. .jiange{
  415. margin-left: 20px;
  416. color: black;
  417. }
  418. .rightjiange{
  419. margin-right: 40px;
  420. font-size: 15px;
  421. }
  422. input{
  423. -webkit-appearance: checkbox;
  424. }
  425. .saoyang{
  426. padding: 5px;
  427. }
  428. }
  429. .bottoms{
  430. display: inline-block;
  431. margin-left: 10px;
  432. margin-top: 5px;
  433. }
  434. </style>