| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import { SlideShow } from "./SlideShow" | 
					
						
							| 
									
										
										
										
											2023-12-05 18:35:18 +01:00
										 |  |  | import { Store, UIEventSource } from "../../Logic/UIEventSource" | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import Combine from "../Base/Combine" | 
					
						
							|  |  |  | import DeleteImage from "./DeleteImage" | 
					
						
							|  |  |  | import BaseUIElement from "../BaseUIElement" | 
					
						
							|  |  |  | import Toggle from "../Input/Toggle" | 
					
						
							| 
									
										
										
										
											2023-12-05 18:35:18 +01:00
										 |  |  | import ImageProvider, { ProvidedImage } from "../../Logic/ImageProviders/ImageProvider" | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import { OsmConnection } from "../../Logic/Osm/OsmConnection" | 
					
						
							|  |  |  | import { Changes } from "../../Logic/Osm/Changes" | 
					
						
							|  |  |  | import LayoutConfig from "../../Models/ThemeConfig/LayoutConfig" | 
					
						
							| 
									
										
										
										
											2023-12-02 03:12:34 +01:00
										 |  |  | import { Feature } from "geojson" | 
					
						
							| 
									
										
										
										
											2023-12-05 18:35:18 +01:00
										 |  |  | import SvelteUIElement from "../Base/SvelteUIElement" | 
					
						
							|  |  |  | import AttributedImage from "./AttributedImage.svelte" | 
					
						
							| 
									
										
										
										
											2020-07-14 20:18:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-14 19:21:33 +02:00
										 |  |  | export class ImageCarousel extends Toggle { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     constructor( | 
					
						
							| 
									
										
										
										
											2023-12-16 01:39:10 +01:00
										 |  |  |         images: Store<{ id: string; key: string; url: string; provider: ImageProvider }[]>, | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         tags: Store<any>, | 
					
						
							| 
									
										
										
										
											2023-12-16 01:39:10 +01:00
										 |  |  |         state: { | 
					
						
							|  |  |  |             osmConnection?: OsmConnection | 
					
						
							|  |  |  |             changes?: Changes | 
					
						
							|  |  |  |             layout: LayoutConfig | 
					
						
							|  |  |  |             previewedImage?: UIEventSource<ProvidedImage> | 
					
						
							| 
									
										
										
										
											2024-01-24 23:45:20 +01:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     ) { | 
					
						
							|  |  |  |         const uiElements = images.map( | 
					
						
							| 
									
										
										
										
											2023-12-16 01:39:10 +01:00
										 |  |  |             (imageURLS: { key: string; url: string; provider: ImageProvider; id: string }[]) => { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                 const uiElements: BaseUIElement[] = [] | 
					
						
							|  |  |  |                 for (const url of imageURLS) { | 
					
						
							|  |  |  |                     try { | 
					
						
							| 
									
										
										
										
											2023-12-16 01:39:10 +01:00
										 |  |  |                         let image: BaseUIElement = new SvelteUIElement(AttributedImage, { | 
					
						
							|  |  |  |                             image: url, | 
					
						
							| 
									
										
										
										
											2024-02-22 18:58:34 +01:00
										 |  |  |                             previewedImage: state?.previewedImage, | 
					
						
							| 
									
										
										
										
											2023-12-16 01:39:10 +01:00
										 |  |  |                         }) | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                         if (url.key !== undefined) { | 
					
						
							|  |  |  |                             image = new Combine([ | 
					
						
							|  |  |  |                                 image, | 
					
						
							|  |  |  |                                 new DeleteImage(url.key, tags, state).SetClass( | 
					
						
							|  |  |  |                                     "delete-image-marker absolute top-0 left-0 pl-3" | 
					
						
							|  |  |  |                                 ), | 
					
						
							|  |  |  |                             ]).SetClass("relative") | 
					
						
							|  |  |  |                         } | 
					
						
							|  |  |  |                         image | 
					
						
							| 
									
										
										
										
											2023-12-09 16:04:35 +01:00
										 |  |  |                             .SetClass("w-full block cursor-zoom-in") | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                             .SetStyle("min-width: 50px; background: grey;") | 
					
						
							|  |  |  |                         uiElements.push(image) | 
					
						
							|  |  |  |                     } catch (e) { | 
					
						
							|  |  |  |                         console.error("Could not generate image element for", url.url, "due to", e) | 
					
						
							| 
									
										
										
										
											2021-09-29 23:56:59 +02:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2020-09-13 03:29:44 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                 return uiElements | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2020-07-07 15:08:52 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-14 19:21:33 +02:00
										 |  |  |         super( | 
					
						
							| 
									
										
										
										
											2024-06-23 02:54:53 +02:00
										 |  |  |             new SlideShow(uiElements).SetClass("w-full block w-full my-4"), | 
					
						
							| 
									
										
										
										
											2021-06-14 19:21:33 +02:00
										 |  |  |             undefined, | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             uiElements.map((els) => els.length > 0) | 
					
						
							| 
									
										
										
										
											2021-06-14 19:21:33 +02:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | } |