2021-07-28 16:48:59 +02:00
|
|
|
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";
|
2021-09-21 02:10:42 +02:00
|
|
|
import {UIEventSource} from "../../Logic/UIEventSource";
|
|
|
|
import FeaturePipeline from "../../Logic/FeatureSource/FeaturePipeline";
|
|
|
|
import Loc from "../../Models/Loc";
|
2021-09-28 17:30:48 +02:00
|
|
|
import {BBox} from "../../Logic/BBox";
|
2021-10-15 05:20:02 +02:00
|
|
|
import LayoutConfig from "../../Models/ThemeConfig/LayoutConfig";
|
|
|
|
import FilteredLayer from "../../Models/FilteredLayer";
|
2021-11-03 00:44:53 +01:00
|
|
|
import BaseLayer from "../../Models/BaseLayer";
|
|
|
|
import {OsmConnection} from "../../Logic/Osm/OsmConnection";
|
2021-11-21 02:44:35 +01:00
|
|
|
import BackgroundMapSwitch from "./BackgroundMapSwitch";
|
2021-12-10 17:30:50 +01:00
|
|
|
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";
|
2021-12-14 03:12:10 +01:00
|
|
|
import FeatureSwitchState from "../../Logic/State/FeatureSwitchState";
|
|
|
|
import CopyrightPanel from "./CopyrightPanel";
|
2021-07-28 16:48:59 +02:00
|
|
|
|
|
|
|
export default class LeftControls extends Combine {
|
|
|
|
|
2021-12-14 03:12:10 +01:00
|
|
|
constructor(state: FeatureSwitchState & {
|
2021-12-10 17:30:50 +01:00
|
|
|
allElements: ElementStorage;
|
|
|
|
currentView: FeatureSourceForLayer;
|
2021-12-04 12:20:24 +01:00
|
|
|
featureSwitchBackgroundSelection: UIEventSource<boolean>;
|
2021-10-15 05:20:02 +02:00
|
|
|
layoutToUse: LayoutConfig,
|
|
|
|
featurePipeline: FeaturePipeline,
|
|
|
|
currentBounds: UIEventSource<BBox>,
|
|
|
|
locationControl: UIEventSource<Loc>,
|
|
|
|
overlayToggles: any,
|
|
|
|
featureSwitchEnableExport: UIEventSource<boolean>,
|
|
|
|
featureSwitchExportAsPdf: UIEventSource<boolean>,
|
|
|
|
filteredLayers: UIEventSource<FilteredLayer[]>,
|
2021-11-03 00:44:53 +01:00
|
|
|
featureSwitchFilter: UIEventSource<boolean>,
|
|
|
|
backgroundLayer: UIEventSource<BaseLayer>,
|
|
|
|
osmConnection: OsmConnection
|
2021-10-15 05:20:02 +02:00
|
|
|
},
|
|
|
|
guiState: {
|
2021-12-10 17:30:50 +01:00
|
|
|
currentViewControlIsOpened: UIEventSource<boolean>;
|
2021-10-15 05:20:02 +02:00
|
|
|
downloadControlIsOpened: UIEventSource<boolean>,
|
|
|
|
filterViewIsOpened: UIEventSource<boolean>,
|
2021-10-23 02:46:37 +02:00
|
|
|
copyrightViewIsOpened: UIEventSource<boolean>
|
2021-10-15 05:20:02 +02:00
|
|
|
}) {
|
2021-07-28 16:48:59 +02:00
|
|
|
|
|
|
|
|
2021-12-10 17:30:50 +01:00
|
|
|
const currentViewFL = state.currentView?.layer
|
|
|
|
const currentViewAction = new Toggle(
|
|
|
|
new Lazy(() => {
|
2021-12-14 03:12:10 +01:00
|
|
|
const feature: UIEventSource<any> = state.currentView.features.map(ffs => ffs[0]?.feature)
|
2021-12-10 17:30:50 +01:00
|
|
|
const icon = new VariableUiElement(feature.map(feature => {
|
|
|
|
const defaultIcon = Svg.checkbox_empty_svg()
|
|
|
|
if (feature === undefined) {
|
|
|
|
return defaultIcon;
|
|
|
|
}
|
|
|
|
const tags = {...feature.properties, button: "yes"}
|
2021-12-11 02:19:28 +01:00
|
|
|
const elem = currentViewFL.layerDef.mapRendering[0]?.GenerateLeafletStyle(new UIEventSource(tags), false, {
|
2021-12-10 17:30:50 +01:00
|
|
|
noSize: true
|
|
|
|
})?.html
|
2021-12-14 03:12:10 +01:00
|
|
|
if (elem === undefined) {
|
2021-12-10 17:30:50 +01:00
|
|
|
return defaultIcon
|
|
|
|
}
|
|
|
|
return elem
|
2021-12-11 02:19:28 +01:00
|
|
|
})).SetClass("inline-block w-full h-full")
|
2021-12-14 03:12:10 +01:00
|
|
|
|
2021-12-10 17:30:50 +01:00
|
|
|
const featureBox = new VariableUiElement(feature.map(feature => {
|
2021-12-14 03:12:10 +01:00
|
|
|
if (feature === undefined) {
|
|
|
|
return undefined
|
|
|
|
}
|
2021-12-10 17:30:50 +01:00
|
|
|
return new Lazy(() => {
|
2021-12-14 03:12:10 +01:00
|
|
|
const tagsSource = state.allElements.getEventSourceById(feature.properties.id)
|
2021-12-10 17:30:50 +01:00
|
|
|
return new FeatureInfoBox(tagsSource, currentViewFL.layerDef, "currentview", guiState.currentViewControlIsOpened)
|
2021-12-12 02:59:24 +01:00
|
|
|
.SetClass("md:floating-element-width")
|
2021-12-10 17:30:50 +01:00
|
|
|
})
|
|
|
|
}))
|
2021-12-14 03:12:10 +01:00
|
|
|
|
2021-12-10 17:30:50 +01:00
|
|
|
|
|
|
|
return new Toggle(
|
|
|
|
featureBox,
|
|
|
|
new MapControlButton(icon),
|
|
|
|
guiState.currentViewControlIsOpened
|
|
|
|
)
|
|
|
|
|
2021-12-11 02:19:28 +01:00
|
|
|
}).onClick(() => {
|
2021-12-10 17:30:50 +01:00
|
|
|
guiState.currentViewControlIsOpened.setData(true)
|
|
|
|
}),
|
|
|
|
|
|
|
|
|
|
|
|
undefined,
|
|
|
|
new UIEventSource<boolean>(currentViewFL !== undefined && currentViewFL?.layerDef?.tagRenderings !== null)
|
|
|
|
)
|
|
|
|
|
2021-07-28 16:48:59 +02:00
|
|
|
const toggledDownload = new Toggle(
|
|
|
|
new AllDownloads(
|
2021-10-15 05:20:02 +02:00
|
|
|
guiState.downloadControlIsOpened
|
2021-12-12 02:59:24 +01:00
|
|
|
).SetClass("block p-1 rounded-full md:floating-element-width"),
|
2021-07-28 18:20:59 +02:00
|
|
|
new MapControlButton(Svg.download_svg())
|
2021-10-15 05:20:02 +02:00
|
|
|
.onClick(() => guiState.downloadControlIsOpened.setData(true)),
|
|
|
|
guiState.downloadControlIsOpened
|
2021-07-28 18:20:59 +02:00
|
|
|
)
|
2021-07-28 16:48:59 +02:00
|
|
|
|
|
|
|
const downloadButtonn = new Toggle(
|
|
|
|
toggledDownload,
|
|
|
|
undefined,
|
2021-10-15 05:20:02 +02:00
|
|
|
state.featureSwitchEnableExport.map(downloadEnabled => downloadEnabled || state.featureSwitchExportAsPdf.data,
|
|
|
|
[state.featureSwitchExportAsPdf])
|
2021-07-28 16:48:59 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
const toggledFilter = new Toggle(
|
|
|
|
new ScrollableFullScreen(
|
|
|
|
() => Translations.t.general.layerSelection.title.Clone(),
|
|
|
|
() =>
|
2021-10-15 05:20:02 +02:00
|
|
|
new FilterView(state.filteredLayers, state.overlayToggles).SetClass(
|
2021-10-23 02:46:37 +02:00
|
|
|
"block p-1"
|
2021-07-28 16:48:59 +02:00
|
|
|
),
|
2021-10-25 20:50:59 +02:00
|
|
|
"filters",
|
2021-10-15 05:20:02 +02:00
|
|
|
guiState.filterViewIsOpened
|
2021-12-12 02:59:24 +01:00
|
|
|
).SetClass("rounded-lg md:floating-element-width"),
|
2021-07-28 18:20:59 +02:00
|
|
|
new MapControlButton(Svg.filter_svg())
|
2021-10-15 05:20:02 +02:00
|
|
|
.onClick(() => guiState.filterViewIsOpened.setData(true)),
|
|
|
|
guiState.filterViewIsOpened
|
2021-07-28 18:20:59 +02:00
|
|
|
)
|
2021-07-28 16:48:59 +02:00
|
|
|
|
|
|
|
const filterButton = new Toggle(
|
|
|
|
toggledFilter,
|
|
|
|
undefined,
|
2021-10-15 05:20:02 +02:00
|
|
|
state.featureSwitchFilter
|
2021-07-28 16:48:59 +02:00
|
|
|
);
|
2021-12-10 17:30:50 +01:00
|
|
|
|
2021-12-04 12:20:24 +01:00
|
|
|
const mapSwitch = new Toggle(
|
|
|
|
new BackgroundMapSwitch(state, state.backgroundLayer),
|
|
|
|
undefined,
|
|
|
|
state.featureSwitchBackgroundSelection
|
|
|
|
)
|
2021-07-28 16:48:59 +02:00
|
|
|
|
2021-12-14 03:12:10 +01:00
|
|
|
// 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
|
|
|
|
)
|
|
|
|
|
2021-12-10 17:30:50 +01:00
|
|
|
super([
|
|
|
|
currentViewAction,
|
|
|
|
filterButton,
|
2021-07-28 16:48:59 +02:00
|
|
|
downloadButtonn,
|
2021-12-14 03:12:10 +01:00
|
|
|
copyright,
|
2021-12-10 17:30:50 +01:00
|
|
|
mapSwitch
|
2021-11-21 02:44:35 +01:00
|
|
|
])
|
2021-09-09 00:05:51 +02:00
|
|
|
|
2021-07-28 16:48:59 +02:00
|
|
|
this.SetClass("flex flex-col")
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|