Added the default location behaviour back in. Added in a Map Attribution field for users who alter their tile url. Some refactoring based on feedback
This commit is contained in:
parent
13627136cf
commit
482684c6e7
|
@ -2499,7 +2499,7 @@
|
||||||
"type": "boolean",
|
"type": "boolean",
|
||||||
"label": "Enable Location",
|
"label": "Enable Location",
|
||||||
"key": "locationEnabled",
|
"key": "locationEnabled",
|
||||||
"defaultValue": false
|
"defaultValue": true
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"type": "boolean",
|
"type": "boolean",
|
||||||
|
@ -2535,6 +2535,18 @@
|
||||||
"label": "Tile URL",
|
"label": "Tile URL",
|
||||||
"key": "tileURL",
|
"key": "tileURL",
|
||||||
"defaultValue": "https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
|
"defaultValue": "https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"label": "Default Location (lat,lng)",
|
||||||
|
"key": "defaultLocation",
|
||||||
|
"defaultValue": "51.5072,-0.1276"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"label": "Map Attribution",
|
||||||
|
"key": "mapAttribution",
|
||||||
|
"defaultValue": "OpenStreetMap contributors"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
|
|
@ -20,13 +20,16 @@
|
||||||
export let titleKey = null
|
export let titleKey = null
|
||||||
export let fullScreenEnabled = true
|
export let fullScreenEnabled = true
|
||||||
export let locationEnabled = true
|
export let locationEnabled = true
|
||||||
|
export let defaultLocation
|
||||||
export let tileURL = "https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
|
export let tileURL = "https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png"
|
||||||
|
export let mapAttribution
|
||||||
|
|
||||||
const { styleable, notificationStore } = getContext("sdk")
|
const { styleable, notificationStore } = getContext("sdk")
|
||||||
const component = getContext("component")
|
const component = getContext("component")
|
||||||
const embeddedMapId = `${Helpers.uuid()}-wrapper`
|
const embeddedMapId = `${Helpers.uuid()}-wrapper`
|
||||||
|
|
||||||
let cachedDeviceCoordinates
|
let cachedDeviceCoordinates
|
||||||
|
const fallbackCoordinates = [51.5072, -0.1276] //London
|
||||||
|
|
||||||
let mapInstance
|
let mapInstance
|
||||||
let mapMarkerGroup = new L.FeatureGroup()
|
let mapMarkerGroup = new L.FeatureGroup()
|
||||||
|
@ -38,6 +41,14 @@
|
||||||
? 72
|
? 72
|
||||||
: Math.round(zoomLevel * (maxZoomLevel / 100))
|
: Math.round(zoomLevel * (maxZoomLevel / 100))
|
||||||
|
|
||||||
|
$: zoomControlUpdated(mapInstance, zoomEnabled)
|
||||||
|
$: locationControlUpdated(mapInstance, locationEnabled)
|
||||||
|
$: fullScreenControlUpdated(mapInstance, fullScreenEnabled)
|
||||||
|
$: updateMapDimensions(
|
||||||
|
mapInstance,
|
||||||
|
$component.styles.normal.width,
|
||||||
|
$component.styles.normal.height
|
||||||
|
)
|
||||||
$: addMapMarkers(
|
$: addMapMarkers(
|
||||||
mapInstance,
|
mapInstance,
|
||||||
dataProvider?.rows,
|
dataProvider?.rows,
|
||||||
|
@ -47,16 +58,10 @@
|
||||||
)
|
)
|
||||||
$: if (typeof mapInstance === "object" && mapMarkers.length > 0) {
|
$: if (typeof mapInstance === "object" && mapMarkers.length > 0) {
|
||||||
mapInstance.setZoom(0)
|
mapInstance.setZoom(0)
|
||||||
mapInstance.fitBounds(mapMarkerGroup.getBounds())
|
mapInstance.fitBounds(mapMarkerGroup.getBounds(), {
|
||||||
|
paddingTopLeft: [0, 24],
|
||||||
|
})
|
||||||
}
|
}
|
||||||
$: zoomControlUpdated(mapInstance, zoomEnabled)
|
|
||||||
$: locationControlUpdated(mapInstance, locationEnabled)
|
|
||||||
$: fullScreenControlUpdated(mapInstance, fullScreenEnabled)
|
|
||||||
$: updateMapDimensions(
|
|
||||||
mapInstance,
|
|
||||||
$component.styles.normal.width,
|
|
||||||
$component.styles.normal.height
|
|
||||||
)
|
|
||||||
|
|
||||||
const updateMapDimensions = mapInstance => {
|
const updateMapDimensions = mapInstance => {
|
||||||
if (typeof mapInstance !== "object") {
|
if (typeof mapInstance !== "object") {
|
||||||
|
@ -65,6 +70,37 @@
|
||||||
mapInstance.invalidateSize()
|
mapInstance.invalidateSize()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let isValidLatitude = value => {
|
||||||
|
return !isNaN(value) && value > -90 && value < 90
|
||||||
|
}
|
||||||
|
|
||||||
|
let isValidLongitude = value => {
|
||||||
|
return !isNaN(value) && value > -180 && value < 180
|
||||||
|
}
|
||||||
|
|
||||||
|
const parseDefaultLocation = defaultLocation => {
|
||||||
|
if (typeof defaultLocation !== "string") {
|
||||||
|
return fallbackCoordinates
|
||||||
|
}
|
||||||
|
let defaultLocationParts = defaultLocation.split(",")
|
||||||
|
if (defaultLocationParts.length !== 2) {
|
||||||
|
return fallbackCoordinates
|
||||||
|
}
|
||||||
|
|
||||||
|
let parsedDefaultLatitude = parseFloat(defaultLocationParts[0].trim())
|
||||||
|
let parsedDefaultLongitude = parseFloat(defaultLocationParts[1].trim())
|
||||||
|
|
||||||
|
return isValidLatitude(parsedDefaultLatitude) === true &&
|
||||||
|
isValidLongitude(parsedDefaultLongitude) === true
|
||||||
|
? [parsedDefaultLatitude, parsedDefaultLongitude]
|
||||||
|
: fallbackCoordinates
|
||||||
|
}
|
||||||
|
|
||||||
|
$: defaultCoordinates =
|
||||||
|
mapMarkers.length > 0
|
||||||
|
? parseDefaultLocation(defaultLocation)
|
||||||
|
: fallbackCoordinates
|
||||||
|
|
||||||
// Map Button Controls
|
// Map Button Controls
|
||||||
let locationControl = new LocationControl({
|
let locationControl = new LocationControl({
|
||||||
position: "bottomright",
|
position: "bottomright",
|
||||||
|
@ -165,14 +201,6 @@
|
||||||
|
|
||||||
mapMarkerGroup.clearLayers()
|
mapMarkerGroup.clearLayers()
|
||||||
|
|
||||||
let isValidLatitude = value => {
|
|
||||||
return !isNaN(value) && value > -90 && value < 90
|
|
||||||
}
|
|
||||||
|
|
||||||
let isValidLongitude = value => {
|
|
||||||
return !isNaN(value) && value > -180 && value < 180
|
|
||||||
}
|
|
||||||
|
|
||||||
const validRows = rows.filter(row => {
|
const validRows = rows.filter(row => {
|
||||||
return isValidLatitude(row[latKey]) && isValidLongitude(row[lngKey])
|
return isValidLatitude(row[latKey]) && isValidLongitude(row[lngKey])
|
||||||
})
|
})
|
||||||
|
@ -203,14 +231,13 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
const initMap = () => {
|
const initMap = () => {
|
||||||
const initCoords = [51.5072, -0.1276]
|
const initCoords = defaultCoordinates
|
||||||
|
|
||||||
mapInstance = L.map(embeddedMapId, mapOptions)
|
mapInstance = L.map(embeddedMapId, mapOptions)
|
||||||
mapMarkerGroup.addTo(mapInstance)
|
mapMarkerGroup.addTo(mapInstance)
|
||||||
|
|
||||||
L.tileLayer(tileURL, {
|
L.tileLayer(tileURL, {
|
||||||
attribution:
|
attribution: "© " + mapAttribution, //No attribution, warning?
|
||||||
'© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors',
|
|
||||||
zoom: adjustedZoomLevel,
|
zoom: adjustedZoomLevel,
|
||||||
}).addTo(mapInstance)
|
}).addTo(mapInstance)
|
||||||
|
|
||||||
|
@ -259,8 +286,4 @@
|
||||||
height: 100%;
|
height: 100%;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
:global(.leaflet-tile) {
|
|
||||||
width: 258px !important;
|
|
||||||
height: 258px !important;
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
|
@ -31,7 +31,7 @@ export { default as cardstat } from "./CardStat.svelte"
|
||||||
export { default as spectrumcard } from "./SpectrumCard.svelte"
|
export { default as spectrumcard } from "./SpectrumCard.svelte"
|
||||||
export { default as tag } from "./Tag.svelte"
|
export { default as tag } from "./Tag.svelte"
|
||||||
export { default as markdownviewer } from "./MarkdownViewer.svelte"
|
export { default as markdownviewer } from "./MarkdownViewer.svelte"
|
||||||
export { default as embeddedmap } from "./EmbeddedMap.svelte"
|
export { default as embeddedmap } from "./embedded-map/EmbeddedMap.svelte"
|
||||||
export * from "./charts"
|
export * from "./charts"
|
||||||
export * from "./forms"
|
export * from "./forms"
|
||||||
export * from "./table"
|
export * from "./table"
|
||||||
|
|
Loading…
Reference in New Issue