mapcomplete/UI/BigComponents/LayerSelection.ts

84 lines
3 KiB
TypeScript
Raw Normal View History

import {UIEventSource} from "../../Logic/UIEventSource";
import {UIElement} from "../UIElement";
import {VariableUiElement} from "../Base/VariableUIElement";
import State from "../../State";
import CheckBox from "../Input/CheckBox";
import Combine from "../Base/Combine";
import {FixedUiElement} from "../Base/FixedUiElement";
import Translations from "../i18n/Translations";
import LayerConfig from "../../Customizations/JSON/LayerConfig";
2020-07-22 09:49:01 +00:00
/**
* Shows the panel with all layers and a toggle for each of them
*/
export default class LayerSelection extends UIElement {
2020-07-22 09:49:01 +00:00
private _checkboxes: UIElement[];
private activeLayers: UIEventSource<{
readonly isDisplayed: UIEventSource<boolean>,
readonly layerDef: LayerConfig;
}[]>;
constructor(activeLayers: UIEventSource<{
readonly isDisplayed: UIEventSource<boolean>,
readonly layerDef: LayerConfig;
}[]>) {
super(activeLayers);
if(activeLayers === undefined){
throw "ActiveLayers should be defined..."
}
this.activeLayers = activeLayers;
}
InnerRender(): string {
2020-07-22 09:49:01 +00:00
2020-07-31 14:17:16 +00:00
this._checkboxes = [];
for (const layer of this.activeLayers.data) {
const leafletStyle = layer.layerDef.GenerateLeafletStyle(
new UIEventSource<any>({id: "node/-1"}),
false)
const leafletHtml = leafletStyle.icon.html;
const icon =
new FixedUiElement(leafletHtml.Render())
.SetClass("single-layer-selection-toggle")
let iconUnselected: UIElement = new FixedUiElement(leafletHtml.Render())
.SetClass("single-layer-selection-toggle")
.SetStyle("opacity:0.2;");
2020-09-17 17:11:16 +00:00
const name = Translations.WT(layer.layerDef.name)?.Clone()
?.SetStyle("font-size:large;margin-left: 0.5em;");
2020-07-23 14:28:19 +00:00
if((name ?? "") === ""){
continue
}
2020-09-17 18:59:05 +00:00
2020-09-17 17:11:16 +00:00
const zoomStatus = new VariableUiElement(State.state.locationControl.map(location => {
2020-09-17 18:59:05 +00:00
if (location.zoom < layer.layerDef.minzoom) {
2021-01-08 01:13:44 +00:00
return Translations.t.general.layerSelection.zoomInToSeeThisLayer
2020-09-17 17:11:16 +00:00
.SetClass("alert")
2020-09-17 18:59:05 +00:00
.SetStyle("display: block ruby;width:min-content;")
2020-09-17 17:11:16 +00:00
.Render();
}
return ""
}))
2021-01-08 13:23:12 +00:00
const style = "display:flex;align-items:center;"
const styleWhole = "display:flex; flex-wrap: wrap"
2020-07-31 14:17:16 +00:00
this._checkboxes.push(new CheckBox(
2021-01-08 13:23:12 +00:00
new Combine([new Combine([icon, name]).SetStyle(style), zoomStatus])
.SetStyle(styleWhole),
new Combine([new Combine([iconUnselected, "<del>", name, "</del>"]).SetStyle(style), zoomStatus])
.SetStyle(styleWhole),
layer.isDisplayed)
.SetStyle("margin:0.3em;")
);
}
2020-07-22 09:49:01 +00:00
return new Combine(this._checkboxes)
.SetStyle("display:flex;flex-direction:column;")
.Render();
2020-07-22 09:49:01 +00:00
}
}