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

printSix.vue 16KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563
  1. <template>
  2. <div id="prescriptionPrint">
  3. <div v-for="(item, index) in advicePrint" :key="index">
  4. <div
  5. id="prescription-print"
  6. class="prescription-print"
  7. style="page-break-after: always"
  8. >
  9. <div class="printTitle" v-if="prescriptions[index].med_type == '1111'">
  10. {{ orgname }}第一类精神处方笺
  11. </div>
  12. <div class="printTitle" v-if="prescriptions[index].med_type == '1112'">
  13. {{ orgname }}第二类精神处方笺
  14. </div>
  15. <div
  16. v-if="
  17. prescriptions[index].med_type != '1112' &&
  18. prescriptions[index].med_type != '1111'
  19. "
  20. class="printTitle"
  21. >
  22. {{ orgname }}处方笺 普通
  23. <!-- <div v-else style="line-height: 60px;font-size: 30px;">{{ orgname }}处方笺</div>-->
  24. <!-- <img class="logo" src="../assets/shuiyin.jpg" alt="加载失败..">-->
  25. </div>
  26. <div class="infoTitle" style="border-bottom: 1px solid #000">
  27. <p style="width: 174px">科室:{{ item.info ? getDepart(item.info.departments) : "" }}</p>
  28. <p style="width: 150px">费别:</p>
  29. <p style="width: 210px" v-if="hisPatient.number.length <= 11">
  30. 门诊号:{{ hisPatient.number ? hisPatient.number : "" }}
  31. </p>
  32. <p style="text-align: right; width: 155px">
  33. <span>{{ record_date.split("-")[0] }}年</span
  34. ><span>{{ record_date.split("-")[1] }}月</span
  35. ><span>{{ record_date.split("-")[2] }}日</span>
  36. <!-- {{getTime(item.ctime)?getTime(item.ctime):""}} -->
  37. </p>
  38. </div>
  39. <div
  40. class="infoTitle"
  41. style="border-bottom: 1px solid #000"
  42. v-if="hisPatient.number.length > 11"
  43. >
  44. <p style="width: 100%;">
  45. 门诊号:{{
  46. hisPatient.number ? hisPatient.number : ""
  47. }}
  48. </p>
  49. </div>
  50. <div class="infoTitle" style="border-bottom: 1px solid #000">
  51. <p style="width: 150px;">姓名:{{ item.patient.name ? item.patient.name : "" }}</p>
  52. <p style="width: 145px;">
  53. 性别:
  54. <span v-if="item.patient.gender == 1">男</span>
  55. <span v-if="item.patient.gender == 2">女</span>
  56. </p>
  57. <p style="width: 135px;">年龄:{{ getAge(item.patient) ? getAge(item.patient) : "" }}岁</p>
  58. <p style="max-width: 150px;text-align: right;">电话:{{ item.patient.phone }}</p>
  59. </div>
  60. <div class="infoTitle" style="border-bottom: 1px solid #000">
  61. <p style="width:100%">地址:{{ item.patient.home_address }}</p>
  62. </div>
  63. <div class="infoMain">
  64. <div style="display:flex;width:100%">诊断:{{ getDiagnosis(item.info.diagnosis) }}</div>
  65. </div>
  66. <div class="prescriptionBox">
  67. <div class="Rp">R:</div>
  68. <div
  69. class="drugsBox"
  70. v-for="(it, index) in item.advices"
  71. :key="index"
  72. :style="{'page-break-after':index==yi&&item.advices.length>5? 'always':'auto'}"
  73. >
  74. <!-- <div class="drugsOne"><span style="font-weight:bold;">{{ index+1 + '.' }}</span>{{it.advice_name?it.advice_name:""}}&nbsp;&nbsp;{{it.single_dose}}{{it.single_dose_unit}}&nbsp;×&nbsp; {{it.prescribing_number}}{{it.prescribing_number_unit}}</div> -->
  75. <div class="drugsOne">
  76. <!-- <span style="font-weight: bold">{{ index + 1 + "." }}</span> -->
  77. {{ it.advice_name ? it.advice_name : "" }}&nbsp;&nbsp;<span
  78. v-if="it.drug.min_unit != it.drug.dose_unit"
  79. >{{ it.drug.dose }}{{ it.drug.dose_unit }}&nbsp;* &nbsp;</span
  80. >{{ it.drug.min_number }}{{ it.drug.min_unit }}/{{
  81. it.drug.max_unit
  82. }}&nbsp;×&nbsp; {{ it.prescribing_number
  83. }}{{ it.prescribing_number_unit }}
  84. </div>
  85. <div style="margin-left: 100px">
  86. <span>用法:{{ it.single_dose }}{{ it.single_dose_unit }}</span
  87. >&nbsp;&nbsp;<span
  88. >{{ it.execution_frequency }}&nbsp;{{
  89. it.delivery_way
  90. }}&nbsp;</span
  91. >&nbsp;&nbsp;<span>{{ it.advice_desc }}</span>
  92. </div>
  93. </div>
  94. <div
  95. class="drugsBox"
  96. v-for="(it, i) in item.additionalcharge"
  97. :key="i"
  98. >
  99. <div class="drugsOne">
  100. {{ it.item_name ? it.item_name : "" }}:&nbsp;{{ it.price }}元/{{
  101. it.count
  102. }}次
  103. </div>
  104. </div>
  105. <div
  106. class="drugsBox"
  107. v-for="(it, index) in item.project"
  108. :key="index"
  109. >
  110. <div class="drugsOne">
  111. <!-- <span style="font-weight: bold">{{ index + 1 + "." }}</span> -->
  112. {{
  113. it.type == 2
  114. ? getProjectName(it.project_id)
  115. ? getProjectName(it.project_id)
  116. : ""
  117. : it.good_info.good_name
  118. }}&nbsp;&nbsp;{{ it.single_dose
  119. }}{{ it.single_dose_unit }}&nbsp;×&nbsp; {{ it.count }}{{ unit }}
  120. </div>
  121. <div style="margin-left: 100px">
  122. <span>用法:{{ it.single_dose }}{{ it.single_dose_unit }}</span
  123. >&nbsp;&nbsp;<span>{{ it.delivery_way }}</span
  124. >&nbsp;&nbsp;<span>{{ it.advice_desc }}</span>
  125. </div>
  126. </div>
  127. <div
  128. class="drugsBox"
  129. v-for="(it, i) in item.additionalcharge"
  130. :key="i"
  131. >
  132. <div class="drugsOne">
  133. {{ it.project_id ? it.project_id : "" }}:&nbsp;{{
  134. it.price.toFixed(2)
  135. }}元/{{ it.count }}次
  136. </div>
  137. </div>
  138. <!-- <div style="text-align: center">(以下空白)</div> -->
  139. </div>
  140. <div class="infoTitle"></div>
  141. <div class="actionBar" v-if="org_id != 10188">
  142. <div class="actionBar_list">
  143. <div style="width:120px;">
  144. 医师:
  145. <span>{{ item.doctor ? item.doctor : "" }} </span>
  146. </div>
  147. </div>
  148. <div class="actionBar_list">
  149. <div style="width:120px;">
  150. 审核:<span v-if="item.advices.length> 0 || item.advices != undefined" >{{
  151. getDoctor(item.advices[0].checker)
  152. ? getDoctor(item.advices[0].checker)
  153. : ""
  154. }}</span>
  155. </div>
  156. </div>
  157. <div class="actionBar_list">
  158. <div style="width:120px;">
  159. 金额:
  160. {{
  161. getTotalOne(item.id).toFixed(2)
  162. ? getTotalOne(item.id).toFixed(2)
  163. : 0
  164. }}
  165. </div>
  166. <!-- <div class="actionBar_val">
  167. </div> -->
  168. </div>
  169. </div>
  170. <div class="actionBar">
  171. <div class="actionBar_list">
  172. <div style="width:120px;">调配:</div>
  173. <!-- <div class="actionBar_val"></div> -->
  174. </div>
  175. <div class="actionBar_list">
  176. <div style="width:120px;">
  177. 核对:<span v-if="item.advices.length> 0 || item.advices != undefined" >{{
  178. getDoctor(item.advices[0].checker)
  179. ? getDoctor(item.advices[0].checker)
  180. : ""
  181. }}</span>
  182. </div>
  183. <!-- <div class="actionBar_val">
  184. </div> -->
  185. </div>
  186. <div class="actionBar_list">
  187. <div style="width:120px;">
  188. 发药:{{
  189. getDoctor(item.advices[0].execution_staff)
  190. ? getDoctor(item.advices[0].execution_staff)
  191. : ""
  192. }}
  193. <!-- <span>占位符</span> -->
  194. </div>
  195. <!-- <div class="actionBar_val">
  196. </div> -->
  197. </div>
  198. </div>
  199. <div style="page-break-after: always"></div>
  200. </div>
  201. </div>
  202. </div>
  203. </template>
  204. <script>
  205. import { jsGetAge, uParseTime } from "@/utils/tools";
  206. import {
  207. getAllDoctorList,
  208. getPrescriptionPrint,
  209. getHisPatientDetail,
  210. } from "@/api/project/project";
  211. import { getInitData } from "@/api/his/his";
  212. export default {
  213. props: {
  214. patient_id: Number,
  215. record_date: String,
  216. prescription_id: Number,
  217. ids: String,
  218. },
  219. data() {
  220. return {
  221. doctorList: [],
  222. advicePrint: {},
  223. yi:4,
  224. patient: {},
  225. tableData: [],
  226. prescriptionInfo: [],
  227. hisPatient: {},
  228. department: [],
  229. prescriptions: [],
  230. projectList: [],
  231. orgname: "",
  232. diagnoses: [],
  233. org_id: 0,
  234. };
  235. },
  236. methods: {
  237. getAge(patient) {
  238. var thisLen = patient.id_card_no.length;
  239. var birth = "";
  240. if (thisLen == 15) {
  241. birth = "19" + patient.id_card_no.substr(6, 6);
  242. } else {
  243. birth = patient.id_card_no.substr(6, 8);
  244. }
  245. var births =
  246. birth.substr(0, 4) +
  247. "-" +
  248. birth.substr(4, 2) +
  249. "-" +
  250. birth.substr(6, 2);
  251. return jsGetAge(births, "-");
  252. },
  253. getAllDoctorList() {
  254. getAllDoctorList().then((response) => {
  255. if (response.data.state == 1) {
  256. var doctor = response.data.data.doctor;
  257. this.doctorList = doctor;
  258. }
  259. });
  260. },
  261. getDoctor(id) {
  262. var name = "";
  263. for (let i = 0; i < this.doctorList.length; i++) {
  264. if (id == this.doctorList[i].admin_user_id) {
  265. name = this.doctorList[i].user_name;
  266. }
  267. }
  268. return name;
  269. },
  270. getTime(value, temp) {
  271. if (value != undefined) {
  272. return uParseTime(value, temp);
  273. }
  274. return "";
  275. },
  276. getPrescriptionPrint() {
  277. var params = {
  278. // patient_id:this.patient_id,
  279. // record_date:this.record_date,
  280. // prescription_id:this.prescription_id,
  281. patient_id: this.patient_id,
  282. record_date: this.record_date,
  283. prescription_id: this.prescription_id,
  284. ids: this.ids,
  285. p_type: 2,
  286. };
  287. console.log("params", params);
  288. getPrescriptionPrint(params).then((response) => {
  289. if (response.data.state == 1) {
  290. var advicePrint = response.data.data.advicePrint;
  291. this.advicePrint = advicePrint;
  292. this.prescriptions = advicePrint;
  293. var hisPatient = response.data.data.hisPatient;
  294. this.hisPatient = hisPatient;
  295. var projectlist = response.data.data.projectlist;
  296. this.projectList = projectlist;
  297. }
  298. });
  299. },
  300. getHisPatientDetail() {
  301. const params = {
  302. patient_id: this.patient_id,
  303. };
  304. getHisPatientDetail(params).then((response) => {
  305. if (response.data.state == 1) {
  306. var hisPatient = response.data.data.hisPatient;
  307. console.log("挂号病人", hisPatient);
  308. this.hisPatient = hisPatient;
  309. }
  310. });
  311. },
  312. getInitData() {
  313. getInitData().then((response) => {
  314. if (response.data.state == 1) {
  315. this.department = response.data.data.department;
  316. this.diagnoses = response.data.data.diagnose;
  317. console.log("争端", this.diagnoses);
  318. }
  319. });
  320. },
  321. getDepart(id) {
  322. var name = "";
  323. for (let i = 0; i < this.department.length; i++) {
  324. if (id == this.department[i].id) {
  325. name = this.department[i].name;
  326. }
  327. }
  328. return name;
  329. },
  330. getTotalOne(id) {
  331. var total = 0;
  332. var addtotal = 0;
  333. for (let i = 0; i < this.prescriptions.length; i++) {
  334. if (id == this.prescriptions[i].id) {
  335. if (this.prescriptions[i].project != null) {
  336. for (let a = 0; a < this.prescriptions[i].project.length; a++) {
  337. total =
  338. total +
  339. this.prescriptions[i].project[a].price *
  340. this.prescriptions[i].project[a].count;
  341. }
  342. }
  343. if (this.prescriptions[i].additionalcharge != null) {
  344. for (
  345. let a = 0;
  346. a < this.prescriptions[i].additionalcharge.length;
  347. a++
  348. ) {
  349. addtotal =
  350. addtotal +
  351. this.prescriptions[i].additionalcharge[a].price *
  352. this.prescriptions[i].additionalcharge[a].count;
  353. }
  354. }
  355. addtotal = Math.floor(addtotal * 100) / 100;
  356. }
  357. }
  358. for (let i = 0; i < this.prescriptions.length; i++) {
  359. if (id == this.prescriptions[i].id) {
  360. if (this.prescriptions[i].advices != null) {
  361. for (let a = 0; a < this.prescriptions[i].advices.length; a++) {
  362. total =
  363. total +
  364. this.prescriptions[i].advices[a].price *
  365. this.prescriptions[i].advices[a].prescribing_number;
  366. }
  367. }
  368. if (this.prescriptions[i].additionalcharge != null) {
  369. for (
  370. let a = 0;
  371. a < this.prescriptions[i].additionalcharge.length;
  372. a++
  373. ) {
  374. addtotal =
  375. addtotal +
  376. this.prescriptions[i].additionalcharge[a].price *
  377. this.prescriptions[i].additionalcharge[a].count;
  378. }
  379. }
  380. addtotal = Math.floor(addtotal * 100) / 100;
  381. }
  382. }
  383. return total + addtotal;
  384. },
  385. getProjectName(id) {
  386. var project_name = "";
  387. for (let i = 0; i < this.projectList.length; i++) {
  388. if (id == this.projectList[i].id) {
  389. project_name = this.projectList[i].project_name;
  390. }
  391. }
  392. return project_name;
  393. },
  394. getDiagnosis(id) {
  395. let ids = id.split(",");
  396. var name = "";
  397. for (let i = 0; i < ids.length; i++) {
  398. for (let b = 0; b < this.diagnoses.length; b++) {
  399. if (parseInt(ids[i]) == this.diagnoses[b].id) {
  400. if (name.length == 0) {
  401. name = this.diagnoses[b].class_name;
  402. } else {
  403. name = name + "," + this.diagnoses[b].class_name;
  404. }
  405. }
  406. }
  407. }
  408. return name;
  409. },
  410. },
  411. created() {
  412. this.getAllDoctorList();
  413. this.getInitData();
  414. this.getPrescriptionPrint();
  415. this.getHisPatientDetail();
  416. var xtuser = this.$store.getters.xt_user;
  417. this.orgname = xtuser.org.org_name;
  418. this.org_id = xtuser.org.id;
  419. },
  420. watch: {
  421. ids: function (val) {
  422. this.ids = val;
  423. this.getPrescriptionPrint();
  424. },
  425. },
  426. };
  427. </script>
  428. <style lang="scss" scoped>
  429. .prescription-print {
  430. -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27),
  431. 0 0 60px rgba(0, 0, 0, 0.06) inset;
  432. -moz-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27),
  433. 0 0 40px rgba(0, 0, 0, 0.06) inset;
  434. box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
  435. margin-bottom: 20px;
  436. padding: 20px 10px;
  437. }
  438. .printTitle {
  439. font-size: 22px;
  440. text-align: center;
  441. font-weight: bold;
  442. // display: flex;
  443. position: relative;
  444. left: 50%;
  445. transform: translateX(-50%);
  446. }
  447. .infoTitle_thin {
  448. display: flex;
  449. border-bottom: 2px solid #000;
  450. margin-top: 10px;
  451. line-height: 24px;
  452. padding: 0 10px;
  453. }
  454. .infoTitle_thin p {
  455. width: 250px;
  456. }
  457. .infoTitle {
  458. display: flex;
  459. border-bottom: 2px solid #000;
  460. margin-top: 10px;
  461. line-height: 24px;
  462. padding: 0 10px;
  463. }
  464. .infoTitle p {
  465. width: 165px;
  466. }
  467. .infoMain {
  468. display: flex;
  469. flex-wrap: wrap;
  470. border-bottom: 2px solid #000;
  471. padding: 0 10px;
  472. }
  473. .infoMain div {
  474. width: 50%;
  475. line-height: 24px;
  476. }
  477. .prescriptionBox {
  478. padding: 0 10px;
  479. min-height: 450px;
  480. }
  481. .Rp {
  482. font-size: 22px;
  483. font-weight: bold;
  484. }
  485. .drugsBox {
  486. padding-left: 40px;
  487. margin-bottom: 10px;
  488. }
  489. .drugsBox div {
  490. line-height: 20px;
  491. }
  492. .drugsOne {
  493. line-height: 24px;
  494. }
  495. .drugsOne span {
  496. margin-right: 20px;
  497. }
  498. .doctorBox {
  499. display: flex;
  500. justify-content: space-between;
  501. padding: 0 10px;
  502. line-height: 24px;
  503. border-bottom: 2px solid #000;
  504. }
  505. .actionBar {
  506. display: flex;
  507. justify-content: space-between;
  508. line-height: 24px;
  509. padding: 0 10px;
  510. .actionBar_list {
  511. display: flex;
  512. width: 120px;
  513. .actionBar_val {
  514. width: 100px;
  515. border-bottom: 2px solid #000;
  516. text-align: center;
  517. }
  518. .title_bar {
  519. position: relative;
  520. .val_list {
  521. position: absolute;
  522. width: 105px;
  523. top: 0;
  524. left: 42px;
  525. border-bottom: 1px solid #000;
  526. }
  527. }
  528. }
  529. }
  530. .actionBar p {
  531. width: 150px;
  532. }
  533. .logo {
  534. }
  535. </style>