mapcomplete/UI/FeatureInfoBox.ts

132 lines
3.8 KiB
TypeScript
Raw Normal View History

import {UIElement} from "./UIElement";
import {UIEventSource} from "./UIEventSource";
import {QuestionPicker} from "./QuestionPicker";
import {OsmImageUploadHandler} from "../Logic/OsmImageUploadHandler";
import {ImageCarousel} from "./Image/ImageCarousel";
import {Changes} from "../Logic/Changes";
import {UserDetails} from "../Logic/OsmConnection";
2020-06-29 03:12:44 +02:00
import {VerticalCombine} from "./Base/VerticalCombine";
2020-07-12 23:19:05 +02:00
import {TagRenderingOptions} from "../Customizations/TagRendering";
2020-07-05 18:59:47 +02:00
import {OsmLink} from "../Customizations/Questions/OsmLink";
import {WikipediaLink} from "../Customizations/Questions/WikipediaLink";
import {And} from "../Logic/TagsFilter";
2020-07-12 23:19:05 +02:00
import {TagDependantUIElement} from "../Customizations/UIElementConstructor";
export class FeatureInfoBox extends UIElement {
private _tagsES: UIEventSource<any>;
private _changes: Changes;
private _userDetails: UIEventSource<UserDetails>;
private _title: UIElement;
private _osmLink: UIElement;
private _wikipedialink: UIElement;
2020-07-12 23:19:05 +02:00
private _infoboxes: TagDependantUIElement[];
private _questions: QuestionPicker;
constructor(
tagsES: UIEventSource<any>,
2020-07-05 18:59:47 +02:00
title: TagRenderingOptions,
elementsToShow: TagRenderingOptions[],
changes: Changes,
userDetails: UIEventSource<UserDetails>
) {
super(tagsES);
this._tagsES = tagsES;
this._changes = changes;
this._userDetails = userDetails;
2020-06-29 16:21:36 +02:00
this.ListenTo(userDetails);
2020-07-05 18:59:47 +02:00
this._infoboxes = [];
elementsToShow = elementsToShow ?? []
2020-07-05 18:59:47 +02:00
for (const tagRenderingOption of elementsToShow) {
2020-07-12 23:19:05 +02:00
this._infoboxes.push(
tagRenderingOption.construct(this._tagsES, this._changes));
}
2020-07-05 18:59:47 +02:00
title = title ?? new TagRenderingOptions(
{
mappings: [{k: new And([]), txt: ""}]
}
)
2020-07-12 23:19:05 +02:00
this._title = new TagRenderingOptions(title.options).construct(this._tagsES, this._changes);
this._osmLink =new OsmLink().construct(this._tagsES, this._changes);
this._wikipedialink = new WikipediaLink().construct(this._tagsES, this._changes);
}
InnerRender(): string {
2020-07-05 18:59:47 +02:00
const info = [];
2020-07-12 23:19:05 +02:00
const questions : TagDependantUIElement[] = [];
2020-07-05 18:59:47 +02:00
for (const infobox of this._infoboxes) {
if (infobox.IsKnown()) {
info.push(infobox);
} else if (infobox.IsQuestioning()) {
questions.push(infobox);
}
}
let questionsHtml = "";
if (this._userDetails.data.loggedIn && questions.length > 0) {
// We select the most important question and render that one
let mostImportantQuestion;
let score = -1000;
for (const question of questions) {
2020-07-12 23:19:05 +02:00
if (mostImportantQuestion === undefined || question.Priority() > score) {
2020-07-05 18:59:47 +02:00
mostImportantQuestion = question;
2020-07-12 23:19:05 +02:00
score = question.Priority();
2020-07-05 18:59:47 +02:00
}
}
questionsHtml = mostImportantQuestion.Render();
}
return "<div class='featureinfobox'>" +
"<div class='featureinfoboxtitle'>" +
2020-07-05 18:59:47 +02:00
"<span>" +
this._title.Render() +
"</span>" +
this._wikipedialink.Render() +
this._osmLink.Render() +
"</div>" +
"<div class='infoboxcontents'>" +
2020-07-05 18:59:47 +02:00
new VerticalCombine(info, "infobox-information ").Render() +
2020-07-05 18:59:47 +02:00
questionsHtml +
"</div>" +
"" +
"</div>";
}
Activate() {
super.Activate();
2020-07-05 18:59:47 +02:00
for (const infobox of this._infoboxes) {
infobox.Activate();
}
}
Update() {
super.Update();
2020-07-05 18:59:47 +02:00
this._title.Update();
for (const infobox of this._infoboxes) {
infobox.Update();
}
}
}