barsa-kanban 2.2.73 → 2.2.74

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.
@@ -1,275 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, ElementRef, inject, Input, ViewChild, signal } from '@angular/core';
2
- import { moveItemInArray } from '@angular/cdk/drag-drop';
3
- import { MultipleGroupByPipe, ReportViewBaseComponent, SortDirection } from 'barsa-novin-ray-core';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/common";
6
- import * as i2 from "barsa-novin-ray-core";
7
- import * as i3 from "@fundamental-ngx/core/card";
8
- import * as i4 from "@fundamental-ngx/core/checkbox";
9
- import * as i5 from "@fundamental-ngx/core/layout-grid";
10
- import * as i6 from "@fundamental-ngx/core/layout-panel";
11
- import * as i7 from "@fundamental-ngx/core/title";
12
- import * as i8 from "@fundamental-ngx/core/table";
13
- import * as i9 from "@angular/forms";
14
- import * as i10 from "@angular/cdk/drag-drop";
15
- import * as i11 from "../kanban-card/kanban-card.component";
16
- export class KanbanViewComponent extends ReportViewBaseComponent {
17
- constructor() {
18
- super(...arguments);
19
- this.groupbyProperty = 'State';
20
- this.isNewColumnMode = false;
21
- this.newCard = { Id: null, $Caption: null };
22
- this.newColumn = { Id: null, $Caption: null };
23
- this._multipleGroup = inject(MultipleGroupByPipe);
24
- this.groupedMoList = signal({});
25
- this.sceneConfig = {
26
- scene: { url: 'assets/images/sapIllus-Scene-NoMail.svg', id: 'sapIllus-Scene-NoMail-1' },
27
- dialog: { url: 'assets/images/sapIllus-Dialog-NoMail.svg', id: 'sapIllus-Dialog-NoMail' }
28
- };
29
- }
30
- ngOnInit() {
31
- super.ngOnInit();
32
- const columnsReport = this.viewSetting.ColumnsReport.$Caption;
33
- this._portalService.ReportExecute(columnsReport).subscribe((report) => {
34
- this.kanbanColumns = report.MoDataList;
35
- this._changeDetect();
36
- });
37
- // this.formSetting.View.ControlInfo.forEach((c) => (c.InlineEditMode = true));
38
- const assigneesReport = this.viewSetting.AssigneesReport?.$Caption;
39
- if (assigneesReport) {
40
- this._portalService.ReportExecute(assigneesReport).subscribe((report) => {
41
- this.allAvailableAssignees = report.MoDataList;
42
- this._changeDetect();
43
- });
44
- }
45
- this.viewSetting = {
46
- ...this.viewSetting,
47
- ...this._findColumn(this.allColumns, [
48
- this.viewSetting.Cover,
49
- this.viewSetting.State,
50
- this.viewSetting.Caption
51
- ])
52
- };
53
- this._prepareGroupMoList(this.moDataList);
54
- }
55
- ngOnChanges(changes) {
56
- super.ngOnChanges(changes);
57
- const { moDataList } = changes;
58
- if (moDataList && !moDataList.firstChange) {
59
- this._prepareGroupMoList(moDataList.currentValue);
60
- }
61
- }
62
- _prepareGroupMoList(molist) {
63
- const column = this._findColumnByDbName.transform(this.allColumns, this.viewSetting.State);
64
- const name = column?.Name || this.viewSetting.State;
65
- const dict = {};
66
- const s = this._multipleGroup.transform(molist, [
67
- {
68
- IsGrouped: true,
69
- Name: name,
70
- SortDirection: SortDirection.ASC
71
- }
72
- ]);
73
- s.forEach((c) => {
74
- if (c.$Group) {
75
- dict[c.$Group] = c.$Children;
76
- }
77
- });
78
- this.groupedMoList.set(dict);
79
- }
80
- onAddNewColumn() {
81
- this.kanbanColumns.push(this.newColumn);
82
- this._cdr.detectChanges();
83
- this._resetNewColumn();
84
- this._scrollInputIntoView();
85
- }
86
- onActiveNewColumnMode() {
87
- this._changeNewColumnMode(true);
88
- }
89
- onCancelNewColumn() {
90
- this._changeNewColumnMode(false);
91
- this._resetNewColumn();
92
- }
93
- onInitNewCard(groupby) {
94
- this._resetNewCard();
95
- this.newCard[this.groupbyProperty] = groupby;
96
- }
97
- onAddNewCard(e) {
98
- e.stopPropagation();
99
- e.preventDefault();
100
- this._addNewCard();
101
- }
102
- onNewCardInputFocusout() {
103
- if (this.newCard.$Caption) {
104
- this._addNewCard();
105
- }
106
- else {
107
- this._cancelNewCard();
108
- }
109
- }
110
- onCancelNewCard(e) {
111
- e.stopPropagation();
112
- e.preventDefault();
113
- this._cancelNewCard();
114
- }
115
- onDrop(event, isColumn) {
116
- let previousIndex;
117
- let currentIndex;
118
- const array = event.container.data;
119
- if (isColumn) {
120
- previousIndex = event.previousIndex;
121
- currentIndex = event.currentIndex;
122
- }
123
- else {
124
- const draggedItemId = this.dropActionTodo.draggedId;
125
- if (!draggedItemId) {
126
- return;
127
- }
128
- const draggedItem = this._getMoById(draggedItemId);
129
- const targetState = this.dropActionTodo.targetState;
130
- previousIndex = array.indexOf(draggedItem);
131
- currentIndex = this.dropActionTodo.targetIndex;
132
- draggedItem.State = targetState;
133
- this._stopDragging();
134
- }
135
- moveItemInArray(array, previousIndex, currentIndex);
136
- }
137
- onDragMove(event, draggedMo, draggedIndex, targetState) {
138
- const elementFromPoint = document.elementFromPoint(event.pointerPosition.x, event.pointerPosition.y);
139
- if (targetState) {
140
- }
141
- if (!elementFromPoint) {
142
- this._stopDragging();
143
- return;
144
- }
145
- const targetNodeElement = elementFromPoint.closest('[state]');
146
- if (!targetNodeElement) {
147
- this._stopDragging();
148
- return;
149
- }
150
- this.dropActionTodo = {
151
- draggedId: draggedMo.Id,
152
- targetId: targetNodeElement.getAttribute('id'),
153
- targetState: null,
154
- targetIndex: Number(targetNodeElement.getAttribute('index'))
155
- };
156
- const targetRect = targetNodeElement.getBoundingClientRect();
157
- const oneThird = targetRect.height / 3;
158
- const isCardTarget = !targetNodeElement.classList.contains('column');
159
- const isBefore = event.pointerPosition.y - targetRect.top < oneThird && isCardTarget;
160
- const isAfter = event.pointerPosition.y - targetRect.top > 2 * oneThird && isCardTarget;
161
- const isInside = !isCardTarget;
162
- const targetIndex = this.dropActionTodo.targetIndex ?? -1;
163
- const targetMo = this.moDataList[targetIndex];
164
- if (isCardTarget) {
165
- this.dropActionTodo.targetState = targetMo[this.viewSetting.State];
166
- }
167
- else {
168
- this.dropActionTodo.targetState = {
169
- $Caption: targetNodeElement.getAttribute('state'),
170
- Id: targetNodeElement.getAttribute('id'),
171
- $TypeDefId: draggedMo[this.viewSetting.State]?.$TypeDefId
172
- };
173
- }
174
- if (isBefore) {
175
- this.dropActionTodo.action = 'before';
176
- this.dropActionTodo.targetIndex = draggedIndex > targetIndex ? targetIndex : targetIndex - 1;
177
- }
178
- else if (isAfter) {
179
- this.dropActionTodo.action = 'after';
180
- this.dropActionTodo.targetIndex = draggedIndex < targetIndex ? targetIndex : targetIndex + 1;
181
- }
182
- else if (isInside) {
183
- this.dropActionTodo.action = 'inside';
184
- this.dropActionTodo.targetIndex = 0;
185
- }
186
- // console.log(this.dropActionTodo.targetState);
187
- this._showDragInfo();
188
- }
189
- _changeDetect() {
190
- this._cdr.detectChanges();
191
- }
192
- _stopDragging() {
193
- this._clearDragInfo();
194
- this._resetDropActionTodo();
195
- }
196
- _changeNewColumnMode(mode) {
197
- this.isNewColumnMode = mode;
198
- }
199
- _resetDropActionTodo() {
200
- this.dropActionTodo = {
201
- targetId: null,
202
- draggedId: null,
203
- targetState: null,
204
- targetIndex: null,
205
- action: null
206
- };
207
- }
208
- _scrollInputIntoView() {
209
- const inputEl = this.inputEl.nativeElement;
210
- inputEl.focus();
211
- inputEl.scrollIntoView({ inline: 'end' });
212
- }
213
- _resetNewColumn() {
214
- this.newColumn = { Id: '', $Caption: '' };
215
- }
216
- _clearDragInfo(dropped = false) {
217
- if (dropped) {
218
- this._resetDropActionTodo();
219
- }
220
- const elDom = this._el.nativeElement;
221
- elDom
222
- .querySelectorAll('.drop-before')
223
- .forEach((element) => this._renderer2.removeClass(element, 'drop-before'));
224
- elDom.querySelectorAll('.drop-after').forEach((element) => this._renderer2.removeClass(element, 'drop-after'));
225
- elDom
226
- .querySelectorAll('.drop-inside')
227
- .forEach((element) => this._renderer2.removeClass(element, 'drop-inside'));
228
- }
229
- _showDragInfo() {
230
- this._clearDragInfo();
231
- if (this.dropActionTodo.targetId) {
232
- const targetNodeElement = this._el.nativeElement.querySelector('#' + this.dropActionTodo.targetId);
233
- if (!targetNodeElement) {
234
- this._resetDropActionTodo();
235
- return;
236
- }
237
- this._renderer2.addClass(targetNodeElement, 'drop-' + this.dropActionTodo?.action);
238
- }
239
- }
240
- _addNewCard() {
241
- this.moDataList.push(this.newCard);
242
- const currentGroupby = this.newCard[this.groupbyProperty];
243
- this.onInitNewCard(currentGroupby);
244
- }
245
- _resetNewCard() {
246
- this.newCard = { Id: null, $Caption: null };
247
- }
248
- _cancelNewCard() {
249
- this._resetNewCard();
250
- }
251
- _getMoById(id) {
252
- return this.moDataList.find((c) => c.Id === id);
253
- }
254
- _findColumn(allColumns, columnsName) {
255
- const columns = {};
256
- columnsName.forEach((name) => {
257
- columns[name + 'Column'] = this._findColumnByDbName.transform(this.allColumns, name);
258
- });
259
- return columns;
260
- }
261
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KanbanViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
262
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: KanbanViewComponent, selector: "bk-kanban-view", inputs: { kanbanColumns: "kanbanColumns", groupbyProperty: "groupbyProperty" }, viewQueries: [{ propertyName: "inputEl", first: true, predicate: ["inputEl"], descendants: true, read: ElementRef }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<fd-layout-panel>\r\n <fd-layout-panel-body [bleed]=\"true\">\r\n @if (isCheckList) {\r\n <table fd-table>\r\n <thead fd-table-header>\r\n <tr fd-table-row>\r\n <th fd-table-cell>\r\n <fd-checkbox\r\n name=\"allCheckbox\"\r\n [ngModel]=\"allChecked\"\r\n (ngModelChange)=\"onAllCheckbox($event)\"\r\n >{{ 'All' | bbbTranslate }}</fd-checkbox\r\n >\r\n </th>\r\n </tr>\r\n </thead>\r\n </table>\r\n }\r\n </fd-layout-panel-body>\r\n</fd-layout-panel>\r\n\r\n<fd-layout-grid\r\n class=\"columns\"\r\n fillEmptySpace\r\n [setMinHeight]=\"true\"\r\n [disable]=\"true\"\r\n cdkDropList\r\n cdkDropListOrientation=\"horizontal\"\r\n [cdkDropListData]=\"kanbanColumns\"\r\n [id]=\"'$Root'\"\r\n (cdkDropListDropped)=\"onDrop($event, true)\"\r\n>\r\n @for (column of kanbanColumns; track column; let columnIndex = $index) {\r\n <div\r\n [fdLayoutGridCol]=\"12\"\r\n [colMd]=\"4\"\r\n [colLg]=\"3\"\r\n [colXl]=\"2\"\r\n class=\"column\"\r\n [id]=\"column.Id\"\r\n [attr.state]=\"column.$Caption\"\r\n cdkDrag\r\n >\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n columnCard;\r\n context: {\r\n column: column,\r\n columnIndex: columnIndex\r\n }\r\n \"\r\n ></ng-container>\r\n </div>\r\n }\r\n</fd-layout-grid>\r\n\r\n<!--noData-->\r\n\r\n<!--column card-->\r\n<ng-template #columnCard let-column=\"column\" let-columnIndex=\"columnIndex\">\r\n <fd-card cardType=\"quickView\" class=\"docs-flex-item-margin\" ellipsify>\r\n <fd-card-header>\r\n <fd-card-main-header [style.background]=\"column.Color\" [class.hasColumnColor]=\"column.Color\">\r\n <h2 fd-card-title>{{ column.$Caption }}</h2>\r\n </fd-card-main-header>\r\n </fd-card-header>\r\n <fd-card-content\r\n cdkDropList\r\n (cdkDropListDropped)=\"onDrop($event)\"\r\n [cdkDropListSortingDisabled]=\"true\"\r\n [cdkDropListData]=\"moDataList\"\r\n >\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n columnMoList;\r\n context: { $implicit: groupedMoList()[column.$Caption], column: column }\r\n \"\r\n >\r\n </ng-container>\r\n </fd-card-content>\r\n <!-- <fd-card-footer class=\"column-footer\">\r\n @if (newCard[groupbyProperty] === column.$Caption) {\r\n <div class=\"new-card\">\r\n <fd-card>\r\n <div fd-form-item>\r\n <textarea\r\n fd-form-control\r\n [autofocus]=\"true\"\r\n [(ngModel)]=\"newCard.$Caption\"\r\n (keydown.enter)=\"onAddNewCard($event)\"\r\n (focusout)=\"onNewCardInputFocusout()\"\r\n [placeholder]=\"'Title' | bbbTranslate\"\r\n ></textarea>\r\n </div>\r\n </fd-card>\r\n <div class=\"new-card-actions\">\r\n <button\r\n fd-button\r\n (click)=\"onAddNewCard($event)\"\r\n fdType=\"emphasized\"\r\n class=\"add-card-btn\"\r\n [label]=\"'\u0627\u0641\u0632\u0648\u062F\u0646'\"\r\n ></button>\r\n <fd-icon (mousedown)=\"onCancelNewCard($event)\" glyph=\"decline\"></fd-icon>\r\n </div>\r\n </div>\r\n } @else {\r\n <div class=\"add-new-card\" (click)=\"onInitNewCard(column.$Caption)\">\r\n <span>\r\n <fd-icon glyph=\"add\"></fd-icon>\r\n \u06A9\u0627\u0631\u062A \u062C\u062F\u06CC\u062F\r\n </span>\r\n </div>\r\n }\r\n </fd-card-footer> -->\r\n </fd-card>\r\n</ng-template>\r\n\r\n<ng-template #columnMoList let-moList let-column=\"column\">\r\n @if(moList && moList.length>0){ @for (mo of moList; track mo; let index = $index) {\r\n <bk-kanban-card\r\n [mo]=\"mo\"\r\n [allColumns]=\"columns\"\r\n [viewSetting]=\"viewSetting\"\r\n [formSetting]=\"formSetting\"\r\n [styleIndex]=\"mo.$StyleIndex\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [allAvailableAssignees]=\"allAvailableAssignees\"\r\n [index]=\"index\"\r\n [attr.id]=\"mo.Id\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [isChecked]=\"mo.$IsChecked\"\r\n [attr.state]=\"column.$Caption\"\r\n [attr.index]=\"index\"\r\n [class.selected]=\"mo.$IsChecked\"\r\n (cdkDragMoved)=\"onDragMove($event, mo, index, column)\"\r\n (click)=\"onRowCheck({mo, index})\"\r\n (dblclick)=\"onRowClick({mo, index})\"\r\n cdkDrag\r\n >\r\n </bk-kanban-card>\r\n } }@else{\r\n\r\n <h3 fd-title>{{ 'NoData' | bbbTranslate }}</h3>\r\n }\r\n</ng-template>\r\n", styles: ["fd-card-main-header.hasColumnColor{display:block}fd-card-main-header.hasColumnColor ::ng-deep .fd-card__header-main{background-color:transparent}figure{padding:0!important}figure ::ng-deep svg{margin:0}::-webkit-scrollbar{height:7px;width:7px}::-webkit-scrollbar-track{box-shadow:inset 0 0 2px #d0cece;border-radius:10px}::-webkit-scrollbar-thumb{background:#c8cacb;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#adb0b2}.columns{height:inherit;width:100%;column-gap:15px;flex-wrap:nowrap!important}.column{height:100%}.column.cdk-drag-placeholder{opacity:0}.column>fd-card{overflow-y:hidden;height:100%}.column>fd-card fd-card-content{flex:1;overflow-y:auto;padding:1rem .5rem;margin:0;display:flex;flex-direction:column;row-gap:1rem}.column>fd-card .column-footer{padding:1rem 1rem 1rem 1.5rem;position:sticky}.column>fd-card .column-footer .new-card{display:flex;flex-direction:column;justify-content:center;row-gap:1rem}.column>fd-card .column-footer .new-card fd-card{padding:0 1rem;background:var(--sapBackgroundColor, #f7f7f7)!important}.column>fd-card .column-footer .new-card textarea{background:var(--sapBackgroundColor, #f7f7f7)!important;border:none}.column>fd-card .column-footer .new-card span{height:auto!important}.column>fd-card .column-footer .new-card .new-card-actions{display:flex;align-items:center;column-gap:10px}.column>fd-card .column-footer .new-card .new-card-actions fd-icon{font-size:1rem}.column>fd-card .column-footer .add-new-card{padding:0 1rem}.column>fd-card .column-footer .add-new-card span{display:flex;column-gap:4px}.newColumn{background-color:var(--sapList_Background, #fff)!important;border-radius:var(--sapElement_BorderCornerRadius, .25rem);align-self:flex-start;height:100px;opacity:.5;display:flex;align-items:center;justify-content:center;border:1px dashed;position:relative;cursor:pointer}.newColumn span{position:absolute}.newColumn .new-column-popover{width:100%}.newColumn .new-column-popover fd-popover-control{width:100%;height:1px}.new-column-popover-body input{border:none}.row{display:flex;align-items:center}.drop-inside{border:1px solid #00f}.drop-inside ::ng-deep .fd-list__item{background-color:#dce9f6!important}.drop-before{border-top:2px solid #00f}.drop-before ::ng-deep .fd-list__item{background-color:#dce9f6!important}.drop-after{border-bottom:2px solid #00f}.drop-after ::ng-deep .fd-list__item{background-color:#dce9f6!important}.columns.cdk-drop-list-dragging .column:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}\n"], dependencies: [{ kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.EllipsifyDirective, selector: "[ellipsify]", inputs: ["limitLine"] }, { kind: "directive", type: i2.FillEmptySpaceDirective, selector: "[fillEmptySpace]", inputs: ["containerDom", "decrement", "disable", "height", "dontUseTopBound", "setMinHeight"], outputs: ["heightChanged"], exportAs: ["fillEmptySpace"] }, { kind: "component", type: i3.CardComponent, selector: "fd-card", inputs: ["badge", "badgeIcon", "badgeColor", "badgeColorSecondary", "badgeStatus", "badgeAriaLabel", "secondBadge", "secondBadgeIcon", "secondBadgeColor", "secondBadgeColorSecondary", "secondBadgeStatus", "secondBadgeAriaLabel", "isLoading", "cardType", "id", "ariaRoledescription", "ariaDescription", "ariaLabel", "role", "interactive", "selected", "ariaPosinset", "ariaSetsize"], outputs: ["ariaPosinsetChange", "ariaSetsizeChange"] }, { kind: "component", type: i3.CardHeaderComponent, selector: "fd-card-header", inputs: ["ariaRoleDescription"] }, { kind: "component", type: i3.CardMainHeaderComponent, selector: "fd-card-main-header", inputs: ["interactive", "title"] }, { kind: "component", type: i3.CardContentComponent, selector: "fd-card-content" }, { kind: "directive", type: i3.CardTitleDirective, selector: "[fd-card-title]", inputs: ["id"] }, { kind: "component", type: i4.CheckboxComponent, selector: "fd-checkbox", inputs: ["wrapLabel", "valignLabel", "ariaLabel", "role", "value", "ariaLabelledBy", "ariaDescribedBy", "title", "inputId", "state", "name", "label", "disabled", "readonly", "tristate", "tristateSelectable", "labelClass", "required", "displayOnly", "values", "standalone"], outputs: ["focusChange"] }, { kind: "component", type: i5.LayoutGridComponent, selector: "fd-layout-grid, [fdLayoutGrid]", inputs: ["class", "noGap", "noHorizontalGap", "noVerticalGap"] }, { kind: "directive", type: i5.LayoutGridColDirective, selector: "[fd-layout-grid-col], [fdLayoutGridCol]", inputs: ["fdLayoutGridCol", "colGrow", "colMd", "colLg", "colXl", "colOffset", "colOffsetMd", "colOffsetLg", "colOffsetXl", "class"] }, { kind: "component", type: i6.LayoutPanelComponent, selector: "fd-layout-panel", inputs: ["backgroundImage", "id", "transparent"] }, { kind: "component", type: i6.LayoutPanelBodyComponent, selector: "fd-layout-panel-body", inputs: ["bleed"] }, { kind: "component", type: i7.TitleComponent, selector: "[fd-title], [fdTitle]", inputs: ["headerSize", "wrap"], exportAs: ["fd-title"] }, { kind: "component", type: i8.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "noOuterBorder", "topBorder", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i8.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY", "nonInteractive"] }, { kind: "directive", type: i8.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i8.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "hoverable", "fitContent", "noPadding", "noData", "nonInteractive", "key"] }, { kind: "directive", type: i9.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i9.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i10.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep", "cdkDropListElementContainer"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i10.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i11.KanbanCardComponent, selector: "bk-kanban-card", inputs: ["index", "mo", "viewSetting", "allAvailableAssignees"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
263
- }
264
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: KanbanViewComponent, decorators: [{
265
- type: Component,
266
- args: [{ selector: 'bk-kanban-view', changeDetection: ChangeDetectionStrategy.OnPush, standalone: false, template: "<fd-layout-panel>\r\n <fd-layout-panel-body [bleed]=\"true\">\r\n @if (isCheckList) {\r\n <table fd-table>\r\n <thead fd-table-header>\r\n <tr fd-table-row>\r\n <th fd-table-cell>\r\n <fd-checkbox\r\n name=\"allCheckbox\"\r\n [ngModel]=\"allChecked\"\r\n (ngModelChange)=\"onAllCheckbox($event)\"\r\n >{{ 'All' | bbbTranslate }}</fd-checkbox\r\n >\r\n </th>\r\n </tr>\r\n </thead>\r\n </table>\r\n }\r\n </fd-layout-panel-body>\r\n</fd-layout-panel>\r\n\r\n<fd-layout-grid\r\n class=\"columns\"\r\n fillEmptySpace\r\n [setMinHeight]=\"true\"\r\n [disable]=\"true\"\r\n cdkDropList\r\n cdkDropListOrientation=\"horizontal\"\r\n [cdkDropListData]=\"kanbanColumns\"\r\n [id]=\"'$Root'\"\r\n (cdkDropListDropped)=\"onDrop($event, true)\"\r\n>\r\n @for (column of kanbanColumns; track column; let columnIndex = $index) {\r\n <div\r\n [fdLayoutGridCol]=\"12\"\r\n [colMd]=\"4\"\r\n [colLg]=\"3\"\r\n [colXl]=\"2\"\r\n class=\"column\"\r\n [id]=\"column.Id\"\r\n [attr.state]=\"column.$Caption\"\r\n cdkDrag\r\n >\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n columnCard;\r\n context: {\r\n column: column,\r\n columnIndex: columnIndex\r\n }\r\n \"\r\n ></ng-container>\r\n </div>\r\n }\r\n</fd-layout-grid>\r\n\r\n<!--noData-->\r\n\r\n<!--column card-->\r\n<ng-template #columnCard let-column=\"column\" let-columnIndex=\"columnIndex\">\r\n <fd-card cardType=\"quickView\" class=\"docs-flex-item-margin\" ellipsify>\r\n <fd-card-header>\r\n <fd-card-main-header [style.background]=\"column.Color\" [class.hasColumnColor]=\"column.Color\">\r\n <h2 fd-card-title>{{ column.$Caption }}</h2>\r\n </fd-card-main-header>\r\n </fd-card-header>\r\n <fd-card-content\r\n cdkDropList\r\n (cdkDropListDropped)=\"onDrop($event)\"\r\n [cdkDropListSortingDisabled]=\"true\"\r\n [cdkDropListData]=\"moDataList\"\r\n >\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n columnMoList;\r\n context: { $implicit: groupedMoList()[column.$Caption], column: column }\r\n \"\r\n >\r\n </ng-container>\r\n </fd-card-content>\r\n <!-- <fd-card-footer class=\"column-footer\">\r\n @if (newCard[groupbyProperty] === column.$Caption) {\r\n <div class=\"new-card\">\r\n <fd-card>\r\n <div fd-form-item>\r\n <textarea\r\n fd-form-control\r\n [autofocus]=\"true\"\r\n [(ngModel)]=\"newCard.$Caption\"\r\n (keydown.enter)=\"onAddNewCard($event)\"\r\n (focusout)=\"onNewCardInputFocusout()\"\r\n [placeholder]=\"'Title' | bbbTranslate\"\r\n ></textarea>\r\n </div>\r\n </fd-card>\r\n <div class=\"new-card-actions\">\r\n <button\r\n fd-button\r\n (click)=\"onAddNewCard($event)\"\r\n fdType=\"emphasized\"\r\n class=\"add-card-btn\"\r\n [label]=\"'\u0627\u0641\u0632\u0648\u062F\u0646'\"\r\n ></button>\r\n <fd-icon (mousedown)=\"onCancelNewCard($event)\" glyph=\"decline\"></fd-icon>\r\n </div>\r\n </div>\r\n } @else {\r\n <div class=\"add-new-card\" (click)=\"onInitNewCard(column.$Caption)\">\r\n <span>\r\n <fd-icon glyph=\"add\"></fd-icon>\r\n \u06A9\u0627\u0631\u062A \u062C\u062F\u06CC\u062F\r\n </span>\r\n </div>\r\n }\r\n </fd-card-footer> -->\r\n </fd-card>\r\n</ng-template>\r\n\r\n<ng-template #columnMoList let-moList let-column=\"column\">\r\n @if(moList && moList.length>0){ @for (mo of moList; track mo; let index = $index) {\r\n <bk-kanban-card\r\n [mo]=\"mo\"\r\n [allColumns]=\"columns\"\r\n [viewSetting]=\"viewSetting\"\r\n [formSetting]=\"formSetting\"\r\n [styleIndex]=\"mo.$StyleIndex\"\r\n [conditionalFormats]=\"conditionalFormats\"\r\n [allAvailableAssignees]=\"allAvailableAssignees\"\r\n [index]=\"index\"\r\n [attr.id]=\"mo.Id\"\r\n [inlineEditMode]=\"inlineEditMode\"\r\n [isChecked]=\"mo.$IsChecked\"\r\n [attr.state]=\"column.$Caption\"\r\n [attr.index]=\"index\"\r\n [class.selected]=\"mo.$IsChecked\"\r\n (cdkDragMoved)=\"onDragMove($event, mo, index, column)\"\r\n (click)=\"onRowCheck({mo, index})\"\r\n (dblclick)=\"onRowClick({mo, index})\"\r\n cdkDrag\r\n >\r\n </bk-kanban-card>\r\n } }@else{\r\n\r\n <h3 fd-title>{{ 'NoData' | bbbTranslate }}</h3>\r\n }\r\n</ng-template>\r\n", styles: ["fd-card-main-header.hasColumnColor{display:block}fd-card-main-header.hasColumnColor ::ng-deep .fd-card__header-main{background-color:transparent}figure{padding:0!important}figure ::ng-deep svg{margin:0}::-webkit-scrollbar{height:7px;width:7px}::-webkit-scrollbar-track{box-shadow:inset 0 0 2px #d0cece;border-radius:10px}::-webkit-scrollbar-thumb{background:#c8cacb;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#adb0b2}.columns{height:inherit;width:100%;column-gap:15px;flex-wrap:nowrap!important}.column{height:100%}.column.cdk-drag-placeholder{opacity:0}.column>fd-card{overflow-y:hidden;height:100%}.column>fd-card fd-card-content{flex:1;overflow-y:auto;padding:1rem .5rem;margin:0;display:flex;flex-direction:column;row-gap:1rem}.column>fd-card .column-footer{padding:1rem 1rem 1rem 1.5rem;position:sticky}.column>fd-card .column-footer .new-card{display:flex;flex-direction:column;justify-content:center;row-gap:1rem}.column>fd-card .column-footer .new-card fd-card{padding:0 1rem;background:var(--sapBackgroundColor, #f7f7f7)!important}.column>fd-card .column-footer .new-card textarea{background:var(--sapBackgroundColor, #f7f7f7)!important;border:none}.column>fd-card .column-footer .new-card span{height:auto!important}.column>fd-card .column-footer .new-card .new-card-actions{display:flex;align-items:center;column-gap:10px}.column>fd-card .column-footer .new-card .new-card-actions fd-icon{font-size:1rem}.column>fd-card .column-footer .add-new-card{padding:0 1rem}.column>fd-card .column-footer .add-new-card span{display:flex;column-gap:4px}.newColumn{background-color:var(--sapList_Background, #fff)!important;border-radius:var(--sapElement_BorderCornerRadius, .25rem);align-self:flex-start;height:100px;opacity:.5;display:flex;align-items:center;justify-content:center;border:1px dashed;position:relative;cursor:pointer}.newColumn span{position:absolute}.newColumn .new-column-popover{width:100%}.newColumn .new-column-popover fd-popover-control{width:100%;height:1px}.new-column-popover-body input{border:none}.row{display:flex;align-items:center}.drop-inside{border:1px solid #00f}.drop-inside ::ng-deep .fd-list__item{background-color:#dce9f6!important}.drop-before{border-top:2px solid #00f}.drop-before ::ng-deep .fd-list__item{background-color:#dce9f6!important}.drop-after{border-bottom:2px solid #00f}.drop-after ::ng-deep .fd-list__item{background-color:#dce9f6!important}.columns.cdk-drop-list-dragging .column:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}\n"] }]
267
- }], propDecorators: { inputEl: [{
268
- type: ViewChild,
269
- args: ['inputEl', { read: ElementRef }]
270
- }], kanbanColumns: [{
271
- type: Input
272
- }], groupbyProperty: [{
273
- type: Input
274
- }] } });
275
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kanban-view.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-kanban/src/lib/kanban-view/kanban-view.component.ts","../../../../../projects/barsa-kanban/src/lib/kanban-view/kanban-view.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    ElementRef,\r\n    inject,\r\n    Input,\r\n    OnInit,\r\n    SimpleChanges,\r\n    ViewChild,\r\n    signal\r\n} from '@angular/core';\r\nimport { moveItemInArray } from '@angular/cdk/drag-drop';\r\n\r\nimport { MetaobjectDataModel, MultipleGroupByPipe, ReportViewBaseComponent, SortDirection } from 'barsa-novin-ray-core';\r\nimport { KanbanViewSetting } from '../Models/kanban-view-setting.interface';\r\nimport { DropInfo } from '../Models/drop-info';\r\n\r\n@Component({\r\n    selector: 'bk-kanban-view',\r\n    templateUrl: './kanban-view.component.html',\r\n    styleUrls: ['./kanban-view.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: false\r\n})\r\nexport class KanbanViewComponent extends ReportViewBaseComponent<KanbanViewSetting> implements OnInit {\r\n    @ViewChild('inputEl', { read: ElementRef }) inputEl: ElementRef<any>;\r\n    @Input() kanbanColumns: MetaobjectDataModel[];\r\n    @Input() groupbyProperty = 'State';\r\n    dropActionTodo: DropInfo;\r\n    allAvailableAssignees: MetaobjectDataModel[];\r\n    isNewColumnMode = false;\r\n    newCard: any = { Id: null, $Caption: null };\r\n    newColumn: any = { Id: null, $Caption: null };\r\n    _multipleGroup = inject(MultipleGroupByPipe);\r\n    groupedMoList = signal({});\r\n    sceneConfig = {\r\n        scene: { url: 'assets/images/sapIllus-Scene-NoMail.svg', id: 'sapIllus-Scene-NoMail-1' },\r\n        dialog: { url: 'assets/images/sapIllus-Dialog-NoMail.svg', id: 'sapIllus-Dialog-NoMail' }\r\n    };\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n\r\n        const columnsReport = this.viewSetting.ColumnsReport.$Caption;\r\n        this._portalService.ReportExecute(columnsReport).subscribe((report) => {\r\n            this.kanbanColumns = report.MoDataList;\r\n            this._changeDetect();\r\n        });\r\n        // this.formSetting.View.ControlInfo.forEach((c) => (c.InlineEditMode = true));\r\n        const assigneesReport = this.viewSetting.AssigneesReport?.$Caption;\r\n        if (assigneesReport) {\r\n            this._portalService.ReportExecute(assigneesReport).subscribe((report) => {\r\n                this.allAvailableAssignees = report.MoDataList;\r\n                this._changeDetect();\r\n            });\r\n        }\r\n        this.viewSetting = {\r\n            ...this.viewSetting,\r\n            ...this._findColumn(this.allColumns, [\r\n                this.viewSetting.Cover,\r\n                this.viewSetting.State,\r\n                this.viewSetting.Caption\r\n            ])\r\n        };\r\n        this._prepareGroupMoList(this.moDataList);\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        const { moDataList } = changes;\r\n        if (moDataList && !moDataList.firstChange) {\r\n            this._prepareGroupMoList(moDataList.currentValue);\r\n        }\r\n    }\r\n    _prepareGroupMoList(molist: MetaobjectDataModel[]): void {\r\n        const column = this._findColumnByDbName.transform(this.allColumns, this.viewSetting.State);\r\n        const name = column?.Name || this.viewSetting.State;\r\n        const dict = {};\r\n        const s: any[] = this._multipleGroup.transform(molist, [\r\n            {\r\n                IsGrouped: true,\r\n                Name: name,\r\n                SortDirection: SortDirection.ASC\r\n            }\r\n        ]);\r\n        s.forEach((c) => {\r\n            if (c.$Group) {\r\n                dict[c.$Group] = c.$Children;\r\n            }\r\n        });\r\n        this.groupedMoList.set(dict);\r\n    }\r\n\r\n    onAddNewColumn(): void {\r\n        this.kanbanColumns.push(this.newColumn);\r\n        this._cdr.detectChanges();\r\n        this._resetNewColumn();\r\n        this._scrollInputIntoView();\r\n    }\r\n\r\n    onActiveNewColumnMode(): void {\r\n        this._changeNewColumnMode(true);\r\n    }\r\n\r\n    onCancelNewColumn(): void {\r\n        this._changeNewColumnMode(false);\r\n        this._resetNewColumn();\r\n    }\r\n\r\n    onInitNewCard(groupby: string): void {\r\n        this._resetNewCard();\r\n        this.newCard[this.groupbyProperty] = groupby;\r\n    }\r\n\r\n    onAddNewCard(e): void {\r\n        e.stopPropagation();\r\n        e.preventDefault();\r\n        this._addNewCard();\r\n    }\r\n\r\n    onNewCardInputFocusout(): void {\r\n        if (this.newCard.$Caption) {\r\n            this._addNewCard();\r\n        } else {\r\n            this._cancelNewCard();\r\n        }\r\n    }\r\n\r\n    onCancelNewCard(e: MouseEvent): void {\r\n        e.stopPropagation();\r\n        e.preventDefault();\r\n        this._cancelNewCard();\r\n    }\r\n\r\n    onDrop(event, isColumn?: boolean): void {\r\n        let previousIndex;\r\n        let currentIndex;\r\n        const array = event.container.data;\r\n\r\n        if (isColumn) {\r\n            previousIndex = event.previousIndex;\r\n            currentIndex = event.currentIndex;\r\n        } else {\r\n            const draggedItemId = this.dropActionTodo.draggedId;\r\n            if (!draggedItemId) {\r\n                return;\r\n            }\r\n            const draggedItem = this._getMoById(draggedItemId);\r\n            const targetState = this.dropActionTodo.targetState;\r\n            previousIndex = array.indexOf(draggedItem);\r\n            currentIndex = this.dropActionTodo.targetIndex;\r\n            draggedItem.State = targetState;\r\n            this._stopDragging();\r\n        }\r\n\r\n        moveItemInArray(array, previousIndex, currentIndex);\r\n    }\r\n\r\n    onDragMove(event, draggedMo, draggedIndex: number, targetState: MetaobjectDataModel): void {\r\n        const elementFromPoint = document.elementFromPoint(event.pointerPosition.x, event.pointerPosition.y);\r\n\r\n        if (targetState) {\r\n        }\r\n        if (!elementFromPoint) {\r\n            this._stopDragging();\r\n            return;\r\n        }\r\n        const targetNodeElement = elementFromPoint.closest('[state]');\r\n        if (!targetNodeElement) {\r\n            this._stopDragging();\r\n            return;\r\n        }\r\n        this.dropActionTodo = {\r\n            draggedId: draggedMo.Id,\r\n            targetId: targetNodeElement.getAttribute('id'),\r\n            targetState: null,\r\n            targetIndex: Number(targetNodeElement.getAttribute('index'))\r\n        };\r\n        const targetRect = targetNodeElement.getBoundingClientRect();\r\n        const oneThird = targetRect.height / 3;\r\n\r\n        const isCardTarget = !targetNodeElement.classList.contains('column');\r\n\r\n        const isBefore = event.pointerPosition.y - targetRect.top < oneThird && isCardTarget;\r\n\r\n        const isAfter = event.pointerPosition.y - targetRect.top > 2 * oneThird && isCardTarget;\r\n\r\n        const isInside = !isCardTarget;\r\n\r\n        const targetIndex = this.dropActionTodo.targetIndex ?? -1;\r\n        const targetMo = this.moDataList[targetIndex];\r\n\r\n        if (isCardTarget) {\r\n            this.dropActionTodo.targetState = targetMo[this.viewSetting.State];\r\n        } else {\r\n            this.dropActionTodo.targetState = {\r\n                $Caption: targetNodeElement.getAttribute('state')!,\r\n                Id: targetNodeElement.getAttribute('id')!,\r\n                $TypeDefId: draggedMo[this.viewSetting.State]?.$TypeDefId\r\n            };\r\n        }\r\n        if (isBefore) {\r\n            this.dropActionTodo.action = 'before';\r\n            this.dropActionTodo.targetIndex = draggedIndex > targetIndex ? targetIndex : targetIndex - 1;\r\n        } else if (isAfter) {\r\n            this.dropActionTodo.action = 'after';\r\n            this.dropActionTodo.targetIndex = draggedIndex < targetIndex ? targetIndex : targetIndex + 1;\r\n        } else if (isInside) {\r\n            this.dropActionTodo.action = 'inside';\r\n            this.dropActionTodo.targetIndex = 0;\r\n        }\r\n        // console.log(this.dropActionTodo.targetState);\r\n        this._showDragInfo();\r\n    }\r\n    private _changeDetect(): void {\r\n        this._cdr.detectChanges();\r\n    }\r\n\r\n    private _stopDragging(): void {\r\n        this._clearDragInfo();\r\n        this._resetDropActionTodo();\r\n    }\r\n\r\n    private _changeNewColumnMode(mode: boolean): void {\r\n        this.isNewColumnMode = mode;\r\n    }\r\n\r\n    private _resetDropActionTodo(): void {\r\n        this.dropActionTodo = {\r\n            targetId: null,\r\n            draggedId: null,\r\n            targetState: null,\r\n            targetIndex: null,\r\n            action: null\r\n        };\r\n    }\r\n\r\n    private _scrollInputIntoView(): void {\r\n        const inputEl: HTMLInputElement = this.inputEl.nativeElement;\r\n        inputEl.focus();\r\n        inputEl.scrollIntoView({ inline: 'end' });\r\n    }\r\n\r\n    private _resetNewColumn(): void {\r\n        this.newColumn = { Id: '', $Caption: '' };\r\n    }\r\n\r\n    private _clearDragInfo(dropped = false): void {\r\n        if (dropped) {\r\n            this._resetDropActionTodo();\r\n        }\r\n        const elDom = this._el.nativeElement;\r\n        elDom\r\n            .querySelectorAll('.drop-before')\r\n            .forEach((element) => this._renderer2.removeClass(element, 'drop-before'));\r\n        elDom.querySelectorAll('.drop-after').forEach((element) => this._renderer2.removeClass(element, 'drop-after'));\r\n        elDom\r\n            .querySelectorAll('.drop-inside')\r\n            .forEach((element) => this._renderer2.removeClass(element, 'drop-inside'));\r\n    }\r\n\r\n    private _showDragInfo(): void {\r\n        this._clearDragInfo();\r\n        if (this.dropActionTodo.targetId) {\r\n            const targetNodeElement = this._el.nativeElement.querySelector('#' + this.dropActionTodo.targetId);\r\n            if (!targetNodeElement) {\r\n                this._resetDropActionTodo();\r\n                return;\r\n            }\r\n            this._renderer2.addClass(targetNodeElement, 'drop-' + this.dropActionTodo?.action);\r\n        }\r\n    }\r\n\r\n    private _addNewCard(): void {\r\n        this.moDataList.push(this.newCard);\r\n        const currentGroupby = this.newCard[this.groupbyProperty];\r\n        this.onInitNewCard(currentGroupby);\r\n    }\r\n\r\n    private _resetNewCard(): void {\r\n        this.newCard = { Id: null, $Caption: null };\r\n    }\r\n\r\n    private _cancelNewCard(): void {\r\n        this._resetNewCard();\r\n    }\r\n\r\n    private _getMoById(id: string): MetaobjectDataModel {\r\n        return this.moDataList.find((c) => c.Id === id);\r\n    }\r\n\r\n    private _findColumn(allColumns, columnsName: string[]): object {\r\n        const columns = {};\r\n        columnsName.forEach((name) => {\r\n            columns[name + 'Column'] = this._findColumnByDbName.transform(this.allColumns, name);\r\n        });\r\n        return columns;\r\n    }\r\n}\r\n","<fd-layout-panel>\r\n    <fd-layout-panel-body [bleed]=\"true\">\r\n        @if (isCheckList) {\r\n        <table fd-table>\r\n            <thead fd-table-header>\r\n                <tr fd-table-row>\r\n                    <th fd-table-cell>\r\n                        <fd-checkbox\r\n                            name=\"allCheckbox\"\r\n                            [ngModel]=\"allChecked\"\r\n                            (ngModelChange)=\"onAllCheckbox($event)\"\r\n                            >{{ 'All' | bbbTranslate }}</fd-checkbox\r\n                        >\r\n                    </th>\r\n                </tr>\r\n            </thead>\r\n        </table>\r\n        }\r\n    </fd-layout-panel-body>\r\n</fd-layout-panel>\r\n\r\n<fd-layout-grid\r\n    class=\"columns\"\r\n    fillEmptySpace\r\n    [setMinHeight]=\"true\"\r\n    [disable]=\"true\"\r\n    cdkDropList\r\n    cdkDropListOrientation=\"horizontal\"\r\n    [cdkDropListData]=\"kanbanColumns\"\r\n    [id]=\"'$Root'\"\r\n    (cdkDropListDropped)=\"onDrop($event, true)\"\r\n>\r\n    @for (column of kanbanColumns; track column; let columnIndex = $index) {\r\n    <div\r\n        [fdLayoutGridCol]=\"12\"\r\n        [colMd]=\"4\"\r\n        [colLg]=\"3\"\r\n        [colXl]=\"2\"\r\n        class=\"column\"\r\n        [id]=\"column.Id\"\r\n        [attr.state]=\"column.$Caption\"\r\n        cdkDrag\r\n    >\r\n        <ng-container\r\n            *ngTemplateOutlet=\"\r\n                columnCard;\r\n                context: {\r\n                    column: column,\r\n                    columnIndex: columnIndex\r\n                }\r\n            \"\r\n        ></ng-container>\r\n    </div>\r\n    }\r\n</fd-layout-grid>\r\n\r\n<!--noData-->\r\n\r\n<!--column card-->\r\n<ng-template #columnCard let-column=\"column\" let-columnIndex=\"columnIndex\">\r\n    <fd-card cardType=\"quickView\" class=\"docs-flex-item-margin\" ellipsify>\r\n        <fd-card-header>\r\n            <fd-card-main-header [style.background]=\"column.Color\" [class.hasColumnColor]=\"column.Color\">\r\n                <h2 fd-card-title>{{ column.$Caption }}</h2>\r\n            </fd-card-main-header>\r\n        </fd-card-header>\r\n        <fd-card-content\r\n            cdkDropList\r\n            (cdkDropListDropped)=\"onDrop($event)\"\r\n            [cdkDropListSortingDisabled]=\"true\"\r\n            [cdkDropListData]=\"moDataList\"\r\n        >\r\n            <ng-container\r\n                *ngTemplateOutlet=\"\r\n                    columnMoList;\r\n                    context: { $implicit: groupedMoList()[column.$Caption], column: column }\r\n                \"\r\n            >\r\n            </ng-container>\r\n        </fd-card-content>\r\n        <!-- <fd-card-footer class=\"column-footer\">\r\n            @if (newCard[groupbyProperty] === column.$Caption) {\r\n            <div class=\"new-card\">\r\n                <fd-card>\r\n                    <div fd-form-item>\r\n                        <textarea\r\n                            fd-form-control\r\n                            [autofocus]=\"true\"\r\n                            [(ngModel)]=\"newCard.$Caption\"\r\n                            (keydown.enter)=\"onAddNewCard($event)\"\r\n                            (focusout)=\"onNewCardInputFocusout()\"\r\n                            [placeholder]=\"'Title' | bbbTranslate\"\r\n                        ></textarea>\r\n                    </div>\r\n                </fd-card>\r\n                <div class=\"new-card-actions\">\r\n                    <button\r\n                        fd-button\r\n                        (click)=\"onAddNewCard($event)\"\r\n                        fdType=\"emphasized\"\r\n                        class=\"add-card-btn\"\r\n                        [label]=\"'افزودن'\"\r\n                    ></button>\r\n                    <fd-icon (mousedown)=\"onCancelNewCard($event)\" glyph=\"decline\"></fd-icon>\r\n                </div>\r\n            </div>\r\n            } @else {\r\n            <div class=\"add-new-card\" (click)=\"onInitNewCard(column.$Caption)\">\r\n                <span>\r\n                    <fd-icon glyph=\"add\"></fd-icon>\r\n                    کارت جدید\r\n                </span>\r\n            </div>\r\n            }\r\n        </fd-card-footer> -->\r\n    </fd-card>\r\n</ng-template>\r\n\r\n<ng-template #columnMoList let-moList let-column=\"column\">\r\n    @if(moList && moList.length>0){ @for (mo of moList; track mo; let index = $index) {\r\n    <bk-kanban-card\r\n        [mo]=\"mo\"\r\n        [allColumns]=\"columns\"\r\n        [viewSetting]=\"viewSetting\"\r\n        [formSetting]=\"formSetting\"\r\n        [styleIndex]=\"mo.$StyleIndex\"\r\n        [conditionalFormats]=\"conditionalFormats\"\r\n        [allAvailableAssignees]=\"allAvailableAssignees\"\r\n        [index]=\"index\"\r\n        [attr.id]=\"mo.Id\"\r\n        [inlineEditMode]=\"inlineEditMode\"\r\n        [isChecked]=\"mo.$IsChecked\"\r\n        [attr.state]=\"column.$Caption\"\r\n        [attr.index]=\"index\"\r\n        [class.selected]=\"mo.$IsChecked\"\r\n        (cdkDragMoved)=\"onDragMove($event, mo, index, column)\"\r\n        (click)=\"onRowCheck({mo, index})\"\r\n        (dblclick)=\"onRowClick({mo, index})\"\r\n        cdkDrag\r\n    >\r\n    </bk-kanban-card>\r\n    } }@else{\r\n\r\n    <h3 fd-title>{{ 'NoData' | bbbTranslate }}</h3>\r\n    }\r\n</ng-template>\r\n"]}
@@ -1,7 +0,0 @@
1
- export * from './lib/kanban-base/kanban-base.component';
2
- export * from './lib/kanban-tags/kanban-tags.component';
3
- export * from './lib/kanban-card/kanban-card.component';
4
- export * from './lib/avatar-group/barsa-avatar-group.component';
5
- export * from './lib/kanban-view/kanban-view.component';
6
- export * from './lib/barsa-kanban.module';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWthbmJhbi9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2thbmJhbi1iYXNlL2thbmJhbi1iYXNlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2thbmJhbi10YWdzL2thbmJhbi10YWdzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2thbmJhbi1jYXJkL2thbmJhbi1jYXJkLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F2YXRhci1ncm91cC9iYXJzYS1hdmF0YXItZ3JvdXAuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIva2FuYmFuLXZpZXcva2FuYmFuLXZpZXcuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYmFyc2Eta2FuYmFuLm1vZHVsZSc7XHJcbiJdfQ==