printTwo.vue 12KB

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