| 
									
										
										
										
											2025-04-15 18:18:44 +02:00
										 |  |  | import { | 
					
						
							|  |  |  |     SpecialVisualization, | 
					
						
							|  |  |  |     SpecialVisualizationState, | 
					
						
							|  |  |  |     SpecialVisualizationSvelte, | 
					
						
							|  |  |  | } from "../SpecialVisualization" | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  | import Constants from "../../Models/Constants" | 
					
						
							|  |  |  | import { UIEventSource } from "../../Logic/UIEventSource" | 
					
						
							|  |  |  | import { Feature } from "geojson" | 
					
						
							|  |  |  | import { GeoOperations } from "../../Logic/GeoOperations" | 
					
						
							|  |  |  | import SvelteUIElement from "../Base/SvelteUIElement" | 
					
						
							|  |  |  | import CreateNewNote from "../Popup/Notes/CreateNewNote.svelte" | 
					
						
							|  |  |  | import { Utils } from "../../Utils" | 
					
						
							|  |  |  | import CloseNoteButton from "../Popup/Notes/CloseNoteButton.svelte" | 
					
						
							|  |  |  | import Translations from "../i18n/Translations" | 
					
						
							|  |  |  | import AddNoteComment from "../Popup/Notes/AddNoteComment.svelte" | 
					
						
							|  |  |  | import { Imgur } from "../../Logic/ImageProviders/Imgur" | 
					
						
							|  |  |  | import UploadImage from "../Image/UploadImage.svelte" | 
					
						
							| 
									
										
										
										
											2025-01-29 20:37:04 +01:00
										 |  |  | import { VariableUiElement } from "../Base/VariableUIElement" | 
					
						
							|  |  |  | import Combine from "../Base/Combine" | 
					
						
							|  |  |  | import NoteCommentElement from "../Popup/Notes/NoteCommentElement.svelte" | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | class CloseNoteViz implements SpecialVisualizationSvelte { | 
					
						
							|  |  |  |     public readonly funcName = "close_note" | 
					
						
							|  |  |  |     public readonly needsUrls = [Constants.osmAuthConfig.url] | 
					
						
							|  |  |  |     public readonly docs = | 
					
						
							|  |  |  |         "Button to close a note. A predefined text can be defined to close the note with. If the note is already closed, will show a small text." | 
					
						
							|  |  |  |     public readonly args = [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             name: "text", | 
					
						
							|  |  |  |             doc: "Text to show on this button", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |             required: true, | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             name: "icon", | 
					
						
							|  |  |  |             doc: "Icon to show", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |             defaultValue: "checkmark.svg", | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             name: "idkey", | 
					
						
							|  |  |  |             doc: "The property name where the ID of the note to close can be found", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |             defaultValue: "id", | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             name: "comment", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |             doc: "Text to add onto the note when closing", | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             name: "minZoom", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |             doc: "If set, only show the closenote button if zoomed in enough", | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             name: "zoomButton", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |             doc: "Text to show if not zoomed in enough", | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |     ] | 
					
						
							|  |  |  |     public readonly group: "notes" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public constr( | 
					
						
							|  |  |  |         state: SpecialVisualizationState, | 
					
						
							|  |  |  |         tags: UIEventSource<Record<string, string>>, | 
					
						
							|  |  |  |         args: string[] | 
					
						
							|  |  |  |     ): SvelteUIElement { | 
					
						
							|  |  |  |         const { text, icon, idkey, comment, minZoom, zoomButton } = Utils.ParseVisArgs( | 
					
						
							|  |  |  |             this.args, | 
					
						
							|  |  |  |             args | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return new SvelteUIElement(CloseNoteButton, { | 
					
						
							|  |  |  |             state, | 
					
						
							|  |  |  |             tags, | 
					
						
							|  |  |  |             icon, | 
					
						
							|  |  |  |             idkey, | 
					
						
							|  |  |  |             message: comment, | 
					
						
							|  |  |  |             text: Translations.T(text), | 
					
						
							|  |  |  |             minzoom: minZoom, | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |             zoomMoreMessage: zoomButton, | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |         }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class AddNoteCommentViz implements SpecialVisualizationSvelte { | 
					
						
							|  |  |  |     funcName = "add_note_comment" | 
					
						
							|  |  |  |     needsUrls = [Constants.osmAuthConfig.url] | 
					
						
							|  |  |  |     docs = "A textfield to add a comment to a node (with the option to close the note)." | 
					
						
							|  |  |  |     args = [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             name: "Id-key", | 
					
						
							|  |  |  |             doc: "The property name where the ID of the note to close can be found", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |             defaultValue: "id", | 
					
						
							|  |  |  |         }, | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |     ] | 
					
						
							|  |  |  |     public readonly group: "notes" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |     public constr( | 
					
						
							|  |  |  |         state: SpecialVisualizationState, | 
					
						
							|  |  |  |         tags: UIEventSource<Record<string, string>> | 
					
						
							|  |  |  |     ): SvelteUIElement { | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |         return new SvelteUIElement(AddNoteComment, { state, tags }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class NoteVisualisations { | 
					
						
							| 
									
										
										
										
											2025-01-29 20:37:04 +01:00
										 |  |  |     public static initList(): (SpecialVisualization & { group })[] { | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |         return [ | 
					
						
							|  |  |  |             new AddNoteCommentViz(), | 
					
						
							| 
									
										
										
										
											2025-01-29 20:37:04 +01:00
										 |  |  |             new CloseNoteViz(), | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |             { | 
					
						
							|  |  |  |                 funcName: "open_note", | 
					
						
							|  |  |  |                 args: [], | 
					
						
							|  |  |  |                 group: "notes", | 
					
						
							|  |  |  |                 needsUrls: [Constants.osmAuthConfig.url], | 
					
						
							|  |  |  |                 docs: "Creates a new map note on the given location. This options is placed in the 'last_click'-popup automatically if the 'notes'-layer is enabled", | 
					
						
							|  |  |  |                 constr( | 
					
						
							|  |  |  |                     state: SpecialVisualizationState, | 
					
						
							|  |  |  |                     tagSource: UIEventSource<Record<string, string>>, | 
					
						
							|  |  |  |                     argument: string[], | 
					
						
							|  |  |  |                     feature: Feature | 
					
						
							|  |  |  |                 ): SvelteUIElement { | 
					
						
							|  |  |  |                     const [lon, lat] = GeoOperations.centerpointCoordinates(feature) | 
					
						
							|  |  |  |                     return new SvelteUIElement(CreateNewNote, { | 
					
						
							|  |  |  |                         state, | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |                         coordinate: new UIEventSource({ lon, lat }), | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |                     }) | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |             }, | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 funcName: "add_image_to_note", | 
					
						
							|  |  |  |                 docs: "Adds an image to a node", | 
					
						
							|  |  |  |                 args: [ | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         name: "Id-key", | 
					
						
							|  |  |  |                         doc: "The property name where the ID of the note to close can be found", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |                         defaultValue: "id", | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |                 ], | 
					
						
							|  |  |  |                 group: "notes", | 
					
						
							|  |  |  |                 needsUrls: [Imgur.apiUrl, ...Imgur.supportingUrls], | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-04-08 04:40:33 +02:00
										 |  |  |                 constr: (state, tags, args, feature) => { | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |                     const id = tags.data[args[0] ?? "id"] | 
					
						
							|  |  |  |                     tags = state.featureProperties.getStore(id) | 
					
						
							| 
									
										
										
										
											2025-04-08 04:40:33 +02:00
										 |  |  |                     return new SvelteUIElement(UploadImage, { state, tags, feature }) | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |                 }, | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |             }, | 
					
						
							| 
									
										
										
										
											2025-01-29 20:37:04 +01:00
										 |  |  |             { | 
					
						
							|  |  |  |                 funcName: "visualize_note_comments", | 
					
						
							|  |  |  |                 group: "notes", | 
					
						
							|  |  |  |                 docs: "Visualises the comments for notes", | 
					
						
							|  |  |  |                 args: [ | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         name: "commentsKey", | 
					
						
							|  |  |  |                         doc: "The property name of the comments, which should be stringified json", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |                         defaultValue: "comments", | 
					
						
							| 
									
										
										
										
											2025-01-29 20:37:04 +01:00
										 |  |  |                     }, | 
					
						
							|  |  |  |                     { | 
					
						
							|  |  |  |                         name: "start", | 
					
						
							|  |  |  |                         doc: "Drop the first 'start' comments", | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |                         defaultValue: "0", | 
					
						
							|  |  |  |                     }, | 
					
						
							| 
									
										
										
										
											2025-01-29 20:37:04 +01:00
										 |  |  |                 ], | 
					
						
							|  |  |  |                 needsUrls: [Constants.osmAuthConfig.url], | 
					
						
							|  |  |  |                 constr: (state, tags, args) => | 
					
						
							|  |  |  |                     new VariableUiElement( | 
					
						
							|  |  |  |                         tags | 
					
						
							|  |  |  |                             .map((tags) => tags[args[0]]) | 
					
						
							|  |  |  |                             .map((commentsStr) => { | 
					
						
							|  |  |  |                                 const comments: { text: string }[] = JSON.parse(commentsStr) | 
					
						
							|  |  |  |                                 const startLoc = Number(args[1] ?? 0) | 
					
						
							|  |  |  |                                 if (!isNaN(startLoc) && startLoc > 0) { | 
					
						
							|  |  |  |                                     comments.splice(0, startLoc) | 
					
						
							|  |  |  |                                 } | 
					
						
							|  |  |  |                                 return new Combine( | 
					
						
							|  |  |  |                                     comments | 
					
						
							|  |  |  |                                         .filter((c) => c.text !== "") | 
					
						
							|  |  |  |                                         .map( | 
					
						
							|  |  |  |                                             (comment) => | 
					
						
							|  |  |  |                                                 new SvelteUIElement(NoteCommentElement, { | 
					
						
							|  |  |  |                                                     comment, | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |                                                     state, | 
					
						
							| 
									
										
										
										
											2025-01-29 20:37:04 +01:00
										 |  |  |                                                 }) | 
					
						
							|  |  |  |                                         ) | 
					
						
							|  |  |  |                                 ).SetClass("flex flex-col") | 
					
						
							|  |  |  |                             }) | 
					
						
							| 
									
										
										
										
											2025-02-10 02:04:58 +01:00
										 |  |  |                     ), | 
					
						
							|  |  |  |             }, | 
					
						
							| 
									
										
										
										
											2025-01-27 04:50:44 +01:00
										 |  |  |         ] | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |