see999 3 years ago
parent
commit
52e3e16b51

+ 1 - 1
src/xt_pages/dialysis/details/dialog/assessmentBeforeDislysisDialog.vue View File

@@ -885,7 +885,7 @@
885 885
           console.log("为首务2322323",this.assessmentBeforeDislysis.period)
886 886
           this.assessmentBeforeDislysis.period = this.assessmentBeforeDislysis.period.toString()
887 887
      
888
-          this.assessmentBeforeDislysis.dry_weight = this.predialysis_evaluation['dry_weight']
888
+          // this.assessmentBeforeDislysis.dry_weight = this.predialysis_evaluation['dry_weight']
889 889
           this.weight_adjust.weight = this.predialysis_evaluation['dry_weight']
890 890
         }
891 891
 

+ 5 - 3
src/xt_pages/outpatientCharges/invoicePrint.vue View File

@@ -13,12 +13,12 @@
13 13
     </template>
14 14
     <div class="app-container" style="padding-top:40px;">
15 15
         <div class='dialysisPage'>
16
-          <div v-if="org_id != 10106" >
16
+          <div v-if="org_id != 10106 && org_id != 10215" >
17 17
             <printOne v-if="org_id != 10088" :paramsObj="invoiceParams"></printOne>
18 18
             <printThree v-if="org_id == 10088" :paramsObj="invoiceParams"></printThree>
19 19
           </div>
20 20
           <printTwo v-if="org_id == 10106" :paramsObj="invoiceParams"></printTwo>
21
-            
21
+          <printFour v-if="org_id == 10215" :paramsObj="invoiceParams"></printFour>
22 22
         </div>
23 23
     </div>
24 24
   </div>
@@ -28,12 +28,14 @@
28 28
 import printOne from './invoiceTemplate/printOne'
29 29
 import printTwo from './invoiceTemplate/printTwo'
30 30
 import printThree from './invoiceTemplate/printThree'
31
+import printFour from './invoiceTemplate/printFour'
31 32
 export default {
32 33
    name: "invoicePrint",
33 34
   components: {
34 35
     printOne,
35 36
     printTwo,
36
-    printThree
37
+    printThree,
38
+    printFour
37 39
   },
38 40
   props:{
39 41
     invoiceParams:Object

+ 246 - 0
src/xt_pages/outpatientCharges/invoiceTemplate/printFour.vue View File

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