vue2-client 1.8.259 → 1.8.261

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 (210) hide show
  1. package/.env +19 -19
  2. package/.eslintrc.js +90 -90
  3. package/CHANGELOG.md +824 -824
  4. package/Components.md +60 -60
  5. package/babel.config.js +21 -21
  6. package/docs/index.md +30 -30
  7. package/docs/lowcode.md +188 -188
  8. package/docs/lowcodeForDeveloper.md +200 -192
  9. package/index.js +31 -31
  10. package/jest-transform-stub.js +8 -8
  11. package/jest.config.js +21 -21
  12. package/jest.setup.js +7 -7
  13. package/package.json +95 -95
  14. package/public/index.html +27 -27
  15. package/src/App.vue +188 -188
  16. package/src/ReportView.js +19 -19
  17. package/src/assets/img/querySlotDemo.svg +15 -15
  18. package/src/assets/svg/badtwo.svg +1 -1
  19. package/src/assets/svg/goodtwo.svg +1 -1
  20. package/src/base-client/components/common/AMisRender/index.js +3 -3
  21. package/src/base-client/components/common/AMisRender/index.vue +263 -263
  22. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +413 -413
  23. package/src/base-client/components/common/AddressSearchCombobox/demo.vue +36 -36
  24. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  25. package/src/base-client/components/common/CitySelect/CitySelect.vue +348 -348
  26. package/src/base-client/components/common/CitySelect/index.js +3 -3
  27. package/src/base-client/components/common/CitySelect/index.md +109 -109
  28. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  29. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +1014 -1014
  30. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  31. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  32. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +452 -452
  33. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +511 -511
  34. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  35. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  36. package/src/base-client/components/common/FormGroupEdit/FormGroupEdit.vue +149 -149
  37. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  38. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  39. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  40. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  41. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  42. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  43. package/src/base-client/components/common/LowCodeComponent/LowCodePageOrganization.vue +394 -355
  44. package/src/base-client/components/common/LowCodePageRender/LowCodePageRender.vue +29 -29
  45. package/src/base-client/components/common/LowCodePageRender/editorPageRender.vue +533 -467
  46. package/src/base-client/components/common/LowCodePageRender/index.js +3 -3
  47. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  48. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  49. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  50. package/src/base-client/components/common/Tree/index.js +2 -2
  51. package/src/base-client/components/common/Upload/Upload.vue +197 -197
  52. package/src/base-client/components/common/Upload/index.js +3 -3
  53. package/src/base-client/components/common/XAddForm/XAddForm.vue +98 -98
  54. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +732 -732
  55. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  56. package/src/base-client/components/common/XAddNativeForm/lowcodeEditorRegister.js +16 -12
  57. package/src/base-client/components/common/XAddNativeFormOA/XAddNativeFormOA.vue +303 -303
  58. package/src/base-client/components/common/XAddNativeFormOA/index.js +3 -3
  59. package/src/base-client/components/common/XAddNativeFormOA/index.md +146 -146
  60. package/src/base-client/components/common/XBadge/XBadge.vue +78 -78
  61. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  62. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  63. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  64. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  65. package/src/base-client/components/common/XDescriptions/XDescriptions.vue +167 -167
  66. package/src/base-client/components/common/XDescriptions/XDescriptionsGroup.vue +299 -299
  67. package/src/base-client/components/common/XDescriptions/demo.vue +50 -50
  68. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  69. package/src/base-client/components/common/XDescriptions/index.md +83 -83
  70. package/src/base-client/components/common/XDescriptions/lowcodeEditorRegister.js +15 -5
  71. package/src/base-client/components/common/XDetailsView/XDetailsView.vue +214 -214
  72. package/src/base-client/components/common/XDetailsView/index.js +3 -3
  73. package/src/base-client/components/common/XForm/XForm.vue +281 -281
  74. package/src/base-client/components/common/XForm/XFormItem.vue +807 -807
  75. package/src/base-client/components/common/XForm/XTreeSelect.vue +206 -206
  76. package/src/base-client/components/common/XForm/index.md +178 -178
  77. package/src/base-client/components/common/XFormCol/XFormCol.vue +36 -36
  78. package/src/base-client/components/common/XFormGroup/XFormGroup.vue +241 -241
  79. package/src/base-client/components/common/XFormGroup/demo.vue +40 -40
  80. package/src/base-client/components/common/XFormGroup/index.js +3 -3
  81. package/src/base-client/components/common/XFormGroup/index.md +38 -38
  82. package/src/base-client/components/common/XFormGroupDetails/XFormGroupDetails.vue +72 -72
  83. package/src/base-client/components/common/XFormGroupDetails/index.js +3 -3
  84. package/src/base-client/components/common/XFormTable/XFormTable.vue +519 -519
  85. package/src/base-client/components/common/XFormTable/index.md +98 -98
  86. package/src/base-client/components/common/XFormTable/lowcodeEditorRegister.js +16 -12
  87. package/src/base-client/components/common/XImportExcel/XImportExcel.vue +147 -147
  88. package/src/base-client/components/common/XReport/XReport.vue +843 -843
  89. package/src/base-client/components/common/XReport/XReportDemo.vue +2233 -2233
  90. package/src/base-client/components/common/XReport/XReportDesign.vue +470 -470
  91. package/src/base-client/components/common/XReport/XReportJsonRender.vue +267 -267
  92. package/src/base-client/components/common/XReport/XReportTrGroup.vue +745 -742
  93. package/src/base-client/components/common/XReport/index.js +3 -3
  94. package/src/base-client/components/common/XReport/index.md +44 -44
  95. package/src/base-client/components/common/XReportSlot/XReportSlot.vue +110 -110
  96. package/src/base-client/components/common/XReportSlot/index.js +3 -3
  97. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  98. package/src/base-client/components/common/XStepView/index.js +3 -3
  99. package/src/base-client/components/common/XStepView/index.md +31 -31
  100. package/src/base-client/components/common/XTable/XTable.vue +636 -636
  101. package/src/base-client/components/common/XTable/index.md +255 -255
  102. package/src/base-client/components/common/XTree/XTree.vue +318 -318
  103. package/src/base-client/components/common/XTree/index.js +3 -3
  104. package/src/base-client/components/common/XTree/index.md +36 -36
  105. package/src/base-client/components/common/XTreeOne/XTreeOne.vue +114 -114
  106. package/src/base-client/components/common/XTreeOne/lowcodeEditorRegister.js +11 -9
  107. package/src/base-client/components/index.js +51 -51
  108. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  109. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  110. package/src/base-client/plugins/AppData.js +115 -115
  111. package/src/base-client/plugins/Config.js +19 -19
  112. package/src/base-client/plugins/GetLoginInfoService.js +183 -183
  113. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  114. package/src/bootstrap.js +39 -39
  115. package/src/components/CodeMirror/inedx.vue +118 -118
  116. package/src/components/CodeMirror/setting.js +40 -40
  117. package/src/components/FilePreview/FilePreview.vue +166 -166
  118. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  119. package/src/components/STable/index.js +323 -323
  120. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  121. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  122. package/src/components/menu/SideMenu.vue +75 -75
  123. package/src/components/menu/menu.js +273 -273
  124. package/src/components/tool/AStepItem.vue +60 -60
  125. package/src/config/CreateQueryConfig.js +322 -322
  126. package/src/config/default/antd.config.js +89 -89
  127. package/src/config/default/setting.config.js +55 -55
  128. package/src/font-style/font.css +4 -4
  129. package/src/layouts/CommonLayout.vue +56 -56
  130. package/src/layouts/PageLayout.vue +151 -151
  131. package/src/layouts/SinglePageView.vue +138 -138
  132. package/src/layouts/header/AdminHeader.vue +132 -132
  133. package/src/layouts/header/HeaderNotice.vue +177 -177
  134. package/src/layouts/tabs/TabsHead.vue +189 -189
  135. package/src/layouts/tabs/TabsView.vue +387 -387
  136. package/src/lib.js +1 -1
  137. package/src/main.js +26 -26
  138. package/src/mock/extend/index.js +84 -84
  139. package/src/mock/goods/index.js +108 -108
  140. package/src/pages/AMisDemo/AMisDemo.vue +325 -325
  141. package/src/pages/AMisDemo/AMisDemo2.vue +74 -74
  142. package/src/pages/DynamicStatistics/ChartSelector.vue +331 -331
  143. package/src/pages/DynamicStatistics/DataTabs.vue +83 -83
  144. package/src/pages/DynamicStatistics/DynamicTable.vue +128 -128
  145. package/src/pages/DynamicStatistics/EvaluationArea.vue +69 -69
  146. package/src/pages/DynamicStatistics/FavoriteList.vue +51 -51
  147. package/src/pages/DynamicStatistics/QuestionHistoryAndFavorites.vue +591 -591
  148. package/src/pages/DynamicStatistics/SearchBar.vue +192 -192
  149. package/src/pages/DynamicStatistics/index.vue +282 -282
  150. package/src/pages/Example/index.vue +32 -32
  151. package/src/pages/NewDynamicStatistics/ChartSelector.vue +331 -331
  152. package/src/pages/NewDynamicStatistics/DataTabs.vue +122 -122
  153. package/src/pages/NewDynamicStatistics/DynamicTable.vue +128 -128
  154. package/src/pages/NewDynamicStatistics/EvaluationArea.vue +69 -69
  155. package/src/pages/NewDynamicStatistics/FavoriteList.vue +51 -51
  156. package/src/pages/NewDynamicStatistics/QuestionHistoryAndFavorites.vue +289 -289
  157. package/src/pages/NewDynamicStatistics/SearchBar.vue +193 -193
  158. package/src/pages/NewDynamicStatistics/index.vue +258 -258
  159. package/src/pages/ServiceReview/index.vue +284 -284
  160. package/src/pages/XReportView/index.vue +62 -62
  161. package/src/pages/login/Login.vue +378 -378
  162. package/src/pages/login/LoginV3.vue +389 -389
  163. package/src/pages/lowCode/lowCodeEditor.vue +1501 -1285
  164. package/src/pages/lowCode/lowCodeRender.vue +39 -39
  165. package/src/pages/resourceManage/orgListManage.vue +98 -98
  166. package/src/pages/system/dictionary/index.vue +44 -44
  167. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  168. package/src/pages/system/monitor/operLog/index.vue +37 -37
  169. package/src/pages/system/settings/modifyPassword.vue +117 -117
  170. package/src/pages/system/ticket/index.vue +480 -480
  171. package/src/pages/system/ticket/submitTicketSuccess.vue +484 -484
  172. package/src/router/async/config.async.js +33 -33
  173. package/src/router/async/router.map.js +107 -107
  174. package/src/router/guards.js +220 -220
  175. package/src/router/index.js +27 -27
  176. package/src/router.js +19 -19
  177. package/src/services/api/TicketDetailsViewApi.js +46 -46
  178. package/src/services/api/cas.js +79 -79
  179. package/src/services/api/common.js +284 -284
  180. package/src/services/api/entity.js +18 -18
  181. package/src/services/api/index.js +17 -17
  182. package/src/services/api/restTools.js +46 -46
  183. package/src/services/apiService.js +14 -14
  184. package/src/services/user.js +71 -71
  185. package/src/store/modules/setting.js +119 -119
  186. package/src/theme/default/style.less +57 -57
  187. package/src/theme/global.less +130 -130
  188. package/src/utils/authority-utils.js +85 -85
  189. package/src/utils/errorCode.js +6 -6
  190. package/src/utils/htmlToPDF.js +108 -108
  191. package/src/utils/htmlToPDFApi.js +5 -5
  192. package/src/utils/indexedDB.js +201 -201
  193. package/src/utils/login.js +144 -144
  194. package/src/utils/lowcode/lowcodeComponentMixin.js +112 -78
  195. package/src/utils/lowcode/lowcodeLog.js +29 -29
  196. package/src/utils/lowcode/lowcodeUtils.js +276 -129
  197. package/src/utils/lowcode/registerComponentForEditor.js +11 -11
  198. package/src/utils/lowcode/registerComponentForRender.js +11 -11
  199. package/src/utils/map-utils.js +47 -47
  200. package/src/utils/reg.js +19 -19
  201. package/src/utils/request.js +343 -343
  202. package/src/utils/routerUtil.js +435 -435
  203. package/src/utils/runEvalFunction.js +6 -6
  204. package/src/utils/util.js +241 -241
  205. package/src/utils/waterMark.js +31 -31
  206. package/test/Amis.spec.js +163 -163
  207. package/test/Tree.spec.js +167 -167
  208. package/test/myDialog.spec.js +46 -46
  209. package/vue.config.js +177 -177
  210. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,413 +1,413 @@
1
- <template>
2
- <div id="addressSearchCombobox">
3
- <div>
4
- <a-input-group
5
- style="display: flex; width: 100%;"
6
- compact>
7
- <a-input
8
- v-model="addressInput"
9
- :read-only="readOnly || !this.addressObj.address"
10
- @change="change"
11
- style="flex: 1; width: auto; min-width: 0;"
12
- placeholder="请选择地址信息"/>
13
- <a-button
14
- v-if="attr?.inputOnAfterName && attr?.inputOnAfterFunc"
15
- style="flex: 1; width: auto; min-width: 4rem;max-width: 6rem"
16
- type="primary"
17
- @click="emitFunc(attr?.inputOnAfterFunc,addressInput)">
18
- {{ attr?.inputOnAfterName }}
19
- </a-button>
20
- <!-- 默认展示该图标 如果配置了按钮插槽展示 primary 央视 -->
21
- <a-button
22
- style="width: 2rem; flex-shrink: 0;"
23
- :type="attr?.inputOnAfterName ? 'primary' :''"
24
- icon="environment"
25
- @click="visible=true">
26
- </a-button>
27
- </a-input-group>
28
- </div>
29
- <a-modal
30
- v-model="visible"
31
- title="地址选择"
32
- @ok="selected"
33
- :zIndex="m_index"
34
- :destroyOnClose="true">
35
- <div class="certain-category-search-wrapper">
36
- <a-auto-complete
37
- style="right: 0px;width: 90%;z-index:2;margin-top:2%;"
38
- :disabled="!mapAutocomplete"
39
- class="certain-category-search"
40
- dropdown-class-name="certain-category-search-dropdown"
41
- option-label-prop="value"
42
- placeholder="输入地址关键字搜索"
43
- @search="fetchFunction"
44
- @select="onSelect"
45
- >
46
- <a-spin v-if="searching" slot="notFoundContent" size="small"/>
47
- <template slot="dataSource">
48
- <a-select-opt-group v-for="group in option" :key="group.title">
49
- <span
50
- slot="label">
51
- <a-icon type="bank"/> {{ group.title }}
52
- </span>
53
- <a-select-option v-for="address in group.children" :key="address.label + ' <' + address.value + '>'">
54
- <p class="addressName">
55
- <a-icon type="environment"/>
56
- <span v-html="highLight(address.label, address.word)"></span></p>
57
- <p v-if="address.address !== '[]'" class="addressRemark">
58
- {{ address.address }}
59
- </p>
60
- </a-select-option>
61
- </a-select-opt-group>
62
- </template>
63
- <a-input>
64
- <a-icon slot="suffix" class="certain-category-icon" type="search"/>
65
- </a-input>
66
- </a-auto-complete>
67
- </div>
68
- <div id="addressSearchCombobox_map"/>
69
- <a-descriptions
70
- bordered
71
- class="asc_descriptions"
72
- :column="{ xxl: 2, xl: 2, lg: 2, md: 2, sm: 1, xs: 1 }"
73
- >
74
- <a-descriptions-item label="坐标" span="2"><span>{{ addressObj.lng_lat }}</span></a-descriptions-item>
75
- <a-descriptions-item label="地址" span="2"><span>{{ addressObj.address }}</span></a-descriptions-item>
76
- </a-descriptions>
77
- </a-modal>
78
- <!-- -->
79
- </div>
80
- </template>
81
- <script>
82
-
83
- import { GetGDMap } from '@vue2-client/utils/map-utils'
84
- import { debounce } from 'ant-design-vue/lib/vc-table/src/utils'
85
- import { mapState } from 'vuex'
86
- import { runLogic } from '@vue2-client/services/api/common'
87
-
88
- export default {
89
- name: 'AddressSearchCombobox',
90
- data () {
91
- // 检索去抖
92
- this.fetchFunction = debounce(this.fetchFunction, 300)
93
- return {
94
- // 地址搜索联想
95
- mapAutocomplete: undefined,
96
- // 检索结果
97
- option: [],
98
- // 最后检索版本
99
- lastFetchId: 0,
100
- // 检索中
101
- searching: false,
102
- addressObj: {
103
- lng_lat: '',
104
- address: '',
105
- },
106
- visible: false,
107
- map: null,
108
- m_index: 1002,
109
- positionPicker: null,
110
- addressInput: this.searchResult,
111
- // 选择地址返回的行政区域
112
- divisions: {},
113
- // 生成地址串中省市区街道信息禁止修改
114
- readOnlyDivisions: false
115
- }
116
- },
117
- computed: {
118
- ...mapState('setting', ['isMobile', 'gaode_key', 'gaode_secret_key'])
119
- },
120
- props: {
121
- attr: {
122
- type: Object,
123
- default: () => {
124
- }
125
- },
126
- emitFunc: {
127
- type: Function,
128
- default: () => {
129
- }
130
- },
131
- searchResult: {
132
- type: String,
133
- default: undefined
134
- },
135
- // 返回数据格式
136
- searchResultType: {
137
- type: String,
138
- default: 'Default'
139
- // default: 'Array'
140
- // default: 'Object'
141
- },
142
- // Object 返回格式时 可以自定义key
143
- resultKeys: {
144
- type: Object,
145
- default: () => {
146
- return { address: 'address', coords: 'coords' }
147
- }
148
- },
149
- readOnly: {
150
- type: Boolean,
151
- default: false
152
- },
153
- // 省市区是否可以修改
154
- divisionsChange: {
155
- type: Boolean,
156
- default: false
157
- },
158
- },
159
- created () {
160
- },
161
- mounted () {
162
- },
163
- methods: {
164
- change (value) {
165
- if (this.readOnlyDivisions && !this.divisionsChange) {
166
- // 如果省市区街道信息禁止修改
167
- if (this.divisions.str && !this.addressInput.startsWith(this.divisions.str)) {
168
- this.addressInput = this.addressObj.address
169
- this.$message.info('省市区街道信息请从选择新地址以变更')
170
- return
171
- }
172
- }
173
- debounce(() => {
174
- this.selected(null, this.addressInput)
175
- }, 200)()
176
- },
177
- initMap (aMap) {
178
- this.map = new (aMap).Map('addressSearchCombobox_map', { // 设置地图容器id
179
- resizeEnable: true, // 是否监控地图容器尺寸变化
180
- zoom: 10, // 初始化地图层级
181
- })
182
- this.geocoder = new (aMap).Geocoder({
183
- radius: 500 // 范围,默认:500
184
- })
185
- this.map.addControl(new (aMap).ToolBar()) // 初始化工具插件
186
- // 初始化窗体
187
- /* this.infoWindow = new (aMap).InfoWindow({
188
- anchor: 'bottom-center',
189
- isCustom: false, // 使用自定义窗体
190
- autoMove: true,
191
- content: '',
192
- showShadow: true,
193
- offset: new (aMap).Pixel(0, -25)
194
- }) */
195
- },
196
- onSelect (value) {
197
- console.log(' value--- ', this.searchResult)
198
- const _arr = value.replace('>', '').split('<')
199
- this.addressObj.address = _arr[0]
200
- this.addressObj.lng_lat = _arr[1]
201
- this.map.setCenter(this.addressObj.lng_lat.split(','))
202
- },
203
- selected (_value, _addstr) {
204
- let result
205
- if (this.searchResultType !== 'Default') {
206
- if (this.searchResultType === 'Array') {
207
- result = [_addstr || this.addressObj.address, this.addressObj.lng_lat]
208
- } else {
209
- result = {}
210
- result[this.resultKeys.address] = _addstr || this.addressObj.address
211
- result[this.resultKeys.coords] = this.addressObj.lng_lat
212
- }
213
- }
214
- this.visible = false
215
- this.$emit('onSelect', JSON.stringify(result))
216
- // 如果传递了地址 是为了更新上级 不做省市区检验处理
217
- if (!_addstr) {
218
- this.addressInput = this.addressObj.address
219
- this.$emit('onDivisionsChange', Object.assign({}, result, { divisions: this.divisions, vm: this }))
220
- }
221
- },
222
- // 懒加载检索方法
223
- fetchFunction (value) {
224
- if (value && this.mapAutocomplete) {
225
- this.searching = true
226
- this.lastFetchId += 1
227
- const fetchId = this.lastFetchId
228
- this.mapAutocomplete.search(value, (status, result) => {
229
- if (fetchId !== this.lastFetchId) {
230
- return
231
- }
232
- if (status === 'complete') {
233
- this.option = []
234
- const addressMap = {}
235
- result.tips.forEach((res) => {
236
- if (res.location) {
237
- if (!Object.prototype.hasOwnProperty.call(addressMap, res.district)) {
238
- addressMap[res.district] = []
239
- }
240
- addressMap[res.district].push({
241
- label: res.name,
242
- value: res.location.lng + ',' + res.location.lat,
243
- address: res.address + '',
244
- word: value
245
- })
246
- }
247
- })
248
- for (const key of Object.keys(addressMap)) {
249
- this.option.push({
250
- title: key,
251
- children: addressMap[key]
252
- })
253
- }
254
- }
255
- this.searching = false
256
- })
257
- }
258
- },
259
- // 获取数据
260
- getData (value, callback) {
261
- if (value !== '') {
262
- const logicName = this.attr.keyName
263
- const logic = logicName.substring(6)
264
- runLogic(logic, value, 'af-system').then(res => {
265
- callback(res)
266
- })
267
- }
268
- },
269
- // 关键字高亮
270
- highLight (value, word) {
271
- // 如果标题中包含,关键字就替换一下
272
- if (value.includes(word)) {
273
- value = value.replace(word,
274
- // 这里是替换成html格式的数据,最好再加一个样式权重,保险一点
275
- '<span style="color:red!important;">' + word + '</span>'
276
- )
277
- return value
278
- // eslint-disable-next-line brace-style
279
- }
280
- // 不包含的话还用这个
281
- else {
282
- return value
283
- }
284
- }
285
- },
286
- watch: {
287
- 'visible' (val) {
288
- if (val) {
289
- this.$nextTick(() => {
290
- GetGDMap(this.gaode_secret_key, this.gaode_key).then(aMap => {
291
- this.initMap(aMap)
292
- this.mapAutocomplete = new (aMap).AutoComplete({
293
- // city 限定城市,默认全国
294
- city: '全国',
295
- dragEnable: true,
296
- animateEnable: false
297
- })
298
- this.positionPicker = new window.AMapUI.PositionPicker({
299
- mode: 'dragMap',
300
- map: this.map
301
- })
302
- this.positionPicker.on('success', (positionResult) => {
303
- console.log(positionResult)
304
- console.log(positionResult.position)
305
- // 设置 行政区划信息
306
- if (positionResult?.regeocode?.addressComponent) {
307
- const { addressComponent } = positionResult?.regeocode
308
- this.divisions.province = addressComponent.province
309
- this.divisions.city = addressComponent.city
310
- this.divisions.district = addressComponent.district
311
- this.divisions.township = addressComponent.township
312
- this.divisions.towncode = addressComponent.towncode
313
- this.divisions.street = addressComponent.street
314
- // 试着获取小区
315
- if (positionResult?.regeocode?.aois && positionResult?.regeocode?.aois.length) {
316
- // 取第一个当做小区
317
- this.divisions.area = positionResult?.regeocode?.aois[0]?.name
318
- } else if (positionResult?.regeocode?.pois && positionResult?.regeocode?.pois.length) {
319
- // 取第一个当做小区
320
- this.divisions.area = positionResult?.regeocode?.pois[0]?.name
321
- }
322
- this.divisions.str =
323
- `${addressComponent.province}${addressComponent.city}${addressComponent.district}${addressComponent.township}`
324
- }
325
- if (this.divisions.str && positionResult.address.startsWith(this.divisions.str)) {
326
- // 如果 省市区信息和获取到的地址的前缀一致 那么省市区前缀禁止修改只能修改后面的 通过 onchange事件拦截
327
- this.readOnlyDivisions = true
328
- }
329
- this.addressObj.address = positionResult.address
330
- this.addressObj.lng_lat = `${positionResult.position.lng},${positionResult.position.lat}`
331
- })
332
- this.positionPicker.on('fail', function (positionResult) {
333
- })
334
- this.positionPicker.start()
335
- })
336
- })
337
- }
338
- }
339
- }
340
- }
341
- </script>
342
-
343
- <style lang="less" scoped>
344
- #addressSearchCombobox_map {
345
- margin: 1% 0;
346
- width: 100%;
347
- height: 400px;
348
- text-align: center
349
- }
350
-
351
- .asc_descriptions .ant-descriptions-item-content {
352
- width: 80%;
353
- }
354
-
355
- .certain-category-search-wrapper {
356
- margin-bottom: -4rem;
357
- text-align: center;
358
- }
359
-
360
- #addressSearchCombobox {
361
-
362
- .certain-category-search-dropdown .ant-select-dropdown-menu-item-group-title {
363
- color: #666;
364
- font-weight: bold;
365
- font-size: 14px;
366
- }
367
-
368
- .certain-category-search-dropdown .ant-select-dropdown-menu-item-group {
369
- border-bottom: 1px solid #f6f6f6;
370
- }
371
-
372
- .certain-category-search-dropdown .ant-select-dropdown-menu-item {
373
- padding-left: 16px;
374
- }
375
-
376
- .certain-category-search-dropdown .ant-select-dropdown-menu-item.show-all {
377
- text-align: center;
378
- cursor: default;
379
- }
380
-
381
- .certain-category-search-dropdown .ant-select-dropdown-menu {
382
- max-height: 300px;
383
- }
384
-
385
- .certain-category-search-wrapper .certain-search-item-count {
386
- position: absolute;
387
- color: #999;
388
- right: 16px;
389
- }
390
-
391
- .certain-category-search-wrapper .certain-category-search.ant-select-focused,
392
- .certain-category-icon {
393
- color: #108ee9;
394
- }
395
-
396
- .certain-category-search-wrapper .certain-category-icon {
397
- color: #6e6e6e;
398
- transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
399
- font-size: 16px;
400
- }
401
-
402
- .addressName {
403
- margin-bottom: 0;
404
- font-size: 14px;
405
- font-weight: bold;
406
- }
407
-
408
- .addressRemark {
409
- margin-bottom: 0;
410
- font-size: 12px;
411
- }
412
- }
413
- </style>
1
+ <template>
2
+ <div id="addressSearchCombobox">
3
+ <div>
4
+ <a-input-group
5
+ style="display: flex; width: 100%;"
6
+ compact>
7
+ <a-input
8
+ v-model="addressInput"
9
+ :read-only="readOnly || !this.addressObj.address"
10
+ @change="change"
11
+ style="flex: 1; width: auto; min-width: 0;"
12
+ placeholder="请选择地址信息"/>
13
+ <a-button
14
+ v-if="attr?.inputOnAfterName && attr?.inputOnAfterFunc"
15
+ style="flex: 1; width: auto; min-width: 4rem;max-width: 6rem"
16
+ type="primary"
17
+ @click="emitFunc(attr?.inputOnAfterFunc,addressInput)">
18
+ {{ attr?.inputOnAfterName }}
19
+ </a-button>
20
+ <!-- 默认展示该图标 如果配置了按钮插槽展示 primary 央视 -->
21
+ <a-button
22
+ style="width: 2rem; flex-shrink: 0;"
23
+ :type="attr?.inputOnAfterName ? 'primary' :''"
24
+ icon="environment"
25
+ @click="visible=true">
26
+ </a-button>
27
+ </a-input-group>
28
+ </div>
29
+ <a-modal
30
+ v-model="visible"
31
+ title="地址选择"
32
+ @ok="selected"
33
+ :zIndex="m_index"
34
+ :destroyOnClose="true">
35
+ <div class="certain-category-search-wrapper">
36
+ <a-auto-complete
37
+ style="right: 0px;width: 90%;z-index:2;margin-top:2%;"
38
+ :disabled="!mapAutocomplete"
39
+ class="certain-category-search"
40
+ dropdown-class-name="certain-category-search-dropdown"
41
+ option-label-prop="value"
42
+ placeholder="输入地址关键字搜索"
43
+ @search="fetchFunction"
44
+ @select="onSelect"
45
+ >
46
+ <a-spin v-if="searching" slot="notFoundContent" size="small"/>
47
+ <template slot="dataSource">
48
+ <a-select-opt-group v-for="group in option" :key="group.title">
49
+ <span
50
+ slot="label">
51
+ <a-icon type="bank"/> {{ group.title }}
52
+ </span>
53
+ <a-select-option v-for="address in group.children" :key="address.label + ' <' + address.value + '>'">
54
+ <p class="addressName">
55
+ <a-icon type="environment"/>
56
+ <span v-html="highLight(address.label, address.word)"></span></p>
57
+ <p v-if="address.address !== '[]'" class="addressRemark">
58
+ {{ address.address }}
59
+ </p>
60
+ </a-select-option>
61
+ </a-select-opt-group>
62
+ </template>
63
+ <a-input>
64
+ <a-icon slot="suffix" class="certain-category-icon" type="search"/>
65
+ </a-input>
66
+ </a-auto-complete>
67
+ </div>
68
+ <div id="addressSearchCombobox_map"/>
69
+ <a-descriptions
70
+ bordered
71
+ class="asc_descriptions"
72
+ :column="{ xxl: 2, xl: 2, lg: 2, md: 2, sm: 1, xs: 1 }"
73
+ >
74
+ <a-descriptions-item label="坐标" span="2"><span>{{ addressObj.lng_lat }}</span></a-descriptions-item>
75
+ <a-descriptions-item label="地址" span="2"><span>{{ addressObj.address }}</span></a-descriptions-item>
76
+ </a-descriptions>
77
+ </a-modal>
78
+ <!-- -->
79
+ </div>
80
+ </template>
81
+ <script>
82
+
83
+ import { GetGDMap } from '@vue2-client/utils/map-utils'
84
+ import { debounce } from 'ant-design-vue/lib/vc-table/src/utils'
85
+ import { mapState } from 'vuex'
86
+ import { runLogic } from '@vue2-client/services/api/common'
87
+
88
+ export default {
89
+ name: 'AddressSearchCombobox',
90
+ data () {
91
+ // 检索去抖
92
+ this.fetchFunction = debounce(this.fetchFunction, 300)
93
+ return {
94
+ // 地址搜索联想
95
+ mapAutocomplete: undefined,
96
+ // 检索结果
97
+ option: [],
98
+ // 最后检索版本
99
+ lastFetchId: 0,
100
+ // 检索中
101
+ searching: false,
102
+ addressObj: {
103
+ lng_lat: '',
104
+ address: '',
105
+ },
106
+ visible: false,
107
+ map: null,
108
+ m_index: 1002,
109
+ positionPicker: null,
110
+ addressInput: this.searchResult,
111
+ // 选择地址返回的行政区域
112
+ divisions: {},
113
+ // 生成地址串中省市区街道信息禁止修改
114
+ readOnlyDivisions: false
115
+ }
116
+ },
117
+ computed: {
118
+ ...mapState('setting', ['isMobile', 'gaode_key', 'gaode_secret_key'])
119
+ },
120
+ props: {
121
+ attr: {
122
+ type: Object,
123
+ default: () => {
124
+ }
125
+ },
126
+ emitFunc: {
127
+ type: Function,
128
+ default: () => {
129
+ }
130
+ },
131
+ searchResult: {
132
+ type: String,
133
+ default: undefined
134
+ },
135
+ // 返回数据格式
136
+ searchResultType: {
137
+ type: String,
138
+ default: 'Default'
139
+ // default: 'Array'
140
+ // default: 'Object'
141
+ },
142
+ // Object 返回格式时 可以自定义key
143
+ resultKeys: {
144
+ type: Object,
145
+ default: () => {
146
+ return { address: 'address', coords: 'coords' }
147
+ }
148
+ },
149
+ readOnly: {
150
+ type: Boolean,
151
+ default: false
152
+ },
153
+ // 省市区是否可以修改
154
+ divisionsChange: {
155
+ type: Boolean,
156
+ default: false
157
+ },
158
+ },
159
+ created () {
160
+ },
161
+ mounted () {
162
+ },
163
+ methods: {
164
+ change (value) {
165
+ if (this.readOnlyDivisions && !this.divisionsChange) {
166
+ // 如果省市区街道信息禁止修改
167
+ if (this.divisions.str && !this.addressInput.startsWith(this.divisions.str)) {
168
+ this.addressInput = this.addressObj.address
169
+ this.$message.info('省市区街道信息请从选择新地址以变更')
170
+ return
171
+ }
172
+ }
173
+ debounce(() => {
174
+ this.selected(null, this.addressInput)
175
+ }, 200)()
176
+ },
177
+ initMap (aMap) {
178
+ this.map = new (aMap).Map('addressSearchCombobox_map', { // 设置地图容器id
179
+ resizeEnable: true, // 是否监控地图容器尺寸变化
180
+ zoom: 10, // 初始化地图层级
181
+ })
182
+ this.geocoder = new (aMap).Geocoder({
183
+ radius: 500 // 范围,默认:500
184
+ })
185
+ this.map.addControl(new (aMap).ToolBar()) // 初始化工具插件
186
+ // 初始化窗体
187
+ /* this.infoWindow = new (aMap).InfoWindow({
188
+ anchor: 'bottom-center',
189
+ isCustom: false, // 使用自定义窗体
190
+ autoMove: true,
191
+ content: '',
192
+ showShadow: true,
193
+ offset: new (aMap).Pixel(0, -25)
194
+ }) */
195
+ },
196
+ onSelect (value) {
197
+ console.log(' value--- ', this.searchResult)
198
+ const _arr = value.replace('>', '').split('<')
199
+ this.addressObj.address = _arr[0]
200
+ this.addressObj.lng_lat = _arr[1]
201
+ this.map.setCenter(this.addressObj.lng_lat.split(','))
202
+ },
203
+ selected (_value, _addstr) {
204
+ let result
205
+ if (this.searchResultType !== 'Default') {
206
+ if (this.searchResultType === 'Array') {
207
+ result = [_addstr || this.addressObj.address, this.addressObj.lng_lat]
208
+ } else {
209
+ result = {}
210
+ result[this.resultKeys.address] = _addstr || this.addressObj.address
211
+ result[this.resultKeys.coords] = this.addressObj.lng_lat
212
+ }
213
+ }
214
+ this.visible = false
215
+ this.$emit('onSelect', JSON.stringify(result))
216
+ // 如果传递了地址 是为了更新上级 不做省市区检验处理
217
+ if (!_addstr) {
218
+ this.addressInput = this.addressObj.address
219
+ this.$emit('onDivisionsChange', Object.assign({}, result, { divisions: this.divisions, vm: this }))
220
+ }
221
+ },
222
+ // 懒加载检索方法
223
+ fetchFunction (value) {
224
+ if (value && this.mapAutocomplete) {
225
+ this.searching = true
226
+ this.lastFetchId += 1
227
+ const fetchId = this.lastFetchId
228
+ this.mapAutocomplete.search(value, (status, result) => {
229
+ if (fetchId !== this.lastFetchId) {
230
+ return
231
+ }
232
+ if (status === 'complete') {
233
+ this.option = []
234
+ const addressMap = {}
235
+ result.tips.forEach((res) => {
236
+ if (res.location) {
237
+ if (!Object.prototype.hasOwnProperty.call(addressMap, res.district)) {
238
+ addressMap[res.district] = []
239
+ }
240
+ addressMap[res.district].push({
241
+ label: res.name,
242
+ value: res.location.lng + ',' + res.location.lat,
243
+ address: res.address + '',
244
+ word: value
245
+ })
246
+ }
247
+ })
248
+ for (const key of Object.keys(addressMap)) {
249
+ this.option.push({
250
+ title: key,
251
+ children: addressMap[key]
252
+ })
253
+ }
254
+ }
255
+ this.searching = false
256
+ })
257
+ }
258
+ },
259
+ // 获取数据
260
+ getData (value, callback) {
261
+ if (value !== '') {
262
+ const logicName = this.attr.keyName
263
+ const logic = logicName.substring(6)
264
+ runLogic(logic, value, 'af-system').then(res => {
265
+ callback(res)
266
+ })
267
+ }
268
+ },
269
+ // 关键字高亮
270
+ highLight (value, word) {
271
+ // 如果标题中包含,关键字就替换一下
272
+ if (value.includes(word)) {
273
+ value = value.replace(word,
274
+ // 这里是替换成html格式的数据,最好再加一个样式权重,保险一点
275
+ '<span style="color:red!important;">' + word + '</span>'
276
+ )
277
+ return value
278
+ // eslint-disable-next-line brace-style
279
+ }
280
+ // 不包含的话还用这个
281
+ else {
282
+ return value
283
+ }
284
+ }
285
+ },
286
+ watch: {
287
+ 'visible' (val) {
288
+ if (val) {
289
+ this.$nextTick(() => {
290
+ GetGDMap(this.gaode_secret_key, this.gaode_key).then(aMap => {
291
+ this.initMap(aMap)
292
+ this.mapAutocomplete = new (aMap).AutoComplete({
293
+ // city 限定城市,默认全国
294
+ city: '全国',
295
+ dragEnable: true,
296
+ animateEnable: false
297
+ })
298
+ this.positionPicker = new window.AMapUI.PositionPicker({
299
+ mode: 'dragMap',
300
+ map: this.map
301
+ })
302
+ this.positionPicker.on('success', (positionResult) => {
303
+ console.log(positionResult)
304
+ console.log(positionResult.position)
305
+ // 设置 行政区划信息
306
+ if (positionResult?.regeocode?.addressComponent) {
307
+ const { addressComponent } = positionResult?.regeocode
308
+ this.divisions.province = addressComponent.province
309
+ this.divisions.city = addressComponent.city
310
+ this.divisions.district = addressComponent.district
311
+ this.divisions.township = addressComponent.township
312
+ this.divisions.towncode = addressComponent.towncode
313
+ this.divisions.street = addressComponent.street
314
+ // 试着获取小区
315
+ if (positionResult?.regeocode?.aois && positionResult?.regeocode?.aois.length) {
316
+ // 取第一个当做小区
317
+ this.divisions.area = positionResult?.regeocode?.aois[0]?.name
318
+ } else if (positionResult?.regeocode?.pois && positionResult?.regeocode?.pois.length) {
319
+ // 取第一个当做小区
320
+ this.divisions.area = positionResult?.regeocode?.pois[0]?.name
321
+ }
322
+ this.divisions.str =
323
+ `${addressComponent.province}${addressComponent.city}${addressComponent.district}${addressComponent.township}`
324
+ }
325
+ if (this.divisions.str && positionResult.address.startsWith(this.divisions.str)) {
326
+ // 如果 省市区信息和获取到的地址的前缀一致 那么省市区前缀禁止修改只能修改后面的 通过 onchange事件拦截
327
+ this.readOnlyDivisions = true
328
+ }
329
+ this.addressObj.address = positionResult.address
330
+ this.addressObj.lng_lat = `${positionResult.position.lng},${positionResult.position.lat}`
331
+ })
332
+ this.positionPicker.on('fail', function (positionResult) {
333
+ })
334
+ this.positionPicker.start()
335
+ })
336
+ })
337
+ }
338
+ }
339
+ }
340
+ }
341
+ </script>
342
+
343
+ <style lang="less" scoped>
344
+ #addressSearchCombobox_map {
345
+ margin: 1% 0;
346
+ width: 100%;
347
+ height: 400px;
348
+ text-align: center
349
+ }
350
+
351
+ .asc_descriptions .ant-descriptions-item-content {
352
+ width: 80%;
353
+ }
354
+
355
+ .certain-category-search-wrapper {
356
+ margin-bottom: -4rem;
357
+ text-align: center;
358
+ }
359
+
360
+ #addressSearchCombobox {
361
+
362
+ .certain-category-search-dropdown .ant-select-dropdown-menu-item-group-title {
363
+ color: #666;
364
+ font-weight: bold;
365
+ font-size: 14px;
366
+ }
367
+
368
+ .certain-category-search-dropdown .ant-select-dropdown-menu-item-group {
369
+ border-bottom: 1px solid #f6f6f6;
370
+ }
371
+
372
+ .certain-category-search-dropdown .ant-select-dropdown-menu-item {
373
+ padding-left: 16px;
374
+ }
375
+
376
+ .certain-category-search-dropdown .ant-select-dropdown-menu-item.show-all {
377
+ text-align: center;
378
+ cursor: default;
379
+ }
380
+
381
+ .certain-category-search-dropdown .ant-select-dropdown-menu {
382
+ max-height: 300px;
383
+ }
384
+
385
+ .certain-category-search-wrapper .certain-search-item-count {
386
+ position: absolute;
387
+ color: #999;
388
+ right: 16px;
389
+ }
390
+
391
+ .certain-category-search-wrapper .certain-category-search.ant-select-focused,
392
+ .certain-category-icon {
393
+ color: #108ee9;
394
+ }
395
+
396
+ .certain-category-search-wrapper .certain-category-icon {
397
+ color: #6e6e6e;
398
+ transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
399
+ font-size: 16px;
400
+ }
401
+
402
+ .addressName {
403
+ margin-bottom: 0;
404
+ font-size: 14px;
405
+ font-weight: bold;
406
+ }
407
+
408
+ .addressRemark {
409
+ margin-bottom: 0;
410
+ font-size: 12px;
411
+ }
412
+ }
413
+ </style>