address-client 3.2.106 → 3.2.107

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 (159) hide show
  1. package/.gradle/buildOutputCleanup/cache.properties +2 -2
  2. package/CHANGELOG.md +15 -15
  3. package/build/dev-server.js +185 -185
  4. package/build/versionCheck.js +31 -31
  5. package/build/webpack.base.conf.js +82 -82
  6. package/examples/showAdd/App.vue +40 -40
  7. package/index.html +44 -44
  8. package/package.json +101 -101
  9. package/src/address.js +74 -74
  10. package/src/components/AddAreaMsg.vue +734 -743
  11. package/src/components/AddCommunityManageMsg.vue +220 -220
  12. package/src/components/AddStreetManageMsg.vue +204 -204
  13. package/src/components/AddStreetOrPcd.vue +316 -316
  14. package/src/components/AddressAddAddress.vue +479 -479
  15. package/src/components/AddressFiles.vue +156 -156
  16. package/src/components/AddressList.vue +630 -629
  17. package/src/components/AddressListLiuLi.vue +17 -17
  18. package/src/components/AddressManage.vue +117 -117
  19. package/src/components/AddressTree.vue +501 -501
  20. package/src/components/AreaFiles.vue +73 -73
  21. package/src/components/AreaList.vue +410 -410
  22. package/src/components/AreaManage.vue +104 -104
  23. package/src/components/AreaTree.vue +508 -508
  24. package/src/components/Basch.vue +72 -72
  25. package/src/components/BatchOrders.vue +328 -328
  26. package/src/components/BuildingList.vue +129 -129
  27. package/src/components/CityList.vue +134 -134
  28. package/src/components/CityManage.vue +76 -76
  29. package/src/components/CommunityAreaList.vue +87 -87
  30. package/src/components/CommunityManage.vue +78 -78
  31. package/src/components/CommunityManageList.vue +244 -244
  32. package/src/components/NewAddressInfo.vue +432 -432
  33. package/src/components/StreetList.vue +241 -241
  34. package/src/components/StreetManage.vue +68 -68
  35. package/src/components/StreetManageList.vue +225 -225
  36. package/src/components/UserAddress.vue +910 -910
  37. package/src/components/UserAddressChange.vue +58 -58
  38. package/src/components/selectAddress/BatchList.vue +326 -326
  39. package/src/filiale/WEINAN/AddAreaMsg.vue +745 -745
  40. package/src/filiale/WEINAN/AddressList.vue +588 -588
  41. package/src/filiale/WEINAN/AddressManage.vue +122 -122
  42. package/src/filiale/WEINAN/AreaList.vue +435 -435
  43. package/src/filiale/WEINAN/AreaManage.vue +109 -109
  44. package/src/filiale/WEINAN/AreaUserList.vue +226 -226
  45. package/src/filiale/WEINAN/UserAddress.vue +783 -783
  46. package/src/filiale/WEINAN/sale.js +18 -18
  47. package/src/filiale/chengtou/UserAddress.vue +894 -894
  48. package/src/filiale/chengtou/sale.js +7 -7
  49. package/src/filiale/dongguan/AddStreetOrPcd.vue +422 -422
  50. package/src/filiale/dongguan/sale.js +7 -7
  51. package/src/filiale/gaomi/AddressList.vue +430 -430
  52. package/src/filiale/gaomi/UserAddress.vue +832 -832
  53. package/src/filiale/gaomi/sale.js +14 -14
  54. package/src/filiale/gongyi/AddAreaMsg.vue +651 -651
  55. package/src/filiale/gongyi/AreaManage.vue +100 -100
  56. package/src/filiale/gongyi/UserAddress.vue +751 -751
  57. package/src/filiale/gongyi/sale.js +14 -14
  58. package/src/filiale/haile/AddressList.vue +615 -615
  59. package/src/filiale/haile/sale.js +8 -8
  60. package/src/filiale/jingwei/UserAddress.vue +764 -764
  61. package/src/filiale/jingwei/sale.js +12 -12
  62. package/src/filiale/lixianV3/AreaList.vue +416 -416
  63. package/src/filiale/lixianV3/sale.js +12 -12
  64. package/src/filiale/macheng/AddAreaMsg.vue +635 -635
  65. package/src/filiale/macheng/AddStreetOrPcd.vue +231 -231
  66. package/src/filiale/macheng/AddressList.vue +613 -613
  67. package/src/filiale/macheng/AreaList.vue +318 -318
  68. package/src/filiale/macheng/CityManage.vue +76 -76
  69. package/src/filiale/macheng/StreetList.vue +186 -186
  70. package/src/filiale/macheng/UserAddress.vue +743 -743
  71. package/src/filiale/macheng/sale.js +17 -17
  72. package/src/filiale/meihekou/UserAddress.vue +898 -898
  73. package/src/filiale/meihekou/sale.js +8 -8
  74. package/src/filiale/qianneng/AddAreaMsg.vue +755 -755
  75. package/src/filiale/qianneng/AddStreetOrPcd.vue +328 -328
  76. package/src/filiale/qianneng/AddressList.vue +638 -638
  77. package/src/filiale/qianneng/AreaList.vue +431 -431
  78. package/src/filiale/qianneng/CityManage.vue +81 -81
  79. package/src/filiale/qianneng/UserAddress.vue +1125 -1125
  80. package/src/filiale/qianneng/sale.js +20 -20
  81. package/src/filiale/qinhua/AddAreaMsg.vue +743 -743
  82. package/src/filiale/qinhua/AddressList.vue +627 -627
  83. package/src/filiale/qinhua/AddressManage.vue +117 -117
  84. package/src/filiale/qinhua/AreaList.vue +425 -425
  85. package/src/filiale/qinhua/AreaManage.vue +100 -100
  86. package/src/filiale/qinhua/CityManage.vue +76 -76
  87. package/src/filiale/qinhua/StreetList.vue +241 -241
  88. package/src/filiale/qinhua/UserAddress.vue +894 -894
  89. package/src/filiale/qinhua/sale.js +20 -20
  90. package/src/filiale/rizhao/UserAddress.vue +897 -897
  91. package/src/filiale/rizhao/sale.js +8 -8
  92. package/src/filiale/rongcheng/AddressList.vue +363 -363
  93. package/src/filiale/rongcheng/UserAddress.vue +799 -799
  94. package/src/filiale/rongcheng/sale.js +11 -11
  95. package/src/filiale/shanggao/AddAreaMsg.vue +752 -752
  96. package/src/filiale/shanggao/AddStreetOrPcd.vue +312 -312
  97. package/src/filiale/shanggao/AddressList.vue +613 -613
  98. package/src/filiale/shanggao/AreaList.vue +436 -436
  99. package/src/filiale/shanggao/BuildingList.vue +129 -129
  100. package/src/filiale/shanggao/StreetList.vue +240 -240
  101. package/src/filiale/shanggao/UserAddress.vue +953 -953
  102. package/src/filiale/shanggao/sale.js +16 -16
  103. package/src/filiale/shanxian/AddAreaMsg.vue +766 -766
  104. package/src/filiale/shanxian/AddressList.vue +658 -658
  105. package/src/filiale/shanxian/AreaList.vue +458 -458
  106. package/src/filiale/shanxian/AreaManage.vue +107 -107
  107. package/src/filiale/shanxian/UserAddress.vue +900 -900
  108. package/src/filiale/shanxian/sale.js +15 -15
  109. package/src/filiale/shaoguan/AddAreaMsg.vue +629 -629
  110. package/src/filiale/shaoguan/UserAddress.vue +762 -762
  111. package/src/filiale/shaoguan/sale.js +11 -11
  112. package/src/filiale/tongchuan/AddAreaMsg.vue +635 -635
  113. package/src/filiale/tongchuan/AddStreetOrPcd.vue +351 -351
  114. package/src/filiale/tongchuan/AddressList.vue +379 -379
  115. package/src/filiale/tongchuan/AreaList.vue +315 -315
  116. package/src/filiale/tongchuan/AreaManage.vue +100 -100
  117. package/src/filiale/tongchuan/CityList.vue +133 -133
  118. package/src/filiale/tongchuan/StreetList.vue +215 -215
  119. package/src/filiale/tongchuan/UserAddress.vue +822 -822
  120. package/src/filiale/tongchuan/sale.js +19 -19
  121. package/src/filiale/wuhai/UserAddress.vue +795 -795
  122. package/src/filiale/wuhai/sale.js +12 -12
  123. package/src/filiale/xinkang/AddAreaMsg.vue +780 -780
  124. package/src/filiale/xinkang/AreaList.vue +413 -413
  125. package/src/filiale/xinkang/sale.js +9 -9
  126. package/src/filiale/yangchun/AddAreaMsg.vue +764 -764
  127. package/src/filiale/yangchun/sale.js +7 -7
  128. package/src/filiale/zhongsheng/AddressList.vue +671 -671
  129. package/src/filiale/zhongsheng/AreaList.vue +500 -500
  130. package/src/filiale/zhongsheng/sale.js +12 -12
  131. package/src/filiale/zhongyi/AddAreaMsg.vue +757 -757
  132. package/src/filiale/zhongyi/sale.js +12 -12
  133. package/src/filiale/zhoukou/AddAreaMsg.vue +673 -673
  134. package/src/filiale/zhoukou/AddressList.vue +391 -391
  135. package/src/filiale/zhoukou/AddressManage.vue +115 -115
  136. package/src/filiale/zhoukou/AreaList.vue +319 -319
  137. package/src/filiale/zhoukou/AreaManage.vue +100 -100
  138. package/src/filiale/zhoukou/UserAddress.vue +925 -925
  139. package/src/filiale/zhoukou/sale.js +23 -23
  140. package/src/main.js +23 -23
  141. package/.gradle/8.5/checksums/checksums.lock +0 -0
  142. package/.gradle/8.5/dependencies-accessors/dependencies-accessors.lock +0 -0
  143. package/.gradle/8.5/dependencies-accessors/gc.properties +0 -0
  144. package/.gradle/8.5/executionHistory/executionHistory.bin +0 -0
  145. package/.gradle/8.5/executionHistory/executionHistory.lock +0 -0
  146. package/.gradle/8.5/fileChanges/last-build.bin +0 -0
  147. package/.gradle/8.5/fileHashes/fileHashes.bin +0 -0
  148. package/.gradle/8.5/fileHashes/fileHashes.lock +0 -0
  149. package/.gradle/8.5/gc.properties +0 -0
  150. package/.gradle/buildOutputCleanup/buildOutputCleanup.lock +0 -0
  151. package/.gradle/file-system.probe +0 -0
  152. package/.gradle/vcs-1/gc.properties +0 -0
  153. package/address-client-3.2.106-yangchun.tgz +0 -0
  154. package/build/libs/AddressClient-V3-3.0.11.jar +0 -0
  155. package/build/tmp/jar/MANIFEST.MF +0 -2
  156. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  157. package/gradle/wrapper/gradle-wrapper.properties +0 -7
  158. package/gradlew +0 -249
  159. package/gradlew.bat +0 -92
@@ -1,743 +1,734 @@
1
- <template>
2
- <div class="span">
3
- <validator name='v'>
4
- <div class="form-horizontal select-overspread container-fluid" style="overflow-y: auto">
5
- <div class="row auto">
6
- <div class="col-sm-12 bg-info text-center" style="padding: 8px;font-size: 18px;font-weight: bold">
7
- <span v-if="operation=='add'&&!f_specia">添加{{areatype}}</span>
8
- <span v-if="operation=='modify'&&!f_special">修改【{{areamodel.f_residential_area}}】小区</span>
9
- <span v-if="operation=='add'&&f_specia">添加{{areatype}}</span>
10
- <span v-if="operation=='modify'&&f_special">修改【{{areamodel.f_residential_area}}】单位</span>
11
- </div>
12
- <div v-if="areatype != '楼栋'">
13
- <!--基本小区(单位)信息-->
14
- <div class="col-sm-6 form-group" v-if="!config.hasnumber">
15
- <label class="font_normal_body">小区编号</label>
16
- <input type="text" class="input_search" style="width:60%" v-model="areamodel.f_area_id"
17
- @blur="areaidChange" placeholder="小区编号">
18
- </div>
19
-
20
- <div class="col-sm-6 form-group" v-if="config.hasnumber"
21
- :class="[$v.f_area_id.required ? 'has-error' : 'has-success']">
22
- <label class="font_normal_body">小区编号</label>
23
- <input type="number" class="input_search" style="width:60%" v-model="areamodel.f_area_id"
24
- v-validate:f_area_id='{required: true }'
25
- @change="areaidChangeHasnumber" placeholder="小区编号">
26
- </div>
27
-
28
- <div class="col-sm-6 form-group"
29
- :class="[$v.f_pcd_id.required ? 'has-error' : 'has-success']">
30
- <label class="font_normal_body">省&ensp;市&ensp;区</label>
31
- <input type="text" class="input_search" class="input_search" style="width:60%" v-show="false" v-model="areamodel.f_pcd_id"
32
- v-validate:f_pcd_id='{required: true }'>
33
- <v-select
34
- :value.sync="areamodel.f_pcd_id" :value-single="true"
35
- :options='pcdslist' placeholder='请选择'
36
- close-on-select search="true" @change="pcdChange">
37
- </v-select>
38
- </div>
39
- <div class="col-sm-6 form-group"
40
- :class="[$v.f_street_id.required ? 'has-error' : 'has-success']">
41
- <label class="font_normal_body">街道/乡镇</label>
42
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_street_id"
43
- v-validate:f_street_id='{required: true }'>
44
- <v-select
45
- :value.sync="areamodel.f_street_id" :value-single="true"
46
- :options='streetslist' placeholder='请选择'
47
- close-on-select search="true" @change="streetChange">
48
- </v-select>
49
- </div>
50
- <div class="col-sm-6 form-group" :class="[$v.slice.required ? 'has-error' : 'has-success']">
51
- <label class="font_normal_body">片&emsp;&emsp;区</label>
52
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="$refs.slice.selectedItems"
53
- v-validate:slice='{required: true }'>
54
- <v-select :value.sync="areamodel.slice_area" v-model="areamodel.slice_area"
55
- :options='sliceArea' placeholder='片区/管理站' filer-key="name"
56
- close-on-select v-ref:slice>
57
- </v-select>
58
- </div>
59
- <!--小区(特殊)信息-->
60
- <div v-if="!f_special"
61
- class="col-sm-6 form-group"
62
- :class="[$v.f_residential_area.required ? 'has-error' : 'has-success']">
63
- <label class="font_normal_body">小区名称</label>
64
- <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_residential_area"
65
- class="form-control" placeholder="小区名称"
66
- v-validate:f_residential_area='{required: true }'>
67
- </div>
68
- <div v-if="!f_special"
69
- class="col-sm-12 form-group">
70
- <label class="font_normal_body">小区地址</label>
71
- <input type="text" style="width:80%" class="input_search" v-model="areamodel.f_area_address"
72
- class="form-control" placeholder="小区地址">
73
- </div>
74
- <!--单位(特殊)信息-->
75
- <div v-if="f_special"
76
- class="col-sm-6 form-group"
77
- :class="[$v.f_residential_area.required ? 'has-error' : 'has-success']">
78
- <label class="font_normal_body">单位名称</label>
79
- <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_residential_area"
80
- class="form-control" placeholder="单位名称"
81
- v-validate:f_residential_area='{required: true }'>
82
- </div>
83
- <div v-if="f_special"
84
- class="col-sm-12 form-group">
85
- <label class="font_normal_body">单位地址</label>
86
- <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_area_address"
87
- class="form-control" placeholder="单位地址">
88
- </div>
89
- <div v-if="f_special"
90
- class="col-sm-6 form-group"
91
- :class="[$v.f_linkname.required ? 'has-error' : 'has-success']">
92
- <label class="font_normal_body">联&ensp;系&ensp;人</label>
93
- <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_linkname"
94
- class="form-control" placeholder="联系人"
95
- v-validate:f_linkname='{required: true }'>
96
- </div>
97
- <div v-if="f_special"
98
- class="col-sm-6 form-group"
99
- :class="[$v.f_linkphone.required ? 'has-error' : 'has-success']">
100
- <label class="font_normal_body">联系电话</label>
101
- <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_linkphone"
102
- class="form-control" placeholder="联系电话"
103
- v-validate:f_linkphone='{required: true }'>
104
- </div>
105
- <div class="col-sm-12 form-group">
106
- <label class="font_normal_body " style="">备&emsp;&emsp;注</label>
107
- <textarea class="input_textarea" rows="3" style="margin-top:20px;width:80%;height: auto;" v-model="areamodel.f_comments"></textarea>
108
- </div>
109
- <div class="col-sm-12 form-group">
110
- <br/>
111
- </div>
112
- <!--表具信息-->
113
- <div v-if="!f_special" class="col-sm-12 bg-info text-center" style="padding: 8px;font-size: 18px;font-weight: bold">
114
- <span >默认表具信息</span>
115
- </div>
116
- <div v-if="!f_special" class="row">
117
- <div class="col-sm-6 form-group">
118
- <label class="font_normal_body">用户类型</label>
119
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_user_type">
120
- <v-select
121
- :value.sync="areamodel.f_user_type" :value-single="true"
122
- :options='usertypes' placeholder='用户类型' @change="userTypeChange"
123
- close-on-select >
124
- </v-select>
125
- </div>
126
- <div class="col-sm-6 form-group">
127
- <label class="font_normal_body">用气性质</label>
128
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_gasproperties">
129
- <v-select
130
- :value.sync="areamodel.f_gasproperties" :value-single="true"
131
- :options='gasproperties' placeholder='用气性质'
132
- close-on-select >
133
- </v-select>
134
- </div>
135
- <div class="col-sm-6 form-group">
136
- <label class="font_normal_body">气价类型</label>
137
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_price_type">
138
- <v-select
139
- :value.sync="areamodel.f_price_type" :value-single="true"
140
- :options='f_price_types' placeholder='气价类型'
141
- close-on-select >
142
- </v-select>
143
- </div>
144
- <div class="col-sm-6 form-group">
145
- <label class="font_normal_body">气价名称</label>
146
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_price_name">
147
- <v-select
148
- :value.sync="areamodel.f_price_name" :value-single="true"
149
- :options='pricenames' placeholder='气价名称'
150
- close-on-select >
151
- </v-select>
152
- </div>
153
- <div class="col-sm-6 form-group">
154
- <label class="font_normal_body">气表品牌</label>
155
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_meter_brand">
156
- <v-select
157
- :value.sync="areamodel.f_meter_brand" :value-single="true"
158
- :options='meterbrands' placeholder='气表品牌'
159
- close-on-select >
160
- </v-select>
161
- </div>
162
- <div class="col-sm-6 form-group">
163
- <label class="font_normal_body">气表型号</label>
164
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_meter_style">
165
- <v-select
166
- :value.sync="areamodel.f_meter_style" :value-single="true"
167
- :options='meterstyle' placeholder='气表型号'
168
- close-on-select >
169
- </v-select>
170
- </div>
171
- <div class="col-sm-6 form-group" :class="[$v.f_meter_type.required ? 'has-error' : 'has-success']">
172
- <label class="font_normal_body">气表类型</label>
173
- <input type="text" style="width:60%" class="input_search" v-show="false"
174
- v-model="areamodel.f_meter_type">
175
- <v-select :value.sync="areamodel.f_meter_type" :value-single="true"
176
- :options='metertypes' placeholder='请选择'
177
- close-on-select></v-select>
178
- </div>
179
- <div class="col-sm-6 form-group" v-if="isMachine">
180
- <label class="font_normal_body">抄&ensp;表&ensp;册</label>
181
- <input type="text" style="width:60%" class="input_search" v-show="false"
182
- v-model="areamodel.f_meter_book">
183
- <v-select
184
- :value.sync="areamodel.f_meter_book" :value-single="true"
185
- :options='meterbooks' placeholder='抄表册'
186
- close-on-select >
187
- </v-select>
188
- </div>
189
- <div class="col-sm-6 form-group" v-if="!isMachine" :class="[$v.f_meter_book.required ? 'has-error' : 'has-success']">
190
- <label class="font_normal_body">抄&ensp;表&ensp;册</label>
191
- <input type="text" style="width:60%" class="input_search" v-show="false"
192
- v-model="areamodel.f_meter_book">
193
- <v-select
194
- :value.sync="areamodel.f_meter_book" :value-single="true"
195
- :options='meterbooks' placeholder='抄表册'
196
- close-on-select >
197
- </v-select>
198
- </div>
199
- <div class="col-sm-6 form-group" :class="[$v.f_inputtor.required ? 'has-error' : 'has-success']">
200
- <label class="font_normal_body">抄&ensp;表&ensp;员</label>
201
- <input type="text" style="width:60%" class="input_search"
202
- v-show="false" v-model="areamodel.f_inputtor">
203
- <v-select
204
- :value.sync="areamodel.f_inputtor" :value-single="true"
205
- :options='inputtores' placeholder='抄表员'
206
- close-on-select >
207
- </v-select>
208
- </div>
209
- <div class="col-sm-6 form-group" :class="[$v.f_adjustable_id.required ? 'has-error' : 'has-success']">
210
- <label class="font_normal_body">调&ensp;压&ensp;箱</label>
211
- <input type="text" style="width:60%" class="input_search" v-show="false"
212
- v-model="areamodel.f_adjustable_id">
213
- <v-select
214
- :value.sync="areamodel.f_adjustable_id" :value-single="true"
215
- :options='adjustables' placeholder='调压箱'
216
- close-on-select >
217
- </v-select>
218
- </div>
219
- <div class="col-sm-6 form-group" :class="[$v.f_house_type.required ? 'has-error' : 'has-success']">
220
- <label class="font_normal_body">房屋类型</label>
221
- <input type="text" style="width:60%" class="input_search" v-show="false"
222
- v-model="areamodel.f_house_type" >
223
- <v-select
224
- :value.sync="areamodel.f_house_type" :value-single="true"
225
- :options='housetypeoptions' placeholder='房屋类型'
226
- close-on-select >
227
- </v-select>
228
- </div>
229
- <div class="col-sm-6 form-group" :class="[$v.f_position.required ? 'has-error' : 'has-success']">
230
- <label class="font_normal_body">安装位置</label>
231
- <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_position" >
232
- <v-select
233
- :value.sync="areamodel.f_position" :value-single="true"
234
- :options='positions' placeholder='安装位置'
235
- close-on-select >
236
- </v-select>
237
- </div>
238
- </div>
239
- <div v-if="f_special" class="col-sm-6 form-group">
240
- <br/>
241
- </div>
242
- </div>
243
- <div v-if="areatype == '楼栋'">
244
- <div class="col-sm-6 form-group " :class="[$v.f_residential_area_id1.required ? 'has-error' : 'has-success']">
245
- <label class="font_normal_body">小区名称</label>
246
- <input type="text" style="width:41%" v-show="false" v-model="buildingmodel.f_residential_area_id"
247
- v-validate:f_residential_area_id1='{required: true }'>
248
- <v-select :value.sync="buildingmodel.f_residential_area_id" :value-single="true" v-ref:areaselect
249
- :options='areaslist' placeholder='请选择'
250
- close-on-select search="true">
251
- </v-select>
252
- </div>
253
- <div class="col-sm-6 form-group" :class="[$v.f_building.required ? 'has-error' : 'has-success']">
254
- <label class="font_normal_body">楼栋名称</label>
255
- <input type="text" class="input_search" style="width:60%" v-validate:f_building='{required: true }'
256
- v-model="buildingmodel.f_building" placeholder="楼栋名称">
257
- </div>
258
- </div>
259
- </div>
260
- <div class="row auto" style="text-align:right;">
261
- <button class="button_search button_spacing" @click="confirm()" :disabled='!$v.valid'>保存</button>
262
- <button class="button_clear button_spacing" @click="cancel()">取消</button>
263
- </div>
264
- <div v-if="areatype == '楼栋'" class="row" style="margin-top:40px;height: 580px;">
265
- <building-list v-ref:buildinglist @select-changed="selected" :areaslist="areaslist" :f_filialeids.sync="f_filialeids"></building-list>
266
- </div>
267
- </div>
268
- </validator>
269
- </div>
270
- </template>
271
-
272
- <script>
273
- import {HttpResetClass} from 'vue-client'
274
-
275
- let initGen = async function (self) {
276
- await self.$getConfig(self, 'UserArea')
277
- console.log('原地址配置',self.config)
278
- console.log('获取地址配置',self.config)
279
- // Object.assign(self.model, self.config)
280
- await self.initdata()
281
- await self.$LoadParams.loadMeterBook(self.f_filialeids)
282
- await self.loadMeterBooks();
283
- }
284
- export default {
285
- title: '小区添加',
286
- data () {
287
- return {
288
- config:{
289
- hasnumber:false,
290
- },
291
- //初始化省市区数据
292
- pcdslist:[],
293
- //初始化街道数据
294
- streetslist:[],
295
- //小区
296
- areamodel: {
297
- f_area_id: '',
298
- f_pcd_id:'',
299
- f_linkname:'',
300
- f_linkphone:'',
301
- f_street_id:'',
302
- f_slice_area:'',
303
- f_adjustable_id:'',
304
- f_residential_area:'',
305
- f_user_type:'',
306
- f_gasproperties:'',
307
- f_meter_brand:'',
308
- f_price_name:'',
309
- f_area_address:'',
310
- f_price_type:'',
311
- f_meter_style:'',
312
- f_position:'',
313
- f_comments:'',
314
- f_meter_type: ''
315
- },
316
- // 初始化小区数据
317
- areaslist:[],
318
- // 楼栋
319
- buildingmodel: {
320
- f_residential_area: '',
321
- f_residential_area_id: '',
322
- f_building: ''
323
- },
324
- meterbrands: [],
325
- adjustables: [],
326
- sliceArea: [],
327
- gasproperties: [],
328
- meterbooks:[{label: '全部',value: ''}],
329
- housetypeoptions:[{label: '楼房', value: '楼房'}, {label: '自建房', value: '自建房'}],
330
- isMachine: true
331
- }
332
- },
333
- props: ['f_filialeids','f_special', 'areatype','row','operation'],
334
- ready(){
335
- initGen(this)
336
- },
337
- methods: {
338
- loadMeterBooks(){
339
- this.meterbooks = [...this.meterbooks, ...this.$GetSaleParam.getMeterBooks()]
340
- },
341
- //初始化数据
342
- async initdata(){
343
- // 初始化参数
344
- await this.initParams()
345
- if (this.areatype == '楼栋') {
346
- this.initareas(` f_orgid = '${this.f_filialeids}'`)
347
- }
348
- // 初始化片区
349
- await this.initSlice(this.f_filialeids)
350
- await this.initpcds(` f_filialeid = '${this.f_filialeids}'`)
351
- },
352
- initrow(val){
353
- this.areamodel.f_meter_book = val.f_meter_book;
354
- this.areamodel.f_adjustable_id = val.f_adjustable_id;
355
- },
356
- async initParams() {
357
- await this.$LoadParams.loadParam(this.f_filialeids)
358
- this.initBrands()
359
- this.initAdjustables()
360
- },
361
-
362
- initBrands () {
363
- let ret = this.$GetSaleParam.getGasbrand()
364
- let rs = new Array()
365
- ret.forEach((item, index) =>{
366
- rs.push({label: item.label, value: item.value.f_meter_brand})
367
- })
368
- this.meterbrands = rs
369
- },
370
-
371
- initAdjustables () {
372
- let filter = this.$login.f.orgid
373
- let ret = this.$GetSaleParam.getAdjustable(filter)
374
- let arr = new Array()
375
- ret.forEach((item, index) => {
376
- arr.push({label: `[${item.value.f_adjustable_id}]-${item.label}`, value: item.value.id})
377
- })
378
- this.adjustables = arr
379
- },
380
-
381
- async initSlice (val) {
382
- if (val) {
383
- let getAllArea = await this.$resetpost('/rs/search', {
384
- source: 'this.getParentByType($organization$).getAllChildrens().where(row.getType() == $zone$)',
385
- userid: this.$login.f.id
386
- }, {resolveMsg: null, rejectMsg: '获取片区出错!!!'})
387
-
388
- let arr = getAllArea.data.filter((res) => {
389
- return res.parentid == val
390
- })
391
- this.sliceArea = []
392
- arr.forEach((res) => {
393
- this.sliceArea.push({label: res.name, value: {name: res.name, code:res.number}})
394
- })
395
- }
396
- },
397
- //初始化小区添加小区
398
- async initareas(pconditon){
399
- // if(this.usertype){
400
- // pconditon=pconditon+` and f_special='1' `
401
- // }
402
- this.areaslist = []
403
- let HttpReset = new HttpResetClass()
404
- let req = await HttpReset.load('POST', 'api/af-revenue/sql/address_singleTableOrderBy?pageNo=1&pageSize=9999999', {
405
- data: {
406
- items: '*',
407
- tablename: 't_area',
408
- orderitem: 'id',
409
- condition: pconditon
410
- }
411
- }, {resolveMsg: null, rejectMsg: '获取地址失败!'})
412
- let redata = []
413
- req.data.forEach((row) => {
414
- redata.push({
415
- label: '['+row.f_street+']'+row.f_residential_area,
416
- value: row.id,
417
- data: row,
418
- id: row.id
419
- })
420
- })
421
- this.areaslist=redata
422
- },
423
-
424
- //初始化省市区,添加街道
425
- async initpcds(pconditon){
426
- this.pcdslist = []
427
- let HttpReset = new HttpResetClass()
428
- let req = await HttpReset.load('POST', 'api/af-revenue/sql/address_singleTableOrderBy', {
429
- data: {
430
- items: '*',
431
- tablename: 't_pcd',
432
- orderitem: 'id',
433
- condition: pconditon
434
- }
435
- }, {resolveMsg: null, rejectMsg: '获取地址失败!'})
436
- let redata = []
437
- req.data.forEach((row, n) => {
438
- redata[n] = {
439
- label: row.f_pcd,
440
- value: row.id,
441
- data:row,
442
- id:row.id
443
- }
444
- })
445
- this.pcdslist=redata
446
-
447
- },
448
- //初始化街道 添加小区
449
- async initstreets(pconditon){
450
- this.streetslist = []
451
- let HttpReset = new HttpResetClass()
452
- let req = await HttpReset.load('POST', 'api/af-revenue/sql/address_singleTableOrderBy', {
453
- data: {
454
- items: '*',
455
- tablename: 't_street',
456
- orderitem: 'id',
457
- condition: pconditon
458
- }
459
- }, {resolveMsg: null, rejectMsg: '获取地址失败!'})
460
- let redata = []
461
- req.data.forEach((row, n) => {
462
- redata[n] = {
463
- label: row.f_street,
464
- value: row.id,
465
- data:row,
466
- id:row.id
467
- }
468
- })
469
- this.streetslist=redata
470
- },
471
- async areaidChangeHasnumber(){
472
- console.log(this.areamodel.f_area_id.length)
473
- if (this.areamodel.f_area_id.length != 2){
474
- this.$showAlert('请输入正确的位数', 'warning', 2000)
475
- this.areamodel.f_area_id = ''
476
- }else{
477
- let res =await this.$resetpost('api/af-revenue/sql/address_singleTableOrderBy', {
478
- data: {
479
- items: '*',
480
- tablename: 't_area',
481
- orderitem: 'id',
482
- condition: `f_area_id = '${this.areamodel.f_area_id}' and f_orgid = '${this.$login.f.orgid}'`
483
- }
484
- }, {resolveMsg: null, rejectMsg: null})
485
- if (res.data.length>0){
486
- if (res.data[0].id != this.areamodel.id) {
487
- this.$showAlert('当前编号已存在', 'warning', 2000)
488
- this.areamodel.f_area_id = ''
489
- }
490
- }
491
- }
492
- },
493
- async areaidChange () {
494
- // 验证小区编号是否已存在
495
-
496
- let param = {
497
- id: this.areamodel.id,
498
- f_area_id: this.areamodel.f_area_id,
499
- f_filialeid: this.f_filialeids
500
- }
501
-
502
- let res = await this.$resetpost('api/af-revenue/logic/address_validateAreaID', param, {resolveMsg: null,rejectMsg: '小区编号验证失败!!'})
503
- console.log('验证小区是否存在', res)
504
- if (res.data) {
505
- this.$showAlert('这个小区编号已存在!!!请核实', 'warning', 3000)
506
- this.areamodel.f_area_id = ''
507
- }
508
-
509
- },
510
-
511
-
512
- //根据名字找数据
513
- findbyid(list,name){
514
- var result
515
- list.forEach((row, n) => {
516
- if(name==row.id){
517
- result= row.data
518
- }
519
- })
520
- return result
521
- },
522
- userTypeChange () {
523
- this.gasproperties = []
524
- if (this.areamodel.f_user_type) {
525
- this.gasproperties = this.$appdata.getParam(this.areamodel.f_user_type)
526
- }
527
- },
528
-
529
- //省/市/区变化
530
- async pcdChange(val){
531
- if(val){
532
- //那就把街道数据重新组织一下
533
- await this.initstreets(` f_filialeid = '${this.f_filialeids}' and f_pcd_id ='${val}' `)
534
- if(this.areamodel.f_street_id){
535
- if (this.findbyid(this.streetslist,this.areamodel.f_street_id)) {
536
- let pcd_id=this.findbyid(this.streetslist,this.areamodel.f_street_id).f_pcd_id
537
- if(pcd_id!=val){
538
- this.areamodel.f_street_id=''
539
- }
540
- } else {
541
- this.areamodel.f_street_id=''
542
- }
543
-
544
- }
545
- }
546
- this.$resetValidation()
547
- },
548
- //街道变化
549
- streetChange(val){
550
- if(val&&this.operation=='add'){
551
- // if(this.areamodel.f_pcd_id.length==0){
552
- if (this.findbyid(this.streetslist,this.areamodel.f_street_id)) {
553
- this.areamodel.f_pcd_id=this.findbyid(this.streetslist,this.areamodel.f_street_id).f_pcd_id
554
- }
555
- // }
556
- }
557
- this.$resetValidation()
558
- },
559
- //保存
560
- async confirm(){
561
- if(this.areatype=='楼栋'){
562
- await this.savebuilding()
563
- } else {
564
- await this.savearea()
565
- this.cleardara()
566
- this.$dispatch('confirm')
567
- }
568
- },
569
- // 保存楼栋
570
- async savebuilding () {
571
- this.buildingmodel.f_residential_area = this.$refs.areaselect.selectedItems
572
- this.buildingmodel.f_filialeid = this.f_filialeids
573
- this.buildingmodel.f_operator = this.$login.f.name
574
- this.buildingmodel.f_operatorid = this.$login.f.id
575
- this.buildingmodel.f_orgid = this.$login.f.orgid
576
- this.buildingmodel.f_orgname = this.$login.f.orgs
577
- this.buildingmodel.f_depid = this.$login.f.depids
578
- this.buildingmodel.f_depname = this.$login.f.deps
579
- await this.$resetpost('api/af-revenue/logic/address_savebuilding', this.buildingmodel)
580
- this.$refs.buildinglist.search()
581
- },
582
- //保存小区
583
- async savearea(){
584
- if(this.f_special){
585
- this.areamodel.f_special='1'
586
- }
587
- this.areamodel.f_filialeid = this.f_filialeids
588
- this.areamodel.f_operator = this.$login.f.name
589
- this.areamodel.f_operatorid = this.$login.f.id
590
- this.areamodel.f_orgid = this.$login.f.orgid
591
- this.areamodel.f_orgname = this.$login.f.orgs
592
- this.areamodel.f_depid = this.$login.f.depids
593
- this.areamodel.f_depname = this.$login.f.deps
594
- if (this.areamodel.slice_area) {
595
- if (this.areamodel.slice_area.length > 0) {
596
- this.areamodel.f_slice_area = this.areamodel.slice_area[0].name
597
- this.areamodel.f_area_code = this.areamodel.slice_area[0].code
598
- }
599
- }
600
- this.areamodel.f_pcd=this.findbyid(this.pcdslist,this.areamodel.f_pcd_id).f_pcd
601
- this.areamodel.f_street=this.findbyid(this.streetslist,this.areamodel.f_street_id).f_street
602
-
603
- await this.$resetpost('api/af-revenue/logic/address_updatearea', this.areamodel)
604
- },
605
- cleardara(){
606
- this.areamodel= {
607
- f_area_id: '',
608
- f_pcd_id:'',
609
- f_street_id:'',
610
- f_slice_area:'',
611
- f_linkname:'',
612
- f_linkphone:'',
613
- f_adjustable_id:'',
614
- f_residential_area:'',
615
- f_user_type:'',
616
- f_gasproperties:'',
617
- f_area_address:'',
618
- f_meter_brand:'',
619
- f_price_name:'',
620
- f_price_type:'',
621
- f_meter_style:'',
622
- f_position:'',
623
- f_comments:'',
624
- f_meter_type: ''
625
- }
626
- },
627
- cancel(){
628
- this.cleardara()
629
- this.$dispatch('cancel')
630
- },
631
- },
632
- watch: {
633
- 'areamodel.f_meter_type' (val) {
634
- if (val === '机表')
635
- this.isMachine = false
636
- },
637
- 'areatype'(){
638
- this.initdata()
639
- },
640
- 'areamodel.f_pcd_id'(){
641
- if(this.areamodel.f_pcd_id&&this.areamodel.f_street_id){
642
- if (this.findbyid(this.pcdslist,this.areamodel.f_pcd_id) && this.findbyid(this.streetslist,this.areamodel.f_street_id)) {
643
- this.areamodel.f_area_address = this.findbyid(this.pcdslist,this.areamodel.f_pcd_id).f_pcd + this.findbyid(this.streetslist,this.areamodel.f_street_id).f_street
644
- }
645
- }
646
- },
647
- 'areamodel.f_street_id'(){
648
- if (this.areamodel.f_pcd_id && this.areamodel.f_street_id) {
649
- if (this.findbyid(this.pcdslist, this.areamodel.f_pcd_id) && this.findbyid(this.streetslist, this.areamodel.f_street_id)) {
650
- this.areamodel.f_area_address = this.findbyid(this.pcdslist, this.areamodel.f_pcd_id).f_pcd + this.findbyid(this.streetslist, this.areamodel.f_street_id).f_street
651
- }
652
- }
653
- },
654
- 'f_filialeids'(){
655
- if (this.areamodel.f_filialeid) {
656
- if (this.areamodel.f_filialeid != this.f_filialeids) {
657
- this.$dispatch('cancel')
658
- }
659
- }
660
- this.cleardara()
661
- this.initdata()
662
- }
663
- },
664
- computed: {
665
- metertypes() {
666
- return this.$appdata.getParam('气表类型')
667
- },
668
- usertypes () {
669
- return this.$appdata.getParam('用户类型')
670
- },
671
- f_price_types () {
672
- return this.$appdata.getParam('气价类型')
673
- },
674
- meterstyle () {
675
- let ret = this.$GetSaleParam.getGasbrand()
676
- let rs = new Array()
677
- if(this.areamodel.f_meter_brand) {
678
- ret.forEach((item, index) => {
679
- if(this.areamodel.f_meter_brand == item.value.f_meter_brand) {
680
- item.value.gasmodel.forEach((item1, index) =>{
681
- rs.push({label: item1.label, value:item1.label})
682
- })
683
- }
684
- })
685
- }
686
- return rs
687
- },
688
- pricenames () {
689
- let rs = new Array()
690
- if (this.areamodel.f_user_type && this.areamodel.f_gasproperties && this.areamodel.f_price_type) {
691
- let params = {
692
- f_user_type: this.areamodel.f_user_type,
693
- f_gasproperties: this.areamodel.f_gasproperties,
694
- f_price_type: this.areamodel.f_price_type,
695
- filter: this.f_filialeids
696
- }
697
- let ret = this.$GetSaleParam.getPrice(params)
698
- ret.forEach((item, index) => {
699
- rs.push({label: item.label, value: item.value.f_price_name})
700
- })
701
- }
702
- if (rs.length == 0) {
703
- this.areamodel.f_price_name = ''
704
- }
705
- return rs
706
- },
707
- positions () {
708
- return this.$appdata.getParam('安装位置')
709
- },
710
- inputtores () {
711
- // 获取抄表员
712
- let rs = new Array()
713
- if (this.$login.f.f_gasman.length > 0) {
714
- for (let i = 0; i < this.$login.f.f_gasman.length; i++) {
715
- let temp = {
716
- label: this.$login.f.f_gasman[i].name,
717
- value: this.$login.f.f_gasman[i].name
718
- }
719
- rs.push(temp)
720
- }
721
- }
722
- return rs
723
- }
724
- }
725
- }
726
- </script>
727
- <style>
728
- .box {
729
- width: 727px;
730
- height: 175px;
731
- border-radius: 2px;
732
- background-color: #fafafa;
733
- border: 1px solid #999999;
734
- margin-top: 13px;
735
- }
736
- .datapanel {
737
- color: #333;
738
- background-color: white;
739
- box-shadow: darkgrey 0.5px 0.5px 0.5px 0.5px ;
740
- padding: 10px 30px 10px 30px;
741
- border-radius:15px;
742
- }
743
- </style>
1
+ <template>
2
+ <div class="span">
3
+ <validator name='v'>
4
+ <div class="form-horizontal select-overspread container-fluid" style="overflow-y: auto">
5
+ <div class="row auto">
6
+ <div class="col-sm-12 bg-info text-center" style="padding: 8px;font-size: 18px;font-weight: bold">
7
+ <span v-if="operation=='add'&&!f_specia">添加{{areatype}}</span>
8
+ <span v-if="operation=='modify'&&!f_special">修改【{{areamodel.f_residential_area}}】小区</span>
9
+ <span v-if="operation=='add'&&f_specia">添加{{areatype}}</span>
10
+ <span v-if="operation=='modify'&&f_special">修改【{{areamodel.f_residential_area}}】单位</span>
11
+ </div>
12
+ <div v-if="areatype != '楼栋'">
13
+ <!--基本小区(单位)信息-->
14
+ <div class="col-sm-6 form-group" v-if="!config.hasnumber">
15
+ <label class="font_normal_body">小区编号</label>
16
+ <input type="text" class="input_search" style="width:60%" v-model="areamodel.f_area_id"
17
+ @blur="areaidChange" placeholder="小区编号">
18
+ </div>
19
+
20
+ <div class="col-sm-6 form-group" v-if="config.hasnumber"
21
+ :class="[$v.f_area_id.required ? 'has-error' : 'has-success']">
22
+ <label class="font_normal_body">小区编号</label>
23
+ <input type="number" class="input_search" style="width:60%" v-model="areamodel.f_area_id"
24
+ v-validate:f_area_id='{required: true }'
25
+ @change="areaidChangeHasnumber" placeholder="小区编号">
26
+ </div>
27
+
28
+ <div class="col-sm-6 form-group"
29
+ :class="[$v.f_pcd_id.required ? 'has-error' : 'has-success']">
30
+ <label class="font_normal_body">省&ensp;市&ensp;区</label>
31
+ <input type="text" class="input_search" class="input_search" style="width:60%" v-show="false" v-model="areamodel.f_pcd_id"
32
+ v-validate:f_pcd_id='{required: true }'>
33
+ <v-select
34
+ :value.sync="areamodel.f_pcd_id" :value-single="true"
35
+ :options='pcdslist' placeholder='请选择'
36
+ close-on-select search="true" @change="pcdChange">
37
+ </v-select>
38
+ </div>
39
+ <div class="col-sm-6 form-group"
40
+ :class="[$v.f_street_id.required ? 'has-error' : 'has-success']">
41
+ <label class="font_normal_body">街道/乡镇</label>
42
+ <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_street_id"
43
+ v-validate:f_street_id='{required: true }'>
44
+ <v-select
45
+ :value.sync="areamodel.f_street_id" :value-single="true"
46
+ :options='streetslist' placeholder='请选择'
47
+ close-on-select search="true" @change="streetChange">
48
+ </v-select>
49
+ </div>
50
+ <!--小区(特殊)信息-->
51
+ <div v-if="!f_special"
52
+ class="col-sm-6 form-group"
53
+ :class="[$v.f_residential_area.required ? 'has-error' : 'has-success']">
54
+ <label class="font_normal_body">小区名称</label>
55
+ <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_residential_area"
56
+ class="form-control" placeholder="小区名称"
57
+ v-validate:f_residential_area='{required: true }'>
58
+ </div>
59
+ <div v-if="!f_special"
60
+ class="col-sm-12 form-group">
61
+ <label class="font_normal_body">小区地址</label>
62
+ <input type="text" style="width:80%" class="input_search" v-model="areamodel.f_area_address"
63
+ class="form-control" placeholder="小区地址">
64
+ </div>
65
+ <!--单位(特殊)信息-->
66
+ <div v-if="f_special"
67
+ class="col-sm-6 form-group"
68
+ :class="[$v.f_residential_area.required ? 'has-error' : 'has-success']">
69
+ <label class="font_normal_body">单位名称</label>
70
+ <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_residential_area"
71
+ class="form-control" placeholder="单位名称"
72
+ v-validate:f_residential_area='{required: true }'>
73
+ </div>
74
+ <div v-if="f_special"
75
+ class="col-sm-12 form-group">
76
+ <label class="font_normal_body">单位地址</label>
77
+ <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_area_address"
78
+ class="form-control" placeholder="单位地址">
79
+ </div>
80
+ <div v-if="f_special"
81
+ class="col-sm-6 form-group"
82
+ :class="[$v.f_linkname.required ? 'has-error' : 'has-success']">
83
+ <label class="font_normal_body">联&ensp;系&ensp;人</label>
84
+ <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_linkname"
85
+ class="form-control" placeholder="联系人"
86
+ v-validate:f_linkname='{required: true }'>
87
+ </div>
88
+ <div v-if="f_special"
89
+ class="col-sm-6 form-group"
90
+ :class="[$v.f_linkphone.required ? 'has-error' : 'has-success']">
91
+ <label class="font_normal_body">联系电话</label>
92
+ <input type="text" style="width:60%" class="input_search" v-model="areamodel.f_linkphone"
93
+ class="form-control" placeholder="联系电话"
94
+ v-validate:f_linkphone='{required: true }'>
95
+ </div>
96
+ <div class="col-sm-12 form-group">
97
+ <label class="font_normal_body " style="">备&emsp;&emsp;注</label>
98
+ <textarea class="input_textarea" rows="3" style="margin-top:20px;width:80%;height: auto;" v-model="areamodel.f_comments"></textarea>
99
+ </div>
100
+ <div class="col-sm-12 form-group">
101
+ <br/>
102
+ </div>
103
+ <!--表具信息-->
104
+ <div v-if="!f_special" class="col-sm-12 bg-info text-center" style="padding: 8px;font-size: 18px;font-weight: bold">
105
+ <span >默认表具信息</span>
106
+ </div>
107
+ <div v-if="!f_special" class="row">
108
+ <div class="col-sm-6 form-group">
109
+ <label class="font_normal_body">用户类型</label>
110
+ <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_user_type">
111
+ <v-select
112
+ :value.sync="areamodel.f_user_type" :value-single="true"
113
+ :options='usertypes' placeholder='用户类型' @change="userTypeChange"
114
+ close-on-select >
115
+ </v-select>
116
+ </div>
117
+ <div class="col-sm-6 form-group">
118
+ <label class="font_normal_body">用气性质</label>
119
+ <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_gasproperties">
120
+ <v-select
121
+ :value.sync="areamodel.f_gasproperties" :value-single="true"
122
+ :options='gasproperties' placeholder='用气性质'
123
+ close-on-select >
124
+ </v-select>
125
+ </div>
126
+ <div class="col-sm-6 form-group">
127
+ <label class="font_normal_body">气价类型</label>
128
+ <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_price_type">
129
+ <v-select
130
+ :value.sync="areamodel.f_price_type" :value-single="true"
131
+ :options='f_price_types' placeholder='气价类型'
132
+ close-on-select >
133
+ </v-select>
134
+ </div>
135
+ <div class="col-sm-6 form-group">
136
+ <label class="font_normal_body">气价名称</label>
137
+ <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_price_name">
138
+ <v-select
139
+ :value.sync="areamodel.f_price_name" :value-single="true"
140
+ :options='pricenames' placeholder='气价名称'
141
+ close-on-select >
142
+ </v-select>
143
+ </div>
144
+ <div class="col-sm-6 form-group">
145
+ <label class="font_normal_body">气表品牌</label>
146
+ <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_meter_brand">
147
+ <v-select
148
+ :value.sync="areamodel.f_meter_brand" :value-single="true"
149
+ :options='meterbrands' placeholder='气表品牌'
150
+ close-on-select >
151
+ </v-select>
152
+ </div>
153
+ <div class="col-sm-6 form-group">
154
+ <label class="font_normal_body">气表型号</label>
155
+ <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_meter_style">
156
+ <v-select
157
+ :value.sync="areamodel.f_meter_style" :value-single="true"
158
+ :options='meterstyle' placeholder='气表型号'
159
+ close-on-select >
160
+ </v-select>
161
+ </div>
162
+ <div class="col-sm-6 form-group" :class="[$v.f_meter_type.required ? 'has-error' : 'has-success']">
163
+ <label class="font_normal_body">气表类型</label>
164
+ <input type="text" style="width:60%" class="input_search" v-show="false"
165
+ v-model="areamodel.f_meter_type">
166
+ <v-select :value.sync="areamodel.f_meter_type" :value-single="true"
167
+ :options='metertypes' placeholder='请选择'
168
+ close-on-select></v-select>
169
+ </div>
170
+ <div class="col-sm-6 form-group" v-if="isMachine">
171
+ <label class="font_normal_body">抄&ensp;表&ensp;册</label>
172
+ <input type="text" style="width:60%" class="input_search" v-show="false"
173
+ v-model="areamodel.f_meter_book">
174
+ <v-select
175
+ :value.sync="areamodel.f_meter_book" :value-single="true"
176
+ :options='meterbooks' placeholder='抄表册'
177
+ close-on-select >
178
+ </v-select>
179
+ </div>
180
+ <div class="col-sm-6 form-group" v-if="!isMachine" :class="[$v.f_meter_book.required ? 'has-error' : 'has-success']">
181
+ <label class="font_normal_body">抄&ensp;表&ensp;册</label>
182
+ <input type="text" style="width:60%" class="input_search" v-show="false"
183
+ v-model="areamodel.f_meter_book">
184
+ <v-select
185
+ :value.sync="areamodel.f_meter_book" :value-single="true"
186
+ :options='meterbooks' placeholder='抄表册'
187
+ close-on-select >
188
+ </v-select>
189
+ </div>
190
+ <div class="col-sm-6 form-group" :class="[$v.f_inputtor.required ? 'has-error' : 'has-success']">
191
+ <label class="font_normal_body">抄&ensp;表&ensp;员</label>
192
+ <input type="text" style="width:60%" class="input_search"
193
+ v-show="false" v-model="areamodel.f_inputtor">
194
+ <v-select
195
+ :value.sync="areamodel.f_inputtor" :value-single="true"
196
+ :options='inputtores' placeholder='抄表员'
197
+ close-on-select >
198
+ </v-select>
199
+ </div>
200
+ <div class="col-sm-6 form-group" :class="[$v.f_adjustable_id.required ? 'has-error' : 'has-success']">
201
+ <label class="font_normal_body">调&ensp;压&ensp;箱</label>
202
+ <input type="text" style="width:60%" class="input_search" v-show="false"
203
+ v-model="areamodel.f_adjustable_id">
204
+ <v-select
205
+ :value.sync="areamodel.f_adjustable_id" :value-single="true"
206
+ :options='adjustables' placeholder='调压箱'
207
+ close-on-select >
208
+ </v-select>
209
+ </div>
210
+ <div class="col-sm-6 form-group" :class="[$v.f_house_type.required ? 'has-error' : 'has-success']">
211
+ <label class="font_normal_body">房屋类型</label>
212
+ <input type="text" style="width:60%" class="input_search" v-show="false"
213
+ v-model="areamodel.f_house_type" >
214
+ <v-select
215
+ :value.sync="areamodel.f_house_type" :value-single="true"
216
+ :options='housetypeoptions' placeholder='房屋类型'
217
+ close-on-select >
218
+ </v-select>
219
+ </div>
220
+ <div class="col-sm-6 form-group" :class="[$v.f_position.required ? 'has-error' : 'has-success']">
221
+ <label class="font_normal_body">安装位置</label>
222
+ <input type="text" style="width:60%" class="input_search" v-show="false" v-model="areamodel.f_position" >
223
+ <v-select
224
+ :value.sync="areamodel.f_position" :value-single="true"
225
+ :options='positions' placeholder='安装位置'
226
+ close-on-select >
227
+ </v-select>
228
+ </div>
229
+ </div>
230
+ <div v-if="f_special" class="col-sm-6 form-group">
231
+ <br/>
232
+ </div>
233
+ </div>
234
+ <div v-if="areatype == '楼栋'">
235
+ <div class="col-sm-6 form-group " :class="[$v.f_residential_area_id1.required ? 'has-error' : 'has-success']">
236
+ <label class="font_normal_body">小区名称</label>
237
+ <input type="text" style="width:41%" v-show="false" v-model="buildingmodel.f_residential_area_id"
238
+ v-validate:f_residential_area_id1='{required: true }'>
239
+ <v-select :value.sync="buildingmodel.f_residential_area_id" :value-single="true" v-ref:areaselect
240
+ :options='areaslist' placeholder='请选择'
241
+ close-on-select search="true">
242
+ </v-select>
243
+ </div>
244
+ <div class="col-sm-6 form-group" :class="[$v.f_building.required ? 'has-error' : 'has-success']">
245
+ <label class="font_normal_body">楼栋名称</label>
246
+ <input type="text" class="input_search" style="width:60%" v-validate:f_building='{required: true }'
247
+ v-model="buildingmodel.f_building" placeholder="楼栋名称">
248
+ </div>
249
+ </div>
250
+ </div>
251
+ <div class="row auto" style="text-align:right;">
252
+ <button class="button_search button_spacing" @click="confirm()" :disabled='!$v.valid'>保存</button>
253
+ <button class="button_clear button_spacing" @click="cancel()">取消</button>
254
+ </div>
255
+ <div v-if="areatype == '楼栋'" class="row" style="margin-top:40px;height: 580px;">
256
+ <building-list v-ref:buildinglist @select-changed="selected" :areaslist="areaslist" :f_filialeids.sync="f_filialeids"></building-list>
257
+ </div>
258
+ </div>
259
+ </validator>
260
+ </div>
261
+ </template>
262
+
263
+ <script>
264
+ import {HttpResetClass} from 'vue-client'
265
+
266
+ let initGen = async function (self) {
267
+ await self.$getConfig(self, 'UserArea')
268
+ console.log('原地址配置',self.config)
269
+ console.log('获取地址配置',self.config)
270
+ // Object.assign(self.model, self.config)
271
+ await self.initdata()
272
+ await self.$LoadParams.loadMeterBook(self.f_filialeids)
273
+ await self.loadMeterBooks();
274
+ }
275
+ export default {
276
+ title: '小区添加',
277
+ data () {
278
+ return {
279
+ config:{
280
+ hasnumber:false,
281
+ },
282
+ //初始化省市区数据
283
+ pcdslist:[],
284
+ //初始化街道数据
285
+ streetslist:[],
286
+ //小区
287
+ areamodel: {
288
+ f_area_id: '',
289
+ f_pcd_id:'',
290
+ f_linkname:'',
291
+ f_linkphone:'',
292
+ f_street_id:'',
293
+ f_slice_area:'',
294
+ f_adjustable_id:'',
295
+ f_residential_area:'',
296
+ f_user_type:'',
297
+ f_gasproperties:'',
298
+ f_meter_brand:'',
299
+ f_price_name:'',
300
+ f_area_address:'',
301
+ f_price_type:'',
302
+ f_meter_style:'',
303
+ f_position:'',
304
+ f_comments:'',
305
+ f_meter_type: ''
306
+ },
307
+ // 初始化小区数据
308
+ areaslist:[],
309
+ // 楼栋
310
+ buildingmodel: {
311
+ f_residential_area: '',
312
+ f_residential_area_id: '',
313
+ f_building: ''
314
+ },
315
+ meterbrands: [],
316
+ adjustables: [],
317
+ sliceArea: [],
318
+ gasproperties: [],
319
+ meterbooks:[{label: '全部',value: ''}],
320
+ housetypeoptions:[{label: '楼房', value: '楼房'}, {label: '自建房', value: '自建房'}],
321
+ isMachine: true
322
+ }
323
+ },
324
+ props: ['f_filialeids','f_special', 'areatype','row','operation'],
325
+ ready(){
326
+ initGen(this)
327
+ },
328
+ methods: {
329
+ loadMeterBooks(){
330
+ this.meterbooks = [...this.meterbooks, ...this.$GetSaleParam.getMeterBooks()]
331
+ },
332
+ //初始化数据
333
+ async initdata(){
334
+ // 初始化参数
335
+ await this.initParams()
336
+ if (this.areatype == '楼栋') {
337
+ this.initareas(` f_orgid = '${this.f_filialeids}'`)
338
+ }
339
+ // 初始化片区
340
+ await this.initSlice(this.f_filialeids)
341
+ await this.initpcds(` f_filialeid = '${this.f_filialeids}'`)
342
+ },
343
+ initrow(val){
344
+ this.areamodel.f_meter_book = val.f_meter_book;
345
+ this.areamodel.f_adjustable_id = val.f_adjustable_id;
346
+ },
347
+ async initParams() {
348
+ await this.$LoadParams.loadParam(this.f_filialeids)
349
+ this.initBrands()
350
+ this.initAdjustables()
351
+ },
352
+
353
+ initBrands () {
354
+ let ret = this.$GetSaleParam.getGasbrand()
355
+ let rs = new Array()
356
+ ret.forEach((item, index) =>{
357
+ rs.push({label: item.label, value: item.value.f_meter_brand})
358
+ })
359
+ this.meterbrands = rs
360
+ },
361
+
362
+ initAdjustables () {
363
+ let filter = this.$login.f.orgid
364
+ let ret = this.$GetSaleParam.getAdjustable(filter)
365
+ let arr = new Array()
366
+ ret.forEach((item, index) => {
367
+ arr.push({label: `[${item.value.f_adjustable_id}]-${item.label}`, value: item.value.id})
368
+ })
369
+ this.adjustables = arr
370
+ },
371
+
372
+ async initSlice (val) {
373
+ if (val) {
374
+ let getAllArea = await this.$resetpost('/rs/search', {
375
+ source: 'this.getParentByType($organization$).getAllChildrens().where(row.getType() == $zone$)',
376
+ userid: this.$login.f.id
377
+ }, {resolveMsg: null, rejectMsg: '获取片区出错!!!'})
378
+
379
+ let arr = getAllArea.data.filter((res) => {
380
+ return res.parentid == val
381
+ })
382
+ this.sliceArea = []
383
+ arr.forEach((res) => {
384
+ this.sliceArea.push({label: res.name, value: {name: res.name, code:res.number}})
385
+ })
386
+ }
387
+ },
388
+ //初始化小区添加小区
389
+ async initareas(pconditon){
390
+ // if(this.usertype){
391
+ // pconditon=pconditon+` and f_special='1' `
392
+ // }
393
+ this.areaslist = []
394
+ let HttpReset = new HttpResetClass()
395
+ let req = await HttpReset.load('POST', 'api/af-revenue/sql/address_singleTableOrderBy?pageNo=1&pageSize=9999999', {
396
+ data: {
397
+ items: '*',
398
+ tablename: 't_area',
399
+ orderitem: 'id',
400
+ condition: pconditon
401
+ }
402
+ }, {resolveMsg: null, rejectMsg: '获取地址失败!'})
403
+ let redata = []
404
+ req.data.forEach((row) => {
405
+ redata.push({
406
+ label: '['+row.f_street+']'+row.f_residential_area,
407
+ value: row.id,
408
+ data: row,
409
+ id: row.id
410
+ })
411
+ })
412
+ this.areaslist=redata
413
+ },
414
+
415
+ //初始化省市区,添加街道
416
+ async initpcds(pconditon){
417
+ this.pcdslist = []
418
+ let HttpReset = new HttpResetClass()
419
+ let req = await HttpReset.load('POST', 'api/af-revenue/sql/address_singleTableOrderBy', {
420
+ data: {
421
+ items: '*',
422
+ tablename: 't_pcd',
423
+ orderitem: 'id',
424
+ condition: pconditon
425
+ }
426
+ }, {resolveMsg: null, rejectMsg: '获取地址失败!'})
427
+ let redata = []
428
+ req.data.forEach((row, n) => {
429
+ redata[n] = {
430
+ label: row.f_pcd,
431
+ value: row.id,
432
+ data:row,
433
+ id:row.id
434
+ }
435
+ })
436
+ this.pcdslist=redata
437
+
438
+ },
439
+ //初始化街道 添加小区
440
+ async initstreets(pconditon){
441
+ this.streetslist = []
442
+ let HttpReset = new HttpResetClass()
443
+ let req = await HttpReset.load('POST', 'api/af-revenue/sql/address_singleTableOrderBy', {
444
+ data: {
445
+ items: '*',
446
+ tablename: 't_street',
447
+ orderitem: 'id',
448
+ condition: pconditon
449
+ }
450
+ }, {resolveMsg: null, rejectMsg: '获取地址失败!'})
451
+ let redata = []
452
+ req.data.forEach((row, n) => {
453
+ redata[n] = {
454
+ label: row.f_street,
455
+ value: row.id,
456
+ data:row,
457
+ id:row.id
458
+ }
459
+ })
460
+ this.streetslist=redata
461
+ },
462
+ async areaidChangeHasnumber(){
463
+ console.log(this.areamodel.f_area_id.length)
464
+ if (this.areamodel.f_area_id.length != 2){
465
+ this.$showAlert('请输入正确的位数', 'warning', 2000)
466
+ this.areamodel.f_area_id = ''
467
+ }else{
468
+ let res =await this.$resetpost('api/af-revenue/sql/address_singleTableOrderBy', {
469
+ data: {
470
+ items: '*',
471
+ tablename: 't_area',
472
+ orderitem: 'id',
473
+ condition: `f_area_id = '${this.areamodel.f_area_id}' and f_orgid = '${this.$login.f.orgid}'`
474
+ }
475
+ }, {resolveMsg: null, rejectMsg: null})
476
+ if (res.data.length>0){
477
+ if (res.data[0].id != this.areamodel.id) {
478
+ this.$showAlert('当前编号已存在', 'warning', 2000)
479
+ this.areamodel.f_area_id = ''
480
+ }
481
+ }
482
+ }
483
+ },
484
+ async areaidChange () {
485
+ // 验证小区编号是否已存在
486
+
487
+ let param = {
488
+ id: this.areamodel.id,
489
+ f_area_id: this.areamodel.f_area_id,
490
+ f_filialeid: this.f_filialeids
491
+ }
492
+
493
+ let res = await this.$resetpost('api/af-revenue/logic/address_validateAreaID', param, {resolveMsg: null,rejectMsg: '小区编号验证失败!!'})
494
+ console.log('验证小区是否存在', res)
495
+ if (res.data) {
496
+ this.$showAlert('这个小区编号已存在!!!请核实', 'warning', 3000)
497
+ this.areamodel.f_area_id = ''
498
+ }
499
+
500
+ },
501
+
502
+
503
+ //根据名字找数据
504
+ findbyid(list,name){
505
+ var result
506
+ list.forEach((row, n) => {
507
+ if(name==row.id){
508
+ result= row.data
509
+ }
510
+ })
511
+ return result
512
+ },
513
+ userTypeChange () {
514
+ this.gasproperties = []
515
+ if (this.areamodel.f_user_type) {
516
+ this.gasproperties = this.$appdata.getParam(this.areamodel.f_user_type)
517
+ }
518
+ },
519
+
520
+ //省/市/区变化
521
+ async pcdChange(val){
522
+ if(val){
523
+ //那就把街道数据重新组织一下
524
+ await this.initstreets(` f_filialeid = '${this.f_filialeids}' and f_pcd_id ='${val}' `)
525
+ if(this.areamodel.f_street_id){
526
+ if (this.findbyid(this.streetslist,this.areamodel.f_street_id)) {
527
+ let pcd_id=this.findbyid(this.streetslist,this.areamodel.f_street_id).f_pcd_id
528
+ if(pcd_id!=val){
529
+ this.areamodel.f_street_id=''
530
+ }
531
+ } else {
532
+ this.areamodel.f_street_id=''
533
+ }
534
+
535
+ }
536
+ }
537
+ this.$resetValidation()
538
+ },
539
+ //街道变化
540
+ streetChange(val){
541
+ if(val&&this.operation=='add'){
542
+ // if(this.areamodel.f_pcd_id.length==0){
543
+ if (this.findbyid(this.streetslist,this.areamodel.f_street_id)) {
544
+ this.areamodel.f_pcd_id=this.findbyid(this.streetslist,this.areamodel.f_street_id).f_pcd_id
545
+ }
546
+ // }
547
+ }
548
+ this.$resetValidation()
549
+ },
550
+ //保存
551
+ async confirm(){
552
+ if(this.areatype=='楼栋'){
553
+ await this.savebuilding()
554
+ } else {
555
+ await this.savearea()
556
+ this.cleardara()
557
+ this.$dispatch('confirm')
558
+ }
559
+ },
560
+ // 保存楼栋
561
+ async savebuilding () {
562
+ this.buildingmodel.f_residential_area = this.$refs.areaselect.selectedItems
563
+ this.buildingmodel.f_filialeid = this.f_filialeids
564
+ this.buildingmodel.f_operator = this.$login.f.name
565
+ this.buildingmodel.f_operatorid = this.$login.f.id
566
+ this.buildingmodel.f_orgid = this.$login.f.orgid
567
+ this.buildingmodel.f_orgname = this.$login.f.orgs
568
+ this.buildingmodel.f_depid = this.$login.f.depids
569
+ this.buildingmodel.f_depname = this.$login.f.deps
570
+ await this.$resetpost('api/af-revenue/logic/address_savebuilding', this.buildingmodel)
571
+ this.$refs.buildinglist.search()
572
+ },
573
+ //保存小区
574
+ async savearea(){
575
+ if(this.f_special){
576
+ this.areamodel.f_special='1'
577
+ }
578
+ this.areamodel.f_filialeid = this.f_filialeids
579
+ this.areamodel.f_operator = this.$login.f.name
580
+ this.areamodel.f_operatorid = this.$login.f.id
581
+ this.areamodel.f_orgid = this.$login.f.orgid
582
+ this.areamodel.f_orgname = this.$login.f.orgs
583
+ this.areamodel.f_depid = this.$login.f.depids
584
+ this.areamodel.f_depname = this.$login.f.deps
585
+ if (this.areamodel.slice_area) {
586
+ if (this.areamodel.slice_area.length > 0) {
587
+ this.areamodel.f_slice_area = this.areamodel.slice_area[0].name
588
+ this.areamodel.f_area_code = this.areamodel.slice_area[0].code
589
+ }
590
+ }
591
+ this.areamodel.f_pcd=this.findbyid(this.pcdslist,this.areamodel.f_pcd_id).f_pcd
592
+ this.areamodel.f_street=this.findbyid(this.streetslist,this.areamodel.f_street_id).f_street
593
+
594
+ await this.$resetpost('api/af-revenue/logic/address_updatearea', this.areamodel)
595
+ },
596
+ cleardara(){
597
+ this.areamodel= {
598
+ f_area_id: '',
599
+ f_pcd_id:'',
600
+ f_street_id:'',
601
+ f_slice_area:'',
602
+ f_linkname:'',
603
+ f_linkphone:'',
604
+ f_adjustable_id:'',
605
+ f_residential_area:'',
606
+ f_user_type:'',
607
+ f_gasproperties:'',
608
+ f_area_address:'',
609
+ f_meter_brand:'',
610
+ f_price_name:'',
611
+ f_price_type:'',
612
+ f_meter_style:'',
613
+ f_position:'',
614
+ f_comments:'',
615
+ f_meter_type: ''
616
+ }
617
+ },
618
+ cancel(){
619
+ this.cleardara()
620
+ this.$dispatch('cancel')
621
+ },
622
+ },
623
+ watch: {
624
+ 'areamodel.f_meter_type' (val) {
625
+ if (val === '机表')
626
+ this.isMachine = false
627
+ },
628
+ 'areatype'(){
629
+ this.initdata()
630
+ },
631
+ 'areamodel.f_pcd_id'(){
632
+ if(this.areamodel.f_pcd_id&&this.areamodel.f_street_id){
633
+ if (this.findbyid(this.pcdslist,this.areamodel.f_pcd_id) && this.findbyid(this.streetslist,this.areamodel.f_street_id)) {
634
+ this.areamodel.f_area_address = this.findbyid(this.pcdslist,this.areamodel.f_pcd_id).f_pcd + this.findbyid(this.streetslist,this.areamodel.f_street_id).f_street
635
+ }
636
+ }
637
+ },
638
+ 'areamodel.f_street_id'(){
639
+ if (this.areamodel.f_pcd_id && this.areamodel.f_street_id) {
640
+ if (this.findbyid(this.pcdslist, this.areamodel.f_pcd_id) && this.findbyid(this.streetslist, this.areamodel.f_street_id)) {
641
+ this.areamodel.f_area_address = this.findbyid(this.pcdslist, this.areamodel.f_pcd_id).f_pcd + this.findbyid(this.streetslist, this.areamodel.f_street_id).f_street
642
+ }
643
+ }
644
+ },
645
+ 'f_filialeids'(){
646
+ if (this.areamodel.f_filialeid) {
647
+ if (this.areamodel.f_filialeid != this.f_filialeids) {
648
+ this.$dispatch('cancel')
649
+ }
650
+ }
651
+ this.cleardara()
652
+ this.initdata()
653
+ }
654
+ },
655
+ computed: {
656
+ metertypes() {
657
+ return this.$appdata.getParam('气表类型')
658
+ },
659
+ usertypes () {
660
+ return this.$appdata.getParam('用户类型')
661
+ },
662
+ f_price_types () {
663
+ return this.$appdata.getParam('气价类型')
664
+ },
665
+ meterstyle () {
666
+ let ret = this.$GetSaleParam.getGasbrand()
667
+ let rs = new Array()
668
+ if(this.areamodel.f_meter_brand) {
669
+ ret.forEach((item, index) => {
670
+ if(this.areamodel.f_meter_brand == item.value.f_meter_brand) {
671
+ item.value.gasmodel.forEach((item1, index) =>{
672
+ rs.push({label: item1.label, value:item1.label})
673
+ })
674
+ }
675
+ })
676
+ }
677
+ return rs
678
+ },
679
+ pricenames () {
680
+ let rs = new Array()
681
+ if (this.areamodel.f_user_type && this.areamodel.f_gasproperties && this.areamodel.f_price_type) {
682
+ let params = {
683
+ f_user_type: this.areamodel.f_user_type,
684
+ f_gasproperties: this.areamodel.f_gasproperties,
685
+ f_price_type: this.areamodel.f_price_type,
686
+ filter: this.f_filialeids
687
+ }
688
+ let ret = this.$GetSaleParam.getPrice(params)
689
+ ret.forEach((item, index) => {
690
+ rs.push({label: item.label, value: item.value.f_price_name})
691
+ })
692
+ }
693
+ if (rs.length == 0) {
694
+ this.areamodel.f_price_name = ''
695
+ }
696
+ return rs
697
+ },
698
+ positions () {
699
+ return this.$appdata.getParam('安装位置')
700
+ },
701
+ inputtores () {
702
+ // 获取抄表员
703
+ let rs = new Array()
704
+ if (this.$login.f.f_gasman.length > 0) {
705
+ for (let i = 0; i < this.$login.f.f_gasman.length; i++) {
706
+ let temp = {
707
+ label: this.$login.f.f_gasman[i].name,
708
+ value: this.$login.f.f_gasman[i].name
709
+ }
710
+ rs.push(temp)
711
+ }
712
+ }
713
+ return rs
714
+ }
715
+ }
716
+ }
717
+ </script>
718
+ <style>
719
+ .box {
720
+ width: 727px;
721
+ height: 175px;
722
+ border-radius: 2px;
723
+ background-color: #fafafa;
724
+ border: 1px solid #999999;
725
+ margin-top: 13px;
726
+ }
727
+ .datapanel {
728
+ color: #333;
729
+ background-color: white;
730
+ box-shadow: darkgrey 0.5px 0.5px 0.5px 0.5px ;
731
+ padding: 10px 30px 10px 30px;
732
+ border-radius:15px;
733
+ }
734
+ </style>