2020-08-30 01:13:18 +02:00
|
|
|
import {LayerDefinition} from "../LayerDefinition";
|
2020-07-29 13:16:21 +02:00
|
|
|
import Translations from "../../UI/i18n/Translations";
|
2020-08-30 01:13:18 +02:00
|
|
|
import {And, RegexTag, Tag} from "../../Logic/Tags";
|
2020-07-31 17:38:03 +02:00
|
|
|
import {TagRenderingOptions} from "../TagRenderingOptions";
|
2020-07-29 13:16:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
export default class BikeOtherShops extends LayerDefinition {
|
|
|
|
private readonly sellsBikes = new Tag("service:bicycle:retail", "yes")
|
|
|
|
|
|
|
|
private readonly to = Translations.t.cyclofix.nonBikeShop
|
|
|
|
|
|
|
|
constructor() {
|
2020-07-31 04:58:58 +02:00
|
|
|
super("bikeOtherShop");
|
2020-07-29 13:16:21 +02:00
|
|
|
this.name = this.to.name
|
|
|
|
this.icon = "./assets/bike/non_bike_repair_shop.svg"
|
|
|
|
this.overpassFilter = new And([
|
2020-08-31 02:59:47 +02:00
|
|
|
new RegexTag("shop", /^bicycle$/, true),
|
2020-08-30 01:13:18 +02:00
|
|
|
new RegexTag(/^service:bicycle:/, /.*/),
|
2020-07-29 13:16:21 +02:00
|
|
|
])
|
2020-07-29 18:35:46 +02:00
|
|
|
this.presets = []
|
2020-07-29 13:16:21 +02:00
|
|
|
this.maxAllowedOverlapPercentage = 10
|
|
|
|
this.wayHandling = LayerDefinition.WAYHANDLING_CENTER_AND_WAY
|
|
|
|
|
|
|
|
this.minzoom = 13;
|
|
|
|
this.style = this.generateStyleFunction();
|
|
|
|
this.title = new TagRenderingOptions({
|
|
|
|
mappings: [
|
|
|
|
{
|
|
|
|
k: new And([new Tag("name", "*"), this.sellsBikes]),
|
|
|
|
txt: this.to.titleShopNamed
|
|
|
|
},
|
|
|
|
{
|
|
|
|
k: new And([new Tag("name", "*"), new Tag("service:bicycle:retail", "")]),
|
|
|
|
txt: this.to.titleShop
|
|
|
|
},
|
|
|
|
{
|
|
|
|
k: new And([new Tag("name", "*"), new Tag("service:bicycle:retail", "no")]),
|
|
|
|
txt: this.to.titleRepairNamed
|
|
|
|
},
|
|
|
|
{k: this.sellsBikes, txt: this.to.titleShop},
|
|
|
|
{k: new Tag("service:bicycle:retail", " "), txt: this.to.title},
|
|
|
|
{k: new Tag("service:bicycle:retail", "no"), txt: this.to.titleRepair},
|
|
|
|
{
|
|
|
|
k: new And([new Tag("name", "*")]),
|
|
|
|
txt: this.to.titleNamed
|
|
|
|
},
|
|
|
|
{k: null, txt: this.to.title},
|
|
|
|
]
|
|
|
|
})
|
|
|
|
|
|
|
|
this.elementsToShow = [
|
2020-09-16 01:29:38 +02:00
|
|
|
// new ImageCarouselWithUploadConstructor(),
|
|
|
|
// new PhoneNumberQuestion("{name}"),
|
|
|
|
// new Website("{name}"),
|
|
|
|
// ShopRetail
|
|
|
|
// new ShopRental(),
|
|
|
|
// new ShopRepair(),
|
|
|
|
// new ShopPump(),
|
|
|
|
// new ShopDiy(),
|
|
|
|
// new ShopSecondHand()
|
2020-07-29 13:16:21 +02:00
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
private generateStyleFunction() {
|
|
|
|
const self = this;
|
|
|
|
return function (tags: any) {
|
|
|
|
let icon = "assets/bike/non_bike_repair_shop.svg";
|
|
|
|
|
|
|
|
if (self.sellsBikes.matchesProperties(tags)) {
|
|
|
|
icon = "assets/bike/non_bike_shop.svg";
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
color: "#00bb00",
|
|
|
|
icon: {
|
|
|
|
iconUrl: icon,
|
|
|
|
iconSize: [50, 50],
|
|
|
|
iconAnchor: [25, 50]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|