| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import { InputElement } from "./InputElement" | 
					
						
							|  |  |  | import { Store, Stores, UIEventSource } from "../../Logic/UIEventSource" | 
					
						
							|  |  |  | import Combine from "../Base/Combine" | 
					
						
							|  |  |  | import Slider from "./Slider" | 
					
						
							|  |  |  | import { ClickableToggle } from "./Toggle" | 
					
						
							|  |  |  | import { FixedUiElement } from "../Base/FixedUiElement" | 
					
						
							|  |  |  | import { VariableUiElement } from "../Base/VariableUIElement" | 
					
						
							|  |  |  | import BaseUIElement from "../BaseUIElement" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default class FloorLevelInputElement | 
					
						
							|  |  |  |     extends VariableUiElement | 
					
						
							|  |  |  |     implements InputElement<string> | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     private readonly _value: UIEventSource<string> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     constructor( | 
					
						
							|  |  |  |         currentLevels: Store<Record<string, number>>, | 
					
						
							|  |  |  |         options?: { | 
					
						
							|  |  |  |             value?: UIEventSource<string> | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ) { | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |         const value = options?.value ?? new UIEventSource<string>("0") | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         super( | 
					
						
							|  |  |  |             currentLevels.map((levels) => { | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |                 const allLevels = Object.keys(levels) | 
					
						
							|  |  |  |                 allLevels.sort((a, b) => { | 
					
						
							|  |  |  |                     const an = Number(a) | 
					
						
							|  |  |  |                     const bn = Number(b) | 
					
						
							|  |  |  |                     if (isNaN(an) || isNaN(bn)) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                         return a < b ? -1 : 1 | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                     return an - bn | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |                 }) | 
					
						
							|  |  |  |                 return FloorLevelInputElement.constructPicker(allLevels, value) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             }) | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         this._value = value | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private static constructPicker(levels: string[], value: UIEventSource<string>): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         let slider = new Slider(0, levels.length - 1, { vertical: true }) | 
					
						
							|  |  |  |         const toggleClass = | 
					
						
							|  |  |  |             "flex border-2 border-blue-500 w-10 h-10 place-content-center items-center border-box" | 
					
						
							|  |  |  |         slider | 
					
						
							|  |  |  |             .SetClass("flex elevator w-10") | 
					
						
							|  |  |  |             .SetStyle(`height: ${2.5 * levels.length}rem; background: #00000000`) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const values = levels.map((data, i) => | 
					
						
							|  |  |  |             new ClickableToggle( | 
					
						
							|  |  |  |                 new FixedUiElement(data).SetClass("font-bold active bg-subtle " + toggleClass), | 
					
						
							|  |  |  |                 new FixedUiElement(data).SetClass("normal-background " + toggleClass), | 
					
						
							|  |  |  |                 slider.GetValue().sync( | 
					
						
							|  |  |  |                     (sliderVal) => { | 
					
						
							|  |  |  |                         return sliderVal === i | 
					
						
							|  |  |  |                     }, | 
					
						
							|  |  |  |                     [], | 
					
						
							|  |  |  |                     (isSelected) => { | 
					
						
							|  |  |  |                         return isSelected ? i : slider.GetValue().data | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             ) | 
					
						
							|  |  |  |                 .ToggleOnClick() | 
					
						
							|  |  |  |                 .SetClass("flex w-10 h-10") | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         values.reverse(/* This is a new list, no side-effects */) | 
					
						
							|  |  |  |         const combine = new Combine([new Combine(values), slider]) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         combine.SetClass("flex flex-row overflow-hidden") | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         slider.GetValue().addCallbackD((i) => { | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |             if (levels === undefined) { | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             if (levels[i] == undefined) { | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |                 return | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             value.setData(levels[i]) | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |         }) | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         value.addCallbackAndRunD((level) => { | 
					
						
							|  |  |  |             const i = levels.findIndex((l) => l === level) | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |             slider.GetValue().setData(i) | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         return combine | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     GetValue(): UIEventSource<string> { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         return this._value | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     IsValid(t: string): boolean { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         return false | 
					
						
							| 
									
										
										
										
											2022-08-06 17:30:23 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | } |