@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,101 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { DrDropdownModule } from '../../../../dr-dropdown/dr-dropdown.module';
4
+ import { DrInputsModule } from '../../../../dr-inputs/dr-inputs.module';
5
+ import { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/common";
8
+ import * as i2 from "../../../../dr-inputs/button/button.component";
9
+ import * as i3 from "../../../../dr-tooltip/dr-tooltip.directive";
10
+ import * as i4 from "../../../../dr-dropdown/dr-dropdown.directive";
11
+ function CellIconActionsComponent_div_1_span_1_ng_container_1_Template(rf, ctx) { if (rf & 1) {
12
+ i0.ɵɵelementContainer(0);
13
+ } }
14
+ const _c0 = function (a0) { return { $implicit: a0 }; };
15
+ function CellIconActionsComponent_div_1_span_1_Template(rf, ctx) { if (rf & 1) {
16
+ i0.ɵɵelementStart(0, "span", 6);
17
+ i0.ɵɵtemplate(1, CellIconActionsComponent_div_1_span_1_ng_container_1_Template, 1, 0, "ng-container", 7);
18
+ i0.ɵɵelementEnd();
19
+ } if (rf & 2) {
20
+ const icon_r5 = i0.ɵɵnextContext().$implicit;
21
+ const ctx_r8 = i0.ɵɵnextContext();
22
+ const _r3 = i0.ɵɵreference(5);
23
+ const _r1 = i0.ɵɵreference(3);
24
+ i0.ɵɵstyleProp("background-color", icon_r5.badgeColor);
25
+ i0.ɵɵclassProp("badge", icon_r5.badgeColor);
26
+ i0.ɵɵproperty("drTooltipMouseEnterTimeout", 100)("drTooltip", icon_r5.customTooltip ? icon_r5.customTooltip(ctx_r8.field, ctx_r8.rowIndex, ctx_r8.rowData) : icon_r5.tooltip);
27
+ i0.ɵɵadvance(1);
28
+ i0.ɵɵproperty("ngTemplateOutlet", icon_r5.isSimpleIcon ? _r3 : _r1)("ngTemplateOutletContext", i0.ɵɵpureFunction1(8, _c0, icon_r5));
29
+ } }
30
+ function CellIconActionsComponent_div_1_Template(rf, ctx) { if (rf & 1) {
31
+ i0.ɵɵelementStart(0, "div", 4);
32
+ i0.ɵɵtemplate(1, CellIconActionsComponent_div_1_span_1_Template, 2, 10, "span", 5);
33
+ i0.ɵɵelementEnd();
34
+ } if (rf & 2) {
35
+ const icon_r5 = ctx.$implicit;
36
+ const odd_r6 = ctx.odd;
37
+ const first_r7 = ctx.first;
38
+ const ctx_r0 = i0.ɵɵnextContext();
39
+ i0.ɵɵstyleProp("margin-right", odd_r6 && ctx_r0.marginForEvenIcon)("margin-left", odd_r6 && !first_r7 && ctx_r0.marginForEvenIcon);
40
+ i0.ɵɵclassProp("hide-delimer", ctx_r0.hideIconDelimer);
41
+ i0.ɵɵadvance(1);
42
+ i0.ɵɵproperty("ngIf", !icon_r5.hidden && icon_r5.show ? icon_r5.show(ctx_r0.field) : true);
43
+ } }
44
+ function CellIconActionsComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) {
45
+ const _r13 = i0.ɵɵgetCurrentView();
46
+ i0.ɵɵelementStart(0, "dr-button", 8);
47
+ i0.ɵɵlistener("click", function CellIconActionsComponent_ng_template_2_Template_dr_button_click_0_listener() { const restoredCtx = i0.ɵɵrestoreView(_r13); const icon_r11 = restoredCtx.$implicit; const ctx_r12 = i0.ɵɵnextContext(); return i0.ɵɵresetView(icon_r11.action && icon_r11.action(ctx_r12.field, ctx_r12.rowIndex, ctx_r12.rowData)); });
48
+ i0.ɵɵelementEnd();
49
+ } if (rf & 2) {
50
+ const icon_r11 = ctx.$implicit;
51
+ const ctx_r2 = i0.ɵɵnextContext();
52
+ i0.ɵɵproperty("icon", icon_r11.dynamicClass ? icon_r11.dynamicClass(ctx_r2.field, ctx_r2.rowIndex, ctx_r2.rowData) : icon_r11.class)("iconSize", icon_r11.size)("iconColor", icon_r11.colorFn ? icon_r11.colorFn(ctx_r2.field) : icon_r11.color)("disabled", ctx_r2.isIconDisabled(icon_r11))("drDropdown", icon_r11.dropdownActions);
53
+ } }
54
+ function CellIconActionsComponent_ng_template_4_Template(rf, ctx) { if (rf & 1) {
55
+ i0.ɵɵelement(0, "span");
56
+ } if (rf & 2) {
57
+ const icon_r14 = ctx.$implicit;
58
+ i0.ɵɵclassMap(icon_r14.class);
59
+ i0.ɵɵstyleProp("color", icon_r14.color)("font-size", icon_r14.size);
60
+ } }
61
+ export class CellIconActionsComponent {
62
+ agInit(params) {
63
+ this.containerMargin = params.containerMargin;
64
+ this.bindValue = params.bindValue;
65
+ this.pinRight = params.pinRight;
66
+ if (params.bindValue && params.data?.[this.bindValue]) {
67
+ this.field = params.data[this.bindValue];
68
+ }
69
+ else {
70
+ this.field = params.data;
71
+ }
72
+ this.rowData = params.data;
73
+ this.icons = params.icons;
74
+ this.rowIndex = params.rowIndex;
75
+ this.hideIconDelimer = params.hideIconDelimer;
76
+ this.marginForEvenIcon = params.marginForEvenIcon;
77
+ }
78
+ refresh() {
79
+ return true;
80
+ }
81
+ isIconDisabled(icon) {
82
+ return icon.disabled instanceof Function ? icon.disabled(this.field, this.rowIndex, this.rowData) : icon.disabled;
83
+ }
84
+ /** @nocollapse */ static { this.ɵfac = function CellIconActionsComponent_Factory(t) { return new (t || CellIconActionsComponent)(); }; }
85
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: CellIconActionsComponent, selectors: [["dr-cell-icon-actions"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 6, vars: 5, consts: [[1, "action-icons"], ["class", "action-icons__item-container action-item", 3, "hide-delimer", "margin-right", "margin-left", 4, "ngFor", "ngForOf"], ["buttonIconRef", ""], ["simpleIconRef", ""], [1, "action-icons__item-container", "action-item"], ["class", "action-item__wrapper", 3, "badge", "background-color", "drTooltipMouseEnterTimeout", "drTooltip", 4, "ngIf"], [1, "action-item__wrapper", 3, "drTooltipMouseEnterTimeout", "drTooltip"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], ["data-analytics", "tables_cells_cell-icon-actions_button-0", "theme", "icon", "drDropdownPosition", "bottom", 1, "action-item__button", 3, "icon", "iconSize", "iconColor", "disabled", "drDropdown", "click"]], template: function CellIconActionsComponent_Template(rf, ctx) { if (rf & 1) {
86
+ i0.ɵɵelementStart(0, "div", 0);
87
+ i0.ɵɵtemplate(1, CellIconActionsComponent_div_1_Template, 2, 7, "div", 1);
88
+ i0.ɵɵelementEnd();
89
+ i0.ɵɵtemplate(2, CellIconActionsComponent_ng_template_2_Template, 1, 5, "ng-template", null, 2, i0.ɵɵtemplateRefExtractor);
90
+ i0.ɵɵtemplate(4, CellIconActionsComponent_ng_template_4_Template, 1, 6, "ng-template", null, 3, i0.ɵɵtemplateRefExtractor);
91
+ } if (rf & 2) {
92
+ i0.ɵɵstyleProp("margin", ctx.containerMargin)("justify-content", ctx.pinRight && "flex-end");
93
+ i0.ɵɵadvance(1);
94
+ i0.ɵɵproperty("ngForOf", ctx.icons);
95
+ } }, dependencies: [CommonModule, i1.NgForOf, i1.NgIf, i1.NgTemplateOutlet, DrInputsModule, i2.DrButtonComponent, DrTooltipModule, i3.DrTooltipDirective, DrDropdownModule, i4.DrDropdownDirective], styles: [".action-icons[_ngcontent-%COMP%]{display:flex;align-items:center;height:100%}.action-item[_ngcontent-%COMP%]{display:flex}.action-item[_ngcontent-%COMP%]:nth-child(2n) > .action-item__button[_ngcontent-%COMP%]{margin-left:3px}.action-item[_ngcontent-%COMP%]:nth-child(odd) > .action-item__button[_ngcontent-%COMP%]{margin-right:3px}.action-item__wrapper[_ngcontent-%COMP%]{display:inline-flex}.action-item__wrapper.badge[_ngcontent-%COMP%]{padding:8px;border-radius:4px}.hide-delimer.action-item[_ngcontent-%COMP%]:nth-child(2n):before{content:none}[_nghost-%COMP%] .action-item__wrapper.badge>dr-button>button:hover{background:none;border:none}"], changeDetection: 0 }); }
96
+ }
97
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CellIconActionsComponent, [{
98
+ type: Component,
99
+ args: [{ selector: 'dr-cell-icon-actions', standalone: true, imports: [CommonModule, DrInputsModule, DrTooltipModule, DrDropdownModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"action-icons\" [style.margin]=\"containerMargin\" [style.justify-content]=\"pinRight && 'flex-end'\">\n <div\n *ngFor=\"let icon of icons; let odd = odd; let first = first\"\n class=\"action-icons__item-container action-item\"\n [class.hide-delimer]=\"hideIconDelimer\"\n [style.margin-right]=\"odd && marginForEvenIcon\"\n [style.margin-left]=\"odd && !first && marginForEvenIcon\">\n <span\n *ngIf=\"!icon.hidden && icon.show ? icon.show(field) : true\"\n class=\"action-item__wrapper\"\n [class.badge]=\"icon.badgeColor\"\n [style.background-color]=\"icon.badgeColor\"\n [drTooltipMouseEnterTimeout]=\"100\"\n [drTooltip]=\"icon.customTooltip ? icon.customTooltip(field, rowIndex, rowData) : icon.tooltip\">\n <ng-container\n *ngTemplateOutlet=\"\n icon.isSimpleIcon ? simpleIconRef : buttonIconRef;\n context: { $implicit: icon }\n \"></ng-container>\n </span>\n </div>\n</div>\n\n<ng-template #buttonIconRef let-icon>\n <dr-button\n data-analytics=\"tables_cells_cell-icon-actions_button-0\"\n class=\"action-item__button\"\n theme=\"icon\"\n [icon]=\"icon.dynamicClass ? icon.dynamicClass(field, rowIndex, rowData) : icon.class\"\n [iconSize]=\"icon.size\"\n [iconColor]=\"icon.colorFn ? icon.colorFn(field) : icon.color\"\n [disabled]=\"isIconDisabled(icon)\"\n (click)=\"icon.action && icon.action(field, rowIndex, rowData)\"\n [drDropdown]=\"icon.dropdownActions\"\n drDropdownPosition=\"bottom\"></dr-button>\n</ng-template>\n\n<ng-template #simpleIconRef let-icon>\n <span [class]=\"icon.class\" [style.color]=\"icon.color\" [style.font-size]=\"icon.size\"></span>\n</ng-template>\n", styles: [".action-icons{display:flex;align-items:center;height:100%}.action-item{display:flex}.action-item:nth-child(2n)>.action-item__button{margin-left:3px}.action-item:nth-child(odd)>.action-item__button{margin-right:3px}.action-item__wrapper{display:inline-flex}.action-item__wrapper.badge{padding:8px;border-radius:4px}.hide-delimer.action-item:nth-child(2n):before{content:none}:host::ng-deep .action-item__wrapper.badge>dr-button>button:hover{background:none;border:none}\n"] }]
100
+ }], null, null); })();
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-icon-actions.component.js","sourceRoot":"","sources":["../../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/cells/cell-icon-actions/cell-icon-actions.component.ts","../../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/cells/cell-icon-actions/cell-icon-actions.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,4CAA4C,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,wCAAwC,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;;;;;;;ICS/D,wBAIqB;;;;IAXzB,+BAMmG;IAC/F,wGAIqB;IACzB,iBAAO;;;;;;IARH,sDAA0C;IAD1C,2CAA+B;IAE/B,gDAAkC,6HAAA;IAG7B,eAEwB;IAFxB,mEAEwB,gEAAA;;;IAhBrC,8BAK6D;IACzD,kFAYO;IACX,iBAAM;;;;;;IAfF,kEAA+C,gEAAA;IAD/C,sDAAsC;IAIjC,eAAyD;IAAzD,0FAAyD;;;;IAgBlE,oCAUgC;IAF5B,8OAAS,kCAAe,iEAAqC,CAAA,IAAC;IAElC,iBAAY;;;;IANxC,oIAAqF,2BAAA,iFAAA,6CAAA,wCAAA;;;IAUzF,uBAA2F;;;IAArF,6BAAoB;IAAC,uCAA0B,4BAAA;;ADLzD,MAAM,OAAO,wBAAwB;IAWjC,MAAM,CAAC,MAAM;QACT,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,eAAe,CAAC;QAC9C,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;QAClC,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAEhC,IAAI,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;YACnD,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAC5C;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC;SAC5B;QAED,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC;QAE3B,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QAChC,IAAI,CAAC,eAAe,GAAG,MAAM,CAAC,eAAe,CAAC;QAC9C,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC;IACtD,CAAC;IAED,OAAO;QACH,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,cAAc,CAAC,IAAyB;QACpC,OAAO,IAAI,CAAC,QAAQ,YAAY,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;IACtH,CAAC;4GApCQ,wBAAwB;mGAAxB,wBAAwB;YCjCrC,8BAA4G;YACxG,yEAmBM;YACV,iBAAM;YAEN,0HAYc;YAEd,0HAEc;;YAvCY,6CAAgC,+CAAA;YAEjC,eAAU;YAAV,mCAAU;4BD4BrB,YAAY,4CAAE,cAAc,wBAAE,eAAe,yBAAE,gBAAgB;;uFAGhE,wBAAwB;cARpC,SAAS;2BACI,sBAAsB,cAGpB,IAAI,WACP,CAAC,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,gBAAgB,CAAC,mBACzD,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { IGridCellRendererComponent } from '../../../models/interfaces';\nimport { DrDropdownModule } from '../../../../dr-dropdown/dr-dropdown.module';\nimport { DrInputsModule } from '../../../../dr-inputs/dr-inputs.module';\nimport { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';\nimport { IDropdownItem } from '../../../../models/dropdown';\n\nexport interface IGridCellIconAction {\n    class: string;\n    dynamicClass?: (field?: any, rowIndex?: number, rowData?: any) => string;\n    action?: (field?: any, rowIndex?: number, rowData?: any) => any;\n    hidden?: boolean;\n    show?: (field?: any) => boolean;\n    size?: string;\n    color?: string;\n    colorFn?: (field?: any) => string;\n    tooltip?: string;\n    disabled?: (field?: any, rowIndex?: number, rowData?: any) => boolean;\n    customTooltip?: (field?: any, rowIndex?: number, rowData?: any) => string;\n    isSimpleIcon?: boolean;\n    badgeColor?: string;\n    dropdownActions?: IDropdownItem<any>[];\n}\n\n@Component({\n    selector: 'dr-cell-icon-actions',\n    templateUrl: './cell-icon-actions.component.html',\n    styleUrls: ['./cell-icon-actions.component.scss'],\n    standalone: true,\n    imports: [CommonModule, DrInputsModule, DrTooltipModule, DrDropdownModule],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CellIconActionsComponent implements IGridCellRendererComponent {\n    icons: IGridCellIconAction[];\n    field: any;\n    rowIndex: number;\n    hideIconDelimer: boolean;\n    marginForEvenIcon: string;\n    bindValue: string;\n    pinRight: boolean;\n    containerMargin: string;\n    rowData: any;\n\n    agInit(params): void {\n        this.containerMargin = params.containerMargin;\n        this.bindValue = params.bindValue;\n        this.pinRight = params.pinRight;\n\n        if (params.bindValue && params.data?.[this.bindValue]) {\n            this.field = params.data[this.bindValue];\n        } else {\n            this.field = params.data;\n        }\n\n        this.rowData = params.data;\n\n        this.icons = params.icons;\n        this.rowIndex = params.rowIndex;\n        this.hideIconDelimer = params.hideIconDelimer;\n        this.marginForEvenIcon = params.marginForEvenIcon;\n    }\n\n    refresh(): boolean {\n        return true;\n    }\n\n    isIconDisabled(icon: IGridCellIconAction): boolean {\n        return icon.disabled instanceof Function ? icon.disabled(this.field, this.rowIndex, this.rowData) : icon.disabled;\n    }\n}\n","<div class=\"action-icons\" [style.margin]=\"containerMargin\" [style.justify-content]=\"pinRight && 'flex-end'\">\n    <div\n        *ngFor=\"let icon of icons; let odd = odd; let first = first\"\n        class=\"action-icons__item-container action-item\"\n        [class.hide-delimer]=\"hideIconDelimer\"\n        [style.margin-right]=\"odd && marginForEvenIcon\"\n        [style.margin-left]=\"odd && !first && marginForEvenIcon\">\n        <span\n            *ngIf=\"!icon.hidden && icon.show ? icon.show(field) : true\"\n            class=\"action-item__wrapper\"\n            [class.badge]=\"icon.badgeColor\"\n            [style.background-color]=\"icon.badgeColor\"\n            [drTooltipMouseEnterTimeout]=\"100\"\n            [drTooltip]=\"icon.customTooltip ? icon.customTooltip(field, rowIndex, rowData) : icon.tooltip\">\n            <ng-container\n                *ngTemplateOutlet=\"\n                    icon.isSimpleIcon ? simpleIconRef : buttonIconRef;\n                    context: { $implicit: icon }\n                \"></ng-container>\n        </span>\n    </div>\n</div>\n\n<ng-template #buttonIconRef let-icon>\n    <dr-button\n        data-analytics=\"tables_cells_cell-icon-actions_button-0\"\n        class=\"action-item__button\"\n        theme=\"icon\"\n        [icon]=\"icon.dynamicClass ? icon.dynamicClass(field, rowIndex, rowData) : icon.class\"\n        [iconSize]=\"icon.size\"\n        [iconColor]=\"icon.colorFn ? icon.colorFn(field) : icon.color\"\n        [disabled]=\"isIconDisabled(icon)\"\n        (click)=\"icon.action && icon.action(field, rowIndex, rowData)\"\n        [drDropdown]=\"icon.dropdownActions\"\n        drDropdownPosition=\"bottom\"></dr-button>\n</ng-template>\n\n<ng-template #simpleIconRef let-icon>\n    <span [class]=\"icon.class\" [style.color]=\"icon.color\" [style.font-size]=\"icon.size\"></span>\n</ng-template>\n"]}
@@ -0,0 +1,130 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostListener, ViewChild, } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';
4
+ import { isArray as _isArray } from 'lodash';
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
+ const _c0 = ["textSpan"];
9
+ function CellIconTextEditComponent_i_1_Template(rf, ctx) { if (rf & 1) {
10
+ i0.ɵɵelement(0, "i", 5);
11
+ } if (rf & 2) {
12
+ const ctx_r0 = i0.ɵɵnextContext();
13
+ i0.ɵɵclassMap(ctx_r0.icon);
14
+ } }
15
+ function CellIconTextEditComponent_img_2_Template(rf, ctx) { if (rf & 1) {
16
+ i0.ɵɵelement(0, "img", 6);
17
+ } if (rf & 2) {
18
+ const ctx_r1 = i0.ɵɵnextContext();
19
+ i0.ɵɵclassMap(ctx_r1.icon);
20
+ i0.ɵɵproperty("src", ctx_r1.iconPath, i0.ɵɵsanitizeUrl);
21
+ } }
22
+ function CellIconTextEditComponent_span_3_Template(rf, ctx) { if (rf & 1) {
23
+ i0.ɵɵelementStart(0, "span", 7, 8);
24
+ i0.ɵɵtext(2);
25
+ i0.ɵɵelementEnd();
26
+ } if (rf & 2) {
27
+ const ctx_r2 = i0.ɵɵnextContext();
28
+ i0.ɵɵclassProp("highlight", ctx_r2.cellParams.highlightText);
29
+ i0.ɵɵadvance(2);
30
+ i0.ɵɵtextInterpolate1(" ", ctx_r2.text, " ");
31
+ } }
32
+ function CellIconTextEditComponent_i_4_Template(rf, ctx) { if (rf & 1) {
33
+ i0.ɵɵelement(0, "i", 9);
34
+ } }
35
+ export class CellIconTextEditComponent {
36
+ cellClick() {
37
+ if (!this.isCellDisabled) {
38
+ this.cellParams.onCellClicked?.(this.rowData);
39
+ }
40
+ }
41
+ constructor(cdr) {
42
+ this.cdr = cdr;
43
+ this.tooltip = '';
44
+ this.isCellDisabled = false;
45
+ }
46
+ agInit(params) {
47
+ this.cellParams = params.colDef.cellRendererParams;
48
+ this.text =
49
+ this.cellParams.text ||
50
+ (typeof params.value === 'boolean' ? '' : _isArray(params.value) ? params.value.join(', ') : params.value);
51
+ this.rowData = params.data;
52
+ if (this.cellParams.tooltip) {
53
+ this.tooltip =
54
+ typeof this.cellParams?.tooltip === 'string'
55
+ ? this.cellParams?.tooltip
56
+ : this.cellParams?.tooltip?.(this.rowData);
57
+ }
58
+ this.isCellDisabled =
59
+ this.cellParams?.isDisabled &&
60
+ (typeof this.cellParams?.isDisabled === 'boolean'
61
+ ? this.cellParams?.isDisabled
62
+ : this.cellParams?.isDisabled?.(this.rowData));
63
+ if (this.isCellDisabled && this.cellParams.disabledTooltip) {
64
+ this.tooltip =
65
+ typeof this.cellParams?.disabledTooltip === 'string'
66
+ ? this.cellParams?.disabledTooltip
67
+ : this.cellParams?.disabledTooltip?.(this.rowData);
68
+ }
69
+ this.icon =
70
+ this.cellParams?.icon &&
71
+ (typeof this.cellParams?.icon === 'string' ? this.cellParams.icon : this.cellParams.icon(this.rowData));
72
+ // FIXME: remove iconPath
73
+ this.iconPath =
74
+ this.cellParams?.iconPath &&
75
+ (typeof this.cellParams?.iconPath === 'string' ? this.cellParams.iconPath : this.cellParams.iconPath(this.rowData));
76
+ if (this.cellParams?.iconSize) {
77
+ this.icon += ' ' + this.cellParams?.iconSize;
78
+ }
79
+ }
80
+ ngAfterViewInit() {
81
+ if (!this.tooltip && this.textSpan) {
82
+ setTimeout(() => {
83
+ const el = this.textSpan.nativeElement;
84
+ this.tooltip = el.scrollWidth > el.clientWidth ? this.text : '';
85
+ this.cdr.markForCheck();
86
+ });
87
+ }
88
+ }
89
+ refresh(params) {
90
+ return false;
91
+ }
92
+ /** @nocollapse */ static { this.ɵfac = function CellIconTextEditComponent_Factory(t) { return new (t || CellIconTextEditComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
93
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: CellIconTextEditComponent, selectors: [["dr-cell-icon-text-edit"]], viewQuery: function CellIconTextEditComponent_Query(rf, ctx) { if (rf & 1) {
94
+ i0.ɵɵviewQuery(_c0, 5);
95
+ } if (rf & 2) {
96
+ let _t;
97
+ i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.textSpan = _t.first);
98
+ } }, hostBindings: function CellIconTextEditComponent_HostBindings(rf, ctx) { if (rf & 1) {
99
+ i0.ɵɵlistener("click", function CellIconTextEditComponent_click_HostBindingHandler() { return ctx.cellClick(); });
100
+ } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 5, vars: 12, consts: [[1, "cell-icon-text-edit", 3, "drTooltip", "drTooltipMouseEnterTimeout"], ["class", "cell-icon-text-edit__icon", 3, "class", 4, "ngIf"], ["class", "cell-icon-text-edit__icon", "width", "24px", "height", "24px", 3, "class", "src", 4, "ngIf"], ["class", "cell-icon-text-edit__text", 3, "highlight", 4, "ngIf"], ["class", "cell-icon-text-edit__edit-icon dr-icon-edit", 4, "ngIf"], [1, "cell-icon-text-edit__icon"], ["width", "24px", "height", "24px", 1, "cell-icon-text-edit__icon", 3, "src"], [1, "cell-icon-text-edit__text"], ["textSpan", ""], [1, "cell-icon-text-edit__edit-icon", "dr-icon-edit"]], template: function CellIconTextEditComponent_Template(rf, ctx) { if (rf & 1) {
101
+ i0.ɵɵelementStart(0, "div", 0);
102
+ i0.ɵɵtemplate(1, CellIconTextEditComponent_i_1_Template, 1, 2, "i", 1);
103
+ i0.ɵɵtemplate(2, CellIconTextEditComponent_img_2_Template, 1, 3, "img", 2);
104
+ i0.ɵɵtemplate(3, CellIconTextEditComponent_span_3_Template, 3, 3, "span", 3);
105
+ i0.ɵɵtemplate(4, CellIconTextEditComponent_i_4_Template, 1, 0, "i", 4);
106
+ i0.ɵɵelementEnd();
107
+ } if (rf & 2) {
108
+ i0.ɵɵclassProp("disabled", ctx.isCellDisabled)("only-icon", !ctx.text && !ctx.cellParams.showEditIcon)("no-hover", !!ctx.cellParams.noHover);
109
+ i0.ɵɵproperty("drTooltip", ctx.tooltip)("drTooltipMouseEnterTimeout", 300);
110
+ i0.ɵɵadvance(1);
111
+ i0.ɵɵproperty("ngIf", ctx.icon);
112
+ i0.ɵɵadvance(1);
113
+ i0.ɵɵproperty("ngIf", ctx.iconPath);
114
+ i0.ɵɵadvance(1);
115
+ i0.ɵɵproperty("ngIf", ctx.text);
116
+ i0.ɵɵadvance(1);
117
+ i0.ɵɵproperty("ngIf", ctx.cellParams.showEditIcon && !ctx.isCellDisabled);
118
+ } }, dependencies: [CommonModule, i1.NgIf, DrTooltipModule, i2.DrTooltipDirective], styles: ["[_nghost-%COMP%]{width:100%;height:100%}.cell-icon-text-edit[_ngcontent-%COMP%]{height:100%;display:flex;align-items:center}.cell-icon-text-edit__icon[_ngcontent-%COMP%]{margin-right:8px}.cell-icon-text-edit__icon.medium-icon[_ngcontent-%COMP%]{font-size:20px}.cell-icon-text-edit__icon.small-icon[_ngcontent-%COMP%]{font-size:16px}.cell-icon-text-edit__text[_ngcontent-%COMP%]{position:relative;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.cell-icon-text-edit__text.highlight[_ngcontent-%COMP%]{color:#4646ce}.cell-icon-text-edit__text.highlight[_ngcontent-%COMP%]:hover{color:#333}.cell-icon-text-edit__edit-icon[_ngcontent-%COMP%]{visibility:hidden;font-size:20px}.cell-icon-text-edit__text[_ngcontent-%COMP%] + .cell-icon-text-edit__edit-icon[_ngcontent-%COMP%]{margin-left:8px}.cell-icon-text-edit[_ngcontent-%COMP%]:hover:not(.no-hover){cursor:pointer}.cell-icon-text-edit[_ngcontent-%COMP%]:hover:not(.no-hover) .cell-icon-text-edit__edit-icon[_ngcontent-%COMP%]{visibility:visible}.cell-icon-text-edit.disabled[_ngcontent-%COMP%]{color:#aeabac;cursor:default}.cell-icon-text-edit.only-icon[_ngcontent-%COMP%]{justify-content:center}.cell-icon-text-edit.only-icon[_ngcontent-%COMP%] i[_ngcontent-%COMP%]{margin:0}"], changeDetection: 0 }); }
119
+ }
120
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CellIconTextEditComponent, [{
121
+ type: Component,
122
+ args: [{ selector: 'dr-cell-icon-text-edit', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [CommonModule, DrTooltipModule], template: "<div\n class=\"cell-icon-text-edit\"\n [class.disabled]=\"isCellDisabled\"\n [class.only-icon]=\"!text && !cellParams.showEditIcon\"\n [class.no-hover]=\"!!cellParams.noHover\"\n [drTooltip]=\"tooltip\"\n [drTooltipMouseEnterTimeout]=\"300\">\n <i *ngIf=\"icon\" class=\"cell-icon-text-edit__icon\" [class]=\"icon\"></i>\n <img *ngIf=\"iconPath\" class=\"cell-icon-text-edit__icon\" [class]=\"icon\" width=\"24px\" height=\"24px\" [src]=\"iconPath\" />\n <span *ngIf=\"text\" #textSpan class=\"cell-icon-text-edit__text\" [class.highlight]=\"cellParams.highlightText\">\n {{ text }}\n </span>\n <i *ngIf=\"cellParams.showEditIcon && !isCellDisabled\" class=\"cell-icon-text-edit__edit-icon dr-icon-edit\"></i>\n</div>\n", styles: [":host{width:100%;height:100%}.cell-icon-text-edit{height:100%;display:flex;align-items:center}.cell-icon-text-edit__icon{margin-right:8px}.cell-icon-text-edit__icon.medium-icon{font-size:20px}.cell-icon-text-edit__icon.small-icon{font-size:16px}.cell-icon-text-edit__text{position:relative;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.cell-icon-text-edit__text.highlight{color:#4646ce}.cell-icon-text-edit__text.highlight:hover{color:#333}.cell-icon-text-edit__edit-icon{visibility:hidden;font-size:20px}.cell-icon-text-edit__text+.cell-icon-text-edit__edit-icon{margin-left:8px}.cell-icon-text-edit:hover:not(.no-hover){cursor:pointer}.cell-icon-text-edit:hover:not(.no-hover) .cell-icon-text-edit__edit-icon{visibility:visible}.cell-icon-text-edit.disabled{color:#aeabac;cursor:default}.cell-icon-text-edit.only-icon{justify-content:center}.cell-icon-text-edit.only-icon i{margin:0}\n"] }]
123
+ }], function () { return [{ type: i0.ChangeDetectorRef }]; }, { textSpan: [{
124
+ type: ViewChild,
125
+ args: ['textSpan', { static: false }]
126
+ }], cellClick: [{
127
+ type: HostListener,
128
+ args: ['click']
129
+ }] }); })();
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-icon-text-edit.component.js","sourceRoot":"","sources":["../../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/cells/cell-icon-text-edit/cell-icon-text-edit.component.ts","../../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/cells/cell-icon-text-edit/cell-icon-text-edit.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    HostListener,\n    ViewChild,\n} from '@angular/core';\nimport { IGridCellRendererComponent, IGridCellRendererParams } from '../../../models/interfaces';\nimport { CommonModule } from '@angular/common';\nimport { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';\nimport { isArray as _isArray } from 'lodash';\n\nexport interface ICellIconTextEdit<T> {\n    text: string;\n    tooltip?: string | ((rowData: T) => string);\n    isDisabled?: boolean | ((rowData: T) => boolean);\n    disabledTooltip?: string | ((rowData: T) => string);\n    onCellClicked?: (rowData: T) => any;\n    icon?: string | ((rowData: T) => string);\n    iconPath?: string | ((rowData: T) => string);\n    iconSize?: 'medium-icon' | 'small-icon';\n    showEditIcon: boolean;\n    highlightText: boolean;\n    noHover?: boolean;\n}\n\n@Component({\n    selector: 'dr-cell-icon-text-edit',\n    templateUrl: './cell-icon-text-edit.component.html',\n    styleUrls: ['./cell-icon-text-edit.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [CommonModule, DrTooltipModule],\n})\nexport class CellIconTextEditComponent<T> implements AfterViewInit, IGridCellRendererComponent {\n    rowData: T;\n    cellParams: ICellIconTextEdit<T>;\n\n    icon: string;\n    text: string;\n    tooltip: string = '';\n    isCellDisabled: boolean = false;\n    iconPath: string;\n\n    @ViewChild('textSpan', { static: false }) textSpan!: ElementRef<HTMLElement>;\n    @HostListener('click') cellClick() {\n        if (!this.isCellDisabled) {\n            this.cellParams.onCellClicked?.(this.rowData);\n        }\n    }\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    agInit(params: IGridCellRendererParams): void {\n        this.cellParams = params.colDef.cellRendererParams;\n\n        this.text =\n            this.cellParams.text ||\n            (typeof params.value === 'boolean' ? '' : _isArray(params.value) ? params.value.join(', ') : params.value);\n        this.rowData = params.data;\n\n        if (this.cellParams.tooltip) {\n            this.tooltip =\n                typeof this.cellParams?.tooltip === 'string'\n                    ? this.cellParams?.tooltip\n                    : this.cellParams?.tooltip?.(this.rowData);\n        }\n\n        this.isCellDisabled =\n            this.cellParams?.isDisabled &&\n            (typeof this.cellParams?.isDisabled === 'boolean'\n                ? this.cellParams?.isDisabled\n                : this.cellParams?.isDisabled?.(this.rowData));\n\n        if (this.isCellDisabled && this.cellParams.disabledTooltip) {\n            this.tooltip =\n                typeof this.cellParams?.disabledTooltip === 'string'\n                    ? this.cellParams?.disabledTooltip\n                    : this.cellParams?.disabledTooltip?.(this.rowData);\n        }\n\n        this.icon =\n            this.cellParams?.icon &&\n            (typeof this.cellParams?.icon === 'string' ? this.cellParams.icon : this.cellParams.icon(this.rowData));\n\n        // FIXME: remove iconPath\n        this.iconPath =\n            this.cellParams?.iconPath &&\n            (typeof this.cellParams?.iconPath === 'string' ? this.cellParams.iconPath : this.cellParams.iconPath(this.rowData));\n\n        if (this.cellParams?.iconSize) {\n            this.icon += ' ' + this.cellParams?.iconSize;\n        }\n    }\n\n    ngAfterViewInit(): void {\n        if (!this.tooltip && this.textSpan) {\n            setTimeout(() => {\n                const el = this.textSpan.nativeElement;\n                this.tooltip = el.scrollWidth > el.clientWidth ? this.text : '';\n                this.cdr.markForCheck();\n            });\n        }\n    }\n\n    refresh(params: IGridCellRendererParams<any>): boolean {\n        return false;\n    }\n}\n","<div\n    class=\"cell-icon-text-edit\"\n    [class.disabled]=\"isCellDisabled\"\n    [class.only-icon]=\"!text && !cellParams.showEditIcon\"\n    [class.no-hover]=\"!!cellParams.noHover\"\n    [drTooltip]=\"tooltip\"\n    [drTooltipMouseEnterTimeout]=\"300\">\n    <i *ngIf=\"icon\" class=\"cell-icon-text-edit__icon\" [class]=\"icon\"></i>\n    <img *ngIf=\"iconPath\" class=\"cell-icon-text-edit__icon\" [class]=\"icon\" width=\"24px\" height=\"24px\" [src]=\"iconPath\" />\n    <span *ngIf=\"text\" #textSpan class=\"cell-icon-text-edit__text\" [class.highlight]=\"cellParams.highlightText\">\n        {{ text }}\n    </span>\n    <i *ngIf=\"cellParams.showEditIcon && !isCellDisabled\" class=\"cell-icon-text-edit__edit-icon dr-icon-edit\"></i>\n</div>\n"]}
@@ -0,0 +1,94 @@
1
+ import { ChangeDetectionStrategy, Component, HostBinding, HostListener } from '@angular/core';
2
+ import * as _ from 'lodash';
3
+ import { Router } from '@angular/router';
4
+ import { CommonModule } from '@angular/common';
5
+ import { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/router";
8
+ import * as i2 from "../../../../dr-tooltip/dr-tooltip.directive";
9
+ export class CellLinkComponent {
10
+ constructor(router) {
11
+ this.router = router;
12
+ this.isOutsideAngular = false;
13
+ this.dynamicLink = false;
14
+ this.isCellDisabled = false;
15
+ this.tooltip = '';
16
+ }
17
+ agInit(params) {
18
+ this.templates = params.data;
19
+ this.query = params.colDef.cellRendererParams;
20
+ this.params = _.get(this.templates, this.query?.params);
21
+ this.isCellDisabled = this.query?.isDisabled?.(this.templates);
22
+ if (this.isCellDisabled) {
23
+ this.tooltip = this.query.disabledTooltipGetter
24
+ ? this.query.disabledTooltipGetter(this.templates)
25
+ : this.query.disabledTooltip;
26
+ }
27
+ this.queryParams = _.get(this.templates, this.query?.queryParams);
28
+ this.state = this.getStateData(params);
29
+ this.isOutsideAngular = !!_.get(this.query, 'isOutsideAngular');
30
+ this.dynamicLink = !!_.get(this.query, 'dynamicLink');
31
+ }
32
+ getStateData(params) {
33
+ return this.query.useState ? { [this.query.stateKey || 'data']: params.data } : undefined;
34
+ }
35
+ refresh() {
36
+ return false;
37
+ }
38
+ goTo(e) {
39
+ if (this.query?.isDisabled?.(this.templates)) {
40
+ e?.stopPropagation?.();
41
+ return;
42
+ }
43
+ let link = this.query.link;
44
+ if (this.isOutsideAngular) {
45
+ let linkWithParams = link;
46
+ _.forEach(_.keys(this.templates), (fieldKey) => {
47
+ const fieldValue = this.templates[fieldKey];
48
+ linkWithParams = linkWithParams.replace(`{${fieldKey}}`, fieldValue);
49
+ });
50
+ window.location = linkWithParams;
51
+ }
52
+ else {
53
+ if (this.params) {
54
+ link = `${link}/${this.params}`;
55
+ }
56
+ if (this.dynamicLink) {
57
+ _.forEach(_.keys(this.templates), (fieldKey) => {
58
+ const fieldValue = this.templates[fieldKey];
59
+ link = link.replace(`{${fieldKey}}`, fieldValue);
60
+ });
61
+ }
62
+ this.router.navigate([link], { queryParams: this.queryParams, state: this.state });
63
+ if (this.query.afterLinkCLick) {
64
+ this.query.afterLinkCLick();
65
+ }
66
+ }
67
+ }
68
+ /** @nocollapse */ static { this.ɵfac = function CellLinkComponent_Factory(t) { return new (t || CellLinkComponent)(i0.ɵɵdirectiveInject(i1.Router)); }; }
69
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: CellLinkComponent, selectors: [["dr-cell-link"]], hostVars: 2, hostBindings: function CellLinkComponent_HostBindings(rf, ctx) { if (rf & 1) {
70
+ i0.ɵɵlistener("click", function CellLinkComponent_click_HostBindingHandler() { return ctx.goTo(); });
71
+ } if (rf & 2) {
72
+ i0.ɵɵclassProp("disabled", ctx.isCellDisabled);
73
+ } }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 4, consts: [[3, "drTooltip"]], template: function CellLinkComponent_Template(rf, ctx) { if (rf & 1) {
74
+ i0.ɵɵelementStart(0, "a", 0);
75
+ i0.ɵɵtext(1);
76
+ i0.ɵɵelementEnd();
77
+ } if (rf & 2) {
78
+ i0.ɵɵclassProp("disabled", ctx.isCellDisabled);
79
+ i0.ɵɵproperty("drTooltip", ctx.tooltip);
80
+ i0.ɵɵadvance(1);
81
+ i0.ɵɵtextInterpolate1(" ", ctx.templates[ctx.query.field], "\n");
82
+ } }, dependencies: [CommonModule, DrTooltipModule, i2.DrTooltipDirective], styles: ["[_nghost-%COMP%]{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}[_nghost-%COMP%] a[_ngcontent-%COMP%]{color:#4646ce;text-decoration:none}[_nghost-%COMP%]:hover:not(.disabled) a[_ngcontent-%COMP%]{text-decoration:underline!important}.disabled[_nghost-%COMP%] a[_ngcontent-%COMP%]{color:#aeabac!important}"], changeDetection: 0 }); }
83
+ }
84
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CellLinkComponent, [{
85
+ type: Component,
86
+ args: [{ selector: 'dr-cell-link', standalone: true, imports: [CommonModule, DrTooltipModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<a [class.disabled]=\"isCellDisabled\" [drTooltip]=\"tooltip\">\n {{ templates[query.field] }}\n</a>\n", styles: [":host{width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}:host a{color:#4646ce;text-decoration:none}:host:hover:not(.disabled) a{text-decoration:underline!important}:host.disabled a{color:#aeabac!important}\n"] }]
87
+ }], function () { return [{ type: i1.Router }]; }, { isCellDisabled: [{
88
+ type: HostBinding,
89
+ args: ['class.disabled']
90
+ }], goTo: [{
91
+ type: HostListener,
92
+ args: ['click']
93
+ }] }); })();
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-link.component.js","sourceRoot":"","sources":["../../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/cells/cell-link/cell-link.component.ts","../../../../../../../../projects/datarailsshared/src/lib/dr-grid/components/cells/cell-link/cell-link.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE9F,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;;;;AAU3E,MAAM,OAAO,iBAAiB;IAsB1B,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QALlC,qBAAgB,GAAG,KAAK,CAAC;QACzB,gBAAW,GAAG,KAAK,CAAC;QACW,mBAAc,GAAY,KAAK,CAAC;QAC/D,YAAO,GAAW,EAAE,CAAC;IAEgB,CAAC;IAEtC,MAAM,CAAC,MAAM;QACT,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC;QAC7B,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC;QAC9C,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACxD,IAAI,CAAC,cAAc,GAAI,IAAI,CAAC,KAAa,EAAE,UAAU,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxE,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,qBAAqB;gBAC3C,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC,IAAI,CAAC,SAAS,CAAC;gBAClD,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC;SACpC;QACD,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;QAClE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACvC,IAAI,CAAC,gBAAgB,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,kBAAkB,CAAC,CAAC;QAChE,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,aAAa,CAAC,CAAC;IAC1D,CAAC;IAED,YAAY,CAAC,MAAM;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,MAAM,CAAC,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC;IAC9F,CAAC;IAED,OAAO;QACH,OAAO,KAAK,CAAC;IACjB,CAAC;IAGD,IAAI,CAAC,CAAC;QACF,IAAI,IAAI,CAAC,KAAK,EAAE,UAAU,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;YAC1C,CAAC,EAAE,eAAe,EAAE,EAAE,CAAC;YACvB,OAAO;SACV;QACD,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;QAE3B,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,cAAc,GAAG,IAAI,CAAC;YAC1B,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE;gBAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;gBAC5C,cAAc,GAAG,cAAc,CAAC,OAAO,CAAC,IAAI,QAAQ,GAAG,EAAE,UAAU,CAAC,CAAC;YACzE,CAAC,CAAC,CAAC;YACH,MAAM,CAAC,QAAQ,GAAG,cAAgD,CAAC;SACtE;aAAM;YACH,IAAI,IAAI,CAAC,MAAM,EAAE;gBACb,IAAI,GAAG,GAAG,IAAI,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;aACnC;YACD,IAAI,IAAI,CAAC,WAAW,EAAE;gBAClB,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,QAAQ,EAAE,EAAE;oBAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;oBAC5C,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,QAAQ,GAAG,EAAE,UAAU,CAAC,CAAC;gBACrD,CAAC,CAAC,CAAC;aACN;YACD,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,WAAW,EAAE,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;YACnF,IAAI,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE;gBAC3B,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;aAC/B;SACJ;IACL,CAAC;qGA9EQ,iBAAiB;mGAAjB,iBAAiB;kGAAjB,UAAM;;;;YCfnB,4BAA2D;YACvD,YACJ;YAAA,iBAAI;;YAFD,8CAAiC;YAAC,uCAAqB;YACtD,eACJ;YADI,gEACJ;4BDUc,YAAY,EAAE,eAAe;;uFAG9B,iBAAiB;cAR7B,SAAS;2BACI,cAAc,cAGZ,IAAI,WACP,CAAC,YAAY,EAAE,eAAe,CAAC,mBACvB,uBAAuB,CAAC,MAAM;yDAqBhB,cAAc;kBAA5C,WAAW;mBAAC,gBAAgB;YA8B7B,IAAI;kBADH,YAAY;mBAAC,OAAO","sourcesContent":["import { ChangeDetectionStrategy, Component, HostBinding, HostListener } from '@angular/core';\nimport { IGridCellRendererComponent } from '../../../models/interfaces';\nimport * as _ from 'lodash';\nimport { Router } from '@angular/router';\nimport { CommonModule } from '@angular/common';\nimport { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';\n\n@Component({\n    selector: 'dr-cell-link',\n    templateUrl: './cell-link.component.html',\n    styleUrls: ['./cell-link.component.scss'],\n    standalone: true,\n    imports: [CommonModule, DrTooltipModule],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class CellLinkComponent<T> implements IGridCellRendererComponent {\n    templates: T;\n    query: {\n        field: string;\n        queryParams: string;\n        params: string;\n        link: string;\n        afterLinkCLick?: () => void;\n        useState?: boolean;\n        stateKey?: string;\n        isDisabled?: (data: any) => boolean;\n        disabledTooltip?: string;\n        disabledTooltipGetter?: (data: any) => string;\n    };\n    params: unknown;\n    queryParams: unknown;\n    state: any;\n    isOutsideAngular = false;\n    dynamicLink = false;\n    @HostBinding('class.disabled') isCellDisabled: boolean = false;\n    tooltip: string = '';\n\n    constructor(private router: Router) {}\n\n    agInit(params): void {\n        this.templates = params.data;\n        this.query = params.colDef.cellRendererParams;\n        this.params = _.get(this.templates, this.query?.params);\n        this.isCellDisabled = (this.query as any)?.isDisabled?.(this.templates);\n        if (this.isCellDisabled) {\n            this.tooltip = this.query.disabledTooltipGetter\n                ? this.query.disabledTooltipGetter(this.templates)\n                : this.query.disabledTooltip;\n        }\n        this.queryParams = _.get(this.templates, this.query?.queryParams);\n        this.state = this.getStateData(params);\n        this.isOutsideAngular = !!_.get(this.query, 'isOutsideAngular');\n        this.dynamicLink = !!_.get(this.query, 'dynamicLink');\n    }\n\n    getStateData(params): any {\n        return this.query.useState ? { [this.query.stateKey || 'data']: params.data } : undefined;\n    }\n\n    refresh(): boolean {\n        return false;\n    }\n\n    @HostListener('click')\n    goTo(e) {\n        if (this.query?.isDisabled?.(this.templates)) {\n            e?.stopPropagation?.();\n            return;\n        }\n        let link = this.query.link;\n\n        if (this.isOutsideAngular) {\n            let linkWithParams = link;\n            _.forEach(_.keys(this.templates), (fieldKey) => {\n                const fieldValue = this.templates[fieldKey];\n                linkWithParams = linkWithParams.replace(`{${fieldKey}}`, fieldValue);\n            });\n            window.location = linkWithParams as Location | (string & Location);\n        } else {\n            if (this.params) {\n                link = `${link}/${this.params}`;\n            }\n            if (this.dynamicLink) {\n                _.forEach(_.keys(this.templates), (fieldKey) => {\n                    const fieldValue = this.templates[fieldKey];\n                    link = link.replace(`{${fieldKey}}`, fieldValue);\n                });\n            }\n            this.router.navigate([link], { queryParams: this.queryParams, state: this.state });\n            if (this.query.afterLinkCLick) {\n                this.query.afterLinkCLick();\n            }\n        }\n    }\n}\n","<a [class.disabled]=\"isCellDisabled\" [drTooltip]=\"tooltip\">\n    {{ templates[query.field] }}\n</a>\n"]}
@@ -0,0 +1,45 @@
1
+ import { ChangeDetectionStrategy, Component } from '@angular/core';
2
+ import { DrInputsModule } from '../../../../dr-inputs/dr-inputs.module';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { NgIf } from '@angular/common';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/forms";
7
+ import * as i2 from "../../../../dr-inputs/dr-select/dr-select.component";
8
+ function CellSelectComponent_div_0_Template(rf, ctx) { if (rf & 1) {
9
+ const _r2 = i0.ɵɵgetCurrentView();
10
+ i0.ɵɵelementStart(0, "div", 1)(1, "dr-select", 2);
11
+ i0.ɵɵlistener("ngModelChange", function CellSelectComponent_div_0_Template_dr_select_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView((ctx_r1.field[ctx_r1.bindFieldValue] = $event)); })("ngModelChange", function CellSelectComponent_div_0_Template_dr_select_ngModelChange_1_listener() { i0.ɵɵrestoreView(_r2); const ctx_r3 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r3.onChange()); });
12
+ i0.ɵɵelementEnd()();
13
+ } if (rf & 2) {
14
+ const ctx_r0 = i0.ɵɵnextContext();
15
+ i0.ɵɵadvance(1);
16
+ i0.ɵɵproperty("ngModel", ctx_r0.field[ctx_r0.bindFieldValue])("bindLabel", ctx_r0.selectConfig == null ? null : ctx_r0.selectConfig.bindLabel)("bindValue", ctx_r0.selectConfig == null ? null : ctx_r0.selectConfig.bindValue)("multiple", ctx_r0.selectConfig == null ? null : ctx_r0.selectConfig.multiple)("addTag", ctx_r0.selectConfig == null ? null : ctx_r0.selectConfig.addTag)("clearable", ctx_r0.selectConfig == null ? null : ctx_r0.selectConfig.clearable)("searchable", ctx_r0.selectConfig == null ? null : ctx_r0.selectConfig.searchable)("items", ctx_r0.selectItems);
17
+ } }
18
+ export class CellSelectComponent {
19
+ agInit(params) {
20
+ this.field = params.data;
21
+ this.bindFieldValue = params.colDef.field || params.bindFieldValue;
22
+ this.onChangeFn = params.onChangeFn;
23
+ this.selectItems = params.selectItems;
24
+ this.selectConfig = params.selectConfig;
25
+ }
26
+ refresh() {
27
+ return false;
28
+ }
29
+ onChange() {
30
+ if (this.onChangeFn) {
31
+ this.onChangeFn(this.field);
32
+ }
33
+ }
34
+ /** @nocollapse */ static { this.ɵfac = function CellSelectComponent_Factory(t) { return new (t || CellSelectComponent)(); }; }
35
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: CellSelectComponent, selectors: [["dr-cell-select"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 1, vars: 1, consts: [["class", "cell-select", 4, "ngIf"], [1, "cell-select"], ["data-analytics", "cell-select_select-0", "appendTo", "body", 3, "ngModel", "bindLabel", "bindValue", "multiple", "addTag", "clearable", "searchable", "items", "ngModelChange"]], template: function CellSelectComponent_Template(rf, ctx) { if (rf & 1) {
36
+ i0.ɵɵtemplate(0, CellSelectComponent_div_0_Template, 2, 8, "div", 0);
37
+ } if (rf & 2) {
38
+ i0.ɵɵproperty("ngIf", ctx.field && ctx.selectItems);
39
+ } }, dependencies: [NgIf, FormsModule, i1.NgControlStatus, i1.NgModel, DrInputsModule, i2.DrSelectComponent], styles: ["[_nghost-%COMP%]{flex-grow:1}"], changeDetection: 0 }); }
40
+ }
41
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CellSelectComponent, [{
42
+ type: Component,
43
+ args: [{ selector: 'dr-cell-select', standalone: true, imports: [NgIf, FormsModule, DrInputsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div *ngIf=\"field && selectItems\" class=\"cell-select\">\n <dr-select\n data-analytics=\"cell-select_select-0\"\n [(ngModel)]=\"field[bindFieldValue]\"\n appendTo=\"body\"\n [bindLabel]=\"selectConfig?.bindLabel\"\n [bindValue]=\"selectConfig?.bindValue\"\n [multiple]=\"selectConfig?.multiple\"\n [addTag]=\"selectConfig?.addTag\"\n [clearable]=\"selectConfig?.clearable\"\n [searchable]=\"selectConfig?.searchable\"\n [items]=\"selectItems\"\n (ngModelChange)=\"onChange()\"></dr-select>\n</div>\n", styles: [":host{flex-grow:1}\n"] }]
44
+ }], null, null); })();
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC1zZWxlY3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGF0YXJhaWxzc2hhcmVkL3NyYy9saWIvZHItZ3JpZC9jb21wb25lbnRzL2NlbGxzL2NlbGwtc2VsZWN0L2NlbGwtc2VsZWN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWdyaWQvY29tcG9uZW50cy9jZWxscy9jZWxsLXNlbGVjdC9jZWxsLXNlbGVjdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRW5FLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3Q0FBd0MsQ0FBQztBQUN4RSxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7Ozs7SUNKdkMsOEJBQXNELG1CQUFBO0lBRzlDLDJQQUFtQyxzS0FTbEIsZUFBQSxpQkFBVSxDQUFBLElBVFE7SUFTTixpQkFBWSxFQUFBOzs7SUFUekMsZUFBbUM7SUFBbkMsNkRBQW1DLGlGQUFBLGlGQUFBLCtFQUFBLDJFQUFBLGlGQUFBLG1GQUFBLDZCQUFBOztBRG9CM0MsTUFBTSxPQUFPLG1CQUFtQjtJQU9yQixNQUFNLENBQUMsTUFBTTtRQUNoQixJQUFJLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUM7UUFDekIsSUFBSSxDQUFDLGNBQWMsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLEtBQUssSUFBSSxNQUFNLENBQUMsY0FBYyxDQUFDO1FBQ25FLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQztRQUNwQyxJQUFJLENBQUMsV0FBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUM7UUFDdEMsSUFBSSxDQUFDLFlBQVksR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDO0lBQzVDLENBQUM7SUFFTSxPQUFPO1FBQ1YsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQztJQUVNLFFBQVE7UUFDWCxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDakIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDL0I7SUFDTCxDQUFDO3VHQXZCUSxtQkFBbUI7bUdBQW5CLG1CQUFtQjtZQ3ZCaEMsb0VBYU07O1lBYkEsbURBQTBCOzRCRG9CbEIsSUFBSSxFQUFFLFdBQVcsa0NBQUUsY0FBYzs7dUZBR2xDLG1CQUFtQjtjQVIvQixTQUFTOzJCQUNJLGdCQUFnQixjQUdkLElBQUksV0FDUCxDQUFDLElBQUksRUFBRSxXQUFXLEVBQUUsY0FBYyxDQUFDLG1CQUMzQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSUdyaWRDZWxsUmVuZGVyZXJDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBEcklucHV0c01vZHVsZSB9IGZyb20gJy4uLy4uLy4uLy4uL2RyLWlucHV0cy9kci1pbnB1dHMubW9kdWxlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgTmdJZiB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUNlbGxTZWxlY3RDb25maWcge1xuICAgIGJpbmRMYWJlbD86IHN0cmluZztcbiAgICBiaW5kVmFsdWU/OiBzdHJpbmc7XG4gICAgbXVsdGlwbGU/OiBib29sZWFuO1xuICAgIGFkZFRhZz86IGJvb2xlYW47XG4gICAgY2xlYXJhYmxlPzogYm9vbGVhbjtcbiAgICBzZWFyY2hhYmxlPzogYm9vbGVhbjtcbn1cblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkci1jZWxsLXNlbGVjdCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NlbGwtc2VsZWN0LmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jZWxsLXNlbGVjdC5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW05nSWYsIEZvcm1zTW9kdWxlLCBEcklucHV0c01vZHVsZV0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIENlbGxTZWxlY3RDb21wb25lbnQgaW1wbGVtZW50cyBJR3JpZENlbGxSZW5kZXJlckNvbXBvbmVudCB7XG4gICAgcHVibGljIGZpZWxkOiBhbnk7XG4gICAgcHVibGljIGJpbmRGaWVsZFZhbHVlOiBzdHJpbmc7XG4gICAgcHVibGljIHNlbGVjdEl0ZW1zOiBhbnlbXTtcbiAgICBwdWJsaWMgc2VsZWN0Q29uZmlnOiBJQ2VsbFNlbGVjdENvbmZpZztcbiAgICBwdWJsaWMgb25DaGFuZ2VGbjogKGZpZWxkRGF0YTogYW55KSA9PiB2b2lkO1xuXG4gICAgcHVibGljIGFnSW5pdChwYXJhbXMpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5maWVsZCA9IHBhcmFtcy5kYXRhO1xuICAgICAgICB0aGlzLmJpbmRGaWVsZFZhbHVlID0gcGFyYW1zLmNvbERlZi5maWVsZCB8fCBwYXJhbXMuYmluZEZpZWxkVmFsdWU7XG4gICAgICAgIHRoaXMub25DaGFuZ2VGbiA9IHBhcmFtcy5vbkNoYW5nZUZuO1xuICAgICAgICB0aGlzLnNlbGVjdEl0ZW1zID0gcGFyYW1zLnNlbGVjdEl0ZW1zO1xuICAgICAgICB0aGlzLnNlbGVjdENvbmZpZyA9IHBhcmFtcy5zZWxlY3RDb25maWc7XG4gICAgfVxuXG4gICAgcHVibGljIHJlZnJlc2goKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb25DaGFuZ2UoKTogdm9pZCB7XG4gICAgICAgIGlmICh0aGlzLm9uQ2hhbmdlRm4pIHtcbiAgICAgICAgICAgIHRoaXMub25DaGFuZ2VGbih0aGlzLmZpZWxkKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxkaXYgKm5nSWY9XCJmaWVsZCAmJiBzZWxlY3RJdGVtc1wiIGNsYXNzPVwiY2VsbC1zZWxlY3RcIj5cbiAgICA8ZHItc2VsZWN0XG4gICAgICAgIGRhdGEtYW5hbHl0aWNzPVwiY2VsbC1zZWxlY3Rfc2VsZWN0LTBcIlxuICAgICAgICBbKG5nTW9kZWwpXT1cImZpZWxkW2JpbmRGaWVsZFZhbHVlXVwiXG4gICAgICAgIGFwcGVuZFRvPVwiYm9keVwiXG4gICAgICAgIFtiaW5kTGFiZWxdPVwic2VsZWN0Q29uZmlnPy5iaW5kTGFiZWxcIlxuICAgICAgICBbYmluZFZhbHVlXT1cInNlbGVjdENvbmZpZz8uYmluZFZhbHVlXCJcbiAgICAgICAgW211bHRpcGxlXT1cInNlbGVjdENvbmZpZz8ubXVsdGlwbGVcIlxuICAgICAgICBbYWRkVGFnXT1cInNlbGVjdENvbmZpZz8uYWRkVGFnXCJcbiAgICAgICAgW2NsZWFyYWJsZV09XCJzZWxlY3RDb25maWc/LmNsZWFyYWJsZVwiXG4gICAgICAgIFtzZWFyY2hhYmxlXT1cInNlbGVjdENvbmZpZz8uc2VhcmNoYWJsZVwiXG4gICAgICAgIFtpdGVtc109XCJzZWxlY3RJdGVtc1wiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cIm9uQ2hhbmdlKClcIj48L2RyLXNlbGVjdD5cbjwvZGl2PlxuIl19
@@ -0,0 +1,48 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { DrTooltipModule } from '../../../../dr-tooltip/dr-tooltip.module';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../../../dr-tooltip/dr-tooltip.directive";
6
+ export class CellSetAsDefaultComponent {
7
+ constructor() {
8
+ this.key = 'is_favorite';
9
+ this.disabledTooltip = '';
10
+ }
11
+ agInit(params) {
12
+ this.data = params.data;
13
+ this.query = params.colDef.cellRendererParams;
14
+ if (params?.bindKey) {
15
+ this.key = params.bindKey;
16
+ }
17
+ this.tooltipMsg = params?.tooltipMsg;
18
+ const isCellDisabled = this.query?.isDisabled?.(this.data);
19
+ if (isCellDisabled) {
20
+ this.disabledTooltip = this.query.disabledTooltipGetter
21
+ ? this.query.disabledTooltipGetter(this.data)
22
+ : this.query.disabledTooltip;
23
+ }
24
+ }
25
+ // responsible for updating the state of the component
26
+ refresh() {
27
+ return true;
28
+ }
29
+ /** @nocollapse */ static { this.ɵfac = function CellSetAsDefaultComponent_Factory(t) { return new (t || CellSetAsDefaultComponent)(); }; }
30
+ /** @nocollapse */ static { this.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: CellSetAsDefaultComponent, selectors: [["dr-cell-set-as-default"]], inputs: { key: "key" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 2, vars: 6, consts: [[1, "ui-grid-cell-contents", "cell-set-as-default", 3, "drTooltip"], [3, "drTooltip"]], template: function CellSetAsDefaultComponent_Template(rf, ctx) { if (rf & 1) {
31
+ i0.ɵɵelementStart(0, "div", 0);
32
+ i0.ɵɵelement(1, "div", 1);
33
+ i0.ɵɵelementEnd();
34
+ } if (rf & 2) {
35
+ i0.ɵɵclassProp("disabled", ctx.query == null ? null : ctx.query.isDisabled == null ? null : ctx.query.isDisabled(ctx.data));
36
+ i0.ɵɵproperty("drTooltip", ctx.disabledTooltip);
37
+ i0.ɵɵadvance(1);
38
+ i0.ɵɵclassMap(ctx.data[ctx.key] ? "dr-icon-favorite-on" : "dr-icon-favorite-off");
39
+ i0.ɵɵproperty("drTooltip", !ctx.data[ctx.key] ? ctx.tooltipMsg : "");
40
+ } }, dependencies: [CommonModule, DrTooltipModule, i1.DrTooltipDirective], styles: [".cell-set-as-default[_ngcontent-%COMP%]{height:100%;display:flex;justify-content:center;align-items:center;flex-wrap:nowrap}.cell-set-as-default.disabled[_ngcontent-%COMP%]{color:#aeabac!important}.cell-set-as-default.disabled[_ngcontent-%COMP%] div[_ngcontent-%COMP%]{pointer-events:none;color:#aeabac!important}.cell-set-as-default[_ngcontent-%COMP%]:hover{cursor:pointer}.cell-set-as-default[_ngcontent-%COMP%] div[_ngcontent-%COMP%]{font-size:26px}.cell-set-as-default[_ngcontent-%COMP%] div.dr-icon-star-fill[_ngcontent-%COMP%]{color:#fda013;font-size:26px}"] }); }
41
+ }
42
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CellSetAsDefaultComponent, [{
43
+ type: Component,
44
+ args: [{ selector: 'dr-cell-set-as-default', standalone: true, imports: [CommonModule, DrTooltipModule], template: "<div [class.disabled]=\"query?.isDisabled?.(data)\" [drTooltip]=\"disabledTooltip\" class=\"ui-grid-cell-contents cell-set-as-default\">\n <div [class]=\"data[key] ? 'dr-icon-favorite-on' : 'dr-icon-favorite-off'\" [drTooltip]=\"!data[key] ? tooltipMsg : ''\"></div>\n</div>\n", styles: [".cell-set-as-default{height:100%;display:flex;justify-content:center;align-items:center;flex-wrap:nowrap}.cell-set-as-default.disabled{color:#aeabac!important}.cell-set-as-default.disabled div{pointer-events:none;color:#aeabac!important}.cell-set-as-default:hover{cursor:pointer}.cell-set-as-default div{font-size:26px}.cell-set-as-default div.dr-icon-star-fill{color:#fda013;font-size:26px}\n"] }]
45
+ }], null, { key: [{
46
+ type: Input
47
+ }] }); })();
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2VsbC1zZXQtYXMtZGVmYXVsdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kYXRhcmFpbHNzaGFyZWQvc3JjL2xpYi9kci1ncmlkL2NvbXBvbmVudHMvY2VsbHMvY2VsbC1zZXQtYXMtZGVmYXVsdC9jZWxsLXNldC1hcy1kZWZhdWx0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2RhdGFyYWlsc3NoYXJlZC9zcmMvbGliL2RyLWdyaWQvY29tcG9uZW50cy9jZWxscy9jZWxsLXNldC1hcy1kZWZhdWx0L2NlbGwtc2V0LWFzLWRlZmF1bHQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQzs7O0FBUzNFLE1BQU0sT0FBTyx5QkFBeUI7SUFQdEM7UUFRYSxRQUFHLEdBQUcsYUFBYSxDQUFDO1FBRTdCLG9CQUFlLEdBQVcsRUFBRSxDQUFDO0tBaUNoQztJQXZCRyxNQUFNLENBQUMsTUFBTTtRQUNULElBQUksQ0FBQyxJQUFJLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQztRQUV4QixJQUFJLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsa0JBQWtCLENBQUM7UUFFOUMsSUFBSSxNQUFNLEVBQUUsT0FBTyxFQUFFO1lBQ2pCLElBQUksQ0FBQyxHQUFHLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQztTQUM3QjtRQUVELElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxFQUFFLFVBQVUsQ0FBQztRQUVyQyxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsS0FBSyxFQUFFLFVBQVUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUMzRCxJQUFJLGNBQWMsRUFBRTtZQUNoQixJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMscUJBQXFCO2dCQUNuRCxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO2dCQUM3QyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxlQUFlLENBQUM7U0FDcEM7SUFDTCxDQUFDO0lBRUQsc0RBQXNEO0lBQ3RELE9BQU87UUFDSCxPQUFPLElBQUksQ0FBQztJQUNoQixDQUFDOzZHQW5DUSx5QkFBeUI7bUdBQXpCLHlCQUF5QjtZQ1h0Qyw4QkFBa0k7WUFDOUgseUJBQTJIO1lBQy9ILGlCQUFNOztZQUZELDJIQUE0QztZQUFDLCtDQUE2QjtZQUN0RSxlQUFvRTtZQUFwRSxpRkFBb0U7WUFBQyxvRUFBMEM7NEJEUTFHLFlBQVksRUFBRSxlQUFlOzt1RkFFOUIseUJBQXlCO2NBUHJDLFNBQVM7MkJBQ0ksd0JBQXdCLGNBR3RCLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxlQUFlLENBQUM7Z0JBRy9CLEdBQUc7a0JBQVgsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEclRvb2x0aXBNb2R1bGUgfSBmcm9tICcuLi8uLi8uLi8uLi9kci10b29sdGlwL2RyLXRvb2x0aXAubW9kdWxlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkci1jZWxsLXNldC1hcy1kZWZhdWx0JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY2VsbC1zZXQtYXMtZGVmYXVsdC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vY2VsbC1zZXQtYXMtZGVmYXVsdC5jb21wb25lbnQuc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRHJUb29sdGlwTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgQ2VsbFNldEFzRGVmYXVsdENvbXBvbmVudCB7XG4gICAgQElucHV0KCkga2V5ID0gJ2lzX2Zhdm9yaXRlJztcbiAgICB0b29sdGlwTXNnOiBzdHJpbmc7XG4gICAgZGlzYWJsZWRUb29sdGlwOiBzdHJpbmcgPSAnJztcblxuICAgIGRhdGE6IGFueTtcblxuICAgIHF1ZXJ5OiB7XG4gICAgICAgIGlzRGlzYWJsZWQ/OiAoZGF0YTogYW55KSA9PiBib29sZWFuO1xuICAgICAgICBkaXNhYmxlZFRvb2x0aXA/OiBzdHJpbmc7XG4gICAgICAgIGRpc2FibGVkVG9vbHRpcEdldHRlcj86IChkYXRhOiBhbnkpID0+IHN0cmluZztcbiAgICB9O1xuXG4gICAgYWdJbml0KHBhcmFtcyk6IHZvaWQge1xuICAgICAgICB0aGlzLmRhdGEgPSBwYXJhbXMuZGF0YTtcblxuICAgICAgICB0aGlzLnF1ZXJ5ID0gcGFyYW1zLmNvbERlZi5jZWxsUmVuZGVyZXJQYXJhbXM7XG5cbiAgICAgICAgaWYgKHBhcmFtcz8uYmluZEtleSkge1xuICAgICAgICAgICAgdGhpcy5rZXkgPSBwYXJhbXMuYmluZEtleTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMudG9vbHRpcE1zZyA9IHBhcmFtcz8udG9vbHRpcE1zZztcblxuICAgICAgICBjb25zdCBpc0NlbGxEaXNhYmxlZCA9IHRoaXMucXVlcnk/LmlzRGlzYWJsZWQ/Lih0aGlzLmRhdGEpO1xuICAgICAgICBpZiAoaXNDZWxsRGlzYWJsZWQpIHtcbiAgICAgICAgICAgIHRoaXMuZGlzYWJsZWRUb29sdGlwID0gdGhpcy5xdWVyeS5kaXNhYmxlZFRvb2x0aXBHZXR0ZXJcbiAgICAgICAgICAgICAgICA/IHRoaXMucXVlcnkuZGlzYWJsZWRUb29sdGlwR2V0dGVyKHRoaXMuZGF0YSlcbiAgICAgICAgICAgICAgICA6IHRoaXMucXVlcnkuZGlzYWJsZWRUb29sdGlwO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLy8gcmVzcG9uc2libGUgZm9yIHVwZGF0aW5nIHRoZSBzdGF0ZSBvZiB0aGUgY29tcG9uZW50XG4gICAgcmVmcmVzaCgpOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgfVxufVxuIiwiPGRpdiBbY2xhc3MuZGlzYWJsZWRdPVwicXVlcnk/LmlzRGlzYWJsZWQ/LihkYXRhKVwiIFtkclRvb2x0aXBdPVwiZGlzYWJsZWRUb29sdGlwXCIgY2xhc3M9XCJ1aS1ncmlkLWNlbGwtY29udGVudHMgY2VsbC1zZXQtYXMtZGVmYXVsdFwiPlxuICAgIDxkaXYgW2NsYXNzXT1cImRhdGFba2V5XSA/ICdkci1pY29uLWZhdm9yaXRlLW9uJyA6ICdkci1pY29uLWZhdm9yaXRlLW9mZidcIiBbZHJUb29sdGlwXT1cIiFkYXRhW2tleV0gPyB0b29sdGlwTXNnIDogJydcIj48L2Rpdj5cbjwvZGl2PlxuIl19