support google map

This commit is contained in:
MaysWind
2023-06-17 23:14:09 +08:00
parent 38baf77c30
commit a5dbf5d4b7
10 changed files with 170 additions and 14 deletions
+2 -1
View File
@@ -145,7 +145,8 @@ export default {
});
document.addEventListener('DOMContentLoaded', () => {
loadMapAssets();
const languageInfo = this.$locale.getCurrentLanguageInfo();
loadMapAssets(languageInfo ? languageInfo.code : null);
});
},
methods: {
+12 -9
View File
@@ -8,10 +8,10 @@
<f7-link :text="$t('Done')" @click="save"></f7-link>
</div>
</f7-toolbar>
<f7-page-content class="no-margin-vertical no-padding-vertical" v-if="mapHolder && dependencyLoaded">
<f7-page-content class="no-margin-vertical no-padding-vertical" v-if="mapSupported && mapDependencyLoaded">
<div ref="map" style="height: 400px; width: 100%"></div>
</f7-page-content>
<f7-page-content class="no-margin-top no-padding-top" v-else-if="!mapHolder || !dependencyLoaded">
<f7-page-content class="no-margin-top no-padding-top" v-else-if="!mapSupported || !mapDependencyLoaded">
<div class="display-flex padding justify-content-space-between align-items-center">
<div class="ebk-sheet-title"><b>{{ mapErrorTitle }}</b></div>
</div>
@@ -44,8 +44,12 @@ export default {
'update:show'
],
data() {
this.mapHolder = createMapHolder();
return {
mapHolder: createMapHolder(),
mapSupported: !!this.mapHolder,
mapDependencyLoaded: this.mapHolder.dependencyLoaded,
mapInited: false,
initCenter: {
latitude: 0,
longitude: 0,
@@ -54,15 +58,12 @@ export default {
}
},
computed: {
dependencyLoaded() {
return this.mapHolder && this.mapHolder.dependencyLoaded;
},
mapErrorTitle() {
if (!this.mapHolder) {
if (!this.mapSupported) {
return this.$t('Unsupported Map Provider');
}
if (!this.dependencyLoaded) {
if (!this.mapDependencyLoaded) {
return this.$t('Cannot Initialize Map');
}
@@ -80,7 +81,7 @@ export default {
let isFirstInit = false;
let centerChanged = false;
if (!this.mapHolder || !this.mapHolder.dependencyLoaded) {
if (!this.mapSupported || !this.mapDependencyLoaded) {
return;
}
@@ -104,6 +105,8 @@ export default {
if (!this.mapHolder.inited) {
initMapInstance(this.mapHolder, this.$refs.map, {
initCenter: this.initCenter,
zoomLevel: this.zoomLevel,
text: {
zoomIn: this.$t('Zoom in'),
zoomOut: this.$t('Zoom out'),
+2
View File
@@ -1,9 +1,11 @@
const baseApiUrlPath = '/api';
const baseProxyUrlPath = '/proxy';
const googleMapJavascriptUrl = 'https://maps.googleapis.com/maps/api/js';
const baiduMapJavascriptUrl = 'https://api.map.baidu.com/api?v=3.0';
export default {
baseApiUrlPath: baseApiUrlPath,
baseProxyUrlPath: baseProxyUrlPath,
googleMapJavascriptUrl: googleMapJavascriptUrl,
baiduMapJavascriptUrl: baiduMapJavascriptUrl
}
+109
View File
@@ -0,0 +1,109 @@
import { asyncLoadAssets } from "@/lib/misc.js";
import services from "@/lib/services.js";
const googleMapHolder = {
googleMap: null,
ControlPosition: {
LEFT_TOP: (window.google && window.google.maps && window.google.maps.ControlPosition) ? window.google.maps.ControlPosition.LEFT_TOP : 5
}
};
export function loadGoogleMapAssets(language) {
if (googleMapHolder.googleMap) {
return;
}
if (!window.onGoogleMapCallback) {
window.onGoogleMapCallback = () => {
if (window.google) {
googleMapHolder.googleMap = window.google.maps;
}
};
}
return asyncLoadAssets('js', services.generateGoogleMapJavascriptUrl(language, 'onGoogleMapCallback'));
}
export function createGoogleMapHolder() {
return {
mapProvider: 'googlemap',
dependencyLoaded: !!googleMapHolder.googleMap,
inited: false,
defaultZoomLevel: 14,
minZoomLevel: 1,
googleMapInstance: null,
googleMapCenterMarker: null
};
}
export function createGoogleMapInstance(mapHolder, mapContainer, options) {
if (!googleMapHolder.googleMap) {
return null;
}
const googleMap = googleMapHolder.googleMap;
mapHolder.googleMapInstance = new googleMap.Map(mapContainer, {
zoom: options.zoomLevel,
center: {
lat: options.initCenter.latitude,
lng: options.initCenter.longitude
},
maxZoom: 19,
zoomControl: true,
mapTypeControl: false,
scaleControl: false,
streetViewControl: false,
rotateControl: false,
fullscreenControl: false,
gestureHandling: 'greedy',
zoomControlOptions: {
position: googleMapHolder.ControlPosition.LEFT_TOP
}
});
mapHolder.inited = true;
}
export function setGoogleMapCenterTo(mapHolder, center, zoomLevel) {
if (!googleMapHolder.googleMap || !mapHolder.googleMapInstance) {
return;
}
mapHolder.googleMapInstance.setCenter({
lat: center.latitude,
lng: center.longitude
});
mapHolder.googleMapInstance.setZoom(zoomLevel);
}
export function setGoogleMapCenterMaker(mapHolder, position) {
if (!googleMapHolder.googleMap || !mapHolder.googleMapInstance) {
return;
}
const googleMap = googleMapHolder.googleMap;
if (!mapHolder.googleMapCenterMarker) {
mapHolder.googleMapCenterMarker = new googleMap.Marker({
position: {
lat: position.latitude,
lng: position.longitude
},
map: mapHolder.googleMapInstance
});
} else {
mapHolder.googleMapCenterMarker.setPosition({
lat: position.latitude,
lng: position.longitude
});
}
}
export function removeGoogleMapCenterMaker(mapHolder) {
if (!mapHolder.googleMapInstance || !mapHolder.googleMapCenterMarker) {
return;
}
mapHolder.googleMapCenterMarker.setMap(null);
mapHolder.googleMapCenterMarker = null;
}
+24 -3
View File
@@ -9,6 +9,15 @@ import {
removeLeafletMapCenterMaker
} from './openstreetmap.js';
import {
loadGoogleMapAssets,
createGoogleMapHolder,
createGoogleMapInstance,
setGoogleMapCenterTo,
setGoogleMapCenterMaker,
removeGoogleMapCenterMaker
} from './googlemap.js';
import {
loadBaiduMapAssets,
createBaiduMapHolder,
@@ -18,17 +27,21 @@ import {
removeBaiduMapCenterMaker
} from './baidumap.js';
export function loadMapAssets() {
export function loadMapAssets(language) {
if (settings.getMapProvider() === 'openstreetmap') {
return loadLeafletMapAssets();
return loadLeafletMapAssets(language);
} else if (settings.getMapProvider() === 'googlemap') {
return loadGoogleMapAssets(language);
} else if (settings.getMapProvider() === 'baidumap') {
return loadBaiduMapAssets();
return loadBaiduMapAssets(language);
}
}
export function createMapHolder() {
if (settings.getMapProvider() === 'openstreetmap') {
return createLeafletMapHolder();
} else if (settings.getMapProvider() === 'googlemap') {
return createGoogleMapHolder();
} else if (settings.getMapProvider() === 'baidumap') {
return createBaiduMapHolder();
} else {
@@ -43,6 +56,8 @@ export function initMapInstance(mapHolder, mapContainer, options) {
if (mapHolder.mapProvider === 'openstreetmap') {
createLeafletMapInstance(mapHolder, mapContainer, options);
} else if (mapHolder.mapProvider === 'googlemap') {
createGoogleMapInstance(mapHolder, mapContainer, options);
} else if (mapHolder.mapProvider === 'baidumap') {
createBaiduMapInstance(mapHolder, mapContainer, options);
}
@@ -55,6 +70,8 @@ export function setMapCenterTo(mapHolder, center, zoomLevel) {
if (mapHolder.mapProvider === 'openstreetmap') {
setLeafletMapCenterTo(mapHolder, center, zoomLevel);
} else if (mapHolder.mapProvider === 'googlemap') {
setGoogleMapCenterTo(mapHolder, center, zoomLevel);
} else if (mapHolder.mapProvider === 'baidumap') {
setBaiduMapCenterTo(mapHolder, center, zoomLevel);
}
@@ -67,6 +84,8 @@ export function setMapCenterMarker(mapHolder, position) {
if (mapHolder.mapProvider === 'openstreetmap') {
setLeafletMapCenterMaker(mapHolder, position);
} else if (mapHolder.mapProvider === 'googlemap') {
setGoogleMapCenterMaker(mapHolder, position);
} else if (mapHolder.mapProvider === 'baidumap') {
setBaiduMapCenterMaker(mapHolder, position);
}
@@ -79,6 +98,8 @@ export function removeMapCenterMarker(mapHolder) {
if (mapHolder.mapProvider === 'openstreetmap') {
removeLeafletMapCenterMaker(mapHolder);
} else if (mapHolder.mapProvider === 'googlemap') {
removeGoogleMapCenterMaker(mapHolder);
} else if (mapHolder.mapProvider === 'baidumap') {
removeBaiduMapCenterMaker(mapHolder);
}
+7
View File
@@ -411,6 +411,13 @@ export default {
};
}
},
generateGoogleMapJavascriptUrl: (language, callbackFnName) => {
if (language) {
return `${api.googleMapJavascriptUrl}?key=${settings.getGoogleMapAPIKey()}&language=${language}&callback=${callbackFnName}`;
} else {
return `${api.googleMapJavascriptUrl}?key=${settings.getGoogleMapAPIKey()}&callback=${callbackFnName}`;
}
},
generateBaiduMapJavascriptUrl: (callbackFnName) => {
return `${api.baiduMapJavascriptUrl}&ak=${settings.getBaiduMapAK()}&callback=${callbackFnName}`;
}
+1
View File
@@ -169,6 +169,7 @@ export default {
isDataExportingEnabled: () => getServerSetting('e') === '1',
getMapProvider: () => getServerSetting('m'),
isMapDataFetchProxyEnabled: () => getServerSetting('mp') === '1',
getGoogleMapAPIKey: () => getServerSetting('gmak'),
getBaiduMapAK: () => getServerSetting('bmak'),
clearSettings: clearSettings
};