Elizabeth's proactive approach involves introducing urinal toilet attachment , an ingenious concept that optimizes space and functionality.

dialysisGatherPrint.vue 18KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443
  1. <template>
  2. <div class="main-contain">
  3. <div class="position">
  4. <bread-crumb :crumbs="crumbs"></bread-crumb>
  5. <el-row style="float:right;">
  6. <el-col :span="24">
  7. <el-button size="small" icon="el-icon-printer" type="primary" @click="printAction">打印</el-button>
  8. </el-col>
  9. </el-row>
  10. </div>
  11. <div class="app-container" style="background-color: white;">
  12. <div id="print_content">
  13. <div class="print_main_content">
  14. <div class="order_title_panl">
  15. <span class="main_title"> &nbsp;
  16. 汇总
  17. </span>
  18. <span style="float:left;">打印日期: &nbsp;
  19. {{$route.query.schedule_date}}
  20. </span>
  21. </div>
  22. <div class="table_panel">
  23. <table class="table">
  24. <thead>
  25. <tr>
  26. <td width="60" v-if="gatherSetting.index_number == 1">序号</td>
  27. <td width="100" v-if="gatherSetting.name==1">姓名</td>
  28. <td width="100" v-if="gatherSetting.dialysis_no==1">透析号</td>
  29. <td width="100" v-if="gatherSetting.admission_number==1">住院(门诊)号</td>
  30. <td width="100" v-if="gatherSetting.mode_type==1">透析模式</td>
  31. <td width="100" v-if="gatherSetting.dialysis_dialyszers == 1">透析器</td>
  32. <td width="100" v-if="gatherSetting.dialysis_irrigation ==1">灌流器</td>
  33. <td width="100" v-if="gatherSetting.dialysis_irrigation ==1">滤过器</td>
  34. <td width="100" v-if="gatherSetting.change_nurse ==1">换药包/穿刺针</td>
  35. <td width="100" v-if="gatherSetting.anticoagulant==1">抗凝剂(首剂)(维持)(总量)</td>
  36. <td width="200" v-if="gatherSetting.tube==1">封管液</td>
  37. <td width="100" v-if="gatherSetting.kalium==1">钾</td>
  38. <td width="100" v-if="gatherSetting.calcium==1">钙</td>
  39. <td width="100" v-if="gatherSetting.cuhong == 1">促红素</td>
  40. <td width="100" v-if="gatherSetting.zuoka == 1">左卡</td>
  41. <td width="100" v-if="gatherSetting.niaojimei == 1">尿激酶</td>
  42. <td width="100" v-if="gatherSetting.putaosuangai == 1">葡萄糖酸钙</td>
  43. </tr>
  44. </thead>
  45. <tbody>
  46. <tr v-for="(item,i) in list" :key="i">
  47. <td width="60" v-if="gatherSetting.index_number == 1">{{ i+1 }}</td>
  48. <td width="100" v-if="gatherSetting.name==1">
  49. {{item.patient.name}}
  50. </td>
  51. <td width="100" v-if="gatherSetting.dialysis_no==1">
  52. {{item.patient.dialysis_no}}
  53. </td>
  54. <td width="100" v-if="gatherSetting.admission_number==1">
  55. {{item.xt_receive_treatment_asses.admission_number}}
  56. </td>
  57. <td width="100" v-if="gatherSetting.mode_type==1">
  58. <span v-if="item.mode_id == 1">HD</span>
  59. <span v-if="item.mode_id == 2">HDF</span>
  60. <span v-if="item.mode_id == 3">HD+HP</span>
  61. <span v-if="item.mode_id == 4">HP</span>
  62. <span v-if="item.mode_id == 5">HF</span>
  63. <span v-if="item.mode_id == 6">SCUF</span>
  64. <span v-if="item.mode_id == 7">IUF</span>
  65. <span v-if="item.mode_id == 8">HFHD</span>
  66. <span v-if="item.mode_id == 9">HFHD+HP</span>
  67. <span v-if="item.mode_id == 10">PHF</span>
  68. <span v-if="item.mode_id == 11">HFR</span>
  69. <span v-if="item.mode_id == 12">HDF+HP</span>
  70. <span v-if="item.mode_id == 13">CRRT</span>
  71. <span v-if="item.mode_id == 19">IUF+HD</span>
  72. <span v-if="item.mode_id == 20">UF</span>
  73. <span v-if="item.mode_id == 21">HD+</span>
  74. <span v-if="item.mode_id == 22">血浆胆红素吸附+HDF</span>
  75. <span v-if="item.mode_id == 23">血浆胆红素吸附</span>
  76. <span v-if="item.mode_id == 24">I-HDF</span>
  77. <span v-if="item.mode_id == 25">HD高通F</span>
  78. <span v-if="item.mode_id == 26">CVVH</span>
  79. <span v-if="item.mode_id == 27">CVVHD</span>
  80. <span v-if="item.mode_id == 28">CVVHDF</span>
  81. <span v-if="item.mode_id == 29">PE</span>
  82. <span v-if="item.mode_id == 30">血浆胆红素吸附+HP</span>
  83. <span v-if="item.mode_id == 31">HPD</span>
  84. <span v-if="item.mode_id == 32">HDP</span>
  85. <span v-if="item.mode_id == 33">HFD</span>
  86. <span v-if="item.mode_id == 34">HDF100</span>
  87. <span v-if="item.mode_id == 35">HDF600</span>
  88. <span v-if="item.mode_id == 35">HDF800</span>
  89. <span v-if="item.mode_id == 35">HDF1000</span>
  90. </td>
  91. <td width="100" v-if="gatherSetting.dialysis_dialyszers == 1">
  92. {{item.dialysis_prescription.dialysis_dialyszers}}
  93. </td>
  94. <td width="100" v-if="gatherSetting.dialysis_irrigation ==1">
  95. <span>{{item.dialysis_prescription.dialysis_irrigation}}</span>
  96. </td>
  97. <td width="100" v-if="gatherSetting.dialysis_irrigation ==1">
  98. <span>{{item.dialysis_prescription.dialysis_strainer}}</span>
  99. </td>
  100. <td width="100" v-if="gatherSetting.change_nurse ==1">
  101. <span v-if="(getBloodAccessOption(item.dialysis_prescription.blood_access)).indexOf('导管')!=-1">1</span>
  102. <span v-if="(getBloodAccessOption(item.dialysis_prescription.blood_access)).indexOf('导管')==-1">0</span>
  103. /
  104. <span v-if="(getBloodAccessOption(item.dialysis_prescription.blood_access)).indexOf('内瘘')==-1">0</span>
  105. <span v-if="(getBloodAccessOption(item.dialysis_prescription.blood_access)).indexOf('内瘘')!=-1">1</span>
  106. </td>
  107. <td width="100" v-if="gatherSetting.anticoagulant==1">
  108. <span>{{getAnticoagualnt(item.dialysis_prescription.anticoagulant)}}</span>
  109. <span v-if="item.dialysis_prescription.anticoagulant_shouji > 0">({{item.dialysis_prescription.anticoagulant_shouji}})</span>
  110. <span v-if="item.dialysis_prescription.anticoagulant_weichi > 0">({{item.dialysis_prescription.anticoagulant_weichi}})</span>
  111. <span v-if="item.dialysis_prescription.anticoagulant_zongliang > 0">({{item.dialysis_prescription.anticoagulant_zongliang}})</span>
  112. </td>
  113. <td width="200" v-if="gatherSetting.tube==1">
  114. <span v-if="getBloodAccessOption(item.dialysis_prescription.blood_access).indexOf('导管')!==-1">1</span>
  115. </td>
  116. <td width="100" v-if="gatherSetting.kalium==1">
  117. <span v-if="item.dialysis_prescription.kalium>0">{{item.dialysis_prescription.kalium}}</span>
  118. </td>
  119. <td width="100" v-if="gatherSetting.calcium==1">
  120. <span v-if="item.dialysis_prescription.calcium>0">{{item.dialysis_prescription.calcium}}</span>
  121. </td>
  122. <td width="100" v-if="gatherSetting.cuhong == 1">
  123. {{ item.advice_spc }}
  124. </td>
  125. <td width="100" v-if="gatherSetting.zuoka == 1">
  126. {{ item.advice_spc_one }}
  127. </td>
  128. <td width="100" v-if="gatherSetting.niaojimei == 1">
  129. {{ item.advice_spc_two }}
  130. </td>
  131. <td width="100" v-if="gatherSetting.putaosuangai == 1">
  132. {{ item.advice_spc_three }}
  133. </td>
  134. </tr>
  135. </tbody>
  136. </table>
  137. </div>
  138. </div>
  139. </div>
  140. </div>
  141. </div>
  142. </template>
  143. <script>
  144. import { getDialysisGatherList } from '@/api/dialysis'
  145. import { parseTime } from '@/utils'
  146. import { uParseTime } from '@/utils/tools'
  147. import BreadCrumb from '@/xt_pages/components/bread-crumb'
  148. import print from 'print-js'
  149. import { getDataConfig } from '@/utils/data'
  150. export default {
  151. name: 'SchedulePrint',
  152. data() {
  153. return {
  154. crumbs: [
  155. { path: false, name: '排班管理' },
  156. { path: false, name: '透析汇总打印' }
  157. ],
  158. td_1_width: '8%',
  159. td_2_width: '8%',
  160. td_3_width: '64%',
  161. td_4_width: '20%',
  162. month: 1,
  163. begin_day: 1,
  164. total:[],
  165. list:[],
  166. schedule_date:"",
  167. schedule_type:0,
  168. partition_type:0,
  169. keywords:"",
  170. loading:false,
  171. tableData:[],
  172. numberList:[],
  173. partitionArr:[],
  174. his_config:{},
  175. typeList:[],
  176. rowList:[],
  177. dialysate_formulation:[],
  178. body_fluid_option:[],
  179. displace_liqui_part_option:[],
  180. blood_access_option:[],
  181. hemodialysisPipelinesOptions:[],
  182. tableList:[],
  183. list:[],
  184. dialysisSett:{},
  185. total_one:0,
  186. total_two:0,
  187. total_three:0,
  188. org_id:'',
  189. gatherSetting:{}
  190. }
  191. },
  192. components: {
  193. BreadCrumb
  194. },
  195. created() {
  196. this.org_id = this.$store.getters.xt_user.org.id
  197. this.displace_liqui_part_option = this.$store.getters.displace_liqui
  198. this.blood_access_option = getDataConfig('hemodialysis', 'vascular_access_desc')
  199. this.getlist()
  200. },
  201. methods: {
  202. getlist(){
  203. var params = {
  204. schedule_date:this.$route.query.schedule_date,
  205. schedule_type:this.$route.query.schedule_type,
  206. partition_id:this.$route.query.partion_id,
  207. page:this.$route.query.page,
  208. limit:500,
  209. ids:this.$route.query.ids,
  210. }
  211. console.log("params",params)
  212. getDialysisGatherList(params).then(response=>{
  213. if(response.data.state == 1){
  214. this.gatherSetting = response.data.data.gatherSetting
  215. var list = response.data.data.list
  216. if(list!=null &&list.length>0){
  217. for(let i=0;i<list.length;i++){
  218. list[i].sort = 0
  219. list[i].sort = list[i].device_number.sort
  220. }
  221. }
  222. list.sort(this.compare('sort'))
  223. var total_one =0
  224. var total_two=0
  225. var total_three =0
  226. console.log("listoowowowwoww",list)
  227. for(let i=0;i<list.length;i++){
  228. list[i].advice_spc =""
  229. list[i].advice_spc_one =""
  230. list[i].advice_spc_two =""
  231. list[i].advice_spc_three = ""
  232. for(let j=0;j<list[i].advice.length;j++){
  233. if((list[i].advice[j].advice_name).indexOf("促红")!=-1){
  234. list[i].advice_spc+= (list[i].advice[j].single_dose + list[i].advice[j].single_dose_unit+"/"+ list[i].advice[j].prescribing_number_unit)+","
  235. }
  236. if((list[i].advice[j].advice_name).indexOf("左卡")!=-1){
  237. list[i].advice_spc_one+= (list[i].advice[j].single_dose + list[i].advice[j].single_dose_unit+"/"+ list[i].advice[j].prescribing_number_unit)+","
  238. }
  239. if((list[i].advice[j].advice_name).indexOf("尿激酶")!=-1){
  240. list[i].advice_spc_two+= (list[i].advice[j].single_dose + list[i].advice[j].single_dose_unit+"/"+ list[i].advice[j].prescribing_number_unit)+","
  241. }
  242. if((list[i].advice[j].advice_name).indexOf("葡萄糖酸钙")!=-1){
  243. list[i].advice_spc_three+= (list[i].advice[j].single_dose + list[i].advice[j].single_dose_unit+"/"+ list[i].advice[j].prescribing_number_unit)+","
  244. }
  245. }
  246. }
  247. this.list = list
  248. }
  249. })
  250. },
  251. getTimeOne(val) {
  252. if(val == ""){
  253. return ""
  254. }else {
  255. return uParseTime(val, '{y}-{m}-{d}')
  256. }
  257. },
  258. printAction: function() {
  259. if(this.org_id != 10490 && this.org_id != 0){
  260. const style = '@media print { .print_main_content { background-color: white; width:960px; margin:0 auto; padding: 0 0 20px 0; } .order_title_panl { text-align: center; } .main_title { font-size: 18px; line-height: 40px; font-weight: 500; } .table_panel { } .table { width: 100%; border: 1px solid; border-collapse: collapse; padding: 2px; } thead tr td { border: 1px solid; text-align: center; font-size: 16px; padding: 0px 5px; } tbody tr td { border: 1px solid; text-align: center; font-size: 14px; padding: 0px 5px; } .proj { padding: 5px 0; text-align: left; } .proj_title { font-size: 16px; font-weight: 500; line-height: 25px; } .proj_item { font-size: 15px; line-height: 20px; } .zone_name { font-weight: 500; } }'
  261. printJS({
  262. printable: 'print_content',
  263. type: 'html',
  264. documentTitle: ' ',
  265. style: style,
  266. scanStyles: false
  267. })
  268. }else{
  269. // const style = '@media print { .print_main_content { background-color: white; width:960px; margin:0 auto; padding: 0 0 20px 0; } .order_title_panl { text-align: center; } .main_title { font-size: 18px; line-height: 40px; font-weight: 500; } .table_panel { } .table { width: 100%; border: 1px solid; border-collapse: collapse; padding: 2px; } thead tr td { border: 1px solid; text-align: center; font-size: 16px; padding: 0px 5px; } tbody tr td { border: 1px solid; text-align: center; font-size: 14px; padding: 0px 5px; } .proj { padding: 5px 0; text-align: left; } .proj_title { font-size: 16px; font-weight: 500; line-height: 25px; } .proj_item { font-size: 15px; line-height: 20px; } .zone_name { font-weight: 500; } }'
  270. const style = '@media print { .print_main_content { background-color: white; width:960px; margin:0 auto; padding: 0 0 20px 0; } .order_title_panl { text-align: center; } .main_title { font-size: 18px; line-height: 40px; font-weight: 500; } .table_panel { } .table { width: 100%; border: 1px solid; border-collapse: collapse; padding: 2px; } thead tr td { border: 1px solid; text-align: center; font-size: 20px; padding: 15px 5px; } tbody tr td { border: 1px solid; text-align: center; font-size: 18px; padding: 10px 5px; } .proj { padding: 5px 0; text-align: left; } .proj_title { font-size: 16px; font-weight: 500; line-height: 25px; } .proj_item { font-size: 15px; line-height: 20px; } .zone_name { font-weight: 500; } }'
  271. printJS({
  272. printable: 'print_content',
  273. type: 'html',
  274. documentTitle: ' ',
  275. style: style,
  276. scanStyles: false
  277. })
  278. }
  279. },
  280. getAnticoagualnt(id){
  281. var name = ""
  282. if(id == 1){
  283. name = "无肝素"
  284. }
  285. if(id == 2){
  286. name = "普通肝素"
  287. }
  288. if(id == 3){
  289. name ="低分子肝素"
  290. }
  291. if(id == 4){
  292. name ="阿加曲班"
  293. }
  294. if(id == 5){
  295. name ="枸橼酸钠"
  296. }
  297. if(id == 6){
  298. name ="低分子肝素钙"
  299. }
  300. if(id == 7){
  301. name ="低分子肝素钠"
  302. }
  303. if(id == 8){
  304. name ="依诺肝素"
  305. }
  306. if(id == 9){
  307. name ="达肝素"
  308. }
  309. if(id == 10){
  310. name ="体外抗凝"
  311. }
  312. if(id == 11){
  313. name ="那屈肝素"
  314. }
  315. if(id == 12){
  316. name ="无抗凝剂"
  317. }
  318. if(id == 13){
  319. name ="那屈肝素钙"
  320. }
  321. return name
  322. },
  323. getBloodAccessOption(id){
  324. var name = ""
  325. for(let i=0;i<this.blood_access_option.length;i++){
  326. if(id == this.blood_access_option[i].id){
  327. name = this.blood_access_option[i].name
  328. }
  329. }
  330. return name
  331. },
  332. getDisplaceLiquiPart(id){
  333. var name = ""
  334. for(let i=0;i<this.displace_liqui_part_option.length;i++){
  335. if(id == this.displace_liqui_part_option[i].id){
  336. name = this.displace_liqui_part_option[i].name
  337. }
  338. }
  339. return name
  340. },
  341. compare(p) { //这是比较函数
  342. return function (m, n) {
  343. var a = m[p];
  344. var b = n[p];
  345. return a - b; //升序
  346. }
  347. },
  348. }
  349. }
  350. </script>
  351. <style rel="stylesheet/scss" lang="scss" scoped>
  352. .print_main_content {
  353. background-color: white;
  354. width: 960px;
  355. margin: 0 auto;
  356. padding: 0 0 20px 0;
  357. .order_title_panl {
  358. text-align: center;
  359. .main_title {
  360. font-size: 18px;
  361. line-height: 40px;
  362. font-weight: 500;
  363. }
  364. }
  365. .table_panel {
  366. .table {
  367. width: 100%;
  368. border: 1px solid;
  369. border-collapse: collapse;
  370. padding: 2px;
  371. thead {
  372. tr {
  373. td {
  374. border: 1px solid;
  375. text-align: center;
  376. font-size: 20px;
  377. padding: 15px 5px;
  378. }
  379. }
  380. }
  381. tbody {
  382. tr {
  383. td {
  384. border: 1px solid;
  385. text-align: center;
  386. font-size: 18px;
  387. padding: 10px 5px;
  388. .proj {
  389. padding: 5px 0;
  390. text-align: left;
  391. .proj_title {
  392. font-size: 16px;
  393. font-weight: 500;
  394. line-height: 25px;
  395. }
  396. .proj_item {
  397. font-size: 15px;
  398. line-height: 20px;
  399. .zone_name {
  400. font-weight: 500;
  401. }
  402. }
  403. }
  404. }
  405. }
  406. }
  407. }
  408. }
  409. }
  410. </style>