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

hisLongSignPrint.vue 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421
  1. <template>
  2. <div class="main-contain">
  3. <div class="position">
  4. <bread-crumb :crumbs="crumbs"></bread-crumb>
  5. <el-row style="float:right;">
  6. <el-col :span="24">
  7. <el-button size="small" icon="el-icon-printer" type="primary" @click="printAction">打印</el-button>
  8. </el-col>
  9. </el-row>
  10. </div>
  11. <div class="app-container" style="background-color: white;" v-show="show">
  12. <div id="dialysisTable">
  13. <div v-for="(item, index) in list" :key="index">
  14. <div class="signPrint" style="page-break-after: always;" v-for="(it,i) in item.his_advice_list">
  15. <div>分区/床位号:{{item.device_number.zone.name}}/{{item.device_number.number}}</div>
  16. <div>姓名:{{item.patient.name}}</div>
  17. <div>
  18. <div>医嘱内容:{{ it.advice_name }}
  19. </div>
  20. <div>
  21. 规格:{{getSpecialName(it.drug_id)}}
  22. </div>
  23. <div>单次用量: {{it.single_dose}}{{ it.single_dose_unit }}</div>
  24. <div>执行频率:{{it.execution_frequency}}</div>
  25. <div>给药途径:{{it.delivery_way}}</div>
  26. </div>
  27. <div>打印时间:{{$route.query.selected_date}}</div>
  28. </div>
  29. </div>
  30. </div>
  31. </div>
  32. </div>
  33. </template>
  34. <script>
  35. import BreadCrumb from '@/xt_pages/components/bread-crumb'
  36. import { getDialysisAdviceTemplateList } from '@/api/dialysis'
  37. import { parseTime } from '@/utils'
  38. import print from 'print-js'
  39. const moment = require('moment')
  40. export default {
  41. components:{
  42. BreadCrumb
  43. },
  44. data(){
  45. return{
  46. crumbs: [
  47. { path: false, name: '耗材药品' },
  48. { path: false, name: '打印' }
  49. ],
  50. tableData:[],
  51. start_time:"",
  52. end_time:"",
  53. print_time:moment(new Date()).add('year', 0).format('YYYY-MM-DD'),
  54. zone_selected: 0,
  55. scheduleMap:[],
  56. time:'',
  57. show:true,
  58. showOne:false,
  59. delivery_way:"",
  60. list:[],
  61. execution_frequency:"",
  62. org_id:0,
  63. adviceList:[],
  64. drugList:[],
  65. }
  66. },
  67. methods:{
  68. printAction: function() {
  69. const style = '@media print { .dialysisTable{width:960px;margin: 0 auto;text-align: center;border-collapse: collapse;}.order_title_panl {text-align: center;.main_title {font-size: 18px;line-height: 40px;font-weight: 500;}}.dialysisTable tr{padding: 10px 0;}.dialysisTable th {color: #000;padding: 0;margin: 0;height: 30px;}.dialysisTable tr td {padding: 12px 0;}.subadvice_content {text-align: left;padding-left: 25px !important;padding-right: 5px !important;}.advice_content {text-align: left;padding-left: 5px !important;padding-right: 5px !important;padding: 15px 5px !important;} }'
  70. printJS({
  71. printable: 'dialysisTable',
  72. type: 'html',
  73. documentTitle: ' ',
  74. style: style,
  75. scanStyles: false
  76. })
  77. },
  78. compare (property) {
  79. return function (a, b) {
  80. var value1 = a[property]
  81. var value2 = b[property]
  82. return value1 - value2
  83. }
  84. },
  85. parseTime: function (time, layout) {
  86. if (time == 0) {
  87. return ''
  88. }
  89. return parseTime(time, layout)
  90. },
  91. getName (val) {
  92. for (let i = 0; i < this.admin_user.length; i++) {
  93. if (this.admin_user[i].id == val) {
  94. return this.admin_user[i].name
  95. }
  96. }
  97. },
  98. getAdvice: function(doctor_advice) {
  99. if (doctor_advice.length > 0) {
  100. let name = "";
  101. for (let i = 0; i < doctor_advice.length; i++) {
  102. let prescribing_number = "";
  103. let single_dose = "";
  104. let drug_spec = "";
  105. if (doctor_advice[i].prescribing_number > 0) {
  106. prescribing_number =
  107. doctor_advice[i].prescribing_number +
  108. doctor_advice[i].prescribing_number_unit;
  109. }
  110. if (doctor_advice[i].single_dose > 0) {
  111. single_dose =
  112. " 单次用量 " +
  113. doctor_advice[i].single_dose +
  114. doctor_advice[i].single_dose_unit;
  115. }
  116. if (doctor_advice[i].drug_spec > 0) {
  117. drug_spec =
  118. doctor_advice[i].drug_spec + doctor_advice[i].drug_spec_unit;
  119. }
  120. name =
  121. name +
  122. doctor_advice[i].advice_name +
  123. " " +
  124. drug_spec +
  125. " " +
  126. prescribing_number +
  127. " " +
  128. single_dose +
  129. " " +
  130. doctor_advice[i].delivery_way +
  131. " " +
  132. doctor_advice[i].execution_frequency +
  133. " " +
  134. doctor_advice[i].remark +
  135. "\n";
  136. }
  137. return name;
  138. }else{
  139. return ""
  140. }
  141. },
  142. getSpecialName(drug_id){
  143. console.log("drug_id woowow",drug_id)
  144. var name = ""
  145. for(let i=0;i<this.drugList.length;i++){
  146. if(drug_id == this.drugList[i].id){
  147. name = this.drugList[i].dose + this.drugList[i].dose_unit + "*" + this.drugList[i].min_number + this.drugList[i].min_unit +"/"+this.drugList[i].max_unit
  148. }
  149. }
  150. return name
  151. },
  152. getweekday(date){
  153. var weekArray = new Array("周日", "周一", "周二", "周三", "周四", "周五", "周六");
  154. var week = weekArray[new Date(date).getDay()];//注意此处必须是先new一个Date
  155. return week;
  156. },
  157. getlist(){
  158. var params = {
  159. total:0,
  160. schedule_date:this.$route.query.selected_date,
  161. schedule_type:this.$route.query.schedule_type,
  162. partition_id:this.$route.query.partition_id,
  163. page:this.$route.query.page,
  164. limit:1000,
  165. keywords:"",
  166. good_type:0,
  167. ids:"",
  168. }
  169. getDialysisAdviceTemplateList(params).then(response=>{
  170. if(response.data.state == 1){
  171. var list = response.data.data.list
  172. if(list!=null){
  173. for(let i=0;i<list.length;i++){
  174. list[i].his_advice_list=[]
  175. }
  176. }
  177. this.list = list
  178. this.total = response.data.data.total
  179. var adviceList = response.data.data.adviceList
  180. this.adviceList = adviceList
  181. for(let i=0;i<list.length;i++){
  182. for(let j=0;j<adviceList.length;j++){
  183. if(list[i].patient_id == adviceList[j].patient_id){
  184. list[i].his_advice_list.push(adviceList[j])
  185. }
  186. }
  187. }
  188. var druglist = response.data.data.drugList
  189. this.drugList =druglist
  190. this.config = response.data.data.config
  191. }
  192. })
  193. },
  194. getZoneName(patient_id){
  195. var zone_name = ""
  196. for(let i=0;i<this.list.length;i++){
  197. if(patient_id == this.list[i].patient_id){
  198. zone_name = this.list[i].device_number.zone.name
  199. }
  200. }
  201. return zone_name
  202. },
  203. getBedName(patient_id){
  204. var number = ""
  205. for(let i=0;i<this.list.length;i++){
  206. if(patient_id == this.list[i].patient_id){
  207. number = this.list[i].device_number.number
  208. }
  209. }
  210. return number
  211. }
  212. },
  213. computed: {
  214. filtedScheduals: function () {
  215. var scheduleMap = new Object()
  216. if (this.zone_selected == 0) {
  217. for (const key in this.scheduleMap) {
  218. scheduleMap[key] = this.scheduleMap[key]
  219. }
  220. } else {
  221. var zone_name = this.zones[this.zone_selected].text
  222. scheduleMap[zone_name] = this.scheduleMap[zone_name]
  223. }
  224. if (this.schedule_type_selected != 0) {
  225. var _scheduleMap = {}
  226. for (const key in scheduleMap) {
  227. var origin_schedules = scheduleMap[key]
  228. var schedules = []
  229. for (let index = 0; index < origin_schedules.length; index++) {
  230. const schedule = origin_schedules[index]
  231. if (schedule.schedule_type == this.schedule_type_selected) {
  232. schedules.push(schedule)
  233. }
  234. }
  235. if (schedules.length > 0) {
  236. _scheduleMap[key] = schedules
  237. }
  238. }
  239. scheduleMap = _scheduleMap
  240. }
  241. for (var key in scheduleMap) {
  242. let mapArr = scheduleMap[key]
  243. for (let i = 0; i < mapArr.length; i++) {
  244. mapArr[i]['new_advice'] = []
  245. }
  246. }
  247. for (var key in scheduleMap) {
  248. let mapArr = scheduleMap[key]
  249. for (let i = 0; i < mapArr.length; i++) {
  250. var maps = mapArr[i]
  251. var resp_advices = maps.new_doctor_advice
  252. if (resp_advices.length > 0) {
  253. var newGroupObject = function () {
  254. return Object.assign(
  255. {},
  256. {
  257. group_no: 0,
  258. advices: []
  259. }
  260. )
  261. }
  262. var initGroupBlock = function (group, advice) {
  263. group.group_no = advice.groupno
  264. }
  265. var advice_groups = []
  266. var group = newGroupObject()
  267. for (let index = 0; index < resp_advices.length; index++) {
  268. const advice = resp_advices[index]
  269. if (advice.groupno == 0) {
  270. // 老版本的医嘱
  271. if (advice.parent_id > 0) {
  272. if (advice_groups.length > 0) {
  273. var parent_group = advice_groups[advice_groups.length - 1]
  274. if (parent_group.advices.length > 0) {
  275. if (parent_group.advices[0].id == advice.parent_id) {
  276. parent_group.advices.push(advice)
  277. }
  278. }
  279. }
  280. continue
  281. } else {
  282. if (group.group_no > 0) {
  283. advice_groups.push(group)
  284. group = newGroupObject()
  285. }
  286. initGroupBlock(group, advice)
  287. group.advices.push(advice)
  288. advice_groups.push(group)
  289. group = newGroupObject()
  290. continue
  291. }
  292. } else {
  293. if (group.group_no > 0 && group.group_no != advice.groupno) {
  294. advice_groups.push(group)
  295. group = newGroupObject()
  296. }
  297. if (group.group_no == 0) {
  298. initGroupBlock(group, advice)
  299. }
  300. if (group.group_no == advice.groupno) {
  301. group.advices.push(advice)
  302. }
  303. }
  304. }
  305. if (group.group_no > 0) {
  306. // 上述的算法会导致最后一组没有加到advice_groups,这里要手动加
  307. advice_groups.push(group)
  308. }
  309. advice_groups = advice_groups
  310. } else {
  311. advice_groups = []
  312. }
  313. maps.new_advice = advice_groups
  314. }
  315. }
  316. console.log("222222",scheduleMap)
  317. return scheduleMap
  318. },
  319. },
  320. created(){
  321. var time = this.$route.query.time
  322. var selected_date = this.$route.query.selected_date
  323. var schedule_type = this.$route.query.schedule_type
  324. var partition_id = this.$route.query.partition_id
  325. this.org_id = this.$store.getters.xt_user.org.id
  326. this.getlist()
  327. }
  328. }
  329. </script>
  330. <style rel="stylesheet/scss" lang="scss" scoped>
  331. .signPrint{
  332. -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 60px rgba(0, 0, 0, 0.06) inset;
  333. -moz-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
  334. box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
  335. margin-bottom: 20px;
  336. padding: 20px 10px;
  337. }
  338. .dialysisTable{
  339. width:960px;
  340. margin: 0 auto;
  341. text-align: center;
  342. border-collapse: collapse;
  343. }
  344. .order_title_panl {
  345. text-align: center;
  346. .main_title {
  347. font-size: 18px;
  348. line-height: 40px;
  349. font-weight: 500;
  350. }
  351. }
  352. .dialysisTable tr{
  353. padding: 10px 0;
  354. }
  355. .dialysisTable th {
  356. color: #000;
  357. padding: 0;
  358. margin: 0;
  359. height: 30px;
  360. }
  361. .dialysisTable tr td {
  362. padding: 12px 0;
  363. }
  364. .subadvice_content {
  365. text-align: left;
  366. padding-left: 25px !important;
  367. padding-right: 5px !important;
  368. }
  369. .advice_content {
  370. text-align: left;
  371. padding-left: 5px !important;
  372. padding-right: 5px !important;
  373. padding: 15px 5px !important;
  374. }
  375. </style>