@sisense/sdk-ui-angular 1.33.0 → 2.0.0

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 (154) hide show
  1. package/dist/ai/lib/component-wrapper-helpers/context-connectors.d.ts +2 -2
  2. package/dist/ai/lib/components/chatbot.component.d.ts +2 -8
  3. package/dist/ai/lib/components/get-nlg-insights.component.d.ts +2 -8
  4. package/dist/ai/lib/sdk-ai.module.d.ts +0 -2
  5. package/dist/ai/lib/sdk-ui-core-exports.d.ts +1 -1
  6. package/dist/ai/lib/services/ai.service.d.ts +12 -8
  7. package/dist/ai/public-api.d.ts +2 -2
  8. package/dist/esm2020/ai/lib/component-wrapper-helpers/context-connectors.mjs +15 -9
  9. package/dist/esm2020/ai/lib/components/chatbot.component.mjs +9 -16
  10. package/dist/esm2020/ai/lib/components/get-nlg-insights.component.mjs +9 -16
  11. package/dist/esm2020/ai/lib/sdk-ai.module.mjs +2 -4
  12. package/dist/esm2020/ai/lib/sdk-ui-core-exports.mjs +1 -1
  13. package/dist/esm2020/ai/lib/services/ai.service.mjs +4 -9
  14. package/dist/esm2020/ai/public-api.mjs +3 -3
  15. package/dist/esm2020/lib/component-wrapper-helpers/context-connectors.mjs +60 -36
  16. package/dist/esm2020/lib/components/charts/area-chart.component.mjs +1 -2
  17. package/dist/esm2020/lib/components/charts/area-range-chart.component.mjs +1 -3
  18. package/dist/esm2020/lib/components/charts/areamap-chart.component.mjs +1 -2
  19. package/dist/esm2020/lib/components/charts/bar-chart.component.mjs +1 -2
  20. package/dist/esm2020/lib/components/charts/boxplot-chart.component.mjs +1 -2
  21. package/dist/esm2020/lib/components/charts/chart.component.mjs +8 -10
  22. package/dist/esm2020/lib/components/charts/column-chart.component.mjs +1 -2
  23. package/dist/esm2020/lib/components/charts/funnel-chart.component.mjs +1 -2
  24. package/dist/esm2020/lib/components/charts/index.mjs +13 -13
  25. package/dist/esm2020/lib/components/charts/indicator-chart.component.mjs +1 -2
  26. package/dist/esm2020/lib/components/charts/line-chart.component.mjs +1 -2
  27. package/dist/esm2020/lib/components/charts/pie-chart.component.mjs +1 -2
  28. package/dist/esm2020/lib/components/charts/pivot-table.component.mjs +8 -9
  29. package/dist/esm2020/lib/components/charts/polar-chart.component.mjs +1 -2
  30. package/dist/esm2020/lib/components/charts/scatter-chart.component.mjs +1 -2
  31. package/dist/esm2020/lib/components/charts/scattermap-chart.component.mjs +1 -1
  32. package/dist/esm2020/lib/components/charts/sunburst-chart.component.mjs +1 -2
  33. package/dist/esm2020/lib/components/charts/table.component.mjs +8 -10
  34. package/dist/esm2020/lib/components/charts/treemap-chart.component.mjs +1 -2
  35. package/dist/esm2020/lib/components/context-menu.component.mjs +9 -9
  36. package/dist/esm2020/lib/components/dashboard/dashboard-by-id.component.mjs +8 -9
  37. package/dist/esm2020/lib/components/dashboard/dashboard.component.mjs +10 -10
  38. package/dist/esm2020/lib/components/dashboard/index.mjs +2 -2
  39. package/dist/esm2020/lib/components/drilldown-breadcrumbs.component.mjs +8 -9
  40. package/dist/esm2020/lib/components/filters/criteria-filter-tile.component.mjs +8 -9
  41. package/dist/esm2020/lib/components/filters/date-range-filter-tile.component.mjs +8 -9
  42. package/dist/esm2020/lib/components/filters/filter-tile.component.mjs +147 -0
  43. package/dist/esm2020/lib/components/filters/index.mjs +4 -3
  44. package/dist/esm2020/lib/components/filters/member-filter-tile.component.mjs +9 -10
  45. package/dist/esm2020/lib/components/filters/relative-date-filter-tile.component.mjs +8 -9
  46. package/dist/esm2020/lib/components/index.mjs +4 -4
  47. package/dist/esm2020/lib/components/widgets/chart-widget.component.mjs +9 -11
  48. package/dist/esm2020/lib/components/widgets/drilldown-widget.component.mjs +19 -23
  49. package/dist/esm2020/lib/components/widgets/index.mjs +5 -5
  50. package/dist/esm2020/lib/components/widgets/pivot-table-widget.component.mjs +8 -9
  51. package/dist/esm2020/lib/components/widgets/table-widget.component.mjs +8 -9
  52. package/dist/esm2020/lib/components/widgets/widget-by-id.component.mjs +8 -9
  53. package/dist/esm2020/lib/components/widgets/widget.component.mjs +168 -0
  54. package/dist/esm2020/lib/decorators/decorators.module.mjs +1 -1
  55. package/dist/esm2020/lib/decorators/index.mjs +2 -2
  56. package/dist/esm2020/lib/decorators/trackable.decorator.mjs +2 -2
  57. package/dist/esm2020/lib/helpers/dashboard-props-preact-translator.mjs +14 -0
  58. package/dist/esm2020/lib/helpers/event-emitter-with-has-listeners.mjs +31 -0
  59. package/dist/esm2020/lib/helpers/index.mjs +2 -0
  60. package/dist/esm2020/lib/helpers/widget-props-preact-translator.mjs +37 -0
  61. package/dist/esm2020/lib/sdk-ui-core-exports.mjs +1 -1
  62. package/dist/esm2020/lib/sdk-ui.module.mjs +13 -10
  63. package/dist/esm2020/lib/services/dashboard.service.mjs +86 -2
  64. package/dist/esm2020/lib/services/hierarchy.service.mjs +1 -1
  65. package/dist/esm2020/lib/services/index.mjs +4 -4
  66. package/dist/esm2020/lib/services/plugins.service.mjs +1 -1
  67. package/dist/esm2020/lib/services/query.service.mjs +35 -6
  68. package/dist/esm2020/lib/services/sisense-context.service.mjs +1 -1
  69. package/dist/esm2020/lib/services/theme.service.mjs +2 -2
  70. package/dist/esm2020/lib/services/widget.service.mjs +1 -1
  71. package/dist/esm2020/lib/types/chart-event-props.mjs +1 -1
  72. package/dist/esm2020/lib/types/dashboard-config.mjs +1 -1
  73. package/dist/esm2020/lib/types/data-point.mjs +1 -1
  74. package/dist/esm2020/lib/types/filter-event-props.mjs +2 -0
  75. package/dist/esm2020/lib/types/index.mjs +4 -3
  76. package/dist/esm2020/lib/utilities/dashboard-helpers.mjs +2 -15
  77. package/dist/esm2020/lib/utilities/dashboard-model-translator.mjs +1 -1
  78. package/dist/esm2020/lib/utilities/widget-model-translator.mjs +1 -1
  79. package/dist/esm2020/public-api.mjs +4 -4
  80. package/dist/esm2020/version.mjs +2 -2
  81. package/dist/fesm2015/sisense-sdk-ui-angular-ai.mjs +32 -49
  82. package/dist/fesm2015/sisense-sdk-ui-angular-ai.mjs.map +1 -1
  83. package/dist/fesm2015/sisense-sdk-ui-angular.mjs +2545 -2221
  84. package/dist/fesm2015/sisense-sdk-ui-angular.mjs.map +1 -1
  85. package/dist/fesm2020/sisense-sdk-ui-angular-ai.mjs +32 -47
  86. package/dist/fesm2020/sisense-sdk-ui-angular-ai.mjs.map +1 -1
  87. package/dist/fesm2020/sisense-sdk-ui-angular.mjs +2571 -2216
  88. package/dist/fesm2020/sisense-sdk-ui-angular.mjs.map +1 -1
  89. package/dist/lib/component-wrapper-helpers/context-connectors.d.ts +5 -5
  90. package/dist/lib/components/charts/area-chart.component.d.ts +1 -3
  91. package/dist/lib/components/charts/area-range-chart.component.d.ts +1 -4
  92. package/dist/lib/components/charts/areamap-chart.component.d.ts +5 -8
  93. package/dist/lib/components/charts/bar-chart.component.d.ts +1 -3
  94. package/dist/lib/components/charts/boxplot-chart.component.d.ts +7 -9
  95. package/dist/lib/components/charts/chart.component.d.ts +4 -6
  96. package/dist/lib/components/charts/column-chart.component.d.ts +1 -3
  97. package/dist/lib/components/charts/funnel-chart.component.d.ts +1 -3
  98. package/dist/lib/components/charts/index.d.ts +12 -12
  99. package/dist/lib/components/charts/indicator-chart.component.d.ts +3 -5
  100. package/dist/lib/components/charts/line-chart.component.d.ts +1 -3
  101. package/dist/lib/components/charts/pie-chart.component.d.ts +1 -3
  102. package/dist/lib/components/charts/pivot-table.component.d.ts +1 -1
  103. package/dist/lib/components/charts/polar-chart.component.d.ts +1 -3
  104. package/dist/lib/components/charts/scatter-chart.component.d.ts +7 -9
  105. package/dist/lib/components/charts/scattermap-chart.component.d.ts +5 -7
  106. package/dist/lib/components/charts/sunburst-chart.component.d.ts +1 -3
  107. package/dist/lib/components/charts/table.component.d.ts +1 -3
  108. package/dist/lib/components/charts/treemap-chart.component.d.ts +1 -3
  109. package/dist/lib/components/context-menu.component.d.ts +1 -1
  110. package/dist/lib/components/dashboard/dashboard-by-id.component.d.ts +2 -2
  111. package/dist/lib/components/dashboard/dashboard.component.d.ts +7 -2
  112. package/dist/lib/components/dashboard/index.d.ts +1 -1
  113. package/dist/lib/components/drilldown-breadcrumbs.component.d.ts +1 -1
  114. package/dist/lib/components/filters/criteria-filter-tile.component.d.ts +1 -1
  115. package/dist/lib/components/filters/date-range-filter-tile.component.d.ts +1 -1
  116. package/dist/lib/components/filters/filter-tile.component.d.ts +125 -0
  117. package/dist/lib/components/filters/index.d.ts +3 -2
  118. package/dist/lib/components/filters/member-filter-tile.component.d.ts +2 -2
  119. package/dist/lib/components/filters/relative-date-filter-tile.component.d.ts +1 -1
  120. package/dist/lib/components/index.d.ts +3 -3
  121. package/dist/lib/components/widgets/chart-widget.component.d.ts +5 -7
  122. package/dist/lib/components/widgets/drilldown-widget.component.d.ts +3 -13
  123. package/dist/lib/components/widgets/index.d.ts +4 -4
  124. package/dist/lib/components/widgets/pivot-table-widget.component.d.ts +1 -1
  125. package/dist/lib/components/widgets/table-widget.component.d.ts +1 -1
  126. package/dist/lib/components/widgets/widget-by-id.component.d.ts +1 -2
  127. package/dist/lib/components/widgets/widget.component.d.ts +209 -0
  128. package/dist/lib/decorators/index.d.ts +1 -1
  129. package/dist/lib/helpers/dashboard-props-preact-translator.d.ts +4 -0
  130. package/dist/lib/helpers/event-emitter-with-has-listeners.d.ts +24 -0
  131. package/dist/lib/helpers/index.d.ts +1 -0
  132. package/dist/lib/helpers/widget-props-preact-translator.d.ts +4 -0
  133. package/dist/lib/sdk-ui-core-exports.d.ts +1 -1
  134. package/dist/lib/sdk-ui.module.d.ts +20 -20
  135. package/dist/lib/services/dashboard.service.d.ts +79 -1
  136. package/dist/lib/services/hierarchy.service.d.ts +1 -1
  137. package/dist/lib/services/index.d.ts +3 -3
  138. package/dist/lib/services/plugins.service.d.ts +1 -1
  139. package/dist/lib/services/query.service.d.ts +17 -8
  140. package/dist/lib/services/sisense-context.service.d.ts +1 -1
  141. package/dist/lib/services/theme.service.d.ts +1 -1
  142. package/dist/lib/types/chart-event-props.d.ts +9 -10
  143. package/dist/lib/types/dashboard-config.d.ts +1 -1
  144. package/dist/lib/types/data-point.d.ts +18 -11
  145. package/dist/lib/types/filter-event-props.d.ts +35 -0
  146. package/dist/lib/types/index.d.ts +3 -2
  147. package/dist/lib/utilities/dashboard-helpers.d.ts +1 -12
  148. package/dist/lib/utilities/widget-model-translator.d.ts +2 -2
  149. package/dist/package.json +4 -4
  150. package/dist/public-api.d.ts +4 -4
  151. package/dist/version.d.ts +1 -1
  152. package/package.json +10 -10
  153. package/dist/esm2020/lib/components/widgets/dashboard-widget.component.mjs +0 -118
  154. package/dist/lib/components/widgets/dashboard-widget.component.d.ts +0 -120
@@ -0,0 +1,147 @@
1
+ import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
+ import { ComponentAdapter, FilterTile as FilterTilePreact, } from '@sisense/sdk-ui-preact';
3
+ import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
4
+ import { rootId, template } from '../../component-wrapper-helpers/template';
5
+ import { EventEmitterWithHasListeners } from '../../helpers';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../../services/sisense-context.service";
8
+ import * as i2 from "../../services/theme.service";
9
+ /**
10
+ * UI component that renders a filter tile based on filter type
11
+ *
12
+ * @example
13
+ * Here’s how to render a filter model as a filter tile.
14
+ *
15
+ * ```html
16
+ <!--Component HTML template in example.component.html-->
17
+ <csdk-filter-tile
18
+ [filter]="filterTileProps.filter"
19
+ (filterChange)="filterTileProps.filterChange($event)"
20
+ />
21
+ * ```
22
+ *
23
+ * ```ts
24
+ // Component behavior in example.component.ts
25
+ import { Component } from '@angular/core';
26
+ import { type FilterTileProps } from '@sisense/sdk-ui-angular';
27
+ import { filterFactory } from '@sisense/sdk-data';
28
+ import * as DM from '../../assets/sample-healthcare-model';
29
+
30
+ @Component({
31
+ selector: 'example',
32
+ templateUrl: './example.component.html',
33
+ styleUrls: ['./example.component.scss'],
34
+ })
35
+ export class ExampleComponent {
36
+ filterTileProps: FilterTileProps = {
37
+ filter: filterFactory.members(DM.ER.Date.Years, ['2013-01-01T00:00:00']),
38
+ filterChange({ filter }) {
39
+ if (filter) {
40
+ this.filter = filter;
41
+ }
42
+ },
43
+ };
44
+ }
45
+ * ```
46
+ * <img src="media://angular-member-filter-tile-example.png" width="225px" />
47
+ * @group Filter Tiles
48
+ * @shortDescription Facade component rendering a filter tile based on filter type
49
+ */
50
+ export class FilterTileComponent {
51
+ /**
52
+ * Constructor for the `FilterTileComponent`.
53
+ *
54
+ * @param sisenseContextService - Sisense context service
55
+ * @param themeService - Theme service
56
+ */
57
+ constructor(
58
+ /**
59
+ * Sisense context service
60
+ *
61
+ * @category Constructor
62
+ */
63
+ sisenseContextService,
64
+ /**
65
+ * Theme service
66
+ *
67
+ * @category Constructor
68
+ */
69
+ themeService) {
70
+ this.sisenseContextService = sisenseContextService;
71
+ this.themeService = themeService;
72
+ /**
73
+ * {@inheritDoc FilterTileProps.filterChange}
74
+ */
75
+ this.filterChange = new EventEmitter();
76
+ /**
77
+ * {@inheritDoc FilterTileProps.filterEdit}
78
+ */
79
+ this.filterEdit = new EventEmitterWithHasListeners();
80
+ /**
81
+ * {@inheritDoc FilterTileProps.filterDelete}
82
+ */
83
+ this.filterDelete = new EventEmitterWithHasListeners();
84
+ this.componentAdapter = new ComponentAdapter(FilterTilePreact, [
85
+ createSisenseContextConnector(this.sisenseContextService),
86
+ createThemeContextConnector(this.themeService),
87
+ ]);
88
+ }
89
+ /**
90
+ * @internal
91
+ */
92
+ ngAfterViewInit() {
93
+ this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());
94
+ }
95
+ /**
96
+ * @internal
97
+ */
98
+ ngOnChanges() {
99
+ if (this.preactRef) {
100
+ this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());
101
+ }
102
+ }
103
+ getPreactComponentProps() {
104
+ const hasFilterEditListeners = this.filterEdit
105
+ .hasListeners;
106
+ const hasFilterDeleteListeners = this.filterDelete
107
+ .hasListeners;
108
+ return {
109
+ filter: this.filter,
110
+ defaultDataSource: this.defaultDataSource,
111
+ onChange: (...[filter]) => this.filterChange.emit({ filter }),
112
+ ...(hasFilterEditListeners && {
113
+ onEdit: (...[levelIndex]) => this.filterEdit.emit({ levelIndex }),
114
+ }),
115
+ ...(hasFilterDeleteListeners && { onDelete: () => this.filterDelete.emit() }),
116
+ };
117
+ }
118
+ /**
119
+ * @internal
120
+ */
121
+ ngOnDestroy() {
122
+ this.componentAdapter.destroy();
123
+ }
124
+ }
125
+ FilterTileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FilterTileComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
126
+ FilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: FilterTileComponent, selector: "csdk-filter-tile", inputs: { filter: "filter", defaultDataSource: "defaultDataSource" }, outputs: { filterChange: "filterChange", filterEdit: "filterEdit", filterDelete: "filterDelete" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact style=\"width: 100%; height: 100%\"></div>\n", isInline: true });
127
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FilterTileComponent, decorators: [{
128
+ type: Component,
129
+ args: [{
130
+ selector: 'csdk-filter-tile',
131
+ template,
132
+ }]
133
+ }], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
134
+ type: ViewChild,
135
+ args: [rootId]
136
+ }], filter: [{
137
+ type: Input
138
+ }], defaultDataSource: [{
139
+ type: Input
140
+ }], filterChange: [{
141
+ type: Output
142
+ }], filterEdit: [{
143
+ type: Output
144
+ }], filterDelete: [{
145
+ type: Output
146
+ }] } });
147
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/filter-tile.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  FilterTile as FilterTilePreact,\n  type FilterTileProps as FilterTilePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { rootId, template } from '../../component-wrapper-helpers/template';\nimport { EventEmitterWithHasListeners } from '../../helpers';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type {\n  Arguments,\n  BaseFilterTileEventProps,\n  FilterChangeEvent,\n  FilterEditEvent,\n} from '../../types';\n\n/**\n * Props of the {@link FilterTileComponent}.\n */\nexport interface FilterTileProps\n  extends Omit<FilterTilePropsPreact, 'onChange' | 'onEdit' | 'onDelete'>,\n    BaseFilterTileEventProps {}\n\n/**\n * UI component that renders a filter tile based on filter type\n *\n * @example\n * Here’s how to render a filter model as a filter tile.\n *\n * ```html\n<!--Component HTML template in example.component.html-->\n<csdk-filter-tile\n  [filter]=\"filterTileProps.filter\"\n  (filterChange)=\"filterTileProps.filterChange($event)\"\n/>\n * ```\n *\n * ```ts\n// Component behavior in example.component.ts\nimport { Component } from '@angular/core';\nimport { type FilterTileProps } from '@sisense/sdk-ui-angular';\nimport { filterFactory } from '@sisense/sdk-data';\nimport * as DM from '../../assets/sample-healthcare-model';\n\n@Component({\n  selector: 'example',\n  templateUrl: './example.component.html',\n  styleUrls: ['./example.component.scss'],\n})\nexport class ExampleComponent {\n  filterTileProps: FilterTileProps = {\n    filter: filterFactory.members(DM.ER.Date.Years, ['2013-01-01T00:00:00']),\n    filterChange({ filter }) {\n      if (filter) {\n        this.filter = filter;\n      }\n    },\n  };\n}\n * ```\n * <img src=\"media://angular-member-filter-tile-example.png\" width=\"225px\" />\n * @group Filter Tiles\n * @shortDescription Facade component rendering a filter tile based on filter type\n */\n@Component({\n  selector: 'csdk-filter-tile',\n  template,\n})\nexport class FilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!FilterTileProps.filter}\n   */\n  @Input()\n  filter!: FilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!FilterTileProps.defaultDataSource}\n   */\n  @Input()\n  defaultDataSource: FilterTileProps['defaultDataSource'];\n\n  /**\n   * {@inheritDoc FilterTileProps.filterChange}\n   */\n  @Output()\n  filterChange = new EventEmitter<FilterChangeEvent>();\n\n  /**\n   * {@inheritDoc FilterTileProps.filterEdit}\n   */\n  @Output()\n  filterEdit: EventEmitter<FilterEditEvent> = new EventEmitterWithHasListeners<FilterEditEvent>();\n\n  /**\n   * {@inheritDoc FilterTileProps.filterDelete}\n   */\n  @Output()\n  filterDelete: EventEmitter<void> = new EventEmitterWithHasListeners();\n\n  private componentAdapter: ComponentAdapter<typeof FilterTilePreact>;\n\n  /**\n   * Constructor for the `FilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(FilterTilePreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): FilterTilePropsPreact {\n    const hasFilterEditListeners = (this.filterEdit as EventEmitterWithHasListeners<unknown>)\n      .hasListeners;\n    const hasFilterDeleteListeners = (this.filterDelete as EventEmitterWithHasListeners<unknown>)\n      .hasListeners;\n\n    return {\n      filter: this.filter,\n      defaultDataSource: this.defaultDataSource,\n      onChange: (...[filter]: Arguments<FilterTilePropsPreact['onChange']>) =>\n        this.filterChange.emit({ filter }),\n      ...(hasFilterEditListeners && {\n        onEdit: (...[levelIndex]: Arguments<FilterTilePropsPreact['onEdit']>) =>\n          this.filterEdit.emit({ levelIndex }),\n      }),\n      ...(hasFilterDeleteListeners && { onDelete: () => this.filterDelete.emit() }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
@@ -1,5 +1,6 @@
1
- export * from './member-filter-tile.component';
1
+ export * from './criteria-filter-tile.component';
2
2
  export * from './date-range-filter-tile.component';
3
+ export * from './filter-tile.component';
4
+ export * from './member-filter-tile.component';
3
5
  export * from './relative-date-filter-tile.component';
4
- export * from './criteria-filter-tile.component';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZmlsdGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLGtDQUFrQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9tZW1iZXItZmlsdGVyLXRpbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZGF0ZS1yYW5nZS1maWx0ZXItdGlsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9yZWxhdGl2ZS1kYXRlLWZpbHRlci10aWxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NyaXRlcmlhLWZpbHRlci10aWxlLmNvbXBvbmVudCc7XG4iXX0=
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZmlsdGVycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsdUNBQXVDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NyaXRlcmlhLWZpbHRlci10aWxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2RhdGUtcmFuZ2UtZmlsdGVyLXRpbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmlsdGVyLXRpbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbWVtYmVyLWZpbHRlci10aWxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3JlbGF0aXZlLWRhdGUtZmlsdGVyLXRpbGUuY29tcG9uZW50JztcbiJdfQ==
@@ -1,7 +1,7 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
- import { MemberFilterTile, ComponentAdapter, createElement, } from '@sisense/sdk-ui-preact';
2
+ import { ComponentAdapter, MemberFilterTile as MemberFilterTilePreact, } from '@sisense/sdk-ui-preact';
3
3
  import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
4
- import { template, rootId } from '../../component-wrapper-helpers/template';
4
+ import { rootId, template } from '../../component-wrapper-helpers/template';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../../services/sisense-context.service";
7
7
  import * as i2 from "../../services/theme.service";
@@ -39,7 +39,7 @@ import * as i2 from "../../services/theme.service";
39
39
  * };
40
40
  * }
41
41
  * ```
42
- * <img src="media://angular-member-filter-tile-example.png" width="400px" />
42
+ * <img src="media://angular-member-filter-tile-example.png" width="225px" />
43
43
  * @group Filter Tiles
44
44
  */
45
45
  export class MemberFilterTileComponent {
@@ -68,7 +68,7 @@ export class MemberFilterTileComponent {
68
68
  * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.onChange}
69
69
  */
70
70
  this.filterChange = new EventEmitter();
71
- this.componentAdapter = new ComponentAdapter(() => this.createPreactComponent(), [
71
+ this.componentAdapter = new ComponentAdapter(MemberFilterTilePreact, [
72
72
  createSisenseContextConnector(this.sisenseContextService),
73
73
  createThemeContextConnector(this.themeService),
74
74
  ]);
@@ -77,25 +77,24 @@ export class MemberFilterTileComponent {
77
77
  * @internal
78
78
  */
79
79
  ngAfterViewInit() {
80
- this.componentAdapter.render(this.preactRef.nativeElement);
80
+ this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());
81
81
  }
82
82
  /**
83
83
  * @internal
84
84
  */
85
85
  ngOnChanges() {
86
86
  if (this.preactRef) {
87
- this.componentAdapter.render(this.preactRef.nativeElement);
87
+ this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());
88
88
  }
89
89
  }
90
- createPreactComponent() {
91
- const props = {
90
+ getPreactComponentProps() {
91
+ return {
92
92
  title: this.title,
93
93
  dataSource: this.dataSource,
94
94
  attribute: this.attribute,
95
95
  filter: this.filter,
96
96
  onChange: (...[filter]) => this.filterChange.emit({ filter }),
97
97
  };
98
- return createElement(MemberFilterTile, props);
99
98
  }
100
99
  /**
101
100
  * @internal
@@ -126,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
126
125
  }], filterChange: [{
127
126
  type: Output
128
127
  }] } });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"member-filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/member-filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAEhB,gBAAgB,EAChB,aAAa,GACd,MAAM,wBAAwB,CAAC;AAIhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,GAC5B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,0CAA0C,CAAC;;;;AAS5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoCG;AAKH,MAAM,OAAO,yBAAyB;IAyCpC;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QA5BnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAE5B,CAAC;QAwBF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAC1C,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,EAAE,EAClC;YACE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;SAC5D;IACH,CAAC;IAEO,qBAAqB;QAC3B,MAAM,KAAK,GAAG;YACZ,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAAqD,EAAE,EAAE,CAC5E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;SACrC,CAAC;QAEF,OAAO,aAAa,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;IAChD,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;uHAxGU,yBAAyB;2GAAzB,yBAAyB;4FAAzB,yBAAyB;kBAJrC,SAAS;mBAAC;oBACT,QAAQ,EAAE,yBAAyB;oBACnC,QAAQ;iBACT;uIAMC,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,UAAU;sBADT,KAAK;gBAON,SAAS;sBADR,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  MemberFilterTile,\n  type MemberFilterTileProps as MemberFilterTilePropsPreact,\n  ComponentAdapter,\n  createElement,\n} from '@sisense/sdk-ui-preact';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { template, rootId } from '../../component-wrapper-helpers/template';\n\n/**\n * Props of the {@link MemberFilterTileComponent}.\n */\nexport interface MemberFilterTileProps extends Omit<MemberFilterTilePropsPreact, 'onChange'> {\n  filterChange?: (filter: Arguments<MemberFilterTilePropsPreact['onChange']>[0]) => void;\n}\n\n/**\n * Member Filter Tile Component\n *\n * @example\n * ```html\n *     <csdk-member-filter-tile\n *       title=\"Years Filter\"\n *       [attribute]=\"DM.ER.Date.Years\"\n *       [filter]=\"memberFilterTileProps.yearFilter\"\n *       (filterChange)=\"memberFilterTileProps.setYearFilter($event)\"\n *     />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { Filter, filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-filters',\n *   templateUrl: './filters.component.html',\n *   styleUrls: ['./filters.component.scss'],\n * })\n * export class FiltersComponent {\n *   DM = DM;\n *   memberFilterTileProps = {\n *     yearFilter: filterFactory.members(DM.ER.Date.Years, ['2013-01-01T00:00:00']),\n *     setYearFilter({ filter }: { filter: Filter | null }) {\n *       if (filter) {\n *         this.yearFilter = filter;\n *       }\n *     },\n *   };\n * }\n * ```\n * <img src=\"media://angular-member-filter-tile-example.png\" width=\"400px\" />\n * @group Filter Tiles\n */\n@Component({\n  selector: 'csdk-member-filter-tile',\n  template,\n})\nexport class MemberFilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.title}\n   */\n  @Input()\n  title!: MemberFilterTileProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.dataSource}\n   */\n  @Input()\n  dataSource: MemberFilterTileProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.attribute}\n   */\n  @Input()\n  attribute!: MemberFilterTileProps['attribute'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.filter}\n   */\n  @Input()\n  filter!: MemberFilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.onChange}\n   */\n  @Output()\n  filterChange = new EventEmitter<\n    ArgumentsAsObject<MemberFilterTilePropsPreact['onChange'], ['filter']>\n  >();\n\n  private componentAdapter: ComponentAdapter;\n\n  /**\n   * Constructor for the `MemberFilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(\n      () => this.createPreactComponent(),\n      [\n        createSisenseContextConnector(this.sisenseContextService),\n        createThemeContextConnector(this.themeService),\n      ],\n    );\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement);\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement);\n    }\n  }\n\n  private createPreactComponent() {\n    const props = {\n      title: this.title,\n      dataSource: this.dataSource,\n      attribute: this.attribute,\n      filter: this.filter,\n      onChange: (...[filter]: Arguments<MemberFilterTilePropsPreact['onChange']>) =>\n        this.filterChange.emit({ filter }),\n    };\n\n    return createElement(MemberFilterTile, props);\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"member-filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/member-filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,gBAAgB,IAAI,sBAAsB,GAE3C,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,GAC5B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,0CAA0C,CAAC;;;;AAY5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoCG;AAKH,MAAM,OAAO,yBAAyB;IAyCpC;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QA5BnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAE5B,CAAC;QAwBF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,sBAAsB,EAAE;YACnE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAAqD,EAAE,EAAE,CAC5E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;SACrC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;uHAnGU,yBAAyB;2GAAzB,yBAAyB;4FAAzB,yBAAyB;kBAJrC,SAAS;mBAAC;oBACT,QAAQ,EAAE,yBAAyB;oBACnC,QAAQ;iBACT;uIAMC,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,UAAU;sBADT,KAAK;gBAON,SAAS;sBADR,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  MemberFilterTile as MemberFilterTilePreact,\n  type MemberFilterTileProps as MemberFilterTilePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { rootId, template } from '../../component-wrapper-helpers/template';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\n\n/**\n * Props of the {@link MemberFilterTileComponent}.\n */\nexport interface MemberFilterTileProps extends Omit<MemberFilterTilePropsPreact, 'onChange'> {\n  filterChange?: (filter: Arguments<MemberFilterTilePropsPreact['onChange']>[0]) => void;\n}\n\n/**\n * Member Filter Tile Component\n *\n * @example\n * ```html\n *     <csdk-member-filter-tile\n *       title=\"Years Filter\"\n *       [attribute]=\"DM.ER.Date.Years\"\n *       [filter]=\"memberFilterTileProps.yearFilter\"\n *       (filterChange)=\"memberFilterTileProps.setYearFilter($event)\"\n *     />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { Filter, filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-filters',\n *   templateUrl: './filters.component.html',\n *   styleUrls: ['./filters.component.scss'],\n * })\n * export class FiltersComponent {\n *   DM = DM;\n *   memberFilterTileProps = {\n *     yearFilter: filterFactory.members(DM.ER.Date.Years, ['2013-01-01T00:00:00']),\n *     setYearFilter({ filter }: { filter: Filter | null }) {\n *       if (filter) {\n *         this.yearFilter = filter;\n *       }\n *     },\n *   };\n * }\n * ```\n * <img src=\"media://angular-member-filter-tile-example.png\" width=\"225px\" />\n * @group Filter Tiles\n */\n@Component({\n  selector: 'csdk-member-filter-tile',\n  template,\n})\nexport class MemberFilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.title}\n   */\n  @Input()\n  title!: MemberFilterTileProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.dataSource}\n   */\n  @Input()\n  dataSource: MemberFilterTileProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.attribute}\n   */\n  @Input()\n  attribute!: MemberFilterTileProps['attribute'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.filter}\n   */\n  @Input()\n  filter!: MemberFilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.onChange}\n   */\n  @Output()\n  filterChange = new EventEmitter<\n    ArgumentsAsObject<MemberFilterTilePropsPreact['onChange'], ['filter']>\n  >();\n\n  private componentAdapter: ComponentAdapter<typeof MemberFilterTilePreact>;\n\n  /**\n   * Constructor for the `MemberFilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(MemberFilterTilePreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): MemberFilterTilePropsPreact {\n    return {\n      title: this.title,\n      dataSource: this.dataSource,\n      attribute: this.attribute,\n      filter: this.filter,\n      onChange: (...[filter]: Arguments<MemberFilterTilePropsPreact['onChange']>) =>\n        this.filterChange.emit({ filter }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
- import { RelativeDateFilterTile, ComponentAdapter, createElement, } from '@sisense/sdk-ui-preact';
2
+ import { ComponentAdapter, RelativeDateFilterTile as RelativeDateFilterTilePreact, } from '@sisense/sdk-ui-preact';
3
3
  import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
4
- import { template, rootId } from '../../component-wrapper-helpers/template';
4
+ import { rootId, template } from '../../component-wrapper-helpers/template';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../../services/sisense-context.service";
7
7
  import * as i2 from "../../services/theme.service";
@@ -72,7 +72,7 @@ export class RelativeDateFilterTileComponent {
72
72
  * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.onUpdate}
73
73
  */
74
74
  this.filterChange = new EventEmitter();
75
- this.componentAdapter = new ComponentAdapter(() => this.createPreactComponent(), [
75
+ this.componentAdapter = new ComponentAdapter(RelativeDateFilterTilePreact, [
76
76
  createSisenseContextConnector(this.sisenseContextService),
77
77
  createThemeContextConnector(this.themeService),
78
78
  ]);
@@ -81,25 +81,24 @@ export class RelativeDateFilterTileComponent {
81
81
  * @internal
82
82
  */
83
83
  ngAfterViewInit() {
84
- this.componentAdapter.render(this.preactRef.nativeElement);
84
+ this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());
85
85
  }
86
86
  /**
87
87
  * @internal
88
88
  */
89
89
  ngOnChanges() {
90
90
  if (this.preactRef) {
91
- this.componentAdapter.render(this.preactRef.nativeElement);
91
+ this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());
92
92
  }
93
93
  }
94
- createPreactComponent() {
95
- const props = {
94
+ getPreactComponentProps() {
95
+ return {
96
96
  title: this.title,
97
97
  filter: this.filter,
98
98
  arrangement: this.arrangement,
99
99
  limit: this.limit,
100
100
  onUpdate: (...[filter]) => this.filterChange.emit({ filter }),
101
101
  };
102
- return createElement(RelativeDateFilterTile, props);
103
102
  }
104
103
  /**
105
104
  * @internal
@@ -130,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
130
129
  }], filterChange: [{
131
130
  type: Output
132
131
  }] } });
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relative-date-filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/relative-date-filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,sBAAsB,EAEtB,gBAAgB,EAChB,aAAa,GACd,MAAM,wBAAwB,CAAC;AAIhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,GAC5B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,0CAA0C,CAAC;;;;AAU5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAKH,MAAM,OAAO,+BAA+B;IAyC1C;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QA5BnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAE5B,CAAC;QAwBF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAC1C,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,EAAE,EAClC;YACE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;SAC5D;IACH,CAAC;IAEO,qBAAqB;QAC3B,MAAM,KAAK,GAAG;YACZ,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAA2D,EAAE,EAAE,CAClF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;SACrC,CAAC;QAEF,OAAO,aAAa,CAAC,sBAAsB,EAAE,KAAK,CAAC,CAAC;IACtD,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;6HAxGU,+BAA+B;iHAA/B,+BAA+B;4FAA/B,+BAA+B;kBAJ3C,SAAS;mBAAC;oBACT,QAAQ,EAAE,gCAAgC;oBAC1C,QAAQ;iBACT;uIAMC,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,WAAW;sBADV,KAAK;gBAON,KAAK;sBADJ,KAAK;gBAON,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  RelativeDateFilterTile,\n  type RelativeDateFilterTileProps as RelativeDateFilterTilePropsPreact,\n  ComponentAdapter,\n  createElement,\n} from '@sisense/sdk-ui-preact';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { template, rootId } from '../../component-wrapper-helpers/template';\n\n/**\n * Props of the {@link RelativeDateFilterTileComponent}.\n */\nexport interface RelativeDateFilterTileProps\n  extends Omit<RelativeDateFilterTilePropsPreact, 'onUpdate'> {\n  filterChange?: (filter: Arguments<RelativeDateFilterTilePropsPreact['onUpdate']>[0]) => void;\n}\n\n/**\n * Relative Date Filter Tile Component\n *\n * @example\n * ```html\n * <csdk-relative-date-filter-tile\n *       [title]=\"relativeDateFilterTileProps.title\"\n *       [arrangement]=\"relativeDateFilterTileProps.arrangement\"\n *       [filter]=\"relativeDateFilterTileProps.filter\"\n *       (filterChange)=\"relativeDateFilterTileProps.setFilter($event)\"\n *     />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { Filter, filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-filters',\n *   templateUrl: './filters.component.html',\n *   styleUrls: ['./filters.component.scss'],\n * })\n * export class FiltersComponent {\n *   DM = DM;\n *\n *   relativeDateFilterTileProps = {\n *     title: 'Relative Date Filter',\n *     arrangement: 'vertical',\n *     filter: filterFactory.dateRelativeTo(DM.ER.Date.Days, 0, 150),\n *     setFilter({ filter }: { filter: Filter | null }) {\n *       console.log(filter);\n *       if (filter) {\n *         this.filter = filter;\n *       }\n *     },\n *   };\n * }\n * ```\n * <img src=\"media://angular-relative-date-filter-tile-example.png\" width=\"600px\" />\n * @group Filter Tiles\n */\n@Component({\n  selector: 'csdk-relative-date-filter-tile',\n  template,\n})\nexport class RelativeDateFilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.title}\n   */\n  @Input()\n  title!: RelativeDateFilterTileProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.filter}\n   */\n  @Input()\n  filter!: RelativeDateFilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.arrangement}\n   */\n  @Input()\n  arrangement: RelativeDateFilterTileProps['arrangement'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.limit}\n   */\n  @Input()\n  limit: RelativeDateFilterTileProps['limit'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.onUpdate}\n   */\n  @Output()\n  filterChange = new EventEmitter<\n    ArgumentsAsObject<RelativeDateFilterTilePropsPreact['onUpdate'], ['filter']>\n  >();\n\n  private componentAdapter: ComponentAdapter;\n\n  /**\n   * Constructor for the `RelativeDateFilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(\n      () => this.createPreactComponent(),\n      [\n        createSisenseContextConnector(this.sisenseContextService),\n        createThemeContextConnector(this.themeService),\n      ],\n    );\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement);\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement);\n    }\n  }\n\n  private createPreactComponent() {\n    const props = {\n      title: this.title,\n      filter: this.filter,\n      arrangement: this.arrangement,\n      limit: this.limit,\n      onUpdate: (...[filter]: Arguments<RelativeDateFilterTilePropsPreact['onUpdate']>) =>\n        this.filterChange.emit({ filter }),\n    };\n\n    return createElement(RelativeDateFilterTile, props);\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relative-date-filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/relative-date-filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,sBAAsB,IAAI,4BAA4B,GAEvD,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,GAC5B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,0CAA0C,CAAC;;;;AAa5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAKH,MAAM,OAAO,+BAA+B;IAyC1C;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QA5BnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAE5B,CAAC;QAwBF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,4BAA4B,EAAE;YACzE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAA2D,EAAE,EAAE,CAClF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;SACrC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;6HAnGU,+BAA+B;iHAA/B,+BAA+B;4FAA/B,+BAA+B;kBAJ3C,SAAS;mBAAC;oBACT,QAAQ,EAAE,gCAAgC;oBAC1C,QAAQ;iBACT;uIAMC,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,WAAW;sBADV,KAAK;gBAON,KAAK;sBADJ,KAAK;gBAON,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  RelativeDateFilterTile as RelativeDateFilterTilePreact,\n  type RelativeDateFilterTileProps as RelativeDateFilterTilePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { rootId, template } from '../../component-wrapper-helpers/template';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\n\n/**\n * Props of the {@link RelativeDateFilterTileComponent}.\n */\nexport interface RelativeDateFilterTileProps\n  extends Omit<RelativeDateFilterTilePropsPreact, 'onUpdate'> {\n  filterChange?: (filter: Arguments<RelativeDateFilterTilePropsPreact['onUpdate']>[0]) => void;\n}\n\n/**\n * Relative Date Filter Tile Component\n *\n * @example\n * ```html\n * <csdk-relative-date-filter-tile\n *       [title]=\"relativeDateFilterTileProps.title\"\n *       [arrangement]=\"relativeDateFilterTileProps.arrangement\"\n *       [filter]=\"relativeDateFilterTileProps.filter\"\n *       (filterChange)=\"relativeDateFilterTileProps.setFilter($event)\"\n *     />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { Filter, filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-filters',\n *   templateUrl: './filters.component.html',\n *   styleUrls: ['./filters.component.scss'],\n * })\n * export class FiltersComponent {\n *   DM = DM;\n *\n *   relativeDateFilterTileProps = {\n *     title: 'Relative Date Filter',\n *     arrangement: 'vertical',\n *     filter: filterFactory.dateRelativeTo(DM.ER.Date.Days, 0, 150),\n *     setFilter({ filter }: { filter: Filter | null }) {\n *       console.log(filter);\n *       if (filter) {\n *         this.filter = filter;\n *       }\n *     },\n *   };\n * }\n * ```\n * <img src=\"media://angular-relative-date-filter-tile-example.png\" width=\"600px\" />\n * @group Filter Tiles\n */\n@Component({\n  selector: 'csdk-relative-date-filter-tile',\n  template,\n})\nexport class RelativeDateFilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.title}\n   */\n  @Input()\n  title!: RelativeDateFilterTileProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.filter}\n   */\n  @Input()\n  filter!: RelativeDateFilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.arrangement}\n   */\n  @Input()\n  arrangement: RelativeDateFilterTileProps['arrangement'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.limit}\n   */\n  @Input()\n  limit: RelativeDateFilterTileProps['limit'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.onUpdate}\n   */\n  @Output()\n  filterChange = new EventEmitter<\n    ArgumentsAsObject<RelativeDateFilterTilePropsPreact['onUpdate'], ['filter']>\n  >();\n\n  private componentAdapter: ComponentAdapter<typeof RelativeDateFilterTilePreact>;\n\n  /**\n   * Constructor for the `RelativeDateFilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(RelativeDateFilterTilePreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): RelativeDateFilterTilePropsPreact {\n    return {\n      title: this.title,\n      filter: this.filter,\n      arrangement: this.arrangement,\n      limit: this.limit,\n      onUpdate: (...[filter]: Arguments<RelativeDateFilterTilePropsPreact['onUpdate']>) =>\n        this.filterChange.emit({ filter }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
@@ -1,7 +1,7 @@
1
- export * from './filters';
2
1
  export * from './charts';
3
- export * from './widgets';
2
+ export * from './context-menu.component';
4
3
  export * from './dashboard';
5
4
  export * from './drilldown-breadcrumbs.component';
6
- export * from './context-menu.component';
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9maWx0ZXJzJztcbmV4cG9ydCAqIGZyb20gJy4vY2hhcnRzJztcbmV4cG9ydCAqIGZyb20gJy4vd2lkZ2V0cyc7XG5leHBvcnQgKiBmcm9tICcuL2Rhc2hib2FyZCc7XG5leHBvcnQgKiBmcm9tICcuL2RyaWxsZG93bi1icmVhZGNydW1icy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LW1lbnUuY29tcG9uZW50JztcbiJdfQ==
5
+ export * from './filters';
6
+ export * from './widgets';
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsV0FBVyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jaGFydHMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LW1lbnUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZGFzaGJvYXJkJztcbmV4cG9ydCAqIGZyb20gJy4vZHJpbGxkb3duLWJyZWFkY3J1bWJzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi93aWRnZXRzJztcbiJdfQ==
@@ -1,7 +1,7 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
- import { ChartWidget, ComponentAdapter, createElement, } from '@sisense/sdk-ui-preact';
2
+ import { ChartWidget as ChartWidgetPreact, ComponentAdapter, } from '@sisense/sdk-ui-preact';
3
3
  import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
4
- import { template, rootId } from '../../component-wrapper-helpers/template';
4
+ import { rootId, template } from '../../component-wrapper-helpers/template';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../../services/sisense-context.service";
7
7
  import * as i2 from "../../services/theme.service";
@@ -59,8 +59,7 @@ import * as i2 from "../../services/theme.service";
59
59
  *
60
60
  * }
61
61
  * ```
62
- * <img src="media://angular-chart-widget-example.png" width="800px" />
63
- *
62
+ * <img src="media://angular-chart-widget-example.png" width="500px" />
64
63
  * @group Dashboards
65
64
  */
66
65
  export class ChartWidgetComponent {
@@ -85,23 +84,23 @@ export class ChartWidgetComponent {
85
84
  * @category Callbacks
86
85
  */
87
86
  this.dataPointsSelect = new EventEmitter();
88
- this.componentAdapter = new ComponentAdapter(() => this.createPreactComponent(), [
87
+ this.componentAdapter = new ComponentAdapter(ChartWidgetPreact, [
89
88
  createSisenseContextConnector(this.sisenseContextService),
90
89
  createThemeContextConnector(this.themeService),
91
90
  ]);
92
91
  }
93
92
  /** @internal */
94
93
  ngAfterViewInit() {
95
- this.componentAdapter.render(this.preactRef.nativeElement);
94
+ this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());
96
95
  }
97
96
  /** @internal */
98
97
  ngOnChanges() {
99
98
  if (this.preactRef) {
100
- this.componentAdapter.render(this.preactRef.nativeElement);
99
+ this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());
101
100
  }
102
101
  }
103
- createPreactComponent() {
104
- const props = {
102
+ getPreactComponentProps() {
103
+ return {
105
104
  chartType: this.chartType,
106
105
  dataSource: this.dataSource,
107
106
  dataOptions: this.dataOptions,
@@ -118,7 +117,6 @@ export class ChartWidgetComponent {
118
117
  onDataPointContextMenu: (...[point, nativeEvent]) => this.dataPointContextMenu.emit({ point, nativeEvent }),
119
118
  onDataPointsSelected: (...[points, nativeEvent]) => this.dataPointsSelect.emit({ points, nativeEvent }),
120
119
  };
121
- return createElement(ChartWidget, props);
122
120
  }
123
121
  /** @internal */
124
122
  ngOnDestroy() {
@@ -167,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
167
165
  }], dataPointsSelect: [{
168
166
  type: Output
169
167
  }] } });
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/chart-widget.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ChartWidget,\n  type ChartWidgetProps as ChartWidgetPropsPreact,\n  ComponentAdapter,\n  createElement,\n} from '@sisense/sdk-ui-preact';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments } from '../../types/utility-types';\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { template, rootId } from '../../component-wrapper-helpers/template';\nimport { ChartEventProps, WithoutPreactChartEventProps } from '../../types/chart-event-props';\nimport { ChartDataPointEvent, ChartDataPointsEvent } from '../../types/data-point';\n\n/**\n * Props of the {@link ChartWidgetComponent}.\n */\nexport interface ChartWidgetProps\n  extends WithoutPreactChartEventProps<ChartWidgetPropsPreact>,\n    ChartEventProps {}\n\n/**\n * The Chart Widget component extending {@link ChartComponent} to support widget style options.\n *\n * @example\n * ```html\n * <csdk-chart-widget\n *   [chartType]=\"chartWidget.chartType\"\n *   [dataSource]=\"chartWidget.dataSource\"\n *   [dataOptions]=\"chartWidget.dataOptions\"\n *   [highlights]=\"filters\"\n *   [title]=\"chartWidget.title\"\n *   [description]=\"chartWidget.description\"\n *   [beforeRender]=\"onBeforeRender\"\n *   (dataPointClick)=\"logArguments($event)\"\n *   (dataPointContextMenu)=\"logArguments($event)\"\n *   (dataPointsSelect)=\"logArguments($event)\"\n * />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { ChartType } from '@sisense/sdk-ui-angular';\n * import { filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-widgets',\n *   templateUrl: './widgets.component.html',\n *   styleUrls: ['./widgets.component.scss'],\n * })\n * export class WidgetsComponent {\n *   filters = [filterFactory.members(DM.Divisions.Divison_name, ['Cardiology', 'Neurology'])];\n *   chartWidget = {\n *     chartType: 'column' as ChartType,\n *     dataSource: DM.DataSource,\n *     dataOptions: {\n *       category: [DM.Divisions.Divison_name],\n *       value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],\n *       breakBy: [],\n *     },\n *     title: 'Chart Title',\n *     description: 'Chart Description',\n *   };\n *  logArguments(...args: any[]) {\n *   console.log(args);\n * }\n *\n * onBeforeRender(options: any) {\n *   console.log('beforeRender');\n *   console.log(options);\n *   return options;\n * }\n *\n * }\n * ```\n * <img src=\"media://angular-chart-widget-example.png\" width=\"800px\" />\n *\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-chart-widget',\n  template,\n})\nexport class ChartWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.chartType}\n   *\n   * @category Chart\n   */\n  @Input()\n  chartType!: ChartWidgetProps['chartType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: ChartWidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataOptions}\n   *\n   * @category Chart\n   */\n  @Input()\n  dataOptions!: ChartWidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: ChartWidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: ChartWidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: ChartWidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.drilldownOptions}\n   *\n   * @category Widget\n   * @internal\n   */\n  @Input()\n  drilldownOptions: ChartWidgetProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: ChartWidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: ChartWidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   */\n  @Input()\n  highlightSelectionDisabled: ChartWidgetProps['highlightSelectionDisabled'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onBeforeRender}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  beforeRender: ChartWidgetProps['beforeRender'];\n\n  /**\n   * {@inheritDoc  @sisense/sdk-ui!ChartWidgetProps.onDataReady}\n   *\n   * @category Callbacks\n   * @internal\n   */\n  @Input()\n  dataReady: ChartWidgetProps['dataReady'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointClick}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointClick = new EventEmitter<ChartDataPointEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointContextMenu}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointContextMenu = new EventEmitter<ChartDataPointEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointsSelected}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointsSelect = new EventEmitter<ChartDataPointsEvent>();\n\n  private componentAdapter: ComponentAdapter;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(\n      () => this.createPreactComponent(),\n      [\n        createSisenseContextConnector(this.sisenseContextService),\n        createThemeContextConnector(this.themeService),\n      ],\n    );\n  }\n\n  /** @internal */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement);\n  }\n\n  /** @internal */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement);\n    }\n  }\n\n  private createPreactComponent() {\n    const props = {\n      chartType: this.chartType,\n      dataSource: this.dataSource,\n      dataOptions: this.dataOptions,\n      filters: this.filters,\n      highlights: this.highlights,\n      styleOptions: this.styleOptions,\n      drilldownOptions: this.drilldownOptions,\n      title: this.title,\n      description: this.description,\n      highlightSelectionDisabled: this.highlightSelectionDisabled,\n      onBeforeRender: this.beforeRender?.bind(this),\n      onDataReady: this.dataReady?.bind(this),\n      onDataPointClick: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointClick']>\n      ) => this.dataPointClick.emit({ point, nativeEvent }),\n      onDataPointContextMenu: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointContextMenu']>\n      ) => this.dataPointContextMenu.emit({ point, nativeEvent }),\n      onDataPointsSelected: (\n        ...[points, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointsSelected']>\n      ) => this.dataPointsSelect.emit({ points, nativeEvent }),\n    };\n\n    return createElement(ChartWidget, props);\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/chart-widget.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ChartWidget as ChartWidgetPreact,\n  type ChartWidgetProps as ChartWidgetPropsPreact,\n  ComponentAdapter,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { rootId, template } from '../../component-wrapper-helpers/template';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport { ChartEventProps, WithoutPreactChartEventProps } from '../../types/chart-event-props';\nimport {\n  ChartDataPointClickEvent,\n  ChartDataPointContextMenuEvent,\n  ChartDataPointsEvent,\n} from '../../types/data-point';\nimport type { Arguments } from '../../types/utility-types';\n\n/**\n * Props of the {@link ChartWidgetComponent}.\n */\nexport interface ChartWidgetProps\n  extends WithoutPreactChartEventProps<ChartWidgetPropsPreact>,\n    ChartEventProps {}\n\n/**\n * The Chart Widget component extending {@link ChartComponent} to support widget style options.\n *\n * @example\n * ```html\n * <csdk-chart-widget\n *   [chartType]=\"chartWidget.chartType\"\n *   [dataSource]=\"chartWidget.dataSource\"\n *   [dataOptions]=\"chartWidget.dataOptions\"\n *   [highlights]=\"filters\"\n *   [title]=\"chartWidget.title\"\n *   [description]=\"chartWidget.description\"\n *   [beforeRender]=\"onBeforeRender\"\n *   (dataPointClick)=\"logArguments($event)\"\n *   (dataPointContextMenu)=\"logArguments($event)\"\n *   (dataPointsSelect)=\"logArguments($event)\"\n * />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { ChartType } from '@sisense/sdk-ui-angular';\n * import { filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-widgets',\n *   templateUrl: './widgets.component.html',\n *   styleUrls: ['./widgets.component.scss'],\n * })\n * export class WidgetsComponent {\n *   filters = [filterFactory.members(DM.Divisions.Divison_name, ['Cardiology', 'Neurology'])];\n *   chartWidget = {\n *     chartType: 'column' as ChartType,\n *     dataSource: DM.DataSource,\n *     dataOptions: {\n *       category: [DM.Divisions.Divison_name],\n *       value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],\n *       breakBy: [],\n *     },\n *     title: 'Chart Title',\n *     description: 'Chart Description',\n *   };\n *  logArguments(...args: any[]) {\n *   console.log(args);\n * }\n *\n * onBeforeRender(options: any) {\n *   console.log('beforeRender');\n *   console.log(options);\n *   return options;\n * }\n *\n * }\n * ```\n * <img src=\"media://angular-chart-widget-example.png\" width=\"500px\" />\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-chart-widget',\n  template,\n})\nexport class ChartWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.chartType}\n   *\n   * @category Chart\n   */\n  @Input()\n  chartType!: ChartWidgetProps['chartType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: ChartWidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataOptions}\n   *\n   * @category Chart\n   */\n  @Input()\n  dataOptions!: ChartWidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: ChartWidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: ChartWidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: ChartWidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.drilldownOptions}\n   *\n   * @category Widget\n   * @internal\n   */\n  @Input()\n  drilldownOptions: ChartWidgetProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: ChartWidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: ChartWidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   */\n  @Input()\n  highlightSelectionDisabled: ChartWidgetProps['highlightSelectionDisabled'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onBeforeRender}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  beforeRender: ChartWidgetProps['beforeRender'];\n\n  /**\n   * {@inheritDoc  @sisense/sdk-ui!ChartWidgetProps.onDataReady}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  dataReady: ChartWidgetProps['dataReady'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointClick}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointClick = new EventEmitter<ChartDataPointClickEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointContextMenu}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointContextMenu = new EventEmitter<ChartDataPointContextMenuEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointsSelected}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointsSelect = new EventEmitter<ChartDataPointsEvent>();\n\n  private componentAdapter: ComponentAdapter<typeof ChartWidgetPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(ChartWidgetPreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /** @internal */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /** @internal */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): ChartWidgetPropsPreact {\n    return {\n      chartType: this.chartType,\n      dataSource: this.dataSource,\n      dataOptions: this.dataOptions,\n      filters: this.filters,\n      highlights: this.highlights,\n      styleOptions: this.styleOptions,\n      drilldownOptions: this.drilldownOptions,\n      title: this.title,\n      description: this.description,\n      highlightSelectionDisabled: this.highlightSelectionDisabled,\n      onBeforeRender: this.beforeRender?.bind(this),\n      onDataReady: this.dataReady?.bind(this),\n      onDataPointClick: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointClick']>\n      ) => this.dataPointClick.emit({ point, nativeEvent } as ChartDataPointClickEvent),\n      onDataPointContextMenu: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointContextMenu']>\n      ) => this.dataPointContextMenu.emit({ point, nativeEvent } as ChartDataPointContextMenuEvent),\n      onDataPointsSelected: (\n        ...[points, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointsSelected']>\n      ) => this.dataPointsSelect.emit({ points, nativeEvent } as ChartDataPointsEvent),\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}