| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import { InputElement } from "./InputElement" | 
					
						
							|  |  |  | import { UIEventSource } from "../../Logic/UIEventSource" | 
					
						
							|  |  |  | import { Utils } from "../../Utils" | 
					
						
							|  |  |  | import BaseUIElement from "../BaseUIElement" | 
					
						
							|  |  |  | import InputElementMap from "./InputElementMap" | 
					
						
							| 
									
										
										
										
											2022-09-17 03:24:01 +02:00
										 |  |  | import Translations from "../i18n/Translations"; | 
					
						
							| 
									
										
										
										
											2022-03-31 03:30:20 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-08 03:14:55 +02:00
										 |  |  | export class CheckBox extends InputElementMap<number[], boolean> { | 
					
						
							| 
									
										
										
										
											2022-09-17 03:24:01 +02:00
										 |  |  |     constructor(el: (BaseUIElement | string), defaultValue?: boolean) { | 
					
						
							| 
									
										
										
										
											2022-03-31 03:30:20 +02:00
										 |  |  |         super( | 
					
						
							| 
									
										
										
										
											2022-09-27 18:48:02 +02:00
										 |  |  |             new CheckBoxes([Translations.W(el)]), | 
					
						
							| 
									
										
										
										
											2022-03-31 03:30:20 +02:00
										 |  |  |             (x0, x1) => x0 === x1, | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             (t) => t.length > 0, | 
					
						
							|  |  |  |             (x) => (x ? [0] : []) | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |         if (defaultValue !== undefined) { | 
					
						
							| 
									
										
										
										
											2022-03-31 03:30:20 +02:00
										 |  |  |             this.GetValue().setData(defaultValue) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-09-09 22:17:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2022-06-03 01:33:41 +02:00
										 |  |  |  * A list of individual checkboxes | 
					
						
							|  |  |  |  * The value will contain the indexes of the selected checkboxes | 
					
						
							| 
									
										
										
										
											2020-09-09 22:17:46 +02:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-10-02 19:00:24 +02:00
										 |  |  | export default class CheckBoxes extends InputElement<number[]> { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     constructor(elements: BaseUIElement[], value = new UIEventSource<number[]>([])) { | 
					
						
							|  |  |  |         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 { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +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[]> { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +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 { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         const formTag = document.createElement("form") | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +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++) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +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
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             const label = document.createElement("label") | 
					
						
							|  |  |  |             label.htmlFor = input.id | 
					
						
							|  |  |  |             label.appendChild(inputI.ConstructElement()) | 
					
						
							|  |  |  |             label.classList.add("block", "w-full", "p-2", "cursor-pointer", "bg-red") | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             const wrapper = document.createElement("div") | 
					
						
							|  |  |  |             wrapper.classList.add("wrapper", "flex", "w-full", "border", "border-gray-400", "mb-1") | 
					
						
							|  |  |  |             wrapper.appendChild(input) | 
					
						
							|  |  |  |             wrapper.appendChild(label) | 
					
						
							|  |  |  |             formTag.appendChild(wrapper) | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |             value.addCallbackAndRunD((selectedValues) => { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                 input.checked = selectedValues.indexOf(i) >= 0 | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 if (input.checked) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                     wrapper.classList.remove("border-gray-400") | 
					
						
							|  |  |  |                     wrapper.classList.add("border-black") | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } else { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                     wrapper.classList.add("border-gray-400") | 
					
						
							|  |  |  |                     wrapper.classList.remove("border-black") | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +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
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                 const index = value.data.indexOf(i) | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 if (input.checked && index < 0) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                     value.data.push(i) | 
					
						
							|  |  |  |                     value.ping() | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } else if (index >= 0) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |                     value.data.splice(index, 1) | 
					
						
							|  |  |  |                     value.ping() | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-06-11 22:51:45 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         return formTag | 
					
						
							| 
									
										
										
										
											2021-07-26 17:59:15 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-07-26 17:45:54 +02:00
										 |  |  | } |