gridstack 10.1.2 → 10.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (142) hide show
  1. package/angular/angular.json +3 -0
  2. package/angular/package.json +1 -1
  3. package/dist/angular/esm2020/gridstack-angular.mjs +4 -4
  4. package/dist/angular/esm2020/lib/base-widget.mjs +30 -30
  5. package/dist/angular/esm2020/lib/gridstack-item.component.mjs +52 -52
  6. package/dist/angular/esm2020/lib/gridstack.component.mjs +266 -264
  7. package/dist/angular/esm2020/lib/gridstack.module.mjs +39 -39
  8. package/dist/angular/esm2020/public-api.mjs +7 -7
  9. package/dist/angular/fesm2015/gridstack-angular.mjs +368 -366
  10. package/dist/angular/fesm2015/gridstack-angular.mjs.map +1 -1
  11. package/dist/angular/fesm2020/gridstack-angular.mjs +363 -361
  12. package/dist/angular/fesm2020/gridstack-angular.mjs.map +1 -1
  13. package/dist/angular/index.d.ts +5 -5
  14. package/dist/angular/lib/base-widget.d.ts +16 -16
  15. package/dist/angular/lib/gridstack-item.component.d.ts +37 -37
  16. package/dist/angular/lib/gridstack.component.d.ts +129 -129
  17. package/dist/angular/lib/gridstack.module.d.ts +10 -10
  18. package/dist/angular/public-api.d.ts +4 -4
  19. package/dist/dd-base-impl.d.ts +1 -1
  20. package/dist/dd-base-impl.js +1 -1
  21. package/dist/dd-base-impl.js.map +1 -1
  22. package/dist/dd-draggable.d.ts +4 -4
  23. package/dist/dd-draggable.js +63 -19
  24. package/dist/dd-draggable.js.map +1 -1
  25. package/dist/dd-droppable.d.ts +1 -1
  26. package/dist/dd-droppable.js +1 -1
  27. package/dist/dd-droppable.js.map +1 -1
  28. package/dist/dd-element.d.ts +1 -1
  29. package/dist/dd-element.js +1 -1
  30. package/dist/dd-element.js.map +1 -1
  31. package/dist/dd-gridstack.d.ts +1 -1
  32. package/dist/dd-gridstack.js +2 -2
  33. package/dist/dd-gridstack.js.map +1 -1
  34. package/dist/dd-manager.d.ts +1 -1
  35. package/dist/dd-manager.js +1 -1
  36. package/dist/dd-manager.js.map +1 -1
  37. package/dist/dd-resizable-handle.d.ts +4 -3
  38. package/dist/dd-resizable-handle.js +12 -1
  39. package/dist/dd-resizable-handle.js.map +1 -1
  40. package/dist/dd-resizable.d.ts +1 -1
  41. package/dist/dd-resizable.js +1 -1
  42. package/dist/dd-resizable.js.map +1 -1
  43. package/dist/dd-touch.d.ts +1 -1
  44. package/dist/dd-touch.js +1 -1
  45. package/dist/dd-touch.js.map +1 -1
  46. package/dist/es5/dd-base-impl.d.ts +1 -1
  47. package/dist/es5/dd-base-impl.js +1 -1
  48. package/dist/es5/dd-base-impl.js.map +1 -1
  49. package/dist/es5/dd-draggable.d.ts +4 -4
  50. package/dist/es5/dd-draggable.js +78 -21
  51. package/dist/es5/dd-draggable.js.map +1 -1
  52. package/dist/es5/dd-droppable.d.ts +1 -1
  53. package/dist/es5/dd-droppable.js +1 -1
  54. package/dist/es5/dd-droppable.js.map +1 -1
  55. package/dist/es5/dd-element.d.ts +1 -1
  56. package/dist/es5/dd-element.js +1 -1
  57. package/dist/es5/dd-element.js.map +1 -1
  58. package/dist/es5/dd-gridstack.d.ts +1 -1
  59. package/dist/es5/dd-gridstack.js +2 -2
  60. package/dist/es5/dd-gridstack.js.map +1 -1
  61. package/dist/es5/dd-manager.d.ts +1 -1
  62. package/dist/es5/dd-manager.js +1 -1
  63. package/dist/es5/dd-manager.js.map +1 -1
  64. package/dist/es5/dd-resizable-handle.d.ts +4 -3
  65. package/dist/es5/dd-resizable-handle.js +13 -1
  66. package/dist/es5/dd-resizable-handle.js.map +1 -1
  67. package/dist/es5/dd-resizable.d.ts +1 -1
  68. package/dist/es5/dd-resizable.js +1 -1
  69. package/dist/es5/dd-resizable.js.map +1 -1
  70. package/dist/es5/dd-touch.d.ts +1 -1
  71. package/dist/es5/dd-touch.js +1 -1
  72. package/dist/es5/dd-touch.js.map +1 -1
  73. package/dist/es5/gridstack-all.js +1 -1
  74. package/dist/es5/gridstack-all.js.LICENSE.txt +1 -1
  75. package/dist/es5/gridstack-all.js.map +1 -1
  76. package/dist/es5/gridstack-engine.d.ts +1 -1
  77. package/dist/es5/gridstack-engine.js +1 -1
  78. package/dist/es5/gridstack-engine.js.map +1 -1
  79. package/dist/es5/gridstack-poly.js +1 -1
  80. package/dist/es5/gridstack.d.ts +9 -3
  81. package/dist/es5/gridstack.js +61 -28
  82. package/dist/es5/gridstack.js.map +1 -1
  83. package/dist/es5/types.d.ts +8 -8
  84. package/dist/es5/types.js +1 -1
  85. package/dist/es5/types.js.map +1 -1
  86. package/dist/es5/utils.d.ts +6 -1
  87. package/dist/es5/utils.js +26 -10
  88. package/dist/es5/utils.js.map +1 -1
  89. package/dist/gridstack-all.js +1 -1
  90. package/dist/gridstack-all.js.LICENSE.txt +1 -1
  91. package/dist/gridstack-all.js.map +1 -1
  92. package/dist/gridstack-engine.d.ts +1 -1
  93. package/dist/gridstack-engine.js +1 -1
  94. package/dist/gridstack-engine.js.map +1 -1
  95. package/dist/gridstack.css +1 -1
  96. package/dist/gridstack.d.ts +9 -3
  97. package/dist/gridstack.js +56 -26
  98. package/dist/gridstack.js.map +1 -1
  99. package/dist/types.d.ts +8 -8
  100. package/dist/types.js +1 -1
  101. package/dist/types.js.map +1 -1
  102. package/dist/utils.d.ts +6 -1
  103. package/dist/utils.js +25 -10
  104. package/dist/utils.js.map +1 -1
  105. package/doc/CHANGES.md +15 -0
  106. package/doc/README.md +7 -1
  107. package/package.json +3 -2
  108. package/angular/.vscode/extensions.json +0 -4
  109. package/angular/.vscode/launch.json +0 -20
  110. package/angular/.vscode/tasks.json +0 -42
  111. package/angular/projects/demo/.browserslistrc +0 -16
  112. package/angular/projects/demo/src/app/app.component.css +0 -11
  113. package/angular/projects/demo/src/app/app.component.html +0 -110
  114. package/angular/projects/demo/src/app/app.component.spec.ts +0 -25
  115. package/angular/projects/demo/src/app/app.component.ts +0 -223
  116. package/angular/projects/demo/src/app/app.module.ts +0 -39
  117. package/angular/projects/demo/src/app/dummy.component.ts +0 -34
  118. package/angular/projects/demo/src/app/ngFor.ts +0 -131
  119. package/angular/projects/demo/src/app/ngFor_cmd.ts +0 -106
  120. package/angular/projects/demo/src/app/simple.ts +0 -46
  121. package/angular/projects/demo/src/assets/.gitkeep +0 -0
  122. package/angular/projects/demo/src/environments/environment.ts +0 -16
  123. package/angular/projects/demo/src/favicon.ico +0 -0
  124. package/angular/projects/demo/src/index.html +0 -13
  125. package/angular/projects/demo/src/main.ts +0 -12
  126. package/angular/projects/demo/src/polyfills.ts +0 -53
  127. package/angular/projects/demo/src/styles.css +0 -41
  128. package/angular/projects/demo/src/test.ts +0 -26
  129. package/angular/projects/demo/tsconfig.app.json +0 -15
  130. package/angular/projects/demo/tsconfig.spec.json +0 -18
  131. package/angular/projects/lib/src/lib/base-widget.ts +0 -28
  132. package/angular/projects/lib/src/lib/gridstack-item.component.ts +0 -78
  133. package/angular/projects/lib/src/lib/gridstack.component.ts +0 -287
  134. package/angular/projects/lib/src/lib/gridstack.module.ts +0 -32
  135. package/angular/projects/lib/src/public-api.ts +0 -8
  136. package/angular/projects/lib/src/test.ts +0 -27
  137. package/dist/angular/src/base-widget.ts +0 -28
  138. package/dist/angular/src/gridstack-item.component.ts +0 -78
  139. package/dist/angular/src/gridstack.component.ts +0 -287
  140. package/dist/angular/src/gridstack.module.ts +0 -32
  141. package/dist/src/gridstack-extra.scss +0 -25
  142. package/dist/src/gridstack.scss +0 -157
@@ -1,136 +1,136 @@
1
- /**
2
- * gridstack.component.ts 10.1.2
3
- * Copyright (c) 2022 Alain Dumesny - see GridStack root license
4
- */
5
- import { Component, ContentChildren, EventEmitter, Input, Output, ViewChild, ViewContainerRef, reflectComponentType } from '@angular/core';
6
- import { Subject } from 'rxjs';
7
- import { takeUntil } from 'rxjs/operators';
8
- import { GridStack } from 'gridstack';
9
- import { GridstackItemComponent } from './gridstack-item.component';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "@angular/common";
12
- /**
13
- * HTML Component Wrapper for gridstack, in combination with GridstackItemComponent for the items
14
- */
15
- export class GridstackComponent {
16
- constructor(
17
- // private readonly zone: NgZone,
18
- // private readonly cd: ChangeDetectorRef,
19
- elementRef) {
20
- this.elementRef = elementRef;
21
- /** individual list of GridStackEvent callbacks handlers as output
22
- * otherwise use this.grid.on('name1 name2 name3', callback) to handle multiple at once
23
- * see https://github.com/gridstack/gridstack.js/blob/master/demo/events.js#L4
24
- *
25
- * Note: camel casing and 'CB' added at the end to prevent @angular-eslint/no-output-native
26
- * eg: 'change' would trigger the raw CustomEvent so use different name.
27
- */
28
- this.addedCB = new EventEmitter();
29
- this.changeCB = new EventEmitter();
30
- this.disableCB = new EventEmitter();
31
- this.dragCB = new EventEmitter();
32
- this.dragStartCB = new EventEmitter();
33
- this.dragStopCB = new EventEmitter();
34
- this.droppedCB = new EventEmitter();
35
- this.enableCB = new EventEmitter();
36
- this.removedCB = new EventEmitter();
37
- this.resizeCB = new EventEmitter();
38
- this.resizeStartCB = new EventEmitter();
39
- this.resizeStopCB = new EventEmitter();
40
- this.ngUnsubscribe = new Subject();
41
- this.el._gridComp = this;
42
- }
43
- /** initial options for creation of the grid */
44
- set options(val) { this._options = val; }
45
- /** return the current running options */
46
- get options() { return this._grid?.opts || this._options || {}; }
47
- /** return the native element that contains grid specific fields as well */
48
- get el() { return this.elementRef.nativeElement; }
49
- /** return the GridStack class */
50
- get grid() { return this._grid; }
51
- /** add a list of ng Component to be mapped to selector */
52
- static addComponentToSelectorType(typeList) {
53
- typeList.forEach(type => GridstackComponent.selectorToType[GridstackComponent.getSelector(type)] = type);
54
- }
55
- /** return the ng Component selector */
56
- static getSelector(type) {
57
- return reflectComponentType(type).selector;
58
- }
59
- ngOnInit() {
60
- // init ourself before any template children are created since we track them below anyway - no need to double create+update widgets
61
- this.loaded = !!this.options?.children?.length;
62
- this._grid = GridStack.init(this._options, this.el);
63
- delete this._options; // GS has it now
64
- this.checkEmpty();
65
- }
66
- /** wait until after all DOM is ready to init gridstack children (after angular ngFor and sub-components run first) */
67
- ngAfterContentInit() {
68
- // track whenever the children list changes and update the layout...
69
- this.gridstackItems?.changes
70
- .pipe(takeUntil(this.ngUnsubscribe))
71
- .subscribe(() => this.updateAll());
72
- // ...and do this once at least unless we loaded children already
73
- if (!this.loaded)
74
- this.updateAll();
75
- this.hookEvents(this.grid);
76
- }
77
- ngOnDestroy() {
78
- delete this.ref;
79
- this.ngUnsubscribe.next();
80
- this.ngUnsubscribe.complete();
81
- this.grid?.destroy();
82
- delete this._grid;
83
- delete this.el._gridComp;
84
- }
85
- /**
86
- * called when the TEMPLATE list of items changes - get a list of nodes and
87
- * update the layout accordingly (which will take care of adding/removing items changed by Angular)
88
- */
89
- updateAll() {
90
- if (!this.grid)
91
- return;
92
- const layout = [];
93
- this.gridstackItems?.forEach(item => {
94
- layout.push(item.options);
95
- item.clearOptions();
96
- });
97
- this.grid.load(layout); // efficient that does diffs only
98
- }
99
- /** check if the grid is empty, if so show alternative content */
100
- checkEmpty() {
101
- if (!this.grid)
102
- return;
103
- const isEmpty = !this.grid.engine.nodes.length;
104
- if (isEmpty === this.isEmpty)
105
- return;
106
- this.isEmpty = isEmpty;
107
- // this.cd.detectChanges();
108
- }
109
- /** get all known events as easy to use Outputs for convenience */
110
- hookEvents(grid) {
111
- if (!grid)
112
- return;
113
- grid
114
- .on('added', (event, nodes) => { this.checkEmpty(); this.addedCB.emit({ event, nodes }); })
115
- .on('change', (event, nodes) => this.changeCB.emit({ event, nodes }))
116
- .on('disable', (event) => this.disableCB.emit({ event }))
117
- .on('drag', (event, el) => this.dragCB.emit({ event, el }))
118
- .on('dragstart', (event, el) => this.dragStartCB.emit({ event, el }))
119
- .on('dragstop', (event, el) => this.dragStopCB.emit({ event, el }))
120
- .on('dropped', (event, previousNode, newNode) => this.droppedCB.emit({ event, previousNode, newNode }))
121
- .on('enable', (event) => this.enableCB.emit({ event }))
122
- .on('removed', (event, nodes) => { this.checkEmpty(); this.removedCB.emit({ event, nodes }); })
123
- .on('resize', (event, el) => this.resizeCB.emit({ event, el }))
124
- .on('resizestart', (event, el) => this.resizeStartCB.emit({ event, el }))
125
- .on('resizestop', (event, el) => this.resizeStopCB.emit({ event, el }));
126
- }
127
- }
128
- /**
129
- * stores the selector -> Type mapping, so we can create items dynamically from a string.
130
- * Unfortunately Ng doesn't provide public access to that mapping.
131
- */
132
- GridstackComponent.selectorToType = {};
133
- GridstackComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GridstackComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
1
+ /**
2
+ * gridstack.component.ts 10.2.1
3
+ * Copyright (c) 2022 Alain Dumesny - see GridStack root license
4
+ */
5
+ import { Component, ContentChildren, EventEmitter, Input, Output, ViewChild, ViewContainerRef, reflectComponentType } from '@angular/core';
6
+ import { Subject } from 'rxjs';
7
+ import { takeUntil } from 'rxjs/operators';
8
+ import { GridStack } from 'gridstack';
9
+ import { GridstackItemComponent } from './gridstack-item.component';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "@angular/common";
12
+ /**
13
+ * HTML Component Wrapper for gridstack, in combination with GridstackItemComponent for the items
14
+ */
15
+ export class GridstackComponent {
16
+ constructor(
17
+ // private readonly zone: NgZone,
18
+ // private readonly cd: ChangeDetectorRef,
19
+ elementRef) {
20
+ this.elementRef = elementRef;
21
+ /** individual list of GridStackEvent callbacks handlers as output
22
+ * otherwise use this.grid.on('name1 name2 name3', callback) to handle multiple at once
23
+ * see https://github.com/gridstack/gridstack.js/blob/master/demo/events.js#L4
24
+ *
25
+ * Note: camel casing and 'CB' added at the end to prevent @angular-eslint/no-output-native
26
+ * eg: 'change' would trigger the raw CustomEvent so use different name.
27
+ */
28
+ this.addedCB = new EventEmitter();
29
+ this.changeCB = new EventEmitter();
30
+ this.disableCB = new EventEmitter();
31
+ this.dragCB = new EventEmitter();
32
+ this.dragStartCB = new EventEmitter();
33
+ this.dragStopCB = new EventEmitter();
34
+ this.droppedCB = new EventEmitter();
35
+ this.enableCB = new EventEmitter();
36
+ this.removedCB = new EventEmitter();
37
+ this.resizeCB = new EventEmitter();
38
+ this.resizeStartCB = new EventEmitter();
39
+ this.resizeStopCB = new EventEmitter();
40
+ this.ngUnsubscribe = new Subject();
41
+ this.el._gridComp = this;
42
+ }
43
+ /** initial options for creation of the grid */
44
+ set options(val) { this._options = val; }
45
+ /** return the current running options */
46
+ get options() { return this._grid?.opts || this._options || {}; }
47
+ /** return the native element that contains grid specific fields as well */
48
+ get el() { return this.elementRef.nativeElement; }
49
+ /** return the GridStack class */
50
+ get grid() { return this._grid; }
51
+ /** add a list of ng Component to be mapped to selector */
52
+ static addComponentToSelectorType(typeList) {
53
+ typeList.forEach(type => GridstackComponent.selectorToType[GridstackComponent.getSelector(type)] = type);
54
+ }
55
+ /** return the ng Component selector */
56
+ static getSelector(type) {
57
+ return reflectComponentType(type).selector;
58
+ }
59
+ ngOnInit() {
60
+ // init ourself before any template children are created since we track them below anyway - no need to double create+update widgets
61
+ this.loaded = !!this.options?.children?.length;
62
+ this._grid = GridStack.init(this._options, this.el);
63
+ delete this._options; // GS has it now
64
+ this.checkEmpty();
65
+ }
66
+ /** wait until after all DOM is ready to init gridstack children (after angular ngFor and sub-components run first) */
67
+ ngAfterContentInit() {
68
+ // track whenever the children list changes and update the layout...
69
+ this.gridstackItems?.changes
70
+ .pipe(takeUntil(this.ngUnsubscribe))
71
+ .subscribe(() => this.updateAll());
72
+ // ...and do this once at least unless we loaded children already
73
+ if (!this.loaded)
74
+ this.updateAll();
75
+ this.hookEvents(this.grid);
76
+ }
77
+ ngOnDestroy() {
78
+ delete this.ref;
79
+ this.ngUnsubscribe.next();
80
+ this.ngUnsubscribe.complete();
81
+ this.grid?.destroy();
82
+ delete this._grid;
83
+ delete this.el._gridComp;
84
+ }
85
+ /**
86
+ * called when the TEMPLATE list of items changes - get a list of nodes and
87
+ * update the layout accordingly (which will take care of adding/removing items changed by Angular)
88
+ */
89
+ updateAll() {
90
+ if (!this.grid)
91
+ return;
92
+ const layout = [];
93
+ this.gridstackItems?.forEach(item => {
94
+ layout.push(item.options);
95
+ item.clearOptions();
96
+ });
97
+ this.grid.load(layout); // efficient that does diffs only
98
+ }
99
+ /** check if the grid is empty, if so show alternative content */
100
+ checkEmpty() {
101
+ if (!this.grid)
102
+ return;
103
+ const isEmpty = !this.grid.engine.nodes.length;
104
+ if (isEmpty === this.isEmpty)
105
+ return;
106
+ this.isEmpty = isEmpty;
107
+ // this.cd.detectChanges();
108
+ }
109
+ /** get all known events as easy to use Outputs for convenience */
110
+ hookEvents(grid) {
111
+ if (!grid)
112
+ return;
113
+ grid
114
+ .on('added', (event, nodes) => { this.checkEmpty(); this.addedCB.emit({ event, nodes }); })
115
+ .on('change', (event, nodes) => this.changeCB.emit({ event, nodes }))
116
+ .on('disable', (event) => this.disableCB.emit({ event }))
117
+ .on('drag', (event, el) => this.dragCB.emit({ event, el }))
118
+ .on('dragstart', (event, el) => this.dragStartCB.emit({ event, el }))
119
+ .on('dragstop', (event, el) => this.dragStopCB.emit({ event, el }))
120
+ .on('dropped', (event, previousNode, newNode) => this.droppedCB.emit({ event, previousNode, newNode }))
121
+ .on('enable', (event) => this.enableCB.emit({ event }))
122
+ .on('removed', (event, nodes) => { this.checkEmpty(); this.removedCB.emit({ event, nodes }); })
123
+ .on('resize', (event, el) => this.resizeCB.emit({ event, el }))
124
+ .on('resizestart', (event, el) => this.resizeStartCB.emit({ event, el }))
125
+ .on('resizestop', (event, el) => this.resizeStopCB.emit({ event, el }));
126
+ }
127
+ }
128
+ /**
129
+ * stores the selector -> Type mapping, so we can create items dynamically from a string.
130
+ * Unfortunately Ng doesn't provide public access to that mapping.
131
+ */
132
+ GridstackComponent.selectorToType = {};
133
+ GridstackComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GridstackComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
134
134
  GridstackComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: GridstackComponent, selector: "gridstack", inputs: { options: "options", isEmpty: "isEmpty" }, outputs: { addedCB: "addedCB", changeCB: "changeCB", disableCB: "disableCB", dragCB: "dragCB", dragStartCB: "dragStartCB", dragStopCB: "dragStopCB", droppedCB: "droppedCB", enableCB: "enableCB", removedCB: "removedCB", resizeCB: "resizeCB", resizeStartCB: "resizeStartCB", resizeStopCB: "resizeStopCB" }, queries: [{ propertyName: "gridstackItems", predicate: GridstackItemComponent }], viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: `
135
135
  <!-- content to show when when grid is empty, like instructions on how to add widgets -->
136
136
  <ng-content select="[empty-content]" *ngIf="isEmpty"></ng-content>
@@ -138,9 +138,9 @@ GridstackComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", ver
138
138
  <ng-template #container></ng-template>
139
139
  <!-- where template items go -->
140
140
  <ng-content></ng-content>
141
- `, isInline: true, styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
142
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GridstackComponent, decorators: [{
143
- type: Component,
141
+ `, isInline: true, styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
142
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GridstackComponent, decorators: [{
143
+ type: Component,
144
144
  args: [{ selector: 'gridstack', template: `
145
145
  <!-- content to show when when grid is empty, like instructions on how to add widgets -->
146
146
  <ng-content select="[empty-content]" *ngIf="isEmpty"></ng-content>
@@ -148,131 +148,133 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
148
148
  <ng-template #container></ng-template>
149
149
  <!-- where template items go -->
150
150
  <ng-content></ng-content>
151
- `, styles: [":host{display:block}\n"] }]
152
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { gridstackItems: [{
153
- type: ContentChildren,
154
- args: [GridstackItemComponent]
155
- }], container: [{
156
- type: ViewChild,
157
- args: ['container', { read: ViewContainerRef, static: true }]
158
- }], options: [{
159
- type: Input
160
- }], isEmpty: [{
161
- type: Input
162
- }], addedCB: [{
163
- type: Output
164
- }], changeCB: [{
165
- type: Output
166
- }], disableCB: [{
167
- type: Output
168
- }], dragCB: [{
169
- type: Output
170
- }], dragStartCB: [{
171
- type: Output
172
- }], dragStopCB: [{
173
- type: Output
174
- }], droppedCB: [{
175
- type: Output
176
- }], enableCB: [{
177
- type: Output
178
- }], removedCB: [{
179
- type: Output
180
- }], resizeCB: [{
181
- type: Output
182
- }], resizeStartCB: [{
183
- type: Output
184
- }], resizeStopCB: [{
185
- type: Output
186
- }] } });
187
- /**
188
- * can be used when a new item needs to be created, which we do as a Angular component, or deleted (skip)
189
- **/
190
- export function gsCreateNgComponents(host, w, add, isGrid) {
191
- if (add) {
192
- //
193
- // create the component dynamically - see https://angular.io/docs/ts/latest/cookbook/dynamic-component-loader.html
194
- //
195
- if (!host)
196
- return;
197
- if (isGrid) {
198
- const container = host.parentElement?._gridItemComp?.container;
199
- // TODO: figure out how to create ng component inside regular Div. need to access app injectors...
200
- // if (!container) {
201
- // const hostElement: Element = host;
202
- // const environmentInjector: EnvironmentInjector;
203
- // grid = createComponent(GridstackComponent, {environmentInjector, hostElement})?.instance;
204
- // }
205
- const gridRef = container?.createComponent(GridstackComponent);
206
- const grid = gridRef?.instance;
207
- if (!grid)
208
- return;
209
- grid.ref = gridRef;
210
- grid.options = w;
211
- return grid.el;
212
- }
213
- else {
214
- const gridComp = host._gridComp;
215
- const gridItemRef = gridComp?.container?.createComponent(GridstackItemComponent);
216
- const gridItem = gridItemRef?.instance;
217
- if (!gridItem)
218
- return;
219
- gridItem.ref = gridItemRef;
220
- // IFF we're not a subGrid, define what type of component to create as child, OR you can do it GridstackItemComponent template, but this is more generic
221
- const selector = w.selector;
222
- const type = selector ? GridstackComponent.selectorToType[selector] : undefined;
223
- if (!w.subGridOpts && type) {
224
- const childWidget = gridItem.container?.createComponent(type)?.instance;
225
- if (typeof childWidget?.serialize === 'function' && typeof childWidget?.deserialize === 'function') {
226
- // proper BaseWidget subclass, save it and load additional data
227
- gridItem.childWidget = childWidget;
228
- childWidget.deserialize(w);
229
- }
230
- }
231
- return gridItem.el;
232
- }
233
- }
234
- else {
235
- //
236
- // REMOVE - have to call ComponentRef:destroy() for dynamic objects to correctly remove themselves
237
- // Note: this will destroy all children dynamic components as well: gridItem -> childWidget
238
- //
239
- const n = w;
240
- if (isGrid) {
241
- const grid = n.el?._gridComp;
242
- if (grid?.ref)
243
- grid.ref.destroy();
244
- else
245
- grid?.ngOnDestroy();
246
- }
247
- else {
248
- const gridItem = n.el?._gridItemComp;
249
- if (gridItem?.ref)
250
- gridItem.ref.destroy();
251
- else
252
- gridItem?.ngOnDestroy();
253
- }
254
- }
255
- return;
256
- }
257
- /**
258
- * called for each item in the grid - check if additional information needs to be saved.
259
- * Note: since this is options minus gridstack private members using Utils.removeInternalForSave(),
260
- * this typically doesn't need to do anything. However your custom Component @Input() are now supported
261
- * using BaseWidget.serialize()
262
- */
263
- export function gsSaveAdditionalNgInfo(n, w) {
264
- const gridItem = n.el?._gridItemComp;
265
- if (gridItem) {
266
- const input = gridItem.childWidget?.serialize();
267
- if (input) {
268
- w.input = input;
269
- }
270
- return;
271
- }
272
- // else check if Grid
273
- const grid = n.el?._gridComp;
274
- if (grid) {
275
- //.... save any custom data
276
- }
277
- }
278
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridstack.component.js","sourceRoot":"","sources":["../../../../angular/projects/lib/src/lib/gridstack.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * gridstack.component.ts 10.1.2\n * Copyright (c) 2022 Alain Dumesny - see GridStack root license\n */\n\nimport { AfterContentInit, Component, ContentChildren, ElementRef, EventEmitter, Input,\n  OnDestroy, OnInit, Output, QueryList, Type, ViewChild, ViewContainerRef, reflectComponentType, ComponentRef } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { GridHTMLElement, GridItemHTMLElement, GridStack, GridStackNode, GridStackOptions, GridStackWidget } from 'gridstack';\n\nimport { GridItemCompHTMLElement, GridstackItemComponent } from './gridstack-item.component';\nimport { BaseWidget } from './base-widget';\n\n/** events handlers emitters signature for different events */\nexport type eventCB = {event: Event};\nexport type elementCB = {event: Event, el: GridItemHTMLElement};\nexport type nodesCB = {event: Event, nodes: GridStackNode[]};\nexport type droppedCB = {event: Event, previousNode: GridStackNode, newNode: GridStackNode};\n\nexport type NgCompInputs = {[key: string]: any};\n\n/** extends to store Ng Component selector, instead/inAddition to content */\nexport interface NgGridStackWidget extends GridStackWidget {\n  selector?: string; // component type to create as content\n  input?: NgCompInputs; // serialized data for the component input fields\n}\nexport interface NgGridStackNode extends GridStackNode {\n  selector?: string; // component type to create as content\n}\nexport interface NgGridStackOptions extends GridStackOptions {\n  children?: NgGridStackWidget[];\n  subGridOpts?: NgGridStackOptions;\n}\n\n/** store element to Ng Class pointer back */\nexport interface GridCompHTMLElement extends GridHTMLElement {\n  _gridComp?: GridstackComponent;\n}\n\n/** selector string to runtime Type mapping */\nexport type SelectorToType = {[key: string]: Type<Object>};\n\n/**\n * HTML Component Wrapper for gridstack, in combination with GridstackItemComponent for the items\n */\n@Component({\n  selector: 'gridstack',\n  template: `\n    <!-- content to show when when grid is empty, like instructions on how to add widgets -->\n    <ng-content select=\"[empty-content]\" *ngIf=\"isEmpty\"></ng-content>\n    <!-- where dynamic items go -->\n    <ng-template #container></ng-template>\n    <!-- where template items go -->\n    <ng-content></ng-content>\n  `,\n  styles: [`\n    :host { display: block; }\n  `],\n  // changeDetection: ChangeDetectionStrategy.OnPush, // IFF you want to optimize and control when ChangeDetection needs to happen...\n})\nexport class GridstackComponent implements OnInit, AfterContentInit, OnDestroy {\n\n  /** track list of TEMPLATE grid items so we can sync between DOM and GS internals */\n  @ContentChildren(GridstackItemComponent) public gridstackItems?: QueryList<GridstackItemComponent>;\n  /** container to append items dynamically */\n  @ViewChild('container', { read: ViewContainerRef, static: true}) public container?: ViewContainerRef;\n\n  /** initial options for creation of the grid */\n  @Input() public set options(val: GridStackOptions) { this._options = val; }\n  /** return the current running options */\n  public get options(): GridStackOptions { return this._grid?.opts || this._options || {}; }\n\n  /** true while ng-content with 'no-item-content' should be shown when last item is removed from a grid */\n  @Input() public isEmpty?: boolean;\n\n  /** individual list of GridStackEvent callbacks handlers as output\n   * otherwise use this.grid.on('name1 name2 name3', callback) to handle multiple at once\n   * see https://github.com/gridstack/gridstack.js/blob/master/demo/events.js#L4\n   *\n   * Note: camel casing and 'CB' added at the end to prevent @angular-eslint/no-output-native\n   * eg: 'change' would trigger the raw CustomEvent so use different name.\n   */\n  @Output() public addedCB = new EventEmitter<nodesCB>();\n  @Output() public changeCB = new EventEmitter<nodesCB>();\n  @Output() public disableCB = new EventEmitter<eventCB>();\n  @Output() public dragCB = new EventEmitter<elementCB>();\n  @Output() public dragStartCB = new EventEmitter<elementCB>();\n  @Output() public dragStopCB = new EventEmitter<elementCB>();\n  @Output() public droppedCB = new EventEmitter<droppedCB>();\n  @Output() public enableCB = new EventEmitter<eventCB>();\n  @Output() public removedCB = new EventEmitter<nodesCB>();\n  @Output() public resizeCB = new EventEmitter<elementCB>();\n  @Output() public resizeStartCB = new EventEmitter<elementCB>();\n  @Output() public resizeStopCB = new EventEmitter<elementCB>();\n\n  /** return the native element that contains grid specific fields as well */\n  public get el(): GridCompHTMLElement { return this.elementRef.nativeElement; }\n\n  /** return the GridStack class */\n  public get grid(): GridStack | undefined { return this._grid; }\n\n  /** ComponentRef of ourself - used by dynamic object to correctly get removed */\n  public ref: ComponentRef<GridstackComponent> | undefined;\n\n  /**\n   * stores the selector -> Type mapping, so we can create items dynamically from a string.\n   * Unfortunately Ng doesn't provide public access to that mapping.\n   */\n  public static selectorToType: SelectorToType = {};\n  /** add a list of ng Component to be mapped to selector */\n  public static addComponentToSelectorType(typeList: Array<Type<Object>>) {\n    typeList.forEach(type => GridstackComponent.selectorToType[ GridstackComponent.getSelector(type) ] = type);\n  }\n  /** return the ng Component selector */\n  public static getSelector(type: Type<Object>): string {\n    return reflectComponentType(type)!.selector;\n  }\n\n  private _options?: GridStackOptions;\n  private _grid?: GridStack;\n  private loaded?: boolean;\n  private ngUnsubscribe: Subject<void> = new Subject();\n\n  constructor(\n    // private readonly zone: NgZone,\n    // private readonly cd: ChangeDetectorRef,\n    private readonly elementRef: ElementRef<GridCompHTMLElement>,\n  ) {\n    this.el._gridComp = this;\n  }\n\n  public ngOnInit(): void {\n    // init ourself before any template children are created since we track them below anyway - no need to double create+update widgets\n    this.loaded = !!this.options?.children?.length;\n    this._grid = GridStack.init(this._options, this.el);\n    delete this._options; // GS has it now\n\n    this.checkEmpty();\n  }\n\n  /** wait until after all DOM is ready to init gridstack children (after angular ngFor and sub-components run first) */\n  public ngAfterContentInit(): void {\n    // track whenever the children list changes and update the layout...\n    this.gridstackItems?.changes\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => this.updateAll());\n    // ...and do this once at least unless we loaded children already\n    if (!this.loaded) this.updateAll();\n    this.hookEvents(this.grid);\n  }\n\n  public ngOnDestroy(): void {\n    delete this.ref;\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n    this.grid?.destroy();\n    delete this._grid;\n    delete this.el._gridComp;\n  }\n\n  /**\n   * called when the TEMPLATE list of items changes - get a list of nodes and\n   * update the layout accordingly (which will take care of adding/removing items changed by Angular)\n   */\n  public updateAll() {\n    if (!this.grid) return;\n    const layout: GridStackWidget[] = [];\n    this.gridstackItems?.forEach(item => {\n      layout.push(item.options);\n      item.clearOptions();\n    });\n    this.grid.load(layout); // efficient that does diffs only\n  }\n\n  /** check if the grid is empty, if so show alternative content */\n  public checkEmpty() {\n    if (!this.grid) return;\n    const isEmpty = !this.grid.engine.nodes.length;\n    if (isEmpty === this.isEmpty) return;\n    this.isEmpty = isEmpty;\n    // this.cd.detectChanges();\n  }\n\n  /** get all known events as easy to use Outputs for convenience */\n  private hookEvents(grid?: GridStack) {\n    if (!grid) return;\n    grid\n    .on('added', (event: Event, nodes: GridStackNode[]) => { this.checkEmpty(); this.addedCB.emit({event, nodes}); })\n    .on('change', (event: Event, nodes: GridStackNode[]) => this.changeCB.emit({event, nodes}))\n    .on('disable', (event: Event) => this.disableCB.emit({event}))\n    .on('drag', (event: Event, el: GridItemHTMLElement) => this.dragCB.emit({event, el}))\n    .on('dragstart', (event: Event, el: GridItemHTMLElement) => this.dragStartCB.emit({event, el}))\n    .on('dragstop', (event: Event, el: GridItemHTMLElement) => this.dragStopCB.emit({event, el}))\n    .on('dropped', (event: Event, previousNode: GridStackNode, newNode: GridStackNode) => this.droppedCB.emit({event, previousNode, newNode}))\n    .on('enable', (event: Event) => this.enableCB.emit({event}))\n    .on('removed', (event: Event, nodes: GridStackNode[]) => { this.checkEmpty(); this.removedCB.emit({event, nodes}); })\n    .on('resize', (event: Event, el: GridItemHTMLElement) => this.resizeCB.emit({event, el}))\n    .on('resizestart', (event: Event, el: GridItemHTMLElement) => this.resizeStartCB.emit({event, el}))\n    .on('resizestop', (event: Event, el: GridItemHTMLElement) => this.resizeStopCB.emit({event, el}))\n  }\n}\n\n/**\n * can be used when a new item needs to be created, which we do as a Angular component, or deleted (skip)\n **/\nexport function gsCreateNgComponents(host: GridCompHTMLElement | HTMLElement, w: NgGridStackWidget | GridStackNode, add: boolean, isGrid: boolean): HTMLElement | undefined {\n  if (add) {\n    //\n    // create the component dynamically - see https://angular.io/docs/ts/latest/cookbook/dynamic-component-loader.html\n    //\n    if (!host) return;\n    if (isGrid) {\n      const container = (host.parentElement as GridItemCompHTMLElement)?._gridItemComp?.container;\n      // TODO: figure out how to create ng component inside regular Div. need to access app injectors...\n      // if (!container) {\n      //   const hostElement: Element = host;\n      //   const environmentInjector: EnvironmentInjector;\n      //   grid = createComponent(GridstackComponent, {environmentInjector, hostElement})?.instance;\n      // }\n      const gridRef = container?.createComponent(GridstackComponent);\n      const grid = gridRef?.instance;\n      if (!grid) return;\n      grid.ref = gridRef;\n      grid.options = w as GridStackOptions;\n      return grid.el;\n    } else {\n      const gridComp = (host as GridCompHTMLElement)._gridComp;\n      const gridItemRef = gridComp?.container?.createComponent(GridstackItemComponent);\n      const gridItem = gridItemRef?.instance;\n      if (!gridItem) return;\n      gridItem.ref = gridItemRef\n\n      // IFF we're not a subGrid, define what type of component to create as child, OR you can do it GridstackItemComponent template, but this is more generic\n      const selector = (w as NgGridStackWidget).selector;\n      const type = selector ? GridstackComponent.selectorToType[selector] : undefined;\n      if (!w.subGridOpts && type) {\n        const childWidget = gridItem.container?.createComponent(type)?.instance as BaseWidget;\n        if (typeof childWidget?.serialize === 'function' && typeof childWidget?.deserialize === 'function') {\n          // proper BaseWidget subclass, save it and load additional data\n          gridItem.childWidget = childWidget;\n          childWidget.deserialize(w);\n        }\n      }\n\n      return gridItem.el;\n    }\n  } else {\n    //\n    // REMOVE - have to call ComponentRef:destroy() for dynamic objects to correctly remove themselves\n    // Note: this will destroy all children dynamic components as well: gridItem -> childWidget\n    //\n    const n = w as GridStackNode;\n    if (isGrid) {\n      const grid = (n.el as GridCompHTMLElement)?._gridComp;\n      if (grid?.ref) grid.ref.destroy();\n      else grid?.ngOnDestroy();\n    } else {\n      const gridItem = (n.el as GridItemCompHTMLElement)?._gridItemComp;\n      if (gridItem?.ref) gridItem.ref.destroy();\n      else gridItem?.ngOnDestroy();\n    }\n  }\n  return;\n}\n\n/**\n * called for each item in the grid - check if additional information needs to be saved.\n * Note: since this is options minus gridstack private members using Utils.removeInternalForSave(),\n * this typically doesn't need to do anything. However your custom Component @Input() are now supported\n * using BaseWidget.serialize()\n */\nexport function gsSaveAdditionalNgInfo(n: NgGridStackNode, w: NgGridStackWidget) {\n  const gridItem = (n.el as GridItemCompHTMLElement)?._gridItemComp;\n  if (gridItem) {\n    const input = gridItem.childWidget?.serialize();\n    if (input) {\n      w.input = input;\n    }\n    return;\n  }\n  // else check if Grid\n  const grid = (n.el as GridCompHTMLElement)?._gridComp;\n  if (grid) {\n    //.... save any custom data\n  }\n}\n"]}
151
+ `, styles: [":host{display:block}\n"] }]
152
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { gridstackItems: [{
153
+ type: ContentChildren,
154
+ args: [GridstackItemComponent]
155
+ }], container: [{
156
+ type: ViewChild,
157
+ args: ['container', { read: ViewContainerRef, static: true }]
158
+ }], options: [{
159
+ type: Input
160
+ }], isEmpty: [{
161
+ type: Input
162
+ }], addedCB: [{
163
+ type: Output
164
+ }], changeCB: [{
165
+ type: Output
166
+ }], disableCB: [{
167
+ type: Output
168
+ }], dragCB: [{
169
+ type: Output
170
+ }], dragStartCB: [{
171
+ type: Output
172
+ }], dragStopCB: [{
173
+ type: Output
174
+ }], droppedCB: [{
175
+ type: Output
176
+ }], enableCB: [{
177
+ type: Output
178
+ }], removedCB: [{
179
+ type: Output
180
+ }], resizeCB: [{
181
+ type: Output
182
+ }], resizeStartCB: [{
183
+ type: Output
184
+ }], resizeStopCB: [{
185
+ type: Output
186
+ }] } });
187
+ /**
188
+ * can be used when a new item needs to be created, which we do as a Angular component, or deleted (skip)
189
+ **/
190
+ export function gsCreateNgComponents(host, w, add, isGrid) {
191
+ if (add) {
192
+ //
193
+ // create the component dynamically - see https://angular.io/docs/ts/latest/cookbook/dynamic-component-loader.html
194
+ //
195
+ if (!host)
196
+ return;
197
+ if (isGrid) {
198
+ const container = host.parentElement?._gridItemComp?.container;
199
+ // TODO: figure out how to create ng component inside regular Div. need to access app injectors...
200
+ // if (!container) {
201
+ // const hostElement: Element = host;
202
+ // const environmentInjector: EnvironmentInjector;
203
+ // grid = createComponent(GridstackComponent, {environmentInjector, hostElement})?.instance;
204
+ // }
205
+ const gridRef = container?.createComponent(GridstackComponent);
206
+ const grid = gridRef?.instance;
207
+ if (!grid)
208
+ return;
209
+ grid.ref = gridRef;
210
+ grid.options = w;
211
+ return grid.el;
212
+ }
213
+ else {
214
+ const gridComp = host._gridComp;
215
+ const gridItemRef = gridComp?.container?.createComponent(GridstackItemComponent);
216
+ const gridItem = gridItemRef?.instance;
217
+ if (!gridItem)
218
+ return;
219
+ gridItem.ref = gridItemRef;
220
+ // IFF we're not a subGrid, define what type of component to create as child, OR you can do it GridstackItemComponent template, but this is more generic
221
+ if (!w.subGridOpts) {
222
+ const selector = w.selector;
223
+ const type = selector ? GridstackComponent.selectorToType[selector] : undefined;
224
+ if (type) {
225
+ const childWidget = gridItem.container?.createComponent(type)?.instance;
226
+ // if proper BaseWidget subclass, save it and load additional data
227
+ if (childWidget && typeof childWidget.serialize === 'function' && typeof childWidget.deserialize === 'function') {
228
+ gridItem.childWidget = childWidget;
229
+ childWidget.deserialize(w);
230
+ }
231
+ }
232
+ }
233
+ return gridItem.el;
234
+ }
235
+ }
236
+ else {
237
+ //
238
+ // REMOVE - have to call ComponentRef:destroy() for dynamic objects to correctly remove themselves
239
+ // Note: this will destroy all children dynamic components as well: gridItem -> childWidget
240
+ //
241
+ const n = w;
242
+ if (isGrid) {
243
+ const grid = n.el?._gridComp;
244
+ if (grid?.ref)
245
+ grid.ref.destroy();
246
+ else
247
+ grid?.ngOnDestroy();
248
+ }
249
+ else {
250
+ const gridItem = n.el?._gridItemComp;
251
+ if (gridItem?.ref)
252
+ gridItem.ref.destroy();
253
+ else
254
+ gridItem?.ngOnDestroy();
255
+ }
256
+ }
257
+ return;
258
+ }
259
+ /**
260
+ * called for each item in the grid - check if additional information needs to be saved.
261
+ * Note: since this is options minus gridstack private members using Utils.removeInternalForSave(),
262
+ * this typically doesn't need to do anything. However your custom Component @Input() are now supported
263
+ * using BaseWidget.serialize()
264
+ */
265
+ export function gsSaveAdditionalNgInfo(n, w) {
266
+ const gridItem = n.el?._gridItemComp;
267
+ if (gridItem) {
268
+ const input = gridItem.childWidget?.serialize();
269
+ if (input) {
270
+ w.input = input;
271
+ }
272
+ return;
273
+ }
274
+ // else check if Grid
275
+ const grid = n.el?._gridComp;
276
+ if (grid) {
277
+ //.... save any custom data
278
+ }
279
+ }
280
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gridstack.component.js","sourceRoot":"","sources":["../../../../angular/projects/lib/src/lib/gridstack.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * gridstack.component.ts 10.2.1\n * Copyright (c) 2022 Alain Dumesny - see GridStack root license\n */\n\nimport { AfterContentInit, Component, ContentChildren, ElementRef, EventEmitter, Input,\n  OnDestroy, OnInit, Output, QueryList, Type, ViewChild, ViewContainerRef, reflectComponentType, ComponentRef } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { GridHTMLElement, GridItemHTMLElement, GridStack, GridStackNode, GridStackOptions, GridStackWidget } from 'gridstack';\n\nimport { GridItemCompHTMLElement, GridstackItemComponent } from './gridstack-item.component';\nimport { BaseWidget } from './base-widget';\n\n/** events handlers emitters signature for different events */\nexport type eventCB = {event: Event};\nexport type elementCB = {event: Event, el: GridItemHTMLElement};\nexport type nodesCB = {event: Event, nodes: GridStackNode[]};\nexport type droppedCB = {event: Event, previousNode: GridStackNode, newNode: GridStackNode};\n\nexport type NgCompInputs = {[key: string]: any};\n\n/** extends to store Ng Component selector, instead/inAddition to content */\nexport interface NgGridStackWidget extends GridStackWidget {\n  selector?: string; // component type to create as content\n  input?: NgCompInputs; // serialized data for the component input fields\n}\nexport interface NgGridStackNode extends GridStackNode {\n  selector?: string; // component type to create as content\n}\nexport interface NgGridStackOptions extends GridStackOptions {\n  children?: NgGridStackWidget[];\n  subGridOpts?: NgGridStackOptions;\n}\n\n/** store element to Ng Class pointer back */\nexport interface GridCompHTMLElement extends GridHTMLElement {\n  _gridComp?: GridstackComponent;\n}\n\n/** selector string to runtime Type mapping */\nexport type SelectorToType = {[key: string]: Type<Object>};\n\n/**\n * HTML Component Wrapper for gridstack, in combination with GridstackItemComponent for the items\n */\n@Component({\n  selector: 'gridstack',\n  template: `\n    <!-- content to show when when grid is empty, like instructions on how to add widgets -->\n    <ng-content select=\"[empty-content]\" *ngIf=\"isEmpty\"></ng-content>\n    <!-- where dynamic items go -->\n    <ng-template #container></ng-template>\n    <!-- where template items go -->\n    <ng-content></ng-content>\n  `,\n  styles: [`\n    :host { display: block; }\n  `],\n  // changeDetection: ChangeDetectionStrategy.OnPush, // IFF you want to optimize and control when ChangeDetection needs to happen...\n})\nexport class GridstackComponent implements OnInit, AfterContentInit, OnDestroy {\n\n  /** track list of TEMPLATE grid items so we can sync between DOM and GS internals */\n  @ContentChildren(GridstackItemComponent) public gridstackItems?: QueryList<GridstackItemComponent>;\n  /** container to append items dynamically */\n  @ViewChild('container', { read: ViewContainerRef, static: true}) public container?: ViewContainerRef;\n\n  /** initial options for creation of the grid */\n  @Input() public set options(val: GridStackOptions) { this._options = val; }\n  /** return the current running options */\n  public get options(): GridStackOptions { return this._grid?.opts || this._options || {}; }\n\n  /** true while ng-content with 'no-item-content' should be shown when last item is removed from a grid */\n  @Input() public isEmpty?: boolean;\n\n  /** individual list of GridStackEvent callbacks handlers as output\n   * otherwise use this.grid.on('name1 name2 name3', callback) to handle multiple at once\n   * see https://github.com/gridstack/gridstack.js/blob/master/demo/events.js#L4\n   *\n   * Note: camel casing and 'CB' added at the end to prevent @angular-eslint/no-output-native\n   * eg: 'change' would trigger the raw CustomEvent so use different name.\n   */\n  @Output() public addedCB = new EventEmitter<nodesCB>();\n  @Output() public changeCB = new EventEmitter<nodesCB>();\n  @Output() public disableCB = new EventEmitter<eventCB>();\n  @Output() public dragCB = new EventEmitter<elementCB>();\n  @Output() public dragStartCB = new EventEmitter<elementCB>();\n  @Output() public dragStopCB = new EventEmitter<elementCB>();\n  @Output() public droppedCB = new EventEmitter<droppedCB>();\n  @Output() public enableCB = new EventEmitter<eventCB>();\n  @Output() public removedCB = new EventEmitter<nodesCB>();\n  @Output() public resizeCB = new EventEmitter<elementCB>();\n  @Output() public resizeStartCB = new EventEmitter<elementCB>();\n  @Output() public resizeStopCB = new EventEmitter<elementCB>();\n\n  /** return the native element that contains grid specific fields as well */\n  public get el(): GridCompHTMLElement { return this.elementRef.nativeElement; }\n\n  /** return the GridStack class */\n  public get grid(): GridStack | undefined { return this._grid; }\n\n  /** ComponentRef of ourself - used by dynamic object to correctly get removed */\n  public ref: ComponentRef<GridstackComponent> | undefined;\n\n  /**\n   * stores the selector -> Type mapping, so we can create items dynamically from a string.\n   * Unfortunately Ng doesn't provide public access to that mapping.\n   */\n  public static selectorToType: SelectorToType = {};\n  /** add a list of ng Component to be mapped to selector */\n  public static addComponentToSelectorType(typeList: Array<Type<Object>>) {\n    typeList.forEach(type => GridstackComponent.selectorToType[ GridstackComponent.getSelector(type) ] = type);\n  }\n  /** return the ng Component selector */\n  public static getSelector(type: Type<Object>): string {\n    return reflectComponentType(type)!.selector;\n  }\n\n  private _options?: GridStackOptions;\n  private _grid?: GridStack;\n  private loaded?: boolean;\n  private ngUnsubscribe: Subject<void> = new Subject();\n\n  constructor(\n    // private readonly zone: NgZone,\n    // private readonly cd: ChangeDetectorRef,\n    private readonly elementRef: ElementRef<GridCompHTMLElement>,\n  ) {\n    this.el._gridComp = this;\n  }\n\n  public ngOnInit(): void {\n    // init ourself before any template children are created since we track them below anyway - no need to double create+update widgets\n    this.loaded = !!this.options?.children?.length;\n    this._grid = GridStack.init(this._options, this.el);\n    delete this._options; // GS has it now\n\n    this.checkEmpty();\n  }\n\n  /** wait until after all DOM is ready to init gridstack children (after angular ngFor and sub-components run first) */\n  public ngAfterContentInit(): void {\n    // track whenever the children list changes and update the layout...\n    this.gridstackItems?.changes\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => this.updateAll());\n    // ...and do this once at least unless we loaded children already\n    if (!this.loaded) this.updateAll();\n    this.hookEvents(this.grid);\n  }\n\n  public ngOnDestroy(): void {\n    delete this.ref;\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n    this.grid?.destroy();\n    delete this._grid;\n    delete this.el._gridComp;\n  }\n\n  /**\n   * called when the TEMPLATE list of items changes - get a list of nodes and\n   * update the layout accordingly (which will take care of adding/removing items changed by Angular)\n   */\n  public updateAll() {\n    if (!this.grid) return;\n    const layout: GridStackWidget[] = [];\n    this.gridstackItems?.forEach(item => {\n      layout.push(item.options);\n      item.clearOptions();\n    });\n    this.grid.load(layout); // efficient that does diffs only\n  }\n\n  /** check if the grid is empty, if so show alternative content */\n  public checkEmpty() {\n    if (!this.grid) return;\n    const isEmpty = !this.grid.engine.nodes.length;\n    if (isEmpty === this.isEmpty) return;\n    this.isEmpty = isEmpty;\n    // this.cd.detectChanges();\n  }\n\n  /** get all known events as easy to use Outputs for convenience */\n  private hookEvents(grid?: GridStack) {\n    if (!grid) return;\n    grid\n    .on('added', (event: Event, nodes: GridStackNode[]) => { this.checkEmpty(); this.addedCB.emit({event, nodes}); })\n    .on('change', (event: Event, nodes: GridStackNode[]) => this.changeCB.emit({event, nodes}))\n    .on('disable', (event: Event) => this.disableCB.emit({event}))\n    .on('drag', (event: Event, el: GridItemHTMLElement) => this.dragCB.emit({event, el}))\n    .on('dragstart', (event: Event, el: GridItemHTMLElement) => this.dragStartCB.emit({event, el}))\n    .on('dragstop', (event: Event, el: GridItemHTMLElement) => this.dragStopCB.emit({event, el}))\n    .on('dropped', (event: Event, previousNode: GridStackNode, newNode: GridStackNode) => this.droppedCB.emit({event, previousNode, newNode}))\n    .on('enable', (event: Event) => this.enableCB.emit({event}))\n    .on('removed', (event: Event, nodes: GridStackNode[]) => { this.checkEmpty(); this.removedCB.emit({event, nodes}); })\n    .on('resize', (event: Event, el: GridItemHTMLElement) => this.resizeCB.emit({event, el}))\n    .on('resizestart', (event: Event, el: GridItemHTMLElement) => this.resizeStartCB.emit({event, el}))\n    .on('resizestop', (event: Event, el: GridItemHTMLElement) => this.resizeStopCB.emit({event, el}))\n  }\n}\n\n/**\n * can be used when a new item needs to be created, which we do as a Angular component, or deleted (skip)\n **/\nexport function gsCreateNgComponents(host: GridCompHTMLElement | HTMLElement, w: NgGridStackWidget | GridStackNode, add: boolean, isGrid: boolean): HTMLElement | undefined {\n  if (add) {\n    //\n    // create the component dynamically - see https://angular.io/docs/ts/latest/cookbook/dynamic-component-loader.html\n    //\n    if (!host) return;\n    if (isGrid) {\n      const container = (host.parentElement as GridItemCompHTMLElement)?._gridItemComp?.container;\n      // TODO: figure out how to create ng component inside regular Div. need to access app injectors...\n      // if (!container) {\n      //   const hostElement: Element = host;\n      //   const environmentInjector: EnvironmentInjector;\n      //   grid = createComponent(GridstackComponent, {environmentInjector, hostElement})?.instance;\n      // }\n      const gridRef = container?.createComponent(GridstackComponent);\n      const grid = gridRef?.instance;\n      if (!grid) return;\n      grid.ref = gridRef;\n      grid.options = w as GridStackOptions;\n      return grid.el;\n    } else {\n      const gridComp = (host as GridCompHTMLElement)._gridComp;\n      const gridItemRef = gridComp?.container?.createComponent(GridstackItemComponent);\n      const gridItem = gridItemRef?.instance;\n      if (!gridItem) return;\n      gridItem.ref = gridItemRef\n\n      // IFF we're not a subGrid, define what type of component to create as child, OR you can do it GridstackItemComponent template, but this is more generic\n      if (!w.subGridOpts) {\n        const selector = (w as NgGridStackWidget).selector;\n        const type = selector ? GridstackComponent.selectorToType[selector] : undefined;\n        if (type) {\n          const childWidget = gridItem.container?.createComponent(type)?.instance as BaseWidget;\n          // if proper BaseWidget subclass, save it and load additional data\n          if (childWidget && typeof childWidget.serialize === 'function' && typeof childWidget.deserialize === 'function') {\n            gridItem.childWidget = childWidget;\n            childWidget.deserialize(w);\n          }\n        }\n      }\n\n      return gridItem.el;\n    }\n  } else {\n    //\n    // REMOVE - have to call ComponentRef:destroy() for dynamic objects to correctly remove themselves\n    // Note: this will destroy all children dynamic components as well: gridItem -> childWidget\n    //\n    const n = w as GridStackNode;\n    if (isGrid) {\n      const grid = (n.el as GridCompHTMLElement)?._gridComp;\n      if (grid?.ref) grid.ref.destroy();\n      else grid?.ngOnDestroy();\n    } else {\n      const gridItem = (n.el as GridItemCompHTMLElement)?._gridItemComp;\n      if (gridItem?.ref) gridItem.ref.destroy();\n      else gridItem?.ngOnDestroy();\n    }\n  }\n  return;\n}\n\n/**\n * called for each item in the grid - check if additional information needs to be saved.\n * Note: since this is options minus gridstack private members using Utils.removeInternalForSave(),\n * this typically doesn't need to do anything. However your custom Component @Input() are now supported\n * using BaseWidget.serialize()\n */\nexport function gsSaveAdditionalNgInfo(n: NgGridStackNode, w: NgGridStackWidget) {\n  const gridItem = (n.el as GridItemCompHTMLElement)?._gridItemComp;\n  if (gridItem) {\n    const input = gridItem.childWidget?.serialize();\n    if (input) {\n      w.input = input;\n    }\n    return;\n  }\n  // else check if Grid\n  const grid = (n.el as GridCompHTMLElement)?._gridComp;\n  if (grid) {\n    //.... save any custom data\n  }\n}\n"]}