| 
									
										
										
										
											2020-10-02 19:00:24 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * A single opening hours range, shown on top of the OH-picker table | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  | import Svg from "../../Svg" | 
					
						
							|  |  |  | import { Utils } from "../../Utils" | 
					
						
							|  |  |  | import Combine from "../Base/Combine" | 
					
						
							|  |  |  | import { OH, OpeningHour } from "./OpeningHours" | 
					
						
							|  |  |  | import BaseUIElement from "../BaseUIElement" | 
					
						
							|  |  |  | import { FixedUiElement } from "../Base/FixedUiElement" | 
					
						
							| 
									
										
										
										
											2021-01-02 16:04:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-16 14:23:53 +02:00
										 |  |  | export default class OpeningHoursRange extends BaseUIElement { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     private _oh: OpeningHour | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |     private readonly _onDelete: () => void | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-16 14:23:53 +02:00
										 |  |  |     constructor(oh: OpeningHour, onDelete: () => void) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         super() | 
					
						
							|  |  |  |         this._oh = oh | 
					
						
							|  |  |  |         this._onDelete = onDelete | 
					
						
							|  |  |  |         this.SetClass("oh-timerange") | 
					
						
							| 
									
										
										
										
											2021-06-16 14:23:53 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-16 14:23:53 +02:00
										 |  |  |     InnerConstructElement(): HTMLElement { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         const height = this.getHeight() | 
					
						
							|  |  |  |         const oh = this._oh | 
					
						
							|  |  |  |         const startTime = new FixedUiElement( | 
					
						
							|  |  |  |             Utils.TwoDigits(oh.startHour) + ":" + Utils.TwoDigits(oh.startMinutes) | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  |         const endTime = new FixedUiElement( | 
					
						
							|  |  |  |             Utils.TwoDigits(oh.endHour) + ":" + Utils.TwoDigits(oh.endMinutes) | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         const deleteRange = Svg.delete_icon_ui() | 
					
						
							| 
									
										
										
										
											2023-05-04 23:32:37 +02:00
										 |  |  |             .SetClass("rounded-full w-6 h-6 block bg-black pointer-events-auto  ") | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             .onClick(() => { | 
					
						
							|  |  |  |                 this._onDelete() | 
					
						
							|  |  |  |             }) | 
					
						
							| 
									
										
										
										
											2020-10-08 19:03:00 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         let content: BaseUIElement | 
					
						
							| 
									
										
										
										
											2020-10-08 19:03:00 +02:00
										 |  |  |         if (height > 2) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             content = new Combine([startTime, deleteRange, endTime]).SetClass( | 
					
						
							|  |  |  |                 "flex flex-col h-full justify-between" | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2021-06-16 16:39:48 +02:00
										 |  |  |         } else { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             content = new Combine([deleteRange]) | 
					
						
							|  |  |  |                 .SetClass("flex flex-col h-full") | 
					
						
							|  |  |  |                 .SetStyle("flex-content: center; overflow-x: unset;") | 
					
						
							| 
									
										
										
										
											2020-10-08 19:03:00 +02:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         const el = new Combine([content]).ConstructElement() | 
					
						
							| 
									
										
										
										
											2021-06-16 14:23:53 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         el.style.top = `${(100 * OH.startTime(oh)) / 24}%` | 
					
						
							|  |  |  |         el.style.height = `${(100 * this.getHeight()) / 24}%` | 
					
						
							|  |  |  |         return el | 
					
						
							| 
									
										
										
										
											2020-10-02 19:00:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  |     private getHeight(): number { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         const oh = this._oh | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         let endhour = oh.endHour | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  |         if (oh.endHour == 0 && oh.endMinutes == 0) { | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |             endhour = 24 | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2022-09-08 21:40:48 +02:00
										 |  |  |         return endhour - oh.startHour + (oh.endMinutes - oh.startMinutes) / 60 | 
					
						
							| 
									
										
										
										
											2020-10-04 01:04:46 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-09-22 19:53:47 +02:00
										 |  |  | } |