safecheck-client 4.0.2-19 → 4.0.2-20

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 (27) hide show
  1. package/package.json +1 -1
  2. package/src/components/NewDefectList/DefectPaperNew.vue +1184 -1184
  3. package/src/components/android/PhoneUpUserinfo.vue +1249 -1249
  4. package/src/components/android/SafeRightTree.vue +218 -218
  5. package/src/components/android/SafecheckDevices.vue +1340 -1340
  6. package/src/components/android/week/CheckResultSimple.vue +222 -0
  7. package/src/components/android/week/FirstWeekCheck.vue +236 -0
  8. package/src/components/android/week/StepHeaderBar.vue +323 -0
  9. package/src/components/android/week/WeekCheck.vue +151 -0
  10. package/src/components/android/week/WeekCheckPaper.vue +151 -0
  11. package/src/components/pc/CheckBook.vue +303 -303
  12. package/src/components/pc/CheckBookArea.vue +146 -146
  13. package/src/components/pc/CheckBookCompany.vue +144 -144
  14. package/src/components/pc/CheckBookDetails.vue +161 -161
  15. package/src/components/pc/CheckBookEntry.vue +60 -60
  16. package/src/components/pc/CheckBookSearchArea.vue +560 -560
  17. package/src/components/pc/CheckBookSearchUnit.vue +229 -229
  18. package/src/components/pc/CheckBookSearchUser.vue +659 -659
  19. package/src/components/pc/CheckBookSearchUserList.vue +674 -674
  20. package/src/filiale/meihekou/android/CheckPlanList.vue +198 -198
  21. package/src/filiale/meihekou/android/CheckPlanListArea.vue +190 -190
  22. package/src/filiale/meihekou/android/PaperFeedback.vue +1542 -1542
  23. package/src/filiale/meihekou/android/SafecheckDevices.vue +1343 -1343
  24. package/src/filiale/meihekou/android/SafecheckOrderV.vue +2447 -2447
  25. package/src/filiale/meihekou/android.js +22 -22
  26. package/src/filiale/meihekou/pc/NewCheckpaperNew.vue +2050 -2050
  27. package/src/safecheck-android.js +326 -316
@@ -1,1343 +1,1343 @@
1
- <template>
2
- <div class="select-overspread repair-bg auto" style="padding-bottom:5px;">
3
- <!--<div class="bq-parent" v-if="shutype == 'heng'">-->
4
- <!--<blockquote class="blockquote">-->
5
- <!--<p><span>{{repairitem.header}}</span><a @click="mute()" style="float:right" href="#" class="repair-mute-class"><img src="../../assets/novoice.png" width="25px;" alt=""><span style="margin-left:10px;color: #304A66">关闭声音</span></a></p>-->
6
- <!--</blockquote>-->
7
- <!--</div>-->
8
- <div class="panel panel-default auto repair-info-content">
9
- <div class="panel-body" style="padding: 0">
10
- <!-- 安检项内容 -->
11
- <div class="auto repair-info-content compatible" style="padding: 0">
12
- <div class="row auto" style="padding: 0">
13
- <div v-show="false" class="{{shuclass}}" v-if=" device.device != '燃气表'">
14
- <button type="button" name="button" class="btn btn-primary" @click='adddetails()' :disabled="issee">增加</button>
15
- </div>
16
- <!--<div class="{{shuclass}}" v-if="device.device != '燃气表' && candelete">-->
17
- <!--<button type="button" name="button" class="btn btn-primary" @click='deletedetails()' :disabled="issee">删除</button>-->
18
- <!--</div>-->
19
- <div class="shuclass1" v-show="row.isshow" v-for="(idxs,row) in f_items" style="padding: 4px; border:1px solid #D4D4D4;border-bottom: 0" >
20
- <label v-if="row.type != 'radio' && row.type != 'text' && row.type != 'picture' && row.type != 'checkbox'" v-show="row.isshow" class="fivelabel">{{row.f_item_name}}<span v-if="row.unit">({{row.unit}})</span><br/>{{row.remark}}</label>
21
- <label v-if="row.type == 'radio'" v-show="row.isshow" class="radiolabel">{{row.f_item_name}}<span v-if="row.unit">({{row.unit}})</span><br/>{{row.remark}}</label>
22
- <label v-if="row.type == 'text'" v-show="row.isshow" class="textlabel1">{{row.f_item_name}}<span v-if="row.unit">({{row.unit}})</span><br/>{{row.remark}}</label>
23
- <label v-if="row.type == 'picture' || row.type == 'checkbox'" v-show="row.isshow" class="textlabel">{{row.f_item_name}} <br/>{{row.remark}} <span v-show="row.verification_state" :style="{color:row.verification_state==='pass'?'green':'red'}">{{row.verification_text}}</span></label>
24
- <!--<span v-if="show" style="font-weight:bold">{{row.f_content}}</span>-->
25
- <!--<datepicker placeholder="请选择时间"-->
26
- <!--:value.sync="row.f_content"-->
27
- <!--v-model="row.f_content"-->
28
- <!--:format="'yyyy-MM-dd'"-->
29
- <!--v-if="!show && row.type == 'date'"-->
30
- <!--:readonly="true"-->
31
- <!--&gt;</datepicker>-->
32
- <div style="clear: both" v-if="row.type == 'picture'" class="form-group col-sm-12" >
33
- <div class="auto" >
34
- <div class="panel">
35
- <div class="panel-body panel-self" style="background-color: #F8F8F8;width: 160px;height: 160px;position: relative">
36
- <div class="row" style="height: 160px;width:160px;overflow: scroll;top: 1px">
37
- <div class="col-sm-4" v-show="row.f_path">
38
- <img-self-android :src="row.f_path" :alt="row.f_item_name" width="140" height="140"></img-self-android>
39
- </div>
40
- <div class="col-sm-4" v-show="!row.f_path" @click="takePic(idxs, row.f_item_name)">
41
- <img src="../../../assets/tackpic.png" :alt="点击拍摄照片" width="140" height="140"></img>
42
- </div>
43
- <img v-show="row.f_path" src="../../../assets/remove.png" :class="style__" @click="delfile(idxs, row.f_path)" v-if="role!='androidview'" style="width: 40px;height: 40px;position: absolute;left:110px;top:110px"></img>
44
- </div>
45
- </div>
46
- </div>
47
- </div>
48
- </div>
49
- <div style="float: left;width:60%" class="form-group" v-if="row.type == 'string'" v-show="row.isshow">
50
- <input type="text" class="form-control" maxlength="100" v-model="row.f_item_value" :readonly="role == 'androidview' || row.readonly">
51
- </div>
52
- <div style="float: left;width:60%" class="form-group col-sm-12" v-if="row.type == 'date'" v-show="row.isshow">
53
- <datepicker id="f_making_date" :placeholder= row.f_item_name
54
- :value.sync="row.f_item_value"
55
- v-if="row.type == 'date'"
56
- v-show="row.isshow"
57
- :disabled-days-of-Week="[]"
58
- :format="'yyyy-MM-dd HH:mm:ss'"
59
- :show-reset-button="reset" readonly="readonly">
60
- </datepicker>
61
- </div>
62
-
63
- <div style="float: left;width:60%" class="form-group" v-if="!show && row.type == 'number'" v-show="row.isshow">
64
- <input type="text" class="form-control" maxlength="100" v-model="row.f_item_value" onkeyup="value=value.replace(/[^\d\.-]/g,'')" :readonly="row.readonly">
65
- </div>
66
- <!--<input type="text" class="form-control" v-model="row.f_content" v-if="!show && row.type == 'string' && row.f_project != '表号'" :disabled="(!(ischecked == '有')) || issee" :readonly="issee">-->
67
- <!--<input type="text" class="form-control" v-model="meternum" v-if="!show && row.type == 'string' && row.f_project == '表号' " :disabled="(!(ischecked == '有')) || issee" :readonly="issee" >-->
68
- <!--<button type="button" name="button" class="btn btn-primary" @click="scan" v-if="!show && row.f_project == '表号' ">扫码</button>-->
69
- <input-select v-if="row.type == 'inputSelector'"
70
- v-show="row.isshow"
71
- :value.sync="row.selected"
72
- v-model="row.selected"
73
- :readonly="false"
74
- :options="row.options"
75
- @change="changse"
76
- @click="transelation(idxs)"></input-select>
77
- <v-select style="float: left" :value.sync="row.selected"
78
- v-model="row.selected"
79
- v-if="row.type == 'selector'"
80
- :search="false"
81
- v-show="row.isshow"
82
- placeholder='请选择'
83
- :options="row.options"
84
- :disabled="role == 'androidview' || row.readonly"
85
- @change="changse"
86
- @click="transelation(idxs)"
87
- :multiple="row.multiple"
88
- :close-on-select="!row.multiple" clear-button></v-select>
89
- <div style="float: left;width: 30%" class="form-group" v-if="!show && row.type == 'radio'">
90
- <div class="col-xs-6 col-sm-6 col-md-6" v-for="item in row.options">
91
- <!-- <input type="radio" :name="row.f_item_name" @click="disSelect($parent.idxs,item.value)" :value="item.value" :disabled="(!(ischecked == '有')) || issee" v-model="row.f_item_value" >-->
92
- <input type="radio" :name="row.f_item_name" :value="item.value" :disabled="(!(ischecked == '有')) || issee" v-model="row.f_item_value" >
93
- <span>{{item.label}}</span>
94
- </div>
95
- </div>
96
- <div v-if="!show && row.type == 'checkbox'" class="col-xs-12 col-sm-12 col-md-12" style="white-space: nowrap" >
97
- <div style="float: left" v-for="item in row.options">
98
- <input type="checkbox" :name="row.f_item_name" :value="item.value" :disabled="(!(ischecked == '有')) || issee" v-model="row.f_item_value">
99
- <span>{{item.label}}</span>
100
- </div>
101
- </div>
102
- <div style="clear: both">
103
- <label v-if="row.f_item_value.indexOf('其他') >-1" class="fivelabel">其他</label>
104
- <div style="float: left;width:60%" class="form-group" v-if="row.f_item_value.indexOf('其他') >-1">
105
- <input type="text" class="form-control" maxlength="100" v-model="row.f_else" :readonly="role == 'androidview' || row.readonly">
106
- </div>
107
- </div>
108
- <div style="clear: both">
109
- <!-- <div class="form-group" style="display: flex;flex-wrap: wrap" v-if="(row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && (row.f_path != '' || row.f_is_defect != '') && (livedispose == 'true' || livedispose == true) " >-->
110
- <!-- <label class="fivelabel">现场已处理</label>-->
111
- <!-- <v-select :value="row.f_live_dispose"-->
112
- <!-- :value-single="true"-->
113
- <!-- :options="lives"-->
114
- <!-- :disabled="role == 'androidview'"-->
115
- <!-- @change="changlive"-->
116
- <!-- @click="transelation(idxs)"-->
117
- <!-- close-on-select clear-button></v-select>-->
118
- <!-- </div>-->
119
- <div class="form-group" style="display: flex;flex-wrap: wrap" v-if="(row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && (row.f_path != '' || row.f_is_defect != '') && (dealdispose == 'true' || dealdispose == true) " >
120
- <label class="fivelabel">处理方式</label>
121
- <v-select
122
- :value="row.f_deal_dispose"
123
- :value-single="true"
124
- :options="deals"
125
- :disabled="role == 'androidview'"
126
- @change="changdeal"
127
- @click="transelation(idxs)"
128
- close-on-select clear-button>
129
- </v-select>
130
- </div>
131
- <div style="display: flex;flex-wrap: wrap" v-if="row.f_deal_dispose == '自行处理' && this.showZXTime">
132
- <label class="fivelabel">处理时效:</label>
133
- <datepicker
134
- :value.sync="row.f_handle_date"
135
- v-model="row.f_handle_date"
136
- :format="'yyyy-MM-dd 00:00:00'"
137
- placeholder="请选择"
138
- style="width: 60%">
139
- </datepicker>
140
- </div>
141
- <div style="margin-left: 10px" class="form-group col-sm-10" v-if="(row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && row.tooltip != undefined && row.tooltip != '' ">
142
- ☆{{row.tooltip}}
143
- </div>
144
- <div class="form-group col-sm-12" style="display: flex;flex-wrap: wrap" v-if="(row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && (row.f_path != '' || row.f_is_defect != '')">
145
- <div class="auto" style="margin:1px;">
146
- <div class="panel">
147
- <div class="panel-body panel-self" style="background-color: #F8F8F8;width: 160px;height: 160px;position: relative">
148
- <div class="col-xs-6" style="height: 160px;width:160px;overflow: scroll;top: 1px">
149
- <div class="col-sm-4" v-show="row.f_path">
150
- <img-self-android :src="row.f_path" :alt="row.f_item_name" width="140" height="140"></img-self-android>
151
- </div>
152
- <div class="col-sm-4" v-show="!row.f_path" @click="takePic(idxs, row.f_item_name)">
153
- <img src="../../../assets/tackpic.png" :alt="点击拍摄照片" width="140" height="140"></img>
154
- </div>
155
- <img v-show="row.f_path" src="../../../assets/remove.png" :class="style__" @click="delfile(idxs, row.f_path)" v-if="role!='androidview'" style="width: 40px;height: 40px;position: absolute;left:110px;top:110px"></img>
156
- </div>
157
- <button v-if="isalbum" style="float: right" type="button" name="button" class="btn btn-primary btn-photo"
158
- @click="takePic2(idxs, row.f_item_name)">相册
159
- </button>
160
- </div>
161
- </div>
162
- </div>
163
- <!--多张隐患照片-->
164
- <div class="auto" v-for="itemIndex in hiddenDangerImgNumber" style="margin: 1px;">
165
- <div class="panel">
166
- <div class="panel-body panel-self" style="background-color: #F8F8F8;width: 160px;height: 160px;position: relative">
167
- <div class="col-xs-6" style="height: 160px;width:160px;overflow: scroll;top: 1px">
168
- <div class="col-sm-4" v-show="row['f_p' + (itemIndex+1) + '_path']">
169
- <img-self-android :src="row['f_p' + (itemIndex+1) + '_path']" :alt="row.f_item_name" width="140" height="140"></img-self-android>
170
- </div>
171
- <div class="col-sm-4" v-show="!row['f_p' + (itemIndex+1) + '_path']" @click="takePic(idxs, row.f_item_name,'f_p' + (itemIndex+1)+ '_path')">
172
- <img src="../../../assets/tackpic.png" :alt="点击拍摄照片" width="140" height="140"></img>
173
- </div>
174
- <img v-show="row['f_p' + (itemIndex+1)+'_path']" src="../../../assets/remove.png" :class="style__" @click="delfile(idxs,row['f_p' + (itemIndex+1)+'_path'],'f_p' + (itemIndex+1)+ '_path')" v-if="role!='androidview'" style="width: 40px;height: 40px;position: absolute;left:110px;top:110px"></img>
175
- </div >
176
- <button v-if="isalbum" style="float: right" type="button" name="button" class="btn btn-primary btn-photo"
177
- @click="takePic2(idxs, row.f_item_name,'f_p' + (itemIndex+1)+ '_path')">相册
178
- </button>
179
- </div>
180
- </div>
181
- </div>
182
- <div style="display: flex;flex-wrap: wrap;margin-top: 10px" v-if="row.f_deal_dispose == '现场整改' && (row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && this.showXCImg">
183
- <label class="fivelabel">整改照片:</label>
184
- <div class="auto" style="margin:1px;">
185
- <div class="panel">
186
- <div class="panel-body panel-self" style="background-color: #F8F8F8;width: 160px;height: 160px;position: relative">
187
- <div class="col-xs-6" style="height: 160px;width:160px;overflow: scroll;top: 1px">
188
- <div class="col-sm-4" v-show="row.f_repair_path">
189
- <img-self-android :src="row.f_repair_path" :alt="row.f_item_name" width="140" height="140"></img-self-android>
190
- </div>
191
- <div class="col-sm-4" v-show="!row.f_repair_path" @click="takePic(idxs, row.f_item_name,'f_repair_path',row.f_defect_level)">
192
- <img src="../../../assets/tackpic.png" alt="点击拍摄照片" width="140" height="140"></img>
193
- </div>
194
- <img v-show="row.f_repair_path" src="../../../assets/remove.png" :class="style__" @click="delfile(idxs, row.f_repair_path, 'f_repair_path')" v-if="role!='androidview'" style="width: 40px;height: 40px;position: absolute;left:110px;top:110px"></img>
195
- </div>
196
- </div>
197
- </div>
198
- </div>
199
- </div>
200
- </div>
201
- </div>
202
-
203
- <!--<v-select :value.sync="row.f_content" :options='getOptions(row.f_project)' placeholder='请选择' :disabled="(!(ischecked == '有')) || issee" close-on-select :value-single="true" v-if="!show && row.type == 'selector' && row.f_project != '气表品牌'"-->
204
- <!--&gt;</v-select>-->
205
- <!--<v-select :value.sync="row.f_content" :options='getOptions(row.f_project)' @change="getgasmodel" placeholder='请选择' :disabled="(!(ischecked == '有')) || issee" close-on-select :value-single="true" v-if="!show && row.type == 'selector' && row.f_project == '气表品牌'"-->
206
- <!--&gt;</v-select>-->
207
- <!-- <div class="auto" v-if="!show && row.type == 'checkbox' ">-->
208
- <!-- <input class="magic-checkbox" type="checkbox" id="shebeicheckbox"-->
209
- <!-- :checked="row.f_content == '有'"-->
210
- <!-- @click="switchDetails(row.f_project, $event)" :disabled="issee"/>-->
211
- <!-- <label for="shebeicheckbox" style="width:150px;padding-bottom: 10px">{{row.f_project}}</label>-->
212
- <!-- </div>-->
213
- <!--<img-area :model="Detail.imgs" :sutitle="row.f_project" v-if="row.type == 'picture'" :disabled="issee"></img-area>-->
214
- </div>
215
- </div>
216
- </div>
217
- <div style="border-top: 1px solid #D4D4D4"></div>
218
- </div>
219
- </div>
220
- </div>
221
- </template>
222
- <script>
223
- import Vue from 'vue'
224
- import * as Util from '../../Util'
225
-
226
- export default {
227
- title: '维修列表信息',
228
- data() {
229
- return {
230
- // telphoneValid: '/^((0\\d{2,3}-\\d{7,8})|(1[3584]\\d{9}))$/',
231
- // meterstyle:[],
232
- hiddenDangerImgNumber:0,//隐患图片数
233
- shuclass:'col-xs-12 col-sm-12 col-md-12 form-input-group mg8',
234
- shuclass1:'col-xs-12 col-sm-12 col-md-12 mg8',
235
- // labels:[],
236
- meternum:'',
237
- ischecked:'有',
238
- gasmodel:'',
239
- textstyle:'color: red',
240
- paper: this.$parent.$parent.data,
241
- f_items:[],
242
- page:{},
243
- selectindex:null,
244
- lives:[{label: '是', value: '是'},{label: '否', value: '否'}],
245
- deals:[{label: '现场处理', value: '现场处理'},{label: '自行处理', value: '自行处理'}],
246
- f_live_dispose:'否',
247
- f_deal_dispose:'未处理',
248
- // 初始表底
249
- f_initial_base: {},
250
- // 气量异常差值 计算公式 => 气量异常差值 = 累计购气量 - (已用气量 - 初始表底) - 剩余气量
251
- f_gas_aberrant_number: {},
252
- // 金额异常差值 计算公式 => 金额异常差值 = 累计购金额 - 已用金额 - 剩余金额
253
- f_fee_aberrant_number: {},
254
- // 累购气量
255
- f_total_gas: {},
256
- // 累购金额
257
- f_total_fee: {},
258
- // 已用气量
259
- f_table_base: {},
260
- // 已用金额
261
- f_fee_base: {},
262
- // 剩余气量
263
- f_gas_balance: {},
264
- // 剩余金额
265
- f_fee_balance: {},
266
- // 表端剩余金额
267
- f_table_balance: {},
268
- // 气量异常差值允许误差
269
-
270
- //物联网表数据存储
271
- f_balance_amount:{},//物联网表剩余金额
272
- f_meter_base:{},//物联网表读数
273
- f_balance_amount1:{},//物联网表现场录入的表上剩余金额
274
- f_meter_base1:{},//物联网表现场录入的表字轮数
275
- f_meter_aberrant_number1: {},//物联网表 表数异常差值
276
- f_fee_aberrant_number1: {},//物联网 表金额异常差值
277
- gasDeviation: (
278
- function (_this) {
279
- let deviation = _this.$appdata.getSingleValue('气量异常差值允许误差')
280
- if (deviation && !isNaN(deviation)) {
281
- return deviation
282
- } else {
283
- return 0
284
- }
285
- }
286
- )(this),
287
- // 金额异常差值允许误差
288
- feeDeviation: (
289
- function (_this) {
290
- let deviation = _this.$appdata.getSingleValue('金额异常差值允许误差')
291
- if (deviation && !isNaN(deviation)) {
292
- return deviation
293
- } else {
294
- return 0
295
- }
296
- }
297
- )(this),
298
- // 字轮异常差值允许误差
299
- meterbase: (
300
- function (_this) {
301
- let deviation = _this.$appdata.getSingleValue('字轮异常差值允许误差')
302
- if (deviation && !isNaN(deviation)) {
303
- return deviation
304
- } else {
305
- return 0
306
- }
307
- }
308
- )(this),
309
- showElse:false, //控制其他选项是否显示
310
- showXCImg: false, // 是否显示现场整改拍照选项
311
- showZXTime: false, // 是否显示自行整改处理时效
312
- isalbum:this.$appdata.getSingleValue('安检使用相册') || false,
313
- }
314
- },
315
- props: ['config','device','idx','operation','role'],
316
- // props: {
317
- // // 维修对应的用户数据收集
318
- // model: {
319
- // type: Object
320
- // },
321
- // service:{
322
- // type: Object
323
- // },
324
- // show: {
325
- // type: Boolean,
326
- // default: false
327
- // },
328
- // repairitem:{
329
- // type: Object
330
- // },
331
- // shutype:'heng',
332
- // tabs:{
333
- // type: Object
334
- // },
335
- // repairdetails:{
336
- // type: Object
337
- // },
338
- // faultshow:{
339
- // type: Object
340
- // },
341
- // issee:''
342
- // },
343
- methods: {
344
- changse(val){
345
- if(val == undefined){
346
- return
347
- }
348
- if(this.selectindex != null) {
349
- if(this.f_items[this.selectindex].type == 'selector'){
350
- this.f_items[this.selectindex].f_item_value = val
351
- }else if(this.f_items[this.selectindex].type == 'inputSelector'){
352
- this.f_items[this.selectindex].f_item_value = val.target.value
353
- }
354
- }
355
- },
356
- changlive(val){
357
- if(val == undefined){
358
- return
359
- }
360
- if(this.selectindex != null) {
361
- this.f_items[this.selectindex].f_live_dispose = val
362
- }
363
- },
364
- changdeal(val){
365
- if(val == undefined){
366
- this.f_items[this.selectindex].f_deal_dispose = ''
367
- return
368
- }
369
- if(this.selectindex != null) {
370
- this.f_items[this.selectindex].f_deal_dispose = val
371
- }
372
- },
373
- switchDetails(detailsType, event){
374
- if (event.srcElement.checked) {
375
- for(var i = 0;i<this.Detail.details.length;i++){
376
- if(this.Detail.details[i].f_project == detailsType){
377
- this.Detail.details[i].f_content = '有'
378
- this.ischecked = '有'
379
- return
380
- }
381
- }
382
- } else {
383
- this.Detail.imgs = []
384
- for(var i = 0;i<this.Detail.details.length;i++){
385
- if(this.Detail.details[i].f_project == detailsType){
386
- this.Detail.details[i].f_content = '无'
387
- this.ischecked = '无'
388
- }else{
389
- this.Detail.details[i].f_content = ''
390
- }
391
- }
392
- }
393
- },
394
- getgasmodel(val){
395
- this.gasmodel = val
396
- },
397
- getradios(val,flag){
398
- let Reoptions = []
399
- for (let i = 0;i<this.repairdetails.length;i++) {
400
- var t = false
401
- if(this.repairdetails[i].f_type == this.repairitem.header ){
402
- for(var j =0;j<this.repairdetails[i].details.length;j++){
403
- if(this.repairdetails[i].details[j].f_project == val ){
404
- Reoptions = this.repairdetails[i].details[j].options
405
- t = true
406
- break
407
- }
408
- }
409
- }
410
- if(t){
411
- break
412
- }
413
- }
414
- for(let j = 0;j<Reoptions.length;j++){
415
- if(Reoptions[j].data == flag){
416
- for(var e = 0;e<this.Detail.details.length;e++){
417
- if(this.Detail.details[e].f_project == val){
418
- this.Detail.details[e].f_status = Reoptions[j].f_status
419
- return
420
- }
421
- }
422
- break
423
- }
424
- }
425
- },
426
- deletedetails(){
427
- this.$showMessage('该操作会删除所填信息,是否继续!', ['confirm', 'cancel']).then((res) => {
428
- if (res === 'confirm') {
429
- for(var i = 0;i<this.tabs.length;i++){
430
- if(this.tabs[i].number == this.repairitem.number){
431
- this.tabs.splice(i, 1)
432
- this.model.servicerepair.splice(this.repairitem.number, 1)
433
- for(let t = i;t < this.tabs.length;t++ ) {
434
- this.tabs[t].number -= 1
435
- }
436
- return
437
- }
438
- }
439
- }
440
- })
441
- },
442
- takePic(prop, title, pathname='null') {
443
- if (this.role == 'androidview') {
444
- return
445
- }
446
- HostApp.__callback__ = this.cameraCallBack
447
- HostApp.__this__ = this
448
- //tag
449
- let fileName
450
- if (pathname == 'null') {
451
- if (!this.f_items[prop].f_path || this.f_items[prop].f_path.includes("nopic.png")) {
452
- fileName = Util.guid() + '-' + 'device'+this.device.n + '-' + this.idx + '-'+'f_items'+prop+ '.jpg'
453
- } else {
454
- fileName = Util.getFileName(this.f_items[prop].f_path)
455
- }
456
- } else {
457
- if (!this.f_items[prop][pathname] || this.f_items[prop][pathname].includes("nopic.png")) {
458
- fileName = Util.guid() + '-' + 'device'+this.device.n + '-' + this.idx + '-'+'f_items'+prop+ '.jpg'
459
- } else {
460
- fileName = Util.getFileName(this.f_items[prop][pathname])
461
- }
462
- }
463
- let jingweidu = ''
464
- if (this.$parent.$parent.is_has_jingweidu == 'true'){
465
- const obj = HostApp.getGpsDetailAddress()
466
- jingweidu = '\t经度:' + obj.longitude+ '\t纬度:' + obj.latitude
467
- this.f_items[prop].f_longitude = obj.longitude
468
- this.f_items[prop].f_latitude = obj.latitude
469
- }
470
- //tag
471
- //tag
472
- HostApp._open_a_page({type: 'boomerang',
473
- page: 'com.aofeng.hybrid.android.peripheral.CameraActivity',
474
- param: {file: fileName, requestCode: 111, callback:'javascript:HostApp.__callback__("'+ prop +'","'+ title +'", "%s","'+pathname+'");', watermark: title + '\t时间:'+ Util.toStandardTimeString() + '\t' + Vue.user.name + jingweidu}
475
- })
476
- },
477
- takePic2(prop, title, pathname='null') {
478
- if (this.role == 'androidview') {
479
- return
480
- }
481
- HostApp.__callback__ = this.cameraCallBack
482
- HostApp.__this__ = this
483
- //tag
484
- let fileName
485
- if (pathname == 'null') {
486
- if (!this.f_items[prop].f_path || this.f_items[prop].f_path.includes("nopic.png")) {
487
- fileName = Util.guid() + '-' + 'device' + this.device.n + '-' + this.idx + '-' + 'f_items' + prop + '.jpg'
488
- } else {
489
- fileName = Util.getFileName(this.f_items[prop].f_path)
490
- }
491
- } else {
492
- if (!this.f_items[prop][pathname] || this.f_items[prop][pathname].includes("nopic.png")) {
493
- fileName = Util.guid() + '-' + 'device' + this.device.n + '-' + this.idx + '-' + 'f_items' + prop + '.jpg'
494
- } else {
495
- fileName = Util.getFileName(this.f_items[prop][pathname])
496
- }
497
- }
498
- let jingweidu = ''
499
- if (this.$parent.$parent.is_has_jingweidu == 'true'){
500
- const obj = HostApp.getGpsDetailAddress()
501
- jingweidu = '\t经度:' + obj.longitude+ '\t纬度:' + obj.latitude
502
- this.f_items[prop].f_longitude = obj.longitude
503
- this.f_items[prop].f_latitude = obj.latitude
504
- }
505
- //tag
506
- //tag
507
- HostApp._open_a_page({type: 'boomerang',
508
- page: 'com.aofeng.hybrid.android.peripheral.ActionPickActivity',
509
- param: {file: fileName, requestCode: 111, callback:'javascript:HostApp.__callback__("'+ prop +'","'+ title +'", "%s","'+pathname+'");', watermark: title + '\t时间:'+ Util.toStandardTimeString() + '\t' + Vue.user.name + jingweidu}
510
- })
511
- },
512
- cameraCallBack(prop,title, fileName,pathname) {
513
- //tag
514
- if (pathname == 'null') {
515
- //tag
516
- HostApp.__this__.$set( 'f_items['+prop+'].f_path', fileName + '?' + Math.random())
517
- //tag
518
- HostApp.__callback__ = null
519
- HostApp.__this__ = null
520
- } else {
521
- //tag
522
- //tag)
523
- HostApp.__this__.$set( 'f_items['+prop+'].'+pathname+'', fileName + '?' + Math.random())
524
- HostApp.__callback__ = null
525
- HostApp.__this__ = null
526
- }
527
- if(this.f_items[prop].is_verification){
528
- let path=fileName.replace('http://newimg','')
529
- path=path.replace('file://','')
530
- console.log('fileName',fileName)
531
- console.log(path)
532
- let res=HostApp.pictureVerificationAI(path,title)
533
- if(res.code==200){
534
- if(res.type_result){
535
- // this.$showMessage("检测通过,当前照片为"+title)
536
- this.f_items[prop].verification_text=`检测通过,当前照片为 ${title}`
537
- this.f_items[prop].verification_state='pass'
538
- }else{
539
- // this.$showMessage("检测失败,未识别到当前照片为 "+title+",请重新拍摄!")
540
- this.f_items[prop].verification_text=`检测失败,未识别到当前照片为'${title}',请重新拍摄!`
541
- this.f_items[prop].verification_state='npass'
542
- }
543
- }else{
544
- // this.$showMessage("检测失败,请重试!")
545
- this.f_items[prop].verification_text=`检测失败,请重试!`
546
- this.f_items[prop].verification_state='npass'
547
- }
548
- }
549
- },
550
- delfile(prop, fileName, pathname='null') {
551
- if (pathname == 'null') {
552
- //tag
553
- //tag)
554
- if(fileName == Vue.nopic){
555
- return
556
- } else {
557
- HostApp.delfile(fileName)
558
- this.f_items[prop].f_path = Vue.nopic
559
- }
560
- }else {
561
- //tag
562
- //tag)
563
- if(fileName == Vue.nopic){
564
- return
565
- } else {
566
- HostApp.delfile(fileName)
567
- this.f_items[prop][pathname] = Vue.nopic
568
- }
569
- }
570
- },
571
- adddetails(){
572
- // 下标作为序号,取值用。 增加 序号得依次增加
573
- if(this.tabs.length > 0){
574
- for(let i = this.tabs.length-1;i > 0 ;i-- ){
575
- if(this.tabs[i].header == this.repairitem.header){
576
- if(this.model.servicerepair.length > 0){
577
- for(let j = this.model.servicerepair.length -1;j > -1;j-- ){
578
- if(this.model.servicerepair[j].f_type == this.repairitem.header){
579
- this.model.servicerepair.splice(j+1, 0, Object.assign({}, JSON.parse(JSON.stringify(this.tabs[i].details))))
580
- this.tabs.splice(i+1, 0, {header: `${this.repairitem.header}`,details:this.tabs[i].details,complete:'repair-details',class:'repair-details-class',number:j+1,items:this.tabs[i].items})
581
- for(let t = i+2;t < this.tabs.length;t++ ) {
582
- this.tabs[t].number += 1
583
- }
584
- this.faultshow.number += this.faultshow.number + 1
585
- return
586
- }
587
- }
588
- }
589
- }
590
- }
591
- }
592
- },
593
- transelation(val){
594
- this.selectindex = val
595
- },
596
- towatch(){
597
- for(let n in this.f_items){
598
- if(typeof this.f_items[n]=='function'){
599
- continue
600
- }
601
- if(this.f_items[n].type == 'selector' || this.f_items[n].type == 'inputSelector'){
602
- // 监听下拉框,如果有隐患,需要拍照
603
- this.$watch('f_items['+n+'].selected',function(val) {
604
- // 下拉框值
605
- //tag)
606
- // 下拉框所属设备
607
- //tag
608
- // 下拉框所属项
609
- //tag
610
- if (val == undefined || val.length == 0 || val[0] == ''){
611
- this.f_items[n].f_path = ''
612
- this.f_items[n].f_is_defect = ''
613
- this.f_items[n].f_defect_level = ''
614
- this.f_items[n].f_live_dispose = ''
615
- this.f_items[n].f_deal_dispose = ''
616
- this.f_items[n].tooltip = ''
617
- this.f_items[n].f_else = ''
618
- return
619
- }
620
- let shImage = false
621
- if(val.indexOf('其他') == -1){
622
- this.f_items[n].f_else = ''
623
- }
624
- // if(this.config[this.device.device].items[item].type == 'selector'){
625
- // this.f_items[n].f_item_value = val
626
- // }else if(this.config[this.device.device].items[item].type == 'inputSelector'){
627
- // this.f_items[n].f_item_value = val[0]
628
- // }
629
- // 在配置中查找该项
630
- for (let item in this.config[this.device.device].items) {
631
- if(typeof this.config[this.device.device].items[item]=='function'){
632
- continue
633
- }
634
- let type = this.config[this.device.device].items[item].type
635
- let multiple = false
636
- if(this.config[this.device.device].items[item].multiple){
637
- multiple = this.config[this.device.device].items[item].multiple === 'true' || this.config[this.device.device].items[item].multiple === true
638
- }
639
- let options = this.config[this.device.device].items[item].options
640
- if ((this.config[this.device.device].items[item].type == 'selector' || this.config[this.device.device].items[item].type == 'inputSelector') && this.config[this.device.device].items[item].itemname == this.f_items[n].f_item_name) {
641
- for (let i in options) {
642
- if(typeof options[i]=='function'){
643
- continue
644
- }
645
- let value
646
- if(this.config[this.device.device].items[item].type == 'selector' && this.config[this.device.device].items[item].multiple == false){
647
- value = val[0]
648
- }else if (this.config[this.device.device].items[item].type == 'inputSelector'){
649
- value = val
650
- }
651
- //tag)
652
- // 如果未选择,清空图片、隐患信息等
653
- if((type == 'selector' && val.length == 0) || (type == 'inputSelector' && val == '')){
654
- this.f_items[n].f_path = ''
655
- this.f_items[n].f_is_defect = ''
656
- this.f_items[n].f_defect_level = ''
657
- this.f_items[n].f_live_dispose = ''
658
- this.f_items[n].f_deal_dispose = ''
659
- this.f_items[n].tooltip = ''
660
- }
661
- if((type == 'selector' && multiple == false && options[i].data == val[0]) || (type == 'inputSelector' && options[i].data == val) || (type == 'selector' && multiple == true && val.indexOf(options[i].data) > -1)){
662
- // 找到选中的项了
663
- //tag
664
- if(options[i].isdefect == true ){
665
- shImage = true
666
- }
667
- if(options[i].isdefect == false || this.f_items[n].f_item_value == ''){
668
- shImage = false
669
- }
670
- //tag
671
- if(shImage){
672
- this.f_items[n].f_is_defect =true
673
- this.f_items[n].f_defect_level = options[i].level
674
- if (!multiple){
675
- this.f_items[n].f_path = Vue.nopic
676
- }
677
- this.f_items[n].f_live_dispose = '否'
678
- this.f_items[n].f_deal_dispose = '未处理'
679
- //tag
680
- this.f_items[n].tooltip= options[i].tooltip
681
- }else{
682
- this.f_items[n].f_path = ''
683
- this.f_items[n].f_is_defect = ''
684
- this.f_items[n].f_defect_level = ''
685
- this.f_items[n].f_live_dispose = ''
686
- this.f_items[n].f_deal_dispose = ''
687
- this.f_items[n].tooltip = ''
688
- }
689
- }
690
- }
691
- }
692
- }
693
- }
694
- )
695
- // this.$watch('other',function(val){
696
- // //tag
697
- // if(this.selectindex != null) {
698
- // let index = this.f_items[this.selectindex].f_item_value.indexOf('其他')
699
- // if(index > -1){
700
- // this.f_items[this.selectindex].f_item_value.splice(index,1,this.other)
701
- // }
702
- // }
703
- //
704
- // })
705
- }else if(this.f_items[n].type == 'radio') {
706
- // 监听单选框,如果有隐患,需要拍照
707
- this.$watch('f_items[' + n + '].f_item_value', function (val) {
708
- //tag)
709
- let options = this.f_items[n].options
710
- //tag)
711
- for (let i = 0; i < options.length; i++) {
712
- //tag)
713
- // 找到选中的项了
714
- if (options[i].value == val) {
715
- // 如果有隐患,拍图片
716
- if (options[i].isdefect) {
717
- this.f_items[n].f_is_defect = true
718
- this.f_items[n].f_defect_level = options[i].level
719
- this.f_items[n].f_path = Vue.nopic
720
- this.f_items[n].f_live_dispose = '否'
721
- this.f_items[n].f_deal_dispose = '未处理'
722
- this.f_items[n].tooltip = options[i].tooltip
723
- //tag)
724
- return
725
- }
726
- }
727
- }
728
- this.f_items[n].f_path = ''
729
- this.f_items[n].f_is_defect = ''
730
- this.f_items[n].f_defect_level = ''
731
- this.f_items[n].f_live_dispose = ''
732
- this.f_items[n].f_deal_dispose = ''
733
- this.f_items[n].tooltip = ''
734
- })
735
- }else if(this.f_items[n].type == 'checkbox') {
736
- // 监听单选框,如果有隐患,需要拍照
737
- this.$watch('f_items[' + n + '].f_item_value', function (val) {
738
- //tag)
739
- // 如果是手动赋值,不执行下面逻辑
740
- if (this.f_items[n].isReSet) {
741
- this.f_items[n].isReSet = false
742
- return
743
- }
744
- let options = this.f_items[n].options
745
- //tag)
746
- // 取出选中项中有隐患的详细信息
747
- let selected = options.filter(item => { return val.indexOf(item.value) != -1 && item.isdefect })
748
-
749
- if(selected.length > 0){
750
- // 防止赋值无限调用
751
- this.f_items[n].isReSet = true
752
- let selectList = selected.map(item => {return item.value})
753
- // 如果选中的是非隐患项,取消选中isdefect为true的
754
- if (selectList.indexOf(val[val.length - 1]) == -1) {
755
- this.f_items[n].f_item_value = val.filter(item => {return selectList.indexOf(item) == -1})
756
- this.f_items[n].f_path = ''
757
- this.f_items[n].f_is_defect = ''
758
- this.f_items[n].f_defect_level = ''
759
- this.f_items[n].f_live_dispose = ''
760
- this.f_items[n].f_deal_dispose = ''
761
- this.f_items[n].tooltip = ''
762
- return
763
- }
764
- // 如果选中的是隐患项,取消选中isdefect为false的
765
- this.f_items[n].f_item_value = selectList
766
- // 如果第一次选择隐患项,初始化
767
- if (!this.f_items[n].f_is_defect) {
768
- this.f_items[n].f_is_defect = true
769
- this.f_items[n].f_defect_level = selected[0].level
770
- this.f_items[n].f_path = Vue.nopic
771
- this.f_items[n].f_live_dispose = '否'
772
- this.f_items[n].f_deal_dispose = '未处理'
773
- //tag
774
- this.f_items[n].tooltip = selected[0].tooltip
775
- }
776
- //tag)
777
- return
778
- }
779
- this.f_items[n].f_path = ''
780
- this.f_items[n].f_is_defect = ''
781
- this.f_items[n].f_defect_level = ''
782
- this.f_items[n].f_live_dispose = ''
783
- this.f_items[n].f_deal_dispose = ''
784
- this.f_items[n].tooltip = ''
785
- })
786
- }
787
- }
788
- //tag)
789
- },
790
- getGasAberrantNumber(val) {
791
- //tag
792
- if(!this.f_table_base.index || !this.f_gas_balance.index){
793
- //tag
794
- return
795
- }
796
- // 先清空
797
- this.f_items[this.f_gas_aberrant_number.index].f_item_value = null
798
- this.f_items[this.f_gas_aberrant_number.index].f_is_defect = false
799
- if(val=='已用气量'){
800
- //剩余气量 = 累购-已用
801
- this.f_items[this.f_gas_balance.index].f_item_value= (this.f_items[this.f_total_gas.index].f_item_value-this.f_items[this.f_table_base.index].f_item_value).toFixed(2)
802
- if (isNaN(this.f_items[this.f_gas_balance.index].f_item_value)) {
803
- this.f_items[this.f_gas_balance.index].f_item_value = null
804
- }
805
- }
806
-
807
- // 只有两个值都填了才会计算
808
- if (!this.f_items[this.f_table_base.index].f_item_value || !this.f_items[this.f_gas_balance.index].f_item_value) {
809
- return
810
- }
811
- //tag)
812
- //tag
813
- //tag
814
-
815
- // 计算公式 => 气量异常差值 = 累计购气量 - (已用气量 - 初始表底) - 剩余气量
816
- this.f_items[this.f_gas_aberrant_number.index].f_item_value = this.f_items[this.f_total_gas.index].f_item_value - this.f_items[this.f_gas_balance.index].f_item_value - (this.f_items[this.f_table_base.index].f_item_value - (this.f_initial_base.index?this.f_items[this.f_initial_base.index].f_item_value:0))
817
- this.f_items[this.f_gas_aberrant_number.index].f_item_value = this.f_items[this.f_gas_aberrant_number.index].f_item_value.toFixed(3)
818
- // 如果数值有误,清空结果s
819
- if (isNaN(this.f_items[this.f_gas_aberrant_number.index].f_item_value)) {
820
- this.f_items[this.f_gas_aberrant_number.index].f_item_value = null
821
- }
822
- //tag ===> ' + Math.abs(this.f_items[this.f_gas_aberrant_number.index].f_item_value))
823
- //tag ===> ' + JSON.stringify(Number(this.gasDeviation)))
824
- // 计算差值是否在范围内
825
- if (Math.abs(this.f_items[this.f_gas_aberrant_number.index].f_item_value) > Number(this.gasDeviation)|| Math.abs(this.f_items[this.f_gas_aberrant_number.index].f_item_value) < Number(this.gasDeviation) * -1) {
826
- this.f_items[this.f_gas_aberrant_number.index].f_is_defect = true
827
- this.f_items[this.f_gas_aberrant_number.index].f_deal_dispose = '未处理'
828
- }else{
829
- this.f_items[this.f_gas_aberrant_number.index].f_is_defect = null
830
- this.f_items[this.f_gas_aberrant_number.index].f_deal_dispose = null
831
- }
832
-
833
- //tag)
834
- },
835
- getFeeAberrantNumber(val) {
836
- //tag
837
- // 只有两个值都填了才会计算
838
- if(!this.f_fee_base.index || !this.f_fee_balance.index){
839
- //tag
840
- return
841
- }
842
- // 先清空
843
- this.f_items[this.f_fee_aberrant_number.index].f_item_value = null
844
- this.f_items[this.f_fee_aberrant_number.index].f_is_defect = false
845
-
846
- if(val=='已用金额'){
847
- this.f_items[this.f_fee_balance.index].f_item_value=(this.f_items[this.f_total_fee.index].f_item_value-this.f_items[this.f_fee_base.index].f_item_value).toFixed(3)
848
- if (isNaN(this.f_items[this.f_fee_balance.index].f_item_value)) {
849
- this.f_items[this.f_fee_balance.index].f_item_value = null
850
- }
851
- }
852
-
853
- if (!this.f_items[this.f_fee_base.index].f_item_value || !this.f_items[this.f_fee_balance.index].f_item_value) {
854
- return
855
- }
856
-
857
- // 计算公式 => 金额异常差值 = 累计购金额 - 已用金额 - 剩余金额
858
- this.f_items[this.f_fee_aberrant_number.index].f_item_value = this.f_items[this.f_total_fee.index].f_item_value - this.f_items[this.f_fee_balance.index].f_item_value - this.f_items[this.f_fee_base.index].f_item_value
859
- this.f_items[this.f_fee_aberrant_number.index].f_item_value = this.f_items[this.f_fee_aberrant_number.index].f_item_value.toFixed(3)
860
- if (isNaN(this.f_items[this.f_fee_aberrant_number.index].f_item_value)) {
861
- this.f_items[this.f_fee_aberrant_number.index].f_item_value = null
862
- }
863
- //tag ===> ' + Math.abs(this.f_items[this.f_fee_aberrant_number.index].f_item_value))
864
- //tag ===> ' + JSON.stringify(Number(this.feeDeviation)))
865
- // 计算差值是否在范围内
866
- if (Math.abs(this.f_items[this.f_fee_aberrant_number.index].f_item_value) > Number(this.feeDeviation)) {
867
- this.f_items[this.f_fee_aberrant_number.index].f_is_defect = true
868
- this.f_items[this.f_fee_aberrant_number.index].f_deal_dispose = '未处理'
869
- }else{
870
- this.f_items[this.f_fee_aberrant_number.index].f_is_defect = null
871
- this.f_items[this.f_fee_aberrant_number.index].f_deal_dispose = null
872
- }
873
-
874
- //tag)
875
- },
876
- // 计算剩余金额和剩余金额差值
877
- getFeeAberrantNumber2(val) {
878
- //tag
879
- // 只有两个值都填了才会计算
880
- if(!this.f_table_balance.index || !this.f_fee_balance.index){
881
- //tag
882
- return
883
- }
884
- // 先清空
885
- this.f_items[this.f_fee_aberrant_number.index].f_item_value = null
886
- this.f_items[this.f_fee_aberrant_number.index].f_is_defect = false
887
-
888
- // 计算公式 => 金额异常差值 = 系统剩余金额 - 表端剩余金额
889
- this.f_items[this.f_fee_aberrant_number.index].f_item_value = this.f_items[this.f_fee_balance.index].f_item_value - this.f_items[this.f_table_balance.index].f_item_value
890
- this.f_items[this.f_fee_aberrant_number.index].f_item_value = this.f_items[this.f_fee_aberrant_number.index].f_item_value.toFixed(3)
891
- if (isNaN(this.f_items[this.f_fee_aberrant_number.index].f_item_value)) {
892
- this.f_items[this.f_fee_aberrant_number.index].f_item_value = null
893
- }
894
- //tag ===> ' + Math.abs(this.f_items[this.f_fee_aberrant_number.index].f_item_value))
895
- //tag ===> ' + JSON.stringify(Number(this.feeDeviation)))
896
- // 计算差值是否在范围内
897
- if (Math.abs(this.f_items[this.f_fee_aberrant_number.index].f_item_value) > Number(this.feeDeviation)) {
898
- this.f_items[this.f_fee_aberrant_number.index].f_is_defect = true
899
- this.f_items[this.f_fee_aberrant_number.index].f_deal_dispose = '未处理'
900
- }else{
901
- this.f_items[this.f_fee_aberrant_number.index].f_is_defect = null
902
- this.f_items[this.f_fee_aberrant_number.index].f_deal_dispose = null
903
- }
904
- console.log('--------------------------------')
905
- console.log(this.f_items[this.f_fee_aberrant_number.index].f_item_value)
906
-
907
- //tag)
908
- },
909
- //物联网表字轮数改变触发
910
- getmeteraberrantnumber() {
911
- //tag
912
-
913
- // 先清空
914
- this.f_items[this.f_meter_aberrant_number1.index].f_item_value = null
915
- this.f_items[this.f_meter_aberrant_number1.index].f_is_defect = false
916
- //tag
917
- // 只有两个值都填了才会计算
918
- if (!this.f_items[this.f_meter_base.index].f_item_value || !this.f_items[this.f_meter_base1.index].f_item_value) {
919
- return
920
- }
921
- //tag
922
- // 计算公式 => 表数异常差值= - 字轮数 - 后台表读数
923
- this.f_items[this.f_meter_aberrant_number1.index].f_item_value = this.f_items[this.f_meter_base1.index].f_item_value - this.f_items[this.f_meter_base.index].f_item_value
924
- this.f_items[this.f_meter_aberrant_number1.index].f_item_value = this.f_items[this.f_meter_aberrant_number1.index].f_item_value.toFixed(3)
925
- if (isNaN(this.f_items[this.f_meter_aberrant_number1.index].f_item_value)) {
926
- this.f_items[this.f_meter_aberrant_number1.index].f_item_value = null
927
- }
928
- //tag ===> ' + Math.abs(this.f_items[this.f_meter_aberrant_number1.index].f_item_value))
929
- // 计算差值是否在范围内
930
- //tag)
931
- if (Math.abs(this.f_items[this.f_meter_aberrant_number1.index].f_item_value) > Number(this.meterbase)){
932
- this.f_items[this.f_meter_aberrant_number1.index].f_is_defect = true
933
- }
934
-
935
- //tag)
936
- },
937
-
938
- disSelect(index, itemValue) {
939
- //tag)
940
- //tag)
941
- if (this.f_items[index].f_item_value == itemValue) {
942
- this.$set(`f_items[${index}].f_item_value`, '')
943
- }
944
- }
945
- },
946
- ready() {
947
- //tag
948
- //tag
949
- if(Vue.config.safecheck != undefined){
950
- if(Vue.config.safecheck.ApproveConfig != undefined){
951
- if(Vue.config.safecheck.ApproveConfig.livedispose != undefined) {
952
- this.livedispose = Vue.config.safecheck.ApproveConfig.livedispose
953
- }
954
- if(Vue.config.safecheck.ApproveConfig.dealdispose != undefined) {
955
- this.dealdispose = Vue.config.safecheck.ApproveConfig.dealdispose
956
- }
957
- if(Vue.config.safecheck.ApproveConfig.showtorepair) {
958
- this.deals=[{label: '现场整改', value: '现场整改'},
959
- {label: '自行处理', value: '自行处理'},
960
- {label: '转维修', value: '报修'}
961
- ]
962
- }
963
- if(Vue.config.safecheck.ApproveConfig.Processing) {
964
- if(Vue.config.safecheck.ApproveConfig.Processing.length > 0){
965
- this.deals = Vue.config.safecheck.ApproveConfig.Processing
966
- }
967
- }
968
- if(Vue.config.safecheck.ApproveConfig.showXCImg) {
969
- this.showXCImg = true
970
- }
971
- if(Vue.config.safecheck.ApproveConfig.showZXTime) {
972
- this.showZXTime = true
973
- }
974
- if(Vue.config.safecheck.ApproveConfig.showtorepair) {
975
- }
976
- if(Vue.config.safecheck.ApproveConfig.hiddendanger != undefined) {
977
- if (parseInt(Vue.config.safecheck.ApproveConfig.hiddendanger) >= 5) {
978
- this.hiddenDangerImgNumber = 5
979
- }else {
980
- this.hiddenDangerImgNumber = parseInt(Vue.config.safecheck.ApproveConfig.hiddendanger)
981
- }
982
- }
983
- }
984
- }
985
- //tag
986
- //tag)
987
- //tag)
988
- //tag)
989
- //创建页面所需数据
990
- this.$set('piece', this.paper['device'+this.device.n][this.idx])
991
- //tag)
992
- //tag)
993
- let n = 0
994
- for (let item in this.config[this.device.device].items) {
995
- if(typeof this.config[this.device.device].items[item]=='function'){
996
- continue
997
- }
998
- let index = item
999
- this.$set('page.options' + index, [])
1000
- //tag)
1001
- //tag)
1002
- //tag)
1003
- // 先根据配置组接页面
1004
- let f_item_value
1005
- if(this.config[this.device.device].items[item].type == 'selector' || this.config[this.device.device].items[item].type == 'checkbox'){
1006
- f_item_value = []
1007
- // 判断选项的默认值
1008
- for (let defitem in this.config[this.device.device].items[item].options) {
1009
- if(typeof this.config[this.device.device].items[item].options[defitem]=='function'){
1010
- continue
1011
- }
1012
- let defopt = this.config[this.device.device].items[item].options[defitem]
1013
- if (defopt.isdefault) {
1014
- //tag
1015
- f_item_value[0] = defopt.data
1016
- }
1017
- }
1018
- // if(this.config[this.device.device].items[item].data){
1019
- // f_item_value.push(this.config[this.device.device].items[item].data)
1020
- // }
1021
- }else if(this.config[this.device.device].items[item].type == 'radio'){
1022
- //为radio添加默认值
1023
- f_item_value=''
1024
- //tag)
1025
- for (let defitem in this.config[this.device.device].items[item].options) {
1026
- if(typeof this.config[this.device.device].items[item].options[defitem]=='function'){
1027
- continue
1028
- }
1029
- //tag)
1030
- let defopt = this.config[this.device.device].items[item].options[defitem]
1031
- if (defopt.isdefault) {
1032
- //tag)
1033
- f_item_value = defopt.data
1034
- }
1035
- }
1036
- }else{
1037
- f_item_value = this.config[this.device.device].items[item].data ? this.config[this.device.device].items[item].data : ''
1038
- }
1039
- //tag)
1040
- let it = {
1041
- type: this.config[this.device.device].items[item].type,
1042
- f_item_name: this.config[this.device.device].items[item].itemname,
1043
- checkmust: this.config[this.device.device].items[item].checkmust,
1044
- f_item_value: this.config[this.device.device].items[item].f_item_value || f_item_value,
1045
- is_verification:this.config[this.device.device].items[item].is_verification,
1046
- verification_text:'',
1047
- verification_state:'',// ai验证是否通过 npass(未通过)/pass(通过)
1048
- f_is_defect: '',
1049
- multiple:this.config[this.device.device].items[item].multiple === 'true' || this.config[this.device.device].items[item].multiple == true?this.config[this.device.device].items[item].multiple:false,
1050
- isshow:this.config[this.device.device].items[item].isshow == false?this.config[this.device.device].items[item].isshow:true,
1051
- readonly: this.config[this.device.device].items[item].readonly == true?true:false,
1052
- remark: this.config[this.device.device].items[item].remark ? this.config[this.device.device].items[item].remark : '',
1053
- f_path: '',
1054
- unit: this.config[this.device.device].items[item].unit ? this.config[this.device.device].items[item].unit : '',
1055
- tooltip:'',
1056
- f_live_dispose:'',
1057
- f_deal_dispose: this.config[this.device.device].items[item].f_process_mode,
1058
- f_else: '',
1059
- f_p1_path: '',
1060
- f_p2_path: '',
1061
- f_p3_path: '',
1062
- f_longitude:'',
1063
- f_latitude:''
1064
- }
1065
- //tag)
1066
- //tag)
1067
- this.$set('f_items['+index+']',it)
1068
- if (this.config[this.device.device].items[item].type == 'selector' ||this.config[this.device.device].items[item].type == 'inputSelector') {
1069
- if(this.config[this.device.device].items[item].type == 'selector'){
1070
- this.page['options' + index].push({
1071
- label: "请选择",
1072
- value: ''
1073
- })
1074
- }
1075
- for (let i in this.config[this.device.device].items[item].options) {
1076
- if(typeof this.config[this.device.device].items[item].options[i]=='function'){
1077
- continue
1078
- }
1079
- this.page['options' + index].push({
1080
- label: this.config[this.device.device].items[item].options[i].data,
1081
- value: this.config[this.device.device].items[item].options[i].data,
1082
- tooltip: this.config[this.device.device].items[item].options[i].tooltip
1083
- })
1084
- }
1085
- if(this.config[this.device.device].items[item].type == 'selector'){
1086
- this.$set('f_items['+index+'].selected', f_item_value)
1087
- }else if(this.config[this.device.device].items[item].type == 'inputSelector'){
1088
- this.$set('f_items['+index+'].selected', f_item_value)
1089
- }
1090
-
1091
- this.$set('f_items['+index+'].options',this.page['options' + index])
1092
-
1093
- //tag)
1094
- } else if (this.config[this.device.device].items[item].type == 'radio' || this.config[this.device.device].items[item].type == 'checkbox') {
1095
- //tag)
1096
- //tag
1097
- //tag)
1098
- for (let i in this.config[this.device.device].items[item].options) {
1099
- if(typeof this.config[this.device.device].items[item].options[i]=='function'){
1100
- continue
1101
- }
1102
- //tag
1103
- this.page['options' + index].push({
1104
- label: this.config[this.device.device].items[item].options[i].data,
1105
- value: this.config[this.device.device].items[item].options[i].data,
1106
- isdefect: this.config[this.device.device].items[item].options[i].isdefect,
1107
- level: this.config[this.device.device].items[item].options[i].level,
1108
- tooltip: this.config[this.device.device].items[item].options[i].tooltip
1109
- })
1110
- //tag)
1111
- }
1112
- //tag)
1113
- this.$set('f_items[' + index + '].options', this.page['options' + index])
1114
- this.$set('f_items[' + index + '].f_item_value', f_item_value)
1115
- //tag)
1116
- }
1117
- n = n + 1
1118
- }
1119
- if(!this.piece || JSON.stringify(this.piece) == '{}') {
1120
- // 如果没有,则新建
1121
- this.$set('piece.f_items',this.f_items)
1122
- this.$set('piece.f_device_type', this.config[this.device.device].itemname)
1123
- } else {
1124
- // 已经存在,把之前的数据重新填入
1125
- for (let f in this.f_items){
1126
- if(typeof this.f_items[f]=='function'){
1127
- continue
1128
- }
1129
- for(let p in this.piece.f_items) {
1130
- if(typeof this.piece.f_items[p]=='function'){
1131
- continue
1132
- }
1133
- if (this.f_items[f].f_item_name == this.piece.f_items[p].f_item_name) {
1134
- //tag)
1135
- //tag)
1136
- this.f_items[f] = Object.assign(this.f_items[f], this.piece.f_items[p])
1137
- //tag)
1138
- if (this.f_items[f].type == 'selector' || this.f_items[f].type == 'inputSelector') {
1139
- //tag)
1140
- //tag)
1141
- this.f_items[f].selected = this.piece.f_items[p].f_item_value
1142
- //tag)
1143
- }
1144
- // 取出特殊值
1145
- if (this.f_items[f].f_item_name == '初始表底') {
1146
- //tag)
1147
- this.f_initial_base.index = f
1148
- } else if (this.f_items[f].f_item_name == '累购气量') {
1149
- //tag)
1150
- this.f_total_gas.index = f
1151
- } else if (this.f_items[f].f_item_name == '已用气量') {
1152
- //tag)
1153
- this.f_table_base.index = f
1154
- this.$watch('f_items[' + f + '].f_item_value', function () {
1155
- this.getGasAberrantNumber('已用气量')
1156
- })
1157
- } else if (this.f_items[f].f_item_name == '剩余气量') {
1158
- //tag)
1159
- this.f_gas_balance.index = f
1160
- this.$watch('f_items[' + f + '].f_item_value', function () {
1161
- this.getGasAberrantNumber('')
1162
- })
1163
- } else if (this.f_items[f].f_item_name == '气量异常差值') {
1164
- //tag)
1165
- this.f_gas_aberrant_number.index = f
1166
- } else if (this.f_items[f].f_item_name == '累购金额') {
1167
- //tag)
1168
- this.f_total_fee.index = f
1169
- } else if (this.f_items[f].f_item_name == '已用金额') {
1170
- //tag)
1171
- this.f_fee_base.index = f
1172
- this.$watch('f_items[' + f + '].f_item_value', function () {
1173
- this.getFeeAberrantNumber('已用金额')
1174
- })
1175
- } else if (this.f_items[f].f_item_name == '剩余金额') {
1176
- //tag)
1177
- this.f_fee_balance.index = f
1178
- this.$watch('f_items[' + f + '].f_item_value', function () {
1179
- this.getFeeAberrantNumber('')
1180
- this.getFeeAberrantNumber2('')
1181
- })
1182
- } else if (this.f_items[f].f_item_name == '表端剩余金额') {
1183
- this.f_table_balance.index = f
1184
- this.$watch('f_items[' + f + '].f_item_value', function () {
1185
- this.getFeeAberrantNumber2('')
1186
- })
1187
- } else if (this.f_items[f].f_item_name == '金额异常差值') {
1188
- //tag)
1189
- this.f_fee_aberrant_number.index = f
1190
- }else if (this.f_items[f].f_item_name == '表读数') {
1191
- //tag)
1192
- this.f_meter_base.index = f
1193
- }else if (this.f_items[f].f_item_name == '表剩余金额') {
1194
- //tag)
1195
- this.f_balance_amount.index = f
1196
- }else if (this.f_items[f].f_item_name == '字轮数') {
1197
- //tag)
1198
- this.f_meter_base1.index = f
1199
- this.$watch('f_items[' + f + '].f_item_value', function () {
1200
- this.getmeteraberrantnumber()
1201
- })
1202
- }else if (this.f_items[f].f_item_name == '表余额') {
1203
- //tag)
1204
- this.f_balance_amount1.index = f
1205
- this.$watch('f_items[' + f + '].f_item_value', function () {
1206
- this.getfeeaberrantnumber1()
1207
- })
1208
- }else if (this.f_items[f].f_item_name == '表数异常差值') {
1209
- //tag)
1210
- this.f_meter_aberrant_number1.index = f
1211
- }else if (this.f_items[f].f_item_name == '表金额异常差值') {
1212
- //tag)
1213
- this.f_fee_aberrant_number1.index = f
1214
- }
1215
- }
1216
- }
1217
- for (let em in this.config[this.device.device].items) {
1218
- if(typeof this.config[this.device.device].items[em]=='function'){
1219
- continue
1220
- }
1221
- if (this.config[this.device.device].items[em].type == 'selector' && em == this.f_items[f].f_item_name) {
1222
- this.f_items[f].options =[]
1223
- for (let k in this.config[this.device.device].items[em].options) {
1224
- if(typeof this.config[this.device.device].items[em].options[k]=='function'){
1225
- continue
1226
- }
1227
- this.f_items[f].options.push({
1228
- label: this.config[this.device.device].items[em].options[k].data,
1229
- value: this.config[this.device.device].items[em].options[k].data
1230
- })
1231
- }
1232
- }
1233
- }
1234
- }
1235
- //tag)
1236
- this.$set('piece.f_items',this.f_items)
1237
- }
1238
- this.towatch()
1239
- },
1240
- destroyed(){
1241
- let nullCount = 0
1242
- let metertitles
1243
- //判断当前是否有选中项
1244
- for (let row in this.f_items){
1245
- if(typeof this.f_items[row]=='function'){
1246
- continue
1247
- }
1248
- if(this.f_items[row].selected && this.f_items[row].selected != '' && this.f_items[row].selected instanceof Array){
1249
- //tag
1250
- this.f_items[row].f_item_value = this.f_items[row].selected
1251
- }else if(this.f_items[row].selected && this.f_items[row].selected != ''){
1252
- //tag
1253
- this.f_items[row].f_item_value = this.f_items[row].selected
1254
- }
1255
- // if(this.f_items[row].f_item_value instanceof Array && this.f_items[row].f_item_value.length != 0 ){
1256
- // nullCount = nullCount+1
1257
- // }else if(this.f_items[row].f_item_value != ''){
1258
- // nullCount = nullCount+1
1259
- // }
1260
- }
1261
- let picture = []
1262
- // for (let row in this.f_items){
1263
- // let a={}
1264
- // a.f_path = this.f_items[row].f_path
1265
- // a.name = this.f_items[row].f_item_name
1266
- // }
1267
- // picture.push(a)
1268
- this.$set(`paper['device${this.device.n}'][${this.idx}]`, this.piece)
1269
- //tag
1270
- },
1271
- computed:{
1272
-
1273
- }
1274
- }
1275
- </script>
1276
- <style lang="less" scoped>
1277
- .class-erro {
1278
- color: #a94442;
1279
- }
1280
- .fivelabel{
1281
- border: none;
1282
- border-left: 5px solid #A2C2EB;
1283
- float: left;
1284
- width: 35%;
1285
- margin-bottom: 3px;
1286
- text-align: left;
1287
- word-wrap: break-word;
1288
- white-space: normal;
1289
- }
1290
- .radiolabel{
1291
- border: none;
1292
- border-left: 5px solid #A2C2EB;
1293
- float: left;
1294
- width: 65%;
1295
- margin-bottom: 3px;
1296
- text-align: left;
1297
- word-wrap: break-word;
1298
- white-space: normal;
1299
- }
1300
-
1301
- .textlabel {
1302
- border: none;
1303
- border-left: 5px solid #A2C2EB;
1304
- width: 100%;
1305
- margin-bottom: 3px;
1306
- text-align: left;
1307
- word-wrap: break-word;
1308
- white-space: normal;
1309
- }
1310
- .textlabel1 {
1311
- border: none;
1312
- border-left: 5px solid #f7cb32;
1313
- width: 100%;
1314
- margin-bottom: 3px;
1315
- text-align: left;
1316
- word-wrap: break-word;
1317
- white-space: normal;
1318
- }
1319
- .spanrodio{
1320
- margin-right: 10px;
1321
- }
1322
- .div-photo{
1323
- width: auto;
1324
- height: auto;
1325
- /* margin-top: 10px; */
1326
- position: absolute;
1327
- bottom: 10px;
1328
- right: 10px;
1329
- }
1330
- .panel-self{
1331
- border-radius: 5px;
1332
- border:1px solid #c5e1f7;
1333
- //background-color: #F2F6FA;
1334
- }
1335
- .btn-photo{
1336
- border: 0;
1337
- border-radius: 7px;
1338
- background-color: #7dc1f4;
1339
- font: 15px PingFang-SC-Bold;
1340
- height: 20%;
1341
- }
1342
- </style>
1343
-
1
+ <template>
2
+ <div class="select-overspread repair-bg auto" style="padding-bottom:5px;">
3
+ <!--<div class="bq-parent" v-if="shutype == 'heng'">-->
4
+ <!--<blockquote class="blockquote">-->
5
+ <!--<p><span>{{repairitem.header}}</span><a @click="mute()" style="float:right" href="#" class="repair-mute-class"><img src="../../assets/novoice.png" width="25px;" alt=""><span style="margin-left:10px;color: #304A66">关闭声音</span></a></p>-->
6
+ <!--</blockquote>-->
7
+ <!--</div>-->
8
+ <div class="panel panel-default auto repair-info-content">
9
+ <div class="panel-body" style="padding: 0">
10
+ <!-- 安检项内容 -->
11
+ <div class="auto repair-info-content compatible" style="padding: 0">
12
+ <div class="row auto" style="padding: 0">
13
+ <div v-show="false" class="{{shuclass}}" v-if=" device.device != '燃气表'">
14
+ <button type="button" name="button" class="btn btn-primary" @click='adddetails()' :disabled="issee">增加</button>
15
+ </div>
16
+ <!--<div class="{{shuclass}}" v-if="device.device != '燃气表' && candelete">-->
17
+ <!--<button type="button" name="button" class="btn btn-primary" @click='deletedetails()' :disabled="issee">删除</button>-->
18
+ <!--</div>-->
19
+ <div class="shuclass1" v-show="row.isshow" v-for="(idxs,row) in f_items" style="padding: 4px; border:1px solid #D4D4D4;border-bottom: 0" >
20
+ <label v-if="row.type != 'radio' && row.type != 'text' && row.type != 'picture' && row.type != 'checkbox'" v-show="row.isshow" class="fivelabel">{{row.f_item_name}}<span v-if="row.unit">({{row.unit}})</span><br/>{{row.remark}}</label>
21
+ <label v-if="row.type == 'radio'" v-show="row.isshow" class="radiolabel">{{row.f_item_name}}<span v-if="row.unit">({{row.unit}})</span><br/>{{row.remark}}</label>
22
+ <label v-if="row.type == 'text'" v-show="row.isshow" class="textlabel1">{{row.f_item_name}}<span v-if="row.unit">({{row.unit}})</span><br/>{{row.remark}}</label>
23
+ <label v-if="row.type == 'picture' || row.type == 'checkbox'" v-show="row.isshow" class="textlabel">{{row.f_item_name}} <br/>{{row.remark}} <span v-show="row.verification_state" :style="{color:row.verification_state==='pass'?'green':'red'}">{{row.verification_text}}</span></label>
24
+ <!--<span v-if="show" style="font-weight:bold">{{row.f_content}}</span>-->
25
+ <!--<datepicker placeholder="请选择时间"-->
26
+ <!--:value.sync="row.f_content"-->
27
+ <!--v-model="row.f_content"-->
28
+ <!--:format="'yyyy-MM-dd'"-->
29
+ <!--v-if="!show && row.type == 'date'"-->
30
+ <!--:readonly="true"-->
31
+ <!--&gt;</datepicker>-->
32
+ <div style="clear: both" v-if="row.type == 'picture'" class="form-group col-sm-12" >
33
+ <div class="auto" >
34
+ <div class="panel">
35
+ <div class="panel-body panel-self" style="background-color: #F8F8F8;width: 160px;height: 160px;position: relative">
36
+ <div class="row" style="height: 160px;width:160px;overflow: scroll;top: 1px">
37
+ <div class="col-sm-4" v-show="row.f_path">
38
+ <img-self-android :src="row.f_path" :alt="row.f_item_name" width="140" height="140"></img-self-android>
39
+ </div>
40
+ <div class="col-sm-4" v-show="!row.f_path" @click="takePic(idxs, row.f_item_name)">
41
+ <img src="../../../assets/tackpic.png" :alt="点击拍摄照片" width="140" height="140"></img>
42
+ </div>
43
+ <img v-show="row.f_path" src="../../../assets/remove.png" :class="style__" @click="delfile(idxs, row.f_path)" v-if="role!='androidview'" style="width: 40px;height: 40px;position: absolute;left:110px;top:110px"></img>
44
+ </div>
45
+ </div>
46
+ </div>
47
+ </div>
48
+ </div>
49
+ <div style="float: left;width:60%" class="form-group" v-if="row.type == 'string'" v-show="row.isshow">
50
+ <input type="text" class="form-control" maxlength="100" v-model="row.f_item_value" :readonly="role == 'androidview' || row.readonly">
51
+ </div>
52
+ <div style="float: left;width:60%" class="form-group col-sm-12" v-if="row.type == 'date'" v-show="row.isshow">
53
+ <datepicker id="f_making_date" :placeholder= row.f_item_name
54
+ :value.sync="row.f_item_value"
55
+ v-if="row.type == 'date'"
56
+ v-show="row.isshow"
57
+ :disabled-days-of-Week="[]"
58
+ :format="'yyyy-MM-dd HH:mm:ss'"
59
+ :show-reset-button="reset" readonly="readonly">
60
+ </datepicker>
61
+ </div>
62
+
63
+ <div style="float: left;width:60%" class="form-group" v-if="!show && row.type == 'number'" v-show="row.isshow">
64
+ <input type="text" class="form-control" maxlength="100" v-model="row.f_item_value" onkeyup="value=value.replace(/[^\d\.-]/g,'')" :readonly="row.readonly">
65
+ </div>
66
+ <!--<input type="text" class="form-control" v-model="row.f_content" v-if="!show && row.type == 'string' && row.f_project != '表号'" :disabled="(!(ischecked == '有')) || issee" :readonly="issee">-->
67
+ <!--<input type="text" class="form-control" v-model="meternum" v-if="!show && row.type == 'string' && row.f_project == '表号' " :disabled="(!(ischecked == '有')) || issee" :readonly="issee" >-->
68
+ <!--<button type="button" name="button" class="btn btn-primary" @click="scan" v-if="!show && row.f_project == '表号' ">扫码</button>-->
69
+ <input-select v-if="row.type == 'inputSelector'"
70
+ v-show="row.isshow"
71
+ :value.sync="row.selected"
72
+ v-model="row.selected"
73
+ :readonly="false"
74
+ :options="row.options"
75
+ @change="changse"
76
+ @click="transelation(idxs)"></input-select>
77
+ <v-select style="float: left" :value.sync="row.selected"
78
+ v-model="row.selected"
79
+ v-if="row.type == 'selector'"
80
+ :search="false"
81
+ v-show="row.isshow"
82
+ placeholder='请选择'
83
+ :options="row.options"
84
+ :disabled="role == 'androidview' || row.readonly"
85
+ @change="changse"
86
+ @click="transelation(idxs)"
87
+ :multiple="row.multiple"
88
+ :close-on-select="!row.multiple" clear-button></v-select>
89
+ <div style="float: left;width: 30%" class="form-group" v-if="!show && row.type == 'radio'">
90
+ <div class="col-xs-6 col-sm-6 col-md-6" v-for="item in row.options">
91
+ <!-- <input type="radio" :name="row.f_item_name" @click="disSelect($parent.idxs,item.value)" :value="item.value" :disabled="(!(ischecked == '有')) || issee" v-model="row.f_item_value" >-->
92
+ <input type="radio" :name="row.f_item_name" :value="item.value" :disabled="(!(ischecked == '有')) || issee" v-model="row.f_item_value" >
93
+ <span>{{item.label}}</span>
94
+ </div>
95
+ </div>
96
+ <div v-if="!show && row.type == 'checkbox'" class="col-xs-12 col-sm-12 col-md-12" style="white-space: nowrap" >
97
+ <div style="float: left" v-for="item in row.options">
98
+ <input type="checkbox" :name="row.f_item_name" :value="item.value" :disabled="(!(ischecked == '有')) || issee" v-model="row.f_item_value">
99
+ <span>{{item.label}}</span>
100
+ </div>
101
+ </div>
102
+ <div style="clear: both">
103
+ <label v-if="row.f_item_value.indexOf('其他') >-1" class="fivelabel">其他</label>
104
+ <div style="float: left;width:60%" class="form-group" v-if="row.f_item_value.indexOf('其他') >-1">
105
+ <input type="text" class="form-control" maxlength="100" v-model="row.f_else" :readonly="role == 'androidview' || row.readonly">
106
+ </div>
107
+ </div>
108
+ <div style="clear: both">
109
+ <!-- <div class="form-group" style="display: flex;flex-wrap: wrap" v-if="(row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && (row.f_path != '' || row.f_is_defect != '') && (livedispose == 'true' || livedispose == true) " >-->
110
+ <!-- <label class="fivelabel">现场已处理</label>-->
111
+ <!-- <v-select :value="row.f_live_dispose"-->
112
+ <!-- :value-single="true"-->
113
+ <!-- :options="lives"-->
114
+ <!-- :disabled="role == 'androidview'"-->
115
+ <!-- @change="changlive"-->
116
+ <!-- @click="transelation(idxs)"-->
117
+ <!-- close-on-select clear-button></v-select>-->
118
+ <!-- </div>-->
119
+ <div class="form-group" style="display: flex;flex-wrap: wrap" v-if="(row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && (row.f_path != '' || row.f_is_defect != '') && (dealdispose == 'true' || dealdispose == true) " >
120
+ <label class="fivelabel">处理方式</label>
121
+ <v-select
122
+ :value="row.f_deal_dispose"
123
+ :value-single="true"
124
+ :options="deals"
125
+ :disabled="role == 'androidview'"
126
+ @change="changdeal"
127
+ @click="transelation(idxs)"
128
+ close-on-select clear-button>
129
+ </v-select>
130
+ </div>
131
+ <div style="display: flex;flex-wrap: wrap" v-if="row.f_deal_dispose == '自行处理' && this.showZXTime">
132
+ <label class="fivelabel">处理时效:</label>
133
+ <datepicker
134
+ :value.sync="row.f_handle_date"
135
+ v-model="row.f_handle_date"
136
+ :format="'yyyy-MM-dd 00:00:00'"
137
+ placeholder="请选择"
138
+ style="width: 60%">
139
+ </datepicker>
140
+ </div>
141
+ <div style="margin-left: 10px" class="form-group col-sm-10" v-if="(row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && row.tooltip != undefined && row.tooltip != '' ">
142
+ ☆{{row.tooltip}}
143
+ </div>
144
+ <div class="form-group col-sm-12" style="display: flex;flex-wrap: wrap" v-if="(row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && (row.f_path != '' || row.f_is_defect != '')">
145
+ <div class="auto" style="margin:1px;">
146
+ <div class="panel">
147
+ <div class="panel-body panel-self" style="background-color: #F8F8F8;width: 160px;height: 160px;position: relative">
148
+ <div class="col-xs-6" style="height: 160px;width:160px;overflow: scroll;top: 1px">
149
+ <div class="col-sm-4" v-show="row.f_path">
150
+ <img-self-android :src="row.f_path" :alt="row.f_item_name" width="140" height="140"></img-self-android>
151
+ </div>
152
+ <div class="col-sm-4" v-show="!row.f_path" @click="takePic(idxs, row.f_item_name)">
153
+ <img src="../../../assets/tackpic.png" :alt="点击拍摄照片" width="140" height="140"></img>
154
+ </div>
155
+ <img v-show="row.f_path" src="../../../assets/remove.png" :class="style__" @click="delfile(idxs, row.f_path)" v-if="role!='androidview'" style="width: 40px;height: 40px;position: absolute;left:110px;top:110px"></img>
156
+ </div>
157
+ <button v-if="isalbum" style="float: right" type="button" name="button" class="btn btn-primary btn-photo"
158
+ @click="takePic2(idxs, row.f_item_name)">相册
159
+ </button>
160
+ </div>
161
+ </div>
162
+ </div>
163
+ <!--多张隐患照片-->
164
+ <div class="auto" v-for="itemIndex in hiddenDangerImgNumber" style="margin: 1px;">
165
+ <div class="panel">
166
+ <div class="panel-body panel-self" style="background-color: #F8F8F8;width: 160px;height: 160px;position: relative">
167
+ <div class="col-xs-6" style="height: 160px;width:160px;overflow: scroll;top: 1px">
168
+ <div class="col-sm-4" v-show="row['f_p' + (itemIndex+1) + '_path']">
169
+ <img-self-android :src="row['f_p' + (itemIndex+1) + '_path']" :alt="row.f_item_name" width="140" height="140"></img-self-android>
170
+ </div>
171
+ <div class="col-sm-4" v-show="!row['f_p' + (itemIndex+1) + '_path']" @click="takePic(idxs, row.f_item_name,'f_p' + (itemIndex+1)+ '_path')">
172
+ <img src="../../../assets/tackpic.png" :alt="点击拍摄照片" width="140" height="140"></img>
173
+ </div>
174
+ <img v-show="row['f_p' + (itemIndex+1)+'_path']" src="../../../assets/remove.png" :class="style__" @click="delfile(idxs,row['f_p' + (itemIndex+1)+'_path'],'f_p' + (itemIndex+1)+ '_path')" v-if="role!='androidview'" style="width: 40px;height: 40px;position: absolute;left:110px;top:110px"></img>
175
+ </div >
176
+ <button v-if="isalbum" style="float: right" type="button" name="button" class="btn btn-primary btn-photo"
177
+ @click="takePic2(idxs, row.f_item_name,'f_p' + (itemIndex+1)+ '_path')">相册
178
+ </button>
179
+ </div>
180
+ </div>
181
+ </div>
182
+ <div style="display: flex;flex-wrap: wrap;margin-top: 10px" v-if="row.f_deal_dispose == '现场整改' && (row.type == 'selector' || row.type == 'radio' || row.type =='checkbox') && this.showXCImg">
183
+ <label class="fivelabel">整改照片:</label>
184
+ <div class="auto" style="margin:1px;">
185
+ <div class="panel">
186
+ <div class="panel-body panel-self" style="background-color: #F8F8F8;width: 160px;height: 160px;position: relative">
187
+ <div class="col-xs-6" style="height: 160px;width:160px;overflow: scroll;top: 1px">
188
+ <div class="col-sm-4" v-show="row.f_repair_path">
189
+ <img-self-android :src="row.f_repair_path" :alt="row.f_item_name" width="140" height="140"></img-self-android>
190
+ </div>
191
+ <div class="col-sm-4" v-show="!row.f_repair_path" @click="takePic(idxs, row.f_item_name,'f_repair_path',row.f_defect_level)">
192
+ <img src="../../../assets/tackpic.png" alt="点击拍摄照片" width="140" height="140"></img>
193
+ </div>
194
+ <img v-show="row.f_repair_path" src="../../../assets/remove.png" :class="style__" @click="delfile(idxs, row.f_repair_path, 'f_repair_path')" v-if="role!='androidview'" style="width: 40px;height: 40px;position: absolute;left:110px;top:110px"></img>
195
+ </div>
196
+ </div>
197
+ </div>
198
+ </div>
199
+ </div>
200
+ </div>
201
+ </div>
202
+
203
+ <!--<v-select :value.sync="row.f_content" :options='getOptions(row.f_project)' placeholder='请选择' :disabled="(!(ischecked == '有')) || issee" close-on-select :value-single="true" v-if="!show && row.type == 'selector' && row.f_project != '气表品牌'"-->
204
+ <!--&gt;</v-select>-->
205
+ <!--<v-select :value.sync="row.f_content" :options='getOptions(row.f_project)' @change="getgasmodel" placeholder='请选择' :disabled="(!(ischecked == '有')) || issee" close-on-select :value-single="true" v-if="!show && row.type == 'selector' && row.f_project == '气表品牌'"-->
206
+ <!--&gt;</v-select>-->
207
+ <!-- <div class="auto" v-if="!show && row.type == 'checkbox' ">-->
208
+ <!-- <input class="magic-checkbox" type="checkbox" id="shebeicheckbox"-->
209
+ <!-- :checked="row.f_content == '有'"-->
210
+ <!-- @click="switchDetails(row.f_project, $event)" :disabled="issee"/>-->
211
+ <!-- <label for="shebeicheckbox" style="width:150px;padding-bottom: 10px">{{row.f_project}}</label>-->
212
+ <!-- </div>-->
213
+ <!--<img-area :model="Detail.imgs" :sutitle="row.f_project" v-if="row.type == 'picture'" :disabled="issee"></img-area>-->
214
+ </div>
215
+ </div>
216
+ </div>
217
+ <div style="border-top: 1px solid #D4D4D4"></div>
218
+ </div>
219
+ </div>
220
+ </div>
221
+ </template>
222
+ <script>
223
+ import Vue from 'vue'
224
+ import * as Util from '../../Util'
225
+
226
+ export default {
227
+ title: '维修列表信息',
228
+ data() {
229
+ return {
230
+ // telphoneValid: '/^((0\\d{2,3}-\\d{7,8})|(1[3584]\\d{9}))$/',
231
+ // meterstyle:[],
232
+ hiddenDangerImgNumber:0,//隐患图片数
233
+ shuclass:'col-xs-12 col-sm-12 col-md-12 form-input-group mg8',
234
+ shuclass1:'col-xs-12 col-sm-12 col-md-12 mg8',
235
+ // labels:[],
236
+ meternum:'',
237
+ ischecked:'有',
238
+ gasmodel:'',
239
+ textstyle:'color: red',
240
+ paper: this.$parent.$parent.data,
241
+ f_items:[],
242
+ page:{},
243
+ selectindex:null,
244
+ lives:[{label: '是', value: '是'},{label: '否', value: '否'}],
245
+ deals:[{label: '现场处理', value: '现场处理'},{label: '自行处理', value: '自行处理'}],
246
+ f_live_dispose:'否',
247
+ f_deal_dispose:'未处理',
248
+ // 初始表底
249
+ f_initial_base: {},
250
+ // 气量异常差值 计算公式 => 气量异常差值 = 累计购气量 - (已用气量 - 初始表底) - 剩余气量
251
+ f_gas_aberrant_number: {},
252
+ // 金额异常差值 计算公式 => 金额异常差值 = 累计购金额 - 已用金额 - 剩余金额
253
+ f_fee_aberrant_number: {},
254
+ // 累购气量
255
+ f_total_gas: {},
256
+ // 累购金额
257
+ f_total_fee: {},
258
+ // 已用气量
259
+ f_table_base: {},
260
+ // 已用金额
261
+ f_fee_base: {},
262
+ // 剩余气量
263
+ f_gas_balance: {},
264
+ // 剩余金额
265
+ f_fee_balance: {},
266
+ // 表端剩余金额
267
+ f_table_balance: {},
268
+ // 气量异常差值允许误差
269
+
270
+ //物联网表数据存储
271
+ f_balance_amount:{},//物联网表剩余金额
272
+ f_meter_base:{},//物联网表读数
273
+ f_balance_amount1:{},//物联网表现场录入的表上剩余金额
274
+ f_meter_base1:{},//物联网表现场录入的表字轮数
275
+ f_meter_aberrant_number1: {},//物联网表 表数异常差值
276
+ f_fee_aberrant_number1: {},//物联网 表金额异常差值
277
+ gasDeviation: (
278
+ function (_this) {
279
+ let deviation = _this.$appdata.getSingleValue('气量异常差值允许误差')
280
+ if (deviation && !isNaN(deviation)) {
281
+ return deviation
282
+ } else {
283
+ return 0
284
+ }
285
+ }
286
+ )(this),
287
+ // 金额异常差值允许误差
288
+ feeDeviation: (
289
+ function (_this) {
290
+ let deviation = _this.$appdata.getSingleValue('金额异常差值允许误差')
291
+ if (deviation && !isNaN(deviation)) {
292
+ return deviation
293
+ } else {
294
+ return 0
295
+ }
296
+ }
297
+ )(this),
298
+ // 字轮异常差值允许误差
299
+ meterbase: (
300
+ function (_this) {
301
+ let deviation = _this.$appdata.getSingleValue('字轮异常差值允许误差')
302
+ if (deviation && !isNaN(deviation)) {
303
+ return deviation
304
+ } else {
305
+ return 0
306
+ }
307
+ }
308
+ )(this),
309
+ showElse:false, //控制其他选项是否显示
310
+ showXCImg: false, // 是否显示现场整改拍照选项
311
+ showZXTime: false, // 是否显示自行整改处理时效
312
+ isalbum:this.$appdata.getSingleValue('安检使用相册') || false,
313
+ }
314
+ },
315
+ props: ['config','device','idx','operation','role'],
316
+ // props: {
317
+ // // 维修对应的用户数据收集
318
+ // model: {
319
+ // type: Object
320
+ // },
321
+ // service:{
322
+ // type: Object
323
+ // },
324
+ // show: {
325
+ // type: Boolean,
326
+ // default: false
327
+ // },
328
+ // repairitem:{
329
+ // type: Object
330
+ // },
331
+ // shutype:'heng',
332
+ // tabs:{
333
+ // type: Object
334
+ // },
335
+ // repairdetails:{
336
+ // type: Object
337
+ // },
338
+ // faultshow:{
339
+ // type: Object
340
+ // },
341
+ // issee:''
342
+ // },
343
+ methods: {
344
+ changse(val){
345
+ if(val == undefined){
346
+ return
347
+ }
348
+ if(this.selectindex != null) {
349
+ if(this.f_items[this.selectindex].type == 'selector'){
350
+ this.f_items[this.selectindex].f_item_value = val
351
+ }else if(this.f_items[this.selectindex].type == 'inputSelector'){
352
+ this.f_items[this.selectindex].f_item_value = val.target.value
353
+ }
354
+ }
355
+ },
356
+ changlive(val){
357
+ if(val == undefined){
358
+ return
359
+ }
360
+ if(this.selectindex != null) {
361
+ this.f_items[this.selectindex].f_live_dispose = val
362
+ }
363
+ },
364
+ changdeal(val){
365
+ if(val == undefined){
366
+ this.f_items[this.selectindex].f_deal_dispose = ''
367
+ return
368
+ }
369
+ if(this.selectindex != null) {
370
+ this.f_items[this.selectindex].f_deal_dispose = val
371
+ }
372
+ },
373
+ switchDetails(detailsType, event){
374
+ if (event.srcElement.checked) {
375
+ for(var i = 0;i<this.Detail.details.length;i++){
376
+ if(this.Detail.details[i].f_project == detailsType){
377
+ this.Detail.details[i].f_content = '有'
378
+ this.ischecked = '有'
379
+ return
380
+ }
381
+ }
382
+ } else {
383
+ this.Detail.imgs = []
384
+ for(var i = 0;i<this.Detail.details.length;i++){
385
+ if(this.Detail.details[i].f_project == detailsType){
386
+ this.Detail.details[i].f_content = '无'
387
+ this.ischecked = '无'
388
+ }else{
389
+ this.Detail.details[i].f_content = ''
390
+ }
391
+ }
392
+ }
393
+ },
394
+ getgasmodel(val){
395
+ this.gasmodel = val
396
+ },
397
+ getradios(val,flag){
398
+ let Reoptions = []
399
+ for (let i = 0;i<this.repairdetails.length;i++) {
400
+ var t = false
401
+ if(this.repairdetails[i].f_type == this.repairitem.header ){
402
+ for(var j =0;j<this.repairdetails[i].details.length;j++){
403
+ if(this.repairdetails[i].details[j].f_project == val ){
404
+ Reoptions = this.repairdetails[i].details[j].options
405
+ t = true
406
+ break
407
+ }
408
+ }
409
+ }
410
+ if(t){
411
+ break
412
+ }
413
+ }
414
+ for(let j = 0;j<Reoptions.length;j++){
415
+ if(Reoptions[j].data == flag){
416
+ for(var e = 0;e<this.Detail.details.length;e++){
417
+ if(this.Detail.details[e].f_project == val){
418
+ this.Detail.details[e].f_status = Reoptions[j].f_status
419
+ return
420
+ }
421
+ }
422
+ break
423
+ }
424
+ }
425
+ },
426
+ deletedetails(){
427
+ this.$showMessage('该操作会删除所填信息,是否继续!', ['confirm', 'cancel']).then((res) => {
428
+ if (res === 'confirm') {
429
+ for(var i = 0;i<this.tabs.length;i++){
430
+ if(this.tabs[i].number == this.repairitem.number){
431
+ this.tabs.splice(i, 1)
432
+ this.model.servicerepair.splice(this.repairitem.number, 1)
433
+ for(let t = i;t < this.tabs.length;t++ ) {
434
+ this.tabs[t].number -= 1
435
+ }
436
+ return
437
+ }
438
+ }
439
+ }
440
+ })
441
+ },
442
+ takePic(prop, title, pathname='null') {
443
+ if (this.role == 'androidview') {
444
+ return
445
+ }
446
+ HostApp.__callback__ = this.cameraCallBack
447
+ HostApp.__this__ = this
448
+ //tag
449
+ let fileName
450
+ if (pathname == 'null') {
451
+ if (!this.f_items[prop].f_path || this.f_items[prop].f_path.includes("nopic.png")) {
452
+ fileName = Util.guid() + '-' + 'device'+this.device.n + '-' + this.idx + '-'+'f_items'+prop+ '.jpg'
453
+ } else {
454
+ fileName = Util.getFileName(this.f_items[prop].f_path)
455
+ }
456
+ } else {
457
+ if (!this.f_items[prop][pathname] || this.f_items[prop][pathname].includes("nopic.png")) {
458
+ fileName = Util.guid() + '-' + 'device'+this.device.n + '-' + this.idx + '-'+'f_items'+prop+ '.jpg'
459
+ } else {
460
+ fileName = Util.getFileName(this.f_items[prop][pathname])
461
+ }
462
+ }
463
+ let jingweidu = ''
464
+ if (this.$parent.$parent.is_has_jingweidu == 'true'){
465
+ const obj = HostApp.getGpsDetailAddress()
466
+ jingweidu = '\t经度:' + obj.longitude+ '\t纬度:' + obj.latitude
467
+ this.f_items[prop].f_longitude = obj.longitude
468
+ this.f_items[prop].f_latitude = obj.latitude
469
+ }
470
+ //tag
471
+ //tag
472
+ HostApp._open_a_page({type: 'boomerang',
473
+ page: 'com.aofeng.hybrid.android.peripheral.CameraActivity',
474
+ param: {file: fileName, requestCode: 111, callback:'javascript:HostApp.__callback__("'+ prop +'","'+ title +'", "%s","'+pathname+'");', watermark: title + '\t时间:'+ Util.toStandardTimeString() + '\t' + Vue.user.name + jingweidu}
475
+ })
476
+ },
477
+ takePic2(prop, title, pathname='null') {
478
+ if (this.role == 'androidview') {
479
+ return
480
+ }
481
+ HostApp.__callback__ = this.cameraCallBack
482
+ HostApp.__this__ = this
483
+ //tag
484
+ let fileName
485
+ if (pathname == 'null') {
486
+ if (!this.f_items[prop].f_path || this.f_items[prop].f_path.includes("nopic.png")) {
487
+ fileName = Util.guid() + '-' + 'device' + this.device.n + '-' + this.idx + '-' + 'f_items' + prop + '.jpg'
488
+ } else {
489
+ fileName = Util.getFileName(this.f_items[prop].f_path)
490
+ }
491
+ } else {
492
+ if (!this.f_items[prop][pathname] || this.f_items[prop][pathname].includes("nopic.png")) {
493
+ fileName = Util.guid() + '-' + 'device' + this.device.n + '-' + this.idx + '-' + 'f_items' + prop + '.jpg'
494
+ } else {
495
+ fileName = Util.getFileName(this.f_items[prop][pathname])
496
+ }
497
+ }
498
+ let jingweidu = ''
499
+ if (this.$parent.$parent.is_has_jingweidu == 'true'){
500
+ const obj = HostApp.getGpsDetailAddress()
501
+ jingweidu = '\t经度:' + obj.longitude+ '\t纬度:' + obj.latitude
502
+ this.f_items[prop].f_longitude = obj.longitude
503
+ this.f_items[prop].f_latitude = obj.latitude
504
+ }
505
+ //tag
506
+ //tag
507
+ HostApp._open_a_page({type: 'boomerang',
508
+ page: 'com.aofeng.hybrid.android.peripheral.ActionPickActivity',
509
+ param: {file: fileName, requestCode: 111, callback:'javascript:HostApp.__callback__("'+ prop +'","'+ title +'", "%s","'+pathname+'");', watermark: title + '\t时间:'+ Util.toStandardTimeString() + '\t' + Vue.user.name + jingweidu}
510
+ })
511
+ },
512
+ cameraCallBack(prop,title, fileName,pathname) {
513
+ //tag
514
+ if (pathname == 'null') {
515
+ //tag
516
+ HostApp.__this__.$set( 'f_items['+prop+'].f_path', fileName + '?' + Math.random())
517
+ //tag
518
+ HostApp.__callback__ = null
519
+ HostApp.__this__ = null
520
+ } else {
521
+ //tag
522
+ //tag)
523
+ HostApp.__this__.$set( 'f_items['+prop+'].'+pathname+'', fileName + '?' + Math.random())
524
+ HostApp.__callback__ = null
525
+ HostApp.__this__ = null
526
+ }
527
+ if(this.f_items[prop].is_verification){
528
+ let path=fileName.replace('http://newimg','')
529
+ path=path.replace('file://','')
530
+ console.log('fileName',fileName)
531
+ console.log(path)
532
+ let res=HostApp.pictureVerificationAI(path,title)
533
+ if(res.code==200){
534
+ if(res.type_result){
535
+ // this.$showMessage("检测通过,当前照片为"+title)
536
+ this.f_items[prop].verification_text=`检测通过,当前照片为 ${title}`
537
+ this.f_items[prop].verification_state='pass'
538
+ }else{
539
+ // this.$showMessage("检测失败,未识别到当前照片为 "+title+",请重新拍摄!")
540
+ this.f_items[prop].verification_text=`检测失败,未识别到当前照片为'${title}',请重新拍摄!`
541
+ this.f_items[prop].verification_state='npass'
542
+ }
543
+ }else{
544
+ // this.$showMessage("检测失败,请重试!")
545
+ this.f_items[prop].verification_text=`检测失败,请重试!`
546
+ this.f_items[prop].verification_state='npass'
547
+ }
548
+ }
549
+ },
550
+ delfile(prop, fileName, pathname='null') {
551
+ if (pathname == 'null') {
552
+ //tag
553
+ //tag)
554
+ if(fileName == Vue.nopic){
555
+ return
556
+ } else {
557
+ HostApp.delfile(fileName)
558
+ this.f_items[prop].f_path = Vue.nopic
559
+ }
560
+ }else {
561
+ //tag
562
+ //tag)
563
+ if(fileName == Vue.nopic){
564
+ return
565
+ } else {
566
+ HostApp.delfile(fileName)
567
+ this.f_items[prop][pathname] = Vue.nopic
568
+ }
569
+ }
570
+ },
571
+ adddetails(){
572
+ // 下标作为序号,取值用。 增加 序号得依次增加
573
+ if(this.tabs.length > 0){
574
+ for(let i = this.tabs.length-1;i > 0 ;i-- ){
575
+ if(this.tabs[i].header == this.repairitem.header){
576
+ if(this.model.servicerepair.length > 0){
577
+ for(let j = this.model.servicerepair.length -1;j > -1;j-- ){
578
+ if(this.model.servicerepair[j].f_type == this.repairitem.header){
579
+ this.model.servicerepair.splice(j+1, 0, Object.assign({}, JSON.parse(JSON.stringify(this.tabs[i].details))))
580
+ this.tabs.splice(i+1, 0, {header: `${this.repairitem.header}`,details:this.tabs[i].details,complete:'repair-details',class:'repair-details-class',number:j+1,items:this.tabs[i].items})
581
+ for(let t = i+2;t < this.tabs.length;t++ ) {
582
+ this.tabs[t].number += 1
583
+ }
584
+ this.faultshow.number += this.faultshow.number + 1
585
+ return
586
+ }
587
+ }
588
+ }
589
+ }
590
+ }
591
+ }
592
+ },
593
+ transelation(val){
594
+ this.selectindex = val
595
+ },
596
+ towatch(){
597
+ for(let n in this.f_items){
598
+ if(typeof this.f_items[n]=='function'){
599
+ continue
600
+ }
601
+ if(this.f_items[n].type == 'selector' || this.f_items[n].type == 'inputSelector'){
602
+ // 监听下拉框,如果有隐患,需要拍照
603
+ this.$watch('f_items['+n+'].selected',function(val) {
604
+ // 下拉框值
605
+ //tag)
606
+ // 下拉框所属设备
607
+ //tag
608
+ // 下拉框所属项
609
+ //tag
610
+ if (val == undefined || val.length == 0 || val[0] == ''){
611
+ this.f_items[n].f_path = ''
612
+ this.f_items[n].f_is_defect = ''
613
+ this.f_items[n].f_defect_level = ''
614
+ this.f_items[n].f_live_dispose = ''
615
+ this.f_items[n].f_deal_dispose = ''
616
+ this.f_items[n].tooltip = ''
617
+ this.f_items[n].f_else = ''
618
+ return
619
+ }
620
+ let shImage = false
621
+ if(val.indexOf('其他') == -1){
622
+ this.f_items[n].f_else = ''
623
+ }
624
+ // if(this.config[this.device.device].items[item].type == 'selector'){
625
+ // this.f_items[n].f_item_value = val
626
+ // }else if(this.config[this.device.device].items[item].type == 'inputSelector'){
627
+ // this.f_items[n].f_item_value = val[0]
628
+ // }
629
+ // 在配置中查找该项
630
+ for (let item in this.config[this.device.device].items) {
631
+ if(typeof this.config[this.device.device].items[item]=='function'){
632
+ continue
633
+ }
634
+ let type = this.config[this.device.device].items[item].type
635
+ let multiple = false
636
+ if(this.config[this.device.device].items[item].multiple){
637
+ multiple = this.config[this.device.device].items[item].multiple === 'true' || this.config[this.device.device].items[item].multiple === true
638
+ }
639
+ let options = this.config[this.device.device].items[item].options
640
+ if ((this.config[this.device.device].items[item].type == 'selector' || this.config[this.device.device].items[item].type == 'inputSelector') && this.config[this.device.device].items[item].itemname == this.f_items[n].f_item_name) {
641
+ for (let i in options) {
642
+ if(typeof options[i]=='function'){
643
+ continue
644
+ }
645
+ let value
646
+ if(this.config[this.device.device].items[item].type == 'selector' && this.config[this.device.device].items[item].multiple == false){
647
+ value = val[0]
648
+ }else if (this.config[this.device.device].items[item].type == 'inputSelector'){
649
+ value = val
650
+ }
651
+ //tag)
652
+ // 如果未选择,清空图片、隐患信息等
653
+ if((type == 'selector' && val.length == 0) || (type == 'inputSelector' && val == '')){
654
+ this.f_items[n].f_path = ''
655
+ this.f_items[n].f_is_defect = ''
656
+ this.f_items[n].f_defect_level = ''
657
+ this.f_items[n].f_live_dispose = ''
658
+ this.f_items[n].f_deal_dispose = ''
659
+ this.f_items[n].tooltip = ''
660
+ }
661
+ if((type == 'selector' && multiple == false && options[i].data == val[0]) || (type == 'inputSelector' && options[i].data == val) || (type == 'selector' && multiple == true && val.indexOf(options[i].data) > -1)){
662
+ // 找到选中的项了
663
+ //tag
664
+ if(options[i].isdefect == true ){
665
+ shImage = true
666
+ }
667
+ if(options[i].isdefect == false || this.f_items[n].f_item_value == ''){
668
+ shImage = false
669
+ }
670
+ //tag
671
+ if(shImage){
672
+ this.f_items[n].f_is_defect =true
673
+ this.f_items[n].f_defect_level = options[i].level
674
+ if (!multiple){
675
+ this.f_items[n].f_path = Vue.nopic
676
+ }
677
+ this.f_items[n].f_live_dispose = '否'
678
+ this.f_items[n].f_deal_dispose = '未处理'
679
+ //tag
680
+ this.f_items[n].tooltip= options[i].tooltip
681
+ }else{
682
+ this.f_items[n].f_path = ''
683
+ this.f_items[n].f_is_defect = ''
684
+ this.f_items[n].f_defect_level = ''
685
+ this.f_items[n].f_live_dispose = ''
686
+ this.f_items[n].f_deal_dispose = ''
687
+ this.f_items[n].tooltip = ''
688
+ }
689
+ }
690
+ }
691
+ }
692
+ }
693
+ }
694
+ )
695
+ // this.$watch('other',function(val){
696
+ // //tag
697
+ // if(this.selectindex != null) {
698
+ // let index = this.f_items[this.selectindex].f_item_value.indexOf('其他')
699
+ // if(index > -1){
700
+ // this.f_items[this.selectindex].f_item_value.splice(index,1,this.other)
701
+ // }
702
+ // }
703
+ //
704
+ // })
705
+ }else if(this.f_items[n].type == 'radio') {
706
+ // 监听单选框,如果有隐患,需要拍照
707
+ this.$watch('f_items[' + n + '].f_item_value', function (val) {
708
+ //tag)
709
+ let options = this.f_items[n].options
710
+ //tag)
711
+ for (let i = 0; i < options.length; i++) {
712
+ //tag)
713
+ // 找到选中的项了
714
+ if (options[i].value == val) {
715
+ // 如果有隐患,拍图片
716
+ if (options[i].isdefect) {
717
+ this.f_items[n].f_is_defect = true
718
+ this.f_items[n].f_defect_level = options[i].level
719
+ this.f_items[n].f_path = Vue.nopic
720
+ this.f_items[n].f_live_dispose = '否'
721
+ this.f_items[n].f_deal_dispose = '未处理'
722
+ this.f_items[n].tooltip = options[i].tooltip
723
+ //tag)
724
+ return
725
+ }
726
+ }
727
+ }
728
+ this.f_items[n].f_path = ''
729
+ this.f_items[n].f_is_defect = ''
730
+ this.f_items[n].f_defect_level = ''
731
+ this.f_items[n].f_live_dispose = ''
732
+ this.f_items[n].f_deal_dispose = ''
733
+ this.f_items[n].tooltip = ''
734
+ })
735
+ }else if(this.f_items[n].type == 'checkbox') {
736
+ // 监听单选框,如果有隐患,需要拍照
737
+ this.$watch('f_items[' + n + '].f_item_value', function (val) {
738
+ //tag)
739
+ // 如果是手动赋值,不执行下面逻辑
740
+ if (this.f_items[n].isReSet) {
741
+ this.f_items[n].isReSet = false
742
+ return
743
+ }
744
+ let options = this.f_items[n].options
745
+ //tag)
746
+ // 取出选中项中有隐患的详细信息
747
+ let selected = options.filter(item => { return val.indexOf(item.value) != -1 && item.isdefect })
748
+
749
+ if(selected.length > 0){
750
+ // 防止赋值无限调用
751
+ this.f_items[n].isReSet = true
752
+ let selectList = selected.map(item => {return item.value})
753
+ // 如果选中的是非隐患项,取消选中isdefect为true的
754
+ if (selectList.indexOf(val[val.length - 1]) == -1) {
755
+ this.f_items[n].f_item_value = val.filter(item => {return selectList.indexOf(item) == -1})
756
+ this.f_items[n].f_path = ''
757
+ this.f_items[n].f_is_defect = ''
758
+ this.f_items[n].f_defect_level = ''
759
+ this.f_items[n].f_live_dispose = ''
760
+ this.f_items[n].f_deal_dispose = ''
761
+ this.f_items[n].tooltip = ''
762
+ return
763
+ }
764
+ // 如果选中的是隐患项,取消选中isdefect为false的
765
+ this.f_items[n].f_item_value = selectList
766
+ // 如果第一次选择隐患项,初始化
767
+ if (!this.f_items[n].f_is_defect) {
768
+ this.f_items[n].f_is_defect = true
769
+ this.f_items[n].f_defect_level = selected[0].level
770
+ this.f_items[n].f_path = Vue.nopic
771
+ this.f_items[n].f_live_dispose = '否'
772
+ this.f_items[n].f_deal_dispose = '未处理'
773
+ //tag
774
+ this.f_items[n].tooltip = selected[0].tooltip
775
+ }
776
+ //tag)
777
+ return
778
+ }
779
+ this.f_items[n].f_path = ''
780
+ this.f_items[n].f_is_defect = ''
781
+ this.f_items[n].f_defect_level = ''
782
+ this.f_items[n].f_live_dispose = ''
783
+ this.f_items[n].f_deal_dispose = ''
784
+ this.f_items[n].tooltip = ''
785
+ })
786
+ }
787
+ }
788
+ //tag)
789
+ },
790
+ getGasAberrantNumber(val) {
791
+ //tag
792
+ if(!this.f_table_base.index || !this.f_gas_balance.index){
793
+ //tag
794
+ return
795
+ }
796
+ // 先清空
797
+ this.f_items[this.f_gas_aberrant_number.index].f_item_value = null
798
+ this.f_items[this.f_gas_aberrant_number.index].f_is_defect = false
799
+ if(val=='已用气量'){
800
+ //剩余气量 = 累购-已用
801
+ this.f_items[this.f_gas_balance.index].f_item_value= (this.f_items[this.f_total_gas.index].f_item_value-this.f_items[this.f_table_base.index].f_item_value).toFixed(2)
802
+ if (isNaN(this.f_items[this.f_gas_balance.index].f_item_value)) {
803
+ this.f_items[this.f_gas_balance.index].f_item_value = null
804
+ }
805
+ }
806
+
807
+ // 只有两个值都填了才会计算
808
+ if (!this.f_items[this.f_table_base.index].f_item_value || !this.f_items[this.f_gas_balance.index].f_item_value) {
809
+ return
810
+ }
811
+ //tag)
812
+ //tag
813
+ //tag
814
+
815
+ // 计算公式 => 气量异常差值 = 累计购气量 - (已用气量 - 初始表底) - 剩余气量
816
+ this.f_items[this.f_gas_aberrant_number.index].f_item_value = this.f_items[this.f_total_gas.index].f_item_value - this.f_items[this.f_gas_balance.index].f_item_value - (this.f_items[this.f_table_base.index].f_item_value - (this.f_initial_base.index?this.f_items[this.f_initial_base.index].f_item_value:0))
817
+ this.f_items[this.f_gas_aberrant_number.index].f_item_value = this.f_items[this.f_gas_aberrant_number.index].f_item_value.toFixed(3)
818
+ // 如果数值有误,清空结果s
819
+ if (isNaN(this.f_items[this.f_gas_aberrant_number.index].f_item_value)) {
820
+ this.f_items[this.f_gas_aberrant_number.index].f_item_value = null
821
+ }
822
+ //tag ===> ' + Math.abs(this.f_items[this.f_gas_aberrant_number.index].f_item_value))
823
+ //tag ===> ' + JSON.stringify(Number(this.gasDeviation)))
824
+ // 计算差值是否在范围内
825
+ if (Math.abs(this.f_items[this.f_gas_aberrant_number.index].f_item_value) > Number(this.gasDeviation)|| Math.abs(this.f_items[this.f_gas_aberrant_number.index].f_item_value) < Number(this.gasDeviation) * -1) {
826
+ this.f_items[this.f_gas_aberrant_number.index].f_is_defect = true
827
+ this.f_items[this.f_gas_aberrant_number.index].f_deal_dispose = '未处理'
828
+ }else{
829
+ this.f_items[this.f_gas_aberrant_number.index].f_is_defect = null
830
+ this.f_items[this.f_gas_aberrant_number.index].f_deal_dispose = null
831
+ }
832
+
833
+ //tag)
834
+ },
835
+ getFeeAberrantNumber(val) {
836
+ //tag
837
+ // 只有两个值都填了才会计算
838
+ if(!this.f_fee_base.index || !this.f_fee_balance.index){
839
+ //tag
840
+ return
841
+ }
842
+ // 先清空
843
+ this.f_items[this.f_fee_aberrant_number.index].f_item_value = null
844
+ this.f_items[this.f_fee_aberrant_number.index].f_is_defect = false
845
+
846
+ if(val=='已用金额'){
847
+ this.f_items[this.f_fee_balance.index].f_item_value=(this.f_items[this.f_total_fee.index].f_item_value-this.f_items[this.f_fee_base.index].f_item_value).toFixed(3)
848
+ if (isNaN(this.f_items[this.f_fee_balance.index].f_item_value)) {
849
+ this.f_items[this.f_fee_balance.index].f_item_value = null
850
+ }
851
+ }
852
+
853
+ if (!this.f_items[this.f_fee_base.index].f_item_value || !this.f_items[this.f_fee_balance.index].f_item_value) {
854
+ return
855
+ }
856
+
857
+ // 计算公式 => 金额异常差值 = 累计购金额 - 已用金额 - 剩余金额
858
+ this.f_items[this.f_fee_aberrant_number.index].f_item_value = this.f_items[this.f_total_fee.index].f_item_value - this.f_items[this.f_fee_balance.index].f_item_value - this.f_items[this.f_fee_base.index].f_item_value
859
+ this.f_items[this.f_fee_aberrant_number.index].f_item_value = this.f_items[this.f_fee_aberrant_number.index].f_item_value.toFixed(3)
860
+ if (isNaN(this.f_items[this.f_fee_aberrant_number.index].f_item_value)) {
861
+ this.f_items[this.f_fee_aberrant_number.index].f_item_value = null
862
+ }
863
+ //tag ===> ' + Math.abs(this.f_items[this.f_fee_aberrant_number.index].f_item_value))
864
+ //tag ===> ' + JSON.stringify(Number(this.feeDeviation)))
865
+ // 计算差值是否在范围内
866
+ if (Math.abs(this.f_items[this.f_fee_aberrant_number.index].f_item_value) > Number(this.feeDeviation)) {
867
+ this.f_items[this.f_fee_aberrant_number.index].f_is_defect = true
868
+ this.f_items[this.f_fee_aberrant_number.index].f_deal_dispose = '未处理'
869
+ }else{
870
+ this.f_items[this.f_fee_aberrant_number.index].f_is_defect = null
871
+ this.f_items[this.f_fee_aberrant_number.index].f_deal_dispose = null
872
+ }
873
+
874
+ //tag)
875
+ },
876
+ // 计算剩余金额和剩余金额差值
877
+ getFeeAberrantNumber2(val) {
878
+ //tag
879
+ // 只有两个值都填了才会计算
880
+ if(!this.f_table_balance.index || !this.f_fee_balance.index){
881
+ //tag
882
+ return
883
+ }
884
+ // 先清空
885
+ this.f_items[this.f_fee_aberrant_number.index].f_item_value = null
886
+ this.f_items[this.f_fee_aberrant_number.index].f_is_defect = false
887
+
888
+ // 计算公式 => 金额异常差值 = 系统剩余金额 - 表端剩余金额
889
+ this.f_items[this.f_fee_aberrant_number.index].f_item_value = this.f_items[this.f_fee_balance.index].f_item_value - this.f_items[this.f_table_balance.index].f_item_value
890
+ this.f_items[this.f_fee_aberrant_number.index].f_item_value = this.f_items[this.f_fee_aberrant_number.index].f_item_value.toFixed(3)
891
+ if (isNaN(this.f_items[this.f_fee_aberrant_number.index].f_item_value)) {
892
+ this.f_items[this.f_fee_aberrant_number.index].f_item_value = null
893
+ }
894
+ //tag ===> ' + Math.abs(this.f_items[this.f_fee_aberrant_number.index].f_item_value))
895
+ //tag ===> ' + JSON.stringify(Number(this.feeDeviation)))
896
+ // 计算差值是否在范围内
897
+ if (Math.abs(this.f_items[this.f_fee_aberrant_number.index].f_item_value) > Number(this.feeDeviation)) {
898
+ this.f_items[this.f_fee_aberrant_number.index].f_is_defect = true
899
+ this.f_items[this.f_fee_aberrant_number.index].f_deal_dispose = '未处理'
900
+ }else{
901
+ this.f_items[this.f_fee_aberrant_number.index].f_is_defect = null
902
+ this.f_items[this.f_fee_aberrant_number.index].f_deal_dispose = null
903
+ }
904
+ console.log('--------------------------------')
905
+ console.log(this.f_items[this.f_fee_aberrant_number.index].f_item_value)
906
+
907
+ //tag)
908
+ },
909
+ //物联网表字轮数改变触发
910
+ getmeteraberrantnumber() {
911
+ //tag
912
+
913
+ // 先清空
914
+ this.f_items[this.f_meter_aberrant_number1.index].f_item_value = null
915
+ this.f_items[this.f_meter_aberrant_number1.index].f_is_defect = false
916
+ //tag
917
+ // 只有两个值都填了才会计算
918
+ if (!this.f_items[this.f_meter_base.index].f_item_value || !this.f_items[this.f_meter_base1.index].f_item_value) {
919
+ return
920
+ }
921
+ //tag
922
+ // 计算公式 => 表数异常差值= - 字轮数 - 后台表读数
923
+ this.f_items[this.f_meter_aberrant_number1.index].f_item_value = this.f_items[this.f_meter_base1.index].f_item_value - this.f_items[this.f_meter_base.index].f_item_value
924
+ this.f_items[this.f_meter_aberrant_number1.index].f_item_value = this.f_items[this.f_meter_aberrant_number1.index].f_item_value.toFixed(3)
925
+ if (isNaN(this.f_items[this.f_meter_aberrant_number1.index].f_item_value)) {
926
+ this.f_items[this.f_meter_aberrant_number1.index].f_item_value = null
927
+ }
928
+ //tag ===> ' + Math.abs(this.f_items[this.f_meter_aberrant_number1.index].f_item_value))
929
+ // 计算差值是否在范围内
930
+ //tag)
931
+ if (Math.abs(this.f_items[this.f_meter_aberrant_number1.index].f_item_value) > Number(this.meterbase)){
932
+ this.f_items[this.f_meter_aberrant_number1.index].f_is_defect = true
933
+ }
934
+
935
+ //tag)
936
+ },
937
+
938
+ disSelect(index, itemValue) {
939
+ //tag)
940
+ //tag)
941
+ if (this.f_items[index].f_item_value == itemValue) {
942
+ this.$set(`f_items[${index}].f_item_value`, '')
943
+ }
944
+ }
945
+ },
946
+ ready() {
947
+ //tag
948
+ //tag
949
+ if(Vue.config.safecheck != undefined){
950
+ if(Vue.config.safecheck.ApproveConfig != undefined){
951
+ if(Vue.config.safecheck.ApproveConfig.livedispose != undefined) {
952
+ this.livedispose = Vue.config.safecheck.ApproveConfig.livedispose
953
+ }
954
+ if(Vue.config.safecheck.ApproveConfig.dealdispose != undefined) {
955
+ this.dealdispose = Vue.config.safecheck.ApproveConfig.dealdispose
956
+ }
957
+ if(Vue.config.safecheck.ApproveConfig.showtorepair) {
958
+ this.deals=[{label: '现场整改', value: '现场整改'},
959
+ {label: '自行处理', value: '自行处理'},
960
+ {label: '转维修', value: '报修'}
961
+ ]
962
+ }
963
+ if(Vue.config.safecheck.ApproveConfig.Processing) {
964
+ if(Vue.config.safecheck.ApproveConfig.Processing.length > 0){
965
+ this.deals = Vue.config.safecheck.ApproveConfig.Processing
966
+ }
967
+ }
968
+ if(Vue.config.safecheck.ApproveConfig.showXCImg) {
969
+ this.showXCImg = true
970
+ }
971
+ if(Vue.config.safecheck.ApproveConfig.showZXTime) {
972
+ this.showZXTime = true
973
+ }
974
+ if(Vue.config.safecheck.ApproveConfig.showtorepair) {
975
+ }
976
+ if(Vue.config.safecheck.ApproveConfig.hiddendanger != undefined) {
977
+ if (parseInt(Vue.config.safecheck.ApproveConfig.hiddendanger) >= 5) {
978
+ this.hiddenDangerImgNumber = 5
979
+ }else {
980
+ this.hiddenDangerImgNumber = parseInt(Vue.config.safecheck.ApproveConfig.hiddendanger)
981
+ }
982
+ }
983
+ }
984
+ }
985
+ //tag
986
+ //tag)
987
+ //tag)
988
+ //tag)
989
+ //创建页面所需数据
990
+ this.$set('piece', this.paper['device'+this.device.n][this.idx])
991
+ //tag)
992
+ //tag)
993
+ let n = 0
994
+ for (let item in this.config[this.device.device].items) {
995
+ if(typeof this.config[this.device.device].items[item]=='function'){
996
+ continue
997
+ }
998
+ let index = item
999
+ this.$set('page.options' + index, [])
1000
+ //tag)
1001
+ //tag)
1002
+ //tag)
1003
+ // 先根据配置组接页面
1004
+ let f_item_value
1005
+ if(this.config[this.device.device].items[item].type == 'selector' || this.config[this.device.device].items[item].type == 'checkbox'){
1006
+ f_item_value = []
1007
+ // 判断选项的默认值
1008
+ for (let defitem in this.config[this.device.device].items[item].options) {
1009
+ if(typeof this.config[this.device.device].items[item].options[defitem]=='function'){
1010
+ continue
1011
+ }
1012
+ let defopt = this.config[this.device.device].items[item].options[defitem]
1013
+ if (defopt.isdefault) {
1014
+ //tag
1015
+ f_item_value[0] = defopt.data
1016
+ }
1017
+ }
1018
+ // if(this.config[this.device.device].items[item].data){
1019
+ // f_item_value.push(this.config[this.device.device].items[item].data)
1020
+ // }
1021
+ }else if(this.config[this.device.device].items[item].type == 'radio'){
1022
+ //为radio添加默认值
1023
+ f_item_value=''
1024
+ //tag)
1025
+ for (let defitem in this.config[this.device.device].items[item].options) {
1026
+ if(typeof this.config[this.device.device].items[item].options[defitem]=='function'){
1027
+ continue
1028
+ }
1029
+ //tag)
1030
+ let defopt = this.config[this.device.device].items[item].options[defitem]
1031
+ if (defopt.isdefault) {
1032
+ //tag)
1033
+ f_item_value = defopt.data
1034
+ }
1035
+ }
1036
+ }else{
1037
+ f_item_value = this.config[this.device.device].items[item].data ? this.config[this.device.device].items[item].data : ''
1038
+ }
1039
+ //tag)
1040
+ let it = {
1041
+ type: this.config[this.device.device].items[item].type,
1042
+ f_item_name: this.config[this.device.device].items[item].itemname,
1043
+ checkmust: this.config[this.device.device].items[item].checkmust,
1044
+ f_item_value: this.config[this.device.device].items[item].f_item_value || f_item_value,
1045
+ is_verification:this.config[this.device.device].items[item].is_verification,
1046
+ verification_text:'',
1047
+ verification_state:'',// ai验证是否通过 npass(未通过)/pass(通过)
1048
+ f_is_defect: '',
1049
+ multiple:this.config[this.device.device].items[item].multiple === 'true' || this.config[this.device.device].items[item].multiple == true?this.config[this.device.device].items[item].multiple:false,
1050
+ isshow:this.config[this.device.device].items[item].isshow == false?this.config[this.device.device].items[item].isshow:true,
1051
+ readonly: this.config[this.device.device].items[item].readonly == true?true:false,
1052
+ remark: this.config[this.device.device].items[item].remark ? this.config[this.device.device].items[item].remark : '',
1053
+ f_path: '',
1054
+ unit: this.config[this.device.device].items[item].unit ? this.config[this.device.device].items[item].unit : '',
1055
+ tooltip:'',
1056
+ f_live_dispose:'',
1057
+ f_deal_dispose: this.config[this.device.device].items[item].f_process_mode,
1058
+ f_else: '',
1059
+ f_p1_path: '',
1060
+ f_p2_path: '',
1061
+ f_p3_path: '',
1062
+ f_longitude:'',
1063
+ f_latitude:''
1064
+ }
1065
+ //tag)
1066
+ //tag)
1067
+ this.$set('f_items['+index+']',it)
1068
+ if (this.config[this.device.device].items[item].type == 'selector' ||this.config[this.device.device].items[item].type == 'inputSelector') {
1069
+ if(this.config[this.device.device].items[item].type == 'selector'){
1070
+ this.page['options' + index].push({
1071
+ label: "请选择",
1072
+ value: ''
1073
+ })
1074
+ }
1075
+ for (let i in this.config[this.device.device].items[item].options) {
1076
+ if(typeof this.config[this.device.device].items[item].options[i]=='function'){
1077
+ continue
1078
+ }
1079
+ this.page['options' + index].push({
1080
+ label: this.config[this.device.device].items[item].options[i].data,
1081
+ value: this.config[this.device.device].items[item].options[i].data,
1082
+ tooltip: this.config[this.device.device].items[item].options[i].tooltip
1083
+ })
1084
+ }
1085
+ if(this.config[this.device.device].items[item].type == 'selector'){
1086
+ this.$set('f_items['+index+'].selected', f_item_value)
1087
+ }else if(this.config[this.device.device].items[item].type == 'inputSelector'){
1088
+ this.$set('f_items['+index+'].selected', f_item_value)
1089
+ }
1090
+
1091
+ this.$set('f_items['+index+'].options',this.page['options' + index])
1092
+
1093
+ //tag)
1094
+ } else if (this.config[this.device.device].items[item].type == 'radio' || this.config[this.device.device].items[item].type == 'checkbox') {
1095
+ //tag)
1096
+ //tag
1097
+ //tag)
1098
+ for (let i in this.config[this.device.device].items[item].options) {
1099
+ if(typeof this.config[this.device.device].items[item].options[i]=='function'){
1100
+ continue
1101
+ }
1102
+ //tag
1103
+ this.page['options' + index].push({
1104
+ label: this.config[this.device.device].items[item].options[i].data,
1105
+ value: this.config[this.device.device].items[item].options[i].data,
1106
+ isdefect: this.config[this.device.device].items[item].options[i].isdefect,
1107
+ level: this.config[this.device.device].items[item].options[i].level,
1108
+ tooltip: this.config[this.device.device].items[item].options[i].tooltip
1109
+ })
1110
+ //tag)
1111
+ }
1112
+ //tag)
1113
+ this.$set('f_items[' + index + '].options', this.page['options' + index])
1114
+ this.$set('f_items[' + index + '].f_item_value', f_item_value)
1115
+ //tag)
1116
+ }
1117
+ n = n + 1
1118
+ }
1119
+ if(!this.piece || JSON.stringify(this.piece) == '{}') {
1120
+ // 如果没有,则新建
1121
+ this.$set('piece.f_items',this.f_items)
1122
+ this.$set('piece.f_device_type', this.config[this.device.device].itemname)
1123
+ } else {
1124
+ // 已经存在,把之前的数据重新填入
1125
+ for (let f in this.f_items){
1126
+ if(typeof this.f_items[f]=='function'){
1127
+ continue
1128
+ }
1129
+ for(let p in this.piece.f_items) {
1130
+ if(typeof this.piece.f_items[p]=='function'){
1131
+ continue
1132
+ }
1133
+ if (this.f_items[f].f_item_name == this.piece.f_items[p].f_item_name) {
1134
+ //tag)
1135
+ //tag)
1136
+ this.f_items[f] = Object.assign(this.f_items[f], this.piece.f_items[p])
1137
+ //tag)
1138
+ if (this.f_items[f].type == 'selector' || this.f_items[f].type == 'inputSelector') {
1139
+ //tag)
1140
+ //tag)
1141
+ this.f_items[f].selected = this.piece.f_items[p].f_item_value
1142
+ //tag)
1143
+ }
1144
+ // 取出特殊值
1145
+ if (this.f_items[f].f_item_name == '初始表底') {
1146
+ //tag)
1147
+ this.f_initial_base.index = f
1148
+ } else if (this.f_items[f].f_item_name == '累购气量') {
1149
+ //tag)
1150
+ this.f_total_gas.index = f
1151
+ } else if (this.f_items[f].f_item_name == '已用气量') {
1152
+ //tag)
1153
+ this.f_table_base.index = f
1154
+ this.$watch('f_items[' + f + '].f_item_value', function () {
1155
+ this.getGasAberrantNumber('已用气量')
1156
+ })
1157
+ } else if (this.f_items[f].f_item_name == '剩余气量') {
1158
+ //tag)
1159
+ this.f_gas_balance.index = f
1160
+ this.$watch('f_items[' + f + '].f_item_value', function () {
1161
+ this.getGasAberrantNumber('')
1162
+ })
1163
+ } else if (this.f_items[f].f_item_name == '气量异常差值') {
1164
+ //tag)
1165
+ this.f_gas_aberrant_number.index = f
1166
+ } else if (this.f_items[f].f_item_name == '累购金额') {
1167
+ //tag)
1168
+ this.f_total_fee.index = f
1169
+ } else if (this.f_items[f].f_item_name == '已用金额') {
1170
+ //tag)
1171
+ this.f_fee_base.index = f
1172
+ this.$watch('f_items[' + f + '].f_item_value', function () {
1173
+ this.getFeeAberrantNumber('已用金额')
1174
+ })
1175
+ } else if (this.f_items[f].f_item_name == '剩余金额') {
1176
+ //tag)
1177
+ this.f_fee_balance.index = f
1178
+ this.$watch('f_items[' + f + '].f_item_value', function () {
1179
+ this.getFeeAberrantNumber('')
1180
+ this.getFeeAberrantNumber2('')
1181
+ })
1182
+ } else if (this.f_items[f].f_item_name == '表端剩余金额') {
1183
+ this.f_table_balance.index = f
1184
+ this.$watch('f_items[' + f + '].f_item_value', function () {
1185
+ this.getFeeAberrantNumber2('')
1186
+ })
1187
+ } else if (this.f_items[f].f_item_name == '金额异常差值') {
1188
+ //tag)
1189
+ this.f_fee_aberrant_number.index = f
1190
+ }else if (this.f_items[f].f_item_name == '表读数') {
1191
+ //tag)
1192
+ this.f_meter_base.index = f
1193
+ }else if (this.f_items[f].f_item_name == '表剩余金额') {
1194
+ //tag)
1195
+ this.f_balance_amount.index = f
1196
+ }else if (this.f_items[f].f_item_name == '字轮数') {
1197
+ //tag)
1198
+ this.f_meter_base1.index = f
1199
+ this.$watch('f_items[' + f + '].f_item_value', function () {
1200
+ this.getmeteraberrantnumber()
1201
+ })
1202
+ }else if (this.f_items[f].f_item_name == '表余额') {
1203
+ //tag)
1204
+ this.f_balance_amount1.index = f
1205
+ this.$watch('f_items[' + f + '].f_item_value', function () {
1206
+ this.getfeeaberrantnumber1()
1207
+ })
1208
+ }else if (this.f_items[f].f_item_name == '表数异常差值') {
1209
+ //tag)
1210
+ this.f_meter_aberrant_number1.index = f
1211
+ }else if (this.f_items[f].f_item_name == '表金额异常差值') {
1212
+ //tag)
1213
+ this.f_fee_aberrant_number1.index = f
1214
+ }
1215
+ }
1216
+ }
1217
+ for (let em in this.config[this.device.device].items) {
1218
+ if(typeof this.config[this.device.device].items[em]=='function'){
1219
+ continue
1220
+ }
1221
+ if (this.config[this.device.device].items[em].type == 'selector' && em == this.f_items[f].f_item_name) {
1222
+ this.f_items[f].options =[]
1223
+ for (let k in this.config[this.device.device].items[em].options) {
1224
+ if(typeof this.config[this.device.device].items[em].options[k]=='function'){
1225
+ continue
1226
+ }
1227
+ this.f_items[f].options.push({
1228
+ label: this.config[this.device.device].items[em].options[k].data,
1229
+ value: this.config[this.device.device].items[em].options[k].data
1230
+ })
1231
+ }
1232
+ }
1233
+ }
1234
+ }
1235
+ //tag)
1236
+ this.$set('piece.f_items',this.f_items)
1237
+ }
1238
+ this.towatch()
1239
+ },
1240
+ destroyed(){
1241
+ let nullCount = 0
1242
+ let metertitles
1243
+ //判断当前是否有选中项
1244
+ for (let row in this.f_items){
1245
+ if(typeof this.f_items[row]=='function'){
1246
+ continue
1247
+ }
1248
+ if(this.f_items[row].selected && this.f_items[row].selected != '' && this.f_items[row].selected instanceof Array){
1249
+ //tag
1250
+ this.f_items[row].f_item_value = this.f_items[row].selected
1251
+ }else if(this.f_items[row].selected && this.f_items[row].selected != ''){
1252
+ //tag
1253
+ this.f_items[row].f_item_value = this.f_items[row].selected
1254
+ }
1255
+ // if(this.f_items[row].f_item_value instanceof Array && this.f_items[row].f_item_value.length != 0 ){
1256
+ // nullCount = nullCount+1
1257
+ // }else if(this.f_items[row].f_item_value != ''){
1258
+ // nullCount = nullCount+1
1259
+ // }
1260
+ }
1261
+ let picture = []
1262
+ // for (let row in this.f_items){
1263
+ // let a={}
1264
+ // a.f_path = this.f_items[row].f_path
1265
+ // a.name = this.f_items[row].f_item_name
1266
+ // }
1267
+ // picture.push(a)
1268
+ this.$set(`paper['device${this.device.n}'][${this.idx}]`, this.piece)
1269
+ //tag
1270
+ },
1271
+ computed:{
1272
+
1273
+ }
1274
+ }
1275
+ </script>
1276
+ <style lang="less" scoped>
1277
+ .class-erro {
1278
+ color: #a94442;
1279
+ }
1280
+ .fivelabel{
1281
+ border: none;
1282
+ border-left: 5px solid #A2C2EB;
1283
+ float: left;
1284
+ width: 35%;
1285
+ margin-bottom: 3px;
1286
+ text-align: left;
1287
+ word-wrap: break-word;
1288
+ white-space: normal;
1289
+ }
1290
+ .radiolabel{
1291
+ border: none;
1292
+ border-left: 5px solid #A2C2EB;
1293
+ float: left;
1294
+ width: 65%;
1295
+ margin-bottom: 3px;
1296
+ text-align: left;
1297
+ word-wrap: break-word;
1298
+ white-space: normal;
1299
+ }
1300
+
1301
+ .textlabel {
1302
+ border: none;
1303
+ border-left: 5px solid #A2C2EB;
1304
+ width: 100%;
1305
+ margin-bottom: 3px;
1306
+ text-align: left;
1307
+ word-wrap: break-word;
1308
+ white-space: normal;
1309
+ }
1310
+ .textlabel1 {
1311
+ border: none;
1312
+ border-left: 5px solid #f7cb32;
1313
+ width: 100%;
1314
+ margin-bottom: 3px;
1315
+ text-align: left;
1316
+ word-wrap: break-word;
1317
+ white-space: normal;
1318
+ }
1319
+ .spanrodio{
1320
+ margin-right: 10px;
1321
+ }
1322
+ .div-photo{
1323
+ width: auto;
1324
+ height: auto;
1325
+ /* margin-top: 10px; */
1326
+ position: absolute;
1327
+ bottom: 10px;
1328
+ right: 10px;
1329
+ }
1330
+ .panel-self{
1331
+ border-radius: 5px;
1332
+ border:1px solid #c5e1f7;
1333
+ //background-color: #F2F6FA;
1334
+ }
1335
+ .btn-photo{
1336
+ border: 0;
1337
+ border-radius: 7px;
1338
+ background-color: #7dc1f4;
1339
+ font: 15px PingFang-SC-Bold;
1340
+ height: 20%;
1341
+ }
1342
+ </style>
1343
+