Merge and bugfixes

This commit is contained in:
Pieter Vander Vennet 2020-07-08 16:11:40 +02:00
commit c3664ce82f
9 changed files with 87 additions and 44 deletions

View file

@ -14,9 +14,10 @@ export class AllKnownLayouts {
new Groen(), new Groen(),
new GRB(), new GRB(),
new BikePumpsLayout(), new BikePumpsLayout(),
new Bookcases()
/*new Toilets(), /*new Toilets(),
new Statues(), new Statues(),
new Bookcases()*/ */
]; ];
const allSets = {}; const allSets = {};
for (const layout of layouts) { for (const layout of layouts) {

View file

@ -3,6 +3,7 @@ import L from "leaflet";
import {Tag} from "../../Logic/TagsFilter"; import {Tag} from "../../Logic/TagsFilter";
import {QuestionDefinition} from "../../Logic/Question"; import {QuestionDefinition} from "../../Logic/Question";
import {TagRenderingOptions} from "../TagRendering"; import {TagRenderingOptions} from "../TagRendering";
import {NameInline} from "../Questions/NameInline";
export class Bookcases extends LayerDefinition { export class Bookcases extends LayerDefinition {
@ -10,21 +11,38 @@ export class Bookcases extends LayerDefinition {
super(); super();
this.name = "boekenkast"; this.name = "boekenkast";
this.newElementTags = [new Tag( "amenity", "public_bookcase")]; this.newElementTags = [new Tag("amenity", "public_bookcase")];
this.icon = "./assets/bookcase.svg"; this.icon = "./assets/bookcase.svg";
this.overpassFilter = new Tag("amenity","public_bookcase"); this.overpassFilter = new Tag("amenity", "public_bookcase");
this.minzoom = 13; this.minzoom = 13;
this.title = new NameInline("ruilboekenkastje");
this.elementsToShow = [
this.questions = [ new TagRenderingOptions(
{
question: "Hoeveel boeken passen in dit boekenruilkastje?",
freeform: {
renderTemplate: "Er passen {capacity} boeken in dit boekenruilkastje",
template: "Er passen $$$ boeken in dit boekenruilkastje",
key: "capacity",
placeholder: "aantal"
},
priority: 15
}
)
];
/* this.questions = [
QuestionDefinition.noNameOrNameQuestion("Wat is de naam van dit boekenruilkastje?", "Dit boekenruilkastje heeft niet echt een naam", 20), QuestionDefinition.noNameOrNameQuestion("Wat is de naam van dit boekenruilkastje?", "Dit boekenruilkastje heeft niet echt een naam", 20),
QuestionDefinition.textQuestion("Hoeveel boeken kunnen er in?", "capacity", 15),
QuestionDefinition.textQuestion("Heeft dit boekenkastje een peter, meter of voogd?", "operator", 10), QuestionDefinition.textQuestion("Heeft dit boekenkastje een peter, meter of voogd?", "operator", 10),
// QuestionDefinition.textQuestion("Wie kunnen we (per email) contacteren voor dit boekenruilkastje?", "email", 5), // QuestionDefinition.textQuestion("Wie kunnen we (per email) contacteren voor dit boekenruilkastje?", "email", 5),
] ]
; ;
*/
this.style = function (tags) { this.style = function (tags) {
return { return {
@ -36,6 +54,7 @@ export class Bookcases extends LayerDefinition {
}; };
} }
/*
this.elementsToShow = [ this.elementsToShow = [
@ -58,7 +77,7 @@ export class Bookcases extends LayerDefinition {
new TagMappingOptions({key: "description", template: "Extra beschrijving: <br /> <p>{description}</p>"}), new TagMappingOptions({key: "description", template: "Extra beschrijving: <br /> <p>{description}</p>"}),
] ]
; ;*/
} }

View file

@ -9,18 +9,32 @@ import {NameInline} from "../Questions/NameInline";
export class Park extends LayerDefinition { export class Park extends LayerDefinition {
private accessByDefault = new TagRenderingOptions({ private accessByDefault = new TagRenderingOptions({
question: "Is dit park publiek toegankelijk?", question: "Is dit park publiek toegankelijk?",
mappings: [ mappings: [
{k: new Tag("access","yes"), txt: "Publiek toegankelijk"}, {k: new Tag("access", "yes"), txt: "Publiek toegankelijk"},
{k: new Tag("access",""), txt: "Publiek toegankelijk"}, {k: new Tag("access", ""), txt: "Publiek toegankelijk"},
{k: new Tag("access","no"), txt: "Niet-publiek toegankelijk park"}, {k: new Tag("access", "no"), txt: "Niet publiek toegankelijk"},
{k: new Tag("access","guided"), txt: "Enkel toegankelijk met een gids of op een activiteit"} {k: new Tag("access", "guided"), txt: "Enkel toegankelijk met een gids of op een activiteit"}
] ]
}) })
private operatorByDefault = new
TagRenderingOptions({
question: "Wie beheert dit park?",
freeform: {
key: "operator",
renderTemplate: "Dit park wordt beheerd door {operator}",
template: "$$$",
},
mappings: [{
k: null, txt: "De gemeente beheert dit park"
}]
});
constructor() { constructor() {
super(); super();
this.name = "park"; this.name = "park";
@ -35,8 +49,9 @@ export class Park extends LayerDefinition {
this.style = this.generateStyleFunction(); this.style = this.generateStyleFunction();
this.title = new NameInline("park"); this.title = new NameInline("park");
this.elementsToShow = [new NameQuestion(), this.elementsToShow = [new NameQuestion(),
this.accessByDefault this.accessByDefault,
this.operatorByDefault
]; ];
} }

View file

@ -6,7 +6,7 @@ import {Layout} from "../Layout";
export class Groen extends Layout { export class Groen extends Layout {
constructor() { constructor() {
super("groen", super("buurtnatuur",
"Buurtnatuur", "Buurtnatuur",
[new NatureReserves(), new Park(), new Bos()], [new NatureReserves(), new Park(), new Bos()],
10, 10,

View file

@ -72,7 +72,7 @@ export class TagRenderingOptions {
const tagsKV = TagUtils.proprtiesToKV(tags); const tagsKV = TagUtils.proprtiesToKV(tags);
for (const oneOnOneElement of this.options.mappings) { for (const oneOnOneElement of this.options.mappings) {
if (oneOnOneElement.k.matches(tagsKV)) { if (oneOnOneElement.k === null || oneOnOneElement.k.matches(tagsKV)) {
return false; return false;
} }
} }
@ -147,10 +147,9 @@ export class TagRendering extends UIElement {
this.elementPriority = options.priority ?? 0; this.elementPriority = options.priority ?? 0;
// Prepare the choices for the Radio buttons // Prepare the choices for the Radio buttons
let i = 0;
const choices: UIElement[] = []; const choices: UIElement[] = [];
const alreadyUsedTexts: string[] = []; const usedChoices: string [] = [];
for (const choice of options.mappings ?? []) { for (const choice of options.mappings ?? []) {
if (choice.k === null) { if (choice.k === null) {
this._mapping.push(choice); this._mapping.push(choice);
@ -167,15 +166,16 @@ export class TagRendering extends UIElement {
} }
} }
const txt = choiceSubbed.txt;
if (alreadyUsedTexts.indexOf(txt) < 0) { const txt = choiceSubbed.txt
// Choices is what is shown in the radio buttons
if (usedChoices.indexOf(txt) < 0) {
choices.push(new FixedUiElement(txt)); choices.push(new FixedUiElement(txt));
alreadyUsedTexts.push(txt); usedChoices.push(txt);
// This is used to convert the radio button index into tags needed to add
this._mapping.push(choiceSubbed);
} }
this._mapping.push(choiceSubbed);
i++;
} }
// Map radiobutton choice and textfield answer onto tagfilter. That tagfilter will be pushed into the changes later on // Map radiobutton choice and textfield answer onto tagfilter. That tagfilter will be pushed into the changes later on
@ -205,6 +205,7 @@ export class TagRendering extends UIElement {
// Prepare the actual input element -> pick an appropriate implementation // Prepare the actual input element -> pick an appropriate implementation
let inputElement: UIInputElement<TagsFilter>; let inputElement: UIInputElement<TagsFilter>;
if (this._freeform !== undefined && this._mapping !== undefined) { if (this._freeform !== undefined && this._mapping !== undefined) {
// Radio buttons with 'other' // Radio buttons with 'other'
inputElement = new UIRadioButtonWithOther( inputElement = new UIRadioButtonWithOther(
@ -215,14 +216,15 @@ export class TagRendering extends UIElement {
pickString pickString
); );
this._questionElement = inputElement; this._questionElement = inputElement;
} else if (this._mapping !== undefined) { } else if (this._mapping !== [] && this._mapping.length > 0) {
// This is a classic radio selection element // This is a classic radio selection element
inputElement = new UIRadioButton(new UIEventSource(choices), pickChoice) inputElement = new UIRadioButton(new UIEventSource(choices), pickChoice, false)
this._questionElement = inputElement; this._questionElement = inputElement;
} else if (this._freeform !== undefined) { } else if (this._freeform !== undefined) {
this._textField = new TextField(new UIEventSource<string>(this._freeform.placeholder), pickString); this._textField = new TextField(new UIEventSource<string>(this._freeform.placeholder), pickString);
inputElement = this._textField; inputElement = this._textField;
this._questionElement = new FixedUiElement(this._freeform.template.replace("$$$", inputElement.Render())) this._questionElement = new FixedUiElement(
"<div>" + this._freeform.template.replace("$$$", inputElement.Render()) + "</div>")
} else { } else {
throw "Invalid questionRendering, expected at least choices or a freeform" throw "Invalid questionRendering, expected at least choices or a freeform"
} }
@ -239,6 +241,7 @@ export class TagRendering extends UIElement {
const cancel = () => { const cancel = () => {
self._questionSkipped.setData(true); self._questionSkipped.setData(true);
self._editMode.setData(false); self._editMode.setData(false);
self._source.ping(); // Send a ping upstream to render the next question
} }
// Setup the save button and it's action // Setup the save button and it's action
@ -357,7 +360,7 @@ export class TagRendering extends UIElement {
return "<div class='question'>" + return "<div class='question'>" +
this._question + "<span class='question-text'>" + this._question + "</span>" +
(this._question !== "" ? "<br/>" : "") + (this._question !== "" ? "<br/>" : "") +
this._questionElement.Render() + this._questionElement.Render() +
this._skipButton.Render() + this._skipButton.Render() +

View file

@ -74,9 +74,11 @@ export class UIRadioButton<T> extends UIInputElement<T> {
if (this.SelectedElementIndex.data == null) { if (this.SelectedElementIndex.data == null) {
if (this._selectFirstAsDefault) { if (this._selectFirstAsDefault) {
const el = document.getElementById(this.IdFor(0)); const el = document.getElementById(this.IdFor(0));
// @ts-ignore if (el) {
el.checked = true; // @ts-ignore
checkButtons(); el.checked = true;
checkButtons();
}
} }
} else { } else {

View file

@ -8,6 +8,10 @@ body {
font-family: 'Helvetica Neue', Arial, sans-serif; font-family: 'Helvetica Neue', Arial, sans-serif;
} }
form {
display: inline;
}
#leafletDiv { #leafletDiv {
height: 100%; height: 100%;
} }
@ -670,6 +674,11 @@ body {
} }
.question-text{
font-size: larger;
font-weight: bold;
}
.answer { .answer {
display: inline-block; display: inline-block;
margin: 0.1em; margin: 0.1em;

View file

@ -38,7 +38,7 @@ if (location.hostname === "localhost" || location.hostname === "127.0.0.1") {
// ----------------- SELECT THE RIGHT QUESTSET ----------------- // ----------------- SELECT THE RIGHT QUESTSET -----------------
let defaultQuest = "groen" let defaultQuest = "buurtnatuur"
if (window.location.search) { if (window.location.search) {
const params = window.location.search.substr(1).split("&"); const params = window.location.search.substr(1).split("&");
const paramDict: any = {}; const paramDict: any = {};
@ -88,7 +88,7 @@ const saveTimeout = 30000; // After this many milliseconds without changes, save
const allElements = new ElementStorage(); const allElements = new ElementStorage();
const osmConnection = new OsmConnection(dryRun); const osmConnection = new OsmConnection(dryRun);
const changes = new Changes( const changes = new Changes(
"Beantwoorden van vragen met MapComplete voor vragenset #" + questSetToRender.name, "Beantwoorden van vragen met #MapComplete voor vragenset #" + questSetToRender.name,
osmConnection, allElements); osmConnection, allElements);
const bm = new Basemap("leafletDiv", locationControl, new VariableUiElement( const bm = new Basemap("leafletDiv", locationControl, new VariableUiElement(
locationControl.map((location) => { locationControl.map((location) => {

View file

@ -7,9 +7,3 @@ import {OsmLink} from "./Customizations/Questions/OsmLink";
import {ConfirmDialog} from "./UI/ConfirmDialog"; import {ConfirmDialog} from "./UI/ConfirmDialog";
import {Imgur} from "./Logic/Imgur"; import {Imgur} from "./Logic/Imgur";
console.log("Hello world")
Imgur.getDescriptionOfImage("https://i.imgur.com/pJfQYsj.jpg",
(info) => {
console.log(info)
})