| 
									
										
										
										
											2021-09-09 00:05:51 +02:00
										 |  |  | import {InputElement} from "./InputElement"; | 
					
						
							|  |  |  | import {UIEventSource} from "../../Logic/UIEventSource"; | 
					
						
							|  |  |  | import {Utils} from "../../Utils"; | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  | import BaseUIElement from "../BaseUIElement"; | 
					
						
							| 
									
										
										
										
											2020-09-09 22:17:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * Supports multi-input | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-10-02 19:00:24 +02:00
										 |  |  | export default class CheckBoxes extends InputElement<number[]> { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |     private static _nextId = 0; | 
					
						
							|  |  |  |     IsSelected: UIEventSource<boolean> = new UIEventSource<boolean>(false); | 
					
						
							|  |  |  |     private readonly value: UIEventSource<number[]>; | 
					
						
							|  |  |  |     private readonly _elements: BaseUIElement[]; | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     constructor( | 
					
						
							|  |  |  |         elements: BaseUIElement[], | 
					
						
							| 
									
										
										
										
											2021-07-27 17:00:05 +02:00
										 |  |  |         value = new UIEventSource<number[]>([]) | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     ) { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |         super(); | 
					
						
							|  |  |  |         this.value = value; | 
					
						
							|  |  |  |         this._elements = Utils.NoNull(elements); | 
					
						
							|  |  |  |         this.SetClass("flex flex-col"); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     IsValid(ts: number[]): boolean { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |         return ts !== undefined; | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     GetValue(): UIEventSource<number[]> { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |         return this.value; | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     protected InnerConstructElement(): HTMLElement { | 
					
						
							| 
									
										
										
										
											2021-09-30 21:41:21 +02:00
										 |  |  |         const formTag = document.createElement("form"); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |         const value = this.value; | 
					
						
							|  |  |  |         const elements = this._elements; | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |         for (let i = 0; i < elements.length; i++) { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |             let inputI = elements[i]; | 
					
						
							|  |  |  |             const input = document.createElement("input"); | 
					
						
							|  |  |  |             const id = CheckBoxes._nextId; | 
					
						
							|  |  |  |             CheckBoxes._nextId++; | 
					
						
							|  |  |  |             input.id = "checkbox" + id; | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |             input.type = "checkbox"; | 
					
						
							|  |  |  |             input.classList.add("p-1", "cursor-pointer", "m-3", "pl-3", "mr-0"); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |             const label = document.createElement("label"); | 
					
						
							|  |  |  |             label.htmlFor = input.id; | 
					
						
							|  |  |  |             label.appendChild(inputI.ConstructElement()); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |             label.classList.add( | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |                 "block", | 
					
						
							|  |  |  |                 "w-full", | 
					
						
							|  |  |  |                 "p-2", | 
					
						
							|  |  |  |                 "cursor-pointer", | 
					
						
							|  |  |  |                 "bg-red" | 
					
						
							|  |  |  |             ); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-30 21:41:21 +02:00
										 |  |  |             const wrapper = document.createElement("div"); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |             wrapper.classList.add( | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |                 "wrapper", | 
					
						
							|  |  |  |                 "flex", | 
					
						
							|  |  |  |                 "w-full", | 
					
						
							|  |  |  |                 "border", | 
					
						
							|  |  |  |                 "border-gray-400", | 
					
						
							| 
									
										
										
										
											2021-09-30 21:42:31 +02:00
										 |  |  |                 "mb-1" | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |             ); | 
					
						
							|  |  |  |             wrapper.appendChild(input); | 
					
						
							|  |  |  |             wrapper.appendChild(label); | 
					
						
							| 
									
										
										
										
											2021-09-30 21:41:21 +02:00
										 |  |  |             formTag.appendChild(wrapper); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |             value.addCallbackAndRunD((selectedValues) => { | 
					
						
							|  |  |  |                 if (selectedValues.indexOf(i) >= 0) { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |                     input.checked = true; | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 if (input.checked) { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |                     wrapper.classList.remove("border-gray-400"); | 
					
						
							|  |  |  |                     wrapper.classList.add("border-black"); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |                     wrapper.classList.add("border-gray-400"); | 
					
						
							|  |  |  |                     wrapper.classList.remove("border-black"); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |             }); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |             input.onchange = () => { | 
					
						
							|  |  |  |                 // Index = index in the list of already checked items
 | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |                 const index = value.data.indexOf(i); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 if (input.checked && index < 0) { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |                     value.data.push(i); | 
					
						
							|  |  |  |                     value.ping(); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } else if (index >= 0) { | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |                     value.data.splice(index, 1); | 
					
						
							|  |  |  |                     value.ping(); | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2021-07-26 18:00:21 +02:00
										 |  |  |             }; | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-06-11 22:51:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-09-30 21:41:21 +02:00
										 |  |  |         return formTag; | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | } |