mirror of
https://github.com/immich-app/immich.git
synced 2025-07-31 15:08:44 -04:00
feat(web): better coordinate parsing (#19832)
feat: better coordinate parsing
This commit is contained in:
parent
82c3165247
commit
daea57f7d2
7
web/package-lock.json
generated
7
web/package-lock.json
generated
@ -25,6 +25,7 @@
|
||||
"async-mutex": "^0.5.0",
|
||||
"dom-to-image": "^2.6.0",
|
||||
"fabric": "^6.5.4",
|
||||
"geo-coordinates-parser": "^1.7.4",
|
||||
"geojson": "^0.5.0",
|
||||
"handlebars": "^4.7.8",
|
||||
"happy-dom": "^18.0.1",
|
||||
@ -5778,6 +5779,12 @@
|
||||
"node": ">=10"
|
||||
}
|
||||
},
|
||||
"node_modules/geo-coordinates-parser": {
|
||||
"version": "1.7.4",
|
||||
"resolved": "https://registry.npmjs.org/geo-coordinates-parser/-/geo-coordinates-parser-1.7.4.tgz",
|
||||
"integrity": "sha512-gVGxBW+s1csexXVMf5bIwz3TH9n4sCEglOOOqmrPk8YazUI5f79jCowKjTw05m/0h1//3+Z2m/nv8IIozgZyUw==",
|
||||
"license": "MIT"
|
||||
},
|
||||
"node_modules/geojson": {
|
||||
"version": "0.5.0",
|
||||
"resolved": "https://registry.npmjs.org/geojson/-/geojson-0.5.0.tgz",
|
||||
|
@ -42,6 +42,7 @@
|
||||
"async-mutex": "^0.5.0",
|
||||
"dom-to-image": "^2.6.0",
|
||||
"fabric": "^6.5.4",
|
||||
"geo-coordinates-parser": "^1.7.4",
|
||||
"geojson": "^0.5.0",
|
||||
"handlebars": "^4.7.8",
|
||||
"happy-dom": "^18.0.1",
|
||||
|
@ -1,6 +1,7 @@
|
||||
<script lang="ts">
|
||||
import NumberRangeInput from '$lib/components/shared-components/number-range-input.svelte';
|
||||
import { generateId } from '$lib/utils/generate-id';
|
||||
import { convert } from 'geo-coordinates-parser';
|
||||
import { t } from 'svelte-i18n';
|
||||
|
||||
interface Props {
|
||||
@ -20,22 +21,22 @@
|
||||
};
|
||||
|
||||
const onPaste = (event: ClipboardEvent) => {
|
||||
const coords = event.clipboardData?.getData('text/plain')?.split(',');
|
||||
if (!coords || coords.length !== 2) {
|
||||
return;
|
||||
}
|
||||
|
||||
const [latitude, longitude] = coords.map((coord) => Number.parseFloat(coord));
|
||||
if (Number.isNaN(latitude) || latitude < -90 || latitude > 90) {
|
||||
return;
|
||||
}
|
||||
if (Number.isNaN(longitude) || longitude < -180 || longitude > 180) {
|
||||
const pastedText = event.clipboardData?.getData('text/plain');
|
||||
if (!pastedText) {
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
const parsed = convert(pastedText);
|
||||
if (parsed) {
|
||||
event.preventDefault();
|
||||
[lat, lng] = [latitude, longitude];
|
||||
lat = parsed.decimalLatitude;
|
||||
lng = parsed.decimalLongitude;
|
||||
onInput();
|
||||
}
|
||||
} catch {
|
||||
// Invalid coordinate format, do nothing (let the default paste behavior occur)
|
||||
}
|
||||
};
|
||||
</script>
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user