vue2-client 1.15.41 → 1.15.42
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.
package/package.json
CHANGED
@@ -1,186 +1,186 @@
|
|
1
|
-
// print.js
|
2
|
-
|
3
|
-
export function printElement (elementToPrint) {
|
4
|
-
// 创建一个新的浏览器窗口
|
5
|
-
const printWindow = window.open('', '_blank', 'height=1024,width=768')
|
6
|
-
// 设置新窗口的文档内容
|
7
|
-
printWindow.document.write(`
|
8
|
-
<html>
|
9
|
-
<head>
|
10
|
-
<title>Print</title>
|
11
|
-
<style>
|
12
|
-
@page {
|
13
|
-
size: auto;
|
14
|
-
margin: 0mm;
|
15
|
-
}
|
16
|
-
html, body {
|
17
|
-
margin: 0;
|
18
|
-
padding: 0;
|
19
|
-
width: 100%;
|
20
|
-
height: 100%;
|
21
|
-
}
|
22
|
-
#print-container {
|
23
|
-
display: none
|
24
|
-
}
|
25
|
-
.img{
|
26
|
-
width: 95%;
|
27
|
-
height: 180px;
|
28
|
-
object-fit: cover;
|
29
|
-
}
|
30
|
-
.reportMain {
|
31
|
-
text-align: center;
|
32
|
-
margin: 0 auto;
|
33
|
-
font-size: 16px;
|
34
|
-
color: #000;
|
35
|
-
background-color: #fff;
|
36
|
-
padding: 15px;
|
37
|
-
border-radius: 8px;
|
38
|
-
|
39
|
-
.reportTitle {
|
40
|
-
font-weight: bold;
|
41
|
-
}
|
42
|
-
|
43
|
-
.subTitle {
|
44
|
-
display: flex;
|
45
|
-
justify-content: space-between;
|
46
|
-
margin-bottom: 1%;
|
47
|
-
|
48
|
-
.subTitleItems {
|
49
|
-
max-width: 30%;
|
50
|
-
}
|
51
|
-
}
|
52
|
-
|
53
|
-
.inputsDiv {
|
54
|
-
display: flex;
|
55
|
-
justify-content: space-between;
|
56
|
-
.inputsDivItem {
|
57
|
-
display: flex;
|
58
|
-
align-items: center;
|
59
|
-
padding: 0 4px;
|
60
|
-
white-space: nowrap;
|
61
|
-
.inputsDivItemLabel {
|
62
|
-
padding: 0 4px;
|
63
|
-
}
|
64
|
-
}
|
65
|
-
}
|
66
|
-
|
67
|
-
.reportTable {
|
68
|
-
width: 100%;
|
69
|
-
border-collapse: collapse;
|
70
|
-
table-layout:fixed;
|
71
|
-
word-break:break-all;
|
72
|
-
text-align: center;
|
73
|
-
}
|
74
|
-
}
|
75
|
-
.reportMainForDisplay {
|
76
|
-
text-align: center;
|
77
|
-
margin: 10% auto;
|
78
|
-
font-size: 16px;
|
79
|
-
color: #000;
|
80
|
-
background-color: #fff;
|
81
|
-
padding: 15px;
|
82
|
-
border-radius: 8px;
|
83
|
-
|
84
|
-
.reportTitle {
|
85
|
-
font-weight: bold;
|
86
|
-
}
|
87
|
-
|
88
|
-
.subTitle {
|
89
|
-
display: flex;
|
90
|
-
justify-content: space-between;
|
91
|
-
|
92
|
-
.subTitleItems {
|
93
|
-
max-width: 30%;
|
94
|
-
}
|
95
|
-
}
|
96
|
-
|
97
|
-
.inputsDiv {
|
98
|
-
display: flex;
|
99
|
-
justify-content: space-around;
|
100
|
-
.inputsDivItem {
|
101
|
-
display: flex;
|
102
|
-
align-items: center;
|
103
|
-
padding: 0 4px;
|
104
|
-
white-space: nowrap;
|
105
|
-
.inputsDivItemLabel {
|
106
|
-
padding: 0 4px;
|
107
|
-
}
|
108
|
-
}
|
109
|
-
}
|
110
|
-
|
111
|
-
.reportTable {
|
112
|
-
width: 100%;
|
113
|
-
border-collapse: collapse;
|
114
|
-
table-layout:fixed;
|
115
|
-
word-break:break-all;
|
116
|
-
}
|
117
|
-
}
|
118
|
-
.reportMainNoPadding {
|
119
|
-
text-align: center;
|
120
|
-
margin: 0 auto;
|
121
|
-
font-size: 16px;
|
122
|
-
color: #000;
|
123
|
-
background-color: #fff;
|
124
|
-
border-radius: 8px;
|
125
|
-
|
126
|
-
.reportTitle {
|
127
|
-
font-weight: bold;
|
128
|
-
}
|
129
|
-
|
130
|
-
.subTitle {
|
131
|
-
display: flex;
|
132
|
-
justify-content: space-between;
|
133
|
-
|
134
|
-
.subTitleItems {
|
135
|
-
max-width: 30%;
|
136
|
-
}
|
137
|
-
}
|
138
|
-
|
139
|
-
.inputsDiv {
|
140
|
-
display: flex;
|
141
|
-
justify-content: space-between;
|
142
|
-
.inputsDivItem {
|
143
|
-
display: flex;
|
144
|
-
align-items: center;
|
145
|
-
padding: 0 4px;
|
146
|
-
white-space: nowrap;
|
147
|
-
.inputsDivItemLabel {
|
148
|
-
padding: 0 4px;
|
149
|
-
}
|
150
|
-
}
|
151
|
-
}
|
152
|
-
|
153
|
-
.reportTable {
|
154
|
-
width: 100%;
|
155
|
-
border-collapse: collapse;
|
156
|
-
table-layout:fixed;
|
157
|
-
word-break:break-all;
|
158
|
-
}
|
159
|
-
}
|
160
|
-
.tools{
|
161
|
-
position: fixed;
|
162
|
-
right: 2%;
|
163
|
-
text-align: right;
|
164
|
-
width: 60%;
|
165
|
-
cursor: pointer;
|
166
|
-
.toolsItem{
|
167
|
-
width: 15%;
|
168
|
-
margin-right: 3%;
|
169
|
-
display: inline-block;
|
170
|
-
}
|
171
|
-
}
|
172
|
-
</style>
|
173
|
-
</head>
|
174
|
-
<body>
|
175
|
-
<!-- 将需要打印的元素内容复制到新窗口中 -->
|
176
|
-
${elementToPrint.innerHTML}
|
177
|
-
</body>
|
178
|
-
</html>
|
179
|
-
`)
|
180
|
-
// 延迟执行打印,以确保新窗口的内容已加载完成
|
181
|
-
printWindow.document.close() // 关闭文档流,确保内容完全加载
|
182
|
-
setTimeout(() => {
|
183
|
-
printWindow.print() // 调用打印方法
|
184
|
-
printWindow.close()
|
185
|
-
}, 500) // 延迟500毫秒后执行打印
|
186
|
-
}
|
1
|
+
// print.js
|
2
|
+
|
3
|
+
export function printElement (elementToPrint) {
|
4
|
+
// 创建一个新的浏览器窗口
|
5
|
+
const printWindow = window.open('', '_blank', 'height=1024,width=768')
|
6
|
+
// 设置新窗口的文档内容
|
7
|
+
printWindow.document.write(`
|
8
|
+
<html>
|
9
|
+
<head>
|
10
|
+
<title>Print</title>
|
11
|
+
<style>
|
12
|
+
@page {
|
13
|
+
size: auto;
|
14
|
+
margin: 0mm;
|
15
|
+
}
|
16
|
+
html, body {
|
17
|
+
margin: 0;
|
18
|
+
padding: 0;
|
19
|
+
width: 100%;
|
20
|
+
height: 100%;
|
21
|
+
}
|
22
|
+
#print-container {
|
23
|
+
display: none
|
24
|
+
}
|
25
|
+
.img{
|
26
|
+
width: 95%;
|
27
|
+
height: 180px;
|
28
|
+
object-fit: cover;
|
29
|
+
}
|
30
|
+
.reportMain {
|
31
|
+
text-align: center;
|
32
|
+
margin: 0 auto;
|
33
|
+
font-size: 16px;
|
34
|
+
color: #000;
|
35
|
+
background-color: #fff;
|
36
|
+
padding: 15px;
|
37
|
+
border-radius: 8px;
|
38
|
+
|
39
|
+
.reportTitle {
|
40
|
+
font-weight: bold;
|
41
|
+
}
|
42
|
+
|
43
|
+
.subTitle {
|
44
|
+
display: flex;
|
45
|
+
justify-content: space-between;
|
46
|
+
margin-bottom: 1%;
|
47
|
+
|
48
|
+
.subTitleItems {
|
49
|
+
max-width: 30%;
|
50
|
+
}
|
51
|
+
}
|
52
|
+
|
53
|
+
.inputsDiv {
|
54
|
+
display: flex;
|
55
|
+
justify-content: space-between;
|
56
|
+
.inputsDivItem {
|
57
|
+
display: flex;
|
58
|
+
align-items: center;
|
59
|
+
padding: 0 4px;
|
60
|
+
white-space: nowrap;
|
61
|
+
.inputsDivItemLabel {
|
62
|
+
padding: 0 4px;
|
63
|
+
}
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
.reportTable {
|
68
|
+
width: 100%;
|
69
|
+
border-collapse: collapse;
|
70
|
+
table-layout:fixed;
|
71
|
+
word-break:break-all;
|
72
|
+
text-align: center;
|
73
|
+
}
|
74
|
+
}
|
75
|
+
.reportMainForDisplay {
|
76
|
+
text-align: center;
|
77
|
+
margin: 10% auto;
|
78
|
+
font-size: 16px;
|
79
|
+
color: #000;
|
80
|
+
background-color: #fff;
|
81
|
+
padding: 15px;
|
82
|
+
border-radius: 8px;
|
83
|
+
|
84
|
+
.reportTitle {
|
85
|
+
font-weight: bold;
|
86
|
+
}
|
87
|
+
|
88
|
+
.subTitle {
|
89
|
+
display: flex;
|
90
|
+
justify-content: space-between;
|
91
|
+
|
92
|
+
.subTitleItems {
|
93
|
+
max-width: 30%;
|
94
|
+
}
|
95
|
+
}
|
96
|
+
|
97
|
+
.inputsDiv {
|
98
|
+
display: flex;
|
99
|
+
justify-content: space-around;
|
100
|
+
.inputsDivItem {
|
101
|
+
display: flex;
|
102
|
+
align-items: center;
|
103
|
+
padding: 0 4px;
|
104
|
+
white-space: nowrap;
|
105
|
+
.inputsDivItemLabel {
|
106
|
+
padding: 0 4px;
|
107
|
+
}
|
108
|
+
}
|
109
|
+
}
|
110
|
+
|
111
|
+
.reportTable {
|
112
|
+
width: 100%;
|
113
|
+
border-collapse: collapse;
|
114
|
+
table-layout:fixed;
|
115
|
+
word-break:break-all;
|
116
|
+
}
|
117
|
+
}
|
118
|
+
.reportMainNoPadding {
|
119
|
+
text-align: center;
|
120
|
+
margin: 0 auto;
|
121
|
+
font-size: 16px;
|
122
|
+
color: #000;
|
123
|
+
background-color: #fff;
|
124
|
+
border-radius: 8px;
|
125
|
+
|
126
|
+
.reportTitle {
|
127
|
+
font-weight: bold;
|
128
|
+
}
|
129
|
+
|
130
|
+
.subTitle {
|
131
|
+
display: flex;
|
132
|
+
justify-content: space-between;
|
133
|
+
|
134
|
+
.subTitleItems {
|
135
|
+
max-width: 30%;
|
136
|
+
}
|
137
|
+
}
|
138
|
+
|
139
|
+
.inputsDiv {
|
140
|
+
display: flex;
|
141
|
+
justify-content: space-between;
|
142
|
+
.inputsDivItem {
|
143
|
+
display: flex;
|
144
|
+
align-items: center;
|
145
|
+
padding: 0 4px;
|
146
|
+
white-space: nowrap;
|
147
|
+
.inputsDivItemLabel {
|
148
|
+
padding: 0 4px;
|
149
|
+
}
|
150
|
+
}
|
151
|
+
}
|
152
|
+
|
153
|
+
.reportTable {
|
154
|
+
width: 100%;
|
155
|
+
border-collapse: collapse;
|
156
|
+
table-layout:fixed;
|
157
|
+
word-break:break-all;
|
158
|
+
}
|
159
|
+
}
|
160
|
+
.tools{
|
161
|
+
position: fixed;
|
162
|
+
right: 2%;
|
163
|
+
text-align: right;
|
164
|
+
width: 60%;
|
165
|
+
cursor: pointer;
|
166
|
+
.toolsItem{
|
167
|
+
width: 15%;
|
168
|
+
margin-right: 3%;
|
169
|
+
display: inline-block;
|
170
|
+
}
|
171
|
+
}
|
172
|
+
</style>
|
173
|
+
</head>
|
174
|
+
<body>
|
175
|
+
<!-- 将需要打印的元素内容复制到新窗口中 -->
|
176
|
+
${elementToPrint.innerHTML}
|
177
|
+
</body>
|
178
|
+
</html>
|
179
|
+
`)
|
180
|
+
// 延迟执行打印,以确保新窗口的内容已加载完成
|
181
|
+
printWindow.document.close() // 关闭文档流,确保内容完全加载
|
182
|
+
setTimeout(() => {
|
183
|
+
printWindow.print() // 调用打印方法
|
184
|
+
printWindow.close()
|
185
|
+
}, 500) // 延迟500毫秒后执行打印
|
186
|
+
}
|
@@ -54,14 +54,13 @@ routerResource.example = {
|
|
54
54
|
path: 'example',
|
55
55
|
name: '示例主页面',
|
56
56
|
// component: () => import('@vue2-client/pages/WorkflowDetail/WorkFlowDemo2.vue'),
|
57
|
-
component: () => import('@vue2-client/pages/WorkflowDetail/WorkFlowDemo3.vue'),
|
58
57
|
// component: () => import('@vue2-client/pages/WorkflowDetail/WorkFlowDemo.vue'),
|
59
58
|
// component: () => import('@vue2-client/pages/addressSelect/addressDemo.vue'),
|
60
59
|
// component: () => import('@vue2-client/base-client/components/common/XDescriptions/demo.vue'),
|
61
60
|
// component: () => import('@vue2-client/base-client/components/common/XAddNativeForm/demo.vue'),
|
62
61
|
// component: () => import('@vue2-client/base-client/components/common/XFormGroup/demo.vue'),
|
63
62
|
// component: () => import('@vue2-client/base-client/components/common/XReport/XReportDemo.vue'),
|
64
|
-
|
63
|
+
component: () => import('@vue2-client/base-client/components/common/XFormTable/demo.vue'),
|
65
64
|
// component: () => import('@vue2-client/base-client/components/common/XDatePicker/demo.vue'),
|
66
65
|
// component: () => import('@vue2-client/base-client/components/common/XTab/XTabDemo.vue'),
|
67
66
|
// component: () => import('@vue2-client/base-client/components/common/XRate/demo.vue'),
|
package/src/theme/global.less
CHANGED
@@ -48,107 +48,107 @@ ol {
|
|
48
48
|
// 成功样式 - 绿色 (#52c41a)
|
49
49
|
.ant-table-row-success {
|
50
50
|
background-color: rgba(82, 196, 26, 0.2);
|
51
|
-
|
51
|
+
|
52
52
|
&:hover {
|
53
53
|
background-color: rgba(82, 196, 26, 0.3);
|
54
|
-
|
54
|
+
|
55
55
|
td {
|
56
56
|
background-color: transparent;
|
57
57
|
}
|
58
58
|
}
|
59
|
-
|
59
|
+
|
60
60
|
// 选中状态
|
61
61
|
&.ant-table-row-selected {
|
62
62
|
background-color: rgba(82, 196, 26, 0.4);
|
63
|
-
|
63
|
+
|
64
64
|
td {
|
65
65
|
background-color: transparent;
|
66
66
|
}
|
67
67
|
}
|
68
|
-
|
68
|
+
|
69
69
|
td {
|
70
70
|
background-color: transparent;
|
71
71
|
}
|
72
72
|
}
|
73
|
-
|
73
|
+
|
74
74
|
// 警告样式 - 黄色 (#faad14)
|
75
75
|
.ant-table-row-warning {
|
76
76
|
background-color: rgba(250, 173, 20, 0.1) ;
|
77
|
-
|
77
|
+
|
78
78
|
&:hover {
|
79
79
|
background-color: rgba(250, 173, 20, 0.15) ;
|
80
|
-
|
80
|
+
|
81
81
|
td {
|
82
82
|
background-color: transparent ;
|
83
83
|
}
|
84
84
|
}
|
85
|
-
|
85
|
+
|
86
86
|
// 选中状态
|
87
87
|
&.ant-table-row-selected {
|
88
88
|
background-color: rgba(250, 173, 20, 0.2);
|
89
|
-
|
89
|
+
|
90
90
|
td {
|
91
91
|
background-color: transparent;
|
92
92
|
}
|
93
93
|
}
|
94
|
-
|
94
|
+
|
95
95
|
td {
|
96
96
|
background-color: transparent ;
|
97
97
|
}
|
98
98
|
}
|
99
|
-
|
99
|
+
|
100
100
|
// 错误样式 - 红色 (#f5222f)
|
101
101
|
.ant-table-row-error {
|
102
102
|
background-color: rgba(245, 34, 47, 0.1) ;
|
103
|
-
|
103
|
+
|
104
104
|
&:hover {
|
105
105
|
background-color: rgba(245, 34, 47, 0.15) ;
|
106
|
-
|
106
|
+
|
107
107
|
td {
|
108
108
|
background-color: transparent ;
|
109
109
|
}
|
110
110
|
}
|
111
|
-
|
111
|
+
|
112
112
|
// 选中状态
|
113
113
|
&.ant-table-row-selected {
|
114
114
|
background-color: rgba(245, 34, 47, 0.2) ;
|
115
|
-
|
115
|
+
|
116
116
|
td {
|
117
117
|
background-color: transparent ;
|
118
118
|
}
|
119
119
|
}
|
120
|
-
|
120
|
+
|
121
121
|
td {
|
122
122
|
background-color: transparent ;
|
123
123
|
}
|
124
124
|
}
|
125
|
-
|
125
|
+
|
126
126
|
// 魔法样式 - 紫色
|
127
127
|
.ant-table-row-magic {
|
128
128
|
background-color: rgba(114, 46, 209, 0.1) ;
|
129
|
-
|
129
|
+
|
130
130
|
&:hover {
|
131
131
|
background-color: rgba(114, 46, 209, 0.15) ;
|
132
|
-
|
132
|
+
|
133
133
|
td {
|
134
134
|
background-color: transparent ;
|
135
135
|
}
|
136
136
|
}
|
137
|
-
|
137
|
+
|
138
138
|
// 选中状态
|
139
139
|
&.ant-table-row-selected {
|
140
140
|
background-color: rgba(114, 46, 209, 0.2) ;
|
141
|
-
|
141
|
+
|
142
142
|
td {
|
143
143
|
background-color: transparent ;
|
144
144
|
}
|
145
145
|
}
|
146
|
-
|
146
|
+
|
147
147
|
td {
|
148
148
|
background-color: transparent ;
|
149
149
|
}
|
150
150
|
}
|
151
|
-
|
151
|
+
|
152
152
|
// 默认选中状态(没有特殊行样式时)
|
153
153
|
.ant-table-row-selected:not(.ant-table-row-success):not(.ant-table-row-warning):not(.ant-table-row-error):not(.ant-table-row-magic) {
|
154
154
|
background-color: rgba(24, 144, 255, 0.1) ;
|
@@ -173,6 +173,14 @@ ol {
|
|
173
173
|
margin: 2px 0;
|
174
174
|
}
|
175
175
|
|
176
|
+
#XAddNativeForm {
|
177
|
+
// 日期选择框的样式
|
178
|
+
.ant-calendar-picker {
|
179
|
+
min-width: 0 !important;
|
180
|
+
width: 100% !important;
|
181
|
+
}
|
182
|
+
}
|
183
|
+
|
176
184
|
// 数据列表 搜索条件 form表单样式
|
177
185
|
.table-page-search-wrapper {
|
178
186
|
|
package/src/utils/map-utils.js
CHANGED
@@ -1,47 +1,47 @@
|
|
1
|
-
import AMapLoader from '@amap/amap-jsapi-loader'
|
2
|
-
let Amap
|
3
|
-
async function GetGDMap (secretKey, key) {
|
4
|
-
if (!Amap) {
|
5
|
-
window._AMapSecurityConfig = {
|
6
|
-
securityJsCode: secretKey
|
7
|
-
}
|
8
|
-
// 解决高德地图加载报错 ---> 禁止多种API加载方式混用
|
9
|
-
AMapLoader.reset()
|
10
|
-
Amap = await AMapLoader.load({
|
11
|
-
key: key, // 申请好的Web端开发者Key,首次调用 load 时必填
|
12
|
-
version: '2.0', // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
|
13
|
-
plugins: ['AMap.IndexCluster', 'AMP.MarkerCluster', 'AMap.InfoWindow', 'AMap.HeatMap', 'AMap.HawkEye', 'AMap.DistrictSearch',
|
14
|
-
'AMap.ToolBar', 'AMap.Geolocation', 'AMap.MouseTool',
|
15
|
-
'AMap.Geocoder', 'AMap.MarkerClusterer', 'AMap.AutoComplete', 'AMap.Scale'], // 需要使用的的插件列表,如比例尺'AMap.Scale'等
|
16
|
-
AMapUI: {
|
17
|
-
version: '1.1', // AMapUI 缺省 1.1
|
18
|
-
plugins: ['misc/PositionPicker'] // 需要加载的 AMapUI ui插件
|
19
|
-
}
|
20
|
-
})
|
21
|
-
}
|
22
|
-
return Amap
|
23
|
-
}
|
24
|
-
|
25
|
-
async function getGDMap (address) {
|
26
|
-
new (await GetGDMap()).Geocoder({
|
27
|
-
radius: 500 // 范围,默认:500
|
28
|
-
}).getLocation(address, function (status, result) {
|
29
|
-
if (status === 'complete' && result.geocodes.length) {
|
30
|
-
return ({ lng: result.geocodes[0].location.lng, lat: result.geocodes[0].location.lat })
|
31
|
-
} else {
|
32
|
-
// eslint-disable-next-line prefer-promise-reject-errors
|
33
|
-
throw new Error('根据经纬度查询地址失败')
|
34
|
-
}
|
35
|
-
})
|
36
|
-
}
|
37
|
-
|
38
|
-
async function GetLocation (address) {
|
39
|
-
return new Promise((resolve, reject) => {
|
40
|
-
try {
|
41
|
-
resolve(getGDMap(address))
|
42
|
-
} catch (e) {
|
43
|
-
reject(e)
|
44
|
-
}
|
45
|
-
})
|
46
|
-
}
|
47
|
-
export { GetGDMap, GetLocation }
|
1
|
+
import AMapLoader from '@amap/amap-jsapi-loader'
|
2
|
+
let Amap
|
3
|
+
async function GetGDMap (secretKey, key) {
|
4
|
+
if (!Amap) {
|
5
|
+
window._AMapSecurityConfig = {
|
6
|
+
securityJsCode: secretKey
|
7
|
+
}
|
8
|
+
// 解决高德地图加载报错 ---> 禁止多种API加载方式混用
|
9
|
+
AMapLoader.reset()
|
10
|
+
Amap = await AMapLoader.load({
|
11
|
+
key: key, // 申请好的Web端开发者Key,首次调用 load 时必填
|
12
|
+
version: '2.0', // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
|
13
|
+
plugins: ['AMap.IndexCluster', 'AMP.MarkerCluster', 'AMap.InfoWindow', 'AMap.HeatMap', 'AMap.HawkEye', 'AMap.DistrictSearch',
|
14
|
+
'AMap.ToolBar', 'AMap.Geolocation', 'AMap.MouseTool',
|
15
|
+
'AMap.Geocoder', 'AMap.MarkerClusterer', 'AMap.AutoComplete', 'AMap.Scale'], // 需要使用的的插件列表,如比例尺'AMap.Scale'等
|
16
|
+
AMapUI: {
|
17
|
+
version: '1.1', // AMapUI 缺省 1.1
|
18
|
+
plugins: ['misc/PositionPicker'] // 需要加载的 AMapUI ui插件
|
19
|
+
}
|
20
|
+
})
|
21
|
+
}
|
22
|
+
return Amap
|
23
|
+
}
|
24
|
+
|
25
|
+
async function getGDMap (address) {
|
26
|
+
new (await GetGDMap()).Geocoder({
|
27
|
+
radius: 500 // 范围,默认:500
|
28
|
+
}).getLocation(address, function (status, result) {
|
29
|
+
if (status === 'complete' && result.geocodes.length) {
|
30
|
+
return ({ lng: result.geocodes[0].location.lng, lat: result.geocodes[0].location.lat })
|
31
|
+
} else {
|
32
|
+
// eslint-disable-next-line prefer-promise-reject-errors
|
33
|
+
throw new Error('根据经纬度查询地址失败')
|
34
|
+
}
|
35
|
+
})
|
36
|
+
}
|
37
|
+
|
38
|
+
async function GetLocation (address) {
|
39
|
+
return new Promise((resolve, reject) => {
|
40
|
+
try {
|
41
|
+
resolve(getGDMap(address))
|
42
|
+
} catch (e) {
|
43
|
+
reject(e)
|
44
|
+
}
|
45
|
+
})
|
46
|
+
}
|
47
|
+
export { GetGDMap, GetLocation }
|