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

printFour.vue 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252
  1. <template>
  2. <div id='invoice-print' style="font-size:12px;">
  3. <div style="display:flex;">
  4. <div style="position: absolute;top:50px;left:60px;">{{ list.order_number }}</div>
  5. <!-- <div>{{ list.id_card_no }}</div> -->
  6. </div>
  7. <div style="display:flex;justify-content: space-between;">
  8. <!-- <div>{{ list.department_name }}</div> -->
  9. <div style="position: absolute;top:50px;left:260px">{{ list.id_card_no }}</div>
  10. <div></div>
  11. </div>
  12. <div style="display:flex;justify-content: space-between;">
  13. <!-- <div>{{ list.department_name }}</div> -->
  14. <div style="position: absolute;top:70px;left:90px">门诊</div>
  15. <div></div>
  16. <div style="position: absolute;top:70px;left:240px">{{ list.number }}</div>
  17. <div style="position: absolute;left:470px;top:70px;">
  18. <span>{{ printDate.slice(0,4) }}</span>
  19. </div>
  20. <div style="position: absolute;left:530px;top:70px;">
  21. <span>{{ parseInt(printDate.slice(5,7)) }}</span>
  22. </div>
  23. <div style="position: absolute;left:560px;top:70px;">
  24. <span>{{ parseInt(printDate.slice(8,11)) }}</span>
  25. </div>
  26. </div>
  27. <div style="display:flex;justify-content: space-between;">
  28. <div style="position: absolute;top:85px;left:100px;"> {{ paramsObj.name }}</div>
  29. <div style="position: absolute;top:85px;left:180px;">√</div>
  30. <!-- <div>{{ list.pay_way }}</div> -->
  31. <div style="position: absolute;top:85px;left:380px;">{{ paramsObj.setl_time.split(' ')[0] }}</div>
  32. <div style="position: absolute;top:85px;left:530px;">{{ paramsObj.setl_time.split(' ')[0] }}</div>
  33. </div>
  34. <div style="display:flex;justify-content: space-between;">
  35. <!-- <div>{{ paramsObj.gend == 1 ? '男' : '女' }}</div> -->
  36. <div v-if="paramsObj.gend == 1" style="position: absolute;top:110px;left:100px;">√</div>
  37. <div v-else style="position: absolute;top:110px;left:140px;">√</div>
  38. <div style="position: absolute;top:110px;left:260px;">{{ (totalPrice - list.psn_cash_money).toFixed(2) }}</div>
  39. <div style="position: absolute;top:110px;left:420px;">{{ list.psn_cash_money.toFixed(2) }}</div>
  40. <div style="position: absolute;top:110px;left:540px;">现金</div>
  41. </div>
  42. <div style="display:flex;justify-content: space-between;">
  43. <div style="position: absolute;top:145px;left:50px">西药</div>
  44. <div style="position: absolute;top:145px;left:130px">{{ list.westernMedicineCostTotal ? list.westernMedicineCostTotal.toFixed(2) : '' }}</div>
  45. <div style="position: absolute;top:145px;left:180px">检查费</div>
  46. <div style="position: absolute;top:145px;left:260px">{{ list.checkCostTotal ? list.checkCostTotal.toFixed(2) : '' }}</div>
  47. <div style="position: absolute;top:145px;left:340px">治疗费</div>
  48. <div style="position: absolute;top:145px;left:420px">{{ list.treatCostTotal ? list.treatCostTotal.toFixed(2) : '' }}</div>
  49. <div style="position: absolute;top:145px;left:480px">床位费</div>
  50. <div style="position: absolute;top:145px;left:540px">{{ list.bedCostTotal ? list.bedCostTotal.toFixed(2) : '' }}</div>
  51. </div>
  52. <div style="display:flex;justify-content: space-between;">
  53. <div style="position: absolute;top:170px;left:50px">中成药</div>
  54. <div style="position: absolute;top:170px;left:130px">{{ list.chineseTraditionalMedicineCostTotal ? list.chineseTraditionalMedicineCostTotal.toFixed(2) : '' }}</div>
  55. <div style="position: absolute;top:170px;left:180px">化验费</div>
  56. <div style="position: absolute;top:170px;left:260px">{{ list.laboratoryCostTotal ? list.laboratoryCostTotal.toFixed(2) : '' }}</div>
  57. <div style="position: absolute;top:170px;left:340px">手术费</div>
  58. <div style="position: absolute;top:170px;left:420px">{{ list.operationCostTotal ? list.operationCostTotal.toFixed(2) : '' }}</div>
  59. <div style="position: absolute;top:170px;left:480px">其他费</div>
  60. <div style="position: absolute;top:170px;left:540px">{{ list.otherCostTotal ? list.otherCostTotal.toFixed(2) : '' }}</div>
  61. </div>
  62. <div style="display:flex;justify-content: space-between;">
  63. <div style="position: absolute;top:190px;left:50px"></div>
  64. <div style="position: absolute;top:190px;left:130px"></div>
  65. <div style="position: absolute;top:190px;left:180px"></div>
  66. <div style="position: absolute;top:190px;left:260px"></div>
  67. <div style="position: absolute;top:190px;left:340px">材料费</div>
  68. <div style="position: absolute;top:190px;left:420px">{{ list.materialCostTotal ? list.materialCostTotal.toFixed(2) : '' }}</div>
  69. <div style="position: absolute;top:190px;left:480px"></div>
  70. <div style="position: absolute;top:190px;left:540px"></div>
  71. </div>
  72. <div style="display:flex;justify-content: space-between;">
  73. <div style="position: absolute;top:210px;left:50px"></div>
  74. <div style="position: absolute;top:210px;left:130px"></div>
  75. <div style="position: absolute;top:210px;left:180px"></div>
  76. <div style="position: absolute;top:210px;left:260px">{{ list.psn_cash_money ? list.psn_cash_money.toFixed(2) : '' }}</div>
  77. <div style="position: absolute;top:210px;left:340px"></div>
  78. <div style="position: absolute;top:210px;left:420px"></div>
  79. <div style="position: absolute;top:210px;left:480px"></div>
  80. <div style="position: absolute;top:210px;left:540px"></div>
  81. </div>
  82. <div>
  83. <span>
  84. <span style="position: absolute;top:235px;left:190px">
  85. <span v-if="zhongwen.indexOf('万') > -1 && zhongwen.indexOf('拾') > -1 && zhongwen.indexOf('拾') == 1">
  86. {{ zhongwen.substring(0,1) }}
  87. </span>
  88. <span v-else>零</span>
  89. </span>
  90. <span style="position: absolute;top:235px;left:220px">
  91. <span v-if="zhongwen.indexOf('万') > -1">
  92. {{ zhongwen.substring(zhongwen.indexOf('万') - 1,zhongwen.indexOf('万')) }}
  93. </span>
  94. <span v-else>零</span>
  95. </span>
  96. <span style="position: absolute;top:235px;left:250px">
  97. <span v-if="zhongwen.indexOf('仟') > -1">
  98. {{ zhongwen.substring(zhongwen.indexOf('仟') - 1,zhongwen.indexOf('仟')) }}
  99. </span>
  100. <span v-else>零</span>
  101. </span>
  102. <span style="position: absolute;top:235px;left:290px">
  103. <span v-if="zhongwen.indexOf('佰') > -1">
  104. {{ zhongwen.substring(zhongwen.indexOf('佰') - 1,zhongwen.indexOf('佰')) }}
  105. </span>
  106. <span v-else>零</span>
  107. </span>
  108. <span style="position: absolute;top:235px;left:320px">
  109. <span v-if="zhongwen.indexOf('拾') > -1">
  110. {{ zhongwen.substring(zhongwen.indexOf('拾') - 1,zhongwen.indexOf('拾')) }}
  111. </span>
  112. <span v-else>零</span>
  113. </span>
  114. <span style="position: absolute;top:235px;left:350px">
  115. <span v-if="zhongwen.indexOf('元') > -1 && zhongwen.substring(zhongwen.indexOf('元') - 1,zhongwen.indexOf('元')) != '拾'">
  116. {{ zhongwen.substring(zhongwen.indexOf('元') - 1,zhongwen.indexOf('元')) }}
  117. </span>
  118. <span v-else>零</span>
  119. </span>
  120. <span style="position: absolute;top:235px;left:380px">
  121. <span v-if="zhongwen.indexOf('角') > -1">
  122. {{ zhongwen.substring(zhongwen.indexOf('角') - 1,zhongwen.indexOf('角')) }}
  123. </span>
  124. <span v-else>零</span>
  125. </span>
  126. <span style="position: absolute;top:235px;left:415px">
  127. <span v-if="zhongwen.indexOf('分') > -1">
  128. {{ zhongwen.substring(zhongwen.indexOf('分') - 1,zhongwen.indexOf('分')) }}
  129. </span>
  130. <span v-else>零</span>
  131. </span>
  132. </span>
  133. <span style="position: absolute;top:235px;left:500px">{{ totalPrice.toFixed(2) }}</span>
  134. </div>
  135. <!-- <div style="position: absolute;top:300px;left:460px">现金:{{ list.psn_cash_money }}</div> -->
  136. <div>
  137. <div style="position: absolute;top:300px;left:120px">{{ org_name }}</div>
  138. <div style="position: absolute;top:300px;left:460px">高慧裕</div>
  139. </div>
  140. </div>
  141. </template>
  142. <script>
  143. import { getInvoice } from '@/api/project/project'
  144. export default {
  145. props:{
  146. paramsObj:Object
  147. },
  148. data(){
  149. return{
  150. list:{},
  151. printDate:'',
  152. zhongwen:'',
  153. totalPrice:0.0,
  154. org_id:'',
  155. org_name:''
  156. }
  157. },
  158. created(){
  159. console.log('paramsObj',this.paramsObj)
  160. let params = {
  161. order_id: this.paramsObj.order_id,
  162. patient_id: this.paramsObj.patient_id,
  163. number: this.paramsObj.number,
  164. }
  165. this.getInvoice(params)
  166. // var data = new Date();
  167. // var month =data.getMonth() < 9 ? "0" + (data.getMonth() + 1) : data.getMonth() + 1;
  168. // var date = data.getDate() <= 9 ? "0" + data.getDate() : data.getDate();
  169. // this.printDate = data.getFullYear() + "-" + month + "-" + date;
  170. // this.smalltoBIG(982732.21)
  171. this.org_id = this.$store.getters.xt_user.org_id
  172. this.org_name = this.$store.getters.xt_user.org.org_name
  173. },
  174. methods:{
  175. getInvoice(params){
  176. getInvoice(params).then((res) => {
  177. console.log('res',res)
  178. this.list = res.data.data
  179. this.totalPrice = this.list.westernMedicineCostTotal + this.list.checkCostTotal + this.list.treatCostTotal + this.list.bedCostTotal + this.list.chineseTraditionalMedicineCostTotal +
  180. this.list.laboratoryCostTotal + this.list.operationCostTotal + this.list.otherCostTotal + this.list.materialCostTotal
  181. this.smalltoBIG(this.totalPrice)
  182. var data = new Date(res.data.data.date * 1000);
  183. var month =data.getMonth() < 9 ? "0" + (data.getMonth() + 1) : data.getMonth() + 1;
  184. var date = data.getDate() <= 9 ? "0" + data.getDate() : data.getDate();
  185. this.printDate = data.getFullYear() + "-" + month + "-" + date;
  186. })
  187. },
  188. smalltoBIG(n) {
  189. // let fraction = ['角', '分'];
  190. // let digit = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
  191. // let unit = [['元.', '万,', '亿,'], ["元",'拾', '佰', '仟']];
  192. // let head = price < 0 ? '欠' : '';
  193. // price = Math.abs(price);
  194. // let upper = '';
  195. // for (let i = 0; i < fraction.length; i++) {
  196. // upper += (digit[Math.floor(price * 10 * Math.pow(10, i)) % 10] + fraction[i]).replace(/零./, '');
  197. // }
  198. // upper = upper || '整';
  199. // price = Math.floor(price);
  200. // for (let i = 0; i < unit[0].length && price > 0; i++) {
  201. // let p = '';
  202. // for (let j = 0; j < unit[1].length && price > 0; j++) {
  203. // p = digit[price % 10] + unit[1][j] + p;
  204. // price = Math.floor(price / 10);
  205. // }
  206. // upper = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][i] + upper;
  207. // }
  208. // this.zhongwen = head + upper.replace(/(零.)*零圆/, '圆').replace(/(零.)+/g, '零').replace(/^整$/, '零圆整')
  209. // console.log('6666',head + upper.replace(/(零.)*零圆/, '圆').replace(/(零.)+/g, '零').replace(/^整$/, '零圆整'))
  210. if (!/^(0|[1-9]\d*)(\.\d+)?$/.test(n)){
  211. return "数据非法"; //判断数据是否大于0
  212. }
  213. var unit = "仟佰拾亿仟佰拾万仟佰拾元角分", str = "";
  214. n += "00";
  215. var indexpoint = n.indexOf('.'); // 如果是小数,截取小数点前面的位数
  216. if (indexpoint >= 0){
  217. n = n.substring(0, indexpoint) + n.substr(indexpoint+1, 2); // 若为小数,截取需要使用的unit单位
  218. }
  219. unit = unit.substr(unit.length - n.length); // 若为整数,截取需要使用的unit单位
  220. for (var i=0; i < n.length; i++){
  221. str += "零壹贰叁肆伍陆柒捌玖".charAt(n.charAt(i)) + unit.charAt(i); //遍历转化为大写的数字
  222. }
  223. this.zhongwen = str.replace(/零(仟|佰|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(万|亿|元)/g, "$1").replace(/(亿)万|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整");
  224. console.log(this.zhongwen)
  225. },
  226. },
  227. watch:{
  228. paramsObj:{//深度监听,可监听到对象、数组的变化
  229. handler(val, oldVal){
  230. let params = {
  231. order_id: val.order_id,
  232. patient_id: val.patient_id,
  233. number: val.number,
  234. }
  235. this.getInvoice(params)
  236. },
  237. deep:true
  238. }
  239. }
  240. }
  241. </script>