Porting repair_station to JSON configuration file

This commit is contained in:
Pieter Vander Vennet 2020-09-05 17:43:30 +02:00
parent b7b1bc13e4
commit 9e9d80c045
18 changed files with 455 additions and 503 deletions

View file

@ -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),
]; ];

View file

@ -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]
}
};
};
}
}

View file

@ -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,

View file

@ -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}
]
});
}
}

View file

@ -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}
]
});
}
}

View file

@ -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}
]
});
}
}

View file

@ -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
}
});
}
}

View file

@ -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},
]
});
}
}

View file

@ -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"
}
});
}
}

View file

@ -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}
]
});
}
}

View file

@ -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},
]
});
}
}

View file

@ -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: [],

View file

@ -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);
} }

View file

@ -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", "")
]; ];

View file

@ -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());

View file

@ -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({

View file

@ -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": {
"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"
] ]
} }
],
"title": {
"render": {
}
},
"tagRenderings": [
] ]
} }

View file

@ -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");
} }