血透系统pad前端

DialysisPrintOrderSix.vue 70KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592
  1. <template>
  2. <div id="dialysis-print-box-1">
  3. <div id="dialysis-print-box-1-1" class="dialysis-print-order print-template-two print_page_main_content" >
  4. <div style="display:inline-block;width:100%;text-align:center;">
  5. <div class="order-yy-name" style="letter-spacing: 0;font-weight:600;font-size:22px;display:inline-block;">{{orgname}}</div>
  6. <div class="order-title" style="letter-spacing: 0;font-weight:600;font-size:22px;display:inline-block;">血液净化治疗记录单</div>
  7. </div>
  8. <div class="row">
  9. <div class="inline_block" >
  10. 姓名:
  11. <div class="under_line" style="width: 50px;text-align: center;">{{patientInfo.name}}</div>
  12. </div>
  13. <div class="inline_block" style="margin-left: 10px;">
  14. 性别:
  15. <div class="under_line" style="width: 30px;text-align: center;">{{patientInfo_gender_1?"男":"女"}}</div>
  16. </div>
  17. <div class="inline_block" style="margin-left: 10px;">
  18. 年龄:
  19. <div class="under_line" style="width: 30px;text-align: center;">{{getAge(patientInfo)}}</div>
  20. </div>
  21. <div class="inline_block">
  22. 门诊:
  23. <div class="under_line" style="width: 30px;text-align: center;">
  24. <check-box :checked="patientInfo_source_1 "></check-box>
  25. </div>
  26. </div>
  27. <div class="inline_block">
  28. 病区:
  29. <div class="under_line" style="width: 50px;text-align: center;">
  30. {{'/'}}
  31. </div>
  32. </div>
  33. <div class="inline_block">
  34. 床号:
  35. <div class="under_line" style="width: 50px;text-align: center;">
  36. {{'/'}}
  37. </div>
  38. </div>
  39. <div class="inline_block">
  40. 透析号:
  41. <div class="under_line" style="width: 70px;text-align: center;">
  42. {{patientInfo.dialysis_no}}
  43. </div>
  44. </div>
  45. <div class="inline_block" style="margin-left: 5px;">
  46. 住院号/门诊号:
  47. <div class="under_line" style="width: 70px;text-align: left" v-if="patientInfo.admission_number">
  48. {{patientInfo.admission_number}}
  49. </div>
  50. <div class="under_line" style="width: 70px;text-align: left" v-else>
  51. {{'/'}}
  52. </div>
  53. </div>
  54. </div>
  55. <div class="row" >
  56. <div class="inline_block" >
  57. 入科方式:
  58. <div class="under_line" v-if="receiverTreatmentAccess.way==0" style="width: 180px;text-align: left"> </div>
  59. <div class="under_line" v-if="receiverTreatmentAccess.way==1" style="width: 180px;text-align: left">步行 </div>
  60. <div class="under_line" v-if="receiverTreatmentAccess.way==2" style="width: 180px;text-align: left">扶行 </div>
  61. <div class="under_line" v-if="receiverTreatmentAccess.way==3" style="width: 180px;text-align: left">轮椅 </div>
  62. <div class="under_line" v-if="receiverTreatmentAccess.way==4" style="width: 180px;text-align: left">平车 </div>
  63. </div>
  64. <div class="inline_block" style="margin-left: 10px;">
  65. 诊断:
  66. <div class="under_line" style="width: 180px;text-align: left">{{patientInfo.diagnose}}</div>
  67. </div>
  68. </div>
  69. <div class="row" :style=" this.totollength > 13?'margin-bottom:400px;':''">
  70. <table class="proj_table" >
  71. <tbody>
  72. <tr><td colspan="2" style="letter-spacing:5px;text-align:center;font-weight:520;font-size:16px;padding: 6px 8px;line-height: 30px;">透析前情况</td></tr>
  73. <tr>
  74. <td colspan="2">
  75. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  76. <div class="inline_block" style="flex:1;">
  77. 本次透析日期:
  78. <div class="under_line" style="width: 100px;text-align: center">
  79. {{xtdate}}
  80. </div>
  81. </div>
  82. <div class="inline_block" style="flex:1;">
  83. 透析次数:
  84. <div class="under_line" style="width: 70px;text-align: center">
  85. {{patientInfo.total_dialysis?patientInfo.total_dialysis:'/'}}
  86. </div>
  87. </div>
  88. <div class="inline_block" style="flex:1;">
  89. 透前症状:
  90. <div class="under_line" style="width: 150px;text-align: center">
  91. {{predialysis.symptom_before_dialysis?predialysis.symptom_before_dialysis:'/'}}
  92. </div>
  93. </div>
  94. </div>
  95. <div class="row" style="padding: 2px 0;line-height:23px;">
  96. <div class="inline_block" >
  97. T:
  98. <div class="under_line" style="width: 50px;text-align: center">
  99. {{predialysis.temperature?predialysis.temperature:'/'}}
  100. </div>
  101. °C
  102. </div>
  103. <div class="inline_block" style="margin-left:10px;">
  104. P:
  105. <div class="under_line" style="width: 50px;text-align: center;">
  106. {{predialysis.pulse_frequency?predialysis.pulse_frequency:'/'}}
  107. </div>
  108. 次/分
  109. </div>
  110. <div class="inline_block" style="margin-left:10px;">
  111. R:
  112. <div class="under_line" style="width: 50px;text-align: center;">
  113. {{predialysis.breathing_rate?predialysis.breathing_rate:'/'}}
  114. </div>
  115. 次/分
  116. </div>
  117. <div class="inline_block" style="margin-left:10px;">
  118. BP:
  119. <div class="under_line" style="width: 50px;text-align: center;">
  120. {{predialysis.systolic_blood_pressure?predialysis.systolic_blood_pressure:'/'}}
  121. </div>
  122. /
  123. <div class="under_line" style="width: 50px;text-align: center;">
  124. {{predialysis.diastolic_blood_pressure?predialysis.diastolic_blood_pressure:'/'}}
  125. </div>
  126. mmHg
  127. </div>
  128. <div class="inline_block" style="margin-left:10px;">
  129. 血管通路:
  130. <div class="under_line" style="width: 200px;text-align: center;">
  131. {{QueryPartById(predialysis.blood_access_part_id)}} {{predialysis.blood_access_part_opera_name}}
  132. </div>
  133. </div>
  134. </div>
  135. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  136. <div class="inline_block" style="flex:1;">
  137. 内瘘:
  138. <div class="under_line" style="width: 150px;text-align: center">
  139. {{predialysis.internal_fistula?predialysis.internal_fistula:'/'}}
  140. </div>
  141. </div>
  142. <div class="inline_block" style="margin-left:10px;flex:1;">
  143. 导管:
  144. <div class="under_line" style="width: 150px;text-align: center">
  145. {{predialysis.catheter?predialysis.catheter:'/'}}
  146. </div>
  147. </div>
  148. <div class="inline_block" style="margin-left:10px;flex:1;">
  149. 穿刺方式:
  150. <div class="under_line" style="width: 100px;text-align: center" v-if="predialysis.puncture_way == 0">
  151. /
  152. </div>
  153. <div class="under_line" style="width: 100px;text-align: center" v-if="predialysis.puncture_way == 1">
  154. 绳梯
  155. </div>
  156. <div class="under_line" style="width: 100px;text-align: center" v-if="predialysis.puncture_way == 2">
  157. 扣眼
  158. </div>
  159. <div class="under_line" style="width: 100px;text-align: center" v-if="predialysis.puncture_way == 3">
  160. 区域
  161. </div>
  162. </div>
  163. <div class="inline_block" style="margin-left:10px;flex:1;">
  164. 穿刺针:
  165. <div class="under_line" style="width: 100px;text-align: center">
  166. {{predialysis.puncture_needle?predialysis.puncture_needle:'/'}}
  167. </div>
  168. </div>
  169. </div>
  170. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  171. <div class="inline_block" style="flex:1;">
  172. 透析方式:
  173. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="!prescription.mode_id">
  174. /
  175. </div>
  176. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==1">
  177. HD
  178. </div>
  179. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==2">
  180. HDF
  181. </div>
  182. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==3">
  183. HD+HP
  184. </div>
  185. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==4">
  186. HP
  187. </div>
  188. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==5">
  189. HF
  190. </div>
  191. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==6">
  192. SCUF
  193. </div>
  194. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==7">
  195. IUF
  196. </div>
  197. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==8">
  198. HFHD
  199. </div>
  200. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==9">
  201. HFHD+HP
  202. </div>
  203. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==10">
  204. PHF
  205. </div>
  206. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==11">
  207. HFR
  208. </div>
  209. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==12">
  210. HDF+HP
  211. </div>
  212. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==13">
  213. CRRT
  214. </div>
  215. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==14">
  216. 腹水回输
  217. </div>
  218. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==15">
  219. HD前置换
  220. </div>
  221. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==16">
  222. HD后置换
  223. </div>
  224. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==17">
  225. HDF前置换
  226. </div>
  227. <div class="under_line" style="width: 100px;text-align: center;font-weight:600;" v-if="prescription.mode_id==18">
  228. HDF后置换
  229. </div>
  230. </div>
  231. <div class="inline_block" style="margin-left:10px;flex:1;">
  232. 置换方式:
  233. <div class="under_line" style="width: 100px;text-align: center">
  234. {{getDisplaceLiquiPart(prescription.displace_liqui_part)}}
  235. </div>
  236. </div>
  237. <div class="inline_block" style="margin-left:10px;flex:1;">
  238. 置换量:
  239. <div class="under_line" style="width: 70px;text-align: center">
  240. {{prescription.displace_liqui_value?prescription.displace_liqui_value:'/'}}
  241. </div>
  242. L
  243. </div>
  244. <div class="inline_block" style="margin-left:10px;flex:1;">
  245. 血流量:
  246. <div class="under_line" style="width: 50px;text-align: center">
  247. {{prescription.blood_flow_volume?prescription.blood_flow_volume:'/'}}
  248. </div>
  249. ml/min
  250. </div>
  251. <div class="inline_block" style="margin-left:10px;flex:1;">
  252. 透析时间:
  253. <div class="under_line" style="width: 50px;text-align: center">
  254. {{prescription.dialysis_duration_hour?prescription.dialysis_duration_hour:'/'}}
  255. </div>
  256. h
  257. </div>
  258. </div>
  259. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  260. <div class="inline_block" style="flex:1;">
  261. 透析(滤)器:
  262. <div class="under_line" style="width: 100px;text-align: center">
  263. {{prescription.dialyzer_perfusion_apparatus?prescription.dialyzer_perfusion_apparatus:'/'}}
  264. </div>
  265. </div>
  266. <div class="inline_block" style="flex:1;">
  267. 灌流器:
  268. <div class="under_line" style="width: 70px;text-align: center">
  269. /
  270. </div>
  271. </div>
  272. <div class="inline_block" style="flex:1;">
  273. 干体重:
  274. <div class="under_line" style="width: 150px;text-align: center">
  275. {{predialysis.dry_weight?predialysis.dry_weight:'/'}}
  276. </div>kg
  277. </div>
  278. </div>
  279. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  280. <div class="inline_block" style="flex:1;">
  281. 上次透后体重:
  282. <div class="under_line" style="width: 100px;text-align: center">
  283. {{predialysis.weight_after_last_transparency?predialysis.weight_after_last_transparency:'未称重'}}
  284. </div>
  285. kg
  286. </div>
  287. <div class="inline_block" style="flex:1;">
  288. 透前体重:
  289. <div class="under_line" style="width: 70px;text-align: center">
  290. {{predialysis.weight_before?predialysis.weight_before:'/'}}
  291. </div>
  292. kg
  293. </div>
  294. <div class="inline_block" style="flex:1;">
  295. 计划超滤量:
  296. <div class="under_line" style="width: 150px;text-align: center">
  297. {{prescription.target_ultrafiltration?prescription.target_ultrafiltration:'/'}}
  298. </div>
  299. L
  300. </div>
  301. </div>
  302. <div class="row" style="padding: 2px 0;line-height:23px;">
  303. <div class="inline_block" >
  304. 透析液成分钾:
  305. <div class="under_line" style="width: 50px;text-align: center">
  306. {{prescription.kalium?prescription.kalium:'/'}}
  307. </div>
  308. mmol/L
  309. </div>
  310. <div class="inline_block" style="margin-left:10px;">
  311. 钠:
  312. <div class="under_line" style="width: 50px;text-align: center;">
  313. {{prescription.sodium?prescription.sodium:'/'}}
  314. </div>
  315. mmol/L
  316. </div>
  317. <div class="inline_block" style="margin-left:10px;">
  318. 钙:
  319. <div class="under_line" style="width: 50px;text-align: center;">
  320. {{prescription.calcium?prescription.calcium:'/'}}
  321. </div>
  322. mmol/L
  323. </div>
  324. <div class="inline_block" style="margin-left:10px;">
  325. 碳酸氢根:
  326. <div class="under_line" style="width: 50px;text-align: center;">
  327. {{prescription.bicarbonate?prescription.bicarbonate:'/'}}
  328. </div>
  329. mmol/L
  330. </div>
  331. <div class="inline_block" style="margin-left:10px;">
  332. 流量:
  333. <div class="under_line" style="width: 50px;text-align: center;">
  334. {{prescription.dialysate_flow?prescription.dialysate_flow:'/'}}
  335. </div>
  336. ml/min
  337. </div>
  338. </div>
  339. <div class="row" style="padding: 2px 0;line-height:23px;">
  340. <div class="inline_block" >
  341. 抗凝剂:
  342. <div class="under_line" style="width: 150px;text-align: center">
  343. {{prescription.anticoagulant_name?prescription.anticoagulant_name:'/'}}
  344. </div>
  345. </div>
  346. <div class="inline_block" style="margin-left:20px;">
  347. 首剂:
  348. <div class="under_line" style="width: 50px;text-align: center;">
  349. {{prescription.anticoagulant_shouji?prescription.anticoagulant_shouji:'/'}}
  350. </div>
  351. lu
  352. </div>
  353. <div class="inline_block" style="margin-left:20px;">
  354. 维持:
  355. <div v-if="prescription.anticoagulant == 1" class="under_line" style="width: 50px;text-align: center;">
  356. {{prescription.anticoagulant_weichi?prescription.anticoagulant_weichi:'/'}}
  357. </div>
  358. <div v-if="prescription.anticoagulant != 1" class="under_line" style="width: 50px;text-align: center;">
  359. {{prescription.anticoagulant_weichi?prescription.anticoagulant_weichi:0}}
  360. </div>
  361. lu
  362. </div>
  363. <div class="inline_block" style="margin-left:20px;">
  364. 总量:
  365. <div class="under_line" style="width: 50px;text-align: center;">
  366. {{prescription.anticoagulant_zongliang?prescription.anticoagulant_zongliang:'/'}}
  367. </div>
  368. lu
  369. </div>
  370. <div class="inline_block" style="margin-left:20px;">
  371. 透析机号:
  372. <div class="under_line" style="width: 50px;text-align: center;">
  373. {{dialysisOrder&&dialysisOrder.DeviceNumber&&dialysisOrder.DeviceNumber.number.length > 0?dialysisOrder.DeviceNumber.number:patientInfo.DialysisSchedule.device_number.number}}
  374. </div>
  375. </div>
  376. </div>
  377. </td>
  378. </tr>
  379. <tr>
  380. <td style="padding: 0; position: relative;" colspan="2">
  381. <table class="inside_table">
  382. <tbody>
  383. <tr><td :colspan="(prescription.mode_id==2 || prescription.mode_id==5 || prescription.mode_id== 12) ? 12 :11" style="letter-spacing:5px;text-align:center;font-weight:520;font-size:16px;padding: 6px 8px;line-height: 30px;">治疗纪录</td></tr>
  384. <tr>
  385. <td width="60">时间</td>
  386. <td width="60">血压<br/>(mmHg)</td>
  387. <td width="50">脉搏<br>(次/分)</td>
  388. <td width="50">呼吸<br/>(次/分)</td>
  389. <td width="50">血流量<br/>(ml/min)</td>
  390. <td width="50">静脉压<br/>(mmHg)</td>
  391. <td width="50">跨膜压<br/>(mmHg)</td>
  392. <td width="60">透析液温度(°C)</td>
  393. <td width="50">电导度<br/>(ms/cm)</td>
  394. <td width="50">超滤量<br/>(ml)</td>
  395. <td v-if="prescription.mode_id==2 || prescription.mode_id==5 || prescription.mode_id== 12" width="50">置换量<br/>(ml)</td>
  396. <td width="200">病情变化及处理</td>
  397. <!-- <td width="100">时间</td>
  398. <td width="30">T<br>C°</td>
  399. <td width="30">P<br/>次/分</td>
  400. <td width="30">R<br/>次/分</td>
  401. <td width="100">BP<br/>mmHg</td>
  402. <td width="60">静脉压/动脉压<br/>mmHg</td>
  403. <td width="80">血流量<br/>ml/min</td>
  404. <td width="90">超滤量累计L</td>
  405. <td width="80">钠浓度<br/>mmol/L</td>
  406. <td width="240">病情特殊情况处理<br/>及专科护理措施记录</td>
  407. <td width="100">护士签名</td> -->
  408. </tr>
  409. <tr v-for="(monitor,monindex) in monitors" :key="monindex">
  410. <td>{{getTime(monitor.operate_time,'{h}:{i}')}}</td>
  411. <td>{{monitor.systolic_blood_pressure?monitor.systolic_blood_pressure+'/':''}}{{monitor.diastolic_blood_pressure?monitor.diastolic_blood_pressure:''}}</td>
  412. <td>{{monitor.pulse_frequency?monitor.pulse_frequency:''}}</td>
  413. <td>{{monitor.breathing_rate?monitor.breathing_rate:''}}</td>
  414. <td>{{monitor.blood_flow_volume?monitor.blood_flow_volume:''}}</td>
  415. <td>{{monitor.venous_pressure?monitor.venous_pressure:''}}</td>
  416. <td>{{monitor.transmembrane_pressure?monitor.transmembrane_pressure:0}}</td>
  417. <td>{{monitor.dialysate_temperature?monitor.dialysate_temperature:''}}</td>
  418. <td>{{monitor.sodium_concentration?monitor.sodium_concentration:''}}</td>
  419. <td>{{monitor.ultrafiltration_volume?monitor.ultrafiltration_volume:0}}</td>
  420. <td v-if="prescription.mode_id==2 || prescription.mode_id==5 || prescription.mode_id== 12" width="50">{{monitor.displacement_quantity?monitor.displacement_quantity:0}}</td>
  421. <td style="line-height:16px;padding:0px;">
  422. <div style="min-height:40px;line-height:40px; overflow:hidden;">
  423. <span style="word-break: break-all;margin:0;line-height:16px;-webkit-line-clamp:3;overflow:visible;display:inline-block;vertical-align:middle;height:auto;">
  424. <template v-if="monindex == 0">【开始透析】</template>
  425. {{monitor.end}}
  426. {{monitor.symptom}} &nbsp;{{monitor.dispose}} &nbsp;{{monitor.result}}
  427. </span>
  428. </div>
  429. </td>
  430. </tr>
  431. <tr v-for="(monitor,monindex) in monitors2" :key="monindex">
  432. <td> </td>
  433. <td> </td>
  434. <td> </td>
  435. <td> </td>
  436. <td> </td>
  437. <td> </td>
  438. <td> </td>
  439. <td> </td>
  440. <td> </td>
  441. <td> </td>
  442. <td v-if="prescription.mode_id==2 || prescription.mode_id==5 || prescription.mode_id== 12" width="50"></td>
  443. <td style="line-height:16px;padding:0px;"><div style="height:40px;line-height:20px; overflow:hidden;"><span style="word-break: break-all;margin:0;line-height:16px;-webkit-line-clamp:3;overflow:visible;display:inline-block;vertical-align:middle;height:auto;"> </span> </div></td>
  444. </tr>
  445. </tbody>
  446. </table>
  447. </td>
  448. </tr>
  449. <tr>
  450. <td style="padding: 0; position: relative;" colspan="2">
  451. <table class="inside_table">
  452. <tbody>
  453. <tr style="line-height:35px;padding:8px 5px;">
  454. <td colspan="7" style="letter-spacing:5px;text-align:center;font-weight:520;font-size:16px;padding: 6px 8px;line-height: 30px;">医嘱内容</td>
  455. </tr>
  456. <!-- <tr style="line-height:35px;padding:8px 5px;">
  457. <td colspan="4" style="font-size: 16px">开医嘱</td>
  458. <td colspan="3" style="font-size: 16px">执行核对医嘱</td>
  459. </tr> -->
  460. <tr style="line-height:35px;padding:8px 5px;">
  461. <td style="font-size: 16px" width="10%">时间</td>
  462. <td style="font-size: 16px" colspan="2" width="45%">医嘱内容</td>
  463. <td style="font-size: 16px" width="10%">医生签名</td>
  464. <!-- <td style="font-size: 16px" width="10%">核对人签名</td> -->
  465. <td style="font-size: 16px" width="10%">执行人签名</td>
  466. <td style="font-size: 16px" width="10%">时间</td>
  467. </tr>
  468. <!-- <template v-for="group in doctor_advices" > -->
  469. <tr v-for="(advice, advice_index) in doctor_advices" :key="advice_index" >
  470. <td height="35px" >
  471. <span v-if="advice.start_time">
  472. {{getTime(advice.start_time,'{h}:{i}')}}
  473. </span>
  474. <!-- <span v-else>&nbsp;<br/>&nbsp;</span> -->
  475. </td>
  476. <td height="35px" colspan="2" class="advice-name" style="padding-left:7px;" >
  477. <span v-if="advice.parent_id > 0">---></span>
  478. <span >{{advice.advice_name }}</span>
  479. <span v-if="advice&&advice.advice_desc">({{advice.advice_desc}}{{advice.drug_spec_unit}})</span>
  480. <span v-if="advice.prescribing_number">* {{advice.prescribing_number}}{{advice.prescribing_number_unit}}</span>
  481. <span v-if="advice.single_dose != 0"> {{advice.single_dose}}{{advice.single_dose_unit}}</span>
  482. <span v-if="advice.parent_id == 0">{{advice.delivery_way}}</span>
  483. <span v-if="advice.parent_id == 0">{{advice.execution_frequency}}</span>
  484. <span v-if="advice.parent_id == 0 && advice.remark.length > 0" >({{advice.remark}})</span>
  485. </td>
  486. <!-- <td colspan="2" height="60px" style="text-align: center" v-else >
  487. <span>{{advice.delivery_way}}</span>
  488. <span>{{advice.execution_frequency}}</span>
  489. <span v-if="advice.remark.length > 0">({{advice.remark}})</span>
  490. </td> -->
  491. <!-- <td width="10%" v-if="(advice.children && advice.children.length > 0 || advice.parent_id > 0) && advice.isShow == 2" ></td> -->
  492. <td height="35px">
  493. <span v-if="setAdminUserES(advice.advice_doctor) == ''">{{getAdminUser(advice.advice_doctor)}}</span>
  494. <img style="height:20px;" :src="setAdminUserES(advice.advice_doctor)" alt="" srcset="" v-else>
  495. </td>
  496. <!-- <td height="35px">
  497. <span v-if="setAdminUserES(advice.checker) == ''">{{getAdminUser(advice.checker)}}</span>
  498. <img style="height:20px;" :src="setAdminUserES(advice.checker)" alt="" srcset="" v-else>
  499. </td> -->
  500. <td height="35px">
  501. <span v-if="setAdminUserES(advice.execution_staff) == ''">{{getAdminUser(advice.execution_staff)}}</span>
  502. <img style="height:20px;" :src="setAdminUserES(advice.execution_staff)" alt="" srcset="" v-else>
  503. </td>
  504. <td height="35px">
  505. <span v-if="advice.execution_time">{{getTime(advice.execution_time,'{h}:{i}')}}</span>
  506. </td>
  507. </tr>
  508. <!-- </template> -->
  509. </tbody>
  510. </table>
  511. </td>
  512. </tr>
  513. </tbody>
  514. </table>
  515. </div>
  516. <template v-if="this.totollength > 13">
  517. <div style="display:inline-block;width:100%;text-align:center;">
  518. <div class="order-yy-name" style="letter-spacing: 0;font-weight:600;font-size:22px;display:inline-block;">{{orgname}}</div>
  519. <div class="order-title" style="letter-spacing: 0;font-weight:600;font-size:22px;display:inline-block;">血液净化治疗记录单</div>
  520. </div>
  521. <div class="row">
  522. <div class="inline_block" >
  523. 姓名:
  524. <div class="under_line" style="width: 50px;text-align: center;">{{patientInfo.name}}</div>
  525. </div>
  526. <div class="inline_block" style="margin-left: 10px;">
  527. 性别:
  528. <div class="under_line" style="width: 30px;text-align: center;">{{patientInfo_gender_1?"男":"女"}}</div>
  529. </div>
  530. <div class="inline_block" style="margin-left: 10px;">
  531. 年龄:
  532. <div class="under_line" style="width: 30px;text-align: center;">{{getAge(patientInfo)}}</div>
  533. </div>
  534. <div class="inline_block">
  535. 门诊:
  536. <div class="under_line" style="width: 30px;text-align: center;">
  537. <check-box :checked="patientInfo_source_1 "></check-box>
  538. </div>
  539. </div>
  540. <div class="inline_block">
  541. 病区:
  542. <div class="under_line" style="width: 50px;text-align: center;">
  543. {{'/'}}
  544. </div>
  545. </div>
  546. <div class="inline_block">
  547. 床号:
  548. <div class="under_line" style="width: 50px;text-align: center;">
  549. {{'/'}}
  550. </div>
  551. </div>
  552. <div class="inline_block">
  553. 透析号:
  554. <div class="under_line" style="width: 70px;text-align: center;">
  555. {{patientInfo.dialysis_no}}
  556. </div>
  557. </div>
  558. <div class="inline_block" style="margin-left: 5px;">
  559. 住院号/门诊号:
  560. <div class="under_line" style="width: 70px;text-align: left" v-if="patientInfo.admission_number">
  561. {{patientInfo.admission_number}}
  562. </div>
  563. <div class="under_line" style="width: 70px;text-align: left" v-else>
  564. {{'/'}}
  565. </div>
  566. </div>
  567. </div>
  568. <div class="row" >
  569. <div class="inline_block" >
  570. 入科方式:
  571. <div class="under_line" v-if="receiverTreatmentAccess.way==0" style="width: 180px;text-align: left"> </div>
  572. <div class="under_line" v-if="receiverTreatmentAccess.way==1" style="width: 180px;text-align: left">步行 </div>
  573. <div class="under_line" v-if="receiverTreatmentAccess.way==2" style="width: 180px;text-align: left">扶行 </div>
  574. <div class="under_line" v-if="receiverTreatmentAccess.way==3" style="width: 180px;text-align: left">轮椅 </div>
  575. <div class="under_line" v-if="receiverTreatmentAccess.way==4" style="width: 180px;text-align: left">平车 </div>
  576. </div>
  577. <div class="inline_block" style="margin-left: 10px;">
  578. 诊断:
  579. <div class="under_line" style="width: 180px;text-align: left">{{patientInfo.diagnose}}</div>
  580. </div>
  581. </div>
  582. </template>
  583. <div class="row" style="margin-top:-11px;position: relative;">
  584. <table class="proj_table">
  585. <tbody>
  586. <tr><td colspan="2" style="letter-spacing:5px;text-align:center;font-weight:520;font-size:16px;padding: 6px 8px;line-height: 30px;">透析后情况</td></tr>
  587. <tr>
  588. <td>
  589. <div class="row" style="padding: 2px 0;line-height:23px; display:flex;">
  590. <div class="inline_block" style="flex:1;" >
  591. T:
  592. <div class="under_line" style="width: 50px;text-align: center">
  593. {{afterdialysis.temperature?afterdialysis.temperature:'/'}}
  594. </div>
  595. °C
  596. </div>
  597. <div class="inline_block" style="margin-left:10px;flex:1;">
  598. P:
  599. <div class="under_line" style="width: 50px;text-align: center;">
  600. {{afterdialysis.pulse_frequency?afterdialysis.pulse_frequency:'/'}}
  601. </div>
  602. 次/分
  603. </div>
  604. <div class="inline_block" style="margin-left:10px;flex:1;">
  605. R:
  606. <div class="under_line" style="width: 50px;text-align: center;">
  607. {{afterdialysis.breathing_rate?afterdialysis.breathing_rate:'/'}}
  608. </div>
  609. 次/分
  610. </div>
  611. <div class="inline_block" style="margin-left:10px;flex:1.5;">
  612. BP:
  613. <div class="under_line" style="width: 50px;text-align: center;">
  614. {{afterdialysis.systolic_blood_pressure?afterdialysis.systolic_blood_pressure:'/'}}
  615. </div>
  616. /
  617. <div class="under_line" style="width: 50px;text-align: center;">
  618. {{afterdialysis.diastolic_blood_pressure?afterdialysis.diastolic_blood_pressure:'/'}}
  619. </div>
  620. mmHg
  621. </div>
  622. <div class="inline_block" style="margin-left:10px;flex:1.5;">
  623. 实际治疗时间:
  624. <div class="under_line" style="width: 20px;text-align: center">
  625. {{afterdialysis.actual_treatment_hour?afterdialysis.actual_treatment_hour:'/'}}
  626. </div>
  627. h
  628. <div class="under_line" style="width: 20px;text-align: center">
  629. {{afterdialysis.actual_treatment_minute?afterdialysis.actual_treatment_minute:0}}
  630. </div>
  631. min
  632. </div>
  633. </div>
  634. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  635. <div class="inline_block" style="flex:2;">
  636. 凝血程度:
  637. <div class="under_line" style="width: 200px;text-align: center">
  638. {{afterdialysis.cruor?afterdialysis.cruor:'/'}}
  639. </div>
  640. </div>
  641. <div class="inline_block" style="flex:2;">
  642. 内瘘:
  643. <div class="under_line" style="width: 200px;text-align: center">
  644. {{afterdialysis.internal_fistula?afterdialysis.internal_fistula:'/'}}
  645. </div>
  646. </div>
  647. <div class="inline_block" style="flex:1;">
  648. 导管:
  649. <div class="under_line" style="width: 150px;text-align: center">
  650. {{afterdialysis.catheter?afterdialysis.catheter:'/'}}
  651. </div>
  652. </div>
  653. </div>
  654. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  655. <div class="inline_block" style="flex:1;">
  656. 透后体重:
  657. <div class="under_line" style="width: 50px;text-align: center">
  658. {{afterdialysis.weight_after?afterdialysis.weight_after:'/'}}
  659. </div>kg
  660. </div>
  661. <div class="inline_block" style="flex:1;">
  662. 体重减少:
  663. <div class="under_line" style="width: 50px;text-align: center">
  664. {{afterdialysis.weight_loss?afterdialysis.weight_loss:'/'}}
  665. </div>kg
  666. </div>
  667. <div class="inline_block" style="flex:1;">
  668. 透析中入量:
  669. <div class="under_line" style="width: 50px;text-align: center">
  670. {{afterdialysis.dialysis_intakes?afterdialysis.dialysis_intakes:'/'}}
  671. </div>{{getUnit(afterdialysis.dialysis_intakes_unit)}}
  672. </div>
  673. <div class="inline_block" style="flex:1;">
  674. 实际超滤量:
  675. <div class="under_line" style="width: 50px;text-align: center">
  676. {{afterdialysis.actual_ultrafiltration?afterdialysis.actual_ultrafiltration:'/'}}
  677. </div>ml
  678. </div>
  679. </div>
  680. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  681. <div class="inline_block" style="flex:1;">
  682. 治疗小结:
  683. <!--<div class="under_line" style="width: 300px;text-align: center">-->
  684. <!--{{summary.dialysis_summary?summary.dialysis_summary:'/'}}-->
  685. <!--</div>-->
  686. <div style="width: 95%;line-height: 25px;text-align: left;margin-left: 2px;text-underline-position: under; text-decoration: underline;"> {{summary.dialysis_summary?summary.dialysis_summary:'/'}}</div>
  687. </div>
  688. </div>
  689. </td>
  690. </tr>
  691. <tr>
  692. <td>
  693. <div class="row" style="padding: 2px 0;line-height:23px;display:flex;">
  694. <div class="inline_block" style="flex:1;">
  695. 穿刺护士:
  696. <div class="under_line" style="width: 80px;text-align: center">
  697. <span v-if="setAdminUserES(dialysisOrder==null?0:dialysisOrder.puncture_nurse) == ''">{{getAdminUser(dialysisOrder==null?0:dialysisOrder.puncture_nurse)}}</span>
  698. <img style="height:20px;" :src="setAdminUserES(dialysisOrder==null?0:dialysisOrder.puncture_nurse)" alt="" srcset="" v-else>
  699. </div>
  700. </div>
  701. <div class="inline_block" style="flex:1;">
  702. 治疗护士:
  703. <div class="under_line" style="width: 80px;text-align: center">
  704. <span v-if="setAdminUserES(dialysisOrder==null?0:dialysisOrder.start_nurse) == ''">{{getAdminUser(dialysisOrder==null?0:dialysisOrder.start_nurse)}}</span>
  705. <img style="height:20px;" :src="setAdminUserES(dialysisOrder==null?0:dialysisOrder.start_nurse)" alt="" srcset="" v-else>
  706. </div>
  707. </div>
  708. <div class="inline_block" style="flex:1;">
  709. 核对人员:
  710. <div class="under_line" style="width: 80px;text-align: center" v-if="dialysisOrder == null">
  711. <span v-if="setAdminUserES(check==null?0:check.creater) == ''">{{getAdminUser(check==null?0:check.creater)}}</span>
  712. <img style="height:20px;" :src="setAdminUserES(check==null?0:check.creater)" alt="" srcset="" v-else>
  713. </div>
  714. <div class="under_line" style="width: 80px;text-align: center" v-if="dialysisOrder != null && dialysisOrder.start_nurse == check.modifier">
  715. <span v-if="setAdminUserES(check==null?0:check.creater) == ''">{{getAdminUser(check==null?0:check.creater)}}</span>
  716. <img style="height:20px;" :src="setAdminUserES(check==null?0:check.creater)" alt="" srcset="" v-else>
  717. </div>
  718. <div class="under_line" style="width: 80px;text-align: center" v-if="dialysisOrder != null && dialysisOrder.start_nurse == check.creater">
  719. <span v-if="setAdminUserES(check==null?0:check.modifier) == ''">{{getAdminUser(check==null?0:check.modifier)}}</span>
  720. <img style="height:20px;" :src="setAdminUserES(check==null?0:check.modifier)" alt="" srcset="" v-else>
  721. </div>
  722. <div class="under_line" style="width: 80px;text-align: center" v-if="dialysisOrder != null && dialysisOrder.start_nurse != check.creater&&dialysisOrder.start_nurse != check.modifier">
  723. <span v-if="setAdminUserES(check==null?0:check.creater) == ''">{{getAdminUser(check==null?0:check.creater)}}</span>
  724. <img style="height:20px;" :src="setAdminUserES(check==null?0:check.creater)" alt="" srcset="" v-else>
  725. </div>
  726. </div>
  727. <div class="inline_block" style="flex:1;">
  728. 下机护士:
  729. <div class="under_line" style="width: 80px;text-align: center">
  730. <span v-if="setAdminUserES(dialysisOrder==null?0:dialysisOrder.finish_nurse) == ''">{{getAdminUser(dialysisOrder==null?0:dialysisOrder.finish_nurse)}}</span>
  731. <img style="height:20px;" :src="setAdminUserES(dialysisOrder==null?0:dialysisOrder.finish_nurse)" alt="" srcset="" v-else>
  732. </div>
  733. </div>
  734. <div class="inline_block" style="flex:1;">
  735. 治疗医生:
  736. <div class="under_line" style="width: 80px;text-align: center">
  737. <span v-if="setAdminUserES(prescription.prescription_doctor) == ''">{{getAdminUser(prescription.prescription_doctor)}}</span>
  738. <img style="height:20px;" :src="setAdminUserES(prescription.prescription_doctor)" alt="" srcset="" v-else>
  739. </div>
  740. </div>
  741. </div>
  742. </td>
  743. </tr>
  744. </tbody>
  745. </table>
  746. <!-- <div class="print-yema">1</div> -->
  747. </div>
  748. </div>
  749. </div>
  750. </template>
  751. <script>
  752. import CheckBox from './option_check_box'
  753. import { getDialysisRecord } from '@/api/dialysis'
  754. import { getDataConfig } from '@/utils/data'
  755. import { jsGetAge, uParseTime } from '@/utils/tools'
  756. import LabelBox from '../printItem/LabelBox'
  757. // import DialysisPrintOrderOne from './template/dialysisPrintOrderOne'
  758. // import DialysisPrintOrderTwo from './template/dialysisPrintOrderTwo'
  759. import print from 'print-js'
  760. export default {
  761. name: 'DialysisPrintOrderSix',
  762. props: ['childResponse'],
  763. components: {
  764. // DialysisPrintOrderOne,
  765. // DialysisPrintOrderTwo,
  766. CheckBox,
  767. LabelBox,
  768. },
  769. data() {
  770. return {
  771. crumbs: [
  772. { path: false, name: '透析管理' },
  773. { path: false, name: '打印单' }
  774. ],
  775. operators: [],
  776. adminUser: [],
  777. check: {},
  778. xtdate: "",
  779. dialysisOrder: {
  780. DeviceNumber: []
  781. },
  782. displaceLiquiPartOptions: [],
  783. operatorMaps: {},
  784. complications: ['低血压', '高血压', '心律失常', '头晕', '头痛', '呕吐', '抽搐', '出血', '心衰', '腹痛'],
  785. jilurow: 0,
  786. advice_jilurow: 0,
  787. loading: false,
  788. orgname: '',
  789. patientInfo_gender_1: false,
  790. patientInfo_gender_2: false,
  791. patientInfo_source_2: false,
  792. patientInfo_source_1: false,
  793. modeOptions: {},
  794. replacementWays: [],
  795. perfusionApparatus: [],
  796. anticoagulantsConfit: {},
  797. bloodAccessParOpera: {},
  798. dialysateFormulationOptions: {},
  799. totollength: 0,
  800. queryParams: {
  801. xtdate: '',
  802. xtno: ''
  803. },
  804. patientInfo: {
  805. birth: '',
  806. age: '',
  807. DialysisSchedule: {
  808. device_number: { number: '' },
  809. device_zone: { name: '' }
  810. },
  811. gender: 0
  812. },
  813. predialysis: {
  814. score: '',
  815. internal_fistula: '',
  816. internal_fistula_skin: '',
  817. catheter: '',
  818. blood_access_part_opera_name: ''
  819. },
  820. afterdialysis: {
  821. complications_index: ''
  822. },
  823. prescription: {
  824. dialysate_formulation_name: '',
  825. device: {}
  826. },
  827. advices: [],
  828. users: [],
  829. monitors: [],
  830. monitors2: [],
  831. summary: {},
  832. receiverTreatmentAccess: {},
  833. org_template_info: {},
  834. doctor_advices: [],
  835. advice_groups: [],
  836. advice_groups_2: [],
  837. print_length : 0,
  838. blood_access_part: [],
  839. blood_access_part_opera: [],
  840. AlPanel: {
  841. id: 0,
  842. name: '',
  843. type: 1,
  844. shouji: 2,
  845. weichi: 2,
  846. zongliang: 2,
  847. gaimingcheng: -1,
  848. gaijiliang: -1,
  849. shouji_unit: 'mg',
  850. weichi_unit: 'mg/h',
  851. zongliang_unit: 'mg',
  852. gaimingcheng_unit: '',
  853. gaijiliang_unit: ''
  854. }
  855. }
  856. },
  857. methods: {
  858. getDisplaceLiquiPart: function (val) {
  859. let displace_liqui_part_name = '/'
  860. let displace_liqui_part = this.displaceLiquiPartOptions
  861. for (let i = 0; i < displace_liqui_part.length; i++) {
  862. if (displace_liqui_part[i].id == val) {
  863. displace_liqui_part_name = displace_liqui_part[i].name
  864. }
  865. }
  866. return displace_liqui_part_name
  867. },
  868. replacementWaysById: function (val) {
  869. let replacementWaysname = '/'
  870. // let vascular_access = getDataConfig('hemodialysis', 'vascular_access')
  871. for (let i = 0; i < this.replacementWays.length; i++) {
  872. if (this.replacementWays[i].id == val) {
  873. replacementWaysname = this.replacementWays[i].name
  874. }
  875. }
  876. return replacementWaysname
  877. },
  878. QueryPartById: function (val) {
  879. let vascular_access_part_name = '/'
  880. let vascular_access = getDataConfig('hemodialysis', 'vascular_access')
  881. for (let i = 0; i < vascular_access.length; i++) {
  882. if (vascular_access[i].id == val) {
  883. vascular_access_part_name = vascular_access[i].name
  884. }
  885. }
  886. return vascular_access_part_name
  887. },
  888. getAdminUser(id) {
  889. if (id == 0) {
  890. return ''
  891. }
  892. if (id == undefined) {
  893. return ''
  894. }
  895. for (let i = 0; i < this.adminUser.length; i++) {
  896. if (this.adminUser[i].id == id) {
  897. return this.adminUser[i].name
  898. }
  899. }
  900. },
  901. getTime(value, temp) {
  902. if (value == 0) {
  903. return ''
  904. }
  905. if (value != undefined) {
  906. return uParseTime(value, temp)
  907. }
  908. return ''
  909. },
  910. printThisPage() {
  911. var ptime = Math.round(new Date().getTime() / 1000)
  912. this.print_time = uParseTime(ptime, '{y}-{m}-{d} {h}:{i}')
  913. const style = '@media print {.dialysis-print-order{width:960px;margin:0 auto}.dialysis-print-order .order-yy-name{margin:auto;text-align:center;font-size:20px;letter-spacing:5px}.dialysis-print-order .order-title{margin:auto;font-weight:600;text-align:center;font-size:22px;padding:10px}.dialysis-print-order .table-box{width:100%;line-height:23px;font-size:14px}.dialysis-print-order .print-table{width:100%;text-align:center;border-collapse:collapse;line-height:25px;font-size:14px}.dialysis-print-order .print-table-no{width:100%;text-align:left;border-collapse:collapse;font-size:14px} .dialysis-print-order .under_line {display: inline-block;border-bottom: 1px solid #999;text-align:left;white-space: nowrap;width: 50%;} .dialysis-print-order .title-box{text-align:center;font-size:16px;border:1px solid #666}.dialysis-print-order .radio-lebel-box{font-weight:400;cursor:pointer}.dialysis-print-order .radio-no{opacity:0;outline:0;position:absolute;margin:0;width:0;height:0;z-index:-1}.dialysis-print-order .radio-inner{white-space:nowrap;cursor:pointer;outline:0;display:inline-block;line-height:1;position:relative;vertical-align:middle}.dialysis-print-order .radio-fang{display:inline-block;position:relative;border:1px solid #000;box-sizing:border-box;width:14px;height:14px;background-color:#fff;z-index:1;transition:border-color .25s cubic-bezier(.71,-.46,.29,1.46),background-color .25s cubic-bezier(.71,-.46,.29,1.46)}.dialysis-print-order .is-checked-radio::after{content:"√";font-size:15px}}.dialysis-print-order .print-table-no tr td { padding: 8px 5px; line-height: 25px; }.es-img{height: 20px; }.advice-name{text-align: left;}.advice-children{display:flex;} .dialysis-print-order .print-table tr td{padding: 0px 0px;} .print-template-two tr {line-height: 30px;} .title-box-pro{border: 0 #fff;line-height: 40px;height: 40px;text-align: left;padding-left: 10px !important;} .text-align-left{text-align: left !important;padding-left:10px !important;font-size: 14px !important;line-height: 25px;}'
  914. if (this.org_template_info.template_id == 1) {
  915. printJS({
  916. printable: 'dialysis-print-box',
  917. type: 'html',
  918. style: style,
  919. scanStyles: false
  920. })
  921. } else if (this.org_template_info.template_id == 2 ||this.org_template_info.template_id == 0 ) {
  922. printJS({
  923. printable: 'dialysis-print-box-1',
  924. type: 'html',
  925. style: style,
  926. scanStyles: false
  927. })
  928. }
  929. }, getNumber() {
  930. if (this.dialysisOrder != null) {
  931. return this.patientInfo.DialysisSchedule.device_zone.name + this.dialysisOrder.DeviceNumber.number
  932. } else {
  933. return this.patientInfo.DialysisSchedule.device_zone.name + this.patientInfo.DialysisSchedule.device_number.number
  934. }
  935. },
  936. getXuserName(id) {
  937. if (id <= 0) {
  938. return ''
  939. }
  940. var name = ''
  941. if (this.users == null || typeof (this.users.length) === 'undefined') {
  942. return name
  943. }
  944. var leng = this.users.length
  945. if (leng == 0) {
  946. return name
  947. }
  948. for (let index = 0; index < leng; index++) {
  949. if (this.users[index].id == id) {
  950. name = this.users[index].name
  951. break
  952. }
  953. }
  954. return name
  955. },
  956. setAdminUserES(id) {
  957. if (id == 0) {
  958. return ''
  959. }
  960. if (id in this.operatorMaps) {
  961. return this.operatorMaps[id].url
  962. } else {
  963. return ''
  964. }
  965. },
  966. modeName(mode_id) {
  967. return typeof (this.modeOptions[mode_id]) !== 'undefined' && typeof (this.modeOptions[mode_id].name) !== 'undefined' ? this.modeOptions[mode_id].name : ''
  968. },
  969. getDialysisRecord() {
  970. this.loading = true
  971. // getDialysisRecord(this.queryParams).then(response => {
  972. var response = this.childResponse
  973. if (response.data.state == 1) {
  974. this.adminUser = response.data.data.users
  975. this.users = response.data.data.users
  976. this.patientInfo = response.data.data.patientInfo
  977. this.patientInfo.birth = uParseTime(this.patientInfo.birthday, '{y}-{m}-{d}')
  978. // this.patientInfo.age = jsGetAge(this.patientInfo.birth, '-')
  979. if (response.data.data.patientInfo.first_dialysis_date != 0) {
  980. this.patientInfo.first_dialysis_date = uParseTime(response.data.data.patientInfo.first_dialysis_date, '{y}-{m}-{d}')
  981. } else {
  982. this.patientInfo.first_dialysis_date = ''
  983. }
  984. this.check = response.data.data.check
  985. this.xtdate = this.$route.query.xtdate
  986. this.predialysis = response.data.data.PredialysisEvaluation
  987. this.predialysis.blood_access_part_opera_name = this.bloodAccessParOperaName(this.predialysis.blood_access_part_opera_id)
  988. this.afterdialysis = response.data.data.AssessmentAfterDislysis
  989. this.operators = response.data.data.operators
  990. this.dialysisOrder = response.data.data.dialysisOrder === null ? null : response.data.data.dialysisOrder
  991. if (this.operators.length > 0) {
  992. var operatorsLen = this.operators.length
  993. for (var index = 0; index < operatorsLen; index++) {
  994. this.$set(this.operatorMaps, this.operators[index].creator, this.operators[index])
  995. }
  996. }
  997. this.afterdialysis.txqnx = -1
  998. if (this.afterdialysis.cruor.indexOf('0度') > -1) {
  999. this.afterdialysis.txqnx = 0
  1000. }
  1001. if (this.afterdialysis.cruor.indexOf('Ⅰ度') > -1) {
  1002. this.afterdialysis.txqnx = 1
  1003. }
  1004. if (this.afterdialysis.cruor.indexOf('Ⅱ度') > -1) {
  1005. this.afterdialysis.txqnx = 2
  1006. }
  1007. if (this.afterdialysis.cruor.indexOf('Ⅲ度') > -1) {
  1008. this.afterdialysis.txqnx = 3
  1009. }
  1010. this.afterdialysis.complications = this.afterdialysis.complication.split(',')
  1011. this.afterdialysis.complications_other = []
  1012. this.afterdialysis.complications_index = []
  1013. var acllen = this.afterdialysis.complications.length
  1014. for (let index = 0; index < acllen; index++) {
  1015. if (this.complications.indexOf(this.afterdialysis.complications[index]) >= 0) {
  1016. this.afterdialysis.complications_index.push(this.afterdialysis.complications[index])
  1017. } else if (this.complications.indexOf(this.afterdialysis.complications[index]) < 0 && this.afterdialysis.complications_other.indexOf(this.afterdialysis.complications[index]) < 0) {
  1018. this.afterdialysis.complications_other.push(this.afterdialysis.complications[index])
  1019. }
  1020. }
  1021. this.afterdialysis.complications_other = this.afterdialysis.complications_other.join(',')
  1022. this.prescription = response.data.data.dialysisPrescription
  1023. this.receiverTreatmentAccess = response.data.data.receiverTreatmentAccess
  1024. this.prescription.mode = this.modeName(this.prescription.mode_id)
  1025. var rwLen = this.replacementWays.length
  1026. this.prescription.replacement = ''
  1027. for (let index = 0; index < rwLen; index++) {
  1028. if (this.replacementWays[index].id == this.prescription.replacement_way) {
  1029. this.prescription.replacement = this.replacementWays[index].name
  1030. break
  1031. }
  1032. }
  1033. this.prescription.dialysate_formulation_name = this.dialysateFormulationName(this.prescription.dialysate_formulation)
  1034. var paLen = this.perfusionApparatus.length
  1035. this.prescription.perfusion_apparatus_name = ''
  1036. for (let index = 0; index < paLen; index++) {
  1037. if (this.perfusionApparatus[index].id == this.prescription.perfusion_apparatus) {
  1038. this.prescription.perfusion_apparatus_name = this.perfusionApparatus[index].name
  1039. break
  1040. }
  1041. }
  1042. var acLen = this.anticoagulantsConfit.length
  1043. var thisALID = this.prescription.anticoagulant
  1044. this.prescription.anticoagulant_name = ''
  1045. if (typeof (this.anticoagulantsConfit[thisALID]) !== 'undefined' && this.anticoagulantsConfit[thisALID] != null) {
  1046. this.prescription.anticoagulant_name = this.anticoagulantsConfit[thisALID].name
  1047. this.AlPanel = this.anticoagulantsConfit[thisALID]
  1048. }
  1049. this.advices = response.data.data.advices
  1050. this.monitors = response.data.data.monitors
  1051. this.summary = response.data.data.summary
  1052. this.org_template_info = response.data.data.org_template_info
  1053. if (this.monitors.length <= 6) {
  1054. var nl = 6
  1055. this.print_length = 6
  1056. for (let index = 0; index < nl; index++) {
  1057. if (this.monitors[index] == undefined || this.monitors[index].length <= 0) {
  1058. this.monitors2.push([])
  1059. } else {
  1060. continue
  1061. }
  1062. }
  1063. }
  1064. var tempmonitorflag = true;
  1065. for (let index = 0; index < this.monitors.length; index++) {
  1066. const monitor = this.monitors[index];
  1067. this.monitors[index].end =""
  1068. if(Object.keys(monitor).length > 0 && index > 1){
  1069. if(monitor.operate_time == this.dialysisOrder.end_time){
  1070. this.monitors[index].end ="【结束透析】"
  1071. tempmonitorflag = false
  1072. }
  1073. if(tempmonitorflag && index == this.monitors.length-1){
  1074. this.monitors[index].end ="【结束透析】"
  1075. }
  1076. }
  1077. }
  1078. this.jilurow = this.monitors.length + 1
  1079. this.advice_jilurow = this.advices.length + 1
  1080. var childMap = {}
  1081. for (const index in this.advices) {
  1082. if (this.advices[index].parent_id == 0) {
  1083. continue
  1084. }
  1085. if (!(this.advices[index].parent_id in childMap)) {
  1086. childMap[this.advices[index].parent_id] = []
  1087. }
  1088. childMap[this.advices[index].parent_id].push(this.advices[index])
  1089. }
  1090. var advices = []
  1091. for (const index in this.advices) {
  1092. if (this.advices[index].parent_id > 0) {
  1093. continue
  1094. }
  1095. var item = this.advices[index]
  1096. if (item.id in childMap) {
  1097. item.children = childMap[item.id]
  1098. } else {
  1099. item.children = []
  1100. }
  1101. advices.push(item)
  1102. }
  1103. var leftAdvice = []
  1104. var rightAdvice = []
  1105. var adlen = advices.length
  1106. var halfLen = adlen % 2 == 0 ? adlen / 2 : (adlen + 1) / 2
  1107. for (var i = 0; i < halfLen; i++) {
  1108. leftAdvice.push(advices[i])
  1109. rightAdvice.push(advices[i + halfLen])
  1110. }
  1111. if (halfLen < 5) {
  1112. var nl = 5 - leftAdvice.length
  1113. for (let index = 0; index < nl; index++) {
  1114. leftAdvice.push([])
  1115. }
  1116. var nl = 5 - rightAdvice.length
  1117. for (let index = 0; index < nl; index++) {
  1118. rightAdvice.push([])
  1119. }
  1120. }
  1121. this.advices = []
  1122. for (var i = 0; i < halfLen; i++) {
  1123. var item = []
  1124. item.push(leftAdvice[i])
  1125. item.push(rightAdvice[i])
  1126. this.advices.push(item)
  1127. }
  1128. this.loading = false
  1129. this.doctor_advices = response.data.data.advices == null ? [] : response.data.data.advices
  1130. for (let index = 0; index < this.doctor_advices.length; index++) {
  1131. this.doctor_advices[index]['isShow'] = 2
  1132. }
  1133. // if (this.doctor_advices.length > 0) {
  1134. // var group = this.newAdviceGroupObject()
  1135. // var initGroupBlock = function(group, advice) {
  1136. // group.group_no = advice.groupno
  1137. // }
  1138. // for (let index = this.doctor_advices.length - 1; index >= 0; index--) {
  1139. // var new_advice_index = 0
  1140. // if ('children' in this.doctor_advices[index] && this.doctor_advices[index].children.length > 0) {
  1141. // new_advice_index = index + this.doctor_advices[index].children.length + 1
  1142. // var doctor_advice = {
  1143. // delivery_way: this.doctor_advices[index].delivery_way,
  1144. // execution_frequency: this.doctor_advices[index].execution_frequency,
  1145. // groupno: this.doctor_advices[index].groupno,
  1146. // id: this.doctor_advices[index].id,
  1147. // parent_id: this.doctor_advices[index].parent_id,
  1148. // children: this.doctor_advices[index].children,
  1149. // remark: this.doctor_advices[index].remark,
  1150. // execution_staff: this.doctor_advices[index].execution_staff,
  1151. // checker: this.doctor_advices[index].checker,
  1152. // execution_time: this.doctor_advices[index].execution_time,
  1153. // advice_doctor: this.doctor_advices[index].advice_doctor
  1154. // }
  1155. // doctor_advice['isShow'] = 1
  1156. // this.doctor_advices.splice(new_advice_index, 0, doctor_advice)
  1157. // // this.doctor_advices.push(doctor_advice)
  1158. // }
  1159. // }
  1160. // for (let index = 0; index < this.doctor_advices.length; index++) {
  1161. // const advice = this.doctor_advices[index]
  1162. // if (advice.groupno == 0) {
  1163. // // 老版本的医嘱没有分组的概念,所以这一个 if 是解决这个问题的,将每个无分组的医嘱各自归为一组
  1164. // if (advice.parent_id > 0) {
  1165. // if (this.advice_groups.length > 0) {
  1166. // var parent_group = this.advice_groups[
  1167. // this.advice_groups.length - 1
  1168. // ]
  1169. // if (parent_group.advices.length > 0) {
  1170. // if (parent_group.advices[0].id == advice.parent_id) {
  1171. // parent_group.advices.push(advice)
  1172. // }
  1173. // }
  1174. // }
  1175. // continue
  1176. // } else {
  1177. // if (group.group_no > 0) {
  1178. // this.advice_groups.push(group)
  1179. // group = this.newAdviceGroupObject()
  1180. // }
  1181. // initGroupBlock(group, advice)
  1182. // group.advices.push(advice)
  1183. // this.advice_groups.push(group)
  1184. // group = this.newAdviceGroupObject()
  1185. // continue
  1186. // }
  1187. // }
  1188. // if (group.group_no > 0 && group.group_no != advice.groupno) {
  1189. // this.advice_groups.push(group)
  1190. // group = this.newAdviceGroupObject()
  1191. // }
  1192. // if (group.group_no == 0) {
  1193. // initGroupBlock(group, advice)
  1194. // }
  1195. // if (group.group_no == advice.groupno) {
  1196. // group.advices.push(advice)
  1197. // }
  1198. // }
  1199. // if (group.group_no > 0) {
  1200. // // 上述的算法会导致最后一组没有加到advice_groups,这里要手动加上
  1201. // this.advice_groups.push(group)
  1202. // }
  1203. // }
  1204. if (this.doctor_advices.length <= 6) {
  1205. var nl = 6
  1206. this.print_length = 6
  1207. for (let index = 0; index < nl; index++) {
  1208. if (this.doctor_advices[index] == undefined || this.doctor_advices[index].length <= 0) {
  1209. this.doctor_advices.push([])
  1210. } else {
  1211. continue
  1212. }
  1213. }
  1214. }
  1215. this.totollength = this.doctor_advices.length + this.monitors.length
  1216. console.log(this.advice_groups)
  1217. } else {
  1218. this.loading = false
  1219. this.$message.error('请求数据失败')
  1220. return false
  1221. }
  1222. // })
  1223. },
  1224. bloodAccessParOperaName(id) {
  1225. if (id in this.bloodAccessParOpera) {
  1226. return this.bloodAccessParOpera[id].name
  1227. }
  1228. return ''
  1229. },
  1230. dialysateFormulationName(id) {
  1231. if (id in this.dialysateFormulationOptions) {
  1232. return this.dialysateFormulationOptions[id].name
  1233. }
  1234. return ''
  1235. }, getAge: function(val) {
  1236. if (this.org_template_info.template_id == 2 || this.org_template_info.template_id == 0) {
  1237. if (val.age == 0) {
  1238. return jsGetAge(val.birth, '-')
  1239. } else {
  1240. return val.age
  1241. }
  1242. } else {
  1243. return jsGetAge(val.birth, '-')
  1244. }
  1245. }, newAdviceGroupObject: function() {
  1246. return Object.assign(
  1247. {},
  1248. {
  1249. group_no: 0,
  1250. // advice_doctor: 0,
  1251. // start_time: 0,
  1252. advices: []
  1253. // exec_staff: 0,
  1254. // exec_time: 0,
  1255. // checker: 0,
  1256. }
  1257. )
  1258. }, getFloat: function(x) {
  1259. if(x == 0){
  1260. return "/"
  1261. }
  1262. if (x != '.') {
  1263. var f = Math.round(x * 100) / 100
  1264. var s = f.toString()
  1265. var rs = s.indexOf('.')
  1266. if (rs <= 0) {
  1267. rs = s.length
  1268. s += '.'
  1269. }
  1270. while (s.length <= rs + 1) {
  1271. s += '0'
  1272. }
  1273. return s
  1274. } else {
  1275. return '0.0'
  1276. }
  1277. },getUnit:function (val) {
  1278. switch (val) {
  1279. case 1:
  1280. return "g"
  1281. break
  1282. case 2:
  1283. return "ml"
  1284. break
  1285. }
  1286. }
  1287. },
  1288. watch: {
  1289. 'patientInfo.gender': function() {
  1290. if (this.patientInfo.gender == 1) {
  1291. this.patientInfo_gender_1 = true
  1292. this.patientInfo_gender_2 = false
  1293. } else if (this.patientInfo.gender == 2) {
  1294. this.patientInfo_gender_2 = true
  1295. this.patientInfo_gender_1 = false
  1296. } else {
  1297. this.patientInfo_gender_2 = false
  1298. this.patientInfo_gender_1 = false
  1299. }
  1300. },
  1301. 'patientInfo.source': function() {
  1302. if (this.patientInfo.source == 1) {
  1303. this.patientInfo_source_1 = true
  1304. this.patientInfo_source_2 = false
  1305. } else if (this.patientInfo.source == 2) {
  1306. this.patientInfo_source_2 = true
  1307. this.patientInfo_source_1 = false
  1308. } else {
  1309. this.patientInfo_source_2 = false
  1310. this.patientInfo_source_1 = false
  1311. }
  1312. }
  1313. },
  1314. created() {
  1315. var xtuser = this.$store.getters.user
  1316. this.orgname = xtuser.org.org_name
  1317. // this.orgname = "遂溪方济医院";
  1318. this.modeOptions = this.$store.getters.treatment_mode
  1319. this.replacementWays = this.$store.getters.replacement_ways
  1320. this.perfusionApparatus = this.$store.getters.perfusion_apparatus
  1321. this.anticoagulantsConfit = this.$store.getters.anticoagulants_confit
  1322. this.displaceLiquiPartOptions = this.$store.getters.displace_liqui
  1323. this.blood_access_part = getDataConfig('hemodialysis', 'vascular_access')
  1324. this.blood_access_part_opera = getDataConfig('hemodialysis', 'vascular_access_desc')
  1325. // this.bloodAccessParOpera = getDataConfig('hemodialysis', 'vascular_access_desc')
  1326. var bloodAccessParOpera = getDataConfig('hemodialysis', 'vascular_access_desc')
  1327. for (var key in bloodAccessParOpera) {
  1328. this.bloodAccessParOpera[bloodAccessParOpera[key].id] = bloodAccessParOpera[key]
  1329. }
  1330. var dialysateFormulationOptions = getDataConfig('hemodialysis', 'dialysate_formulation')
  1331. for (var key in dialysateFormulationOptions) {
  1332. this.dialysateFormulationOptions[dialysateFormulationOptions[key].id] = dialysateFormulationOptions[key]
  1333. }
  1334. const xtdate = this.$route.query && this.$route.query.xtdate
  1335. const xtno = this.$route.query && this.$route.query.xtno
  1336. if (typeof (xtdate) === 'string' && xtdate.length > 0 && typeof (xtno) === 'string' && xtno.length > 0) {
  1337. this.queryParams.xtdate = xtdate
  1338. this.queryParams.xtno = xtno
  1339. this.getDialysisRecord()
  1340. } else {
  1341. this.$message.error('参数不齐')
  1342. return false
  1343. }
  1344. }
  1345. }
  1346. </script>
  1347. <style>
  1348. .print_page_main_content {
  1349. background-color: white;
  1350. width: 960px;
  1351. margin: 0 auto 50px;
  1352. padding: 0 0 0 0;
  1353. page-break-after: always;
  1354. }
  1355. .print_page_main_content .order-yy-name {
  1356. margin: auto;
  1357. text-align: center;
  1358. font-size: 20px;
  1359. letter-spacing: 5px;
  1360. }
  1361. .dialysis-print-order .order-title {
  1362. margin: auto;
  1363. font-weight: 600;
  1364. text-align: center;
  1365. font-size: 22px;
  1366. padding: 10px;
  1367. }
  1368. .print_page_main_content .order_title {
  1369. text-align: center;
  1370. font-size: 23px;
  1371. line-height: 50px;
  1372. font-weight: 500;
  1373. }
  1374. .row {
  1375. font-size: 14px;
  1376. line-height: 20px;
  1377. padding: 5px 0;
  1378. }
  1379. .inline_block {
  1380. display: inline-block;
  1381. }
  1382. .under_line_two {display: inline-block;border-bottom: 1px solid #999;text-align: left;white-space: nowrap;width: 50%;}
  1383. .under_line_two::before {content: "\00A0";}
  1384. .under_line_two::after {content: "\00A0";}
  1385. .under_line {display: inline-block;border-bottom: 1px solid #999;text-align: center;white-space: nowrap;width: 50%;}
  1386. .under_line::before {
  1387. content: "\00A0";
  1388. }
  1389. .under_line::after {
  1390. content: "\00A0";
  1391. }
  1392. .flex {
  1393. display: -webkit-box;
  1394. display: -moz-box;
  1395. display: -ms-flexbox;
  1396. display: -webkit-flex;
  1397. display: flex;
  1398. align-items: center;
  1399. -webkit-align-items: center;
  1400. box-align: center;
  1401. -moz-box-align: center;
  1402. -webkit-box-align: center;
  1403. text-align: center;
  1404. -webkit-justify-content: space-between;
  1405. justify-content: space-between;
  1406. -moz-box-pack: space-between;
  1407. -webkit--moz-box-pack: space-between;
  1408. box-pack: space-between;
  1409. }
  1410. .print_page_main_content .proj_table {
  1411. width: 100%;
  1412. border: 1px solid;
  1413. border-collapse: collapse;
  1414. padding: 2px;
  1415. }
  1416. .print_page_main_content .proj_table tbody tr td {
  1417. border: 1px solid;
  1418. /* text-align: center; */
  1419. font-size: 16px;
  1420. padding: 5px 8px;
  1421. line-height: 30px;
  1422. }
  1423. .print_page_main_content .proj_table .inside_table {
  1424. width: 100%;
  1425. border: hidden; /* 解决边框冲突 */
  1426. border-collapse: collapse;
  1427. }
  1428. .print_page_main_content .proj_table .inside_table tr td {
  1429. border: 1px solid;
  1430. text-align: center;
  1431. font-size: 14px;
  1432. padding: 6px 5px;
  1433. line-height: 16px;
  1434. }
  1435. .print-table-no {
  1436. width: 100%;
  1437. text-align: center;
  1438. border-collapse: collapse;
  1439. font-size: 14px;
  1440. }
  1441. .es-img {
  1442. height: 20px;
  1443. }
  1444. .advice-name {
  1445. text-align: left !important;
  1446. line-height: 16px !important;
  1447. }
  1448. .advice-children {
  1449. display: flex;
  1450. }
  1451. .margin-bottom-50{
  1452. }
  1453. .margin-bottom-300 {
  1454. margin-bottom:450px;
  1455. }
  1456. .margin-bottom-600 {
  1457. margin-bottom:600px;
  1458. }
  1459. .margin-bottom-900 {
  1460. margin-bottom:900px;
  1461. }
  1462. .print-yema{
  1463. position: absolute;
  1464. left: 50%;
  1465. }
  1466. .print-yema2{
  1467. position: absolute;
  1468. left: 50%;
  1469. }
  1470. .print-yema3{
  1471. position: absolute;
  1472. left: 50%;
  1473. }
  1474. .print-yema4{
  1475. position: absolute;
  1476. left: 50%;
  1477. }
  1478. .check_box_panel .did_checke::after {
  1479. font-size: 8px;
  1480. margin-left: 2px;
  1481. margin-top: 2px;
  1482. position: absolute;
  1483. }
  1484. </style>