From a75471df77f822a9072977c0c33e41e4e73785eb Mon Sep 17 00:00:00 2001 From: Pieter Vander Vennet Date: Thu, 1 Oct 2020 00:03:12 +0200 Subject: [PATCH] Open popup of newly added element immediatly, fix #132 --- Customizations/Questions/OsmLink.ts | 3 ++- Logic/FilteredLayer.ts | 17 +++++++++++++---- 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/Customizations/Questions/OsmLink.ts b/Customizations/Questions/OsmLink.ts index fdcf5e71a..bed6e7c34 100644 --- a/Customizations/Questions/OsmLink.ts +++ b/Customizations/Questions/OsmLink.ts @@ -1,6 +1,7 @@ import {Img} from "../../UI/Img"; import {RegexTag, Tag} from "../../Logic/Tags"; import {TagRenderingOptions} from "../TagRenderingOptions"; +import {FixedUiElement} from "../../UI/Base/FixedUiElement"; export class OsmLink extends TagRenderingOptions { @@ -18,7 +19,7 @@ export class OsmLink extends TagRenderingOptions { placeholder: "", }, mappings: [ - {k: new RegexTag("id", /node\/-.+/), txt: "Uploading"} + {k: new RegexTag("id", /node\/-.+/), txt: ""} ] } diff --git a/Logic/FilteredLayer.ts b/Logic/FilteredLayer.ts index 7d0c4abe2..7d13d9d1e 100644 --- a/Logic/FilteredLayer.ts +++ b/Logic/FilteredLayer.ts @@ -165,12 +165,11 @@ export class FilteredLayer { public AddNewElement(element) { this._newElements.push(element); - console.log("Element added"); - this.RenderLayer({features:this._dataFromOverpass}); // Update the layer + this.RenderLayer({features: this._dataFromOverpass}, element); // Update the layer } - private RenderLayer(data) { + private RenderLayer(data, openPopupOf = undefined) { let self = this; if (this._geolayer !== undefined && this._geolayer !== null) { @@ -219,6 +218,7 @@ export class FilteredLayer { // The points get a special treatment in order to render them properly // Note that some features might get a point representation as well + const runWhenAdded: (() => void)[] = [] this._geolayer = L.geoJSON(data, { style: function (feature) { @@ -252,7 +252,7 @@ export class FilteredLayer { const popup = L.popup({}, marker); let uiElement: UIElement; let content = undefined; - marker.bindPopup(popup) + let p = marker.bindPopup(popup) .on("popupopen", () => { if (content === undefined) { uiElement = self._showOnPopup(eventSource, feature); @@ -263,6 +263,12 @@ export class FilteredLayer { uiElement.Update(); }); + if (feature === openPopupOf) { + runWhenAdded.push(() => { + p.openPopup(); + }) + } + return marker; }, @@ -321,6 +327,9 @@ export class FilteredLayer { if (this.combinedIsDisplayed.data) { this._geolayer.addTo(State.state.bm.map); + for (const f of runWhenAdded) { + f(); + } } }