af-mobile-client-vue3 1.1.6 → 1.1.7

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 (79) hide show
  1. package/.env +6 -6
  2. package/.env.development +4 -4
  3. package/.env.envoiceShow +6 -6
  4. package/.env.production +6 -6
  5. package/.husky/commit-msg +1 -1
  6. package/.husky/pre-commit +1 -1
  7. package/.vscode/settings.json +61 -61
  8. package/mock/modules/user.mock.ts +152 -152
  9. package/package.json +1 -1
  10. package/public/favicon.svg +4 -4
  11. package/public/safari-pinned-tab.svg +32 -32
  12. package/scripts/verifyCommit.js +19 -19
  13. package/src/App.vue +43 -43
  14. package/src/api/user/index.ts +40 -40
  15. package/src/bootstrap.ts +18 -18
  16. package/src/components/core/NavBar/index.vue +12 -12
  17. package/src/components/core/Tabbar/index.vue +38 -38
  18. package/src/components/core/XGridDropOption/index.vue +151 -151
  19. package/src/components/core/XMultiSelect/index.vue +183 -183
  20. package/src/components/data/XCellDetail/index.vue +106 -106
  21. package/src/components/data/XForm/index.vue +5 -0
  22. package/src/components/data/XFormItem/index.vue +3 -4
  23. package/src/components/data/XOlMap/README.md +0 -2
  24. package/src/components/data/XOlMap/XLocationPicker/index.vue +21 -9
  25. package/src/components/data/XOlMap/index.vue +81 -74
  26. package/src/components/data/XOlMap/types.ts +0 -4
  27. package/src/components/data/XOlMap/utils/wgs84ToGcj02.js +154 -154
  28. package/src/components/data/XReportForm/XReportFormJsonRender.vue +220 -220
  29. package/src/components/data/XReportForm/index.vue +1079 -1079
  30. package/src/components/data/XReportGrid/XAddReport/index.ts +1 -1
  31. package/src/components/data/XReportGrid/XReportDrawer/index.ts +1 -1
  32. package/src/components/data/XSignature/index.vue +285 -285
  33. package/src/components/data/XTag/index.vue +10 -10
  34. package/src/components/layout/NormalDataLayout/index.vue +70 -70
  35. package/src/components/layout/TabBarLayout/index.vue +40 -40
  36. package/src/components.d.ts +53 -53
  37. package/src/env.d.ts +16 -16
  38. package/src/font-style/font.css +3 -3
  39. package/src/hooks/useCommon.ts +9 -9
  40. package/src/locales/en-US.json +25 -25
  41. package/src/locales/zh-CN.json +25 -25
  42. package/src/plugins/AppData.ts +38 -38
  43. package/src/router/guards.ts +59 -59
  44. package/src/router/index.ts +61 -61
  45. package/src/router/invoiceRoutes.ts +33 -33
  46. package/src/services/api/common.ts +109 -109
  47. package/src/services/api/manage.ts +8 -8
  48. package/src/services/api/search.ts +16 -16
  49. package/src/services/restTools.ts +56 -56
  50. package/src/services/v3Api.ts +11 -11
  51. package/src/stores/modules/setting.ts +52 -52
  52. package/src/stores/mutation-type.ts +7 -7
  53. package/src/utils/authority-utils.ts +84 -84
  54. package/src/utils/crypto.ts +39 -39
  55. package/src/utils/i18n.ts +41 -41
  56. package/src/utils/indexedDB.ts +180 -180
  57. package/src/utils/mobileUtil.ts +26 -26
  58. package/src/utils/routerUtil.ts +271 -271
  59. package/src/utils/runEvalFunction.ts +13 -13
  60. package/src/utils/wechatUtil.ts +9 -9
  61. package/src/views/common/LoadError.vue +64 -64
  62. package/src/views/common/NotFound.vue +68 -68
  63. package/src/views/component/EvaluateRecordView/index.vue +40 -40
  64. package/src/views/component/XCellDetailView/index.vue +217 -217
  65. package/src/views/component/XOlMapView/XLocationPicker/index.vue +120 -120
  66. package/src/views/component/XOlMapView/index.vue +0 -1
  67. package/src/views/component/XReportFormIframeView/index.vue +47 -47
  68. package/src/views/component/XReportFormView/index.vue +13 -13
  69. package/src/views/component/XSignatureView/index.vue +50 -50
  70. package/src/views/component/menu.vue +117 -117
  71. package/src/views/component/notice.vue +46 -46
  72. package/src/views/component/topNav.vue +36 -36
  73. package/src/views/invoiceShow/index.vue +61 -61
  74. package/src/views/user/login/ForgetPasswordForm.vue +94 -94
  75. package/src/views/user/login/LoginTitle.vue +68 -68
  76. package/src/views/user/login/index.vue +22 -22
  77. package/src/views/user/my/index.vue +230 -230
  78. package/src/vue-router.d.ts +9 -9
  79. package/tsconfig.json +43 -43
@@ -1,217 +1,217 @@
1
- <script setup lang="ts">
2
- import XCellDetail from '@af-mobile-client-vue3/components/data/XCellDetail/index.vue'
3
- import NormalDataLayout from '@af-mobile-client-vue3/components/layout/NormalDataLayout/index.vue'
4
- import TabBarLayout from '@af-mobile-client-vue3/components/layout/TabBarLayout/index.vue'
5
- import { remove } from '@af-mobile-client-vue3/services/api/common'
6
- import {
7
- showConfirmDialog,
8
- showFailToast,
9
- showSuccessToast,
10
- Cell as VanCell,
11
- CellGroup as VanCellGroup,
12
- Dialog as VanDialog,
13
- Field as VanField,
14
- Form as VanForm,
15
- Grid as VanGrid,
16
- GridItem as VanGridItem,
17
- Popup as VanPopup,
18
- } from 'vant'
19
- import { onMounted, ref } from 'vue'
20
- import { useRoute } from 'vue-router'
21
-
22
- const options = ref([
23
- { text: '微信', icon: 'wechat' },
24
- { text: '微博', icon: 'weibo' },
25
- { text: '微信', icon: 'wechat' },
26
- { text: '微博', icon: 'weibo' },
27
- { text: '微信', icon: 'wechat' },
28
- { text: '微博', icon: 'weibo' },
29
- { text: '微信', icon: 'wechat' },
30
- { text: '微博', icon: 'weibo' },
31
- ])
32
-
33
- const barList = ref([
34
- { icon: 'edit', text: '编辑', method: 'editElement' },
35
- { icon: 'delete-o', text: '删除', method: 'delElement' },
36
- { icon: 'ellipsis', text: '更多', method: 'getMore' },
37
- ])
38
-
39
- const serviceName = ref('af-system')
40
-
41
- const queryParamsName = ref('crud_oper_log_manage')
42
-
43
- const route = useRoute()
44
-
45
- const id = ref(-1)
46
-
47
- const showMore = ref(false)
48
-
49
- const showEdit = ref(false)
50
-
51
- const msg = ref({
52
- info1: '',
53
- info2: '',
54
- })
55
-
56
- const loading = ref(true)
57
-
58
- const detailContent = ref({
59
- 编号: '测试编号3.1415926...',
60
- 姓名: '测试人员',
61
- 部门: '测试部门',
62
- 完成日期: '测试时间 2024/4/16 16:59:12',
63
- 请求方式: '测试方法 POST',
64
- 请求ip: '测试ip 127.0.0.1',
65
- })
66
-
67
- const callbacks = {
68
- editElement,
69
- delElement,
70
- getMore,
71
- }
72
-
73
- function editElement() {
74
- showEdit.value = true
75
- }
76
-
77
- function doEdit() {
78
- showEdit.value = false
79
- }
80
- function delElement() {
81
- showConfirmDialog({
82
- title: '提示',
83
- message:
84
- `确认删除---${id.value}---?`,
85
- closeOnClickOverlay: true,
86
- })
87
- .then(() => {
88
- const params = {
89
- queryParamsName: queryParamsName.value,
90
- idList: [id.value],
91
- }
92
- remove(params, serviceName)
93
- .then((_res) => {
94
- showSuccessToast('删除成功')
95
- history.back()
96
- })
97
- .catch((_err) => {
98
- showFailToast('删除失败')
99
- })
100
- })
101
- .catch((err) => {
102
- console.warn(err)
103
- })
104
- }
105
-
106
- function getMore() {
107
- showMore.value = true
108
- }
109
-
110
- onMounted(() => {
111
- id.value = route.params.id as unknown as number
112
- setTimeout(() => {
113
- loading.value = false
114
- }, 1000)
115
- })
116
- </script>
117
-
118
- <template>
119
- <div id="XCellDetailView">
120
- <NormalDataLayout title="详情" class="normal-body">
121
- <template #layout_content>
122
- <XCellDetail
123
- title="测试标题"
124
- describe="测试描述信息"
125
- extra="12345"
126
- :loading="loading"
127
- :status-bar="{ icon: 'success', color: 'green' }"
128
- >
129
- <template #detailContent>
130
- <div v-for="(value, key) in detailContent" :key="key" class="detail-content">
131
- <div class="detail-content-title">
132
- {{ key }}
133
- </div>
134
- <div class="detail-content-msg">
135
- {{ value }}
136
- </div>
137
- </div>
138
- </template>
139
- </XCellDetail>
140
- </template>
141
- </NormalDataLayout>
142
- <TabBarLayout :bar-list="barList" :callbacks="callbacks" />
143
- <VanPopup
144
- v-model:show="showMore"
145
- class="pop-box"
146
- :overlay-style="{ height: '92.5vh', top: '7.5vh' }"
147
- round
148
- position="bottom"
149
- >
150
- <div class="grid-box">
151
- <VanGrid :gutter="10">
152
- <VanGridItem v-for="(item, index) in options" :key="index" :icon="(item as any).icon" :text="(item as any).text" />
153
- </VanGrid>
154
- </div>
155
- <VanCell class="cell" title="取消" @click="showMore = false" />
156
- </VanPopup>
157
- <VanDialog :show="showEdit" title="编辑信息" :close-on-click-overlay="true" @confirm="doEdit">
158
- <VanForm>
159
- <VanCellGroup class="cell-group">
160
- <VanField
161
- v-model="msg.info1"
162
- name="信息一"
163
- label="信息一"
164
- placeholder="请填写信息一"
165
- :rules="[{ required: true, message: '信息一不得为空' }]"
166
- />
167
- <VanField
168
- v-model="msg.info2"
169
- name="信息二"
170
- label="信息二"
171
- placeholder="请填写信息二"
172
- :rules="[{ required: true, message: '信息二不得为空' }]"
173
- />
174
- </VanCellGroup>
175
- </VanForm>
176
- </VanDialog>
177
- </div>
178
- </template>
179
-
180
- <style scoped lang="less">
181
- #XCellDetailView {
182
- .normal-body {
183
- height: 92vh;
184
- }
185
- .grid-box {
186
- background-color: #f7f8fa;
187
- margin-top: 2vh;
188
- :deep(.van-grid-item__content) {
189
- background-color: #f7f8fa;
190
- }
191
- :deep(.van-grid-item__content:hover) {
192
- background-color: white;
193
- }
194
- }
195
- .pop-box {
196
- height: 28vh;
197
- background-color: #f7f8fa;
198
- }
199
- .cell {
200
- margin-top: 1vh;
201
- text-align: center;
202
- }
203
- .cell-group {
204
- margin-top: 2vh;
205
- margin-bottom: 2vh;
206
- }
207
- .detail-content {
208
- margin: 5px 0 0 0;
209
- font-size: 15px;
210
- .detail-content-title {
211
- font-size: 13px;
212
- margin-bottom: 5px;
213
- color: var(--van-text-color-2);
214
- }
215
- }
216
- }
217
- </style>
1
+ <script setup lang="ts">
2
+ import XCellDetail from '@af-mobile-client-vue3/components/data/XCellDetail/index.vue'
3
+ import NormalDataLayout from '@af-mobile-client-vue3/components/layout/NormalDataLayout/index.vue'
4
+ import TabBarLayout from '@af-mobile-client-vue3/components/layout/TabBarLayout/index.vue'
5
+ import { remove } from '@af-mobile-client-vue3/services/api/common'
6
+ import {
7
+ showConfirmDialog,
8
+ showFailToast,
9
+ showSuccessToast,
10
+ Cell as VanCell,
11
+ CellGroup as VanCellGroup,
12
+ Dialog as VanDialog,
13
+ Field as VanField,
14
+ Form as VanForm,
15
+ Grid as VanGrid,
16
+ GridItem as VanGridItem,
17
+ Popup as VanPopup,
18
+ } from 'vant'
19
+ import { onMounted, ref } from 'vue'
20
+ import { useRoute } from 'vue-router'
21
+
22
+ const options = ref([
23
+ { text: '微信', icon: 'wechat' },
24
+ { text: '微博', icon: 'weibo' },
25
+ { text: '微信', icon: 'wechat' },
26
+ { text: '微博', icon: 'weibo' },
27
+ { text: '微信', icon: 'wechat' },
28
+ { text: '微博', icon: 'weibo' },
29
+ { text: '微信', icon: 'wechat' },
30
+ { text: '微博', icon: 'weibo' },
31
+ ])
32
+
33
+ const barList = ref([
34
+ { icon: 'edit', text: '编辑', method: 'editElement' },
35
+ { icon: 'delete-o', text: '删除', method: 'delElement' },
36
+ { icon: 'ellipsis', text: '更多', method: 'getMore' },
37
+ ])
38
+
39
+ const serviceName = ref('af-system')
40
+
41
+ const queryParamsName = ref('crud_oper_log_manage')
42
+
43
+ const route = useRoute()
44
+
45
+ const id = ref(-1)
46
+
47
+ const showMore = ref(false)
48
+
49
+ const showEdit = ref(false)
50
+
51
+ const msg = ref({
52
+ info1: '',
53
+ info2: '',
54
+ })
55
+
56
+ const loading = ref(true)
57
+
58
+ const detailContent = ref({
59
+ 编号: '测试编号3.1415926...',
60
+ 姓名: '测试人员',
61
+ 部门: '测试部门',
62
+ 完成日期: '测试时间 2024/4/16 16:59:12',
63
+ 请求方式: '测试方法 POST',
64
+ 请求ip: '测试ip 127.0.0.1',
65
+ })
66
+
67
+ const callbacks = {
68
+ editElement,
69
+ delElement,
70
+ getMore,
71
+ }
72
+
73
+ function editElement() {
74
+ showEdit.value = true
75
+ }
76
+
77
+ function doEdit() {
78
+ showEdit.value = false
79
+ }
80
+ function delElement() {
81
+ showConfirmDialog({
82
+ title: '提示',
83
+ message:
84
+ `确认删除---${id.value}---?`,
85
+ closeOnClickOverlay: true,
86
+ })
87
+ .then(() => {
88
+ const params = {
89
+ queryParamsName: queryParamsName.value,
90
+ idList: [id.value],
91
+ }
92
+ remove(params, serviceName)
93
+ .then((_res) => {
94
+ showSuccessToast('删除成功')
95
+ history.back()
96
+ })
97
+ .catch((_err) => {
98
+ showFailToast('删除失败')
99
+ })
100
+ })
101
+ .catch((err) => {
102
+ console.warn(err)
103
+ })
104
+ }
105
+
106
+ function getMore() {
107
+ showMore.value = true
108
+ }
109
+
110
+ onMounted(() => {
111
+ id.value = route.params.id as unknown as number
112
+ setTimeout(() => {
113
+ loading.value = false
114
+ }, 1000)
115
+ })
116
+ </script>
117
+
118
+ <template>
119
+ <div id="XCellDetailView">
120
+ <NormalDataLayout title="详情" class="normal-body">
121
+ <template #layout_content>
122
+ <XCellDetail
123
+ title="测试标题"
124
+ describe="测试描述信息"
125
+ extra="12345"
126
+ :loading="loading"
127
+ :status-bar="{ icon: 'success', color: 'green' }"
128
+ >
129
+ <template #detailContent>
130
+ <div v-for="(value, key) in detailContent" :key="key" class="detail-content">
131
+ <div class="detail-content-title">
132
+ {{ key }}
133
+ </div>
134
+ <div class="detail-content-msg">
135
+ {{ value }}
136
+ </div>
137
+ </div>
138
+ </template>
139
+ </XCellDetail>
140
+ </template>
141
+ </NormalDataLayout>
142
+ <TabBarLayout :bar-list="barList" :callbacks="callbacks" />
143
+ <VanPopup
144
+ v-model:show="showMore"
145
+ class="pop-box"
146
+ :overlay-style="{ height: '92.5vh', top: '7.5vh' }"
147
+ round
148
+ position="bottom"
149
+ >
150
+ <div class="grid-box">
151
+ <VanGrid :gutter="10">
152
+ <VanGridItem v-for="(item, index) in options" :key="index" :icon="(item as any).icon" :text="(item as any).text" />
153
+ </VanGrid>
154
+ </div>
155
+ <VanCell class="cell" title="取消" @click="showMore = false" />
156
+ </VanPopup>
157
+ <VanDialog :show="showEdit" title="编辑信息" :close-on-click-overlay="true" @confirm="doEdit">
158
+ <VanForm>
159
+ <VanCellGroup class="cell-group">
160
+ <VanField
161
+ v-model="msg.info1"
162
+ name="信息一"
163
+ label="信息一"
164
+ placeholder="请填写信息一"
165
+ :rules="[{ required: true, message: '信息一不得为空' }]"
166
+ />
167
+ <VanField
168
+ v-model="msg.info2"
169
+ name="信息二"
170
+ label="信息二"
171
+ placeholder="请填写信息二"
172
+ :rules="[{ required: true, message: '信息二不得为空' }]"
173
+ />
174
+ </VanCellGroup>
175
+ </VanForm>
176
+ </VanDialog>
177
+ </div>
178
+ </template>
179
+
180
+ <style scoped lang="less">
181
+ #XCellDetailView {
182
+ .normal-body {
183
+ height: 92vh;
184
+ }
185
+ .grid-box {
186
+ background-color: #f7f8fa;
187
+ margin-top: 2vh;
188
+ :deep(.van-grid-item__content) {
189
+ background-color: #f7f8fa;
190
+ }
191
+ :deep(.van-grid-item__content:hover) {
192
+ background-color: white;
193
+ }
194
+ }
195
+ .pop-box {
196
+ height: 28vh;
197
+ background-color: #f7f8fa;
198
+ }
199
+ .cell {
200
+ margin-top: 1vh;
201
+ text-align: center;
202
+ }
203
+ .cell-group {
204
+ margin-top: 2vh;
205
+ margin-bottom: 2vh;
206
+ }
207
+ .detail-content {
208
+ margin: 5px 0 0 0;
209
+ font-size: 15px;
210
+ .detail-content-title {
211
+ font-size: 13px;
212
+ margin-bottom: 5px;
213
+ color: var(--van-text-color-2);
214
+ }
215
+ }
216
+ }
217
+ </style>
@@ -1,120 +1,120 @@
1
- <script setup lang="ts">
2
- import type { LocationResult } from '@af-mobile-client-vue3/components/data/XOlMap/types'
3
- import LocationPicker from '@af-mobile-client-vue3/components/data/XOlMap/XLocationPicker/index.vue'
4
- import NormalDataLayout from '@af-mobile-client-vue3/components/layout/NormalDataLayout/index.vue'
5
- import { showNotify } from 'vant'
6
- import { ref } from 'vue'
7
-
8
- const selectedLocation = ref<LocationResult>()
9
-
10
- // 处理位置选择
11
- function handleLocationConfirm(location: LocationResult) {
12
- // console.log('选择的位置:', location)
13
- // selectedLocation.value = location
14
- showNotify({ type: 'success', message: '位置已选择' })
15
- }
16
- </script>
17
-
18
- <template>
19
- <NormalDataLayout id="XLocationPicker" title="XOlMap地址选择器">
20
- <template #layout_content>
21
- <div class="location-picker-demo">
22
- <!-- 页面标题 -->
23
- <div class="page-header">
24
- <div class="title">
25
- 位置选择
26
- </div>
27
- </div>
28
-
29
- <!-- 选择结果展示 -->
30
- <div v-if="selectedLocation" class="location-result">
31
- <div class="label">
32
- 已选位置:
33
- </div>
34
- <div class="value">
35
- {{ selectedLocation.address }}
36
- </div>
37
- <div class="coordinates">
38
- 经度: {{ selectedLocation.longitude.toFixed(6) }},
39
- 纬度: {{ selectedLocation.latitude.toFixed(6) }}
40
- </div>
41
- </div>
42
-
43
- <!-- 地图组件 -->
44
- <div class="map-container">
45
- <LocationPicker
46
- v-model="selectedLocation"
47
- tian-di-tu-key="c16876b28898637c0a1a68b3fa410504"
48
- amap-key="5ebabc4536d4b42e0dd1e20175cca8ab"
49
- :default-center="[108.948024, 34.263161]"
50
- :default-zoom="12"
51
- @confirm="handleLocationConfirm"
52
- />
53
- </div>
54
- </div>
55
- </template>
56
- </NormalDataLayout>
57
- </template>
58
-
59
- <style scoped lang="less">
60
- .location-picker-demo {
61
- width: 100%;
62
- height: 100%;
63
- position: relative;
64
- display: flex;
65
- flex-direction: column;
66
- background-color: #f7f8fa;
67
- }
68
-
69
- .page-header {
70
- height: 44px;
71
- display: flex;
72
- align-items: center;
73
- justify-content: center;
74
- background: white;
75
- box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
76
- position: relative;
77
- z-index: 1;
78
-
79
- .title {
80
- font-size: 16px;
81
- color: #333;
82
- font-weight: 500;
83
- }
84
- }
85
-
86
- .location-result {
87
- background: white;
88
- padding: 12px 16px;
89
- margin: 10px;
90
- border-radius: 8px;
91
- box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
92
-
93
- .label {
94
- font-size: 14px;
95
- color: #666;
96
- margin-bottom: 4px;
97
- }
98
-
99
- .value {
100
- font-size: 16px;
101
- color: #333;
102
- margin-bottom: 8px;
103
- word-break: break-all;
104
- }
105
-
106
- .coordinates {
107
- font-size: 12px;
108
- color: #999;
109
- }
110
- }
111
-
112
- .map-container {
113
- flex: 1;
114
- position: relative;
115
- margin: 0 10px 10px 10px;
116
- border-radius: 8px;
117
- overflow: hidden;
118
- box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
119
- }
120
- </style>
1
+ <script setup lang="ts">
2
+ import type { LocationResult } from '@af-mobile-client-vue3/components/data/XOlMap/types'
3
+ import LocationPicker from '@af-mobile-client-vue3/components/data/XOlMap/XLocationPicker/index.vue'
4
+ import NormalDataLayout from '@af-mobile-client-vue3/components/layout/NormalDataLayout/index.vue'
5
+ import { showNotify } from 'vant'
6
+ import { ref } from 'vue'
7
+
8
+ const selectedLocation = ref<LocationResult>()
9
+
10
+ // 处理位置选择
11
+ function handleLocationConfirm(location: LocationResult) {
12
+ // console.log('选择的位置:', location)
13
+ // selectedLocation.value = location
14
+ showNotify({ type: 'success', message: '位置已选择' })
15
+ }
16
+ </script>
17
+
18
+ <template>
19
+ <NormalDataLayout id="XLocationPicker" title="XOlMap地址选择器">
20
+ <template #layout_content>
21
+ <div class="location-picker-demo">
22
+ <!-- 页面标题 -->
23
+ <div class="page-header">
24
+ <div class="title">
25
+ 位置选择
26
+ </div>
27
+ </div>
28
+
29
+ <!-- 选择结果展示 -->
30
+ <div v-if="selectedLocation" class="location-result">
31
+ <div class="label">
32
+ 已选位置:
33
+ </div>
34
+ <div class="value">
35
+ {{ selectedLocation.address }}
36
+ </div>
37
+ <div class="coordinates">
38
+ 经度: {{ selectedLocation.longitude.toFixed(6) }},
39
+ 纬度: {{ selectedLocation.latitude.toFixed(6) }}
40
+ </div>
41
+ </div>
42
+
43
+ <!-- 地图组件 -->
44
+ <div class="map-container">
45
+ <LocationPicker
46
+ v-model="selectedLocation"
47
+ tian-di-tu-key="c16876b28898637c0a1a68b3fa410504"
48
+ amap-key="5ebabc4536d4b42e0dd1e20175cca8ab"
49
+ :default-center="[108.948024, 34.263161]"
50
+ :default-zoom="12"
51
+ @confirm="handleLocationConfirm"
52
+ />
53
+ </div>
54
+ </div>
55
+ </template>
56
+ </NormalDataLayout>
57
+ </template>
58
+
59
+ <style scoped lang="less">
60
+ .location-picker-demo {
61
+ width: 100%;
62
+ height: 100%;
63
+ position: relative;
64
+ display: flex;
65
+ flex-direction: column;
66
+ background-color: #f7f8fa;
67
+ }
68
+
69
+ .page-header {
70
+ height: 44px;
71
+ display: flex;
72
+ align-items: center;
73
+ justify-content: center;
74
+ background: white;
75
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
76
+ position: relative;
77
+ z-index: 1;
78
+
79
+ .title {
80
+ font-size: 16px;
81
+ color: #333;
82
+ font-weight: 500;
83
+ }
84
+ }
85
+
86
+ .location-result {
87
+ background: white;
88
+ padding: 12px 16px;
89
+ margin: 10px;
90
+ border-radius: 8px;
91
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
92
+
93
+ .label {
94
+ font-size: 14px;
95
+ color: #666;
96
+ margin-bottom: 4px;
97
+ }
98
+
99
+ .value {
100
+ font-size: 16px;
101
+ color: #333;
102
+ margin-bottom: 8px;
103
+ word-break: break-all;
104
+ }
105
+
106
+ .coordinates {
107
+ font-size: 12px;
108
+ color: #999;
109
+ }
110
+ }
111
+
112
+ .map-container {
113
+ flex: 1;
114
+ position: relative;
115
+ margin: 0 10px 10px 10px;
116
+ border-radius: 8px;
117
+ overflow: hidden;
118
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
119
+ }
120
+ </style>
@@ -69,7 +69,6 @@ onMounted(() => {
69
69
  zoom: 12,
70
70
  maxZoom: 18,
71
71
  minZoom: 4,
72
- tianDiTuKey: 'c16876b28898637c0a1a68b3fa410504',
73
72
  })
74
73
  mapRef.value.addWMSLayers(wmsConfig)
75
74
  })