import Combine from "../Base/Combine"; import ScrollableFullScreen from "../Base/ScrollableFullScreen"; import Translations from "../i18n/Translations"; import Toggle from "../Input/Toggle"; import MapControlButton from "../MapControlButton"; import Svg from "../../Svg"; import AllDownloads from "./AllDownloads"; import FilterView from "./FilterView"; import {UIEventSource} from "../../Logic/UIEventSource"; import FeaturePipeline from "../../Logic/FeatureSource/FeaturePipeline"; import Loc from "../../Models/Loc"; import {BBox} from "../../Logic/BBox"; import LayoutConfig from "../../Models/ThemeConfig/LayoutConfig"; import FilteredLayer from "../../Models/FilteredLayer"; import BaseLayer from "../../Models/BaseLayer"; import {OsmConnection} from "../../Logic/Osm/OsmConnection"; import BackgroundMapSwitch from "./BackgroundMapSwitch"; import {FeatureSourceForLayer} from "../../Logic/FeatureSource/FeatureSource"; import Lazy from "../Base/Lazy"; import {VariableUiElement} from "../Base/VariableUIElement"; import FeatureInfoBox from "../Popup/FeatureInfoBox"; import {ElementStorage} from "../../Logic/ElementStorage"; import FeatureSwitchState from "../../Logic/State/FeatureSwitchState"; import CopyrightPanel from "./CopyrightPanel"; export default class LeftControls extends Combine { constructor(state: FeatureSwitchState & { allElements: ElementStorage; currentView: FeatureSourceForLayer; featureSwitchBackgroundSelection: UIEventSource; layoutToUse: LayoutConfig, featurePipeline: FeaturePipeline, currentBounds: UIEventSource, locationControl: UIEventSource, overlayToggles: any, featureSwitchEnableExport: UIEventSource, featureSwitchExportAsPdf: UIEventSource, filteredLayers: UIEventSource, featureSwitchFilter: UIEventSource, backgroundLayer: UIEventSource, osmConnection: OsmConnection }, guiState: { currentViewControlIsOpened: UIEventSource; downloadControlIsOpened: UIEventSource, filterViewIsOpened: UIEventSource, copyrightViewIsOpened: UIEventSource }) { const currentViewFL = state.currentView?.layer const currentViewAction = new Toggle( new Lazy(() => { const feature: UIEventSource = state.currentView.features.map(ffs => ffs[0]?.feature) const icon = new VariableUiElement(feature.map(feature => { const defaultIcon = Svg.checkbox_empty_svg() if (feature === undefined) { return defaultIcon; } const tags = {...feature.properties, button: "yes"} const elem = currentViewFL.layerDef.mapRendering[0]?.GenerateLeafletStyle(new UIEventSource(tags), false, { noSize: true })?.html if (elem === undefined) { return defaultIcon } return elem })).SetClass("inline-block w-full h-full") const featureBox = new VariableUiElement(feature.map(feature => { if (feature === undefined) { return undefined } return new Lazy(() => { const tagsSource = state.allElements.getEventSourceById(feature.properties.id) return new FeatureInfoBox(tagsSource, currentViewFL.layerDef, "currentview", guiState.currentViewControlIsOpened) .SetClass("md:floating-element-width") }) })) return new Toggle( featureBox, new MapControlButton(icon), guiState.currentViewControlIsOpened ) }).onClick(() => { guiState.currentViewControlIsOpened.setData(true) }), undefined, new UIEventSource(currentViewFL !== undefined && currentViewFL?.layerDef?.tagRenderings !== null) ) const toggledDownload = new Toggle( new AllDownloads( guiState.downloadControlIsOpened ).SetClass("block p-1 rounded-full md:floating-element-width"), new MapControlButton(Svg.download_svg()) .onClick(() => guiState.downloadControlIsOpened.setData(true)), guiState.downloadControlIsOpened ) const downloadButtonn = new Toggle( toggledDownload, undefined, state.featureSwitchEnableExport.map(downloadEnabled => downloadEnabled || state.featureSwitchExportAsPdf.data, [state.featureSwitchExportAsPdf]) ); const toggledFilter = new Toggle( new ScrollableFullScreen( () => Translations.t.general.layerSelection.title.Clone(), () => new FilterView(state.filteredLayers, state.overlayToggles).SetClass( "block p-1" ), "filters", guiState.filterViewIsOpened ).SetClass("rounded-lg md:floating-element-width"), new MapControlButton(Svg.filter_svg()) .onClick(() => guiState.filterViewIsOpened.setData(true)), guiState.filterViewIsOpened ) const filterButton = new Toggle( toggledFilter, undefined, state.featureSwitchFilter ); const mapSwitch = new Toggle( new BackgroundMapSwitch(state, state.backgroundLayer), undefined, state.featureSwitchBackgroundSelection ) // If the welcomeMessage is disabled, the copyright is hidden (as that is where the copyright is located const copyright = new Toggle( undefined, new Lazy(() => new Toggle( new ScrollableFullScreen( () => Translations.t.general.attribution.attributionTitle, () => new CopyrightPanel(state), "copyright", guiState.copyrightViewIsOpened ), new MapControlButton(Svg.copyright_svg()).onClick(() => guiState.copyrightViewIsOpened.setData(true)), guiState.copyrightViewIsOpened ) ), state.featureSwitchWelcomeMessage ) super([ currentViewAction, filterButton, downloadButtonn, copyright, mapSwitch ]) this.SetClass("flex flex-col") } }