mirror of
https://github.com/mayswind/ezbookkeeping.git
synced 2026-05-20 17:54:30 +08:00
support google map
This commit is contained in:
@@ -111,12 +111,15 @@ enable_register = true
|
|||||||
enable_export = true
|
enable_export = true
|
||||||
|
|
||||||
[map]
|
[map]
|
||||||
# Map provider, supports "openstreetmap", "baidumap". Leave blank if you want to disable map
|
# Map provider, supports "openstreetmap", "googlemap", "baidumap" Leave blank if you want to disable map
|
||||||
map_provider = openstreetmap
|
map_provider = openstreetmap
|
||||||
|
|
||||||
# Set to true to use the ezbookkeeping server to proxy map data requests, for "openstreetmap"
|
# Set to true to use the ezbookkeeping server to proxy map data requests, for "openstreetmap"
|
||||||
map_data_fetch_proxy = false
|
map_data_fetch_proxy = false
|
||||||
|
|
||||||
|
# For "googlemap" only, Google map API key, please visit https://developers.google.com/maps/get-started for more information
|
||||||
|
google_map_api_key =
|
||||||
|
|
||||||
# For "baidumap" only, Baidu map javascript api application key, please visit https://lbsyun.baidu.com/index.php?title=jspopular3.0/guide/getkey for more information
|
# For "baidumap" only, Baidu map javascript api application key, please visit https://lbsyun.baidu.com/index.php?title=jspopular3.0/guide/getkey for more information
|
||||||
baidu_map_ak =
|
baidu_map_ak =
|
||||||
|
|
||||||
|
|||||||
@@ -23,6 +23,10 @@ func ServerSettingsCookie(config *settings.Config) core.MiddlewareHandlerFunc {
|
|||||||
settingsArr = append(settingsArr, buildBooleanSetting("mp", config.EnableMapDataFetchProxy))
|
settingsArr = append(settingsArr, buildBooleanSetting("mp", config.EnableMapDataFetchProxy))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if config.GoogleMapAPIKey != "" {
|
||||||
|
settingsArr = append(settingsArr, buildStringSetting("gmak", config.GoogleMapAPIKey))
|
||||||
|
}
|
||||||
|
|
||||||
if config.BaiduMapAK != "" {
|
if config.BaiduMapAK != "" {
|
||||||
settingsArr = append(settingsArr, buildStringSetting("bmak", config.BaiduMapAK))
|
settingsArr = append(settingsArr, buildStringSetting("bmak", config.BaiduMapAK))
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -65,6 +65,7 @@ const (
|
|||||||
// Map provider types
|
// Map provider types
|
||||||
const (
|
const (
|
||||||
OpenStreetMapProvider string = "openstreetmap"
|
OpenStreetMapProvider string = "openstreetmap"
|
||||||
|
GoogleMapProvider string = "googlemap"
|
||||||
BaiduMapProvider string = "baidumap"
|
BaiduMapProvider string = "baidumap"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -177,6 +178,7 @@ type Config struct {
|
|||||||
|
|
||||||
// Map
|
// Map
|
||||||
MapProvider string
|
MapProvider string
|
||||||
|
GoogleMapAPIKey string
|
||||||
BaiduMapAK string
|
BaiduMapAK string
|
||||||
EnableMapDataFetchProxy bool
|
EnableMapDataFetchProxy bool
|
||||||
|
|
||||||
@@ -438,6 +440,8 @@ func loadMapConfiguration(config *Config, configFile *ini.File, sectionName stri
|
|||||||
config.MapProvider = ""
|
config.MapProvider = ""
|
||||||
} else if getConfigItemStringValue(configFile, sectionName, "map_provider") == OpenStreetMapProvider {
|
} else if getConfigItemStringValue(configFile, sectionName, "map_provider") == OpenStreetMapProvider {
|
||||||
config.MapProvider = OpenStreetMapProvider
|
config.MapProvider = OpenStreetMapProvider
|
||||||
|
} else if getConfigItemStringValue(configFile, sectionName, "map_provider") == GoogleMapProvider {
|
||||||
|
config.MapProvider = GoogleMapProvider
|
||||||
} else if getConfigItemStringValue(configFile, sectionName, "map_provider") == BaiduMapProvider {
|
} else if getConfigItemStringValue(configFile, sectionName, "map_provider") == BaiduMapProvider {
|
||||||
config.MapProvider = BaiduMapProvider
|
config.MapProvider = BaiduMapProvider
|
||||||
} else {
|
} else {
|
||||||
@@ -445,6 +449,7 @@ func loadMapConfiguration(config *Config, configFile *ini.File, sectionName stri
|
|||||||
}
|
}
|
||||||
|
|
||||||
config.EnableMapDataFetchProxy = getConfigItemBoolValue(configFile, sectionName, "map_data_fetch_proxy", false)
|
config.EnableMapDataFetchProxy = getConfigItemBoolValue(configFile, sectionName, "map_data_fetch_proxy", false)
|
||||||
|
config.GoogleMapAPIKey = getConfigItemStringValue(configFile, sectionName, "google_map_api_key")
|
||||||
config.BaiduMapAK = getConfigItemStringValue(configFile, sectionName, "baidu_map_ak")
|
config.BaiduMapAK = getConfigItemStringValue(configFile, sectionName, "baidu_map_ak")
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
|
|||||||
+2
-1
@@ -145,7 +145,8 @@ export default {
|
|||||||
});
|
});
|
||||||
|
|
||||||
document.addEventListener('DOMContentLoaded', () => {
|
document.addEventListener('DOMContentLoaded', () => {
|
||||||
loadMapAssets();
|
const languageInfo = this.$locale.getCurrentLanguageInfo();
|
||||||
|
loadMapAssets(languageInfo ? languageInfo.code : null);
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
|||||||
@@ -8,10 +8,10 @@
|
|||||||
<f7-link :text="$t('Done')" @click="save"></f7-link>
|
<f7-link :text="$t('Done')" @click="save"></f7-link>
|
||||||
</div>
|
</div>
|
||||||
</f7-toolbar>
|
</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>
|
<div ref="map" style="height: 400px; width: 100%"></div>
|
||||||
</f7-page-content>
|
</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="display-flex padding justify-content-space-between align-items-center">
|
||||||
<div class="ebk-sheet-title"><b>{{ mapErrorTitle }}</b></div>
|
<div class="ebk-sheet-title"><b>{{ mapErrorTitle }}</b></div>
|
||||||
</div>
|
</div>
|
||||||
@@ -44,8 +44,12 @@ export default {
|
|||||||
'update:show'
|
'update:show'
|
||||||
],
|
],
|
||||||
data() {
|
data() {
|
||||||
|
this.mapHolder = createMapHolder();
|
||||||
|
|
||||||
return {
|
return {
|
||||||
mapHolder: createMapHolder(),
|
mapSupported: !!this.mapHolder,
|
||||||
|
mapDependencyLoaded: this.mapHolder.dependencyLoaded,
|
||||||
|
mapInited: false,
|
||||||
initCenter: {
|
initCenter: {
|
||||||
latitude: 0,
|
latitude: 0,
|
||||||
longitude: 0,
|
longitude: 0,
|
||||||
@@ -54,15 +58,12 @@ export default {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
dependencyLoaded() {
|
|
||||||
return this.mapHolder && this.mapHolder.dependencyLoaded;
|
|
||||||
},
|
|
||||||
mapErrorTitle() {
|
mapErrorTitle() {
|
||||||
if (!this.mapHolder) {
|
if (!this.mapSupported) {
|
||||||
return this.$t('Unsupported Map Provider');
|
return this.$t('Unsupported Map Provider');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!this.dependencyLoaded) {
|
if (!this.mapDependencyLoaded) {
|
||||||
return this.$t('Cannot Initialize Map');
|
return this.$t('Cannot Initialize Map');
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -80,7 +81,7 @@ export default {
|
|||||||
let isFirstInit = false;
|
let isFirstInit = false;
|
||||||
let centerChanged = false;
|
let centerChanged = false;
|
||||||
|
|
||||||
if (!this.mapHolder || !this.mapHolder.dependencyLoaded) {
|
if (!this.mapSupported || !this.mapDependencyLoaded) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -104,6 +105,8 @@ export default {
|
|||||||
|
|
||||||
if (!this.mapHolder.inited) {
|
if (!this.mapHolder.inited) {
|
||||||
initMapInstance(this.mapHolder, this.$refs.map, {
|
initMapInstance(this.mapHolder, this.$refs.map, {
|
||||||
|
initCenter: this.initCenter,
|
||||||
|
zoomLevel: this.zoomLevel,
|
||||||
text: {
|
text: {
|
||||||
zoomIn: this.$t('Zoom in'),
|
zoomIn: this.$t('Zoom in'),
|
||||||
zoomOut: this.$t('Zoom out'),
|
zoomOut: this.$t('Zoom out'),
|
||||||
|
|||||||
@@ -1,9 +1,11 @@
|
|||||||
const baseApiUrlPath = '/api';
|
const baseApiUrlPath = '/api';
|
||||||
const baseProxyUrlPath = '/proxy';
|
const baseProxyUrlPath = '/proxy';
|
||||||
|
const googleMapJavascriptUrl = 'https://maps.googleapis.com/maps/api/js';
|
||||||
const baiduMapJavascriptUrl = 'https://api.map.baidu.com/api?v=3.0';
|
const baiduMapJavascriptUrl = 'https://api.map.baidu.com/api?v=3.0';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
baseApiUrlPath: baseApiUrlPath,
|
baseApiUrlPath: baseApiUrlPath,
|
||||||
baseProxyUrlPath: baseProxyUrlPath,
|
baseProxyUrlPath: baseProxyUrlPath,
|
||||||
|
googleMapJavascriptUrl: googleMapJavascriptUrl,
|
||||||
baiduMapJavascriptUrl: baiduMapJavascriptUrl
|
baiduMapJavascriptUrl: baiduMapJavascriptUrl
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
@@ -9,6 +9,15 @@ import {
|
|||||||
removeLeafletMapCenterMaker
|
removeLeafletMapCenterMaker
|
||||||
} from './openstreetmap.js';
|
} from './openstreetmap.js';
|
||||||
|
|
||||||
|
import {
|
||||||
|
loadGoogleMapAssets,
|
||||||
|
createGoogleMapHolder,
|
||||||
|
createGoogleMapInstance,
|
||||||
|
setGoogleMapCenterTo,
|
||||||
|
setGoogleMapCenterMaker,
|
||||||
|
removeGoogleMapCenterMaker
|
||||||
|
} from './googlemap.js';
|
||||||
|
|
||||||
import {
|
import {
|
||||||
loadBaiduMapAssets,
|
loadBaiduMapAssets,
|
||||||
createBaiduMapHolder,
|
createBaiduMapHolder,
|
||||||
@@ -18,17 +27,21 @@ import {
|
|||||||
removeBaiduMapCenterMaker
|
removeBaiduMapCenterMaker
|
||||||
} from './baidumap.js';
|
} from './baidumap.js';
|
||||||
|
|
||||||
export function loadMapAssets() {
|
export function loadMapAssets(language) {
|
||||||
if (settings.getMapProvider() === 'openstreetmap') {
|
if (settings.getMapProvider() === 'openstreetmap') {
|
||||||
return loadLeafletMapAssets();
|
return loadLeafletMapAssets(language);
|
||||||
|
} else if (settings.getMapProvider() === 'googlemap') {
|
||||||
|
return loadGoogleMapAssets(language);
|
||||||
} else if (settings.getMapProvider() === 'baidumap') {
|
} else if (settings.getMapProvider() === 'baidumap') {
|
||||||
return loadBaiduMapAssets();
|
return loadBaiduMapAssets(language);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export function createMapHolder() {
|
export function createMapHolder() {
|
||||||
if (settings.getMapProvider() === 'openstreetmap') {
|
if (settings.getMapProvider() === 'openstreetmap') {
|
||||||
return createLeafletMapHolder();
|
return createLeafletMapHolder();
|
||||||
|
} else if (settings.getMapProvider() === 'googlemap') {
|
||||||
|
return createGoogleMapHolder();
|
||||||
} else if (settings.getMapProvider() === 'baidumap') {
|
} else if (settings.getMapProvider() === 'baidumap') {
|
||||||
return createBaiduMapHolder();
|
return createBaiduMapHolder();
|
||||||
} else {
|
} else {
|
||||||
@@ -43,6 +56,8 @@ export function initMapInstance(mapHolder, mapContainer, options) {
|
|||||||
|
|
||||||
if (mapHolder.mapProvider === 'openstreetmap') {
|
if (mapHolder.mapProvider === 'openstreetmap') {
|
||||||
createLeafletMapInstance(mapHolder, mapContainer, options);
|
createLeafletMapInstance(mapHolder, mapContainer, options);
|
||||||
|
} else if (mapHolder.mapProvider === 'googlemap') {
|
||||||
|
createGoogleMapInstance(mapHolder, mapContainer, options);
|
||||||
} else if (mapHolder.mapProvider === 'baidumap') {
|
} else if (mapHolder.mapProvider === 'baidumap') {
|
||||||
createBaiduMapInstance(mapHolder, mapContainer, options);
|
createBaiduMapInstance(mapHolder, mapContainer, options);
|
||||||
}
|
}
|
||||||
@@ -55,6 +70,8 @@ export function setMapCenterTo(mapHolder, center, zoomLevel) {
|
|||||||
|
|
||||||
if (mapHolder.mapProvider === 'openstreetmap') {
|
if (mapHolder.mapProvider === 'openstreetmap') {
|
||||||
setLeafletMapCenterTo(mapHolder, center, zoomLevel);
|
setLeafletMapCenterTo(mapHolder, center, zoomLevel);
|
||||||
|
} else if (mapHolder.mapProvider === 'googlemap') {
|
||||||
|
setGoogleMapCenterTo(mapHolder, center, zoomLevel);
|
||||||
} else if (mapHolder.mapProvider === 'baidumap') {
|
} else if (mapHolder.mapProvider === 'baidumap') {
|
||||||
setBaiduMapCenterTo(mapHolder, center, zoomLevel);
|
setBaiduMapCenterTo(mapHolder, center, zoomLevel);
|
||||||
}
|
}
|
||||||
@@ -67,6 +84,8 @@ export function setMapCenterMarker(mapHolder, position) {
|
|||||||
|
|
||||||
if (mapHolder.mapProvider === 'openstreetmap') {
|
if (mapHolder.mapProvider === 'openstreetmap') {
|
||||||
setLeafletMapCenterMaker(mapHolder, position);
|
setLeafletMapCenterMaker(mapHolder, position);
|
||||||
|
} else if (mapHolder.mapProvider === 'googlemap') {
|
||||||
|
setGoogleMapCenterMaker(mapHolder, position);
|
||||||
} else if (mapHolder.mapProvider === 'baidumap') {
|
} else if (mapHolder.mapProvider === 'baidumap') {
|
||||||
setBaiduMapCenterMaker(mapHolder, position);
|
setBaiduMapCenterMaker(mapHolder, position);
|
||||||
}
|
}
|
||||||
@@ -79,6 +98,8 @@ export function removeMapCenterMarker(mapHolder) {
|
|||||||
|
|
||||||
if (mapHolder.mapProvider === 'openstreetmap') {
|
if (mapHolder.mapProvider === 'openstreetmap') {
|
||||||
removeLeafletMapCenterMaker(mapHolder);
|
removeLeafletMapCenterMaker(mapHolder);
|
||||||
|
} else if (mapHolder.mapProvider === 'googlemap') {
|
||||||
|
removeGoogleMapCenterMaker(mapHolder);
|
||||||
} else if (mapHolder.mapProvider === 'baidumap') {
|
} else if (mapHolder.mapProvider === 'baidumap') {
|
||||||
removeBaiduMapCenterMaker(mapHolder);
|
removeBaiduMapCenterMaker(mapHolder);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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) => {
|
generateBaiduMapJavascriptUrl: (callbackFnName) => {
|
||||||
return `${api.baiduMapJavascriptUrl}&ak=${settings.getBaiduMapAK()}&callback=${callbackFnName}`;
|
return `${api.baiduMapJavascriptUrl}&ak=${settings.getBaiduMapAK()}&callback=${callbackFnName}`;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -169,6 +169,7 @@ export default {
|
|||||||
isDataExportingEnabled: () => getServerSetting('e') === '1',
|
isDataExportingEnabled: () => getServerSetting('e') === '1',
|
||||||
getMapProvider: () => getServerSetting('m'),
|
getMapProvider: () => getServerSetting('m'),
|
||||||
isMapDataFetchProxyEnabled: () => getServerSetting('mp') === '1',
|
isMapDataFetchProxyEnabled: () => getServerSetting('mp') === '1',
|
||||||
|
getGoogleMapAPIKey: () => getServerSetting('gmak'),
|
||||||
getBaiduMapAK: () => getServerSetting('bmak'),
|
getBaiduMapAK: () => getServerSetting('bmak'),
|
||||||
clearSettings: clearSettings
|
clearSettings: clearSettings
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user