| 
									
										
										
										
											2022-12-01 13:07:23 +01:00
										 |  |  | import Component from "../components/component.js"; | 
					
						
							| 
									
										
										
										
											2020-01-15 21:36:01 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | class BasicWidget extends Component { | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |     constructor() { | 
					
						
							|  |  |  |         super(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.attrs = { | 
					
						
							|  |  |  |             style: '' | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         this.classes = []; | 
					
						
							| 
									
										
										
										
											2022-09-18 14:57:44 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         this.children = []; | 
					
						
							|  |  |  |         this.childPositionCounter = 10; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     child(...components) { | 
					
						
							|  |  |  |         if (!components) { | 
					
						
							|  |  |  |             return this; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         super.child(...components); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for (const component of components) { | 
					
						
							|  |  |  |             if (component.position === undefined) { | 
					
						
							|  |  |  |                 component.position = this.childPositionCounter; | 
					
						
							|  |  |  |                 this.childPositionCounter += 10; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.children.sort((a, b) => a.position - b.position < 0 ? -1 : 1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return this; | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     id(id) { | 
					
						
							|  |  |  |         this.attrs.id = id; | 
					
						
							|  |  |  |         return this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class(className) { | 
					
						
							|  |  |  |         this.classes.push(className); | 
					
						
							|  |  |  |         return this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     css(name, value) { | 
					
						
							|  |  |  |         this.attrs.style += `${name}: ${value};`; | 
					
						
							|  |  |  |         return this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-16 22:57:48 +02:00
										 |  |  |     contentSized() { | 
					
						
							| 
									
										
										
										
											2021-06-13 22:55:31 +02:00
										 |  |  |         this.css("contain", "none"); | 
					
						
							| 
									
										
										
										
											2021-06-05 22:07:15 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-16 22:57:48 +02:00
										 |  |  |         return this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |     collapsible() { | 
					
						
							|  |  |  |         this.css('min-height', '0'); | 
					
						
							| 
									
										
										
										
											2021-06-13 22:55:31 +02:00
										 |  |  |         this.css('min-width', '0'); | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |         return this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 12:45:32 +02:00
										 |  |  |     filling() { | 
					
						
							|  |  |  |         this.css('flex-grow', '1'); | 
					
						
							|  |  |  |         return this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |     cssBlock(block) { | 
					
						
							|  |  |  |         this.cssEl = block; | 
					
						
							|  |  |  |         return this; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-11 21:19:56 +01:00
										 |  |  |     render() { | 
					
						
							| 
									
										
										
										
											2020-06-26 22:17:39 +02:00
										 |  |  |         this.doRender(); | 
					
						
							| 
									
										
										
										
											2020-01-20 22:35:52 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-12-11 13:20:37 +01:00
										 |  |  |         this.$widget.attr('data-component-id', this.componentId); | 
					
						
							| 
									
										
										
										
											2020-06-26 22:17:39 +02:00
										 |  |  |         this.$widget.addClass('component') | 
					
						
							| 
									
										
										
										
											2020-02-16 10:50:48 +01:00
										 |  |  |             .prop('component', this); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-14 23:29:37 +02:00
										 |  |  |         if (!this.isEnabled()) { | 
					
						
							|  |  |  |             this.toggleInt(false); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-02-08 21:54:39 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |         if (this.cssEl) { | 
					
						
							|  |  |  |             const css = this.cssEl.trim().startsWith('<style>') ? this.cssEl : `<style>${this.cssEl}</style>`; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-26 22:17:39 +02:00
										 |  |  |             this.$widget.append(css); | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for (const key in this.attrs) { | 
					
						
							| 
									
										
										
										
											2020-04-07 22:53:03 +02:00
										 |  |  |             if (key === 'style') { | 
					
						
							| 
									
										
										
										
											2020-04-08 10:19:15 +02:00
										 |  |  |                 if (this.attrs[key]) { | 
					
						
							| 
									
										
										
										
											2020-06-26 22:17:39 +02:00
										 |  |  |                     let style = this.$widget.attr('style'); | 
					
						
							| 
									
										
										
										
											2020-04-25 11:09:07 +02:00
										 |  |  |                     style = style ? `${style}; ${this.attrs[key]}` : this.attrs[key]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-26 22:17:39 +02:00
										 |  |  |                     this.$widget.attr(key, style); | 
					
						
							| 
									
										
										
										
											2020-04-08 10:19:15 +02:00
										 |  |  |                 } | 
					
						
							| 
									
										
										
										
											2020-04-07 22:53:03 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |             else { | 
					
						
							| 
									
										
										
										
											2020-06-26 22:17:39 +02:00
										 |  |  |                 this.$widget.attr(key, this.attrs[key]); | 
					
						
							| 
									
										
										
										
											2020-04-07 22:53:03 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         for (const className of this.classes) { | 
					
						
							| 
									
										
										
										
											2020-06-26 22:17:39 +02:00
										 |  |  |             this.$widget.addClass(className); | 
					
						
							| 
									
										
										
										
											2020-03-01 18:57:13 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-26 22:17:39 +02:00
										 |  |  |         return this.$widget; | 
					
						
							| 
									
										
										
										
											2020-01-11 21:19:56 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-08 21:54:39 +01:00
										 |  |  |     isEnabled() { | 
					
						
							|  |  |  |         return true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-11 21:19:56 +01:00
										 |  |  |     /** | 
					
						
							|  |  |  |      * for overriding | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-01-19 09:02:18 +01:00
										 |  |  |     doRender() {} | 
					
						
							| 
									
										
										
										
											2020-01-11 21:19:56 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 22:17:07 +01:00
										 |  |  |     toggleInt(show) { | 
					
						
							|  |  |  |         this.$widget.toggleClass('hidden-int', !show); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-30 17:45:59 +02:00
										 |  |  |     isHiddenInt() { | 
					
						
							|  |  |  |         return this.$widget.hasClass('hidden-int'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 22:17:07 +01:00
										 |  |  |     toggleExt(show) { | 
					
						
							|  |  |  |         this.$widget.toggleClass('hidden-ext', !show); | 
					
						
							| 
									
										
										
										
											2020-01-14 20:27:40 +01:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-05-30 17:45:59 +02:00
										 |  |  |     isHiddenExt() { | 
					
						
							|  |  |  |         return this.$widget.hasClass('hidden-ext'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     canBeShown() { | 
					
						
							|  |  |  |         return !this.isHiddenInt() && !this.isHiddenExt(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-04 22:46:17 +01:00
										 |  |  |     isVisible() { | 
					
						
							|  |  |  |         return this.$widget.is(":visible"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-16 21:16:09 +01:00
										 |  |  |     getPosition() { | 
					
						
							|  |  |  |         return this.position; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-19 21:12:53 +01:00
										 |  |  |     remove() { | 
					
						
							|  |  |  |         if (this.$widget) { | 
					
						
							|  |  |  |             this.$widget.remove(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-07-03 23:10:13 +02:00
										 |  |  |     getClosestNtxId() { | 
					
						
							| 
									
										
										
										
											2021-05-24 21:05:44 +02:00
										 |  |  |         if (this.$widget) { | 
					
						
							|  |  |  |             return this.$widget.closest("[data-ntx-id]").attr("data-ntx-id"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else { | 
					
						
							|  |  |  |             return null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-11 21:19:56 +01:00
										 |  |  |     cleanup() {} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-12 12:45:32 +02:00
										 |  |  | export default BasicWidget; |