forked from MapComplete/MapComplete
Add image delete button
This commit is contained in:
parent
f548ddea84
commit
0fe6b67976
13 changed files with 303 additions and 54 deletions
|
@ -9,6 +9,18 @@ import {NameInline} from "../Questions/NameInline";
|
||||||
|
|
||||||
export class Park extends LayerDefinition {
|
export class Park extends LayerDefinition {
|
||||||
|
|
||||||
|
|
||||||
|
private accessByDefault = new TagRenderingOptions({
|
||||||
|
question: "Is dit park publiek toegankelijk?",
|
||||||
|
mappings: [
|
||||||
|
{k: new Tag("access","yes"), txt: "Publiek toegankelijk"},
|
||||||
|
{k: new Tag("access",""), txt: "Publiek toegankelijk"},
|
||||||
|
{k: new Tag("access","no"), txt: "Niet-publiek toegankelijk park"},
|
||||||
|
{k: new Tag("access","guided"), txt: "Enkel toegankelijk met een gids of op een activiteit"}
|
||||||
|
]
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
this.name = "park";
|
this.name = "park";
|
||||||
|
@ -22,7 +34,10 @@ export class Park extends LayerDefinition {
|
||||||
this.minzoom = 13;
|
this.minzoom = 13;
|
||||||
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
|
||||||
|
|
||||||
|
];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,16 +6,16 @@ export class BikePumpsLayout extends Layout {
|
||||||
constructor() {
|
constructor() {
|
||||||
super(
|
super(
|
||||||
"pomp",
|
"pomp",
|
||||||
"Grb import fix tool",
|
"Cyclofix",
|
||||||
[new BikePumps()],
|
[new BikePumps()],
|
||||||
15,
|
15,
|
||||||
51.2083,
|
51.2083,
|
||||||
3.2279,
|
3.2279,
|
||||||
|
|
||||||
|
|
||||||
"<h3>GRB Fix tool</h3>\n" +
|
"<h3>Open CycloFix</h3>\n" +
|
||||||
"\n" +
|
"\n" +
|
||||||
"Expert use only"
|
"Something something bikes"
|
||||||
|
|
||||||
,
|
,
|
||||||
"", "");
|
"", "");
|
||||||
|
|
|
@ -65,7 +65,6 @@ export class TagRenderingOptions {
|
||||||
mappings?: { k: TagsFilter, txt: string, priority?: number, substitute?: boolean }[]
|
mappings?: { k: TagsFilter, txt: string, priority?: number, substitute?: boolean }[]
|
||||||
}) {
|
}) {
|
||||||
this.options = options;
|
this.options = options;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -150,6 +149,7 @@ export class TagRendering extends UIElement {
|
||||||
// Prepare the choices for the Radio buttons
|
// Prepare the choices for the Radio buttons
|
||||||
let i = 0;
|
let i = 0;
|
||||||
const choices: UIElement[] = [];
|
const choices: UIElement[] = [];
|
||||||
|
const alreadyUsedTexts: string[] = [];
|
||||||
|
|
||||||
for (const choice of options.mappings ?? []) {
|
for (const choice of options.mappings ?? []) {
|
||||||
if (choice.k === null) {
|
if (choice.k === null) {
|
||||||
|
@ -159,16 +159,21 @@ export class TagRendering extends UIElement {
|
||||||
let choiceSubbed = choice;
|
let choiceSubbed = choice;
|
||||||
if (choice.substitute) {
|
if (choice.substitute) {
|
||||||
choiceSubbed = {
|
choiceSubbed = {
|
||||||
k : choice.k.substituteValues(
|
k: choice.k.substituteValues(
|
||||||
options.tagsPreprocessor(this._source.data)),
|
options.tagsPreprocessor(this._source.data)),
|
||||||
txt : this.ApplyTemplate(choice.txt),
|
txt: this.ApplyTemplate(choice.txt),
|
||||||
substitute: false,
|
substitute: false,
|
||||||
priority: choice.priority
|
priority: choice.priority
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
choices.push(new FixedUiElement(choiceSubbed.txt));
|
const txt = choiceSubbed.txt;
|
||||||
|
if (alreadyUsedTexts.indexOf(txt) < 0) {
|
||||||
|
choices.push(new FixedUiElement(txt));
|
||||||
|
alreadyUsedTexts.push(txt);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
this._mapping.push(choiceSubbed);
|
this._mapping.push(choiceSubbed);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
|
@ -105,9 +105,8 @@ export class ImageSearcher extends UIEventSource<string[]> {
|
||||||
if(key === undefined){
|
if(key === undefined){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
console.log("Deleting image...");
|
console.log("Deleting image...", key, " --> ", url);
|
||||||
|
this._changes.addChange(this._tags.data.id, key, "");
|
||||||
// this._changes.addChange(this._tags.data.id, key, "");
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -133,16 +132,11 @@ export class ImageSearcher extends UIEventSource<string[]> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const image0 = this._tags.data["image:0"];
|
for (const key in this._tags.data) {
|
||||||
if (image0 !== undefined) {
|
// @ts-ignore
|
||||||
this.AddImage(image0);
|
if(key.startsWith("image:")){
|
||||||
}
|
this.AddImage(this._tags.data[key]);
|
||||||
let imageIndex = 1;
|
}
|
||||||
let imagei = this._tags.data["image:" + imageIndex];
|
|
||||||
while (imagei !== undefined) {
|
|
||||||
this.AddImage(imagei);
|
|
||||||
imageIndex++;
|
|
||||||
imagei = this._tags.data["image:" + imageIndex];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const wdItem = this._tags.data.wikidata;
|
const wdItem = this._tags.data.wikidata;
|
||||||
|
|
|
@ -78,7 +78,8 @@ Camera Icon, Dave Gandy, CC-BY-SA 3.0
|
||||||
https://commons.wikimedia.org/wiki/File:OOjs_UI_indicator_search-rtl.svg
|
https://commons.wikimedia.org/wiki/File:OOjs_UI_indicator_search-rtl.svg
|
||||||
Search Icon, MIT
|
Search Icon, MIT
|
||||||
|
|
||||||
|
https://commons.wikimedia.org/wiki/File:Trash_font_awesome.svg
|
||||||
|
Trash icon by Dave Gandy, CC-BY-SA
|
||||||
|
|
||||||
https://commons.wikimedia.org/wiki/File:Home-icon.svg
|
https://commons.wikimedia.org/wiki/File:Home-icon.svg
|
||||||
Home icon by Timothy Miller, CC-BY-SA 3.0
|
Home icon by Timothy Miller, CC-BY-SA 3.0
|
||||||
|
|
69
UI/ConfirmDialog.ts
Normal file
69
UI/ConfirmDialog.ts
Normal file
|
@ -0,0 +1,69 @@
|
||||||
|
import {UIElement} from "./UIElement";
|
||||||
|
import {UIEventSource} from "./UIEventSource";
|
||||||
|
import {FixedUiElement} from "./Base/FixedUiElement";
|
||||||
|
import {VariableUiElement} from "./Base/VariableUIElement";
|
||||||
|
|
||||||
|
|
||||||
|
export class ConfirmDialog extends UIElement {
|
||||||
|
private _showOptions: UIEventSource<boolean> = new UIEventSource<boolean>(false);
|
||||||
|
|
||||||
|
private _question: UIElement;
|
||||||
|
private _optionA: UIElement;
|
||||||
|
private _optionB: UIElement;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
show: UIEventSource<boolean>,
|
||||||
|
question: string,
|
||||||
|
optionA: string, optionB: string,
|
||||||
|
executeA: () => void,
|
||||||
|
executeB: () => void,
|
||||||
|
classA: string = "",
|
||||||
|
classB: string = "") {
|
||||||
|
super(show);
|
||||||
|
this.ListenTo(this._showOptions);
|
||||||
|
const self = this;
|
||||||
|
show.addCallback(() => {
|
||||||
|
self._showOptions.setData(false);
|
||||||
|
})
|
||||||
|
this._question = new FixedUiElement("<span class='ui-question'>" + question + "</span>")
|
||||||
|
.onClick(() => {
|
||||||
|
self._showOptions.setData(!self._showOptions.data);
|
||||||
|
});
|
||||||
|
this._optionA = new VariableUiElement(
|
||||||
|
this._showOptions.map(
|
||||||
|
(show) => show ? "<div class='" + classA + "'>" + optionA + "</div>" : ""))
|
||||||
|
.onClick(() => {
|
||||||
|
self._showOptions.setData(false);
|
||||||
|
executeA();
|
||||||
|
}
|
||||||
|
);
|
||||||
|
this._optionB = new VariableUiElement(
|
||||||
|
this._showOptions.map((show) =>
|
||||||
|
show ? "<div class='" + classB + "'>" + optionB + "</div>" : "") )
|
||||||
|
.onClick(() => {
|
||||||
|
self._showOptions.setData(false);
|
||||||
|
executeB();
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected InnerRender(): string {
|
||||||
|
if (!this._source.data) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
return this._question.Render() +
|
||||||
|
this._optionA.Render() +
|
||||||
|
this._optionB.Render();
|
||||||
|
}
|
||||||
|
|
||||||
|
Update() {
|
||||||
|
super.Update();
|
||||||
|
this._question.Update();
|
||||||
|
this._optionA.Update();
|
||||||
|
this._optionB.Update();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -6,6 +6,7 @@ import {FixedUiElement} from "../Base/FixedUiElement";
|
||||||
import {VerticalCombine} from "../Base/VerticalCombine";
|
import {VerticalCombine} from "../Base/VerticalCombine";
|
||||||
import {Changes} from "../../Logic/Changes";
|
import {Changes} from "../../Logic/Changes";
|
||||||
import {VariableUiElement} from "../Base/VariableUIElement";
|
import {VariableUiElement} from "../Base/VariableUIElement";
|
||||||
|
import {ConfirmDialog} from "../ConfirmDialog";
|
||||||
|
|
||||||
export class ImageCarousel extends UIElement {
|
export class ImageCarousel extends UIElement {
|
||||||
/**
|
/**
|
||||||
|
@ -25,7 +26,6 @@ export class ImageCarousel extends UIElement {
|
||||||
|
|
||||||
private readonly _uiElements: UIEventSource<UIElement[]>;
|
private readonly _uiElements: UIEventSource<UIElement[]>;
|
||||||
|
|
||||||
private readonly _deleteButtonText = new UIEventSource<string>("");
|
|
||||||
private readonly _deleteButton: UIElement;
|
private readonly _deleteButton: UIElement;
|
||||||
|
|
||||||
constructor(tags: UIEventSource<any>, changes: Changes) {
|
constructor(tags: UIEventSource<any>, changes: Changes) {
|
||||||
|
@ -48,24 +48,33 @@ export class ImageCarousel extends UIElement {
|
||||||
new FixedUiElement("")).HideOnEmpty(true);
|
new FixedUiElement("")).HideOnEmpty(true);
|
||||||
|
|
||||||
|
|
||||||
this._deleteButtonText = this.slideshow._currentSlide.map((i) => {
|
const showDeleteButton = this.slideshow._currentSlide.map((i) => {
|
||||||
if(self.searcher.IsDeletable(self.searcher.data[i])){
|
return self.searcher.IsDeletable(self.searcher.data[i]);
|
||||||
return "DELETE";
|
}, [this.searcher]);
|
||||||
}else{
|
this.slideshow._currentSlide.addCallback(() => {
|
||||||
return "";
|
showDeleteButton.ping(); // This pings the showDeleteButton, which indicates that it has to hide it's subbuttons
|
||||||
}
|
})
|
||||||
});
|
|
||||||
|
|
||||||
this._deleteButton = new VariableUiElement(this._deleteButtonText)
|
|
||||||
.HideOnEmpty(true)
|
const deleteCurrent = () => self.searcher.Delete(self.searcher.data[self.slideshow._currentSlide.data]);
|
||||||
.onClick(() => {
|
|
||||||
self.searcher.Delete(self.searcher.data[self.slideshow._currentSlide.data]);
|
this._deleteButton = new ConfirmDialog(showDeleteButton,
|
||||||
});
|
"<img src='assets/delete.svg' alt='Afbeelding verwijderen' class='delete-image'>",
|
||||||
|
"<span>Afbeelding verwijderen</span>",
|
||||||
|
"<span>Terug</span>",
|
||||||
|
deleteCurrent,
|
||||||
|
() => {},
|
||||||
|
'delete-image-confirm',
|
||||||
|
'delete-image-cancel');
|
||||||
}
|
}
|
||||||
|
|
||||||
InnerRender(): string {
|
InnerRender(): string {
|
||||||
return this.slideshow.Render() ;
|
return "<span class='image-carousel-container'>" +
|
||||||
// + this._deleteButton.Render();
|
"<div class='image-delete-container'>" +
|
||||||
|
this._deleteButton.Render() +
|
||||||
|
"</div>" +
|
||||||
|
this.slideshow.Render() +
|
||||||
|
"</span>";
|
||||||
}
|
}
|
||||||
|
|
||||||
InnerUpdate(htmlElement: HTMLElement) {
|
InnerUpdate(htmlElement: HTMLElement) {
|
||||||
|
|
|
@ -58,6 +58,17 @@ export abstract class UIElement {
|
||||||
}
|
}
|
||||||
element.style.pointerEvents = "all";
|
element.style.pointerEvents = "all";
|
||||||
element.style.cursor = "pointer";
|
element.style.cursor = "pointer";
|
||||||
|
/*
|
||||||
|
const childs = element.children;
|
||||||
|
for (let i = 0; i < childs.length; i++) {
|
||||||
|
const ch = childs[i];
|
||||||
|
console.log(ch);
|
||||||
|
ch.style.cursor = "pointer";
|
||||||
|
ch.onclick = () => {
|
||||||
|
self._onClick();
|
||||||
|
}
|
||||||
|
ch.style.pointerEvents = "all";
|
||||||
|
}*/
|
||||||
}
|
}
|
||||||
|
|
||||||
this.InnerUpdate(element);
|
this.InnerUpdate(element);
|
||||||
|
|
|
@ -27,15 +27,23 @@ export class UIEventSource<T>{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public map<J>(f: ((T) => J)): UIEventSource<J> {
|
public map<J>(f: ((T) => J),
|
||||||
|
extraSources : UIEventSource<any>[] = []): UIEventSource<J> {
|
||||||
const self = this;
|
const self = this;
|
||||||
this.addCallback(function () {
|
|
||||||
|
const update = function () {
|
||||||
newSource.setData(f(self.data));
|
newSource.setData(f(self.data));
|
||||||
newSource.ping();
|
newSource.ping();
|
||||||
});
|
}
|
||||||
|
|
||||||
|
this.addCallback(update);
|
||||||
|
for (const extraSource of extraSources) {
|
||||||
|
extraSource.addCallback(update);
|
||||||
|
}
|
||||||
const newSource = new UIEventSource<J>(
|
const newSource = new UIEventSource<J>(
|
||||||
f(this.data)
|
f(this.data)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
return newSource;
|
return newSource;
|
||||||
|
|
||||||
|
|
55
assets/delete.svg
Normal file
55
assets/delete.svg
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
|
||||||
|
<svg
|
||||||
|
xmlns:dc="http://purl.org/dc/elements/1.1/"
|
||||||
|
xmlns:cc="http://creativecommons.org/ns#"
|
||||||
|
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
|
||||||
|
xmlns:svg="http://www.w3.org/2000/svg"
|
||||||
|
xmlns="http://www.w3.org/2000/svg"
|
||||||
|
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
|
||||||
|
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
|
||||||
|
viewBox="0 -256 1792 1792"
|
||||||
|
id="svg3741"
|
||||||
|
version="1.1"
|
||||||
|
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"
|
||||||
|
width="100%"
|
||||||
|
height="100%"
|
||||||
|
sodipodi:docname="delete.svg">
|
||||||
|
<metadata
|
||||||
|
id="metadata3751">
|
||||||
|
<rdf:RDF>
|
||||||
|
<cc:Work
|
||||||
|
rdf:about="">
|
||||||
|
<dc:format>image/svg+xml</dc:format>
|
||||||
|
<dc:type
|
||||||
|
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
|
||||||
|
</cc:Work>
|
||||||
|
</rdf:RDF>
|
||||||
|
</metadata>
|
||||||
|
<defs
|
||||||
|
id="defs3749" />
|
||||||
|
<sodipodi:namedview
|
||||||
|
pagecolor="#ffffff"
|
||||||
|
bordercolor="#666666"
|
||||||
|
borderopacity="1"
|
||||||
|
objecttolerance="10"
|
||||||
|
gridtolerance="10"
|
||||||
|
guidetolerance="10"
|
||||||
|
inkscape:pageopacity="0"
|
||||||
|
inkscape:pageshadow="2"
|
||||||
|
inkscape:window-width="1920"
|
||||||
|
inkscape:window-height="1001"
|
||||||
|
id="namedview3747"
|
||||||
|
showgrid="false"
|
||||||
|
inkscape:zoom="0.18624688"
|
||||||
|
inkscape:cx="795.91988"
|
||||||
|
inkscape:cy="822.60792"
|
||||||
|
inkscape:window-x="0"
|
||||||
|
inkscape:window-y="0"
|
||||||
|
inkscape:window-maximized="1"
|
||||||
|
inkscape:current-layer="svg3741" />
|
||||||
|
<path
|
||||||
|
style="fill:#ff0000;fill-opacity:1"
|
||||||
|
inkscape:connector-curvature="0"
|
||||||
|
id="path3745"
|
||||||
|
d="m 709.42373,455.0508 v 576 q 0,14 -9,23 -9,9 -23,9 h -64 q -14,0 -23,-9 -9,-9 -9,-23 v -576 q 0,-14 9,-23 9,-9 23,-9 h 64 q 14,0 23,9 9,9 9,23 z m 256,0 v 576 q 0,14 -9,23 -9,9 -23,9 h -64 q -14,0 -23,-9 -9,-9 -9,-23 v -576 q 0,-14 9,-23 9,-9 23,-9 h 64 q 14,0 23,9 9,9 9,23 z m 255.99997,0 v 576 q 0,14 -9,23 -9,9 -23,9 h -64 q -14,0 -23,-9 -9,-9 -9,-23 v -576 q 0,-14 9,-23 9,-9 23,-9 h 64 q 14,0 23,9 9,9 9,23 z m 128,724 v -948 H 453.42373 v 948 q 0,22 7,40.5 7,18.5 14.5,27 7.5,8.5 10.5,8.5 h 831.99997 q 3,0 10.5,-8.5 7.5,-8.5 14.5,-27 7,-18.5 7,-40.5 z m -671.99997,-1076 h 447.99997 l -48,-117 q -7,-9 -17,-11 H 743.42373 q -10,2 -17,11 z m 927.99997,32 v 64 q 0,14 -9,23 -9,9 -23,9 h -96 v 948 q 0,83 -47,143.5 -47,60.5 -113,60.5 H 485.42373 q -66,0 -113,-58.5 -47,-58.5 -47,-141.5 v -952 h -96 q -14,0 -23,-9 -9,-9 -9,-23 v -64 q 0,-14 9,-23 9,-9 23,-9 h 309 l 70,-167 q 15,-37 54,-63 39,-26 79,-26 h 319.99997 q 40,0 79,26 39,26 54,63 l 70,167 h 309 q 14,0 23,9 9,9 9,23 z" />
|
||||||
|
</svg>
|
After Width: | Height: | Size: 2.5 KiB |
78
index.css
78
index.css
|
@ -682,6 +682,84 @@ body {
|
||||||
display: inline-block
|
display: inline-block
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/******* THe remove image buttons ****/
|
||||||
|
|
||||||
|
.image-carousel-container {
|
||||||
|
position: relative;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-delete-container {
|
||||||
|
position: absolute;
|
||||||
|
left: 6em;
|
||||||
|
top: 1.5em;
|
||||||
|
display: inline-block;
|
||||||
|
z-index: 7000;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.delete-image {
|
||||||
|
width: 1.5em;
|
||||||
|
height: 1.5em;
|
||||||
|
padding: 0.5em;
|
||||||
|
border-radius: 3em;
|
||||||
|
background-color: black;
|
||||||
|
}
|
||||||
|
|
||||||
|
.delete-image-confirm {
|
||||||
|
position: absolute;
|
||||||
|
display: inline-block;
|
||||||
|
left: 0;
|
||||||
|
top: 2.5em;
|
||||||
|
|
||||||
|
padding: 0.5em;
|
||||||
|
padding-left: 0.75em;
|
||||||
|
|
||||||
|
z-index: -1;
|
||||||
|
height: 3em;
|
||||||
|
width: 14em;
|
||||||
|
border-radius: 1em;
|
||||||
|
border-top-left-radius: 0;
|
||||||
|
border-top-right-radius: 0;
|
||||||
|
background-color: #ff8c8c;
|
||||||
|
|
||||||
|
color: white;
|
||||||
|
height: 1.5em; /* same as .delete-image */
|
||||||
|
|
||||||
|
z-index: 7000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.delete-image-confirm span {
|
||||||
|
font-size: larger;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
.delete-image-cancel {
|
||||||
|
display: inline-block;
|
||||||
|
position: absolute;
|
||||||
|
|
||||||
|
left: 0em;
|
||||||
|
padding: 0.5em;
|
||||||
|
padding-left: 0.75em;
|
||||||
|
|
||||||
|
border-radius: 1em;
|
||||||
|
border-bottom-right-radius: 0;
|
||||||
|
border-bottom-left-radius: 0;
|
||||||
|
|
||||||
|
height: 1.5em; /* same as .delete-image */
|
||||||
|
width: 14em; /* Same as delete-image-confirm */
|
||||||
|
|
||||||
|
|
||||||
|
background-color: black;
|
||||||
|
color: white;
|
||||||
|
z-index: 7000;
|
||||||
|
}
|
||||||
|
|
||||||
|
.delete-image-cancel span {
|
||||||
|
font-size: larger;
|
||||||
|
font-weight: bold;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
/**** The save button *****/
|
/**** The save button *****/
|
||||||
|
|
||||||
|
|
|
@ -5,7 +5,9 @@
|
||||||
<link href="index.css" rel="stylesheet"/>
|
<link href="index.css" rel="stylesheet"/>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
<span class="image-delete-container">
|
||||||
<div id="maindiv">'maindiv' not attached</div>
|
<div id="maindiv">'maindiv' not attached</div>
|
||||||
|
</span>
|
||||||
<div id="extradiv">'extradiv' not attached</div>
|
<div id="extradiv">'extradiv' not attached</div>
|
||||||
<script src="./test.ts"></script>
|
<script src="./test.ts"></script>
|
||||||
</body>
|
</body>
|
||||||
|
|
28
test.ts
28
test.ts
|
@ -4,18 +4,20 @@ import {OsmConnection} from "./Logic/OsmConnection";
|
||||||
import {ElementStorage} from "./Logic/ElementStorage";
|
import {ElementStorage} from "./Logic/ElementStorage";
|
||||||
import {WikipediaLink} from "./Customizations/Questions/WikipediaLink";
|
import {WikipediaLink} from "./Customizations/Questions/WikipediaLink";
|
||||||
import {OsmLink} from "./Customizations/Questions/OsmLink";
|
import {OsmLink} from "./Customizations/Questions/OsmLink";
|
||||||
|
import {ConfirmDialog} from "./UI/ConfirmDialog";
|
||||||
const tags = {name: "Test",
|
|
||||||
wikipedia: "nl:Pieter",
|
|
||||||
id: "node/-1"};
|
|
||||||
const tagsES = new UIEventSource(tags);
|
|
||||||
|
|
||||||
const login = new OsmConnection(true);
|
|
||||||
|
|
||||||
const allElements = new ElementStorage();
|
|
||||||
allElements.addElementById(tags.id, tagsES);
|
|
||||||
|
|
||||||
const changes = new Changes("Test", login, allElements)
|
|
||||||
|
|
||||||
|
|
||||||
new OsmLink(tagsES, changes).AttachTo("maindiv");
|
new ConfirmDialog(new UIEventSource<boolean>(true),
|
||||||
|
"<img src='assets/delete.svg' alt='Afbeelding verwijderen' class='delete-image'>",
|
||||||
|
"Deze afbeelding verwijderen",
|
||||||
|
"Terug",
|
||||||
|
|
||||||
|
() => {
|
||||||
|
console.log("Verwijderen");
|
||||||
|
},
|
||||||
|
() => {
|
||||||
|
console.log("terug")
|
||||||
|
},
|
||||||
|
'delete-image-confirm',
|
||||||
|
'delete-image-cancel')
|
||||||
|
.AttachTo("maindiv")
|
Loading…
Reference in a new issue