barsa-sap-ui 1.0.262 → 1.0.263
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/esm2020/lib/barsa-table-header/barsa-table-header.component.mjs +11 -6
- package/fesm2015/barsa-sap-ui.mjs +10 -5
- package/fesm2015/barsa-sap-ui.mjs.map +1 -1
- package/fesm2020/barsa-sap-ui.mjs +10 -5
- package/fesm2020/barsa-sap-ui.mjs.map +1 -1
- package/lib/barsa-sap-ui.module.d.ts +1 -1
- package/lib/barsa-table-header/barsa-table-header.component.d.ts +6 -1
- package/lib/index.d.ts +2 -1
- package/package.json +1 -1
|
@@ -10,8 +10,12 @@ import * as i6 from "@fundamental-ngx/core/menu";
|
|
|
10
10
|
import * as i7 from "@fundamental-ngx/core/popover";
|
|
11
11
|
import * as i8 from "@fundamental-ngx/core/table";
|
|
12
12
|
export class BarsaTableHeaderComponent extends BaseComponent {
|
|
13
|
-
|
|
14
|
-
|
|
13
|
+
/**
|
|
14
|
+
*
|
|
15
|
+
*/
|
|
16
|
+
constructor(_cdr) {
|
|
17
|
+
super();
|
|
18
|
+
this._cdr = _cdr;
|
|
15
19
|
this.showDetailsInRow = false;
|
|
16
20
|
this.allCheckbox = new EventEmitter();
|
|
17
21
|
this.sortAscending = new EventEmitter();
|
|
@@ -27,6 +31,7 @@ export class BarsaTableHeaderComponent extends BaseComponent {
|
|
|
27
31
|
const { columns, inlineEditMode } = changes;
|
|
28
32
|
if (columns && !columns.firstChange) {
|
|
29
33
|
this._prepareColumnsWidth(this.tableWidth, columns.currentValue);
|
|
34
|
+
this._cdr.detectChanges();
|
|
30
35
|
}
|
|
31
36
|
if (inlineEditMode &&
|
|
32
37
|
!inlineEditMode.firstChange &&
|
|
@@ -42,7 +47,7 @@ export class BarsaTableHeaderComponent extends BaseComponent {
|
|
|
42
47
|
return;
|
|
43
48
|
}
|
|
44
49
|
this.columnsWidth = sum;
|
|
45
|
-
if (sum > val) {
|
|
50
|
+
if (sum > val && val > 0) {
|
|
46
51
|
columns.forEach((column) => (column.$Width2 = (column.Width * 100) / val + '%'));
|
|
47
52
|
this.columnsSmallerThanTableWidth = true;
|
|
48
53
|
}
|
|
@@ -75,12 +80,12 @@ export class BarsaTableHeaderComponent extends BaseComponent {
|
|
|
75
80
|
return `${column.Name}${index}`;
|
|
76
81
|
}
|
|
77
82
|
}
|
|
78
|
-
BarsaTableHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTableHeaderComponent, deps:
|
|
83
|
+
BarsaTableHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTableHeaderComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
79
84
|
BarsaTableHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaTableHeaderComponent, selector: "bsu-barsa-table-header", inputs: { allChecked: "allChecked", isCheckList: "isCheckList", columns: "columns", fitWidth: "fitWidth", contextMenuItems: "contextMenuItems", canView: "canView", hideOpenIcon: "hideOpenIcon", disableOverflowContextMenu: "disableOverflowContextMenu", inlineEditMode: "inlineEditMode", hideHeader: "hideHeader", showDetailsInRow: "showDetailsInRow", viewSetting: "viewSetting", tableWidth: "tableWidth", resizedByUser: "resizedByUser", disableResponsive: "disableResponsive" }, outputs: { allCheckbox: "allCheckbox", sortAscending: "sortAscending", sortDescending: "sortDescending", filter: "filter" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<thead\r\n fd-table-header\r\n [class.inline-edit]=\"inlineEditMode\"\r\n [class.smallColumns]=\"columnsSmallerThanTableWidth\"\r\n [attr.columnsWidth]=\"columnsWidth\"\r\n [attr.tableWidth]=\"tableWidth\"\r\n>\r\n <tr fd-table-row>\r\n <ng-container *ngIf=\"!hideHeader\">\r\n <th fd-table-cell *ngIf=\"isCheckList\">\r\n <fd-checkbox\r\n name=\"allCheckbox\"\r\n [ngModel]=\"allChecked\"\r\n (ngModelChange)=\"onAllCheckbox($event)\"\r\n ></fd-checkbox>\r\n </th>\r\n <th fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\"></th>\r\n <th\r\n *ngFor=\"let column of columns; let i = index; let last = last; trackBy: _trackByColumn\"\r\n [columnIndex]=\"i\"\r\n fd-table-cell\r\n [style.width]=\"column.FieldTypeId === 38 ? '40px' : column.$Width2\"\r\n [style.min-width]=\"last ? '100%' : 'auto'\"\r\n columnResizer\r\n [disableResizer]=\"fitWidth\"\r\n [attr.columnName]=\"column.Name\"\r\n [attr.index]=\"i\"\r\n [ngClass]=\"column.$CSSClassName + ' column__' + column.Caption\"\r\n [class.displayIcon]=\"column.Extra?.IconDisplayTypeEnum\"\r\n >\r\n <fd-popover #menu>\r\n <fd-popover-control>\r\n <div style=\"display: flex\">\r\n <!-- FieldTypeId 38 means it is auto row number field-->\r\n <img\r\n [src]=\"column.Icon\"\r\n *ngIf=\"column.Extra?.IconDisplayTypeEnum === 'Image' || column.FieldTypeId === 42\"\r\n />\r\n {{\r\n column.Extra?.IconDisplayTypeEnum !== 'Image' && column.FieldTypeId !== 38\r\n ? (column.Caption | bbbTranslate)\r\n : ''\r\n }}\r\n </div>\r\n </fd-popover-control>\r\n <fd-popover-body>\r\n <ul fd-list>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onSortAscending(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"sort-ascending\"></fd-menu-addon>\r\n <span fd-menu-title\r\n >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Ascending' | bbbTranslate }}</span\r\n >\r\n </a>\r\n </li>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onSortDescending(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"sort-descending\"></fd-menu-addon>\r\n <span fd-menu-title\r\n >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Descending' | bbbTranslate }}</span\r\n >\r\n </a>\r\n </li>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onFilter(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"filter\"></fd-menu-addon>\r\n <span fd-menu-title>{{ 'Filter' | bbbTranslate }}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </fd-popover-body>\r\n </fd-popover>\r\n </th>\r\n\r\n <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0 && !inlineEditMode\">\r\n <th\r\n class=\"col-header col-context-menu\"\r\n fd-table-cell\r\n [fitContent]=\"disableOverflowContextMenu\"\r\n [style.width]=\"disableOverflowContextMenu ? '100%' : contextMenuItems.length > 1 ? '40px' : '100px'\"\r\n ></th>\r\n </ng-container>\r\n <th\r\n class=\"col-header col-details\"\r\n fd-table-cell\r\n style=\"width: 120px\"\r\n *ngIf=\"showDetailsInRow && !inlineEditMode\"\r\n ></th>\r\n <th\r\n class=\"col-header col-view\"\r\n fd-table-cell\r\n style=\"width: 40px\"\r\n *ngIf=\"canView && !inlineEditMode && !hideOpenIcon\"\r\n ></th>\r\n </ng-container>\r\n </tr>\r\n</thead>\r\n", styles: [":host{display:contents;width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i3.ColumnResizerDirective, selector: "[columnResizer]", inputs: ["disableResizer"] }, { kind: "component", type: i4.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: i5.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i5.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i6.MenuInteractiveDirective, selector: "[fd-menu-interactive]" }, { kind: "directive", type: i6.MenuTitleDirective, selector: "[fd-menu-title]" }, { kind: "component", type: i6.MenuAddonDirective, selector: "fd-menu-addon", inputs: ["position", "glyph", "submenuIndicator", "ariaHidden"] }, { kind: "component", type: i7.PopoverControlComponent, selector: "fd-popover-control" }, { kind: "component", type: i7.PopoverBodyComponent, selector: "fd-popover-body" }, { kind: "component", type: i7.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "directive", type: i8.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY"] }, { 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", "tabindex", "hoverable", "fitContent", "noPadding", "noData", "key", "cellFocusedEventAnnouncer"] }, { kind: "pipe", type: i3.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
80
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTableHeaderComponent, decorators: [{
|
|
81
86
|
type: Component,
|
|
82
87
|
args: [{ selector: 'bsu-barsa-table-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<thead\r\n fd-table-header\r\n [class.inline-edit]=\"inlineEditMode\"\r\n [class.smallColumns]=\"columnsSmallerThanTableWidth\"\r\n [attr.columnsWidth]=\"columnsWidth\"\r\n [attr.tableWidth]=\"tableWidth\"\r\n>\r\n <tr fd-table-row>\r\n <ng-container *ngIf=\"!hideHeader\">\r\n <th fd-table-cell *ngIf=\"isCheckList\">\r\n <fd-checkbox\r\n name=\"allCheckbox\"\r\n [ngModel]=\"allChecked\"\r\n (ngModelChange)=\"onAllCheckbox($event)\"\r\n ></fd-checkbox>\r\n </th>\r\n <th fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\"></th>\r\n <th\r\n *ngFor=\"let column of columns; let i = index; let last = last; trackBy: _trackByColumn\"\r\n [columnIndex]=\"i\"\r\n fd-table-cell\r\n [style.width]=\"column.FieldTypeId === 38 ? '40px' : column.$Width2\"\r\n [style.min-width]=\"last ? '100%' : 'auto'\"\r\n columnResizer\r\n [disableResizer]=\"fitWidth\"\r\n [attr.columnName]=\"column.Name\"\r\n [attr.index]=\"i\"\r\n [ngClass]=\"column.$CSSClassName + ' column__' + column.Caption\"\r\n [class.displayIcon]=\"column.Extra?.IconDisplayTypeEnum\"\r\n >\r\n <fd-popover #menu>\r\n <fd-popover-control>\r\n <div style=\"display: flex\">\r\n <!-- FieldTypeId 38 means it is auto row number field-->\r\n <img\r\n [src]=\"column.Icon\"\r\n *ngIf=\"column.Extra?.IconDisplayTypeEnum === 'Image' || column.FieldTypeId === 42\"\r\n />\r\n {{\r\n column.Extra?.IconDisplayTypeEnum !== 'Image' && column.FieldTypeId !== 38\r\n ? (column.Caption | bbbTranslate)\r\n : ''\r\n }}\r\n </div>\r\n </fd-popover-control>\r\n <fd-popover-body>\r\n <ul fd-list>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onSortAscending(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"sort-ascending\"></fd-menu-addon>\r\n <span fd-menu-title\r\n >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Ascending' | bbbTranslate }}</span\r\n >\r\n </a>\r\n </li>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onSortDescending(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"sort-descending\"></fd-menu-addon>\r\n <span fd-menu-title\r\n >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Descending' | bbbTranslate }}</span\r\n >\r\n </a>\r\n </li>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onFilter(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"filter\"></fd-menu-addon>\r\n <span fd-menu-title>{{ 'Filter' | bbbTranslate }}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </fd-popover-body>\r\n </fd-popover>\r\n </th>\r\n\r\n <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0 && !inlineEditMode\">\r\n <th\r\n class=\"col-header col-context-menu\"\r\n fd-table-cell\r\n [fitContent]=\"disableOverflowContextMenu\"\r\n [style.width]=\"disableOverflowContextMenu ? '100%' : contextMenuItems.length > 1 ? '40px' : '100px'\"\r\n ></th>\r\n </ng-container>\r\n <th\r\n class=\"col-header col-details\"\r\n fd-table-cell\r\n style=\"width: 120px\"\r\n *ngIf=\"showDetailsInRow && !inlineEditMode\"\r\n ></th>\r\n <th\r\n class=\"col-header col-view\"\r\n fd-table-cell\r\n style=\"width: 40px\"\r\n *ngIf=\"canView && !inlineEditMode && !hideOpenIcon\"\r\n ></th>\r\n </ng-container>\r\n </tr>\r\n</thead>\r\n", styles: [":host{display:contents;width:100%}\n"] }]
|
|
83
|
-
}], propDecorators: { allChecked: [{
|
|
88
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { allChecked: [{
|
|
84
89
|
type: Input
|
|
85
90
|
}], isCheckList: [{
|
|
86
91
|
type: Input
|
|
@@ -119,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
119
124
|
}], filter: [{
|
|
120
125
|
type: Output
|
|
121
126
|
}] } });
|
|
122
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-table-header.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-table-header/barsa-table-header.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-table-header/barsa-table-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,uBAAuB,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAiB,MAAM,eAAe,CAAC;AAC/G,OAAO,EAAE,aAAa,EAAoB,MAAM,sBAAsB,CAAC;;;;;;;;;;AASvE,MAAM,OAAO,yBAA0B,SAAQ,aAAa;IAN5D;;QAiBa,qBAAgB,GAAG,KAAK,CAAC;QAKxB,gBAAW,GAAG,IAAI,YAAY,EAAW,CAAC;QAC1C,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QACxC,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,WAAM,GAAG,IAAI,YAAY,EAAoB,CAAC;KA+D3D;IA3DG,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7D,CAAC;IACD,WAAW,CAAC,OAAsB;QAC9B,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC3B,MAAM,EAAE,OAAO,EAAE,cAAc,EAAE,GAAG,OAAO,CAAC;QAC5C,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE;YACjC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,YAAY,CAAC,CAAC;SACpE;QACD,IACI,cAAc;YACd,CAAC,cAAc,CAAC,WAAW;YAC3B,cAAc,CAAC,YAAY,KAAK,IAAI;YACpC,IAAI,CAAC,cAAc,KAAK,KAAK,EAC/B;YACE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;SAC5D;IACL,CAAC;IACS,oBAAoB,CAAC,GAAW,EAAE,OAA2B;QACnE,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,CAAC,IAAI,GAAG,MAAM,EAAE,CAAC,CAAC,CAAC;QAC7F,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;QAC9D,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,OAAO;SACV;QACD,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC;QACxB,IAAI,GAAG,GAAG,GAAG,EAAE;YACX,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,GAAG,CAAC,MAAM,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC;YACjF,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC;SAC5C;aAAM,IAAI,GAAG,GAAG,EAAE,GAAG,GAAG,EAAE;YACvB,OAAO,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,OAAO,GAAG,MAAM,CAAC;SAChD;IACL,CAAC;IACD,aAAa,CAAC,OAAO;QACjB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnC,CAAC;IACD,eAAe,CAAC,MAAwB,EAAE,IAAI;QAC1C,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;QACD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACpC,CAAC;IAED,gBAAgB,CAAC,MAAwB,EAAE,IAAI;QAC3C,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACrC,CAAC;IAED,QAAQ,CAAC,MAAwB,EAAE,IAAI;QACnC,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,KAAK,EAAE,CAAC;SAChB;QACD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IACD,cAAc,CAAC,KAAa,EAAE,MAAwB;QAClD,OAAO,GAAG,MAAM,CAAC,IAAI,GAAG,KAAK,EAAE,CAAC;IACpC,CAAC;;sHAjFQ,yBAAyB;0GAAzB,yBAAyB,qsBCVtC,i5JAiGA;2FDvFa,yBAAyB;kBANrC,SAAS;+BACI,wBAAwB,mBAGjB,uBAAuB,CAAC,MAAM;8BAGtC,UAAU;sBAAlB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,0BAA0B;sBAAlC,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACI,WAAW;sBAApB,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBACG,cAAc;sBAAvB,MAAM;gBACG,MAAM;sBAAf,MAAM","sourcesContent":["import { Component, ChangeDetectionStrategy, Input, EventEmitter, Output, SimpleChanges } from '@angular/core';\r\nimport { BaseComponent, ReportViewColumn } from 'barsa-novin-ray-core';\r\nimport { UiTableViewSetting } from '../models/grid-view';\r\n\r\n@Component({\r\n    selector: 'bsu-barsa-table-header',\r\n    templateUrl: './barsa-table-header.component.html',\r\n    styleUrls: ['./barsa-table-header.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class BarsaTableHeaderComponent extends BaseComponent {\r\n    @Input() allChecked: boolean;\r\n    @Input() isCheckList: boolean;\r\n    @Input() columns: ReportViewColumn[];\r\n    @Input() fitWidth: boolean;\r\n    @Input() contextMenuItems: any[];\r\n    @Input() canView: boolean;\r\n    @Input() hideOpenIcon: boolean;\r\n    @Input() disableOverflowContextMenu: boolean;\r\n    @Input() inlineEditMode: boolean;\r\n    @Input() hideHeader: boolean;\r\n    @Input() showDetailsInRow = false;\r\n    @Input() viewSetting: UiTableViewSetting;\r\n    @Input() tableWidth: number;\r\n    @Input() resizedByUser: boolean;\r\n    @Input() disableResponsive: boolean;\r\n    @Output() allCheckbox = new EventEmitter<boolean>();\r\n    @Output() sortAscending = new EventEmitter<any>();\r\n    @Output() sortDescending = new EventEmitter<any>();\r\n    @Output() filter = new EventEmitter<ReportViewColumn>();\r\n    columnsSmallerThanTableWidth: boolean;\r\n    columnsWidth: number;\r\n\r\n    ngOnInit(): void {\r\n        super.ngOnInit();\r\n        this._prepareColumnsWidth(this.tableWidth, this.columns);\r\n    }\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        super.ngOnChanges(changes);\r\n        const { columns, inlineEditMode } = changes;\r\n        if (columns && !columns.firstChange) {\r\n            this._prepareColumnsWidth(this.tableWidth, columns.currentValue);\r\n        }\r\n        if (\r\n            inlineEditMode &&\r\n            !inlineEditMode.firstChange &&\r\n            inlineEditMode.currentValue === true &&\r\n            this.inlineEditMode === false\r\n        ) {\r\n            this._prepareColumnsWidth(this.tableWidth, this.columns);\r\n        }\r\n    }\r\n    protected _prepareColumnsWidth(val: number, columns: ReportViewColumn[]): void {\r\n        const sum = columns.map((column) => column.Width).reduce((val2, column) => val2 + column, 0);\r\n        columns.forEach((column) => (column.$Width2 = column.$Width));\r\n        if (this.resizedByUser) {\r\n            return;\r\n        }\r\n        this.columnsWidth = sum;\r\n        if (sum > val) {\r\n            columns.forEach((column) => (column.$Width2 = (column.Width * 100) / val + '%'));\r\n            this.columnsSmallerThanTableWidth = true;\r\n        } else if (sum + 10 < val) {\r\n            columns[columns.length - 1].$Width2 = '100%';\r\n        }\r\n    }\r\n    onAllCheckbox(checked): void {\r\n        this.allCheckbox.emit(checked);\r\n    }\r\n    onSortAscending(column: ReportViewColumn, menu): void {\r\n        if (menu) {\r\n            menu.close();\r\n        }\r\n        this.sortAscending.emit(column);\r\n    }\r\n\r\n    onSortDescending(column: ReportViewColumn, menu): void {\r\n        if (menu) {\r\n            menu.close();\r\n        }\r\n        this.sortDescending.emit(column);\r\n    }\r\n\r\n    onFilter(column: ReportViewColumn, menu): void {\r\n        if (menu) {\r\n            menu.close();\r\n        }\r\n        this.filter.emit(column);\r\n    }\r\n    _trackByColumn(index: number, column: ReportViewColumn): string {\r\n        return `${column.Name}${index}`;\r\n    }\r\n}\r\n","<thead\r\n    fd-table-header\r\n    [class.inline-edit]=\"inlineEditMode\"\r\n    [class.smallColumns]=\"columnsSmallerThanTableWidth\"\r\n    [attr.columnsWidth]=\"columnsWidth\"\r\n    [attr.tableWidth]=\"tableWidth\"\r\n>\r\n    <tr fd-table-row>\r\n        <ng-container *ngIf=\"!hideHeader\">\r\n            <th fd-table-cell *ngIf=\"isCheckList\">\r\n                <fd-checkbox\r\n                    name=\"allCheckbox\"\r\n                    [ngModel]=\"allChecked\"\r\n                    (ngModelChange)=\"onAllCheckbox($event)\"\r\n                ></fd-checkbox>\r\n            </th>\r\n            <th fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\"></th>\r\n            <th\r\n                *ngFor=\"let column of columns; let i = index; let last = last; trackBy: _trackByColumn\"\r\n                [columnIndex]=\"i\"\r\n                fd-table-cell\r\n                [style.width]=\"column.FieldTypeId === 38 ? '40px' : column.$Width2\"\r\n                [style.min-width]=\"last ? '100%' : 'auto'\"\r\n                columnResizer\r\n                [disableResizer]=\"fitWidth\"\r\n                [attr.columnName]=\"column.Name\"\r\n                [attr.index]=\"i\"\r\n                [ngClass]=\"column.$CSSClassName + ' column__' + column.Caption\"\r\n                [class.displayIcon]=\"column.Extra?.IconDisplayTypeEnum\"\r\n            >\r\n                <fd-popover #menu>\r\n                    <fd-popover-control>\r\n                        <div style=\"display: flex\">\r\n                            <!-- FieldTypeId 38 means it is auto row number field-->\r\n                            <img\r\n                                [src]=\"column.Icon\"\r\n                                *ngIf=\"column.Extra?.IconDisplayTypeEnum === 'Image' || column.FieldTypeId === 42\"\r\n                            />\r\n                            {{\r\n                                column.Extra?.IconDisplayTypeEnum !== 'Image' && column.FieldTypeId !== 38\r\n                                    ? (column.Caption | bbbTranslate)\r\n                                    : ''\r\n                            }}\r\n                        </div>\r\n                    </fd-popover-control>\r\n                    <fd-popover-body>\r\n                        <ul fd-list>\r\n                            <li fd-list-item>\r\n                                <a fd-menu-interactive (click)=\"onSortAscending(column, menu)\">\r\n                                    <fd-menu-addon position=\"before\" glyph=\"sort-ascending\"></fd-menu-addon>\r\n                                    <span fd-menu-title\r\n                                        >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Ascending' | bbbTranslate }}</span\r\n                                    >\r\n                                </a>\r\n                            </li>\r\n                            <li fd-list-item>\r\n                                <a fd-menu-interactive (click)=\"onSortDescending(column, menu)\">\r\n                                    <fd-menu-addon position=\"before\" glyph=\"sort-descending\"></fd-menu-addon>\r\n                                    <span fd-menu-title\r\n                                        >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Descending' | bbbTranslate }}</span\r\n                                    >\r\n                                </a>\r\n                            </li>\r\n                            <li fd-list-item>\r\n                                <a fd-menu-interactive (click)=\"onFilter(column, menu)\">\r\n                                    <fd-menu-addon position=\"before\" glyph=\"filter\"></fd-menu-addon>\r\n                                    <span fd-menu-title>{{ 'Filter' | bbbTranslate }}</span>\r\n                                </a>\r\n                            </li>\r\n                        </ul>\r\n                    </fd-popover-body>\r\n                </fd-popover>\r\n            </th>\r\n\r\n            <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0 && !inlineEditMode\">\r\n                <th\r\n                    class=\"col-header col-context-menu\"\r\n                    fd-table-cell\r\n                    [fitContent]=\"disableOverflowContextMenu\"\r\n                    [style.width]=\"disableOverflowContextMenu ? '100%' : contextMenuItems.length > 1 ? '40px' : '100px'\"\r\n                ></th>\r\n            </ng-container>\r\n            <th\r\n                class=\"col-header col-details\"\r\n                fd-table-cell\r\n                style=\"width: 120px\"\r\n                *ngIf=\"showDetailsInRow && !inlineEditMode\"\r\n            ></th>\r\n            <th\r\n                class=\"col-header col-view\"\r\n                fd-table-cell\r\n                style=\"width: 40px\"\r\n                *ngIf=\"canView && !inlineEditMode && !hideOpenIcon\"\r\n            ></th>\r\n        </ng-container>\r\n    </tr>\r\n</thead>\r\n"]}
|
|
127
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"barsa-table-header.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/barsa-table-header/barsa-table-header.component.ts","../../../../../projects/barsa-sap-ui/src/lib/barsa-table-header/barsa-table-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ChangeDetectionStrategy,\n    Input,\n    EventEmitter,\n    Output,\n    SimpleChanges,\n    ChangeDetectorRef\n} from '@angular/core';\nimport { BaseComponent, ReportViewColumn } from 'barsa-novin-ray-core';\nimport { UiTableViewSetting } from '../models/grid-view';\n\n@Component({\n    selector: 'bsu-barsa-table-header',\n    templateUrl: './barsa-table-header.component.html',\n    styleUrls: ['./barsa-table-header.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarsaTableHeaderComponent extends BaseComponent {\n    @Input() allChecked: boolean;\n    @Input() isCheckList: boolean;\n    @Input() columns: ReportViewColumn[];\n    @Input() fitWidth: boolean;\n    @Input() contextMenuItems: any[];\n    @Input() canView: boolean;\n    @Input() hideOpenIcon: boolean;\n    @Input() disableOverflowContextMenu: boolean;\n    @Input() inlineEditMode: boolean;\n    @Input() hideHeader: boolean;\n    @Input() showDetailsInRow = false;\n    @Input() viewSetting: UiTableViewSetting;\n    @Input() tableWidth: number;\n    @Input() resizedByUser: boolean;\n    @Input() disableResponsive: boolean;\n    @Output() allCheckbox = new EventEmitter<boolean>();\n    @Output() sortAscending = new EventEmitter<any>();\n    @Output() sortDescending = new EventEmitter<any>();\n    @Output() filter = new EventEmitter<ReportViewColumn>();\n    columnsSmallerThanTableWidth: boolean;\n    columnsWidth: number;\n    /**\n     *\n     */\n    constructor(private _cdr: ChangeDetectorRef) {\n        super();\n    }\n    ngOnInit(): void {\n        super.ngOnInit();\n        this._prepareColumnsWidth(this.tableWidth, this.columns);\n    }\n    ngOnChanges(changes: SimpleChanges): void {\n        super.ngOnChanges(changes);\n        const { columns, inlineEditMode } = changes;\n        if (columns && !columns.firstChange) {\n            this._prepareColumnsWidth(this.tableWidth, columns.currentValue);\n            this._cdr.detectChanges();\n        }\n        if (\n            inlineEditMode &&\n            !inlineEditMode.firstChange &&\n            inlineEditMode.currentValue === true &&\n            this.inlineEditMode === false\n        ) {\n            this._prepareColumnsWidth(this.tableWidth, this.columns);\n        }\n    }\n    protected _prepareColumnsWidth(val: number, columns: ReportViewColumn[]): void {\n        const sum = columns.map((column) => column.Width).reduce((val2, column) => val2 + column, 0);\n        columns.forEach((column) => (column.$Width2 = column.$Width));\n        if (this.resizedByUser) {\n            return;\n        }\n        this.columnsWidth = sum;\n        if (sum > val && val > 0) {\n            columns.forEach((column) => (column.$Width2 = (column.Width * 100) / val + '%'));\n            this.columnsSmallerThanTableWidth = true;\n        } else if (sum + 10 < val) {\n            columns[columns.length - 1].$Width2 = '100%';\n        }\n    }\n    onAllCheckbox(checked): void {\n        this.allCheckbox.emit(checked);\n    }\n    onSortAscending(column: ReportViewColumn, menu): void {\n        if (menu) {\n            menu.close();\n        }\n        this.sortAscending.emit(column);\n    }\n\n    onSortDescending(column: ReportViewColumn, menu): void {\n        if (menu) {\n            menu.close();\n        }\n        this.sortDescending.emit(column);\n    }\n\n    onFilter(column: ReportViewColumn, menu): void {\n        if (menu) {\n            menu.close();\n        }\n        this.filter.emit(column);\n    }\n    _trackByColumn(index: number, column: ReportViewColumn): string {\n        return `${column.Name}${index}`;\n    }\n}\n","<thead\r\n    fd-table-header\r\n    [class.inline-edit]=\"inlineEditMode\"\r\n    [class.smallColumns]=\"columnsSmallerThanTableWidth\"\r\n    [attr.columnsWidth]=\"columnsWidth\"\r\n    [attr.tableWidth]=\"tableWidth\"\r\n>\r\n    <tr fd-table-row>\r\n        <ng-container *ngIf=\"!hideHeader\">\r\n            <th fd-table-cell *ngIf=\"isCheckList\">\r\n                <fd-checkbox\r\n                    name=\"allCheckbox\"\r\n                    [ngModel]=\"allChecked\"\r\n                    (ngModelChange)=\"onAllCheckbox($event)\"\r\n                ></fd-checkbox>\r\n            </th>\r\n            <th fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\"></th>\r\n            <th\r\n                *ngFor=\"let column of columns; let i = index; let last = last; trackBy: _trackByColumn\"\r\n                [columnIndex]=\"i\"\r\n                fd-table-cell\r\n                [style.width]=\"column.FieldTypeId === 38 ? '40px' : column.$Width2\"\r\n                [style.min-width]=\"last ? '100%' : 'auto'\"\r\n                columnResizer\r\n                [disableResizer]=\"fitWidth\"\r\n                [attr.columnName]=\"column.Name\"\r\n                [attr.index]=\"i\"\r\n                [ngClass]=\"column.$CSSClassName + ' column__' + column.Caption\"\r\n                [class.displayIcon]=\"column.Extra?.IconDisplayTypeEnum\"\r\n            >\r\n                <fd-popover #menu>\r\n                    <fd-popover-control>\r\n                        <div style=\"display: flex\">\r\n                            <!-- FieldTypeId 38 means it is auto row number field-->\r\n                            <img\r\n                                [src]=\"column.Icon\"\r\n                                *ngIf=\"column.Extra?.IconDisplayTypeEnum === 'Image' || column.FieldTypeId === 42\"\r\n                            />\r\n                            {{\r\n                                column.Extra?.IconDisplayTypeEnum !== 'Image' && column.FieldTypeId !== 38\r\n                                    ? (column.Caption | bbbTranslate)\r\n                                    : ''\r\n                            }}\r\n                        </div>\r\n                    </fd-popover-control>\r\n                    <fd-popover-body>\r\n                        <ul fd-list>\r\n                            <li fd-list-item>\r\n                                <a fd-menu-interactive (click)=\"onSortAscending(column, menu)\">\r\n                                    <fd-menu-addon position=\"before\" glyph=\"sort-ascending\"></fd-menu-addon>\r\n                                    <span fd-menu-title\r\n                                        >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Ascending' | bbbTranslate }}</span\r\n                                    >\r\n                                </a>\r\n                            </li>\r\n                            <li fd-list-item>\r\n                                <a fd-menu-interactive (click)=\"onSortDescending(column, menu)\">\r\n                                    <fd-menu-addon position=\"before\" glyph=\"sort-descending\"></fd-menu-addon>\r\n                                    <span fd-menu-title\r\n                                        >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Descending' | bbbTranslate }}</span\r\n                                    >\r\n                                </a>\r\n                            </li>\r\n                            <li fd-list-item>\r\n                                <a fd-menu-interactive (click)=\"onFilter(column, menu)\">\r\n                                    <fd-menu-addon position=\"before\" glyph=\"filter\"></fd-menu-addon>\r\n                                    <span fd-menu-title>{{ 'Filter' | bbbTranslate }}</span>\r\n                                </a>\r\n                            </li>\r\n                        </ul>\r\n                    </fd-popover-body>\r\n                </fd-popover>\r\n            </th>\r\n\r\n            <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0 && !inlineEditMode\">\r\n                <th\r\n                    class=\"col-header col-context-menu\"\r\n                    fd-table-cell\r\n                    [fitContent]=\"disableOverflowContextMenu\"\r\n                    [style.width]=\"disableOverflowContextMenu ? '100%' : contextMenuItems.length > 1 ? '40px' : '100px'\"\r\n                ></th>\r\n            </ng-container>\r\n            <th\r\n                class=\"col-header col-details\"\r\n                fd-table-cell\r\n                style=\"width: 120px\"\r\n                *ngIf=\"showDetailsInRow && !inlineEditMode\"\r\n            ></th>\r\n            <th\r\n                class=\"col-header col-view\"\r\n                fd-table-cell\r\n                style=\"width: 40px\"\r\n                *ngIf=\"canView && !inlineEditMode && !hideOpenIcon\"\r\n            ></th>\r\n        </ng-container>\r\n    </tr>\r\n</thead>\r\n"]}
|
|
@@ -4657,8 +4657,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
|
|
|
4657
4657
|
}] });
|
|
4658
4658
|
|
|
4659
4659
|
class BarsaTableHeaderComponent extends BaseComponent {
|
|
4660
|
-
|
|
4661
|
-
|
|
4660
|
+
/**
|
|
4661
|
+
*
|
|
4662
|
+
*/
|
|
4663
|
+
constructor(_cdr) {
|
|
4664
|
+
super();
|
|
4665
|
+
this._cdr = _cdr;
|
|
4662
4666
|
this.showDetailsInRow = false;
|
|
4663
4667
|
this.allCheckbox = new EventEmitter();
|
|
4664
4668
|
this.sortAscending = new EventEmitter();
|
|
@@ -4674,6 +4678,7 @@ class BarsaTableHeaderComponent extends BaseComponent {
|
|
|
4674
4678
|
const { columns, inlineEditMode } = changes;
|
|
4675
4679
|
if (columns && !columns.firstChange) {
|
|
4676
4680
|
this._prepareColumnsWidth(this.tableWidth, columns.currentValue);
|
|
4681
|
+
this._cdr.detectChanges();
|
|
4677
4682
|
}
|
|
4678
4683
|
if (inlineEditMode &&
|
|
4679
4684
|
!inlineEditMode.firstChange &&
|
|
@@ -4689,7 +4694,7 @@ class BarsaTableHeaderComponent extends BaseComponent {
|
|
|
4689
4694
|
return;
|
|
4690
4695
|
}
|
|
4691
4696
|
this.columnsWidth = sum;
|
|
4692
|
-
if (sum > val) {
|
|
4697
|
+
if (sum > val && val > 0) {
|
|
4693
4698
|
columns.forEach((column) => (column.$Width2 = (column.Width * 100) / val + '%'));
|
|
4694
4699
|
this.columnsSmallerThanTableWidth = true;
|
|
4695
4700
|
}
|
|
@@ -4722,12 +4727,12 @@ class BarsaTableHeaderComponent extends BaseComponent {
|
|
|
4722
4727
|
return `${column.Name}${index}`;
|
|
4723
4728
|
}
|
|
4724
4729
|
}
|
|
4725
|
-
BarsaTableHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTableHeaderComponent, deps:
|
|
4730
|
+
BarsaTableHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTableHeaderComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
4726
4731
|
BarsaTableHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: BarsaTableHeaderComponent, selector: "bsu-barsa-table-header", inputs: { allChecked: "allChecked", isCheckList: "isCheckList", columns: "columns", fitWidth: "fitWidth", contextMenuItems: "contextMenuItems", canView: "canView", hideOpenIcon: "hideOpenIcon", disableOverflowContextMenu: "disableOverflowContextMenu", inlineEditMode: "inlineEditMode", hideHeader: "hideHeader", showDetailsInRow: "showDetailsInRow", viewSetting: "viewSetting", tableWidth: "tableWidth", resizedByUser: "resizedByUser", disableResponsive: "disableResponsive" }, outputs: { allCheckbox: "allCheckbox", sortAscending: "sortAscending", sortDescending: "sortDescending", filter: "filter" }, usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<thead\r\n fd-table-header\r\n [class.inline-edit]=\"inlineEditMode\"\r\n [class.smallColumns]=\"columnsSmallerThanTableWidth\"\r\n [attr.columnsWidth]=\"columnsWidth\"\r\n [attr.tableWidth]=\"tableWidth\"\r\n>\r\n <tr fd-table-row>\r\n <ng-container *ngIf=\"!hideHeader\">\r\n <th fd-table-cell *ngIf=\"isCheckList\">\r\n <fd-checkbox\r\n name=\"allCheckbox\"\r\n [ngModel]=\"allChecked\"\r\n (ngModelChange)=\"onAllCheckbox($event)\"\r\n ></fd-checkbox>\r\n </th>\r\n <th fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\"></th>\r\n <th\r\n *ngFor=\"let column of columns; let i = index; let last = last; trackBy: _trackByColumn\"\r\n [columnIndex]=\"i\"\r\n fd-table-cell\r\n [style.width]=\"column.FieldTypeId === 38 ? '40px' : column.$Width2\"\r\n [style.min-width]=\"last ? '100%' : 'auto'\"\r\n columnResizer\r\n [disableResizer]=\"fitWidth\"\r\n [attr.columnName]=\"column.Name\"\r\n [attr.index]=\"i\"\r\n [ngClass]=\"column.$CSSClassName + ' column__' + column.Caption\"\r\n [class.displayIcon]=\"column.Extra?.IconDisplayTypeEnum\"\r\n >\r\n <fd-popover #menu>\r\n <fd-popover-control>\r\n <div style=\"display: flex\">\r\n <!-- FieldTypeId 38 means it is auto row number field-->\r\n <img\r\n [src]=\"column.Icon\"\r\n *ngIf=\"column.Extra?.IconDisplayTypeEnum === 'Image' || column.FieldTypeId === 42\"\r\n />\r\n {{\r\n column.Extra?.IconDisplayTypeEnum !== 'Image' && column.FieldTypeId !== 38\r\n ? (column.Caption | bbbTranslate)\r\n : ''\r\n }}\r\n </div>\r\n </fd-popover-control>\r\n <fd-popover-body>\r\n <ul fd-list>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onSortAscending(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"sort-ascending\"></fd-menu-addon>\r\n <span fd-menu-title\r\n >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Ascending' | bbbTranslate }}</span\r\n >\r\n </a>\r\n </li>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onSortDescending(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"sort-descending\"></fd-menu-addon>\r\n <span fd-menu-title\r\n >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Descending' | bbbTranslate }}</span\r\n >\r\n </a>\r\n </li>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onFilter(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"filter\"></fd-menu-addon>\r\n <span fd-menu-title>{{ 'Filter' | bbbTranslate }}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </fd-popover-body>\r\n </fd-popover>\r\n </th>\r\n\r\n <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0 && !inlineEditMode\">\r\n <th\r\n class=\"col-header col-context-menu\"\r\n fd-table-cell\r\n [fitContent]=\"disableOverflowContextMenu\"\r\n [style.width]=\"disableOverflowContextMenu ? '100%' : contextMenuItems.length > 1 ? '40px' : '100px'\"\r\n ></th>\r\n </ng-container>\r\n <th\r\n class=\"col-header col-details\"\r\n fd-table-cell\r\n style=\"width: 120px\"\r\n *ngIf=\"showDetailsInRow && !inlineEditMode\"\r\n ></th>\r\n <th\r\n class=\"col-header col-view\"\r\n fd-table-cell\r\n style=\"width: 40px\"\r\n *ngIf=\"canView && !inlineEditMode && !hideOpenIcon\"\r\n ></th>\r\n </ng-container>\r\n </tr>\r\n</thead>\r\n", styles: [":host{display:contents;width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: i2$2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2$2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.ColumnResizerDirective, selector: "[columnResizer]", inputs: ["disableResizer"] }, { kind: "component", type: i6.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$1.ListComponent, selector: "[fd-list], [fdList]", inputs: ["dropdownMode", "multiInputMode", "mobileMode", "hasMessage", "noBorder", "navigationIndicator", "selection", "keyboardSupport", "byline"], outputs: ["focusEscapeList"] }, { kind: "component", type: i6$1.ListItemComponent, selector: "[fdListItem] ,[fd-list-item]", inputs: ["selected", "ariaDescribedBy", "noData", "action", "interactive", "growing", "counter", "unread", "selectedListItemScreenReaderText", "navigatedListItemScreenReaderText", "navigatableListItemScreenReaderText"], outputs: ["keyDown"] }, { kind: "directive", type: i6$3.MenuInteractiveDirective, selector: "[fd-menu-interactive]" }, { kind: "directive", type: i6$3.MenuTitleDirective, selector: "[fd-menu-title]" }, { kind: "component", type: i6$3.MenuAddonDirective, selector: "fd-menu-addon", inputs: ["position", "glyph", "submenuIndicator", "ariaHidden"] }, { kind: "component", type: i7$2.PopoverControlComponent, selector: "fd-popover-control" }, { kind: "component", type: i7$2.PopoverBodyComponent, selector: "fd-popover-body" }, { kind: "component", type: i7$2.PopoverComponent, selector: "fd-popover", inputs: ["title", "trigger", "fixedPosition", "id", "mobile", "mobileConfig"] }, { kind: "directive", type: i8$1.TableHeaderDirective, selector: "[fdTableHeader], [fd-table-header]", inputs: ["noBorderX", "noBorderY"] }, { kind: "directive", type: i8$1.TableRowDirective, selector: "[fdTableRow], [fd-table-row]", inputs: ["activable", "highlightActive", "hoverable", "focusable", "main", "secondary", "active"] }, { kind: "directive", type: i8$1.TableCellDirective, selector: "[fdTableCell], [fd-table-cell]", inputs: ["noBorderX", "noBorderY", "activable", "focusable", "tabindex", "hoverable", "fitContent", "noPadding", "noData", "key", "cellFocusedEventAnnouncer"] }, { kind: "pipe", type: i2.BbbTranslatePipe, name: "bbbTranslate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
4727
4732
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: BarsaTableHeaderComponent, decorators: [{
|
|
4728
4733
|
type: Component,
|
|
4729
4734
|
args: [{ selector: 'bsu-barsa-table-header', changeDetection: ChangeDetectionStrategy.OnPush, template: "<thead\r\n fd-table-header\r\n [class.inline-edit]=\"inlineEditMode\"\r\n [class.smallColumns]=\"columnsSmallerThanTableWidth\"\r\n [attr.columnsWidth]=\"columnsWidth\"\r\n [attr.tableWidth]=\"tableWidth\"\r\n>\r\n <tr fd-table-row>\r\n <ng-container *ngIf=\"!hideHeader\">\r\n <th fd-table-cell *ngIf=\"isCheckList\">\r\n <fd-checkbox\r\n name=\"allCheckbox\"\r\n [ngModel]=\"allChecked\"\r\n (ngModelChange)=\"onAllCheckbox($event)\"\r\n ></fd-checkbox>\r\n </th>\r\n <th fd-table-cell *ngIf=\"!isCheckList\" class=\"single-select\"></th>\r\n <th\r\n *ngFor=\"let column of columns; let i = index; let last = last; trackBy: _trackByColumn\"\r\n [columnIndex]=\"i\"\r\n fd-table-cell\r\n [style.width]=\"column.FieldTypeId === 38 ? '40px' : column.$Width2\"\r\n [style.min-width]=\"last ? '100%' : 'auto'\"\r\n columnResizer\r\n [disableResizer]=\"fitWidth\"\r\n [attr.columnName]=\"column.Name\"\r\n [attr.index]=\"i\"\r\n [ngClass]=\"column.$CSSClassName + ' column__' + column.Caption\"\r\n [class.displayIcon]=\"column.Extra?.IconDisplayTypeEnum\"\r\n >\r\n <fd-popover #menu>\r\n <fd-popover-control>\r\n <div style=\"display: flex\">\r\n <!-- FieldTypeId 38 means it is auto row number field-->\r\n <img\r\n [src]=\"column.Icon\"\r\n *ngIf=\"column.Extra?.IconDisplayTypeEnum === 'Image' || column.FieldTypeId === 42\"\r\n />\r\n {{\r\n column.Extra?.IconDisplayTypeEnum !== 'Image' && column.FieldTypeId !== 38\r\n ? (column.Caption | bbbTranslate)\r\n : ''\r\n }}\r\n </div>\r\n </fd-popover-control>\r\n <fd-popover-body>\r\n <ul fd-list>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onSortAscending(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"sort-ascending\"></fd-menu-addon>\r\n <span fd-menu-title\r\n >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Ascending' | bbbTranslate }}</span\r\n >\r\n </a>\r\n </li>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onSortDescending(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"sort-descending\"></fd-menu-addon>\r\n <span fd-menu-title\r\n >{{ ('Sort' | bbbTranslate) + ' ' }} {{ 'Descending' | bbbTranslate }}</span\r\n >\r\n </a>\r\n </li>\r\n <li fd-list-item>\r\n <a fd-menu-interactive (click)=\"onFilter(column, menu)\">\r\n <fd-menu-addon position=\"before\" glyph=\"filter\"></fd-menu-addon>\r\n <span fd-menu-title>{{ 'Filter' | bbbTranslate }}</span>\r\n </a>\r\n </li>\r\n </ul>\r\n </fd-popover-body>\r\n </fd-popover>\r\n </th>\r\n\r\n <ng-container *ngIf=\"contextMenuItems && contextMenuItems.length > 0 && !inlineEditMode\">\r\n <th\r\n class=\"col-header col-context-menu\"\r\n fd-table-cell\r\n [fitContent]=\"disableOverflowContextMenu\"\r\n [style.width]=\"disableOverflowContextMenu ? '100%' : contextMenuItems.length > 1 ? '40px' : '100px'\"\r\n ></th>\r\n </ng-container>\r\n <th\r\n class=\"col-header col-details\"\r\n fd-table-cell\r\n style=\"width: 120px\"\r\n *ngIf=\"showDetailsInRow && !inlineEditMode\"\r\n ></th>\r\n <th\r\n class=\"col-header col-view\"\r\n fd-table-cell\r\n style=\"width: 40px\"\r\n *ngIf=\"canView && !inlineEditMode && !hideOpenIcon\"\r\n ></th>\r\n </ng-container>\r\n </tr>\r\n</thead>\r\n", styles: [":host{display:contents;width:100%}\n"] }]
|
|
4730
|
-
}], propDecorators: { allChecked: [{
|
|
4735
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { allChecked: [{
|
|
4731
4736
|
type: Input
|
|
4732
4737
|
}], isCheckList: [{
|
|
4733
4738
|
type: Input
|