keevo-components 2.0.251 → 2.0.253

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.
@@ -6,10 +6,10 @@ export class KvCardsInstructionComponent {
6
6
  this.blackCard = input();
7
7
  }
8
8
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCardsInstructionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
9
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvCardsInstructionComponent, isStandalone: true, selector: "kv-cards-instruction", inputs: { whiteCard: { classPropertyName: "whiteCard", publicName: "whiteCard", isSignal: true, isRequired: false, transformFunction: null }, blackCard: { classPropertyName: "blackCard", publicName: "blackCard", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"w-full h-full flex flex-column gap-2\">\r\n @if (whiteCard()) {\r\n <div\r\n class=\"bg-white border-1 border-gray-300 border-round-lg p-3 min-h-0 flex flex-column gap-2\"\r\n [style.height.%]=\"whiteCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-4\">\r\n @if(whiteCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ whiteCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ whiteCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[white-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (blackCard()) {\r\n <div\r\n class=\"bg-gray-900 text-white border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"blackCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(blackCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ blackCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ blackCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[black-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [""] }); }
9
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvCardsInstructionComponent, isStandalone: true, selector: "kv-cards-instruction", inputs: { whiteCard: { classPropertyName: "whiteCard", publicName: "whiteCard", isSignal: true, isRequired: false, transformFunction: null }, blackCard: { classPropertyName: "blackCard", publicName: "blackCard", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"w-full h-full flex flex-column gap-2\">\r\n @if (whiteCard()) {\r\n <div\r\n class=\"bg-white border-1 border-gray-300 border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"whiteCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(whiteCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ whiteCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ whiteCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[white-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (blackCard()) {\r\n <div\r\n class=\"bg-gray-900 text-white border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"blackCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(blackCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ blackCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ blackCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[black-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [""] }); }
10
10
  }
11
11
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCardsInstructionComponent, decorators: [{
12
12
  type: Component,
13
- args: [{ selector: 'kv-cards-instruction', standalone: true, imports: [], template: "<div class=\"w-full h-full flex flex-column gap-2\">\r\n @if (whiteCard()) {\r\n <div\r\n class=\"bg-white border-1 border-gray-300 border-round-lg p-3 min-h-0 flex flex-column gap-2\"\r\n [style.height.%]=\"whiteCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-4\">\r\n @if(whiteCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ whiteCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ whiteCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[white-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (blackCard()) {\r\n <div\r\n class=\"bg-gray-900 text-white border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"blackCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(blackCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ blackCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ blackCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[black-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n" }]
13
+ args: [{ selector: 'kv-cards-instruction', standalone: true, imports: [], template: "<div class=\"w-full h-full flex flex-column gap-2\">\r\n @if (whiteCard()) {\r\n <div\r\n class=\"bg-white border-1 border-gray-300 border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"whiteCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(whiteCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ whiteCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ whiteCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[white-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (blackCard()) {\r\n <div\r\n class=\"bg-gray-900 text-white border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"blackCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(blackCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ blackCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ blackCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[black-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n" }]
14
14
  }] });
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtY2FyZHMtaW5zdHJ1Y3Rpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtaW5zdHJ1Y3Rpb24tcGFnZS9jb21wb25lbnRzL2NhcmRzLWluc3RydWN0aW9uL2t2LWNhcmRzLWluc3RydWN0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWluc3RydWN0aW9uLXBhZ2UvY29tcG9uZW50cy9jYXJkcy1pbnN0cnVjdGlvbi9rdi1jYXJkcy1pbnN0cnVjdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFTakQsTUFBTSxPQUFPLDJCQUEyQjtJQVB4QztRQVFFLGNBQVMsR0FBRyxLQUFLLENBSUYsU0FBUyxDQUFDLENBQUM7UUFHMUIsY0FBUyxHQUFHLEtBQUssRUFJRCxDQUFDO0tBQ2xCOzhHQWJZLDJCQUEyQjtrR0FBM0IsMkJBQTJCLG9XQ1R4QyxpM0NBcUNBOzsyRkQ1QmEsMkJBQTJCO2tCQVB2QyxTQUFTOytCQUNFLHNCQUFzQixjQUNwQixJQUFJLFdBQ1AsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAna3YtY2FyZHMtaW5zdHJ1Y3Rpb24nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW10sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2t2LWNhcmRzLWluc3RydWN0aW9uLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4va3YtY2FyZHMtaW5zdHJ1Y3Rpb24uY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkNhcmRzSW5zdHJ1Y3Rpb25Db21wb25lbnQge1xyXG4gIHdoaXRlQ2FyZCA9IGlucHV0PHtcclxuICAgIHRpdGxlOiBzdHJpbmc7XHJcbiAgICBpY29uOiBzdHJpbmc7XHJcbiAgICBoZWlnaHQ6IG51bWJlcjtcclxuICB9IHwgdW5kZWZpbmVkPih1bmRlZmluZWQpO1xyXG5cclxuXHJcbiAgYmxhY2tDYXJkID0gaW5wdXQ8e1xyXG4gICAgdGl0bGU6IHN0cmluZztcclxuICAgIGljb246IHN0cmluZztcclxuICAgIGhlaWdodDogbnVtYmVyO1xyXG4gIH0gfCB1bmRlZmluZWQ+KCk7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cInctZnVsbCBoLWZ1bGwgZmxleCBmbGV4LWNvbHVtbiBnYXAtMlwiPlxyXG4gIEBpZiAod2hpdGVDYXJkKCkpIHtcclxuICAgIDxkaXZcclxuICAgICAgY2xhc3M9XCJiZy13aGl0ZSBib3JkZXItMSBib3JkZXItZ3JheS0zMDAgYm9yZGVyLXJvdW5kLWxnIHAtMyBtaW4taC0wIGZsZXggZmxleC1jb2x1bW4gZ2FwLTJcIlxyXG4gICAgICBbc3R5bGUuaGVpZ2h0LiVdPVwid2hpdGVDYXJkKCk/LmhlaWdodFwiXHJcbiAgICA+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJmbGV4IGZsZXgtcm93IGFsaWduLWl0ZW1zLWNlbnRlciBnYXAtNFwiPlxyXG4gICAgICAgIEBpZih3aGl0ZUNhcmQoKT8uaWNvbikge1xyXG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJtYXRlcmlhbC1zeW1ib2xzLW91dGxpbmVkXCI+IHt7IHdoaXRlQ2FyZCgpPy5pY29uIH19PC9zcGFuPlxyXG4gICAgICAgIH1cclxuICAgICAgICA8c3BhbiBjbGFzcz1cImZvbnQtc2VtaWJvbGRcIj57eyB3aGl0ZUNhcmQoKT8udGl0bGUgfX08L3NwYW4+XHJcbiAgICAgIDwvZGl2PlxyXG5cclxuICAgICAgPGRpdiBjbGFzcz1cImgtZnVsbCBtYXgtaC1mdWxsIG92ZXJmbG93LXktYXV0byB0ZXh0LXhzXCI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW3doaXRlLWNhcmQtY29udGVudF1cIj48L25nLWNvbnRlbnQ+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgfVxyXG5cclxuICBAaWYgKGJsYWNrQ2FyZCgpKSB7XHJcbiAgICA8ZGl2XHJcbiAgICAgIGNsYXNzPVwiYmctZ3JheS05MDAgdGV4dC13aGl0ZSBib3JkZXItcm91bmQtbGcgcC0zIG1pbi1oLTAgZmxleCBmbGV4LWNvbHVtbiBnYXAtNFwiXHJcbiAgICAgIFtzdHlsZS5oZWlnaHQuJV09XCJibGFja0NhcmQoKT8uaGVpZ2h0XCJcclxuICAgID5cclxuICAgICAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1yb3cgYWxpZ24taXRlbXMtY2VudGVyIGdhcC0yXCI+XHJcbiAgICAgICAgQGlmKGJsYWNrQ2FyZCgpPy5pY29uKSB7XHJcbiAgICAgICAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWRcIj4ge3sgYmxhY2tDYXJkKCk/Lmljb24gfX08L3NwYW4+XHJcbiAgICAgICAgfVxyXG4gICAgICAgIDxzcGFuIGNsYXNzPVwiZm9udC1zZW1pYm9sZFwiPnt7IGJsYWNrQ2FyZCgpPy50aXRsZSB9fTwvc3Bhbj5cclxuICAgICAgPC9kaXY+XHJcblxyXG4gICAgICA8ZGl2IGNsYXNzPVwiaC1mdWxsIG1heC1oLWZ1bGwgb3ZlcmZsb3cteS1hdXRvIHRleHQteHNcIj5cclxuICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbYmxhY2stY2FyZC1jb250ZW50XVwiPjwvbmctY29udGVudD5cclxuICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuICB9XHJcbjwvZGl2PlxyXG4iXX0=
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtY2FyZHMtaW5zdHJ1Y3Rpb24uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtaW5zdHJ1Y3Rpb24tcGFnZS9jb21wb25lbnRzL2NhcmRzLWluc3RydWN0aW9uL2t2LWNhcmRzLWluc3RydWN0aW9uLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWluc3RydWN0aW9uLXBhZ2UvY29tcG9uZW50cy9jYXJkcy1pbnN0cnVjdGlvbi9rdi1jYXJkcy1pbnN0cnVjdGlvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFTakQsTUFBTSxPQUFPLDJCQUEyQjtJQVB4QztRQVFFLGNBQVMsR0FBRyxLQUFLLENBSUYsU0FBUyxDQUFDLENBQUM7UUFHMUIsY0FBUyxHQUFHLEtBQUssRUFJRCxDQUFDO0tBQ2xCOzhHQWJZLDJCQUEyQjtrR0FBM0IsMkJBQTJCLG9XQ1R4QyxpM0NBcUNBOzsyRkQ1QmEsMkJBQTJCO2tCQVB2QyxTQUFTOytCQUNFLHNCQUFzQixjQUNwQixJQUFJLFdBQ1AsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAna3YtY2FyZHMtaW5zdHJ1Y3Rpb24nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW10sXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2t2LWNhcmRzLWluc3RydWN0aW9uLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4va3YtY2FyZHMtaW5zdHJ1Y3Rpb24uY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkNhcmRzSW5zdHJ1Y3Rpb25Db21wb25lbnQge1xyXG4gIHdoaXRlQ2FyZCA9IGlucHV0PHtcclxuICAgIHRpdGxlOiBzdHJpbmc7XHJcbiAgICBpY29uOiBzdHJpbmc7XHJcbiAgICBoZWlnaHQ6IG51bWJlcjtcclxuICB9IHwgdW5kZWZpbmVkPih1bmRlZmluZWQpO1xyXG5cclxuXHJcbiAgYmxhY2tDYXJkID0gaW5wdXQ8e1xyXG4gICAgdGl0bGU6IHN0cmluZztcclxuICAgIGljb246IHN0cmluZztcclxuICAgIGhlaWdodDogbnVtYmVyO1xyXG4gIH0gfCB1bmRlZmluZWQ+KCk7XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cInctZnVsbCBoLWZ1bGwgZmxleCBmbGV4LWNvbHVtbiBnYXAtMlwiPlxyXG4gIEBpZiAod2hpdGVDYXJkKCkpIHtcclxuICAgIDxkaXZcclxuICAgICAgY2xhc3M9XCJiZy13aGl0ZSBib3JkZXItMSBib3JkZXItZ3JheS0zMDAgYm9yZGVyLXJvdW5kLWxnIHAtMyBtaW4taC0wIGZsZXggZmxleC1jb2x1bW4gZ2FwLTRcIlxyXG4gICAgICBbc3R5bGUuaGVpZ2h0LiVdPVwid2hpdGVDYXJkKCk/LmhlaWdodFwiXHJcbiAgICA+XHJcbiAgICAgIDxkaXYgY2xhc3M9XCJmbGV4IGZsZXgtcm93IGFsaWduLWl0ZW1zLWNlbnRlciBnYXAtMlwiPlxyXG4gICAgICAgIEBpZih3aGl0ZUNhcmQoKT8uaWNvbikge1xyXG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJtYXRlcmlhbC1zeW1ib2xzLW91dGxpbmVkXCI+IHt7IHdoaXRlQ2FyZCgpPy5pY29uIH19PC9zcGFuPlxyXG4gICAgICAgIH1cclxuICAgICAgICA8c3BhbiBjbGFzcz1cImZvbnQtc2VtaWJvbGRcIj57eyB3aGl0ZUNhcmQoKT8udGl0bGUgfX08L3NwYW4+XHJcbiAgICAgIDwvZGl2PlxyXG5cclxuICAgICAgPGRpdiBjbGFzcz1cImgtZnVsbCBtYXgtaC1mdWxsIG92ZXJmbG93LXktYXV0byB0ZXh0LXhzXCI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiW3doaXRlLWNhcmQtY29udGVudF1cIj48L25nLWNvbnRlbnQ+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgfVxyXG5cclxuICBAaWYgKGJsYWNrQ2FyZCgpKSB7XHJcbiAgICA8ZGl2XHJcbiAgICAgIGNsYXNzPVwiYmctZ3JheS05MDAgdGV4dC13aGl0ZSBib3JkZXItcm91bmQtbGcgcC0zIG1pbi1oLTAgZmxleCBmbGV4LWNvbHVtbiBnYXAtNFwiXHJcbiAgICAgIFtzdHlsZS5oZWlnaHQuJV09XCJibGFja0NhcmQoKT8uaGVpZ2h0XCJcclxuICAgID5cclxuICAgICAgPGRpdiBjbGFzcz1cImZsZXggZmxleC1yb3cgYWxpZ24taXRlbXMtY2VudGVyIGdhcC0yXCI+XHJcbiAgICAgICAgQGlmKGJsYWNrQ2FyZCgpPy5pY29uKSB7XHJcbiAgICAgICAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWRcIj4ge3sgYmxhY2tDYXJkKCk/Lmljb24gfX08L3NwYW4+XHJcbiAgICAgICAgfVxyXG4gICAgICAgIDxzcGFuIGNsYXNzPVwiZm9udC1zZW1pYm9sZFwiPnt7IGJsYWNrQ2FyZCgpPy50aXRsZSB9fTwvc3Bhbj5cclxuICAgICAgPC9kaXY+XHJcblxyXG4gICAgICA8ZGl2IGNsYXNzPVwiaC1mdWxsIG1heC1oLWZ1bGwgb3ZlcmZsb3cteS1hdXRvIHRleHQteHNcIj5cclxuICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbYmxhY2stY2FyZC1jb250ZW50XVwiPjwvbmctY29udGVudD5cclxuICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuICB9XHJcbjwvZGl2PlxyXG4iXX0=
@@ -12,6 +12,7 @@ export class KvKanbanComponent {
12
12
  constructor() {
13
13
  this.sharedMenu = viewChild('sharedMenu');
14
14
  this.currentMenuOptions = [];
15
+ this.currentCard = null;
15
16
  this.actions = input([]);
16
17
  this.columnConfigs = input([]);
17
18
  this.columnLists = input([]);
@@ -48,7 +49,9 @@ export class KvKanbanComponent {
48
49
  }
49
50
  openCardMenu(event, item) {
50
51
  event.stopPropagation();
52
+ this.currentCard = item;
51
53
  this.currentMenuOptions = this.getActionsForCard(item);
54
+ this.onSelectedCard.emit(item);
52
55
  this.sharedMenu()?.toggle(event);
53
56
  }
54
57
  onScroll(event, columnId) {
@@ -70,8 +73,8 @@ export class KvKanbanComponent {
70
73
  if (action.command) {
71
74
  action.command(event);
72
75
  }
73
- if (action.label) {
74
- this.onActionClick(action.label, card);
76
+ if (action.label && this.currentCard) {
77
+ this.onActionClick(action.label, this.currentCard);
75
78
  }
76
79
  }
77
80
  }));
@@ -94,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
94
97
  type: Component,
95
98
  args: [{ standalone: true, selector: 'kv-kanban', imports: [CommonModule, DragDropModule, MenuModule, TooltipModule], template: "<div class=\"flex w-full h-full\">\r\n <div class=\"board-wrapper flex-column lg:flex-row\" cdkDropListGroup>\r\n \r\n @for(config of columnConfigs(); track $index) {\r\n\r\n <div class=\"board-column\" [style.flex]=\"getColumnFlex()\">\r\n \r\n <div class=\"column-header\" [style.backgroundColor]=\"config.corTitulo\">\r\n <span class=\"text-base font-semibold\">{{ config.nome }}</span>\r\n @if(this.showColumnsCounter()) {\r\n <span class=\"column-count-badge px-2 py-1\" [style.color]=\"config.corTitulo\">{{ config.contador | number:'2.0' }}</span>\r\n }\r\n </div>\r\n\r\n <div \r\n class=\"column-content\"\r\n cdkDropList\r\n [id]=\"config.id.toString()\"\r\n [cdkDropListData]=\"getColumnList()(config.id)\"\r\n (cdkDropListDropped)=\"drop($event)\"\r\n (scroll)=\"onScroll($event, config.id)\">\r\n\r\n\r\n @for(item of getColumnList()(config.id); track $index) {\r\n \r\n <div class=\"kanban-card\" cdkDrag [cdkDragDisabled]=\"!enableDrag()\">\r\n\r\n @if(actions().length > 0) {\r\n <span class=\"material-symbols-outlined card-menu-btn text-xl text-black-alpha-50 hover:surface-200 border-round-lg\" (click)=\"openCardMenu($event, item)\">\r\n more_vert\r\n </span>\r\n }\r\n \r\n\r\n @if (item.status && item.status.length > 0) {\r\n <div class=\"card-header mt-1 mr-3 gap-2 overflow-hidden\" \r\n [pTooltip]=\"getStatusTooltip(item.status)\" \r\n tooltipPosition=\"top\">\r\n @for(statusItem of item.status; track $index) {\r\n <span class=\"status-tag font-semibold text-xs border-round-3xl py-1 px-2\" \r\n [style.backgroundColor]=\"statusItem.statusColor\"\r\n [style.color]=\"statusItem.statusLabelColor\">\r\n {{ statusItem.label }}\r\n </span>\r\n }\r\n </div>\r\n }\r\n\r\n <div class=\"card-body overflow-hidden ml-1\">\r\n <p class=\"p-0 m-0 text-sm text-black-alpha-70 font-semibold mb-2 pr-4 white-space-nowrap\" pTooltip=\"{{item.titulo}}\" tooltipPosition=\"top\">\r\n {{ item.titulo }}\r\n </p>\r\n \r\n <ng-container [ngTemplateOutlet]=\"cardTemplate()\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n </div>\r\n\r\n <div *cdkDragPlaceholder class=\"custom-placeholder\"></div>\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n <div class=\"column-footer text-xs text-black-alpha-80\">\r\n Ver {{ getColumnList()(config.id).length }} de {{ config.contador }}\r\n </div>\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n</div>\r\n\r\n<p-menu #sharedMenu [model]=\"currentMenuOptions\" [popup]=\"true\" appendTo=\"body\"></p-menu>", styles: [".board-wrapper{display:flex;flex:1 1 0%;gap:16px;overflow-x:auto;padding:20px;height:100%;min-height:0}.board-column{display:flex;flex-direction:column;background-color:#f0f2f5;border-radius:18px;min-width:280px;overflow:visible;min-height:400px;max-height:600px}@media (min-width: 1024px){.board-column{height:100%;max-height:100%;min-height:0}}.column-header{padding:10px 20px;margin:7px;border-radius:18px;color:#fff;display:flex;justify-content:space-between;align-items:center;font-weight:600;gap:8px}.column-header span:first-child{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.column-header .column-count-badge{background-color:#ffffffe6;border-radius:12px;font-size:.85rem;font-weight:700;flex-shrink:0}.column-content{flex:1 1 0;overflow-y:auto;overflow-x:visible;padding:12px;min-height:0}.column-content::-webkit-scrollbar{width:6px}.column-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.kanban-card{background:#fff;border-radius:16px;padding:12px;margin-bottom:8px;box-shadow:0 4px 6px #0000001a;cursor:grab;transition:box-shadow .2s;position:relative}.kanban-card:active{cursor:grabbing}.kanban-card:hover{box-shadow:0 4px 8px #0000001a}.kanban-card.cdk-drag-disabled,.kanban-card.cdk-drag-disabled:active{cursor:default}.card-header{display:flex;margin-bottom:8px;flex-wrap:nowrap}.card-header .status-tag{white-space:nowrap;flex-shrink:0}.card-menu-btn{position:absolute;top:12px;right:8px;cursor:pointer;z-index:10;-webkit-user-select:none;user-select:none}.column-footer{padding:10px;text-align:center}.cdk-drag-preview{box-sizing:border-box;border-radius:8px;box-shadow:0 5px 15px #0003;background:#fff}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.column-content.cdk-drop-list-dragging .kanban-card:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}::ng-deep .p-menu{scale:.8;z-index:1000!important}\n"] }]
96
99
  }] });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-kanban.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-kanban/kv-kanban.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-kanban/kv-kanban.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, OnInit, output, TemplateRef, viewChild } from '@angular/core';\r\nimport { KanbanColumn, KanbanCard, KanbanAction, KanbanColumnConfig, KanbanColumnList } from './kv-kanban-models.model';\r\nimport { CdkDragDrop, DragDropModule, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MenuModule, Menu } from 'primeng/menu';\r\nimport { MenuItem } from 'primeng/api';\r\nimport { TooltipModule } from 'primeng/tooltip';\r\n\r\n@Component({\r\n  standalone: true,\r\n  selector: 'kv-kanban',\r\n  templateUrl: './kv-kanban.component.html',\r\n  styleUrls: ['./kv-kanban.component.scss'],\r\n  imports: [CommonModule, DragDropModule, MenuModule, TooltipModule]\r\n})\r\nexport class KvKanbanComponent {\r\n\r\n  sharedMenu = viewChild<Menu>('sharedMenu');\r\n\r\n  currentMenuOptions: MenuItem[] = [];\r\n\r\n  actions = input<MenuItem[]>([]);\r\n  columnConfigs = input<KanbanColumnConfig[]>([]);\r\n  columnLists = input<KanbanColumnList[]>([]);\r\n  cardTemplate = input<TemplateRef<any> | null>(null);\r\n  showColumnsCounter = input<boolean>(true);\r\n  enableDrag = input<boolean>(true);\r\n  onCardMoved = output<any>();\r\n  onActionClicked = output<{ action: string, card: KanbanCard }>();\r\n  onLoadMoreCards = output<{ columnId: number }>();\r\n  onSelectedCard = output<KanbanCard>();\r\n\r\n  getColumnList = computed(() => (columnId: number) => {\r\n    const list = this.columnLists().find(l => l.idColuna === columnId);\r\n    return list?.listagem || [] as KanbanCard[];\r\n  });\r\n\r\n  drop(event: CdkDragDrop<KanbanCard[]>) {\r\n    if (event.previousContainer === event.container) {\r\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\r\n    } else {\r\n      transferArrayItem(\r\n        event.previousContainer.data,\r\n        event.container.data,\r\n        event.previousIndex,\r\n        event.currentIndex,\r\n      );\r\n    }\r\n\r\n    const movedCard = event.container.data[event.currentIndex];\r\n    \r\n    this.onCardMoved.emit({\r\n      item: movedCard,\r\n      fromColumnId: event.previousContainer.id,\r\n      toColumnId: event.container.id\r\n    });\r\n    \r\n    this.onSelectedCard.emit(movedCard);\r\n  }\r\n\r\n  onActionClick(actionCode: string, card: KanbanCard) {\r\n    this.onActionClicked.emit({ action: actionCode, card });\r\n    \r\n    this.onSelectedCard.emit(card);\r\n  }\r\n\r\n  openCardMenu(event: MouseEvent, item: any) {\r\n    event.stopPropagation();\r\n\r\n    this.currentMenuOptions = this.getActionsForCard(item);\r\n\r\n    this.sharedMenu()?.toggle(event);\r\n  }\r\n\r\n  onScroll(event: Event, columnId: number) {\r\n    const element = event.target as HTMLElement;\r\n    const threshold = 50;\r\n    const atBottom = element.scrollHeight - element.scrollTop - element.clientHeight < threshold;\r\n    \r\n    if (atBottom) {\r\n      this.onLoadMoreCards.emit({ columnId });\r\n    }\r\n  }\r\n\r\n  getColumnTotalItems(columnId: number): number {\r\n    const config = this.columnConfigs().find(c => c.id === columnId);\r\n    return config?.contador || 0;\r\n  }\r\n\r\n  getActionsForCard(card: KanbanCard): MenuItem[] {\r\n    return this.actions().map(action => ({\r\n      ...action,\r\n      command: (event?: any) => {\r\n        if (action.command) {\r\n          action.command(event);\r\n        }\r\n        \r\n        if (action.label) {\r\n          this.onActionClick(action.label, card);\r\n        }\r\n      }\r\n    }));\r\n  }\r\n\r\n  getColumnFlex(): string {\r\n    const totalColumns = this.columnConfigs().length;\r\n    if (totalColumns === 0) return '1 1 280px';\r\n    \r\n    return `1 1 calc((100% - ${(totalColumns - 1) * 16}px) / ${totalColumns})`;\r\n  }\r\n\r\n  getStatusTooltip(status: any[]): string {\r\n    if (!status || status.length === 0) return '';\r\n    return status.map(s => s.label).join(', ');\r\n  }\r\n\r\n}\r\n","<div class=\"flex w-full h-full\">\r\n  <div class=\"board-wrapper flex-column lg:flex-row\" cdkDropListGroup>\r\n    \r\n    @for(config of columnConfigs(); track $index) {\r\n\r\n      <div class=\"board-column\" [style.flex]=\"getColumnFlex()\">\r\n        \r\n        <div class=\"column-header\" [style.backgroundColor]=\"config.corTitulo\">\r\n          <span class=\"text-base font-semibold\">{{ config.nome }}</span>\r\n          @if(this.showColumnsCounter()) {\r\n            <span class=\"column-count-badge px-2 py-1\" [style.color]=\"config.corTitulo\">{{ config.contador | number:'2.0' }}</span>\r\n          }\r\n        </div>\r\n\r\n        <div \r\n          class=\"column-content\"\r\n          cdkDropList\r\n          [id]=\"config.id.toString()\"\r\n          [cdkDropListData]=\"getColumnList()(config.id)\"\r\n          (cdkDropListDropped)=\"drop($event)\"\r\n          (scroll)=\"onScroll($event, config.id)\">\r\n\r\n\r\n          @for(item of getColumnList()(config.id); track $index) {\r\n            \r\n            <div class=\"kanban-card\" cdkDrag [cdkDragDisabled]=\"!enableDrag()\">\r\n\r\n              @if(actions().length > 0) {\r\n                <span class=\"material-symbols-outlined card-menu-btn text-xl text-black-alpha-50 hover:surface-200 border-round-lg\" (click)=\"openCardMenu($event, item)\">\r\n                  more_vert\r\n                </span>\r\n              }\r\n              \r\n\r\n              @if (item.status && item.status.length > 0) {\r\n                <div class=\"card-header mt-1 mr-3 gap-2 overflow-hidden\" \r\n                     [pTooltip]=\"getStatusTooltip(item.status)\" \r\n                     tooltipPosition=\"top\">\r\n                  @for(statusItem of item.status; track $index) {\r\n                    <span class=\"status-tag font-semibold text-xs border-round-3xl py-1 px-2\" \r\n                          [style.backgroundColor]=\"statusItem.statusColor\"\r\n                          [style.color]=\"statusItem.statusLabelColor\">\r\n                      {{ statusItem.label }}\r\n                    </span>\r\n                  }\r\n                </div>\r\n              }\r\n\r\n              <div class=\"card-body overflow-hidden ml-1\">\r\n                <p class=\"p-0 m-0 text-sm text-black-alpha-70 font-semibold mb-2 pr-4 white-space-nowrap\" pTooltip=\"{{item.titulo}}\" tooltipPosition=\"top\">\r\n                  {{ item.titulo }}\r\n                </p>\r\n                \r\n                <ng-container [ngTemplateOutlet]=\"cardTemplate()\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n              </div>\r\n\r\n              <div *cdkDragPlaceholder class=\"custom-placeholder\"></div>\r\n            </div>\r\n          }\r\n\r\n        </div>\r\n\r\n        <div class=\"column-footer text-xs text-black-alpha-80\">\r\n          Ver {{ getColumnList()(config.id).length }} de {{ config.contador }}\r\n        </div>\r\n\r\n      </div>\r\n\r\n    }\r\n\r\n  </div>\r\n</div>\r\n\r\n<p-menu #sharedMenu [model]=\"currentMenuOptions\" [popup]=\"true\" appendTo=\"body\"></p-menu>"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-kanban.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-kanban/kv-kanban.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-kanban/kv-kanban.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, OnInit, output, TemplateRef, viewChild } from '@angular/core';\r\nimport { KanbanColumn, KanbanCard, KanbanAction, KanbanColumnConfig, KanbanColumnList } from './kv-kanban-models.model';\r\nimport { CdkDragDrop, DragDropModule, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MenuModule, Menu } from 'primeng/menu';\r\nimport { MenuItem } from 'primeng/api';\r\nimport { TooltipModule } from 'primeng/tooltip';\r\n\r\n@Component({\r\n  standalone: true,\r\n  selector: 'kv-kanban',\r\n  templateUrl: './kv-kanban.component.html',\r\n  styleUrls: ['./kv-kanban.component.scss'],\r\n  imports: [CommonModule, DragDropModule, MenuModule, TooltipModule]\r\n})\r\nexport class KvKanbanComponent {\r\n\r\n  sharedMenu = viewChild<Menu>('sharedMenu');\r\n\r\n  currentMenuOptions: MenuItem[] = [];\r\n  currentCard: KanbanCard | null = null;\r\n\r\n  actions = input<MenuItem[]>([]);\r\n  columnConfigs = input<KanbanColumnConfig[]>([]);\r\n  columnLists = input<KanbanColumnList[]>([]);\r\n  cardTemplate = input<TemplateRef<any> | null>(null);\r\n  showColumnsCounter = input<boolean>(true);\r\n  enableDrag = input<boolean>(true);\r\n  onCardMoved = output<any>();\r\n  onActionClicked = output<{ action: string, card: KanbanCard }>();\r\n  onLoadMoreCards = output<{ columnId: number }>();\r\n  onSelectedCard = output<KanbanCard>();\r\n\r\n  getColumnList = computed(() => (columnId: number) => {\r\n    const list = this.columnLists().find(l => l.idColuna === columnId);\r\n    return list?.listagem || [] as KanbanCard[];\r\n  });\r\n\r\n  drop(event: CdkDragDrop<KanbanCard[]>) {\r\n    if (event.previousContainer === event.container) {\r\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\r\n    } else {\r\n      transferArrayItem(\r\n        event.previousContainer.data,\r\n        event.container.data,\r\n        event.previousIndex,\r\n        event.currentIndex,\r\n      );\r\n    }\r\n\r\n    const movedCard = event.container.data[event.currentIndex];\r\n    \r\n    this.onCardMoved.emit({\r\n      item: movedCard,\r\n      fromColumnId: event.previousContainer.id,\r\n      toColumnId: event.container.id\r\n    });\r\n    \r\n    this.onSelectedCard.emit(movedCard);\r\n  }\r\n\r\n  onActionClick(actionCode: string, card: KanbanCard) {\r\n    this.onActionClicked.emit({ action: actionCode, card });\r\n    \r\n    this.onSelectedCard.emit(card);\r\n  }\r\n\r\n  openCardMenu(event: MouseEvent, item: any) {\r\n    event.stopPropagation();\r\n\r\n    this.currentCard = item;\r\n    this.currentMenuOptions = this.getActionsForCard(item);\r\n\r\n    this.onSelectedCard.emit(item);\r\n    \r\n    this.sharedMenu()?.toggle(event);\r\n  }\r\n\r\n  onScroll(event: Event, columnId: number) {\r\n    const element = event.target as HTMLElement;\r\n    const threshold = 50;\r\n    const atBottom = element.scrollHeight - element.scrollTop - element.clientHeight < threshold;\r\n    \r\n    if (atBottom) {\r\n      this.onLoadMoreCards.emit({ columnId });\r\n    }\r\n  }\r\n\r\n  getColumnTotalItems(columnId: number): number {\r\n    const config = this.columnConfigs().find(c => c.id === columnId);\r\n    return config?.contador || 0;\r\n  }\r\n\r\n  getActionsForCard(card: KanbanCard): MenuItem[] {\r\n    return this.actions().map(action => ({\r\n      ...action,\r\n      command: (event?: any) => {\r\n        if (action.command) {\r\n          action.command(event);\r\n        }\r\n        \r\n        if (action.label && this.currentCard) {\r\n          this.onActionClick(action.label, this.currentCard);\r\n        }\r\n      }\r\n    }));\r\n  }\r\n\r\n  getColumnFlex(): string {\r\n    const totalColumns = this.columnConfigs().length;\r\n    if (totalColumns === 0) return '1 1 280px';\r\n    \r\n    return `1 1 calc((100% - ${(totalColumns - 1) * 16}px) / ${totalColumns})`;\r\n  }\r\n\r\n  getStatusTooltip(status: any[]): string {\r\n    if (!status || status.length === 0) return '';\r\n    return status.map(s => s.label).join(', ');\r\n  }\r\n\r\n}\r\n","<div class=\"flex w-full h-full\">\r\n  <div class=\"board-wrapper flex-column lg:flex-row\" cdkDropListGroup>\r\n    \r\n    @for(config of columnConfigs(); track $index) {\r\n\r\n      <div class=\"board-column\" [style.flex]=\"getColumnFlex()\">\r\n        \r\n        <div class=\"column-header\" [style.backgroundColor]=\"config.corTitulo\">\r\n          <span class=\"text-base font-semibold\">{{ config.nome }}</span>\r\n          @if(this.showColumnsCounter()) {\r\n            <span class=\"column-count-badge px-2 py-1\" [style.color]=\"config.corTitulo\">{{ config.contador | number:'2.0' }}</span>\r\n          }\r\n        </div>\r\n\r\n        <div \r\n          class=\"column-content\"\r\n          cdkDropList\r\n          [id]=\"config.id.toString()\"\r\n          [cdkDropListData]=\"getColumnList()(config.id)\"\r\n          (cdkDropListDropped)=\"drop($event)\"\r\n          (scroll)=\"onScroll($event, config.id)\">\r\n\r\n\r\n          @for(item of getColumnList()(config.id); track $index) {\r\n            \r\n            <div class=\"kanban-card\" cdkDrag [cdkDragDisabled]=\"!enableDrag()\">\r\n\r\n              @if(actions().length > 0) {\r\n                <span class=\"material-symbols-outlined card-menu-btn text-xl text-black-alpha-50 hover:surface-200 border-round-lg\" (click)=\"openCardMenu($event, item)\">\r\n                  more_vert\r\n                </span>\r\n              }\r\n              \r\n\r\n              @if (item.status && item.status.length > 0) {\r\n                <div class=\"card-header mt-1 mr-3 gap-2 overflow-hidden\" \r\n                     [pTooltip]=\"getStatusTooltip(item.status)\" \r\n                     tooltipPosition=\"top\">\r\n                  @for(statusItem of item.status; track $index) {\r\n                    <span class=\"status-tag font-semibold text-xs border-round-3xl py-1 px-2\" \r\n                          [style.backgroundColor]=\"statusItem.statusColor\"\r\n                          [style.color]=\"statusItem.statusLabelColor\">\r\n                      {{ statusItem.label }}\r\n                    </span>\r\n                  }\r\n                </div>\r\n              }\r\n\r\n              <div class=\"card-body overflow-hidden ml-1\">\r\n                <p class=\"p-0 m-0 text-sm text-black-alpha-70 font-semibold mb-2 pr-4 white-space-nowrap\" pTooltip=\"{{item.titulo}}\" tooltipPosition=\"top\">\r\n                  {{ item.titulo }}\r\n                </p>\r\n                \r\n                <ng-container [ngTemplateOutlet]=\"cardTemplate()\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n              </div>\r\n\r\n              <div *cdkDragPlaceholder class=\"custom-placeholder\"></div>\r\n            </div>\r\n          }\r\n\r\n        </div>\r\n\r\n        <div class=\"column-footer text-xs text-black-alpha-80\">\r\n          Ver {{ getColumnList()(config.id).length }} de {{ config.contador }}\r\n        </div>\r\n\r\n      </div>\r\n\r\n    }\r\n\r\n  </div>\r\n</div>\r\n\r\n<p-menu #sharedMenu [model]=\"currentMenuOptions\" [popup]=\"true\" appendTo=\"body\"></p-menu>"]}
@@ -14412,6 +14412,7 @@ class KvKanbanComponent {
14412
14412
  constructor() {
14413
14413
  this.sharedMenu = viewChild('sharedMenu');
14414
14414
  this.currentMenuOptions = [];
14415
+ this.currentCard = null;
14415
14416
  this.actions = input([]);
14416
14417
  this.columnConfigs = input([]);
14417
14418
  this.columnLists = input([]);
@@ -14448,7 +14449,9 @@ class KvKanbanComponent {
14448
14449
  }
14449
14450
  openCardMenu(event, item) {
14450
14451
  event.stopPropagation();
14452
+ this.currentCard = item;
14451
14453
  this.currentMenuOptions = this.getActionsForCard(item);
14454
+ this.onSelectedCard.emit(item);
14452
14455
  this.sharedMenu()?.toggle(event);
14453
14456
  }
14454
14457
  onScroll(event, columnId) {
@@ -14470,8 +14473,8 @@ class KvKanbanComponent {
14470
14473
  if (action.command) {
14471
14474
  action.command(event);
14472
14475
  }
14473
- if (action.label) {
14474
- this.onActionClick(action.label, card);
14476
+ if (action.label && this.currentCard) {
14477
+ this.onActionClick(action.label, this.currentCard);
14475
14478
  }
14476
14479
  }
14477
14480
  }));
@@ -14501,11 +14504,11 @@ class KvCardsInstructionComponent {
14501
14504
  this.blackCard = input();
14502
14505
  }
14503
14506
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCardsInstructionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14504
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvCardsInstructionComponent, isStandalone: true, selector: "kv-cards-instruction", inputs: { whiteCard: { classPropertyName: "whiteCard", publicName: "whiteCard", isSignal: true, isRequired: false, transformFunction: null }, blackCard: { classPropertyName: "blackCard", publicName: "blackCard", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"w-full h-full flex flex-column gap-2\">\r\n @if (whiteCard()) {\r\n <div\r\n class=\"bg-white border-1 border-gray-300 border-round-lg p-3 min-h-0 flex flex-column gap-2\"\r\n [style.height.%]=\"whiteCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-4\">\r\n @if(whiteCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ whiteCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ whiteCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[white-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (blackCard()) {\r\n <div\r\n class=\"bg-gray-900 text-white border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"blackCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(blackCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ blackCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ blackCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[black-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [""] }); }
14507
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvCardsInstructionComponent, isStandalone: true, selector: "kv-cards-instruction", inputs: { whiteCard: { classPropertyName: "whiteCard", publicName: "whiteCard", isSignal: true, isRequired: false, transformFunction: null }, blackCard: { classPropertyName: "blackCard", publicName: "blackCard", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"w-full h-full flex flex-column gap-2\">\r\n @if (whiteCard()) {\r\n <div\r\n class=\"bg-white border-1 border-gray-300 border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"whiteCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(whiteCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ whiteCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ whiteCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[white-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (blackCard()) {\r\n <div\r\n class=\"bg-gray-900 text-white border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"blackCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(blackCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ blackCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ blackCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[black-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [""] }); }
14505
14508
  }
14506
14509
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvCardsInstructionComponent, decorators: [{
14507
14510
  type: Component,
14508
- args: [{ selector: 'kv-cards-instruction', standalone: true, imports: [], template: "<div class=\"w-full h-full flex flex-column gap-2\">\r\n @if (whiteCard()) {\r\n <div\r\n class=\"bg-white border-1 border-gray-300 border-round-lg p-3 min-h-0 flex flex-column gap-2\"\r\n [style.height.%]=\"whiteCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-4\">\r\n @if(whiteCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ whiteCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ whiteCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[white-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (blackCard()) {\r\n <div\r\n class=\"bg-gray-900 text-white border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"blackCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(blackCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ blackCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ blackCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[black-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n" }]
14511
+ args: [{ selector: 'kv-cards-instruction', standalone: true, imports: [], template: "<div class=\"w-full h-full flex flex-column gap-2\">\r\n @if (whiteCard()) {\r\n <div\r\n class=\"bg-white border-1 border-gray-300 border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"whiteCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(whiteCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ whiteCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ whiteCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[white-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if (blackCard()) {\r\n <div\r\n class=\"bg-gray-900 text-white border-round-lg p-3 min-h-0 flex flex-column gap-4\"\r\n [style.height.%]=\"blackCard()?.height\"\r\n >\r\n <div class=\"flex flex-row align-items-center gap-2\">\r\n @if(blackCard()?.icon) {\r\n <span class=\"material-symbols-outlined\"> {{ blackCard()?.icon }}</span>\r\n }\r\n <span class=\"font-semibold\">{{ blackCard()?.title }}</span>\r\n </div>\r\n\r\n <div class=\"h-full max-h-full overflow-y-auto text-xs\">\r\n <ng-content select=\"[black-card-content]\"></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n" }]
14509
14512
  }] });
14510
14513
 
14511
14514
  class KvInstructionPageComponent {