forked from MapComplete/MapComplete
66 lines
No EOL
2.4 KiB
TypeScript
66 lines
No EOL
2.4 KiB
TypeScript
import {UIElement} from "../UIElement";
|
|
import {VariableUiElement} from "../Base/VariableUIElement";
|
|
import {UIEventSource} from "../../Logic/UIEventSource";
|
|
import {LayoutConfigJson} from "../../Customizations/JSON/LayoutConfigJson";
|
|
import Combine from "../Base/Combine";
|
|
import {OsmConnection} from "../../Logic/Osm/OsmConnection";
|
|
import {FixedUiElement} from "../Base/FixedUiElement";
|
|
import {TextField} from "../Input/TextField";
|
|
import {SubtleButton} from "../Base/SubtleButton";
|
|
|
|
export default class SavePanel extends UIElement {
|
|
private json: UIElement;
|
|
private lastSaveEl: UIElement;
|
|
private loadFromJson: UIElement;
|
|
|
|
constructor(
|
|
connection: OsmConnection,
|
|
config: UIEventSource<LayoutConfigJson>,
|
|
chronic: UIEventSource<Date>) {
|
|
super();
|
|
|
|
|
|
this.lastSaveEl = new VariableUiElement(chronic
|
|
.map(date => {
|
|
if (date === undefined) {
|
|
return new FixedUiElement("Your theme will be saved automatically within two minutes... Click here to force saving").SetClass("alert").Render()
|
|
}
|
|
return "Your theme was last saved at " + date.toISOString()
|
|
})).onClick(() => chronic.setData(new Date()));
|
|
|
|
const jsonStr = config.map(config =>
|
|
JSON.stringify(config, null, 2));
|
|
|
|
|
|
const jsonTextField = new TextField({
|
|
placeholder: "JSON Config",
|
|
fromString: str => str,
|
|
toString: str => str,
|
|
value: jsonStr,
|
|
startValidated: false,
|
|
textArea: true,
|
|
textAreaRows: 20
|
|
});
|
|
this.json = jsonTextField;
|
|
this.loadFromJson = new SubtleButton("./assets/reload.svg", "<b>Load the JSON file below</b>")
|
|
.onClick(() => {
|
|
const json = jsonTextField.GetValue().data;
|
|
config.setData(JSON.parse(json));
|
|
});
|
|
}
|
|
|
|
InnerRender(): string {
|
|
return new Combine([
|
|
"<h3>Saving</h3>",
|
|
this.lastSaveEl,
|
|
"<h3>JSON configuration</h3>",
|
|
"The url hash is actually no more then a BASE64-encoding of the below JSON. This json contains the full configuration of the theme.<br/>" +
|
|
"This configuration is mainly useful for debugging",
|
|
"<br/>",
|
|
this.loadFromJson,
|
|
this.json
|
|
]).SetClass("scrollable")
|
|
.Render();
|
|
}
|
|
|
|
} |