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:
Dean 2022-03-10 12:48:49 +00:00
parent 13627136cf
commit 482684c6e7
4 changed files with 61 additions and 26 deletions

View File

@ -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"
} }
] ]
}, },

View File

@ -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: "&copy; " + mapAttribution, //No attribution, warning?
'&copy; <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>

View File

@ -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"