@sebgroup/green-angular 3.5.2 → 3.6.0
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.
- package/esm2020/index.mjs +2 -1
- package/esm2020/lib/green-angular.module.mjs +7 -3
- package/esm2020/lib/sortable-list/index.mjs +3 -0
- package/esm2020/lib/sortable-list/sortable-list.component.mjs +181 -0
- package/esm2020/lib/sortable-list/sortable-list.module.mjs +20 -0
- package/fesm2015/sebgroup-green-angular.mjs +198 -3
- package/fesm2015/sebgroup-green-angular.mjs.map +1 -1
- package/fesm2020/sebgroup-green-angular.mjs +198 -3
- package/fesm2020/sebgroup-green-angular.mjs.map +1 -1
- package/index.d.ts +1 -0
- package/lib/green-angular.module.d.ts +2 -1
- package/lib/sortable-list/index.d.ts +2 -0
- package/lib/sortable-list/sortable-list.component.d.ts +91 -0
- package/lib/sortable-list/sortable-list.module.d.ts +10 -0
- package/package.json +2 -2
package/esm2020/index.mjs
CHANGED
|
@@ -12,6 +12,7 @@ export * from './lib/shared';
|
|
|
12
12
|
export * from './lib/slider';
|
|
13
13
|
export * from './lib/in-page-wizard';
|
|
14
14
|
export * from './lib/context-menu';
|
|
15
|
+
export * from './lib/sortable-list';
|
|
15
16
|
export * from './lib/cell-table';
|
|
16
17
|
export * from './lib/shared/core-element';
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUE7QUFDMUMsY0FBYyxpQkFBaUIsQ0FBQTtBQUMvQixjQUFjLGFBQWEsQ0FBQTtBQUMzQixjQUFjLGNBQWMsQ0FBQTtBQUM1QixjQUFjLGtCQUFrQixDQUFBO0FBQ2hDLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyxhQUFhLENBQUE7QUFDM0IsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLHVCQUF1QixDQUFBO0FBQ3JDLGNBQWMseUJBQXlCLENBQUE7QUFDdkMsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYyxzQkFBc0IsQ0FBQTtBQUNwQyxjQUFjLG9CQUFvQixDQUFBO0FBQ2xDLGNBQWMscUJBQXFCLENBQUE7QUFDbkMsY0FBYyxrQkFBa0IsQ0FBQTtBQUVoQyxjQUFjLDJCQUEyQixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvZ3JlZW4tYW5ndWxhci5tb2R1bGUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9hY2NvcmRpb24nXG5leHBvcnQgKiBmcm9tICcuL2xpYi9iYWRnZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL2J1dHRvbidcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGVwaWNrZXInXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kcm9wZG93bidcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGFsJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcGFnaW5hdGlvbidcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Byb2dyZXNzLWNpcmNsZSdcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlZ21lbnRlZC1jb250cm9sJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2hhcmVkJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2xpZGVyJ1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW4tcGFnZS13aXphcmQnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb250ZXh0LW1lbnUnXG5leHBvcnQgKiBmcm9tICcuL2xpYi9zb3J0YWJsZS1saXN0J1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY2VsbC10YWJsZSdcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2hhcmVkL2NvcmUtZWxlbWVudCdcbiJdfQ==
|
|
@@ -12,6 +12,7 @@ import { NggProgressCircleModule } from './progress-circle/progress-circle.modul
|
|
|
12
12
|
import { NggSegmentedControlModule } from './segmented-control/segmented-control.module';
|
|
13
13
|
import { NggSharedModule } from './shared/shared.module';
|
|
14
14
|
import { NggSliderModule } from './slider/slider.module';
|
|
15
|
+
import { NggSortableListModule } from './sortable-list/sortable-list.module';
|
|
15
16
|
import { NggCellTableModule } from './cell-table';
|
|
16
17
|
import * as i0 from "@angular/core";
|
|
17
18
|
export class NggModule {
|
|
@@ -29,7 +30,8 @@ NggModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.
|
|
|
29
30
|
NggContextMenuModule,
|
|
30
31
|
NggInPageWizardModule,
|
|
31
32
|
NggCellTableModule,
|
|
32
|
-
NggSharedModule
|
|
33
|
+
NggSharedModule,
|
|
34
|
+
NggSortableListModule] });
|
|
33
35
|
NggModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggModule, imports: [CommonModule, NggAccordionModule,
|
|
34
36
|
NggBadgeModule,
|
|
35
37
|
NggButtonModule,
|
|
@@ -42,7 +44,8 @@ NggModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.
|
|
|
42
44
|
NggContextMenuModule,
|
|
43
45
|
NggInPageWizardModule,
|
|
44
46
|
NggCellTableModule,
|
|
45
|
-
NggSharedModule
|
|
47
|
+
NggSharedModule,
|
|
48
|
+
NggSortableListModule] });
|
|
46
49
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggModule, decorators: [{
|
|
47
50
|
type: NgModule,
|
|
48
51
|
args: [{
|
|
@@ -62,7 +65,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
62
65
|
NggInPageWizardModule,
|
|
63
66
|
NggCellTableModule,
|
|
64
67
|
NggSharedModule,
|
|
68
|
+
NggSortableListModule,
|
|
65
69
|
],
|
|
66
70
|
}]
|
|
67
71
|
}] });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JlZW4tYW5ndWxhci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9ncmVlbi1hbmd1bGFyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxhQUFhLENBQUE7QUFDaEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHNCQUFzQixDQUFBO0FBQ3JELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQTtBQUN4RCxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUNyRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQTtBQUNwRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQTtBQUM5RCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQTtBQUN4RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sU0FBUyxDQUFBO0FBQ3hDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDBDQUEwQyxDQUFBO0FBQ2xGLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDhDQUE4QyxDQUFBO0FBQ3hGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQTtBQUN4RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFDeEQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0NBQXNDLENBQUE7QUFDNUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFBOztBQXNCakQsTUFBTSxPQUFPLFNBQVM7O3NHQUFULFNBQVM7dUdBQVQsU0FBUyxZQWxCVixZQUFZLGFBRXBCLGtCQUFrQjtRQUNsQixjQUFjO1FBQ2QsZUFBZTtRQUNmLG1CQUFtQjtRQUNuQixpQkFBaUI7UUFDakIsY0FBYztRQUNkLHVCQUF1QjtRQUN2Qix5QkFBeUI7UUFDekIsZUFBZTtRQUNmLG9CQUFvQjtRQUNwQixxQkFBcUI7UUFDckIsa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixxQkFBcUI7dUdBR1osU0FBUyxZQWxCVixZQUFZLEVBRXBCLGtCQUFrQjtRQUNsQixjQUFjO1FBQ2QsZUFBZTtRQUNmLG1CQUFtQjtRQUNuQixpQkFBaUI7UUFDakIsY0FBYztRQUNkLHVCQUF1QjtRQUN2Qix5QkFBeUI7UUFDekIsZUFBZTtRQUNmLG9CQUFvQjtRQUNwQixxQkFBcUI7UUFDckIsa0JBQWtCO1FBQ2xCLGVBQWU7UUFDZixxQkFBcUI7MkZBR1osU0FBUztrQkFwQnJCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLEVBQUU7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFO3dCQUNQLGtCQUFrQjt3QkFDbEIsY0FBYzt3QkFDZCxlQUFlO3dCQUNmLG1CQUFtQjt3QkFDbkIsaUJBQWlCO3dCQUNqQixjQUFjO3dCQUNkLHVCQUF1Qjt3QkFDdkIseUJBQXlCO3dCQUN6QixlQUFlO3dCQUNmLG9CQUFvQjt3QkFDcEIscUJBQXFCO3dCQUNyQixrQkFBa0I7d0JBQ2xCLGVBQWU7d0JBQ2YscUJBQXFCO3FCQUN0QjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IE5nZ0FjY29yZGlvbk1vZHVsZSB9IGZyb20gJy4vYWNjb3JkaW9uJ1xuaW1wb3J0IHsgTmdnQmFkZ2VNb2R1bGUgfSBmcm9tICcuL2JhZGdlL2JhZGdlLm1vZHVsZSdcbmltcG9ydCB7IE5nZ0J1dHRvbk1vZHVsZSB9IGZyb20gJy4vYnV0dG9uL2J1dHRvbi5tb2R1bGUnXG5pbXBvcnQgeyBOZ2dDb250ZXh0TWVudU1vZHVsZSB9IGZyb20gJy4vY29udGV4dC1tZW51J1xuaW1wb3J0IHsgTmdnRGF0ZXBpY2tlck1vZHVsZSB9IGZyb20gJy4vZGF0ZXBpY2tlci9kYXRlcGlja2VyLm1vZHVsZSdcbmltcG9ydCB7IE5nZ0Ryb3Bkb3duTW9kdWxlIH0gZnJvbSAnLi9kcm9wZG93bi9kcm9wZG93bi5tb2R1bGUnXG5pbXBvcnQgeyBOZ2dJblBhZ2VXaXphcmRNb2R1bGUgfSBmcm9tICcuL2luLXBhZ2Utd2l6YXJkJ1xuaW1wb3J0IHsgTmdnTW9kYWxNb2R1bGUgfSBmcm9tICcuL21vZGFsJ1xuaW1wb3J0IHsgTmdnUHJvZ3Jlc3NDaXJjbGVNb2R1bGUgfSBmcm9tICcuL3Byb2dyZXNzLWNpcmNsZS9wcm9ncmVzcy1jaXJjbGUubW9kdWxlJ1xuaW1wb3J0IHsgTmdnU2VnbWVudGVkQ29udHJvbE1vZHVsZSB9IGZyb20gJy4vc2VnbWVudGVkLWNvbnRyb2wvc2VnbWVudGVkLWNvbnRyb2wubW9kdWxlJ1xuaW1wb3J0IHsgTmdnU2hhcmVkTW9kdWxlIH0gZnJvbSAnLi9zaGFyZWQvc2hhcmVkLm1vZHVsZSdcbmltcG9ydCB7IE5nZ1NsaWRlck1vZHVsZSB9IGZyb20gJy4vc2xpZGVyL3NsaWRlci5tb2R1bGUnXG5pbXBvcnQgeyBOZ2dTb3J0YWJsZUxpc3RNb2R1bGUgfSBmcm9tICcuL3NvcnRhYmxlLWxpc3Qvc29ydGFibGUtbGlzdC5tb2R1bGUnXG5pbXBvcnQgeyBOZ2dDZWxsVGFibGVNb2R1bGUgfSBmcm9tICcuL2NlbGwtdGFibGUnXG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW10sXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICBleHBvcnRzOiBbXG4gICAgTmdnQWNjb3JkaW9uTW9kdWxlLFxuICAgIE5nZ0JhZGdlTW9kdWxlLFxuICAgIE5nZ0J1dHRvbk1vZHVsZSxcbiAgICBOZ2dEYXRlcGlja2VyTW9kdWxlLFxuICAgIE5nZ0Ryb3Bkb3duTW9kdWxlLFxuICAgIE5nZ01vZGFsTW9kdWxlLFxuICAgIE5nZ1Byb2dyZXNzQ2lyY2xlTW9kdWxlLFxuICAgIE5nZ1NlZ21lbnRlZENvbnRyb2xNb2R1bGUsXG4gICAgTmdnU2xpZGVyTW9kdWxlLFxuICAgIE5nZ0NvbnRleHRNZW51TW9kdWxlLFxuICAgIE5nZ0luUGFnZVdpemFyZE1vZHVsZSxcbiAgICBOZ2dDZWxsVGFibGVNb2R1bGUsXG4gICAgTmdnU2hhcmVkTW9kdWxlLFxuICAgIE5nZ1NvcnRhYmxlTGlzdE1vZHVsZSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgTmdnTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './sortable-list.component';
|
|
2
|
+
export * from './sortable-list.module';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9zb3J0YWJsZS1saXN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkJBQTJCLENBQUE7QUFDekMsY0FBYyx3QkFBd0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc29ydGFibGUtbGlzdC5jb21wb25lbnQnXG5leHBvcnQgKiBmcm9tICcuL3NvcnRhYmxlLWxpc3QubW9kdWxlJ1xuIl19
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { moveItemInArray, transferArrayItem, } from '@angular/cdk/drag-drop';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@angular/cdk/drag-drop";
|
|
6
|
+
export class NggSortableListComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.groups = [];
|
|
9
|
+
this.shouldDisplayCheckboxes = false;
|
|
10
|
+
this.isReadOnly = false;
|
|
11
|
+
this.isDraggable = true;
|
|
12
|
+
this.description = '';
|
|
13
|
+
this.suffixTemplate = null;
|
|
14
|
+
this.itemSelectionChanged = new EventEmitter();
|
|
15
|
+
this.itemOrderChanged = new EventEmitter();
|
|
16
|
+
this.focusedIndex = { 0: 0 };
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Toggles the selection of a checklist item and updates its position in the list.
|
|
20
|
+
*
|
|
21
|
+
* @param item - The checklist item to update.
|
|
22
|
+
*/
|
|
23
|
+
toggleSelection(item) {
|
|
24
|
+
item.selected = !item.selected;
|
|
25
|
+
this.emitCheckListItem(item);
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Handles the onDragDrop event.
|
|
29
|
+
*
|
|
30
|
+
* @param event - The drag and drop event.
|
|
31
|
+
*/
|
|
32
|
+
onDragDrop(event) {
|
|
33
|
+
if (event.previousContainer === event.container) {
|
|
34
|
+
moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
transferArrayItem(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);
|
|
38
|
+
}
|
|
39
|
+
this.emitItemOrderChanged([Number(event.previousContainer.id), event.previousIndex], [Number(event.container.id), event.currentIndex]);
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Handles moving items up or down using the alt + arrow up or alt + arrow down keys.
|
|
43
|
+
*
|
|
44
|
+
* @param groupIndex - The index of the group.
|
|
45
|
+
* @param currentItemIndex - The current index of the item.
|
|
46
|
+
* @param newItemIndex - The new index of the item.
|
|
47
|
+
*/
|
|
48
|
+
onAltArrowKeydown(groupIndex, currentItemIndex, newItemIndex, event) {
|
|
49
|
+
event.preventDefault();
|
|
50
|
+
let newIndex = newItemIndex;
|
|
51
|
+
let newGroupIndex = groupIndex;
|
|
52
|
+
let transfer = false;
|
|
53
|
+
if (newIndex > this.groups[groupIndex].items.length - 1) {
|
|
54
|
+
newIndex = 0;
|
|
55
|
+
newGroupIndex = groupIndex + 1;
|
|
56
|
+
transfer = true;
|
|
57
|
+
this.focusedIndex[groupIndex] = this.groups[groupIndex].items.length - 2;
|
|
58
|
+
}
|
|
59
|
+
else if (newIndex < 0) {
|
|
60
|
+
newGroupIndex = groupIndex - 1;
|
|
61
|
+
newIndex = this.groups[newGroupIndex].items.length;
|
|
62
|
+
transfer = true;
|
|
63
|
+
this.focusedIndex[groupIndex] = 0;
|
|
64
|
+
}
|
|
65
|
+
if (transfer) {
|
|
66
|
+
transferArrayItem(this.groups[groupIndex].items, this.groups[newGroupIndex].items, currentItemIndex, newIndex);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
moveItemInArray(this.groups[groupIndex].items, currentItemIndex, newIndex);
|
|
70
|
+
}
|
|
71
|
+
this.emitItemOrderChanged([groupIndex, currentItemIndex], [newGroupIndex, newIndex]);
|
|
72
|
+
setTimeout(() => {
|
|
73
|
+
this.focusItem(newGroupIndex, newIndex);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Handles focus by arrow keydown event.
|
|
78
|
+
*
|
|
79
|
+
* @param groupIndex - The index of the group.
|
|
80
|
+
* @param itemIndex - The index of the item.
|
|
81
|
+
* @param event - The keyboard event.
|
|
82
|
+
*/
|
|
83
|
+
onArrowKeydown(groupIndex, itemIndex, event) {
|
|
84
|
+
event.preventDefault();
|
|
85
|
+
setTimeout(() => {
|
|
86
|
+
let gi = groupIndex;
|
|
87
|
+
if (itemIndex > this.groups[groupIndex].items.length - 1) {
|
|
88
|
+
gi = groupIndex + 1;
|
|
89
|
+
itemIndex = 0;
|
|
90
|
+
}
|
|
91
|
+
if (itemIndex < 0) {
|
|
92
|
+
gi = groupIndex - 1;
|
|
93
|
+
if (gi < 0) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
itemIndex = this.groups[gi].items.length - 1;
|
|
97
|
+
}
|
|
98
|
+
this.focusItem(gi, itemIndex);
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Emits the item order changed event.
|
|
103
|
+
*
|
|
104
|
+
* @param previousIndex - The previous index of the item.
|
|
105
|
+
* @param currentIndex - The current index of the item.
|
|
106
|
+
*/
|
|
107
|
+
emitItemOrderChanged(previousIndex, currentIndex) {
|
|
108
|
+
this.itemOrderChanged.emit({
|
|
109
|
+
previousIndex,
|
|
110
|
+
currentIndex,
|
|
111
|
+
groups: [...this.groups],
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Emits the selected checklist item through an event.
|
|
116
|
+
*
|
|
117
|
+
* @param item - The checklist item to emit.
|
|
118
|
+
*/
|
|
119
|
+
emitCheckListItem(item) {
|
|
120
|
+
this.itemSelectionChanged.emit({ changedItem: item, groups: this.groups });
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Focuses on a specific item in the sortable list.
|
|
124
|
+
*
|
|
125
|
+
* @param groupIndex - The index of the group.
|
|
126
|
+
* @param itemIndex - The index of the item.
|
|
127
|
+
*/
|
|
128
|
+
focusItem(groupIndex, itemIndex) {
|
|
129
|
+
const groupElements = this.sortableListGroups.nativeElement.querySelectorAll('.item-list-group');
|
|
130
|
+
if (groupElements && groupElements.length > groupIndex) {
|
|
131
|
+
const itemElements = groupElements[groupIndex].querySelectorAll('.item');
|
|
132
|
+
if (itemElements && itemElements.length > itemIndex) {
|
|
133
|
+
if (this.shouldDisplayCheckboxes) {
|
|
134
|
+
itemElements[itemIndex].querySelector('input').focus();
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
itemElements[itemIndex].focus();
|
|
138
|
+
}
|
|
139
|
+
this.focusedIndex[groupIndex] = itemIndex;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Checks if an item has focus.
|
|
145
|
+
*
|
|
146
|
+
* @param groupIndex - The index of the group.
|
|
147
|
+
* @param itemIndex - The index of the item.
|
|
148
|
+
*/
|
|
149
|
+
itemHasFocus(groupIndex, itemIndex) {
|
|
150
|
+
if (!this.focusedIndex[groupIndex]) {
|
|
151
|
+
this.focusedIndex[groupIndex] = 0;
|
|
152
|
+
}
|
|
153
|
+
return this.focusedIndex[groupIndex] === itemIndex;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
NggSortableListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
157
|
+
NggSortableListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NggSortableListComponent, selector: "ngg-sortable-list", inputs: { groups: "groups", shouldDisplayCheckboxes: "shouldDisplayCheckboxes", isReadOnly: "isReadOnly", isDraggable: "isDraggable", description: "description", suffixTemplate: "suffixTemplate" }, outputs: { itemSelectionChanged: "itemSelectionChanged", itemOrderChanged: "itemOrderChanged" }, viewQueries: [{ propertyName: "sortableListGroups", first: true, predicate: ["sortableListGroups"], descendants: true }], ngImport: i0, template: "<div class=\"item-list\">\n <ng-container>\n <p class=\"item-list-header\">\n <span class=\"item-list-header-title\">{{ description }}</span>\n </p>\n <div #sortableListGroups cdkDropListGroup>\n <div\n *ngFor=\"let group of groups; let g_i = index\"\n class=\"item-list-group\"\n [class.drag-enabled]=\"isDraggable && !isReadOnly\"\n role=\"list\"\n cdkDropList\n [cdkDropListData]=\"group.items\"\n [id]=\"g_i.toString()\"\n (cdkDropListDropped)=\"onDragDrop($event)\"\n >\n <p\n *ngIf=\"group.title && group.title.length > 0\"\n class=\"item-list-header\"\n >\n <span class=\"item-list-header-title\">{{ group.title }}</span>\n </p>\n <p\n *ngIf=\"group.description && group.description.length > 0\"\n class=\"item-list-header-description\"\n >\n {{ group.description }}\n </p>\n <div\n *ngFor=\"let checklistItem of group.items; let i = index\"\n [cdkDragDisabled]=\"!isDraggable || isReadOnly\"\n [cdkDragData]=\"checklistItem\"\n cdkDrag\n cdkDragLockAxis=\"y\"\n class=\"item-box\"\n role=\"listitem\"\n >\n <div *cdkDragPlaceholder class=\"item-custom-placeholder\"></div>\n <label\n (keydown.alt.arrowDown)=\"onAltArrowKeydown(g_i, i, i + 1, $event)\"\n (keydown.alt.arrowUp)=\"onAltArrowKeydown(g_i, i, i - 1, $event)\"\n (keydown.arrowDown)=\"onArrowKeydown(g_i, i + 1, $event)\"\n (keydown.arrowUp)=\"onArrowKeydown(g_i, i - 1, $event)\"\n class=\"form-control item-control align-items-center item\"\n [tabindex]=\"shouldDisplayCheckboxes ? '-1' : '0'\"\n >\n <div class=\"form-control\">\n <input\n (change)=\"toggleSelection(checklistItem)\"\n [checked]=\"checklistItem.selected\"\n [disabled]=\"isReadOnly\"\n [type]=\"shouldDisplayCheckboxes ? 'checkbox' : 'hidden'\"\n />\n <div class=\"item-box-title\">\n <span name=\"agendaItemName\"\n >{{ checklistItem.name }}\n <span\n *ngIf=\"checklistItem.hasCustomSuffix\"\n class=\"item-list-suffix\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n suffixTemplate;\n context: { $implicit: checklistItem }\n \"\n class=\"user-icon\"\n >\n </ng-container>\n </span>\n </span>\n <br />\n <span *ngIf=\"!!checklistItem.description\">\n <span class=\"item-list-suffix\" name=\"agendaItemToolTip\">\n {{ checklistItem.description }}\n </span>\n <br />\n </span>\n </div>\n <i></i>\n </div>\n <div *ngIf=\"isDraggable && !isReadOnly\" class=\"item-grip-icon\">\n <i class=\"sg-icon sg-icon-grip-vertical text-primary\"></i>\n </div>\n </label>\n </div>\n </div>\n </div>\n </ng-container>\n</div>\n", styles: [".item-list{width:100%;display:block}label.item{padding:0!important}.item-box{background-color:var(--sg-card-background);color:var(--text-primary-color);display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;font-size:14px;margin:5px 0;border:1px solid var(--border-color);border-radius:4px}.form-control{line-height:20px;font-size:16px;font-weight:500}.item-list-header{display:flex;flex-direction:row;justify-content:space-between;margin-bottom:1rem}.item-list-header-title{font-weight:600;font-size:1rem;line-height:1.25rem;font-style:normal}.item-list-header-subtitle{font-size:.75rem;color:var(--text-primary-color);display:flex;justify-content:center;align-content:center}.item-list-suffix{font-weight:400;font-size:.85rem}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.item-grip-icon{font-weight:400;padding:.75rem 1rem .75rem 0rem}.cdk-drop-list.cdk-drop-list-dragging{cursor:grabbing!important;pointer-events:all!important}.item-custom-placeholder.cdk-drag-placeholder{pointer-events:all!important}.cdk-drop-list.drag-enabled:not(.cdk-drag-placeholder) label{cursor:grab}.cdk-drop-list label:focus-visible{outline-color:#333;outline-offset:4px}.item-list.cdk-drop-list-dragging .item-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1);pointer-events:all!important}.item-custom-placeholder{border:dotted 1px #999;min-height:44px;transition:transform .25s cubic-bezier(0,0,.2,1);border-radius:4px;margin:5px 0;padding:12px 12px 12px 16px}.user-icon{margin-right:.5rem}.item-control{width:100%;display:flex;flex-direction:row;justify-content:space-between}.form-control.item-layout{display:flex;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i2.CdkDropListGroup, selector: "[cdkDropListGroup]", inputs: ["cdkDropListGroupDisabled"], exportAs: ["cdkDropListGroup"] }, { kind: "directive", type: i2.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i2.CdkDragPlaceholder, selector: "ng-template[cdkDragPlaceholder]", inputs: ["data"] }] });
|
|
158
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListComponent, decorators: [{
|
|
159
|
+
type: Component,
|
|
160
|
+
args: [{ selector: 'ngg-sortable-list', template: "<div class=\"item-list\">\n <ng-container>\n <p class=\"item-list-header\">\n <span class=\"item-list-header-title\">{{ description }}</span>\n </p>\n <div #sortableListGroups cdkDropListGroup>\n <div\n *ngFor=\"let group of groups; let g_i = index\"\n class=\"item-list-group\"\n [class.drag-enabled]=\"isDraggable && !isReadOnly\"\n role=\"list\"\n cdkDropList\n [cdkDropListData]=\"group.items\"\n [id]=\"g_i.toString()\"\n (cdkDropListDropped)=\"onDragDrop($event)\"\n >\n <p\n *ngIf=\"group.title && group.title.length > 0\"\n class=\"item-list-header\"\n >\n <span class=\"item-list-header-title\">{{ group.title }}</span>\n </p>\n <p\n *ngIf=\"group.description && group.description.length > 0\"\n class=\"item-list-header-description\"\n >\n {{ group.description }}\n </p>\n <div\n *ngFor=\"let checklistItem of group.items; let i = index\"\n [cdkDragDisabled]=\"!isDraggable || isReadOnly\"\n [cdkDragData]=\"checklistItem\"\n cdkDrag\n cdkDragLockAxis=\"y\"\n class=\"item-box\"\n role=\"listitem\"\n >\n <div *cdkDragPlaceholder class=\"item-custom-placeholder\"></div>\n <label\n (keydown.alt.arrowDown)=\"onAltArrowKeydown(g_i, i, i + 1, $event)\"\n (keydown.alt.arrowUp)=\"onAltArrowKeydown(g_i, i, i - 1, $event)\"\n (keydown.arrowDown)=\"onArrowKeydown(g_i, i + 1, $event)\"\n (keydown.arrowUp)=\"onArrowKeydown(g_i, i - 1, $event)\"\n class=\"form-control item-control align-items-center item\"\n [tabindex]=\"shouldDisplayCheckboxes ? '-1' : '0'\"\n >\n <div class=\"form-control\">\n <input\n (change)=\"toggleSelection(checklistItem)\"\n [checked]=\"checklistItem.selected\"\n [disabled]=\"isReadOnly\"\n [type]=\"shouldDisplayCheckboxes ? 'checkbox' : 'hidden'\"\n />\n <div class=\"item-box-title\">\n <span name=\"agendaItemName\"\n >{{ checklistItem.name }}\n <span\n *ngIf=\"checklistItem.hasCustomSuffix\"\n class=\"item-list-suffix\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n suffixTemplate;\n context: { $implicit: checklistItem }\n \"\n class=\"user-icon\"\n >\n </ng-container>\n </span>\n </span>\n <br />\n <span *ngIf=\"!!checklistItem.description\">\n <span class=\"item-list-suffix\" name=\"agendaItemToolTip\">\n {{ checklistItem.description }}\n </span>\n <br />\n </span>\n </div>\n <i></i>\n </div>\n <div *ngIf=\"isDraggable && !isReadOnly\" class=\"item-grip-icon\">\n <i class=\"sg-icon sg-icon-grip-vertical text-primary\"></i>\n </div>\n </label>\n </div>\n </div>\n </div>\n </ng-container>\n</div>\n", styles: [".item-list{width:100%;display:block}label.item{padding:0!important}.item-box{background-color:var(--sg-card-background);color:var(--text-primary-color);display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;font-size:14px;margin:5px 0;border:1px solid var(--border-color);border-radius:4px}.form-control{line-height:20px;font-size:16px;font-weight:500}.item-list-header{display:flex;flex-direction:row;justify-content:space-between;margin-bottom:1rem}.item-list-header-title{font-weight:600;font-size:1rem;line-height:1.25rem;font-style:normal}.item-list-header-subtitle{font-size:.75rem;color:var(--text-primary-color);display:flex;justify-content:center;align-content:center}.item-list-suffix{font-weight:400;font-size:.85rem}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.item-grip-icon{font-weight:400;padding:.75rem 1rem .75rem 0rem}.cdk-drop-list.cdk-drop-list-dragging{cursor:grabbing!important;pointer-events:all!important}.item-custom-placeholder.cdk-drag-placeholder{pointer-events:all!important}.cdk-drop-list.drag-enabled:not(.cdk-drag-placeholder) label{cursor:grab}.cdk-drop-list label:focus-visible{outline-color:#333;outline-offset:4px}.item-list.cdk-drop-list-dragging .item-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1);pointer-events:all!important}.item-custom-placeholder{border:dotted 1px #999;min-height:44px;transition:transform .25s cubic-bezier(0,0,.2,1);border-radius:4px;margin:5px 0;padding:12px 12px 12px 16px}.user-icon{margin-right:.5rem}.item-control{width:100%;display:flex;flex-direction:row;justify-content:space-between}.form-control.item-layout{display:flex;justify-content:space-between}\n"] }]
|
|
161
|
+
}], propDecorators: { groups: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], shouldDisplayCheckboxes: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], isReadOnly: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], isDraggable: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], description: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], suffixTemplate: [{
|
|
172
|
+
type: Input
|
|
173
|
+
}], itemSelectionChanged: [{
|
|
174
|
+
type: Output
|
|
175
|
+
}], itemOrderChanged: [{
|
|
176
|
+
type: Output
|
|
177
|
+
}], sortableListGroups: [{
|
|
178
|
+
type: ViewChild,
|
|
179
|
+
args: ['sortableListGroups']
|
|
180
|
+
}] } });
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sortable-list.component.js","sourceRoot":"","sources":["../../../../../../libs/angular/src/lib/sortable-list/sortable-list.component.ts","../../../../../../libs/angular/src/lib/sortable-list/sortable-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EACL,MAAM,EAEN,SAAS,GACV,MAAM,eAAe,CAAA;AACtB,OAAO,EAEL,eAAe,EACf,iBAAiB,GAClB,MAAM,wBAAwB,CAAA;;;;AAqB/B,MAAM,OAAO,wBAAwB;IALrC;QAMW,WAAM,GAAwB,EAAE,CAAA;QAChC,4BAAuB,GAAG,KAAK,CAAA;QAC/B,eAAU,GAAG,KAAK,CAAA;QAClB,gBAAW,GAAG,IAAI,CAAA;QAClB,gBAAW,GAAG,EAAE,CAAA;QAChB,mBAAc,GAA4B,IAAI,CAAA;QAE7C,yBAAoB,GAAG,IAAI,YAAY,EAG7C,CAAA;QACM,qBAAgB,GAAG,IAAI,YAAY,EAIzC,CAAA;QAIJ,iBAAY,GAA2B,EAAE,CAAC,EAAE,CAAC,EAAE,CAAA;KAqLhD;IAnLC;;;;OAIG;IACH,eAAe,CAAC,IAAsB;QACpC,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAA;QAC9B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAA;IAC9B,CAAC;IAED;;;;OAIG;IACH,UAAU,CAAC,KAAsC;QAC/C,IAAI,KAAK,CAAC,iBAAiB,KAAK,KAAK,CAAC,SAAS,EAAE;YAC/C,eAAe,CACb,KAAK,CAAC,SAAS,CAAC,IAAI,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,YAAY,CACnB,CAAA;SACF;aAAM;YACL,iBAAiB,CACf,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAC5B,KAAK,CAAC,SAAS,CAAC,IAAI,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,YAAY,CACnB,CAAA;SACF;QAED,IAAI,CAAC,oBAAoB,CACvB,CAAC,MAAM,CAAC,KAAK,CAAC,iBAAiB,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC,EACzD,CAAC,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,YAAY,CAAC,CACjD,CAAA;IACH,CAAC;IAED;;;;;;OAMG;IACH,iBAAiB,CACf,UAAkB,EAClB,gBAAwB,EACxB,YAAoB,EACpB,KAAU;QAEV,KAAK,CAAC,cAAc,EAAE,CAAA;QAEtB,IAAI,QAAQ,GAAG,YAAY,CAAA;QAC3B,IAAI,aAAa,GAAG,UAAU,CAAA;QAC9B,IAAI,QAAQ,GAAG,KAAK,CAAA;QAEpB,IAAI,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACvD,QAAQ,GAAG,CAAC,CAAA;YACZ,aAAa,GAAG,UAAU,GAAG,CAAC,CAAA;YAC9B,QAAQ,GAAG,IAAI,CAAA;YACf,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAA;SACzE;aAAM,IAAI,QAAQ,GAAG,CAAC,EAAE;YACvB,aAAa,GAAG,UAAU,GAAG,CAAC,CAAA;YAC9B,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,MAAM,CAAA;YAClD,QAAQ,GAAG,IAAI,CAAA;YACf,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;SAClC;QAED,IAAI,QAAQ,EAAE;YACZ,iBAAiB,CACf,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,KAAK,EAC7B,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,KAAK,EAChC,gBAAgB,EAChB,QAAQ,CACT,CAAA;SACF;aAAM;YACL,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,KAAK,EAAE,gBAAgB,EAAE,QAAQ,CAAC,CAAA;SAC3E;QAED,IAAI,CAAC,oBAAoB,CACvB,CAAC,UAAU,EAAE,gBAAgB,CAAC,EAC9B,CAAC,aAAa,EAAE,QAAQ,CAAC,CAC1B,CAAA;QAED,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAA;QACzC,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;;;;;OAMG;IACH,cAAc,CAAC,UAAkB,EAAE,SAAiB,EAAE,KAAY;QAChE,KAAK,CAAC,cAAc,EAAE,CAAA;QACtB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,EAAE,GAAG,UAAU,CAAA;YAEnB,IAAI,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;gBACxD,EAAE,GAAG,UAAU,GAAG,CAAC,CAAA;gBACnB,SAAS,GAAG,CAAC,CAAA;aACd;YAED,IAAI,SAAS,GAAG,CAAC,EAAE;gBACjB,EAAE,GAAG,UAAU,GAAG,CAAC,CAAA;gBACnB,IAAI,EAAE,GAAG,CAAC,EAAE;oBACV,OAAM;iBACP;gBACD,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAA;aAC7C;YAED,IAAI,CAAC,SAAS,CAAC,EAAE,EAAE,SAAS,CAAC,CAAA;QAC/B,CAAC,CAAC,CAAA;IACJ,CAAC;IAED;;;;;OAKG;IACK,oBAAoB,CAC1B,aAA+B,EAC/B,YAA8B;QAE9B,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC;YACzB,aAAa;YACb,YAAY;YACZ,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;SACzB,CAAC,CAAA;IACJ,CAAC;IAED;;;;OAIG;IACK,iBAAiB,CAAC,IAAsB;QAC9C,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,WAAW,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAA;IAC5E,CAAC;IAED;;;;;OAKG;IACK,SAAS,CAAC,UAAkB,EAAE,SAAiB;QACrD,MAAM,aAAa,GACjB,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,CAAA;QAE5E,IAAI,aAAa,IAAI,aAAa,CAAC,MAAM,GAAG,UAAU,EAAE;YACtD,MAAM,YAAY,GAAG,aAAa,CAAC,UAAU,CAAC,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAA;YACxE,IAAI,YAAY,IAAI,YAAY,CAAC,MAAM,GAAG,SAAS,EAAE;gBACnD,IAAI,IAAI,CAAC,uBAAuB,EAAE;oBAChC,YAAY,CAAC,SAAS,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,CAAA;iBACvD;qBAAM;oBACL,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,CAAA;iBAChC;gBACD,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,SAAS,CAAA;aAC1C;SACF;IACH,CAAC;IAED;;;;;OAKG;IACH,YAAY,CAAC,UAAkB,EAAE,SAAiB;QAChD,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,EAAE;YAClC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,CAAA;SAClC;QACD,OAAO,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,KAAK,SAAS,CAAA;IACpD,CAAC;;qHAxMU,wBAAwB;yGAAxB,wBAAwB,0dClCrC,61GAyFA;2FDvDa,wBAAwB;kBALpC,SAAS;+BACE,mBAAmB;8BAKpB,MAAM;sBAAd,KAAK;gBACG,uBAAuB;sBAA/B,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEI,oBAAoB;sBAA7B,MAAM;gBAIG,gBAAgB;sBAAzB,MAAM;gBAM0B,kBAAkB;sBAAlD,SAAS;uBAAC,oBAAoB","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport {\n  CdkDragDrop,\n  moveItemInArray,\n  transferArrayItem,\n} from '@angular/cdk/drag-drop'\n\nexport interface SortableListItem {\n  id: any\n  name: string\n  description?: string\n  selected?: boolean\n  hasCustomSuffix?: boolean\n}\n\nexport interface SortableListGroup {\n  items: SortableListItem[]\n  title: string\n  description?: string\n}\n\n@Component({\n  selector: 'ngg-sortable-list',\n  templateUrl: './sortable-list.component.html',\n  styleUrls: ['./sortable-list.component.scss'],\n})\nexport class NggSortableListComponent {\n  @Input() groups: SortableListGroup[] = []\n  @Input() shouldDisplayCheckboxes = false\n  @Input() isReadOnly = false\n  @Input() isDraggable = true\n  @Input() description = ''\n  @Input() suffixTemplate: TemplateRef<any> | null = null\n\n  @Output() itemSelectionChanged = new EventEmitter<{\n    changedItem: SortableListItem\n    groups: SortableListGroup[]\n  }>()\n  @Output() itemOrderChanged = new EventEmitter<{\n    previousIndex: [number, number]\n    currentIndex: [number, number]\n    groups: SortableListGroup[]\n  }>()\n\n  @ViewChild('sortableListGroups') sortableListGroups!: ElementRef\n\n  focusedIndex: Record<number, number> = { 0: 0 }\n\n  /**\n   * Toggles the selection of a checklist item and updates its position in the list.\n   *\n   * @param item - The checklist item to update.\n   */\n  toggleSelection(item: SortableListItem) {\n    item.selected = !item.selected\n    this.emitCheckListItem(item)\n  }\n\n  /**\n   * Handles the onDragDrop event.\n   *\n   * @param event - The drag and drop event.\n   */\n  onDragDrop(event: CdkDragDrop<SortableListItem[]>) {\n    if (event.previousContainer === event.container) {\n      moveItemInArray(\n        event.container.data,\n        event.previousIndex,\n        event.currentIndex\n      )\n    } else {\n      transferArrayItem(\n        event.previousContainer.data,\n        event.container.data,\n        event.previousIndex,\n        event.currentIndex\n      )\n    }\n\n    this.emitItemOrderChanged(\n      [Number(event.previousContainer.id), event.previousIndex],\n      [Number(event.container.id), event.currentIndex]\n    )\n  }\n\n  /**\n   * Handles moving items up or down using the alt + arrow up or alt + arrow down keys.\n   *\n   * @param groupIndex - The index of the group.\n   * @param currentItemIndex - The current index of the item.\n   * @param newItemIndex - The new index of the item.\n   */\n  onAltArrowKeydown(\n    groupIndex: number,\n    currentItemIndex: number,\n    newItemIndex: number,\n    event: any\n  ) {\n    event.preventDefault()\n\n    let newIndex = newItemIndex\n    let newGroupIndex = groupIndex\n    let transfer = false\n\n    if (newIndex > this.groups[groupIndex].items.length - 1) {\n      newIndex = 0\n      newGroupIndex = groupIndex + 1\n      transfer = true\n      this.focusedIndex[groupIndex] = this.groups[groupIndex].items.length - 2\n    } else if (newIndex < 0) {\n      newGroupIndex = groupIndex - 1\n      newIndex = this.groups[newGroupIndex].items.length\n      transfer = true\n      this.focusedIndex[groupIndex] = 0\n    }\n\n    if (transfer) {\n      transferArrayItem(\n        this.groups[groupIndex].items,\n        this.groups[newGroupIndex].items,\n        currentItemIndex,\n        newIndex\n      )\n    } else {\n      moveItemInArray(this.groups[groupIndex].items, currentItemIndex, newIndex)\n    }\n\n    this.emitItemOrderChanged(\n      [groupIndex, currentItemIndex],\n      [newGroupIndex, newIndex]\n    )\n\n    setTimeout(() => {\n      this.focusItem(newGroupIndex, newIndex)\n    })\n  }\n\n  /**\n   * Handles focus by arrow keydown event.\n   *\n   * @param groupIndex - The index of the group.\n   * @param itemIndex - The index of the item.\n   * @param event - The keyboard event.\n   */\n  onArrowKeydown(groupIndex: number, itemIndex: number, event: Event) {\n    event.preventDefault()\n    setTimeout(() => {\n      let gi = groupIndex\n\n      if (itemIndex > this.groups[groupIndex].items.length - 1) {\n        gi = groupIndex + 1\n        itemIndex = 0\n      }\n\n      if (itemIndex < 0) {\n        gi = groupIndex - 1\n        if (gi < 0) {\n          return\n        }\n        itemIndex = this.groups[gi].items.length - 1\n      }\n\n      this.focusItem(gi, itemIndex)\n    })\n  }\n\n  /**\n   * Emits the item order changed event.\n   *\n   * @param previousIndex - The previous index of the item.\n   * @param currentIndex - The current index of the item.\n   */\n  private emitItemOrderChanged(\n    previousIndex: [number, number],\n    currentIndex: [number, number]\n  ) {\n    this.itemOrderChanged.emit({\n      previousIndex,\n      currentIndex,\n      groups: [...this.groups],\n    })\n  }\n\n  /**\n   * Emits the selected checklist item through an event.\n   *\n   * @param item - The checklist item to emit.\n   */\n  private emitCheckListItem(item: SortableListItem) {\n    this.itemSelectionChanged.emit({ changedItem: item, groups: this.groups })\n  }\n\n  /**\n   * Focuses on a specific item in the sortable list.\n   *\n   * @param groupIndex - The index of the group.\n   * @param itemIndex - The index of the item.\n   */\n  private focusItem(groupIndex: number, itemIndex: number): void {\n    const groupElements =\n      this.sortableListGroups.nativeElement.querySelectorAll('.item-list-group')\n\n    if (groupElements && groupElements.length > groupIndex) {\n      const itemElements = groupElements[groupIndex].querySelectorAll('.item')\n      if (itemElements && itemElements.length > itemIndex) {\n        if (this.shouldDisplayCheckboxes) {\n          itemElements[itemIndex].querySelector('input').focus()\n        } else {\n          itemElements[itemIndex].focus()\n        }\n        this.focusedIndex[groupIndex] = itemIndex\n      }\n    }\n  }\n\n  /**\n   * Checks if an item has focus.\n   *\n   * @param groupIndex - The index of the group.\n   * @param itemIndex - The index of the item.\n   */\n  itemHasFocus(groupIndex: number, itemIndex: number) {\n    if (!this.focusedIndex[groupIndex]) {\n      this.focusedIndex[groupIndex] = 0\n    }\n    return this.focusedIndex[groupIndex] === itemIndex\n  }\n}\n","<div class=\"item-list\">\n  <ng-container>\n    <p class=\"item-list-header\">\n      <span class=\"item-list-header-title\">{{ description }}</span>\n    </p>\n    <div #sortableListGroups cdkDropListGroup>\n      <div\n        *ngFor=\"let group of groups; let g_i = index\"\n        class=\"item-list-group\"\n        [class.drag-enabled]=\"isDraggable && !isReadOnly\"\n        role=\"list\"\n        cdkDropList\n        [cdkDropListData]=\"group.items\"\n        [id]=\"g_i.toString()\"\n        (cdkDropListDropped)=\"onDragDrop($event)\"\n      >\n        <p\n          *ngIf=\"group.title && group.title.length > 0\"\n          class=\"item-list-header\"\n        >\n          <span class=\"item-list-header-title\">{{ group.title }}</span>\n        </p>\n        <p\n          *ngIf=\"group.description && group.description.length > 0\"\n          class=\"item-list-header-description\"\n        >\n          {{ group.description }}\n        </p>\n        <div\n          *ngFor=\"let checklistItem of group.items; let i = index\"\n          [cdkDragDisabled]=\"!isDraggable || isReadOnly\"\n          [cdkDragData]=\"checklistItem\"\n          cdkDrag\n          cdkDragLockAxis=\"y\"\n          class=\"item-box\"\n          role=\"listitem\"\n        >\n          <div *cdkDragPlaceholder class=\"item-custom-placeholder\"></div>\n          <label\n            (keydown.alt.arrowDown)=\"onAltArrowKeydown(g_i, i, i + 1, $event)\"\n            (keydown.alt.arrowUp)=\"onAltArrowKeydown(g_i, i, i - 1, $event)\"\n            (keydown.arrowDown)=\"onArrowKeydown(g_i, i + 1, $event)\"\n            (keydown.arrowUp)=\"onArrowKeydown(g_i, i - 1, $event)\"\n            class=\"form-control item-control align-items-center item\"\n            [tabindex]=\"shouldDisplayCheckboxes ? '-1' : '0'\"\n          >\n            <div class=\"form-control\">\n              <input\n                (change)=\"toggleSelection(checklistItem)\"\n                [checked]=\"checklistItem.selected\"\n                [disabled]=\"isReadOnly\"\n                [type]=\"shouldDisplayCheckboxes ? 'checkbox' : 'hidden'\"\n              />\n              <div class=\"item-box-title\">\n                <span name=\"agendaItemName\"\n                  >{{ checklistItem.name }}\n                  <span\n                    *ngIf=\"checklistItem.hasCustomSuffix\"\n                    class=\"item-list-suffix\"\n                  >\n                    <ng-container\n                      *ngTemplateOutlet=\"\n                        suffixTemplate;\n                        context: { $implicit: checklistItem }\n                      \"\n                      class=\"user-icon\"\n                    >\n                    </ng-container>\n                  </span>\n                </span>\n                <br />\n                <span *ngIf=\"!!checklistItem.description\">\n                  <span class=\"item-list-suffix\" name=\"agendaItemToolTip\">\n                    {{ checklistItem.description }}\n                  </span>\n                  <br />\n                </span>\n              </div>\n              <i></i>\n            </div>\n            <div *ngIf=\"isDraggable && !isReadOnly\" class=\"item-grip-icon\">\n              <i class=\"sg-icon sg-icon-grip-vertical text-primary\"></i>\n            </div>\n          </label>\n        </div>\n      </div>\n    </div>\n  </ng-container>\n</div>\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { NggSortableListComponent } from './sortable-list.component';
|
|
5
|
+
import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class NggSortableListModule {
|
|
8
|
+
}
|
|
9
|
+
NggSortableListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
NggSortableListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListModule, declarations: [NggSortableListComponent], imports: [CommonModule, FormsModule, DragDropModule], exports: [NggSortableListComponent] });
|
|
11
|
+
NggSortableListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListModule, imports: [CommonModule, FormsModule, DragDropModule] });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListModule, decorators: [{
|
|
13
|
+
type: NgModule,
|
|
14
|
+
args: [{
|
|
15
|
+
imports: [CommonModule, FormsModule, DragDropModule],
|
|
16
|
+
exports: [NggSortableListComponent],
|
|
17
|
+
declarations: [NggSortableListComponent],
|
|
18
|
+
}]
|
|
19
|
+
}] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydGFibGUtbGlzdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXIvc3JjL2xpYi9zb3J0YWJsZS1saXN0L3NvcnRhYmxlLWxpc3QubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQTtBQUM5QyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ3hDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUM1QyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQTtBQUNwRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sd0JBQXdCLENBQUE7O0FBT3ZELE1BQU0sT0FBTyxxQkFBcUI7O2tIQUFyQixxQkFBcUI7bUhBQXJCLHFCQUFxQixpQkFGakIsd0JBQXdCLGFBRjdCLFlBQVksRUFBRSxXQUFXLEVBQUUsY0FBYyxhQUN6Qyx3QkFBd0I7bUhBR3ZCLHFCQUFxQixZQUp0QixZQUFZLEVBQUUsV0FBVyxFQUFFLGNBQWM7MkZBSXhDLHFCQUFxQjtrQkFMakMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxFQUFFLGNBQWMsQ0FBQztvQkFDcEQsT0FBTyxFQUFFLENBQUMsd0JBQXdCLENBQUM7b0JBQ25DLFlBQVksRUFBRSxDQUFDLHdCQUF3QixDQUFDO2lCQUN6QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbidcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSdcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnXG5pbXBvcnQgeyBOZ2dTb3J0YWJsZUxpc3RDb21wb25lbnQgfSBmcm9tICcuL3NvcnRhYmxlLWxpc3QuY29tcG9uZW50J1xuaW1wb3J0IHsgRHJhZ0Ryb3BNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJ1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb3Jtc01vZHVsZSwgRHJhZ0Ryb3BNb2R1bGVdLFxuICBleHBvcnRzOiBbTmdnU29ydGFibGVMaXN0Q29tcG9uZW50XSxcbiAgZGVjbGFyYXRpb25zOiBbTmdnU29ydGFibGVMaXN0Q29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgTmdnU29ydGFibGVMaXN0TW9kdWxlIHt9XG4iXX0=
|
|
@@ -15,6 +15,8 @@ import * as i1$2 from '@angular/router';
|
|
|
15
15
|
import { RouterModule } from '@angular/router';
|
|
16
16
|
import { Subject, fromEvent, interval } from 'rxjs';
|
|
17
17
|
import { takeUntil, throttle } from 'rxjs/operators';
|
|
18
|
+
import * as i2$1 from '@angular/cdk/drag-drop';
|
|
19
|
+
import { moveItemInArray, transferArrayItem, DragDropModule } from '@angular/cdk/drag-drop';
|
|
18
20
|
import * as i1$3 from '@angular/platform-browser';
|
|
19
21
|
|
|
20
22
|
class NggAccordionListItemComponent {
|
|
@@ -1449,6 +1451,196 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
1449
1451
|
}]
|
|
1450
1452
|
}] });
|
|
1451
1453
|
|
|
1454
|
+
class NggSortableListComponent {
|
|
1455
|
+
constructor() {
|
|
1456
|
+
this.groups = [];
|
|
1457
|
+
this.shouldDisplayCheckboxes = false;
|
|
1458
|
+
this.isReadOnly = false;
|
|
1459
|
+
this.isDraggable = true;
|
|
1460
|
+
this.description = '';
|
|
1461
|
+
this.suffixTemplate = null;
|
|
1462
|
+
this.itemSelectionChanged = new EventEmitter();
|
|
1463
|
+
this.itemOrderChanged = new EventEmitter();
|
|
1464
|
+
this.focusedIndex = { 0: 0 };
|
|
1465
|
+
}
|
|
1466
|
+
/**
|
|
1467
|
+
* Toggles the selection of a checklist item and updates its position in the list.
|
|
1468
|
+
*
|
|
1469
|
+
* @param item - The checklist item to update.
|
|
1470
|
+
*/
|
|
1471
|
+
toggleSelection(item) {
|
|
1472
|
+
item.selected = !item.selected;
|
|
1473
|
+
this.emitCheckListItem(item);
|
|
1474
|
+
}
|
|
1475
|
+
/**
|
|
1476
|
+
* Handles the onDragDrop event.
|
|
1477
|
+
*
|
|
1478
|
+
* @param event - The drag and drop event.
|
|
1479
|
+
*/
|
|
1480
|
+
onDragDrop(event) {
|
|
1481
|
+
if (event.previousContainer === event.container) {
|
|
1482
|
+
moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
|
|
1483
|
+
}
|
|
1484
|
+
else {
|
|
1485
|
+
transferArrayItem(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);
|
|
1486
|
+
}
|
|
1487
|
+
this.emitItemOrderChanged([Number(event.previousContainer.id), event.previousIndex], [Number(event.container.id), event.currentIndex]);
|
|
1488
|
+
}
|
|
1489
|
+
/**
|
|
1490
|
+
* Handles moving items up or down using the alt + arrow up or alt + arrow down keys.
|
|
1491
|
+
*
|
|
1492
|
+
* @param groupIndex - The index of the group.
|
|
1493
|
+
* @param currentItemIndex - The current index of the item.
|
|
1494
|
+
* @param newItemIndex - The new index of the item.
|
|
1495
|
+
*/
|
|
1496
|
+
onAltArrowKeydown(groupIndex, currentItemIndex, newItemIndex, event) {
|
|
1497
|
+
event.preventDefault();
|
|
1498
|
+
let newIndex = newItemIndex;
|
|
1499
|
+
let newGroupIndex = groupIndex;
|
|
1500
|
+
let transfer = false;
|
|
1501
|
+
if (newIndex > this.groups[groupIndex].items.length - 1) {
|
|
1502
|
+
newIndex = 0;
|
|
1503
|
+
newGroupIndex = groupIndex + 1;
|
|
1504
|
+
transfer = true;
|
|
1505
|
+
this.focusedIndex[groupIndex] = this.groups[groupIndex].items.length - 2;
|
|
1506
|
+
}
|
|
1507
|
+
else if (newIndex < 0) {
|
|
1508
|
+
newGroupIndex = groupIndex - 1;
|
|
1509
|
+
newIndex = this.groups[newGroupIndex].items.length;
|
|
1510
|
+
transfer = true;
|
|
1511
|
+
this.focusedIndex[groupIndex] = 0;
|
|
1512
|
+
}
|
|
1513
|
+
if (transfer) {
|
|
1514
|
+
transferArrayItem(this.groups[groupIndex].items, this.groups[newGroupIndex].items, currentItemIndex, newIndex);
|
|
1515
|
+
}
|
|
1516
|
+
else {
|
|
1517
|
+
moveItemInArray(this.groups[groupIndex].items, currentItemIndex, newIndex);
|
|
1518
|
+
}
|
|
1519
|
+
this.emitItemOrderChanged([groupIndex, currentItemIndex], [newGroupIndex, newIndex]);
|
|
1520
|
+
setTimeout(() => {
|
|
1521
|
+
this.focusItem(newGroupIndex, newIndex);
|
|
1522
|
+
});
|
|
1523
|
+
}
|
|
1524
|
+
/**
|
|
1525
|
+
* Handles focus by arrow keydown event.
|
|
1526
|
+
*
|
|
1527
|
+
* @param groupIndex - The index of the group.
|
|
1528
|
+
* @param itemIndex - The index of the item.
|
|
1529
|
+
* @param event - The keyboard event.
|
|
1530
|
+
*/
|
|
1531
|
+
onArrowKeydown(groupIndex, itemIndex, event) {
|
|
1532
|
+
event.preventDefault();
|
|
1533
|
+
setTimeout(() => {
|
|
1534
|
+
let gi = groupIndex;
|
|
1535
|
+
if (itemIndex > this.groups[groupIndex].items.length - 1) {
|
|
1536
|
+
gi = groupIndex + 1;
|
|
1537
|
+
itemIndex = 0;
|
|
1538
|
+
}
|
|
1539
|
+
if (itemIndex < 0) {
|
|
1540
|
+
gi = groupIndex - 1;
|
|
1541
|
+
if (gi < 0) {
|
|
1542
|
+
return;
|
|
1543
|
+
}
|
|
1544
|
+
itemIndex = this.groups[gi].items.length - 1;
|
|
1545
|
+
}
|
|
1546
|
+
this.focusItem(gi, itemIndex);
|
|
1547
|
+
});
|
|
1548
|
+
}
|
|
1549
|
+
/**
|
|
1550
|
+
* Emits the item order changed event.
|
|
1551
|
+
*
|
|
1552
|
+
* @param previousIndex - The previous index of the item.
|
|
1553
|
+
* @param currentIndex - The current index of the item.
|
|
1554
|
+
*/
|
|
1555
|
+
emitItemOrderChanged(previousIndex, currentIndex) {
|
|
1556
|
+
this.itemOrderChanged.emit({
|
|
1557
|
+
previousIndex,
|
|
1558
|
+
currentIndex,
|
|
1559
|
+
groups: [...this.groups],
|
|
1560
|
+
});
|
|
1561
|
+
}
|
|
1562
|
+
/**
|
|
1563
|
+
* Emits the selected checklist item through an event.
|
|
1564
|
+
*
|
|
1565
|
+
* @param item - The checklist item to emit.
|
|
1566
|
+
*/
|
|
1567
|
+
emitCheckListItem(item) {
|
|
1568
|
+
this.itemSelectionChanged.emit({ changedItem: item, groups: this.groups });
|
|
1569
|
+
}
|
|
1570
|
+
/**
|
|
1571
|
+
* Focuses on a specific item in the sortable list.
|
|
1572
|
+
*
|
|
1573
|
+
* @param groupIndex - The index of the group.
|
|
1574
|
+
* @param itemIndex - The index of the item.
|
|
1575
|
+
*/
|
|
1576
|
+
focusItem(groupIndex, itemIndex) {
|
|
1577
|
+
const groupElements = this.sortableListGroups.nativeElement.querySelectorAll('.item-list-group');
|
|
1578
|
+
if (groupElements && groupElements.length > groupIndex) {
|
|
1579
|
+
const itemElements = groupElements[groupIndex].querySelectorAll('.item');
|
|
1580
|
+
if (itemElements && itemElements.length > itemIndex) {
|
|
1581
|
+
if (this.shouldDisplayCheckboxes) {
|
|
1582
|
+
itemElements[itemIndex].querySelector('input').focus();
|
|
1583
|
+
}
|
|
1584
|
+
else {
|
|
1585
|
+
itemElements[itemIndex].focus();
|
|
1586
|
+
}
|
|
1587
|
+
this.focusedIndex[groupIndex] = itemIndex;
|
|
1588
|
+
}
|
|
1589
|
+
}
|
|
1590
|
+
}
|
|
1591
|
+
/**
|
|
1592
|
+
* Checks if an item has focus.
|
|
1593
|
+
*
|
|
1594
|
+
* @param groupIndex - The index of the group.
|
|
1595
|
+
* @param itemIndex - The index of the item.
|
|
1596
|
+
*/
|
|
1597
|
+
itemHasFocus(groupIndex, itemIndex) {
|
|
1598
|
+
if (!this.focusedIndex[groupIndex]) {
|
|
1599
|
+
this.focusedIndex[groupIndex] = 0;
|
|
1600
|
+
}
|
|
1601
|
+
return this.focusedIndex[groupIndex] === itemIndex;
|
|
1602
|
+
}
|
|
1603
|
+
}
|
|
1604
|
+
NggSortableListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
1605
|
+
NggSortableListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: NggSortableListComponent, selector: "ngg-sortable-list", inputs: { groups: "groups", shouldDisplayCheckboxes: "shouldDisplayCheckboxes", isReadOnly: "isReadOnly", isDraggable: "isDraggable", description: "description", suffixTemplate: "suffixTemplate" }, outputs: { itemSelectionChanged: "itemSelectionChanged", itemOrderChanged: "itemOrderChanged" }, viewQueries: [{ propertyName: "sortableListGroups", first: true, predicate: ["sortableListGroups"], descendants: true }], ngImport: i0, template: "<div class=\"item-list\">\n <ng-container>\n <p class=\"item-list-header\">\n <span class=\"item-list-header-title\">{{ description }}</span>\n </p>\n <div #sortableListGroups cdkDropListGroup>\n <div\n *ngFor=\"let group of groups; let g_i = index\"\n class=\"item-list-group\"\n [class.drag-enabled]=\"isDraggable && !isReadOnly\"\n role=\"list\"\n cdkDropList\n [cdkDropListData]=\"group.items\"\n [id]=\"g_i.toString()\"\n (cdkDropListDropped)=\"onDragDrop($event)\"\n >\n <p\n *ngIf=\"group.title && group.title.length > 0\"\n class=\"item-list-header\"\n >\n <span class=\"item-list-header-title\">{{ group.title }}</span>\n </p>\n <p\n *ngIf=\"group.description && group.description.length > 0\"\n class=\"item-list-header-description\"\n >\n {{ group.description }}\n </p>\n <div\n *ngFor=\"let checklistItem of group.items; let i = index\"\n [cdkDragDisabled]=\"!isDraggable || isReadOnly\"\n [cdkDragData]=\"checklistItem\"\n cdkDrag\n cdkDragLockAxis=\"y\"\n class=\"item-box\"\n role=\"listitem\"\n >\n <div *cdkDragPlaceholder class=\"item-custom-placeholder\"></div>\n <label\n (keydown.alt.arrowDown)=\"onAltArrowKeydown(g_i, i, i + 1, $event)\"\n (keydown.alt.arrowUp)=\"onAltArrowKeydown(g_i, i, i - 1, $event)\"\n (keydown.arrowDown)=\"onArrowKeydown(g_i, i + 1, $event)\"\n (keydown.arrowUp)=\"onArrowKeydown(g_i, i - 1, $event)\"\n class=\"form-control item-control align-items-center item\"\n [tabindex]=\"shouldDisplayCheckboxes ? '-1' : '0'\"\n >\n <div class=\"form-control\">\n <input\n (change)=\"toggleSelection(checklistItem)\"\n [checked]=\"checklistItem.selected\"\n [disabled]=\"isReadOnly\"\n [type]=\"shouldDisplayCheckboxes ? 'checkbox' : 'hidden'\"\n />\n <div class=\"item-box-title\">\n <span name=\"agendaItemName\"\n >{{ checklistItem.name }}\n <span\n *ngIf=\"checklistItem.hasCustomSuffix\"\n class=\"item-list-suffix\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n suffixTemplate;\n context: { $implicit: checklistItem }\n \"\n class=\"user-icon\"\n >\n </ng-container>\n </span>\n </span>\n <br />\n <span *ngIf=\"!!checklistItem.description\">\n <span class=\"item-list-suffix\" name=\"agendaItemToolTip\">\n {{ checklistItem.description }}\n </span>\n <br />\n </span>\n </div>\n <i></i>\n </div>\n <div *ngIf=\"isDraggable && !isReadOnly\" class=\"item-grip-icon\">\n <i class=\"sg-icon sg-icon-grip-vertical text-primary\"></i>\n </div>\n </label>\n </div>\n </div>\n </div>\n </ng-container>\n</div>\n", styles: [".item-list{width:100%;display:block}label.item{padding:0!important}.item-box{background-color:var(--sg-card-background);color:var(--text-primary-color);display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;font-size:14px;margin:5px 0;border:1px solid var(--border-color);border-radius:4px}.form-control{line-height:20px;font-size:16px;font-weight:500}.item-list-header{display:flex;flex-direction:row;justify-content:space-between;margin-bottom:1rem}.item-list-header-title{font-weight:600;font-size:1rem;line-height:1.25rem;font-style:normal}.item-list-header-subtitle{font-size:.75rem;color:var(--text-primary-color);display:flex;justify-content:center;align-content:center}.item-list-suffix{font-weight:400;font-size:.85rem}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.item-grip-icon{font-weight:400;padding:.75rem 1rem .75rem 0rem}.cdk-drop-list.cdk-drop-list-dragging{cursor:grabbing!important;pointer-events:all!important}.item-custom-placeholder.cdk-drag-placeholder{pointer-events:all!important}.cdk-drop-list.drag-enabled:not(.cdk-drag-placeholder) label{cursor:grab}.cdk-drop-list label:focus-visible{outline-color:#333;outline-offset:4px}.item-list.cdk-drop-list-dragging .item-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1);pointer-events:all!important}.item-custom-placeholder{border:dotted 1px #999;min-height:44px;transition:transform .25s cubic-bezier(0,0,.2,1);border-radius:4px;margin:5px 0;padding:12px 12px 12px 16px}.user-icon{margin-right:.5rem}.item-control{width:100%;display:flex;flex-direction:row;justify-content:space-between}.form-control.item-layout{display:flex;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2$1.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i2$1.CdkDropListGroup, selector: "[cdkDropListGroup]", inputs: ["cdkDropListGroupDisabled"], exportAs: ["cdkDropListGroup"] }, { kind: "directive", type: i2$1.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i2$1.CdkDragPlaceholder, selector: "ng-template[cdkDragPlaceholder]", inputs: ["data"] }] });
|
|
1606
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListComponent, decorators: [{
|
|
1607
|
+
type: Component,
|
|
1608
|
+
args: [{ selector: 'ngg-sortable-list', template: "<div class=\"item-list\">\n <ng-container>\n <p class=\"item-list-header\">\n <span class=\"item-list-header-title\">{{ description }}</span>\n </p>\n <div #sortableListGroups cdkDropListGroup>\n <div\n *ngFor=\"let group of groups; let g_i = index\"\n class=\"item-list-group\"\n [class.drag-enabled]=\"isDraggable && !isReadOnly\"\n role=\"list\"\n cdkDropList\n [cdkDropListData]=\"group.items\"\n [id]=\"g_i.toString()\"\n (cdkDropListDropped)=\"onDragDrop($event)\"\n >\n <p\n *ngIf=\"group.title && group.title.length > 0\"\n class=\"item-list-header\"\n >\n <span class=\"item-list-header-title\">{{ group.title }}</span>\n </p>\n <p\n *ngIf=\"group.description && group.description.length > 0\"\n class=\"item-list-header-description\"\n >\n {{ group.description }}\n </p>\n <div\n *ngFor=\"let checklistItem of group.items; let i = index\"\n [cdkDragDisabled]=\"!isDraggable || isReadOnly\"\n [cdkDragData]=\"checklistItem\"\n cdkDrag\n cdkDragLockAxis=\"y\"\n class=\"item-box\"\n role=\"listitem\"\n >\n <div *cdkDragPlaceholder class=\"item-custom-placeholder\"></div>\n <label\n (keydown.alt.arrowDown)=\"onAltArrowKeydown(g_i, i, i + 1, $event)\"\n (keydown.alt.arrowUp)=\"onAltArrowKeydown(g_i, i, i - 1, $event)\"\n (keydown.arrowDown)=\"onArrowKeydown(g_i, i + 1, $event)\"\n (keydown.arrowUp)=\"onArrowKeydown(g_i, i - 1, $event)\"\n class=\"form-control item-control align-items-center item\"\n [tabindex]=\"shouldDisplayCheckboxes ? '-1' : '0'\"\n >\n <div class=\"form-control\">\n <input\n (change)=\"toggleSelection(checklistItem)\"\n [checked]=\"checklistItem.selected\"\n [disabled]=\"isReadOnly\"\n [type]=\"shouldDisplayCheckboxes ? 'checkbox' : 'hidden'\"\n />\n <div class=\"item-box-title\">\n <span name=\"agendaItemName\"\n >{{ checklistItem.name }}\n <span\n *ngIf=\"checklistItem.hasCustomSuffix\"\n class=\"item-list-suffix\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n suffixTemplate;\n context: { $implicit: checklistItem }\n \"\n class=\"user-icon\"\n >\n </ng-container>\n </span>\n </span>\n <br />\n <span *ngIf=\"!!checklistItem.description\">\n <span class=\"item-list-suffix\" name=\"agendaItemToolTip\">\n {{ checklistItem.description }}\n </span>\n <br />\n </span>\n </div>\n <i></i>\n </div>\n <div *ngIf=\"isDraggable && !isReadOnly\" class=\"item-grip-icon\">\n <i class=\"sg-icon sg-icon-grip-vertical text-primary\"></i>\n </div>\n </label>\n </div>\n </div>\n </div>\n </ng-container>\n</div>\n", styles: [".item-list{width:100%;display:block}label.item{padding:0!important}.item-box{background-color:var(--sg-card-background);color:var(--text-primary-color);display:flex;flex-direction:row;align-items:center;justify-content:space-between;box-sizing:border-box;font-size:14px;margin:5px 0;border:1px solid var(--border-color);border-radius:4px}.form-control{line-height:20px;font-size:16px;font-weight:500}.item-list-header{display:flex;flex-direction:row;justify-content:space-between;margin-bottom:1rem}.item-list-header-title{font-weight:600;font-size:1rem;line-height:1.25rem;font-style:normal}.item-list-header-subtitle{font-size:.75rem;color:var(--text-primary-color);display:flex;justify-content:center;align-content:center}.item-list-suffix{font-weight:400;font-size:.85rem}.cdk-drag-preview{box-sizing:border-box;border-radius:4px;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.item-grip-icon{font-weight:400;padding:.75rem 1rem .75rem 0rem}.cdk-drop-list.cdk-drop-list-dragging{cursor:grabbing!important;pointer-events:all!important}.item-custom-placeholder.cdk-drag-placeholder{pointer-events:all!important}.cdk-drop-list.drag-enabled:not(.cdk-drag-placeholder) label{cursor:grab}.cdk-drop-list label:focus-visible{outline-color:#333;outline-offset:4px}.item-list.cdk-drop-list-dragging .item-box:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1);pointer-events:all!important}.item-custom-placeholder{border:dotted 1px #999;min-height:44px;transition:transform .25s cubic-bezier(0,0,.2,1);border-radius:4px;margin:5px 0;padding:12px 12px 12px 16px}.user-icon{margin-right:.5rem}.item-control{width:100%;display:flex;flex-direction:row;justify-content:space-between}.form-control.item-layout{display:flex;justify-content:space-between}\n"] }]
|
|
1609
|
+
}], propDecorators: { groups: [{
|
|
1610
|
+
type: Input
|
|
1611
|
+
}], shouldDisplayCheckboxes: [{
|
|
1612
|
+
type: Input
|
|
1613
|
+
}], isReadOnly: [{
|
|
1614
|
+
type: Input
|
|
1615
|
+
}], isDraggable: [{
|
|
1616
|
+
type: Input
|
|
1617
|
+
}], description: [{
|
|
1618
|
+
type: Input
|
|
1619
|
+
}], suffixTemplate: [{
|
|
1620
|
+
type: Input
|
|
1621
|
+
}], itemSelectionChanged: [{
|
|
1622
|
+
type: Output
|
|
1623
|
+
}], itemOrderChanged: [{
|
|
1624
|
+
type: Output
|
|
1625
|
+
}], sortableListGroups: [{
|
|
1626
|
+
type: ViewChild,
|
|
1627
|
+
args: ['sortableListGroups']
|
|
1628
|
+
}] } });
|
|
1629
|
+
|
|
1630
|
+
class NggSortableListModule {
|
|
1631
|
+
}
|
|
1632
|
+
NggSortableListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
1633
|
+
NggSortableListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListModule, declarations: [NggSortableListComponent], imports: [CommonModule, FormsModule, DragDropModule], exports: [NggSortableListComponent] });
|
|
1634
|
+
NggSortableListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListModule, imports: [CommonModule, FormsModule, DragDropModule] });
|
|
1635
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggSortableListModule, decorators: [{
|
|
1636
|
+
type: NgModule,
|
|
1637
|
+
args: [{
|
|
1638
|
+
imports: [CommonModule, FormsModule, DragDropModule],
|
|
1639
|
+
exports: [NggSortableListComponent],
|
|
1640
|
+
declarations: [NggSortableListComponent],
|
|
1641
|
+
}]
|
|
1642
|
+
}] });
|
|
1643
|
+
|
|
1452
1644
|
class SlidingUnderlineDirective {
|
|
1453
1645
|
constructor(element) {
|
|
1454
1646
|
this.element = element;
|
|
@@ -1724,7 +1916,8 @@ NggModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.
|
|
|
1724
1916
|
NggContextMenuModule,
|
|
1725
1917
|
NggInPageWizardModule,
|
|
1726
1918
|
NggCellTableModule,
|
|
1727
|
-
NggSharedModule
|
|
1919
|
+
NggSharedModule,
|
|
1920
|
+
NggSortableListModule] });
|
|
1728
1921
|
NggModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggModule, imports: [CommonModule, NggAccordionModule,
|
|
1729
1922
|
NggBadgeModule,
|
|
1730
1923
|
NggButtonModule,
|
|
@@ -1737,7 +1930,8 @@ NggModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.
|
|
|
1737
1930
|
NggContextMenuModule,
|
|
1738
1931
|
NggInPageWizardModule,
|
|
1739
1932
|
NggCellTableModule,
|
|
1740
|
-
NggSharedModule
|
|
1933
|
+
NggSharedModule,
|
|
1934
|
+
NggSortableListModule] });
|
|
1741
1935
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: NggModule, decorators: [{
|
|
1742
1936
|
type: NgModule,
|
|
1743
1937
|
args: [{
|
|
@@ -1757,6 +1951,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
1757
1951
|
NggInPageWizardModule,
|
|
1758
1952
|
NggCellTableModule,
|
|
1759
1953
|
NggSharedModule,
|
|
1954
|
+
NggSortableListModule,
|
|
1760
1955
|
],
|
|
1761
1956
|
}]
|
|
1762
1957
|
}] });
|
|
@@ -1950,5 +2145,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
1950
2145
|
* Generated bundle index. Do not edit.
|
|
1951
2146
|
*/
|
|
1952
2147
|
|
|
1953
|
-
export { NggAccordionComponent, NggAccordionListItemComponent, NggAccordionModule, NggBadgeComponent, NggBadgeModule, NggButtonComponent, NggButtonModule, NggCellTableComponent, NggCellTableModule, NggContextMenuComponent, NggContextMenuModule, NggCoreElementDirective, NggCoreWrapperModule, NggDatepickerComponent, NggDatepickerModule, NggDropdownButtonDirective, NggDropdownComponent, NggDropdownModule, NggDropdownOptionDirective, NggInPageWizardModule, NggInPageWizardStepCardComponent, NggModalBodyComponent, NggModalComponent, NggModalFooterComponent, NggModalFooterDirective, NggModalHeaderComponent, NggModalHeaderDirective, NggModalModule, NggModule, NggOnScrollDirective, NggPaginationComponent, NggPaginationModule, NggProgressCircleComponent, NggProgressCircleModule, NggSegmentedControlComponent, NggSegmentedControlModule, NggSharedModule, NggSliderComponent, NggSliderModule, ON_SCROLL_TOKEN, dateValidator };
|
|
2148
|
+
export { NggAccordionComponent, NggAccordionListItemComponent, NggAccordionModule, NggBadgeComponent, NggBadgeModule, NggButtonComponent, NggButtonModule, NggCellTableComponent, NggCellTableModule, NggContextMenuComponent, NggContextMenuModule, NggCoreElementDirective, NggCoreWrapperModule, NggDatepickerComponent, NggDatepickerModule, NggDropdownButtonDirective, NggDropdownComponent, NggDropdownModule, NggDropdownOptionDirective, NggInPageWizardModule, NggInPageWizardStepCardComponent, NggModalBodyComponent, NggModalComponent, NggModalFooterComponent, NggModalFooterDirective, NggModalHeaderComponent, NggModalHeaderDirective, NggModalModule, NggModule, NggOnScrollDirective, NggPaginationComponent, NggPaginationModule, NggProgressCircleComponent, NggProgressCircleModule, NggSegmentedControlComponent, NggSegmentedControlModule, NggSharedModule, NggSliderComponent, NggSliderModule, NggSortableListComponent, NggSortableListModule, ON_SCROLL_TOKEN, dateValidator };
|
|
1954
2149
|
//# sourceMappingURL=sebgroup-green-angular.mjs.map
|