safecheck-client 3.0.30-7 → 3.0.30-71
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.
- package/examples/SafePlan-liaoyuan/App.vue +3 -1
- package/package.json +4 -3
- package/src/components/Util.js +15 -0
- package/src/components/android/AddPlanItem.vue +5 -2
- package/src/components/android/AreaPlan.vue +2 -2
- package/src/components/android/CurrentCreate.vue +3 -2
- package/src/components/android/CurrentCreate_new.vue +563 -559
- package/src/components/android/PhoneotherInfo.vue +132 -132
- package/src/components/android/SafecheckOrderV.vue +2 -2
- package/src/components/android/UploadPage.vue +13 -123
- package/src/components/paper/PlanChooser.vue +8 -6
- package/src/components/pc/Edit.vue +126 -0
- package/src/components/pc/LodopFuncs.js +159 -0
- package/src/components/pc/NewCheckpaper.vue +9 -5
- package/src/components/pc/PaperEdit.vue +151 -0
- package/src/components/pc/PrintData.vue +243 -0
- package/src/components/pc/PrintTable.vue +241 -0
- package/src/components/pc/SelectCheckPlanAndNoPLan.vue +281 -278
- package/src/components/querycheckpaper/CheckSearchUser.vue +1067 -1067
- package/src/components/report/NoCheckplanSafecheck.vue +0 -2
- package/src/filiale/bayan/android/SafecheckDevices.vue +1303 -1303
- package/src/filiale/bayan/android/SafecheckOrderV.vue +2850 -2850
- package/src/filiale/bayan/android/SafecheckUserInfo.vue +806 -806
- package/src/filiale/fugou/android/AddPlanItem.vue +413 -0
- package/src/filiale/fugou/android.js +10 -0
- package/src/filiale/hanzhong/android/PaperFeedback.vue +1477 -1477
- package/src/filiale/hanzhong/android/SafecheckDevices.vue +1313 -1294
- package/src/filiale/hanzhong/android/SafecheckOrderV.vue +2683 -2683
- package/src/filiale/hanzhong/android.js +16 -16
- package/src/filiale/hanzhong/pc/NewCheckpaper.vue +1923 -0
- package/src/filiale/hanzhong/pc.js +4 -1
- package/src/filiale/huatong/android/CurrentCreate.vue +564 -564
- package/src/filiale/huatong/android/SafecheckOrderV.vue +8 -0
- package/src/filiale/jingyang/android/PhoneUpUserinfo.vue +34 -34
- package/src/filiale/jingyang/pc/PaperList.vue +1 -2
- package/src/filiale/kelai/android/AddPlanItem.vue +488 -0
- package/src/filiale/kelai/android.js +1 -0
- package/src/filiale/pingxiang/pc/DefectPaperNew.vue +1 -1
- package/src/filiale/qianneng/android/PaperFeedback.vue +40 -0
- package/src/filiale/qingjian/android/PhoneUpUserinfo.vue +6 -0
- package/src/filiale/tianke/pc/checkScreen.vue +781 -781
- package/src/filiale/tianke/pc/cq.jpg +0 -0
- package/src/filiale/tianke/pc/qy.jpg +0 -0
- package/src/filiale/tongchuan/android/SafecheckDevices.vue +1 -0
- package/src/filiale/tongchuan/pc/PaperDefectMain.vue +1095 -1090
- package/src/filiale/wensu/android/AndroidDefectDeal.vue +321 -366
- package/src/filiale/wensu/android/AndroidDefectDealItems.vue +480 -0
- package/src/filiale/wensu/android.js +1 -0
- package/src/filiale/wensu/pc/CheckSearchUser.vue +64 -0
- package/src/filiale/wensu/pc/DefectPaperNew.vue +16 -10
- package/src/filiale/wensu/pc/NewCheckpaper.vue +1936 -0
- package/src/filiale/wensu/pc/RoleSelector.vue +4 -1
- package/src/filiale/wensu/pc/checkUserList.vue +50 -0
- package/src/filiale/wensu/pc.js +2 -1
- package/src/filiale/wenxi/pc/DefectPaper.vue +1 -1
- package/src/filiale/wuhai/android/SafecheckOrderV.vue +2069 -2041
- package/src/filiale/yangchunboneng/android/PaperFeedback.vue +20 -0
- package/src/filiale/yangchunboneng/pc/CheckBookDetails.vue +19 -0
- package/src/filiale/yongzhou/pc/CheckSearchUser.vue +1092 -0
- package/src/filiale/yongzhou/pc/LodopFuncs.js +159 -0
- package/src/filiale/yongzhou/pc/NoCheckplanSafecheck.vue +252 -0
- package/src/filiale/yongzhou/pc/PaperList.vue +798 -0
- package/src/filiale/yongzhou/pc/PrintData.vue +243 -0
- package/src/filiale/yongzhou/pc/PrintTable.vue +241 -0
- package/src/filiale/yongzhou/pc/communityDetail.vue +35 -12
- package/src/filiale/yongzhou/pc/communityTypeDetailG.vue +28 -14
- package/src/filiale/yongzhou/pc/communityTypeDetailM.vue +28 -14
- package/src/filiale/yongzhou/pc/safeDetail.vue +43 -15
- package/src/filiale/yongzhou/pc/safeStatistics.vue +16 -6
- package/src/filiale/yongzhou/pc/safeStatisticsDay.vue +88 -29
- package/src/filiale/yongzhou/pc/safeStatisticsMonth.vue +63 -27
- package/src/filiale/yongzhou/pc/safeStatisticsYear.vue +16 -6
- package/src/filiale/yongzhou/pc/safeTable.vue +10 -2
- package/src/filiale/yongzhou/pc.js +17 -12
- package/src/filiale/zhongsheng/android/CurrentCreate.vue +540 -536
- package/src/filiale/zhongsheng/android/SafecheckUserInfo.vue +151 -53
- package/src/filiale/zhongsheng/pc/NewCheckpaper.vue +14 -0
- package/src/safecheck-android.js +290 -290
- package/src/safecheck.js +12 -0
@@ -0,0 +1,488 @@
|
|
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">表 号:</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">楼 号:</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">单 元:</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">表 封 号:</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">电 话 号:</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">卡 号:</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">抄 表 册:</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
|
+
|
127
|
+
|
128
|
+
|
129
|
+
<div class="row text-center" style="margin-top: 20px;">
|
130
|
+
<button type="button" class="btn btn-lg btn-font btn-color" style="width: 45%;" @click="search">查询</button>
|
131
|
+
</div>
|
132
|
+
<div style="height:30px;"></div>
|
133
|
+
</form>
|
134
|
+
</div>
|
135
|
+
</criteria>
|
136
|
+
|
137
|
+
<list :model="model" partial='list'>
|
138
|
+
<div partial>
|
139
|
+
<div class="auto app-text" style="margin-top: 5px;">
|
140
|
+
<div class="panel" style="padding: 10px 10px 5px 10px;">
|
141
|
+
<div class="panel-body panel-self">
|
142
|
+
<div class="row">
|
143
|
+
<p class="panel-title col-xs-4 text-left font">用户编号</p>
|
144
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_userinfo_code }}</p>
|
145
|
+
</div>
|
146
|
+
<div class="row">
|
147
|
+
<p class="panel-title col-xs-4 text-left font">用户名称</p>
|
148
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_user_name }}</p>
|
149
|
+
</div>
|
150
|
+
<div class="row">
|
151
|
+
<p class="panel-title col-xs-4 text-left font">表号</p>
|
152
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_meternumber }}</p>
|
153
|
+
</div>
|
154
|
+
<div class="row">
|
155
|
+
<p class="panel-title col-xs-4 text-left font">用户类型</p>
|
156
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_user_type }}</p>
|
157
|
+
</div>
|
158
|
+
<div class="row">
|
159
|
+
<p class="panel-title col-xs-4 text-left font">用户电话</p>
|
160
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_user_phone2 ? row.f_user_phone2 : row.f_user_phone }}</p>
|
161
|
+
</div>
|
162
|
+
|
163
|
+
<div class="row">
|
164
|
+
<p class="panel-title col-xs-4 text-left font">小区名称</p>
|
165
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_residential_area }}</p>
|
166
|
+
</div>
|
167
|
+
<div class="row">
|
168
|
+
<p class="panel-title col-xs-4 text-left font">用户地址</p>
|
169
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_address }}</p>
|
170
|
+
</div>
|
171
|
+
<div class="row">
|
172
|
+
<p class="panel-title col-xs-4 text-left font">最后安检日期</p>
|
173
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_last_check_date }}</p>
|
174
|
+
</div>
|
175
|
+
<div class="row">
|
176
|
+
<p class="panel-title col-xs-4 text-left font">最后安检状态</p>
|
177
|
+
<p class="panel-title col-xs-8 text-left input-font">{{ row.f_last_check_state }}</p>
|
178
|
+
</div>
|
179
|
+
<div class="row">
|
180
|
+
<button type="button" v-if="$parent.$parent.$parent.isHasJurisdiction" class="btn btn-lg btn-font btn-color" style="width: 45%;float: left;" @click="$parent.$parent.$parent.showDelModal(row)">销户</button>
|
181
|
+
<button type="button" class="btn btn-lg btn-font btn-color" style="width: 45%;float: right;" @click="$parent.$parent.$parent.inspect(row)">处理</button>
|
182
|
+
</div>
|
183
|
+
</div>
|
184
|
+
</div>
|
185
|
+
|
186
|
+
</div>
|
187
|
+
</div>
|
188
|
+
</list>
|
189
|
+
</criteria-paged>
|
190
|
+
<modal :show.sync="showModal">
|
191
|
+
<div slot="modal-header" class="modal-header">
|
192
|
+
<h4 class="modal-title">
|
193
|
+
销户
|
194
|
+
</h4>
|
195
|
+
</div>
|
196
|
+
<div slot="modal-body" class="modal-body">
|
197
|
+
<div class="row app-row">
|
198
|
+
<div class="col-xs-2">
|
199
|
+
<label class="font text-left">销户原因:</label>
|
200
|
+
</div>
|
201
|
+
<div class="col-xs-10" >
|
202
|
+
<input type="text" style="width: 100%" class="search_input input-font" v-model="modalData.f_comments" placeholder="请输入销户原因">
|
203
|
+
</div>
|
204
|
+
</div>
|
205
|
+
</div>
|
206
|
+
<div slot="modal-footer" class="modal-footer">
|
207
|
+
<button type="button" class="btn btn-default" @click="accountClosure()">确认</button>
|
208
|
+
<button type="button" class="btn btn-default" @click="closeModal()">取消</button>
|
209
|
+
</div>
|
210
|
+
</modal>
|
211
|
+
<!--<back-page :need-back='true' @flag="$back()"></back-page>-->
|
212
|
+
</div>
|
213
|
+
</template>
|
214
|
+
|
215
|
+
<script>
|
216
|
+
import {HttpResetClass, PagedList} from 'vue-client'
|
217
|
+
import Vue from 'vue'
|
218
|
+
import * as Util from '../../Util'
|
219
|
+
|
220
|
+
export default {
|
221
|
+
title: '安检员B',
|
222
|
+
data () {
|
223
|
+
let model = new PagedList(`${this.$androidUtil.getProxyUrl()}/rs/sql/提取用户档案`, 20, { groupitem: '""', orderitem: '"f_residential_area,CAST(build as int),f_unit,CAST(floor1 as int),f_room"',f_check_type:'this.f_check_type[0]',
|
224
|
+
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'})
|
225
|
+
model.f_sign = ['']
|
226
|
+
model.f_user_type = ''
|
227
|
+
model.f_user_state =['']
|
228
|
+
model.f_check_type =['']
|
229
|
+
model.myCycle = 0
|
230
|
+
model.fyCycle = 0
|
231
|
+
model.f_filialeid = Vue.user.orgid
|
232
|
+
//model.f_filialeid = 287
|
233
|
+
return {
|
234
|
+
model: model,
|
235
|
+
cbc:[],
|
236
|
+
isHasJurisdiction:false,
|
237
|
+
showModal:false,
|
238
|
+
modalData:{
|
239
|
+
"f_operat_type": "销户",
|
240
|
+
"f_describe":'',
|
241
|
+
"f_user_id": '',
|
242
|
+
"f_user_name": '',
|
243
|
+
"f_state": "销户",
|
244
|
+
"f_comments": '',
|
245
|
+
"f_operator": Vue.user.name,
|
246
|
+
"f_operatorid": Vue.user.id,
|
247
|
+
"f_orgid": Vue.user.orgid,
|
248
|
+
"f_orgname": Vue.user.orgs,
|
249
|
+
"f_depid": Vue.user.depids,
|
250
|
+
"f_depname": Vue.user.deps,
|
251
|
+
"f_userinfo_id": ''
|
252
|
+
},
|
253
|
+
signs: [
|
254
|
+
{label:'请选择录入状态', value:''},
|
255
|
+
{label:'录入', value:'1'},
|
256
|
+
{label:'非录入', value:'0'},
|
257
|
+
],
|
258
|
+
ischecks: [
|
259
|
+
],
|
260
|
+
user_types: [
|
261
|
+
{label: '请选择用户类型', value: ''},
|
262
|
+
{label: '民用', value: '民用'},
|
263
|
+
{label: '非民用', value: '非民用'},
|
264
|
+
],
|
265
|
+
f_user_states: [
|
266
|
+
{label:'请选择档案状态', value:''},
|
267
|
+
{label:'正常', value:'正常'},
|
268
|
+
{label:'点火', value:'点火'},
|
269
|
+
],
|
270
|
+
f_check_types: [
|
271
|
+
{label:'请选择安检类型', value:''},
|
272
|
+
{label:'应检', value:'应检'},
|
273
|
+
{label:'超期', value:'超期'},
|
274
|
+
],
|
275
|
+
}
|
276
|
+
},
|
277
|
+
ready () {
|
278
|
+
this.isHasJurisdiction = Vue.user.r.includes('手机端销户')
|
279
|
+
},
|
280
|
+
computed: {
|
281
|
+
reload(){
|
282
|
+
this.$refs.paged.loadPage(this.$refs.paged.model.pageIndex)
|
283
|
+
},
|
284
|
+
selected () {
|
285
|
+
return this.$refs.paged.$refs.grid.selected
|
286
|
+
}
|
287
|
+
},
|
288
|
+
methods:{
|
289
|
+
accountClosure(){
|
290
|
+
if(!this.modalData.f_comments){
|
291
|
+
return this.$showMessage('请输入销户原因')
|
292
|
+
}
|
293
|
+
this.$showMessage('是否确认销户!', ['confirm', 'cancel']).then((res) => {
|
294
|
+
if (res === 'confirm') {
|
295
|
+
new HttpResetClass().load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/saveSingleCancellation`, {data: this.modalData}).then(resp=>{
|
296
|
+
this.$showMessage('销户成功。')
|
297
|
+
this.closeModal()
|
298
|
+
this.reload()
|
299
|
+
}).catch(err=>{
|
300
|
+
this.$showMessage('销户失败,服务器内部错误。')
|
301
|
+
})
|
302
|
+
}
|
303
|
+
})
|
304
|
+
},
|
305
|
+
closeModal(){
|
306
|
+
this.modalData = {
|
307
|
+
"f_operat_type": "销户",
|
308
|
+
"f_describe":'',
|
309
|
+
"f_user_id": '',
|
310
|
+
"f_user_name": '',
|
311
|
+
"f_state": "销户",
|
312
|
+
"f_comments": '',
|
313
|
+
"f_operator": Vue.user.name,
|
314
|
+
"f_operatorid": Vue.user.id,
|
315
|
+
"f_orgid": Vue.user.orgid,
|
316
|
+
"f_orgname": Vue.user.orgs,
|
317
|
+
"f_depid": Vue.user.depids,
|
318
|
+
"f_depname": Vue.user.deps,
|
319
|
+
"f_userinfo_id": ''
|
320
|
+
}
|
321
|
+
this.showModal = false
|
322
|
+
},
|
323
|
+
showDelModal(row){
|
324
|
+
this.showModal = true
|
325
|
+
this.modalData.f_userinfo_id = row.f_userinfo_id
|
326
|
+
this.modalData.f_user_name = row.f_user_name
|
327
|
+
this.modalData.f_user_id = row.f_user_id
|
328
|
+
this.modalData.f_describe = `${Vue.user.name}对用户${row.f_user_name}进行销户`
|
329
|
+
|
330
|
+
},
|
331
|
+
scan(){
|
332
|
+
HostApp.__this__=this,
|
333
|
+
HostApp.scanCode({callback:"javascript:HostApp.__this__.getCode();"})
|
334
|
+
},
|
335
|
+
getCode(){
|
336
|
+
var datapa = HostApp.getCode().data;
|
337
|
+
//tag
|
338
|
+
this.$refs.paged.$refs.cri.model.f_meternumber=datapa
|
339
|
+
},
|
340
|
+
getCheckTime(){
|
341
|
+
//tag
|
342
|
+
new HttpResetClass().load('post',`${this.$androidUtil.getProxyUrl()}/rs/sql/tel_singleTable_OrderBy`,{data: {
|
343
|
+
items: 'f_circle,f_start_time',
|
344
|
+
tablename: 't_safe_circle',
|
345
|
+
condition: `f_filialeid = '${Vue.user.orgid}'`,
|
346
|
+
orderitem: 'id'
|
347
|
+
}}).then(res=>{
|
348
|
+
//tag)
|
349
|
+
let nocheck=''
|
350
|
+
let ischeck=''
|
351
|
+
if (res.data[0]){
|
352
|
+
if (res.data[0].f_circle=='1'){
|
353
|
+
nocheck=`(ua.f_last_check_date<'${res.data[0].f_start_time}' or ua.f_last_check_date is null)`
|
354
|
+
ischeck=`ua.f_last_check_date>'${res.data[0].f_start_time}'`
|
355
|
+
|
356
|
+
}else{
|
357
|
+
let addtime= (Util.toStandardTimeString().substring(0,4)-res.data[0].f_start_time.substring(0,4))%res.data[0].f_circle
|
358
|
+
//tag
|
359
|
+
let time =(Util.toStandardTimeString().substring(0,4)-addtime)+'-01-01 00:00:00'
|
360
|
+
//tag
|
361
|
+
nocheck=`(ua.f_last_check_date<'${time}' or ua.f_last_check_date is null)`
|
362
|
+
ischeck=`ua.f_last_check_date>'${time}'`
|
363
|
+
}
|
364
|
+
//tag
|
365
|
+
this.ischecks=[
|
366
|
+
{label: '全部', value: ''},
|
367
|
+
{label: '已检', value: ischeck },
|
368
|
+
{label: '未检', value: nocheck},
|
369
|
+
]
|
370
|
+
//tag
|
371
|
+
}else{
|
372
|
+
this.$showMessage("未配置安检周期")
|
373
|
+
}
|
374
|
+
|
375
|
+
})
|
376
|
+
//tag
|
377
|
+
},
|
378
|
+
inspect (info){
|
379
|
+
if(info.f_last_check_date){
|
380
|
+
this.$showMessage("该用户最后一次安检时间为 "+info.f_last_check_date+" 是否继续对该用户进行安检",['confirm', 'cancel']).then((butt)=>{
|
381
|
+
if(butt=="confirm"){
|
382
|
+
info.id = ''
|
383
|
+
info.f_state = '未检'
|
384
|
+
info.f_no_checkplan = '无计划安检'
|
385
|
+
//tag
|
386
|
+
this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/查询计划项表信息`,{data:{f_userid:info.f_userinfo_id}}).then((response)=>{
|
387
|
+
//tag)
|
388
|
+
info['f_plan_meters'] = response.data
|
389
|
+
var pardate = {
|
390
|
+
_this:this,
|
391
|
+
tittle:'安检详情',
|
392
|
+
safe:true
|
393
|
+
}
|
394
|
+
this.$dispatch('gotoson',pardate)
|
395
|
+
this.$goto('safecheck-order-v', {item: info, role: 'inspect',parentPage:'AddPlanItem'}, 'self', this.reload)
|
396
|
+
|
397
|
+
})
|
398
|
+
}
|
399
|
+
})
|
400
|
+
}else{
|
401
|
+
info.id = ''
|
402
|
+
info.f_state = '未检'
|
403
|
+
info.f_no_checkplan = '无计划安检'
|
404
|
+
//tag
|
405
|
+
this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/sql/查询计划项表信息`,{data:{f_userid:info.f_userinfo_id}}).then((response)=>{
|
406
|
+
//tag)
|
407
|
+
info['f_plan_meters'] = response.data
|
408
|
+
var pardate = {
|
409
|
+
_this:this,
|
410
|
+
tittle:'安检详情',
|
411
|
+
safe:true
|
412
|
+
}
|
413
|
+
this.$dispatch('gotoson',pardate)
|
414
|
+
this.$goto('safecheck-order-v', {item: info, role: 'inspect',parentPage:'AddPlanItem'}, 'self', this.reload)
|
415
|
+
|
416
|
+
})
|
417
|
+
}
|
418
|
+
},
|
419
|
+
Mreadibook(){
|
420
|
+
this.cbc=[]
|
421
|
+
let http = new HttpResetClass()
|
422
|
+
http.load('POST',`${this.$androidUtil.getProxyUrl()}/rs/logic/getMeterBooksData`,
|
423
|
+
{data: {f_orgid: "('"+Vue.user.orgid+"')"}},
|
424
|
+
{resolveMsg: null, rejectMsg: '获取失败!!!'}).then((getMeterReadingBooks)=>{
|
425
|
+
this.cbc = [{label: '全部', value: ''}]
|
426
|
+
//tag
|
427
|
+
//tag)
|
428
|
+
//tag
|
429
|
+
getMeterReadingBooks.data.meterbooks.forEach((res) => {
|
430
|
+
this.cbc.push({label: res.f_book_name, value: res.id})
|
431
|
+
/*if(res.f_book_slice_area){
|
432
|
+
if(this.sliceArea.indexOf(res.f_book_slice_area)<0){
|
433
|
+
this.sliceArea.push(res.f_book_slice_area)
|
434
|
+
}
|
435
|
+
}*/
|
436
|
+
})
|
437
|
+
})
|
438
|
+
|
439
|
+
|
440
|
+
}
|
441
|
+
}
|
442
|
+
}
|
443
|
+
</script>
|
444
|
+
<style scoped>
|
445
|
+
.app-row {
|
446
|
+
background-color: white;
|
447
|
+
padding: 10px 10px 0 10px;
|
448
|
+
border-bottom: 1px solid rgba(235, 235, 235, 0.5);
|
449
|
+
}
|
450
|
+
.search_input {
|
451
|
+
border: 0;
|
452
|
+
outline: none;
|
453
|
+
}
|
454
|
+
.font{
|
455
|
+
font: 15px PingFang-SC-Medium;
|
456
|
+
color: #666666;
|
457
|
+
}
|
458
|
+
.input-font{
|
459
|
+
font: 15px PingFang-SC-Medium;
|
460
|
+
color: #333333;
|
461
|
+
}
|
462
|
+
.btn-font{
|
463
|
+
font:600 16px PingFang-SC-Bold;
|
464
|
+
color: #499EDF;
|
465
|
+
}
|
466
|
+
.btn-color{
|
467
|
+
background-color: #FFFFFF;
|
468
|
+
border-radius: 10px ;
|
469
|
+
border: 1px solid #499EDF;
|
470
|
+
}
|
471
|
+
.app-text {
|
472
|
+
font-size: 12px;
|
473
|
+
}
|
474
|
+
.panel-self{
|
475
|
+
border-radius: 10px;
|
476
|
+
border:1px solid #499EDF;
|
477
|
+
background-color: #F8F8F8;
|
478
|
+
}
|
479
|
+
.yybtn-color{
|
480
|
+
border-radius: 4px ;
|
481
|
+
border: 1px solid #499EDF;
|
482
|
+
}
|
483
|
+
.qxbtn-color{
|
484
|
+
background-color: #FFFFFF;
|
485
|
+
border-radius: 4px ;
|
486
|
+
border: 1px solid #499EDF;
|
487
|
+
}
|
488
|
+
</style>
|
@@ -4,6 +4,7 @@ import Vue from "vue";
|
|
4
4
|
// 手机特殊目录注册到该文件中
|
5
5
|
let specialComp = {
|
6
6
|
'safecheck-order-v': (resolve) => { require(['./android/SafecheckOrderV'], resolve) },
|
7
|
+
'add-plan-item': (resolve) => { require(['./android/AddPlanItem'], resolve) },
|
7
8
|
'safecheck-devices' : (resolve) => { require(['./android/SafecheckDevices'], resolve) },
|
8
9
|
'paper-feedback' : (resolve) => { require(['./android/PaperFeedback'], resolve) },
|
9
10
|
'current-create' : (resolve) => { require(['./android/CurrentCreate'], resolve) },
|
@@ -545,7 +545,7 @@ export default {
|
|
545
545
|
cbcs:[],
|
546
546
|
thead: '',
|
547
547
|
headData: ['入户状态','用户编号','用户名','用户电话','用户小区','用户地址','安检时间','安检员','计划名','是否有隐患','隐患数','隐患明细'],
|
548
|
-
bodyData: ['f_entry_status','f_userinfo_code','f_user_name','f_user_phone','f_residential_area','f_address','f_offsite_time','f_checker_name','f_plan_name','f_has_defect','f_defect_count','
|
548
|
+
bodyData: ['f_entry_status','f_userinfo_code','f_user_name','f_user_phone','f_residential_area','f_address','f_offsite_time','f_checker_name','f_plan_name','f_has_defect','f_defect_count','defecttext'],
|
549
549
|
}
|
550
550
|
},
|
551
551
|
props:{
|
@@ -123,6 +123,10 @@
|
|
123
123
|
<input type="checkbox" v-model="paper.f_gas_manual" /><label class="text-left font" >安全用气手册</label>
|
124
124
|
</div>
|
125
125
|
</div>
|
126
|
+
<div class="row">
|
127
|
+
<label for="readsafe" class="text-left font">蓝牙状态:{{blueState}}</label>
|
128
|
+
<button type="button" @click="initBlueState()">重新连接</button>
|
129
|
+
</div>
|
126
130
|
<div class="form-group col-md-12 col-sm-12 col-xs-12" :class="style__">
|
127
131
|
<div class="form-group col-md-12 col-sm-12 col-xs-12">
|
128
132
|
<input type="checkbox" v-model="paper.f_defect_notified" class="showIi" />隐患整改单
|
@@ -463,6 +467,7 @@
|
|
463
467
|
title: '用户反馈',
|
464
468
|
data() {
|
465
469
|
return {
|
470
|
+
blueState:'',
|
466
471
|
defectImgs: [],
|
467
472
|
defectToolTip: [],
|
468
473
|
defectReason: [],
|
@@ -525,6 +530,25 @@
|
|
525
530
|
Radio
|
526
531
|
},
|
527
532
|
methods: {
|
533
|
+
initBlueState(){
|
534
|
+
let state = HostApp.getBluetoothState()
|
535
|
+
if (state && state.state == 3){
|
536
|
+
this.blueState = '连接完成'
|
537
|
+
}else {
|
538
|
+
if (state && state.state == -1){
|
539
|
+
this.$showMessage('蓝牙连接未打开,打开后重新尝试')
|
540
|
+
return
|
541
|
+
}
|
542
|
+
this.blueState = '连接失败,请重试'
|
543
|
+
this.$androidUtil.print(JSON.stringify([{ type: 4, value: 2, unit: 'line' }]))
|
544
|
+
let state2 = HostApp.getBluetoothState()
|
545
|
+
if (state2 && state2.state == 3){
|
546
|
+
this.blueState = '连接完成'
|
547
|
+
}else {
|
548
|
+
this.blueState = '连接失败,请重试'
|
549
|
+
}
|
550
|
+
}
|
551
|
+
},
|
528
552
|
timeSet(val) {
|
529
553
|
//////tag
|
530
554
|
if (!val) {
|
@@ -759,6 +783,16 @@
|
|
759
783
|
return hasError
|
760
784
|
},
|
761
785
|
print() {
|
786
|
+
let state = HostApp.getBluetoothState()
|
787
|
+
if (state && state.state == 3){
|
788
|
+
this.blueState = '连接完成'
|
789
|
+
}else {
|
790
|
+
this.blueState = '连接失败,请重试'
|
791
|
+
}
|
792
|
+
if (state && state.state == -1){
|
793
|
+
this.$showMessage('蓝牙未打开,请确认蓝牙是否打开')
|
794
|
+
return
|
795
|
+
}
|
762
796
|
let errString = this.verify()
|
763
797
|
if (errString) {
|
764
798
|
////tag
|
@@ -1193,6 +1227,12 @@
|
|
1193
1227
|
},
|
1194
1228
|
},
|
1195
1229
|
async ready() {
|
1230
|
+
let state = HostApp.getBluetoothState()
|
1231
|
+
if (state && state.state == 3){
|
1232
|
+
this.blueState = '连接完成'
|
1233
|
+
}else {
|
1234
|
+
this.blueState = '连接失败,请重试'
|
1235
|
+
}
|
1196
1236
|
this.isRecodr = this.$appdata.getSingleValue('无限制录音');
|
1197
1237
|
// await this.isoverDate()
|
1198
1238
|
////tag
|
@@ -616,6 +616,9 @@ export default {
|
|
616
616
|
}
|
617
617
|
this.$showMessage('确定是否修改上传用户信息?', ['confirm', 'cancel']).then((res) => {
|
618
618
|
if (res === 'confirm') {
|
619
|
+
this.userinfo.addressinfo.f_residential_area = this.selectArea.f_residential_area ? this.selectArea.f_residential_area : ''
|
620
|
+
this.userinfo.addressinfo.f_residential_area_id = this.selectArea.id ? this.selectArea.id : ''
|
621
|
+
this.userinfo.addressinfo.f_slice_area = this.selectArea.f_slice_area ? this.selectArea.f_slice_area : ''
|
619
622
|
this.excessive = true
|
620
623
|
let address = {}
|
621
624
|
address.f_filialeid = this.userinfo.addressinfo.f_filialeid
|
@@ -695,6 +698,9 @@ export default {
|
|
695
698
|
}
|
696
699
|
this.$showMessage('确定是否修改上传审核用户信息?', ['confirm', 'cancel']).then((res) => {
|
697
700
|
if (res === 'confirm') {
|
701
|
+
this.userinfo.addressinfo.f_residential_area = this.selectArea.f_residential_area ? this.selectArea.f_residential_area : ''
|
702
|
+
this.userinfo.addressinfo.f_residential_area_id = this.selectArea.id ? this.selectArea.id : ''
|
703
|
+
this.userinfo.addressinfo.f_slice_area = this.selectArea.f_slice_area ? this.selectArea.f_slice_area : ''
|
698
704
|
this.excessive = true
|
699
705
|
let address = {}
|
700
706
|
address.f_filialeid = this.userinfo.addressinfo.f_filialeid
|