mapcomplete/Customizations/Layout.ts

130 lines
4.6 KiB
TypeScript
Raw Normal View History

import {UIElement} from "../UI/UIElement";
2020-07-20 23:37:48 +00:00
import Translations from "../UI/i18n/Translations";
import Combine from "../UI/Base/Combine";
import State from "../State";
2020-11-02 11:00:50 +00:00
import {Translation} from "../UI/i18n/Translations";
2020-10-27 00:01:34 +00:00
import LayerConfig from "./JSON/LayerConfig";
import {LayoutConfigJson} from "./JSON/LayoutConfigJson";
import TagRenderingConfig from "./JSON/TagRenderingConfig";
import {FromJSON} from "./JSON/FromJSON";
2020-07-05 16:59:47 +00:00
/**
* A layout is a collection of settings of the global view (thus: welcome text, title, selection of layers).
*/
export class Layout {
public id: string;
public icon: string = "./assets/logo.svg";
2020-07-20 10:39:43 +00:00
public title: UIElement;
public maintainer: string;
public version: string;
2020-07-29 13:48:21 +00:00
public description: string | UIElement;
public changesetMessage: string;
public socialImage: string = "";
/**
* Custom CSS link
*/
public customCss: string = undefined;
2020-10-27 00:01:34 +00:00
public layers: LayerConfig[];
2020-07-20 10:39:43 +00:00
public welcomeMessage: UIElement;
2020-07-20 23:37:48 +00:00
public gettingStartedPlzLogin: UIElement;
public welcomeBackMessage: UIElement;
public welcomeTail: UIElement;
2020-07-05 16:59:47 +00:00
2020-07-20 22:07:04 +00:00
public supportedLanguages: string[];
public startzoom: number;
2020-07-05 16:59:47 +00:00
public startLon: number;
public startLat: number;
public enableAdd: boolean = true;
public enableUserBadge: boolean = true;
public enableSearch: boolean = true;
public enableLayers: boolean = true;
public enableBackgroundLayers: boolean = true;
2020-08-06 22:45:33 +00:00
public enableMoreQuests: boolean = true;
public enableShareScreen: boolean = true;
public enableGeolocation: boolean = true;
2020-08-06 22:45:33 +00:00
public hideFromOverview: boolean = false;
2020-07-15 09:23:35 +00:00
/**
* The BBOX of the currently visible map are widened by this factor, in order to make some panning possible.
* This number influences this
*/
2020-08-06 22:45:33 +00:00
public widenFactor: number = 0.07;
public defaultBackground: string = "osm";
2020-10-27 00:01:34 +00:00
public static LayoutFromJSON(json: LayoutConfigJson, sharedLayers): Layout {
const tr = FromJSON.Translation;
const layers = json.layers.map(jsonLayer => {
if(typeof jsonLayer === "string"){
return sharedLayers[jsonLayer];
}
return new LayerConfig(jsonLayer, "theme."+json.id);
});
const roaming: TagRenderingConfig[] = json.roamingRenderings?.map((tr, i) =>
new TagRenderingConfig(tr, `theme.${json.id}.roamingRendering[${i}]`)) ?? [];
for (const layer of layers) {
layer.tagRenderings.push(...roaming);
}
const layout = new Layout(
json.id,
typeof (json.language) === "string" ? [json.language] : json.language,
tr(json.title ?? "Title not defined"),
layers,
json.startZoom,
json.startLat,
json.startLon,
new Combine(["<h3>", tr(json.title), "</h3>", tr(json.description)]),
undefined,
undefined,
tr(json.descriptionTail)
);
layout.defaultBackground = json.defaultBackgroundId ?? "osm";
layout.widenFactor = json.widenFactor ?? 0.07;
layout.icon = json.icon;
layout.maintainer = json.maintainer;
layout.version = json.version;
layout.socialImage = json.socialImage;
layout.description = tr(json.shortDescription) ?? tr(json.description)?.FirstSentence();
layout.changesetMessage = json.changesetmessage;
return layout;
}
2020-07-05 16:59:47 +00:00
constructor(
id: string,
2020-07-20 22:07:04 +00:00
supportedLanguages: string[],
2020-10-10 12:09:12 +00:00
title: Translation | string,
2020-10-27 00:01:34 +00:00
layers: LayerConfig[],
2020-07-05 16:59:47 +00:00
startzoom: number,
startLat: number,
startLon: number,
2020-10-11 16:22:04 +00:00
welcomeMessage: UIElement | string,
gettingStartedPlzLogin: UIElement | string = new Combine([
Translations.t.general.getStartedLogin
.SetClass("soft")
.onClick(() => {State.state.osmConnection.AttemptLogin()}),
Translations.t.general.getStartedNewAccount
]),
welcomeBackMessage: UIElement | string = Translations.t.general.welcomeBack,
welcomeTail: UIElement | string = "",
2020-07-05 16:59:47 +00:00
) {
2020-07-20 22:07:04 +00:00
this.supportedLanguages = supportedLanguages;
2020-10-10 12:09:12 +00:00
this.title = Translations.WT(title)
2020-07-05 16:59:47 +00:00
this.startLon = startLon;
this.startLat = startLat;
this.startzoom = startzoom;
this.id = id;
2020-07-05 16:59:47 +00:00
this.layers = layers;
this.welcomeMessage = Translations.W(welcomeMessage)
2020-07-20 23:37:48 +00:00
this.gettingStartedPlzLogin = Translations.W(gettingStartedPlzLogin);
this.welcomeBackMessage = Translations.W(welcomeBackMessage);
this.welcomeTail = Translations.W(welcomeTail);
2020-07-05 16:59:47 +00:00
}
}