@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.
Files changed (67) hide show
  1. package/assets/styles/_storybook-styles.scss +3 -0
  2. package/assets/styles/_styles.scss +3 -0
  3. package/datarailsshared-datarailsshared-1.6.238.tgz +0 -0
  4. package/esm2022/lib/decorators/decorators.mjs +26 -0
  5. package/esm2022/lib/dr-grid/components/cells/cell-action/cell-action.component.mjs +95 -0
  6. package/esm2022/lib/dr-grid/components/cells/cell-badge-status/cell-badge-status.component.mjs +49 -0
  7. package/esm2022/lib/dr-grid/components/cells/cell-button/cell-button.component.mjs +38 -0
  8. package/esm2022/lib/dr-grid/components/cells/cell-checkbox/cell-checkbox.component.mjs +50 -0
  9. package/esm2022/lib/dr-grid/components/cells/cell-children-list/cell-children-list.component.mjs +141 -0
  10. package/esm2022/lib/dr-grid/components/cells/cell-custom-template/cell-custom-template.component.mjs +28 -0
  11. package/esm2022/lib/dr-grid/components/cells/cell-icon-actions/cell-icon-actions.component.mjs +101 -0
  12. package/esm2022/lib/dr-grid/components/cells/cell-icon-text-edit/cell-icon-text-edit.component.mjs +130 -0
  13. package/esm2022/lib/dr-grid/components/cells/cell-link/cell-link.component.mjs +94 -0
  14. package/esm2022/lib/dr-grid/components/cells/cell-select/cell-select.component.mjs +45 -0
  15. package/esm2022/lib/dr-grid/components/cells/cell-set-as-default/cell-set-as-default.component.mjs +48 -0
  16. package/esm2022/lib/dr-grid/components/cells/cell-split-rows/cell-split-rows.component.mjs +99 -0
  17. package/esm2022/lib/dr-grid/components/cells/cell-toggle/cell-toggle.component.mjs +38 -0
  18. package/esm2022/lib/dr-grid/components/cells/tbl-header/tbl-header.component.mjs +169 -0
  19. package/esm2022/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.mjs +87 -0
  20. package/esm2022/lib/dr-grid/components/dr-grid-no-rows/dr-grid-no-rows.component.mjs +10 -0
  21. package/esm2022/lib/dr-grid/components/dr-grid-pagination/dr-grid-pagination.component.mjs +150 -0
  22. package/esm2022/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.mjs +194 -0
  23. package/esm2022/lib/dr-grid/components/tbl-toggle-button-header/tbl-toggle-button-header.component.mjs +46 -0
  24. package/esm2022/lib/dr-grid/dr-grid.component.mjs +364 -0
  25. package/esm2022/lib/dr-grid/dr-grid.mjs +26 -0
  26. package/esm2022/lib/dr-grid/models/dr-grid-events.mjs +9 -0
  27. package/esm2022/lib/dr-grid/models/dr-grid-theme.mjs +27 -0
  28. package/esm2022/lib/dr-grid/models/interfaces.mjs +6 -0
  29. package/esm2022/lib/dr-grid/services/abstract-single-grid.mjs +136 -0
  30. package/esm2022/lib/dr-grid/services/grid-utils.mjs +53 -0
  31. package/esm2022/lib/emoji-picker/emoji-picker.component.mjs +2 -2
  32. package/esm2022/lib/pipes/indeterminate/indeterminate.pipe.mjs +38 -0
  33. package/esm2022/local-api.mjs +6 -2
  34. package/fesm2022/datarailsshared-datarailsshared.mjs +2335 -265
  35. package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
  36. package/lib/decorators/decorators.d.ts +2 -0
  37. package/lib/dr-grid/components/cells/cell-action/cell-action.component.d.ts +37 -0
  38. package/lib/dr-grid/components/cells/cell-badge-status/cell-badge-status.component.d.ts +22 -0
  39. package/lib/dr-grid/components/cells/cell-button/cell-button.component.d.ts +19 -0
  40. package/lib/dr-grid/components/cells/cell-checkbox/cell-checkbox.component.d.ts +24 -0
  41. package/lib/dr-grid/components/cells/cell-children-list/cell-children-list.component.d.ts +21 -0
  42. package/lib/dr-grid/components/cells/cell-custom-template/cell-custom-template.component.d.ts +23 -0
  43. package/lib/dr-grid/components/cells/cell-icon-actions/cell-icon-actions.component.d.ts +35 -0
  44. package/lib/dr-grid/components/cells/cell-icon-text-edit/cell-icon-text-edit.component.d.ts +34 -0
  45. package/lib/dr-grid/components/cells/cell-link/cell-link.component.d.ts +33 -0
  46. package/lib/dr-grid/components/cells/cell-select/cell-select.component.d.ts +22 -0
  47. package/lib/dr-grid/components/cells/cell-set-as-default/cell-set-as-default.component.d.ts +16 -0
  48. package/lib/dr-grid/components/cells/cell-split-rows/cell-split-rows.component.d.ts +19 -0
  49. package/lib/dr-grid/components/cells/cell-toggle/cell-toggle.component.d.ts +15 -0
  50. package/lib/dr-grid/components/cells/tbl-header/tbl-header.component.d.ts +23 -0
  51. package/lib/dr-grid/components/dr-grid-columns-filter-popover/dr-grid-columns-filter-popover.component.d.ts +18 -0
  52. package/lib/dr-grid/components/dr-grid-no-rows/dr-grid-no-rows.component.d.ts +6 -0
  53. package/lib/dr-grid/components/dr-grid-pagination/dr-grid-pagination.component.d.ts +25 -0
  54. package/lib/dr-grid/components/dr-grid-toolbar/dr-grid-toolbar.component.d.ts +37 -0
  55. package/lib/dr-grid/components/tbl-toggle-button-header/tbl-toggle-button-header.component.d.ts +31 -0
  56. package/lib/dr-grid/dr-grid.component.d.ts +86 -0
  57. package/lib/dr-grid/dr-grid.d.ts +25 -0
  58. package/lib/dr-grid/models/dr-grid-events.d.ts +7 -0
  59. package/lib/dr-grid/models/dr-grid-theme.d.ts +3 -0
  60. package/lib/dr-grid/models/interfaces.d.ts +125 -0
  61. package/lib/dr-grid/services/abstract-single-grid.d.ts +37 -0
  62. package/lib/dr-grid/services/grid-utils.d.ts +11 -0
  63. package/lib/pipes/indeterminate/indeterminate.pipe.d.ts +12 -0
  64. package/local-api.d.ts +4 -1
  65. package/package.json +4 -2
  66. package/styles.css +7995 -0
  67. 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=