@seniorsistemas/angular-components 17.9.1 → 17.9.3
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/bundles/seniorsistemas-angular-components.umd.js +60 -27
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/kanban/components/kanban-column/kanban-column.component.d.ts +2 -0
- package/components/kanban/components/kanban-item/kanban-item.component.d.ts +7 -4
- package/components/kanban/kanban.component.d.ts +7 -5
- package/components/kanban/models/index.d.ts +1 -1
- package/components/kanban/models/kanban-data.d.ts +9 -2
- package/components/tooltip/tooltip.directive.d.ts +1 -2
- package/esm2015/components/kanban/components/kanban-column/kanban-column.component.js +14 -2
- package/esm2015/components/kanban/components/kanban-item/kanban-item.component.js +20 -6
- package/esm2015/components/kanban/kanban.component.js +26 -18
- package/esm2015/components/kanban/models/index.js +1 -1
- package/esm2015/components/kanban/models/kanban-data.js +1 -1
- package/esm2015/components/navigation-button/navigation-button.component.js +5 -1
- package/esm2015/components/tooltip/tooltip.directive.js +7 -14
- package/esm5/components/kanban/components/kanban-column/kanban-column.component.js +16 -3
- package/esm5/components/kanban/components/kanban-item/kanban-item.component.js +22 -7
- package/esm5/components/kanban/kanban.component.js +26 -18
- package/esm5/components/kanban/models/index.js +1 -1
- package/esm5/components/kanban/models/kanban-data.js +1 -1
- package/esm5/components/navigation-button/navigation-button.component.js +5 -1
- package/esm5/components/tooltip/tooltip.directive.js +7 -14
- package/fesm2015/seniorsistemas-angular-components.js +58 -27
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +60 -27
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -5,12 +5,14 @@ import { FormControl } from "@angular/forms";
|
|
|
5
5
|
export declare class KanbanColumnComponent implements OnInit, OnDestroy {
|
|
6
6
|
private readonly kanbanEventService;
|
|
7
7
|
data: KanbanColumn;
|
|
8
|
+
showCheckbox: boolean;
|
|
8
9
|
headerTemplate: TemplateRef<any>;
|
|
9
10
|
selectionControl: FormControl;
|
|
10
11
|
private _unsubscribe$;
|
|
11
12
|
constructor(kanbanEventService: KanbanEventService);
|
|
12
13
|
ngOnInit(): void;
|
|
13
14
|
ngOnDestroy(): void;
|
|
15
|
+
private _createTieredOptions;
|
|
14
16
|
private _subscriveEvents;
|
|
15
17
|
private _validateInputs;
|
|
16
18
|
}
|
|
@@ -1,13 +1,16 @@
|
|
|
1
|
-
import { TemplateRef } from
|
|
2
|
-
import { KanbanItem } from
|
|
3
|
-
import { KanbanEventService } from
|
|
4
|
-
export declare class KanbanItemComponent {
|
|
1
|
+
import { OnInit, TemplateRef } from "@angular/core";
|
|
2
|
+
import { KanbanItem } from "../../models";
|
|
3
|
+
import { KanbanEventService } from "../../kanban-event.service";
|
|
4
|
+
export declare class KanbanItemComponent implements OnInit {
|
|
5
5
|
private readonly _kanbanEventService;
|
|
6
6
|
item: KanbanItem;
|
|
7
7
|
selected: boolean;
|
|
8
|
+
showCheckbox: boolean;
|
|
8
9
|
headerTemplate: TemplateRef<any>;
|
|
9
10
|
bodyTemplate: TemplateRef<any>;
|
|
10
11
|
footerTemplate: TemplateRef<any>;
|
|
11
12
|
constructor(_kanbanEventService: KanbanEventService);
|
|
13
|
+
ngOnInit(): void;
|
|
12
14
|
onSelectedChange(value: any): void;
|
|
15
|
+
private _createTieredOptions;
|
|
13
16
|
}
|
|
@@ -1,11 +1,13 @@
|
|
|
1
|
-
import { CdkDragDrop } from
|
|
2
|
-
import { AfterContentInit, EventEmitter, OnDestroy, OnInit, QueryList, TemplateRef } from
|
|
3
|
-
import { TemplateDirective } from
|
|
4
|
-
import { KanbanEventService } from
|
|
5
|
-
import { KanbanColumn, KanbanData, KanbanItem, KanbanItemMovedData } from
|
|
1
|
+
import { CdkDragDrop } from "@angular/cdk/drag-drop";
|
|
2
|
+
import { AfterContentInit, EventEmitter, OnDestroy, OnInit, QueryList, TemplateRef } from "@angular/core";
|
|
3
|
+
import { TemplateDirective } from "../template/template.directive";
|
|
4
|
+
import { KanbanEventService } from "./kanban-event.service";
|
|
5
|
+
import { KanbanColumn, KanbanData, KanbanItem, KanbanItemMovedData } from "./models/index";
|
|
6
6
|
export declare class KanbanComponent implements OnInit, AfterContentInit, OnDestroy {
|
|
7
7
|
private readonly kanbanEventService;
|
|
8
8
|
data: KanbanData;
|
|
9
|
+
showItemCheckboxes: boolean;
|
|
10
|
+
showColumnCheckboxes: boolean;
|
|
9
11
|
itemsMoved: EventEmitter<KanbanItemMovedData>;
|
|
10
12
|
dataUpdated: EventEmitter<KanbanData>;
|
|
11
13
|
itemsSelected: EventEmitter<KanbanItem[]>;
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export { KanbanData, KanbanColumn, KanbanItem, KanbanItemMovedData } from "./kanban-data";
|
|
1
|
+
export { KanbanData, KanbanColumn, KanbanItem, KanbanItemMovedData, KanbanItemOption } from "./kanban-data";
|
|
2
2
|
export { KanbanTemplateTypes } from "./kanban-template-types";
|
|
@@ -6,11 +6,12 @@ export interface KanbanColumn {
|
|
|
6
6
|
id?: string;
|
|
7
7
|
title: string;
|
|
8
8
|
items: KanbanItem[];
|
|
9
|
-
options?:
|
|
9
|
+
options?: KanbanColumnOption[];
|
|
10
10
|
}
|
|
11
11
|
export interface KanbanItem {
|
|
12
|
-
options?:
|
|
12
|
+
options?: KanbanItemOption[];
|
|
13
13
|
disabled?: boolean;
|
|
14
|
+
frozen?: boolean;
|
|
14
15
|
data: any;
|
|
15
16
|
}
|
|
16
17
|
export interface KanbanItemMovedData {
|
|
@@ -18,3 +19,9 @@ export interface KanbanItemMovedData {
|
|
|
18
19
|
previousColumn: KanbanColumn;
|
|
19
20
|
targetColumn: KanbanColumn;
|
|
20
21
|
}
|
|
22
|
+
export interface KanbanColumnOption extends Omit<TieredMenuItemData, 'command'> {
|
|
23
|
+
command: (column: KanbanColumn) => void;
|
|
24
|
+
}
|
|
25
|
+
export interface KanbanItemOption extends Omit<TieredMenuItemData, 'command'> {
|
|
26
|
+
command: (item: KanbanItem) => void;
|
|
27
|
+
}
|
|
@@ -34,8 +34,7 @@ export declare class TooltipDirective implements OnInit, OnDestroy {
|
|
|
34
34
|
private updateTooltipVisibilityWhenFocusOnInput;
|
|
35
35
|
/**
|
|
36
36
|
* Obtém o elemento do ícone associado ao label do input em focus.
|
|
37
|
-
* @
|
|
38
|
-
* @returns O ícone do input em focus ou null.
|
|
37
|
+
* @returns O ícone do input em focus.
|
|
39
38
|
*/
|
|
40
39
|
private getIconFromFocusedInput;
|
|
41
40
|
/**
|
|
@@ -7,17 +7,26 @@ import { FormControl } from "@angular/forms";
|
|
|
7
7
|
let KanbanColumnComponent = class KanbanColumnComponent {
|
|
8
8
|
constructor(kanbanEventService) {
|
|
9
9
|
this.kanbanEventService = kanbanEventService;
|
|
10
|
+
this.showCheckbox = true;
|
|
10
11
|
this.selectionControl = new FormControl(false);
|
|
11
12
|
this._unsubscribe$ = new Subject();
|
|
12
13
|
}
|
|
13
14
|
ngOnInit() {
|
|
14
15
|
this._validateInputs();
|
|
15
16
|
this._subscriveEvents();
|
|
17
|
+
this._createTieredOptions();
|
|
16
18
|
}
|
|
17
19
|
ngOnDestroy() {
|
|
18
20
|
this._unsubscribe$.next();
|
|
19
21
|
this._unsubscribe$.complete();
|
|
20
22
|
}
|
|
23
|
+
_createTieredOptions() {
|
|
24
|
+
const options = [];
|
|
25
|
+
this.data.options.forEach((option) => {
|
|
26
|
+
options.push(Object.assign(Object.assign({}, option), { command: () => { option.command(this.data); } }));
|
|
27
|
+
});
|
|
28
|
+
this.data.options = options;
|
|
29
|
+
}
|
|
21
30
|
_subscriveEvents() {
|
|
22
31
|
this.selectionControl.valueChanges
|
|
23
32
|
.pipe(takeUntil(this._unsubscribe$))
|
|
@@ -68,15 +77,18 @@ KanbanColumnComponent.ctorParameters = () => [
|
|
|
68
77
|
__decorate([
|
|
69
78
|
Input()
|
|
70
79
|
], KanbanColumnComponent.prototype, "data", void 0);
|
|
80
|
+
__decorate([
|
|
81
|
+
Input()
|
|
82
|
+
], KanbanColumnComponent.prototype, "showCheckbox", void 0);
|
|
71
83
|
__decorate([
|
|
72
84
|
Input()
|
|
73
85
|
], KanbanColumnComponent.prototype, "headerTemplate", void 0);
|
|
74
86
|
KanbanColumnComponent = __decorate([
|
|
75
87
|
Component({
|
|
76
88
|
selector: "s-kanban-column",
|
|
77
|
-
template: "<div class=\"kanban-column\">\n <div class=\"kanban-column__header\">\n <div class=\"content\">\n <form>\n <input\n type=\"checkbox\"\n name=\"checkbox\"\n [formControl]=\"selectionControl\">\n </form>\n\n <ng-container *ngIf=\"!headerTemplate; then defaultHeaderTemplate else customHeaderTemplate\"></ng-container>\n \n <ng-template #defaultHeaderTemplate>\n <div class=\"header\">\n <span class=\"title\">{{ data.title }} ({{ data.items.length }})</span>\n </div>\n </ng-template>\n \n <ng-template #customHeaderTemplate>\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: data }\"></ng-container>\n </ng-template>\n </div>\n <s-button\n *ngIf=\"data.options\"\n priority=\"default\"\n [disabled]=\"false\"\n [auxiliary]=\"true\"\n size=\"small\"\n [model]=\"data.options\">\n </s-button>\n </div>\n <div class=\"kanban-column__body\">\n <ng-content></ng-content>\n </div>\n</div>",
|
|
89
|
+
template: "<div class=\"kanban-column\">\n <div class=\"kanban-column__header\">\n <div class=\"content\">\n <form>\n <input\n *ngIf=\"showCheckbox\"\n type=\"checkbox\"\n name=\"checkbox\"\n [formControl]=\"selectionControl\">\n </form>\n\n <ng-container *ngIf=\"!headerTemplate; then defaultHeaderTemplate else customHeaderTemplate\"></ng-container>\n \n <ng-template #defaultHeaderTemplate>\n <div class=\"header\">\n <span class=\"title\">{{ data.title }} ({{ data.items.length }})</span>\n </div>\n </ng-template>\n \n <ng-template #customHeaderTemplate>\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: data }\"></ng-container>\n </ng-template>\n </div>\n <s-button\n *ngIf=\"data.options\"\n priority=\"default\"\n [disabled]=\"false\"\n [auxiliary]=\"true\"\n size=\"small\"\n [model]=\"data.options\">\n </s-button>\n </div>\n <div class=\"kanban-column__body\">\n <ng-content></ng-content>\n </div>\n</div>",
|
|
78
90
|
styles: [".kanban-column{-ms-flex-align:center;align-items:center;background-color:#fbfafc;border:1px solid #dedce5;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;height:100%;min-height:120px;-webkit-user-select:none;-ms-user-select:none;user-select:none;width:100%}.kanban-column .kanban-column__header{-ms-flex-align:center;align-items:center;border-bottom:1px solid #dedce5;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between;padding:16px 16px 8px;width:100%}.kanban-column .kanban-column__header .content{display:-ms-flexbox;display:flex;gap:16px}.kanban-column .kanban-column__header .content .teste{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;font-family:\"Open Sans\" sans-serif}.kanban-column .kanban-column__header .content .teste .title{font-size:14px;font-weight:800}.kanban-column .kanban-column__header .content .teste .description{font-size:12px}.kanban-column .kanban-column__body{display:-ms-flexbox;display:flex;height:100%;-ms-flex-pack:center;justify-content:center;width:100%}"]
|
|
79
91
|
})
|
|
80
92
|
], KanbanColumnComponent);
|
|
81
93
|
export { KanbanColumnComponent };
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kanban-column.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/kanban/components/kanban-column/kanban-column.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit, TemplateRef } from \"@angular/core\";\n\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\nimport { KanbanColumn, KanbanItem } from \"../../models\";\nimport { KanbanEventService } from \"../../kanban-event.service\";\nimport { FormControl } from \"@angular/forms\";\nimport { KanbanColumnOption } from \"../../models/kanban-data\";\n\n@Component({\n    selector: \"s-kanban-column\",\n    templateUrl: \"./kanban-column.component.html\",\n    styleUrls: [\"./kanban-column.component.scss\"],\n})\nexport class KanbanColumnComponent implements OnInit, OnDestroy {\n    @Input()\n    public data: KanbanColumn;\n\n    @Input()\n    public showCheckbox = true;\n\n    @Input()\n    public headerTemplate: TemplateRef<any>;\n\n    public selectionControl = new FormControl(false);\n\n    private _unsubscribe$ = new Subject<void>();\n\n    constructor(\n        private readonly kanbanEventService: KanbanEventService,\n    ) { }\n\n    public ngOnInit(): void {\n        this._validateInputs();\n        this._subscriveEvents();\n\n        this._createTieredOptions();\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n    }\n\n    private _createTieredOptions(): void {\n        const options: KanbanColumnOption[] = [];\n\n        this.data.options.forEach((option: KanbanColumnOption) => {\n          options.push({\n            ...option,\n            command: () => { option.command(this.data) },\n          });\n        });\n\n        this.data.options = options;\n    }\n\n    private _subscriveEvents(): void {\n        this.selectionControl.valueChanges\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((value: boolean) => {\n                if (value) {\n                    this.kanbanEventService.emitSelectAllColumnItemsEvent(this.data);\n                } else {\n                    this.kanbanEventService.emitUnselectAllColumnItemsEvent(this.data);\n                }\n            });\n\n        this.kanbanEventService.unselectItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((_) => {\n                this.selectionControl.setValue(false, { emitEvent: false });\n            });\n\n        this.kanbanEventService.selectItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: KanbanItem) => {\n                if (!this.data.items.includes(item)) {\n                    this.selectionControl.setValue(false, { emitEvent: false });\n                }\n            });\n\n        this.kanbanEventService.selectAllColumnItemsEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((column: KanbanColumn) => {\n                if (this.data !== column) {\n                    this.selectionControl.setValue(false, { emitEvent: false });\n                }\n            });\n\n        this.kanbanEventService.unselectAllColumnItemsEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((column: KanbanColumn) => {\n                if (this.data !== column) {\n                    this.selectionControl.setValue(false, { emitEvent: false });\n                }\n            })\n    }\n\n    private _validateInputs(): void {\n        if (!this.data) {\n            throw new Error(\"data parameter is required\");\n        }\n    }\n}\n"]}
|
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { Component, Input } from
|
|
3
|
-
import { KanbanEventService } from
|
|
2
|
+
import { Component, Input } from "@angular/core";
|
|
3
|
+
import { KanbanEventService } from "../../kanban-event.service";
|
|
4
4
|
let KanbanItemComponent = class KanbanItemComponent {
|
|
5
5
|
constructor(_kanbanEventService) {
|
|
6
6
|
this._kanbanEventService = _kanbanEventService;
|
|
7
7
|
this.selected = false;
|
|
8
|
+
this.showCheckbox = true;
|
|
9
|
+
}
|
|
10
|
+
ngOnInit() {
|
|
11
|
+
this._createTieredOptions();
|
|
8
12
|
}
|
|
9
13
|
onSelectedChange(value) {
|
|
10
14
|
if (value) {
|
|
@@ -14,6 +18,13 @@ let KanbanItemComponent = class KanbanItemComponent {
|
|
|
14
18
|
this._kanbanEventService.emitUnselectItemEvent(this.item);
|
|
15
19
|
}
|
|
16
20
|
}
|
|
21
|
+
_createTieredOptions() {
|
|
22
|
+
const options = [];
|
|
23
|
+
this.item.options.forEach((option) => {
|
|
24
|
+
options.push(Object.assign(Object.assign({}, option), { command: () => { option.command(this.item); } }));
|
|
25
|
+
});
|
|
26
|
+
this.item.options = options;
|
|
27
|
+
}
|
|
17
28
|
};
|
|
18
29
|
KanbanItemComponent.ctorParameters = () => [
|
|
19
30
|
{ type: KanbanEventService }
|
|
@@ -24,6 +35,9 @@ __decorate([
|
|
|
24
35
|
__decorate([
|
|
25
36
|
Input()
|
|
26
37
|
], KanbanItemComponent.prototype, "selected", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
Input()
|
|
40
|
+
], KanbanItemComponent.prototype, "showCheckbox", void 0);
|
|
27
41
|
__decorate([
|
|
28
42
|
Input()
|
|
29
43
|
], KanbanItemComponent.prototype, "headerTemplate", void 0);
|
|
@@ -35,10 +49,10 @@ __decorate([
|
|
|
35
49
|
], KanbanItemComponent.prototype, "footerTemplate", void 0);
|
|
36
50
|
KanbanItemComponent = __decorate([
|
|
37
51
|
Component({
|
|
38
|
-
selector:
|
|
39
|
-
template: "<p-tieredMenu\n #optionsMenu\n [popup]=\"true\"\n appendTo=\"body\"\n [baseZIndex]=\"9999\"\n [model]=\"item.options\">\n</p-tieredMenu>\n\n<div\n class=\"kanban-item\"\n [ngClass]=\"{\n 'kanban-item--selected': selected && !item.disabled,\n 'kanban-item--disabled': item.disabled\n }\">\n <div class=\"kanban-item__header\">\n <div class=\"content\">\n <form>\n <input\n *ngIf=\"!item.disabled\"\n type=\"checkbox\"\n name=\"checkbox\"\n [(ngModel)]=\"selected\"\n (ngModelChange)=\"onSelectedChange($event)\"\n (click)=\"$event.stopPropagation()\">\n </form>\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: item }\"></ng-container>\n </div>\n <button\n *ngIf=\"item.options && !item.disabled\"\n class=\"options-button\"\n (click)=\"optionsMenu.toggle($event); $event.stopPropagation();\">\n <i class=\"fas fa-ellipsis-v\"></i>\n </button>\n </div>\n <div class=\"kanban-item__body\">\n <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: item }\"></ng-container>\n </div>\n <div *ngIf=\"footerTemplate\" class=\"kanban-item__footer\">\n <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: item }\"></ng-container> \n </div>\n</div>",
|
|
40
|
-
styles: [".kanban-item{background-color:#fff;border-radius:4px;box-shadow:0 1px 5px 0 rgba(0,0,0,.25);cursor:pointer;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;margin:16px;min-width:260px;padding:16px;-webkit-user-select:none;-ms-user-select:none;user-select:none}.kanban-item .kanban-item__header{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.kanban-item .kanban-item__header .content{display:-ms-flexbox;display:flex;gap:16px}.kanban-item .kanban-item__header .options-button{background-color:transparent;border:none;cursor:pointer;margin-right:-8px;padding:0 8px}.kanban-item .kanban-item__body{margin:16px 0}.kanban-item .kanban-item__footer{border-top:1px solid #dedce5;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.kanban-item .kanban-item__footer .date-info{-ms-flex-align:center;align-items:center;color:#6e7280;display:-ms-flexbox;display:flex;font-family:\"Open Sans\" sans-serif;font-size:12px;gap:4px;line-height:150%}.kanban-item--selected{border:1px solid #428bca}.kanban-item--disabled{opacity:50%}"]
|
|
52
|
+
selector: "s-kanban-item",
|
|
53
|
+
template: "<p-tieredMenu\n #optionsMenu\n [popup]=\"true\"\n appendTo=\"body\"\n [baseZIndex]=\"9999\"\n [model]=\"item.options\">\n</p-tieredMenu>\n\n<div\n class=\"kanban-item\"\n [ngClass]=\"{\n 'kanban-item--selected': selected && !item.disabled,\n 'kanban-item--disabled': item.disabled,\n 'kanban-item--frozen': !item.disabled && item.frozen\n }\">\n <div class=\"kanban-item__header\">\n <div class=\"content\">\n <form>\n <input\n *ngIf=\"showCheckbox && !item.disabled && !item.frozen\"\n type=\"checkbox\"\n name=\"checkbox\"\n [(ngModel)]=\"selected\"\n (ngModelChange)=\"onSelectedChange($event)\"\n (click)=\"$event.stopPropagation()\">\n </form>\n <ng-container *ngTemplateOutlet=\"headerTemplate; context: { $implicit: item }\"></ng-container>\n </div>\n <button\n *ngIf=\"item.options && !item.disabled\"\n class=\"options-button\"\n (click)=\"optionsMenu.toggle($event); $event.stopPropagation();\">\n <i class=\"fas fa-ellipsis-v\"></i>\n </button>\n </div>\n <div class=\"kanban-item__body\">\n <ng-container *ngTemplateOutlet=\"bodyTemplate; context: { $implicit: item }\"></ng-container>\n </div>\n <div *ngIf=\"footerTemplate\" class=\"kanban-item__footer\">\n <ng-container *ngTemplateOutlet=\"footerTemplate; context: { $implicit: item }\"></ng-container> \n </div>\n</div>",
|
|
54
|
+
styles: [".kanban-item{background-color:#fff;border-radius:4px;box-shadow:0 1px 5px 0 rgba(0,0,0,.25);cursor:pointer;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;margin:16px;min-width:260px;padding:16px;-webkit-user-select:none;-ms-user-select:none;user-select:none}.kanban-item .kanban-item__header{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.kanban-item .kanban-item__header .content{display:-ms-flexbox;display:flex;gap:16px}.kanban-item .kanban-item__header .options-button{background-color:transparent;border:none;cursor:pointer;margin-right:-8px;padding:0 8px}.kanban-item .kanban-item__body{margin:16px 0}.kanban-item .kanban-item__footer{border-top:1px solid #dedce5;display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.kanban-item .kanban-item__footer .date-info{-ms-flex-align:center;align-items:center;color:#6e7280;display:-ms-flexbox;display:flex;font-family:\"Open Sans\" sans-serif;font-size:12px;gap:4px;line-height:150%}.kanban-item--selected{border:1px solid #428bca}.kanban-item--disabled{opacity:50%}.kanban-item--frozen{box-shadow:none}"]
|
|
41
55
|
})
|
|
42
56
|
], KanbanItemComponent);
|
|
43
57
|
export { KanbanItemComponent };
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMva2FuYmFuL2NvbXBvbmVudHMva2FuYmFuLWl0ZW0va2FuYmFuLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFHdEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFRaEUsSUFBYSxtQkFBbUIsR0FBaEMsTUFBYSxtQkFBbUI7SUFtQjVCLFlBQTZCLG1CQUF1QztRQUF2Qyx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQW9CO1FBZDdELGFBQVEsR0FBRyxLQUFLLENBQUM7UUFHakIsaUJBQVksR0FBRyxJQUFJLENBQUM7SUFXNEMsQ0FBQztJQUVqRSxRQUFRO1FBQ1gsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVNLGdCQUFnQixDQUFDLEtBQVU7UUFDOUIsSUFBSSxLQUFLLEVBQUU7WUFDUCxJQUFJLENBQUMsbUJBQW1CLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzNEO2FBQU07WUFDSCxJQUFJLENBQUMsbUJBQW1CLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzdEO0lBQ0wsQ0FBQztJQUVPLG9CQUFvQjtRQUN4QixNQUFNLE9BQU8sR0FBdUIsRUFBRSxDQUFDO1FBRXZDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQXdCLEVBQUUsRUFBRTtZQUNyRCxPQUFPLENBQUMsSUFBSSxpQ0FDUCxNQUFNLEtBQ1QsT0FBTyxFQUFFLEdBQUcsRUFBRSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFBLENBQUMsQ0FBQyxJQUM1QyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDaEMsQ0FBQztDQUNKLENBQUE7O1lBMUJxRCxrQkFBa0I7O0FBakJwRTtJQURDLEtBQUssRUFBRTtpREFDZ0I7QUFHeEI7SUFEQyxLQUFLLEVBQUU7cURBQ2dCO0FBR3hCO0lBREMsS0FBSyxFQUFFO3lEQUNtQjtBQUczQjtJQURDLEtBQUssRUFBRTsyREFDZ0M7QUFHeEM7SUFEQyxLQUFLLEVBQUU7eURBQzhCO0FBR3RDO0lBREMsS0FBSyxFQUFFOzJEQUNnQztBQWpCL0IsbUJBQW1CO0lBTC9CLFNBQVMsQ0FBQztRQUNQLFFBQVEsRUFBRSxlQUFlO1FBQ3pCLDZrREFBMkM7O0tBRTlDLENBQUM7R0FDVyxtQkFBbUIsQ0E2Qy9CO1NBN0NZLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgVGVtcGxhdGVSZWYgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBLYW5iYW5JdGVtIH0gZnJvbSBcIi4uLy4uL21vZGVsc1wiO1xuaW1wb3J0IHsgS2FuYmFuRXZlbnRTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uL2thbmJhbi1ldmVudC5zZXJ2aWNlXCI7XG5pbXBvcnQgeyBLYW5iYW5JdGVtT3B0aW9uIH0gZnJvbSBcIi4uLy4uL21vZGVscy9rYW5iYW4tZGF0YVwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJzLWthbmJhbi1pdGVtXCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi9rYW5iYW4taXRlbS5jb21wb25lbnQuaHRtbFwiLFxuICAgIHN0eWxlVXJsczogW1wiLi9rYW5iYW4taXRlbS5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgS2FuYmFuSXRlbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaXRlbTogS2FuYmFuSXRlbTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNlbGVjdGVkID0gZmFsc2U7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzaG93Q2hlY2tib3ggPSB0cnVlO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaGVhZGVyVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBib2R5VGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBmb290ZXJUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVhZG9ubHkgX2thbmJhbkV2ZW50U2VydmljZTogS2FuYmFuRXZlbnRTZXJ2aWNlKSB7fVxuXG4gICAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLl9jcmVhdGVUaWVyZWRPcHRpb25zKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG9uU2VsZWN0ZWRDaGFuZ2UodmFsdWU6IGFueSk6IHZvaWQge1xuICAgICAgICBpZiAodmFsdWUpIHtcbiAgICAgICAgICAgIHRoaXMuX2thbmJhbkV2ZW50U2VydmljZS5lbWl0U2VsZWN0SXRlbUV2ZW50KHRoaXMuaXRlbSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLl9rYW5iYW5FdmVudFNlcnZpY2UuZW1pdFVuc2VsZWN0SXRlbUV2ZW50KHRoaXMuaXRlbSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBwcml2YXRlIF9jcmVhdGVUaWVyZWRPcHRpb25zKCk6IHZvaWQge1xuICAgICAgICBjb25zdCBvcHRpb25zOiBLYW5iYW5JdGVtT3B0aW9uW10gPSBbXTtcblxuICAgICAgICB0aGlzLml0ZW0ub3B0aW9ucy5mb3JFYWNoKChvcHRpb246IEthbmJhbkl0ZW1PcHRpb24pID0+IHtcbiAgICAgICAgICBvcHRpb25zLnB1c2goe1xuICAgICAgICAgICAgLi4ub3B0aW9uLFxuICAgICAgICAgICAgY29tbWFuZDogKCkgPT4geyBvcHRpb24uY29tbWFuZCh0aGlzLml0ZW0pIH0sXG4gICAgICAgICAgfSk7XG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRoaXMuaXRlbS5vcHRpb25zID0gb3B0aW9ucztcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,14 +1,16 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { moveItemInArray, transferArrayItem } from
|
|
3
|
-
import { Component, ContentChildren, EventEmitter, Input, Output } from
|
|
4
|
-
import { Subject } from
|
|
5
|
-
import { takeUntil } from
|
|
6
|
-
import { TemplateDirective } from
|
|
7
|
-
import { KanbanEventService } from
|
|
8
|
-
import { KanbanTemplateTypes } from
|
|
2
|
+
import { moveItemInArray, transferArrayItem } from "@angular/cdk/drag-drop";
|
|
3
|
+
import { Component, ContentChildren, EventEmitter, Input, Output, } from "@angular/core";
|
|
4
|
+
import { Subject } from "rxjs";
|
|
5
|
+
import { takeUntil } from "rxjs/operators";
|
|
6
|
+
import { TemplateDirective } from "../template/template.directive";
|
|
7
|
+
import { KanbanEventService } from "./kanban-event.service";
|
|
8
|
+
import { KanbanTemplateTypes } from "./models/index";
|
|
9
9
|
let KanbanComponent = class KanbanComponent {
|
|
10
10
|
constructor(kanbanEventService) {
|
|
11
11
|
this.kanbanEventService = kanbanEventService;
|
|
12
|
+
this.showItemCheckboxes = true;
|
|
13
|
+
this.showColumnCheckboxes = true;
|
|
12
14
|
this.itemsMoved = new EventEmitter();
|
|
13
15
|
this.dataUpdated = new EventEmitter();
|
|
14
16
|
this.itemsSelected = new EventEmitter();
|
|
@@ -67,6 +69,8 @@ let KanbanComponent = class KanbanComponent {
|
|
|
67
69
|
this.selectedItems.clear();
|
|
68
70
|
}
|
|
69
71
|
selectItem(event, item, column) {
|
|
72
|
+
if (item.disabled || item.frozen)
|
|
73
|
+
return;
|
|
70
74
|
if (event.ctrlKey) {
|
|
71
75
|
if (this.selectedItems.delete(item)) {
|
|
72
76
|
this.kanbanEventService.emitUnselectItemEvent(item);
|
|
@@ -81,6 +85,8 @@ let KanbanComponent = class KanbanComponent {
|
|
|
81
85
|
}
|
|
82
86
|
}
|
|
83
87
|
else {
|
|
88
|
+
if (this.selectedItems.delete(item))
|
|
89
|
+
return;
|
|
84
90
|
this.selectedItems.clear();
|
|
85
91
|
this.selectedItems.add(item);
|
|
86
92
|
this.selectedColumn = column;
|
|
@@ -96,9 +102,7 @@ let KanbanComponent = class KanbanComponent {
|
|
|
96
102
|
this.draggingItems.clear();
|
|
97
103
|
}
|
|
98
104
|
getLinkedColumns(currentColumn) {
|
|
99
|
-
return this.data.columns
|
|
100
|
-
.filter((column) => column != currentColumn)
|
|
101
|
-
.map((column) => column.id);
|
|
105
|
+
return this.data.columns.filter((column) => column != currentColumn).map((column) => column.id);
|
|
102
106
|
}
|
|
103
107
|
getColumnHeaderTemplate() {
|
|
104
108
|
return this._getCustomTemplate(KanbanTemplateTypes.ColumnHeader);
|
|
@@ -124,7 +128,7 @@ let KanbanComponent = class KanbanComponent {
|
|
|
124
128
|
.pipe(takeUntil(this._unsubscribe$))
|
|
125
129
|
.subscribe((column) => {
|
|
126
130
|
column.items
|
|
127
|
-
.filter((item) => !item.disabled)
|
|
131
|
+
.filter((item) => !item.disabled && !item.frozen)
|
|
128
132
|
.forEach((item) => {
|
|
129
133
|
this.selectedItems.add(item);
|
|
130
134
|
});
|
|
@@ -154,9 +158,7 @@ let KanbanComponent = class KanbanComponent {
|
|
|
154
158
|
});
|
|
155
159
|
});
|
|
156
160
|
});
|
|
157
|
-
this.kanbanEventService.unselectItemEvent
|
|
158
|
-
.pipe(takeUntil(this._unsubscribe$))
|
|
159
|
-
.subscribe((item) => {
|
|
161
|
+
this.kanbanEventService.unselectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item) => {
|
|
160
162
|
this.selectedItems.delete(item);
|
|
161
163
|
});
|
|
162
164
|
}
|
|
@@ -186,6 +188,12 @@ KanbanComponent.ctorParameters = () => [
|
|
|
186
188
|
__decorate([
|
|
187
189
|
Input()
|
|
188
190
|
], KanbanComponent.prototype, "data", void 0);
|
|
191
|
+
__decorate([
|
|
192
|
+
Input()
|
|
193
|
+
], KanbanComponent.prototype, "showItemCheckboxes", void 0);
|
|
194
|
+
__decorate([
|
|
195
|
+
Input()
|
|
196
|
+
], KanbanComponent.prototype, "showColumnCheckboxes", void 0);
|
|
189
197
|
__decorate([
|
|
190
198
|
Output()
|
|
191
199
|
], KanbanComponent.prototype, "itemsMoved", void 0);
|
|
@@ -200,10 +208,10 @@ __decorate([
|
|
|
200
208
|
], KanbanComponent.prototype, "templates", void 0);
|
|
201
209
|
KanbanComponent = __decorate([
|
|
202
210
|
Component({
|
|
203
|
-
selector:
|
|
204
|
-
template: "<div class=\"kanban\">\n <s-kanban-column\n *ngFor=\"let column of data.columns\"\n [data]=\"column\"\n [headerTemplate]=\"columnHeaderTemplate\">\n <div\n [id]=\"column.id\"\n style=\"height: 100%; width: 100%;\"\n cdkDropList\n #dynamicList=\"cdkDropList\"\n [cdkDropListData]=\"column.items\"\n [cdkDropListConnectedTo]=\"getLinkedColumns(column)\"\n (cdkDropListDropped)=\"drop($event)\">\n\n <ng-container *ngIf=\"!columnEmptyMessageTemplate; then defaultEmptyMessageTemplate else customEmptyMessageTemplate\"></ng-container>\n\n <ng-template #defaultEmptyMessageTemplate>\n <div *ngIf=\"!column.items.length\" class=\"empty-message\">\n <p class=\"text\">\n <span class=\"fas fa-clock\"></span> \n <span>{{ \"platform.angular_components.count_items_in_target\" | translate:{ count: column.items.length, target: column.title } }}</span>\n </p>\n </div>\n </ng-template>\n\n <ng-template #customEmptyMessageTemplate>\n <ng-container *ngTemplateOutlet=\"columnEmptyMessageTemplate; context: { $implicit: column }\"></ng-container>\n </ng-template>\n\n <div\n *ngFor=\"let item of column.items\"\n cdkDrag\n [cdkDragData]=\"item\"\n [cdkDragDisabled]=\"item.disabled\"\n (cdkDragStarted)=\"dragStarted()\"\n (cdkDragReleased)=\"dragReleased()\"\n (click)=\"selectItem($event, item, column)\">\n \n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n\n <ng-container *cdkDragPreview>\n <ng-container *ngIf=\"selectedItems.size > 1; then itemDraggingTemplate else itemTemplate\"></ng-container>\n </ng-container>\n\n <ng-template #itemTemplate>\n <s-kanban-item\n [item]=\"item\"\n [selected]=\"selectedItems.has(item)\"\n [headerTemplate]=\"itemHeaderTemplate\"\n [bodyTemplate]=\"itemBodyTemplate\"\n [footerTemplate]=\"itemFooterTemplate\">\n </s-kanban-item>\n </ng-template>\n\n <ng-template #itemDraggingTemplate>\n <s-kanban-item-dragging [quantityItems]=\"selectedItems.size\"></s-kanban-item-dragging>\n </ng-template>\n\n <div *cdkDragPlaceholder>\n <div class=\"placeholder\">\n <div class=\"placeholder-line\"></div>\n </div>\n </div>\n </div>\n </div>\n </s-kanban-column>\n</div>\n\n",
|
|
205
|
-
styles: [".kanban{display:-ms-flexbox;display:flex;gap:16px;width:100%}.kanban .empty-message{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;margin:16px}.kanban .empty-message .text{overflow:hidden;text-align:center;text-overflow:ellipsis;width:100%;white-space:nowrap}@media screen and (max-width:600px){.kanban{-ms-flex-direction:column;flex-direction:column}}s-kanban-column{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;min-width:292px}.placeholder{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.placeholder .placeholder-line{background-color:#a5a5b2;height:1px;margin:6px 0;width:50%}"]
|
|
211
|
+
selector: "s-kanban",
|
|
212
|
+
template: "<div class=\"kanban\">\n <s-kanban-column\n *ngFor=\"let column of data.columns\"\n [data]=\"column\"\n [showCheckbox]=\"showColumnCheckboxes\"\n [headerTemplate]=\"columnHeaderTemplate\">\n <div\n [id]=\"column.id\"\n style=\"height: 100%; width: 100%;\"\n cdkDropList\n #dynamicList=\"cdkDropList\"\n [cdkDropListData]=\"column.items\"\n [cdkDropListConnectedTo]=\"getLinkedColumns(column)\"\n (cdkDropListDropped)=\"drop($event)\">\n\n <ng-container *ngIf=\"!columnEmptyMessageTemplate; then defaultEmptyMessageTemplate else customEmptyMessageTemplate\"></ng-container>\n\n <ng-template #defaultEmptyMessageTemplate>\n <div *ngIf=\"!column.items.length\" class=\"empty-message\">\n <p class=\"text\">\n <span class=\"fas fa-clock\"></span> \n <span>{{ \"platform.angular_components.count_items_in_target\" | translate:{ count: column.items.length, target: column.title } }}</span>\n </p>\n </div>\n </ng-template>\n\n <ng-template #customEmptyMessageTemplate>\n <ng-container *ngTemplateOutlet=\"columnEmptyMessageTemplate; context: { $implicit: column }\"></ng-container>\n </ng-template>\n\n <div\n *ngFor=\"let item of column.items\"\n cdkDrag\n [cdkDragData]=\"item\"\n [cdkDragDisabled]=\"item.disabled || item.frozen\"\n (cdkDragStarted)=\"dragStarted()\"\n (cdkDragReleased)=\"dragReleased()\"\n (click)=\"selectItem($event, item, column)\">\n \n <ng-container *ngTemplateOutlet=\"itemTemplate\"></ng-container>\n\n <ng-container *cdkDragPreview>\n <ng-container *ngIf=\"selectedItems.size > 1; then itemDraggingTemplate else itemTemplate\"></ng-container>\n </ng-container>\n\n <ng-template #itemTemplate>\n <s-kanban-item\n [item]=\"item\"\n [selected]=\"selectedItems.has(item)\"\n [showCheckbox]=\"showItemCheckboxes\"\n [headerTemplate]=\"itemHeaderTemplate\"\n [bodyTemplate]=\"itemBodyTemplate\"\n [footerTemplate]=\"itemFooterTemplate\">\n </s-kanban-item>\n </ng-template>\n\n <ng-template #itemDraggingTemplate>\n <s-kanban-item-dragging [quantityItems]=\"selectedItems.size\"></s-kanban-item-dragging>\n </ng-template>\n\n <div *cdkDragPlaceholder>\n <div class=\"placeholder\">\n <div class=\"placeholder-line\"></div>\n </div>\n </div>\n </div>\n </div>\n </s-kanban-column>\n</div>\n\n",
|
|
213
|
+
styles: [".kanban{display:-ms-flexbox;display:flex;gap:16px;overflow:auto;width:100%}.kanban .empty-message{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center;margin:16px}.kanban .empty-message .text{overflow:hidden;text-align:center;text-overflow:ellipsis;width:100%;white-space:nowrap}@media screen and (max-width:600px){.kanban{-ms-flex-direction:column;flex-direction:column}}s-kanban-column{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;min-width:292px}.placeholder{display:-ms-flexbox;display:flex;-ms-flex-pack:center;justify-content:center}.placeholder .placeholder-line{background-color:#a5a5b2;height:1px;margin:6px 0;width:50%}"]
|
|
206
214
|
})
|
|
207
215
|
], KanbanComponent);
|
|
208
216
|
export { KanbanComponent };
|
|
209
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kanban.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/kanban/kanban.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAe,eAAe,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AACzF,OAAO,EAAoB,SAAS,EAAE,eAAe,EAAE,YAAY,EAAE,KAAK,EAAqB,MAAM,EAA0B,MAAM,eAAe,CAAC;AAErJ,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAA6D,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAOhH,IAAa,eAAe,GAA5B,MAAa,eAAe;IA2BxB,YACqB,kBAAsC;QAAtC,uBAAkB,GAAlB,kBAAkB,CAAoB;QAvBpD,eAAU,GAAG,IAAI,YAAY,EAAuB,CAAC;QAGrD,gBAAW,GAAG,IAAI,YAAY,EAAc,CAAC;QAG7C,kBAAa,GAAG,IAAI,YAAY,EAAgB,CAAC;QAGjD,kBAAa,GAAG,IAAI,GAAG,EAAc,CAAC;QACtC,kBAAa,GAAG,IAAI,GAAG,EAAc,CAAC;QAQrC,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;IAMxC,CAAC;IAEE,QAAQ;QACX,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,kBAAkB;QACd,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;IAEM,IAAI,CAAC,KAAgC;;QACxC,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,KAAK,CAAC,iBAAiB,CAAC,EAAE,CAAC,CAAC;QAClH,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QAExG,IAAI,CAAC,cAAc,IAAI,CAAC,YAAY,EAAE;YAClC,MAAM,IAAI,KAAK,CAAC,0EAA0E,CAAC,CAAC;SAC/F;QAED,IAAI,KAAK,CAAC,iBAAiB,KAAK,KAAK,CAAC,SAAS,EAAE;YAC7C,eAAe,CACX,KAAK,CAAC,SAAS,CAAC,IAAI,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,YAAY,CACrB,CAAC;SACL;aAAM;YACH,iBAAiB,CACb,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAC5B,KAAK,CAAC,SAAS,CAAC,IAAI,EACpB,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,YAAY,CACrB,CAAC;SACL;QAED,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,IAAgB,EAAE,EAAE;YAC5C,MAAM,aAAa,GAAG,KAAK,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACjE,IAAI,aAAa,KAAK,CAAC,CAAC,IAAI,IAAI,KAAK,KAAK,CAAC,IAAI,CAAC,IAAI,EAAE;gBAClD,IAAI,KAAK,CAAC,iBAAiB,KAAK,KAAK,CAAC,SAAS,EAAE;oBAC7C,eAAe,CACX,KAAK,CAAC,SAAS,CAAC,IAAI,EACpB,aAAa,EACb,KAAK,CAAC,YAAY,CACrB,CAAC;iBACL;qBAAM;oBACH,iBAAiB,CACb,KAAK,CAAC,iBAAiB,CAAC,IAAI,EAC5B,KAAK,CAAC,SAAS,CAAC,IAAI,EACpB,aAAa,EACb,KAAK,CAAC,YAAY,CACrB,CAAC;iBACL;aACJ;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAExC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YACjB,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC;YAC9B,cAAc;YACd,YAAY;SACf,CAAC,CAAC;QAEH,UAAI,IAAI,CAAC,WAAW,CAAC,SAAS,0CAAE,MAAM,EAAE;YACpC,IAAI,CAAC,WAAW,CAAC,IAAI,mBAAM,IAAI,CAAC,IAAI,EAAG,CAAC;SAC3C;QAED,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAoB,EAAE,EAAE;YAC/C,IAAI,CAAC,kBAAkB,CAAC,+BAA+B,CAAC,MAAM,CAAC,CAAC;QACpE,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAEM,UAAU,CAAC,KAAiB,EAAE,IAAgB,EAAE,MAAoB;QACvE,IAAI,KAAK,CAAC,OAAO,EAAE;YACf,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gBACjC,IAAI,CAAC,kBAAkB,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;aACvD;iBAAM;gBACH,IAAI,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;oBAClE,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;iBAC9B;gBAED,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBAC7B,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;gBAC7B,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;aACrD;SACJ;aAAM;YACH,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC7B,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;YAC7B,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;SACrD;IACL,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,IAAgB,EAAE,EAAE;YAC5C,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,YAAY;QACf,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAEM,gBAAgB,CAAC,aAA2B;QAC/C,OAAO,IAAI,CAAC,IAAI,CAAC,OAAO;aACnB,MAAM,CAAC,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,IAAI,aAAa,CAAC;aACzD,GAAG,CAAC,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;IAClD,CAAC;IAEM,uBAAuB;QAC1B,OAAO,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,YAAY,CAAC,CAAA;IACpE,CAAC;IAEM,6BAA6B;QAChC,OAAO,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,CAAC;IAC3E,CAAC;IAEM,qBAAqB;QACxB,OAAO,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;IACnE,CAAC;IAEM,mBAAmB;QACtB,OAAO,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IACjE,CAAC;IAEM,qBAAqB;QACxB,OAAO,IAAI,CAAC,kBAAkB,CAAC,mBAAmB,CAAC,UAAU,CAAC,CAAC;IACnE,CAAC;IAEO,kBAAkB,CAAC,IAAY;;QACnC,aAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,QAA2B,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,KAAK,IAAI,CAAC,0CAAE,QAAQ,CAAC;IAClG,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,kBAAkB,CAAC,yBAAyB;aAC5C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,MAAoB,EAAE,EAAE;YAChC,MAAM,CAAC,KAAK;iBACP,MAAM,CAAC,CAAC,IAAgB,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;iBAC5C,OAAO,CAAC,CAAC,IAAgB,EAAE,EAAE;gBAC1B,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACjC,CAAC,CAAC,CAAC;YACP,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;YAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;QACrD,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,kBAAkB,CAAC,2BAA2B;aAC9C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACb,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,kBAAkB,CAAC,eAAe;aAClC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,IAAgB,EAAE,EAAE;YAC5B,IAAI,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;gBAClE,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aAC9B;YACD,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;YAEjD,sDAAsD;YACtD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAoB,EAAE,EAAE;gBAC/C,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,WAAuB,EAAE,EAAE;oBAC7C,IAAI,WAAW,KAAK,IAAI,EAAE;wBACtB,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;wBAC7B,OAAO;qBACV;gBACL,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,kBAAkB,CAAC,iBAAiB;aACpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,IAAgB,EAAE,EAAE;YAC5B,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;IACX,CAAC;IAEO,cAAc;QAClB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,MAAoB,EAAE,EAAE;YAC/C,MAAM,CAAC,EAAE,GAAG,MAAM,CAAC,EAAE,IAAI,MAAM,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,CAAC;QAC3G,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,eAAe;QACnB,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC;QAClC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;QAE7E,IAAI,IAAI,GAAG,CAAC,SAAS,CAAC,CAAC,IAAI,KAAK,OAAO,CAAC,MAAM,EAAE;YAC5C,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;SACrD;IACL,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,uBAAuB,EAAE,CAAC;QAC3D,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,6BAA6B,EAAE,CAAC;QACvE,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;QACvD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,EAAE,CAAC;QACnD,IAAI,CAAC,kBAAkB,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC3D,CAAC;CACJ,CAAA;;YAhN4C,kBAAkB;;AA1B3D;IADC,KAAK,EAAE;6CACgB;AAGxB;IADC,MAAM,EAAE;mDACmD;AAG5D;IADC,MAAM,EAAE;oDAC2C;AAGpD;IADC,MAAM,EAAE;sDAC+C;AAcpB;IAAnC,eAAe,CAAC,iBAAiB,CAAC;kDAAyC;AAzBnE,eAAe;IAL3B,SAAS,CAAC;QACP,QAAQ,EAAE,UAAU;QACpB,g+EAAsC;;KAEzC,CAAC;GACW,eAAe,CA4O3B;SA5OY,eAAe","sourcesContent":["import { CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\nimport { AfterContentInit, Component, ContentChildren, EventEmitter, Input, OnDestroy, OnInit, Output, QueryList, TemplateRef } from '@angular/core';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { TemplateDirective } from '../template/template.directive';\nimport { KanbanEventService } from './kanban-event.service';\nimport { KanbanColumn, KanbanData, KanbanItem, KanbanItemMovedData, KanbanTemplateTypes } from './models/index';\n\n@Component({\n    selector: 's-kanban',\n    templateUrl: './kanban.component.html',\n    styleUrls: ['./kanban.component.scss'],\n})\nexport class KanbanComponent implements OnInit, AfterContentInit, OnDestroy {\n    @Input()\n    public data: KanbanData;\n\n    @Output()\n    public itemsMoved = new EventEmitter<KanbanItemMovedData>();\n\n    @Output()\n    public dataUpdated = new EventEmitter<KanbanData>();\n\n    @Output()\n    public itemsSelected = new EventEmitter<KanbanItem[]>();\n\n    public selectedColumn: KanbanColumn;\n    public selectedItems = new Set<KanbanItem>();\n    public draggingItems = new Set<KanbanItem>();\n\n    public columnHeaderTemplate: TemplateRef<any>;\n    public columnEmptyMessageTemplate: TemplateRef<any>;\n    public itemHeaderTemplate: TemplateRef<any>;\n    public itemBodyTemplate: TemplateRef<any>;\n    public itemFooterTemplate: TemplateRef<any>;\n\n    private _unsubscribe$ = new Subject<void>();\n\n    @ContentChildren(TemplateDirective) templates: QueryList<TemplateDirective>;\n\n    constructor(\n        private readonly kanbanEventService: KanbanEventService,\n    ) { }\n\n    public ngOnInit(): void {\n        this._subscribeEvents();\n        this._normalizeData();\n        this._validateInputs();\n    }\n\n    ngAfterContentInit() {\n        this._getTemplates();\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n    }\n\n    public drop(event: CdkDragDrop<KanbanItem[]>): void {\n        const previousColumn = this.data.columns.find((column: KanbanColumn) => column.id === event.previousContainer.id);\n        const targetColumn = this.data.columns.find((column: KanbanColumn) => column.id === event.container.id);\n\n        if (!previousColumn || !targetColumn) {\n            throw new Error(\"Unable to obtain information about columns when performing drag and drop\");\n        }\n\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.selectedItems.forEach((item: KanbanItem) => {\n            const previousIndex = event.previousContainer.data.indexOf(item);\n            if (previousIndex !== -1 && item !== event.item.data) {\n                if (event.previousContainer === event.container) {\n                    moveItemInArray(\n                        event.container.data,\n                        previousIndex,\n                        event.currentIndex,\n                    );\n                } else {\n                    transferArrayItem(\n                        event.previousContainer.data,\n                        event.container.data,\n                        previousIndex,\n                        event.currentIndex,\n                    );\n                }\n            }\n        });\n\n        this.selectedItems.add(event.item.data);\n\n        this.itemsMoved.emit({\n            items: [...this.selectedItems],\n            previousColumn,\n            targetColumn,\n        });\n\n        if (this.dataUpdated.observers?.length) {\n            this.dataUpdated.emit({ ...this.data });\n        }\n\n        this.data.columns.forEach((column: KanbanColumn) => {\n            this.kanbanEventService.emitUnselectAllColumnItemsEvent(column);\n        });\n        this.selectedItems.clear();\n    }\n\n    public selectItem(event: MouseEvent, item: KanbanItem, column: KanbanColumn): void {\n        if (event.ctrlKey) {\n            if (this.selectedItems.delete(item)) {\n                this.kanbanEventService.emitUnselectItemEvent(item);\n            } else {\n                if (this.selectedColumn && !this.selectedColumn.items.includes(item)) {\n                    this.selectedItems.clear();\n                }\n\n                this.selectedItems.add(item);\n                this.selectedColumn = column;\n                this.kanbanEventService.emitSelectItemEvent(item);\n            }\n        } else {\n            this.selectedItems.clear();\n            this.selectedItems.add(item);\n            this.selectedColumn = column;\n            this.kanbanEventService.emitSelectItemEvent(item);\n        }\n    }\n\n    public dragStarted(): void {\n        this.selectedItems.forEach((item: KanbanItem) => {\n            this.draggingItems.add(item);\n        });\n    }\n\n    public dragReleased(): void {\n        this.draggingItems.clear();\n    }\n\n    public getLinkedColumns(currentColumn: KanbanColumn) {\n        return this.data.columns\n            .filter((column: KanbanColumn) => column != currentColumn)\n            .map((column: KanbanColumn) => column.id);\n    }\n\n    public getColumnHeaderTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ColumnHeader)\n    }\n\n    public getColumnEmptyMessageTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ColumnEmptyMessage);\n    }\n\n    public getItemHeaderTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ItemHeader);\n    }\n\n    public getItemBodyTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ItemBody);\n    }\n\n    public getItemFooterTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ItemFooter);\n    }\n\n    private _getCustomTemplate(type: string) {\n        return this.templates.find((template: TemplateDirective) => template.type === type)?.template;\n    }\n\n    private _subscribeEvents(): void {\n        this.kanbanEventService.selectAllColumnItemsEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((column: KanbanColumn) => {\n                column.items\n                    .filter((item: KanbanItem) => !item.disabled)\n                    .forEach((item: KanbanItem) => {\n                        this.selectedItems.add(item);\n                    });\n                this.selectedColumn = column;\n                this.itemsSelected.emit([...this.selectedItems]);\n            });\n\n        this.kanbanEventService.unselectAllColumnItemsEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((_) => {\n                this.selectedItems.clear();\n            });\n\n        this.kanbanEventService.selectItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: KanbanItem) => {\n                if (this.selectedColumn && !this.selectedColumn.items.includes(item)) {\n                    this.selectedItems.clear();\n                }\n                this.selectedItems.add(item);\n                this.itemsSelected.emit([...this.selectedItems]);\n\n                // Finding the item column and setting selectedColumn.\n                this.data.columns.forEach((column: KanbanColumn) => {\n                    column.items.forEach((currentItem: KanbanItem) => {\n                        if (currentItem === item) {\n                            this.selectedColumn = column;\n                            return;\n                        }\n                    });\n                });\n            });\n\n        this.kanbanEventService.unselectItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: KanbanItem) => {\n                this.selectedItems.delete(item);\n            });\n    }\n\n    private _normalizeData(): void {\n        this.data.columns.forEach((column: KanbanColumn) => {\n            column.id = column.id || `id-${Math.random().toString(36).substring(2, 9)}-${Date.now().toString(36)}`;\n        });\n    }\n\n    private _validateInputs(): void {\n        const columns = this.data.columns;\n        const columnIds = this.data.columns.map((column: KanbanColumn) => column.id);\n\n        if (new Set(columnIds).size !== columns.length) {\n            throw new Error(\"Repeated IDs are not accepted.\");\n        }\n    }\n\n    private _getTemplates(): void {\n        this.columnHeaderTemplate = this.getColumnHeaderTemplate();\n        this.columnEmptyMessageTemplate = this.getColumnEmptyMessageTemplate();\n        this.itemHeaderTemplate = this.getItemHeaderTemplate();\n        this.itemBodyTemplate = this.getItemBodyTemplate();\n        this.itemFooterTemplate = this.getItemFooterTemplate();\n    }\n}\n"]}
|
|
217
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kanban.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/kanban/kanban.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDragDrop, moveItemInArray, transferArrayItem } from \"@angular/cdk/drag-drop\";\nimport {\n    AfterContentInit,\n    Component,\n    ContentChildren,\n    EventEmitter,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    TemplateRef,\n} from \"@angular/core\";\n\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\nimport { TemplateDirective } from \"../template/template.directive\";\nimport { KanbanEventService } from \"./kanban-event.service\";\nimport { KanbanColumn, KanbanData, KanbanItem, KanbanItemMovedData, KanbanTemplateTypes } from \"./models/index\";\n\n@Component({\n    selector: \"s-kanban\",\n    templateUrl: \"./kanban.component.html\",\n    styleUrls: [\"./kanban.component.scss\"],\n})\nexport class KanbanComponent implements OnInit, AfterContentInit, OnDestroy {\n    @Input()\n    public data: KanbanData;\n\n    @Input()\n    public showItemCheckboxes = true;\n\n    @Input()\n    public showColumnCheckboxes = true;\n\n    @Output()\n    public itemsMoved = new EventEmitter<KanbanItemMovedData>();\n\n    @Output()\n    public dataUpdated = new EventEmitter<KanbanData>();\n\n    @Output()\n    public itemsSelected = new EventEmitter<KanbanItem[]>();\n\n    public selectedColumn: KanbanColumn;\n    public selectedItems = new Set<KanbanItem>();\n    public draggingItems = new Set<KanbanItem>();\n\n    public columnHeaderTemplate: TemplateRef<any>;\n    public columnEmptyMessageTemplate: TemplateRef<any>;\n    public itemHeaderTemplate: TemplateRef<any>;\n    public itemBodyTemplate: TemplateRef<any>;\n    public itemFooterTemplate: TemplateRef<any>;\n\n    private _unsubscribe$ = new Subject<void>();\n\n    @ContentChildren(TemplateDirective) templates: QueryList<TemplateDirective>;\n\n    constructor(private readonly kanbanEventService: KanbanEventService) {}\n\n    public ngOnInit(): void {\n        this._subscribeEvents();\n        this._normalizeData();\n        this._validateInputs();\n    }\n\n    ngAfterContentInit() {\n        this._getTemplates();\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n    }\n\n    public drop(event: CdkDragDrop<KanbanItem[]>): void {\n        const previousColumn = this.data.columns.find((column: KanbanColumn) => column.id === event.previousContainer.id);\n        const targetColumn = this.data.columns.find((column: KanbanColumn) => column.id === event.container.id);\n\n        if (!previousColumn || !targetColumn) {\n            throw new Error(\"Unable to obtain information about columns when performing drag and drop\");\n        }\n\n        if (event.previousContainer === event.container) {\n            moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\n        } else {\n            transferArrayItem(event.previousContainer.data, event.container.data, event.previousIndex, event.currentIndex);\n        }\n\n        this.selectedItems.forEach((item: KanbanItem) => {\n            const previousIndex = event.previousContainer.data.indexOf(item);\n            if (previousIndex !== -1 && item !== event.item.data) {\n                if (event.previousContainer === event.container) {\n                    moveItemInArray(event.container.data, previousIndex, event.currentIndex);\n                } else {\n                    transferArrayItem(event.previousContainer.data, event.container.data, previousIndex, event.currentIndex);\n                }\n            }\n        });\n\n        this.selectedItems.add(event.item.data);\n\n        this.itemsMoved.emit({\n            items: [...this.selectedItems],\n            previousColumn,\n            targetColumn,\n        });\n\n        if (this.dataUpdated.observers?.length) {\n            this.dataUpdated.emit({ ...this.data });\n        }\n\n        this.data.columns.forEach((column: KanbanColumn) => {\n            this.kanbanEventService.emitUnselectAllColumnItemsEvent(column);\n        });\n        this.selectedItems.clear();\n    }\n\n    public selectItem(event: MouseEvent, item: KanbanItem, column: KanbanColumn): void {\n        if (item.disabled || item.frozen) return;\n\n        if (event.ctrlKey) {\n            if (this.selectedItems.delete(item)) {\n                this.kanbanEventService.emitUnselectItemEvent(item);\n            } else {\n                if (this.selectedColumn && !this.selectedColumn.items.includes(item)) {\n                    this.selectedItems.clear();\n                }\n\n                this.selectedItems.add(item);\n                this.selectedColumn = column;\n                this.kanbanEventService.emitSelectItemEvent(item);\n            }\n        } else {\n            if (this.selectedItems.delete(item)) return;\n\n            this.selectedItems.clear();\n            this.selectedItems.add(item);\n            this.selectedColumn = column;\n            this.kanbanEventService.emitSelectItemEvent(item);\n        }\n    }\n\n    public dragStarted(): void {\n        this.selectedItems.forEach((item: KanbanItem) => {\n            this.draggingItems.add(item);\n        });\n    }\n\n    public dragReleased(): void {\n        this.draggingItems.clear();\n    }\n\n    public getLinkedColumns(currentColumn: KanbanColumn) {\n        return this.data.columns.filter((column: KanbanColumn) => column != currentColumn).map((column: KanbanColumn) => column.id);\n    }\n\n    public getColumnHeaderTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ColumnHeader);\n    }\n\n    public getColumnEmptyMessageTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ColumnEmptyMessage);\n    }\n\n    public getItemHeaderTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ItemHeader);\n    }\n\n    public getItemBodyTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ItemBody);\n    }\n\n    public getItemFooterTemplate(): TemplateRef<any> {\n        return this._getCustomTemplate(KanbanTemplateTypes.ItemFooter);\n    }\n\n    private _getCustomTemplate(type: string) {\n        return this.templates.find((template: TemplateDirective) => template.type === type)?.template;\n    }\n\n    private _subscribeEvents(): void {\n        this.kanbanEventService.selectAllColumnItemsEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((column: KanbanColumn) => {\n            column.items\n                .filter((item: KanbanItem) => !item.disabled && !item.frozen)\n                .forEach((item: KanbanItem) => {\n                    this.selectedItems.add(item);\n                });\n            this.selectedColumn = column;\n            this.itemsSelected.emit([...this.selectedItems]);\n        });\n\n        this.kanbanEventService.unselectAllColumnItemsEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((_) => {\n                this.selectedItems.clear();\n            });\n\n        this.kanbanEventService.selectItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: KanbanItem) => {\n                if (this.selectedColumn && !this.selectedColumn.items.includes(item)) {\n                    this.selectedItems.clear();\n                }\n                this.selectedItems.add(item);\n                this.itemsSelected.emit([...this.selectedItems]);\n\n                // Finding the item column and setting selectedColumn.\n                this.data.columns.forEach((column: KanbanColumn) => {\n                    column.items.forEach((currentItem: KanbanItem) => {\n                        if (currentItem === item) {\n                            this.selectedColumn = column;\n                            return;\n                        }\n                    });\n                });\n            });\n\n        this.kanbanEventService.unselectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item: KanbanItem) => {\n            this.selectedItems.delete(item);\n        });\n    }\n\n    private _normalizeData(): void {\n        this.data.columns.forEach((column: KanbanColumn) => {\n            column.id = column.id || `id-${Math.random().toString(36).substring(2, 9)}-${Date.now().toString(36)}`;\n        });\n    }\n\n    private _validateInputs(): void {\n        const columns = this.data.columns;\n        const columnIds = this.data.columns.map((column: KanbanColumn) => column.id);\n\n        if (new Set(columnIds).size !== columns.length) {\n            throw new Error(\"Repeated IDs are not accepted.\");\n        }\n    }\n\n    private _getTemplates(): void {\n        this.columnHeaderTemplate = this.getColumnHeaderTemplate();\n        this.columnEmptyMessageTemplate = this.getColumnEmptyMessageTemplate();\n        this.itemHeaderTemplate = this.getItemHeaderTemplate();\n        this.itemBodyTemplate = this.getItemBodyTemplate();\n        this.itemFooterTemplate = this.getItemFooterTemplate();\n    }\n}\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export { KanbanTemplateTypes } from "./kanban-template-types";
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgS2FuYmFuRGF0YSwgS2FuYmFuQ29sdW1uLCBLYW5iYW5JdGVtLCBLYW5iYW5JdGVtTW92ZWREYXRhLCBLYW5iYW5JdGVtT3B0aW9uIH0gZnJvbSBcIi4va2FuYmFuLWRhdGFcIjtcbmV4cG9ydCB7IEthbmJhblRlbXBsYXRlVHlwZXMgfSBmcm9tIFwiLi9rYW5iYW4tdGVtcGxhdGUtdHlwZXNcIjtcbiJdfQ==
|
|
@@ -1 +1 @@
|
|
|
1
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWRhdGEuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2thbmJhbi1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaWVyZWRNZW51SXRlbURhdGEgfSBmcm9tIFwiLi4vLi4vdGllcmVkLW1lbnUvbW9kZWxzL3RpZXJlZC1tZW51LWl0ZW0tZGF0YVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkRhdGEge1xuICAgIGNvbHVtbnM6IEthbmJhbkNvbHVtbltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkNvbHVtbiB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdO1xuICAgIG9wdGlvbnM/
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWRhdGEuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2thbmJhbi1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaWVyZWRNZW51SXRlbURhdGEgfSBmcm9tIFwiLi4vLi4vdGllcmVkLW1lbnUvbW9kZWxzL3RpZXJlZC1tZW51LWl0ZW0tZGF0YVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkRhdGEge1xuICAgIGNvbHVtbnM6IEthbmJhbkNvbHVtbltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkNvbHVtbiB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdO1xuICAgIG9wdGlvbnM/OiBLYW5iYW5Db2x1bW5PcHRpb25bXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtIHtcbiAgICBvcHRpb25zPzogS2FuYmFuSXRlbU9wdGlvbltdO1xuICAgIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgICBmcm96ZW4/OiBib29sZWFuO1xuICAgIGRhdGE6IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtTW92ZWREYXRhIHtcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdLFxuICAgIHByZXZpb3VzQ29sdW1uOiBLYW5iYW5Db2x1bW47XG4gICAgdGFyZ2V0Q29sdW1uOiBLYW5iYW5Db2x1bW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgS2FuYmFuQ29sdW1uT3B0aW9uIGV4dGVuZHMgT21pdDxUaWVyZWRNZW51SXRlbURhdGEsICdjb21tYW5kJz4ge1xuICAgIGNvbW1hbmQ6IChjb2x1bW46IEthbmJhbkNvbHVtbikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtT3B0aW9uIGV4dGVuZHMgT21pdDxUaWVyZWRNZW51SXRlbURhdGEsICdjb21tYW5kJz4ge1xuICAgIGNvbW1hbmQ6IChpdGVtOiBLYW5iYW5JdGVtKSA9PiB2b2lkO1xufVxuIl19
|
|
@@ -28,6 +28,10 @@ let NavigationButtonComponent = NavigationButtonComponent_1 = class NavigationBu
|
|
|
28
28
|
this._value = this.defaultValue;
|
|
29
29
|
const index = this.steps.findIndex((step) => step.value === this._value);
|
|
30
30
|
this.currentIndex = index !== -1 ? index : 0;
|
|
31
|
+
this.stepChanged.emit({
|
|
32
|
+
previous: undefined,
|
|
33
|
+
current: this.steps[this.currentIndex],
|
|
34
|
+
});
|
|
31
35
|
this.changeDetectorRef.detectChanges();
|
|
32
36
|
}
|
|
33
37
|
}
|
|
@@ -119,4 +123,4 @@ NavigationButtonComponent = NavigationButtonComponent_1 = __decorate([
|
|
|
119
123
|
})
|
|
120
124
|
], NavigationButtonComponent);
|
|
121
125
|
export { NavigationButtonComponent };
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-button.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/navigation-button/navigation-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef, OnInit, AfterViewInit, ChangeDetectorRef } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { NavigationButtonItem } from \"./models/navigation-button-item\";\nimport { TieredMenuItemData } from \"../tiered-menu\";\nimport { NavigationButtonStepChangedInfo } from \"./models\";\n\n@Component({\n    selector: \"s-navigation-button\",\n    templateUrl: \"./navigation-button.component.html\",\n    styleUrls: [\"./navigation-button.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NavigationButtonComponent),\n            multi: true,\n        },\n    ],\n})\nexport class NavigationButtonComponent implements ControlValueAccessor, OnInit, AfterViewInit {\n    @Input()\n    public steps: NavigationButtonItem[];\n\n    @Input()\n    public defaultValue: unknown;\n\n    @Input()\n    public tooltip: string;\n\n    @Input()\n    public changeOnInit = false;\n\n    @Output()\n    public stepChanged: EventEmitter<NavigationButtonStepChangedInfo> = new EventEmitter();\n\n    public currentIndex = 0;\n    public isDisabled = false;\n    public tieredMenuItems: TieredMenuItemData[] = [];\n\n    private _onChange: (value: unknown) => void;\n    private _onTouched: () => void;\n    private _value: unknown;\n\n    constructor(private readonly changeDetectorRef: ChangeDetectorRef) { }\n\n    public ngOnInit(): void {\n        this._createTieredMenuItems();\n\n        if (this.changeOnInit) {\n            this.stepChanged.emit({\n                previous: undefined,\n                current: this.steps[this.currentIndex],\n            });\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        this._setDefaultValue();\n    }\n\n    private _setDefaultValue(): void {\n        if (this.defaultValue) {\n            this._value = this.defaultValue;\n\n            const index = this.steps.findIndex((step) => step.value === this._value);\n            this.currentIndex = index !== -1 ? index : 0;\n\n            this.changeDetectorRef.detectChanges();\n        }\n    }\n\n    public writeValue(value: unknown): void {\n        this._value = value;\n\n        const index = this.steps.findIndex((step) => step.value === this._value);\n        this.currentIndex = index !== -1 ? index : 0;\n    }\n\n    public registerOnChange(onChange: (value: unknown) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this._onTouched = onTouched;\n    }\n\n    public setDisabledState?(isDisabled: boolean): void {\n        this.isDisabled = isDisabled;\n    }\n\n    public onNext(): void {\n        if (this.isDisabled) return;\n\n        const previous = this.steps[this.currentIndex];\n\n        if (this.currentIndex < this.steps.length - 1) {\n            this.currentIndex++;\n\n            const current = this.steps[this.currentIndex];\n\n            this._onChange && this._onChange(current.value);\n            this.stepChanged.emit({ previous, current });\n        }\n\n        this._onTouched && this._onTouched();\n    }\n\n    public onPrevious(): void {\n        if (this.isDisabled) return;\n\n        const previous = this.steps[this.currentIndex];\n\n        if (this.currentIndex > 0) {\n            this.currentIndex--;\n\n            const current = this.steps[this.currentIndex];\n\n            this._onChange && this._onChange(current.value);\n            this.stepChanged.emit({ previous, current });\n        }\n\n        this._onTouched && this._onTouched();\n    }\n\n    private _createTieredMenuItems() {\n        this.steps.forEach((step: NavigationButtonItem) => {\n            this.tieredMenuItems.push({\n                label: step.label,\n                command: () => {\n                    const index = this.steps.findIndex((s) => s === step);\n                    if (this.currentIndex !== index) {\n                        this._onChange && this._onChange(step.value);\n                        this.stepChanged.emit({ previous: this.steps[this.currentIndex], current: step });\n                        this.currentIndex = index;\n                    }\n\n                    this._onTouched && this._onTouched();\n                },\n            });\n        });\n    }\n}\n"]}
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation-button.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/navigation-button/navigation-button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, forwardRef, OnInit, AfterViewInit, ChangeDetectorRef } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\n\nimport { NavigationButtonItem } from \"./models/navigation-button-item\";\nimport { TieredMenuItemData } from \"../tiered-menu\";\nimport { NavigationButtonStepChangedInfo } from \"./models\";\n\n@Component({\n    selector: \"s-navigation-button\",\n    templateUrl: \"./navigation-button.component.html\",\n    styleUrls: [\"./navigation-button.component.scss\"],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => NavigationButtonComponent),\n            multi: true,\n        },\n    ],\n})\nexport class NavigationButtonComponent implements ControlValueAccessor, OnInit, AfterViewInit {\n    @Input()\n    public steps: NavigationButtonItem[];\n\n    @Input()\n    public defaultValue: unknown;\n\n    @Input()\n    public tooltip: string;\n\n    @Input()\n    public changeOnInit = false;\n\n    @Output()\n    public stepChanged: EventEmitter<NavigationButtonStepChangedInfo> = new EventEmitter();\n\n    public currentIndex = 0;\n    public isDisabled = false;\n    public tieredMenuItems: TieredMenuItemData[] = [];\n\n    private _onChange: (value: unknown) => void;\n    private _onTouched: () => void;\n    private _value: unknown;\n\n    constructor(private readonly changeDetectorRef: ChangeDetectorRef) { }\n\n    public ngOnInit(): void {\n        this._createTieredMenuItems();\n\n        if (this.changeOnInit) {\n            this.stepChanged.emit({\n                previous: undefined,\n                current: this.steps[this.currentIndex],\n            });\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        this._setDefaultValue();\n    }\n\n    private _setDefaultValue(): void {\n        if (this.defaultValue) {\n            this._value = this.defaultValue;\n\n            const index = this.steps.findIndex((step) => step.value === this._value);\n            this.currentIndex = index !== -1 ? index : 0;\n            this.stepChanged.emit({\n                previous: undefined,\n                current: this.steps[this.currentIndex],\n            });\n\n            this.changeDetectorRef.detectChanges();\n        }\n    }\n\n    public writeValue(value: unknown): void {\n        this._value = value;\n\n        const index = this.steps.findIndex((step) => step.value === this._value);\n        this.currentIndex = index !== -1 ? index : 0;\n    }\n\n    public registerOnChange(onChange: (value: unknown) => void): void {\n        this._onChange = onChange;\n    }\n\n    public registerOnTouched(onTouched: () => void): void {\n        this._onTouched = onTouched;\n    }\n\n    public setDisabledState?(isDisabled: boolean): void {\n        this.isDisabled = isDisabled;\n    }\n\n    public onNext(): void {\n        if (this.isDisabled) return;\n\n        const previous = this.steps[this.currentIndex];\n\n        if (this.currentIndex < this.steps.length - 1) {\n            this.currentIndex++;\n\n            const current = this.steps[this.currentIndex];\n\n            this._onChange && this._onChange(current.value);\n            this.stepChanged.emit({ previous, current });\n        }\n\n        this._onTouched && this._onTouched();\n    }\n\n    public onPrevious(): void {\n        if (this.isDisabled) return;\n\n        const previous = this.steps[this.currentIndex];\n\n        if (this.currentIndex > 0) {\n            this.currentIndex--;\n\n            const current = this.steps[this.currentIndex];\n\n            this._onChange && this._onChange(current.value);\n            this.stepChanged.emit({ previous, current });\n        }\n\n        this._onTouched && this._onTouched();\n    }\n\n    private _createTieredMenuItems() {\n        this.steps.forEach((step: NavigationButtonItem) => {\n            this.tieredMenuItems.push({\n                label: step.label,\n                command: () => {\n                    const index = this.steps.findIndex((s) => s === step);\n                    if (this.currentIndex !== index) {\n                        this._onChange && this._onChange(step.value);\n                        this.stepChanged.emit({ previous: this.steps[this.currentIndex], current: step });\n                        this.currentIndex = index;\n                    }\n\n                    this._onTouched && this._onTouched();\n                },\n            });\n        });\n    }\n}\n"]}
|