safecheck-client 3.0.34-86 → 3.0.34-88

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,430 +1,430 @@
1
- <template>
2
- <div class="auto">
3
- <criteria-paged :model="model" v-ref:paged>
4
- <criteria partial='criteria' @condition-changed='search' v-ref:cri>
5
- <div partial>
6
- <form>
7
- <div class="row app-row">
8
- <div class="col-xs-4">
9
- <img src="../../../assets/用户ID.png" style="width: 20px;margin-bottom: 5px" alt="">
10
- <label class="font text-left">用户编号:</label>
11
- </div>
12
- <div class="col-xs-8" >
13
- <input class="search_input input-font"
14
- v-model=model.f_userinfo_code condition="f_userinfo_code = '{}'" placeholder="请输入用户编号" />
15
- </div>
16
- </div>
17
- <div class="row app-row">
18
- <div class="col-xs-4">
19
- <img src="../../../assets/用户ID.png" style="width: 20px;margin-bottom: 5px" alt="">
20
- <label class="font text-left">表 &nbsp;&nbsp; &nbsp;&nbsp; 号:</label>
21
- </div>
22
- <div class="col-xs-8" >
23
- <input class="search_input input-font"
24
- v-model=model.f_meternumber condition="f_meternumber = '{}'" style="width: 70%" placeholder="请输入表号" />
25
- <button type="button" name="button" class="btn btn-primary" style="width: 25%" @click="$parent.$parent.scan">扫码</button>
26
- </div>
27
- </div>
28
- <div class="row app-row">
29
- <div class="col-xs-4">
30
- <img src="../../../assets/用户姓名.png" style="width: 20px;margin-bottom: 5px" alt="">
31
- <label class="font text-left">用户名称:</label>
32
- </div>
33
- <div class="col-xs-8" >
34
- <input class="search_input input-font" v-model="model.f_username" placeholder="请输入用户名称(可模糊查询)">
35
- </div>
36
- </div>
37
- <div class="row app-row">
38
- <div class="col-xs-4">
39
- <img src="../../../assets/用户类型.png" style="width: 20px;margin-bottom: 5px" alt="">
40
- <label class="font text-left">用户类型:</label>
41
- </div>
42
- <div class="col-xs-8" >
43
- <v-select :value.sync="$parent.$parent.model.f_user_type" class="input-font"
44
- :options='$parent.$parent.user_types' placeholder='请选择用户类型' :value-single="true"
45
- v-model="$parent.$parent.model.f_user_type" close-on-select clear-button></v-select>
46
- </div>
47
- </div>
48
- <div class="row app-row">
49
- <div class="col-xs-4">
50
- <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
51
- <label class="font text-left">小区名称:</label>
52
- </div>
53
- <div class="col-xs-8" >
54
- <input style="width: 100%" class="search_input input-font" v-model="model.f_districtname" placeholder="请输入用户小区(可模糊查询)">
55
- </div>
56
- </div>
57
- <div class="row app-row">
58
- <div class="col-xs-4">
59
- <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
60
- <label class="font text-left">楼&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;号:</label>
61
- </div>
62
- <div class="col-xs-8" >
63
- <input style="width: 100%" class="search_input input-font" v-model="model.f_building" placeholder="请输入用户楼号">
64
- </div>
65
- </div>
66
- <div class="row app-row">
67
- <div class="col-xs-4">
68
- <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
69
- <label class="font text-left">单&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;元:</label>
70
- </div>
71
- <div class="col-xs-8" >
72
- <input style="width: 100%" class="search_input input-font" v-model="model.f_unit" placeholder="请输入用户单元">
73
- </div>
74
- </div>
75
- <div class="row app-row">
76
- <div class="col-xs-4">
77
- <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
78
- <label class="font text-left">用户地址:</label>
79
- </div>
80
- <div class="col-xs-8" >
81
- <input style="width: 100%" class="search_input input-font" v-model="model.f_address" placeholder="请输入用户地址(可模糊查询)">
82
- </div>
83
- </div>
84
- <div class="row app-row">
85
- <div class="col-xs-4">
86
- <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
87
- <label class="font text-left">表&nbsp;&nbsp;封&nbsp;&nbsp;号:</label>
88
- </div>
89
- <div class="col-xs-8" >
90
- <input style="width: 100%" class="search_input input-font" v-model="model.f_metertitles" placeholder="请输入表封号" condition="uf.f_metertitles='{}'">
91
- </div>
92
- </div>
93
- <div class="row app-row">
94
- <div class="col-xs-4">
95
- <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
96
- <label class="font text-left">电&nbsp;&nbsp;话&nbsp;&nbsp;号:</label>
97
- </div>
98
- <div class="col-xs-8" >
99
- <input style="width: 100%" class="search_input input-font" v-model="model.f_user_phone" placeholder="请输入电话号" condition="ui.f_user_phone like '%{}%'">
100
- </div>
101
- </div>
102
- <div class="row app-row">
103
- <div class="col-xs-4">
104
- <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
105
- <label class="font text-left">卡&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;号:</label>
106
- </div>
107
- <div class="col-xs-8" >
108
- <input style="width: 100%" class="search_input input-font" v-model="model.f_card_id" placeholder="请输入卡号" condition="uf.f_card_id like '%{}%'">
109
- </div>
110
- </div>
111
- <div class="row app-row">
112
- <div class="col-xs-4">
113
- <img src="../../../assets/安检状态.png" style="width: 20px;margin-bottom: 5px" alt="">
114
- <label class="font text-left">抄&nbsp;&nbsp;表&nbsp;&nbsp;册:</label>
115
- </div>
116
- <div class="col-xs-8" >
117
- <v-select class="input-font"
118
- placeholder='请选择抄表册'
119
- :value.sync="model.f_meter_book_num"
120
- v-model="model.f_meter_book_num"
121
- :options='$parent.$parent.cbc'
122
- condition="uf.f_meter_book_num='{}'"
123
- close-on-select clear-button></v-select>
124
- </div>
125
- </div>
126
- <div class="row text-center" style="margin-top: 20px;">
127
- <button type="button" class="btn btn-lg btn-font btn-color" style="width: 45%;" @click="search">查询</button>
128
- </div>
129
- <div style="height:30px;"></div>
130
- </form>
131
- </div>
132
- </criteria>
133
-
134
- <list :model="model" partial='list'>
135
- <div partial>
136
- <div @click="$parent.$parent.$parent.inspect(row)" class="auto app-text" style="margin-top: 5px;">
137
- <div class="panel" style="padding: 10px 10px 5px 10px;">
138
- <div class="panel-body panel-self">
139
- <div class="row">
140
- <p class="panel-title col-xs-4 text-left font">用户编号</p>
141
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_userinfo_code }}</p>
142
- </div>
143
- <div class="row">
144
- <p class="panel-title col-xs-4 text-left font">用户名称</p>
145
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_user_name }}</p>
146
- </div>
147
- <div class="row">
148
- <p class="panel-title col-xs-4 text-left font">表号</p>
149
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_meternumber }}</p>
150
- </div>
151
- <div class="row">
152
- <p class="panel-title col-xs-4 text-left font">用户类型</p>
153
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_user_type }}</p>
154
- </div>
155
- <div class="row">
156
- <p class="panel-title col-xs-4 text-left font">用户电话</p>
157
- <p class="panel-title col-xs-8 text-left input-font" style="width: 77%">{{ row.f_user_phone2 ? row.f_user_phone2 : row.f_user_phone }}
158
- <img src="../../../assets/phone.png" style="width: 6%" v-on:click.stop.prevent='$parent.$parent.$parent.makeAPhoneCall(row.f_user_phone2 ? row.f_user_phone2 : row.f_user_phone)'></img></p>
159
- </div>
160
-
161
- <div class="row">
162
- <p class="panel-title col-xs-4 text-left font">小区名称</p>
163
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_residential_area }}</p>
164
- </div>
165
- <div class="row">
166
- <p class="panel-title col-xs-4 text-left font">用户地址</p>
167
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_address }}</p>
168
- </div>
169
- <div class="row">
170
- <p class="panel-title col-xs-4 text-left font">最后安检日期</p>
171
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_last_check_date }}</p>
172
- </div>
173
- <div class="row">
174
- <p class="panel-title col-xs-4 text-left font">最后安检状态</p>
175
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_last_check_state }}</p>
176
- </div>
177
- <div class="row">
178
- <p class="panel-title col-xs-4 text-left font">表具状态</p>
179
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_table_state }}</p>
180
- </div>
181
- <div class="row" v-if="row.f_table_state = '停用'">
182
- <p class="panel-title col-xs-4 text-left font">原因</p>
183
- <p class="panel-title col-xs-8 text-left input-font">{{ row.f_table_state }}</p>
184
- </div>
185
- </div>
186
- </div>
187
-
188
- </div>
189
- </div>
190
- </list>
191
- </criteria-paged>
192
- <!--<back-page :need-back='true' @flag="$back()"></back-page>-->
193
- </div>
194
- </template>
195
-
196
- <script>
197
- import {HttpResetClass, PagedList} from 'vue-client'
198
- import Vue from 'vue'
199
- import * as Util from '../../Util'
200
-
201
- export default {
202
- title: '安检员B',
203
- data () {
204
- let model = new PagedList(`${this.$androidUtil.getProxyUrl()}/rs/sql/提取用户档案`, 20, { groupitem: '""', orderitem: '"f_residential_area,f_unit,f_room"',f_check_type:'this.f_check_type[0]',
205
- f_user_name:'this.model.f_username',myCycle: 'this.myCycle',fyCycle: 'this.fyCycle', f_user_type:'this.f_user_type',f_sign: 'this.f_sign[0]', f_residential_area:'this.model.f_districtname', f_address:'this.model.f_address',f_user_state: 'this.f_user_state[0]',f_orgids:'this.f_orgids',f_unit:'this.model.f_unit',f_building:'this.model.f_building',f_filialeid:'this.f_filialeid'})
206
- model.f_sign = ['']
207
- model.f_user_type = ''
208
- model.f_user_state =['']
209
- model.f_check_type =['']
210
- model.myCycle = 0
211
- model.fyCycle = 0
212
- model.f_filialeid = Vue.user.orgid
213
- //model.f_filialeid = 287
214
- return {
215
- model: model,
216
- cbc:[],
217
- showModal:false,
218
- signs: [
219
- {label:'请选择录入状态', value:''},
220
- {label:'录入', value:'1'},
221
- {label:'非录入', value:'0'},
222
- ],
223
- ischecks: [
224
- ],
225
- user_types: [
226
- {label: '请选择用户类型', value: ''},
227
- {label: '民用', value: '民用'},
228
- {label: '非民用', value: '非民用'},
229
- ],
230
- f_user_states: [
231
- {label:'请选择档案状态', value:''},
232
- {label:'正常', value:'正常'},
233
- {label:'点火', value:'点火'},
234
- ],
235
- f_check_types: [
236
- {label:'请选择安检类型', value:''},
237
- {label:'应检', value:'应检'},
238
- {label:'超期', value:'超期'},
239
- ],
240
- }
241
- },
242
- ready () {
243
- // this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/logic/getSafeCheckCycle`,{},{resolveMsg: null, rejectMsg: null}).then((res) => {
244
- // //tag)
245
- // if(res.data.code == 200){
246
- // this.model.myCycle = res.data.civil.value
247
- // this.model.fyCycle = res.data.civilian.value
248
- // }else{
249
- // //this.$showMessage(res.data.msg)
250
- // }
251
- //
252
- // })
253
- // this.getCheckTime()
254
- // this.Mreadibook()
255
- },
256
- computed: {
257
- reload(){
258
- this.$refs.paged.loadPage(this.$refs.paged.model.pageIndex)
259
- },
260
- selected () {
261
- return this.$refs.paged.$refs.grid.selected
262
- }
263
- },
264
- methods:{
265
- makeAPhoneCall(phoneNumber) {
266
- this.$androidUtil.makeAPhoneCall(phoneNumber)
267
- },
268
- scan(){
269
- HostApp.__this__=this,
270
- HostApp.scanCode({callback:"javascript:HostApp.__this__.getCode();"})
271
- },
272
- getCode(){
273
- var datapa = HostApp.getCode().data;
274
- //tag
275
- this.$refs.paged.$refs.cri.model.f_meternumber=datapa
276
- },
277
- getCheckTime(){
278
- //tag
279
- new HttpResetClass().load('post',`${this.$androidUtil.getProxyUrl()}/rs/sql/tel_singleTable_OrderBy`,{data: {
280
- items: 'f_circle,f_start_time',
281
- tablename: 't_safe_circle',
282
- condition: `f_filialeid = '${Vue.user.orgid}'`,
283
- orderitem: 'id'
284
- }}).then(res=>{
285
- //tag)
286
- let nocheck=''
287
- let ischeck=''
288
- if (res.data[0]){
289
- if (res.data[0].f_circle=='1'){
290
- nocheck=`(ua.f_last_check_date<'${res.data[0].f_start_time}' or ua.f_last_check_date is null)`
291
- ischeck=`ua.f_last_check_date>'${res.data[0].f_start_time}'`
292
-
293
- }else{
294
- let addtime= (Util.toStandardTimeString().substring(0,4)-res.data[0].f_start_time.substring(0,4))%res.data[0].f_circle
295
- //tag
296
- let time =(Util.toStandardTimeString().substring(0,4)-addtime)+'-01-01 00:00:00'
297
- //tag
298
- nocheck=`(ua.f_last_check_date<'${time}' or ua.f_last_check_date is null)`
299
- ischeck=`ua.f_last_check_date>'${time}'`
300
- }
301
- //tag
302
- this.ischecks=[
303
- {label: '全部', value: ''},
304
- {label: '已检', value: ischeck },
305
- {label: '未检', value: nocheck},
306
- ]
307
- //tag
308
- }else{
309
- this.$showMessage("未配置安检周期")
310
- }
311
-
312
- })
313
- //tag
314
- },
315
- selfSearch(){
316
- this.$refs.paged.$refs.cri.search()
317
- },
318
- inspect (info){
319
- if(info.f_last_check_date){
320
- this.$showMessage("该用户最后一次安检时间为 "+info.f_last_check_date+" 是否继续对该用户进行安检",['confirm', 'cancel']).then((butt)=>{
321
- if(butt=="confirm"){
322
- info.id = ''
323
- info.f_state = '未检'
324
- info.f_no_checkplan = '无计划安检'
325
- //tag
326
- this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/查询计划项表信息`,{data:{f_userid:info.f_userinfo_id}}).then((response)=>{
327
- //tag)
328
- info['f_plan_meters'] = response.data
329
- var pardate = {
330
- _this:this,
331
- tittle:'安检详情',
332
- safe:true
333
- }
334
- this.$dispatch('gotoson',pardate)
335
- let _this = this
336
- this.$goto('safecheck-order-v', {item: info, role: 'inspect'}, 'self', function(){_this.selfSearch()})
337
-
338
- })
339
- }
340
- })
341
- }else{
342
- info.id = ''
343
- info.f_state = '未检'
344
- info.f_no_checkplan = '无计划安检'
345
- //tag
346
- this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/查询计划项表信息`,{data:{f_userid:info.f_userinfo_id}}).then((response)=>{
347
- //tag)
348
- info['f_plan_meters'] = response.data
349
- var pardate = {
350
- _this:this,
351
- tittle:'安检详情',
352
- safe:true
353
- }
354
- this.$dispatch('gotoson',pardate)
355
- let _this = this
356
- this.$goto('safecheck-order-v', {item: info, role: 'inspect'}, 'self', function(){_this.selfSearch()})
357
-
358
- })
359
- }
360
- },
361
- Mreadibook(){
362
- this.cbc=[]
363
- let http = new HttpResetClass()
364
- http.load('POST',`${this.$androidUtil.getProxyUrl()}/rs/logic/getMeterBooksData`,
365
- {data: {f_orgid: "('"+Vue.user.orgid+"')"}},
366
- {resolveMsg: null, rejectMsg: '获取失败!!!'}).then((getMeterReadingBooks)=>{
367
- this.cbc = [{label: '全部', value: ''}]
368
- //tag
369
- //tag)
370
- //tag
371
- getMeterReadingBooks.data.meterbooks.forEach((res) => {
372
- this.cbc.push({label: res.f_book_name, value: res.id})
373
- /*if(res.f_book_slice_area){
374
- if(this.sliceArea.indexOf(res.f_book_slice_area)<0){
375
- this.sliceArea.push(res.f_book_slice_area)
376
- }
377
- }*/
378
- })
379
- })
380
-
381
-
382
- }
383
- }
384
- }
385
- </script>
386
- <style scoped>
387
- .app-row {
388
- background-color: white;
389
- padding: 10px 10px 0 10px;
390
- border-bottom: 1px solid rgba(235, 235, 235, 0.5);
391
- }
392
- .search_input {
393
- border: 0;
394
- outline: none;
395
- }
396
- .font{
397
- font: 15px PingFang-SC-Medium;
398
- color: #666666;
399
- }
400
- .input-font{
401
- font: 15px PingFang-SC-Medium;
402
- color: #333333;
403
- }
404
- .btn-font{
405
- font:600 16px PingFang-SC-Bold;
406
- color: #499EDF;
407
- }
408
- .btn-color{
409
- background-color: #FFFFFF;
410
- border-radius: 10px ;
411
- border: 1px solid #499EDF;
412
- }
413
- .app-text {
414
- font-size: 12px;
415
- }
416
- .panel-self{
417
- border-radius: 10px;
418
- border:1px solid #499EDF;
419
- background-color: #F8F8F8;
420
- }
421
- .yybtn-color{
422
- border-radius: 4px ;
423
- border: 1px solid #499EDF;
424
- }
425
- .qxbtn-color{
426
- background-color: #FFFFFF;
427
- border-radius: 4px ;
428
- border: 1px solid #499EDF;
429
- }
430
- </style>
1
+ <template>
2
+ <div class="auto">
3
+ <criteria-paged :model="model" v-ref:paged>
4
+ <criteria partial='criteria' @condition-changed='search' v-ref:cri>
5
+ <div partial>
6
+ <form>
7
+ <div class="row app-row">
8
+ <div class="col-xs-4">
9
+ <img src="../../../assets/用户ID.png" style="width: 20px;margin-bottom: 5px" alt="">
10
+ <label class="font text-left">用户编号:</label>
11
+ </div>
12
+ <div class="col-xs-8" >
13
+ <input class="search_input input-font"
14
+ v-model=model.f_userinfo_code condition="f_userinfo_code = '{}'" placeholder="请输入用户编号" />
15
+ </div>
16
+ </div>
17
+ <div class="row app-row">
18
+ <div class="col-xs-4">
19
+ <img src="../../../assets/用户ID.png" style="width: 20px;margin-bottom: 5px" alt="">
20
+ <label class="font text-left">表 &nbsp;&nbsp; &nbsp;&nbsp; 号:</label>
21
+ </div>
22
+ <div class="col-xs-8" >
23
+ <input class="search_input input-font"
24
+ v-model=model.f_meternumber condition="f_meternumber = '{}'" style="width: 70%" placeholder="请输入表号" />
25
+ <button type="button" name="button" class="btn btn-primary" style="width: 25%" @click="$parent.$parent.scan">扫码</button>
26
+ </div>
27
+ </div>
28
+ <div class="row app-row">
29
+ <div class="col-xs-4">
30
+ <img src="../../../assets/用户姓名.png" style="width: 20px;margin-bottom: 5px" alt="">
31
+ <label class="font text-left">用户名称:</label>
32
+ </div>
33
+ <div class="col-xs-8" >
34
+ <input class="search_input input-font" v-model="model.f_username" placeholder="请输入用户名称(可模糊查询)">
35
+ </div>
36
+ </div>
37
+ <div class="row app-row">
38
+ <div class="col-xs-4">
39
+ <img src="../../../assets/用户类型.png" style="width: 20px;margin-bottom: 5px" alt="">
40
+ <label class="font text-left">用户类型:</label>
41
+ </div>
42
+ <div class="col-xs-8" >
43
+ <v-select :value.sync="$parent.$parent.model.f_user_type" class="input-font"
44
+ :options='$parent.$parent.user_types' placeholder='请选择用户类型' :value-single="true"
45
+ v-model="$parent.$parent.model.f_user_type" close-on-select clear-button></v-select>
46
+ </div>
47
+ </div>
48
+ <div class="row app-row">
49
+ <div class="col-xs-4">
50
+ <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
51
+ <label class="font text-left">小区名称:</label>
52
+ </div>
53
+ <div class="col-xs-8" >
54
+ <input style="width: 100%" class="search_input input-font" v-model="model.f_districtname" placeholder="请输入用户小区(可模糊查询)">
55
+ </div>
56
+ </div>
57
+ <div class="row app-row">
58
+ <div class="col-xs-4">
59
+ <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
60
+ <label class="font text-left">楼&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;号:</label>
61
+ </div>
62
+ <div class="col-xs-8" >
63
+ <input style="width: 100%" class="search_input input-font" v-model="model.f_building" placeholder="请输入用户楼号">
64
+ </div>
65
+ </div>
66
+ <div class="row app-row">
67
+ <div class="col-xs-4">
68
+ <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
69
+ <label class="font text-left">单&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;元:</label>
70
+ </div>
71
+ <div class="col-xs-8" >
72
+ <input style="width: 100%" class="search_input input-font" v-model="model.f_unit" placeholder="请输入用户单元">
73
+ </div>
74
+ </div>
75
+ <div class="row app-row">
76
+ <div class="col-xs-4">
77
+ <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
78
+ <label class="font text-left">用户地址:</label>
79
+ </div>
80
+ <div class="col-xs-8" >
81
+ <input style="width: 100%" class="search_input input-font" v-model="model.f_address" placeholder="请输入用户地址(可模糊查询)">
82
+ </div>
83
+ </div>
84
+ <div class="row app-row">
85
+ <div class="col-xs-4">
86
+ <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
87
+ <label class="font text-left">表&nbsp;&nbsp;封&nbsp;&nbsp;号:</label>
88
+ </div>
89
+ <div class="col-xs-8" >
90
+ <input style="width: 100%" class="search_input input-font" v-model="model.f_metertitles" placeholder="请输入表封号" condition="uf.f_metertitles='{}'">
91
+ </div>
92
+ </div>
93
+ <div class="row app-row">
94
+ <div class="col-xs-4">
95
+ <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
96
+ <label class="font text-left">电&nbsp;&nbsp;话&nbsp;&nbsp;号:</label>
97
+ </div>
98
+ <div class="col-xs-8" >
99
+ <input style="width: 100%" class="search_input input-font" v-model="model.f_user_phone" placeholder="请输入电话号" condition="ui.f_user_phone like '%{}%'">
100
+ </div>
101
+ </div>
102
+ <div class="row app-row">
103
+ <div class="col-xs-4">
104
+ <img src="../../../assets/小区.png" style="width: 20px;margin-bottom: 5px" alt="">
105
+ <label class="font text-left">卡&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;号:</label>
106
+ </div>
107
+ <div class="col-xs-8" >
108
+ <input style="width: 100%" class="search_input input-font" v-model="model.f_card_id" placeholder="请输入卡号" condition="uf.f_card_id like '%{}%'">
109
+ </div>
110
+ </div>
111
+ <div class="row app-row">
112
+ <div class="col-xs-4">
113
+ <img src="../../../assets/安检状态.png" style="width: 20px;margin-bottom: 5px" alt="">
114
+ <label class="font text-left">抄&nbsp;&nbsp;表&nbsp;&nbsp;册:</label>
115
+ </div>
116
+ <div class="col-xs-8" >
117
+ <v-select class="input-font"
118
+ placeholder='请选择抄表册'
119
+ :value.sync="model.f_meter_book_num"
120
+ v-model="model.f_meter_book_num"
121
+ :options='$parent.$parent.cbc'
122
+ condition="uf.f_meter_book_num='{}'"
123
+ close-on-select clear-button></v-select>
124
+ </div>
125
+ </div>
126
+ <div class="row text-center" style="margin-top: 20px;">
127
+ <button type="button" class="btn btn-lg btn-font btn-color" style="width: 45%;" @click="search">查询</button>
128
+ </div>
129
+ <div style="height:30px;"></div>
130
+ </form>
131
+ </div>
132
+ </criteria>
133
+
134
+ <list :model="model" partial='list'>
135
+ <div partial>
136
+ <div @click="$parent.$parent.$parent.inspect(row)" class="auto app-text" style="margin-top: 5px;">
137
+ <div class="panel" style="padding: 10px 10px 5px 10px;">
138
+ <div class="panel-body panel-self">
139
+ <div class="row">
140
+ <p class="panel-title col-xs-4 text-left font">用户编号</p>
141
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_userinfo_code }}</p>
142
+ </div>
143
+ <div class="row">
144
+ <p class="panel-title col-xs-4 text-left font">用户名称</p>
145
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_user_name }}</p>
146
+ </div>
147
+ <div class="row">
148
+ <p class="panel-title col-xs-4 text-left font">表号</p>
149
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_meternumber }}</p>
150
+ </div>
151
+ <div class="row">
152
+ <p class="panel-title col-xs-4 text-left font">用户类型</p>
153
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_user_type }}</p>
154
+ </div>
155
+ <div class="row">
156
+ <p class="panel-title col-xs-4 text-left font">用户电话</p>
157
+ <p class="panel-title col-xs-8 text-left input-font" style="width: 77%">{{ row.f_user_phone2 ? row.f_user_phone2 : row.f_user_phone }}
158
+ <img src="../../../assets/phone.png" style="width: 6%" v-on:click.stop.prevent='$parent.$parent.$parent.makeAPhoneCall(row.f_user_phone2 ? row.f_user_phone2 : row.f_user_phone)'></img></p>
159
+ </div>
160
+
161
+ <div class="row">
162
+ <p class="panel-title col-xs-4 text-left font">小区名称</p>
163
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_residential_area }}</p>
164
+ </div>
165
+ <div class="row">
166
+ <p class="panel-title col-xs-4 text-left font">用户地址</p>
167
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_address }}</p>
168
+ </div>
169
+ <div class="row">
170
+ <p class="panel-title col-xs-4 text-left font">最后安检日期</p>
171
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_last_check_date }}</p>
172
+ </div>
173
+ <div class="row">
174
+ <p class="panel-title col-xs-4 text-left font">最后安检状态</p>
175
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_last_check_state }}</p>
176
+ </div>
177
+ <div class="row">
178
+ <p class="panel-title col-xs-4 text-left font">表具状态</p>
179
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_table_state }}</p>
180
+ </div>
181
+ <div class="row" v-if="row.f_table_state = '停用'">
182
+ <p class="panel-title col-xs-4 text-left font">原因</p>
183
+ <p class="panel-title col-xs-8 text-left input-font">{{ row.f_table_state }}</p>
184
+ </div>
185
+ </div>
186
+ </div>
187
+
188
+ </div>
189
+ </div>
190
+ </list>
191
+ </criteria-paged>
192
+ <!--<back-page :need-back='true' @flag="$back()"></back-page>-->
193
+ </div>
194
+ </template>
195
+
196
+ <script>
197
+ import {HttpResetClass, PagedList} from 'vue-client'
198
+ import Vue from 'vue'
199
+ import * as Util from '../../Util'
200
+
201
+ export default {
202
+ title: '安检员B',
203
+ data () {
204
+ let model = new PagedList(`${this.$androidUtil.getProxyUrl()}/rs/sql/提取用户档案`, 20, { groupitem: '""', orderitem: '"f_residential_area,f_unit,f_room"',f_check_type:'this.f_check_type[0]',
205
+ f_user_name:'this.model.f_username',myCycle: 'this.myCycle',fyCycle: 'this.fyCycle', f_user_type:'this.f_user_type',f_sign: 'this.f_sign[0]', f_residential_area:'this.model.f_districtname', f_address:'this.model.f_address',f_user_state: 'this.f_user_state[0]',f_orgids:'this.f_orgids',f_unit:'this.model.f_unit',f_building:'this.model.f_building',f_filialeid:'this.f_filialeid'})
206
+ model.f_sign = ['']
207
+ model.f_user_type = ''
208
+ model.f_user_state =['']
209
+ model.f_check_type =['']
210
+ model.myCycle = 0
211
+ model.fyCycle = 0
212
+ model.f_filialeid = Vue.user.orgid
213
+ //model.f_filialeid = 287
214
+ return {
215
+ model: model,
216
+ cbc:[],
217
+ showModal:false,
218
+ signs: [
219
+ {label:'请选择录入状态', value:''},
220
+ {label:'录入', value:'1'},
221
+ {label:'非录入', value:'0'},
222
+ ],
223
+ ischecks: [
224
+ ],
225
+ user_types: [
226
+ {label: '请选择用户类型', value: ''},
227
+ {label: '民用', value: '民用'},
228
+ {label: '非民用', value: '非民用'},
229
+ ],
230
+ f_user_states: [
231
+ {label:'请选择档案状态', value:''},
232
+ {label:'正常', value:'正常'},
233
+ {label:'点火', value:'点火'},
234
+ ],
235
+ f_check_types: [
236
+ {label:'请选择安检类型', value:''},
237
+ {label:'应检', value:'应检'},
238
+ {label:'超期', value:'超期'},
239
+ ],
240
+ }
241
+ },
242
+ ready () {
243
+ // this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/logic/getSafeCheckCycle`,{},{resolveMsg: null, rejectMsg: null}).then((res) => {
244
+ // //tag)
245
+ // if(res.data.code == 200){
246
+ // this.model.myCycle = res.data.civil.value
247
+ // this.model.fyCycle = res.data.civilian.value
248
+ // }else{
249
+ // //this.$showMessage(res.data.msg)
250
+ // }
251
+ //
252
+ // })
253
+ // this.getCheckTime()
254
+ // this.Mreadibook()
255
+ },
256
+ computed: {
257
+ reload(){
258
+ this.$refs.paged.loadPage(this.$refs.paged.model.pageIndex)
259
+ },
260
+ selected () {
261
+ return this.$refs.paged.$refs.grid.selected
262
+ }
263
+ },
264
+ methods:{
265
+ makeAPhoneCall(phoneNumber) {
266
+ this.$androidUtil.makeAPhoneCall(phoneNumber)
267
+ },
268
+ scan(){
269
+ HostApp.__this__=this,
270
+ HostApp.scanCode({callback:"javascript:HostApp.__this__.getCode();"})
271
+ },
272
+ getCode(){
273
+ var datapa = HostApp.getCode().data;
274
+ //tag
275
+ this.$refs.paged.$refs.cri.model.f_meternumber=datapa
276
+ },
277
+ getCheckTime(){
278
+ //tag
279
+ new HttpResetClass().load('post',`${this.$androidUtil.getProxyUrl()}/rs/sql/tel_singleTable_OrderBy`,{data: {
280
+ items: 'f_circle,f_start_time',
281
+ tablename: 't_safe_circle',
282
+ condition: `f_filialeid = '${Vue.user.orgid}'`,
283
+ orderitem: 'id'
284
+ }}).then(res=>{
285
+ //tag)
286
+ let nocheck=''
287
+ let ischeck=''
288
+ if (res.data[0]){
289
+ if (res.data[0].f_circle=='1'){
290
+ nocheck=`(ua.f_last_check_date<'${res.data[0].f_start_time}' or ua.f_last_check_date is null)`
291
+ ischeck=`ua.f_last_check_date>'${res.data[0].f_start_time}'`
292
+
293
+ }else{
294
+ let addtime= (Util.toStandardTimeString().substring(0,4)-res.data[0].f_start_time.substring(0,4))%res.data[0].f_circle
295
+ //tag
296
+ let time =(Util.toStandardTimeString().substring(0,4)-addtime)+'-01-01 00:00:00'
297
+ //tag
298
+ nocheck=`(ua.f_last_check_date<'${time}' or ua.f_last_check_date is null)`
299
+ ischeck=`ua.f_last_check_date>'${time}'`
300
+ }
301
+ //tag
302
+ this.ischecks=[
303
+ {label: '全部', value: ''},
304
+ {label: '已检', value: ischeck },
305
+ {label: '未检', value: nocheck},
306
+ ]
307
+ //tag
308
+ }else{
309
+ this.$showMessage("未配置安检周期")
310
+ }
311
+
312
+ })
313
+ //tag
314
+ },
315
+ selfSearch(){
316
+ this.$refs.paged.$refs.cri.search()
317
+ },
318
+ inspect (info){
319
+ if(info.f_last_check_date){
320
+ this.$showMessage("该用户最后一次安检时间为 "+info.f_last_check_date+" 是否继续对该用户进行安检",['confirm', 'cancel']).then((butt)=>{
321
+ if(butt=="confirm"){
322
+ info.id = ''
323
+ info.f_state = '未检'
324
+ info.f_no_checkplan = '无计划安检'
325
+ //tag
326
+ this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/查询计划项表信息`,{data:{f_userid:info.f_userinfo_id}}).then((response)=>{
327
+ //tag)
328
+ info['f_plan_meters'] = response.data
329
+ var pardate = {
330
+ _this:this,
331
+ tittle:'安检详情',
332
+ safe:true
333
+ }
334
+ this.$dispatch('gotoson',pardate)
335
+ let _this = this
336
+ this.$goto('safecheck-order-v', {item: info, role: 'inspect'}, 'self', function(){_this.selfSearch()})
337
+
338
+ })
339
+ }
340
+ })
341
+ }else{
342
+ info.id = ''
343
+ info.f_state = '未检'
344
+ info.f_no_checkplan = '无计划安检'
345
+ //tag
346
+ this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/查询计划项表信息`,{data:{f_userid:info.f_userinfo_id}}).then((response)=>{
347
+ //tag)
348
+ info['f_plan_meters'] = response.data
349
+ var pardate = {
350
+ _this:this,
351
+ tittle:'安检详情',
352
+ safe:true
353
+ }
354
+ this.$dispatch('gotoson',pardate)
355
+ let _this = this
356
+ this.$goto('safecheck-order-v', {item: info, role: 'inspect'}, 'self', function(){_this.selfSearch()})
357
+
358
+ })
359
+ }
360
+ },
361
+ Mreadibook(){
362
+ this.cbc=[]
363
+ let http = new HttpResetClass()
364
+ http.load('POST',`${this.$androidUtil.getProxyUrl()}/rs/logic/getMeterBooksData`,
365
+ {data: {f_orgid: "('"+Vue.user.orgid+"')"}},
366
+ {resolveMsg: null, rejectMsg: '获取失败!!!'}).then((getMeterReadingBooks)=>{
367
+ this.cbc = [{label: '全部', value: ''}]
368
+ //tag
369
+ //tag)
370
+ //tag
371
+ getMeterReadingBooks.data.meterbooks.forEach((res) => {
372
+ this.cbc.push({label: res.f_book_name, value: res.id})
373
+ /*if(res.f_book_slice_area){
374
+ if(this.sliceArea.indexOf(res.f_book_slice_area)<0){
375
+ this.sliceArea.push(res.f_book_slice_area)
376
+ }
377
+ }*/
378
+ })
379
+ })
380
+
381
+
382
+ }
383
+ }
384
+ }
385
+ </script>
386
+ <style scoped>
387
+ .app-row {
388
+ background-color: white;
389
+ padding: 10px 10px 0 10px;
390
+ border-bottom: 1px solid rgba(235, 235, 235, 0.5);
391
+ }
392
+ .search_input {
393
+ border: 0;
394
+ outline: none;
395
+ }
396
+ .font{
397
+ font: 15px PingFang-SC-Medium;
398
+ color: #666666;
399
+ }
400
+ .input-font{
401
+ font: 15px PingFang-SC-Medium;
402
+ color: #333333;
403
+ }
404
+ .btn-font{
405
+ font:600 16px PingFang-SC-Bold;
406
+ color: #499EDF;
407
+ }
408
+ .btn-color{
409
+ background-color: #FFFFFF;
410
+ border-radius: 10px ;
411
+ border: 1px solid #499EDF;
412
+ }
413
+ .app-text {
414
+ font-size: 12px;
415
+ }
416
+ .panel-self{
417
+ border-radius: 10px;
418
+ border:1px solid #499EDF;
419
+ background-color: #F8F8F8;
420
+ }
421
+ .yybtn-color{
422
+ border-radius: 4px ;
423
+ border: 1px solid #499EDF;
424
+ }
425
+ .qxbtn-color{
426
+ background-color: #FFFFFF;
427
+ border-radius: 4px ;
428
+ border: 1px solid #499EDF;
429
+ }
430
+ </style>