apply-clients 3.4.2 → 3.4.3

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 (85) hide show
  1. package/android.html +23 -23
  2. package/build/dev-server.js +119 -119
  3. package/build/webpack.base.conf.js +2 -1
  4. package/build/webpack.dev.conf.js +12 -0
  5. package/dingding.html +23 -0
  6. package/index.html +33 -33
  7. package/package.json +2 -1
  8. package/src/AndroidApp.vue +35 -35
  9. package/src/DingDingApp.vue +51 -0
  10. package/src/android.js +21 -21
  11. package/src/apply.js +7 -1
  12. package/src/applyAndroid.js +32 -32
  13. package/src/applyDingDing.js +12 -0
  14. package/src/components/android/AppOnetomany.vue +301 -301
  15. package/src/components/android/AppServiceView.vue +566 -566
  16. package/src/components/android/AppSign.vue +142 -142
  17. package/src/components/android/AppTakePic.vue +143 -143
  18. package/src/components/android/Process/AppExplorationUser.vue +320 -320
  19. package/src/components/android/Process/AppServiceControl.vue +757 -757
  20. package/src/components/android/Process/Processes/AppInstallationDetails.vue +456 -456
  21. package/src/components/android/ProgressReport/ProgressReportDetail.vue +64 -64
  22. package/src/components/android/Supervisory/AppSupervisoryCart.vue +121 -121
  23. package/src/components/android/TaskGraph.vue +125 -125
  24. package/src/components/product/Business/BusinessApply.vue +269 -0
  25. package/src/components/product/Business/CivilApply.vue +269 -0
  26. package/src/components/product/Function/InstallFunction.vue +131 -125
  27. package/src/components/product/Function/InstallInfoSelect.vue +300 -292
  28. package/src/components/product/Function/Service/FunctionServiceControl.vue +420 -222
  29. package/src/components/product/GroupByApply/ApplyGroupByList.vue +253 -0
  30. package/src/components/product/GroupByApply/ApplyGroupByMain.vue +53 -0
  31. package/src/components/product/GroupByApply/ApplyGroupByPaper.vue +376 -0
  32. package/src/components/product/Material/MaterialDetailed.vue +262 -0
  33. package/src/components/product/Onetomany.vue +377 -377
  34. package/src/components/product/Print/BuildOrder/buildOrderList.vue +339 -0
  35. package/src/components/product/Print/BuildOrder/printBuildOrder.vue +157 -0
  36. package/src/components/product/Print/IgnitionBill/IgnitionBill.vue +259 -0
  37. package/src/components/product/Print/IgnitionBill/printIgnitionBill.vue +168 -0
  38. package/src/components/product/Process/ExplorationSelect.vue +7 -0
  39. package/src/components/product/Process/ExplorationUser.vue +138 -138
  40. package/src/components/product/Process/Processes/InstallationDetails.vue +592 -592
  41. package/src/components/product/Process/Processes/Print/printCharge.vue +142 -142
  42. package/src/components/product/Process/Processes/addressAndUserinfoManagement.vue +207 -207
  43. package/src/components/product/Process/Processes/chargeManagement.vue +638 -639
  44. package/src/components/product/Process/Service/ServiceControl.vue +10 -10
  45. package/src/components/product/Process/Service/ShowBackReason.vue +33 -33
  46. package/src/components/product/ServiceView.vue +631 -631
  47. package/src/components/product/Stop/StopApply.vue +105 -103
  48. package/src/components/product/Stop/StopApplyList.vue +269 -269
  49. package/src/components/product/Supervisory/Service/SupervisoryServiceControl.vue +186 -186
  50. package/src/components/product/Supervisory/SupervisoryControl.vue +100 -100
  51. package/src/components/product/Supervisory/SupervisoryList.vue +233 -233
  52. package/src/components/product/Supervisory/SupervisoryhCart.vue +107 -107
  53. package/src/components/product/VueUtils/ApplyUpload.vue +273 -273
  54. package/src/components/product/VueUtils/HighMeter.vue +208 -208
  55. package/src/dingding.js +19 -0
  56. package/src/expandcssAndroid.less +1034 -1034
  57. package/src/filiale/yuchuan/android/Process/AppServiceControl.vue +735 -731
  58. package/src/filiale/yuchuan/android/Process/Processes/AppInstallationDetails.vue +824 -824
  59. package/src/filiale/yuchuan/android/Process/Processes/AppInstallationDetailsCivil.vue +650 -650
  60. package/src/filiale/yuchuan/android/Sign/AppSignTask.vue +182 -182
  61. package/src/filiale/yuchuan/android/Sign/BuildSign.vue +50 -50
  62. package/src/filiale/yuchuan/android/Sign/ConstructSign.vue +50 -50
  63. package/src/filiale/yuchuan/android/Sign/DesignSign.vue +50 -50
  64. package/src/filiale/yuchuan/android/Sign/SupervisorSign.vue +50 -50
  65. package/src/filiale/yuchuan/android/Task/Build/BuildTsak.vue +60 -60
  66. package/src/filiale/yuchuan/android/Task/Survey/SurveyTsak.vue +60 -60
  67. package/src/filiale/yuchuan/android.js +14 -14
  68. package/src/filiale/yuchuan/pc/Order/OrderApply.vue +528 -528
  69. package/src/filiale/yuchuan/pc/Order/OrderApplyList.vue +343 -343
  70. package/src/filiale/yuchuan/pc/Print/BuildOrder/buildOrderList.vue +264 -0
  71. package/src/filiale/yuchuan/pc/Print/BuildOrder/printBuildOrder.vue +152 -0
  72. package/src/filiale/yuchuan/pc/Process/ExplorationUser.vue +149 -149
  73. package/src/filiale/yuchuan/pc/Process/Processes/ApplyMapCom.vue +67 -67
  74. package/src/filiale/yuchuan/pc/Process/Processes/InstallationDetails.vue +809 -809
  75. package/src/filiale/yuchuan/pc/Process/Processes/InstallationDetailsCivil.vue +595 -595
  76. package/src/filiale/yuchuan/pc/Process/Processes/Print/printCharge.vue +125 -0
  77. package/src/filiale/yuchuan/pc/Process/Processes/chargeManagement.vue +621 -470
  78. package/src/filiale/yuchuan/pc/Process/Service/ServiceControl.vue +1108 -1074
  79. package/src/filiale/yuchuan/pc/Sign/SignRecord.vue +24 -0
  80. package/src/filiale/yuchuan/pc/Sign/SignRecordList.vue +174 -0
  81. package/src/filiale/yuchuan/pc.js +20 -12
  82. package/src/main.js +1 -1
  83. package/src/components/product/Function/StopApplyCrrdList.vue +0 -176
  84. package/src/components/product/Function/functions/ApplyRecordCancel.vue +0 -102
  85. package/src/components/product/Function/functions/StopInstall.vue +0 -106
@@ -1,824 +1,824 @@
1
- <template>
2
- <div class="col-xs-12 col-xs-12 form-group app-btn">
3
- <button class="btn btn-info" @click.prevent="showUserFileModal()" :disabled="mark === 1 || model.rows.length >= selectdata.f_install_count">添加用户</button>
4
- </div>
5
- <div class="col-xs-12 col-xs-12">
6
- <list :model="model" partial='list'>
7
- <div partial class="auto app-text panel">
8
- <div class="panel-body panel-self">
9
- <div class="row">
10
- <p class="col-xs-3 text-left font"><b class="control-label-justify">客户编号</b></p>
11
- <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_userinfo_code }}</p>
12
- </div>
13
- <div class="row">
14
- <p class="col-xs-3 text-left font"><b class="control-label-justify">客户名称</b></p>
15
- <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_user_name }}</p>
16
- </div>
17
- <div class="row">
18
- <p class="col-xs-3 text-left font"><b class="control-label-justify">客户电话</b></p>
19
- <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_user_phone }}</p>
20
- </div>
21
- <div class="row" v-if="$parent.$parent.selectdata.f_apply_type === '散户集体报建' || $parent.$parent.selectdata.f_apply_type === '煤改气报建'">
22
- <p class="col-xs-3 text-left font"><b class="control-label-justify">单价</b></p>
23
- <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ $parent.$parent.selectdata.f_price }}</p>
24
- </div>
25
- <div class="row" v-if="$parent.$parent.selectdata.f_apply_type === '散户集体报建' || $parent.$parent.selectdata.f_apply_type === '煤改气报建'">
26
- <p class="col-xs-3 text-left font"><b class="control-label-justify">累计缴费</b></p>
27
- <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_cumulative_payment_money }}</p>
28
- </div>
29
- <div class="row">
30
- <p class="col-xs-3 text-left font"><b class="control-label-justify">地址信息</b></p>
31
- <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_address }}</p>
32
- </div>
33
- <div class="row text-right">
34
- </div>
35
- </div>
36
- </div>
37
- </list>
38
- </div>
39
-
40
- <validator name="v">
41
- <modal v-if="showUserFile" :show.sync="showUserFile" v-ref:modal :large="true" :backdrop="false">
42
- <header slot="modal-header" class="modal-header">
43
- <button type="button" class="close" @click="closeUserFile"><span>&times;</span></button>
44
- <h4 class="modal-title">安装明细</h4>
45
- </header>
46
- <article slot="modal-body" class="modal-body clearfix">
47
- <!-- 基本信息 -->
48
- <div class="form-group col-xs-12 panel panel-info">
49
- <div class="panel-heading head row" style="background-color: #e8f4ff;margin-bottom: 10px">
50
- <div class="col-xs-12 text-left">用户信息</div>
51
- </div>
52
- <div class="form-group row vertical-center">
53
- <label class="col-xs-4 control-label">客户名称:</label>
54
- <div class="col-xs-8">
55
- <input class="form-control input_view" style=""
56
- v-model="userinfo.f_user_name"
57
- :value.sync="serinfo.f_user_name"
58
- :readonly="mark === 1"
59
- placeholder="客户名称"/>
60
- </div>
61
- </div>
62
- <div class="form-group row vertical-center">
63
- <label class="col-xs-4 control-label">客户电话:</label>
64
- <div class="col-xs-8">
65
- <input class="form-control input_view" style=""
66
- v-model="userinfo.f_user_phone"
67
- :value.sync="userinfo.f_user_phone"
68
- :readonly="mark === 1"
69
- placeholder="客户电话"/>
70
- </div>
71
- </div>
72
- <div class="form-group row vertical-center">
73
- <label class="col-xs-4 control-label">证件类型:</label>
74
- <div class="col-xs-8">
75
- <input-select
76
- class="select select_list"
77
- :value.sync="userinfo.f_credentials"
78
- v-model="userinfo.f_credentials"
79
- :options="credentialsList"
80
- :disable="mark === 1"
81
- :valueSingle="true"></input-select>
82
- </div>
83
- </div>
84
- <div class="form-group row vertical-center">
85
- <label class="col-xs-4 control-label">证件号码:</label>
86
- <div class="col-xs-8">
87
- <input class="form-control input_view" style=""
88
- placeholder="证件号码"
89
- v-model="userinfo.f_idnumber"
90
- :value="userinfo.f_idnumber"
91
- :readonly="mark === 1"/>
92
- </div>
93
- </div>
94
- </div>
95
- <!-- 地址信息 -->
96
- <div class="form-group col-xs-12 panel panel-info">
97
- <div class="panel-heading head row" style="background-color: #e8f4ff;margin-bottom: 10px">
98
- <div class="col-xs-6 text-left">地址信息</div>
99
- </div>
100
- <div class="form-group row vertical-center" :class="[$v.f_address_type.required ? 'has-error' : '']">
101
- <label class="col-xs-4 control-label">地址类型:</label>
102
- <div class="col-xs-8">
103
- <input type="text" v-show="false" v-model="useradders.f_address_type" :value.sync="useradders.f_address_type" v-validate:f_address_type = "['required']" >
104
- <input-select
105
- class="select select_list"
106
- :value.sync="useradders.f_address_type"
107
- v-model="useradders.f_address_type"
108
- :options="addressTypeList"
109
- :disable="true"
110
- :valueSingle="true"></input-select>
111
- </div>
112
- </div>
113
- <div class="form-group row vertical-center" :class="[$v.f_slice_area.required ? 'has-error' : '']">
114
- <label class="col-xs-4 control-label">片&emsp;&emsp;区:</label>
115
- <div class="col-xs-8">
116
- <input type="text" v-show="false" v-model="useradders.f_slice_area" v-validate:f_slice_area = "['required']" >
117
- <input-select
118
- class="select select_list"
119
- :value.sync="useradders.f_slice_area"
120
- v-model="useradders.f_slice_area"
121
- :options="sliceAreaList"
122
- :disable="mark === 1 || selectdata.f_apply_nature === '小区'"
123
- :valueSingle="true"></input-select>
124
- </div>
125
- </div>
126
- <div class="form-group row vertical-center" :class="[$v.f_pcd.required ? 'has-error' : '']">
127
- <label class="col-xs-4 control-label">省&ensp;市&ensp;区:</label>
128
- <div class="col-xs-8">
129
- <input type="text" v-show="false" v-model="useradders.f_pcd" :value.sync="useradders.f_pcd" v-validate:f_pcd = "['required']" >
130
- <input-select
131
- class="select select_list"
132
- :value.sync="useradders.f_pcd"
133
- v-model="useradders.f_pcd"
134
- :options="pcdList"
135
- @change="pcdChange(),addressSplicing()"
136
- :disable="mark === 1 || selectdata.f_apply_nature === '小区'"
137
- :valueSingle="true"></input-select>
138
- </div>
139
- </div>
140
- <div class="form-group row vertical-center" :class="[$v.f_street.required ? 'has-error' : '']">
141
- <label class="col-xs-4 control-label">街&emsp;&emsp;道:</label>
142
- <div class="col-xs-8">
143
- <input type="text" v-show="false" v-model="useradders.f_street" :value.sync="useradders.f_street" v-validate:f_street = "['required']" >
144
- <input-select
145
- class="select select_list"
146
- :value.sync="useradders.f_street"
147
- v-model="useradders.f_street"
148
- :options="streetList"
149
- @change="streetChange(),addressSplicing()"
150
- :disable="mark === 1 || selectdata.f_apply_nature === '小区'"
151
- :valueSingle="true"></input-select>
152
- </div>
153
- </div>
154
- <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'" :class="[$v.f_residential_area.required ? 'has-error' : '']">
155
- <label class="col-xs-4 control-label">小&emsp;&emsp;区:</label>
156
- <div class="col-xs-8">
157
- <input type="text" v-show="false" v-model="useradders.f_residential_area" :value.sync="useradders.f_residential_area" v-validate:f_residential_area = "['required']" >
158
- <input-select
159
- class="select select_list"
160
- :value.sync="useradders.f_residential_area"
161
- v-model="useradders.f_residential_area"
162
- :options="residentialList"
163
- @change="addressSplicing"
164
- :disable="mark === 1 || selectdata.f_apply_nature === '小区'"
165
- :valueSingle="true"></input-select>
166
- </div>
167
- </div>
168
- <div class="form-group row vertical-center" v-if="useradders.f_address_type === '特殊地址'">
169
- <label class="col-xs-4 control-label">小&emsp;&emsp;区:</label>
170
- <div class="col-xs-8">
171
- <input-select
172
- class="select select_list"
173
- :value.sync="useradders.f_residential_area"
174
- v-model="useradders.f_residential_area"
175
- :options="residentialList"
176
- @change="addressSplicing"
177
- :disable="mark === 1"
178
- :valueSingle="true"></input-select>
179
- </div>
180
- </div>
181
- <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'">
182
- <label class="col-xs-4 control-label">楼&emsp;&emsp;号:</label>
183
- <div class="col-xs-8">
184
- <input class="form-control input_view col-xs-10" style="width: 80%"
185
- placeholder="楼号"
186
- v-model="useradders.f_building"
187
- :value="useradders.f_building"
188
- @change="addressSplicing"
189
- :readonly="mark === 1"/>
190
- <input class="form-control input_view col-xs-2" style="width: 20%"
191
- v-model="useradders.f_building_suffix"
192
- :value="useradders.f_building_suffix"
193
- @change="addressSplicing"
194
- :readonly="mark === 1"/>
195
- </div>
196
- </div>
197
- <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'">
198
- <label class="col-xs-4 control-label">单&emsp;&emsp;元:</label>
199
- <div class="col-xs-8">
200
- <input class="form-control input_view col-xs-10" style="width: 80%"
201
- placeholder="单元"
202
- v-model="useradders.f_unit"
203
- :value="useradders.f_unit"
204
- @change="addressSplicing"
205
- :readonly="mark === 1"/>
206
- <input class="form-control input_view col-xs-2" style="width: 20%"
207
- v-model="useradders.f_unit_suffix"
208
- :value="useradders.f_unit_suffix"
209
- @change="addressSplicing"
210
- :readonly="mark === 1"/>
211
- </div>
212
- </div>
213
- <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'">
214
- <label class="col-xs-4 control-label">楼&emsp;&emsp;层:</label>
215
- <div class="col-xs-8">
216
- <input class="form-control input_view col-xs-10" style="width: 80%"
217
- placeholder="楼层"
218
- v-model="useradders.f_floor"
219
- :value="useradders.f_floor"
220
- @change="addressSplicing"
221
- :readonly="mark === 1"/>
222
- <input class="form-control input_view col-xs-2" style="width: 20%"
223
- v-model="useradders.f_floor_suffix"
224
- :value="useradders.f_floor_suffix"
225
- @change="addressSplicing"
226
- :readonly="mark === 1"/>
227
- </div>
228
- </div>
229
- <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'" :class="[$v.f_room.required ? 'has-error' : '']">
230
- <label class="col-xs-4 control-label">门&ensp;牌&ensp;号:</label>
231
- <div class="col-xs-8">
232
- <input class="form-control input_view col-xs-10" style="width: 80%"
233
- placeholder="门牌号" v-validate:f_room = "['required']"
234
- v-model="useradders.f_room"
235
- :value="useradders.f_room"
236
- @change="addressSplicing"
237
- :readonly="mark === 1"/>
238
- <input class="form-control input_view col-xs-2" style="width: 20%"
239
- v-model="useradders.f_room_suffix"
240
- :value="useradders.f_room_suffix"
241
- @change="addressSplicing"
242
- :readonly="mark === 1"/>
243
- </div>
244
- </div>
245
- <div class="form-group row vertical-center">
246
- <label class="col-xs-4 control-label">地&emsp;&emsp;址:</label>
247
- <div class="col-xs-8">
248
- <input class="form-control input_view"
249
- placeholder="地址"
250
- v-model="useradders.f_address"
251
- :value.sync="useradders.f_address"
252
- :readonly="mark === 1"/>
253
- </div>
254
- </div>
255
- </div>
256
- <!-- 表具信息 -->
257
- <div class="form-group col-xs-12 panel panel-info">
258
- <div class="panel-heading head row" style="background-color: #e8f4ff;margin-bottom: 10px">
259
- <div class="col-xs-6 text-left">表具信息</div>
260
- <div class="col-xs-6 text-right">
261
- <svg @click="scanCode()" style="width: 25px;height: 25px;margin-right: 10px" t="1636095770822" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2457" width="64" height="64"><path d="M928.016126 543.908618 95.983874 543.908618c-17.717453 0-31.994625-14.277171-31.994625-31.994625S78.26642 479.919368 95.983874 479.919368l832.032253 0c17.717453 0 31.994625 14.277171 31.994625 31.994625S945.73358 543.908618 928.016126 543.908618z" p-id="2458"></path><path d="M832.032253 928.016126 639.892491 928.016126c-17.717453 0-31.994625-14.277171-31.994625-31.994625s14.277171-31.994625 31.994625-31.994625l191.967747 0c17.717453 0 31.994625-14.277171 31.994625-31.994625l0-159.973123c0-17.717453 14.277171-31.994625 31.994625-31.994625s31.994625 14.277171 31.994625 31.994625l0 159.973123C928.016126 884.840585 884.840585 928.016126 832.032253 928.016126z" p-id="2459"></path><path d="M351.94087 928.016126l-159.973123 0c-52.980346 0-95.983874-43.003528-95.983874-95.983874l0-159.973123c0-17.717453 14.277171-31.994625 31.994625-31.994625S159.973123 654.341676 159.973123 672.05913l0 159.973123c0 17.717453 14.449185 31.994625 31.994625 31.994625l159.973123 0c17.717453 0 31.994625 14.277171 31.994625 31.994625C383.935495 913.738955 369.658324 928.016126 351.94087 928.016126z" p-id="2460"></path><path d="M127.978498 383.935495c-17.717453 0-31.994625-14.277171-31.994625-31.994625l0-159.973123c0-52.980346 43.003528-95.983874 95.983874-95.983874l159.973123 0c17.717453 0 31.994625 14.277171 31.994625 31.994625S369.658324 159.973123 351.94087 159.973123l-159.973123 0c-17.545439 0-31.994625 14.449185-31.994625 31.994625l0 159.973123C159.973123 369.658324 145.695952 383.935495 127.978498 383.935495z" p-id="2461"></path><path d="M896.021502 383.935495c-17.717453 0-31.994625-14.277171-31.994625-31.994625l0-159.973123c0-17.545439-14.277171-31.994625-31.994625-31.994625L639.892491 159.973123c-17.717453 0-31.994625-14.277171-31.994625-31.994625s14.277171-31.994625 31.994625-31.994625l191.967747 0c52.980346 0 95.983874 43.003528 95.983874 95.983874l0 159.973123C928.016126 369.658324 913.738955 383.935495 896.021502 383.935495z" p-id="2462"></path></svg>
262
- </div>
263
- </div>
264
- <div class="form-group row vertical-center" :class="[$v.gasbrand.required ? 'has-error' : '']">
265
- <label class="col-xs-4 control-label">气表品牌:</label>
266
- <div class="col-xs-8">
267
- <input type="text" v-show="false" v-model="userfile.gasbrand.id" :value.sync="userfile.gasbrand.id" v-validate:gasbrand = "['required']" >
268
- <input-select
269
- class="select select_list"
270
- :value.sync="userfile.gasbrand"
271
- v-model="userfile.gasbrand"
272
- :options="meterbrands"
273
- @change="gasbrandChange()"
274
- :disable="mark === 1"
275
- :valueSingle="true"></input-select>
276
- </div>
277
- </div>
278
- <div class="form-group row vertical-center" :class="[$v.gasmodel.required ? 'has-error' : '']">
279
- <label class="col-xs-4 control-label">气表型号:</label>
280
- <div class="col-xs-8">
281
- <input type="text" v-show="false" v-model="userfile.gasmodel.id" :value.sync="userfile.gasmodel.id" v-validate:gasmodel = "['required']" >
282
- <input-select
283
- class="select select_list"
284
- :value.sync="userfile.gasmodel"
285
- v-model="userfile.gasmodel"
286
- :options.sync="userfile.gasbrand.gasmodel"
287
- @change="gasmodelChange()"
288
- :disable="mark === 1"
289
- :valueSingle="true"></input-select>
290
- </div>
291
- </div>
292
- <div class="form-group row vertical-center" :class="[$v.f_meternumber.required ? 'has-error' : '']">
293
- <label class="col-xs-4 control-label">表&emsp;&emsp;号:</label>
294
- <div class="col-xs-8">
295
- <input class="form-control input_view" style=""
296
- placeholder="表号" v-validate:f_meternumber = "['required']"
297
- v-model="userfile.f_meternumber"
298
- :value.sync="userfile.f_meternumber"
299
- @change="meternumberValidate()"
300
- :readonly="mark === 1"/>
301
- </div>
302
- </div>
303
- <div class="form-group row vertical-center">
304
- <label class="col-xs-4 control-label">表&ensp;封&ensp;号:</label>
305
- <div class="col-xs-8">
306
- <input class="form-control input_view" style=""
307
- placeholder="表封号"
308
- v-model="userfile.f_metertitles"
309
- :value="userfile.f_metertitles"
310
- :readonly="mark === 1"/>
311
- </div>
312
- </div>
313
- <div class="form-group row vertical-center">
314
- <label class="col-xs-4 control-label">表&ensp;读&ensp;数:</label>
315
- <div class="col-xs-8">
316
- <input class="form-control input_view" style=""
317
- type="number"
318
- placeholder="表读数"
319
- v-model="userfile.f_meter_base"
320
- :value="userfile.f_meter_base"
321
- :readonly="mark === 1"/>
322
- </div>
323
- </div>
324
- <div class="form-group row vertical-center">
325
- <label class="col-xs-4 control-label">初始底数:</label>
326
- <div class="col-xs-8">
327
- <input class="form-control input_view" style=""
328
- type="number"
329
- v-model="userfile.f_initial_base"
330
- :value="userfile.f_initial_base"
331
- placeholder="初始底数"
332
- :readonly="mark === 1"/>
333
- </div>
334
- </div>
335
- <div class="form-group row vertical-center">
336
- <label class="col-xs-4 control-label">表&emsp;&emsp;向:</label>
337
- <div class="col-xs-8">
338
- <input-select
339
- class="select select_list"
340
- :value.sync="userfile.f_aroundmeter"
341
- v-model="userfile.f_aroundmeter"
342
- :options="aroundmeters"
343
- :disable="mark === 1"
344
- :valueSingle="true"></input-select>
345
- </div>
346
- </div>
347
- <div class="form-group row vertical-center">
348
- <label class="col-xs-4 control-label">安装位置:</label>
349
- <div class="col-xs-8">
350
- <input-select
351
- class="select select_list"
352
- :value.sync="userfile.f_position"
353
- v-model="userfile.f_position"
354
- :options="positions"
355
- :disable="mark === 1"
356
- :valueSingle="true"></input-select>
357
- </div>
358
- </div>
359
- <div class="form-group row vertical-center">
360
- <label class="col-xs-4 control-label">安&ensp;装&ensp;人:</label>
361
- <div class="col-xs-8">
362
- <input class="form-control input_view" style=""
363
- v-model="userfile.f_install_person"
364
- :value.sync="installperson(userfile.f_install_person)"
365
- placeholder="安装人"
366
- readonly/>
367
- </div>
368
- </div>
369
- <div class="form-group row vertical-center">
370
- <label class="col-xs-4 control-label">安装日期:</label>
371
- <div class="col-xs-8">
372
- <input class="form-control input_view" style=""
373
- v-model="userfile.f_install_date"
374
- :value.sync="installdate(userfile.f_install_date)"
375
- placeholder="安装日期"
376
- readonly/>
377
- </div>
378
- </div>
379
- </div>
380
- </article>
381
- <footer slot="modal-footer" class="modal-footer">
382
- <template v-if="mark !== 1">
383
- <button type="button" class="btn btn-primary" @click="saveUserFile" :disabled="!$v.valid">确认</button>
384
- </template>
385
- </footer>
386
- </modal>
387
- </validator>
388
-
389
- </template>
390
- <script>
391
- import Vue from 'vue'
392
- import {PagedList} from 'vue-client'
393
- import {HttpResetClass} from 'vue-client'
394
- import {isEmpty} from '../../../../../components/Util'
395
- // Date格式化
396
- Date.prototype.Format = function (fmt) {
397
- var o = {
398
- 'M+': this.getMonth() + 1, // 月份
399
- 'd+': this.getDate(), // 日
400
- 'H+': this.getHours(), // 小时
401
- 'm+': this.getMinutes(), // 分
402
- 's+': this.getSeconds(), // 秒
403
- 'q+': Math.floor((this.getMonth() + 3) / 3), // 季度
404
- 'S': this.getMilliseconds() // 毫秒
405
- }
406
- if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + '').substr(4 - RegExp.$1.length))
407
- for (var k in o) {
408
- if (new RegExp('(' + k + ')').test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length)))
409
- }
410
- return fmt
411
- }
412
-
413
- export default {
414
- title: '安装明细',
415
- props: {
416
- selectdata: {
417
- type: Object
418
- },
419
- mark: {
420
- type: Number,
421
- default: 0
422
- }
423
- },
424
- data () {
425
- return {
426
- showUserFile: false,
427
- model: {
428
- rows: null
429
- },
430
- meterbrands: [], // 气表品牌
431
- useradders: {},
432
- userinfo: {},
433
- userfile: {},
434
- addressTypeList: [
435
- {label: '民用地址', value: '民用地址'},
436
- {label: '特殊地址', value: '特殊地址'}
437
- ],
438
- sliceAreaList: [],
439
- pcdList: [],
440
- streetList: [],
441
- residentialList: [],
442
- config: {},
443
- scanCodeConfig: null
444
- }
445
- },
446
- ready () {
447
- this.search()
448
- this.getMeterbrands()
449
- this.getSliceAreaList()
450
- this.getPcdList()
451
-
452
- this.getConfig()
453
- },
454
- methods: {
455
- async getConfig () {
456
- let http = new HttpResetClass()
457
- let res = await http.load(
458
- 'POST',
459
- `${this.$androidUtil.getProxyUrl()}/rs/logic/getScanCodeConfig`,
460
- null,
461
- {resolveMsg: null, rejectMsg: '扫码配置获取失败!!!'}
462
- )
463
-
464
- this.scanCodeConfig = res.data
465
- },
466
- scanCode () {
467
- console.log('===============扫码===================')
468
- HostApp.__this__=this,
469
- HostApp.scanCode({callback:"javascript:HostApp.__this__.getCode();"})
470
- },
471
- getCode() {
472
- let code = HostApp.getCode().data;
473
- // let code = '013499789111'
474
- console.log('===========扫码结果=============')
475
- console.log(code)
476
- if (!/^\d{12}$/.test(code)) {
477
- this.$showAlert('表号不符合规则', 'danger', 3000)
478
- return
479
- }
480
-
481
- // 解析厂家
482
- let factory = null
483
- for (const item of this.scanCodeConfig.factory) {
484
- if (item.key === code.substring(0, 2)) {
485
- factory = item.val
486
- break
487
- }
488
- }
489
- if (isEmpty(factory)) {
490
- this.$showAlert('未知厂家!!!', 'danger', 3000)
491
- return
492
- }
493
- console.log(factory)
494
-
495
- // 解析运营商
496
- let ips = null
497
- for (const item of this.scanCodeConfig.ips) {
498
- if (item.key === code.substring(4, 6)) {
499
- ips = item.val
500
- break
501
- }
502
- }
503
- if (isEmpty(ips)) {
504
- this.$showAlert('未知运营商!!!', 'danger', 3000)
505
- return
506
- }
507
- console.log(ips)
508
-
509
- // 表向
510
- console.log(code.substring(6, 7) % 2 === 0 ? '偶数' : '奇数')
511
- console.log(code.substring(6, 7) % 2 === 0 ? '右表' : '左表')
512
- this.userfile.f_aroundmeter = code.substring(6, 7) % 2 === 0 ? '右表' : '左表'
513
-
514
- // 顺序号
515
- console.log(code.substring(7, 12))
516
- if (code.substring(7, 12) < this.scanCodeConfig.number.min || code.substring(7, 12) > this.scanCodeConfig.number.max) {
517
- this.$showAlert('顺序号超出范围!!!', 'danger', 3000)
518
- return
519
- }
520
-
521
- for (const item of this.meterbrands) {
522
- if (item.label === factory) {
523
- this.userfile.gasbrand = item.value
524
- this.gasbrandChange()
525
- break
526
- }
527
- }
528
-
529
- Vue.set(this.userfile, 'f_meternumber', code)
530
-
531
- this.meternumberValidate()
532
- },
533
- // 保存档案
534
- async saveUserFile() {
535
- let data = {
536
- user: Vue.user,
537
- useradders: this.useradders,
538
- userinfo: this.userinfo,
539
- userfile: this.userfile,
540
- selectdata: this.selectdata
541
- }
542
- let res = await this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/logic/applyAddUserinfo`, {data:data}, {
543
- resolveMsg: null,
544
- rejectMsg: '用户档案添加失败!!!'
545
- })
546
- this.$dispatch('breakControl', this.selectdata)
547
- },
548
- addressSplicing () {
549
- let f_pcd = this.useradders.f_pcd || ''
550
- let f_street = this.useradders.f_street || ''
551
- let f_residential_area = this.useradders.f_residential_area || ''
552
- let f_building = this.useradders.f_building || ''
553
- let f_building_suffix = f_building ? this.useradders.f_building_suffix : ''
554
- let f_unit = this.useradders.f_unit || ''
555
- let f_unit_suffix = f_unit ? this.useradders.f_unit_suffix : ''
556
- let f_floor = this.useradders.f_floor || ''
557
- let f_floor_suffix = f_floor ? this.useradders.f_floor_suffix : ''
558
- let f_room = this.useradders.f_room || ''
559
- let f_room_suffix = f_room ? this.useradders.f_room_suffix : ''
560
-
561
- Vue.set(this.useradders, 'f_address', f_pcd + f_street + f_residential_area + f_building + f_building_suffix + f_unit + f_unit_suffix + f_floor + f_floor_suffix + f_room + f_room_suffix)
562
- },
563
- // 检查表号是否存在
564
- async meternumberValidate() {
565
- if (!this.userfile.f_gasbrand_id) {
566
- this.userfile.f_meternumber = ''
567
- this.$showAlert('请先选择气表品牌!!!', 'warning', 3000)
568
- return
569
- }
570
- if (this.userfile.f_gasbrand_id && this.userfile.f_meternumber) {
571
- let data = {
572
- f_meternumber: this.userfile.f_meternumber,
573
- f_gasbrand_id: this.userfile.f_gasbrand_id
574
- }
575
- if (this.userfile.f_userfiles_id) {
576
- data.f_userfiles_id = this.userfile.f_userfiles_id
577
- }
578
- let res = await this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/logic/meterbrandsNumberValidate`, {data:data}, {
579
- resolveMsg: null,
580
- rejectMsg: '表号验证失败!!'
581
- })
582
- if (res.data) {
583
- this.$showAlert(`表号:${this.userfile.f_meternumber}已存在!!!`, 'warning', 3000)
584
- this.userfile.f_meternumber = ''
585
- }
586
- }
587
- },
588
- // 选择气表型号
589
- gasmodelChange() {
590
- if (this.userfile.gasmodel) {
591
- this.userfile.f_gasmodel_id = this.userfile.gasmodel.id
592
- }
593
- },
594
- // 选择气表品牌
595
- gasbrandChange() {
596
- // 清空已保存的气表型号
597
- this.userfile.f_gasmodel_id = null
598
- this.userfile.gasmodel = null
599
-
600
- if (this.userfile.gasbrand) {
601
- // 气表品牌id
602
- this.userfile.f_gasbrand_id = this.userfile.gasbrand.id
603
- // 气表分类
604
- this.userfile.f_meter_classify = this.userfile.gasbrand.f_meter_type
605
- }
606
- },
607
- // 打开安装明细
608
- async showUserFileModal (row) {
609
- if (!row) {
610
- console.log('-------------------添加----------------------')
611
- }
612
- console.log('------------------修正---------------------')
613
- this.initUseradders()
614
- this.showUserFile = true
615
- },
616
- async initUseradders () {
617
- if (this.selectdata.f_apply_type === '民用报建') {
618
- Vue.set(this.useradders, 'f_address_type', '民用地址')
619
- }
620
- if (this.selectdata.f_apply_type === '民用报建' && this.selectdata.f_apply_nature === '小区') {
621
- Vue.set(this.useradders, 'f_slice_area', this.selectdata.f_slice_area)
622
- Vue.set(this.useradders, 'f_pcd', this.selectdata.f_pcd)
623
- Vue.set(this.useradders, 'f_street', this.selectdata.f_street)
624
- Vue.set(this.useradders, 'f_residential_area', this.selectdata.f_residential_area)
625
- }
626
-
627
- await this.$getConfig(this, 'UserAddress')
628
-
629
- this.useradders = Object.assign({}, this.useradders, this.config)
630
- },
631
- async streetChange () {
632
- this.residentialList = []
633
- this.useradders.f_residential_area = null
634
- if (isEmpty(this.useradders.f_street)) {
635
- return
636
- }
637
- let data = {
638
- tablename: 't_area',
639
- condition: `f_filialeid = '${Vue.user.orgid}' and f_street = '${this.useradders.f_street}'`
640
- // condition: `f_filialeid = '21142' and f_street = '${this.useradders.f_street}'`
641
- }
642
- let http = new HttpResetClass()
643
- let res = await http.load(
644
- 'POST',
645
- `${this.$androidUtil.getProxyUrl()}/rs/sql/singleTable`,
646
- {data: data},
647
- {resolveMsg: null, rejectMsg: '小区查询失败!!!'}
648
- )
649
-
650
- this.residentialList = res.data.map(item => {
651
- return {
652
- label: item.f_residential_area,
653
- value: item.f_residential_area
654
- }
655
- })
656
- },
657
- async pcdChange () {
658
- this.streetList = []
659
- this.useradders.f_street = null
660
- this.residentialList = []
661
- this.useradders.f_residential_area = null
662
- if (isEmpty(this.useradders.f_pcd)) {
663
- return
664
- }
665
-
666
- let data = {
667
- tablename: 't_street',
668
- condition: `f_filialeid = '${Vue.user.orgid}' and f_pcd = '${this.useradders.f_pcd}'`
669
- // condition: `f_filialeid = '21142' and f_pcd = '${this.useradders.f_pcd}'`
670
- }
671
- let http = new HttpResetClass()
672
- let res = await http.load(
673
- 'POST',
674
- `${this.$androidUtil.getProxyUrl()}/rs/sql/singleTable`,
675
- {data: data},
676
- {resolveMsg: null, rejectMsg: '街道查询失败!!!'}
677
- )
678
-
679
- this.streetList = res.data.map(item => {
680
- return {
681
- label: item.f_street,
682
- value: item.f_street
683
- }
684
- })
685
- },
686
- async getPcdList () {
687
- let data = {
688
- tablename: 't_pcd',
689
- condition: `f_filialeid = '${Vue.user.orgid}'`
690
- // condition: `f_filialeid = '21142'`
691
- }
692
- let http = new HttpResetClass()
693
- let res = await http.load(
694
- 'POST',
695
- `${this.$androidUtil.getProxyUrl()}/rs/sql/singleTable`,
696
- {data: data},
697
- {resolveMsg: null, rejectMsg: '省市区查询失败!!!'}
698
- )
699
-
700
- this.pcdList = res.data.map(item => {
701
- return {
702
- label: item.f_pcd,
703
- value: item.f_pcd
704
- }
705
- })
706
- },
707
- async getSliceAreaList () {
708
- let data = {
709
- source: 'this.getParentByType($organization$).getAllChildrens().where(row.getType() == $zone$)',
710
- userid: Vue.user.id
711
- // userid: '21142'
712
- }
713
-
714
- let http = new HttpResetClass()
715
- let res = await http.load(
716
- 'POST',
717
- `${this.$androidUtil.getProxyUrl()}/rs/search`,
718
- {data: data},
719
- {resolveMsg: null, rejectMsg: '片区查询失败!!!'}
720
- )
721
-
722
- this.sliceAreaList = res.data.map(item => {
723
- return {
724
- label: item.name,
725
- value: item.name
726
- }
727
- })
728
- },
729
- // 获取气表品牌
730
- async getMeterbrands() {
731
- let http = new HttpResetClass()
732
- let data = {
733
- f_orgid: Vue.user.orgid
734
- // f_orgid: 21142
735
- }
736
- let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/getMeterbrands`, {data:data}, {
737
- resolveMsg: null,
738
- rejectMsg: null
739
- })
740
- this.meterbrands = res.data
741
- },
742
- searchCondition (args) {
743
- args.condition = args.condition + `and ua.f_process_id = '${this.selectdata.f_process_id}'`
744
-
745
- this.model.search(args.condition, args.model)
746
- },
747
- // 查询
748
- async search () {
749
- let http = new HttpResetClass()
750
- let data = {
751
- condition: `ua.f_process_id = '${this.selectdata.f_process_id}'`
752
- }
753
- let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/sql/getAddresAndUserinfoAndUserfilesAmount`, {data:data}, {
754
- // let res = await http.load('POST', `rs/sql/getAddresAndUserinfoAndUserfilesAmount`, {data:data}, {
755
- resolveMsg: null,
756
- rejectMsg: null
757
- })
758
- this.model.rows = res.data
759
- },
760
- // 关闭安装明细
761
- closeUserFile() {
762
- this.showUserFile = false
763
- this.useradders = {}
764
- this.userinfo = {}
765
- this.userfile = {}
766
- this.search()
767
- }
768
- },
769
- events: {
770
- },
771
- computed: {
772
- credentialsList() {
773
- return this.$appdata.getParam('证件类型')
774
- },
775
- // 安装人
776
- installperson() {
777
- return function (f_install_person) {
778
- if (isEmpty(f_install_person)) {
779
- return Vue.user.name
780
- }
781
- return f_install_person
782
- }
783
- },
784
- // 安装时间
785
- installdate() {
786
- return function (f_install_date) {
787
- if (isEmpty(f_install_date)) {
788
- return new Date().Format('yyyy-MM-dd HH:mm:ss')
789
- }
790
- return f_install_date
791
- }
792
- },
793
- // 表向
794
- aroundmeters() {
795
- return this.$appdata.getParam('左右表')
796
- },
797
- // 安装位置
798
- positions() {
799
- return this.$appdata.getParam('安装位置')
800
- }
801
- },
802
- watch: {
803
- }
804
- }
805
- </script>
806
- <style scoped>
807
- .panel-self{
808
- border-radius: 10px;
809
- border:1px solid #499EDF;
810
- background-color: #F8F8F8;
811
- }
812
- .vertical-center {
813
- display: flex;
814
- align-items: center;
815
- text-align: center;
816
- }
817
- /*清除model中的浮动*/
818
- .clearfix:after,.clearfix:before{
819
- display: table;
820
- }
821
- .clearfix:after{
822
- clear: both;
823
- }
824
- </style>
1
+ <template>
2
+ <div class="col-xs-12 col-xs-12 form-group app-btn">
3
+ <button class="btn btn-info" @click.prevent="showUserFileModal()" :disabled="mark === 1 || model.rows.length >= selectdata.f_install_count">添加用户</button>
4
+ </div>
5
+ <div class="col-xs-12 col-xs-12">
6
+ <list :model="model" partial='list'>
7
+ <div partial class="auto app-text panel">
8
+ <div class="panel-body panel-self">
9
+ <div class="row">
10
+ <p class="col-xs-3 text-left font"><b class="control-label-justify">客户编号</b></p>
11
+ <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_userinfo_code }}</p>
12
+ </div>
13
+ <div class="row">
14
+ <p class="col-xs-3 text-left font"><b class="control-label-justify">客户名称</b></p>
15
+ <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_user_name }}</p>
16
+ </div>
17
+ <div class="row">
18
+ <p class="col-xs-3 text-left font"><b class="control-label-justify">客户电话</b></p>
19
+ <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_user_phone }}</p>
20
+ </div>
21
+ <div class="row" v-if="$parent.$parent.selectdata.f_apply_type === '散户集体报建' || $parent.$parent.selectdata.f_apply_type === '煤改气报建'">
22
+ <p class="col-xs-3 text-left font"><b class="control-label-justify">单价</b></p>
23
+ <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ $parent.$parent.selectdata.f_price }}</p>
24
+ </div>
25
+ <div class="row" v-if="$parent.$parent.selectdata.f_apply_type === '散户集体报建' || $parent.$parent.selectdata.f_apply_type === '煤改气报建'">
26
+ <p class="col-xs-3 text-left font"><b class="control-label-justify">累计缴费</b></p>
27
+ <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_cumulative_payment_money }}</p>
28
+ </div>
29
+ <div class="row">
30
+ <p class="col-xs-3 text-left font"><b class="control-label-justify">地址信息</b></p>
31
+ <p class="col-xs-8 col-xs-offset-1 text-left input-font">{{ row.f_address }}</p>
32
+ </div>
33
+ <div class="row text-right">
34
+ </div>
35
+ </div>
36
+ </div>
37
+ </list>
38
+ </div>
39
+
40
+ <validator name="v">
41
+ <modal v-if="showUserFile" :show.sync="showUserFile" v-ref:modal :large="true" :backdrop="false">
42
+ <header slot="modal-header" class="modal-header">
43
+ <button type="button" class="close" @click="closeUserFile"><span>&times;</span></button>
44
+ <h4 class="modal-title">安装明细</h4>
45
+ </header>
46
+ <article slot="modal-body" class="modal-body clearfix">
47
+ <!-- 基本信息 -->
48
+ <div class="form-group col-xs-12 panel panel-info">
49
+ <div class="panel-heading head row" style="background-color: #e8f4ff;margin-bottom: 10px">
50
+ <div class="col-xs-12 text-left">用户信息</div>
51
+ </div>
52
+ <div class="form-group row vertical-center">
53
+ <label class="col-xs-4 control-label">客户名称:</label>
54
+ <div class="col-xs-8">
55
+ <input class="form-control input_view" style=""
56
+ v-model="userinfo.f_user_name"
57
+ :value.sync="serinfo.f_user_name"
58
+ :readonly="mark === 1"
59
+ placeholder="客户名称"/>
60
+ </div>
61
+ </div>
62
+ <div class="form-group row vertical-center">
63
+ <label class="col-xs-4 control-label">客户电话:</label>
64
+ <div class="col-xs-8">
65
+ <input class="form-control input_view" style=""
66
+ v-model="userinfo.f_user_phone"
67
+ :value.sync="userinfo.f_user_phone"
68
+ :readonly="mark === 1"
69
+ placeholder="客户电话"/>
70
+ </div>
71
+ </div>
72
+ <div class="form-group row vertical-center">
73
+ <label class="col-xs-4 control-label">证件类型:</label>
74
+ <div class="col-xs-8">
75
+ <input-select
76
+ class="select select_list"
77
+ :value.sync="userinfo.f_credentials"
78
+ v-model="userinfo.f_credentials"
79
+ :options="credentialsList"
80
+ :disable="mark === 1"
81
+ :valueSingle="true"></input-select>
82
+ </div>
83
+ </div>
84
+ <div class="form-group row vertical-center">
85
+ <label class="col-xs-4 control-label">证件号码:</label>
86
+ <div class="col-xs-8">
87
+ <input class="form-control input_view" style=""
88
+ placeholder="证件号码"
89
+ v-model="userinfo.f_idnumber"
90
+ :value="userinfo.f_idnumber"
91
+ :readonly="mark === 1"/>
92
+ </div>
93
+ </div>
94
+ </div>
95
+ <!-- 地址信息 -->
96
+ <div class="form-group col-xs-12 panel panel-info">
97
+ <div class="panel-heading head row" style="background-color: #e8f4ff;margin-bottom: 10px">
98
+ <div class="col-xs-6 text-left">地址信息</div>
99
+ </div>
100
+ <div class="form-group row vertical-center" :class="[$v.f_address_type.required ? 'has-error' : '']">
101
+ <label class="col-xs-4 control-label">地址类型:</label>
102
+ <div class="col-xs-8">
103
+ <input type="text" v-show="false" v-model="useradders.f_address_type" :value.sync="useradders.f_address_type" v-validate:f_address_type = "['required']" >
104
+ <input-select
105
+ class="select select_list"
106
+ :value.sync="useradders.f_address_type"
107
+ v-model="useradders.f_address_type"
108
+ :options="addressTypeList"
109
+ :disable="true"
110
+ :valueSingle="true"></input-select>
111
+ </div>
112
+ </div>
113
+ <div class="form-group row vertical-center" :class="[$v.f_slice_area.required ? 'has-error' : '']">
114
+ <label class="col-xs-4 control-label">片&emsp;&emsp;区:</label>
115
+ <div class="col-xs-8">
116
+ <input type="text" v-show="false" v-model="useradders.f_slice_area" v-validate:f_slice_area = "['required']" >
117
+ <input-select
118
+ class="select select_list"
119
+ :value.sync="useradders.f_slice_area"
120
+ v-model="useradders.f_slice_area"
121
+ :options="sliceAreaList"
122
+ :disable="mark === 1 || selectdata.f_apply_nature === '小区'"
123
+ :valueSingle="true"></input-select>
124
+ </div>
125
+ </div>
126
+ <div class="form-group row vertical-center" :class="[$v.f_pcd.required ? 'has-error' : '']">
127
+ <label class="col-xs-4 control-label">省&ensp;市&ensp;区:</label>
128
+ <div class="col-xs-8">
129
+ <input type="text" v-show="false" v-model="useradders.f_pcd" :value.sync="useradders.f_pcd" v-validate:f_pcd = "['required']" >
130
+ <input-select
131
+ class="select select_list"
132
+ :value.sync="useradders.f_pcd"
133
+ v-model="useradders.f_pcd"
134
+ :options="pcdList"
135
+ @change="pcdChange(),addressSplicing()"
136
+ :disable="mark === 1 || selectdata.f_apply_nature === '小区'"
137
+ :valueSingle="true"></input-select>
138
+ </div>
139
+ </div>
140
+ <div class="form-group row vertical-center" :class="[$v.f_street.required ? 'has-error' : '']">
141
+ <label class="col-xs-4 control-label">街&emsp;&emsp;道:</label>
142
+ <div class="col-xs-8">
143
+ <input type="text" v-show="false" v-model="useradders.f_street" :value.sync="useradders.f_street" v-validate:f_street = "['required']" >
144
+ <input-select
145
+ class="select select_list"
146
+ :value.sync="useradders.f_street"
147
+ v-model="useradders.f_street"
148
+ :options="streetList"
149
+ @change="streetChange(),addressSplicing()"
150
+ :disable="mark === 1 || selectdata.f_apply_nature === '小区'"
151
+ :valueSingle="true"></input-select>
152
+ </div>
153
+ </div>
154
+ <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'" :class="[$v.f_residential_area.required ? 'has-error' : '']">
155
+ <label class="col-xs-4 control-label">小&emsp;&emsp;区:</label>
156
+ <div class="col-xs-8">
157
+ <input type="text" v-show="false" v-model="useradders.f_residential_area" :value.sync="useradders.f_residential_area" v-validate:f_residential_area = "['required']" >
158
+ <input-select
159
+ class="select select_list"
160
+ :value.sync="useradders.f_residential_area"
161
+ v-model="useradders.f_residential_area"
162
+ :options="residentialList"
163
+ @change="addressSplicing"
164
+ :disable="mark === 1 || selectdata.f_apply_nature === '小区'"
165
+ :valueSingle="true"></input-select>
166
+ </div>
167
+ </div>
168
+ <div class="form-group row vertical-center" v-if="useradders.f_address_type === '特殊地址'">
169
+ <label class="col-xs-4 control-label">小&emsp;&emsp;区:</label>
170
+ <div class="col-xs-8">
171
+ <input-select
172
+ class="select select_list"
173
+ :value.sync="useradders.f_residential_area"
174
+ v-model="useradders.f_residential_area"
175
+ :options="residentialList"
176
+ @change="addressSplicing"
177
+ :disable="mark === 1"
178
+ :valueSingle="true"></input-select>
179
+ </div>
180
+ </div>
181
+ <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'">
182
+ <label class="col-xs-4 control-label">楼&emsp;&emsp;号:</label>
183
+ <div class="col-xs-8">
184
+ <input class="form-control input_view col-xs-10" style="width: 80%"
185
+ placeholder="楼号"
186
+ v-model="useradders.f_building"
187
+ :value="useradders.f_building"
188
+ @change="addressSplicing"
189
+ :readonly="mark === 1"/>
190
+ <input class="form-control input_view col-xs-2" style="width: 20%"
191
+ v-model="useradders.f_building_suffix"
192
+ :value="useradders.f_building_suffix"
193
+ @change="addressSplicing"
194
+ :readonly="mark === 1"/>
195
+ </div>
196
+ </div>
197
+ <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'">
198
+ <label class="col-xs-4 control-label">单&emsp;&emsp;元:</label>
199
+ <div class="col-xs-8">
200
+ <input class="form-control input_view col-xs-10" style="width: 80%"
201
+ placeholder="单元"
202
+ v-model="useradders.f_unit"
203
+ :value="useradders.f_unit"
204
+ @change="addressSplicing"
205
+ :readonly="mark === 1"/>
206
+ <input class="form-control input_view col-xs-2" style="width: 20%"
207
+ v-model="useradders.f_unit_suffix"
208
+ :value="useradders.f_unit_suffix"
209
+ @change="addressSplicing"
210
+ :readonly="mark === 1"/>
211
+ </div>
212
+ </div>
213
+ <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'">
214
+ <label class="col-xs-4 control-label">楼&emsp;&emsp;层:</label>
215
+ <div class="col-xs-8">
216
+ <input class="form-control input_view col-xs-10" style="width: 80%"
217
+ placeholder="楼层"
218
+ v-model="useradders.f_floor"
219
+ :value="useradders.f_floor"
220
+ @change="addressSplicing"
221
+ :readonly="mark === 1"/>
222
+ <input class="form-control input_view col-xs-2" style="width: 20%"
223
+ v-model="useradders.f_floor_suffix"
224
+ :value="useradders.f_floor_suffix"
225
+ @change="addressSplicing"
226
+ :readonly="mark === 1"/>
227
+ </div>
228
+ </div>
229
+ <div class="form-group row vertical-center" v-if="useradders.f_address_type === '民用地址'" :class="[$v.f_room.required ? 'has-error' : '']">
230
+ <label class="col-xs-4 control-label">门&ensp;牌&ensp;号:</label>
231
+ <div class="col-xs-8">
232
+ <input class="form-control input_view col-xs-10" style="width: 80%"
233
+ placeholder="门牌号" v-validate:f_room = "['required']"
234
+ v-model="useradders.f_room"
235
+ :value="useradders.f_room"
236
+ @change="addressSplicing"
237
+ :readonly="mark === 1"/>
238
+ <input class="form-control input_view col-xs-2" style="width: 20%"
239
+ v-model="useradders.f_room_suffix"
240
+ :value="useradders.f_room_suffix"
241
+ @change="addressSplicing"
242
+ :readonly="mark === 1"/>
243
+ </div>
244
+ </div>
245
+ <div class="form-group row vertical-center">
246
+ <label class="col-xs-4 control-label">地&emsp;&emsp;址:</label>
247
+ <div class="col-xs-8">
248
+ <input class="form-control input_view"
249
+ placeholder="地址"
250
+ v-model="useradders.f_address"
251
+ :value.sync="useradders.f_address"
252
+ :readonly="mark === 1"/>
253
+ </div>
254
+ </div>
255
+ </div>
256
+ <!-- 表具信息 -->
257
+ <div class="form-group col-xs-12 panel panel-info">
258
+ <div class="panel-heading head row" style="background-color: #e8f4ff;margin-bottom: 10px">
259
+ <div class="col-xs-6 text-left">表具信息</div>
260
+ <div class="col-xs-6 text-right">
261
+ <svg @click="scanCode()" style="width: 25px;height: 25px;margin-right: 10px" t="1636095770822" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2457" width="64" height="64"><path d="M928.016126 543.908618 95.983874 543.908618c-17.717453 0-31.994625-14.277171-31.994625-31.994625S78.26642 479.919368 95.983874 479.919368l832.032253 0c17.717453 0 31.994625 14.277171 31.994625 31.994625S945.73358 543.908618 928.016126 543.908618z" p-id="2458"></path><path d="M832.032253 928.016126 639.892491 928.016126c-17.717453 0-31.994625-14.277171-31.994625-31.994625s14.277171-31.994625 31.994625-31.994625l191.967747 0c17.717453 0 31.994625-14.277171 31.994625-31.994625l0-159.973123c0-17.717453 14.277171-31.994625 31.994625-31.994625s31.994625 14.277171 31.994625 31.994625l0 159.973123C928.016126 884.840585 884.840585 928.016126 832.032253 928.016126z" p-id="2459"></path><path d="M351.94087 928.016126l-159.973123 0c-52.980346 0-95.983874-43.003528-95.983874-95.983874l0-159.973123c0-17.717453 14.277171-31.994625 31.994625-31.994625S159.973123 654.341676 159.973123 672.05913l0 159.973123c0 17.717453 14.449185 31.994625 31.994625 31.994625l159.973123 0c17.717453 0 31.994625 14.277171 31.994625 31.994625C383.935495 913.738955 369.658324 928.016126 351.94087 928.016126z" p-id="2460"></path><path d="M127.978498 383.935495c-17.717453 0-31.994625-14.277171-31.994625-31.994625l0-159.973123c0-52.980346 43.003528-95.983874 95.983874-95.983874l159.973123 0c17.717453 0 31.994625 14.277171 31.994625 31.994625S369.658324 159.973123 351.94087 159.973123l-159.973123 0c-17.545439 0-31.994625 14.449185-31.994625 31.994625l0 159.973123C159.973123 369.658324 145.695952 383.935495 127.978498 383.935495z" p-id="2461"></path><path d="M896.021502 383.935495c-17.717453 0-31.994625-14.277171-31.994625-31.994625l0-159.973123c0-17.545439-14.277171-31.994625-31.994625-31.994625L639.892491 159.973123c-17.717453 0-31.994625-14.277171-31.994625-31.994625s14.277171-31.994625 31.994625-31.994625l191.967747 0c52.980346 0 95.983874 43.003528 95.983874 95.983874l0 159.973123C928.016126 369.658324 913.738955 383.935495 896.021502 383.935495z" p-id="2462"></path></svg>
262
+ </div>
263
+ </div>
264
+ <div class="form-group row vertical-center" :class="[$v.gasbrand.required ? 'has-error' : '']">
265
+ <label class="col-xs-4 control-label">气表品牌:</label>
266
+ <div class="col-xs-8">
267
+ <input type="text" v-show="false" v-model="userfile.gasbrand.id" :value.sync="userfile.gasbrand.id" v-validate:gasbrand = "['required']" >
268
+ <input-select
269
+ class="select select_list"
270
+ :value.sync="userfile.gasbrand"
271
+ v-model="userfile.gasbrand"
272
+ :options="meterbrands"
273
+ @change="gasbrandChange()"
274
+ :disable="mark === 1"
275
+ :valueSingle="true"></input-select>
276
+ </div>
277
+ </div>
278
+ <div class="form-group row vertical-center" :class="[$v.gasmodel.required ? 'has-error' : '']">
279
+ <label class="col-xs-4 control-label">气表型号:</label>
280
+ <div class="col-xs-8">
281
+ <input type="text" v-show="false" v-model="userfile.gasmodel.id" :value.sync="userfile.gasmodel.id" v-validate:gasmodel = "['required']" >
282
+ <input-select
283
+ class="select select_list"
284
+ :value.sync="userfile.gasmodel"
285
+ v-model="userfile.gasmodel"
286
+ :options.sync="userfile.gasbrand.gasmodel"
287
+ @change="gasmodelChange()"
288
+ :disable="mark === 1"
289
+ :valueSingle="true"></input-select>
290
+ </div>
291
+ </div>
292
+ <div class="form-group row vertical-center" :class="[$v.f_meternumber.required ? 'has-error' : '']">
293
+ <label class="col-xs-4 control-label">表&emsp;&emsp;号:</label>
294
+ <div class="col-xs-8">
295
+ <input class="form-control input_view" style=""
296
+ placeholder="表号" v-validate:f_meternumber = "['required']"
297
+ v-model="userfile.f_meternumber"
298
+ :value.sync="userfile.f_meternumber"
299
+ @change="meternumberValidate()"
300
+ :readonly="mark === 1"/>
301
+ </div>
302
+ </div>
303
+ <div class="form-group row vertical-center">
304
+ <label class="col-xs-4 control-label">表&ensp;封&ensp;号:</label>
305
+ <div class="col-xs-8">
306
+ <input class="form-control input_view" style=""
307
+ placeholder="表封号"
308
+ v-model="userfile.f_metertitles"
309
+ :value="userfile.f_metertitles"
310
+ :readonly="mark === 1"/>
311
+ </div>
312
+ </div>
313
+ <div class="form-group row vertical-center">
314
+ <label class="col-xs-4 control-label">表&ensp;读&ensp;数:</label>
315
+ <div class="col-xs-8">
316
+ <input class="form-control input_view" style=""
317
+ type="number"
318
+ placeholder="表读数"
319
+ v-model="userfile.f_meter_base"
320
+ :value="userfile.f_meter_base"
321
+ :readonly="mark === 1"/>
322
+ </div>
323
+ </div>
324
+ <div class="form-group row vertical-center">
325
+ <label class="col-xs-4 control-label">初始底数:</label>
326
+ <div class="col-xs-8">
327
+ <input class="form-control input_view" style=""
328
+ type="number"
329
+ v-model="userfile.f_initial_base"
330
+ :value="userfile.f_initial_base"
331
+ placeholder="初始底数"
332
+ :readonly="mark === 1"/>
333
+ </div>
334
+ </div>
335
+ <div class="form-group row vertical-center">
336
+ <label class="col-xs-4 control-label">表&emsp;&emsp;向:</label>
337
+ <div class="col-xs-8">
338
+ <input-select
339
+ class="select select_list"
340
+ :value.sync="userfile.f_aroundmeter"
341
+ v-model="userfile.f_aroundmeter"
342
+ :options="aroundmeters"
343
+ :disable="mark === 1"
344
+ :valueSingle="true"></input-select>
345
+ </div>
346
+ </div>
347
+ <div class="form-group row vertical-center">
348
+ <label class="col-xs-4 control-label">安装位置:</label>
349
+ <div class="col-xs-8">
350
+ <input-select
351
+ class="select select_list"
352
+ :value.sync="userfile.f_position"
353
+ v-model="userfile.f_position"
354
+ :options="positions"
355
+ :disable="mark === 1"
356
+ :valueSingle="true"></input-select>
357
+ </div>
358
+ </div>
359
+ <div class="form-group row vertical-center">
360
+ <label class="col-xs-4 control-label">安&ensp;装&ensp;人:</label>
361
+ <div class="col-xs-8">
362
+ <input class="form-control input_view" style=""
363
+ v-model="userfile.f_install_person"
364
+ :value.sync="installperson(userfile.f_install_person)"
365
+ placeholder="安装人"
366
+ readonly/>
367
+ </div>
368
+ </div>
369
+ <div class="form-group row vertical-center">
370
+ <label class="col-xs-4 control-label">安装日期:</label>
371
+ <div class="col-xs-8">
372
+ <input class="form-control input_view" style=""
373
+ v-model="userfile.f_install_date"
374
+ :value.sync="installdate(userfile.f_install_date)"
375
+ placeholder="安装日期"
376
+ readonly/>
377
+ </div>
378
+ </div>
379
+ </div>
380
+ </article>
381
+ <footer slot="modal-footer" class="modal-footer">
382
+ <template v-if="mark !== 1">
383
+ <button type="button" class="btn btn-primary" @click="saveUserFile" :disabled="!$v.valid">确认</button>
384
+ </template>
385
+ </footer>
386
+ </modal>
387
+ </validator>
388
+
389
+ </template>
390
+ <script>
391
+ import Vue from 'vue'
392
+ import {PagedList} from 'vue-client'
393
+ import {HttpResetClass} from 'vue-client'
394
+ import {isEmpty} from '../../../../../components/Util'
395
+ // Date格式化
396
+ Date.prototype.Format = function (fmt) {
397
+ var o = {
398
+ 'M+': this.getMonth() + 1, // 月份
399
+ 'd+': this.getDate(), // 日
400
+ 'H+': this.getHours(), // 小时
401
+ 'm+': this.getMinutes(), // 分
402
+ 's+': this.getSeconds(), // 秒
403
+ 'q+': Math.floor((this.getMonth() + 3) / 3), // 季度
404
+ 'S': this.getMilliseconds() // 毫秒
405
+ }
406
+ if (/(y+)/.test(fmt)) fmt = fmt.replace(RegExp.$1, (this.getFullYear() + '').substr(4 - RegExp.$1.length))
407
+ for (var k in o) {
408
+ if (new RegExp('(' + k + ')').test(fmt)) fmt = fmt.replace(RegExp.$1, (RegExp.$1.length === 1) ? (o[k]) : (('00' + o[k]).substr(('' + o[k]).length)))
409
+ }
410
+ return fmt
411
+ }
412
+
413
+ export default {
414
+ title: '安装明细',
415
+ props: {
416
+ selectdata: {
417
+ type: Object
418
+ },
419
+ mark: {
420
+ type: Number,
421
+ default: 0
422
+ }
423
+ },
424
+ data () {
425
+ return {
426
+ showUserFile: false,
427
+ model: {
428
+ rows: null
429
+ },
430
+ meterbrands: [], // 气表品牌
431
+ useradders: {},
432
+ userinfo: {},
433
+ userfile: {},
434
+ addressTypeList: [
435
+ {label: '民用地址', value: '民用地址'},
436
+ {label: '特殊地址', value: '特殊地址'}
437
+ ],
438
+ sliceAreaList: [],
439
+ pcdList: [],
440
+ streetList: [],
441
+ residentialList: [],
442
+ config: {},
443
+ scanCodeConfig: null
444
+ }
445
+ },
446
+ ready () {
447
+ this.search()
448
+ this.getMeterbrands()
449
+ this.getSliceAreaList()
450
+ this.getPcdList()
451
+
452
+ this.getConfig()
453
+ },
454
+ methods: {
455
+ async getConfig () {
456
+ let http = new HttpResetClass()
457
+ let res = await http.load(
458
+ 'POST',
459
+ `${this.$androidUtil.getProxyUrl()}/rs/logic/getScanCodeConfig`,
460
+ null,
461
+ {resolveMsg: null, rejectMsg: '扫码配置获取失败!!!'}
462
+ )
463
+
464
+ this.scanCodeConfig = res.data
465
+ },
466
+ scanCode () {
467
+ console.log('===============扫码===================')
468
+ HostApp.__this__=this,
469
+ HostApp.scanCode({callback:"javascript:HostApp.__this__.getCode();"})
470
+ },
471
+ getCode() {
472
+ let code = HostApp.getCode().data;
473
+ // let code = '0121993123456'
474
+ console.log('===========扫码结果=============')
475
+ console.log(code)
476
+ if (!/^\d{12}$/.test(code)) {
477
+ this.$showAlert('表号不符合规则', 'danger', 3000)
478
+ return
479
+ }
480
+
481
+ // 解析厂家
482
+ let factory = null
483
+ for (const item of this.scanCodeConfig.factory) {
484
+ if (item.key === code.substring(0, 2)) {
485
+ factory = item.val
486
+ break
487
+ }
488
+ }
489
+ if (isEmpty(factory)) {
490
+ this.$showAlert('未知厂家!!!', 'danger', 3000)
491
+ return
492
+ }
493
+ console.log(factory)
494
+
495
+ // 解析运营商
496
+ let ips = null
497
+ for (const item of this.scanCodeConfig.ips) {
498
+ if (item.key === code.substring(4, 6)) {
499
+ ips = item.val
500
+ break
501
+ }
502
+ }
503
+ if (isEmpty(ips)) {
504
+ this.$showAlert('未知运营商!!!', 'danger', 3000)
505
+ return
506
+ }
507
+ console.log(ips)
508
+
509
+ // 表向
510
+ console.log(code.substring(6, 7) % 2 === 0 ? '偶数' : '奇数')
511
+ console.log(code.substring(6, 7) % 2 === 0 ? '右表' : '左表')
512
+ this.userfile.f_aroundmeter = code.substring(6, 7) % 2 === 0 ? '右表' : '左表'
513
+
514
+ // 顺序号
515
+ console.log(code.substring(7, 12))
516
+ if (code.substring(7, 12) < this.scanCodeConfig.number.min || code.substring(7, 12) > this.scanCodeConfig.number.max) {
517
+ this.$showAlert('顺序号超出范围!!!', 'danger', 3000)
518
+ return
519
+ }
520
+
521
+ for (const item of this.meterbrands) {
522
+ if (item.label === factory) {
523
+ this.userfile.gasbrand = item.value
524
+ this.gasbrandChange()
525
+ break
526
+ }
527
+ }
528
+
529
+ Vue.set(this.userfile, 'f_meternumber', code)
530
+
531
+ this.meternumberValidate()
532
+ },
533
+ // 保存档案
534
+ async saveUserFile() {
535
+ let data = {
536
+ user: Vue.user,
537
+ useradders: this.useradders,
538
+ userinfo: this.userinfo,
539
+ userfile: this.userfile,
540
+ selectdata: this.selectdata
541
+ }
542
+ let res = await this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/logic/applyAddUserinfo`, {data:data}, {
543
+ resolveMsg: null,
544
+ rejectMsg: '用户档案添加失败!!!'
545
+ })
546
+ this.$dispatch('breakControl', this.selectdata)
547
+ },
548
+ addressSplicing () {
549
+ let f_pcd = this.useradders.f_pcd || ''
550
+ let f_street = this.useradders.f_street || ''
551
+ let f_residential_area = this.useradders.f_residential_area || ''
552
+ let f_building = this.useradders.f_building || ''
553
+ let f_building_suffix = f_building ? this.useradders.f_building_suffix : ''
554
+ let f_unit = this.useradders.f_unit || ''
555
+ let f_unit_suffix = f_unit ? this.useradders.f_unit_suffix : ''
556
+ let f_floor = this.useradders.f_floor || ''
557
+ let f_floor_suffix = f_floor ? this.useradders.f_floor_suffix : ''
558
+ let f_room = this.useradders.f_room || ''
559
+ let f_room_suffix = f_room ? this.useradders.f_room_suffix : ''
560
+
561
+ Vue.set(this.useradders, 'f_address', f_pcd + f_street + f_residential_area + f_building + f_building_suffix + f_unit + f_unit_suffix + f_floor + f_floor_suffix + f_room + f_room_suffix)
562
+ },
563
+ // 检查表号是否存在
564
+ async meternumberValidate() {
565
+ if (!this.userfile.f_gasbrand_id) {
566
+ this.userfile.f_meternumber = ''
567
+ this.$showAlert('请先选择气表品牌!!!', 'warning', 3000)
568
+ return
569
+ }
570
+ if (this.userfile.f_gasbrand_id && this.userfile.f_meternumber) {
571
+ let data = {
572
+ f_meternumber: this.userfile.f_meternumber,
573
+ f_gasbrand_id: this.userfile.f_gasbrand_id
574
+ }
575
+ if (this.userfile.f_userfiles_id) {
576
+ data.f_userfiles_id = this.userfile.f_userfiles_id
577
+ }
578
+ let res = await this.$resetpost(`${this.$androidUtil.getProxyUrl()}/rs/logic/meterbrandsNumberValidate`, {data:data}, {
579
+ resolveMsg: null,
580
+ rejectMsg: '表号验证失败!!'
581
+ })
582
+ if (res.data) {
583
+ this.$showAlert(`表号:${this.userfile.f_meternumber}已存在!!!`, 'warning', 3000)
584
+ this.userfile.f_meternumber = ''
585
+ }
586
+ }
587
+ },
588
+ // 选择气表型号
589
+ gasmodelChange() {
590
+ if (this.userfile.gasmodel) {
591
+ this.userfile.f_gasmodel_id = this.userfile.gasmodel.id
592
+ }
593
+ },
594
+ // 选择气表品牌
595
+ gasbrandChange() {
596
+ // 清空已保存的气表型号
597
+ this.userfile.f_gasmodel_id = null
598
+ this.userfile.gasmodel = null
599
+
600
+ if (this.userfile.gasbrand) {
601
+ // 气表品牌id
602
+ this.userfile.f_gasbrand_id = this.userfile.gasbrand.id
603
+ // 气表分类
604
+ this.userfile.f_meter_classify = this.userfile.gasbrand.f_meter_type
605
+ }
606
+ },
607
+ // 打开安装明细
608
+ async showUserFileModal (row) {
609
+ if (!row) {
610
+ console.log('-------------------添加----------------------')
611
+ }
612
+ console.log('------------------修正---------------------')
613
+ this.initUseradders()
614
+ this.showUserFile = true
615
+ },
616
+ async initUseradders () {
617
+ if (this.selectdata.f_apply_type === '民用报建') {
618
+ Vue.set(this.useradders, 'f_address_type', '民用地址')
619
+ }
620
+ if (this.selectdata.f_apply_type === '民用报建' && this.selectdata.f_apply_nature === '小区') {
621
+ Vue.set(this.useradders, 'f_slice_area', this.selectdata.f_slice_area)
622
+ Vue.set(this.useradders, 'f_pcd', this.selectdata.f_pcd)
623
+ Vue.set(this.useradders, 'f_street', this.selectdata.f_street)
624
+ Vue.set(this.useradders, 'f_residential_area', this.selectdata.f_residential_area)
625
+ }
626
+
627
+ await this.$getConfig(this, 'UserAddress')
628
+
629
+ this.useradders = Object.assign({}, this.useradders, this.config)
630
+ },
631
+ async streetChange () {
632
+ this.residentialList = []
633
+ this.useradders.f_residential_area = null
634
+ if (isEmpty(this.useradders.f_street)) {
635
+ return
636
+ }
637
+ let data = {
638
+ tablename: 't_area',
639
+ condition: `f_filialeid = '${Vue.user.orgid}' and f_street = '${this.useradders.f_street}'`
640
+ // condition: `f_filialeid = '21142' and f_street = '${this.useradders.f_street}'`
641
+ }
642
+ let http = new HttpResetClass()
643
+ let res = await http.load(
644
+ 'POST',
645
+ `${this.$androidUtil.getProxyUrl()}/rs/sql/singleTable`,
646
+ {data: data},
647
+ {resolveMsg: null, rejectMsg: '小区查询失败!!!'}
648
+ )
649
+
650
+ this.residentialList = res.data.map(item => {
651
+ return {
652
+ label: item.f_residential_area,
653
+ value: item.f_residential_area
654
+ }
655
+ })
656
+ },
657
+ async pcdChange () {
658
+ this.streetList = []
659
+ this.useradders.f_street = null
660
+ this.residentialList = []
661
+ this.useradders.f_residential_area = null
662
+ if (isEmpty(this.useradders.f_pcd)) {
663
+ return
664
+ }
665
+
666
+ let data = {
667
+ tablename: 't_street',
668
+ condition: `f_filialeid = '${Vue.user.orgid}' and f_pcd = '${this.useradders.f_pcd}'`
669
+ // condition: `f_filialeid = '21142' and f_pcd = '${this.useradders.f_pcd}'`
670
+ }
671
+ let http = new HttpResetClass()
672
+ let res = await http.load(
673
+ 'POST',
674
+ `${this.$androidUtil.getProxyUrl()}/rs/sql/singleTable`,
675
+ {data: data},
676
+ {resolveMsg: null, rejectMsg: '街道查询失败!!!'}
677
+ )
678
+
679
+ this.streetList = res.data.map(item => {
680
+ return {
681
+ label: item.f_street,
682
+ value: item.f_street
683
+ }
684
+ })
685
+ },
686
+ async getPcdList () {
687
+ let data = {
688
+ tablename: 't_pcd',
689
+ condition: `f_filialeid = '${Vue.user.orgid}'`
690
+ // condition: `f_filialeid = '21142'`
691
+ }
692
+ let http = new HttpResetClass()
693
+ let res = await http.load(
694
+ 'POST',
695
+ `${this.$androidUtil.getProxyUrl()}/rs/sql/singleTable`,
696
+ {data: data},
697
+ {resolveMsg: null, rejectMsg: '省市区查询失败!!!'}
698
+ )
699
+
700
+ this.pcdList = res.data.map(item => {
701
+ return {
702
+ label: item.f_pcd,
703
+ value: item.f_pcd
704
+ }
705
+ })
706
+ },
707
+ async getSliceAreaList () {
708
+ let data = {
709
+ source: 'this.getParentByType($organization$).getAllChildrens().where(row.getType() == $zone$)',
710
+ userid: Vue.user.id
711
+ // userid: '21142'
712
+ }
713
+
714
+ let http = new HttpResetClass()
715
+ let res = await http.load(
716
+ 'POST',
717
+ `${this.$androidUtil.getProxyUrl()}/rs/search`,
718
+ {data: data},
719
+ {resolveMsg: null, rejectMsg: '片区查询失败!!!'}
720
+ )
721
+
722
+ this.sliceAreaList = res.data.map(item => {
723
+ return {
724
+ label: item.name,
725
+ value: item.name
726
+ }
727
+ })
728
+ },
729
+ // 获取气表品牌
730
+ async getMeterbrands() {
731
+ let http = new HttpResetClass()
732
+ let data = {
733
+ f_orgid: Vue.user.orgid
734
+ // f_orgid: 21142
735
+ }
736
+ let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/logic/getMeterbrands`, {data:data}, {
737
+ resolveMsg: null,
738
+ rejectMsg: null
739
+ })
740
+ this.meterbrands = res.data
741
+ },
742
+ searchCondition (args) {
743
+ args.condition = args.condition + `and ua.f_process_id = '${this.selectdata.f_process_id}'`
744
+
745
+ this.model.search(args.condition, args.model)
746
+ },
747
+ // 查询
748
+ async search () {
749
+ let http = new HttpResetClass()
750
+ let data = {
751
+ condition: `ua.f_process_id = '${this.selectdata.f_process_id}'`
752
+ }
753
+ let res = await http.load('POST', `${this.$androidUtil.getProxyUrl()}/rs/sql/getAddresAndUserinfoAndUserfilesAmount`, {data:data}, {
754
+ // let res = await http.load('POST', `rs/sql/getAddresAndUserinfoAndUserfilesAmount`, {data:data}, {
755
+ resolveMsg: null,
756
+ rejectMsg: null
757
+ })
758
+ this.model.rows = res.data
759
+ },
760
+ // 关闭安装明细
761
+ closeUserFile() {
762
+ this.showUserFile = false
763
+ this.useradders = {}
764
+ this.userinfo = {}
765
+ this.userfile = {}
766
+ this.search()
767
+ }
768
+ },
769
+ events: {
770
+ },
771
+ computed: {
772
+ credentialsList() {
773
+ return this.$appdata.getParam('证件类型')
774
+ },
775
+ // 安装人
776
+ installperson() {
777
+ return function (f_install_person) {
778
+ if (isEmpty(f_install_person)) {
779
+ return Vue.user.name
780
+ }
781
+ return f_install_person
782
+ }
783
+ },
784
+ // 安装时间
785
+ installdate() {
786
+ return function (f_install_date) {
787
+ if (isEmpty(f_install_date)) {
788
+ return new Date().Format('yyyy-MM-dd HH:mm:ss')
789
+ }
790
+ return f_install_date
791
+ }
792
+ },
793
+ // 表向
794
+ aroundmeters() {
795
+ return this.$appdata.getParam('左右表')
796
+ },
797
+ // 安装位置
798
+ positions() {
799
+ return this.$appdata.getParam('安装位置')
800
+ }
801
+ },
802
+ watch: {
803
+ }
804
+ }
805
+ </script>
806
+ <style scoped>
807
+ .panel-self{
808
+ border-radius: 10px;
809
+ border:1px solid #499EDF;
810
+ background-color: #F8F8F8;
811
+ }
812
+ .vertical-center {
813
+ display: flex;
814
+ align-items: center;
815
+ text-align: center;
816
+ }
817
+ /*清除model中的浮动*/
818
+ .clearfix:after,.clearfix:before{
819
+ display: table;
820
+ }
821
+ .clearfix:after{
822
+ clear: both;
823
+ }
824
+ </style>