import LayerConfig from "./ThemeConfig/LayerConfig" import { UIEventSource } from "../Logic/UIEventSource" import UserRelatedState from "../Logic/State/UserRelatedState" import { Utils } from "../Utils" /** * Indicates if a menu is open, and if so, which tab is selected; * Some tabs allow to highlight an element. * * Some convenience methods are provided for this as well */ export class MenuState { private static readonly _themeviewTabs = ["intro", "filters"] as const public readonly themeIsOpened = new UIEventSource(true) public readonly themeViewTabIndex: UIEventSource public readonly themeViewTab: UIEventSource private static readonly _menuviewTabs = ["about", "settings", "community", "privacy"] as const public readonly menuIsOpened = new UIEventSource(false) public readonly menuViewTabIndex: UIEventSource public readonly menuViewTab: UIEventSource public readonly highlightedLayerInFilters: UIEventSource = new UIEventSource( undefined ) public highlightedUserSetting: UIEventSource = new UIEventSource(undefined) constructor() { this.themeViewTabIndex = new UIEventSource(0) this.themeViewTab = this.themeViewTabIndex.sync( (i) => MenuState._themeviewTabs[i], [], (str) => MenuState._themeviewTabs.indexOf(str) ) this.menuViewTabIndex = new UIEventSource(1) this.menuViewTab = this.menuViewTabIndex.sync( (i) => MenuState._menuviewTabs[i], [], (str) => MenuState._menuviewTabs.indexOf(str) ) this.themeIsOpened.addCallbackAndRun((isOpen) => { if (!isOpen) { this.highlightedLayerInFilters.setData(undefined) } }) this.themeViewTab.addCallbackAndRun((tab) => { if (tab !== "filters") { this.highlightedLayerInFilters.setData(undefined) } }) } public openFilterView(highlightLayer?: LayerConfig | string) { this.themeIsOpened.setData(true) this.themeViewTab.setData("filters") if (highlightLayer) { if (typeof highlightLayer !== "string") { highlightLayer = highlightLayer.id } this.highlightedLayerInFilters.setData(highlightLayer) } } public openUsersettings(highlightTagRendering?: string) { this.menuIsOpened.setData(true) this.menuViewTab.setData("settings") if ( highlightTagRendering !== undefined && !UserRelatedState.availableUserSettingsIds.some((tr) => tr === highlightTagRendering) ) { console.error( "No tagRendering with id '" + highlightTagRendering + "'; maybe you meant:", Utils.sortedByLevenshteinDistance( highlightTagRendering, UserRelatedState.availableUserSettingsIds, (x) => x ) ) } this.highlightedUserSetting.setData(highlightTagRendering) } public closeAll() { this.menuIsOpened.setData(false) this.themeIsOpened.setData(false) } }