forked from MapComplete/MapComplete
Fixed some typos, fixed legacy loading in non-legacy settings, also show attribution when layer control is disabled
This commit is contained in:
parent
4a3537f925
commit
b441e6e8a5
8 changed files with 75 additions and 60 deletions
|
@ -81,7 +81,7 @@ export class InitUiElements {
|
||||||
// This is purely for the personal theme to load the layers there
|
// This is purely for the personal theme to load the layers there
|
||||||
const favs = State.state.favouriteLayers.data ?? [];
|
const favs = State.state.favouriteLayers.data ?? [];
|
||||||
|
|
||||||
|
|
||||||
layoutToUse.layers.splice(0, layoutToUse.layers.length);
|
layoutToUse.layers.splice(0, layoutToUse.layers.length);
|
||||||
for (const fav of favs) {
|
for (const fav of favs) {
|
||||||
for (const layouts of State.state.installedThemes.data) {
|
for (const layouts of State.state.installedThemes.data) {
|
||||||
|
@ -206,16 +206,16 @@ export class InitUiElements {
|
||||||
hashFromLocalStorage.setData(hash);
|
hashFromLocalStorage.setData(hash);
|
||||||
dedicatedHashFromLocalStorage.setData(hash);
|
dedicatedHashFromLocalStorage.setData(hash);
|
||||||
}
|
}
|
||||||
|
|
||||||
let json: {}
|
let json: {}
|
||||||
try{
|
try {
|
||||||
json = JSON.parse(atob(hash));
|
json = JSON.parse(atob(hash));
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
// We try to decode with lz-string
|
// We try to decode with lz-string
|
||||||
json = JSON.parse( Utils.UnMinify(LZString.decompressFromBase64(hash))) as LayoutConfigJson;
|
json = JSON.parse(Utils.UnMinify(LZString.decompressFromBase64(hash))) as LayoutConfigJson;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
const layoutToUse = new LayoutConfig(json, false);
|
const layoutToUse = new LayoutConfig(json, false);
|
||||||
userLayoutParam.setData(layoutToUse.id);
|
userLayoutParam.setData(layoutToUse.id);
|
||||||
|
@ -229,7 +229,6 @@ export class InitUiElements {
|
||||||
|
|
||||||
private static OnlyIf(featureSwitch: UIEventSource<boolean>, callback: () => void) {
|
private static OnlyIf(featureSwitch: UIEventSource<boolean>, callback: () => void) {
|
||||||
featureSwitch.addCallbackAndRun(() => {
|
featureSwitch.addCallbackAndRun(() => {
|
||||||
|
|
||||||
if (featureSwitch.data) {
|
if (featureSwitch.data) {
|
||||||
callback();
|
callback();
|
||||||
}
|
}
|
||||||
|
@ -269,48 +268,54 @@ export class InitUiElements {
|
||||||
}
|
}
|
||||||
|
|
||||||
private static InitLayerSelection() {
|
private static InitLayerSelection() {
|
||||||
InitUiElements.OnlyIf(State.state.featureSwitchLayers, () => {
|
|
||||||
|
|
||||||
const layerControlPanel = new LayerControlPanel(
|
const copyrightNotice =
|
||||||
State.state.layerControlIsOpened)
|
new ScrollableFullScreen(
|
||||||
.SetClass("block p-1 rounded-full");
|
() => Translations.t.general.attribution.attributionTitle.Clone(),
|
||||||
const checkbox = new CheckBox(
|
() => new AttributionPanel(State.state.layoutToUse),
|
||||||
layerControlPanel,
|
"copyright"
|
||||||
new MapControlButton(Svg.layers_svg()),
|
|
||||||
State.state.layerControlIsOpened
|
|
||||||
)
|
)
|
||||||
const copyrightNotice =
|
|
||||||
new ScrollableFullScreen(
|
|
||||||
() => Translations.t.general.attribution.attributionTitle.Clone(),
|
|
||||||
() => new AttributionPanel(State.state.layoutToUse),
|
|
||||||
"copyright"
|
|
||||||
)
|
|
||||||
|
|
||||||
;
|
;
|
||||||
const copyrightButton = new CheckBox(
|
const copyrightButton = new CheckBox(
|
||||||
copyrightNotice,
|
copyrightNotice,
|
||||||
new MapControlButton(Svg.osm_copyright_svg()),
|
new MapControlButton(Svg.osm_copyright_svg()),
|
||||||
copyrightNotice.isShown
|
copyrightNotice.isShown
|
||||||
).SetClass("p-0.5")
|
).SetClass("p-0.5")
|
||||||
|
|
||||||
new Combine([copyrightButton, checkbox])
|
const layerControlPanel = new LayerControlPanel(
|
||||||
.AttachTo("bottom-left");
|
State.state.layerControlIsOpened)
|
||||||
|
.SetClass("block p-1 rounded-full");
|
||||||
|
const layerControlButton = new CheckBox(
|
||||||
|
layerControlPanel,
|
||||||
|
new MapControlButton(Svg.layers_svg()),
|
||||||
|
State.state.layerControlIsOpened
|
||||||
|
)
|
||||||
|
|
||||||
|
const layerControl = new CheckBox(
|
||||||
|
layerControlButton,
|
||||||
|
"",
|
||||||
|
State.state.featureSwitchLayers
|
||||||
|
)
|
||||||
|
|
||||||
|
new Combine([copyrightButton, layerControl])
|
||||||
|
.AttachTo("bottom-left");
|
||||||
|
|
||||||
|
|
||||||
State.state.locationControl
|
State.state.locationControl
|
||||||
.addCallback(() => {
|
.addCallback(() => {
|
||||||
// Close the layer selection when the map is moved
|
// Close the layer selection when the map is moved
|
||||||
checkbox.isEnabled.setData(false);
|
layerControlButton.isEnabled.setData(false);
|
||||||
copyrightButton.isEnabled.setData(false);
|
copyrightButton.isEnabled.setData(false);
|
||||||
});
|
});
|
||||||
|
|
||||||
State.state.selectedElement.addCallbackAndRun(feature => {
|
State.state.selectedElement.addCallbackAndRun(feature => {
|
||||||
if (feature !== undefined) {
|
if (feature !== undefined) {
|
||||||
checkbox.isEnabled.setData(false);
|
layerControlButton.isEnabled.setData(false);
|
||||||
}
|
copyrightButton.isEnabled.setData(false);
|
||||||
})
|
}
|
||||||
|
})
|
||||||
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static InitBaseMap() {
|
private static InitBaseMap() {
|
||||||
|
@ -371,7 +376,7 @@ export class InitUiElements {
|
||||||
state.layoutToUse.map(layoutToUse => {
|
state.layoutToUse.map(layoutToUse => {
|
||||||
const flayers = [];
|
const flayers = [];
|
||||||
|
|
||||||
|
|
||||||
for (const layer of layoutToUse.layers) {
|
for (const layer of layoutToUse.layers) {
|
||||||
const isDisplayed = QueryParameters.GetQueryParameter("layer-" + layer.id, "true", "Wether or not layer " + layer.id + " is shown")
|
const isDisplayed = QueryParameters.GetQueryParameter("layer-" + layer.id, "true", "Wether or not layer " + layer.id + " is shown")
|
||||||
.map<boolean>((str) => str !== "false", [], (b) => b.toString());
|
.map<boolean>((str) => str !== "false", [], (b) => b.toString());
|
||||||
|
@ -440,6 +445,6 @@ export class InitUiElements {
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -15,8 +15,6 @@ public readonly name = "FilteringFeatureSource"
|
||||||
|
|
||||||
const self = this;
|
const self = this;
|
||||||
|
|
||||||
console.log("INITING pipeline: ",layers)
|
|
||||||
|
|
||||||
function update() {
|
function update() {
|
||||||
|
|
||||||
const layerDict = {};
|
const layerDict = {};
|
||||||
|
@ -69,6 +67,7 @@ public readonly name = "FilteringFeatureSource"
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
});
|
});
|
||||||
|
console.log("Filtering layer source: input: ", upstream.features.data?.length, "output:", newFeatures.length)
|
||||||
self.features.setData(newFeatures);
|
self.features.setData(newFeatures);
|
||||||
if(missingLayers.size > 0){
|
if(missingLayers.size > 0){
|
||||||
console.error("Some layers were not found: ", Array.from(missingLayers))
|
console.error("Some layers were not found: ", Array.from(missingLayers))
|
||||||
|
|
|
@ -2,7 +2,7 @@ import { Utils } from "../Utils";
|
||||||
|
|
||||||
export default class Constants {
|
export default class Constants {
|
||||||
|
|
||||||
public static vNumber = "0.7.0a";
|
public static vNumber = "0.7.0b";
|
||||||
|
|
||||||
// The user journey states thresholds when a new feature gets unlocked
|
// The user journey states thresholds when a new feature gets unlocked
|
||||||
public static userJourney = {
|
public static userJourney = {
|
||||||
|
|
|
@ -52,7 +52,7 @@ export class SubtleButton extends UIElement{
|
||||||
return new Combine([
|
return new Combine([
|
||||||
this.image,
|
this.image,
|
||||||
this.message,
|
this.message,
|
||||||
]).SetClass("block flex p-3 my-2 bg-blue-100 rounded-lg hover:shadow-xl hover:bg-blue-200")
|
]).SetClass("block flex p-3 my-2 bg-blue-100 rounded-lg hover:shadow-xl hover:bg-blue-200 link-no-underline")
|
||||||
.Render();
|
.Render();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -114,6 +114,10 @@ a {
|
||||||
color: #0078A8;
|
color: #0078A8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.link-no-underline a {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
li {
|
li {
|
||||||
margin-left: 0.5em;
|
margin-left: 0.5em;
|
||||||
padding-left: 0.2em;
|
padding-left: 0.2em;
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<!-- WARNING: index.html serves as a template. If you want to change something, change it there -->
|
<!-- WARNING: index.html serves as a template. If you want to change something, change it there -->
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
{
|
{
|
||||||
"name": "index",
|
"name": "index",
|
||||||
"short_name": "M",
|
"short_name": "MapComplete",
|
||||||
"start_url": "/index.html",
|
"start_url": "/index.html",
|
||||||
"display": "standalone",
|
"display": "standalone",
|
||||||
"background_color": "#fff",
|
"background_color": "#fff",
|
||||||
"description": "M",
|
"description": "An easy to use OpenStreetMap viewer and editor",
|
||||||
"orientation": "portrait-primary, landscape-primary",
|
"orientation": "portrait-primary, landscape-primary",
|
||||||
"icons": [
|
"icons": [
|
||||||
{
|
{
|
||||||
|
|
26
index.ts
26
index.ts
|
@ -70,13 +70,19 @@ let layoutToUse: LayoutConfig = AllKnownLayouts.allKnownLayouts.get(defaultLayou
|
||||||
const userLayoutParam = QueryParameters.GetQueryParameter("userlayout", "false", "If not 'false', a custom (non-official) theme is loaded. This custom layout can be done in multiple ways: \n\n- The hash of the URL contains a base64-encoded .json-file containing the theme definition\n- The hash of the URL contains a lz-compressed .json-file, as generated by the custom theme generator\n- The parameter itself is an URL, in which case that URL will be downloaded. It should point to a .json of a theme");
|
const userLayoutParam = QueryParameters.GetQueryParameter("userlayout", "false", "If not 'false', a custom (non-official) theme is loaded. This custom layout can be done in multiple ways: \n\n- The hash of the URL contains a base64-encoded .json-file containing the theme definition\n- The hash of the URL contains a lz-compressed .json-file, as generated by the custom theme generator\n- The parameter itself is an URL, in which case that URL will be downloaded. It should point to a .json of a theme");
|
||||||
|
|
||||||
// Workaround/legacy to keep the old paramters working as I renamed some of them
|
// Workaround/legacy to keep the old paramters working as I renamed some of them
|
||||||
if(layoutToUse?.id === "cyclofix"){
|
if (layoutToUse?.id === "cyclofix") {
|
||||||
QueryParameters.GetQueryParameter("layer-bike_shops", "true", "Legacy - keep De Fietsambassade working").syncWith(
|
const legacy = QueryParameters.GetQueryParameter("layer-bike_shops", "true", "Legacy - keep De Fietsambassade working");
|
||||||
QueryParameters.GetQueryParameter("layer-bike_shop","true","Legacy - keep De Fietsambassade working")
|
const correct = QueryParameters.GetQueryParameter("layer-bike_shop", "true", "Legacy - keep De Fietsambassade working")
|
||||||
)
|
if(legacy.data !== "true"){
|
||||||
const bikecafes = QueryParameters.GetQueryParameter("layer-bike_cafes", "true", "Legacy - keep De Fietsambassade working").syncWith(
|
correct.setData(legacy.data)
|
||||||
QueryParameters.GetQueryParameter("layer-bike_cafe","true","Legacy - keep De Fietsambassade working")
|
}
|
||||||
)
|
console.log("layer-bike_shop toggles: legacy:",legacy.data, "new:", correct.data)
|
||||||
|
|
||||||
|
const legacyCafe = QueryParameters.GetQueryParameter("layer-bike_cafes", "true", "Legacy - keep De Fietsambassade working")
|
||||||
|
const correctCafe = QueryParameters.GetQueryParameter("layer-bike_cafe", "true", "Legacy - keep De Fietsambassade working")
|
||||||
|
if(legacyCafe.data !== "true"){
|
||||||
|
correctCafe.setData(legacy.data)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -98,7 +104,7 @@ if (layoutFromBase64.startsWith("http")) {
|
||||||
try {
|
try {
|
||||||
console.log("Received ", data)
|
console.log("Received ", data)
|
||||||
let parsed = data;
|
let parsed = data;
|
||||||
if(typeof parsed == "string"){
|
if (typeof parsed == "string") {
|
||||||
parsed = JSON.parse(data);
|
parsed = JSON.parse(data);
|
||||||
}
|
}
|
||||||
// Overwrite the id to the wiki:value
|
// Overwrite the id to the wiki:value
|
||||||
|
@ -129,10 +135,10 @@ if (layoutFromBase64.startsWith("http")) {
|
||||||
// This is the default case: a builtin theme
|
// This is the default case: a builtin theme
|
||||||
InitUiElements.InitAll(layoutToUse, layoutFromBase64, testing, defaultLayout);
|
InitUiElements.InitAll(layoutToUse, layoutFromBase64, testing, defaultLayout);
|
||||||
} else {
|
} else {
|
||||||
// We fall through: no theme loaded: just show a few buttons
|
// We fall through: no theme loaded: just show an overview of layouts
|
||||||
State.state = new State(undefined);
|
State.state = new State(undefined);
|
||||||
new Combine([new MoreScreen(true),
|
new Combine([new MoreScreen(true),
|
||||||
Translations.t.general.aboutMapcomplete
|
Translations.t.general.aboutMapcomplete.SetClass("link-underline")
|
||||||
]).SetClass("block m-5 lg:w-3/4 lg:ml-40")
|
]).SetClass("block m-5 lg:w-3/4 lg:ml-40")
|
||||||
.SetStyle("pointer-events: all;")
|
.SetStyle("pointer-events: all;")
|
||||||
.AttachTo("topleft-tools");
|
.AttachTo("topleft-tools");
|
||||||
|
|
Loading…
Reference in a new issue