barsa-kanban 0.0.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.
- package/README.md +24 -0
- package/esm2020/barsa-kanban.mjs +5 -0
- package/esm2020/lib/Models/drop-info.mjs +2 -0
- package/esm2020/lib/Models/kanban-view-setting.interface.mjs +2 -0
- package/esm2020/lib/avatar-group/barsa-avatar-group.component.mjs +84 -0
- package/esm2020/lib/barsa-kanban.module.mjs +79 -0
- package/esm2020/lib/kanban-base/kanban-base.component.mjs +20 -0
- package/esm2020/lib/kanban-card/kanban-card.component.mjs +38 -0
- package/esm2020/lib/kanban-tags/kanban-tags.component.mjs +43 -0
- package/esm2020/lib/kanban-view/kanban-view.component.mjs +244 -0
- package/esm2020/public-api.mjs +7 -0
- package/fesm2015/barsa-kanban.mjs +476 -0
- package/fesm2015/barsa-kanban.mjs.map +1 -0
- package/fesm2020/barsa-kanban.mjs +477 -0
- package/fesm2020/barsa-kanban.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/Models/drop-info.d.ts +8 -0
- package/lib/Models/kanban-view-setting.interface.d.ts +17 -0
- package/lib/avatar-group/barsa-avatar-group.component.d.ts +28 -0
- package/lib/barsa-kanban.module.d.ts +29 -0
- package/lib/kanban-base/kanban-base.component.d.ts +9 -0
- package/lib/kanban-card/kanban-card.component.d.ts +16 -0
- package/lib/kanban-tags/kanban-tags.component.d.ts +16 -0
- package/lib/kanban-view/kanban-view.component.d.ts +40 -0
- package/package.json +31 -0
- package/public-api.d.ts +6 -0
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ElementRef, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { moveItemInArray } from '@angular/cdk/drag-drop';
|
|
3
|
+
import { ReportViewBaseComponent } 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/button";
|
|
8
|
+
import * as i4 from "@fundamental-ngx/core/card";
|
|
9
|
+
import * as i5 from "@fundamental-ngx/core/checkbox";
|
|
10
|
+
import * as i6 from "@fundamental-ngx/core/form";
|
|
11
|
+
import * as i7 from "@fundamental-ngx/core/icon";
|
|
12
|
+
import * as i8 from "@fundamental-ngx/core/layout-grid";
|
|
13
|
+
import * as i9 from "@fundamental-ngx/core/layout-panel";
|
|
14
|
+
import * as i10 from "@fundamental-ngx/core/table";
|
|
15
|
+
import * as i11 from "barsa-sap-ui";
|
|
16
|
+
import * as i12 from "@angular/forms";
|
|
17
|
+
import * as i13 from "@angular/cdk/drag-drop";
|
|
18
|
+
import * as i14 from "../kanban-card/kanban-card.component";
|
|
19
|
+
export class KanbanViewComponent extends ReportViewBaseComponent {
|
|
20
|
+
constructor() {
|
|
21
|
+
super(...arguments);
|
|
22
|
+
this.groupbyProperty = 'State';
|
|
23
|
+
this.isNewColumnMode = false;
|
|
24
|
+
this.newCard = { Id: null, $Caption: null };
|
|
25
|
+
this.newColumn = { Id: null, $Caption: null };
|
|
26
|
+
}
|
|
27
|
+
ngOnInit() {
|
|
28
|
+
super.ngOnInit();
|
|
29
|
+
const columnsReport = this.viewSetting.ColumnsReport.$Caption;
|
|
30
|
+
this._portalService.ReportExecute(columnsReport).subscribe((report) => {
|
|
31
|
+
this.kanbanColumns = report.MoDataList;
|
|
32
|
+
this._changeDetect();
|
|
33
|
+
});
|
|
34
|
+
this.formSetting.View.ControlInfo.forEach((c) => (c.InlineEditMode = true));
|
|
35
|
+
const assigneesReport = this.viewSetting.AssigneesReport.$Caption;
|
|
36
|
+
this._portalService.ReportExecute(assigneesReport).subscribe((report) => {
|
|
37
|
+
this.allAvailableAssignees = report.MoDataList;
|
|
38
|
+
this._changeDetect();
|
|
39
|
+
});
|
|
40
|
+
this.viewSetting = {
|
|
41
|
+
...this.viewSetting,
|
|
42
|
+
...this._findColumn(this.allColumns, [
|
|
43
|
+
this.viewSetting.Cover,
|
|
44
|
+
this.viewSetting.State,
|
|
45
|
+
this.viewSetting.Caption
|
|
46
|
+
])
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
onAddNewColumn() {
|
|
50
|
+
this.kanbanColumns.push(this.newColumn);
|
|
51
|
+
this._cdr.detectChanges();
|
|
52
|
+
this._resetNewColumn();
|
|
53
|
+
this._scrollInputIntoView();
|
|
54
|
+
}
|
|
55
|
+
onActiveNewColumnMode() {
|
|
56
|
+
this._changeNewColumnMode(true);
|
|
57
|
+
}
|
|
58
|
+
onCancelNewColumn() {
|
|
59
|
+
this._changeNewColumnMode(false);
|
|
60
|
+
this._resetNewColumn();
|
|
61
|
+
}
|
|
62
|
+
onInitNewCard(groupby) {
|
|
63
|
+
this._resetNewCard();
|
|
64
|
+
this.newCard[this.groupbyProperty] = groupby;
|
|
65
|
+
}
|
|
66
|
+
onAddNewCard(e) {
|
|
67
|
+
e.stopPropagation();
|
|
68
|
+
e.preventDefault();
|
|
69
|
+
this._addNewCard();
|
|
70
|
+
}
|
|
71
|
+
onNewCardInputFocusout() {
|
|
72
|
+
if (this.newCard.$Caption) {
|
|
73
|
+
this._addNewCard();
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
this._cancelNewCard();
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
onCancelNewCard(e) {
|
|
80
|
+
e.stopPropagation();
|
|
81
|
+
e.preventDefault();
|
|
82
|
+
this._cancelNewCard();
|
|
83
|
+
}
|
|
84
|
+
onDrop(event, isColumn) {
|
|
85
|
+
let previousIndex;
|
|
86
|
+
let currentIndex;
|
|
87
|
+
const array = event.container.data;
|
|
88
|
+
if (isColumn) {
|
|
89
|
+
previousIndex = event.previousIndex;
|
|
90
|
+
currentIndex = event.currentIndex;
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
const draggedItemId = this.dropActionTodo.draggedId;
|
|
94
|
+
if (!draggedItemId) {
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
const draggedItem = this._getMoById(draggedItemId);
|
|
98
|
+
const targetState = this.dropActionTodo.targetState;
|
|
99
|
+
previousIndex = array.indexOf(draggedItem);
|
|
100
|
+
currentIndex = this.dropActionTodo.targetIndex;
|
|
101
|
+
draggedItem.State = targetState;
|
|
102
|
+
this._stopDragging();
|
|
103
|
+
}
|
|
104
|
+
moveItemInArray(array, previousIndex, currentIndex);
|
|
105
|
+
}
|
|
106
|
+
onDragMove(event, draggedMo, draggedIndex, targetState) {
|
|
107
|
+
const elementFromPoint = document.elementFromPoint(event.pointerPosition.x, event.pointerPosition.y);
|
|
108
|
+
if (targetState) {
|
|
109
|
+
}
|
|
110
|
+
if (!elementFromPoint) {
|
|
111
|
+
this._stopDragging();
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
const targetNodeElement = elementFromPoint.closest('[state]');
|
|
115
|
+
if (!targetNodeElement) {
|
|
116
|
+
this._stopDragging();
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
this.dropActionTodo = {
|
|
120
|
+
draggedId: draggedMo.Id,
|
|
121
|
+
targetId: targetNodeElement.getAttribute('id'),
|
|
122
|
+
targetState: null,
|
|
123
|
+
targetIndex: Number(targetNodeElement.getAttribute('index'))
|
|
124
|
+
};
|
|
125
|
+
const targetRect = targetNodeElement.getBoundingClientRect();
|
|
126
|
+
const oneThird = targetRect.height / 3;
|
|
127
|
+
const isCardTarget = !targetNodeElement.classList.contains('column');
|
|
128
|
+
const isBefore = event.pointerPosition.y - targetRect.top < oneThird && isCardTarget;
|
|
129
|
+
const isAfter = event.pointerPosition.y - targetRect.top > 2 * oneThird && isCardTarget;
|
|
130
|
+
const isInside = !isCardTarget;
|
|
131
|
+
const targetIndex = this.dropActionTodo.targetIndex ?? -1;
|
|
132
|
+
const targetMo = this.moDataList[targetIndex];
|
|
133
|
+
if (isCardTarget) {
|
|
134
|
+
this.dropActionTodo.targetState = targetMo[this.viewSetting.State];
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
this.dropActionTodo.targetState = {
|
|
138
|
+
$Caption: targetNodeElement.getAttribute('state'),
|
|
139
|
+
Id: targetNodeElement.getAttribute('id'),
|
|
140
|
+
$TypeDefId: draggedMo[this.viewSetting.State]?.$TypeDefId
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
if (isBefore) {
|
|
144
|
+
this.dropActionTodo.action = 'before';
|
|
145
|
+
this.dropActionTodo.targetIndex = draggedIndex > targetIndex ? targetIndex : targetIndex - 1;
|
|
146
|
+
}
|
|
147
|
+
else if (isAfter) {
|
|
148
|
+
this.dropActionTodo.action = 'after';
|
|
149
|
+
this.dropActionTodo.targetIndex = draggedIndex < targetIndex ? targetIndex : targetIndex + 1;
|
|
150
|
+
}
|
|
151
|
+
else if (isInside) {
|
|
152
|
+
this.dropActionTodo.action = 'inside';
|
|
153
|
+
this.dropActionTodo.targetIndex = 0;
|
|
154
|
+
}
|
|
155
|
+
console.log(this.dropActionTodo.targetState);
|
|
156
|
+
this._showDragInfo();
|
|
157
|
+
}
|
|
158
|
+
_changeDetect() {
|
|
159
|
+
this._cdr.detectChanges();
|
|
160
|
+
}
|
|
161
|
+
_stopDragging() {
|
|
162
|
+
this._clearDragInfo();
|
|
163
|
+
this._resetDropActionTodo();
|
|
164
|
+
}
|
|
165
|
+
_changeNewColumnMode(mode) {
|
|
166
|
+
this.isNewColumnMode = mode;
|
|
167
|
+
}
|
|
168
|
+
_resetDropActionTodo() {
|
|
169
|
+
this.dropActionTodo = {
|
|
170
|
+
targetId: null,
|
|
171
|
+
draggedId: null,
|
|
172
|
+
targetState: null,
|
|
173
|
+
targetIndex: null,
|
|
174
|
+
action: null
|
|
175
|
+
};
|
|
176
|
+
}
|
|
177
|
+
_scrollInputIntoView() {
|
|
178
|
+
const inputEl = this.inputEl.nativeElement;
|
|
179
|
+
inputEl.focus();
|
|
180
|
+
inputEl.scrollIntoView({ inline: 'end' });
|
|
181
|
+
}
|
|
182
|
+
_resetNewColumn() {
|
|
183
|
+
this.newColumn = { Id: '', $Caption: '' };
|
|
184
|
+
}
|
|
185
|
+
_clearDragInfo(dropped = false) {
|
|
186
|
+
if (dropped) {
|
|
187
|
+
this._resetDropActionTodo();
|
|
188
|
+
}
|
|
189
|
+
const elDom = this._el.nativeElement;
|
|
190
|
+
elDom
|
|
191
|
+
.querySelectorAll('.drop-before')
|
|
192
|
+
.forEach((element) => this._renderer2.removeClass(element, 'drop-before'));
|
|
193
|
+
elDom.querySelectorAll('.drop-after').forEach((element) => this._renderer2.removeClass(element, 'drop-after'));
|
|
194
|
+
elDom
|
|
195
|
+
.querySelectorAll('.drop-inside')
|
|
196
|
+
.forEach((element) => this._renderer2.removeClass(element, 'drop-inside'));
|
|
197
|
+
}
|
|
198
|
+
_showDragInfo() {
|
|
199
|
+
this._clearDragInfo();
|
|
200
|
+
if (this.dropActionTodo.targetId) {
|
|
201
|
+
const targetNodeElement = this._el.nativeElement.querySelector('#' + this.dropActionTodo.targetId);
|
|
202
|
+
if (!targetNodeElement) {
|
|
203
|
+
this._resetDropActionTodo();
|
|
204
|
+
return;
|
|
205
|
+
}
|
|
206
|
+
this._renderer2.addClass(targetNodeElement, 'drop-' + this.dropActionTodo?.action);
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
_addNewCard() {
|
|
210
|
+
this.moDataList.push(this.newCard);
|
|
211
|
+
const currentGroupby = this.newCard[this.groupbyProperty];
|
|
212
|
+
this.onInitNewCard(currentGroupby);
|
|
213
|
+
}
|
|
214
|
+
_resetNewCard() {
|
|
215
|
+
this.newCard = { Id: null, $Caption: null };
|
|
216
|
+
}
|
|
217
|
+
_cancelNewCard() {
|
|
218
|
+
this._resetNewCard();
|
|
219
|
+
}
|
|
220
|
+
_getMoById(id) {
|
|
221
|
+
return this.moDataList.find((c) => c.Id === id);
|
|
222
|
+
}
|
|
223
|
+
_findColumn(allColumns, columnsName) {
|
|
224
|
+
const columns = {};
|
|
225
|
+
columnsName.forEach((name) => {
|
|
226
|
+
columns[name + 'Column'] = this._findColumnByDbName.transform(this.allColumns, name);
|
|
227
|
+
});
|
|
228
|
+
return columns;
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
KanbanViewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: KanbanViewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
232
|
+
KanbanViewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: KanbanViewComponent, selector: "bk-kanban-view", inputs: { kanbanColumns: "kanbanColumns", groupbyProperty: "groupbyProperty" }, viewQueries: [{ propertyName: "inputEl", first: true, predicate: ["inputEl"], descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<fd-layout-panel>\n <fd-layout-panel-body [bleed]=\"true\">\n <table fd-table *ngIf=\"isCheckList\">\n <thead fd-table-header>\n <tr fd-table-row>\n <th fd-table-cell>\n <fd-checkbox\n name=\"allCheckbox\"\n [ngModel]=\"allChecked\"\n (ngModelChange)=\"onAllCheckbox($event)\"\n >{{ 'All' | bbbTranslate }}</fd-checkbox\n >\n </th>\n </tr>\n </thead>\n </table>\n </fd-layout-panel-body>\n</fd-layout-panel>\n\n<fd-layout-grid\n *ngIf=\"moDataList?.length; else noData\"\n class=\"columns\"\n cdkDropList\n cdkDropListOrientation=\"horizontal\"\n [cdkDropListData]=\"kanbanColumns\"\n [id]=\"'$Root'\"\n (cdkDropListDropped)=\"onDrop($event, true)\"\n>\n <div\n *ngFor=\"let column of kanbanColumns; let columnIndex = index\"\n [fdLayoutGridCol]=\"12\"\n [colMd]=\"6\"\n [colLg]=\"4\"\n [colXl]=\"3\"\n class=\"column\"\n [id]=\"column.Id\"\n [attr.state]=\"column.$Caption\"\n cdkDrag\n >\n <ng-container\n *ngTemplateOutlet=\"\n columnCard;\n context: {\n column: column,\n columnIndex: columnIndex\n }\n \"\n ></ng-container>\n </div>\n <div\n [fdLayoutGridCol]=\"12\"\n [colMd]=\"6\"\n [colLg]=\"4\"\n [colXl]=\"3\"\n class=\"newColumn\"\n (click)=\"onActiveNewColumnMode()\"\n *ngIf=\"!isNewColumnMode; else newColumnInput\"\n >\n <ng-container>\n <span>\u0633\u062A\u0648\u0646 \u062C\u062F\u06CC\u062F</span>\n </ng-container>\n </div>\n <ng-template #newColumnInput>\n <div [fdLayoutGridCol]=\"12\" [colMd]=\"6\" [colLg]=\"4\" [colXl]=\"3\">\n <input\n #inputEl\n fd-form-control\n type=\"text\"\n autofocus\n (focusout)=\"onCancelNewColumn()\"\n [(ngModel)]=\"newColumn.$Caption\"\n (keydown.enter)=\"onAddNewColumn()\"\n id=\"new-column-name\"\n placeholder=\" \u0646\u0627\u0645\"\n />\n </div>\n </ng-template>\n</fd-layout-grid>\n\n<!--noData-->\n<ng-template #noData>\n <bsu-no-data></bsu-no-data>\n</ng-template>\n\n<!--column card-->\n<ng-template #columnCard let-column=\"column\" let-columnIndex=\"columnIndex\">\n <fd-card cardType=\"quickView\" class=\"docs-flex-item-margin\" ellipsify>\n <fd-card-header>\n <span fd-card-title>{{ column.$Caption }}</span>\n </fd-card-header>\n <fd-card-content\n cdkDropList\n (cdkDropListDropped)=\"onDrop($event)\"\n [cdkDropListSortingDisabled]=\"true\"\n [cdkDropListData]=\"moDataList\"\n >\n <ng-container *ngFor=\"let mo of moDataList; let index = index\">\n <bk-kanban-card\n [mo]=\"mo\"\n [viewSetting]=\"viewSetting\"\n [formSetting]=\"formSetting\"\n [allAvailableAssignees]=\"allAvailableAssignees\"\n [index]=\"index\"\n *ngIf=\"mo[viewSetting.State].$Caption === column.$Caption\"\n [attr.id]=\"mo.Id\"\n [inlineEditMode]=\"true\"\n [isChecked]=\"true\"\n [attr.state]=\"column.$Caption\"\n [attr.index]=\"index\"\n [class.selected]=\"mo.$IsChecked\"\n (cdkDragMoved)=\"onDragMove($event, mo, index, column)\"\n (click)=\"onRowCheck({mo, index})\"\n (dblclick)=\"onRowClick({mo, index})\"\n cdkDrag\n >\n </bk-kanban-card>\n </ng-container>\n </fd-card-content>\n <fd-card-footer class=\"column-footer\">\n <div class=\"new-card\" *ngIf=\"newCard[groupbyProperty] === column.$Caption; else addNewCard\">\n <fd-card>\n <div fd-form-item>\n <textarea\n fd-form-control\n [autofocus]=\"true\"\n [(ngModel)]=\"newCard.$Caption\"\n (keydown.enter)=\"onAddNewCard($event)\"\n (focusout)=\"onNewCardInputFocusout()\"\n [placeholder]=\"'Title' | bbbTranslate\"\n ></textarea>\n </div>\n </fd-card>\n <div class=\"new-card-actions\">\n <button\n fd-button\n (click)=\"onAddNewCard($event)\"\n fdType=\"emphasized\"\n class=\"add-card-btn\"\n [label]=\"'\u0627\u0641\u0632\u0648\u062F\u0646'\"\n ></button>\n <fd-icon (mousedown)=\"onCancelNewCard($event)\" glyph=\"decline\"></fd-icon>\n </div>\n </div>\n\n <ng-template #addNewCard>\n <div class=\"add-new-card\" (click)=\"onInitNewCard(column.$Caption)\">\n <span>\n <fd-icon glyph=\"add\"></fd-icon>\n \u06A9\u0627\u0631\u062A \u062C\u062F\u06CC\u062F\n </span>\n </div>\n </ng-template>\n </fd-card-footer>\n </fd-card>\n</ng-template>\n", styles: [":host{display:flex;column-gap:20px;row-gap:20px;flex-wrap:wrap;overflow:auto;padding-bottom:1rem;height:calc(100% - 38.5px)}::-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%;background-color:var(--sapList_Background, #fff)!important}.column.cdk-drag-placeholder{opacity:0}.column>fd-card{overflow-y:hidden;height:100%;box-shadow:none}.column>fd-card fd-card-header{border:none;background:none;padding:1rem 2rem!important}.column>fd-card fd-card-content{flex:1;overflow-y:auto;padding:0 1rem;margin:0;display:flex;flex-direction:column;row-gap:20px}.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.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.EllipsifyDirective, selector: "[ellipsify]", inputs: ["limitLine"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.CardComponent, selector: "fd-card", inputs: ["badge", "isLoading", "cardType", "id", "role"] }, { kind: "component", type: i4.CardHeaderComponent, selector: "fd-card-header", inputs: ["interactive", "tabindex"] }, { kind: "component", type: i4.CardContentComponent, selector: "fd-card-content" }, { kind: "directive", type: i4.CardTitleDirective, selector: "[fd-card-title]" }, { kind: "component", type: i4.CardFooterComponent, selector: "fd-card-footer" }, { kind: "component", type: i5.CheckboxComponent, selector: "fd-checkbox", inputs: ["ariaLabel", "value", "ariaLabelledBy", "ariaDescribedBy", "title", "inputId", "state", "name", "label", "disabled", "tristate", "tristateSelectable", "labelClass", "required", "values"], outputs: ["focusChange"] }, { kind: "component", type: i6.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i6.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "directive", type: i6.TextareaFormControlDirective, selector: "textarea[fd-form-control]" }, { kind: "component", type: i6.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i7.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "component", type: i8.LayoutGridComponent, selector: "fd-layout-grid, [fdLayoutGrid]", inputs: ["class", "noGap", "noHorizontalGap", "noVerticalGap"] }, { kind: "directive", type: i8.LayoutGridColDirective, selector: "[fd-layout-grid-col], [fdLayoutGridCol]", inputs: ["fdLayoutGridCol", "colGrow", "colMd", "colLg", "colXl", "colOffset", "colOffsetMd", "colOffsetLg", "colOffsetXl", "class"] }, { kind: "component", type: i9.LayoutPanelComponent, selector: "fd-layout-panel", inputs: ["backgroundImage"] }, { kind: "component", type: i9.LayoutPanelBodyComponent, selector: "fd-layout-panel-body", inputs: ["bleed"] }, { kind: "component", type: i10.TableComponent, selector: "table[fd-table]", inputs: ["noBorderX", "noBorderY", "popIn", "responsive", "keys", "allCellsFocusable"], exportAs: ["fd-table"] }, { kind: "directive", type: i10.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i10.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i10.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "tabindex", "hoverable", "fitContent", "noPadding", "noData", "key", "cellFocusedEventAnnouncer"] }, { kind: "component", type: i11.NoDataComponent, selector: "bsu-no-data" }, { kind: "directive", type: i12.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i12.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i12.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i13.CdkDropList, selector: "[cdkDropList], cdk-drop-list", inputs: ["cdkDropListConnectedTo", "cdkDropListData", "cdkDropListOrientation", "id", "cdkDropListLockAxis", "cdkDropListDisabled", "cdkDropListSortingDisabled", "cdkDropListEnterPredicate", "cdkDropListSortPredicate", "cdkDropListAutoScrollDisabled", "cdkDropListAutoScrollStep"], outputs: ["cdkDropListDropped", "cdkDropListEntered", "cdkDropListExited", "cdkDropListSorted"], exportAs: ["cdkDropList"] }, { kind: "directive", type: i13.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "component", type: i14.KanbanCardComponent, selector: "bk-kanban-card", inputs: ["index", "mo", "viewSetting", "allAvailableAssignees"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
233
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: KanbanViewComponent, decorators: [{
|
|
234
|
+
type: Component,
|
|
235
|
+
args: [{ selector: 'bk-kanban-view', changeDetection: ChangeDetectionStrategy.OnPush, template: "<fd-layout-panel>\n <fd-layout-panel-body [bleed]=\"true\">\n <table fd-table *ngIf=\"isCheckList\">\n <thead fd-table-header>\n <tr fd-table-row>\n <th fd-table-cell>\n <fd-checkbox\n name=\"allCheckbox\"\n [ngModel]=\"allChecked\"\n (ngModelChange)=\"onAllCheckbox($event)\"\n >{{ 'All' | bbbTranslate }}</fd-checkbox\n >\n </th>\n </tr>\n </thead>\n </table>\n </fd-layout-panel-body>\n</fd-layout-panel>\n\n<fd-layout-grid\n *ngIf=\"moDataList?.length; else noData\"\n class=\"columns\"\n cdkDropList\n cdkDropListOrientation=\"horizontal\"\n [cdkDropListData]=\"kanbanColumns\"\n [id]=\"'$Root'\"\n (cdkDropListDropped)=\"onDrop($event, true)\"\n>\n <div\n *ngFor=\"let column of kanbanColumns; let columnIndex = index\"\n [fdLayoutGridCol]=\"12\"\n [colMd]=\"6\"\n [colLg]=\"4\"\n [colXl]=\"3\"\n class=\"column\"\n [id]=\"column.Id\"\n [attr.state]=\"column.$Caption\"\n cdkDrag\n >\n <ng-container\n *ngTemplateOutlet=\"\n columnCard;\n context: {\n column: column,\n columnIndex: columnIndex\n }\n \"\n ></ng-container>\n </div>\n <div\n [fdLayoutGridCol]=\"12\"\n [colMd]=\"6\"\n [colLg]=\"4\"\n [colXl]=\"3\"\n class=\"newColumn\"\n (click)=\"onActiveNewColumnMode()\"\n *ngIf=\"!isNewColumnMode; else newColumnInput\"\n >\n <ng-container>\n <span>\u0633\u062A\u0648\u0646 \u062C\u062F\u06CC\u062F</span>\n </ng-container>\n </div>\n <ng-template #newColumnInput>\n <div [fdLayoutGridCol]=\"12\" [colMd]=\"6\" [colLg]=\"4\" [colXl]=\"3\">\n <input\n #inputEl\n fd-form-control\n type=\"text\"\n autofocus\n (focusout)=\"onCancelNewColumn()\"\n [(ngModel)]=\"newColumn.$Caption\"\n (keydown.enter)=\"onAddNewColumn()\"\n id=\"new-column-name\"\n placeholder=\" \u0646\u0627\u0645\"\n />\n </div>\n </ng-template>\n</fd-layout-grid>\n\n<!--noData-->\n<ng-template #noData>\n <bsu-no-data></bsu-no-data>\n</ng-template>\n\n<!--column card-->\n<ng-template #columnCard let-column=\"column\" let-columnIndex=\"columnIndex\">\n <fd-card cardType=\"quickView\" class=\"docs-flex-item-margin\" ellipsify>\n <fd-card-header>\n <span fd-card-title>{{ column.$Caption }}</span>\n </fd-card-header>\n <fd-card-content\n cdkDropList\n (cdkDropListDropped)=\"onDrop($event)\"\n [cdkDropListSortingDisabled]=\"true\"\n [cdkDropListData]=\"moDataList\"\n >\n <ng-container *ngFor=\"let mo of moDataList; let index = index\">\n <bk-kanban-card\n [mo]=\"mo\"\n [viewSetting]=\"viewSetting\"\n [formSetting]=\"formSetting\"\n [allAvailableAssignees]=\"allAvailableAssignees\"\n [index]=\"index\"\n *ngIf=\"mo[viewSetting.State].$Caption === column.$Caption\"\n [attr.id]=\"mo.Id\"\n [inlineEditMode]=\"true\"\n [isChecked]=\"true\"\n [attr.state]=\"column.$Caption\"\n [attr.index]=\"index\"\n [class.selected]=\"mo.$IsChecked\"\n (cdkDragMoved)=\"onDragMove($event, mo, index, column)\"\n (click)=\"onRowCheck({mo, index})\"\n (dblclick)=\"onRowClick({mo, index})\"\n cdkDrag\n >\n </bk-kanban-card>\n </ng-container>\n </fd-card-content>\n <fd-card-footer class=\"column-footer\">\n <div class=\"new-card\" *ngIf=\"newCard[groupbyProperty] === column.$Caption; else addNewCard\">\n <fd-card>\n <div fd-form-item>\n <textarea\n fd-form-control\n [autofocus]=\"true\"\n [(ngModel)]=\"newCard.$Caption\"\n (keydown.enter)=\"onAddNewCard($event)\"\n (focusout)=\"onNewCardInputFocusout()\"\n [placeholder]=\"'Title' | bbbTranslate\"\n ></textarea>\n </div>\n </fd-card>\n <div class=\"new-card-actions\">\n <button\n fd-button\n (click)=\"onAddNewCard($event)\"\n fdType=\"emphasized\"\n class=\"add-card-btn\"\n [label]=\"'\u0627\u0641\u0632\u0648\u062F\u0646'\"\n ></button>\n <fd-icon (mousedown)=\"onCancelNewCard($event)\" glyph=\"decline\"></fd-icon>\n </div>\n </div>\n\n <ng-template #addNewCard>\n <div class=\"add-new-card\" (click)=\"onInitNewCard(column.$Caption)\">\n <span>\n <fd-icon glyph=\"add\"></fd-icon>\n \u06A9\u0627\u0631\u062A \u062C\u062F\u06CC\u062F\n </span>\n </div>\n </ng-template>\n </fd-card-footer>\n </fd-card>\n</ng-template>\n", styles: [":host{display:flex;column-gap:20px;row-gap:20px;flex-wrap:wrap;overflow:auto;padding-bottom:1rem;height:calc(100% - 38.5px)}::-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%;background-color:var(--sapList_Background, #fff)!important}.column.cdk-drag-placeholder{opacity:0}.column>fd-card{overflow-y:hidden;height:100%;box-shadow:none}.column>fd-card fd-card-header{border:none;background:none;padding:1rem 2rem!important}.column>fd-card fd-card-content{flex:1;overflow-y:auto;padding:0 1rem;margin:0;display:flex;flex-direction:column;row-gap:20px}.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"] }]
|
|
236
|
+
}], propDecorators: { inputEl: [{
|
|
237
|
+
type: ViewChild,
|
|
238
|
+
args: ['inputEl', { read: ElementRef }]
|
|
239
|
+
}], kanbanColumns: [{
|
|
240
|
+
type: Input
|
|
241
|
+
}], groupbyProperty: [{
|
|
242
|
+
type: Input
|
|
243
|
+
}] } });
|
|
244
|
+
//# 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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,UAAU,EAAE,KAAK,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;AACzG,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,OAAO,EAAuB,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;;;;;;;;;;;;;;;;AAUpF,MAAM,OAAO,mBAAoB,SAAQ,uBAA0C;IANnF;;QASa,oBAAe,GAAG,OAAO,CAAC;QAGnC,oBAAe,GAAG,KAAK,CAAC;QACxB,YAAO,GAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;QAC5C,cAAS,GAAQ,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;KAwOjD;IAtOG,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,QAAQ,CAAC;QAC9D,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAClE,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,UAAU,CAAC;YACvC,IAAI,CAAC,aAAa,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC,CAAC;QAC5E,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,QAAQ,CAAC;QAClE,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,eAAe,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACpE,IAAI,CAAC,qBAAqB,GAAG,MAAM,CAAC,UAAU,CAAC;YAC/C,IAAI,CAAC,aAAa,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,WAAW,GAAG;YACf,GAAG,IAAI,CAAC,WAAW;YACnB,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE;gBACjC,IAAI,CAAC,WAAW,CAAC,KAAK;gBACtB,IAAI,CAAC,WAAW,CAAC,KAAK;gBACtB,IAAI,CAAC,WAAW,CAAC,OAAO;aAC3B,CAAC;SACL,CAAC;IACN,CAAC;IAED,cAAc;QACV,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;QAC1B,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAED,qBAAqB;QACjB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,iBAAiB;QACb,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED,aAAa,CAAC,OAAe;QACzB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,GAAG,OAAO,CAAC;IACjD,CAAC;IAED,YAAY,CAAC,CAAC;QACV,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAED,sBAAsB;QAClB,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;YACvB,IAAI,CAAC,WAAW,EAAE,CAAC;SACtB;aAAM;YACH,IAAI,CAAC,cAAc,EAAE,CAAC;SACzB;IACL,CAAC;IAED,eAAe,CAAC,CAAa;QACzB,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,KAAK,EAAE,QAAkB;QAC5B,IAAI,aAAa,CAAC;QAClB,IAAI,YAAY,CAAC;QACjB,MAAM,KAAK,GAAG,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC;QAEnC,IAAI,QAAQ,EAAE;YACV,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;YACpC,YAAY,GAAG,KAAK,CAAC,YAAY,CAAC;SACrC;aAAM;YACH,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC;YACpD,IAAI,CAAC,aAAa,EAAE;gBAChB,OAAO;aACV;YACD,MAAM,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;YACnD,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;YACpD,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;YAC3C,YAAY,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC;YAC/C,WAAW,CAAC,KAAK,GAAG,WAAW,CAAC;YAChC,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;QAED,eAAe,CAAC,KAAK,EAAE,aAAa,EAAE,YAAY,CAAC,CAAC;IACxD,CAAC;IAED,UAAU,CAAC,KAAK,EAAE,SAAS,EAAE,YAAoB,EAAE,WAAgC;QAC/E,MAAM,gBAAgB,GAAG,QAAQ,CAAC,gBAAgB,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,EAAE,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QAErG,IAAI,WAAW,EAAE;SAChB;QACD,IAAI,CAAC,gBAAgB,EAAE;YACnB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,OAAO;SACV;QACD,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAC9D,IAAI,CAAC,iBAAiB,EAAE;YACpB,IAAI,CAAC,aAAa,EAAE,CAAC;YACrB,OAAO;SACV;QACD,IAAI,CAAC,cAAc,GAAG;YAClB,SAAS,EAAE,SAAS,CAAC,EAAE;YACvB,QAAQ,EAAE,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC;YAC9C,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE,MAAM,CAAC,iBAAiB,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;SAC/D,CAAC;QACF,MAAM,UAAU,GAAG,iBAAiB,CAAC,qBAAqB,EAAE,CAAC;QAC7D,MAAM,QAAQ,GAAG,UAAU,CAAC,MAAM,GAAG,CAAC,CAAC;QAEvC,MAAM,YAAY,GAAG,CAAC,iBAAiB,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QAErE,MAAM,QAAQ,GAAG,KAAK,CAAC,eAAe,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,QAAQ,IAAI,YAAY,CAAC;QAErF,MAAM,OAAO,GAAG,KAAK,CAAC,eAAe,CAAC,CAAC,GAAG,UAAU,CAAC,GAAG,GAAG,CAAC,GAAG,QAAQ,IAAI,YAAY,CAAC;QAExF,MAAM,QAAQ,GAAG,CAAC,YAAY,CAAC;QAE/B,MAAM,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,WAAW,IAAI,CAAC,CAAC,CAAC;QAC1D,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QAE9C,IAAI,YAAY,EAAE;YACd,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;SACtE;aAAM;YACH,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG;gBAC9B,QAAQ,EAAE,iBAAiB,CAAC,YAAY,CAAC,OAAO,CAAE;gBAClD,EAAE,EAAE,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAE;gBACzC,UAAU,EAAE,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,UAAU;aAC5D,CAAC;SACL;QACD,IAAI,QAAQ,EAAE;YACV,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,QAAQ,CAAC;YACtC,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,YAAY,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC;SAChG;aAAM,IAAI,OAAO,EAAE;YAChB,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,OAAO,CAAC;YACrC,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,YAAY,GAAG,WAAW,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,WAAW,GAAG,CAAC,CAAC;SAChG;aAAM,IAAI,QAAQ,EAAE;YACjB,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,QAAQ,CAAC;YACtC,IAAI,CAAC,cAAc,CAAC,WAAW,GAAG,CAAC,CAAC;SACvC;QACD,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;QAC7C,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IACO,aAAa;QACjB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAEO,oBAAoB,CAAC,IAAa;QACtC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;IAChC,CAAC;IAEO,oBAAoB;QACxB,IAAI,CAAC,cAAc,GAAG;YAClB,QAAQ,EAAE,IAAI;YACd,SAAS,EAAE,IAAI;YACf,WAAW,EAAE,IAAI;YACjB,WAAW,EAAE,IAAI;YACjB,MAAM,EAAE,IAAI;SACf,CAAC;IACN,CAAC;IAEO,oBAAoB;QACxB,MAAM,OAAO,GAAqB,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;QAC7D,OAAO,CAAC,KAAK,EAAE,CAAC;QAChB,OAAO,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC;IAC9C,CAAC;IAEO,eAAe;QACnB,IAAI,CAAC,SAAS,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;IAC9C,CAAC;IAEO,cAAc,CAAC,OAAO,GAAG,KAAK;QAClC,IAAI,OAAO,EAAE;YACT,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC/B;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC;QACrC,KAAK;aACA,gBAAgB,CAAC,cAAc,CAAC;aAChC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;QAC/E,KAAK,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;QAC/G,KAAK;aACA,gBAAgB,CAAC,cAAc,CAAC;aAChC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;IACnF,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,EAAE;YAC9B,MAAM,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,aAAa,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YACnG,IAAI,CAAC,iBAAiB,EAAE;gBACpB,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,OAAO;aACV;YACD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,iBAAiB,EAAE,OAAO,GAAG,IAAI,CAAC,cAAc,EAAE,MAAM,CAAC,CAAC;SACtF;IACL,CAAC;IAEO,WAAW;QACf,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnC,MAAM,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC1D,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;IACvC,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,OAAO,GAAG,EAAE,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;IAChD,CAAC;IAEO,cAAc;QAClB,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAEO,UAAU,CAAC,EAAU;QACzB,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IACpD,CAAC;IAEO,WAAW,CAAC,UAAU,EAAE,WAAqB;QACjD,MAAM,OAAO,GAAG,EAAE,CAAC;QACnB,WAAW,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACzB,OAAO,CAAC,IAAI,GAAG,QAAQ,CAAC,GAAG,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QACzF,CAAC,CAAC,CAAC;QACH,OAAO,OAAO,CAAC;IACnB,CAAC;;gHA/OQ,mBAAmB;oGAAnB,mBAAmB,qNACE,UAAU,oDCd5C,krLA2JA;2FD9Ia,mBAAmB;kBAN/B,SAAS;+BACI,gBAAgB,mBAGT,uBAAuB,CAAC,MAAM;8BAGH,OAAO;sBAAlD,SAAS;uBAAC,SAAS,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBACjC,aAAa;sBAArB,KAAK;gBACG,eAAe;sBAAvB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\nimport { moveItemInArray } from '@angular/cdk/drag-drop';\n\nimport { MetaobjectDataModel, ReportViewBaseComponent } from 'barsa-novin-ray-core';\nimport { KanbanViewSetting } from '../Models/kanban-view-setting.interface';\nimport { DropInfo } from '../Models/drop-info';\n\n@Component({\n    selector: 'bk-kanban-view',\n    templateUrl: './kanban-view.component.html',\n    styleUrls: ['./kanban-view.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class KanbanViewComponent extends ReportViewBaseComponent<KanbanViewSetting> implements OnInit {\n    @ViewChild('inputEl', { read: ElementRef }) inputEl: ElementRef<any>;\n    @Input() kanbanColumns: MetaobjectDataModel[];\n    @Input() groupbyProperty = 'State';\n    dropActionTodo: DropInfo;\n    allAvailableAssignees: MetaobjectDataModel[];\n    isNewColumnMode = false;\n    newCard: any = { Id: null, $Caption: null };\n    newColumn: any = { Id: null, $Caption: null };\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        const columnsReport = this.viewSetting.ColumnsReport.$Caption;\n        this._portalService.ReportExecute(columnsReport).subscribe((report) => {\n            this.kanbanColumns = report.MoDataList;\n            this._changeDetect();\n        });\n        this.formSetting.View.ControlInfo.forEach((c) => (c.InlineEditMode = true));\n        const assigneesReport = this.viewSetting.AssigneesReport.$Caption;\n        this._portalService.ReportExecute(assigneesReport).subscribe((report) => {\n            this.allAvailableAssignees = report.MoDataList;\n            this._changeDetect();\n        });\n\n        this.viewSetting = {\n            ...this.viewSetting,\n            ...this._findColumn(this.allColumns, [\n                this.viewSetting.Cover,\n                this.viewSetting.State,\n                this.viewSetting.Caption\n            ])\n        };\n    }\n\n    onAddNewColumn(): void {\n        this.kanbanColumns.push(this.newColumn);\n        this._cdr.detectChanges();\n        this._resetNewColumn();\n        this._scrollInputIntoView();\n    }\n\n    onActiveNewColumnMode(): void {\n        this._changeNewColumnMode(true);\n    }\n\n    onCancelNewColumn(): void {\n        this._changeNewColumnMode(false);\n        this._resetNewColumn();\n    }\n\n    onInitNewCard(groupby: string): void {\n        this._resetNewCard();\n        this.newCard[this.groupbyProperty] = groupby;\n    }\n\n    onAddNewCard(e): void {\n        e.stopPropagation();\n        e.preventDefault();\n        this._addNewCard();\n    }\n\n    onNewCardInputFocusout(): void {\n        if (this.newCard.$Caption) {\n            this._addNewCard();\n        } else {\n            this._cancelNewCard();\n        }\n    }\n\n    onCancelNewCard(e: MouseEvent): void {\n        e.stopPropagation();\n        e.preventDefault();\n        this._cancelNewCard();\n    }\n\n    onDrop(event, isColumn?: boolean): void {\n        let previousIndex;\n        let currentIndex;\n        const array = event.container.data;\n\n        if (isColumn) {\n            previousIndex = event.previousIndex;\n            currentIndex = event.currentIndex;\n        } else {\n            const draggedItemId = this.dropActionTodo.draggedId;\n            if (!draggedItemId) {\n                return;\n            }\n            const draggedItem = this._getMoById(draggedItemId);\n            const targetState = this.dropActionTodo.targetState;\n            previousIndex = array.indexOf(draggedItem);\n            currentIndex = this.dropActionTodo.targetIndex;\n            draggedItem.State = targetState;\n            this._stopDragging();\n        }\n\n        moveItemInArray(array, previousIndex, currentIndex);\n    }\n\n    onDragMove(event, draggedMo, draggedIndex: number, targetState: MetaobjectDataModel): void {\n        const elementFromPoint = document.elementFromPoint(event.pointerPosition.x, event.pointerPosition.y);\n\n        if (targetState) {\n        }\n        if (!elementFromPoint) {\n            this._stopDragging();\n            return;\n        }\n        const targetNodeElement = elementFromPoint.closest('[state]');\n        if (!targetNodeElement) {\n            this._stopDragging();\n            return;\n        }\n        this.dropActionTodo = {\n            draggedId: draggedMo.Id,\n            targetId: targetNodeElement.getAttribute('id'),\n            targetState: null,\n            targetIndex: Number(targetNodeElement.getAttribute('index'))\n        };\n        const targetRect = targetNodeElement.getBoundingClientRect();\n        const oneThird = targetRect.height / 3;\n\n        const isCardTarget = !targetNodeElement.classList.contains('column');\n\n        const isBefore = event.pointerPosition.y - targetRect.top < oneThird && isCardTarget;\n\n        const isAfter = event.pointerPosition.y - targetRect.top > 2 * oneThird && isCardTarget;\n\n        const isInside = !isCardTarget;\n\n        const targetIndex = this.dropActionTodo.targetIndex ?? -1;\n        const targetMo = this.moDataList[targetIndex];\n\n        if (isCardTarget) {\n            this.dropActionTodo.targetState = targetMo[this.viewSetting.State];\n        } else {\n            this.dropActionTodo.targetState = {\n                $Caption: targetNodeElement.getAttribute('state')!,\n                Id: targetNodeElement.getAttribute('id')!,\n                $TypeDefId: draggedMo[this.viewSetting.State]?.$TypeDefId\n            };\n        }\n        if (isBefore) {\n            this.dropActionTodo.action = 'before';\n            this.dropActionTodo.targetIndex = draggedIndex > targetIndex ? targetIndex : targetIndex - 1;\n        } else if (isAfter) {\n            this.dropActionTodo.action = 'after';\n            this.dropActionTodo.targetIndex = draggedIndex < targetIndex ? targetIndex : targetIndex + 1;\n        } else if (isInside) {\n            this.dropActionTodo.action = 'inside';\n            this.dropActionTodo.targetIndex = 0;\n        }\n        console.log(this.dropActionTodo.targetState);\n        this._showDragInfo();\n    }\n    private _changeDetect(): void {\n        this._cdr.detectChanges();\n    }\n\n    private _stopDragging(): void {\n        this._clearDragInfo();\n        this._resetDropActionTodo();\n    }\n\n    private _changeNewColumnMode(mode: boolean): void {\n        this.isNewColumnMode = mode;\n    }\n\n    private _resetDropActionTodo(): void {\n        this.dropActionTodo = {\n            targetId: null,\n            draggedId: null,\n            targetState: null,\n            targetIndex: null,\n            action: null\n        };\n    }\n\n    private _scrollInputIntoView(): void {\n        const inputEl: HTMLInputElement = this.inputEl.nativeElement;\n        inputEl.focus();\n        inputEl.scrollIntoView({ inline: 'end' });\n    }\n\n    private _resetNewColumn(): void {\n        this.newColumn = { Id: '', $Caption: '' };\n    }\n\n    private _clearDragInfo(dropped = false): void {\n        if (dropped) {\n            this._resetDropActionTodo();\n        }\n        const elDom = this._el.nativeElement;\n        elDom\n            .querySelectorAll('.drop-before')\n            .forEach((element) => this._renderer2.removeClass(element, 'drop-before'));\n        elDom.querySelectorAll('.drop-after').forEach((element) => this._renderer2.removeClass(element, 'drop-after'));\n        elDom\n            .querySelectorAll('.drop-inside')\n            .forEach((element) => this._renderer2.removeClass(element, 'drop-inside'));\n    }\n\n    private _showDragInfo(): void {\n        this._clearDragInfo();\n        if (this.dropActionTodo.targetId) {\n            const targetNodeElement = this._el.nativeElement.querySelector('#' + this.dropActionTodo.targetId);\n            if (!targetNodeElement) {\n                this._resetDropActionTodo();\n                return;\n            }\n            this._renderer2.addClass(targetNodeElement, 'drop-' + this.dropActionTodo?.action);\n        }\n    }\n\n    private _addNewCard(): void {\n        this.moDataList.push(this.newCard);\n        const currentGroupby = this.newCard[this.groupbyProperty];\n        this.onInitNewCard(currentGroupby);\n    }\n\n    private _resetNewCard(): void {\n        this.newCard = { Id: null, $Caption: null };\n    }\n\n    private _cancelNewCard(): void {\n        this._resetNewCard();\n    }\n\n    private _getMoById(id: string): MetaobjectDataModel {\n        return this.moDataList.find((c) => c.Id === id);\n    }\n\n    private _findColumn(allColumns, columnsName: string[]): object {\n        const columns = {};\n        columnsName.forEach((name) => {\n            columns[name + 'Column'] = this._findColumnByDbName.transform(this.allColumns, name);\n        });\n        return columns;\n    }\n}\n","<fd-layout-panel>\n    <fd-layout-panel-body [bleed]=\"true\">\n        <table fd-table *ngIf=\"isCheckList\">\n            <thead fd-table-header>\n                <tr fd-table-row>\n                    <th fd-table-cell>\n                        <fd-checkbox\n                            name=\"allCheckbox\"\n                            [ngModel]=\"allChecked\"\n                            (ngModelChange)=\"onAllCheckbox($event)\"\n                            >{{ 'All' | bbbTranslate }}</fd-checkbox\n                        >\n                    </th>\n                </tr>\n            </thead>\n        </table>\n    </fd-layout-panel-body>\n</fd-layout-panel>\n\n<fd-layout-grid\n    *ngIf=\"moDataList?.length; else noData\"\n    class=\"columns\"\n    cdkDropList\n    cdkDropListOrientation=\"horizontal\"\n    [cdkDropListData]=\"kanbanColumns\"\n    [id]=\"'$Root'\"\n    (cdkDropListDropped)=\"onDrop($event, true)\"\n>\n    <div\n        *ngFor=\"let column of kanbanColumns; let columnIndex = index\"\n        [fdLayoutGridCol]=\"12\"\n        [colMd]=\"6\"\n        [colLg]=\"4\"\n        [colXl]=\"3\"\n        class=\"column\"\n        [id]=\"column.Id\"\n        [attr.state]=\"column.$Caption\"\n        cdkDrag\n    >\n        <ng-container\n            *ngTemplateOutlet=\"\n                columnCard;\n                context: {\n                    column: column,\n                    columnIndex: columnIndex\n                }\n            \"\n        ></ng-container>\n    </div>\n    <div\n        [fdLayoutGridCol]=\"12\"\n        [colMd]=\"6\"\n        [colLg]=\"4\"\n        [colXl]=\"3\"\n        class=\"newColumn\"\n        (click)=\"onActiveNewColumnMode()\"\n        *ngIf=\"!isNewColumnMode; else newColumnInput\"\n    >\n        <ng-container>\n            <span>ستون جدید</span>\n        </ng-container>\n    </div>\n    <ng-template #newColumnInput>\n        <div [fdLayoutGridCol]=\"12\" [colMd]=\"6\" [colLg]=\"4\" [colXl]=\"3\">\n            <input\n                #inputEl\n                fd-form-control\n                type=\"text\"\n                autofocus\n                (focusout)=\"onCancelNewColumn()\"\n                [(ngModel)]=\"newColumn.$Caption\"\n                (keydown.enter)=\"onAddNewColumn()\"\n                id=\"new-column-name\"\n                placeholder=\" نام\"\n            />\n        </div>\n    </ng-template>\n</fd-layout-grid>\n\n<!--noData-->\n<ng-template #noData>\n    <bsu-no-data></bsu-no-data>\n</ng-template>\n\n<!--column card-->\n<ng-template #columnCard let-column=\"column\" let-columnIndex=\"columnIndex\">\n    <fd-card cardType=\"quickView\" class=\"docs-flex-item-margin\" ellipsify>\n        <fd-card-header>\n            <span fd-card-title>{{ column.$Caption }}</span>\n        </fd-card-header>\n        <fd-card-content\n            cdkDropList\n            (cdkDropListDropped)=\"onDrop($event)\"\n            [cdkDropListSortingDisabled]=\"true\"\n            [cdkDropListData]=\"moDataList\"\n        >\n            <ng-container *ngFor=\"let mo of moDataList; let index = index\">\n                <bk-kanban-card\n                    [mo]=\"mo\"\n                    [viewSetting]=\"viewSetting\"\n                    [formSetting]=\"formSetting\"\n                    [allAvailableAssignees]=\"allAvailableAssignees\"\n                    [index]=\"index\"\n                    *ngIf=\"mo[viewSetting.State].$Caption === column.$Caption\"\n                    [attr.id]=\"mo.Id\"\n                    [inlineEditMode]=\"true\"\n                    [isChecked]=\"true\"\n                    [attr.state]=\"column.$Caption\"\n                    [attr.index]=\"index\"\n                    [class.selected]=\"mo.$IsChecked\"\n                    (cdkDragMoved)=\"onDragMove($event, mo, index, column)\"\n                    (click)=\"onRowCheck({mo, index})\"\n                    (dblclick)=\"onRowClick({mo, index})\"\n                    cdkDrag\n                >\n                </bk-kanban-card>\n            </ng-container>\n        </fd-card-content>\n        <fd-card-footer class=\"column-footer\">\n            <div class=\"new-card\" *ngIf=\"newCard[groupbyProperty] === column.$Caption; else addNewCard\">\n                <fd-card>\n                    <div fd-form-item>\n                        <textarea\n                            fd-form-control\n                            [autofocus]=\"true\"\n                            [(ngModel)]=\"newCard.$Caption\"\n                            (keydown.enter)=\"onAddNewCard($event)\"\n                            (focusout)=\"onNewCardInputFocusout()\"\n                            [placeholder]=\"'Title' | bbbTranslate\"\n                        ></textarea>\n                    </div>\n                </fd-card>\n                <div class=\"new-card-actions\">\n                    <button\n                        fd-button\n                        (click)=\"onAddNewCard($event)\"\n                        fdType=\"emphasized\"\n                        class=\"add-card-btn\"\n                        [label]=\"'افزودن'\"\n                    ></button>\n                    <fd-icon (mousedown)=\"onCancelNewCard($event)\" glyph=\"decline\"></fd-icon>\n                </div>\n            </div>\n\n            <ng-template #addNewCard>\n                <div class=\"add-new-card\" (click)=\"onInitNewCard(column.$Caption)\">\n                    <span>\n                        <fd-icon glyph=\"add\"></fd-icon>\n                        کارت جدید\n                    </span>\n                </div>\n            </ng-template>\n        </fd-card-footer>\n    </fd-card>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,7 @@
|
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2JhcnNhLWthbmJhbi9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLGlEQUFpRCxDQUFDO0FBQ2hFLGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYywyQkFBMkIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2thbmJhbi1iYXNlL2thbmJhbi1iYXNlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9rYW5iYW4tdGFncy9rYW5iYW4tdGFncy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIva2FuYmFuLWNhcmQva2FuYmFuLWNhcmQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2F2YXRhci1ncm91cC9iYXJzYS1hdmF0YXItZ3JvdXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2thbmJhbi12aWV3L2thbmJhbi12aWV3LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9iYXJzYS1rYW5iYW4ubW9kdWxlJztcbiJdfQ==
|