| 
									
										
										
										
											2020-07-29 16:46:45 +02:00
										 |  |  | import Translations from "../i18n/Translations"; | 
					
						
							|  |  |  | import Combine from "./Combine"; | 
					
						
							| 
									
										
										
										
											2021-06-10 01:36:20 +02:00
										 |  |  | import BaseUIElement from "../BaseUIElement"; | 
					
						
							|  |  |  | import Link from "./Link"; | 
					
						
							|  |  |  | import Img from "./Img"; | 
					
						
							| 
									
										
										
										
											2022-06-05 02:24:14 +02:00
										 |  |  | import {Store, UIEventSource} from "../../Logic/UIEventSource"; | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  | import {UIElement} from "../UIElement"; | 
					
						
							| 
									
										
										
										
											2022-02-16 01:28:23 +01:00
										 |  |  | import {VariableUiElement} from "./VariableUIElement"; | 
					
						
							|  |  |  | import Lazy from "./Lazy"; | 
					
						
							|  |  |  | import Loading from "./Loading"; | 
					
						
							| 
									
										
										
										
											2020-07-29 16:46:45 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  | export class SubtleButton extends UIElement { | 
					
						
							| 
									
										
										
										
											2021-12-21 19:09:24 +01:00
										 |  |  |     private readonly imageUrl: string | BaseUIElement; | 
					
						
							|  |  |  |     private readonly message: string | BaseUIElement; | 
					
						
							| 
									
										
										
										
											2022-06-05 02:24:14 +02:00
										 |  |  |     private readonly options: { url?: string | Store<string>; newTab?: boolean ; imgSize?: string}; | 
					
						
							| 
									
										
										
										
											2020-07-29 16:46:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-30 00:17:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-24 01:32:19 +02:00
										 |  |  |     constructor(imageUrl: string | BaseUIElement, message: string | BaseUIElement, options: {  | 
					
						
							| 
									
										
										
										
											2022-06-05 02:24:14 +02:00
										 |  |  |         url?: string | Store<string>,  | 
					
						
							| 
									
										
										
										
											2022-04-24 01:32:19 +02:00
										 |  |  |         newTab?: boolean, | 
					
						
							|  |  |  |         imgSize?: "h-11 w-11" | string | 
					
						
							|  |  |  |     } = undefined) { | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  |         super(); | 
					
						
							| 
									
										
										
										
											2021-12-21 19:09:24 +01:00
										 |  |  |         this.imageUrl = imageUrl; | 
					
						
							|  |  |  |         this.message = message; | 
					
						
							| 
									
										
										
										
											2022-04-24 01:32:19 +02:00
										 |  |  |         this.options = options; | 
					
						
							| 
									
										
										
										
											2021-05-30 00:17:31 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-21 19:09:24 +01:00
										 |  |  |     protected InnerRender(): string | BaseUIElement { | 
					
						
							| 
									
										
										
										
											2022-02-07 01:57:49 +01:00
										 |  |  |         const classes = "block flex p-3 my-2 bg-subtle rounded-lg hover:shadow-xl hover:bg-unsubtle transition-colors transition-shadow link-no-underline"; | 
					
						
							| 
									
										
										
										
											2022-07-01 00:16:05 +02:00
										 |  |  |         const message = Translations.W(this.message)?.SetClass("block overflow-ellipsis no-images flex-shrink"); | 
					
						
							| 
									
										
										
										
											2021-01-18 19:36:19 +01:00
										 |  |  |         let img; | 
					
						
							| 
									
										
										
										
											2022-07-01 00:16:05 +02:00
										 |  |  |         const imgClasses = "block justify-center flex-none mr-4 " + (this.options?.imgSize ?? "h-11 w-11") | 
					
						
							| 
									
										
										
										
											2021-12-21 19:09:24 +01:00
										 |  |  |         if ((this.imageUrl ?? "") === "") { | 
					
						
							| 
									
										
										
										
											2021-06-10 01:36:20 +02:00
										 |  |  |             img = undefined; | 
					
						
							| 
									
										
										
										
											2021-12-21 19:09:24 +01:00
										 |  |  |         } else if (typeof (this.imageUrl) === "string") { | 
					
						
							| 
									
										
										
										
											2022-07-01 00:16:05 +02:00
										 |  |  |             img = new Img(this.imageUrl)?.SetClass(imgClasses) | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2022-07-01 00:16:05 +02:00
										 |  |  |             img = this.imageUrl?.SetClass(imgClasses); | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-07-01 00:16:05 +02:00
										 |  |  |             const button = new Combine([ | 
					
						
							|  |  |  |             img, | 
					
						
							| 
									
										
										
										
											2022-02-07 01:57:49 +01:00
										 |  |  |             message | 
					
						
							| 
									
										
										
										
											2022-07-01 00:16:05 +02:00
										 |  |  |          ]).SetClass("flex items-center group w-full") | 
					
						
							| 
									
										
										
										
											2022-02-07 01:57:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-01 00:16:05 +02:00
										 |  |  |          | 
					
						
							| 
									
										
										
										
											2022-04-24 01:32:19 +02:00
										 |  |  |         if (this.options?.url == undefined) { | 
					
						
							| 
									
										
										
										
											2021-12-21 19:09:24 +01:00
										 |  |  |             this.SetClass(classes) | 
					
						
							| 
									
										
										
										
											2022-02-07 01:57:49 +01:00
										 |  |  |             return button | 
					
						
							| 
									
										
										
										
											2020-07-29 19:02:36 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-05-30 00:17:31 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         return new Link( | 
					
						
							| 
									
										
										
										
											2022-02-07 01:57:49 +01:00
										 |  |  |             button, | 
					
						
							| 
									
										
										
										
											2022-04-24 01:32:19 +02:00
										 |  |  |             this.options.url, | 
					
						
							|  |  |  |             this.options.newTab ?? false | 
					
						
							| 
									
										
										
										
											2021-12-21 19:09:24 +01:00
										 |  |  |         ).SetClass(classes) | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-29 16:46:45 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-16 01:28:23 +01:00
										 |  |  |     public OnClickWithLoading( | 
					
						
							|  |  |  |         loadingText: BaseUIElement | string, | 
					
						
							|  |  |  |         action: () => Promise<void> ) : BaseUIElement{ | 
					
						
							|  |  |  |         const state = new UIEventSource<"idle" | "running">("idle") | 
					
						
							|  |  |  |         const button = this; | 
					
						
							|  |  |  |          | 
					
						
							|  |  |  |         button.onClick(async() => { | 
					
						
							|  |  |  |             state.setData("running") | 
					
						
							|  |  |  |             try{     | 
					
						
							|  |  |  |                await action() | 
					
						
							|  |  |  |             }catch(e){ | 
					
						
							|  |  |  |                 console.error(e) | 
					
						
							|  |  |  |             }finally { | 
					
						
							|  |  |  |                 state.setData("idle") | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |              | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         const loading = new Lazy(() => new Loading(loadingText) ) | 
					
						
							|  |  |  |         return new VariableUiElement(state.map(st => { | 
					
						
							|  |  |  |             if(st === "idle"){ | 
					
						
							|  |  |  |                 return button | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             return loading | 
					
						
							|  |  |  |         })) | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-07-29 16:46:45 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | } |