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

printThree.vue 18KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. <template>
  2. <div id='invoice-print'>
  3. <div style="display:flex;justify-content: space-between;">
  4. <div style="position: absolute;top:5px;left:30px">
  5. <!-- 发票代码 -->
  6. </div>
  7. <div style="position: absolute;top:40px;left:300px"></div>
  8. <div style="position: absolute;top:40px;left:560px"></div>
  9. </div>
  10. <div style="display:flex;justify-content: space-between;">
  11. <!-- 机构名称 -->
  12. <div style="position: absolute;top:70px;left:40px">机构名称:赤峰费森血液透析中心</div>
  13. <!-- 单据号 -->
  14. <!-- <div style="position: absolute;top:70px;left:200px">单据号:{{ list.number }}</div> -->
  15. <!-- <div></div> -->
  16. <!-- 发票序号 -->
  17. <!-- <div style="position: absolute;left:560px;top:70px;">
  18. </div> -->
  19. <div style="position: absolute;left:400px;top:70px;" v-if="insutype == '390'">
  20. 类别:城乡居民基本医疗保险
  21. </div>
  22. <div style="position: absolute;left:400px;top:70px;" v-else-if ="insutype == '310'">
  23. 类别:职工基本医疗保险
  24. </div>
  25. </div>
  26. <div style="display:flex;justify-content: space-between;">
  27. <!-- 姓名 -->
  28. <div style="position: absolute;top:90px;left:40px;"> 姓名:{{ paramsObj.name }}</div>
  29. <!-- 个人电脑编号 -->
  30. <div style="position: absolute;top:90px;left:220px;">个人编号:{{psn_no}}</div>
  31. <!-- 科室 -->
  32. <div style="position: absolute;top:90px;left:530px;">科室:{{'血液透析室'}}</div>
  33. <!-- 床号 -->
  34. <div style="position: absolute;top:90px;left:700px;">床号:</div>
  35. </div>
  36. <div style="display:flex;justify-content: space-between;">
  37. <!-- 住院号 -->
  38. <div style="position: absolute;top:120px;left:40px;"> 住院号:{{ number?number:'' }}</div>
  39. <!-- 入院日期 -->
  40. <div style="position: absolute;top:120px;left:280px;">入院日期:{{in_hosptial_time?in_hosptial_time.split(' ')[0]:''}}</div>
  41. <!-- 出院日期 -->
  42. <div style="position: absolute;top:120px;left:460px;">出院日期:{{out_hosptial_time?out_hosptial_time.split(' ')[0]:''}}</div>
  43. <!-- 住院天数 -->
  44. <div style="position: absolute;top:120px;left:640px;">住院天数:{{getDay(in_hosptial_time.split(' ')[0] ,out_hosptial_time.split(' ')[0])}}</div>
  45. </div>
  46. <!-- <div style="display:flex;justify-content: space-between;">
  47. <div style="position: absolute;top:110px;left:260px;">{{ (totalPrice - list.psn_cash_money).toFixed(2) }}</div>
  48. <div style="position: absolute;top:110px;left:440px;">{{ list.psn_cash_money }}</div>
  49. <div style="position: absolute;top:110px;left:580px;">门特</div>
  50. </div> -->
  51. <div style="display:flex;justify-content: space-between;">
  52. <div style="position: absolute;top:160px;left:40px">西药费</div>
  53. <div style="position: absolute;top:160px;left:110px">{{ list.westernMedicineCostTotal?list.westernMedicineCostTotal:'0.00' }}</div>
  54. <div style="position: absolute;top:160px;left:220px">检查费</div>
  55. <div style="position: absolute;top:160px;left:290px">{{ list.checkCostTotal?list.checkCostTotal:'0.00' }}</div>
  56. <div style="position: absolute;top:160px;left:400px">材料费</div>
  57. <div style="position: absolute;top:160px;left:470px">{{list.materialCostTotal?list.materialCostTotal:"0.00"}}</div>
  58. <div style="position: absolute;top:160px;left:580px">麻醉费</div>
  59. <div style="position: absolute;top:160px;left:650px">0.00</div>
  60. </div>
  61. <div style="display:flex;justify-content: space-between;">
  62. <div style="position: absolute;top:190px;left:40px">中成药费</div>
  63. <div style="position: absolute;top:190px;left:110px">0.00</div>
  64. <div style="position: absolute;top:190px;left:220px">治疗费</div>
  65. <div style="position: absolute;top:190px;left:290px">{{list.treatCostTotal?list.treatCostTotal:'0.00'}}</div>
  66. <div style="position: absolute;top:190px;left:400px">护理费</div>
  67. <div style="position: absolute;top:190px;left:470px">0.00</div>
  68. <div style="position: absolute;top:190px;left:580px">床位费</div>
  69. <div style="position: absolute;top:190px;left:650px">0.00</div>
  70. </div>
  71. <div style="display:flex;justify-content: space-between;">
  72. <div style="position: absolute;top:220px;left:40px">中草药费</div>
  73. <div style="position: absolute;top:220px;left:110px">0.00</div>
  74. <div style="position: absolute;top:220px;left:220px">手术费</div>
  75. <div style="position: absolute;top:220px;left:290px">{{ list.operationCostTotal?list.operationCostTotal:'0.00' }}</div>
  76. <div style="position: absolute;top:220px;left:400px">输血费</div>
  77. <div style="position: absolute;top:220px;left:470px">0.00</div>
  78. <div style="position: absolute;top:220px;left:580px">取暖费</div>
  79. <div style="position: absolute;top:220px;left:650px">0.00</div>
  80. </div>
  81. <div style="display:flex;justify-content: space-between;">
  82. <div style="position: absolute;top:250px;left:40px">高压氧费</div>
  83. <div style="position: absolute;top:250px;left:110px">0.00</div>
  84. <div style="position: absolute;top:250px;left:220px">化验费</div>
  85. <div style="position: absolute;top:250px;left:290px">{{ list.laboratoryCostTotal?list.laboratoryCostTotal:'0.00' }}</div>
  86. <div style="position: absolute;top:250px;left:400px">氧气费</div>
  87. <div style="position: absolute;top:250px;left:470px">0.00</div>
  88. <div style="position: absolute;top:250px;left:580px">其他费</div>
  89. <div style="position: absolute;top:250px;left:650px">{{ list.otherCostTotal?list.otherCostTotal:'0.00' }}</div>
  90. </div>
  91. <div>
  92. <span>
  93. <span style="position: absolute;top:280px;left:40px">合计金额(大写):</span>
  94. <!-- <span style="position: absolute;top:280px;left:180px">
  95. <span v-if="zhongwen.indexOf('万') > -1 && zhongwen.indexOf('拾') > -1 && zhongwen.indexOf('拾') == 1">
  96. {{ zhongwen.substring(0,1) }}十万
  97. </span>
  98. <span v-else>零十万</span>
  99. </span>
  100. <span style="position: absolute;top:280px;left:230px">
  101. <span v-if="zhongwen.indexOf('万') > -1">
  102. {{ zhongwen.substring(zhongwen.indexOf('万') - 1,zhongwen.indexOf('万')) }}万
  103. </span>
  104. <span v-else>零万</span>
  105. </span>
  106. <span style="position: absolute;top:280px;left:270px">
  107. <span v-if="zhongwen.indexOf('仟') > -1">
  108. {{ zhongwen.substring(zhongwen.indexOf('仟') - 1,zhongwen.indexOf('仟')) }}仟
  109. </span>
  110. <span v-else>零仟</span>
  111. </span>
  112. <span style="position: absolute;top:280px;left:310px">
  113. <span v-if="zhongwen.indexOf('佰') > -1">
  114. {{ zhongwen.substring(zhongwen.indexOf('佰') - 1,zhongwen.indexOf('佰')) }}佰
  115. </span>
  116. <span v-else>零佰</span>
  117. </span>
  118. <span style="position: absolute;top:280px;left:350px">
  119. <span v-if="zhongwen.indexOf('拾') > -1">
  120. {{zhongwen.substring(zhongwen.indexOf('拾') - 1,zhongwen.indexOf('拾')) == '佰' || !zhongwen.substring(zhongwen.indexOf('拾') - 1,zhongwen.indexOf('拾'))? '壹' : zhongwen.substring(zhongwen.indexOf('拾') - 1,zhongwen.indexOf('拾')) }}
  121. </span>
  122. <span v-else>零拾</span>
  123. </span>
  124. <span style="position: absolute;top:280px;left:390px">
  125. <span v-if="zhongwen.indexOf('元') > -1 && zhongwen.substring(this.zhongwen.indexOf('元') - 1).substring(0,1)!= '拾'">
  126. {{ zhongwen.substring(zhongwen.indexOf('元') - 1,zhongwen.indexOf('元')) }}
  127. </span>
  128. <span v-else>零元</span>
  129. </span>
  130. <span style="position: absolute;top:280px;left:430px">
  131. <span v-if="zhongwen.indexOf('角') > -1">
  132. {{ zhongwen.substring(zhongwen.indexOf('角') - 1,zhongwen.indexOf('角')) }}角
  133. </span>
  134. <span v-else>零角</span>
  135. </span>
  136. <span style="position: absolute;top:280px;left:470px">
  137. <span v-if="zhongwen.indexOf('分') > -1">
  138. {{ zhongwen.substring(zhongwen.indexOf('分') - 1,zhongwen.indexOf('分')) }}分
  139. </span>
  140. <span v-else>零分</span>
  141. </span> -->
  142. <span style="position: absolute;top:280px;left:170px;letter-spacing: 15px;">{{zhongwen}}</span>
  143. </span>
  144. <span style="position: absolute;top:280px;left:615px">合计:{{ list.order.medfee_sumamt }}</span>
  145. </div>
  146. <div style="position: absolute;top:310px;left:40px">
  147. <!-- 个人账户支付 -->
  148. 个人账户支付:{{list.order.acct_pay?list.order.acct_pay:'0.00'}}
  149. </div>
  150. <div style="position: absolute;top:310px;left:250px">
  151. <!-- 统筹支付 -->
  152. 统筹支付:{{list.order.hifp_pay?list.order.hifp_pay:'0.00'}}
  153. </div>
  154. <div style="position: absolute;top:310px;left:480px">
  155. 现金支付:{{list.order.psn_cash_pay?list.order.psn_cash_pay:'0.00'}}
  156. <!-- 现金支付 -->
  157. </div>
  158. <div style="position: absolute;top:340px;left:40px">
  159. 公务员补助:{{list.order.cvlserv_pay?list.order.cvlserv_pay:'0.00'}}
  160. <!-- 公务员补助 -->
  161. </div>
  162. <div style="position: absolute;top:340px;left:250px">
  163. 医疗救助:{{list.order.maf_pay?list.order.maf_pay:'0.00'}}
  164. <!-- 医疗救助 -->
  165. </div>
  166. <!-- 大病 -->
  167. <!-- <div style="position: absolute;top:340px;left:500px">
  168. {{list.order.hifmi_pay?list.order.hifmi_pay:''}}
  169. </div> -->
  170. <!-- 其他基金支付 -->
  171. <!-- <div style="position: absolute;top:340px;left:560px">
  172. {{list.order.oth_pay?list.order.oth_pay:''}}
  173. </div> -->
  174. <div style="position: absolute;top:370px;left:40px">
  175. <!-- 预交款合计 -->
  176. 预交款合计:{{pre_pay_money}}
  177. </div>
  178. <div style="position: absolute;top:370px;left:250px">
  179. <!-- 补交款 -->
  180. 补交款:0.00
  181. </div>
  182. <div style="position: absolute;top:370px;left:480px">
  183. <!-- 应退款 -->
  184. 应退款:0.00
  185. </div>
  186. <div>
  187. <div style="position: absolute;top:400px;left:40px">
  188. <!-- 开票日期 -->
  189. 开票日期:{{printDate}}
  190. </div>
  191. <div style="position: absolute;top:400px;left:280px">
  192. <!-- 结算日期: -->
  193. 结算日期:{{list.order.setl_time?list.order.setl_time.split(' ')[0]:''}}
  194. </div>
  195. <div style="position: absolute;top:400px;left:500px">
  196. 经手人:<!-- 经手人: -->
  197. {{list.admin_user_name}}
  198. </div>
  199. </div>
  200. <div>
  201. <div style="position: absolute;top:600px;left:40px">
  202. <!-- 开票人: -->
  203. </div>
  204. </div>
  205. </div>
  206. </template>
  207. <script>
  208. import { getInvoice } from '@/api/project/project'
  209. export default {
  210. props:{
  211. paramsObj:Object
  212. },
  213. data(){
  214. return{
  215. list:null,
  216. printDate:'',
  217. zhongwen:'',
  218. totalPrice:0.0,
  219. org_id:'',
  220. org_name:'',
  221. psn_no:"",
  222. in_hosptial_time:'',
  223. out_hosptial_time:'',
  224. number:'',
  225. insutype:'',
  226. pre_pay_money:"",
  227. }
  228. },
  229. mounted(){
  230. console.log('paramsObj',this.paramsObj)
  231. let params = {
  232. order_id: this.paramsObj.order_id,
  233. patient_id: this.paramsObj.patient_id,
  234. }
  235. this.getInvoice(params)
  236. // var data = new Date();
  237. // var month =data.getMonth() < 9 ? "0" + (data.getMonth() + 1) : data.getMonth() + 1;
  238. // var date = data.getDate() <= 9 ? "0" + data.getDate() : data.getDate();
  239. // this.printDate = data.getFullYear() + "-" + month + "-" + date;
  240. // this.smalltoBIG(982732.21)
  241. this.org_id = this.$store.getters.xt_user.org_id
  242. this.org_name = this.$store.getters.xt_user.org.org_name
  243. },
  244. methods:{
  245. getDay(dateString1,dateString2){
  246. var startDate = Date.parse(dateString1);
  247. var endDate = Date.parse(dateString2);
  248. if (startDate>endDate){
  249. return 0;
  250. }
  251. if (startDate==endDate){
  252. return 1;
  253. }
  254. var days=(endDate - startDate)/(1*24*60*60*1000);
  255. return days;
  256. },
  257. getInvoice(params){
  258. getInvoice(params).then((res) => {
  259. console.log('res',res)
  260. this.list = res.data.data
  261. console.log(this.list)
  262. console.log(this.list.his_hospital_record)
  263. this.totalPrice = this.list.westernMedicineCostTotal + this.list.checkCostTotal + this.list.treatCostTotal + this.list.bedCostTotal + this.list.chineseTraditionalMedicineCostTotal +
  264. this.list.laboratoryCostTotal + this.list.operationCostTotal + this.list.otherCostTotal + this.list.materialCostTotal
  265. this.smalltoBIG( this.list.order.medfee_sumamt)
  266. // var data = new Date(res.data.data.date * 1000);
  267. var data = new Date(this.paramsObj.setl_time);
  268. var month =data.getMonth() < 9 ? "0" + (data.getMonth() + 1) : data.getMonth() + 1;
  269. var date = data.getDate() <= 9 ? "0" + data.getDate() : data.getDate();
  270. this.printDate = data.getFullYear() + "-" + month + "-" + date;
  271. if(this.list.his.id > 0){
  272. this.in_hosptial_time = this.getTime()
  273. this.out_hosptial_time = this.list.order.setl_time.split(' ')[0]
  274. }else{
  275. this.in_hosptial_time = this.list.his_hospital_record.in_hosptial_time.split(' ')[0]
  276. this.out_hosptial_time = this.list.his_hospital_record.out_hosptial_time.split(' ')[0]
  277. }
  278. this.insutype = this.list.order.insutype
  279. this.id_card_no = this.list.his_hospital_record.id_card_no
  280. this.number = this.list.his_hospital_record.number
  281. this.psn_no = this.list.his_hospital_record.psn_no
  282. this.pre_pay_money = this.list.pre_pay_money
  283. this.balance_accounts_type = this.list.his_hospital_record.balance_accounts_type
  284. this.gend= this.list.his_hospital_record.gend
  285. })
  286. },
  287. smalltoBIG(n) {
  288. // let fraction = ['角', '分'];
  289. // let digit = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
  290. // let unit = [['元.', '万,', '亿,'], ["元",'拾', '佰', '仟']];
  291. // let head = price < 0 ? '欠' : '';
  292. // price = Math.abs(price);
  293. // let upper = '';
  294. // for (let i = 0; i < fraction.length; i++) {
  295. // upper += (digit[Math.floor(price * 10 * Math.pow(10, i)) % 10] + fraction[i]).replace(/零./, '');
  296. // }
  297. // upper = upper || '整';
  298. // price = Math.floor(price);
  299. // for (let i = 0; i < unit[0].length && price > 0; i++) {
  300. // let p = '';
  301. // for (let j = 0; j < unit[1].length && price > 0; j++) {
  302. // p = digit[price % 10] + unit[1][j] + p;
  303. // price = Math.floor(price / 10);
  304. // }
  305. // upper = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][i] + upper;
  306. // }
  307. // this.zhongwen = head + upper.replace(/(零.)*零圆/, '圆').replace(/(零.)+/g, '零').replace(/^整$/, '零圆整')
  308. // console.log('6666',head + upper.replace(/(零.)*零圆/, '圆').replace(/(零.)+/g, '零').replace(/^整$/, '零圆整'))
  309. if (!/^(0|[1-9]\d*)(\.\d+)?$/.test(n)){
  310. return "数据非法"; //判断数据是否大于0
  311. }
  312. var unit = "仟佰拾亿仟佰拾万仟佰拾元角分", str = "";
  313. n += "00";
  314. var indexpoint = n.indexOf('.'); // 如果是小数,截取小数点前面的位数
  315. if (indexpoint >= 0){
  316. n = n.substring(0, indexpoint) + n.substr(indexpoint+1, 2); // 若为小数,截取需要使用的unit单位
  317. }
  318. unit = unit.substr(unit.length - n.length); // 若为整数,截取需要使用的unit单位
  319. for (var i=0; i < n.length; i++){
  320. str += "零壹贰叁肆伍陆柒捌玖".charAt(n.charAt(i)) + unit.charAt(i); //遍历转化为大写的数字
  321. }
  322. this.zhongwen = str.replace(/零(仟|佰|拾|角)/g, "零").replace(/(零)+/g, "零").replace(/零(万|亿|元)/g, "$1").replace(/(亿)万|壹(拾)/g, "$1$2").replace(/^元零?|零分/g, "").replace(/元$/g, "元整");
  323. console.log(this.zhongwen)
  324. },
  325. },
  326. watch:{
  327. paramsObj:{//深度监听,可监听到对象、数组的变化
  328. handler(val, oldVal){
  329. let params = {
  330. order_id: val.order_id,
  331. patient_id: val.patient_id,
  332. }
  333. this.getInvoice(params)
  334. },
  335. deep:true
  336. }
  337. }
  338. }
  339. </script>