af-mobile-client-vue3 1.3.12 → 1.3.13

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 (270) hide show
  1. package/.claude/settings.local.json +10 -0
  2. package/.cursorrules +60 -60
  3. package/.editorconfig +9 -9
  4. package/.env +10 -10
  5. package/.env.development +1 -1
  6. package/.env.production +1 -1
  7. package/.node-version +1 -1
  8. package/.vscode/extensions.json +12 -12
  9. package/.vscode/settings.json +66 -66
  10. package/CLAUDE.md +189 -184
  11. package/README.md +182 -181
  12. package/af-example-mobile-vue-web.iml +9 -9
  13. package/build/vite/index.ts +98 -98
  14. package/build/vite/optimize.ts +34 -34
  15. package/build/vite/vconsole.ts +47 -47
  16. package/commitlint.config.ts +32 -32
  17. package/compress.js +36 -36
  18. package/eslint.config.ts +30 -30
  19. package/index.html +23 -23
  20. package/mock/data.ts +20 -20
  21. package/mock/index.ts +7 -7
  22. package/mock/modules/prose.mock.ts +13 -13
  23. package/mock/modules/user.mock.ts +152 -152
  24. package/mock/util.ts +19 -19
  25. package/netlify.toml +12 -12
  26. package/package.json +114 -114
  27. package/postcss.config.ts +27 -27
  28. package/public/favicon.svg +4 -4
  29. package/public/safari-pinned-tab.svg +4 -4
  30. package/scripts/verifyCommit.js +19 -19
  31. package/src/App.vue +79 -79
  32. package/src/api/mock/index.ts +30 -30
  33. package/src/api/user/index.ts +40 -40
  34. package/src/assets/img/user/login/background-shadow-1.svg +20 -20
  35. package/src/assets/img/user/login/logo-background.svg +20 -20
  36. package/src/bootstrap.ts +26 -26
  37. package/src/components/core/BeautifulLoading/index.vue +52 -52
  38. package/src/components/core/ImageUploader/index.vue +244 -244
  39. package/src/components/core/NavBar/index.vue +53 -53
  40. package/src/components/core/Tabbar/index.vue +32 -32
  41. package/src/components/core/Uploader/index.vue +124 -124
  42. package/src/components/core/XGridDropOption/index.vue +154 -156
  43. package/src/components/core/XMultiSelect/index.vue +183 -183
  44. package/src/components/core/XSelect/index.vue +149 -149
  45. package/src/components/data/InfoDisplay/index.vue +132 -0
  46. package/src/components/data/UserDetail/api.ts +24 -0
  47. package/src/components/data/UserDetail/index.vue +539 -0
  48. package/src/components/data/UserDetail/recordEntries.ts +159 -0
  49. package/src/components/data/UserDetail/types.ts +26 -0
  50. package/src/components/data/XBadge/index.vue +82 -82
  51. package/src/components/data/XCellDetail/index.vue +105 -105
  52. package/src/components/data/XCellList/XCellList.md +313 -313
  53. package/src/components/data/XCellList/index.vue +1075 -1075
  54. package/src/components/data/XCellListFilter/QrScanner/index.vue +207 -207
  55. package/src/components/data/XCellListFilter/QrScanner/startScanAnimation.ts +53 -53
  56. package/src/components/data/XCellListFilter/VpnRecognition/index.vue +119 -119
  57. package/src/components/data/XCellListFilter/index.vue +705 -705
  58. package/src/components/data/XForm/index.vue +659 -659
  59. package/src/components/data/XFormGroup/doc/DeviceForm.vue +122 -122
  60. package/src/components/data/XFormGroup/doc/FormGroupDemo.vue +56 -56
  61. package/src/components/data/XFormGroup/doc/README.md +286 -273
  62. package/src/components/data/XFormGroup/doc/UserForm.vue +102 -102
  63. package/src/components/data/XFormGroup/index.vue +240 -240
  64. package/src/components/data/XFormItem/index.vue +1310 -1310
  65. package/src/components/data/XOlMap/README.md +227 -227
  66. package/src/components/data/XOlMap/XLocationPicker/index.vue +226 -225
  67. package/src/components/data/XOlMap/index.vue +1490 -1490
  68. package/src/components/data/XOlMap/types.ts +149 -149
  69. package/src/components/data/XOlMap/utils/wgs84ToGcj02.js +154 -154
  70. package/src/components/data/XReportForm/DateTimeSecondsPicker.vue +208 -208
  71. package/src/components/data/XReportForm/XReportFormJsonRender.vue +220 -220
  72. package/src/components/data/XReportForm/index.vue +1393 -1393
  73. package/src/components/data/XReportGrid/XAddReport/XAddReport.vue +198 -198
  74. package/src/components/data/XReportGrid/XAddReport/index.js +3 -3
  75. package/src/components/data/XReportGrid/XAddReport/index.md +53 -52
  76. package/src/components/data/XReportGrid/XAddReport/index.ts +10 -10
  77. package/src/components/data/XReportGrid/XReport.vue +960 -960
  78. package/src/components/data/XReportGrid/XReportDemo.vue +33 -33
  79. package/src/components/data/XReportGrid/XReportDesign.vue +597 -597
  80. package/src/components/data/XReportGrid/XReportDrawer/XReportDrawer.vue +148 -148
  81. package/src/components/data/XReportGrid/XReportDrawer/index.js +3 -3
  82. package/src/components/data/XReportGrid/XReportDrawer/index.ts +10 -10
  83. package/src/components/data/XReportGrid/XReportJsonRender.vue +399 -399
  84. package/src/components/data/XReportGrid/XReportTrGroup.vue +592 -592
  85. package/src/components/data/XReportGrid/index.md +46 -42
  86. package/src/components/data/XReportGrid/print.js +184 -184
  87. package/src/components/data/XSignature/index.vue +284 -285
  88. package/src/components/data/XTag/index.vue +10 -10
  89. package/src/components/layout/NormalDataLayout/index.vue +69 -69
  90. package/src/components/layout/TabBarLayout/index.vue +40 -40
  91. package/src/composables/dark.ts +5 -5
  92. package/src/config/routes.ts +9 -9
  93. package/src/constants/index.ts +2 -2
  94. package/src/enums/requestEnum.ts +25 -25
  95. package/src/expression/ExpressionRunner.ts +28 -28
  96. package/src/expression/TestExpression.ts +510 -510
  97. package/src/expression/core/Delegate.ts +116 -116
  98. package/src/expression/core/Expression.ts +1359 -1359
  99. package/src/expression/core/Program.ts +985 -985
  100. package/src/expression/core/Token.ts +29 -29
  101. package/src/expression/enums/ExpressionType.ts +81 -81
  102. package/src/expression/enums/TokenType.ts +11 -11
  103. package/src/expression/exception/BreakWayException.ts +2 -2
  104. package/src/expression/exception/ContinueWayException.ts +2 -2
  105. package/src/expression/exception/ExpressionException.ts +29 -29
  106. package/src/expression/exception/ReturnWayException.ts +14 -14
  107. package/src/expression/exception/ServiceException.ts +22 -22
  108. package/src/expression/instances/JSONArray.ts +52 -52
  109. package/src/expression/instances/JSONObject.ts +118 -118
  110. package/src/expression/instances/LogicConsole.ts +31 -31
  111. package/src/font-style/font.css +4 -4
  112. package/src/hooks/useBoolean.ts +26 -0
  113. package/src/hooks/useCommon.ts +9 -9
  114. package/src/hooks/useLogin.ts +97 -97
  115. package/src/icons/svg/check-in.svg +32 -32
  116. package/src/icons/svg/dark.svg +4 -4
  117. package/src/icons/svg/github.svg +4 -4
  118. package/src/icons/svg/light.svg +4 -4
  119. package/src/icons/svg/link.svg +4 -4
  120. package/src/icons/svgo.yml +22 -22
  121. package/src/layout/GridView/index.vue +16 -16
  122. package/src/layout/PageLayout.vue +9 -9
  123. package/src/layout/SingleLayout.vue +9 -9
  124. package/src/locales/en-US.json +128 -128
  125. package/src/locales/zh-CN.json +128 -128
  126. package/src/logic/LogicRunner.ts +67 -67
  127. package/src/logic/TestLogic.ts +13 -13
  128. package/src/logic/plugins/common/DateTools.ts +35 -35
  129. package/src/logic/plugins/common/VueTools.ts +30 -30
  130. package/src/logic/plugins/index.ts +7 -7
  131. package/src/main.ts +44 -44
  132. package/src/plugins/AppData.ts +38 -38
  133. package/src/plugins/GetLoginInfoService.ts +10 -10
  134. package/src/plugins/collectIcons.ts +10 -0
  135. package/src/plugins/index.ts +11 -11
  136. package/src/router/README.md +8 -8
  137. package/src/router/guards.ts +59 -59
  138. package/src/router/index.ts +35 -35
  139. package/src/router/invoiceRoutes.ts +33 -33
  140. package/src/router/routes.ts +341 -177
  141. package/src/router/types.ts +7 -7
  142. package/src/services/api/Login.ts +6 -6
  143. package/src/services/api/common.ts +109 -109
  144. package/src/services/api/index.ts +7 -7
  145. package/src/services/api/manage.ts +8 -8
  146. package/src/services/api/search.ts +16 -16
  147. package/src/services/api/user.ts +17 -17
  148. package/src/services/restTools.ts +56 -56
  149. package/src/services/v3Api.ts +147 -147
  150. package/src/stores/index.ts +11 -11
  151. package/src/stores/modules/counter.ts +19 -19
  152. package/src/stores/modules/routeCache.ts +23 -23
  153. package/src/stores/modules/setting.ts +76 -76
  154. package/src/stores/modules/user.ts +235 -235
  155. package/src/stores/mutation-type.ts +7 -7
  156. package/src/styles/app.less +36 -36
  157. package/src/styles/login.less +109 -109
  158. package/src/styles/var.less +16 -16
  159. package/src/types/env.d.ts +16 -16
  160. package/src/types/settings.ts +1 -1
  161. package/src/types/vue-router.d.ts +9 -9
  162. package/src/utils/Storage.ts +124 -124
  163. package/src/utils/authority-utils.ts +84 -84
  164. package/src/utils/common.ts +41 -41
  165. package/src/utils/crypto.ts +39 -39
  166. package/src/utils/dataUtil.ts +42 -42
  167. package/src/utils/dictUtil.ts +52 -52
  168. package/src/utils/http/index.ts +199 -199
  169. package/src/utils/i18n.ts +72 -72
  170. package/src/utils/indexedDB.ts +195 -195
  171. package/src/utils/inline-px-to-vw.ts +28 -28
  172. package/src/utils/mobileUtil.ts +34 -34
  173. package/src/utils/progress.ts +19 -19
  174. package/src/utils/routerUtil.ts +271 -271
  175. package/src/utils/runEvalFunction.ts +13 -13
  176. package/src/utils/secureStorage.ts +71 -71
  177. package/src/utils/set-page-title.ts +5 -5
  178. package/src/utils/validate.ts +6 -6
  179. package/src/utils/wechatUtil.ts +9 -9
  180. package/src/views/chat/index.vue +153 -153
  181. package/src/views/common/LoadError.vue +63 -63
  182. package/src/views/common/NotFound.vue +67 -67
  183. package/src/views/component/EvaluateRecordView/index.vue +40 -40
  184. package/src/views/component/IconifyView/index.vue +504 -507
  185. package/src/views/component/UserDetailView/UserDetailPage.vue +77 -0
  186. package/src/views/component/UserDetailView/index.vue +224 -0
  187. package/src/views/component/XCellDetailView/index.vue +217 -217
  188. package/src/views/component/XCellListView/index.vue +108 -157
  189. package/src/views/component/XFormAppraiseView/index.vue +174 -174
  190. package/src/views/component/XFormGroupView/index.vue +78 -82
  191. package/src/views/component/XFormView/index.vue +27 -27
  192. package/src/views/component/XOlMapView/XLocationPicker/index.vue +118 -118
  193. package/src/views/component/XOlMapView/index.vue +434 -434
  194. package/src/views/component/XOlMapView/testData.ts +64 -64
  195. package/src/views/component/XReportFormIframeView/index.vue +47 -47
  196. package/src/views/component/XReportFormView/index.vue +13 -13
  197. package/src/views/component/XReportGridView/index.vue +17 -17
  198. package/src/views/component/XRequestView/index.vue +234 -234
  199. package/src/views/component/XSignatureView/index.vue +50 -50
  200. package/src/views/component/index.vue +181 -177
  201. package/src/views/component/menu.vue +117 -117
  202. package/src/views/component/notice.vue +46 -46
  203. package/src/views/component/topNav.vue +36 -36
  204. package/src/views/invoiceShow/index.vue +61 -61
  205. package/src/views/user/login/ForgetPasswordForm.vue +94 -94
  206. package/src/views/user/login/LoginForm.vue +346 -346
  207. package/src/views/user/login/LoginTitle.vue +76 -76
  208. package/src/views/user/login/LoginWave.vue +109 -109
  209. package/src/views/user/login/index.vue +22 -22
  210. package/src/views/user/my/comm/ModifyPassword.vue +346 -346
  211. package/src/views/user/my/index.vue +340 -340
  212. package/src/views/userRecords/AbnormalAlarmRecords.vue +21 -0
  213. package/src/views/userRecords/CardReplacementRecords.vue +21 -0
  214. package/src/views/userRecords/ChangeRecords.vue +19 -0
  215. package/src/views/userRecords/CommandViewRecords.vue +20 -0
  216. package/src/views/userRecords/GasCompensationRecords.vue +20 -0
  217. package/src/views/userRecords/InstrumentCollectionRecords.vue +21 -0
  218. package/src/views/userRecords/MeterRecords.vue +20 -0
  219. package/src/views/userRecords/OperateRecords.vue +51 -0
  220. package/src/views/userRecords/OtherChargeRecords.vue +19 -0
  221. package/src/views/userRecords/PaymentRecords.vue +28 -0
  222. package/src/views/userRecords/PriceAdjustmentRecords.vue +19 -0
  223. package/src/views/userRecords/ReplacementRecords.vue +19 -0
  224. package/src/views/userRecords/SafetyRecords.vue +19 -0
  225. package/src/views/userRecords/TransactionRecords.vue +21 -0
  226. package/src/views/userRecords/TransferRecords.vue +19 -0
  227. package/src/views/userRecords/operateRecordDetail/index.vue +316 -0
  228. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/AddUserDetail.vue +124 -0
  229. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/AdvanceDeliveryDetail.vue +88 -0
  230. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/AutoAccountsCancelDetail.vue +205 -0
  231. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/AutoAccountsDetail.vue +192 -0
  232. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/BankDkDetail.vue +192 -0
  233. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/BankPayDetail.vue +192 -0
  234. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/BlacklistDetail.vue +153 -0
  235. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/CancellationDetail.vue +101 -0
  236. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/CardMeterCenterCancelDetail.vue +127 -0
  237. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/CardMeterCenterDetail.vue +153 -0
  238. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/CardOverUserDetail.vue +153 -0
  239. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ChangeMeterCancelDetail.vue +166 -0
  240. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ChangeMeterDetail.vue +205 -0
  241. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/DisableManageDetail.vue +127 -0
  242. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/EnableManageDetail.vue +114 -0
  243. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/FaZheChangeDetail.vue +124 -0
  244. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/FeeDeductionDetail.vue +153 -0
  245. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/GasPriceChangeDetail.vue +126 -0
  246. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/InputtorChangeDetail.vue +126 -0
  247. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/IotMeterCenterCancelDetail.vue +114 -0
  248. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/IotMeterCenterDetail.vue +127 -0
  249. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/IotOpenDetail.vue +88 -0
  250. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/MachineCardDetail.vue +101 -0
  251. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/MachineMeterCenterCancelDetail.vue +218 -0
  252. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/MachineMeterCenterDetail.vue +153 -0
  253. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/OffGasAddGasDetail.vue +140 -0
  254. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/OtherChargeCancelDetail.vue +127 -0
  255. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/OtherChargeDetail.vue +114 -0
  256. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/OverUserChangeDetail.vue +127 -0
  257. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ReBillDetail.vue +127 -0
  258. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/RefundDetail.vue +114 -0
  259. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ReplaceCardManageCancelDetail.vue +127 -0
  260. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/ReplaceCardManageDetail.vue +114 -0
  261. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/SaleCardGasDetail.vue +140 -0
  262. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/TransferManageCancelDetail.vue +152 -0
  263. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/TransferManageDetail.vue +178 -0
  264. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/UserChangeDetail.vue +123 -0
  265. package/src/views/userRecords/operateRecordDetail/operateRecordDetails/WechatPayDetail.vue +192 -0
  266. package/src/views/userRecords/types.ts +66 -0
  267. package/tsconfig.json +39 -39
  268. package/uno.config.ts +82 -78
  269. package/vite.config.ts +118 -118
  270. package/src/views/component/XFormGroupView/xformgroup222.vue +0 -97
@@ -1,225 +1,226 @@
1
- <script setup lang="ts">
2
- import type { LocationResult, PhoneLocationStatus } from '../types'
3
- import { post } from '@af-mobile-client-vue3/services/restTools'
4
- import { mobileUtil } from '@af-mobile-client-vue3/utils/mobileUtil'
5
- import { Button } from 'vant'
6
- import { nextTick, onMounted, ref, watch } from 'vue'
7
- import XOlMap from '../index.vue'
8
-
9
- interface Props {
10
- modelValue?: LocationResult
11
- defaultCenter?: [number, number]
12
- defaultZoom?: number
13
- serviceName?: string
14
- }
15
-
16
- const props = withDefaults(defineProps<Props>(), {
17
- defaultCenter: () => [108.948024, 34.263161],
18
- defaultZoom: 16,
19
- })
20
-
21
- const emit = defineEmits<{
22
- (e: 'update:modelValue', value: LocationResult): void
23
- (e: 'confirm', value: LocationResult): void
24
- }>()
25
-
26
- const mapRef = ref<InstanceType<typeof XOlMap>>()
27
- const currentAddress = ref('')
28
- const currentLocation = ref<[number, number]>(props.defaultCenter)
29
-
30
- // 处理地图中心点变化
31
- async function handleCenterChange(center: [number, number]) {
32
- currentLocation.value = center
33
- // 获取地址信息
34
- if (mapRef.value) {
35
- currentAddress.value = await mapRef.value.getAddressInfo(center)
36
- }
37
- }
38
-
39
- // 处理确定按钮点击
40
- function handleConfirm() {
41
- const result: LocationResult = {
42
- longitude: currentLocation.value[0],
43
- latitude: currentLocation.value[1],
44
- address: currentAddress.value,
45
- }
46
- emit('update:modelValue', result)
47
- emit('confirm', result)
48
- }
49
-
50
- // 组件挂载时初始化地图
51
- onMounted(async () => {
52
- // 使用 nextTick 确保 DOM 已更新
53
- await nextTick()
54
- await mapRef.value.init({
55
- center: props.defaultCenter,
56
- zoom: props.defaultZoom,
57
- })
58
- try {
59
- const webConfig = await post(`/api/${props.serviceName || import.meta.env.VITE_APP_SYSTEM_NAME}/logic/openapi/getLiuliConfiguration`, { configName: 'webConfig' })
60
- const wms = webConfig.wms ?? {}
61
- if (Array.isArray(wms.layers) && wms.layers.length > 0 && wms.wms?.url) {
62
- await mapRef.value.addWMSLayers(wms)
63
- }
64
- }
65
- catch (e) {
66
- console.error('初始化地图wms图层失败', e)
67
- }
68
- // 初始化后尝试获取地址信息
69
- handleCenterChange(props.defaultCenter)
70
-
71
- // 异步获取定位,获取到后更新 currentLocation 和地图中心
72
- try {
73
- mobileUtil.execute({
74
- param: {},
75
- funcName: 'getLocationResult',
76
- callbackFunc: (result) => {
77
- const res = result as PhoneLocationStatus
78
- if (res.status === 'success') {
79
- const locationResult = JSON.parse(res.data.location)
80
- if (locationResult.longitude && locationResult.latitude) {
81
- const newCenter: [number, number] = [locationResult.longitude, locationResult.latitude]
82
- currentLocation.value = newCenter
83
- // 设置地图中心
84
- if (mapRef.value && mapRef.value.setCenter) {
85
- mapRef.value.setCenter(newCenter)
86
- }
87
- handleCenterChange(newCenter)
88
- }
89
- }
90
- },
91
- })
92
- }
93
- catch (error) {
94
- console.error('获取位置信息失败:', error)
95
- }
96
- })
97
-
98
- // 监听弹窗状态变化
99
- watch(() => props.modelValue, (newVal) => {
100
- // 当绑定值变化时,可能需要重新调整地图
101
- nextTick(() => {
102
- if (mapRef.value && mapRef.value.getMap()) {
103
- mapRef.value.getMap().updateSize()
104
- }
105
- })
106
- }, { immediate: true })
107
- </script>
108
-
109
- <template>
110
- <div class="location-picker">
111
- <div class="map-container">
112
- <XOlMap
113
- ref="mapRef"
114
- class="map"
115
- @center-change="handleCenterChange"
116
- />
117
- <!-- 中心点标记 -->
118
- <div class="location-picker-marker">
119
- <div class="marker-icon" />
120
- </div>
121
- </div>
122
-
123
- <!-- 底部地址信息面板 -->
124
- <div class="location-picker-panel">
125
- <div class="address-info">
126
- <div class="address-label">
127
- 位置信息
128
- </div>
129
- <div class="address-text">
130
- {{ currentAddress }}
131
- </div>
132
- <div class="coordinates-text">
133
- 经度: {{ currentLocation[0] }}, 纬度: {{ currentLocation[1] }}
134
- </div>
135
- </div>
136
- <Button type="primary" block @click="handleConfirm">
137
- 确定
138
- </Button>
139
- </div>
140
- </div>
141
- </template>
142
-
143
- <style scoped lang="less">
144
- .location-picker {
145
- position: relative;
146
- width: 100%;
147
- height: 100%;
148
- display: flex;
149
- flex-direction: column;
150
- border-radius: 8px;
151
- overflow: hidden;
152
- }
153
-
154
- .map-container {
155
- position: relative;
156
- flex: 1;
157
- min-height: 0;
158
- border-radius: 40px;
159
- overflow: hidden;
160
- padding: 10px;
161
- }
162
-
163
- .map {
164
- width: 100%;
165
- height: 100%;
166
- min-height: 300px;
167
- }
168
-
169
- .location-picker-marker {
170
- position: absolute;
171
- left: 50%;
172
- top: 50%;
173
- transform: translate(-50%, -50%);
174
- z-index: 1000;
175
- pointer-events: none;
176
-
177
- .marker-icon {
178
- width: 24px;
179
- height: 24px;
180
- background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCI+PHBhdGggZmlsbD0iIzE5ODlmYSIgZD0iTTEyIDJDOC4xMyAyIDUgNS4xMyA1IDljMCA1LjI1IDcgMTMgNyAxM3M3LTcuNzUgNy0xM2MwLTMuODctMy4xMy03LTctN3ptMCA5LjVjLTEuMzggMC0yLjUtMS4xMi0yLjUtMi41czEuMTItMi41IDIuNS0yLjUgMi41IDEuMTIgMi41IDIuNS0xLjEyIDIuNS0yLjUgMi41eiIvPjwvc3ZnPg==') no-repeat center;
181
- background-size: contain;
182
- }
183
- }
184
-
185
- .location-picker-panel {
186
- background: white;
187
- padding: 12px 16px;
188
- box-shadow: 0 -1px 4px rgba(0, 0, 0, 0.1);
189
- border-radius: 8px 8px 0 0;
190
- z-index: 1000;
191
-
192
- .address-info {
193
- margin-bottom: 12px;
194
-
195
- .address-label {
196
- font-size: 14px;
197
- color: #666;
198
- margin-bottom: 4px;
199
- }
200
-
201
- .address-text {
202
- font-size: 15px;
203
- color: #333;
204
- margin-bottom: 4px;
205
- word-break: break-all;
206
- }
207
-
208
- .coordinates-text {
209
- font-size: 12px;
210
- color: #999;
211
- }
212
- }
213
- }
214
-
215
- // 移动端适配
216
- @media screen and (max-width: 768px) {
217
- .location-picker-panel {
218
- padding: 10px 12px;
219
-
220
- .address-info {
221
- margin-bottom: 10px;
222
- }
223
- }
224
- }
225
- </style>
1
+ <script setup lang="ts">
2
+ import type { LocationResult, PhoneLocationStatus } from '../types'
3
+ import { post } from '@af-mobile-client-vue3/services/restTools'
4
+ import { mobileUtil } from '@af-mobile-client-vue3/utils/mobileUtil'
5
+ import { Button } from 'vant'
6
+ import { nextTick, onMounted, ref, watch } from 'vue'
7
+ import XOlMap from '../index.vue'
8
+
9
+ interface Props {
10
+ modelValue?: LocationResult
11
+ defaultCenter?: [number, number]
12
+ defaultZoom?: number
13
+ serviceName?: string
14
+ }
15
+
16
+ const props = withDefaults(defineProps<Props>(), {
17
+ defaultCenter: () => [108.948024, 34.263161],
18
+ defaultZoom: 16,
19
+ })
20
+
21
+ const emit = defineEmits<{
22
+ (e: 'update:modelValue', value: LocationResult): void
23
+ (e: 'confirm', value: LocationResult): void
24
+ }>()
25
+
26
+ const mapRef = ref<InstanceType<typeof XOlMap>>()
27
+ const currentAddress = ref('')
28
+ const currentLocation = ref<[number, number]>(props.defaultCenter)
29
+
30
+ // 处理地图中心点变化
31
+ async function handleCenterChange(center: [number, number]) {
32
+ currentLocation.value = center
33
+ // 获取地址信息
34
+ if (mapRef.value) {
35
+ currentAddress.value = await mapRef.value.getAddressInfo(center)
36
+ }
37
+ }
38
+
39
+ // 处理确定按钮点击
40
+ function handleConfirm() {
41
+ const result: LocationResult = {
42
+ longitude: currentLocation.value[0],
43
+ latitude: currentLocation.value[1],
44
+ address: currentAddress.value,
45
+ }
46
+ emit('update:modelValue', result)
47
+ emit('confirm', result)
48
+ }
49
+
50
+ // 组件挂载时初始化地图
51
+ onMounted(async () => {
52
+ // 使用 nextTick 确保 DOM 已更新
53
+ await nextTick()
54
+ await mapRef.value.init({
55
+ center: props.defaultCenter,
56
+ zoom: props.defaultZoom,
57
+ })
58
+ try {
59
+ const webConfig = await post(`/api/${props.serviceName || import.meta.env.VITE_APP_SYSTEM_NAME}/logic/openapi/getLiuliConfiguration`, { configName: 'webConfig' })
60
+ const wms = webConfig.wms ?? {}
61
+ if (Array.isArray(wms.layers) && wms.layers.length > 0 && wms.wms?.url) {
62
+ await mapRef.value.addWMSLayers(wms)
63
+ }
64
+ }
65
+ catch (e) {
66
+ console.error('初始化地图wms图层失败', e)
67
+ }
68
+ // 初始化后尝试获取地址信息
69
+ handleCenterChange(props.defaultCenter)
70
+
71
+ // 异步获取定位,获取到后更新 currentLocation 和地图中心
72
+ try {
73
+ mobileUtil.execute({
74
+ param: {},
75
+ funcName: 'getLocationResult',
76
+ callbackFunc: (result) => {
77
+ const res = result as PhoneLocationStatus
78
+ if (res.status === 'success') {
79
+ const locationResult = JSON.parse(res.data.location)
80
+ if (locationResult.longitude && locationResult.latitude) {
81
+ const newCenter: [number, number] = [locationResult.longitude, locationResult.latitude]
82
+ currentLocation.value = newCenter
83
+ // 设置地图中心
84
+ if (mapRef.value && mapRef.value.setCenter) {
85
+ mapRef.value.setCenter(newCenter)
86
+ }
87
+ handleCenterChange(newCenter)
88
+ }
89
+ }
90
+ },
91
+ })
92
+ }
93
+ catch (error) {
94
+ console.error('获取位置信息失败:', error)
95
+ }
96
+ })
97
+
98
+ // 监听弹窗状态变化
99
+ watch(() => props.modelValue, (newVal) => {
100
+ // 当绑定值变化时,可能需要重新调整地图
101
+ nextTick(() => {
102
+ if (mapRef.value && mapRef.value.getMap()) {
103
+ mapRef.value.getMap().updateSize()
104
+ }
105
+ })
106
+ }, { immediate: true })
107
+ </script>
108
+
109
+ <template>
110
+ <div class="location-picker">
111
+ <div class="map-container">
112
+ <XOlMap
113
+ ref="mapRef"
114
+ class="map"
115
+ @center-change="handleCenterChange"
116
+ />
117
+ <!-- 中心点标记 -->
118
+ <div class="location-picker-marker">
119
+ <div class="marker-icon" />
120
+ </div>
121
+ </div>
122
+
123
+ <!-- 底部地址信息面板 -->
124
+ <div class="location-picker-panel">
125
+ <div class="address-info">
126
+ <div class="address-label">
127
+ 位置信息
128
+ </div>
129
+ <div class="address-text">
130
+ {{ currentAddress }}
131
+ </div>
132
+ <div class="coordinates-text">
133
+ 经度: {{ currentLocation[0] }}, 纬度: {{ currentLocation[1] }}
134
+ </div>
135
+ </div>
136
+ <Button type="primary" block @click="handleConfirm">
137
+ 确定
138
+ </Button>
139
+ </div>
140
+ </div>
141
+ </template>
142
+
143
+ <style scoped lang="less">
144
+ .location-picker {
145
+ position: relative;
146
+ width: 100%;
147
+ height: 100%;
148
+ display: flex;
149
+ flex-direction: column;
150
+ border-radius: 8px;
151
+ overflow: hidden;
152
+ }
153
+
154
+ .map-container {
155
+ position: relative;
156
+ flex: 1;
157
+ min-height: 0;
158
+ border-radius: 40px;
159
+ overflow: hidden;
160
+ padding: 10px;
161
+ }
162
+
163
+ .map {
164
+ width: 100%;
165
+ height: 100%;
166
+ min-height: 300px;
167
+ }
168
+
169
+ .location-picker-marker {
170
+ position: absolute;
171
+ left: 50%;
172
+ top: 50%;
173
+ transform: translate(-50%, -50%);
174
+ z-index: 1000;
175
+ pointer-events: none;
176
+
177
+ .marker-icon {
178
+ width: 24px;
179
+ height: 24px;
180
+ background: url('data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNCAyNCI+PHBhdGggZmlsbD0iIzE5ODlmYSIgZD0iTTEyIDJDOC4xMyAyIDUgNS4xMyA1IDljMCA1LjI1IDcgMTMgNyAxM3M3LTcuNzUgNy0xM2MwLTMuODctMy4xMy03LTctN3ptMCA5LjVjLTEuMzggMC0yLjUtMS4xMi0yLjUtMi41czEuMTItMi41IDIuNS0yLjUgMi41IDEuMTIgMi41IDIuNS0xLjEyIDIuNS0yLjUgMi41eiIvPjwvc3ZnPg==')
181
+ no-repeat center;
182
+ background-size: contain;
183
+ }
184
+ }
185
+
186
+ .location-picker-panel {
187
+ background: white;
188
+ padding: 12px 16px;
189
+ box-shadow: 0 -1px 4px rgba(0, 0, 0, 0.1);
190
+ border-radius: 8px 8px 0 0;
191
+ z-index: 1000;
192
+
193
+ .address-info {
194
+ margin-bottom: 12px;
195
+
196
+ .address-label {
197
+ font-size: 14px;
198
+ color: #666;
199
+ margin-bottom: 4px;
200
+ }
201
+
202
+ .address-text {
203
+ font-size: 15px;
204
+ color: #333;
205
+ margin-bottom: 4px;
206
+ word-break: break-all;
207
+ }
208
+
209
+ .coordinates-text {
210
+ font-size: 12px;
211
+ color: #999;
212
+ }
213
+ }
214
+ }
215
+
216
+ // 移动端适配
217
+ @media screen and (max-width: 768px) {
218
+ .location-picker-panel {
219
+ padding: 10px 12px;
220
+
221
+ .address-info {
222
+ margin-bottom: 10px;
223
+ }
224
+ }
225
+ }
226
+ </style>