MapComplete/Customizations/Layers/InformationBoard.js
2020-07-20 15:59:48 +02:00

122 lines
5.4 KiB
JavaScript

"use strict";
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
Object.defineProperty(exports, "__esModule", { value: true });
exports.InformationBoard = void 0;
var LayerDefinition_1 = require("../LayerDefinition");
var ImageCarouselWithUpload_1 = require("../../UI/Image/ImageCarouselWithUpload");
var TagRendering_1 = require("../TagRendering");
var TagsFilter_1 = require("../../Logic/TagsFilter");
var leaflet_1 = require("leaflet");
var InformationBoard = /** @class */ (function (_super) {
__extends(InformationBoard, _super);
function InformationBoard() {
var _this = _super.call(this, {
name: "Informatiebord",
minzoom: 12,
overpassFilter: new TagsFilter_1.Tag("tourism", "information"),
newElementTags: [new TagsFilter_1.Tag("tourism", "information")],
maxAllowedOverlapPercentage: 0,
icon: "assets/nature/info.png",
}) || this;
var isMap = new TagsFilter_1.Tag("information", "map");
var isOsmSource = new TagsFilter_1.Tag("map_source", "OpenStreetMap");
_this.title = new TagRendering_1.TagRenderingOptions({
mappings: [
{ k: isMap, txt: "Kaart" },
{ k: null, txt: "Informatiebord" }
]
});
_this.style = function (properties) {
var icon = "assets/nature/info.png";
if (isMap.matchesProperties(properties)) {
icon = "assets/map.svg";
if (isOsmSource.matchesProperties(properties)) {
icon = "assets/osm-logo-white-bg.svg";
var attr = properties["map_source:attribution"];
if (attr == "sticker") {
icon = "assets/map-stickered.svg";
}
else if (attr == "no") {
icon = "assets/osm-logo-buggy-attr.svg";
}
}
}
return {
color: "#000000",
icon: leaflet_1.default.icon({
iconUrl: icon,
iconSize: [50, 50]
})
};
};
_this.elementsToShow = [
new ImageCarouselWithUpload_1.ImageCarouselWithUploadConstructor(),
new TagRendering_1.TagRenderingOptions({
question: "Heeft dit informatiebord een kaart?",
mappings: [
{ k: new TagsFilter_1.Tag("information", "board"), txt: "Dit is een informatiebord" },
{ k: isMap, txt: "Dit is een kaart" }
]
}),
new TagRendering_1.TagRenderingOptions({
question: "Is this map based on OpenStreetMap?",
mappings: [
{
k: isOsmSource,
txt: "This map is based on OpenStreetMap"
},
{
k: new TagsFilter_1.And([new TagsFilter_1.Tag("map_source:attribution", ""), new TagsFilter_1.Tag("map_source", "")]),
txt: "Unknown"
},
],
freeform: {
key: "map_source",
extraTags: new TagsFilter_1.Tag("map_source:attribution", ""),
renderTemplate: "The map data is based on {map_source}",
template: "The map data is based on $$$"
}
}).OnlyShowIf(isMap),
new TagRendering_1.TagRenderingOptions({
question: "Is the attribution present?",
mappings: [
{
k: new TagsFilter_1.Tag("map_source:attribution", "yes"),
txt: "OpenStreetMap is clearly attribute, including the ODBL-license"
},
{
k: new TagsFilter_1.Tag("map_source:attribution", "incomplete"),
txt: "OpenStreetMap is clearly attribute, but the license is not mentioned"
},
{
k: new TagsFilter_1.Tag("map_source:attribution", "sticker"),
txt: "OpenStreetMap wasn't mentioned, but someone put an OpenStreetMap-sticker on it"
},
{
k: new TagsFilter_1.Tag("map_source:attribution", "no"),
txt: "There is no attribution at all"
},
{
k: new TagsFilter_1.Tag("map_source:attribution", "none"),
txt: "There is no attribution at all"
}
]
}).OnlyShowIf(new TagsFilter_1.Tag("map_source", "OpenStreetMap"))
];
return _this;
}
return InformationBoard;
}(LayerDefinition_1.LayerDefinition));
exports.InformationBoard = InformationBoard;