diff --git a/Customizations/AllKnownLayouts.ts b/Customizations/AllKnownLayouts.ts index 9697fd1ca..6e93bfddb 100644 --- a/Customizations/AllKnownLayouts.ts +++ b/Customizations/AllKnownLayouts.ts @@ -3,6 +3,7 @@ import {Toilets} from "./Layouts/Toilets"; import {GRB} from "./Layouts/GRB"; import {Statues} from "./Layouts/Statues"; import {Bookcases} from "./Layouts/Bookcases"; +import { BikePumps } from "./Layers/BikePumps"; export class AllKnownLayouts { public static allSets: any = AllKnownLayouts.AllLayouts(); @@ -11,6 +12,7 @@ export class AllKnownLayouts { const layouts = [ new Groen(), new GRB(), + new BikePumps(), /*new Toilets(), new Statues(), new Bookcases()*/ diff --git a/Customizations/Layers/BikePumps.ts b/Customizations/Layers/BikePumps.ts new file mode 100644 index 000000000..03e0ba855 --- /dev/null +++ b/Customizations/Layers/BikePumps.ts @@ -0,0 +1,77 @@ +import {LayerDefinition} from "../LayerDefinition"; +import {And, Or, Tag} from "../../Logic/TagsFilter"; +import {AccessTag} from "../Questions/AccessTag"; +import {OperatorTag} from "../Questions/OperatorTag"; +import {NameQuestion} from "../Questions/NameQuestion"; +import {NameInline} from "../Questions/NameInline"; +import * as L from "leaflet"; + +export class BikePumps extends LayerDefinition { + + constructor() { + super(); + this.name = "pomp"; + this.icon = "./assets/bike_pump.svg"; + + this.overpassFilter = new Or([ + new And([ + new Tag("amenity", "compressed_air"), + new Tag("bicycle", "yes"), + ]) + ] + ); + + + this.newElementTags = [ + new Tag("amenity", "compressed_air"), + new Tag("bicycle", "yes"), + // new Tag("fixme", "Toegevoegd met MapComplete, geometry nog uit te tekenen") + ]; + this.maxAllowedOverlapPercentage = 10; + + this.minzoom = 13; + this.style = this.generateStyleFunction(); + this.title = new NameInline("pomp"); + this.elementsToShow = [ + // new NameQuestion(), + // new AccessTag(), + new OperatorTag() + ]; + + } + + + private generateStyleFunction() { + const self = this; + return function (properties: any) { + // let questionSeverity = 0; + // for (const qd of self.elementsToShow) { + // if (qd.IsQuestioning(properties)) { + // questionSeverity = Math.max(questionSeverity, qd.options.priority ?? 0); + // } + // } + + // let colormapping = { + // 0: "#00bb00", + // 1: "#00ff00", + // 10: "#dddd00", + // 20: "#ff0000" + // }; + + // let colour = colormapping[questionSeverity]; + // while (colour == undefined) { + // questionSeverity--; + // colour = colormapping[questionSeverity]; + // } + + return { + color: "#00bb00", + icon: new L.icon({ + iconUrl: self.icon, + iconSize: [40, 40] + }) + }; + }; + } + +} \ No newline at end of file diff --git a/Customizations/Layouts/BikePumps.ts b/Customizations/Layouts/BikePumps.ts new file mode 100644 index 000000000..e9d65665b --- /dev/null +++ b/Customizations/Layouts/BikePumps.ts @@ -0,0 +1,23 @@ +import {Layout} from "../Layout"; +import {GrbToFix} from "../Layers/GrbToFix"; +import { BikePumps } from "../Layers/BikePumps"; + +export class GRB extends Layout { + constructor() { + super( + "pomp", + "Grb import fix tool", + [new BikePumps()], + 15, + 51.2083, + 3.2279, + + + "