血透系统PC前端

DialysisPrintOrderSix.vue 66KB

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