printthirteen.vue 14KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288
  1. <template>
  2. <div id='invoice-print'>
  3. <div v-for='(i,index) in pageArr.length' :key="index" style="width: 90%;margin: 0 auto;font-size: 17px;">
  4. <div v-if="org_id==10188" style="text-align: center;width: 100%;font-size: 20px; font-weight: bolder;">盐城响水燕舞血液透析中心收据</div>
  5. <div v-if="org_id==10217" style="text-align: center;width: 100%;font-size: 20px; font-weight: bolder;">大丰燕舞血液透析中心</div>
  6. <div style="display: flex; margin: 15px 0 5px 0;">
  7. <div style="flex: 1.1;">业务流水号:{{ list.order_number }}</div>
  8. <div style="flex: 0.9;">医疗机构类型:</div>
  9. <div style="flex: 1;" v-if="org_id == 10188">医院国家编码:H32092103007</div>
  10. <div style="flex: 1;" v-if="org_id ==10217">医院国家编码:H32090403023</div>
  11. </div>
  12. <div style="display: flex;">
  13. <!-- <div style="flex:1;">医生:{{ doctor_info.user_name }}</div>
  14. <div style="flex: 1;">医生编码:{{ doctor_info.doctor_number }}</div> -->
  15. <div style="flex: 1;">No.{{list.order.fa_piao_number}}</div>
  16. </div>
  17. <div style="display: flex;border: 1px solid black;padding: 5px 0;">
  18. <div style="flex: 1;">姓名:{{ paramsObj.name }}</div>
  19. <div style="flex: 1;">性别:
  20. <span v-if="list.gender == 1">男</span>
  21. <span v-if="list.gender == 2">女</span>
  22. </div>
  23. <div style="flex: 1;">医保类型:</div>
  24. <div style="flex: 1;">社会保障号码:</div>
  25. </div>
  26. <div style="display: flex;border: 1px solid black;text-align: center;border-top:none;">
  27. <div style="flex: 1;display: flex;">
  28. <div style="flex: 1;border-right: 1px solid black;padding: 5px 0;">项目</div>
  29. <div style="flex: 1; padding: 5px 0;">金额</div>
  30. </div>
  31. <div style="flex: 2;display: flex;border-left: 1px solid black;">
  32. <div style="flex: 1; padding: 5px 0;">项目/规格</div>
  33. <div style="flex: 1;border-left: 1px solid black; padding: 5px 0;">数量</div>
  34. <div style="flex: 1;border-left: 1px solid black; padding: 5px 0;">金额</div>
  35. </div>
  36. <div style="flex: 2;display: flex;border-left: 1px solid black;">
  37. <div style="flex: 1; padding: 5px 0;">项目/规格</div>
  38. <div style="flex: 1;border-left: 1px solid black; padding: 5px 0;">数量</div>
  39. <div style="flex: 1;border-left: 1px solid black; padding: 5px 0;">金额</div>
  40. </div>
  41. </div>
  42. <div style="display: flex;border: 1px solid black;border-top:none;min-height: 200px;">
  43. <div style="flex: 1;" >
  44. <div v-if="list.westernMedicineCostTotal">西药 &nbsp;&nbsp;{{ list.westernMedicineCostTotal }}</div>
  45. <div v-if="list.treatCostTotal">治疗费 &nbsp;&nbsp;{{ list.treatCostTotal }}</div>
  46. <div v-if="list.bedCostTotal">床位费 &nbsp;&nbsp;{{ list.bedCostTotal }}</div>
  47. <div v-if="list.chineseTraditionalMedicineCostTotal">中成药 &nbsp;&nbsp;{{ list.chineseTraditionalMedicineCostTotal }}</div>
  48. <div v-if="list.laboratoryCostTotal">化验费 &nbsp;&nbsp;{{ list.laboratoryCostTotal }}</div>
  49. <div v-if="list.operationCostTotal">手术费 &nbsp;&nbsp;{{ list.operationCostTotal }}</div>
  50. <div v-if="list.otherCostTotal">其他费 &nbsp;&nbsp;{{ list.otherCostTotal }}</div>
  51. <div v-if="list.materialCostTotal">材料费 &nbsp;&nbsp;{{ list.materialCostTotal }}</div>
  52. </div>
  53. <div style="flex: 2;border-left: 1px solid black;">
  54. <div v-for="item in list.order_info.slice(index * 10,(index * 10) + pageArr[index])" style="">
  55. <span style="display:inline-block;width:56%;">
  56. <span v-if="item.advice.id == 0">
  57. <span v-if="item.project.type == 2">{{ item.project.project.project_name }}</span>
  58. <span v-if="item.project.type == 3">{{ item.project.good_info.good_name }}</span>
  59. </span>
  60. <span v-else>{{ item.advice.advice_name }}</span>
  61. </span>
  62. <span style="display:inline-block;width:50px;">
  63. <span v-if="item.advice.id == 0">
  64. <span v-if="item.project.type == 2">{{ item.project.count }}{{ item.project.unit }}</span>
  65. <span v-if="item.project.type == 3">{{ item.project.count }}{{ item.project.unit }}</span>
  66. </span>
  67. <span v-else>{{ item.advice.prescribing_number }}{{ item.advice.prescribing_number_unit }}</span>
  68. </span>
  69. <span>
  70. <span v-if="item.advice.id == 0">
  71. <span v-if="item.project.type == 2">{{ (item.project.count * item.pric).toFixed(2) }}</span>
  72. <span v-if="item.project.type == 3">{{ (item.project.count * item.pric).toFixed(2) }}</span>
  73. </span>
  74. <span v-else>{{ (item.advice.prescribing_number * item.pric).toFixed(2) }}</span>
  75. </span>
  76. </div>
  77. </div>
  78. <div style="flex: 2;border-left: 1px solid black;">
  79. </div>
  80. </div>
  81. <div style="display: flex;border:1px solid black;border-top: none;">
  82. <div style="flex: 2; padding: 5px 0;">
  83. <span style="font-weight: bolder;">合计(大写):</span>
  84. <span>{{ zhongwen }}</span>
  85. </div>
  86. <div style="flex: 1;border-left: 1px solid black; padding: 5px 0;">¥:{{ list.medfee_sumamt }}</div>
  87. </div>
  88. <div style="border:1px solid black;border-top: none;min-height: 80px;">
  89. <div style="padding: 5px 0; position: relative;">
  90. <div v-if="index == pageArr.length - 1">
  91. <div style="display:flex;">
  92. <div style="flex: 1;">医疗总费用:{{ list.order.medfee_sumamt }}</div>
  93. <div style="flex: 1;">基金支付总额:{{ list.order.fund_pay_sumamt }}</div>
  94. <div style="flex: 1;">统筹支出:{{ list.order.hifp_pay }}</div>
  95. <div style="flex: 1;">大病支出:{{list.order.hifmi_pay}}</div>
  96. </div>
  97. <div style="display:flex;">
  98. <div style="flex: 1;">个人账户支付:{{ list.order.acct_pay }}</div>
  99. <div style="flex: 1;">现金支出:{{ list.order.psn_cash_pay }}</div>
  100. <div style="flex: 1;">本次账户:0</div>
  101. <div style="flex: 1;">上次账户:0</div>
  102. </div>
  103. <div style="display:flex;">
  104. <div style="flex: 1;">账户余额:{{ list.order.balc }}</div>
  105. <div style="flex: 1;">其他支出:{{ list.order.oth_pay }}</div>
  106. <div style="flex: 1;">大病补充保险支出:0</div>
  107. <div style="flex: 1;">民政支出:0</div>
  108. </div>
  109. <div style="display:flex;">
  110. <div style="flex: 1;">医疗救助基金支出:{{ list.order.maf_pay }}</div>
  111. <div style="flex: 1;">企业补充医疗保险基金支出:{{ list.order.hifes_pay }}</div>
  112. </div>
  113. </div>
  114. <!-- <span style="position: absolute;left: 80%;top: 70%;">(手写无效)</span> -->
  115. </div>
  116. </div>
  117. <div style="display: flex;">
  118. <div style="flex:1;">医生:{{ doctor_info.user_name }}</div>
  119. <div style="flex: 1;">医生编码:{{ doctor_info.doctor_number }}</div>
  120. <!-- <div style="flex: 1;">No.{{list.order.fa_piao_number}}</div> -->
  121. </div>
  122. <div style="display: flex;">
  123. <div style="flex: 1.5;" v-if="org_id==10188">收款单位(章):{{ org_name }}</div>
  124. <div style="flex: 1.5;" v-if="org_id==10217">收款单位(章):大丰燕舞血液透析中心</div>
  125. <div style="flex: 0.7;">收费员:{{ paramsObj.chargeName }}</div>
  126. <div style="flex: 1;">
  127. <span>{{ paramsObj.setl_time ? paramsObj.setl_time.split(' ')[0].slice(0,4) : getTime(list.date, '{y}-{m}-{d}').slice(0,4) }}</span>
  128. <span>{{ paramsObj.setl_time ? parseInt(paramsObj.setl_time.split(' ')[0].slice(5,7)) : getTime(list.date, '{y}-{m}-{d}').slice(5,7) }}</span>
  129. <span>{{ paramsObj.setl_time ? parseInt(paramsObj.setl_time.split(' ')[0].slice(8,11)) : getTime(list.date, '{y}-{m}-{d}').slice(8,11) }}</span>
  130. </div>
  131. </div>
  132. </div>
  133. </div>
  134. </template>
  135. <script>
  136. import { getInvoice } from '@/api/project/project'
  137. import { uParseTime } from '@/utils/tools'
  138. export default {
  139. props:{
  140. paramsObj:Object
  141. },
  142. data(){
  143. return{
  144. list:{},
  145. printDate:'',
  146. zhongwen:'',
  147. totalPrice:0.0,
  148. org_id:'',
  149. org_name:'',
  150. page:1,
  151. pageArr:[],
  152. doctor_info:{},
  153. }
  154. },
  155. created(){
  156. console.log('paramsObj',this.paramsObj)
  157. let params = {
  158. order_id: this.paramsObj.order_id,
  159. patient_id: this.paramsObj.patient_id,
  160. }
  161. this.getInvoice(params)
  162. // var data = new Date();
  163. // var month =data.getMonth() < 9 ? "0" + (data.getMonth() + 1) : data.getMonth() + 1;
  164. // var date = data.getDate() <= 9 ? "0" + data.getDate() : data.getDate();
  165. // this.printDate = data.getFullYear() + "-" + month + "-" + date;
  166. // this.smalltoBIG(982732.21)
  167. this.org_id = this.$store.getters.xt_user.org_id
  168. this.org_name = this.$store.getters.xt_user.org.org_name
  169. },
  170. methods:{
  171. getInvoice(params){
  172. getInvoice(params).then((res) => {
  173. console.log('res',res)
  174. this.list = res.data.data
  175. this.totalPrice = this.list.westernMedicineCostTotal + this.list.checkCostTotal + this.list.treatCostTotal + this.list.bedCostTotal + this.list.chineseTraditionalMedicineCostTotal +
  176. this.list.laboratoryCostTotal + this.list.operationCostTotal + this.list.otherCostTotal + this.list.materialCostTotal
  177. this.smalltoBIG(this.list.medfee_sumamt)
  178. var data = new Date(res.data.data.date * 1000);
  179. var month =data.getMonth() < 9 ? "0" + (data.getMonth() + 1) : data.getMonth() + 1;
  180. var date = data.getDate() <= 9 ? "0" + data.getDate() : data.getDate();
  181. this.printDate = data.getFullYear() + "-" + month + "-" + date;
  182. this.pageArr = []
  183. this.getPage()
  184. this.doctor_info = res.data.data.doctor_info
  185. console.log('pageArr',this.pageArr)
  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. console.log("str",str)
  224. if(str == '零元零角零分'){
  225. this.zhongwen = '零'
  226. }else{
  227. this.zhongwen = str.replace(/零(仟|佰|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(万|亿|元)/g, "$1").replace(/(亿)万|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整");
  228. }
  229. console.log(this.zhongwen)
  230. },
  231. getTime(value, temp) {
  232. if (value == 0) {
  233. return ''
  234. }
  235. if (value != undefined) {
  236. return uParseTime(value, temp)
  237. }
  238. return ''
  239. },
  240. getPage(){
  241. if(this.list.order_info.length <= 10){
  242. this.page = 1
  243. this.pageArr.push(this.list.order_info.length)
  244. }else if(this.list.order_info.length > 10){
  245. this.page = parseInt(this.list.order_info.length / 10)
  246. let num = this.list.order_info.length % 10
  247. for (var i=0;i<this.page;i++){
  248. this.pageArr.push(10)
  249. }
  250. if(num != 0){
  251. this.pageArr.push(num)
  252. }
  253. }
  254. }
  255. },
  256. watch:{
  257. paramsObj:{//深度监听,可监听到对象、数组的变化
  258. handler(val, oldVal){
  259. let params = {
  260. order_id: val.order_id,
  261. patient_id: val.patient_id,
  262. }
  263. this.getInvoice(params)
  264. },
  265. deep:true
  266. }
  267. }
  268. }
  269. </script>