safecheck-client 4.0.1-4 → 4.0.1-41

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 (54) hide show
  1. package/package.json +5 -5
  2. package/src/assets//350/255/246/345/221/212 (3).png +0 -0
  3. package/src/assets//350/255/246/345/221/212 (4).png +0 -0
  4. package/src/assets//350/255/246/345/221/212 (5).png +0 -0
  5. package/src/components/android/SwitchValve.vue +1 -1
  6. package/src/components/checkplan/CheckDetail.vue +1 -1
  7. package/src/components/map/SecurityCheckCoordinates.vue +348 -0
  8. package/src/components/pc/CheckBookUser.vue +337 -333
  9. package/src/filiale/jinhong/android/CurrentCreate.vue +41 -2
  10. package/src/filiale/jinhong/pc/CheckBookList.vue +10 -7
  11. package/src/filiale/jinhong/pc/DefectPaperNew.vue +10 -10
  12. package/src/filiale/jinhong/pc/checkUserList.vue +31 -8
  13. package/src/filiale/libo/android/PaperFeedback.vue +1579 -0
  14. package/src/filiale/libo/android/PhoneUpUserinfo.vue +1249 -0
  15. package/src/filiale/libo/android/SafecheckOrderV.vue +2302 -0
  16. package/src/filiale/libo/android.js +14 -0
  17. package/src/filiale/libo/pc/NewCheckpaper.vue +1987 -0
  18. package/src/filiale/libo/pc.js +12 -0
  19. package/src/filiale/meihekou/android/MeterReading.vue +9 -5
  20. package/src/filiale/meihekou/android/PhoneUpUserinfo.vue +3 -2
  21. package/src/filiale/meihekou/android/SafecheckDevices.vue +5 -5
  22. package/src/filiale/meihekou/android/SafecheckOrderV.vue +323 -310
  23. package/src/filiale/meihekou/pc/NewCheckpaper.vue +2027 -2027
  24. package/src/filiale/meihekou/pc/NewCheckpaperNew.vue +2050 -0
  25. package/src/filiale/meihekou/pc/PaperList.vue +810 -0
  26. package/src/filiale/meihekou/pc.js +15 -13
  27. package/src/filiale/minsheng/android/SwitchValve.vue +1 -1
  28. package/src/filiale/qianneng/android/SwitchValve.vue +1 -1
  29. package/src/filiale/qingjian/pc/NewCheckpaper.vue +1 -0
  30. package/src/filiale/qingjian/pc/checkUserList.vue +35 -0
  31. package/src/filiale/taiyuan/android/CurrentCreate.vue +1016 -0
  32. package/src/filiale/taiyuan/android/PhoneUpUserinfo.vue +1259 -0
  33. package/src/filiale/taiyuan/android/SafecheckOrderV.vue +2341 -0
  34. package/src/filiale/taiyuan/android/SafecheckUserInfo.vue +776 -0
  35. package/src/filiale/taiyuan/android.js +13 -0
  36. package/src/filiale/taiyuan/pc/DefectDeal.vue +1033 -0
  37. package/src/filiale/taiyuan/pc/NewCheckpaper.vue +1976 -0
  38. package/src/filiale/taiyuan/pc/PlanManage.vue +891 -0
  39. package/src/filiale/taiyuan/pc/checkUserList.vue +798 -0
  40. package/src/filiale/taiyuan/pc.js +15 -0
  41. package/src/filiale/tongchuan/android/SwitchValve.vue +1 -1
  42. package/src/filiale/xinkang/android/AddPlanItem.vue +1 -1
  43. package/src/filiale/xinkang/android/SafecheckDevices.vue +29 -7
  44. package/src/filiale/xinkang/android/SafecheckOrderV.vue +21 -44
  45. package/src/filiale/xinkang/android/SafecheckUserInfo.vue +1 -1
  46. package/src/filiale/xinkang/pc/NewCheckpaper.vue +1474 -1498
  47. package/src/filiale/xinkang/pc/PaperList.vue +596 -603
  48. package/src/filiale/yuansheng/android/SwitchValve.vue +1 -1
  49. package/src/filiale/yunchengminsheng/android/PaperFeedback.vue +1030 -1030
  50. package/src/filiale/yunchengminsheng/android/SafecheckDevices.vue +4 -4
  51. package/src/filiale/yunchengminsheng/pc/PaperList.vue +811 -0
  52. package/src/filiale/yunchengminsheng/pc.js +1 -0
  53. package/src/safecheck-android.js +4 -0
  54. package/src/safecheck.js +3 -0
@@ -0,0 +1,2050 @@
1
+ <style scoped id="printStyle">
2
+ .img {
3
+ border: 1px solid #9773ed;
4
+ width: auto;
5
+ height: auto;
6
+ float: left;
7
+ text-align: center;
8
+ margin: 6px;
9
+ }
10
+
11
+ img {
12
+ margin: 6px;
13
+ }
14
+
15
+
16
+ .container {
17
+ margin: 10px auto;
18
+ width: 80%;
19
+ height: auto;
20
+ }
21
+
22
+ div::-webkit-scrollbar {
23
+ width: 8px !important;
24
+ height: 0 !important;
25
+ }
26
+
27
+ div {
28
+ -ms-overflow-style: none;
29
+ overflow: -moz-scrollbars-none;
30
+ }
31
+
32
+ .divmask {
33
+ pointer-events: none;
34
+ }
35
+
36
+ .app-header {
37
+ border-radius: 50%;
38
+ background: rgba(73, 158, 223, 0.4);
39
+ color: #FFF;
40
+ padding: 20px;
41
+ text-align: center;
42
+ font-size: 1.2em;
43
+ z-index: 10;
44
+ opacity: 0.5;
45
+ bottom: 50px;
46
+ margin-top: -20px;
47
+ position: absolute;
48
+ top: 10%;
49
+ right: 2%;
50
+ height: 8%;
51
+ }
52
+ </style>
53
+
54
+ <template>
55
+ <div class="basic-main" style="height: 100%">
56
+ <div class="page-header app-header auto" style="padding: 15px;margin-right: 10px;right: 0%;height: 7%">
57
+ <div @click="back()">
58
+ <img src="../../../assets/back.png" style="margin: 0px"/>
59
+ </div>
60
+ </div>
61
+ <div v-show="showPdfDownload" class="page-header app-header auto"
62
+ style="padding: 15px;margin-right: 3.7%;right: 0%;height: 7%">
63
+ <div @click="exportToPDF()">
64
+ <img src="../../../assets/下载_.png" style="margin: 0px;width: 30px"/>
65
+ </div>
66
+ </div>
67
+ <work-busy :is-busy="loading"></work-busy>
68
+ <div class="container-fluid" style="overflow: scroll">
69
+ <div class="row">
70
+ <div class="col-md-5" style="margin-right: 2%;margin-left: 2%;height: 100%;overflow: scroll">
71
+ <div style="width: 100%;margin: auto">
72
+ <table class="table table-striped table-bordered" style="margin-bottom: 6px;margin-top: 35px">
73
+ <thead>
74
+ <tr>
75
+ <th colspan="6" style="text-align: center">用户基本信息</th>
76
+ </tr>
77
+ </thead>
78
+ <tbody>
79
+ <tr>
80
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">用户编号:</td>
81
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_userinfo_code }}</td>
82
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">用户名称:</td>
83
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_user_name }}</td>
84
+ </tr>
85
+ <tr>
86
+ <td style="text-align: center;border: #E9E9E9 solid 1px">证件号码:</td>
87
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_idnumber }}</td>
88
+ <td style="text-align: center;border: #E9E9E9 solid 1px">用户类型:</td>
89
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_check_type }}</td>
90
+ </tr>
91
+ <tr>
92
+ <td style="text-align: center;border: #E9E9E9 solid 1px">用户电话:</td>
93
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_user_phone }}</td>
94
+ <td style="text-align: center;border: #E9E9E9 solid 1px">区 / 县:</td>
95
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_slice_area }}</td>
96
+ </tr>
97
+ <tr>
98
+ <td style="text-align: center;border: #E9E9E9 solid 1px">街 道:</td>
99
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_street }}</td>
100
+ <td style="text-align: center;border: #E9E9E9 solid 1px">楼 号:</td>
101
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_building }}</td>
102
+ </tr>
103
+ <tr>
104
+ <td style="text-align: center;border: #E9E9E9 solid 1px">单 元:</td>
105
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_unit }}</td>
106
+ <td style="text-align: center;border: #E9E9E9 solid 1px">楼 层:</td>
107
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_floor }}</td>
108
+ </tr>
109
+ <tr>
110
+ <td style="text-align: center;border: #E9E9E9 solid 1px">门 牌 号 :</td>
111
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_room }}</td>
112
+ <td style="text-align: center;border: #E9E9E9 solid 1px">用户性质:</td>
113
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_userproperties }}</td>
114
+ </tr>
115
+ <tr>
116
+ <td style="text-align: center;border: #E9E9E9 solid 1px">备注信息:</td>
117
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_comments }}</td>
118
+ <td style="text-align: center;border: #E9E9E9 solid 1px">小区名称:</td>
119
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_residential_area }}</td>
120
+ </tr>
121
+ <tr>
122
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px">详细住址:</td>
123
+ <td colspan="3" style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_address }}</td>
124
+ </tr>
125
+ </tbody>
126
+ </table>
127
+ <table class="table table-striped table-bordered" style="margin-top: 40px">
128
+ <thead>
129
+ <tr>
130
+ <th colspan="6" style="text-align: center">设备信息</th>
131
+ </tr>
132
+ </thead>
133
+ <tbody>
134
+ <template v-for=" item in userdevice">
135
+ <tr >
136
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">设备名称:</td>
137
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_devices_type }}</td>
138
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">设备型号:</td>
139
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_brand }}</td>
140
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">生产日期:</td>
141
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_make_date }}</td>
142
+ </tr>
143
+ <tr >
144
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">到期时间:</td>
145
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_expire_date }}</td>
146
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">购买方式:</td>
147
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.WatchPurchase }}</td>
148
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">安装方式:</td>
149
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_install_type }}</td>
150
+ </tr>
151
+ </template>
152
+ </tbody>
153
+ </table>
154
+ <table class="table table-striped table-bordered" style="margin-top: 40px"
155
+ v-show="paperdata.f_entry_status=='入户'">
156
+ <thead>
157
+ <tr>
158
+ <th colspan="4" style="text-align: center">用户安检概况</th>
159
+ </tr>
160
+ </thead>
161
+ <tbody>
162
+ <tr>
163
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">到达时间:</td>
164
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_onsite_time }}</td>
165
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">离开时间:</td>
166
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_offsite_time }}</td>
167
+ </tr>
168
+ <tr>
169
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">入户状态:</td>
170
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_entry_status }}</td>
171
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">燃气使用:</td>
172
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_usegas }}</td>
173
+ </tr>
174
+ <tr>
175
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">用户满意度:</td>
176
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">{{
177
+ paperdata.f_client_evaluation
178
+ }}
179
+ </td>
180
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">安检结果:</td>
181
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;"
182
+ :style="{'color':ajresult=='有隐患'?'red':''}">{{ ajresult }}
183
+ </td>
184
+ </tr>
185
+ <tr>
186
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">备注:</td>
187
+ <td colspan="3"
188
+ style="text-align: center;border: #E9E9E9 solid 1px;word-wrap:break-word;word-break:break-all;width:87%">
189
+ {{ paperdata.f_repair_approved_note }}
190
+ </td>
191
+ </tr>
192
+ <tr>
193
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">隐患详情:</td>
194
+ <td colspan="3"
195
+ style="text-align: center;border: #E9E9E9 solid 1px;word-wrap:break-word;word-break:break-all;width:87%">
196
+ <span v-for="deviceCollect in deviceCollects">
197
+ <span class="li-font">
198
+ {{ deviceCollect.name }}:{{ deviceCollect.value }}&nbsp;&nbsp;&nbsp;
199
+ </span>
200
+ <br>
201
+ <span v-if="deviceCollect.value == '有隐患'">
202
+ <lable>
203
+ 隐患:
204
+ </lable>
205
+ <span v-for="val in deviceCollect.devices">
206
+ {{ val }}
207
+ </span><br>
208
+ </span>
209
+
210
+ </span>
211
+ </td>
212
+ </tr>
213
+
214
+ </tbody>
215
+ </table>
216
+ <table class="table table-striped table-bordered" style="margin-top: 40px"
217
+ v-show="paperdata.f_entry_status!='入户'">
218
+ <thead>
219
+ <tr>
220
+ <th colspan="4" style="text-align: center">用户安检概况</th>
221
+ </tr>
222
+ </thead>
223
+ <tbody>
224
+ <tr>
225
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">到达时间:</td>
226
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_onsite_time }}</td>
227
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">离开时间:</td>
228
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_offsite_time }}</td>
229
+ </tr>
230
+ <tr>
231
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">入户状态:</td>
232
+ <td colspan="2" style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">
233
+ {{ paperdata.f_entry_status }}
234
+ </td>
235
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">
236
+ <button-link style="color: black" type="button" class="btn btn-link" @click="showpicture2()">
237
+ {{ dev.itemname }}
238
+ 查看{{ data.f_entry_status }}照片
239
+ </button-link>
240
+ </td>
241
+ </tr>
242
+
243
+ </tbody>
244
+ </table>
245
+ <table class="table table-striped table-bordered" style="margin-top: 40px"
246
+ v-show="item.f_no_checkplan == '复检'">
247
+ <thead>
248
+ <tr>
249
+ <th colspan="4" style="text-align: center">上次安检情况</th>
250
+ </tr>
251
+ </thead>
252
+ <tbody>
253
+ <tr>
254
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">上次安检到达时间:</td>
255
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{
256
+ lastCheckData.f_onsite_time
257
+ }}
258
+ </td>
259
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">上次安检离开时间:</td>
260
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{
261
+ lastCheckData.f_offsite_time
262
+ }}
263
+ </td>
264
+ </tr>
265
+ <tr>
266
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">上次安检员:</td>
267
+ <td colspan="3" style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">
268
+ {{ lastCheckData.f_checker_name }}
269
+ </td>
270
+ </tr>
271
+ <tr>
272
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">安检结果:</td>
273
+ <td colspan="3" style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">
274
+ {{ lastCheckData.f_defect_text }}
275
+ </td>
276
+ </tr>
277
+
278
+ </tbody>
279
+ </table>
280
+ <table class="table table-striped table-bordered" style="margin-top: 35px"
281
+ v-show="paperdata.f_entry_status=='入户' && paperdata.f_usegas == '未用气'">
282
+ <thead>
283
+ <tr>
284
+ <th style="text-align: center">未用气照片</th>
285
+ </tr>
286
+ </thead>
287
+ <tbody>
288
+ <tr>
289
+ <td style="margin: auto;text-align: center">
290
+ <div class="container" style="max-width: 550px;background: #FFFFFF">
291
+ <div class="img">
292
+ <img-self-plus :src="paperdata.f_nongasuser_path" style="float: left" width="150"
293
+ height="200"></img-self-plus>
294
+ </div>
295
+ </div>
296
+ </td>
297
+ </tr>
298
+ </tbody>
299
+ </table>
300
+ <table class="table table-striped table-bordered" style="margin-top: 35px"
301
+ v-show="showPdfImg && paperdata.f_entry_status=='入户' && ajresult=='有隐患'">
302
+ <thead>
303
+ <tr>
304
+ <th style="text-align: center">隐患照片</th>
305
+ </tr>
306
+ </thead>
307
+ <tbody>
308
+ <tr>
309
+ <td style="margin: auto;text-align: center">
310
+ <div class="container" style="max-width: 550px;background: #FFFFFF">
311
+ <div class="img" v-for="img in deviceImgs">
312
+ <img-self-plus :list="deviceCollect.imgs " :src="img.f_overall_path" style="float: left"
313
+ width="150"
314
+ height="200"></img-self-plus>
315
+ </div>
316
+ </div>
317
+
318
+
319
+ </td>
320
+
321
+ </tr>
322
+ </tbody>
323
+ </table>
324
+ <table class="table table-striped table-bordered" style="margin-top: 35px"
325
+ v-show="paperdata.f_entry_status=='入户'">
326
+ <thead>
327
+ <tr>
328
+ <th style="text-align: center">总体安检照片</th>
329
+ </tr>
330
+ </thead>
331
+ <tbody>
332
+ <tr>
333
+ <td style="margin: auto;text-align: center">
334
+ <div class="container" style="max-width: 550px;background: #FFFFFF">
335
+ <div class="img" v-for="img in paperdata.f_overall_imgs">
336
+ <img-self-plus :list="paperdata.f_overall_imgs " :src="img.f_overall_path" style="float: left"
337
+ width="150"
338
+ height="200"></img-self-plus>
339
+ </div>
340
+ </div>
341
+
342
+
343
+ </td>
344
+
345
+ </tr>
346
+ </tbody>
347
+ </table>
348
+ <table class="table table-striped table-bordered" style="width: 100%"
349
+ v-show="paperdata.f_entry_status=='入户' && (paperdata.f_sign_path || f_user_path) ">
350
+ <thead>
351
+ <tr>
352
+ <th style="text-align: center">用户签名照片</th>
353
+ </tr>
354
+ </thead>
355
+ <tbody>
356
+ <tr>
357
+ <td style="margin: auto;text-align: center" v-if="paperdata.f_sign_path">
358
+ <div class="container" style="max-width: 500px;background: #FFFFFF" >
359
+ <div class="img" style="float: none">
360
+ <img-self-plus :src="paperdata.f_sign_path" width="200" height="200"></img-self-plus>
361
+ </div>
362
+ </div>
363
+ </td>
364
+ <td style="margin: auto;text-align: center" v-if="f_user_path">
365
+ <div class="container" style="max-width: 550px;background: #FFFFFF" >
366
+ <div class="img" style="float: none">
367
+ <img-self-plus :src="'rs/image/file/'+f_user_path"
368
+ width="200"
369
+ height="200"></img-self-plus>
370
+ </div>
371
+ </div>
372
+ </td>
373
+ </tr>
374
+ </tbody>
375
+ </table>
376
+ <table class="table table-striped table-bordered"
377
+ v-show="paperdata.f_entry_status=='入户' && paperdata.f_defect_notified">
378
+ <thead>
379
+ <tr>
380
+ <th style="text-align: center">安检通知书/隐患整改通知书</th>
381
+ </tr>
382
+ </thead>
383
+ <tbody>
384
+ <tr>
385
+ <td style="margin: auto;text-align: center">
386
+ <div class="container" style="max-width: 500px;background: #FFFFFF">
387
+ <div class="img" style="float: none">
388
+ <img-self-plus :src="paperdata.f_notified_path" width="486" height="300"></img-self-plus>
389
+ </div>
390
+ </div>
391
+ </td>
392
+ </tr>
393
+ </tbody>
394
+ </table>
395
+ <table class="table table-striped table-bordered"
396
+ v-show="paperdata.f_entry_status=='入户'&& paperdata.f_video_path">
397
+ <thead>
398
+ <tr>
399
+ <th style="text-align: center">安检视频</th>
400
+ </tr>
401
+ </thead>
402
+ <tbody>
403
+ <tr>
404
+ <td style="margin: auto;text-align: center">
405
+ <div class="container" style="max-width: 500px;background: #FFFFFF">
406
+ <video width="320" height="200" controls v-if="paperdata.f_video_path">
407
+ <source :src="paperdata.f_video_path" type="video/mp4">
408
+ </video>
409
+ </div>
410
+ </td>
411
+ </tr>
412
+ </tbody>
413
+ </table>
414
+ <table class="table table-striped table-bordered"
415
+ v-show="item.f_recording1_path">
416
+ <thead>
417
+ <tr>
418
+ <th style="text-align: center">录音文件</th>
419
+ </tr>
420
+ </thead>
421
+ <tbody>
422
+ <tr>
423
+ <td style="margin: auto;text-align: center">
424
+ <div class="container" style="max-width: 500px;background: #FFFFFF">
425
+ <a class="button_spacing button_search-1"
426
+ :download="item.f_user_name+'-'+item.f_check_type+'-'+'录音文件.arm'"
427
+ :href="'rs/image/file/'+item.f_recording1_path">录音下载</a>
428
+ </div>
429
+ </td>
430
+ </tr>
431
+ </tbody>
432
+ </table>
433
+ </div>
434
+ </div>
435
+ <div class style="width: 1%;height: 100%;background-color: #F1F8FF;float: left;"></div>
436
+ <div class="col-md-6" style="height: 100%;overflow: scroll">
437
+ <div style="width: 95%;margin-left: 5%">
438
+ <table class="table table-striped table-bordered" v-for="config in deviceconfig2" style="margin-top: 35px">
439
+ <thead v-show="!(config.itemname!='燃气表'&&paperdata.f_entry_status!='入户')">
440
+ <tr>
441
+ <th style="text-align: center">{{ config.itemname }}</th>
442
+ </tr>
443
+ </thead>
444
+ <tbody v-show="!(config.itemname!='燃气表'&&paperdata.f_entry_status!='入户')">
445
+ <tr v-for="dev in config.items">
446
+ <td v-if="dev.type!='text' && dev.isshow != false">
447
+ <div class="row">
448
+ <div class="col-md-8" style="text-align: center;">
449
+ <label>
450
+ <button-link type="button" class="btn btn-link" @click="showpicture(config.itemname,dev.itemname)"
451
+ :style="isred(config.itemname,dev.itemname)?'color:red':'color:black'">
452
+ {{ dev.itemname }}
453
+ </button-link>
454
+ </label>
455
+ </div>
456
+ <div class="col-md-4" style="text-align: center">
457
+ <label style="font-weight: normal"
458
+ v-if="dev.type!='picture'">{{
459
+ getDeviceValue(config.itemname, dev.itemname) ? getDeviceValue(config.itemname, dev.itemname) : '无'
460
+ }}</label>
461
+ <label style="font-weight: normal" v-if="dev.type=='picture'">
462
+ <div v-show="getDevicePath(config.itemname,dev.itemname)">
463
+ <button-link style="color: black" type="button" class="btn btn-link"
464
+ @click="showpath(getDevicePath(config.itemname,dev.itemname),dev.itemname)">查看照片
465
+ </button-link>
466
+ </div>
467
+ <div v-show="!getDevicePath(config.itemname,dev.itemname)">无照片</div>
468
+ </label>
469
+ </div>
470
+ </div>
471
+ </td>
472
+ <td v-if="dev.type==='text' && dev.isshow != false">
473
+ <label style="width: 100%;text-align: center">{{ dev.itemname }}</label>
474
+ </td>
475
+ </tr>
476
+ </tbody>
477
+ </table>
478
+ <div v-show="showButton">
479
+ <button class="button_spacing button_search" @click="auditSuccesss()">通过</button>
480
+ <button class="button_spacing button_search" @click="auditFail()">不通过</button>
481
+ </div>
482
+ </div>
483
+ </div>
484
+
485
+ </div>
486
+ </div>
487
+ <div v-show="false">
488
+ <div class="container-fluid" id="toPdf" style="overflow: scroll">
489
+ <div class="row">
490
+ <div style="margin-right: 2%;margin-left: 2%;height: 100%;overflow: scroll">
491
+ <div style="width: 100%;margin: auto">
492
+ <table class="table table-striped table-bordered" style="margin-bottom: 6px;margin-top: 35px">
493
+ <thead>
494
+ <tr>
495
+ <th colspan="6" style="text-align: center">用户基本信息</th>
496
+ </tr>
497
+ </thead>
498
+ <tbody>
499
+ <tr>
500
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">用户编号:</td>
501
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{
502
+ paperdata.f_userinfo_code
503
+ }}
504
+ </td>
505
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">用户名称:</td>
506
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_user_name }}</td>
507
+ </tr>
508
+ <tr>
509
+ <td style="text-align: center;border: #E9E9E9 solid 1px">证件号码:</td>
510
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_idnumber }}</td>
511
+ <td style="text-align: center;border: #E9E9E9 solid 1px">用户类型:</td>
512
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_check_type }}</td>
513
+ </tr>
514
+ <tr>
515
+ <td style="text-align: center;border: #E9E9E9 solid 1px">用户电话:</td>
516
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_user_phone }}</td>
517
+ <td style="text-align: center;border: #E9E9E9 solid 1px">区 / 县:</td>
518
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_slice_area }}</td>
519
+ </tr>
520
+ <tr>
521
+ <td style="text-align: center;border: #E9E9E9 solid 1px">街 道:</td>
522
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_street }}</td>
523
+ <td style="text-align: center;border: #E9E9E9 solid 1px">楼 号:</td>
524
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_building }}</td>
525
+ </tr>
526
+ <tr>
527
+ <td style="text-align: center;border: #E9E9E9 solid 1px">单 元:</td>
528
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_unit }}</td>
529
+ <td style="text-align: center;border: #E9E9E9 solid 1px">楼 层:</td>
530
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_floor }}</td>
531
+ </tr>
532
+ <tr>
533
+ <td style="text-align: center;border: #E9E9E9 solid 1px">门 牌 号 :</td>
534
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_room }}</td>
535
+ <td style="text-align: center;border: #E9E9E9 solid 1px">用户性质:</td>
536
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_userproperties }}</td>
537
+ </tr>
538
+ <tr>
539
+ <td style="text-align: center;border: #E9E9E9 solid 1px">备注信息:</td>
540
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_comments }}</td>
541
+ <td style="text-align: center;border: #E9E9E9 solid 1px">小区名称:</td>
542
+ <td style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_residential_area }}</td>
543
+ </tr>
544
+ <tr>
545
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px">详细住址:</td>
546
+ <td colspan="3" style="text-align: center;border: #E9E9E9 solid 1px">{{ paperdata.f_address }}</td>
547
+ </tr>
548
+ </tbody>
549
+ </table>
550
+ <table class="table table-striped table-bordered" style="margin-top: 40px">
551
+ <thead>
552
+ <tr>
553
+ <th colspan="6" style="text-align: center">设备信息</th>
554
+ </tr>
555
+ </thead>
556
+ <tbody>
557
+ <template v-for=" item in userdevice">
558
+ <tr >
559
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">设备名称:</td>
560
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_devices_type }}</td>
561
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">设备型号:</td>
562
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_brand }}</td>
563
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">生产日期:</td>
564
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_make_date }}</td>
565
+ </tr>
566
+ <tr >
567
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">到期时间:</td>
568
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_expire_date }}</td>
569
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">购买方式:</td>
570
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.WatchPurchase }}</td>
571
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">安装方式:</td>
572
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 15%">{{ item.f_install_type }}</td>
573
+ </tr>
574
+ </template>
575
+ </tbody>
576
+ </table>
577
+ <table class="table table-striped table-bordered" style="margin-top: 40px"
578
+ v-show="paperdata.f_entry_status=='入户'">
579
+ <thead>
580
+ <tr>
581
+ <th colspan="4" style="text-align: center">用户安检概况</th>
582
+ </tr>
583
+ </thead>
584
+ <tbody>
585
+ <tr>
586
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">到达时间:</td>
587
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_onsite_time }}</td>
588
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">离开时间:</td>
589
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{
590
+ paperdata.f_offsite_time
591
+ }}
592
+ </td>
593
+ </tr>
594
+ <tr>
595
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">入户状态:</td>
596
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{
597
+ paperdata.f_entry_status
598
+ }}
599
+ </td>
600
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">燃气使用:</td>
601
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_usegas }}</td>
602
+ </tr>
603
+ <tr>
604
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">用户满意度:</td>
605
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">{{
606
+ paperdata.f_client_evaluation
607
+ }}
608
+ </td>
609
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">安检结果:</td>
610
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;"
611
+ :style="{'color':ajresult=='有隐患'?'red':''}">{{ ajresult }}
612
+ </td>
613
+ </tr>
614
+ <tr>
615
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">备注:</td>
616
+ <td colspan="3"
617
+ style="text-align: center;border: #E9E9E9 solid 1px;word-wrap:break-word;word-break:break-all;width:87%">
618
+ {{ paperdata.f_repair_approved_note }}
619
+ </td>
620
+ </tr>
621
+ <tr>
622
+ <td colspan="1" style="text-align: center;border: #E9E9E9 solid 1px;">隐患详情:</td>
623
+ <td colspan="3"
624
+ style="text-align: center;border: #E9E9E9 solid 1px;word-wrap:break-word;word-break:break-all;width:87%">
625
+ <span v-for="deviceCollect in deviceCollects">
626
+ <span class="li-font">
627
+ {{ deviceCollect.name }}:{{ deviceCollect.value }}&nbsp;&nbsp;&nbsp;
628
+ </span>
629
+ <br>
630
+ <span v-if="deviceCollect.value == '有隐患'">
631
+ <lable>
632
+ 隐患:
633
+ </lable>
634
+ <span v-for="val in deviceCollect.devices">
635
+ {{ val }}
636
+ </span><br>
637
+ </span>
638
+
639
+ </span>
640
+ </td>
641
+ </tr>
642
+
643
+ </tbody>
644
+ </table>
645
+ <table class="table table-striped table-bordered" style="margin-top: 40px"
646
+ v-show="paperdata.f_entry_status!='入户'">
647
+ <thead>
648
+ <tr>
649
+ <th colspan="4" style="text-align: center">用户安检概况</th>
650
+ </tr>
651
+ </thead>
652
+ <tbody>
653
+ <tr>
654
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">到达时间:</td>
655
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{ paperdata.f_onsite_time }}</td>
656
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">离开时间:</td>
657
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{
658
+ paperdata.f_offsite_time
659
+ }}
660
+ </td>
661
+ </tr>
662
+ <tr>
663
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">入户状态:</td>
664
+ <td colspan="2" style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">
665
+ {{ paperdata.f_entry_status }}
666
+ </td>
667
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">
668
+ <button-link style="color: black" type="button" class="btn btn-link" @click="showpicture2()">
669
+ {{ dev.itemname }}
670
+ 查看{{ data.f_entry_status }}照片
671
+ </button-link>
672
+ </td>
673
+ </tr>
674
+
675
+ </tbody>
676
+ </table>
677
+ <table class="table table-striped table-bordered" style="margin-top: 40px"
678
+ v-show="item.f_no_checkplan == '复检'">
679
+ <thead>
680
+ <tr>
681
+ <th colspan="4" style="text-align: center">上次安检情况</th>
682
+ </tr>
683
+ </thead>
684
+ <tbody>
685
+ <tr>
686
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">上次安检到达时间:</td>
687
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{
688
+ lastCheckData.f_onsite_time
689
+ }}
690
+ </td>
691
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">上次安检离开时间:</td>
692
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">{{
693
+ lastCheckData.f_offsite_time
694
+ }}
695
+ </td>
696
+ </tr>
697
+ <tr>
698
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">上次安检员:</td>
699
+ <td colspan="3" style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">
700
+ {{ lastCheckData.f_checker_name }}
701
+ </td>
702
+ </tr>
703
+ <tr>
704
+ <td style="text-align: center;border: #E9E9E9 solid 1px;width: 17%">安检结果:</td>
705
+ <td colspan="3" style="text-align: center;border: #E9E9E9 solid 1px;width: 33%">
706
+ {{ lastCheckData.f_defect_text }}
707
+ </td>
708
+ </tr>
709
+
710
+ </tbody>
711
+ </table>
712
+ <table class="table table-striped table-bordered" style="margin-top: 35px"
713
+ v-show="showPdfImg && paperdata.f_entry_status=='入户' && ajresult=='有隐患'">
714
+ <thead>
715
+ <tr>
716
+ <th style="text-align: center">隐患照片</th>
717
+ </tr>
718
+ </thead>
719
+ <tbody>
720
+ <tr>
721
+ <td style="margin: auto;text-align: center">
722
+ <div class="container" style="max-width: 550px;background: #FFFFFF">
723
+ <div class="img" v-for="img in deviceImgs">
724
+ <img-self-plus :list="deviceCollect.imgs " :src="img.f_overall_path" style="float: left"
725
+ width="150"
726
+ height="200"></img-self-plus>
727
+ </div>
728
+ </div>
729
+
730
+
731
+ </td>
732
+
733
+ </tr>
734
+ </tbody>
735
+ </table>
736
+ <table class="table table-striped table-bordered" style="margin-top: 35px"
737
+ v-show="paperdata.f_entry_status=='入户'">
738
+ <thead>
739
+ <tr>
740
+ <th style="text-align: center">总体安检照片</th>
741
+ </tr>
742
+ </thead>
743
+ <tbody>
744
+ <tr>
745
+ <td style="margin: auto;text-align: center">
746
+ <div class="container" style="max-width: 550px;background: #FFFFFF">
747
+ <div class="img" v-for="img in paperdata.f_overall_imgs">
748
+ <img-self-plus :list="paperdata.f_overall_imgs " :src="img.f_overall_path" style="float: left"
749
+ width="150"
750
+ height="200"></img-self-plus>
751
+ </div>
752
+ </div>
753
+
754
+
755
+ </td>
756
+
757
+ </tr>
758
+ </tbody>
759
+ </table>
760
+ <table class="table table-striped table-bordered" style="width: 100%"
761
+ v-show="paperdata.f_entry_status=='入户'">
762
+ <thead>
763
+ <tr>
764
+ <th style="text-align: center">用户签名照片</th>
765
+ </tr>
766
+ </thead>
767
+ <tbody>
768
+ <tr>
769
+ <td style="margin: auto;text-align: center">
770
+ <div class="container" style="max-width: 500px;background: #FFFFFF">
771
+ <div class="img" style="float: none">
772
+ <img-self-plus :src="paperdata.f_sign_path" width="200" height="200"></img-self-plus>
773
+ </div>
774
+ </div>
775
+ </td>
776
+ <td style="margin: auto;text-align: center">
777
+ <div class="container" style="max-width: 550px;background: #FFFFFF" v-if="f_user_path">
778
+ <div class="img" style="float: none">
779
+ <img-self-plus :src="'rs/image/file/'+f_user_path"
780
+ width="200"
781
+ height="200"></img-self-plus>
782
+ </div>
783
+ </div>
784
+ </td>
785
+ </tr>
786
+ </tbody>
787
+ </table>
788
+ <table class="table table-striped table-bordered"
789
+ v-show="paperdata.f_entry_status=='入户' && paperdata.f_defect_notified">
790
+ <thead>
791
+ <tr>
792
+ <th style="text-align: center">安检通知书/隐患整改通知书</th>
793
+ </tr>
794
+ </thead>
795
+ <tbody>
796
+ <tr>
797
+ <td style="margin: auto;text-align: center">
798
+ <div class="container" style="max-width: 500px;background: #FFFFFF">
799
+ <div class="img" style="float: none">
800
+ <img-self-plus :src="paperdata.f_notified_path" width="486" height="300"></img-self-plus>
801
+ </div>
802
+ </div>
803
+ </td>
804
+ </tr>
805
+ </tbody>
806
+ </table>
807
+ <table class="table table-striped table-bordered"
808
+ v-show="paperdata.f_entry_status=='入户'&& paperdata.f_video_path">
809
+ <thead>
810
+ <tr>
811
+ <th style="text-align: center">安检视频</th>
812
+ </tr>
813
+ </thead>
814
+ <tbody>
815
+ <tr>
816
+ <td style="margin: auto;text-align: center">
817
+ <div class="container" style="max-width: 500px;background: #FFFFFF">
818
+ <video width="320" height="200" controls v-if="paperdata.f_video_path">
819
+ <source :src="paperdata.f_video_path" type="video/mp4">
820
+ </video>
821
+ </div>
822
+ </td>
823
+ </tr>
824
+ </tbody>
825
+ </table>
826
+ <table class="table table-striped table-bordered"
827
+ v-show="item.f_recording1_path">
828
+ <thead>
829
+ <tr>
830
+ <th style="text-align: center">录音文件</th>
831
+ </tr>
832
+ </thead>
833
+ <tbody>
834
+ <tr>
835
+ <td style="margin: auto;text-align: center">
836
+ <div class="container" style="max-width: 500px;background: #FFFFFF">
837
+ <a class="button_spacing button_search-1"
838
+ :download="item.f_user_name+'-'+item.f_check_type+'-'+'录音文件.arm'"
839
+ :href="'rs/image/file/'+item.f_recording1_path">录音下载</a>
840
+ </div>
841
+ </td>
842
+ </tr>
843
+ </tbody>
844
+ </table>
845
+ </div>
846
+ </div>
847
+ <div style="margin-right: 2%;margin-left: 2%;height: 100%;overflow: scroll">
848
+ <div style="width: 95%;margin-left: 5%">
849
+ <table class="table table-striped table-bordered" v-for="config in deviceconfig2"
850
+ style="margin-top: 35px">
851
+ <thead v-show="!(config.itemname!='燃气表'&&paperdata.f_entry_status!='入户')">
852
+ <tr>
853
+ <th style="text-align: center">{{ config.itemname }}</th>
854
+ </tr>
855
+ </thead>
856
+ <tbody v-show="!(config.itemname!='燃气表'&&paperdata.f_entry_status!='入户')">
857
+ <tr v-for="dev in config.items">
858
+ <td v-if="dev.type!='text' && dev.isshow != false">
859
+ <div class="row">
860
+ <div class="col-md-8" style="text-align: center;">
861
+ <label>
862
+ <button-link type="button" class="btn btn-link"
863
+ @click="showpicture(config.itemname,dev.itemname)"
864
+ :style="isred(config.itemname,dev.itemname)?'color:red':'color:black'">
865
+ {{ dev.itemname }}
866
+ </button-link>
867
+ </label>
868
+ </div>
869
+ <div class="col-md-4" style="text-align: center">
870
+ <label style="font-weight: normal"
871
+ v-if="dev.type!='picture'">{{
872
+ getDeviceValue(config.itemname, dev.itemname) ? getDeviceValue(config.itemname, dev.itemname) : '无'
873
+ }}</label>
874
+ <label style="font-weight: normal" v-if="dev.type=='picture'">
875
+ <div v-show="getDevicePath(config.itemname,dev.itemname)">
876
+ <button-link style="color: black" type="button" class="btn btn-link"
877
+ @click="showpath(getDevicePath(config.itemname,dev.itemname),dev.itemname)">查看照片
878
+ </button-link>
879
+ </div>
880
+ <div v-show="!getDevicePath(config.itemname,dev.itemname)">无照片</div>
881
+ </label>
882
+ </div>
883
+ </div>
884
+ </td>
885
+ <td v-if="dev.type==='text' && dev.isshow != false">
886
+ <label style="width: 100%;text-align: center">{{ dev.itemname }}</label>
887
+ </td>
888
+ </tr>
889
+ </tbody>
890
+ </table>
891
+ </div>
892
+ </div>
893
+
894
+ </div>
895
+ </div>
896
+ </div>
897
+ </div>
898
+ <modal :show.sync="imgshow" v-ref:modal backdrop="true">
899
+ <header slot="modal-header" class="modal-header">
900
+ {{ picturename }}
901
+ </header>
902
+ <article slot="modal-body" class="modal-body">
903
+ <div class="from-group">
904
+ <div class="row">
905
+ <div class="col-md-6">
906
+ <img-self-plus v-if="showimg1" :src="showimg1" width="240" height="300"></img-self-plus>
907
+ </div>
908
+ <div class="col-md-6">
909
+ <img-self-plus v-if="showimg2" :src="showimg2" width="240" height="300"></img-self-plus>
910
+ </div>
911
+ <div class="col-md-6" v-for="item in otherDarginShowImgs">
912
+ <img-self-plus v-if="item.path" :src="item.path" width="240" height="300"></img-self-plus>
913
+ </div>
914
+ </div>
915
+ </div>
916
+ </article>
917
+ <footer slot="modal-footer" class="modal-footer" v-show="false">
918
+ <button type="button" class="btn btn-success" @click='imgclose'>关闭</button>
919
+ </footer>
920
+ </modal>
921
+ <modal :show.sync="imgshow2" v-ref:modal backdrop="true">
922
+ <header slot="modal-header" class="modal-header">
923
+ {{ paperdata.f_entry_status }}照片
924
+ </header>
925
+ <article slot="modal-body" class="modal-body">
926
+ <div class="from-group">
927
+ <div class="row">
928
+ <div class="col-md-6">
929
+ <img-self-plus v-if="this.paperdata.f_entry_status=='到访不遇'&& this.paperdata.f_noanswer_path" :src="showimg3"
930
+ width="282"
931
+ height="400"></img-self-plus>
932
+ </div>
933
+ <div class="col-md-6">
934
+ <img-self-plus v-if="this.paperdata.f_entry_status=='到访不遇'&& this.paperdata.f_noanswer1_path"
935
+ :src="showimg5" width="282"
936
+ height="400"></img-self-plus>
937
+ </div>
938
+ <div class="col-md-6">
939
+ <img-self-plus v-if="this.paperdata.f_entry_status=='到访不遇'&& this.paperdata.f_noanswer2_path"
940
+ :src="showimg6" width="282"
941
+ height="400"></img-self-plus>
942
+ </div>
943
+ <div class="col-md-6">
944
+ <img-self-plus v-if="this.paperdata.f_entry_status=='拒检' && this.paperdata.f_rejectcheck_path"
945
+ :src="showimg4" width="282"
946
+ height="400"></img-self-plus>
947
+ </div>
948
+ <div class="col-md-6">
949
+ <img-self-plus v-if="this.paperdata.f_entry_status=='拒检' && this.paperdata.f_rejectcheck1_path"
950
+ :src="showimg7" width="282"
951
+ height="400"></img-self-plus>
952
+ </div>
953
+ <div class="col-md-6">
954
+ <img-self-plus v-if="this.paperdata.f_entry_status=='拒检' && this.paperdata.f_rejectcheck2_path"
955
+ :src="showimg8" width="282"
956
+ height="400"></img-self-plus>
957
+ </div>
958
+ </div>
959
+ </div>
960
+ </article>
961
+ <footer slot="modal-footer" class="modal-footer" v-show="false">
962
+ <button type="button" class="btn btn-success" @click='imgclose'>关闭</button>
963
+ </footer>
964
+ </modal>
965
+ <modal :show.sync="showModel" :width="'50%'" :backdrop="false">
966
+ <div slot="modal-header" class="modal-header">
967
+ <h4 class="modal-title">
968
+ 安检审核备注
969
+ </h4>
970
+ </div>
971
+ <div slot="modal-body" class="modal-body">
972
+ <div class="row">
973
+ <div class="form-group col-sm-4">
974
+ <label class="font_normal_body">审核备注:</label>
975
+ <textarea v-model="message"></textarea>
976
+ </div>
977
+ </div>
978
+ </div>
979
+ <div slot="modal-footer" class="modal-footer" style="text-align: center">
980
+ <button class="button_search" style="margin-right: 15px" @click="auditFailOK()">确定</button>
981
+ <button class="button_search" style="margin-right: 15px" @click="auditFailCancel()">取消</button>
982
+ </div>
983
+ </modal>
984
+ </template>
985
+
986
+ <script>
987
+ import html2pdf from 'html2pdf.js'
988
+ import ObjConfig from '../../../utils/GerJsonObjectConfig'
989
+ import RadioGroup from 'vue-client/src/vue-strap/src/radioGroup'
990
+ import Radio from 'vue-client/src/vue-strap/src/radioBtn'
991
+ import Vue from 'vue'
992
+ import * as Util from '../../Util'
993
+ import {jsonSort} from '../../../utils/LdapHelper'
994
+ import {HttpResetClass} from "vue-client";
995
+ let asyncReady = async function (self) {
996
+ // 获取配置信息
997
+ try {
998
+ let res = await new HttpResetClass().load('get','/api/af-safecheck/vue',null, {resolveMsg: null, rejectMsg: null})
999
+ self.delConfigKey(res.data)
1000
+ Vue.config.safecheck=res.data
1001
+ console.log('获取配置结果===', res.data)
1002
+ } catch (error) {
1003
+ // 忽略704,文件找不到异常R
1004
+ if (error.status !== 704) {
1005
+ throw error
1006
+ }
1007
+ }
1008
+ }
1009
+ export default {
1010
+ title: '安检单',
1011
+ props: ['f_plan_id', 'item', 'role','gotoitem'],
1012
+ data() {
1013
+ return {
1014
+ f_user_path:'',
1015
+ message: '',
1016
+ showButton: false,
1017
+ showModel: false,
1018
+ data: {
1019
+ f_devices: [],
1020
+ f_defect_content: ''
1021
+ },
1022
+ showPdfDownload: this.$appdata.getSingleValue('安检结果pdf下载') ? this.$appdata.getSingleValue('安检结果pdf下载') : false,
1023
+ showPdfImg: this.$appdata.getSingleValue('安检结果pdf展示隐患照片') ? this.$appdata.getSingleValue('安检结果pdf展示隐患照片') : false,
1024
+ lastCheckData: {},
1025
+ paperdata: {},
1026
+ picturename: '隐患照片',
1027
+ defectDevice: {},
1028
+ hasDevice: false,
1029
+ deviceCollect: {},
1030
+ deviceCollects: [],
1031
+ deviceImgs:[],
1032
+ isshow: false,
1033
+ ajresult: '',
1034
+ loading: true,
1035
+ imgshow: false,
1036
+ imgshow2: false,
1037
+ isUpload: false,
1038
+ livedispose: '',
1039
+ showimg1: '',
1040
+ showimg2: '',
1041
+ showimg3: '',
1042
+ showimg4: '',
1043
+ showimg5: '',
1044
+ showimg6: '',
1045
+ showimg7: '',
1046
+ showimg8: '',
1047
+ hiddenDangerImgNumber: 0, //配置项中隐患照片数
1048
+ otherDarginShowImgs: [],//其他隐患图片
1049
+ startClick: false, //开始安检按钮是否可点击
1050
+ isStrat: false, //是否开始安检
1051
+ checkResult: {},//查询结果
1052
+ newcheckResult: {},
1053
+ timer: null,
1054
+ showModal: false,
1055
+ pic_to_be_viewed: '',
1056
+ showBack: true,
1057
+ devices: [],
1058
+ devicesAll: [],
1059
+ configAJ: [],
1060
+ configRQ: [],
1061
+ deviceconfig: {},
1062
+ newConfig: '',
1063
+ deviceconfig2: [],
1064
+ f_devices: [],
1065
+ config: [
1066
+ {
1067
+ "itemname": "燃气表",
1068
+ "checkmust": true,
1069
+ "index": 1,
1070
+ "items": [
1071
+ {"itemname": "基表编号", "index": 1, "type": "string", "readonly": true},
1072
+ {"itemname": "气表型号", "index": 2, "type": "string", "readonly": true},
1073
+ {"itemname": "气表品牌", "index": 3, "type": "string", "readonly": true},
1074
+ {"itemname": "表向", "index": 4, "type": "string", "readonly": true},
1075
+ {"itemname": "初始表底", "index": 5, "type": "number", "readonly": true},
1076
+ {"itemname": "上期表读数", "index": 6, "type": "number", "readonly": true},
1077
+
1078
+ {"itemname": "累购气量", "index": 7, "type": "number", "readonly": true,unique: true,collectionType:"按气量"},
1079
+ {"itemname": "已用气量", "index": 8, "type": "number", "checkmust": false,unique: true,collectionType:"按气量"},
1080
+ {"itemname": "剩余气量", "index": 9, "type": "number", "checkmust": false,unique: true,collectionType:"按气量"},
1081
+ {"itemname": "气量异常差值", "index": 10, "type": "number", "readonly": true,unique: true,collectionType:"按气量"},
1082
+
1083
+
1084
+ {"itemname": "累购金额", "index": 7, "type": "number", "readonly": true,unique: true,collectionType:"按金额"},
1085
+ {"itemname": "已用金额", "index": 8, "type": "number", "checkmust": false,unique: true,collectionType:"按金额"},
1086
+ {"itemname": "剩余金额", "index": 9, "type": "number", "checkmust": false,unique: true,collectionType:"按金额"},
1087
+ {"itemname": "金额异常差值", "index": 10, "type": "number", "readonly": true,unique: true,collectionType:"按金额"},
1088
+
1089
+ {"itemname": "系统余额", "index": 10, "type": "number", "readonly": true},
1090
+
1091
+ {"itemname": "表封号", "index": 11, "type": "string", "readonly": true},
1092
+ {"itemname": "燃气表照片", "index": 12, "type": "picture", "checkmust": false}
1093
+ ]
1094
+ }
1095
+ ],
1096
+ //金额
1097
+ config2: [
1098
+ {
1099
+ "itemname": "燃气表",
1100
+ "checkmust": true,
1101
+ "index": 1,
1102
+ "items": [
1103
+ {"itemname": "基表编号", "index": 1, "type": "string", "readonly": true},
1104
+ {"itemname": "气表型号", "index": 2, "type": "string", "readonly": true},
1105
+ {"itemname": "气表品牌", "index": 3, "type": "string", "readonly": true},
1106
+ {"itemname": "表向", "index": 4, "type": "string", "readonly": true},
1107
+ {"itemname": "初始表底", "index": 5, "type": "number", "readonly": true},
1108
+ {"itemname": "上期表读数", "index": 6, "type": "number", "readonly": true},
1109
+
1110
+ {"itemname": "累购气量", "index": 7, "type": "number", "readonly": true,unique: true,collectionType:"按气量"},
1111
+ {"itemname": "已用气量", "index": 8, "type": "number", "checkmust": false,unique: true,collectionType:"按气量"},
1112
+ {"itemname": "剩余气量", "index": 9, "type": "number", "checkmust": false,unique: true,collectionType:"按气量"},
1113
+ {"itemname": "气量异常差值", "index": 10, "type": "number", "readonly": true,unique: true,collectionType:"按气量"},
1114
+
1115
+
1116
+ {"itemname": "累购金额", "index": 7, "type": "number", "readonly": true,unique: true,collectionType:"按金额"},
1117
+ {"itemname": "已用金额", "index": 8, "type": "number", "checkmust": false,unique: true,collectionType:"按金额"},
1118
+ {"itemname": "剩余金额", "index": 9, "type": "number", "checkmust": false,unique: true,collectionType:"按金额"},
1119
+ {"itemname": "金额异常差值", "index": 10, "type": "number", "readonly": true,unique: true,collectionType:"按金额"},
1120
+
1121
+ {"itemname": "系统余额", "index": 10, "type": "number", "readonly": true},
1122
+
1123
+ {"itemname": "表封号", "index": 11, "type": "string", "readonly": true},
1124
+ {"itemname": "燃气表照片", "index": 12, "type": "picture", "checkmust": false}
1125
+ ]
1126
+ }
1127
+ ],
1128
+ userdevice:[]
1129
+ }
1130
+ },
1131
+ components: {
1132
+ RadioGroup,
1133
+ Radio,
1134
+ },
1135
+ computed: {
1136
+ isRecodrDownloadBtn() {
1137
+ // 投诉单下派还是处理
1138
+ let res = this.$appdata.getSingleValue('无限制录音');
1139
+ if (res == 'true') {
1140
+ return true;
1141
+ } else {
1142
+ return false;
1143
+ }
1144
+ },
1145
+ selector: {
1146
+ get() {
1147
+ return 'paper-state'
1148
+ },
1149
+ set(val) {
1150
+ if (this.isStrat) {
1151
+ this.$goto(val, {userinfo: this.data}, 'paper-router')
1152
+ } else {
1153
+ this.$showMessage('未开始安检!')
1154
+ }
1155
+ }
1156
+ },
1157
+ actionEnabled: {
1158
+ get() {
1159
+ return this.role == 'inspect'
1160
+ }
1161
+ }
1162
+ },
1163
+ methods: {
1164
+ getuserinfodevice(){
1165
+ new HttpResetClass().load('POST', `/af-telephone/rs/sql/tel_singleTable_OrderBy`, {
1166
+ data: {
1167
+ items: '*',
1168
+ tablename: 't_devices',
1169
+ condition: `f_userinfo_id = '${this.item.f_userinfoid}'`,
1170
+ orderitem: 'id'
1171
+ }
1172
+ }, {resolveMsg: null, rejectMsg:null}).then((res) => {
1173
+ this.userdevice = res.data
1174
+ })
1175
+ },
1176
+ delConfigKey(obj){
1177
+ // 从琉璃中获取的配置中会包含 $开头的一些额外描述新的key。为了兼容v3的代码逻辑在此函数中去掉
1178
+ Object.keys(obj).forEach(key =>{
1179
+ Object.keys(obj[key]).forEach(col => {
1180
+ // 检查键是否以$开头
1181
+ if (col.startsWith('$')) {
1182
+ // 使用delete操作符删除键
1183
+ delete obj[key][col];
1184
+ }
1185
+ })
1186
+ })
1187
+ },
1188
+ exportToPDF() {
1189
+ const element = document.getElementById('toPdf') // 替换为您要导出的页面元素的ID
1190
+ html2pdf(element)
1191
+ },
1192
+ showAudit() {
1193
+ var audit = this.$appdata.getSingleValue('安检审核');
1194
+ if (audit == '是' && (this.item.f_approved == '未审核' || !this.item.f_approved)) {
1195
+ this.showButton = true
1196
+ }
1197
+ },
1198
+ //安检审核成功
1199
+ auditSuccesss() {
1200
+ this.loading = true;
1201
+ var reqdata = {
1202
+ audit_result: '通过',
1203
+ operator: "success",
1204
+ audit_time: Util.getNowDate(),
1205
+ user_name: this.$login.f.name,
1206
+ id: this.item.id,
1207
+ f_check_item_id: this.item.f_check_item_id
1208
+ }
1209
+ new HttpResetClass().load('POST', '/api/af-safecheck/logic/updateAafeAudit', {data: reqdata}, {
1210
+ resolveMsg: '安检审核成功!',
1211
+ rejectMsg: '安检审核出错!'
1212
+ }).then((res) => {
1213
+ if (res.data.code == 200) {
1214
+ this.loading = false;
1215
+ this.$emit('showback')
1216
+ }
1217
+ })
1218
+ },
1219
+ auditFail() {
1220
+ this.showModel = true;
1221
+ },
1222
+ auditFailOK() {
1223
+
1224
+ this.loading = true;
1225
+ var reqdata = {
1226
+ message: this.message,
1227
+ audit_result: '不通过',
1228
+ operator: "fail",
1229
+ audit_time: Util.getNowDate(),
1230
+ user_name: this.$login.f.name,
1231
+ id: this.item.id,
1232
+ f_check_item_id: this.item.f_check_item_id
1233
+ }
1234
+ new HttpResetClass().load('POST', '/api/af-safecheck/logic/updateAafeAudit', {data: reqdata}, {
1235
+ resolveMsg: '安检审核成功!',
1236
+ rejectMsg: '安检审核出错!'
1237
+ }).then((res) => {
1238
+ if (res.data.code == 200) {
1239
+ this.loading = false;
1240
+ this.message = '';
1241
+ this.showModel = false;
1242
+ this.$emit('showback')
1243
+ }
1244
+ })
1245
+ },
1246
+ auditFailCancel() {
1247
+ this.showModel = false;
1248
+ this.message = '';
1249
+ },
1250
+
1251
+ devicesCollect() {
1252
+ //tag
1253
+ //tag)
1254
+ //tag)
1255
+ //tag
1256
+ this.deviceCollects = []
1257
+ this.deviceImgs = []
1258
+ let checkResult = '正常'
1259
+ this.result = '正常'
1260
+ let codata = JSON.parse(JSON.stringify(this.data))
1261
+ //tag)
1262
+ for (let device in this.data) {
1263
+ let f_device_type
1264
+ if (device.startsWith("device")) {
1265
+ for (let item in this.data[device]) {
1266
+ if (this.data[device].length > 1) {
1267
+ let j = Number.parseInt(item) + 1
1268
+ f_device_type = `${this.data[device][item].f_device_type}${j}`
1269
+ } else {
1270
+ f_device_type = this.data[device][item].f_device_type
1271
+ }
1272
+ // //tag
1273
+ let deviceelse = []
1274
+ let deviceInfos = []
1275
+
1276
+ for (let i in this.data[device][item].f_items) {
1277
+ let defects = ''
1278
+
1279
+ let items = this.data[device][item].f_items[i]
1280
+
1281
+
1282
+ if ((items.type === 'selector' || items.type === 'radio' || items.type === 'checkbox' || items.type === 'picture') && items.f_item_value != null && items.f_item_value instanceof Array) {
1283
+ for (let i in items.f_item_value) {
1284
+ let f_item_value = items.f_item_value[i]
1285
+
1286
+ //tag)
1287
+ //tag)
1288
+ //tag)
1289
+ //tag)
1290
+
1291
+ if (!this.checkConfigExists(this.data[device][item].f_device_type, items.f_item_name) && (items.isdefect && (items.isdefect=='true' || items.isdefect==true))) {
1292
+ continue
1293
+ }
1294
+ /*if(items.f_is_defect != true && items.f_is_defect != 'true'){
1295
+ continue
1296
+ }*/
1297
+ if (items.f_is_defect == 'true' || items.f_is_defect == true) {
1298
+ checkResult = '有隐患'
1299
+ this.result = '有隐患'
1300
+ defects = `${defects}:${f_item_value}/`
1301
+ }
1302
+ /*let options = this.config[this.data[device][item].f_device_type].items[items.f_item_name].options
1303
+ for (let option in options) {
1304
+ if (options[option].data == f_item_value) {
1305
+ if (options[option].isdefect == 'true' || options[option].isdefect == true) {
1306
+ checkResult = '有隐患'
1307
+ this.result = '有隐患'
1308
+ defects = `${defects}:${options[option].data}/`
1309
+ // let level = options[option].level
1310
+ }
1311
+ }
1312
+ }*/
1313
+ //tag)
1314
+ }
1315
+ if (defects != '') {
1316
+ console.log('有隐患items', items)
1317
+ deviceInfos.push(`${items.f_item_name}${defects.substring(0, defects.length - 1)}${items.f_else ? items.f_else : ''}`)
1318
+ this.deviceImgs.push({f_overall_path:items.f_path})
1319
+ }
1320
+ } else if ((items.type === 'string' || items.type === 'number') && items.f_is_defect && items.f_item_value[0]) {
1321
+ checkResult = '有隐患'
1322
+ this.result = '有隐患'
1323
+ deviceInfos.push(`${items.f_item_name}:${items.f_item_value[0]}`)
1324
+ this.deviceImgs.push({f_overall_path:items.f_path})
1325
+
1326
+ } else if (items.f_item_name == '金额异常差值') {
1327
+ var deviation = this.$appdata.getSingleValue('金额异常差值允许误差')
1328
+ //tag
1329
+ if (parseFloat(items.f_item_value[0]).toString() != "NaN" && parseFloat(deviation).toString() != "NaN") {
1330
+ if (parseFloat(items.f_item_value[0]) > parseFloat(deviation) || parseFloat(items.f_item_value[0]) < parseFloat(deviation) * -1) {
1331
+ checkResult = '有隐患'
1332
+ this.result = '有隐患'
1333
+ deviceInfos.push(`${items.f_item_name}:${items.f_item_value[0]}`)
1334
+ }
1335
+ }
1336
+ } else if (items.f_item_name == '气量异常差值') {
1337
+ var deviation = this.$appdata.getSingleValue('气量异常差值允许误差')
1338
+ //tag
1339
+ if (parseFloat(items.f_item_value[0]).toString() != "NaN" && parseFloat(deviation).toString() != "NaN") {
1340
+ if (parseFloat(items.f_item_value[0]) > parseFloat(deviation) || parseFloat(items.f_item_value[0]) < parseFloat(deviation) * -1) {
1341
+ checkResult = '有隐患'
1342
+ this.result = '有隐患'
1343
+ deviceInfos.push(`${items.f_item_name}:${items.f_item_value[0]}`)
1344
+ }
1345
+ }
1346
+ }
1347
+ // if(!this.config[this.data[device][item].f_device_type].items[items.f_item_name]){
1348
+ if(!this.checkConfigExists(this.data[device][item].f_device_type, items.f_item_name)){
1349
+ // console.log('this.config[this.data[device][item].f_device_type]', this.config[this.data[device][item].f_device_type])
1350
+ // console.log('this.deviceconfig2', this.deviceconfig2)
1351
+ for (let dev in this.deviceconfig2) {
1352
+ if(this.deviceconfig2[dev].itemname==this.data[device][item].f_device_type){
1353
+ this.deviceconfig2[dev].items.push({
1354
+ itemname: items.f_item_name
1355
+ })
1356
+ }
1357
+ }
1358
+ }
1359
+ //tag)
1360
+ //tag
1361
+ //tag
1362
+ if (items.type === 'selector') {
1363
+ items.selected = []
1364
+ } else if (items.type === 'inputSelector') {
1365
+ items.selected = ''
1366
+ }
1367
+ }
1368
+
1369
+
1370
+ //tag
1371
+ this.$set('deviceCollect.name', f_device_type)
1372
+ this.$set('deviceCollect.value', checkResult)
1373
+ this.$set('deviceCollect.devices', deviceInfos)
1374
+ this.$set('deviceCollect.else', deviceelse)
1375
+ console.log('deviceCollect.devices', this.deviceCollect.devices)
1376
+ console.log('deviceCollect.else', this.deviceCollect.else)
1377
+ console.log('deviceCollect.imgs', this.deviceCollect.imgs)
1378
+ //tag)
1379
+ if (this.deviceCollect.name) {
1380
+ //tag
1381
+ if(this.deviceCollect.value != '正常'){
1382
+ this.deviceCollects.push(JSON.parse(JSON.stringify(this.deviceCollect)))
1383
+ }
1384
+ }
1385
+
1386
+ checkResult = '正常'
1387
+ this.deviceCollect = {}
1388
+ }
1389
+ }
1390
+ }
1391
+ if (this.deviceCollects.length > 0) {
1392
+ this.hasDevice = true
1393
+ }
1394
+ this.deviceconfig2 = this.deviceconfig2.filter(row => {
1395
+ return !(row.itemname == '$configProp' || row.itemname == '$globalProp');
1396
+ })
1397
+ this.ajresult = JSON.parse(this.data.f_defect_content).result
1398
+ this.showimg3 = this.data.f_noanswer_path
1399
+ this.showimg5 = this.data.f_noanswer1_path
1400
+ this.showimg6 = this.data.f_noanswer2_path
1401
+ this.showimg4 = this.data.f_rejectcheck_path
1402
+ this.showimg7 = this.data.f_rejectcheck1_path
1403
+ this.showimg8 = this.data.f_rejectcheck2_path
1404
+ this.paperdata = this.data
1405
+ this.f_user_path = this.paperdata.f_user_pictures ? JSON.parse(this.paperdata.f_user_pictures)[0].f_user_path : ''
1406
+ this.loading = false
1407
+ },
1408
+ imgclose() {
1409
+ this.imgshow = false
1410
+ },
1411
+ async putDevices() {
1412
+ ////tag
1413
+ this.$set('data.approve', "true")
1414
+ this.$set('data.writeback', "false")
1415
+ if (Vue.config.safecheck.ApproveConfig != undefined) {
1416
+ if (Vue.config.safecheck.ApproveConfig.approve != undefined) {
1417
+ this.$set('data.approve', Vue.config.safecheck.ApproveConfig.approve)
1418
+ }
1419
+ if (Vue.config.safecheck.ApproveConfig.writeback != undefined) {
1420
+ this.$set('data.writeback', Vue.config.safecheck.ApproveConfig.writeback)
1421
+ }
1422
+ if (Vue.config.safecheck.ApproveConfig.livedispose != undefined) {
1423
+ this.livedispose = Vue.config.safecheck.ApproveConfig.livedispose
1424
+ }
1425
+ if (Vue.config.safecheck.ApproveConfig.hiddendanger != undefined) {
1426
+ if (parseInt(Vue.config.safecheck.ApproveConfig.hiddendanger) >= 5) {
1427
+ this.hiddenDangerImgNumber = 5
1428
+ } else {
1429
+ this.hiddenDangerImgNumber = parseInt(Vue.config.safecheck.ApproveConfig.hiddendanger)
1430
+ }
1431
+ }
1432
+ }
1433
+ //tag
1434
+ //tag)
1435
+ let res = await new HttpResetClass().http('POST', `/api/af-safecheck/logic/getSecurityCheckTypeHistoryById`,
1436
+ {data: {id: this.item.f_security_check_type_id}},
1437
+ {resolveMsg: null, rejectMsg: '网络异常'})
1438
+ let serverConfig = {}
1439
+ if (typeof res === 'object') {
1440
+ serverConfig = res
1441
+ } else {
1442
+ serverConfig = JSON.parse(res)
1443
+ }
1444
+ if (this.item.f_collection_type == '按气量'){
1445
+ this.config = this.extend(JSON.parse(serverConfig.data.f_json), this.config)
1446
+ }else {
1447
+ this.config = this.extend(JSON.parse(serverConfig.data.f_json), this.config2)
1448
+ }
1449
+ this.initConfig()
1450
+
1451
+ },
1452
+ checkConfigExists(itemname1, itemname2) {
1453
+ // 遍历 this.config 数组
1454
+ for (let i = 0; i < this.config.length; i++) {
1455
+ // 检查第一层 itemname 是否匹配 itemname1
1456
+ if (this.config[i].itemname === itemname1) {
1457
+ // 遍历第二层 items 数组
1458
+ for (let j = 0; j < this.config[i].items.length; j++) {
1459
+ // 检查第二层 itemname 是否匹配 itemname2
1460
+ if (this.config[i].items[j].itemname === itemname2) {
1461
+ // 如果找到匹配,返回 true
1462
+ return true;
1463
+ }
1464
+ }
1465
+ }
1466
+ }
1467
+ // 如果没有找到匹配项,返回 false
1468
+ return false;
1469
+ },
1470
+ initConfig() {
1471
+ for (let i in this.config) {
1472
+ //取得安检项索引值
1473
+ let n = parseInt(i) + 1
1474
+ //tag
1475
+ this.devices[n - 1] = {device: parseInt(i), n: n, checkmust: this.config[i].checkmust}
1476
+ this.$set('data.' + 'device' + n, [])
1477
+ let items = []
1478
+ for (let it in this.config[i].items) {
1479
+ //赋值下拉选项
1480
+ if (this.config[i].items[it].type == 'selector') {
1481
+ for (let op in this.config[i].items[it].options) {
1482
+ if (this.config[i].items[it].options[op].isdefault == true) {
1483
+ items.push({
1484
+ f_defect_level: this.config[i].items[it].level,
1485
+ f_is_defect: this.config[i].items[it].options[op].isdefect,
1486
+ f_item_name: this.config[i].items[it].itemname,
1487
+ f_item_value: this.config[i].items[it].options[op].data,
1488
+ f_path: "",
1489
+ type: "selector"
1490
+ })
1491
+ }
1492
+ }
1493
+ }
1494
+ }
1495
+ n = n + 1
1496
+ }
1497
+ },
1498
+ showpath(val1, val2) {
1499
+ //tag
1500
+ //tag
1501
+ if (val1) {
1502
+ this.showimg1 = val1
1503
+ this.picturename = val2
1504
+ this.imgshow = true
1505
+ }
1506
+ },
1507
+ showpicture(val1, val2) {
1508
+ //tag
1509
+ if (val2 == '气量异常差值' || val2 == '金额异常差值') {
1510
+ return
1511
+ }
1512
+ for (let i = 0; i < this.devicesAll.length; i++) {
1513
+ for (let j = 0; j < this.devicesAll[i].length; j++) {
1514
+ if (this.devicesAll[i][j].f_device_type == val1) {
1515
+ for (let k = 0; k < this.devicesAll[i][j].f_items.length; k++) {
1516
+ if (this.devicesAll[i][j].f_items[k].f_item_name == val2) {
1517
+ if (!this.devicesAll[i][j].f_items[k].f_is_defect) {
1518
+ return false
1519
+ } else {
1520
+ this.showimg1 = this.devicesAll[i][j].f_items[k].f_path
1521
+ this.showimg2 = this.devicesAll[i][j].f_items[k].f_second_path
1522
+ this.otherDarginShowImgs = []
1523
+ for (let l = 0; l < this.hiddenDangerImgNumber; l++) {
1524
+ let img = {path: ''}
1525
+ if (this.devicesAll[i][j].f_items[k]['f_p' + (l + 1) + '_path']) {
1526
+ img.path = this.devicesAll[i][j].f_items[k]['f_p' + (l + 1) + '_path'] + '?' + Math.random()
1527
+ this.otherDarginShowImgs.push(img)
1528
+ }
1529
+ }
1530
+ this.picturename = '隐患照片'
1531
+ this.imgshow = true
1532
+ return true
1533
+ }
1534
+ }
1535
+ }
1536
+
1537
+ }
1538
+ }
1539
+ }
1540
+ },
1541
+ isred(val1, val2) {
1542
+ //tag
1543
+ if (val2 == '气量异常差值' || val2 == '金额异常差值') {
1544
+ return
1545
+ }
1546
+ for (let i = 0; i < this.devicesAll.length; i++) {
1547
+ for (let j = 0; j < this.devicesAll[i].length; j++) {
1548
+ if (this.devicesAll[i][j].f_device_type == val1) {
1549
+ for (let k = 0; k < this.devicesAll[i][j].f_items.length; k++) {
1550
+ if (this.devicesAll[i][j].f_items[k].f_item_name == val2) {
1551
+ if (!this.devicesAll[i][j].f_items[k].f_is_defect) {
1552
+ return false
1553
+ } else {
1554
+ return true
1555
+ }
1556
+ }
1557
+ }
1558
+
1559
+ }
1560
+ }
1561
+ }
1562
+ },
1563
+ showpicture2() {
1564
+ this.imgshow2 = true
1565
+ },
1566
+ getDeviceValue(val1, val2) {
1567
+ for (let i = 0; i < this.devicesAll.length; i++) {
1568
+ for (let j = 0; j < this.devicesAll[i].length; j++) {
1569
+ if (this.devicesAll[i][j].f_device_type == val1) {
1570
+ for (let k = 0; k < this.devicesAll[i][j].f_items.length; k++) {
1571
+ if (this.devicesAll[i][j].f_items[k].f_item_name == val2) {
1572
+ if(this.devicesAll[i][j].f_items[k].f_item_value.length == 1 && this.devicesAll[i][j].f_items[k].f_item_value[0] == null)
1573
+ return '空'
1574
+ return this.devicesAll[i][j].f_items[k].f_item_value
1575
+ }
1576
+ }
1577
+ }
1578
+ }
1579
+ }
1580
+ },
1581
+ getDevicePath(val1, val2) {
1582
+ for (let i = 0; i < this.devicesAll.length; i++) {
1583
+ for (let j = 0; j < this.devicesAll[i].length; j++) {
1584
+ if (this.devicesAll[i][j].f_device_type == val1) {
1585
+ for (let k = 0; k < this.devicesAll[i][j].f_items.length; k++) {
1586
+ if (this.devicesAll[i][j].f_items[k].f_item_name == val2) {
1587
+ if (this.devicesAll[i][j].f_items[k].f_path || this.devicesAll[i][j].f_items[k].f_p1_path || this.devicesAll[i][j].f_items[k].f_p2_path){
1588
+ return [this.devicesAll[i][j].f_items[k].f_path, this.devicesAll[i][j].f_items[k].f_p1_path, this.devicesAll[i][j].f_items[k].f_p2_path]
1589
+ }else {
1590
+ return undefined
1591
+ }
1592
+ }
1593
+ }
1594
+
1595
+ }
1596
+ }
1597
+ }
1598
+
1599
+ },
1600
+ getDeviceAll() {
1601
+ let keyall = Object.keys(this.data)
1602
+ for (let i = 0; i < keyall.length; i++) {
1603
+ //tag)
1604
+ if ((keyall[i].startsWith('f_devices') || keyall[i].startsWith('devices')) && keyall[i] != 'deviceundefined') {
1605
+ this.devicesAll.push(this.data[keyall[i]])
1606
+ //tag
1607
+ }
1608
+ }
1609
+ //tag
1610
+ //tag)
1611
+ this.devicesCollect()
1612
+
1613
+ },
1614
+
1615
+ back() {
1616
+ if (this.role == 'inspect') {
1617
+ if (!this.isStrat) {
1618
+ this.$emit('showback')
1619
+ return
1620
+ } else {
1621
+ this.savePaper(true).then(() => {
1622
+ this.$emit('showback')
1623
+ this.isStrat = false
1624
+ })
1625
+ }
1626
+ } else {
1627
+ if(this.gotoitem){
1628
+ this.$back()
1629
+ return
1630
+ }
1631
+ this.$emit('showback')
1632
+ }
1633
+ },
1634
+ checkIsStart() {
1635
+ alert('asdad')
1636
+ return
1637
+ },
1638
+
1639
+ viewPic(fileName) {
1640
+ //tag
1641
+ if (this.role == 'view') {
1642
+ if (!fileName.endsWith('nopic.png')) {
1643
+ this.pic_to_be_viewed = fileName
1644
+ this.showModal = true
1645
+ }
1646
+ } else {
1647
+ HostApp.viewPic(fileName)
1648
+ }
1649
+ },
1650
+ tick() {
1651
+ this.timer = null
1652
+ this.data.f_offsite_time = Util.toStandardTimeString()
1653
+ this.timer = window.setTimeout(this.tick, 1000)
1654
+ },
1655
+ getRepairState() {
1656
+ let repaired = true
1657
+ this.data.f_defects.forEach((defect) => {
1658
+ repaired = repaired & (defect.f_ratification == '已处理')
1659
+ })
1660
+ return repaired
1661
+ },
1662
+ verifyRepairDefects() {
1663
+ this.data.f_repair_date = Util.toStandardTimeString()
1664
+ this.data.f_repaired = this.getRepairState() ? '已修' : '在修'
1665
+ },
1666
+ genuineSave(saveOnly) {
1667
+ HostApp.__this__.save(saveOnly)
1668
+ if (!saveOnly)
1669
+ HostApp.__this__.disableTimer()
1670
+ HostApp.__callback__ = null
1671
+ HostApp.__this__ = null
1672
+ },
1673
+ setUrgency() {
1674
+ this.data.f_defect_urgency = 'Z'
1675
+ let that = this
1676
+ this.data.f_defects.forEach(function (defect) {
1677
+ if (that.data.f_defect_urgency > defect.f_defect_level.charAt(0))
1678
+ that.data.f_defect_urgency = defect.f_defect_level.charAt(0)
1679
+ })
1680
+ if (this.data.f_defect_urgency == 'Z')
1681
+ this.data.f_defect_urgency = null
1682
+ },
1683
+ disableTimer() {
1684
+ if (this.timer) {
1685
+ window.clearTimeout(this.timer)
1686
+ this.timer = null
1687
+ }
1688
+ },
1689
+ loaded(paper) {
1690
+ if (!paper.hasOwnProperty('id')) {
1691
+ this.$showMessage("该安检单在手机上已经不存在,可能是卸载过程序。可以进入重新安检,或返回安检计划。")
1692
+ this.init()
1693
+ } else {
1694
+ Util.booleanFilter(paper)
1695
+ HostApp.__this__.$set('data', paper)
1696
+ HostApp.__this__.$goto('paper-state', {}, 'paper-router')
1697
+ // 如果打回重检则重新计时
1698
+ //tag
1699
+ if (HostApp.__this__.role == 'inspect'
1700
+ && HostApp.__this__.data.f_approved
1701
+ && HostApp.__this__.data.f_approved == '打回') {
1702
+ //tag
1703
+ HostApp.__this__.data.f_onsite_time = Util.toStandardTimeString()
1704
+ HostApp.__this__.tick()
1705
+ }
1706
+ }
1707
+ HostApp.__callback__ = null
1708
+ HostApp.__this__ = null
1709
+ },
1710
+ S4() {
1711
+ return (((1 + Math.random()) * 0x10000) | 0).toString(16).substring(1);
1712
+ },
1713
+ init() {
1714
+ this.data.f_noplan_item_id = this.S4() + "" + this.S4() + "" + this.S4() + "" + this.S4() + "" + this.S4() + "" + this.S4() + "" + this.S4() + "" + this.S4()
1715
+ this.data.ename = Vue.user.ename
1716
+ this.data.f_outlets = Vue.user.f_parentname
1717
+ this.data.f_meetunit = Vue.user.orgpathnames
1718
+ this.data.orgpathstr = Vue.user.orgpathstr
1719
+ this.data.f_check_item_id = this.item.id
1720
+ this.data.f_check_plan_id = this.f_plan_id
1721
+ this.data.f_checker_id = Vue.user.id
1722
+ this.data.f_checker_name = Vue.user.name
1723
+ this.data.f_check_type = this.item.f_user_type
1724
+ this.data.f_subcompany = this.item.f_subcompany
1725
+ this.data.f_approved = this.item.f_approved
1726
+ this.data.f_repair_approved = this.item.f_repair_approved
1727
+ this.data.f_no_checkplan = this.item.f_no_checkplan
1728
+ this.data.f_approved = this.item.f_approved
1729
+ this.data.f_filialeid = this.item.f_filialeid
1730
+ this.data.f_orgstr = this.item.f_orgstr
1731
+ this.data.version = this.item.version
1732
+ this.$set('data.f_meters', this.item.f_plan_meters)
1733
+ this.$set('data.f_userinfo_code', this.item.f_userinfo_code)
1734
+ // 安检状态
1735
+ this.$set('data.f_entry_status', '入户')
1736
+ this.$set('data.f_usegas', '已使用')
1737
+ this.$set('data.f_state', this.item.f_state)
1738
+ // 用户信息
1739
+ this.$set('data.f_user_name', this.item.f_user_name)
1740
+ this.$set('data.f_user_phone', this.item.f_user_phone)
1741
+ this.$set('data.f_userinfoid', this.item.f_userinfoid)
1742
+ this.$set('data.f_address', this.item.f_address)
1743
+ this.$set('data.f_card_id', this.item.f_card_id)
1744
+ this.$set('data.f_area', this.item.f_area)
1745
+ this.$set('data.f_street', this.item.f_street)
1746
+ this.$set('data.f_room', this.item.f_room)
1747
+ this.$set('data.f_building', this.item.f_building)
1748
+ this.$set('data.f_unit', this.item.f_unit)
1749
+ this.$set('data.f_floor', this.item.f_floor)
1750
+ this.$set('data.f_residential_area', this.item.f_residential_area)
1751
+ this.$set('data.f_idnumber', this.item.f_idnumber)
1752
+ this.$set('data.f_comments', this.item.f_comments)
1753
+ this.$set('data.f_userproperties', this.item.f_userproperties)
1754
+ // 处置方式
1755
+ this.$set('data.f_no_gas_device', false)
1756
+ this.$set('data.f_close_valve', false)
1757
+ this.$set('data.f_unload_battery', false)
1758
+ if (this.data.f_check_item_id == '' && this.item.f_no_checkplan == '无计划安检') {
1759
+ this.data.f_check_item_id = this.data.f_noplan_item_id
1760
+ }
1761
+
1762
+ //房屋结构
1763
+ // this.$set('data.f_room_style', '多层')
1764
+ //供暖方式
1765
+ // this.$set('data.f_heating_style', '热力公司集中供暖')
1766
+ if (this.item.f_plan_meters) {
1767
+ for (let de in this.devices) {
1768
+ this.$set('data.device' + this.devices[de].n, [])
1769
+ for (let i = 0; i < this.item.f_plan_meters.length; i++) {
1770
+ if (this.item.f_plan_meters[i].f_meter_type) {
1771
+ if (this.devices[de].device == "燃气表" && this.item.f_plan_meters[i].f_meter_type.indexOf('机表') > 0) {
1772
+ delete this.config['燃气表']['items']['累计购气量']
1773
+ this.data['device' + this.devices[de].n].push({
1774
+ f_device_type: "燃气表",
1775
+ f_items: [{
1776
+ f_defect_level: null,
1777
+ f_device_id: "",
1778
+ f_is_defect: "",
1779
+ f_item_name: "表品牌",
1780
+ f_item_value: this.item.f_plan_meters[i].f_aliasname,
1781
+ f_path: "",
1782
+ type: "string"
1783
+ },
1784
+ {
1785
+ f_defect_level: null,
1786
+ f_device_id: "",
1787
+ f_is_defect: "",
1788
+ f_item_name: "位置",
1789
+ f_item_value: this.item.f_plan_meters[i].f_weizhi,
1790
+ f_path: "",
1791
+ type: "selector"
1792
+ },
1793
+ {
1794
+ f_defect_level: null,
1795
+ f_device_id: "",
1796
+ f_is_defect: "",
1797
+ f_item_name: "表号",
1798
+ f_item_value: this.item.f_plan_meters[i].f_meter_no,
1799
+ f_path: "",
1800
+ type: "number"
1801
+ },
1802
+ {
1803
+ f_defect_level: null,
1804
+ f_device_id: "",
1805
+ f_is_defect: "",
1806
+ f_item_name: "表封号",
1807
+ f_item_value: this.item.f_plan_meters[i].f_metertitles,
1808
+ f_path: "",
1809
+ type: "number"
1810
+ },
1811
+ {
1812
+ f_defect_level: null,
1813
+ f_device_id: "",
1814
+ f_is_defect: "",
1815
+ f_item_name: "表型号",
1816
+ f_item_value: this.item.f_plan_meters[i].f_diaphgram_size,
1817
+ f_path: "",
1818
+ type: "selector"
1819
+ },
1820
+ {
1821
+ f_defect_level: null,
1822
+ f_device_id: "",
1823
+ f_is_defect: "",
1824
+ f_item_name: "表底数",
1825
+ f_item_value: this.item.f_plan_meters[i].f_prior_reading,
1826
+ f_path: "",
1827
+ type: "number"
1828
+ }
1829
+ ]
1830
+ })
1831
+ } else if (this.devices[de].device == "燃气表") {
1832
+ delete this.config['燃气表']['items']['表底数']
1833
+ this.data['device' + this.devices[de].n].push({
1834
+ f_device_type: "燃气表",
1835
+ f_items: [{
1836
+ f_defect_level: null,
1837
+ f_device_id: "",
1838
+ f_is_defect: "",
1839
+ f_item_name: "表品牌",
1840
+ f_item_value: this.item.f_plan_meters[i].f_aliasname,
1841
+ f_path: "",
1842
+ type: "string"
1843
+ },
1844
+ {
1845
+ f_defect_level: null,
1846
+ f_device_id: "",
1847
+ f_is_defect: "",
1848
+ f_item_name: "位置",
1849
+ f_item_value: this.item.f_plan_meters[i].f_weizhi,
1850
+ f_path: "",
1851
+ type: "selector"
1852
+ },
1853
+ {
1854
+ f_defect_level: null,
1855
+ f_device_id: "",
1856
+ f_is_defect: "",
1857
+ f_item_name: "表号",
1858
+ f_item_value: this.item.f_plan_meters[i].f_meter_no,
1859
+ f_path: "",
1860
+ type: "number"
1861
+ },
1862
+ {
1863
+ f_defect_level: null,
1864
+ f_device_id: "",
1865
+ f_is_defect: "",
1866
+ f_item_name: "表封号",
1867
+ f_item_value: this.item.f_plan_meters[i].f_metertitles,
1868
+ f_path: "",
1869
+ type: "number"
1870
+ },
1871
+ {
1872
+ f_defect_level: null,
1873
+ f_device_id: "",
1874
+ f_is_defect: "",
1875
+ f_item_name: "表型号",
1876
+ f_item_value: this.item.f_plan_meters[i].f_diaphgram_size,
1877
+ f_path: "",
1878
+ type: "selector"
1879
+ },
1880
+ {
1881
+ f_defect_level: null,
1882
+ f_device_id: "",
1883
+ f_is_defect: "",
1884
+ f_item_name: "累计购气量",
1885
+ f_item_value: this.item.f_plan_meters[i].f_prior_reading,
1886
+ f_path: "",
1887
+ type: "number"
1888
+ }
1889
+ ]
1890
+ })
1891
+ }
1892
+ }
1893
+ }
1894
+ }
1895
+ }
1896
+
1897
+ this.$goto('paper-state', {}, 'paper-router')
1898
+ },
1899
+ extend(initalObj, finalObj) {
1900
+ initalObj.forEach(item2 => {
1901
+ const item1 = finalObj.find(item => item.itemname === item2.itemname);
1902
+
1903
+ if (!item1) {
1904
+ finalObj.push(item2);
1905
+ } else {
1906
+ // 对 item2 的 items 进行逆序遍历
1907
+ item2.items.slice().forEach(subItem2 => {
1908
+ const subItem1Index = item1.items.findIndex(subItem => subItem.itemname === subItem2.itemname);
1909
+
1910
+ if (subItem1Index > -1) {
1911
+ // 如果找到匹配的 subItem1,用 subItem2 替换它
1912
+ item1.items[subItem1Index] = subItem2;
1913
+ } else {
1914
+ // 如果没有找到,将 subItem2 插入到 item1.items 的前面
1915
+ item1.items.push(subItem2);
1916
+ }
1917
+ });
1918
+ }
1919
+ });
1920
+
1921
+ return finalObj;
1922
+ },
1923
+ //获取当前时间
1924
+ getNowFormatDate() {
1925
+ var date = new Date();
1926
+ var seperator1 = "-";
1927
+ var seperator2 = ":";
1928
+ var month = date.getMonth() + 1;
1929
+ var strDate = date.getDate();
1930
+ if (month >= 1 && month <= 9) {
1931
+ month = "0" + month;
1932
+ }
1933
+ if (strDate >= 0 && strDate <= 9) {
1934
+ strDate = "0" + strDate;
1935
+ }
1936
+ var currentdate = date.getFullYear() + seperator1 + month + seperator1 + strDate
1937
+ + " " + date.getHours() + seperator2 + date.getMinutes()
1938
+ + seperator2 + date.getSeconds();
1939
+ return currentdate;
1940
+ }
1941
+ },
1942
+ async ready() {
1943
+ asyncReady(this).then( async () => {
1944
+ setTimeout(() => {
1945
+ this.loading = false;
1946
+ }, 10000)
1947
+ this.getuserinfodevice()
1948
+ await this.putDevices()
1949
+ this.showAudit()
1950
+ this.newConfig = this.$appdata.getSingleValue('配置中心获取文件') ? this.$appdata.getSingleValue('配置中心获取文件') : '否';
1951
+ if (this.item.f_state != '未检' || this.item.f_no_checkplan == '无计划安检' || this.item.f_no_checkplan == '复检') {
1952
+ if (this.role != 'inspect') {
1953
+ let that = this
1954
+ let id
1955
+ if (this.role == 'view') {
1956
+ id = this.item.id
1957
+ } else if (this.role == 'androidview') {
1958
+ id = this.item.f_paper_id
1959
+ }
1960
+ this.$resetpost(`api/af-safecheck/logic/path_getCheckPaper`, {data: {id:id}}).then((respanse) => {
1961
+ //tag
1962
+ if (respanse.data.length != 0) {
1963
+ // 包含 其它 特殊处理的数组
1964
+ // 对应位置
1965
+ that.data = Object.assign(that.data, respanse.data[0])
1966
+ if (respanse.data[0].f_devices) {
1967
+ for (let da in that.devices) {
1968
+ that.$set('data.device' + that.devices[da].n, [])
1969
+ }
1970
+ respanse.data[0].f_devices.forEach((item) => {
1971
+ for (let de in that.devices) {
1972
+ // if (that.devices[de].device == item.f_device_type) {
1973
+ if (this.config[that.devices[de].device].itemname == item.f_device_type) {
1974
+ console.log('item', item)
1975
+ item.f_items.forEach((f_item) => {
1976
+ console.log('f_item', f_item)
1977
+ //tag
1978
+ //tag
1979
+ let itemValues = []
1980
+ if(f_item.f_selected) {
1981
+ f_item.f_selected = JSON.parse(f_item.f_selected)
1982
+ f_item.f_selected.forEach((tempItem) => {
1983
+ itemValues.push(tempItem)
1984
+ })
1985
+ f_item.f_item_value = itemValues
1986
+ } else {
1987
+ itemValues.push(f_item.f_item_value)
1988
+ f_item.f_item_value = itemValues
1989
+ }
1990
+ })
1991
+ that.data['device' + that.devices[de].n].push({
1992
+ f_device_type: item.f_device_type,
1993
+ f_items: item.f_items
1994
+ })
1995
+ }
1996
+ }
1997
+ })
1998
+ }
1999
+ Util.replaceFalse(that.data)
2000
+ Util.booleanFilter(that.data)
2001
+ if (this.role == 'view') {
2002
+ Util.ratifyPics(that.data)
2003
+ Util.ratifyPics(that.picture)
2004
+ } else {
2005
+ Util.androidRatifyPics(that.data, this.$androidUtil.getProxyUrl())
2006
+ }
2007
+ }
2008
+ this.isshow = true
2009
+ this.deviceconfig = this.config
2010
+ this.deviceconfig2 = ObjConfig.getObjConfig(this.deviceconfig)
2011
+ this.deviceconfig2[0].items = jsonSort(this.deviceconfig2[0].items, "index")
2012
+ this.deviceconfig2[1].items = jsonSort(this.deviceconfig2[1].items, "index")
2013
+ this.deviceconfig2 = jsonSort(this.deviceconfig2, "index")
2014
+ this.getDeviceAll()
2015
+
2016
+ }
2017
+ ).catch(
2018
+ (respanse) => {
2019
+ //tag
2020
+ alert('查找安检单失败')
2021
+ this.loading = false
2022
+ })
2023
+ }
2024
+ }
2025
+ })
2026
+ },
2027
+ watch: {
2028
+ // 'isUpload'(val){
2029
+ // //tag
2030
+ // }
2031
+ },
2032
+ destroyed() {
2033
+ //tag
2034
+ this.disableTimer()
2035
+ }
2036
+ }
2037
+
2038
+ </script>
2039
+ <style scoped>
2040
+ .table-striped thead tr th {
2041
+ background-color: rgb(223, 237, 251);
2042
+ padding: 10px;
2043
+ border-left: solid 0px #dae4f2;
2044
+ border-top: solid 1px #dae4f2;
2045
+ border-right: none;
2046
+ border-bottom: none;
2047
+ text-align: center;
2048
+ color: black;
2049
+ }
2050
+ </style>