@datarailsshared/datarailsshared 1.6.234 → 1.6.238
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/assets/styles/_storybook-styles.scss +3 -0
- package/assets/styles/_styles.scss +3 -0
- package/datarailsshared-datarailsshared-1.6.238.tgz +0 -0
- package/esm2022/lib/decorators/decorators.mjs +26 -0
- package/esm2022/lib/dr-grid/components/cells/cell-action/cell-action.component.mjs +95 -0
- package/esm2022/lib/dr-grid/components/cells/cell-badge-status/cell-badge-status.component.mjs +49 -0
- package/esm2022/lib/dr-grid/components/cells/cell-button/cell-button.component.mjs +38 -0
- package/esm2022/lib/dr-grid/components/cells/cell-checkbox/cell-checkbox.component.mjs +50 -0
- package/esm2022/lib/dr-grid/components/cells/cell-children-list/cell-children-list.component.mjs +141 -0
- package/esm2022/lib/dr-grid/components/cells/cell-custom-template/cell-custom-template.component.mjs +28 -0
- package/esm2022/lib/dr-grid/components/cells/cell-icon-actions/cell-icon-actions.component.mjs +101 -0
- package/esm2022/lib/dr-grid/components/cells/cell-icon-text-edit/cell-icon-text-edit.component.mjs +130 -0
- package/esm2022/lib/dr-grid/components/cells/cell-link/cell-link.component.mjs +94 -0
- package/esm2022/lib/dr-grid/components/cells/cell-select/cell-select.component.mjs +45 -0
- package/esm2022/lib/dr-grid/components/cells/cell-set-as-default/cell-set-as-default.component.mjs +48 -0
- package/esm2022/lib/dr-grid/components/cells/cell-split-rows/cell-split-rows.component.mjs +99 -0
- package/esm2022/lib/dr-grid/components/cells/cell-toggle/cell-toggle.component.mjs +38 -0
- package/esm2022/lib/dr-grid/components/cells/tbl-header/tbl-header.component.mjs +169 -0
- package/esm2022/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.mjs +87 -0
- package/esm2022/lib/dr-grid/components/dr-grid-no-rows/dr-grid-no-rows.component.mjs +10 -0
- package/esm2022/lib/dr-grid/components/dr-grid-pagination/dr-grid-pagination.component.mjs +150 -0
- package/esm2022/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.mjs +194 -0
- package/esm2022/lib/dr-grid/components/tbl-toggle-button-header/tbl-toggle-button-header.component.mjs +46 -0
- package/esm2022/lib/dr-grid/dr-grid.component.mjs +364 -0
- package/esm2022/lib/dr-grid/dr-grid.mjs +26 -0
- package/esm2022/lib/dr-grid/models/dr-grid-events.mjs +9 -0
- package/esm2022/lib/dr-grid/models/dr-grid-theme.mjs +27 -0
- package/esm2022/lib/dr-grid/models/interfaces.mjs +6 -0
- package/esm2022/lib/dr-grid/services/abstract-single-grid.mjs +136 -0
- package/esm2022/lib/dr-grid/services/grid-utils.mjs +53 -0
- package/esm2022/lib/emoji-picker/emoji-picker.component.mjs +2 -2
- package/esm2022/lib/pipes/indeterminate/indeterminate.pipe.mjs +38 -0
- package/esm2022/local-api.mjs +6 -2
- package/fesm2022/datarailsshared-datarailsshared.mjs +2335 -265
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/decorators/decorators.d.ts +2 -0
- package/lib/dr-grid/components/cells/cell-action/cell-action.component.d.ts +37 -0
- package/lib/dr-grid/components/cells/cell-badge-status/cell-badge-status.component.d.ts +22 -0
- package/lib/dr-grid/components/cells/cell-button/cell-button.component.d.ts +19 -0
- package/lib/dr-grid/components/cells/cell-checkbox/cell-checkbox.component.d.ts +24 -0
- package/lib/dr-grid/components/cells/cell-children-list/cell-children-list.component.d.ts +21 -0
- package/lib/dr-grid/components/cells/cell-custom-template/cell-custom-template.component.d.ts +23 -0
- package/lib/dr-grid/components/cells/cell-icon-actions/cell-icon-actions.component.d.ts +35 -0
- package/lib/dr-grid/components/cells/cell-icon-text-edit/cell-icon-text-edit.component.d.ts +34 -0
- package/lib/dr-grid/components/cells/cell-link/cell-link.component.d.ts +33 -0
- package/lib/dr-grid/components/cells/cell-select/cell-select.component.d.ts +22 -0
- package/lib/dr-grid/components/cells/cell-set-as-default/cell-set-as-default.component.d.ts +16 -0
- package/lib/dr-grid/components/cells/cell-split-rows/cell-split-rows.component.d.ts +19 -0
- package/lib/dr-grid/components/cells/cell-toggle/cell-toggle.component.d.ts +15 -0
- package/lib/dr-grid/components/cells/tbl-header/tbl-header.component.d.ts +23 -0
- package/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.d.ts +18 -0
- package/lib/dr-grid/components/dr-grid-no-rows/dr-grid-no-rows.component.d.ts +6 -0
- package/lib/dr-grid/components/dr-grid-pagination/dr-grid-pagination.component.d.ts +25 -0
- package/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.d.ts +37 -0
- package/lib/dr-grid/components/tbl-toggle-button-header/tbl-toggle-button-header.component.d.ts +31 -0
- package/lib/dr-grid/dr-grid.component.d.ts +86 -0
- package/lib/dr-grid/dr-grid.d.ts +25 -0
- package/lib/dr-grid/models/dr-grid-events.d.ts +7 -0
- package/lib/dr-grid/models/dr-grid-theme.d.ts +3 -0
- package/lib/dr-grid/models/interfaces.d.ts +125 -0
- package/lib/dr-grid/services/abstract-single-grid.d.ts +37 -0
- package/lib/dr-grid/services/grid-utils.d.ts +11 -0
- package/lib/pipes/indeterminate/indeterminate.pipe.d.ts +12 -0
- package/local-api.d.ts +4 -1
- package/package.json +4 -2
- package/styles.css +7995 -0
- package/datarailsshared-datarailsshared-1.6.234.tgz +0 -0
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { Component, ChangeDetectionStrategy, Input, ChangeDetectorRef } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { ElementOverflowDirective } from '../../../../text-overflow/element-overflow.directive';
|
|
4
|
+
import { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "../../../../dr-tooltip/dr-tooltip.directive";
|
|
8
|
+
function CellSplitRowsComponent_ng_template_2_ng_container_1_Template(rf, ctx) { if (rf & 1) {
|
|
9
|
+
i0.ɵɵelementContainer(0);
|
|
10
|
+
} }
|
|
11
|
+
function CellSplitRowsComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) {
|
|
12
|
+
i0.ɵɵelementStart(0, "div", 4);
|
|
13
|
+
i0.ɵɵtemplate(1, CellSplitRowsComponent_ng_template_2_ng_container_1_Template, 1, 0, "ng-container", 5);
|
|
14
|
+
i0.ɵɵelementEnd();
|
|
15
|
+
} if (rf & 2) {
|
|
16
|
+
i0.ɵɵnextContext();
|
|
17
|
+
const _r2 = i0.ɵɵreference(5);
|
|
18
|
+
i0.ɵɵadvance(1);
|
|
19
|
+
i0.ɵɵproperty("ngTemplateOutlet", _r2);
|
|
20
|
+
} }
|
|
21
|
+
function CellSplitRowsComponent_ng_template_4_p_0_Template(rf, ctx) { if (rf & 1) {
|
|
22
|
+
const _r10 = i0.ɵɵgetCurrentView();
|
|
23
|
+
i0.ɵɵelementStart(0, "p", 7);
|
|
24
|
+
i0.ɵɵlistener("drElementOverflowChange", function CellSplitRowsComponent_ng_template_4_p_0_Template_p_drElementOverflowChange_0_listener($event) { const restoredCtx = i0.ɵɵrestoreView(_r10); const i_r8 = restoredCtx.index; const isMainText_r5 = i0.ɵɵnextContext().isMainText; const ctx_r9 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r9.setOverflown($event, i_r8, isMainText_r5)); });
|
|
25
|
+
i0.ɵɵtext(1);
|
|
26
|
+
i0.ɵɵelementEnd();
|
|
27
|
+
} if (rf & 2) {
|
|
28
|
+
const row_r7 = ctx.$implicit;
|
|
29
|
+
const i_r8 = ctx.index;
|
|
30
|
+
const isMainText_r5 = i0.ɵɵnextContext().isMainText;
|
|
31
|
+
const ctx_r6 = i0.ɵɵnextContext();
|
|
32
|
+
i0.ɵɵproperty("drElementOverflow", isMainText_r5 ? ctx_r6.isOverflownMap.get(i_r8) : null)("ngStyle", ctx_r6.rowStyles == null ? null : ctx_r6.rowStyles[i_r8]);
|
|
33
|
+
i0.ɵɵadvance(1);
|
|
34
|
+
i0.ɵɵtextInterpolate1(" ", row_r7, " ");
|
|
35
|
+
} }
|
|
36
|
+
function CellSplitRowsComponent_ng_template_4_Template(rf, ctx) { if (rf & 1) {
|
|
37
|
+
i0.ɵɵtemplate(0, CellSplitRowsComponent_ng_template_4_p_0_Template, 2, 3, "p", 6);
|
|
38
|
+
} if (rf & 2) {
|
|
39
|
+
const ctx_r3 = i0.ɵɵnextContext();
|
|
40
|
+
i0.ɵɵproperty("ngForOf", ctx_r3.rows);
|
|
41
|
+
} }
|
|
42
|
+
const _c0 = function () { return { isMainText: true }; };
|
|
43
|
+
export class CellSplitRowsComponent {
|
|
44
|
+
constructor(cdr) {
|
|
45
|
+
this.cdr = cdr;
|
|
46
|
+
this.theme = 'regular';
|
|
47
|
+
this.showTooltip = true;
|
|
48
|
+
this.isOverflownMap = new Map();
|
|
49
|
+
this.hasOverflownRow = false;
|
|
50
|
+
}
|
|
51
|
+
agInit(params) {
|
|
52
|
+
this.rows = params.rowsToSplit;
|
|
53
|
+
this.rowStyles = params.rowStyles;
|
|
54
|
+
this.theme = params.theme;
|
|
55
|
+
this.showTooltip = params.showTooltip;
|
|
56
|
+
this.rowGap = params.rowGap;
|
|
57
|
+
}
|
|
58
|
+
refresh() {
|
|
59
|
+
return false;
|
|
60
|
+
}
|
|
61
|
+
setOverflown(isOverflown, rowIndex, shouldUpdate) {
|
|
62
|
+
if (shouldUpdate) {
|
|
63
|
+
this.isOverflownMap.set(rowIndex, isOverflown);
|
|
64
|
+
this.hasOverflownRow = this.hasOverflownRow = Array.from(this.isOverflownMap.values()).some((value) => value);
|
|
65
|
+
this.cdr.markForCheck();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
/** @nocollapse */ static { this.ɵfac = function CellSplitRowsComponent_Factory(t) { return new (t || CellSplitRowsComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
|
|
69
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: CellSplitRowsComponent, selectors: [["dr-cell-split-rows"]], inputs: { rows: "rows", theme: "theme", rowStyles: "rowStyles", showTooltip: "showTooltip", rowGap: "rowGap" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 6, vars: 8, consts: [[1, "cell-split-rows", 3, "drTooltip"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], ["tooltipRef", ""], ["generateRows", ""], [1, "cell-split-rows__tooltip"], [4, "ngTemplateOutlet"], ["class", "cell-split-rows__row", 3, "drElementOverflow", "ngStyle", "drElementOverflowChange", 4, "ngFor", "ngForOf"], [1, "cell-split-rows__row", 3, "drElementOverflow", "ngStyle", "drElementOverflowChange"]], template: function CellSplitRowsComponent_Template(rf, ctx) { if (rf & 1) {
|
|
70
|
+
i0.ɵɵelementStart(0, "div", 0);
|
|
71
|
+
i0.ɵɵelementContainer(1, 1);
|
|
72
|
+
i0.ɵɵelementEnd();
|
|
73
|
+
i0.ɵɵtemplate(2, CellSplitRowsComponent_ng_template_2_Template, 2, 1, "ng-template", null, 2, i0.ɵɵtemplateRefExtractor);
|
|
74
|
+
i0.ɵɵtemplate(4, CellSplitRowsComponent_ng_template_4_Template, 1, 1, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
|
|
75
|
+
} if (rf & 2) {
|
|
76
|
+
const _r0 = i0.ɵɵreference(3);
|
|
77
|
+
const _r2 = i0.ɵɵreference(5);
|
|
78
|
+
i0.ɵɵclassMap(ctx.theme);
|
|
79
|
+
i0.ɵɵstyleProp("gap", ctx.rowGap);
|
|
80
|
+
i0.ɵɵproperty("drTooltip", ctx.showTooltip || ctx.hasOverflownRow ? _r0 : null);
|
|
81
|
+
i0.ɵɵadvance(1);
|
|
82
|
+
i0.ɵɵproperty("ngTemplateOutlet", _r2)("ngTemplateOutletContext", i0.ɵɵpureFunction0(7, _c0));
|
|
83
|
+
} }, dependencies: [CommonModule, i1.NgForOf, i1.NgTemplateOutlet, i1.NgStyle, DrTooltipModule, i2.DrTooltipDirective, ElementOverflowDirective], styles: ["[_nghost-%COMP%]{display:flex;width:100%}.cell-split-rows[_ngcontent-%COMP%]{display:flex;flex-direction:column;width:inherit;font-weight:400}.cell-split-rows__row[_ngcontent-%COMP%]{margin:0;padding:0;color:#0c142b;line-height:16px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-split-rows__row[_ngcontent-%COMP%]:first-child{line-height:24px;font-size:14px}.cell-split-rows.highlightMain[_ngcontent-%COMP%] > .cell-split-rows__row[_ngcontent-%COMP%]{font-size:14px;color:#6d6e6f}.cell-split-rows.highlightMain[_ngcontent-%COMP%] > .cell-split-rows__row[_ngcontent-%COMP%]:first-child{color:#333}.cell-split-rows.simple-text[_ngcontent-%COMP%]{display:flex;flex-direction:column;gap:26px}.cell-split-rows.simple-text[_ngcontent-%COMP%] > .cell-split-rows__row[_ngcontent-%COMP%]{font-weight:400;font-size:14px;line-height:24px;color:#333}.cell-split-rows__tooltip[_ngcontent-%COMP%]{padding:5px}"], changeDetection: 0 }); }
|
|
84
|
+
}
|
|
85
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CellSplitRowsComponent, [{
|
|
86
|
+
type: Component,
|
|
87
|
+
args: [{ selector: 'dr-cell-split-rows', standalone: true, imports: [CommonModule, DrTooltipModule, ElementOverflowDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n class=\"cell-split-rows\"\n [class]=\"theme\"\n [drTooltip]=\"showTooltip || hasOverflownRow ? tooltipRef : null\"\n [style.gap]=\"rowGap\">\n <ng-container [ngTemplateOutlet]=\"generateRows\" [ngTemplateOutletContext]=\"{ isMainText: true }\"></ng-container>\n</div>\n\n<ng-template #tooltipRef>\n <div class=\"cell-split-rows__tooltip\">\n <ng-container *ngTemplateOutlet=\"generateRows\"></ng-container>\n </div>\n</ng-template>\n\n<ng-template #generateRows let-isMainText=\"isMainText\">\n <p\n *ngFor=\"let row of rows; let i = index\"\n [drElementOverflow]=\"isMainText ? isOverflownMap.get(i) : null\"\n (drElementOverflowChange)=\"setOverflown($event, i, isMainText)\"\n class=\"cell-split-rows__row\"\n [ngStyle]=\"rowStyles?.[i]\">\n {{ row }}\n </p>\n</ng-template>\n", styles: [":host{display:flex;width:100%}.cell-split-rows{display:flex;flex-direction:column;width:inherit;font-weight:400}.cell-split-rows__row{margin:0;padding:0;color:#0c142b;line-height:16px;font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cell-split-rows__row:first-child{line-height:24px;font-size:14px}.cell-split-rows.highlightMain>.cell-split-rows__row{font-size:14px;color:#6d6e6f}.cell-split-rows.highlightMain>.cell-split-rows__row:first-child{color:#333}.cell-split-rows.simple-text{display:flex;flex-direction:column;gap:26px}.cell-split-rows.simple-text>.cell-split-rows__row{font-weight:400;font-size:14px;line-height:24px;color:#333}.cell-split-rows__tooltip{padding:5px}\n"] }]
|
|
88
|
+
}], function () { return [{ type: i0.ChangeDetectorRef }]; }, { rows: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], theme: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], rowStyles: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], showTooltip: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], rowGap: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}] }); })();
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC1zcGxpdC1yb3dzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWdyaWQvY29tcG9uZW50cy9jZWxscy9jZWxsLXNwbGl0LXJvd3MvY2VsbC1zcGxpdC1yb3dzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWdyaWQvY29tcG9uZW50cy9jZWxscy9jZWxsLXNwbGl0LXJvd3MvY2VsbC1zcGxpdC1yb3dzLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxzREFBc0QsQ0FBQztBQUNoRyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMENBQTBDLENBQUM7Ozs7O0lDT25FLHdCQUE4RDs7O0lBRGxFLDhCQUFzQztJQUNsQyx1R0FBOEQ7SUFDbEUsaUJBQU07Ozs7SUFEYSxlQUE4QjtJQUE5QixzQ0FBOEI7Ozs7SUFLakQsNEJBSytCO0lBRjNCLDhUQUEyQixlQUFBLGdEQUFtQyxDQUFBLElBQUM7SUFHL0QsWUFDSjtJQUFBLGlCQUFJOzs7Ozs7SUFMQSwwRkFBK0QscUVBQUE7SUFJL0QsZUFDSjtJQURJLHVDQUNKOzs7SUFQQSxpRkFPSTs7O0lBTmdCLHFDQUFTOzs7QURGakMsTUFBTSxPQUFPLHNCQUFzQjtJQVUvQixZQUE2QixHQUFzQjtRQUF0QixRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQVIxQyxVQUFLLEdBQWdELFNBQVMsQ0FBQztRQUUvRCxnQkFBVyxHQUFZLElBQUksQ0FBQztRQUc1QixtQkFBYyxHQUFHLElBQUksR0FBRyxFQUFtQixDQUFDO1FBQ3JELG9CQUFlLEdBQVksS0FBSyxDQUFDO0lBRXFCLENBQUM7SUFFdkQsTUFBTSxDQUFDLE1BQU07UUFDVCxJQUFJLENBQUMsSUFBSSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUM7UUFDL0IsSUFBSSxDQUFDLFNBQVMsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDO1FBQ2xDLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUMxQixJQUFJLENBQUMsV0FBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUM7UUFDdEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDO0lBQ2hDLENBQUM7SUFFRCxPQUFPO1FBQ0gsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQztJQUVELFlBQVksQ0FBQyxXQUFvQixFQUFFLFFBQWdCLEVBQUUsWUFBcUI7UUFDdEUsSUFBSSxZQUFZLEVBQUU7WUFDZCxJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsV0FBVyxDQUFDLENBQUM7WUFDL0MsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsZUFBZSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDOUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxZQUFZLEVBQUUsQ0FBQztTQUMzQjtJQUNMLENBQUM7MEdBOUJRLHNCQUFzQjttR0FBdEIsc0JBQXNCO1lDZG5DLDhCQUl5QjtZQUNyQiwyQkFBZ0g7WUFDcEgsaUJBQU07WUFFTix3SEFJYztZQUVkLHdIQVNjOzs7O1lBckJWLHdCQUFlO1lBRWYsaUNBQW9CO1lBRHBCLCtFQUFnRTtZQUVsRCxlQUFpQztZQUFqQyxzQ0FBaUMsdURBQUE7NEJETXJDLFlBQVksK0NBQUUsZUFBZSx5QkFBRSx3QkFBd0I7O3VGQUd4RCxzQkFBc0I7Y0FSbEMsU0FBUzsyQkFDSSxvQkFBb0IsY0FHbEIsSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLGVBQWUsRUFBRSx3QkFBd0IsQ0FBQyxtQkFDakQsdUJBQXVCLENBQUMsTUFBTTtvRUFHdEMsSUFBSTtrQkFBWixLQUFLO1lBQ0csS0FBSztrQkFBYixLQUFLO1lBQ0csU0FBUztrQkFBakIsS0FBSztZQUNHLFdBQVc7a0JBQW5CLEtBQUs7WUFDRyxNQUFNO2tCQUFkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBJbnB1dCwgQ2hhbmdlRGV0ZWN0b3JSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBFbGVtZW50T3ZlcmZsb3dEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi8uLi8uLi90ZXh0LW92ZXJmbG93L2VsZW1lbnQtb3ZlcmZsb3cuZGlyZWN0aXZlJztcbmltcG9ydCB7IERyVG9vbHRpcE1vZHVsZSB9IGZyb20gJy4uLy4uLy4uLy4uL2RyLXRvb2x0aXAvZHItdG9vbHRpcC5tb2R1bGUnO1xuaW1wb3J0IHsgSUdyaWRDZWxsUmVuZGVyZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvaW50ZXJmYWNlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZHItY2VsbC1zcGxpdC1yb3dzJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2VsbC1zcGxpdC1yb3dzLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jZWxsLXNwbGl0LXJvd3MuY29tcG9uZW50LnNjc3MnXSxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIERyVG9vbHRpcE1vZHVsZSwgRWxlbWVudE92ZXJmbG93RGlyZWN0aXZlXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQ2VsbFNwbGl0Um93c0NvbXBvbmVudCBpbXBsZW1lbnRzIElHcmlkQ2VsbFJlbmRlcmVyQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKSByb3dzOiBzdHJpbmdbXTtcbiAgICBASW5wdXQoKSB0aGVtZTogJ3JlZ3VsYXInIHwgJ2hpZ2hsaWdodE1haW4nIHwgJ3NpbXBsZS10ZXh0JyA9ICdyZWd1bGFyJztcbiAgICBASW5wdXQoKSByb3dTdHlsZXM6IGFueVtdO1xuICAgIEBJbnB1dCgpIHNob3dUb29sdGlwOiBib29sZWFuID0gdHJ1ZTtcbiAgICBASW5wdXQoKSByb3dHYXA6IHN0cmluZztcblxuICAgIHJlYWRvbmx5IGlzT3ZlcmZsb3duTWFwID0gbmV3IE1hcDxudW1iZXIsIGJvb2xlYW4+KCk7XG4gICAgaGFzT3ZlcmZsb3duUm93OiBib29sZWFuID0gZmFsc2U7XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgICBhZ0luaXQocGFyYW1zKTogdm9pZCB7XG4gICAgICAgIHRoaXMucm93cyA9IHBhcmFtcy5yb3dzVG9TcGxpdDtcbiAgICAgICAgdGhpcy5yb3dTdHlsZXMgPSBwYXJhbXMucm93U3R5bGVzO1xuICAgICAgICB0aGlzLnRoZW1lID0gcGFyYW1zLnRoZW1lO1xuICAgICAgICB0aGlzLnNob3dUb29sdGlwID0gcGFyYW1zLnNob3dUb29sdGlwO1xuICAgICAgICB0aGlzLnJvd0dhcCA9IHBhcmFtcy5yb3dHYXA7XG4gICAgfVxuXG4gICAgcmVmcmVzaCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cblxuICAgIHNldE92ZXJmbG93bihpc092ZXJmbG93bjogYm9vbGVhbiwgcm93SW5kZXg6IG51bWJlciwgc2hvdWxkVXBkYXRlOiBib29sZWFuKTogdm9pZCB7XG4gICAgICAgIGlmIChzaG91bGRVcGRhdGUpIHtcbiAgICAgICAgICAgIHRoaXMuaXNPdmVyZmxvd25NYXAuc2V0KHJvd0luZGV4LCBpc092ZXJmbG93bik7XG4gICAgICAgICAgICB0aGlzLmhhc092ZXJmbG93blJvdyA9IHRoaXMuaGFzT3ZlcmZsb3duUm93ID0gQXJyYXkuZnJvbSh0aGlzLmlzT3ZlcmZsb3duTWFwLnZhbHVlcygpKS5zb21lKCh2YWx1ZSkgPT4gdmFsdWUpO1xuICAgICAgICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8ZGl2XG4gICAgY2xhc3M9XCJjZWxsLXNwbGl0LXJvd3NcIlxuICAgIFtjbGFzc109XCJ0aGVtZVwiXG4gICAgW2RyVG9vbHRpcF09XCJzaG93VG9vbHRpcCB8fCBoYXNPdmVyZmxvd25Sb3cgPyB0b29sdGlwUmVmIDogbnVsbFwiXG4gICAgW3N0eWxlLmdhcF09XCJyb3dHYXBcIj5cbiAgICA8bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImdlbmVyYXRlUm93c1wiIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7IGlzTWFpblRleHQ6IHRydWUgfVwiPjwvbmctY29udGFpbmVyPlxuPC9kaXY+XG5cbjxuZy10ZW1wbGF0ZSAjdG9vbHRpcFJlZj5cbiAgICA8ZGl2IGNsYXNzPVwiY2VsbC1zcGxpdC1yb3dzX190b29sdGlwXCI+XG4gICAgICAgIDxuZy1jb250YWluZXIgKm5nVGVtcGxhdGVPdXRsZXQ9XCJnZW5lcmF0ZVJvd3NcIj48L25nLWNvbnRhaW5lcj5cbiAgICA8L2Rpdj5cbjwvbmctdGVtcGxhdGU+XG5cbjxuZy10ZW1wbGF0ZSAjZ2VuZXJhdGVSb3dzIGxldC1pc01haW5UZXh0PVwiaXNNYWluVGV4dFwiPlxuICAgIDxwXG4gICAgICAgICpuZ0Zvcj1cImxldCByb3cgb2Ygcm93czsgbGV0IGkgPSBpbmRleFwiXG4gICAgICAgIFtkckVsZW1lbnRPdmVyZmxvd109XCJpc01haW5UZXh0ID8gaXNPdmVyZmxvd25NYXAuZ2V0KGkpIDogbnVsbFwiXG4gICAgICAgIChkckVsZW1lbnRPdmVyZmxvd0NoYW5nZSk9XCJzZXRPdmVyZmxvd24oJGV2ZW50LCBpLCBpc01haW5UZXh0KVwiXG4gICAgICAgIGNsYXNzPVwiY2VsbC1zcGxpdC1yb3dzX19yb3dcIlxuICAgICAgICBbbmdTdHlsZV09XCJyb3dTdHlsZXM/LltpXVwiPlxuICAgICAgICB7eyByb3cgfX1cbiAgICA8L3A+XG48L25nLXRlbXBsYXRlPlxuIl19
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { DrInputsModule } from '../../../../dr-inputs/dr-inputs.module';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "@angular/forms";
|
|
8
|
+
import * as i3 from "../../../../dr-inputs/dr-toggle/dr-toggle.component";
|
|
9
|
+
function CellToggleComponent_dr_toggle_0_Template(rf, ctx) { if (rf & 1) {
|
|
10
|
+
const _r2 = i0.ɵɵgetCurrentView();
|
|
11
|
+
i0.ɵɵelementStart(0, "dr-toggle", 1);
|
|
12
|
+
i0.ɵɵlistener("checkedChange", function CellToggleComponent_dr_toggle_0_Template_dr_toggle_checkedChange_0_listener() { i0.ɵɵrestoreView(_r2); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.params.event(ctx_r1.field)); })("ngModelChange", function CellToggleComponent_dr_toggle_0_Template_dr_toggle_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView((ctx_r3.field[ctx_r3.params.field] = $event)); });
|
|
13
|
+
i0.ɵɵelementEnd();
|
|
14
|
+
} if (rf & 2) {
|
|
15
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
16
|
+
i0.ɵɵproperty("ngModel", ctx_r0.field[ctx_r0.params.field]);
|
|
17
|
+
} }
|
|
18
|
+
export class CellToggleComponent {
|
|
19
|
+
constructor() { }
|
|
20
|
+
agInit(params) {
|
|
21
|
+
this.field = params.data;
|
|
22
|
+
this.params = params.colDef.cellRendererParams;
|
|
23
|
+
}
|
|
24
|
+
refresh() {
|
|
25
|
+
return false;
|
|
26
|
+
}
|
|
27
|
+
/** @nocollapse */ static { this.ɵfac = function CellToggleComponent_Factory(t) { return new (t || CellToggleComponent)(); }; }
|
|
28
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: CellToggleComponent, selectors: [["dr-cell-toggle"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 1, vars: 1, consts: [[3, "ngModel", "checkedChange", "ngModelChange", 4, "ngIf"], [3, "ngModel", "checkedChange", "ngModelChange"]], template: function CellToggleComponent_Template(rf, ctx) { if (rf & 1) {
|
|
29
|
+
i0.ɵɵtemplate(0, CellToggleComponent_dr_toggle_0_Template, 1, 1, "dr-toggle", 0);
|
|
30
|
+
} if (rf & 2) {
|
|
31
|
+
i0.ɵɵproperty("ngIf", !(ctx.params == null ? null : ctx.params.show) || (ctx.params == null ? null : ctx.params.show(ctx.field)));
|
|
32
|
+
} }, dependencies: [CommonModule, i1.NgIf, FormsModule, i2.NgControlStatus, i2.NgModel, DrInputsModule, i3.DrToggleComponent], styles: ["[_nghost-%COMP%]{display:flex;justify-content:center;height:100%}"], changeDetection: 0 }); }
|
|
33
|
+
}
|
|
34
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CellToggleComponent, [{
|
|
35
|
+
type: Component,
|
|
36
|
+
args: [{ selector: 'dr-cell-toggle', template: '<dr-toggle *ngIf="!params?.show || params?.show(field)" (checkedChange)="params.event(field)" [(ngModel)]="field[params.field]"></dr-toggle>', standalone: true, imports: [CommonModule, FormsModule, DrInputsModule], changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{display:flex;justify-content:center;height:100%}\n"] }]
|
|
37
|
+
}], function () { return []; }, null); })();
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC10b2dnbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZ3JpZC9jb21wb25lbnRzL2NlbGxzL2NlbGwtdG9nZ2xlL2NlbGwtdG9nZ2xlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHdDQUF3QyxDQUFDOzs7Ozs7O0lBTS9ELG9DQUFnSTtJQUF4RSx5TEFBaUIsZUFBQSxpQ0FBbUIsQ0FBQSxJQUFDLGtQQUFBO0lBQW1DLGlCQUFZOzs7SUFBOUMsMkRBQWlDOztBQUt4SSxNQUFNLE9BQU8sbUJBQW1CO0lBSTVCLGdCQUFlLENBQUM7SUFFaEIsTUFBTSxDQUFDLE1BQU07UUFDVCxJQUFJLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLGtCQUFrQixDQUFDO0lBQ25ELENBQUM7SUFFRCxPQUFPO1FBQ0gsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQzt1R0FiUSxtQkFBbUI7bUdBQW5CLG1CQUFtQjtZQUx2QixnRkFBNEk7O1lBQWhJLGlJQUEwQzs0QkFFakQsWUFBWSxXQUFFLFdBQVcsa0NBQUUsY0FBYzs7dUZBRzFDLG1CQUFtQjtjQVQvQixTQUFTOzJCQUNJLGdCQUFnQixZQUd0Qiw4SUFBOEksY0FDdEksSUFBSSxXQUNQLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxjQUFjLENBQUMsbUJBQ25DLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJR3JpZENlbGxSZW5kZXJlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9pbnRlcmZhY2VzJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IERySW5wdXRzTW9kdWxlIH0gZnJvbSAnLi4vLi4vLi4vLi4vZHItaW5wdXRzL2RyLWlucHV0cy5tb2R1bGUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2RyLWNlbGwtdG9nZ2xlJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jZWxsLXRvZ2dsZS5jb21wb25lbnQuc2NzcyddLFxuICAgIHRlbXBsYXRlOlxuICAgICAgICAnPGRyLXRvZ2dsZSAqbmdJZj1cIiFwYXJhbXM/LnNob3cgfHwgcGFyYW1zPy5zaG93KGZpZWxkKVwiIChjaGVja2VkQ2hhbmdlKT1cInBhcmFtcy5ldmVudChmaWVsZClcIiBbKG5nTW9kZWwpXT1cImZpZWxkW3BhcmFtcy5maWVsZF1cIj48L2RyLXRvZ2dsZT4nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIERySW5wdXRzTW9kdWxlXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQ2VsbFRvZ2dsZUNvbXBvbmVudDxUPiBpbXBsZW1lbnRzIElHcmlkQ2VsbFJlbmRlcmVyQ29tcG9uZW50IHtcbiAgICBmaWVsZDogVDtcbiAgICBwYXJhbXM6IHsgZmllbGQ6IHN0cmluZzsgc2hvdz86IChmaWVsZDogVCkgPT4gYm9vbGVhbjsgZXZlbnQ6IChldmVudCkgPT4gVCB9O1xuXG4gICAgY29uc3RydWN0b3IoKSB7fVxuXG4gICAgYWdJbml0KHBhcmFtcyk6IHZvaWQge1xuICAgICAgICB0aGlzLmZpZWxkID0gcGFyYW1zLmRhdGE7XG4gICAgICAgIHRoaXMucGFyYW1zID0gcGFyYW1zLmNvbERlZi5jZWxsUmVuZGVyZXJQYXJhbXM7XG4gICAgfVxuXG4gICAgcmVmcmVzaCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import { Component, HostBinding } from '@angular/core';
|
|
2
|
+
import { takeUntil } from 'rxjs/operators';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import { DrInputsModule } from '../../../../dr-inputs/dr-inputs.module';
|
|
6
|
+
import { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';
|
|
7
|
+
import { getSortTypeByColumnSorting } from '../../../services/grid-utils';
|
|
8
|
+
import { GridDrEventType } from '../../../models/dr-grid-events';
|
|
9
|
+
import { Subject } from 'rxjs';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/common";
|
|
12
|
+
import * as i2 from "@angular/forms";
|
|
13
|
+
import * as i3 from "../../../../dr-inputs/dr-input/dr-input.component";
|
|
14
|
+
import * as i4 from "../../../../dr-inputs/button/button.component";
|
|
15
|
+
import * as i5 from "../../../../dr-tooltip/dr-tooltip.directive";
|
|
16
|
+
function TblHeaderComponent_i_3_Template(rf, ctx) { if (rf & 1) {
|
|
17
|
+
i0.ɵɵelement(0, "i", 5);
|
|
18
|
+
} if (rf & 2) {
|
|
19
|
+
const ctx_r0 = i0.ɵɵnextContext();
|
|
20
|
+
i0.ɵɵproperty("drTooltip", ctx_r0.params == null ? null : ctx_r0.params.infoTooltip);
|
|
21
|
+
} }
|
|
22
|
+
function TblHeaderComponent_dr_button_4_Template(rf, ctx) { if (rf & 1) {
|
|
23
|
+
const _r4 = i0.ɵɵgetCurrentView();
|
|
24
|
+
i0.ɵɵelementStart(0, "dr-button", 6);
|
|
25
|
+
i0.ɵɵlistener("click", function TblHeaderComponent_dr_button_4_Template_dr_button_click_0_listener() { i0.ɵɵrestoreView(_r4); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.onSortChanged()); });
|
|
26
|
+
i0.ɵɵelementEnd();
|
|
27
|
+
} if (rf & 2) {
|
|
28
|
+
const ctx_r1 = i0.ɵɵnextContext();
|
|
29
|
+
i0.ɵɵclassProp("sorted", !!ctx_r1.sort);
|
|
30
|
+
i0.ɵɵproperty("theme", "icon")("icon", ctx_r1.sort === "desc" ? "dr-icon-sort" : "dr-icon-sort-up");
|
|
31
|
+
} }
|
|
32
|
+
function TblHeaderComponent_dr_input_5_Template(rf, ctx) { if (rf & 1) {
|
|
33
|
+
const _r6 = i0.ɵɵgetCurrentView();
|
|
34
|
+
i0.ɵɵelementStart(0, "dr-input", 7);
|
|
35
|
+
i0.ɵɵlistener("ngModelChange", function TblHeaderComponent_dr_input_5_Template_dr_input_ngModelChange_0_listener($event) { i0.ɵɵrestoreView(_r6); const ctx_r5 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r5.onFilterChanged($event)); });
|
|
36
|
+
i0.ɵɵelementEnd();
|
|
37
|
+
} if (rf & 2) {
|
|
38
|
+
const ctx_r2 = i0.ɵɵnextContext();
|
|
39
|
+
i0.ɵɵproperty("ngModel", ctx_r2.filterValue);
|
|
40
|
+
} }
|
|
41
|
+
export class TblHeaderComponent {
|
|
42
|
+
constructor() {
|
|
43
|
+
this.destroy$ = new Subject();
|
|
44
|
+
this.initSorted = true;
|
|
45
|
+
}
|
|
46
|
+
get hostDataTestId() {
|
|
47
|
+
return 'dr-tbl-header';
|
|
48
|
+
}
|
|
49
|
+
agInit(params) {
|
|
50
|
+
this.gridApi = params.api;
|
|
51
|
+
this.gridColumnApi = params.columnApi;
|
|
52
|
+
this.params = params;
|
|
53
|
+
this.defs = params.column.getColDef();
|
|
54
|
+
setTimeout(() => {
|
|
55
|
+
if (this.gridApi?.drEvents) {
|
|
56
|
+
this.subscribeOnSort();
|
|
57
|
+
this.subscribeOnUpdateTableParams();
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
if (this.defs) {
|
|
61
|
+
this.filterValue = this.defs.filter;
|
|
62
|
+
this.sort = this.defs.sort;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
refresh() {
|
|
66
|
+
return false;
|
|
67
|
+
}
|
|
68
|
+
onSortChanged(sort) {
|
|
69
|
+
if (this.defs.sortable) {
|
|
70
|
+
const isFromOutside = typeof sort !== 'undefined';
|
|
71
|
+
if (isFromOutside) {
|
|
72
|
+
this.sort = sort;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
this.sort = this.sort === 'asc' ? 'desc' : this.sort === 'desc' ? null : 'asc';
|
|
76
|
+
}
|
|
77
|
+
if (this.defs.sort) {
|
|
78
|
+
if (this.initSorted) {
|
|
79
|
+
this.sort = this.defs.sort;
|
|
80
|
+
this.initSorted = false;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
this.gridColumnApi.applyColumnState({
|
|
84
|
+
state: [{ colId: this.defs.colId, sort: this.sort }],
|
|
85
|
+
defaultState: { sort: null },
|
|
86
|
+
});
|
|
87
|
+
if (!isFromOutside) {
|
|
88
|
+
this.gridApi.drEvents.emit({
|
|
89
|
+
type: GridDrEventType.UPDATE_SORT,
|
|
90
|
+
data: {
|
|
91
|
+
sort: this.sort,
|
|
92
|
+
header: this.params,
|
|
93
|
+
colId: this.defs.colId,
|
|
94
|
+
},
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
onFilterChanged(filterValue) {
|
|
100
|
+
this.gridApi.drEvents.filtersMap.set(this.defs.field, filterValue);
|
|
101
|
+
this.gridApi.drEvents.emit({ type: GridDrEventType.UPDATE_FILTER, data: this.gridApi.drEvents.filtersMap });
|
|
102
|
+
}
|
|
103
|
+
subscribeOnSort() {
|
|
104
|
+
this.gridApi.drEvents
|
|
105
|
+
.on(GridDrEventType.UPDATE_SORT)
|
|
106
|
+
.pipe(takeUntil(this.destroy$))
|
|
107
|
+
.subscribe((sort) => {
|
|
108
|
+
if (sort.header.displayName !== this.params.displayName) {
|
|
109
|
+
this.sort = null;
|
|
110
|
+
}
|
|
111
|
+
else {
|
|
112
|
+
this.sort = sort.sort;
|
|
113
|
+
}
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
subscribeOnUpdateTableParams() {
|
|
117
|
+
this.gridApi.drEvents
|
|
118
|
+
.on(GridDrEventType.UPDATE_PARAMS)
|
|
119
|
+
.pipe(takeUntil(this.destroy$))
|
|
120
|
+
.subscribe((tableParams) => {
|
|
121
|
+
const columnNameForSorting = tableParams?.ordering?.replace('-', '') || null;
|
|
122
|
+
const sorting = getSortTypeByColumnSorting(tableParams.ordering, columnNameForSorting);
|
|
123
|
+
if (columnNameForSorting === this.params.column?.colId || sorting === null) {
|
|
124
|
+
this.onSortChanged(sorting);
|
|
125
|
+
}
|
|
126
|
+
else if (tableParams.cleanOtherOrdering) {
|
|
127
|
+
this.onSortChanged(null);
|
|
128
|
+
}
|
|
129
|
+
if (tableParams?.filtering?.has(this.params.column?.colId)) {
|
|
130
|
+
this.filterValue = tableParams.filtering.get(this.params.column?.colId);
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
}
|
|
134
|
+
ngOnDestroy() {
|
|
135
|
+
this.destroy$.next();
|
|
136
|
+
this.destroy$.complete();
|
|
137
|
+
}
|
|
138
|
+
/** @nocollapse */ static { this.ɵfac = function TblHeaderComponent_Factory(t) { return new (t || TblHeaderComponent)(); }; }
|
|
139
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TblHeaderComponent, selectors: [["dr-tbl-header"]], hostVars: 1, hostBindings: function TblHeaderComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
140
|
+
i0.ɵɵattribute("data-testid", ctx.hostDataTestId);
|
|
141
|
+
} }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 6, vars: 5, consts: [[1, "table-header"], ["data-testid", "dr-tbl-header-title", 1, "table-header__title", 3, "title"], ["data-testid", "dr-tbl-header__tooltip-icon", "class", "table-header__tooltip dr-icon-info", "drTooltipPosition", "top", 3, "drTooltip", 4, "ngIf"], ["data-analytics", "tables_tbl-header_button-0", "data-testid", "dr-tbl-header__sort-button", 3, "sorted", "theme", "icon", "click", 4, "ngIf"], ["data-analytics", "tables_tbl-header_input-2", 3, "ngModel", "ngModelChange", 4, "ngIf"], ["data-testid", "dr-tbl-header__tooltip-icon", "drTooltipPosition", "top", 1, "table-header__tooltip", "dr-icon-info", 3, "drTooltip"], ["data-analytics", "tables_tbl-header_button-0", "data-testid", "dr-tbl-header__sort-button", 3, "theme", "icon", "click"], ["data-analytics", "tables_tbl-header_input-2", 3, "ngModel", "ngModelChange"]], template: function TblHeaderComponent_Template(rf, ctx) { if (rf & 1) {
|
|
142
|
+
i0.ɵɵelementStart(0, "div", 0)(1, "span", 1);
|
|
143
|
+
i0.ɵɵtext(2);
|
|
144
|
+
i0.ɵɵelementEnd();
|
|
145
|
+
i0.ɵɵtemplate(3, TblHeaderComponent_i_3_Template, 1, 1, "i", 2);
|
|
146
|
+
i0.ɵɵtemplate(4, TblHeaderComponent_dr_button_4_Template, 1, 4, "dr-button", 3);
|
|
147
|
+
i0.ɵɵelementEnd();
|
|
148
|
+
i0.ɵɵtemplate(5, TblHeaderComponent_dr_input_5_Template, 1, 1, "dr-input", 4);
|
|
149
|
+
} if (rf & 2) {
|
|
150
|
+
i0.ɵɵadvance(1);
|
|
151
|
+
i0.ɵɵproperty("title", ctx.params.displayName);
|
|
152
|
+
i0.ɵɵadvance(1);
|
|
153
|
+
i0.ɵɵtextInterpolate(ctx.params.displayName);
|
|
154
|
+
i0.ɵɵadvance(1);
|
|
155
|
+
i0.ɵɵproperty("ngIf", ctx.params == null ? null : ctx.params.infoTooltip);
|
|
156
|
+
i0.ɵɵadvance(1);
|
|
157
|
+
i0.ɵɵproperty("ngIf", ctx.defs == null ? null : ctx.defs.sortable);
|
|
158
|
+
i0.ɵɵadvance(1);
|
|
159
|
+
i0.ɵɵproperty("ngIf", ctx.defs == null ? null : ctx.defs.headerComponentParams == null ? null : ctx.defs.headerComponentParams.filterable);
|
|
160
|
+
} }, dependencies: [CommonModule, i1.NgIf, FormsModule, i2.NgControlStatus, i2.NgModel, DrInputsModule, i3.DrInputComponent, i4.DrButtonComponent, DrTooltipModule, i5.DrTooltipDirective], styles: ["[_nghost-%COMP%]{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;gap:4px}[_nghost-%COMP%] .table-header[_ngcontent-%COMP%]{display:flex;align-items:center;gap:4px;min-height:28px}[_nghost-%COMP%] .table-header__title[_ngcontent-%COMP%]{display:inline-block;text-overflow:ellipsis;overflow:hidden;vertical-align:middle}[_nghost-%COMP%] .table-header__tooltip[_ngcontent-%COMP%]{color:#6d6e6f;cursor:pointer}[_nghost-%COMP%] .table-header[_ngcontent-%COMP%] dr-button[_ngcontent-%COMP%]{display:none}[_nghost-%COMP%] dr-input[_ngcontent-%COMP%]{width:98%}[_nghost-%COMP%]:hover .table-header[_ngcontent-%COMP%] dr-button[_ngcontent-%COMP%], [_nghost-%COMP%] .table-header[_ngcontent-%COMP%] dr-button.sorted[_ngcontent-%COMP%]{display:inline-flex}"] }); }
|
|
161
|
+
}
|
|
162
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TblHeaderComponent, [{
|
|
163
|
+
type: Component,
|
|
164
|
+
args: [{ selector: 'dr-tbl-header', standalone: true, imports: [CommonModule, FormsModule, DrInputsModule, DrTooltipModule], template: "<div class=\"table-header\">\n <span class=\"table-header__title\" [title]=\"params.displayName\" data-testid=\"dr-tbl-header-title\">{{\n params.displayName\n }}</span>\n <i\n *ngIf=\"params?.infoTooltip\"\n data-testid=\"dr-tbl-header__tooltip-icon\"\n class=\"table-header__tooltip dr-icon-info\"\n [drTooltip]=\"params?.infoTooltip\"\n drTooltipPosition=\"top\"></i>\n <dr-button\n data-analytics=\"tables_tbl-header_button-0\"\n data-testid=\"dr-tbl-header__sort-button\"\n *ngIf=\"defs?.sortable\"\n [class.sorted]=\"!!sort\"\n [theme]=\"'icon'\"\n [icon]=\"sort === 'desc' ? 'dr-icon-sort' : 'dr-icon-sort-up'\"\n (click)=\"onSortChanged()\">\n </dr-button>\n</div>\n<dr-input\n *ngIf=\"defs?.headerComponentParams?.filterable\"\n data-analytics=\"tables_tbl-header_input-2\"\n [ngModel]=\"filterValue\"\n (ngModelChange)=\"onFilterChanged($event)\">\n</dr-input>\n", styles: [":host{width:100%;height:100%;display:flex;flex-direction:column;justify-content:center;gap:4px}:host .table-header{display:flex;align-items:center;gap:4px;min-height:28px}:host .table-header__title{display:inline-block;text-overflow:ellipsis;overflow:hidden;vertical-align:middle}:host .table-header__tooltip{color:#6d6e6f;cursor:pointer}:host .table-header dr-button{display:none}:host dr-input{width:98%}:host:hover .table-header dr-button,:host .table-header dr-button.sorted{display:inline-flex}\n"] }]
|
|
165
|
+
}], null, { hostDataTestId: [{
|
|
166
|
+
type: HostBinding,
|
|
167
|
+
args: ['attr.data-testid']
|
|
168
|
+
}] }); })();
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tbl-header.component.js","sourceRoot":"","sources":["../../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/cells/tbl-header/tbl-header.component.ts","../../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/cells/tbl-header/tbl-header.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, OnDestroy } from '@angular/core';\nimport {\n    GridApi,\n    GridColumnApi,\n    GridSortDirection,\n    IGridDrSortEvent,\n    IGridDrUpdateParamsEvent,\n    IGridHeaderAngularComponent,\n    IGridHeaderParams,\n} from '../../../models/interfaces';\nimport { takeUntil } from 'rxjs/operators';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { DrInputsModule } from '../../../../dr-inputs/dr-inputs.module';\nimport { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';\nimport { getSortTypeByColumnSorting } from '../../../services/grid-utils';\nimport { GridDrEventType } from '../../../models/dr-grid-events';\nimport { Subject } from 'rxjs';\n\n@Component({\n    selector: 'dr-tbl-header',\n    templateUrl: './tbl-header.component.html',\n    styleUrls: ['./tbl-header.component.scss'],\n    standalone: true,\n    imports: [CommonModule, FormsModule, DrInputsModule, DrTooltipModule],\n})\nexport class TblHeaderComponent implements IGridHeaderAngularComponent, OnDestroy {\n    @HostBinding('attr.data-testid') get hostDataTestId(): string {\n        return 'dr-tbl-header';\n    }\n    private readonly destroy$ = new Subject<void>();\n    params: any;\n    sort: GridSortDirection;\n    defs: any;\n    filterValue: any;\n    initSorted = true;\n    gridApi: GridApi;\n    gridColumnApi: GridColumnApi;\n\n    agInit(params: IGridHeaderParams): void {\n        this.gridApi = params.api;\n        this.gridColumnApi = params.columnApi;\n        this.params = params;\n        this.defs = params.column.getColDef();\n        setTimeout(() => {\n            if (this.gridApi?.drEvents) {\n                this.subscribeOnSort();\n                this.subscribeOnUpdateTableParams();\n            }\n        });\n\n        if (this.defs) {\n            this.filterValue = this.defs.filter;\n            this.sort = this.defs.sort;\n        }\n    }\n\n    refresh(): boolean {\n        return false;\n    }\n\n    onSortChanged(sort?: GridSortDirection) {\n        if (this.defs.sortable) {\n            const isFromOutside = typeof sort !== 'undefined';\n\n            if (isFromOutside) {\n                this.sort = sort;\n            } else {\n                this.sort = this.sort === 'asc' ? 'desc' : this.sort === 'desc' ? null : 'asc';\n            }\n\n            if (this.defs.sort) {\n                if (this.initSorted) {\n                    this.sort = this.defs.sort;\n                    this.initSorted = false;\n                }\n            }\n\n            this.gridColumnApi.applyColumnState({\n                state: [{ colId: this.defs.colId, sort: this.sort }],\n                defaultState: { sort: null },\n            });\n\n            if (!isFromOutside) {\n                this.gridApi.drEvents.emit({\n                    type: GridDrEventType.UPDATE_SORT,\n                    data: {\n                        sort: this.sort,\n                        header: this.params,\n                        colId: this.defs.colId,\n                    },\n                });\n            }\n        }\n    }\n\n    onFilterChanged(filterValue) {\n        this.gridApi.drEvents.filtersMap.set(this.defs.field, filterValue);\n        this.gridApi.drEvents.emit({ type: GridDrEventType.UPDATE_FILTER, data: this.gridApi.drEvents.filtersMap });\n    }\n\n    private subscribeOnSort() {\n        this.gridApi.drEvents\n            .on(GridDrEventType.UPDATE_SORT)\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((sort: IGridDrSortEvent) => {\n                if (sort.header.displayName !== this.params.displayName) {\n                    this.sort = null;\n                } else {\n                    this.sort = sort.sort;\n                }\n            });\n    }\n\n    private subscribeOnUpdateTableParams() {\n        this.gridApi.drEvents\n            .on(GridDrEventType.UPDATE_PARAMS)\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((tableParams: IGridDrUpdateParamsEvent) => {\n                const columnNameForSorting = tableParams?.ordering?.replace('-', '') || null;\n                const sorting = getSortTypeByColumnSorting(tableParams.ordering, columnNameForSorting);\n\n                if (columnNameForSorting === this.params.column?.colId || sorting === null) {\n                    this.onSortChanged(sorting);\n                } else if (tableParams.cleanOtherOrdering) {\n                    this.onSortChanged(null);\n                }\n\n                if (tableParams?.filtering?.has(this.params.column?.colId)) {\n                    this.filterValue = tableParams.filtering.get(this.params.column?.colId);\n                }\n            });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n}\n","<div class=\"table-header\">\n    <span class=\"table-header__title\" [title]=\"params.displayName\" data-testid=\"dr-tbl-header-title\">{{\n        params.displayName\n    }}</span>\n    <i\n        *ngIf=\"params?.infoTooltip\"\n        data-testid=\"dr-tbl-header__tooltip-icon\"\n        class=\"table-header__tooltip dr-icon-info\"\n        [drTooltip]=\"params?.infoTooltip\"\n        drTooltipPosition=\"top\"></i>\n    <dr-button\n        data-analytics=\"tables_tbl-header_button-0\"\n        data-testid=\"dr-tbl-header__sort-button\"\n        *ngIf=\"defs?.sortable\"\n        [class.sorted]=\"!!sort\"\n        [theme]=\"'icon'\"\n        [icon]=\"sort === 'desc' ? 'dr-icon-sort' : 'dr-icon-sort-up'\"\n        (click)=\"onSortChanged()\">\n    </dr-button>\n</div>\n<dr-input\n    *ngIf=\"defs?.headerComponentParams?.filterable\"\n    data-analytics=\"tables_tbl-header_input-2\"\n    [ngModel]=\"filterValue\"\n    (ngModelChange)=\"onFilterChanged($event)\">\n</dr-input>\n"]}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import * as _ from 'lodash';
|
|
5
|
+
import { AllCheckedPipe, IndeterminatePipe } from '../../../pipes/indeterminate/indeterminate.pipe';
|
|
6
|
+
import { DrInputsModule } from '../../../dr-inputs/dr-inputs.module';
|
|
7
|
+
import { DrPopoverRef } from '../../../models/popover';
|
|
8
|
+
import { FilterPipe } from '../../../pipes/filter/filter.pipe';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "../../../models/popover";
|
|
11
|
+
import * as i2 from "@angular/common";
|
|
12
|
+
import * as i3 from "@angular/forms";
|
|
13
|
+
import * as i4 from "../../../dr-inputs/checkbox/checkbox.component";
|
|
14
|
+
import * as i5 from "../../../dr-inputs/dr-input/dr-input.component";
|
|
15
|
+
import * as i6 from "../../../dr-inputs/button/button.component";
|
|
16
|
+
function DrGridColumnsFilterPopoverComponent_div_9_Template(rf, ctx) { if (rf & 1) {
|
|
17
|
+
const _r3 = i0.ɵɵgetCurrentView();
|
|
18
|
+
i0.ɵɵelementStart(0, "div", 9)(1, "dr-checkbox", 10);
|
|
19
|
+
i0.ɵɵlistener("checkedChange", function DrGridColumnsFilterPopoverComponent_div_9_Template_dr_checkbox_checkedChange_1_listener($event) { const restoredCtx = i0.ɵɵrestoreView(_r3); const column_r1 = restoredCtx.$implicit; return i0.ɵɵresetView(column_r1.hide = !$event); });
|
|
20
|
+
i0.ɵɵtext(2);
|
|
21
|
+
i0.ɵɵelementEnd()();
|
|
22
|
+
} if (rf & 2) {
|
|
23
|
+
const column_r1 = ctx.$implicit;
|
|
24
|
+
i0.ɵɵadvance(1);
|
|
25
|
+
i0.ɵɵproperty("checkedStatus", !column_r1.hide);
|
|
26
|
+
i0.ɵɵadvance(1);
|
|
27
|
+
i0.ɵɵtextInterpolate1(" ", column_r1.headerName, " ");
|
|
28
|
+
} }
|
|
29
|
+
export class DrGridColumnsFilterPopoverComponent {
|
|
30
|
+
constructor(popoverRef) {
|
|
31
|
+
this.popoverRef = popoverRef;
|
|
32
|
+
this.columnDefinitions = [];
|
|
33
|
+
}
|
|
34
|
+
ngOnInit() {
|
|
35
|
+
if (!this.columnDefinitions?.length) {
|
|
36
|
+
this.columnDefinitions = this.gridApi?.getColumnDefs();
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
applyColumnState() {
|
|
40
|
+
this.columnDefinitions = this.columnDefinitions.map((item) => _.omit(item, ['dd_field']));
|
|
41
|
+
this.gridColumnApi.applyColumnState({ state: this.columnDefinitions });
|
|
42
|
+
this.popoverRef.close({ columnDefinitions: this.columnDefinitions });
|
|
43
|
+
}
|
|
44
|
+
onSearch(column) {
|
|
45
|
+
if (!column.headerName) {
|
|
46
|
+
return false;
|
|
47
|
+
}
|
|
48
|
+
return this.searchInput ? column.headerName.toLowerCase().includes(this.searchInput.toLowerCase()) : true;
|
|
49
|
+
}
|
|
50
|
+
onAllCheck($event) {
|
|
51
|
+
this.columnDefinitions.forEach((column) => (column.hide = !$event));
|
|
52
|
+
}
|
|
53
|
+
/** @nocollapse */ static { this.ɵfac = function DrGridColumnsFilterPopoverComponent_Factory(t) { return new (t || DrGridColumnsFilterPopoverComponent)(i0.ɵɵdirectiveInject(i1.DrPopoverRef)); }; }
|
|
54
|
+
/** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: DrGridColumnsFilterPopoverComponent, selectors: [["dr-grid-columns-filter-popover"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 14, vars: 13, consts: [["data-test", "filter_menu", 1, "columns-filter"], ["data-test", "filterName", 1, "columns-filter__header"], [1, "columns-filter__search-bar"], ["data-analytics", "tables_columns-filter-popover_checkbox-0", "data-test", "header_checkbox", 3, "checkedStatus", "indeterminate", "checkedChange"], ["data-analytics", "tables_columns-filter-popover_input-1", "data-test", "input_field", "placeholder", "Search", 3, "ngModel", "ngModelChange"], ["data-test", "filter_list", 1, "columns-filter__list"], ["class", "columns-filter__item", 4, "ngFor", "ngForOf"], [1, "columns-filter__footer"], ["data-analytics", "tables_columns-filter-popover_button-3", "data-test", "save_button", 1, "ml-auto", 3, "click"], [1, "columns-filter__item"], ["data-analytics", "tables_columns-filter-popover_checkbox-2", "data-test", "filter_checkbox", 3, "checkedStatus", "checkedChange"]], template: function DrGridColumnsFilterPopoverComponent_Template(rf, ctx) { if (rf & 1) {
|
|
55
|
+
i0.ɵɵelementStart(0, "div", 0)(1, "div", 1);
|
|
56
|
+
i0.ɵɵtext(2, "Columns Filter");
|
|
57
|
+
i0.ɵɵelementEnd();
|
|
58
|
+
i0.ɵɵelementStart(3, "div", 2)(4, "dr-checkbox", 3);
|
|
59
|
+
i0.ɵɵlistener("checkedChange", function DrGridColumnsFilterPopoverComponent_Template_dr_checkbox_checkedChange_4_listener($event) { return ctx.onAllCheck($event); });
|
|
60
|
+
i0.ɵɵpipe(5, "allChecked");
|
|
61
|
+
i0.ɵɵpipe(6, "indeterminate");
|
|
62
|
+
i0.ɵɵelementEnd();
|
|
63
|
+
i0.ɵɵelementStart(7, "dr-input", 4);
|
|
64
|
+
i0.ɵɵlistener("ngModelChange", function DrGridColumnsFilterPopoverComponent_Template_dr_input_ngModelChange_7_listener($event) { return ctx.searchInput = $event; });
|
|
65
|
+
i0.ɵɵelementEnd()();
|
|
66
|
+
i0.ɵɵelementStart(8, "div", 5);
|
|
67
|
+
i0.ɵɵtemplate(9, DrGridColumnsFilterPopoverComponent_div_9_Template, 3, 2, "div", 6);
|
|
68
|
+
i0.ɵɵpipe(10, "filter");
|
|
69
|
+
i0.ɵɵelementEnd();
|
|
70
|
+
i0.ɵɵelementStart(11, "div", 7)(12, "dr-button", 8);
|
|
71
|
+
i0.ɵɵlistener("click", function DrGridColumnsFilterPopoverComponent_Template_dr_button_click_12_listener() { return ctx.applyColumnState(); });
|
|
72
|
+
i0.ɵɵtext(13, "Save");
|
|
73
|
+
i0.ɵɵelementEnd()()();
|
|
74
|
+
} if (rf & 2) {
|
|
75
|
+
i0.ɵɵadvance(4);
|
|
76
|
+
i0.ɵɵproperty("checkedStatus", !i0.ɵɵpipeBind2(5, 4, ctx.columnDefinitions, "hide"))("indeterminate", i0.ɵɵpipeBind2(6, 7, ctx.columnDefinitions, "hide"));
|
|
77
|
+
i0.ɵɵadvance(3);
|
|
78
|
+
i0.ɵɵproperty("ngModel", ctx.searchInput);
|
|
79
|
+
i0.ɵɵadvance(2);
|
|
80
|
+
i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind2(10, 10, ctx.columnDefinitions, ctx.onSearch.bind(ctx)));
|
|
81
|
+
} }, dependencies: [CommonModule, i2.NgForOf, FormsModule, i3.NgControlStatus, i3.NgModel, DrInputsModule, i4.CheckboxComponent, i5.DrInputComponent, i6.DrButtonComponent, FilterPipe, AllCheckedPipe, IndeterminatePipe], styles: [".columns-filter[_ngcontent-%COMP%]{min-width:350px;font-size:14px}.columns-filter__header[_ngcontent-%COMP%]{padding:16px 32px;border-bottom:1px solid #ccc;white-space:nowrap;font-weight:600}.columns-filter__search-bar[_ngcontent-%COMP%]{display:flex;align-items:center;border-bottom:1px solid #dfe0e3;padding:5px 32px}.columns-filter__list[_ngcontent-%COMP%]{height:160px;overflow:auto;padding:0 32px}.columns-filter__item[_ngcontent-%COMP%]{padding-top:1rem}.columns-filter__item[_ngcontent-%COMP%]:last-child{padding-bottom:1rem}.columns-filter__footer[_ngcontent-%COMP%]{display:flex;border-top:1px solid #dfe0e3;padding:8px 32px}"], changeDetection: 0 }); }
|
|
82
|
+
}
|
|
83
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DrGridColumnsFilterPopoverComponent, [{
|
|
84
|
+
type: Component,
|
|
85
|
+
args: [{ selector: 'dr-grid-columns-filter-popover', standalone: true, imports: [CommonModule, FormsModule, DrInputsModule, FilterPipe, AllCheckedPipe, IndeterminatePipe], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div data-test=\"filter_menu\" class=\"columns-filter\">\n <div data-test=\"filterName\" class=\"columns-filter__header\">Columns Filter</div>\n <div class=\"columns-filter__search-bar\">\n <dr-checkbox\n data-analytics=\"tables_columns-filter-popover_checkbox-0\"\n data-test=\"header_checkbox\"\n (checkedChange)=\"onAllCheck($event)\"\n [checkedStatus]=\"!(columnDefinitions | allChecked: 'hide')\"\n [indeterminate]=\"columnDefinitions | indeterminate: 'hide'\">\n </dr-checkbox>\n <dr-input\n data-analytics=\"tables_columns-filter-popover_input-1\"\n data-test=\"input_field\"\n [(ngModel)]=\"searchInput\"\n placeholder=\"Search\"></dr-input>\n </div>\n <div data-test=\"filter_list\" class=\"columns-filter__list\">\n <div *ngFor=\"let column of columnDefinitions | filter: onSearch.bind(this)\" class=\"columns-filter__item\">\n <dr-checkbox\n data-analytics=\"tables_columns-filter-popover_checkbox-2\"\n data-test=\"filter_checkbox\"\n (checkedChange)=\"column.hide = !$event\"\n [checkedStatus]=\"!column.hide\">\n {{ column.headerName }}\n </dr-checkbox>\n </div>\n </div>\n <div class=\"columns-filter__footer\">\n <dr-button\n data-analytics=\"tables_columns-filter-popover_button-3\"\n data-test=\"save_button\"\n class=\"ml-auto\"\n (click)=\"applyColumnState()\"\n >Save</dr-button\n >\n </div>\n</div>\n", styles: [".columns-filter{min-width:350px;font-size:14px}.columns-filter__header{padding:16px 32px;border-bottom:1px solid #ccc;white-space:nowrap;font-weight:600}.columns-filter__search-bar{display:flex;align-items:center;border-bottom:1px solid #dfe0e3;padding:5px 32px}.columns-filter__list{height:160px;overflow:auto;padding:0 32px}.columns-filter__item{padding-top:1rem}.columns-filter__item:last-child{padding-bottom:1rem}.columns-filter__footer{display:flex;border-top:1px solid #dfe0e3;padding:8px 32px}\n"] }]
|
|
86
|
+
}], function () { return [{ type: i1.DrPopoverRef }]; }, null); })();
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-grid-columns-filter-popover.component.js","sourceRoot":"","sources":["../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.ts","../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport * as _ from 'lodash';\nimport { GridApi, GridColumnApi, IGridColDef, IGridColumnState } from '../../models/interfaces';\nimport { AllCheckedPipe, IndeterminatePipe } from '../../../pipes/indeterminate/indeterminate.pipe';\nimport { DrInputsModule } from '../../../dr-inputs/dr-inputs.module';\nimport { DrPopoverRef } from '../../../models/popover';\nimport { FilterPipe } from '../../../pipes/filter/filter.pipe';\n\n@Component({\n    selector: 'dr-grid-columns-filter-popover',\n    templateUrl: './dr-grid-columns-filter-popover.component.html',\n    styleUrls: ['./dr-grid-columns-filter-popover.component.scss'],\n    standalone: true,\n    imports: [CommonModule, FormsModule, DrInputsModule, FilterPipe, AllCheckedPipe, IndeterminatePipe],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrGridColumnsFilterPopoverComponent implements OnInit {\n    columnDefinitions: IGridColDef[] = [];\n    searchInput: string;\n    gridApi: GridApi;\n    gridColumnApi: GridColumnApi;\n\n    constructor(private popoverRef: DrPopoverRef<DrGridColumnsFilterPopoverComponent>) {}\n\n    ngOnInit(): void {\n        if (!this.columnDefinitions?.length) {\n            this.columnDefinitions = this.gridApi?.getColumnDefs();\n        }\n    }\n\n    applyColumnState(): void {\n        this.columnDefinitions = this.columnDefinitions.map((item) => _.omit(item, ['dd_field']));\n        this.gridColumnApi.applyColumnState({ state: this.columnDefinitions as IGridColumnState[] });\n        this.popoverRef.close({ columnDefinitions: this.columnDefinitions });\n    }\n\n    onSearch(column: IGridColDef): boolean {\n        if (!column.headerName) {\n            return false;\n        }\n        return this.searchInput ? column.headerName.toLowerCase().includes(this.searchInput.toLowerCase()) : true;\n    }\n\n    onAllCheck($event: boolean): void {\n        this.columnDefinitions.forEach((column) => (column.hide = !$event));\n    }\n}\n","<div data-test=\"filter_menu\" class=\"columns-filter\">\n    <div data-test=\"filterName\" class=\"columns-filter__header\">Columns Filter</div>\n    <div class=\"columns-filter__search-bar\">\n        <dr-checkbox\n            data-analytics=\"tables_columns-filter-popover_checkbox-0\"\n            data-test=\"header_checkbox\"\n            (checkedChange)=\"onAllCheck($event)\"\n            [checkedStatus]=\"!(columnDefinitions | allChecked: 'hide')\"\n            [indeterminate]=\"columnDefinitions | indeterminate: 'hide'\">\n        </dr-checkbox>\n        <dr-input\n            data-analytics=\"tables_columns-filter-popover_input-1\"\n            data-test=\"input_field\"\n            [(ngModel)]=\"searchInput\"\n            placeholder=\"Search\"></dr-input>\n    </div>\n    <div data-test=\"filter_list\" class=\"columns-filter__list\">\n        <div *ngFor=\"let column of columnDefinitions | filter: onSearch.bind(this)\" class=\"columns-filter__item\">\n            <dr-checkbox\n                data-analytics=\"tables_columns-filter-popover_checkbox-2\"\n                data-test=\"filter_checkbox\"\n                (checkedChange)=\"column.hide = !$event\"\n                [checkedStatus]=\"!column.hide\">\n                {{ column.headerName }}\n            </dr-checkbox>\n        </div>\n    </div>\n    <div class=\"columns-filter__footer\">\n        <dr-button\n            data-analytics=\"tables_columns-filter-popover_button-3\"\n            data-test=\"save_button\"\n            class=\"ml-auto\"\n            (click)=\"applyColumnState()\"\n            >Save</dr-button\n        >\n    </div>\n</div>\n"]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export class DrGridNoRowsComponent {
|
|
2
|
+
init(params) {
|
|
3
|
+
this.eGui = document.createElement('div');
|
|
4
|
+
params.content.forEach((node) => this.eGui.appendChild(node));
|
|
5
|
+
}
|
|
6
|
+
getGui() {
|
|
7
|
+
return this.eGui;
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHItZ3JpZC1uby1yb3dzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWdyaWQvY29tcG9uZW50cy9kci1ncmlkLW5vLXJvd3MvZHItZ3JpZC1uby1yb3dzLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8scUJBQXFCO0lBRzlCLElBQUksQ0FBQyxNQUFnQztRQUNqQyxJQUFJLENBQUMsSUFBSSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDMUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQyxJQUFTLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDdkUsQ0FBQztJQUVELE1BQU07UUFDRixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDckIsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSUdyaWROb1Jvd3NPdmVybGF5Q29tcCwgSUdyaWROb1Jvd3NPdmVybGF5UGFyYW1zIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2ludGVyZmFjZXMnO1xuXG5leHBvcnQgY2xhc3MgRHJHcmlkTm9Sb3dzQ29tcG9uZW50IGltcGxlbWVudHMgSUdyaWROb1Jvd3NPdmVybGF5Q29tcCB7XG4gICAgcHJpdmF0ZSBlR3VpITogSFRNTEVsZW1lbnQ7XG5cbiAgICBpbml0KHBhcmFtczogSUdyaWROb1Jvd3NPdmVybGF5UGFyYW1zKTogdm9pZCB7XG4gICAgICAgIHRoaXMuZUd1aSA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ2RpdicpO1xuICAgICAgICBwYXJhbXMuY29udGVudC5mb3JFYWNoKChub2RlOiBhbnkpID0+IHRoaXMuZUd1aS5hcHBlbmRDaGlsZChub2RlKSk7XG4gICAgfVxuXG4gICAgZ2V0R3VpKCk6IEhUTUxFbGVtZW50IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZUd1aTtcbiAgICB9XG59XG4iXX0=
|