Porting repair_station to JSON configuration file
This commit is contained in:
parent
b7b1bc13e4
commit
9e9d80c045
18 changed files with 455 additions and 503 deletions
|
@ -15,6 +15,7 @@ import * as drinkingWater from "../../assets/layers/drinking_water/drinking_wate
|
||||||
import * as ghostbikes from "../../assets/layers/ghost_bike/ghost_bike.json"
|
import * as ghostbikes from "../../assets/layers/ghost_bike/ghost_bike.json"
|
||||||
import * as viewpoint from "../../assets/layers/viewpoint/viewpoint.json"
|
import * as viewpoint from "../../assets/layers/viewpoint/viewpoint.json"
|
||||||
import * as bike_parking from "../../assets/layers/bike_parking/bike_parking.json"
|
import * as bike_parking from "../../assets/layers/bike_parking/bike_parking.json"
|
||||||
|
import * as bike_repair_station from "../../assets/layers/bike_repair_station/bike_repair_station.json"
|
||||||
import * as birdhides from "../../assets/layers/bird_hide/birdhides.json"
|
import * as birdhides from "../../assets/layers/bird_hide/birdhides.json"
|
||||||
|
|
||||||
import {Utils} from "../../Utils";
|
import {Utils} from "../../Utils";
|
||||||
|
@ -31,6 +32,7 @@ export class FromJSON {
|
||||||
FromJSON.Layer(ghostbikes),
|
FromJSON.Layer(ghostbikes),
|
||||||
FromJSON.Layer(viewpoint),
|
FromJSON.Layer(viewpoint),
|
||||||
FromJSON.Layer(bike_parking),
|
FromJSON.Layer(bike_parking),
|
||||||
|
FromJSON.Layer(bike_repair_station),
|
||||||
FromJSON.Layer(birdhides),
|
FromJSON.Layer(birdhides),
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
|
@ -1,117 +0,0 @@
|
||||||
import {LayerDefinition} from "../LayerDefinition";
|
|
||||||
import {And, Or, Tag} from "../../Logic/Tags";
|
|
||||||
import BikeStationChain from "../Questions/bike/StationChain";
|
|
||||||
import BikeStationPumpTools from "../Questions/bike/StationPumpTools";
|
|
||||||
import BikeStationStand from "../Questions/bike/StationStand";
|
|
||||||
import PumpManual from "../Questions/bike/PumpManual";
|
|
||||||
import PumpManometer from "../Questions/bike/PumpManometer";
|
|
||||||
import {ImageCarouselWithUploadConstructor} from "../../UI/Image/ImageCarouselWithUpload";
|
|
||||||
import PumpOperational from "../Questions/bike/PumpOperational";
|
|
||||||
import PumpValves from "../Questions/bike/PumpValves";
|
|
||||||
import Translations from "../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class BikeStations extends LayerDefinition {
|
|
||||||
private readonly repairStation = new Tag("amenity", "bicycle_repair_station");
|
|
||||||
private readonly pump = new Tag("service:bicycle:pump", "yes");
|
|
||||||
private readonly nopump = new Tag("service:bicycle:pump", "no");
|
|
||||||
private readonly pumpOperationalOk = new Or([new Tag("service:bicycle:pump:operational_status", "yes"), new Tag("service:bicycle:pump:operational_status", "operational"), new Tag("service:bicycle:pump:operational_status", "ok"), new Tag("service:bicycle:pump:operational_status", "")]);
|
|
||||||
private readonly tools = new Tag("service:bicycle:tools", "yes");
|
|
||||||
private readonly notools = new Tag("service:bicycle:tools", "no");
|
|
||||||
|
|
||||||
private readonly to = Translations.t.cyclofix.station
|
|
||||||
|
|
||||||
constructor() {
|
|
||||||
super("bikestation");
|
|
||||||
this.name = Translations.t.cyclofix.station.name;
|
|
||||||
this.icon = "./assets/bike/repair_station_pump.svg";
|
|
||||||
|
|
||||||
const tr = Translations.t.cyclofix.station
|
|
||||||
this.overpassFilter = this.repairStation;
|
|
||||||
this.presets = [
|
|
||||||
{
|
|
||||||
title: tr.titlePump,
|
|
||||||
description: tr.services.pump,
|
|
||||||
tags: [this.repairStation, this.pump, this.notools]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: tr.titleRepair,
|
|
||||||
description: tr.services.tools,
|
|
||||||
tags: [this.repairStation, this.tools, this.nopump]
|
|
||||||
},
|
|
||||||
{
|
|
||||||
title: tr.titlePumpAndRepair,
|
|
||||||
description: tr.services.both,
|
|
||||||
tags: [this.repairStation, this.tools, this.pump]
|
|
||||||
},
|
|
||||||
|
|
||||||
]
|
|
||||||
|
|
||||||
this.maxAllowedOverlapPercentage = 10;
|
|
||||||
|
|
||||||
this.minzoom = 13;
|
|
||||||
this.style = this.generateStyleFunction();
|
|
||||||
this.title = new TagRenderingOptions({
|
|
||||||
mappings: [
|
|
||||||
{
|
|
||||||
k: new And([this.pump, this.tools]),
|
|
||||||
txt: this.to.titlePumpAndRepair
|
|
||||||
},
|
|
||||||
{
|
|
||||||
k: new And([this.pump]),
|
|
||||||
txt: this.to.titlePump
|
|
||||||
},
|
|
||||||
{k: null, txt: this.to.titleRepair},
|
|
||||||
]
|
|
||||||
})
|
|
||||||
this.wayHandling = LayerDefinition.WAYHANDLING_CENTER_AND_WAY
|
|
||||||
|
|
||||||
this.elementsToShow = [
|
|
||||||
new ImageCarouselWithUploadConstructor(),
|
|
||||||
|
|
||||||
new BikeStationPumpTools(),
|
|
||||||
new BikeStationChain().OnlyShowIf(this.tools),
|
|
||||||
new BikeStationStand().OnlyShowIf(this.tools),
|
|
||||||
|
|
||||||
new PumpManual().OnlyShowIf(this.pump),
|
|
||||||
new PumpManometer().OnlyShowIf(this.pump),
|
|
||||||
new PumpValves().OnlyShowIf(this.pump),
|
|
||||||
new PumpOperational().OnlyShowIf(this.pump),
|
|
||||||
|
|
||||||
// new BikeStationOperator(),
|
|
||||||
// new BikeStationBrand() DISABLED
|
|
||||||
];
|
|
||||||
}
|
|
||||||
|
|
||||||
private generateStyleFunction() {
|
|
||||||
const self = this;
|
|
||||||
return function (properties: any) {
|
|
||||||
const hasPump = self.pump.matchesProperties(properties)
|
|
||||||
const isOperational = self.pumpOperationalOk.matchesProperties(properties)
|
|
||||||
const hasTools = self.tools.matchesProperties(properties)
|
|
||||||
let iconName = "repair_station.svg";
|
|
||||||
if (hasTools && hasPump && isOperational) {
|
|
||||||
iconName = "repair_station_pump.svg"
|
|
||||||
} else if(hasTools) {
|
|
||||||
iconName = "repair_station.svg"
|
|
||||||
} else if(hasPump) {
|
|
||||||
if (isOperational) {
|
|
||||||
iconName = "pump.svg"
|
|
||||||
} else {
|
|
||||||
iconName = "broken_pump_2.svg"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const iconUrl = `./assets/bike/${iconName}`
|
|
||||||
return {
|
|
||||||
color: "#00bb00",
|
|
||||||
icon: {
|
|
||||||
iconUrl: iconUrl,
|
|
||||||
iconSize: [50, 50],
|
|
||||||
iconAnchor: [25, 50]
|
|
||||||
}
|
|
||||||
};
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,5 +1,4 @@
|
||||||
import {Layout} from "../Layout";
|
import {Layout} from "../Layout";
|
||||||
import BikeServices from "../Layers/BikeStations";
|
|
||||||
import BikeShops from "../Layers/BikeShops";
|
import BikeShops from "../Layers/BikeShops";
|
||||||
import Translations from "../../UI/i18n/Translations";
|
import Translations from "../../UI/i18n/Translations";
|
||||||
import Combine from "../../UI/Base/Combine";
|
import Combine from "../../UI/Base/Combine";
|
||||||
|
@ -13,7 +12,9 @@ export default class Cyclofix extends Layout {
|
||||||
"cyclofix",
|
"cyclofix",
|
||||||
["en", "nl", "fr","gl"],
|
["en", "nl", "fr","gl"],
|
||||||
Translations.t.cyclofix.title,
|
Translations.t.cyclofix.title,
|
||||||
[new BikeServices(), new BikeShops(), "drinking_water", "bike_parking", new BikeOtherShops(), new BikeCafes()],
|
["bike_repair_station", new BikeShops(), "drinking_water", "bike_parking", new BikeOtherShops(), new BikeCafes(),
|
||||||
|
// The first of november, we remember our dead
|
||||||
|
...(new Date().getMonth() + 1 == 11 && new Date().getDay() + 1 == 1 ? ["ghost_bike"] : [])],
|
||||||
16,
|
16,
|
||||||
50.8465573,
|
50.8465573,
|
||||||
4.3516970,
|
4.3516970,
|
||||||
|
|
|
@ -1,18 +0,0 @@
|
||||||
import {Tag} from "../../../Logic/Tags";
|
|
||||||
import Translations from "../../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class PumpManometer extends TagRenderingOptions {
|
|
||||||
constructor() {
|
|
||||||
const to = Translations.t.cyclofix.station.manometer
|
|
||||||
super({
|
|
||||||
question: to.question,
|
|
||||||
mappings: [
|
|
||||||
{k: new Tag("manometer", "yes"), txt: to.yes},
|
|
||||||
{k: new Tag("manometer", "no"), txt: to.no},
|
|
||||||
{k: new Tag("manometer", "broken"), txt: to.broken}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
import {Tag} from "../../../Logic/Tags";
|
|
||||||
import Translations from "../../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class PumpManual extends TagRenderingOptions {
|
|
||||||
constructor() {
|
|
||||||
const to = Translations.t.cyclofix.station.electric
|
|
||||||
super({
|
|
||||||
priority: 5,
|
|
||||||
question: to.question,
|
|
||||||
mappings: [
|
|
||||||
{k: new Tag("manual", "yes"), txt: to.manual},
|
|
||||||
{k: new Tag("manual", "no"), txt: to.electric}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,17 +0,0 @@
|
||||||
import {Tag} from "../../../Logic/Tags";
|
|
||||||
import Translations from "../../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class PumpOperational extends TagRenderingOptions {
|
|
||||||
constructor() {
|
|
||||||
const to = Translations.t.cyclofix.station.operational
|
|
||||||
super({
|
|
||||||
question: to.question,
|
|
||||||
mappings: [
|
|
||||||
{k: new Tag("service:bicycle:pump:operational_status","broken"), txt: to.broken},
|
|
||||||
{k: new Tag("service:bicycle:pump:operational_status",""), txt: to.operational}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,29 +0,0 @@
|
||||||
import {Tag} from "../../../Logic/Tags";
|
|
||||||
import Translations from "../../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class
|
|
||||||
PumpValves extends TagRenderingOptions{
|
|
||||||
constructor() {
|
|
||||||
const to = Translations.t.cyclofix.station.valves
|
|
||||||
super({
|
|
||||||
question: to.question,
|
|
||||||
mappings: [
|
|
||||||
{
|
|
||||||
k: new Tag("valves", "sclaverand;schrader;dunlop"),
|
|
||||||
txt: to.default
|
|
||||||
},
|
|
||||||
{k: new Tag("valves", "dunlop"), txt: to.dunlop},
|
|
||||||
{k: new Tag("valves", "sclaverand"), txt: to.sclaverand},
|
|
||||||
{k: new Tag("valves", "auto"), txt: to.auto},
|
|
||||||
],
|
|
||||||
freeform: {
|
|
||||||
extraTags: new Tag("fixme", "Freeform valves= tag used: possibly a wrong value"),
|
|
||||||
key: "valves",
|
|
||||||
template: to.template,
|
|
||||||
renderTemplate: to.render
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
import {Tag} from "../../../Logic/Tags";
|
|
||||||
import Translations from "../../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class StationChain extends TagRenderingOptions {
|
|
||||||
constructor() {
|
|
||||||
const to = Translations.t.cyclofix.station.chain
|
|
||||||
super({
|
|
||||||
priority: 5,
|
|
||||||
question: to.question,
|
|
||||||
mappings: [
|
|
||||||
{k: new Tag("service:bicycle:chain_tool", "yes"), txt: to.yes},
|
|
||||||
{k: new Tag("service:bicycle:chain_tool", "no"), txt: to.no},
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,27 +0,0 @@
|
||||||
import {Tag} from "../../../Logic/Tags";
|
|
||||||
import Translations from "../../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class BikeStationOperator extends TagRenderingOptions {
|
|
||||||
constructor() {
|
|
||||||
const to = Translations.t.cyclofix.station.operator
|
|
||||||
super({
|
|
||||||
priority: 15,
|
|
||||||
question: to.question,
|
|
||||||
mappings: [
|
|
||||||
{k: new Tag("operator", "KU Leuven"), txt: "KU Leuven"},
|
|
||||||
{k: new Tag("operator", "Stad Halle"), txt: "Stad Halle"},
|
|
||||||
{k: new Tag("operator", "Saint Gilles - Sint Gillis"), txt: "Saint Gilles - Sint Gillis"},
|
|
||||||
{k: new Tag("operator", "Jette"), txt: "Jette"},
|
|
||||||
{k: new Tag("operator", "private"), txt: to.private}
|
|
||||||
],
|
|
||||||
freeform: {
|
|
||||||
key: "operator",
|
|
||||||
template: to.template,
|
|
||||||
renderTemplate: to.render,
|
|
||||||
placeholder: "organisatie"
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,19 +0,0 @@
|
||||||
import {Tag, And} from "../../../Logic/Tags";
|
|
||||||
import Translations from "../../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class BikeStationPumpTools extends TagRenderingOptions {
|
|
||||||
constructor() {
|
|
||||||
const to = Translations.t.cyclofix.station.services
|
|
||||||
super({
|
|
||||||
priority: 15,
|
|
||||||
question: to.question,
|
|
||||||
mappings: [
|
|
||||||
{k: new And([new Tag("service:bicycle:tools", "no"), new Tag("service:bicycle:pump", "yes")]), txt: to.pump},
|
|
||||||
{k: new And([new Tag("service:bicycle:tools", "yes"), new Tag("service:bicycle:pump", "no")]), txt: to.tools},
|
|
||||||
{k: new And([new Tag("service:bicycle:tools", "yes"), new Tag("service:bicycle:pump", "yes")]), txt: to.both}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,18 +0,0 @@
|
||||||
import {Tag} from "../../../Logic/Tags";
|
|
||||||
import Translations from "../../../UI/i18n/Translations";
|
|
||||||
import {TagRenderingOptions} from "../../TagRenderingOptions";
|
|
||||||
|
|
||||||
|
|
||||||
export default class BikeStationStand extends TagRenderingOptions {
|
|
||||||
constructor() {
|
|
||||||
const to = Translations.t.cyclofix.station.stand;
|
|
||||||
super({
|
|
||||||
priority: 10,
|
|
||||||
question: to.question,
|
|
||||||
mappings: [
|
|
||||||
{k: new Tag("service:bicycle:stand", "yes"), txt: to.yes},
|
|
||||||
{k: new Tag("service:bicycle:stand", "no"), txt: to.no},
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -5,19 +5,31 @@ import {TagRenderingConfigJson} from "../../Customizations/JSON/TagRenderingConf
|
||||||
export class GenerateEmpty {
|
export class GenerateEmpty {
|
||||||
public static createEmptyLayer(): LayerConfigJson {
|
public static createEmptyLayer(): LayerConfigJson {
|
||||||
return {
|
return {
|
||||||
id: undefined,
|
id: "yourlayer",
|
||||||
name: undefined,
|
name: "Layer",
|
||||||
minzoom: 0,
|
minzoom: 12,
|
||||||
overpassTags: {and: [""]},
|
overpassTags: {and: [""]},
|
||||||
title: undefined,
|
title: "Layer",
|
||||||
description: {},
|
description: {},
|
||||||
tagRenderings: [],
|
tagRenderings: [],
|
||||||
|
icon: {
|
||||||
|
render: "./assets/bug.svg"
|
||||||
|
},
|
||||||
|
width: {
|
||||||
|
render: "8"
|
||||||
|
},
|
||||||
|
iconSize:{
|
||||||
|
render: "40,40,center"
|
||||||
|
},
|
||||||
|
color:{
|
||||||
|
render: "#00f"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static createEmptyLayout(): LayoutConfigJson {
|
public static createEmptyLayout(): LayoutConfigJson {
|
||||||
return {
|
return {
|
||||||
id: "",
|
id: "id",
|
||||||
title: {},
|
title: {},
|
||||||
description: {},
|
description: {},
|
||||||
language: [],
|
language: [],
|
||||||
|
|
|
@ -170,25 +170,29 @@ export default class LayerPanel extends UIElement {
|
||||||
{
|
{
|
||||||
title: "Icon",
|
title: "Icon",
|
||||||
description: "A visual representation for this layer and for the points on the map.",
|
description: "A visual representation for this layer and for the points on the map.",
|
||||||
disableQuestions: true
|
disableQuestions: true,
|
||||||
|
noLanguage: true
|
||||||
});
|
});
|
||||||
const size = new TagRenderingPanel(languages, currentlySelected, userDetails,
|
const size = new TagRenderingPanel(languages, currentlySelected, userDetails,
|
||||||
{
|
{
|
||||||
title: "Icon Size",
|
title: "Icon Size",
|
||||||
description: "The size of the icons on the map in pixels. Can vary based on the tagging",
|
description: "The size of the icons on the map in pixels. Can vary based on the tagging",
|
||||||
disableQuestions: true
|
disableQuestions: true,
|
||||||
|
noLanguage: true
|
||||||
});
|
});
|
||||||
const color = new TagRenderingPanel(languages, currentlySelected, userDetails,
|
const color = new TagRenderingPanel(languages, currentlySelected, userDetails,
|
||||||
{
|
{
|
||||||
title: "Way and area color",
|
title: "Way and area color",
|
||||||
description: "The color or a shown way or area. Can vary based on the tagging",
|
description: "The color or a shown way or area. Can vary based on the tagging",
|
||||||
disableQuestions: true
|
disableQuestions: true,
|
||||||
|
noLanguage: true
|
||||||
});
|
});
|
||||||
const stroke = new TagRenderingPanel(languages, currentlySelected, userDetails,
|
const stroke = new TagRenderingPanel(languages, currentlySelected, userDetails,
|
||||||
{
|
{
|
||||||
title: "Stroke width",
|
title: "Stroke width",
|
||||||
description: "The width of lines representing ways and the outline of areas. Can vary based on the tags",
|
description: "The width of lines representing ways and the outline of areas. Can vary based on the tags",
|
||||||
disableQuestions: true
|
disableQuestions: true,
|
||||||
|
noLanguage: true
|
||||||
});
|
});
|
||||||
this.registerTagRendering(iconSelect);
|
this.registerTagRendering(iconSelect);
|
||||||
this.registerTagRendering(size);
|
this.registerTagRendering(size);
|
||||||
|
@ -201,9 +205,9 @@ export default class LayerPanel extends UIElement {
|
||||||
|
|
||||||
return new SettingsTable([
|
return new SettingsTable([
|
||||||
setting(iconSelect, "icon"),
|
setting(iconSelect, "icon"),
|
||||||
setting(size, "size"),
|
setting(size, "iconSize"),
|
||||||
setting(color, "color"),
|
setting(color, "color"),
|
||||||
setting(stroke, "stroke")
|
setting(stroke, "width")
|
||||||
], currentlySelected);
|
], currentlySelected);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,7 +31,8 @@ export default class TagRenderingPanel extends InputElement<TagRenderingConfigJs
|
||||||
title?: string,
|
title?: string,
|
||||||
description?: string,
|
description?: string,
|
||||||
disableQuestions?: boolean,
|
disableQuestions?: boolean,
|
||||||
isImage?: boolean
|
isImage?: boolean,
|
||||||
|
noLanguage?: boolean
|
||||||
}) {
|
}) {
|
||||||
super();
|
super();
|
||||||
|
|
||||||
|
@ -57,7 +58,8 @@ export default class TagRenderingPanel extends InputElement<TagRenderingConfigJs
|
||||||
const questionSettings = [
|
const questionSettings = [
|
||||||
|
|
||||||
|
|
||||||
setting(new MultiLingualTextFields(languages), "question", "Question", "If the key or mapping doesn't match, this question is asked"),
|
setting(options?.noLanguage ? TextField.StringInput() : new MultiLingualTextFields(languages)
|
||||||
|
, "question", "Question", "If the key or mapping doesn't match, this question is asked"),
|
||||||
|
|
||||||
setting(new AndOrTagInput(), "condition", "Condition",
|
setting(new AndOrTagInput(), "condition", "Condition",
|
||||||
"Only show this tag rendering if these tags matches. Optional field.<br/>Note that the Overpass-tags are already always included in this object"),
|
"Only show this tag rendering if these tags matches. Optional field.<br/>Note that the Overpass-tags are already always included in this object"),
|
||||||
|
@ -76,7 +78,9 @@ export default class TagRenderingPanel extends InputElement<TagRenderingConfigJs
|
||||||
];
|
];
|
||||||
|
|
||||||
const settings: (string | SingleSetting<any>)[] = [
|
const settings: (string | SingleSetting<any>)[] = [
|
||||||
setting(new MultiLingualTextFields(languages), "render", "Value to show", " Renders this value. Note that <span class='literal-code'>{key}</span>-parts are substituted by the corresponding values of the element. If neither 'textFieldQuestion' nor 'mappings' are defined, this text is simply shown as default value."),
|
setting(
|
||||||
|
options?.noLanguage ? TextField.StringInput() :
|
||||||
|
new MultiLingualTextFields(languages), "render", "Value to show", " Renders this value. Note that <span class='literal-code'>{key}</span>-parts are substituted by the corresponding values of the element. If neither 'textFieldQuestion' nor 'mappings' are defined, this text is simply shown as default value."),
|
||||||
|
|
||||||
questionsNotUnlocked ? `You need at least ${State.userJourney.themeGeneratorFullUnlock} changesets to unlock the 'question'-field and to use your theme to edit OSM data`: "",
|
questionsNotUnlocked ? `You need at least ${State.userJourney.themeGeneratorFullUnlock} changesets to unlock the 'question'-field and to use your theme to edit OSM data`: "",
|
||||||
...(options?.disableQuestions ? [] : questionSettings),
|
...(options?.disableQuestions ? [] : questionSettings),
|
||||||
|
@ -85,7 +89,7 @@ export default class TagRenderingPanel extends InputElement<TagRenderingConfigJs
|
||||||
setting(new MultiInput<{ if: AndOrTagConfigJson, then: (string | any), hideInAnswer?: boolean }>("Add a mapping",
|
setting(new MultiInput<{ if: AndOrTagConfigJson, then: (string | any), hideInAnswer?: boolean }>("Add a mapping",
|
||||||
() => ({if: undefined, then: undefined}),
|
() => ({if: undefined, then: undefined}),
|
||||||
() => new MappingInput(languages, options?.disableQuestions ?? false)), "mappings",
|
() => new MappingInput(languages, options?.disableQuestions ?? false)), "mappings",
|
||||||
"Mappings", "")
|
"If a tag matches, then show the respective text", "")
|
||||||
|
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
|
@ -37,7 +37,7 @@ export class SimpleAddUI extends UIElement {
|
||||||
this.ListenTo(State.state.osmConnection.userDetails);
|
this.ListenTo(State.state.osmConnection.userDetails);
|
||||||
this.ListenTo(State.state.layerUpdater.runningQuery);
|
this.ListenTo(State.state.layerUpdater.runningQuery);
|
||||||
this.ListenTo(this._confirmPreset);
|
this.ListenTo(this._confirmPreset);
|
||||||
|
this.ListenTo(State.state.locationControl);
|
||||||
|
|
||||||
this._loginButton = Translations.t.general.add.pleaseLogin.Clone().onClick(() => State.state.osmConnection.AttemptLogin());
|
this._loginButton = Translations.t.general.add.pleaseLogin.Clone().onClick(() => State.state.osmConnection.AttemptLogin());
|
||||||
|
|
||||||
|
|
|
@ -51,7 +51,9 @@ export default class Translations {
|
||||||
gl: 'estación de bicicletas (arranxo, bomba de ar ou ambos)'
|
gl: 'estación de bicicletas (arranxo, bomba de ar ou ambos)'
|
||||||
}),
|
}),
|
||||||
// title: new T({en: 'Bike station', nl: 'Fietsstation', fr: 'Station vélo', gl: 'Estación de bicicletas'}), Old, non-dynamic title
|
// title: new T({en: 'Bike station', nl: 'Fietsstation', fr: 'Station vélo', gl: 'Estación de bicicletas'}), Old, non-dynamic title
|
||||||
titlePump: new T({en: 'Bike pump', nl: 'Fietspomp', fr: 'TODO: fr', gl: 'Bomba de ar'}),
|
titlePump: new T({
|
||||||
|
|
||||||
|
}),
|
||||||
titleRepair: new T({
|
titleRepair: new T({
|
||||||
en: 'Bike repair station',
|
en: 'Bike repair station',
|
||||||
nl: 'Herstelpunt',
|
nl: 'Herstelpunt',
|
||||||
|
@ -64,104 +66,16 @@ export default class Translations {
|
||||||
fr: 'Point station velo avec pompe',
|
fr: 'Point station velo avec pompe',
|
||||||
gl: 'Estación de bicicletas (arranxo e bomba de ar)'
|
gl: 'Estación de bicicletas (arranxo e bomba de ar)'
|
||||||
}),
|
}),
|
||||||
manometer: {
|
|
||||||
question: new T({
|
|
||||||
en: 'Does the pump have a pressure indicator or manometer?',
|
|
||||||
nl: 'Heeft deze pomp een luchtdrukmeter?',
|
|
||||||
fr: 'Est-ce que la pompe à un manomètre integré?',
|
|
||||||
gl: 'Ten a bomba de ar un indicador de presión ou un manómetro?'
|
|
||||||
}),
|
|
||||||
yes: new T({
|
|
||||||
en: 'There is a manometer',
|
|
||||||
nl: 'Er is een luchtdrukmeter',
|
|
||||||
fr: 'Il y a un manomètre',
|
|
||||||
gl: 'Hai manómetro'
|
|
||||||
}),
|
|
||||||
no: new T({
|
|
||||||
en: 'There is no manometer',
|
|
||||||
nl: 'Er is geen luchtdrukmeter',
|
|
||||||
fr: 'Il n\'y a pas de manomètre',
|
|
||||||
gl: 'Non hai manómetro'
|
|
||||||
}),
|
|
||||||
broken: new T({
|
|
||||||
en: 'There is manometer but it is broken',
|
|
||||||
nl: 'Er is een luchtdrukmeter maar die is momenteel defect',
|
|
||||||
fr: 'Il y a un manomètre mais il est cassé',
|
|
||||||
gl: 'Hai manómetro pero está estragado'
|
|
||||||
})
|
|
||||||
},
|
|
||||||
electric: {
|
|
||||||
question: new T({
|
|
||||||
en: 'Is this an electric bike pump?',
|
|
||||||
nl: 'Is dit een electrische fietspomp?',
|
|
||||||
fr: 'Est-ce que cette pompe est électrique?',
|
|
||||||
gl: 'Esta é unha bomba de ar eléctrica?'
|
|
||||||
}),
|
|
||||||
manual: new T({
|
|
||||||
en: 'Manual pump',
|
|
||||||
nl: 'Manuele pomp',
|
|
||||||
fr: 'Pompe manuelle',
|
|
||||||
gl: 'Bomba de ar manual'
|
|
||||||
}),
|
|
||||||
electric: new T({
|
|
||||||
en: 'Electrical pump',
|
|
||||||
nl: 'Electrische pomp',
|
|
||||||
fr: 'Pompe électrique',
|
|
||||||
gl: 'Bomba de ar eléctrica'
|
|
||||||
})
|
|
||||||
},
|
|
||||||
operational: {
|
|
||||||
question: new T({
|
|
||||||
en: 'Is the bike pump still operational?',
|
|
||||||
nl: 'Werkt de fietspomp nog?',
|
|
||||||
fr: 'Est-ce que cette pompe marche t\'elle toujours?',
|
|
||||||
gl: 'Segue a funcionar a bomba de ar?'
|
|
||||||
}),
|
|
||||||
operational: new T({
|
|
||||||
en: 'The bike pump is operational',
|
|
||||||
nl: 'De fietspomp werkt nog',
|
|
||||||
fr: 'La pompe est opérationnelle',
|
|
||||||
gl: 'A bomba de ar está operativa'
|
|
||||||
}),
|
|
||||||
broken: new T({
|
|
||||||
en: 'The bike pump is broken',
|
|
||||||
nl: 'De fietspomp is kapot',
|
|
||||||
fr: 'La pompe est cassé',
|
|
||||||
gl: 'A bomba de ar está estragada'
|
|
||||||
})
|
|
||||||
},
|
|
||||||
valves: {
|
valves: {
|
||||||
question: new T({
|
|
||||||
en: 'What valves are supported?',
|
|
||||||
nl: 'Welke ventielen werken er met de pomp?',
|
|
||||||
fr: 'Quelles valves sont compatibles?',
|
|
||||||
gl: 'Que válvulas son compatíbeis?'
|
|
||||||
}),
|
|
||||||
default: new T({
|
default: new T({
|
||||||
en: 'There is a default head, so Dunlop, Sclaverand and auto',
|
|
||||||
nl: 'Er is een standaard aansluiting, die dus voor Dunlop, Sclaverand en auto\'s werkt',
|
|
||||||
fr: 'Il y a une valve par défaut, fonctionnant sur les valves Dunlop, Sclaverand et les valves de voitures',
|
|
||||||
gl: 'Hai un cabezal predeterminado que é compatíbel con Dunlop, Sclaverand e automóbil'
|
|
||||||
}),
|
}),
|
||||||
dunlop: new T({en: 'Only Dunlop', nl: 'Enkel Dunlop', fr: 'TODO: fr', gl: 'Só Dunlop'}),
|
dunlop: new T({}),
|
||||||
sclaverand: new T({
|
sclaverand: new T({
|
||||||
en: 'Only Sclaverand (also known as Presta)',
|
|
||||||
nl: 'Enkel Sclaverand (ook gekend als Presta)',
|
|
||||||
fr: 'Seulement Sclaverand (aussi appelé Presta)',
|
|
||||||
gl: 'Só Sclaverand (tamén coñecido como Presta)'
|
|
||||||
}),
|
|
||||||
auto: new T({
|
|
||||||
en: 'Only for cars',
|
|
||||||
nl: 'Enkel voor auto\'s',
|
|
||||||
fr: 'TODO: fr',
|
|
||||||
gl: 'Só para automóbiles'
|
|
||||||
}),
|
|
||||||
render: new T({
|
|
||||||
en: 'This pump supports the following valves: {valves}',
|
|
||||||
nl: 'Deze pomp werkt met de volgende ventielen: {valves}',
|
|
||||||
fr: 'Cette pompe est compatible avec les valves suivantes: {valves}',
|
|
||||||
gl: 'Esta bomba de ar admite as seguintes válvulas: {valves}'
|
|
||||||
}),
|
}),
|
||||||
|
|
||||||
template: new T({
|
template: new T({
|
||||||
en: 'Some other valve(s): $$$',
|
en: 'Some other valve(s): $$$',
|
||||||
nl: 'Een ander type ventiel(en): $$$',
|
nl: 'Een ander type ventiel(en): $$$',
|
||||||
|
@ -169,99 +83,6 @@ export default class Translations {
|
||||||
gl: 'Algunha outra válvula: $$$'
|
gl: 'Algunha outra válvula: $$$'
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
chain: {
|
|
||||||
question: new T({
|
|
||||||
en: 'Does this bike repair station have a special tool to repair your bike chain?',
|
|
||||||
nl: 'Heeft dit herstelpunt een speciale reparatieset voor je ketting?',
|
|
||||||
fr: 'Est-ce que cette station vélo a un outils specifique pour réparer la chaîne du velo?',
|
|
||||||
gl: 'Esta estación de arranxo de bicicletas ten unha ferramenta especial para arranxar a cadea da túa bicicleta?'
|
|
||||||
}),
|
|
||||||
yes: new T({
|
|
||||||
en: 'There is a chain tool',
|
|
||||||
nl: 'Er is een reparatieset voor je ketting',
|
|
||||||
fr: 'Il y a un outil pour réparer la chaine',
|
|
||||||
gl: 'Hai unha ferramenta para a cadea'
|
|
||||||
}),
|
|
||||||
no: new T({
|
|
||||||
en: 'There is no chain tool',
|
|
||||||
nl: 'Er is geen reparatieset voor je ketting',
|
|
||||||
fr: 'Il n\'y a pas d\'outil pour réparer la chaine',
|
|
||||||
gl: 'Non hai unha ferramenta para a cadea'
|
|
||||||
}),
|
|
||||||
},
|
|
||||||
operator: {
|
|
||||||
render: new T({
|
|
||||||
en: 'This bike station is operated by {operator}',
|
|
||||||
nl: 'Dit fietspunt wordt beheerd door {operator}',
|
|
||||||
fr: 'Cette station vélo est opéré par {operator}',
|
|
||||||
gl: 'Esta estación de bicicletas es operada por {operator}'
|
|
||||||
}),
|
|
||||||
template: new T({
|
|
||||||
en: 'A different operator: $$$',
|
|
||||||
nl: 'Een andere beheerder: $$$',
|
|
||||||
fr: 'TODO: fr',
|
|
||||||
gl: 'Un operador diferente: $$$'
|
|
||||||
}),
|
|
||||||
question: new T({
|
|
||||||
en: 'Who operates this bike station (name of university, shop, city...)?',
|
|
||||||
nl: 'Wie beheert dit fietsstation (naam universiteit, winkel, stad...)?',
|
|
||||||
fr: 'Qui opére cette station vélo (nom de l\'université, magasin, ville...)?',
|
|
||||||
gl: 'Quen opera esta estación de bicicletas (nome da universidade, tenda, concello...)?'
|
|
||||||
}),
|
|
||||||
private: new T({
|
|
||||||
en: 'Operated by a private person',
|
|
||||||
nl: 'Wordt beheerd door een privépersoon',
|
|
||||||
fr: 'Operé par un tier privé',
|
|
||||||
gl: 'Operado por unha persoa privada'
|
|
||||||
}),
|
|
||||||
},
|
|
||||||
services: {
|
|
||||||
question: new T({
|
|
||||||
en: "Which services are available at this bike station?",
|
|
||||||
nl: "Welke functies biedt dit fietspunt?",
|
|
||||||
fr: "Quels services sont valables à cette station vélo?",
|
|
||||||
gl: "Que servizos están dispoñíbeis nesta estación de bicicletas?"
|
|
||||||
}),
|
|
||||||
pump: new T({
|
|
||||||
// Note: this previously read: a pump is available. It is not because the pump is present, that it is available (e.g. broken)
|
|
||||||
en: "There is only a pump present",
|
|
||||||
nl: "Er is enkel een pomp aanwezig",
|
|
||||||
fr: "Il y a seulement une pompe",
|
|
||||||
gl: "Só hai unha bomba de ar presente"
|
|
||||||
}),
|
|
||||||
tools: new T({
|
|
||||||
en: "There are only tools (screwdrivers, pliers...) present",
|
|
||||||
nl: "Er is enkel gereedschap aanwezig (schroevendraaier, tang...)",
|
|
||||||
fr: "Il y a seulement des outils (tournevis, pinces...)",
|
|
||||||
gl: "Só hai ferramentas (desaparafusadores, alicates...) presentes"
|
|
||||||
}),
|
|
||||||
both: new T({
|
|
||||||
en: "There are both tools and a pump present",
|
|
||||||
nl: "Er is zowel een pomp als gereedschap aanwezig",
|
|
||||||
fr: "IL y a des outils et une pompe",
|
|
||||||
gl: "Hai ferramentas e unha bomba de ar presentes"
|
|
||||||
}),
|
|
||||||
},
|
|
||||||
stand: {
|
|
||||||
question: new T({
|
|
||||||
en: "Does this bike station have a hook to suspend your bike with or a stand to elevate it?",
|
|
||||||
nl: "Heeft dit herstelpunt een haak of standaard om je fiets op te hangen/zetten?",
|
|
||||||
fr: "Est-ce que cette station vélo à un crochet pour suspendre son velo ou une accroche pour l'élevé?",
|
|
||||||
gl: "Esta estación de bicicletas ten un guindastre para pendurar a túa bicicleta ou un soporte para elevala?"
|
|
||||||
}),
|
|
||||||
yes: new T({
|
|
||||||
en: "There is a hook or stand",
|
|
||||||
nl: "Er is een haak of standaard",
|
|
||||||
fr: "Oui il y a un crochet ou une accroche",
|
|
||||||
gl: "Hai un guindastre ou soporte"
|
|
||||||
}),
|
|
||||||
no: new T({
|
|
||||||
en: "There is no hook or stand",
|
|
||||||
nl: "Er is geen haak of standaard",
|
|
||||||
fr: "Non il n'y pas de crochet ou d'accroche",
|
|
||||||
gl: "Non hai un guindastre ou soporte"
|
|
||||||
}),
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
shop: {
|
shop: {
|
||||||
name: new T({
|
name: new T({
|
||||||
|
|
|
@ -6,12 +6,345 @@
|
||||||
"fr": "Station velo (réparation, pompe à vélo)",
|
"fr": "Station velo (réparation, pompe à vélo)",
|
||||||
"gl": "Estación de bicicletas (arranxo, bomba de ar ou ambos)"
|
"gl": "Estación de bicicletas (arranxo, bomba de ar ou ambos)"
|
||||||
},
|
},
|
||||||
"minzoom": 12,
|
"minzoom": 13,
|
||||||
"overpassTags": {
|
"overpassTags": {
|
||||||
"and": [
|
"and": [
|
||||||
"amenity=bicycle_repair_station"
|
"amenity=bicycle_repair_station"
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
"title": {
|
||||||
|
"render": {
|
||||||
|
"en": "Bike station (pump & repair)",
|
||||||
|
"nl": "Herstelpunt met pomp",
|
||||||
|
"fr": "Point station velo avec pompe",
|
||||||
|
"gl": "Estación de bicicletas (arranxo e bomba de ar)"
|
||||||
|
},
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"or": [
|
||||||
|
"service:bicycle:pump=no",
|
||||||
|
"service:bicycle:pump:operational_status=broken"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"en": "Bike repair station",
|
||||||
|
"nl": "Herstelpunt",
|
||||||
|
"fr": "Point de réparation velo",
|
||||||
|
"gl": "Estación de arranxo de bicicletas"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:pump=yes",
|
||||||
|
"service:bicycle:tools=yes"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"en": "Bike repair station",
|
||||||
|
"nl": "Herstelpunt",
|
||||||
|
"fr": "Point de réparation",
|
||||||
|
"gl": "Estación de arranxo de bicicletas"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:pump:operational_status=broken",
|
||||||
|
"service:bicycle:tools=no"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"en": "Broken pump",
|
||||||
|
"nl": "Kapotte fietspomp",
|
||||||
|
"fr": "Pompe cassée",
|
||||||
|
"gl": "Bomba de ar estragada"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:pump=yes",
|
||||||
|
"service:bicycle:tools=no"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"en": "Bicycle pump",
|
||||||
|
"nl": "Fietspomp",
|
||||||
|
"fr": "Pompe de vélo",
|
||||||
|
"gl": "Bomba de ar"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"tagRenderings": [
|
||||||
|
"images",
|
||||||
|
{
|
||||||
|
"question": {
|
||||||
|
"en": "Which services are available at this bike station?",
|
||||||
|
"nl": "Welke functies biedt dit fietspunt?",
|
||||||
|
"fr": "Quels services sont valables à cette station vélo?",
|
||||||
|
"gl": "Que servizos están dispoñíbeis nesta estación de bicicletas?"
|
||||||
|
},
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:tools=no",
|
||||||
|
"service:bicycle:pump=yes"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"en": "There is only a pump present",
|
||||||
|
"nl": "Er is enkel een pomp aanwezig",
|
||||||
|
"fr": "Il y a seulement une pompe",
|
||||||
|
"gl": "Só hai unha bomba de ar presente"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:tools=yes",
|
||||||
|
"service:bicycle:pump=no"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"en": "There are only tools (screwdrivers, pliers...) present",
|
||||||
|
"nl": "Er is enkel gereedschap aanwezig (schroevendraaier, tang...)",
|
||||||
|
"fr": "Il y a seulement des outils (tournevis, pinces...)",
|
||||||
|
"gl": "Só hai ferramentas (desaparafusadores, alicates...) presentes"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:tools=yes",
|
||||||
|
"service:bicycle:pump=yes"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": {
|
||||||
|
"en": "There are both tools and a pump present",
|
||||||
|
"nl": "Er is zowel een pomp als gereedschap aanwezig",
|
||||||
|
"fr": "IL y a des outils et une pompe",
|
||||||
|
"gl": "Hai ferramentas e unha bomba de ar presentes"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"question": {
|
||||||
|
"en": "Does this bike repair station have a special tool to repair your bike chain?",
|
||||||
|
"nl": "Heeft dit herstelpunt een speciale reparatieset voor je ketting?",
|
||||||
|
"fr": "Est-ce que cette station vélo a un outils specifique pour réparer la chaîne du velo?",
|
||||||
|
"gl": "Esta estación de arranxo de bicicletas ten unha ferramenta especial para arranxar a cadea da túa bicicleta?"
|
||||||
|
},
|
||||||
|
"condition": "service:bicycle:tools=yes",
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "service:bicycle:chain_tool=yes",
|
||||||
|
"then": {
|
||||||
|
"en": "There is a chain tool",
|
||||||
|
"nl": "Er is een reparatieset voor je ketting",
|
||||||
|
"fr": "Il y a un outil pour réparer la chaine",
|
||||||
|
"gl": "Hai unha ferramenta para a cadea"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "service:bicycle:chain_tool=no",
|
||||||
|
"then": {
|
||||||
|
"en": "There is no chain tool",
|
||||||
|
"nl": "Er is geen reparatieset voor je ketting",
|
||||||
|
"fr": "Il n'y a pas d'outil pour réparer la chaine",
|
||||||
|
"gl": "Non hai unha ferramenta para a cadea"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"question": {
|
||||||
|
"en": "Does this bike station have a hook to suspend your bike with or a stand to elevate it?",
|
||||||
|
"nl": "Heeft dit herstelpunt een haak of standaard om je fiets op te hangen/zetten?",
|
||||||
|
"fr": "Est-ce que cette station vélo à un crochet pour suspendre son velo ou une accroche pour l'élevé?",
|
||||||
|
"gl": "Esta estación de bicicletas ten un guindastre para pendurar a túa bicicleta ou un soporte para elevala?"
|
||||||
|
},
|
||||||
|
"condition": "service:bicycle:tools=yes",
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "service:bicycle:stand=yes",
|
||||||
|
"then": {
|
||||||
|
"en": "There is a hook or stand",
|
||||||
|
"nl": "Er is een haak of standaard",
|
||||||
|
"fr": "Il y a un crochet ou une accroche",
|
||||||
|
"gl": "Hai un guindastre ou soporte"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "service:bicycle:stand=no",
|
||||||
|
"then": {
|
||||||
|
"en": "There is no hook or stand",
|
||||||
|
"nl": "Er is geen haak of standaard",
|
||||||
|
"fr": "Il n'y pas de crochet ou d'accroche",
|
||||||
|
"gl": "Non hai un guindastre ou soporte"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"question": {
|
||||||
|
"en": "Is the bike pump still operational?",
|
||||||
|
"nl": "Werkt de fietspomp nog?",
|
||||||
|
"fr": "Est-ce que cette pompe marche t'elle toujours?",
|
||||||
|
"gl": "Segue a funcionar a bomba de ar?"
|
||||||
|
},
|
||||||
|
"condition": "service:bicycle:pump=yes",
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "service:bicycle:pump:operational_status=broken",
|
||||||
|
"then": {
|
||||||
|
"en": "The bike pump is broken",
|
||||||
|
"nl": "De fietspomp is kapot",
|
||||||
|
"fr": "La pompe est cassé",
|
||||||
|
"gl": "A bomba de ar está estragada"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "service:bicycle:pump:operational_status=",
|
||||||
|
"then": {
|
||||||
|
"en": "The bike pump is operational",
|
||||||
|
"nl": "De fietspomp werkt nog",
|
||||||
|
"fr": "La pompe est opérationnelle",
|
||||||
|
"gl": "A bomba de ar está operativa"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"question": {
|
||||||
|
"en": "What valves are supported?",
|
||||||
|
"nl": "Welke ventielen werken er met de pomp?",
|
||||||
|
"fr": "Quelles valves sont compatibles?",
|
||||||
|
"gl": "Que válvulas son compatíbeis?"
|
||||||
|
},
|
||||||
|
"render": {
|
||||||
|
"en": "This pump supports the following valves: {valves}",
|
||||||
|
"nl": "Deze pomp werkt met de volgende ventielen: {valves}",
|
||||||
|
"fr": "Cette pompe est compatible avec les valves suivantes: {valves}",
|
||||||
|
"gl": "Esta bomba de ar admite as seguintes válvulas: {valves}"
|
||||||
|
},
|
||||||
|
"freeform": {
|
||||||
|
"addExtraTags": [
|
||||||
|
"fixme=Freeform 'valves'-tag used: possibly a wrong value"
|
||||||
|
],
|
||||||
|
"key": "valves"
|
||||||
|
},
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "valves=sclaverand;schrader;dunlop",
|
||||||
|
"then": {
|
||||||
|
"en": "There is a default head, so Dunlop, Sclaverand and auto",
|
||||||
|
"nl": "Er is een standaard aansluiting, die dus voor Dunlop, Sclaverand en auto's",
|
||||||
|
"fr": "Il y a une valve par défaut, fonctionnant sur les valves Dunlop, Sclaverand et les valves de voitures",
|
||||||
|
"gl": "Hai un cabezal predeterminado que é compatíbel con Dunlop, Sclaverand e automóbil"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "valves=sclaverand",
|
||||||
|
"then": {
|
||||||
|
"en": "Only Sclaverand (also known as Presta)",
|
||||||
|
"nl": "Enkel Sclaverand (ook gekend als Presta)",
|
||||||
|
"fr": "Seulement Sclaverand (aussi appelé Presta)",
|
||||||
|
"gl": "Só Sclaverand (tamén coñecido como Presta)"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "valves=dunlop",
|
||||||
|
"then": {
|
||||||
|
"en": "Only Dunlop",
|
||||||
|
"nl": "Enkel Dunlop",
|
||||||
|
"fr": "Seulement Dunlop",
|
||||||
|
"gl": "Só Dunlop"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "valves=schrader",
|
||||||
|
"then": {
|
||||||
|
"en": "Only for cars",
|
||||||
|
"nl": "Enkel voor auto's",
|
||||||
|
"fr": "Seuelement les valves de voitures",
|
||||||
|
"gl": "Só para automóbiles"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"question": {
|
||||||
|
"en": "Is this an electric bike pump?",
|
||||||
|
"nl": "Is dit een electrische fietspomp?",
|
||||||
|
"fr": "Est-ce que cette pompe est électrique?",
|
||||||
|
"gl": "Esta é unha bomba de ar eléctrica?"
|
||||||
|
},
|
||||||
|
"condition": "service:bicycle:pump=yes",
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "manual=yes",
|
||||||
|
"then": {
|
||||||
|
"en": "Manual pump",
|
||||||
|
"nl": "Manuele pomp",
|
||||||
|
"fr": "Pompe manuelle",
|
||||||
|
"gl": "Bomba de ar manual"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "manual=no",
|
||||||
|
"then": {
|
||||||
|
"en": "Electrical pump",
|
||||||
|
"nl": "Electrische pomp",
|
||||||
|
"fr": "Pompe électrique",
|
||||||
|
"gl": "Bomba de ar eléctrica"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"question": {
|
||||||
|
"en": "Does the pump have a pressure indicator or manometer?",
|
||||||
|
"nl": "Heeft deze pomp een luchtdrukmeter?",
|
||||||
|
"fr": "Est-ce que la pompe à un manomètre integré?",
|
||||||
|
"gl": "Ten a bomba de ar un indicador de presión ou un manómetro?"
|
||||||
|
},
|
||||||
|
"condition": "service:bicycle:pump=yes",
|
||||||
|
"mappings": [
|
||||||
|
{
|
||||||
|
"if": "manometer=yes",
|
||||||
|
"then": {
|
||||||
|
"en": "There is a manometer",
|
||||||
|
"nl": "Er is een luchtdrukmeter",
|
||||||
|
"fr": "Il y a un manomètre",
|
||||||
|
"gl": "Hai manómetro"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "manometer=no",
|
||||||
|
"then": {
|
||||||
|
"en": "There is no manometer",
|
||||||
|
"nl": "Er is geen luchtdrukmeter",
|
||||||
|
"fr": "Il n'y a pas de manomètre",
|
||||||
|
"gl": "Non hai manómetro"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": "manometer=broken",
|
||||||
|
"then": {
|
||||||
|
"en": "There is manometer but it is broken",
|
||||||
|
"nl": "Er is een luchtdrukmeter maar die is momenteel defect",
|
||||||
|
"fr": "Il y a un manomètre mais il est cassé",
|
||||||
|
"gl": "Hai manómetro pero está estragado"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
"icon": {
|
"icon": {
|
||||||
"render": {
|
"render": {
|
||||||
"en": "./assets/layers/bike_repair_station/repair_station.svg"
|
"en": "./assets/layers/bike_repair_station/repair_station.svg"
|
||||||
|
@ -19,13 +352,43 @@
|
||||||
"mappings": [
|
"mappings": [
|
||||||
{
|
{
|
||||||
"if": {
|
"if": {
|
||||||
"and": "service:bicycle:pump:operational_status=broken"
|
"and": [
|
||||||
|
"service:bicycle:pump=no",
|
||||||
|
"service:bicycle:pump:operational_status=broken"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": "./assets/layers/bike_repair_station/repair_station.svg"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:pump=yes",
|
||||||
|
"service:bicycle:tools=yes"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": "./assets/layers/bike_repair_station/repair_station_pump.svg"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:pump:operational_status=broken",
|
||||||
|
"service:bicycle:tools=no"
|
||||||
|
]
|
||||||
},
|
},
|
||||||
"then": "./assets/layers/bike_repair_station/broken_pump_2.svg"
|
"then": "./assets/layers/bike_repair_station/broken_pump_2.svg"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"if": {
|
||||||
|
"and": [
|
||||||
|
"service:bicycle:pump=yes",
|
||||||
|
"service:bicycle:tools=no"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"then": "./assets/layers/bike_repair_station/pump.svg"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
"size": {
|
"iconSize": {
|
||||||
"render": {
|
"render": {
|
||||||
"en": "50,50,bottom"
|
"en": "50,50,bottom"
|
||||||
}
|
}
|
||||||
|
@ -44,20 +407,42 @@
|
||||||
"presets": [
|
"presets": [
|
||||||
{
|
{
|
||||||
"title": {
|
"title": {
|
||||||
"en": "Bike parking",
|
"en": "Bike pump",
|
||||||
"nl": "Fietsparking",
|
"nl": "Fietspomp",
|
||||||
"fr": "Parking à vélo",
|
"fr": "Pompe à vélo",
|
||||||
"gl": "Aparcadoiro de bicicletas"
|
"gl": "Bomba de ar"
|
||||||
},
|
},
|
||||||
"tags": [
|
"tags": [
|
||||||
"amenity=bicycle_parking"
|
"amenity=bicycle_repair_station",
|
||||||
|
"service:bicycle:tools=no",
|
||||||
|
"service:bicycle:pump=yes"
|
||||||
]
|
]
|
||||||
}
|
|
||||||
],
|
|
||||||
"title": {
|
|
||||||
"render": {
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
"tagRenderings": [
|
{
|
||||||
|
"title": {
|
||||||
|
"en": "Bike repair station and pump",
|
||||||
|
"nl": "Herstelpunt en pomp",
|
||||||
|
"fr": "Point de réparation vélo avec pompe",
|
||||||
|
"gl": "Estación de arranxo de bicicletas con bomba de ar"
|
||||||
|
},
|
||||||
|
"tags": [
|
||||||
|
"amenity=bicycle_repair_station",
|
||||||
|
"service:bicycle:tools=yes",
|
||||||
|
"service:bicycle:pump=yes"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"title": {
|
||||||
|
"en": "Bike repair station without pump",
|
||||||
|
"nl": "Herstelpunt zonder pomp",
|
||||||
|
"fr": "Point de réparation vélo sans pompe",
|
||||||
|
"gl": "Estación de arranxo de bicicletas sin bomba de ar"
|
||||||
|
},
|
||||||
|
"tags": [
|
||||||
|
"amenity=bicycle_repair_station",
|
||||||
|
"service:bicycle:tools=yes",
|
||||||
|
"service:bicycle:pump=no"
|
||||||
|
]
|
||||||
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
6
index.ts
6
index.ts
|
@ -17,6 +17,7 @@ import {LocalStorageSource} from "./Logic/Web/LocalStorageSource";
|
||||||
import {PersonalLayout} from "./Logic/PersonalLayout";
|
import {PersonalLayout} from "./Logic/PersonalLayout";
|
||||||
import {FromJSON} from "./Customizations/JSON/FromJSON";
|
import {FromJSON} from "./Customizations/JSON/FromJSON";
|
||||||
import {FullScreenMessageBox} from "./UI/FullScreenMessageBoxHandler";
|
import {FullScreenMessageBox} from "./UI/FullScreenMessageBoxHandler";
|
||||||
|
import {UIEventSource} from "./Logic/UIEventSource";
|
||||||
|
|
||||||
TagRendering.injectFunction();
|
TagRendering.injectFunction();
|
||||||
|
|
||||||
|
@ -28,13 +29,16 @@ if (location.href.startsWith("http://buurtnatuur.be")) {
|
||||||
window.location.replace("https://buurtnatuur.be");
|
window.location.replace("https://buurtnatuur.be");
|
||||||
}
|
}
|
||||||
|
|
||||||
let testing = QueryParameters.GetQueryParameter("test", "false");
|
let testing: UIEventSource<string>;
|
||||||
if (location.hostname === "localhost" || location.hostname === "127.0.0.1") {
|
if (location.hostname === "localhost" || location.hostname === "127.0.0.1") {
|
||||||
|
testing = QueryParameters.GetQueryParameter("test", "true");
|
||||||
// Set to true if testing and changes should NOT be saved
|
// Set to true if testing and changes should NOT be saved
|
||||||
testing.setData(testing.data ?? "true")
|
testing.setData(testing.data ?? "true")
|
||||||
// If you have a testfile somewhere, enable this to spoof overpass
|
// If you have a testfile somewhere, enable this to spoof overpass
|
||||||
// This should be hosted independantly, e.g. with `cd assets; webfsd -p 8080` + a CORS plugin to disable cors rules
|
// This should be hosted independantly, e.g. with `cd assets; webfsd -p 8080` + a CORS plugin to disable cors rules
|
||||||
//Overpass.testUrl = "http://127.0.0.1:8080/streetwidths.geojson";
|
//Overpass.testUrl = "http://127.0.0.1:8080/streetwidths.geojson";
|
||||||
|
} else {
|
||||||
|
testing = QueryParameters.GetQueryParameter("test", "false");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue