safecheck-client 4.0.1-8 → 4.0.1-80

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. package/.trae/.ignore +0 -0
  2. package/.vscode/settings.json +3 -0
  3. package/package.json +5 -5
  4. package/src/assets//350/255/246/345/221/212 (3).png +0 -0
  5. package/src/assets//350/255/246/345/221/212 (4).png +0 -0
  6. package/src/assets//350/255/246/345/221/212 (5).png +0 -0
  7. package/src/components/NewDefectList/DefectListNew.vue +22 -3
  8. package/src/components/Util/RightTreeSafeDep.vue +12 -0
  9. package/src/components/android/AndroidDefectDeal.vue +356 -323
  10. package/src/components/android/AndroidDefectDetails.vue +3 -3
  11. package/src/components/android/AppInstallationMaterial.vue +865 -0
  12. package/src/components/android/DailyworkloadQuery.vue +2 -1
  13. package/src/components/android/NewCheckpaperAndroid.vue +22 -48
  14. package/src/components/android/SafecheckOrderV.vue +6 -0
  15. package/src/components/android/SwitchValve.vue +1 -1
  16. package/src/components/checkplan/CheckDetail.vue +1 -1
  17. package/src/components/map/SecurityCheckCoordinates.vue +361 -0
  18. package/src/components/paper/PaperList.vue +5 -0
  19. package/src/components/pc/DefectDeal.vue +2 -1
  20. package/src/components/pc/DefectMaterialLook.vue +98 -0
  21. package/src/components/pc/PaperDefectMain.vue +26 -1
  22. package/src/components/pc/RoleSelectorDep.vue +9 -2
  23. package/src/components/planmanage/PlanManage.vue +1 -0
  24. package/src/components/querycheckpaper/CheckPaperList.vue +6 -4
  25. package/src/components/querycheckpaper/CheckPaperSearchUser.vue +30 -4
  26. package/src/components/querycheckpaper/CheckSearchUser.vue +6 -1
  27. package/src/filiale/jinhong/android/CurrentCreate.vue +66 -22
  28. package/src/filiale/jinhong/pc/CheckBookList.vue +12 -7
  29. package/src/filiale/jinhong/pc/DefectPaperNew.vue +10 -10
  30. package/src/filiale/jinhong/pc/PaperList.vue +56 -47
  31. package/src/filiale/jinhong/pc/PlanManage.vue +2 -0
  32. package/src/filiale/jinhong/pc/checkPlanList.vue +2 -0
  33. package/src/filiale/jinhong/pc/checkUserList.vue +766 -742
  34. package/src/filiale/libo/android/PaperFeedback.vue +1579 -0
  35. package/src/filiale/libo/android/PhoneUpUserinfo.vue +1249 -0
  36. package/src/filiale/libo/android/SafecheckOrderV.vue +2302 -0
  37. package/src/filiale/libo/android.js +14 -0
  38. package/src/filiale/libo/pc/NewCheckpaper.vue +1987 -0
  39. package/src/filiale/libo/pc.js +12 -0
  40. package/src/filiale/meihekou/android/CurrentCreate.vue +1 -1
  41. package/src/filiale/meihekou/android/MeterReading.vue +9 -5
  42. package/src/filiale/meihekou/android/PhoneUpUserinfo.vue +3 -2
  43. package/src/filiale/meihekou/android/SafecheckDevices.vue +5 -5
  44. package/src/filiale/meihekou/android/SafecheckOrderV.vue +2446 -2427
  45. package/src/filiale/meihekou/pc/NewCheckpaper.vue +2 -2
  46. package/src/filiale/meihekou/pc/NewCheckpaperNew.vue +2050 -0
  47. package/src/filiale/meihekou/pc/PaperList.vue +1205 -0
  48. package/src/filiale/meihekou/pc.js +2 -0
  49. package/src/filiale/minsheng/android/SwitchValve.vue +1 -1
  50. package/src/filiale/qianneng/android/SwitchValve.vue +1 -1
  51. package/src/filiale/qingjian/pc/checkUserList.vue +35 -0
  52. package/src/filiale/taiyuan/android/AddPlanItem.vue +456 -0
  53. package/src/filiale/taiyuan/android/AreaPlan.vue +565 -0
  54. package/src/filiale/taiyuan/android/CurrentCreate.vue +1016 -0
  55. package/src/filiale/taiyuan/android/PhoneUpUserinfo.vue +1253 -0
  56. package/src/filiale/taiyuan/android/SafecheckOrderV.vue +2347 -0
  57. package/src/filiale/taiyuan/android/SafecheckUserInfo.vue +784 -0
  58. package/src/filiale/taiyuan/android.js +15 -0
  59. package/src/filiale/taiyuan/pc/DefectDeal.vue +1034 -0
  60. package/src/filiale/taiyuan/pc/NewCheckpaper.vue +1976 -0
  61. package/src/filiale/taiyuan/pc/PaperList.vue +795 -0
  62. package/src/filiale/taiyuan/pc/PlanManage.vue +891 -0
  63. package/src/filiale/taiyuan/pc/checkUserList.vue +798 -0
  64. package/src/filiale/taiyuan/pc.js +16 -0
  65. package/src/filiale/tianke/android/CurrentCreate.vue +3 -3
  66. package/src/filiale/tongchuan/android/SwitchValve.vue +1 -1
  67. package/src/filiale/xinkang/android/AddPlanItem.vue +244 -196
  68. package/src/filiale/xinkang/android/AndroidDefectDeal.vue +1 -0
  69. package/src/filiale/xinkang/android/SafecheckDevices.vue +52 -22
  70. package/src/filiale/xinkang/android/SafecheckOrderV.vue +24 -80
  71. package/src/filiale/xinkang/android/SafecheckUserInfo.vue +1 -1
  72. package/src/filiale/xinkang/pc/CheckSearchUser.vue +12 -12
  73. package/src/filiale/xinkang/pc/NewCheckpaper.vue +57 -72
  74. package/src/filiale/xinkang/pc/PaperList.vue +25 -10
  75. package/src/filiale/yuansheng/android/SwitchValve.vue +1 -1
  76. package/src/filiale/yunchengminsheng/android/PaperFeedback.vue +1030 -1030
  77. package/src/filiale/yunchengminsheng/android/SafecheckDevices.vue +4 -4
  78. package/src/filiale/yunchengminsheng/pc/PaperList.vue +811 -0
  79. package/src/filiale/yunchengminsheng/pc.js +1 -0
  80. package/src/main.js +33 -33
  81. package/src/safecheck-android.js +4 -0
  82. package/src/safecheck.js +6 -0
@@ -0,0 +1,865 @@
1
+ <template>
2
+ <work-busy :is-busy="button_state"></work-busy>
3
+ <div v-for="(i, item) in material" class="y-form">
4
+ <div class="y-form-head">
5
+ <span style="text-align: center">材料{{ $index + 1 }}信息</span>
6
+ <button style="float: right" class="button_delete button_spacing" v-if="i > 0" @click.prevent="deleteUserFile(i)">删除
7
+ </button>
8
+ </div>
9
+ <div class="y-form-item">
10
+ <label>材料分类</label>
11
+ <input-select
12
+ class="select select_list y-form-item-input"
13
+ :value.sync="item.f_typename" v-model="item.f_typename"
14
+ :options="category.typeoptions"
15
+ @change="materialChange(item.f_typename)"
16
+ :valueSingle="true">
17
+ </input-select>
18
+ </div>
19
+ <div class="y-form-item">
20
+ <label>材料名称</label>
21
+ <input-select
22
+ class="select select_list y-form-item-input"
23
+ :value.sync="item.f_material_name"
24
+ v-model="item.f_material_name"
25
+ :options="category.options"
26
+ @change="item.f_typenumber = undefined"
27
+ :valueSingle="true">
28
+ </input-select>
29
+ </div>
30
+ <div class="y-form-item">
31
+ <label>材料型号</label>
32
+ <input-select
33
+ class="select select_list y-form-item-input"
34
+ :value.sync="item.f_typenumber"
35
+ v-model="item.f_typenumber"
36
+ :options="category.children[item.f_material_name].options"
37
+ @change="handleTypeChange(i)"
38
+ :valueSingle="true">
39
+ </input-select>
40
+ </div>
41
+ <div class="y-form-item">
42
+ <label>单价(元/{{
43
+ category.children[item.f_material_name].children[item.f_typenumber].f_material_spec
44
+ }})</label>
45
+ <input type="number" class="form-control y-form-item-input" v-model="item.f_material_price"
46
+ :value="item.f_material_price || category.children[item.f_material_name].children[item.f_typenumber].f_material_price">
47
+ </div>
48
+ <div class="y-form-item">
49
+ <label>数量</label>
50
+ <input type="number" class="form-control y-form-item-input" v-model="item.f_material_number">
51
+ </div>
52
+ <div class="y-form-item">
53
+ <label>金额</label>
54
+ <input type="number" class="form-control y-form-item-input" v-model="item.f_fee"
55
+ :value="smallnum(item.f_material_price, item.f_material_number)" readonly>
56
+ </div>
57
+ <div class="y-form-item">
58
+ <label>备注</label>
59
+ <textarea type="text" rows="2" class="form-control y-form-item-input" v-model="item.f_remarks"></textarea>
60
+ </div>
61
+ </div>
62
+ <div style="padding: 10px;display: flex;justify-content: space-around;">
63
+ <button type="button" class="btn btn-primary" @click="addUserFile">添加</button>
64
+ <button type="button" class="btn btn-primary" @click="showQrcodeButton">保存</button>
65
+ </div>
66
+ <div v-show="showQrCode">
67
+ <div class="row">
68
+ <label class="text-justify lb-left" style="width: 100px">收款</label>
69
+ <div class="row row_sty">
70
+ <label class="lab_sty col-xs-4">合计金额</label>
71
+ <div class="col-xs-8">
72
+ <input type="number" class="form-control" v-model="payNumber" :value.sync="payNumber" readonly>
73
+ </div>
74
+ </div>
75
+ <div class="row row_sty">
76
+ <label class="lab_sty col-xs-4">收款方式</label>
77
+ <div class="col-xs-8">
78
+ <v-select
79
+ :width="'100%'"
80
+ :value.sync="payType"
81
+ v-model="payType"
82
+ :options='payTypes'
83
+ placeholder='请选择'
84
+ close-on-select
85
+ :value-single="true"
86
+ ></v-select>
87
+ </div>
88
+ </div>
89
+ <div v-if="zfCode" style="margin-top: 20px; text-align: center;">
90
+ <div id="qrcode" style="margin-top: 25px;width: 266px;height: 266px"></div>
91
+ </div>
92
+ </div>
93
+ <div style="padding: 10px;display: flex;justify-content: space-around;">
94
+ <button type="button" name="button" class="btn btn-primary btn-sm" style="float: right;margin-right:10px;"
95
+ @click="beforeSaveCharge()">收费
96
+ </button>
97
+ <button type="button" class="btn btn-primary" @click="cancel">取消</button>
98
+ </div>
99
+ </div>
100
+ </template>
101
+ <script>
102
+ import Vue from 'vue'
103
+ import {HttpResetClass} from 'vue-client'
104
+ import QRCode from 'qrcodejs2'
105
+ import {getNowDate, isEmpty} from '../../components/Util'
106
+
107
+ export default {
108
+ title: '材料添加',
109
+ props: {
110
+ selectdata: {
111
+ type: Object
112
+ }
113
+ },
114
+ data() {
115
+ return {
116
+ originalOptions: [], // 用于保存原始数据
117
+ othercharge_id: '',
118
+ payState: false,
119
+ zfCode: false,
120
+ f_out_trade_no: '',
121
+ payTypes: [{label: '二维码支付', value: '二维码支付'},{label: '微信支付', value: '微信支付'}],
122
+ payType: '',
123
+ payNumber: 0,
124
+ button_state: false,
125
+ category: {
126
+ options: [],
127
+ },
128
+ showFile: false,
129
+ material: [],
130
+ positions: this.$appdata.getParam('品名及规格'), // 获取材料名称
131
+ charge: {
132
+ payment_terms: [{f_payment_term: '', f_charge_money: '', f_amount_words: '', f_payment_method: ''}]
133
+ }, // 收费内容
134
+ showCharge: false, // 收费显示
135
+ timeLeft: 300, // 收费时间
136
+ title1: '', // 二维码标题
137
+ showQrCode: false, // 二维码显示
138
+ order: {}, // 订单信息
139
+ f_cost_sum: 0, // 总收费
140
+ }
141
+ },
142
+ ready() {
143
+ this.loadOptions()
144
+ },
145
+ methods: {
146
+ handleTypeChange(i) {
147
+ if(!isEmpty(this.material[i].f_material_name)){
148
+ this.material[i].f_material_price = this.category.children[this.material[i].f_material_name].children[this.material[i].f_typenumber].f_material_price
149
+ }
150
+
151
+ },
152
+ materialChange(typename) {
153
+ this.category.options=[]
154
+ if(isEmpty(typename)){
155
+ this.category.options=[]
156
+ }else{
157
+ // 从原始数据中过滤,仅保留当前分类下的材料名称
158
+ // this.category.options = this.originalOptions.filter(option => option.key === typename);
159
+ for (let i = 0; i < this.originalOptions.length; i++) {
160
+ if (this.originalOptions[i].key === typename) {
161
+ this.category.options.push({
162
+ label: this.originalOptions[i].label,
163
+ value: this.originalOptions[i].value
164
+ })
165
+ }
166
+
167
+ }
168
+ }
169
+ },
170
+ cancel() {
171
+ this.payNumber = 0
172
+ this.othercharge_id = ''
173
+ this.payState = false
174
+ this.zfCode = false
175
+ this.showQrCode = false
176
+ clearTimeout(this.orderInterval)
177
+ },
178
+ getChangePayNumber() {
179
+ this.payNumber = 0
180
+ for (let i = 0; i < this.material.length; i++) {
181
+ this.material[i].f_fee = this.material[i].f_material_price * this.material[i].f_material_number
182
+ this.payNumber += Number(this.material[i].f_fee)
183
+ }
184
+ },
185
+ showQrcodeButton() {
186
+ this.getChangePayNumber()
187
+ this.showQrCode = true
188
+ },
189
+ loadOptions () {
190
+ const data = {
191
+ tablename: 't_material_management',
192
+ condition: `1=1 and f_orgid='${Vue.user.orgid}'`
193
+ }
194
+ this.$resetpost(this.$androidUtil.getProxyUrl() + '/af-telephone/rs/sql/tel_singleTable', {data}, {
195
+ resolveMsg: null,
196
+ rejectMsg: '获取数据失败'
197
+ }).then((res) => {
198
+ const categories = []
199
+ const types = []
200
+ for (let material of res.data) {
201
+ if (material.f_material_stype == '分类') {
202
+ categories.push(material)
203
+ } else if (material.f_material_stype == '型号') {
204
+ types.push(material)
205
+ }
206
+ }
207
+ this.category.typeoptions = []
208
+ const seen = new Set(); // 用于记录已出现的 f_material_type
209
+ for (let category of categories) {
210
+ const type = category.f_material_type;
211
+ if (!seen.has(type)) {
212
+ seen.add(type);
213
+ this.category.typeoptions.push({
214
+ label: type,
215
+ value: type
216
+ });
217
+ }
218
+ }
219
+ this.originalOptions = []
220
+ for (let category of categories) {
221
+ this.originalOptions.push({
222
+ key: category.f_material_type,
223
+ label: category.f_material_name,
224
+ value: category.f_material_name
225
+ })
226
+ }
227
+
228
+ this.category.children = {}
229
+ for (let category of categories) {
230
+ this.category.children[category.f_material_name] = {
231
+ options: [],
232
+ children: {}
233
+ }
234
+
235
+ for (let type of types) {
236
+ if (type.parent_id == category.id) {
237
+ this.category.children[category.f_material_name].options.push({
238
+ label: type.f_material_name,
239
+ value: type.f_material_name
240
+ })
241
+ this.category.children[category.f_material_name].children[type.f_material_name] = type
242
+ }
243
+ }
244
+ }
245
+ console.log('this.category=', JSON.stringify(this.category))
246
+ this.search()
247
+ })
248
+ },
249
+ // 删除未保存的材料信息
250
+ async deleteUserFile(index) {
251
+ this.material.splice(index, 1)
252
+ this.cancel()
253
+ },
254
+ // 追加材料信息
255
+ addUserFile() {
256
+ this.material.push({})
257
+ this, this.cancel()
258
+ },
259
+ search() {
260
+ let http = new HttpResetClass()
261
+ let data = {
262
+ tablename: 't_material_service',
263
+ condition: `f_process_id = '${this.selectdata.f_process_id}'`
264
+ }
265
+ http.load('post', this.$androidUtil.getProxyUrl() + '/af-telephone/rs/sql/tel_singleTable', {data: data}, {
266
+ resolveMsg: null,
267
+ rejectMsg: '获取数据失败'
268
+ }).then(res => {
269
+ this.material = res.data
270
+ if (this.material.length <= 0) {
271
+ this.material = [{}]
272
+ }
273
+ })
274
+ },
275
+ // 获取品名规格
276
+ // setTypename(i, val) {
277
+ // let ac = this.$appdata.getParam(val)
278
+ // this.$set('material[' + i + '].typeNameList', ac)
279
+ // this.$set('material[' + i + '].typeNumberList', [])
280
+ // this.$set('material[' + i + '].f_typenumber', null)
281
+ // this.$set('material[' + i + '].f_material_price', 0)
282
+ // },
283
+ // 获取类型
284
+ // setTypenumber(i, val) {
285
+ // let ac = this.$appdata.getParam(val)
286
+ // this.$set('material[' + i + '].typeNumberList', ac)
287
+ // this.$set('material[' + i + '].f_material_price', 0)
288
+ // },
289
+ // 获取单价
290
+ // setmaterialprice(i, val) {
291
+ // var num
292
+ // if (val == null) {
293
+ // num = 0
294
+ // }
295
+ // num = this.$appdata.getSingleValue(val)
296
+ // this.$set('material[' + i + '].f_material_price', num)
297
+ // },
298
+ // 金额计算
299
+ smallnum(val, val1) {
300
+ let num = Number(val) * Number(val1)
301
+ return num
302
+ },
303
+ qrcode(url) {
304
+ new QRCode('qrcode', {
305
+ text: url, // 设置二维码内容或跳转地址
306
+ width: 266, // 设置宽度,单位像素
307
+ height: 266, // 设置高度,单位像素
308
+ correctLevel: QRCode.CorrectLevel.L //容错率,L/M/Hs
309
+ })
310
+ },
311
+ clearQrCode() {
312
+ if (document.getElementById('qrcode')) {
313
+ document.getElementById('qrcode').innerHTML = ''
314
+ }
315
+ },
316
+ async getOrderInformation() {
317
+ // 查询订单信息
318
+ console.log('查询订单信息!!!')
319
+ let http = new HttpResetClass()
320
+ let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/wx/rs/weixin/orderStatus`, {
321
+ "f_filiale": "wensuxilong",
322
+ "out_trade_no": `${this.f_out_trade_no}`
323
+ }, {
324
+ resolveMsg: null,
325
+ rejectMsg: '订单查询失败!!!'
326
+ })
327
+ // 支付成功
328
+ if (res.data.trade_state_desc.includes('成功')) {
329
+ this.$showMessage('支付成功!!!')
330
+ await this.saveUserFile('save')
331
+ this.clearQrCode()
332
+ this.cancel()
333
+ }
334
+ },
335
+ async openQrcode() {
336
+ this.clearQrCode()
337
+ let data = {
338
+ tablename: 't_userfiles',
339
+ condition: `f_userinfo_id = '${this.selectdata.model.f_userinfo_id}'`
340
+ }
341
+ let res = await new HttpResetClass().load('post', this.$androidUtil.getProxyUrl() + '/af-telephone/rs/sql/tel_singleTable', {data: data}, {
342
+ resolveMsg: null,
343
+ rejectMsg: '获取数据失败'
344
+ })
345
+ let reqdata = {
346
+ "filiale": "wensuxilong",
347
+ "money": 1,
348
+ "str": "材料收费",
349
+ "attach": {
350
+ "f_userfiles_id": res.data[0].f_userfiles_id,
351
+ "f_userinfo_id": this.selectdata.model.f_userinfo_id
352
+ }
353
+ }
354
+ new HttpResetClass().load('POST', `${this.$androidUtil.getProxyUrl()}/wx/rs/weixin/gasgetcode`, reqdata).then(res => {
355
+ if (res.data.code === 200) {
356
+ this.f_out_trade_no = res.data.out_trade_no
357
+ this.zfCode = true
358
+ this.$nextTick(() => {
359
+ this.qrcode(res.data.url)
360
+ })
361
+ this.orderInterval = setInterval(() => {
362
+ this.getOrderInformation()
363
+ }, 3000)
364
+ } else {
365
+ this.$showMessage('网络异常。。。')
366
+ }
367
+ })
368
+ },
369
+ async beforeSaveCharge() {
370
+
371
+
372
+ if (this.material.length == 0) {
373
+ return this.$showMessage(`请先添加消耗的材料!`)
374
+ }
375
+ for (let index = 0; index < this.material.length; index++) {
376
+ const item = this.material[index]
377
+ if (!item.f_material_name) {
378
+ this.$showMessage(`请选择材料${index + 1}的材料名称`)
379
+ return;
380
+ }
381
+ if (!item.f_typenumber) {
382
+ this.$showMessage(`请选择材料${index + 1}的型号`)
383
+ return;
384
+ }
385
+ if (!item.f_material_price) {
386
+ this.$showMessage(`请填写材料${index + 1}的单价`)
387
+ return;
388
+ }
389
+ if (!item.f_material_number || item.f_material_number == 0) {
390
+ this.$showMessage(`请填写材料${index + 1}的数量`)
391
+ return;
392
+ }
393
+ }
394
+ if (!this.payType) {
395
+ this.$showMessage(`请选择缴费方式`)
396
+ return;
397
+ }
398
+ if (this.payType.includes('二维码') && this.payNumber>0) {
399
+ await this.openQrcode()
400
+ } else {
401
+ this.payState= true
402
+ await this.saveUserFile('save')
403
+ }
404
+ },
405
+ async saveUserFile(type) {
406
+ for (let i = 0; i < this.material.length; i++) {
407
+ this.material[i].f_material_name = this.material[i].f_material_name
408
+ this.material[i].f_process_id = this.selectdata.f_process_id
409
+ this.material[i].f_department = Vue.user.f_department_name
410
+ this.material[i].f_operator = Vue.user.name
411
+ this.material[i].f_fee = this.material[i].f_material_price * this.material[i].f_material_number
412
+ if (isEmpty(this.material[i].f_state)) {
413
+ this.material[i].f_state = null
414
+ }
415
+ }
416
+ await this.saveOrder(type)
417
+ },
418
+ async saveOrder(type) {
419
+ console.log('this.material', this.material)
420
+ let otherdetail = []
421
+ if (this.payNumber == 0) {
422
+ otherdetail.push({
423
+ f_brand_spec: ['维修'],
424
+ f_typename: ['材料费'],
425
+ f_typenumber: [],
426
+ f_unitprice: 0,
427
+ f_number: this.material.length
428
+ })
429
+ } else {
430
+ this.material.forEach((row) => {
431
+ if (row.f_material_price != 0) {
432
+ otherdetail.push({
433
+ f_brand_spec: ['维修'],
434
+ f_typename: [`${row.material_type ? row.material_type : '材料费'}`],
435
+ f_typenumber: [],
436
+ f_unitprice: row.f_material_price,
437
+ f_number: row.f_material_number
438
+ })
439
+ }
440
+ })
441
+ }
442
+ let param = {
443
+ model: this.material,
444
+ operator_type: type,
445
+ othercharge_id: this.othercharge_id,
446
+ f_process_id: this.selectdata.f_process_id,
447
+ f_userinfo_code: this.selectdata.model.f_userinfo_id,
448
+ other:{
449
+ "record_userinfo": this.selectdata.model.f_userinfo_id,
450
+ "f_user_name": this.selectdata.model.f_user_name,
451
+ "f_address": this.selectdata.model.f_address,
452
+ "f_user_type": this.selectdata.model.f_user_type,
453
+ "f_gasproperties": "",
454
+ "f_collection": this.payNumber,
455
+ "f_comments": `${Vue.user.name}进行维修材料收费,收费方式-${this.payType} ${this.order.body && this.order.body.tradeNo ? '。支付订单号:' + this.order.body.tradeNo : ''}`,
456
+ "f_payment": this.payType,
457
+ "f_voucher_number": this.selectdata.f_process_id,
458
+ "f_bill_style": "普通收据",
459
+ "f_userinfo_id": this.selectdata.model.f_userinfo_id,
460
+ "f_service_person": Vue.user.name,
461
+ "f_operat_type": "维修收费",
462
+ "f_describe": "",
463
+ "f_serial_id": this.order.body ? this.order.body.tradeNo : null,
464
+ "f_state": '有效',
465
+ "f_operator": Vue.user.name,
466
+ "f_operatorid": Vue.user.id,
467
+ "f_orgid": Vue.user.orgid,
468
+ "f_orgname": Vue.user.orgs,
469
+ "f_depid": Vue.user.depids,
470
+ "f_depname": Vue.user.f_department_name,
471
+ "t_userfees": "",
472
+ "f_fee_type": "维修费用",
473
+ "f_fee_time": "12",
474
+ "otherdetail": otherdetail
475
+ }
476
+ }
477
+ console.log("材料收费保存", param)
478
+ let res = await new HttpResetClass().load('POST', `${this.$androidUtil.getProxyUrl()}/af-telephone/rs/logic/saveMaterialService`, param, {
479
+ resolveMsg: null,
480
+ rejectMsg: null
481
+ })
482
+ if (res.data.code == 200) {
483
+ if (type === 'create') {
484
+ // this.$showMessage('收费记录创建成功!!!')
485
+ // this.othercharge_id = res.data.othercharge_id
486
+ // this.$emit('aftersave')
487
+ } else {
488
+ this.$showMessage('材料保存成功!!!')
489
+ this.$emit('aftersave')
490
+ }
491
+
492
+
493
+ } else {
494
+ this.$showMessage(res.data.msg)
495
+ }
496
+ },
497
+ // 关闭对话框
498
+ // closeModal() {
499
+ // this.showCharge = false
500
+ // this.charge = {
501
+ // payment_terms: [{
502
+ // f_payment_term: '',
503
+ // f_charge_money: '',
504
+ // f_amount_words: '',
505
+ // f_payment_method: this.charge.f_payment_method
506
+ // }]
507
+ // }
508
+ // },
509
+ // 金额转大写
510
+ // handleInput(index) {
511
+ // // 通过正则过滤小数点后两位
512
+ // console.log('-----------------------')
513
+ // this.charge.payment_terms[index].f_charge_money = (this.charge.payment_terms[index].f_charge_money.match(/^\d*(\.?\d{0,2})/g)[0]) || null
514
+ // this.charge.payment_terms[index].f_amount_words = this.smalltoBIG(this.charge.payment_terms[index].f_charge_money)
515
+ // },
516
+ // 金额转大写
517
+ // smalltoBIG(n) {
518
+ // let fraction = ['角', '分'];
519
+ // let digit = ['零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖'];
520
+ // let unit = [['元', '万', '亿'], ['', '拾', '佰', '仟']];
521
+ // let head = n < 0 ? '欠' : '';
522
+ // n = Math.abs(n);
523
+ //
524
+ // let s = '';
525
+ //
526
+ // for (var i = 0; i < fraction.length; i++) {
527
+ // s += (digit[Math.floor(n * 10 * Math.pow(10, i)) % 10] + fraction[i]).replace(/零./, '');
528
+ // }
529
+ // s = s || '整';
530
+ // n = Math.floor(n);
531
+ //
532
+ // for (var i = 0; i < unit[0].length && n > 0; i++) {
533
+ // let p = '';
534
+ // for (var j = 0; j < unit[1].length && n > 0; j++) {
535
+ // p = digit[n % 10] + unit[1][j] + p;
536
+ // n = Math.floor(n / 10);
537
+ // }
538
+ // s = p.replace(/(零.)*零$/, '').replace(/^$/, '零') + unit[0][i] + s;
539
+ // }
540
+ // return head + s.replace(/(零.)*零元/, '元').replace(/(零.)+/g, '零').replace(/^整$/, '零元整')
541
+ // },
542
+ // moneyChange(index) {
543
+ // console.log(`当前下标----${index}`)
544
+ // if (isEmpty(this.charge.payment_terms[index].f_charge_money) || Number(this.charge.payment_terms[index].f_charge_money) === 0) {
545
+ // this.$showMessage('单笔收费不能为0元!!!', 'warning', 3000)
546
+ // this.charge.payment_terms[index].f_charge_money = null
547
+ // return
548
+ // }
549
+ //
550
+ // },
551
+ // 打开二维码
552
+ // async openQrCode() {
553
+ // let http = new HttpResetClass()
554
+ // for (let row = 0; row < this.charge.payment_terms.length; row++) {
555
+ // console.log(this.charge.payment_terms[row])
556
+ // if (isEmpty(this.charge.payment_terms[row].f_payment_term)) {
557
+ // this.$showMessage('请选择收费项目!!!', 'warning', 3000)
558
+ // return
559
+ // } else if (isEmpty(this.charge.payment_terms[row].f_charge_money)) {
560
+ // this.$showMessage('请输入收费金额!!!', 'warning', 3000)
561
+ // return
562
+ // }
563
+ // }
564
+ // if (this.charge.f_payment_method !== '微信支付' && this.charge.f_payment_method !== '支付宝支付') {
565
+ // this.saveother()
566
+ // this.$showMessage('缴费成功!')
567
+ // this.update()
568
+ // this.showCharge = false
569
+ // return
570
+ // }
571
+ // if (this.charge.f_payment_method == '微信支付') {
572
+ // this.title1 = '微信'
573
+ // }
574
+ // if (this.charge.f_payment_method == '支付宝支付') {
575
+ // this.title1 = '支付宝'
576
+ // }
577
+ // this.showCharge = false
578
+ // // 接口金额 单位为:分
579
+ // let data = {
580
+ // money: this.accMul(this.getTotalAmount(), 1) + '',
581
+ // attach: {
582
+ // "f_user": Vue.user.id,
583
+ // "f_user_name": Vue.user.name
584
+ // },
585
+ // orderType: '工单收费',
586
+ // userfilesid: '',
587
+ // flag: 'JsApiWeiNan',
588
+ // openid: '',
589
+ // filiale: 'weinanchengtou'
590
+ // }
591
+ // // 下订单
592
+ // await http.load('POST', `${this.$androidUtil.getProxyUrl()}/wx/rs/pay/jsApiPay`, data, {
593
+ // resolveMsg: null,
594
+ // rejectMsg: '订单生成失败!!!'
595
+ // }).then(
596
+ // res => {
597
+ // this.order = res.data
598
+ // this.showQrCode = true
599
+ // this.$nextTick(() => {
600
+ // this.qrcode()
601
+ // })
602
+ // // 剩余支付时间
603
+ // this.paymentInterval = setInterval(() => {
604
+ // this.timeLeft = this.timeLeft - 1
605
+ // }, 1000)
606
+ //
607
+ // // 3秒查询一次订单支付信息
608
+ // this.orderInterval = setInterval(() => {
609
+ // this.getOrderInformation()
610
+ // }, 3000)
611
+ // }
612
+ // )
613
+ // },
614
+ // getTotalAmount() {
615
+ // let money = 0
616
+ // this.charge.payment_terms.forEach((row) => {
617
+ // money = Math.floor((Number(money) + Number(row.f_charge_money)) * 100) / 100
618
+ // })
619
+ // return money
620
+ // },
621
+ // getPaymentTerm() {
622
+ // let term = ''
623
+ // this.charge.payment_terms.forEach((row) => {
624
+ // term += `${row.f_payment_term} `
625
+ // })
626
+ // return term
627
+ // },
628
+ // closeQRCode() {
629
+ // clearTimeout(this.paymentInterval)
630
+ // clearTimeout(this.orderInterval)
631
+ // this.timeLeft = 300
632
+ // this.closeOrder()
633
+ // // 清除二维码
634
+ // this.clearQrCode()
635
+ // this.showQrCode = false
636
+ // },
637
+ // clearQrCode() {
638
+ // document.getElementById('qrcode').innerHTML = ''
639
+ // },
640
+ // async closeOrder() {
641
+ // let data = {
642
+ // "flag": "JsApiWeiNan",
643
+ // "f_filiale": "weinanchengtou",
644
+ // "f_out_trade_no": this.order.f_out_trade_no,// 商户单号
645
+ // "isClose": "是",
646
+ // "f_sys_trace": this.order.f_sys_trace // 交易流水号
647
+ // }
648
+ // let http = new HttpResetClass()
649
+ // let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/wx/rs/pay/microPayOrderStatus`, data, {
650
+ // resolveMsg: null,
651
+ // rejectMsg: '关闭失败!!!'
652
+ // })
653
+ // },
654
+ // qrcode() {
655
+ // let qrcode = new QRCode('qrcode', {
656
+ // text: this.order.appId, // 设置二维码内容或跳转地址
657
+ // width: 200, // 设置宽度,单位像素
658
+ // height: 200, // 设置高度,单位像素
659
+ // correctLevel: QRCode.CorrectLevel.L //容错率,L/M/Hs
660
+ // })
661
+ // },
662
+ // // 获取订单信息
663
+ // async getOrderInformation() {
664
+ // // 查询订单信息
665
+ // console.log('查询订单信息!!!')
666
+ // let http = new HttpResetClass()
667
+ // let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/af-telephone/rs/sql/tel_singleTable`, {
668
+ // data: {
669
+ // tablename: "t_weixinreturnxml",
670
+ // condition: ` f_out_trade_no = '${this.order.f_out_trade_no}' and f_order_state = '已支付' `,
671
+ // }
672
+ // }, {
673
+ // resolveMsg: null,
674
+ // rejectMsg: '订单查询失败!!!'
675
+ // })
676
+ // // 支付成功
677
+ // if (res.data.length > 0) {
678
+ // clearTimeout(this.paymentInterval)
679
+ // clearTimeout(this.orderInterval)
680
+ // this.timeLeft = 300
681
+ // // 修改支付状态
682
+ // this.saveother()
683
+ // this.$showMessage('支付成功!!!')
684
+ // this.update()
685
+ // // 清除二维码
686
+ // this.clearQrCode()
687
+ // this.showQrCode = false
688
+ // }
689
+ // },
690
+ // async update() {
691
+ // let http = new HttpResetClass()
692
+ // for (let i = 0; i < this.material.length; i++) {
693
+ // if (this.material[i].f_state == '未收费') {
694
+ // this.material[i].f_state = '已收费'
695
+ // }
696
+ // }
697
+ // let data = {
698
+ // model: this.material
699
+ // }
700
+ // let res = await http.load('post', this.$androidUtil.getProxyUrl() + '/af-telephone/rs/logic/saveweinanmaterial', {data: data}, {
701
+ // resolveMsg: null,
702
+ // rejectMsg: '保存失败'
703
+ // })
704
+ // this.search()
705
+ // },
706
+ // async saveother() {
707
+ // let http = new HttpResetClass()
708
+ // let data1 = {
709
+ // tablename: 't_material_service',
710
+ // condition: `f_process_id = '${this.selectdata.f_process_id}' and f_state = '未收费'`
711
+ // }
712
+ // let res1 = await http.load('post', this.$androidUtil.getProxyUrl() + '/af-telephone/rs/sql/tel_singleTable', {data: data1}, {
713
+ // resolveMsg: null,
714
+ // rejectMsg: '获取数据失败'
715
+ // })
716
+ // let data = {
717
+ // tablename: 't_userfiles',
718
+ // condition: `f_userinfo_id = '${this.selectdata.model.f_userinfo_id}'`
719
+ // }
720
+ // let res = await http.load('post', this.$androidUtil.getProxyUrl() + '/af-telephone/rs/sql/tel_singleTable', {data: data}, {
721
+ // resolveMsg: null,
722
+ // rejectMsg: '获取数据失败'
723
+ // })
724
+ // let otherdetails = []
725
+ // for (let i = 0; i < res1.data.length; i++) {
726
+ // otherdetails.push(
727
+ // {
728
+ // "f_brand_spec": [res1.data[i].f_material_name],
729
+ // "f_unitprice": res1.data[i].f_material_price,
730
+ // "f_typename": [res1.data[i].f_typename],
731
+ // "f_typenumber": [res1.data[i].f_typenumber],
732
+ // "f_number": res1.data[i].f_material_number
733
+ // }
734
+ // )
735
+ // }
736
+ //
737
+ // console.log("查询的用户信息", otherdetails)
738
+ // let data2 = {
739
+ // "record_userinfo": this.selectdata.model.f_userinfo_id,
740
+ // "f_userfiles_id": res.data[0].f_userfiles_id,
741
+ // "f_user_id": res.data[0].f_user_id,
742
+ // "f_user_name": this.selectdata.model.f_user_name,
743
+ // "f_address": this.selectdata.model.f_address,
744
+ // "f_user_type": this.selectdata.model.f_user_type,
745
+ // "f_gasproperties": "",
746
+ // "f_collection": this.f_cost_sum,
747
+ // "f_comments": "",
748
+ // "f_payment": this.charge.f_payment_method,
749
+ // "f_voucher_number": "",
750
+ // "f_bill_style": "普通收据",
751
+ // "f_userinfo_id": this.selectdata.model.f_userinfo_id,
752
+ // "f_service_person": Vue.user.name,
753
+ // "f_operat_type": "其他收费",
754
+ // "f_describe": "",
755
+ // "f_state": "有效",
756
+ // "f_operator": Vue.user.name,
757
+ // "f_operatorid": Vue.user.id,
758
+ // "f_orgid": Vue.user.orgid,
759
+ // "f_orgname": Vue.user.orgs,
760
+ // "f_depid": Vue.user.depids,
761
+ // "f_depname": Vue.user.f_department_name,
762
+ // "t_userfees": "",
763
+ // "f_fee_type": "其他费用",
764
+ // "f_fee_time": "12",
765
+ // "otherdetail": otherdetails
766
+ // }
767
+ // let res2 = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/af-telephone/rs/logic/sale_othercharge_logic`, {data: data2}, {
768
+ // resolveMsg: null,
769
+ // rejectMsg: '保存数据失败'
770
+ // })
771
+ // },
772
+ // async shoufei() {
773
+ // let http = new HttpResetClass()
774
+ // let data = {
775
+ // tablename: 't_material_service',
776
+ // condition: `f_process_id = '${this.selectdata.f_process_id}' and f_state = '未收费'`
777
+ // }
778
+ // let res = await http.load('post', this.$androidUtil.getProxyUrl() + '/af-telephone/rs/sql/tel_singleTable', {data: data}, {
779
+ // resolveMsg: null,
780
+ // rejectMsg: '获取数据失败'
781
+ // })
782
+ // if (res.data.length <= 0) {
783
+ // this.$showMessage('请先添加未收费的材料!!!')
784
+ // return
785
+ // }
786
+ // this.f_cost_sum = 0
787
+ // for (let i = 0; i < res.data.length; i++) {
788
+ // this.f_cost_sum += Number(res.data[i].f_fee)
789
+ // }
790
+ // this.showCharge = true
791
+ // this.charge.payment_terms[0].f_charge_money = this.f_cost_sum
792
+ // },
793
+ // accMul(arg1, arg2) {
794
+ // let m = 0, s1 = arg1.toString(), s2 = arg2.toString();
795
+ // try {
796
+ // m += s1.split(".")[1].length
797
+ // } catch (e) {
798
+ // }
799
+ // try {
800
+ // m += s2.split(".")[1].length
801
+ // } catch (e) {
802
+ // }
803
+ // return Number(s1.replace(".", "")) * Number(s2.replace(".", "")) / Math.pow(10, m)
804
+ // },
805
+ },
806
+ events: {},
807
+ computed: {
808
+ paymentMethod() {
809
+ return this.$appdata.getParam("付款方式")
810
+ },
811
+ paymentTerm() {
812
+ return this.$appdata.getParam("收费项目")
813
+ }
814
+ },
815
+ watch: {}
816
+ }
817
+ </script>
818
+ <style lang="less" scoped>
819
+ .head-but {
820
+ margin-left: 5px;
821
+ height: 34px;
822
+ /*background-color: #6aa6e2;*/
823
+ border-radius: 4px;
824
+ font-family: PingFang;
825
+ color: #ffffff;
826
+ }
827
+
828
+ /*清除model中的浮动*/
829
+ .clearfix:after, .clearfix:before {
830
+ display: table;
831
+ }
832
+
833
+ .clearfix:after {
834
+ clear: both;
835
+ }
836
+
837
+ .y-form {
838
+ display: flex;
839
+ flex-flow: column;
840
+ gap: 10px;
841
+ padding: 10px 5px;
842
+
843
+ .y-form-head {
844
+ background-color: #e8f4ff;
845
+ display: flex;
846
+ padding: 10px 20px;
847
+ align-items: center;
848
+ justify-content: space-between;
849
+ }
850
+
851
+ .y-form-item {
852
+ display: flex;
853
+ gap: 10px;
854
+
855
+ label {
856
+ width: 30%;
857
+ text-align: right;
858
+ }
859
+
860
+ .y-form-item-input {
861
+ width: 70%;
862
+ }
863
+ }
864
+ }
865
+ </style>