| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  | import LayerConfig from "./ThemeConfig/LayerConfig" | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  | import { UIEventSource } from "../Logic/UIEventSource" | 
					
						
							| 
									
										
										
										
											2023-04-07 03:54:11 +02:00
										 |  |  | import UserRelatedState from "../Logic/State/UserRelatedState" | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  | import { Utils } from "../Utils" | 
					
						
							| 
									
										
										
										
											2024-01-11 04:00:56 +01:00
										 |  |  | import Zoomcontrol from "../UI/Zoomcontrol" | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | import { LocalStorageSource } from "../Logic/Web/LocalStorageSource" | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | export type PageType = (typeof MenuState.pageNames)[number] | 
					
						
							| 
									
										
										
										
											2023-05-17 13:21:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Indicates if a menu is open, and if so, which tab is selected; | 
					
						
							|  |  |  |  * Some tabs allow to highlight an element. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Some convenience methods are provided for this as well | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | export class MenuState { | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |     public static readonly pageNames = [ | 
					
						
							| 
									
										
										
										
											2024-09-02 12:48:15 +02:00
										 |  |  |         "copyright", | 
					
						
							|  |  |  |         "copyright_icons", | 
					
						
							|  |  |  |         "community_index", | 
					
						
							|  |  |  |         "hotkeys", | 
					
						
							|  |  |  |         "privacy", | 
					
						
							|  |  |  |         "filter", | 
					
						
							|  |  |  |         "background", | 
					
						
							|  |  |  |         "about_theme", | 
					
						
							|  |  |  |         "download", | 
					
						
							|  |  |  |         "favourites", | 
					
						
							|  |  |  |         "usersettings", | 
					
						
							|  |  |  |         "share", | 
					
						
							| 
									
										
										
										
											2025-01-28 15:42:34 +01:00
										 |  |  |         "menu", | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |     ] as const | 
					
						
							| 
									
										
										
										
											2024-06-27 03:39:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Contains the 'providedImage' which is currently displayed on top of the UI | 
					
						
							|  |  |  |      * This object merely acts as lock or as means to signal the need to close | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2025-01-28 15:42:34 +01:00
										 |  |  |     public static readonly previewedImage: UIEventSource<object> = new UIEventSource<object>( | 
					
						
							|  |  |  |         undefined | 
					
						
							|  |  |  |     ) | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |     public readonly pageStates: Record<PageType, UIEventSource<boolean>> | 
					
						
							| 
									
										
										
										
											2023-06-07 02:42:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  |     public readonly highlightedLayerInFilters: UIEventSource<string> = new UIEventSource<string>( | 
					
						
							| 
									
										
										
										
											2024-09-02 12:48:15 +02:00
										 |  |  |         undefined | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  |     ) | 
					
						
							| 
									
										
										
										
											2023-04-07 02:13:57 +02:00
										 |  |  |     public highlightedUserSetting: UIEventSource<string> = new UIEventSource<string>(undefined) | 
					
						
							| 
									
										
										
										
											2025-02-25 02:16:00 +01:00
										 |  |  |     private readonly _selectedElement: UIEventSource<any> | undefined | 
					
						
							| 
									
										
										
										
											2023-06-07 02:42:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-02-25 02:16:00 +01:00
										 |  |  |     constructor(selectedElement: UIEventSource<any> | undefined) { | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |         this._selectedElement = selectedElement | 
					
						
							| 
									
										
										
										
											2023-08-10 15:37:44 +02:00
										 |  |  |         // Note: this class is _not_ responsible to update the Hash, @see ThemeViewStateHashActor for this
 | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         const states = {} | 
					
						
							|  |  |  |         for (const pageName of MenuState.pageNames) { | 
					
						
							|  |  |  |             const toggle = new UIEventSource(false) | 
					
						
							|  |  |  |             states[pageName] = toggle | 
					
						
							| 
									
										
										
										
											2024-08-31 16:25:41 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         this.pageStates = <Record<PageType, UIEventSource<boolean>>>states | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |         for (const pageName of MenuState.pageNames) { | 
					
						
							| 
									
										
										
										
											2024-09-02 12:48:15 +02:00
										 |  |  |             if (pageName === "menu") { | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |                 continue | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-09-02 12:48:15 +02:00
										 |  |  |             this.pageStates[pageName].addCallback((enabled) => { | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |                 if (enabled) { | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |                     this.pageStates.menu.set(false) | 
					
						
							| 
									
										
										
										
											2024-01-11 04:00:56 +01:00
										 |  |  |                 } | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |     public openMenuIfNeeded(shouldShowWelcomeMessage: boolean, themeid: string) { | 
					
						
							| 
									
										
										
										
											2024-10-17 02:10:25 +02:00
										 |  |  |         const visitedBefore = LocalStorageSource.getParsed<boolean>( | 
					
						
							| 
									
										
										
										
											2024-09-02 12:48:15 +02:00
										 |  |  |             themeid + "thememenuisopened", | 
					
						
							|  |  |  |             false | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         ) | 
					
						
							|  |  |  |         if (!visitedBefore.data && shouldShowWelcomeMessage) { | 
					
						
							|  |  |  |             this.pageStates.about_theme.set(true) | 
					
						
							|  |  |  |             visitedBefore.set(true) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-01-11 04:00:56 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private resetZoomIfAllClosed() { | 
					
						
							|  |  |  |         if (this.isSomethingOpen()) { | 
					
						
							|  |  |  |             return | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         Zoomcontrol.resetzoom() | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2023-06-07 02:42:49 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  |     public openFilterView(highlightLayer?: LayerConfig | string) { | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         this.pageStates.filter.setData(true) | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  |         if (highlightLayer) { | 
					
						
							|  |  |  |             if (typeof highlightLayer !== "string") { | 
					
						
							|  |  |  |                 highlightLayer = highlightLayer.id | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             this.highlightedLayerInFilters.setData(highlightLayer) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-04-07 02:13:57 +02:00
										 |  |  |     public openUsersettings(highlightTagRendering?: string) { | 
					
						
							| 
									
										
										
										
											2023-04-07 03:54:11 +02:00
										 |  |  |         if ( | 
					
						
							|  |  |  |             highlightTagRendering !== undefined && | 
					
						
							|  |  |  |             !UserRelatedState.availableUserSettingsIds.some((tr) => tr === highlightTagRendering) | 
					
						
							|  |  |  |         ) { | 
					
						
							|  |  |  |             console.error( | 
					
						
							|  |  |  |                 "No tagRendering with id '" + highlightTagRendering + "'; maybe you meant:", | 
					
						
							|  |  |  |                 Utils.sortedByLevenshteinDistance( | 
					
						
							|  |  |  |                     highlightTagRendering, | 
					
						
							|  |  |  |                     UserRelatedState.availableUserSettingsIds, | 
					
						
							| 
									
										
										
										
											2024-09-02 12:48:15 +02:00
										 |  |  |                     (x) => x | 
					
						
							|  |  |  |                 ) | 
					
						
							| 
									
										
										
										
											2023-04-07 03:54:11 +02:00
										 |  |  |             ) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-04-07 02:13:57 +02:00
										 |  |  |         this.highlightedUserSetting.setData(highlightTagRendering) | 
					
						
							| 
									
										
										
										
											2024-09-02 12:42:03 +02:00
										 |  |  |         this.pageStates.usersettings.set(true) | 
					
						
							| 
									
										
										
										
											2023-04-07 02:13:57 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-11 04:00:56 +01:00
										 |  |  |     public isSomethingOpen(): boolean { | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |         if (MenuState.previewedImage.data !== undefined) { | 
					
						
							|  |  |  |             return true | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-02-25 02:16:00 +01:00
										 |  |  |         if (this._selectedElement?.data) { | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |             return true | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         return Object.values(this.pageStates).some((t) => t.data) | 
					
						
							| 
									
										
										
										
											2024-01-11 04:00:56 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-07 02:42:49 +02:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * Close all floatOvers. | 
					
						
							|  |  |  |      * Returns 'true' if at least one menu was opened | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     public closeAll(): boolean { | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |         console.log("Closing all") | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |         const ps = this.pageStates | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |         if (ps.menu.data) { | 
					
						
							|  |  |  |             ps.menu.set(false) | 
					
						
							|  |  |  |             return true | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (MenuState.previewedImage.data !== undefined) { | 
					
						
							|  |  |  |             MenuState.previewedImage.setData(undefined) | 
					
						
							|  |  |  |             return true | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-09-02 00:26:02 +02:00
										 |  |  |         for (const key in ps) { | 
					
						
							|  |  |  |             const toggle = ps[key] | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |             const wasOpen = toggle.data | 
					
						
							|  |  |  |             toggle.setData(false) | 
					
						
							|  |  |  |             if (wasOpen) { | 
					
						
							|  |  |  |                 return true | 
					
						
							| 
									
										
										
										
											2023-12-20 02:50:08 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2025-01-23 12:29:54 +01:00
										 |  |  |         if (this._selectedElement.data) { | 
					
						
							|  |  |  |             this._selectedElement.setData(undefined) | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |             return true | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2023-04-06 01:33:08 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | } |