blood_table.vue 16KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482
  1. <template>
  2. <div class="main-contain">
  3. <div class="position">
  4. <div>
  5. <span>
  6. <el-button @click="return_click" type="text" icon="el-icon-arrow-left">返回</el-button>
  7. </span>&nbsp;&nbsp;
  8. <span>患者血压详情</span>
  9. </div>
  10. </div>
  11. <div class="app-container">
  12. <div class="page_patientControlAnalysis">
  13. <div style="display: flex;margin-bottom: 20px;">
  14. <div style="flex: 2;display: flex;flex-wrap:wrap">
  15. <div>
  16. 日期:
  17. <el-select v-model="date_value" @change="datachange" placeholder="请选择" style="width: 100px;">
  18. <el-option
  19. v-for="item in date_options"
  20. :key="item.value"
  21. :label="item.label"
  22. :value="item.value">
  23. </el-option>
  24. </el-select>
  25. </div>
  26. <div style="margin:0 10px;">
  27. <el-date-picker
  28. v-model="start_date"
  29. type="date"
  30. value-format="yyyy-MM-dd"
  31. placeholder="选择日期"
  32. style="width: 150px;">
  33. </el-date-picker>
  34. <span>-</span>
  35. <el-date-picker
  36. v-model="end_date"
  37. type="date"
  38. value-format="yyyy-MM-dd"
  39. placeholder="选择日期"
  40. style="width: 150px;">
  41. </el-date-picker>
  42. </div>
  43. <div>
  44. 状态:
  45. <el-select v-model="status_value" placeholder="请选择" style="width: 100px;">
  46. <el-option :key="0" label="不限" :value="0"></el-option>
  47. <el-option
  48. v-for="item in status_options"
  49. :key="item.value"
  50. :label="item.label"
  51. :value="item.value">
  52. </el-option>
  53. </el-select>
  54. </div>
  55. </div>
  56. <div style="flex: 1;">
  57. <div>
  58. <el-button type="primary" @click="deil_click">查询</el-button>
  59. <el-button type="primary" @click="exportExcel">导出</el-button>
  60. </div>
  61. </div>
  62. </div>
  63. <el-table :data="tableData" border style="width: 100%"
  64. :header-cell-style="{textAlign: 'center'}"
  65. :cell-style="{ textAlign: 'center' }"
  66. height="380">
  67. <el-table-column
  68. prop="index"
  69. label="序号"
  70. width="50">
  71. </el-table-column>
  72. <el-table-column
  73. prop="dialysis_no"
  74. label="透析号"
  75. width="70">
  76. </el-table-column>
  77. <el-table-column
  78. prop="patient_name"
  79. label="患者姓名"
  80. width="80">
  81. </el-table-column>
  82. <el-table-column
  83. prop="gender"
  84. label="性别"
  85. width="50">
  86. </el-table-column>
  87. <el-table-column
  88. prop="age"
  89. label="年龄"
  90. width="50">
  91. </el-table-column>
  92. <el-table-column
  93. prop="dialysis_date"
  94. label="透析日期"
  95. width="100">
  96. </el-table-column>
  97. <el-table-column
  98. prop="dryweight"
  99. label="干体重"
  100. width="70">
  101. </el-table-column>
  102. <el-table-column
  103. prop="UltrafiltrationVol"
  104. label="超滤总量(L)"
  105. width="90">
  106. </el-table-column>
  107. <el-table-column
  108. prop="actual_ultrafiltration"
  109. label="实际超滤量(ml)"
  110. width="100">
  111. </el-table-column>
  112. <el-table-column
  113. prop="ultrafiltration_rate"
  114. label="超滤率"
  115. width="70">
  116. </el-table-column>
  117. <el-table-column
  118. prop="preDialysisBP"
  119. label="透前血压"
  120. width="90">
  121. </el-table-column>
  122. <el-table-column
  123. prop="monitoringbp"
  124. label="监测记录血压">
  125. </el-table-column>
  126. <el-table-column
  127. prop="PostDialysisBP"
  128. label="透后血压"
  129. width="90">
  130. </el-table-column>
  131. </el-table>
  132. <div style="text-align: right;margin-top: 10px;">
  133. <el-pagination
  134. @size-change="handleSizeChange"
  135. @current-change="handleCurrentChange"
  136. :current-page="currentPage"
  137. :page-sizes="[50,100, 200, 300, 400]"
  138. :page-size="limit"
  139. layout="total, sizes, prev, pager, next, jumper"
  140. :total="total">
  141. </el-pagination>
  142. </div>
  143. </div>
  144. </div>
  145. <!-- 弹窗 -->
  146. </div>
  147. </template>
  148. <script>
  149. import * as echarts from 'echarts';
  150. import XLSX from 'xlsx';
  151. import { uParseTime } from "@/utils/tools";
  152. import {Getbpdetail} from '../../../../api/qcd'
  153. import { forEach } from 'jszip';
  154. import html2canvas from "html2canvas"
  155. export default {
  156. components:{
  157. },
  158. data(){
  159. return{
  160. date_value:4,
  161. start_date:'',
  162. end_date:this.getTime(new Date()),
  163. mode:'',
  164. date_mode:'',
  165. source:'',
  166. dialyze_value:0,
  167. dialyze_dialog:false,
  168. currentPage:1,
  169. limit:50,
  170. total:0,
  171. tableData:[],
  172. status_value:1,
  173. status_options:[{value:1,label:'达标'},{value:2,label:'不达标'}],
  174. date_options:[{value:1,label:'最近七天'},{value:2,label:'本周'},{value:3,label:'上周'},{value:4,label:'本月'},
  175. {value:5,label:'上月'},{value:6,label:'本年'},{value:7,label:'上一年'}
  176. ],
  177. date_mode_options:[{value:1,label:'按周'},{value:2,label:'按天'},{value:3,label:'按月'},{value:4,label:'按年'}],
  178. source_options:[{value:1,label:'以开始透析为准'},{value:2,label:'以排班为准'}],
  179. input:'',
  180. }
  181. },
  182. methods:{
  183. // 返回
  184. return_click(){
  185. this.$router.push('/Dialysisanalysis/qualitycontrol/weightblood')
  186. },
  187. // 导出excel
  188. exportExcel(){
  189. let tableData = [
  190. ['序号', '透析号', '患者姓名','性别','年龄', '透析日期','干体重', '超滤总量','实际超滤量','超滤率','透前血压','监测记录血压','透后血压']//导出表头
  191. ]
  192. this.tableData.forEach((item,index) =>{
  193. let rowdata=[]
  194. rowdata=[
  195. item.index,
  196. item.dialysis_no,
  197. item.patient_name,
  198. item.gender,
  199. item.age,
  200. item.dialysis_date,
  201. item.dryweight,
  202. item.UltrafiltrationVol,
  203. item.actual_ultrafiltration,
  204. item.ultrafiltration_rate,
  205. item.preDialysisBP,
  206. item.monitoringbp,
  207. item.PostDialysisBP,
  208. ]
  209. tableData.push(rowdata)
  210. })
  211. let workSheet = XLSX.utils.aoa_to_sheet(tableData);
  212. let bookNew = XLSX.utils.book_new();
  213. XLSX.utils.book_append_sheet(bookNew, workSheet, '患者血压详情') // 工作簿名称
  214. let name = '患者血压详情'+ '.xlsx'
  215. XLSX.writeFile(bookNew, name) // 保存的文件名
  216. },
  217. // 详情查询
  218. deil_click(){
  219. this.Getdialyzerdetail(this.status_value)
  220. },
  221. // 选择日期
  222. datachange(eve){
  223. if(eve ==1){
  224. this.start_date = this.getPreviousDate(7)
  225. this.end_date = this.getTime(new Date())
  226. }else if(eve==2){
  227. this.start_date = this.getFirstDayOfWeek(new Date())
  228. this.end_date = this.getTime(new Date())
  229. console.log('this.start_date', this.start_date);
  230. }else if(eve ==3){
  231. var date=new Date()
  232. date.setDate(date.getDate()-7 - date.getDay() + 1);
  233. var m =''
  234. var d = ''
  235. if(date.getMonth() + 1<10){
  236. m = '0'+(date.getMonth() + 1)
  237. }else{
  238. m = date.getMonth() + 1
  239. }
  240. if(date.getDate()<10){
  241. d = '0'+date.getDate()
  242. }else{
  243. d = date.getDate()
  244. }
  245. // this.start_date = date.getFullYear() + "-" + (date.getMonth() + 1) + "-" + date.getDate() ;
  246. this.start_date = date.getFullYear() + "-" + m + "-" + d ;
  247. date.setDate(date.getDate() +6);
  248. var mm = ''
  249. var dd = ''
  250. if(date.getMonth() + 1<10){
  251. mm = '0'+(date.getMonth() + 1)
  252. }else{
  253. mm = date.getMonth() + 1
  254. }
  255. if(date.getDate()<10){
  256. dd = '0'+date.getDate()
  257. }else{
  258. dd = date.getDate()
  259. }
  260. // if(date.getMonth() + 1<10)
  261. // this.end_date = date.getFullYear() + "-" + (date.getMonth() + 1) + "-" + date.getDate();
  262. this.end_date = date.getFullYear() + "-" + mm + "-" + dd ;
  263. console.log('this.end_date',this.end_date);
  264. }else if(eve ==4){
  265. this.start_date = this.getFirstDayOfMonth(new Date())
  266. this.end_date = this.getTime(new Date())
  267. }else if(eve ==5){
  268. this.getLastMonthFirstDay()
  269. this.getLastMonthLastDay()
  270. }else if(eve == 6){
  271. this.start_date = this.getFirstDayOfYear(new Date())
  272. this.end_date = this.getTime(new Date())
  273. }else if(eve == 7){
  274. this.getLastYearFirstDay()
  275. this.getLastYearLastDay()
  276. }
  277. console.log('eve',eve);
  278. },
  279. // 详情数据源
  280. Getdialyzerdetail(value){
  281. const params={
  282. status_type:value,
  283. start_time:this.start_date,
  284. end_time:this.end_date,
  285. page:this.currentPage,
  286. limit:this.limit,
  287. }
  288. Getbpdetail(params).then(response =>{
  289. if(response.data.state == 1){
  290. const list = response.data.data.list
  291. const table=[]
  292. if(list.length > 0){
  293. list.forEach((item,index)=>{
  294. const obj ={
  295. index:index+1,
  296. dialysis_no:item.dialysis_no,
  297. patient_name:item.patient_name,
  298. gender:this.getgender(item.gender),
  299. age:item.age,
  300. dialysis_date:this.getTime(item.assessment_date),
  301. dryweight:item.dry_weight,
  302. UltrafiltrationVol:item.ultrafiltration_vol/1000,
  303. actual_ultrafiltration:item.actual_ultrafiltration,
  304. ultrafiltration_rate:item.ultrafiltration_rate,
  305. preDialysisBP:item.pre_dialysis_bp,
  306. monitoringbp:item.monitoring_bp,
  307. PostDialysisBP:item.post_dialysis_bp,
  308. }
  309. table.push(obj)
  310. })
  311. this.tableData = table
  312. this.total = response.data.data.total
  313. }
  314. }
  315. console.log('77777血压表格',response);
  316. })
  317. },
  318. // 首先定义一个getPreviousDate函数,方便调用
  319. getPreviousDate(numOfDays) {
  320. var date = new Date();
  321. date.setDate(date.getDate() - numOfDays);
  322. var year = date.getFullYear();
  323. if(date.getMonth() + 1<10){
  324. var month = '0'+(date.getMonth() + 1);
  325. }else{
  326. var month = date.getMonth() + 1;
  327. }
  328. if(date.getDate()<10){
  329. var day = '0'+date.getDate();
  330. }else{
  331. var day = date.getDate();
  332. }
  333. return year + "-" + month + "-" + day;
  334. },
  335. // 本周
  336. getFirstDayOfWeek(date){
  337. var weekday = date.getDay()
  338. date.setDate(date.getDate()-weekday+1);//往前算(weekday-1)天,年份、月份会自动变化
  339. return this.timeFormat(date);
  340. },
  341. // 本月
  342. getFirstDayOfMonth (date) {
  343. date.setDate(1);
  344. return this.timeFormat(date);
  345. },
  346. //上个月第一天
  347. getLastMonthFirstDay() {
  348. var date = new Date();
  349. date.setDate(0);
  350. var y = date.getFullYear(); //获取年份
  351. var m = date.getMonth() + 1; //获取月份
  352. m = m < 10 ? "0" + m : m;
  353. this.start_date = [y, m, '01'].join("-")
  354. // return [y, m, '01'].join("-");
  355. },
  356. // 上个月最后一天
  357. getLastMonthLastDay() {
  358. var date = new Date();
  359. date.setDate(0);
  360. var y = date.getFullYear(); //获取年份
  361. var m = date.getMonth() + 1; //获取月份
  362. var d = new Date(y, m, 0).getDate(); //获取当月最后一日
  363. m = m < 10 ? "0" + m : m; //月份补 0
  364. d = d < 10 ? "0" + d : d; //日数补 0
  365. this.end_date = [y, m, d].join("-")
  366. // return [y, m, d].join("-");
  367. },
  368. // 本年
  369. getFirstDayOfYear (date) {
  370. date.setDate(1);
  371. date.setMonth(0);
  372. return this.timeFormat(date);
  373. },
  374. // 上一年第一天
  375. getLastYearFirstDay() {
  376. let date = new Date();
  377. const year= date.setFullYear(date.getFullYear() - 1); // 设置年份为前一年
  378. const start_month= date.setMonth(0); // 设置月份为1月(注意月份是从0开始的)
  379. const start_day = date.setDate(1); // 设置日期为1日
  380. // const last_month = date.setMonth(11); // 设置月份为12月
  381. // const last_day = date.setDate(0); // 设置日期为0,这将自动设置为该月的最后一天
  382. // this.start_date = year+ "-" +start_month+ "-" +start_day
  383. this.start_date = this.getTime(start_day)
  384. // return this.start_date
  385. },
  386. // 上一年最后一天
  387. getLastYearLastDay() {
  388. let date = new Date();
  389. const year= date.setFullYear(date.getFullYear() - 1); // 设置年份为前一年
  390. const last_month = date.setMonth(12); // 设置月份为12月
  391. const last_day = date.setDate(0);// 设置日期为0,这将自动设置为该月的最后一天
  392. // this.end_date = year+ "-" +last_month+ "-" +last_day
  393. this.end_date = this.getTime(last_day)
  394. console.log('this.end_date',this.end_date);
  395. // return this.end_date;
  396. },
  397. // 日期格式化
  398. timeFormat(date) {
  399. if (!date || typeof(date) === "string") {
  400. this.error("参数异常,请检查...");
  401. }
  402. var y = date.getFullYear(); //年
  403. if(date.getMonth() + 1<10){
  404. var m ='0'+(date.getMonth() + 1); //月
  405. }else{
  406. var m =date.getMonth() + 1; //月
  407. }
  408. if(date.getDate() + 1<10){
  409. var d ='0'+date.getDate(); //日
  410. }else{
  411. var d = date.getDate(); //日
  412. }
  413. // var d = date.getDate(); //日
  414. return y + "-" + m + "-" + d;
  415. },
  416. handleCurrentChange(val){
  417. this.currentPage = val
  418. this.Getdialyzerdetail(this.status_value)
  419. },
  420. handleSizeChange(val){
  421. this.limit = val
  422. this.Getdialyzerdetail(this.status_value)
  423. },
  424. // 性别
  425. getgender(ids){
  426. if(ids ==1){
  427. return "男"
  428. }else{
  429. return "女"
  430. }
  431. },
  432. // getVol(value){
  433. // if(value >1000){
  434. // }
  435. // },
  436. // 转换时间
  437. getTime(val) {
  438. if(val < 0){
  439. return ""
  440. }
  441. if(val == ""){
  442. return ""
  443. }else {
  444. return uParseTime(val, '{y}-{m}-{d}')
  445. }
  446. },
  447. dataURLtoBlob(dataURL) {
  448. const arr = dataURL.split(',');
  449. const mime = arr[0].match(/:(.*?);/)[1];
  450. const bstr = atob(arr[1]);
  451. let n = bstr.length;
  452. const u8arr = new Uint8Array(n);
  453. while (n--) {
  454. u8arr[n] = bstr.charCodeAt(n);
  455. }
  456. return new Blob([u8arr], { type: mime });
  457. },
  458. },
  459. mounted(){
  460. },
  461. created(){
  462. this.start_date = this.getFirstDayOfMonth(new Date())
  463. this.Getdialyzerdetail(this.status_value)
  464. },
  465. }
  466. </script>