X-Git-Url: https://git.openstreetmap.org./nominatim-ui.git/blobdiff_plain/f51f2a70794858f9c8fb5d75ecd40fd1e4ec3897..2ba00544d30017ad30570011b1a2bcc6a8da73a7:/src/components/DetailsLink.svelte?ds=sidebyside
diff --git a/src/components/DetailsLink.svelte b/src/components/DetailsLink.svelte
index 51a0c8c..1785179 100644
--- a/src/components/DetailsLink.svelte
+++ b/src/components/DetailsLink.svelte
@@ -4,7 +4,8 @@
export let extra_classes = '';
export let feature = null;
- let url_params = '';
+ let url_params = new URLSearchParams();
+ let href = 'details.html';
function formatShortOSMType(sType) {
if (sType === 'node') return 'N';
@@ -14,29 +15,40 @@
}
function handleClick() {
- window.history.pushState([], '', 'details.html' + url_params);
- refresh_page();
+ refresh_page('details', url_params);
}
$: {
- if (feature !== null && feature.osm_type) {
- let param = '?osmtype=';
- if (feature.osm_type.length == 1) {
- param += encodeURIComponent(feature.osm_type);
- } else {
- param += formatShortOSMType(feature.osm_type);
- }
- param += '&osmid=' + encodeURIComponent(feature.osm_id);
- if (feature.class) {
- param += '&class=' + encodeURIComponent(feature.class);
- } else if (feature.category) {
- param += '&class=' + encodeURIComponent(feature.category);
+ let new_params = new URLSearchParams();
+
+ if (feature !== null) {
+ if (feature.osm_type) {
+ if (feature.osm_type.length === 1) {
+ new_params.set('osmtype', feature.osm_type);
+ } else {
+ new_params.set('osmtype', formatShortOSMType(feature.osm_type));
+ }
+
+ new_params.set('osmid', feature.osm_id);
+
+ if (feature.class) {
+ new_params.set('class', feature.class);
+ } else if (feature.category) {
+ new_params.set('class', feature.category);
+ }
+ } else if (feature.place_id) {
+ new_params.set('place_id', feature.place_id);
}
- url_params = param
- } else {
- url_params = '';
}
- }
+ url_params = new_params;
+ }
+
+ $: {
+ let param_str = url_params.toString();
+ href = 'details.html' + (param_str ? '?' : '') + param_str;
+ }
-
+