@seniorsistemas/angular-components 17.9.1 → 17.9.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (25) hide show
  1. package/bundles/seniorsistemas-angular-components.umd.js +50 -14
  2. package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
  3. package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
  4. package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
  5. package/components/kanban/components/kanban-column/kanban-column.component.d.ts +2 -0
  6. package/components/kanban/components/kanban-item/kanban-item.component.d.ts +7 -4
  7. package/components/kanban/kanban.component.d.ts +7 -5
  8. package/components/kanban/models/index.d.ts +1 -1
  9. package/components/kanban/models/kanban-data.d.ts +9 -2
  10. package/esm2015/components/kanban/components/kanban-column/kanban-column.component.js +14 -2
  11. package/esm2015/components/kanban/components/kanban-item/kanban-item.component.js +20 -6
  12. package/esm2015/components/kanban/kanban.component.js +26 -18
  13. package/esm2015/components/kanban/models/index.js +1 -1
  14. package/esm2015/components/kanban/models/kanban-data.js +1 -1
  15. package/esm5/components/kanban/components/kanban-column/kanban-column.component.js +16 -3
  16. package/esm5/components/kanban/components/kanban-item/kanban-item.component.js +22 -7
  17. package/esm5/components/kanban/kanban.component.js +26 -18
  18. package/esm5/components/kanban/models/index.js +1 -1
  19. package/esm5/components/kanban/models/kanban-data.js +1 -1
  20. package/fesm2015/seniorsistemas-angular-components.js +48 -14
  21. package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
  22. package/fesm5/seniorsistemas-angular-components.js +50 -14
  23. package/fesm5/seniorsistemas-angular-components.js.map +1 -1
  24. package/package.json +1 -1
  25. package/seniorsistemas-angular-components.metadata.json +1 -1
@@ -1,11 +1,15 @@
1
- import { __decorate } from "tslib";
2
- import { Component, Input } from '@angular/core';
3
- import { KanbanEventService } from '../../kanban-event.service';
1
+ import { __assign, __decorate } from "tslib";
2
+ import { Component, Input } from "@angular/core";
3
+ import { KanbanEventService } from "../../kanban-event.service";
4
4
  var KanbanItemComponent = /** @class */ (function () {
5
5
  function KanbanItemComponent(_kanbanEventService) {
6
6
  this._kanbanEventService = _kanbanEventService;
7
7
  this.selected = false;
8
+ this.showCheckbox = true;
8
9
  }
10
+ KanbanItemComponent.prototype.ngOnInit = function () {
11
+ this._createTieredOptions();
12
+ };
9
13
  KanbanItemComponent.prototype.onSelectedChange = function (value) {
10
14
  if (value) {
11
15
  this._kanbanEventService.emitSelectItemEvent(this.item);
@@ -14,6 +18,14 @@ var KanbanItemComponent = /** @class */ (function () {
14
18
  this._kanbanEventService.emitUnselectItemEvent(this.item);
15
19
  }
16
20
  };
21
+ KanbanItemComponent.prototype._createTieredOptions = function () {
22
+ var _this = this;
23
+ var options = [];
24
+ this.item.options.forEach(function (option) {
25
+ options.push(__assign(__assign({}, option), { command: function () { option.command(_this.item); } }));
26
+ });
27
+ this.item.options = options;
28
+ };
17
29
  KanbanItemComponent.ctorParameters = function () { return [
18
30
  { type: KanbanEventService }
19
31
  ]; };
@@ -23,6 +35,9 @@ var KanbanItemComponent = /** @class */ (function () {
23
35
  __decorate([
24
36
  Input()
25
37
  ], KanbanItemComponent.prototype, "selected", void 0);
38
+ __decorate([
39
+ Input()
40
+ ], KanbanItemComponent.prototype, "showCheckbox", void 0);
26
41
  __decorate([
27
42
  Input()
28
43
  ], KanbanItemComponent.prototype, "headerTemplate", void 0);
@@ -34,12 +49,12 @@ var KanbanItemComponent = /** @class */ (function () {
34
49
  ], KanbanItemComponent.prototype, "footerTemplate", void 0);
35
50
  KanbanItemComponent = __decorate([
36
51
  Component({
37
- selector: 's-kanban-item',
38
- 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>",
39
- 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}"]
40
55
  })
41
56
  ], KanbanItemComponent);
42
57
  return KanbanItemComponent;
43
58
  }());
44
59
  export { KanbanItemComponent };
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMva2FuYmFuL2NvbXBvbmVudHMva2FuYmFuLWl0ZW0va2FuYmFuLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBZSxNQUFNLGVBQWUsQ0FBQztBQUc5RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQU9oRTtJQWdCRSw2QkFDbUIsbUJBQXVDO1FBQXZDLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBb0I7UUFabkQsYUFBUSxHQUFHLEtBQUssQ0FBQztJQWFwQixDQUFDO0lBRUUsOENBQWdCLEdBQXZCLFVBQXdCLEtBQVU7UUFDaEMsSUFBSSxLQUFLLEVBQUU7WUFDVCxJQUFJLENBQUMsbUJBQW1CLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3pEO2FBQU07WUFDTCxJQUFJLENBQUMsbUJBQW1CLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzNEO0lBQ0gsQ0FBQzs7Z0JBVHVDLGtCQUFrQjs7SUFmMUQ7UUFEQyxLQUFLLEVBQUU7cURBQ2dCO0lBR3hCO1FBREMsS0FBSyxFQUFFO3lEQUNnQjtJQUd4QjtRQURDLEtBQUssRUFBRTsrREFDZ0M7SUFHeEM7UUFEQyxLQUFLLEVBQUU7NkRBQzhCO0lBR3RDO1FBREMsS0FBSyxFQUFFOytEQUNnQztJQWQ3QixtQkFBbUI7UUFML0IsU0FBUyxDQUFDO1lBQ1QsUUFBUSxFQUFFLGVBQWU7WUFDekIsOCtDQUEyQzs7U0FFNUMsQ0FBQztPQUNXLG1CQUFtQixDQTJCL0I7SUFBRCwwQkFBQztDQUFBLEFBM0JELElBMkJDO1NBM0JZLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEthbmJhbkl0ZW0gfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xuaW1wb3J0IHsgS2FuYmFuRXZlbnRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4va2FuYmFuLWV2ZW50LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzLWthbmJhbi1pdGVtJyxcbiAgdGVtcGxhdGVVcmw6IFwiLi9rYW5iYW4taXRlbS5jb21wb25lbnQuaHRtbFwiLFxuICBzdHlsZVVybHM6IFtcIi4va2FuYmFuLWl0ZW0uY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIEthbmJhbkl0ZW1Db21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgaXRlbTogS2FuYmFuSXRlbTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgc2VsZWN0ZWQgPSBmYWxzZTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgaGVhZGVyVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgQElucHV0KClcbiAgcHVibGljIGJvZHlUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgZm9vdGVyVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZWFkb25seSBfa2FuYmFuRXZlbnRTZXJ2aWNlOiBLYW5iYW5FdmVudFNlcnZpY2UsXG4gICkgeyB9XG5cbiAgcHVibGljIG9uU2VsZWN0ZWRDaGFuZ2UodmFsdWU6IGFueSkge1xuICAgIGlmICh2YWx1ZSkge1xuICAgICAgdGhpcy5fa2FuYmFuRXZlbnRTZXJ2aWNlLmVtaXRTZWxlY3RJdGVtRXZlbnQodGhpcy5pdGVtKTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5fa2FuYmFuRXZlbnRTZXJ2aWNlLmVtaXRVbnNlbGVjdEl0ZW1FdmVudCh0aGlzLml0ZW0pO1xuICAgIH1cbiAgfVxufVxuIl19
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMva2FuYmFuL2NvbXBvbmVudHMva2FuYmFuLWl0ZW0va2FuYmFuLWl0ZW0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFHdEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFRaEU7SUFtQkksNkJBQTZCLG1CQUF1QztRQUF2Qyx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQW9CO1FBZDdELGFBQVEsR0FBRyxLQUFLLENBQUM7UUFHakIsaUJBQVksR0FBRyxJQUFJLENBQUM7SUFXNEMsQ0FBQztJQUVqRSxzQ0FBUSxHQUFmO1FBQ0ksSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVNLDhDQUFnQixHQUF2QixVQUF3QixLQUFVO1FBQzlCLElBQUksS0FBSyxFQUFFO1lBQ1AsSUFBSSxDQUFDLG1CQUFtQixDQUFDLG1CQUFtQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUMzRDthQUFNO1lBQ0gsSUFBSSxDQUFDLG1CQUFtQixDQUFDLHFCQUFxQixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUM3RDtJQUNMLENBQUM7SUFFTyxrREFBb0IsR0FBNUI7UUFBQSxpQkFXQztRQVZHLElBQU0sT0FBTyxHQUF1QixFQUFFLENBQUM7UUFFdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLFVBQUMsTUFBd0I7WUFDakQsT0FBTyxDQUFDLElBQUksdUJBQ1AsTUFBTSxLQUNULE9BQU8sRUFBRSxjQUFRLE1BQU0sQ0FBQyxPQUFPLENBQUMsS0FBSSxDQUFDLElBQUksQ0FBQyxDQUFBLENBQUMsQ0FBQyxJQUM1QyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sR0FBRyxPQUFPLENBQUM7SUFDaEMsQ0FBQzs7Z0JBekJpRCxrQkFBa0I7O0lBakJwRTtRQURDLEtBQUssRUFBRTtxREFDZ0I7SUFHeEI7UUFEQyxLQUFLLEVBQUU7eURBQ2dCO0lBR3hCO1FBREMsS0FBSyxFQUFFOzZEQUNtQjtJQUczQjtRQURDLEtBQUssRUFBRTsrREFDZ0M7SUFHeEM7UUFEQyxLQUFLLEVBQUU7NkRBQzhCO0lBR3RDO1FBREMsS0FBSyxFQUFFOytEQUNnQztJQWpCL0IsbUJBQW1CO1FBTC9CLFNBQVMsQ0FBQztZQUNQLFFBQVEsRUFBRSxlQUFlO1lBQ3pCLDZrREFBMkM7O1NBRTlDLENBQUM7T0FDVyxtQkFBbUIsQ0E2Qy9CO0lBQUQsMEJBQUM7Q0FBQSxBQTdDRCxJQTZDQztTQTdDWSxtQkFBbUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkluaXQsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuaW1wb3J0IHsgS2FuYmFuSXRlbSB9IGZyb20gXCIuLi8uLi9tb2RlbHNcIjtcbmltcG9ydCB7IEthbmJhbkV2ZW50U2VydmljZSB9IGZyb20gXCIuLi8uLi9rYW5iYW4tZXZlbnQuc2VydmljZVwiO1xuaW1wb3J0IHsgS2FuYmFuSXRlbU9wdGlvbiB9IGZyb20gXCIuLi8uLi9tb2RlbHMva2FuYmFuLWRhdGFcIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy1rYW5iYW4taXRlbVwiLFxuICAgIHRlbXBsYXRlVXJsOiBcIi4va2FuYmFuLWl0ZW0uY29tcG9uZW50Lmh0bWxcIixcbiAgICBzdHlsZVVybHM6IFtcIi4va2FuYmFuLWl0ZW0uY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIEthbmJhbkl0ZW1Db21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGl0ZW06IEthbmJhbkl0ZW07XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzZWxlY3RlZCA9IGZhbHNlO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgc2hvd0NoZWNrYm94ID0gdHJ1ZTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGhlYWRlclRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgYm9keVRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgZm9vdGVyVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT47XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IF9rYW5iYW5FdmVudFNlcnZpY2U6IEthbmJhbkV2ZW50U2VydmljZSkge31cblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fY3JlYXRlVGllcmVkT3B0aW9ucygpO1xuICAgIH1cblxuICAgIHB1YmxpYyBvblNlbGVjdGVkQ2hhbmdlKHZhbHVlOiBhbnkpOiB2b2lkIHtcbiAgICAgICAgaWYgKHZhbHVlKSB7XG4gICAgICAgICAgICB0aGlzLl9rYW5iYW5FdmVudFNlcnZpY2UuZW1pdFNlbGVjdEl0ZW1FdmVudCh0aGlzLml0ZW0pO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5fa2FuYmFuRXZlbnRTZXJ2aWNlLmVtaXRVbnNlbGVjdEl0ZW1FdmVudCh0aGlzLml0ZW0pO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfY3JlYXRlVGllcmVkT3B0aW9ucygpOiB2b2lkIHtcbiAgICAgICAgY29uc3Qgb3B0aW9uczogS2FuYmFuSXRlbU9wdGlvbltdID0gW107XG5cbiAgICAgICAgdGhpcy5pdGVtLm9wdGlvbnMuZm9yRWFjaCgob3B0aW9uOiBLYW5iYW5JdGVtT3B0aW9uKSA9PiB7XG4gICAgICAgICAgb3B0aW9ucy5wdXNoKHtcbiAgICAgICAgICAgIC4uLm9wdGlvbixcbiAgICAgICAgICAgIGNvbW1hbmQ6ICgpID0+IHsgb3B0aW9uLmNvbW1hbmQodGhpcy5pdGVtKSB9LFxuICAgICAgICAgIH0pO1xuICAgICAgICB9KTtcblxuICAgICAgICB0aGlzLml0ZW0ub3B0aW9ucyA9IG9wdGlvbnM7XG4gICAgfVxufVxuIl19
@@ -1,14 +1,16 @@
1
1
  import { __assign, __decorate, __read, __spread } from "tslib";
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';
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
  var KanbanComponent = /** @class */ (function () {
10
10
  function KanbanComponent(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();
@@ -68,6 +70,8 @@ var KanbanComponent = /** @class */ (function () {
68
70
  this.selectedItems.clear();
69
71
  };
70
72
  KanbanComponent.prototype.selectItem = function (event, item, column) {
73
+ if (item.disabled || item.frozen)
74
+ return;
71
75
  if (event.ctrlKey) {
72
76
  if (this.selectedItems.delete(item)) {
73
77
  this.kanbanEventService.emitUnselectItemEvent(item);
@@ -82,6 +86,8 @@ var KanbanComponent = /** @class */ (function () {
82
86
  }
83
87
  }
84
88
  else {
89
+ if (this.selectedItems.delete(item))
90
+ return;
85
91
  this.selectedItems.clear();
86
92
  this.selectedItems.add(item);
87
93
  this.selectedColumn = column;
@@ -98,9 +104,7 @@ var KanbanComponent = /** @class */ (function () {
98
104
  this.draggingItems.clear();
99
105
  };
100
106
  KanbanComponent.prototype.getLinkedColumns = function (currentColumn) {
101
- return this.data.columns
102
- .filter(function (column) { return column != currentColumn; })
103
- .map(function (column) { return column.id; });
107
+ return this.data.columns.filter(function (column) { return column != currentColumn; }).map(function (column) { return column.id; });
104
108
  };
105
109
  KanbanComponent.prototype.getColumnHeaderTemplate = function () {
106
110
  return this._getCustomTemplate(KanbanTemplateTypes.ColumnHeader);
@@ -127,7 +131,7 @@ var KanbanComponent = /** @class */ (function () {
127
131
  .pipe(takeUntil(this._unsubscribe$))
128
132
  .subscribe(function (column) {
129
133
  column.items
130
- .filter(function (item) { return !item.disabled; })
134
+ .filter(function (item) { return !item.disabled && !item.frozen; })
131
135
  .forEach(function (item) {
132
136
  _this.selectedItems.add(item);
133
137
  });
@@ -157,9 +161,7 @@ var KanbanComponent = /** @class */ (function () {
157
161
  });
158
162
  });
159
163
  });
160
- this.kanbanEventService.unselectItemEvent
161
- .pipe(takeUntil(this._unsubscribe$))
162
- .subscribe(function (item) {
164
+ this.kanbanEventService.unselectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(function (item) {
163
165
  _this.selectedItems.delete(item);
164
166
  });
165
167
  };
@@ -188,6 +190,12 @@ var KanbanComponent = /** @class */ (function () {
188
190
  __decorate([
189
191
  Input()
190
192
  ], KanbanComponent.prototype, "data", void 0);
193
+ __decorate([
194
+ Input()
195
+ ], KanbanComponent.prototype, "showItemCheckboxes", void 0);
196
+ __decorate([
197
+ Input()
198
+ ], KanbanComponent.prototype, "showColumnCheckboxes", void 0);
191
199
  __decorate([
192
200
  Output()
193
201
  ], KanbanComponent.prototype, "itemsMoved", void 0);
@@ -202,12 +210,12 @@ var KanbanComponent = /** @class */ (function () {
202
210
  ], KanbanComponent.prototype, "templates", void 0);
203
211
  KanbanComponent = __decorate([
204
212
  Component({
205
- selector: 's-kanban',
206
- 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>&nbsp;\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",
207
- 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%}"]
213
+ selector: "s-kanban",
214
+ 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>&nbsp;\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",
215
+ 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%}"]
208
216
  })
209
217
  ], KanbanComponent);
210
218
  return KanbanComponent;
211
219
  }());
212
220
  export { KanbanComponent };
213
- //# 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 { 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"]}
221
+ //# 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgS2FuYmFuRGF0YSwgS2FuYmFuQ29sdW1uLCBLYW5iYW5JdGVtLCBLYW5iYW5JdGVtTW92ZWREYXRhIH0gZnJvbSBcIi4va2FuYmFuLWRhdGFcIjtcbmV4cG9ydCB7IEthbmJhblRlbXBsYXRlVHlwZXMgfSBmcm9tIFwiLi9rYW5iYW4tdGVtcGxhdGUtdHlwZXNcIjtcbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgS2FuYmFuRGF0YSwgS2FuYmFuQ29sdW1uLCBLYW5iYW5JdGVtLCBLYW5iYW5JdGVtTW92ZWREYXRhLCBLYW5iYW5JdGVtT3B0aW9uIH0gZnJvbSBcIi4va2FuYmFuLWRhdGFcIjtcbmV4cG9ydCB7IEthbmJhblRlbXBsYXRlVHlwZXMgfSBmcm9tIFwiLi9rYW5iYW4tdGVtcGxhdGUtdHlwZXNcIjtcbiJdfQ==
@@ -1 +1 @@
1
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWRhdGEuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2thbmJhbi1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaWVyZWRNZW51SXRlbURhdGEgfSBmcm9tIFwiLi4vLi4vdGllcmVkLW1lbnUvbW9kZWxzL3RpZXJlZC1tZW51LWl0ZW0tZGF0YVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkRhdGEge1xuICAgIGNvbHVtbnM6IEthbmJhbkNvbHVtbltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkNvbHVtbiB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdO1xuICAgIG9wdGlvbnM/OiBUaWVyZWRNZW51SXRlbURhdGFbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtIHtcbiAgICBvcHRpb25zPzogVGllcmVkTWVudUl0ZW1EYXRhW107XG4gICAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICAgIGRhdGE6IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtTW92ZWREYXRhIHtcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdLFxuICAgIHByZXZpb3VzQ29sdW1uOiBLYW5iYW5Db2x1bW47XG4gICAgdGFyZ2V0Q29sdW1uOiBLYW5iYW5Db2x1bW47XG59XG4iXX0=
1
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2FuYmFuLWRhdGEuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy9rYW5iYW4vbW9kZWxzL2thbmJhbi1kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUaWVyZWRNZW51SXRlbURhdGEgfSBmcm9tIFwiLi4vLi4vdGllcmVkLW1lbnUvbW9kZWxzL3RpZXJlZC1tZW51LWl0ZW0tZGF0YVwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkRhdGEge1xuICAgIGNvbHVtbnM6IEthbmJhbkNvbHVtbltdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEthbmJhbkNvbHVtbiB7XG4gICAgaWQ/OiBzdHJpbmc7XG4gICAgdGl0bGU6IHN0cmluZztcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdO1xuICAgIG9wdGlvbnM/OiBLYW5iYW5Db2x1bW5PcHRpb25bXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtIHtcbiAgICBvcHRpb25zPzogS2FuYmFuSXRlbU9wdGlvbltdO1xuICAgIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgICBmcm96ZW4/OiBib29sZWFuO1xuICAgIGRhdGE6IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtTW92ZWREYXRhIHtcbiAgICBpdGVtczogS2FuYmFuSXRlbVtdLFxuICAgIHByZXZpb3VzQ29sdW1uOiBLYW5iYW5Db2x1bW47XG4gICAgdGFyZ2V0Q29sdW1uOiBLYW5iYW5Db2x1bW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgS2FuYmFuQ29sdW1uT3B0aW9uIGV4dGVuZHMgT21pdDxUaWVyZWRNZW51SXRlbURhdGEsICdjb21tYW5kJz4ge1xuICAgIGNvbW1hbmQ6IChjb2x1bW46IEthbmJhbkNvbHVtbikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBLYW5iYW5JdGVtT3B0aW9uIGV4dGVuZHMgT21pdDxUaWVyZWRNZW51SXRlbURhdGEsICdjb21tYW5kJz4ge1xuICAgIGNvbW1hbmQ6IChpdGVtOiBLYW5iYW5JdGVtKSA9PiB2b2lkO1xufVxuIl19
@@ -13547,6 +13547,8 @@ var KanbanTemplateTypes;
13547
13547
  let KanbanComponent = class KanbanComponent {
13548
13548
  constructor(kanbanEventService) {
13549
13549
  this.kanbanEventService = kanbanEventService;
13550
+ this.showItemCheckboxes = true;
13551
+ this.showColumnCheckboxes = true;
13550
13552
  this.itemsMoved = new EventEmitter();
13551
13553
  this.dataUpdated = new EventEmitter();
13552
13554
  this.itemsSelected = new EventEmitter();
@@ -13605,6 +13607,8 @@ let KanbanComponent = class KanbanComponent {
13605
13607
  this.selectedItems.clear();
13606
13608
  }
13607
13609
  selectItem(event, item, column) {
13610
+ if (item.disabled || item.frozen)
13611
+ return;
13608
13612
  if (event.ctrlKey) {
13609
13613
  if (this.selectedItems.delete(item)) {
13610
13614
  this.kanbanEventService.emitUnselectItemEvent(item);
@@ -13619,6 +13623,8 @@ let KanbanComponent = class KanbanComponent {
13619
13623
  }
13620
13624
  }
13621
13625
  else {
13626
+ if (this.selectedItems.delete(item))
13627
+ return;
13622
13628
  this.selectedItems.clear();
13623
13629
  this.selectedItems.add(item);
13624
13630
  this.selectedColumn = column;
@@ -13634,9 +13640,7 @@ let KanbanComponent = class KanbanComponent {
13634
13640
  this.draggingItems.clear();
13635
13641
  }
13636
13642
  getLinkedColumns(currentColumn) {
13637
- return this.data.columns
13638
- .filter((column) => column != currentColumn)
13639
- .map((column) => column.id);
13643
+ return this.data.columns.filter((column) => column != currentColumn).map((column) => column.id);
13640
13644
  }
13641
13645
  getColumnHeaderTemplate() {
13642
13646
  return this._getCustomTemplate(KanbanTemplateTypes.ColumnHeader);
@@ -13662,7 +13666,7 @@ let KanbanComponent = class KanbanComponent {
13662
13666
  .pipe(takeUntil(this._unsubscribe$))
13663
13667
  .subscribe((column) => {
13664
13668
  column.items
13665
- .filter((item) => !item.disabled)
13669
+ .filter((item) => !item.disabled && !item.frozen)
13666
13670
  .forEach((item) => {
13667
13671
  this.selectedItems.add(item);
13668
13672
  });
@@ -13692,9 +13696,7 @@ let KanbanComponent = class KanbanComponent {
13692
13696
  });
13693
13697
  });
13694
13698
  });
13695
- this.kanbanEventService.unselectItemEvent
13696
- .pipe(takeUntil(this._unsubscribe$))
13697
- .subscribe((item) => {
13699
+ this.kanbanEventService.unselectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item) => {
13698
13700
  this.selectedItems.delete(item);
13699
13701
  });
13700
13702
  }
@@ -13724,6 +13726,12 @@ KanbanComponent.ctorParameters = () => [
13724
13726
  __decorate([
13725
13727
  Input()
13726
13728
  ], KanbanComponent.prototype, "data", void 0);
13729
+ __decorate([
13730
+ Input()
13731
+ ], KanbanComponent.prototype, "showItemCheckboxes", void 0);
13732
+ __decorate([
13733
+ Input()
13734
+ ], KanbanComponent.prototype, "showColumnCheckboxes", void 0);
13727
13735
  __decorate([
13728
13736
  Output()
13729
13737
  ], KanbanComponent.prototype, "itemsMoved", void 0);
@@ -13738,26 +13746,35 @@ __decorate([
13738
13746
  ], KanbanComponent.prototype, "templates", void 0);
13739
13747
  KanbanComponent = __decorate([
13740
13748
  Component({
13741
- selector: 's-kanban',
13742
- 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>&nbsp;\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",
13743
- 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%}"]
13749
+ selector: "s-kanban",
13750
+ 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>&nbsp;\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",
13751
+ 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%}"]
13744
13752
  })
13745
13753
  ], KanbanComponent);
13746
13754
 
13747
13755
  let KanbanColumnComponent = class KanbanColumnComponent {
13748
13756
  constructor(kanbanEventService) {
13749
13757
  this.kanbanEventService = kanbanEventService;
13758
+ this.showCheckbox = true;
13750
13759
  this.selectionControl = new FormControl(false);
13751
13760
  this._unsubscribe$ = new Subject();
13752
13761
  }
13753
13762
  ngOnInit() {
13754
13763
  this._validateInputs();
13755
13764
  this._subscriveEvents();
13765
+ this._createTieredOptions();
13756
13766
  }
13757
13767
  ngOnDestroy() {
13758
13768
  this._unsubscribe$.next();
13759
13769
  this._unsubscribe$.complete();
13760
13770
  }
13771
+ _createTieredOptions() {
13772
+ const options = [];
13773
+ this.data.options.forEach((option) => {
13774
+ options.push(Object.assign(Object.assign({}, option), { command: () => { option.command(this.data); } }));
13775
+ });
13776
+ this.data.options = options;
13777
+ }
13761
13778
  _subscriveEvents() {
13762
13779
  this.selectionControl.valueChanges
13763
13780
  .pipe(takeUntil(this._unsubscribe$))
@@ -13808,13 +13825,16 @@ KanbanColumnComponent.ctorParameters = () => [
13808
13825
  __decorate([
13809
13826
  Input()
13810
13827
  ], KanbanColumnComponent.prototype, "data", void 0);
13828
+ __decorate([
13829
+ Input()
13830
+ ], KanbanColumnComponent.prototype, "showCheckbox", void 0);
13811
13831
  __decorate([
13812
13832
  Input()
13813
13833
  ], KanbanColumnComponent.prototype, "headerTemplate", void 0);
13814
13834
  KanbanColumnComponent = __decorate([
13815
13835
  Component({
13816
13836
  selector: "s-kanban-column",
13817
- 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>",
13837
+ 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>",
13818
13838
  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%}"]
13819
13839
  })
13820
13840
  ], KanbanColumnComponent);
@@ -13839,6 +13859,10 @@ let KanbanItemComponent = class KanbanItemComponent {
13839
13859
  constructor(_kanbanEventService) {
13840
13860
  this._kanbanEventService = _kanbanEventService;
13841
13861
  this.selected = false;
13862
+ this.showCheckbox = true;
13863
+ }
13864
+ ngOnInit() {
13865
+ this._createTieredOptions();
13842
13866
  }
13843
13867
  onSelectedChange(value) {
13844
13868
  if (value) {
@@ -13848,6 +13872,13 @@ let KanbanItemComponent = class KanbanItemComponent {
13848
13872
  this._kanbanEventService.emitUnselectItemEvent(this.item);
13849
13873
  }
13850
13874
  }
13875
+ _createTieredOptions() {
13876
+ const options = [];
13877
+ this.item.options.forEach((option) => {
13878
+ options.push(Object.assign(Object.assign({}, option), { command: () => { option.command(this.item); } }));
13879
+ });
13880
+ this.item.options = options;
13881
+ }
13851
13882
  };
13852
13883
  KanbanItemComponent.ctorParameters = () => [
13853
13884
  { type: KanbanEventService }
@@ -13858,6 +13889,9 @@ __decorate([
13858
13889
  __decorate([
13859
13890
  Input()
13860
13891
  ], KanbanItemComponent.prototype, "selected", void 0);
13892
+ __decorate([
13893
+ Input()
13894
+ ], KanbanItemComponent.prototype, "showCheckbox", void 0);
13861
13895
  __decorate([
13862
13896
  Input()
13863
13897
  ], KanbanItemComponent.prototype, "headerTemplate", void 0);
@@ -13869,9 +13903,9 @@ __decorate([
13869
13903
  ], KanbanItemComponent.prototype, "footerTemplate", void 0);
13870
13904
  KanbanItemComponent = __decorate([
13871
13905
  Component({
13872
- selector: 's-kanban-item',
13873
- 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>",
13874
- 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%}"]
13906
+ selector: "s-kanban-item",
13907
+ 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>",
13908
+ 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}"]
13875
13909
  })
13876
13910
  ], KanbanItemComponent);
13877
13911