import {UIEventSource} from "../UIEventSource"; import Translations from "../../UI/i18n/Translations"; import Locale from "../../UI/i18n/Locale"; import TagRenderingAnswer from "../../UI/Popup/TagRenderingAnswer"; import {ElementStorage} from "../ElementStorage"; import Combine from "../../UI/Base/Combine"; import LayoutConfig from "../../Models/ThemeConfig/LayoutConfig"; class TitleElement extends UIEventSource { private readonly _layoutToUse: UIEventSource; private readonly _selectedFeature: UIEventSource; private readonly _allElementsStorage: ElementStorage; constructor(layoutToUse: UIEventSource, selectedFeature: UIEventSource, allElementsStorage: ElementStorage) { super("MapComplete"); this._layoutToUse = layoutToUse; this._selectedFeature = selectedFeature; this._allElementsStorage = allElementsStorage; this.syncWith( this._selectedFeature.map( selected => { const defaultTitle = Translations.WT(this._layoutToUse.data?.title)?.txt ??"MapComplete" if(selected === undefined){ return defaultTitle } const layout = layoutToUse.data; const tags = selected.properties; for (const layer of layout.layers) { if (layer.title === undefined) { continue; } if (layer.source.osmTags.matchesProperties(tags)) { const tagsSource = allElementsStorage.getEventSourceById(tags.id) const title = new TagRenderingAnswer(tagsSource, layer.title) return new Combine([defaultTitle, " | ", title]).ConstructElement().innerText; } } return defaultTitle } , [Locale.language, layoutToUse] ) ) } } export default class TitleHandler { constructor(layoutToUse: UIEventSource, selectedFeature: UIEventSource, allElementsStorage: ElementStorage) { new TitleElement(layoutToUse, selectedFeature, allElementsStorage).addCallbackAndRunD(title => { document.title = title }) } }