@sisense/sdk-ui-angular 2.16.1 → 2.18.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 (31) hide show
  1. package/dist/esm2020/lib/components/charts/pivot-table.component.mjs +28 -5
  2. package/dist/esm2020/lib/components/widgets/pivot-table-widget.component.mjs +25 -5
  3. package/dist/esm2020/lib/components/widgets/widget.component.mjs +1 -1
  4. package/dist/esm2020/lib/helpers/widget-props-preact-translator.mjs +5 -2
  5. package/dist/esm2020/lib/sdk-ui-core-exports.mjs +1 -1
  6. package/dist/esm2020/lib/services/dashboard.service.mjs +18 -6
  7. package/dist/esm2020/lib/services/query.service.mjs +1 -2
  8. package/dist/esm2020/lib/services/widget.service.mjs +146 -6
  9. package/dist/esm2020/lib/types/chart-event-props.mjs +1 -1
  10. package/dist/esm2020/lib/types/data-point.mjs +1 -1
  11. package/dist/esm2020/lib/utilities/widget-model-translator.mjs +52 -1
  12. package/dist/esm2020/public-api.mjs +1 -1
  13. package/dist/esm2020/version.mjs +2 -2
  14. package/dist/fesm2015/sisense-sdk-ui-angular.mjs +265 -20
  15. package/dist/fesm2015/sisense-sdk-ui-angular.mjs.map +1 -1
  16. package/dist/fesm2020/sisense-sdk-ui-angular.mjs +265 -20
  17. package/dist/fesm2020/sisense-sdk-ui-angular.mjs.map +1 -1
  18. package/dist/lib/components/charts/pivot-table.component.d.ts +23 -5
  19. package/dist/lib/components/widgets/pivot-table-widget.component.d.ts +23 -5
  20. package/dist/lib/components/widgets/widget.component.d.ts +8 -4
  21. package/dist/lib/sdk-ui-core-exports.d.ts +1 -1
  22. package/dist/lib/services/dashboard.service.d.ts +13 -5
  23. package/dist/lib/services/query.service.d.ts +0 -1
  24. package/dist/lib/services/widget.service.d.ts +100 -2
  25. package/dist/lib/types/chart-event-props.d.ts +15 -1
  26. package/dist/lib/types/data-point.d.ts +13 -2
  27. package/dist/lib/utilities/widget-model-translator.d.ts +50 -1
  28. package/dist/package.json +1 -1
  29. package/dist/public-api.d.ts +1 -1
  30. package/dist/version.d.ts +1 -1
  31. package/package.json +4 -4
@@ -1,4 +1,4 @@
1
- import { Component, Input, ViewChild, } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
2
  import { ComponentAdapter, PivotTable as PivotTablePreact, } from '@sisense/sdk-ui-preact';
3
3
  import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
4
4
  import * as i0 from "@angular/core";
@@ -43,7 +43,7 @@ export class AnalyticsComponent {
43
43
  dataBars: true,
44
44
  },
45
45
  ],
46
- grandTotals: { title: 'Grand Total', rows: true, columns: true },
46
+ grandTotals: { rows: true, columns: true },
47
47
  };
48
48
 
49
49
  pivotTable = {
@@ -56,13 +56,30 @@ export class AnalyticsComponent {
56
56
  }
57
57
  * ```
58
58
  * <img src="media://angular-pivot-table-example.png" width="800px" />
59
+ *
60
+ * @remarks
61
+ * Configuration options can also be applied within the scope of a `<SisenseContextProvider>` to control the default behavior of PivotTable, by changing available settings within `appConfig.chartConfig.tabular.*`
62
+ *
63
+ * Follow the link to {@link AppConfig} for more details on the available settings.
64
+ *
59
65
  * @group Data Grids
60
- * @beta
61
66
  */
62
67
  export class PivotTableComponent {
63
68
  constructor(sisenseContextService, themeService) {
64
69
  this.sisenseContextService = sisenseContextService;
65
70
  this.themeService = themeService;
71
+ /**
72
+ * {@inheritDoc @sisense/sdk-ui!PivotTableProps.onDataPointClick}
73
+ *
74
+ * @category Callbacks
75
+ */
76
+ this.dataPointClick = new EventEmitter();
77
+ /**
78
+ * {@inheritDoc @sisense/sdk-ui!PivotTableProps.onDataPointContextMenu}
79
+ *
80
+ * @category Callbacks
81
+ */
82
+ this.dataPointContextMenu = new EventEmitter();
66
83
  this.componentAdapter = new ComponentAdapter(PivotTablePreact, [
67
84
  createSisenseContextConnector(this.sisenseContextService),
68
85
  createThemeContextConnector(this.themeService),
@@ -85,6 +102,8 @@ export class PivotTableComponent {
85
102
  filters: this.filters,
86
103
  highlights: this.highlights,
87
104
  styleOptions: this.styleOptions,
105
+ onDataPointClick: (...[point, nativeEvent]) => this.dataPointClick.emit({ point, nativeEvent }),
106
+ onDataPointContextMenu: (...[point, nativeEvent]) => this.dataPointContextMenu.emit({ point, nativeEvent }),
88
107
  };
89
108
  }
90
109
  /** @internal */
@@ -93,7 +112,7 @@ export class PivotTableComponent {
93
112
  }
94
113
  }
95
114
  PivotTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PivotTableComponent, deps: [{ token: i1.SisenseContextService }, { token: i1.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
96
- PivotTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: PivotTableComponent, selector: "csdk-pivot-table", inputs: { dataSet: "dataSet", dataOptions: "dataOptions", filters: "filters", highlights: "highlights", styleOptions: "styleOptions" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
115
+ PivotTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: PivotTableComponent, selector: "csdk-pivot-table", inputs: { dataSet: "dataSet", dataOptions: "dataOptions", filters: "filters", highlights: "highlights", styleOptions: "styleOptions" }, outputs: { dataPointClick: "dataPointClick", dataPointContextMenu: "dataPointContextMenu" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
97
116
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PivotTableComponent, decorators: [{
98
117
  type: Component,
99
118
  args: [{ selector: 'csdk-pivot-table', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
@@ -110,5 +129,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
110
129
  type: Input
111
130
  }], styleOptions: [{
112
131
  type: Input
132
+ }], dataPointClick: [{
133
+ type: Output
134
+ }], dataPointContextMenu: [{
135
+ type: Output
113
136
  }] } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-table.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/charts/pivot-table.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,UAAU,IAAI,gBAAgB,GAE/B,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;AASzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuDG;AAMH,MAAM,OAAO,mBAAmB;IA+C9B,YACU,qBAA4C,EAC5C,YAA0B;QAD1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,iBAAY,GAAZ,YAAY,CAAc;QAElC,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,gBAAgB,EAAE;YAC7D,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;IAChB,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED,gBAAgB;IAChB,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,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC;IACJ,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;iHAlFU,mBAAmB;qGAAnB,mBAAmB;4FAAnB,mBAAmB;kBAL/B,SAAS;+BACE,kBAAkB,YAC5B,QAAQ;uIAMR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBASjB,OAAO;sBADN,KAAK;gBASN,WAAW;sBADV,KAAK;gBASN,OAAO;sBADN,KAAK;gBASN,UAAU;sBADT,KAAK;gBASN,YAAY;sBADX,KAAK","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  PivotTable as PivotTablePreact,\n  type PivotTableProps as PivotTablePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services';\nimport { ThemeService } from '../../services';\n\n/**\n * Props of the {@link PivotTableComponent}.\n */\nexport interface PivotTableProps extends PivotTablePropsPreact {}\n\n/**\n * Pivot Table with and pagination.\n *\n * @example\n * ```html\n *  <csdk-pivot-table\n *    [dataSet]=\"pivotTable.dataSet\"\n *    [dataOptions]=\"pivotTable.dataOptions\"\n *    [filters]=\"pivotTable.filters\"\n *    [styleOptions]=\"pivotTable.styleOptions\"\n *  />\n * ```\n * ```ts\nimport { Component } from '@angular/core';\nimport { measureFactory, filterFactory } from '@sisense/sdk-data';\nimport * as DM from '../../assets/sample-ecommerce';\nimport type { PivotTableDataOptions } from '@sisense/sdk-ui-angular';\n\n@Component({\n  selector: 'app-analytics',\n  templateUrl: './analytics.component.html',\n  styleUrls: ['./analytics.component.scss'],\n})\nexport class AnalyticsComponent {\n\n  pivotTableDataOptions: PivotTableDataOptions = {\n    rows: [\n      { column: DM.Category.Category, includeSubTotals: true },\n      { column: DM.Commerce.AgeRange, includeSubTotals: true },\n      DM.Commerce.Condition,\n    ],\n    columns: [{ column: DM.Commerce.Gender, includeSubTotals: true }],\n    values: [\n      measureFactory.sum(DM.Commerce.Cost, 'Total Cost'),\n      {\n        column: measureFactory.sum(DM.Commerce.Revenue, 'Total Revenue'),\n        totalsCalculation: 'sum',\n        dataBars: true,\n      },\n    ],\n    grandTotals: { title: 'Grand Total', rows: true, columns: true },\n  };\n\n  pivotTable = {\n    dataSet: DM.DataSource,\n    dataOptions: this.pivotTableDataOptions,\n    filters: [filterFactory.members(DM.Commerce.Gender, ['Female', 'Male'])],\n    styleOptions: { width: 1400, height: 600, rowsPerPage: 50 },\n  };\n\n}\n * ```\n * <img src=\"media://angular-pivot-table-example.png\" width=\"800px\" />\n * @group Data Grids\n * @beta\n */\n@Component({\n  selector: 'csdk-pivot-table',\n  template,\n  styles,\n})\nexport class PivotTableComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.dataSet}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSet: PivotTableProps['dataSet'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.dataOptions}\n   *\n   * @category Data\n   */\n  @Input()\n  dataOptions!: PivotTableProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: PivotTableProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: PivotTableProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.styleOptions}\n   *\n   * @category Representation\n   */\n  @Input()\n  styleOptions: PivotTableProps['styleOptions'];\n\n  private componentAdapter: ComponentAdapter<typeof PivotTablePreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(PivotTablePreact, [\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(): PivotTablePropsPreact {\n    return {\n      dataSet: this.dataSet,\n      dataOptions: this.dataOptions,\n      filters: this.filters,\n      highlights: this.highlights,\n      styleOptions: this.styleOptions,\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-table.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/charts/pivot-table.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,UAAU,IAAI,gBAAgB,GAE/B,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;AAiBzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4DG;AAMH,MAAM,OAAO,mBAAmB;IA+D9B,YACU,qBAA4C,EAC5C,YAA0B;QAD1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,iBAAY,GAAZ,YAAY,CAAc;QApBpC;;;;WAIG;QAEH,mBAAc,GAAG,IAAI,YAAY,EAA4B,CAAC;QAE9D;;;;WAIG;QAEH,yBAAoB,GAAG,IAAI,YAAY,EAA4B,CAAC;QAQlE,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,gBAAgB,EAAE;YAC7D,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED,gBAAgB;IAChB,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED,gBAAgB;IAChB,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,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,gBAAgB,EAAE,CAChB,GAAG,CAAC,KAAK,EAAE,WAAW,CAAuD,EAC7E,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,WAAW,EAA8B,CAAC;YACjF,sBAAsB,EAAE,CACtB,GAAG,CAAC,KAAK,EAAE,WAAW,CAA6D,EACnF,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,WAAW,EAA8B,CAAC;SACxF,CAAC;IACJ,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;iHAxGU,mBAAmB;qGAAnB,mBAAmB;4FAAnB,mBAAmB;kBAL/B,SAAS;+BACE,kBAAkB,YAC5B,QAAQ;uIAMR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBASjB,OAAO;sBADN,KAAK;gBASN,WAAW;sBADV,KAAK;gBASN,OAAO;sBADN,KAAK;gBASN,UAAU;sBADT,KAAK;gBASN,YAAY;sBADX,KAAK;gBASN,cAAc;sBADb,MAAM;gBASP,oBAAoB;sBADnB,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  PivotTable as PivotTablePreact,\n  type PivotTableProps as PivotTablePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services';\nimport { ThemeService } from '../../services';\nimport type {\n  Arguments,\n  PivotTableDataPointEvent,\n  PivotTableEventProps,\n  WithoutPreactChartEventProps,\n} from '../../types';\n\n/**\n * Props of the {@link PivotTableComponent}.\n */\nexport interface PivotTableProps\n  extends WithoutPreactChartEventProps<PivotTablePropsPreact>,\n    PivotTableEventProps {}\n\n/**\n * Pivot Table with and pagination.\n *\n * @example\n * ```html\n *  <csdk-pivot-table\n *    [dataSet]=\"pivotTable.dataSet\"\n *    [dataOptions]=\"pivotTable.dataOptions\"\n *    [filters]=\"pivotTable.filters\"\n *    [styleOptions]=\"pivotTable.styleOptions\"\n *  />\n * ```\n * ```ts\nimport { Component } from '@angular/core';\nimport { measureFactory, filterFactory } from '@sisense/sdk-data';\nimport * as DM from '../../assets/sample-ecommerce';\nimport type { PivotTableDataOptions } from '@sisense/sdk-ui-angular';\n\n@Component({\n  selector: 'app-analytics',\n  templateUrl: './analytics.component.html',\n  styleUrls: ['./analytics.component.scss'],\n})\nexport class AnalyticsComponent {\n\n  pivotTableDataOptions: PivotTableDataOptions = {\n    rows: [\n      { column: DM.Category.Category, includeSubTotals: true },\n      { column: DM.Commerce.AgeRange, includeSubTotals: true },\n      DM.Commerce.Condition,\n    ],\n    columns: [{ column: DM.Commerce.Gender, includeSubTotals: true }],\n    values: [\n      measureFactory.sum(DM.Commerce.Cost, 'Total Cost'),\n      {\n        column: measureFactory.sum(DM.Commerce.Revenue, 'Total Revenue'),\n        totalsCalculation: 'sum',\n        dataBars: true,\n      },\n    ],\n    grandTotals: { rows: true, columns: true },\n  };\n\n  pivotTable = {\n    dataSet: DM.DataSource,\n    dataOptions: this.pivotTableDataOptions,\n    filters: [filterFactory.members(DM.Commerce.Gender, ['Female', 'Male'])],\n    styleOptions: { width: 1400, height: 600, rowsPerPage: 50 },\n  };\n\n}\n * ```\n * <img src=\"media://angular-pivot-table-example.png\" width=\"800px\" />\n *\n * @remarks\n * Configuration options can also be applied within the scope of a `<SisenseContextProvider>` to control the default behavior of PivotTable, by changing available settings within `appConfig.chartConfig.tabular.*`\n *\n * Follow the link to {@link AppConfig} for more details on the available settings.\n *\n * @group Data Grids\n */\n@Component({\n  selector: 'csdk-pivot-table',\n  template,\n  styles,\n})\nexport class PivotTableComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.dataSet}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSet: PivotTableProps['dataSet'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.dataOptions}\n   *\n   * @category Data\n   */\n  @Input()\n  dataOptions!: PivotTableProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: PivotTableProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: PivotTableProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.styleOptions}\n   *\n   * @category Representation\n   */\n  @Input()\n  styleOptions: PivotTableProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.onDataPointClick}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointClick = new EventEmitter<PivotTableDataPointEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableProps.onDataPointContextMenu}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointContextMenu = new EventEmitter<PivotTableDataPointEvent>();\n\n  private componentAdapter: ComponentAdapter<typeof PivotTablePreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(PivotTablePreact, [\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(): PivotTablePropsPreact {\n    return {\n      dataSet: this.dataSet,\n      dataOptions: this.dataOptions,\n      filters: this.filters,\n      highlights: this.highlights,\n      styleOptions: this.styleOptions,\n      onDataPointClick: (\n        ...[point, nativeEvent]: Arguments<PivotTablePropsPreact['onDataPointClick']>\n      ) => this.dataPointClick.emit({ point, nativeEvent } as PivotTableDataPointEvent),\n      onDataPointContextMenu: (\n        ...[point, nativeEvent]: Arguments<PivotTablePropsPreact['onDataPointContextMenu']>\n      ) => this.dataPointContextMenu.emit({ point, nativeEvent } as PivotTableDataPointEvent),\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, Input, ViewChild, } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
2
  import { ComponentAdapter, PivotTableWidget as PivotTableWidgetPreact, } from '@sisense/sdk-ui-preact';
3
3
  import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
4
4
  import * as i0 from "@angular/core";
@@ -48,7 +48,7 @@ export class AnalyticsComponent {
48
48
  dataBars: true,
49
49
  },
50
50
  ],
51
- grandTotals: { title: 'Grand Total', rows: true, columns: true },
51
+ grandTotals: { rows: true, columns: true },
52
52
  },
53
53
  filters: [filterFactory.members(DM.Commerce.Gender, ['Female', 'Male'])],
54
54
  styleOptions: { width: 1400, height: 600, rowsPerPage: 25 },
@@ -59,12 +59,23 @@ export class AnalyticsComponent {
59
59
  * ```
60
60
  * <img src="media://angular-pivot-table-widget-example.png" width="800px" />
61
61
  * @group Dashboards
62
- * @beta
63
62
  */
64
63
  export class PivotTableWidgetComponent {
65
64
  constructor(sisenseContextService, themeService) {
66
65
  this.sisenseContextService = sisenseContextService;
67
66
  this.themeService = themeService;
67
+ /**
68
+ * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.onDataPointClick}
69
+ *
70
+ * @category Callbacks
71
+ */
72
+ this.dataPointClick = new EventEmitter();
73
+ /**
74
+ * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.onDataPointContextMenu}
75
+ *
76
+ * @category Callbacks
77
+ */
78
+ this.dataPointContextMenu = new EventEmitter();
68
79
  this.componentAdapter = new ComponentAdapter(PivotTableWidgetPreact, [
69
80
  createSisenseContextConnector(this.sisenseContextService),
70
81
  createThemeContextConnector(this.themeService),
@@ -87,8 +98,11 @@ export class PivotTableWidgetComponent {
87
98
  filters: this.filters,
88
99
  highlights: this.highlights,
89
100
  styleOptions: this.styleOptions,
101
+ drilldownOptions: this.drilldownOptions,
90
102
  title: this.title,
91
103
  description: this.description,
104
+ onDataPointClick: (...[point, nativeEvent]) => this.dataPointClick.emit({ point, nativeEvent }),
105
+ onDataPointContextMenu: (...[point, nativeEvent]) => this.dataPointContextMenu.emit({ point, nativeEvent }),
92
106
  };
93
107
  }
94
108
  /** @internal */
@@ -97,7 +111,7 @@ export class PivotTableWidgetComponent {
97
111
  }
98
112
  }
99
113
  PivotTableWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PivotTableWidgetComponent, deps: [{ token: i1.SisenseContextService }, { token: i1.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
100
- PivotTableWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: PivotTableWidgetComponent, selector: "csdk-pivot-table-widget", inputs: { dataSource: "dataSource", dataOptions: "dataOptions", filters: "filters", highlights: "highlights", styleOptions: "styleOptions", title: "title", description: "description" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
114
+ PivotTableWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: PivotTableWidgetComponent, selector: "csdk-pivot-table-widget", inputs: { dataSource: "dataSource", dataOptions: "dataOptions", filters: "filters", highlights: "highlights", styleOptions: "styleOptions", drilldownOptions: "drilldownOptions", title: "title", description: "description" }, outputs: { dataPointClick: "dataPointClick", dataPointContextMenu: "dataPointContextMenu" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
101
115
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: PivotTableWidgetComponent, decorators: [{
102
116
  type: Component,
103
117
  args: [{ selector: 'csdk-pivot-table-widget', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
@@ -114,9 +128,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
114
128
  type: Input
115
129
  }], styleOptions: [{
116
130
  type: Input
131
+ }], drilldownOptions: [{
132
+ type: Input
117
133
  }], title: [{
118
134
  type: Input
119
135
  }], description: [{
120
136
  type: Input
137
+ }], dataPointClick: [{
138
+ type: Output
139
+ }], dataPointContextMenu: [{
140
+ type: Output
121
141
  }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-table-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/pivot-table-widget.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,gBAAgB,IAAI,sBAAsB,GAE3C,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;AAUzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyDG;AAMH,MAAM,OAAO,yBAAyB;IA+DpC,YACU,qBAA4C,EAC5C,YAA0B;QAD1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,iBAAY,GAAZ,YAAY,CAAc;QAElC,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,gBAAgB;IAChB,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED,gBAAgB;IAChB,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,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,WAAW,EAAE,IAAI,CAAC,WAAW;SAC9B,CAAC;IACJ,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;uHApGU,yBAAyB;2GAAzB,yBAAyB;4FAAzB,yBAAyB;kBALrC,SAAS;+BACE,yBAAyB,YACnC,QAAQ;uIAMR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBASjB,UAAU;sBADT,KAAK;gBASN,WAAW;sBADV,KAAK;gBASN,OAAO;sBADN,KAAK;gBASN,UAAU;sBADT,KAAK;gBASN,YAAY;sBADX,KAAK;gBASN,KAAK;sBADJ,KAAK;gBASN,WAAW;sBADV,KAAK","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  PivotTableWidget as PivotTableWidgetPreact,\n  type PivotTableWidgetProps as PivotTableWidgetPropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services';\nimport { ThemeService } from '../../services';\n\n/**\n * Props of the {@link PivotTableWidgetComponent}.\n */\nexport interface PivotTableWidgetProps\n  extends Omit<PivotTableWidgetPropsPreact, 'onDataPointClick' | 'onDataPointContextMenu'> {}\n\n/**\n * The Pivot Table Widget component extends the {@link PivotTableComponent} component to support widget features,\n * including a header, widget style options, and more.\n *\n * @example\n * ```html\n<csdk-pivot-table-widget\n  [dataSource]=\"pivotProps.dataSource\"\n  [dataOptions]=\"pivotProps.dataOptions\"\n  [filters]=\"pivotProps.filters\"\n  [styleOptions]=\"pivotProps.styleOptions\"\n  [title]=\"pivotProps.title\"\n  [description]=\"pivotProps.description\"\n/>\n * ```\n * ```ts\nimport { Component } from '@angular/core';\nimport { type PivotTableWidgetProps } from '@sisense/sdk-ui-angular';\nimport { measureFactory, filterFactory } from '@sisense/sdk-data';\nimport * as DM from '../../assets/sample-ecommerce';\n\n@Component({\n  selector: 'app-analytics',\n  templateUrl: './analytics.component.html',\n  styleUrls: ['./analytics.component.scss'],\n})\nexport class AnalyticsComponent {\n\n  pivotProps: PivotTableWidgetProps = {\n    dataSource: DM.DataSource,\n    dataOptions: {\n      rows: [\n        { column: DM.Category.Category, includeSubTotals: true },\n        { column: DM.Commerce.AgeRange, includeSubTotals: true },\n        DM.Commerce.Condition,\n      ],\n      columns: [{ column: DM.Commerce.Gender, includeSubTotals: true }],\n      values: [\n        measureFactory.sum(DM.Commerce.Cost, 'Total Cost'),\n        {\n          column: measureFactory.sum(DM.Commerce.Revenue, 'Total Revenue'),\n          totalsCalculation: 'sum',\n          dataBars: true,\n        },\n      ],\n      grandTotals: { title: 'Grand Total', rows: true, columns: true },\n    },\n    filters: [filterFactory.members(DM.Commerce.Gender, ['Female', 'Male'])],\n    styleOptions: { width: 1400, height: 600, rowsPerPage: 25 },\n    title: 'Pivot Table Widget',\n    description: 'Pivot Table Widget Description',\n  };\n}\n * ```\n * <img src=\"media://angular-pivot-table-widget-example.png\" width=\"800px\" />\n * @group Dashboards\n * @beta\n */\n@Component({\n  selector: 'csdk-pivot-table-widget',\n  template,\n  styles,\n})\nexport class PivotTableWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: PivotTableWidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.dataOptions}\n   *\n   * @category Data\n   */\n  @Input()\n  dataOptions!: PivotTableWidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: PivotTableWidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: PivotTableWidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.styleOptions}\n   *\n   * @category Representation\n   */\n  @Input()\n  styleOptions: PivotTableWidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: PivotTableWidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: PivotTableWidgetProps['description'];\n\n  private componentAdapter: ComponentAdapter<typeof PivotTableWidgetPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(PivotTableWidgetPreact, [\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(): PivotTableWidgetPropsPreact {\n    return {\n      dataSource: this.dataSource,\n      dataOptions: this.dataOptions,\n      filters: this.filters,\n      highlights: this.highlights,\n      styleOptions: this.styleOptions,\n      title: this.title,\n      description: this.description,\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pivot-table-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/pivot-table-widget.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,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;AAiBzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwDG;AAMH,MAAM,OAAO,yBAAyB;IAuFpC,YACU,qBAA4C,EAC5C,YAA0B;QAD1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,iBAAY,GAAZ,YAAY,CAAc;QApBpC;;;;WAIG;QAEH,mBAAc,GAAG,IAAI,YAAY,EAA4B,CAAC;QAE9D;;;;WAIG;QAEH,yBAAoB,GAAG,IAAI,YAAY,EAA4B,CAAC;QAQlE,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,gBAAgB;IAChB,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED,gBAAgB;IAChB,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,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,gBAAgB,EAAE,CAChB,GAAG,CAAC,KAAK,EAAE,WAAW,CAA6D,EACnF,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,WAAW,EAA8B,CAAC;YACjF,sBAAsB,EAAE,CACtB,GAAG,CAAC,KAAK,EAAE,WAAW,CAAmE,EACzF,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,WAAW,EAA8B,CAAC;SACxF,CAAC;IACJ,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;uHAnIU,yBAAyB;2GAAzB,yBAAyB;4FAAzB,yBAAyB;kBALrC,SAAS;+BACE,yBAAyB,YACnC,QAAQ;uIAMR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBASjB,UAAU;sBADT,KAAK;gBASN,WAAW;sBADV,KAAK;gBASN,OAAO;sBADN,KAAK;gBASN,UAAU;sBADT,KAAK;gBASN,YAAY;sBADX,KAAK;gBASN,gBAAgB;sBADf,KAAK;gBASN,KAAK;sBADJ,KAAK;gBASN,WAAW;sBADV,KAAK;gBASN,cAAc;sBADb,MAAM;gBASP,oBAAoB;sBADnB,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  PivotTableWidget as PivotTableWidgetPreact,\n  type PivotTableWidgetProps as PivotTableWidgetPropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services';\nimport { ThemeService } from '../../services';\nimport type {\n  Arguments,\n  PivotTableDataPointEvent,\n  PivotTableEventProps,\n  WithoutPreactChartEventProps,\n} from '../../types';\n\n/**\n * Props of the {@link PivotTableWidgetComponent}.\n */\nexport interface PivotTableWidgetProps\n  extends WithoutPreactChartEventProps<PivotTableWidgetPropsPreact>,\n    PivotTableEventProps {}\n\n/**\n * The Pivot Table Widget component extends the {@link PivotTableComponent} component to support widget features,\n * including a header, widget style options, and more.\n *\n * @example\n * ```html\n<csdk-pivot-table-widget\n  [dataSource]=\"pivotProps.dataSource\"\n  [dataOptions]=\"pivotProps.dataOptions\"\n  [filters]=\"pivotProps.filters\"\n  [styleOptions]=\"pivotProps.styleOptions\"\n  [title]=\"pivotProps.title\"\n  [description]=\"pivotProps.description\"\n/>\n * ```\n * ```ts\nimport { Component } from '@angular/core';\nimport { type PivotTableWidgetProps } from '@sisense/sdk-ui-angular';\nimport { measureFactory, filterFactory } from '@sisense/sdk-data';\nimport * as DM from '../../assets/sample-ecommerce';\n\n@Component({\n  selector: 'app-analytics',\n  templateUrl: './analytics.component.html',\n  styleUrls: ['./analytics.component.scss'],\n})\nexport class AnalyticsComponent {\n\n  pivotProps: PivotTableWidgetProps = {\n    dataSource: DM.DataSource,\n    dataOptions: {\n      rows: [\n        { column: DM.Category.Category, includeSubTotals: true },\n        { column: DM.Commerce.AgeRange, includeSubTotals: true },\n        DM.Commerce.Condition,\n      ],\n      columns: [{ column: DM.Commerce.Gender, includeSubTotals: true }],\n      values: [\n        measureFactory.sum(DM.Commerce.Cost, 'Total Cost'),\n        {\n          column: measureFactory.sum(DM.Commerce.Revenue, 'Total Revenue'),\n          totalsCalculation: 'sum',\n          dataBars: true,\n        },\n      ],\n      grandTotals: { rows: true, columns: true },\n    },\n    filters: [filterFactory.members(DM.Commerce.Gender, ['Female', 'Male'])],\n    styleOptions: { width: 1400, height: 600, rowsPerPage: 25 },\n    title: 'Pivot Table Widget',\n    description: 'Pivot Table Widget Description',\n  };\n}\n * ```\n * <img src=\"media://angular-pivot-table-widget-example.png\" width=\"800px\" />\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-pivot-table-widget',\n  template,\n  styles,\n})\nexport class PivotTableWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: PivotTableWidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.dataOptions}\n   *\n   * @category Data\n   */\n  @Input()\n  dataOptions!: PivotTableWidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: PivotTableWidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: PivotTableWidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.styleOptions}\n   *\n   * @category Representation\n   */\n  @Input()\n  styleOptions: PivotTableWidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.drilldownOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  drilldownOptions: PivotTableWidgetProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: PivotTableWidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: PivotTableWidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.onDataPointClick}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointClick = new EventEmitter<PivotTableDataPointEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!PivotTableWidgetProps.onDataPointContextMenu}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointContextMenu = new EventEmitter<PivotTableDataPointEvent>();\n\n  private componentAdapter: ComponentAdapter<typeof PivotTableWidgetPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(PivotTableWidgetPreact, [\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(): PivotTableWidgetPropsPreact {\n    return {\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      onDataPointClick: (\n        ...[point, nativeEvent]: Arguments<PivotTableWidgetPropsPreact['onDataPointClick']>\n      ) => this.dataPointClick.emit({ point, nativeEvent } as PivotTableDataPointEvent),\n      onDataPointContextMenu: (\n        ...[point, nativeEvent]: Arguments<PivotTableWidgetPropsPreact['onDataPointContextMenu']>\n      ) => this.dataPointContextMenu.emit({ point, nativeEvent } as PivotTableDataPointEvent),\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
@@ -161,4 +161,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
161
161
  }], dataPointsSelect: [{
162
162
  type: Output
163
163
  }] } });
164
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/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  type BeforeMenuOpenHandler,\n  ComponentAdapter,\n  CustomWidgetProps,\n  type SoftUnion,\n  TextWidgetProps as TextWidgetPropsPreact,\n  Widget as WidgetPreact,\n  type WidgetProps as WidgetPropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { translateToPreactWidgetProps } from '../../helpers/widget-props-preact-translator';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport { TextWidgetEventProps, WithoutPreactChartEventProps } from '../../types';\nimport {\n  ChartDataPointClickEvent,\n  ChartDataPointContextMenuEvent,\n  ChartDataPointsEvent,\n} from '../../types/data-point';\nimport { ChartWidgetProps } from './chart-widget.component';\nimport { PivotTableWidgetProps } from './pivot-table-widget.component';\n\n/**\n * Props for the text widget.\n */\nexport interface TextWidgetProps\n  extends WithoutPreactChartEventProps<TextWidgetPropsPreact>,\n    TextWidgetEventProps {}\n\n/**\n * {@inheritDoc @sisense/sdk-ui!WithCommonWidgetProps}\n */\nexport type WithCommonWidgetProps<BaseWidget, Type> = BaseWidget & {\n  /**\n   * Unique identifier of the widget within the container component (dashboard)\n   *\n   */\n  readonly id: string;\n  /**\n   * Widget type\n   */\n  widgetType: Type;\n  /**\n   * Optional handler function to process menu options before opening the context menu.\n   *\n   * @internal\n   */\n  beforeMenuOpen?: BeforeMenuOpenHandler;\n};\n\n/**\n * Props of the {@link WidgetComponent}.\n */\nexport type WidgetProps = SoftUnion<\n  | WithCommonWidgetProps<ChartWidgetProps, 'chart'>\n  | WithCommonWidgetProps<PivotTableWidgetProps, 'pivot'>\n  | WithCommonWidgetProps<TextWidgetProps, 'text'>\n  | WithCommonWidgetProps<CustomWidgetProps, 'custom'>\n>;\n\n/**\n * Facade component that renders a widget within a dashboard based on the widget type.\n *\n * @example\n * ```html\n<!--Component HTML template in example.component.html-->\n<csdk-widget\n  [id]=\"widgetProps.id\"\n  [title]=\"widgetProps.title\"\n  [widgetType]=\"widgetProps.widgetType\"\n  [chartType]=\"widgetProps.chartType\"\n  [dataSource]=\"widgetProps.dataSource\"\n  [dataOptions]=\"widgetProps.dataOptions\"\n/>\n * ```\n *\n * ```ts\n// Component behavior in example.component.ts\nimport { Component } from '@angular/core';\nimport { type WidgetProps } from '@sisense/sdk-ui-angular';\n\n@Component({\n  selector: 'example',\n  templateUrl: './example.component.html',\n  styleUrls: ['./example.component.scss'],\n})\nexport class ExampleComponent {\n  widgetProps: WidgetProps = {\n    id: 'widget-id',\n    widgetType: 'chart',\n    chartType: 'column',\n    title: 'Widget Title',\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  };\n}\n * ```\n * <img src=\"media://angular-chart-widget-example.png\" width=\"500px\" />\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-widget',\n  template,\n  styles,\n})\nexport class WidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * Unique identifier of the widget\n   *\n   * @category Widget\n   */\n  @Input()\n  id!: WidgetProps['id'];\n\n  /**\n   * Widget type\n   *\n   * @category Widget\n   */\n  @Input()\n  widgetType!: WidgetProps['widgetType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.chartType}\n   *\n   * @category Chart\n   */\n  @Input()\n  chartType: WidgetProps['chartType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!CustomWidgetProps.customWidgetType}\n   *\n   * @category Widget\n   */\n  @Input()\n  customWidgetType: WidgetProps['customWidgetType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: WidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataOptions}\n   *\n   * @category Chart\n   */\n  @Input()\n  dataOptions: WidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: WidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: WidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: WidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.drilldownOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  drilldownOptions: WidgetProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: WidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: WidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   * @internal\n   */\n  @Input()\n  highlightSelectionDisabled: WidgetProps['highlightSelectionDisabled'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onBeforeRender}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  beforeRender: WidgetProps['beforeRender'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataReady}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  dataReady: WidgetProps['dataReady'];\n\n  /**\n   * Optional handler function to process menu options before opening the context menu.\n   *\n   * @category Callbacks\n   * @internal\n   */\n  @Input()\n  beforeMenuOpen: WidgetProps['beforeMenuOpen'];\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 WidgetPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(WidgetPreact, [\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(): WidgetPropsPreact {\n    return translateToPreactWidgetProps({\n      id: this.id,\n      widgetType: this.widgetType,\n      chartType: this.chartType,\n      customWidgetType: this.customWidgetType,\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      beforeRender: this.beforeRender?.bind(this),\n      dataReady: this.dataReady?.bind(this),\n      beforeMenuOpen: this.beforeMenuOpen?.bind(this),\n      dataPointClick: this.dataPointClick.emit.bind(this.dataPointClick),\n      dataPointContextMenu: this.dataPointContextMenu.emit.bind(this.dataPointContextMenu),\n      dataPointsSelect: this.dataPointsSelect.emit.bind(this.dataPointsSelect),\n    } as WidgetProps);\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
164
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/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  type BeforeMenuOpenHandler,\n  ComponentAdapter,\n  CustomWidgetProps,\n  type SoftUnion,\n  TextWidgetProps as TextWidgetPropsPreact,\n  Widget as WidgetPreact,\n  type WidgetProps as WidgetPropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { translateToPreactWidgetProps } from '../../helpers/widget-props-preact-translator';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport { TextWidgetEventProps, WithoutPreactChartEventProps } from '../../types';\nimport {\n  ChartDataPointsEvent,\n  ChartDataPointsEventHandler,\n  WidgetDataPointClickEvent,\n  WidgetDataPointClickEventHandler,\n  WidgetDataPointContextMenuEvent,\n  WidgetDataPointContextMenuEventHandler,\n} from '../../types/data-point';\nimport { ChartWidgetProps } from './chart-widget.component';\nimport { PivotTableWidgetProps } from './pivot-table-widget.component';\n\n/**\n * Props for the text widget.\n */\nexport interface TextWidgetProps\n  extends WithoutPreactChartEventProps<TextWidgetPropsPreact>,\n    TextWidgetEventProps {}\n\n/**\n * {@inheritDoc @sisense/sdk-ui!WithCommonWidgetProps}\n */\nexport type WithCommonWidgetProps<BaseWidget, Type> = BaseWidget & {\n  /**\n   * Unique identifier of the widget within the container component (dashboard)\n   *\n   */\n  readonly id: string;\n  /**\n   * Widget type\n   */\n  widgetType: Type;\n  /**\n   * Optional handler function to process menu options before opening the context menu.\n   *\n   * @internal\n   */\n  beforeMenuOpen?: BeforeMenuOpenHandler;\n};\n\n/**\n * Props of the {@link WidgetComponent}.\n */\nexport type WidgetProps = SoftUnion<\n  | WithCommonWidgetProps<ChartWidgetProps, 'chart'>\n  | WithCommonWidgetProps<PivotTableWidgetProps, 'pivot'>\n  | WithCommonWidgetProps<TextWidgetProps, 'text'>\n  | WithCommonWidgetProps<CustomWidgetProps, 'custom'>\n> & {\n  // Explicitly declare event handlers to prevent Angular's template type checker\n  // from inferring intersection types when accessing these properties on WidgetProps.\n  // This is needed because WidgetProps is a SoftUnion, and Angular's template compiler\n  // dynamically accesses properties at usage time, causing TypeScript to create\n  // intersections that are incompatible with CalendarHeatmap's unique event structure.\n  dataPointClick?: WidgetDataPointClickEventHandler;\n  dataPointContextMenu?: WidgetDataPointContextMenuEventHandler;\n  dataPointsSelect?: ChartDataPointsEventHandler;\n};\n\n/**\n * Facade component that renders a widget within a dashboard based on the widget type.\n *\n * @example\n * ```html\n<!--Component HTML template in example.component.html-->\n<csdk-widget\n  [id]=\"widgetProps.id\"\n  [title]=\"widgetProps.title\"\n  [widgetType]=\"widgetProps.widgetType\"\n  [chartType]=\"widgetProps.chartType\"\n  [dataSource]=\"widgetProps.dataSource\"\n  [dataOptions]=\"widgetProps.dataOptions\"\n/>\n * ```\n *\n * ```ts\n// Component behavior in example.component.ts\nimport { Component } from '@angular/core';\nimport { type WidgetProps } from '@sisense/sdk-ui-angular';\n\n@Component({\n  selector: 'example',\n  templateUrl: './example.component.html',\n  styleUrls: ['./example.component.scss'],\n})\nexport class ExampleComponent {\n  widgetProps: WidgetProps = {\n    id: 'widget-id',\n    widgetType: 'chart',\n    chartType: 'column',\n    title: 'Widget Title',\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  };\n}\n * ```\n * <img src=\"media://angular-chart-widget-example.png\" width=\"500px\" />\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-widget',\n  template,\n  styles,\n})\nexport class WidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * Unique identifier of the widget\n   *\n   * @category Widget\n   */\n  @Input()\n  id!: WidgetProps['id'];\n\n  /**\n   * Widget type\n   *\n   * @category Widget\n   */\n  @Input()\n  widgetType!: WidgetProps['widgetType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.chartType}\n   *\n   * @category Chart\n   */\n  @Input()\n  chartType: WidgetProps['chartType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!CustomWidgetProps.customWidgetType}\n   *\n   * @category Widget\n   */\n  @Input()\n  customWidgetType: WidgetProps['customWidgetType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: WidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataOptions}\n   *\n   * @category Chart\n   */\n  @Input()\n  dataOptions: WidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: WidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: WidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: WidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.drilldownOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  drilldownOptions: WidgetProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: WidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: WidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   * @internal\n   */\n  @Input()\n  highlightSelectionDisabled: WidgetProps['highlightSelectionDisabled'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onBeforeRender}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  beforeRender: WidgetProps['beforeRender'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataReady}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  dataReady: WidgetProps['dataReady'];\n\n  /**\n   * Optional handler function to process menu options before opening the context menu.\n   *\n   * @category Callbacks\n   * @internal\n   */\n  @Input()\n  beforeMenuOpen: WidgetProps['beforeMenuOpen'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointClick}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointClick = new EventEmitter<WidgetDataPointClickEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointContextMenu}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointContextMenu = new EventEmitter<WidgetDataPointContextMenuEvent>();\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 WidgetPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(WidgetPreact, [\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(): WidgetPropsPreact {\n    return translateToPreactWidgetProps({\n      id: this.id,\n      widgetType: this.widgetType,\n      chartType: this.chartType,\n      customWidgetType: this.customWidgetType,\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      beforeRender: this.beforeRender?.bind(this),\n      dataReady: this.dataReady?.bind(this),\n      beforeMenuOpen: this.beforeMenuOpen?.bind(this),\n      dataPointClick: this.dataPointClick.emit.bind(this.dataPointClick),\n      dataPointContextMenu: this.dataPointContextMenu.emit.bind(this.dataPointContextMenu),\n      dataPointsSelect: this.dataPointsSelect.emit.bind(this.dataPointsSelect),\n    } as WidgetProps);\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
@@ -12,7 +12,10 @@ export function translateToPreactWidgetProps(widgetProps) {
12
12
  })
13
13
  : undefined,
14
14
  onDataPointContextMenu: dataPointContextMenu
15
- ? (...[point, nativeEvent]) => dataPointContextMenu({ point, nativeEvent })
15
+ ? (...[point, nativeEvent]) => dataPointContextMenu({
16
+ point,
17
+ nativeEvent,
18
+ })
16
19
  : undefined,
17
20
  onDataPointsSelected: dataPointsSelect
18
21
  ? (...[points, nativeEvent]) => dataPointsSelect({ points, nativeEvent })
@@ -37,4 +40,4 @@ export function translateFromPreactWidgetProps(widgetProps) {
37
40
  : undefined,
38
41
  };
39
42
  }
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXByb3BzLXByZWFjdC10cmFuc2xhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9oZWxwZXJzL3dpZGdldC1wcm9wcy1wcmVhY3QtdHJhbnNsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFlQSxNQUFNLFVBQVUsNEJBQTRCLENBQUMsV0FBd0I7SUFDbkUsTUFBTSxFQUNKLFlBQVksRUFDWixTQUFTLEVBQ1QsY0FBYyxFQUNkLGNBQWMsRUFDZCxvQkFBb0IsRUFDcEIsZ0JBQWdCLEVBQ2hCLEdBQUcsaUJBQWlCLEVBQ3JCLEdBQUcsV0FBVyxDQUFDO0lBQ2hCLE9BQU87UUFDTCxHQUFHLGlCQUFpQjtRQUNwQixjQUFjLEVBQUUsWUFBWTtRQUM1QixXQUFXLEVBQUUsU0FBUztRQUN0QixnQkFBZ0IsRUFBRSxjQUFjO1FBQ2hDLGdCQUFnQixFQUFFLGNBQWM7WUFDOUIsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxXQUFXLENBQXVELEVBQUUsRUFBRSxDQUMvRSxjQUFtRCxDQUFDO2dCQUNuRCxLQUFLO2dCQUNMLFdBQVc7YUFDaUIsQ0FBQztZQUNuQyxDQUFDLENBQUMsU0FBUztRQUNiLHNCQUFzQixFQUFFLG9CQUFvQjtZQUMxQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLFdBQVcsQ0FBNkQsRUFBRSxFQUFFLENBQ3RGLG9CQUFvQixDQUFDLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBb0MsQ0FBQztZQUNsRixDQUFDLENBQUMsU0FBUztRQUNiLG9CQUFvQixFQUFFLGdCQUFnQjtZQUNwQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLFdBQVcsQ0FBMkQsRUFBRSxFQUFFLENBQ3JGLGdCQUFnQixDQUFDLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBMEIsQ0FBQztZQUNyRSxDQUFDLENBQUMsU0FBUztLQUNPLENBQUM7QUFDekIsQ0FBQztBQUVELE1BQU0sVUFBVSw4QkFBOEIsQ0FBQyxXQUE4QjtJQUMzRSxNQUFNLEVBQ0osY0FBYyxFQUNkLFdBQVcsRUFDWCxnQkFBZ0IsRUFDaEIsZ0JBQWdCLEVBQ2hCLHNCQUFzQixFQUN0QixvQkFBb0IsRUFDcEIsR0FBRyxpQkFBaUIsRUFDckIsR0FBRyxXQUFvQyxDQUFDO0lBQ3pDLE9BQU87UUFDTCxHQUFHLGlCQUFpQjtRQUNwQixZQUFZLEVBQUUsY0FBYztRQUM1QixTQUFTLEVBQUUsV0FBVztRQUN0QixjQUFjLEVBQUUsZ0JBQWdCO1FBQ2hDLGNBQWMsRUFBRSxnQkFBZ0I7WUFDOUIsQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUE0QixFQUFFLEVBQUUsQ0FDbkQsZ0JBQWdCLENBQUMsS0FBWSxFQUFFLFdBQWtCLENBQUM7WUFDdEQsQ0FBQyxDQUFDLFNBQVM7UUFDYixvQkFBb0IsRUFBRSxzQkFBc0I7WUFDMUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLEVBQUUsV0FBVyxFQUFrQyxFQUFFLEVBQUUsQ0FDekQsc0JBQXNCLENBQUMsS0FBWSxFQUFFLFdBQWtCLENBQUM7WUFDNUQsQ0FBQyxDQUFDLFNBQVM7UUFDYixnQkFBZ0IsRUFBRSxvQkFBb0I7WUFDcEMsQ0FBQyxDQUFDLENBQUMsRUFBRSxNQUFNLEVBQUUsV0FBVyxFQUF3QixFQUFFLEVBQUUsQ0FDaEQsb0JBQW9CLENBQUMsTUFBYSxFQUFFLFdBQWtCLENBQUM7WUFDM0QsQ0FBQyxDQUFDLFNBQVM7S0FDQyxDQUFDO0FBQ25CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tdW5uZWNlc3NhcnktdHlwZS1hc3NlcnRpb24gKi9cbmltcG9ydCB7IFNvZnRVbmlvbiwgV2lkZ2V0UHJvcHMgYXMgV2lkZ2V0UHJvcHNQcmVhY3QgfSBmcm9tICdAc2lzZW5zZS9zZGstdWktcHJlYWN0JztcblxuaW1wb3J0IHsgV2lkZ2V0UHJvcHMgfSBmcm9tICcuLi9jb21wb25lbnRzL3dpZGdldHMnO1xuaW1wb3J0IHtcbiAgQXJndW1lbnRzLFxuICBDaGFydERhdGFQb2ludENsaWNrRXZlbnQsXG4gIENoYXJ0RGF0YVBvaW50Q29udGV4dE1lbnVFdmVudCxcbiAgQ2hhcnREYXRhUG9pbnRzRXZlbnQsXG4gIFdpZGdldERhdGFQb2ludENsaWNrRXZlbnQsXG4gIFdpZGdldERhdGFQb2ludENsaWNrRXZlbnRIYW5kbGVyLFxufSBmcm9tICcuLi90eXBlcyc7XG5cbnR5cGUgU29mdFdpZGdldFByb3BzUHJlYWN0ID0gU29mdFVuaW9uPFdpZGdldFByb3BzUHJlYWN0PjtcblxuZXhwb3J0IGZ1bmN0aW9uIHRyYW5zbGF0ZVRvUHJlYWN0V2lkZ2V0UHJvcHMod2lkZ2V0UHJvcHM6IFdpZGdldFByb3BzKTogV2lkZ2V0UHJvcHNQcmVhY3Qge1xuICBjb25zdCB7XG4gICAgYmVmb3JlUmVuZGVyLFxuICAgIGRhdGFSZWFkeSxcbiAgICBiZWZvcmVNZW51T3BlbixcbiAgICBkYXRhUG9pbnRDbGljayxcbiAgICBkYXRhUG9pbnRDb250ZXh0TWVudSxcbiAgICBkYXRhUG9pbnRzU2VsZWN0LFxuICAgIC4uLmNvbW1vbldpZGdldFByb3BzXG4gIH0gPSB3aWRnZXRQcm9wcztcbiAgcmV0dXJuIHtcbiAgICAuLi5jb21tb25XaWRnZXRQcm9wcyxcbiAgICBvbkJlZm9yZVJlbmRlcjogYmVmb3JlUmVuZGVyLFxuICAgIG9uRGF0YVJlYWR5OiBkYXRhUmVhZHksXG4gICAgb25CZWZvcmVNZW51T3BlbjogYmVmb3JlTWVudU9wZW4sXG4gICAgb25EYXRhUG9pbnRDbGljazogZGF0YVBvaW50Q2xpY2tcbiAgICAgID8gKC4uLltwb2ludCwgbmF0aXZlRXZlbnRdOiBBcmd1bWVudHM8U29mdFdpZGdldFByb3BzUHJlYWN0WydvbkRhdGFQb2ludENsaWNrJ10+KSA9PlxuICAgICAgICAgIChkYXRhUG9pbnRDbGljayBhcyBXaWRnZXREYXRhUG9pbnRDbGlja0V2ZW50SGFuZGxlcikoe1xuICAgICAgICAgICAgcG9pbnQsXG4gICAgICAgICAgICBuYXRpdmVFdmVudCxcbiAgICAgICAgICB9IGFzIFdpZGdldERhdGFQb2ludENsaWNrRXZlbnQpXG4gICAgICA6IHVuZGVmaW5lZCxcbiAgICBvbkRhdGFQb2ludENvbnRleHRNZW51OiBkYXRhUG9pbnRDb250ZXh0TWVudVxuICAgICAgPyAoLi4uW3BvaW50LCBuYXRpdmVFdmVudF06IEFyZ3VtZW50czxTb2Z0V2lkZ2V0UHJvcHNQcmVhY3RbJ29uRGF0YVBvaW50Q29udGV4dE1lbnUnXT4pID0+XG4gICAgICAgICAgZGF0YVBvaW50Q29udGV4dE1lbnUoeyBwb2ludCwgbmF0aXZlRXZlbnQgfSBhcyBDaGFydERhdGFQb2ludENvbnRleHRNZW51RXZlbnQpXG4gICAgICA6IHVuZGVmaW5lZCxcbiAgICBvbkRhdGFQb2ludHNTZWxlY3RlZDogZGF0YVBvaW50c1NlbGVjdFxuICAgICAgPyAoLi4uW3BvaW50cywgbmF0aXZlRXZlbnRdOiBBcmd1bWVudHM8U29mdFdpZGdldFByb3BzUHJlYWN0WydvbkRhdGFQb2ludHNTZWxlY3RlZCddPikgPT5cbiAgICAgICAgICBkYXRhUG9pbnRzU2VsZWN0KHsgcG9pbnRzLCBuYXRpdmVFdmVudCB9IGFzIENoYXJ0RGF0YVBvaW50c0V2ZW50KVxuICAgICAgOiB1bmRlZmluZWQsXG4gIH0gYXMgV2lkZ2V0UHJvcHNQcmVhY3Q7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0cmFuc2xhdGVGcm9tUHJlYWN0V2lkZ2V0UHJvcHMod2lkZ2V0UHJvcHM6IFdpZGdldFByb3BzUHJlYWN0KTogV2lkZ2V0UHJvcHMge1xuICBjb25zdCB7XG4gICAgb25CZWZvcmVSZW5kZXIsXG4gICAgb25EYXRhUmVhZHksXG4gICAgb25CZWZvcmVNZW51T3BlbixcbiAgICBvbkRhdGFQb2ludENsaWNrLFxuICAgIG9uRGF0YVBvaW50Q29udGV4dE1lbnUsXG4gICAgb25EYXRhUG9pbnRzU2VsZWN0ZWQsXG4gICAgLi4uY29tbW9uV2lkZ2V0UHJvcHNcbiAgfSA9IHdpZGdldFByb3BzIGFzIFNvZnRXaWRnZXRQcm9wc1ByZWFjdDtcbiAgcmV0dXJuIHtcbiAgICAuLi5jb21tb25XaWRnZXRQcm9wcyxcbiAgICBiZWZvcmVSZW5kZXI6IG9uQmVmb3JlUmVuZGVyLFxuICAgIGRhdGFSZWFkeTogb25EYXRhUmVhZHksXG4gICAgYmVmb3JlTWVudU9wZW46IG9uQmVmb3JlTWVudU9wZW4sXG4gICAgZGF0YVBvaW50Q2xpY2s6IG9uRGF0YVBvaW50Q2xpY2tcbiAgICAgID8gKHsgcG9pbnQsIG5hdGl2ZUV2ZW50IH06IENoYXJ0RGF0YVBvaW50Q2xpY2tFdmVudCkgPT5cbiAgICAgICAgICBvbkRhdGFQb2ludENsaWNrKHBvaW50IGFzIGFueSwgbmF0aXZlRXZlbnQgYXMgYW55KVxuICAgICAgOiB1bmRlZmluZWQsXG4gICAgZGF0YVBvaW50Q29udGV4dE1lbnU6IG9uRGF0YVBvaW50Q29udGV4dE1lbnVcbiAgICAgID8gKHsgcG9pbnQsIG5hdGl2ZUV2ZW50IH06IENoYXJ0RGF0YVBvaW50Q29udGV4dE1lbnVFdmVudCkgPT5cbiAgICAgICAgICBvbkRhdGFQb2ludENvbnRleHRNZW51KHBvaW50IGFzIGFueSwgbmF0aXZlRXZlbnQgYXMgYW55KVxuICAgICAgOiB1bmRlZmluZWQsXG4gICAgZGF0YVBvaW50c1NlbGVjdDogb25EYXRhUG9pbnRzU2VsZWN0ZWRcbiAgICAgID8gKHsgcG9pbnRzLCBuYXRpdmVFdmVudCB9OiBDaGFydERhdGFQb2ludHNFdmVudCkgPT5cbiAgICAgICAgICBvbkRhdGFQb2ludHNTZWxlY3RlZChwb2ludHMgYXMgYW55LCBuYXRpdmVFdmVudCBhcyBhbnkpXG4gICAgICA6IHVuZGVmaW5lZCxcbiAgfSBhcyBXaWRnZXRQcm9wcztcbn1cbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkZ2V0LXByb3BzLXByZWFjdC10cmFuc2xhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9oZWxwZXJzL3dpZGdldC1wcm9wcy1wcmVhY3QtdHJhbnNsYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnQkEsTUFBTSxVQUFVLDRCQUE0QixDQUFDLFdBQXdCO0lBQ25FLE1BQU0sRUFDSixZQUFZLEVBQ1osU0FBUyxFQUNULGNBQWMsRUFDZCxjQUFjLEVBQ2Qsb0JBQW9CLEVBQ3BCLGdCQUFnQixFQUNoQixHQUFHLGlCQUFpQixFQUNyQixHQUFHLFdBQVcsQ0FBQztJQUNoQixPQUFPO1FBQ0wsR0FBRyxpQkFBaUI7UUFDcEIsY0FBYyxFQUFFLFlBQVk7UUFDNUIsV0FBVyxFQUFFLFNBQVM7UUFDdEIsZ0JBQWdCLEVBQUUsY0FBYztRQUNoQyxnQkFBZ0IsRUFBRSxjQUFjO1lBQzlCLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsV0FBVyxDQUF1RCxFQUFFLEVBQUUsQ0FDL0UsY0FBbUQsQ0FBQztnQkFDbkQsS0FBSztnQkFDTCxXQUFXO2FBQ2lCLENBQUM7WUFDbkMsQ0FBQyxDQUFDLFNBQVM7UUFDYixzQkFBc0IsRUFBRSxvQkFBb0I7WUFDMUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLEtBQUssRUFBRSxXQUFXLENBQTZELEVBQUUsRUFBRSxDQUNyRixvQkFBeUQsQ0FBQztnQkFDekQsS0FBSztnQkFDTCxXQUFXO2FBQ3VCLENBQUM7WUFDekMsQ0FBQyxDQUFDLFNBQVM7UUFDYixvQkFBb0IsRUFBRSxnQkFBZ0I7WUFDcEMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxXQUFXLENBQTJELEVBQUUsRUFBRSxDQUNyRixnQkFBZ0IsQ0FBQyxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQTBCLENBQUM7WUFDckUsQ0FBQyxDQUFDLFNBQVM7S0FDTyxDQUFDO0FBQ3pCLENBQUM7QUFFRCxNQUFNLFVBQVUsOEJBQThCLENBQUMsV0FBOEI7SUFDM0UsTUFBTSxFQUNKLGNBQWMsRUFDZCxXQUFXLEVBQ1gsZ0JBQWdCLEVBQ2hCLGdCQUFnQixFQUNoQixzQkFBc0IsRUFDdEIsb0JBQW9CLEVBQ3BCLEdBQUcsaUJBQWlCLEVBQ3JCLEdBQUcsV0FBb0MsQ0FBQztJQUN6QyxPQUFPO1FBQ0wsR0FBRyxpQkFBaUI7UUFDcEIsWUFBWSxFQUFFLGNBQWM7UUFDNUIsU0FBUyxFQUFFLFdBQVc7UUFDdEIsY0FBYyxFQUFFLGdCQUFnQjtRQUNoQyxjQUFjLEVBQUUsZ0JBQWdCO1lBQzlCLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBNEIsRUFBRSxFQUFFLENBQ25ELGdCQUFnQixDQUFDLEtBQVksRUFBRSxXQUFrQixDQUFDO1lBQ3RELENBQUMsQ0FBQyxTQUFTO1FBQ2Isb0JBQW9CLEVBQUUsc0JBQXNCO1lBQzFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBa0MsRUFBRSxFQUFFLENBQ3pELHNCQUFzQixDQUFDLEtBQVksRUFBRSxXQUFrQixDQUFDO1lBQzVELENBQUMsQ0FBQyxTQUFTO1FBQ2IsZ0JBQWdCLEVBQUUsb0JBQW9CO1lBQ3BDLENBQUMsQ0FBQyxDQUFDLEVBQUUsTUFBTSxFQUFFLFdBQVcsRUFBd0IsRUFBRSxFQUFFLENBQ2hELG9CQUFvQixDQUFDLE1BQWEsRUFBRSxXQUFrQixDQUFDO1lBQzNELENBQUMsQ0FBQyxTQUFTO0tBQ0MsQ0FBQztBQUNuQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLXVubmVjZXNzYXJ5LXR5cGUtYXNzZXJ0aW9uICovXG5pbXBvcnQgeyBTb2Z0VW5pb24sIFdpZGdldFByb3BzIGFzIFdpZGdldFByb3BzUHJlYWN0IH0gZnJvbSAnQHNpc2Vuc2Uvc2RrLXVpLXByZWFjdCc7XG5cbmltcG9ydCB7IFdpZGdldFByb3BzIH0gZnJvbSAnLi4vY29tcG9uZW50cy93aWRnZXRzJztcbmltcG9ydCB7XG4gIEFyZ3VtZW50cyxcbiAgQ2hhcnREYXRhUG9pbnRDbGlja0V2ZW50LFxuICBDaGFydERhdGFQb2ludENvbnRleHRNZW51RXZlbnQsXG4gIENoYXJ0RGF0YVBvaW50c0V2ZW50LFxuICBXaWRnZXREYXRhUG9pbnRDbGlja0V2ZW50LFxuICBXaWRnZXREYXRhUG9pbnRDbGlja0V2ZW50SGFuZGxlcixcbiAgV2lkZ2V0RGF0YVBvaW50Q29udGV4dE1lbnVFdmVudCxcbn0gZnJvbSAnLi4vdHlwZXMnO1xuXG50eXBlIFNvZnRXaWRnZXRQcm9wc1ByZWFjdCA9IFNvZnRVbmlvbjxXaWRnZXRQcm9wc1ByZWFjdD47XG5cbmV4cG9ydCBmdW5jdGlvbiB0cmFuc2xhdGVUb1ByZWFjdFdpZGdldFByb3BzKHdpZGdldFByb3BzOiBXaWRnZXRQcm9wcyk6IFdpZGdldFByb3BzUHJlYWN0IHtcbiAgY29uc3Qge1xuICAgIGJlZm9yZVJlbmRlcixcbiAgICBkYXRhUmVhZHksXG4gICAgYmVmb3JlTWVudU9wZW4sXG4gICAgZGF0YVBvaW50Q2xpY2ssXG4gICAgZGF0YVBvaW50Q29udGV4dE1lbnUsXG4gICAgZGF0YVBvaW50c1NlbGVjdCxcbiAgICAuLi5jb21tb25XaWRnZXRQcm9wc1xuICB9ID0gd2lkZ2V0UHJvcHM7XG4gIHJldHVybiB7XG4gICAgLi4uY29tbW9uV2lkZ2V0UHJvcHMsXG4gICAgb25CZWZvcmVSZW5kZXI6IGJlZm9yZVJlbmRlcixcbiAgICBvbkRhdGFSZWFkeTogZGF0YVJlYWR5LFxuICAgIG9uQmVmb3JlTWVudU9wZW46IGJlZm9yZU1lbnVPcGVuLFxuICAgIG9uRGF0YVBvaW50Q2xpY2s6IGRhdGFQb2ludENsaWNrXG4gICAgICA/ICguLi5bcG9pbnQsIG5hdGl2ZUV2ZW50XTogQXJndW1lbnRzPFNvZnRXaWRnZXRQcm9wc1ByZWFjdFsnb25EYXRhUG9pbnRDbGljayddPikgPT5cbiAgICAgICAgICAoZGF0YVBvaW50Q2xpY2sgYXMgV2lkZ2V0RGF0YVBvaW50Q2xpY2tFdmVudEhhbmRsZXIpKHtcbiAgICAgICAgICAgIHBvaW50LFxuICAgICAgICAgICAgbmF0aXZlRXZlbnQsXG4gICAgICAgICAgfSBhcyBXaWRnZXREYXRhUG9pbnRDbGlja0V2ZW50KVxuICAgICAgOiB1bmRlZmluZWQsXG4gICAgb25EYXRhUG9pbnRDb250ZXh0TWVudTogZGF0YVBvaW50Q29udGV4dE1lbnVcbiAgICAgID8gKC4uLltwb2ludCwgbmF0aXZlRXZlbnRdOiBBcmd1bWVudHM8U29mdFdpZGdldFByb3BzUHJlYWN0WydvbkRhdGFQb2ludENvbnRleHRNZW51J10+KSA9PlxuICAgICAgICAgIChkYXRhUG9pbnRDb250ZXh0TWVudSBhcyBXaWRnZXREYXRhUG9pbnRDbGlja0V2ZW50SGFuZGxlcikoe1xuICAgICAgICAgICAgcG9pbnQsXG4gICAgICAgICAgICBuYXRpdmVFdmVudCxcbiAgICAgICAgICB9IGFzIFdpZGdldERhdGFQb2ludENvbnRleHRNZW51RXZlbnQpXG4gICAgICA6IHVuZGVmaW5lZCxcbiAgICBvbkRhdGFQb2ludHNTZWxlY3RlZDogZGF0YVBvaW50c1NlbGVjdFxuICAgICAgPyAoLi4uW3BvaW50cywgbmF0aXZlRXZlbnRdOiBBcmd1bWVudHM8U29mdFdpZGdldFByb3BzUHJlYWN0WydvbkRhdGFQb2ludHNTZWxlY3RlZCddPikgPT5cbiAgICAgICAgICBkYXRhUG9pbnRzU2VsZWN0KHsgcG9pbnRzLCBuYXRpdmVFdmVudCB9IGFzIENoYXJ0RGF0YVBvaW50c0V2ZW50KVxuICAgICAgOiB1bmRlZmluZWQsXG4gIH0gYXMgV2lkZ2V0UHJvcHNQcmVhY3Q7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0cmFuc2xhdGVGcm9tUHJlYWN0V2lkZ2V0UHJvcHMod2lkZ2V0UHJvcHM6IFdpZGdldFByb3BzUHJlYWN0KTogV2lkZ2V0UHJvcHMge1xuICBjb25zdCB7XG4gICAgb25CZWZvcmVSZW5kZXIsXG4gICAgb25EYXRhUmVhZHksXG4gICAgb25CZWZvcmVNZW51T3BlbixcbiAgICBvbkRhdGFQb2ludENsaWNrLFxuICAgIG9uRGF0YVBvaW50Q29udGV4dE1lbnUsXG4gICAgb25EYXRhUG9pbnRzU2VsZWN0ZWQsXG4gICAgLi4uY29tbW9uV2lkZ2V0UHJvcHNcbiAgfSA9IHdpZGdldFByb3BzIGFzIFNvZnRXaWRnZXRQcm9wc1ByZWFjdDtcbiAgcmV0dXJuIHtcbiAgICAuLi5jb21tb25XaWRnZXRQcm9wcyxcbiAgICBiZWZvcmVSZW5kZXI6IG9uQmVmb3JlUmVuZGVyLFxuICAgIGRhdGFSZWFkeTogb25EYXRhUmVhZHksXG4gICAgYmVmb3JlTWVudU9wZW46IG9uQmVmb3JlTWVudU9wZW4sXG4gICAgZGF0YVBvaW50Q2xpY2s6IG9uRGF0YVBvaW50Q2xpY2tcbiAgICAgID8gKHsgcG9pbnQsIG5hdGl2ZUV2ZW50IH06IENoYXJ0RGF0YVBvaW50Q2xpY2tFdmVudCkgPT5cbiAgICAgICAgICBvbkRhdGFQb2ludENsaWNrKHBvaW50IGFzIGFueSwgbmF0aXZlRXZlbnQgYXMgYW55KVxuICAgICAgOiB1bmRlZmluZWQsXG4gICAgZGF0YVBvaW50Q29udGV4dE1lbnU6IG9uRGF0YVBvaW50Q29udGV4dE1lbnVcbiAgICAgID8gKHsgcG9pbnQsIG5hdGl2ZUV2ZW50IH06IENoYXJ0RGF0YVBvaW50Q29udGV4dE1lbnVFdmVudCkgPT5cbiAgICAgICAgICBvbkRhdGFQb2ludENvbnRleHRNZW51KHBvaW50IGFzIGFueSwgbmF0aXZlRXZlbnQgYXMgYW55KVxuICAgICAgOiB1bmRlZmluZWQsXG4gICAgZGF0YVBvaW50c1NlbGVjdDogb25EYXRhUG9pbnRzU2VsZWN0ZWRcbiAgICAgID8gKHsgcG9pbnRzLCBuYXRpdmVFdmVudCB9OiBDaGFydERhdGFQb2ludHNFdmVudCkgPT5cbiAgICAgICAgICBvbkRhdGFQb2ludHNTZWxlY3RlZChwb2ludHMgYXMgYW55LCBuYXRpdmVFdmVudCBhcyBhbnkpXG4gICAgICA6IHVuZGVmaW5lZCxcbiAgfSBhcyBXaWRnZXRQcm9wcztcbn1cbiJdfQ==
@@ -1,4 +1,4 @@
1
1
  // This file re-exports common types/utils from @sisense/sdk-ui-preact
2
2
  // Re-exports utils from @sisense/sdk-ui-preact
3
3
  export { boxWhiskerProcessResult, extractDimensionsAndMeasures } from '@sisense/sdk-ui-preact';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2RrLXVpLWNvcmUtZXhwb3J0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvc2RrLXVpLWNvcmUtZXhwb3J0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxzRUFBc0U7QUFFdEUsK0NBQStDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBmaWxlIHJlLWV4cG9ydHMgY29tbW9uIHR5cGVzL3V0aWxzIGZyb20gQHNpc2Vuc2Uvc2RrLXVpLXByZWFjdFxuXG4vLyBSZS1leHBvcnRzIHV0aWxzIGZyb20gQHNpc2Vuc2Uvc2RrLXVpLXByZWFjdFxuZXhwb3J0IHsgYm94V2hpc2tlclByb2Nlc3NSZXN1bHQsIGV4dHJhY3REaW1lbnNpb25zQW5kTWVhc3VyZXMgfSBmcm9tICdAc2lzZW5zZS9zZGstdWktcHJlYWN0JztcblxuLy8gUmUtZXhwb3J0cyB0eXBlcyBmcm9tIEBzaXNlbnNlL3Nkay11aS1wcmVhY3RcbmV4cG9ydCB0eXBlIHtcbiAgLy8gR2VuZXJhbCAoT3RoZXJzKTpcbiAgQXBwQ29uZmlnLFxuICBBcmVhbWFwQ2hhcnREYXRhT3B0aW9ucyxcbiAgQXJlYW1hcENoYXJ0VHlwZSxcbiAgQXJlYW1hcFN0eWxlT3B0aW9ucyxcbiAgQXJlYVJhbmdlU3R5bGVPcHRpb25zLFxuICBBcmVhU3R5bGVPcHRpb25zLFxuICBBcmVhU3VidHlwZSxcbiAgQXhpc0xhYmVsLFxuICAvLyBDaGFydHMgcmVsYXRlZDpcbiAgQmVmb3JlUmVuZGVySGFuZGxlcixcbiAgQm94cGxvdENoYXJ0Q3VzdG9tRGF0YU9wdGlvbnMsXG4gIEJveHBsb3RDaGFydERhdGFPcHRpb25zLFxuICBCb3hwbG90Q2hhcnRUeXBlLFxuICBCb3hwbG90RGF0YVBvaW50LFxuICBCb3hwbG90U3R5bGVPcHRpb25zLFxuICBCb3hwbG90U3VidHlwZSxcbiAgQm94V2hpc2tlclR5cGUsXG4gIENhbGVuZGFyRGF5T2ZXZWVrLFxuICBDYWxlbmRhckhlYXRtYXBDaGFydERhdGFPcHRpb25zLFxuICBDYWxlbmRhckhlYXRtYXBDaGFydFR5cGUsXG4gIENhbGVuZGFySGVhdG1hcERhdGFQb2ludCxcbiAgQ2FsZW5kYXJIZWF0bWFwU3R5bGVPcHRpb25zLFxuICBDYWxlbmRhckhlYXRtYXBTdWJ0eXBlLFxuICBDYWxlbmRhckhlYXRtYXBWaWV3VHlwZSxcbiAgQ2FydGVzaWFuQ2hhcnREYXRhT3B0aW9ucyxcbiAgQ2FydGVzaWFuQ2hhcnRUeXBlLFxuICBDYXJ0ZXNpYW5XaWRnZXRUeXBlLFxuICBDYXRlZ29yaWNhbENoYXJ0RGF0YU9wdGlvbnMsXG4gIENhdGVnb3JpY2FsQ2hhcnRUeXBlLFxuICBDYXRlZ29yaWNhbFdpZGdldFR5cGUsXG4gIC8vIERhdGEgT3B0aW9uczpcbiAgQ2hhcnREYXRhT3B0aW9ucyxcbiAgLy8gU3R5bGUgT3B0aW9uczpcbiAgQ2hhcnRTdHlsZU9wdGlvbnMsXG4gIENoYXJ0VHlwZSxcbiAgQ2hhcnRXaWRnZXRTdHlsZU9wdGlvbnMsXG4gIENvbG9yLFxuICBDb2xvclBhbGV0dGVUaGVtZSxcbiAgLy8gUHJvcHM6XG4gIENvbW1vbldpZGdldFByb3BzLFxuICBDb25kaXRpb25hbERhdGFDb2xvck9wdGlvbnMsXG4gIENvbnZvbHV0aW9uLFxuICAvLyBEYXNoYm9hcmQ6XG4gIERhc2hib2FyZExheW91dE9wdGlvbnMsXG4gIERhc2hib2FyZE1vZGVsLFxuICBEYXNoU3R5bGUsXG4gIERhdGFDb2xvckNvbmRpdGlvbixcbiAgRGF0YUNvbG9yT3B0aW9ucyxcbiAgLy8gU3R5bGUgcmVsYXRlZDpcbiAgRGF0YUxpbWl0cyxcbiAgRGF0YVBvaW50LFxuICBEYXRlQ29uZmlnLFxuICBEYXRlTGV2ZWwsXG4gIERheU9mV2VlayxcbiAgRGVjaW1hbFNjYWxlLFxuICBEcmlsbGRvd25PcHRpb25zLFxuICBEcmlsbGRvd25TZWxlY3Rpb24sXG4gIEVuZENhcFR5cGUsXG4gIEZpbHRlclZhcmlhbnQsXG4gIEZ1bm5lbFN0eWxlT3B0aW9ucyxcbiAgR2F1Z2VJbmRpY2F0b3JTdHlsZU9wdGlvbnMsXG4gIEdldERhc2hib2FyZE1vZGVsT3B0aW9ucyxcbiAgR2V0RGFzaGJvYXJkTW9kZWxzT3B0aW9ucyxcbiAgSGllcmFyY2h5LFxuICBIaWVyYXJjaHlNb2RlbCxcbiAgSGlnaGNoYXJ0c09wdGlvbnMsXG4gIEluZGljYXRvckJlZm9yZVJlbmRlckhhbmRsZXIsXG4gIEluZGljYXRvckNoYXJ0RGF0YU9wdGlvbnMsXG4gIEluZGljYXRvckNoYXJ0VHlwZSxcbiAgSW5kaWNhdG9yQ29tcG9uZW50cyxcbiAgSW5kaWNhdG9yRGF0YVBvaW50LFxuICBJbmRpY2F0b3JSZW5kZXJPcHRpb25zLFxuICBJbmRpY2F0b3JTdHlsZU9wdGlvbnMsXG4gIExhYmVscyxcbiAgTGVnZW5kLFxuICBMaW5lT3B0aW9ucyxcbiAgTGluZVN0eWxlT3B0aW9ucyxcbiAgTGluZVN1YnR5cGUsXG4gIExpbmVXaWR0aCxcbiAgTWFya2VycyxcbiAgTWVtYmVyLFxuICBNZW51SXRlbVNlY3Rpb24sXG4gIE1lbnVQb3NpdGlvbixcbiAgTW9udGhPZlllYXIsXG4gIE11bHRpQ29sdW1uVmFsdWVUb0NvbG9yTWFwLFxuICBOYXZpZ2F0b3IsXG4gIC8vIERhdGEgT3B0aW9ucyByZWxhdGVkOlxuICBOdW1iZXJGb3JtYXRDb25maWcsXG4gIE51bWVyaWNCYXJJbmRpY2F0b3JTdHlsZU9wdGlvbnMsXG4gIE51bWVyaWNTaW1wbGVJbmRpY2F0b3JTdHlsZU9wdGlvbnMsXG4gIFBpZVN0eWxlT3B0aW9ucyxcbiAgUGllU3VidHlwZSxcbiAgUGl2b3RSb3dzU29ydCxcbiAgUGl2b3RUYWJsZURhdGFPcHRpb25zLFxuICBQaXZvdFRhYmxlU3R5bGVPcHRpb25zLFxuICBQaXZvdFRhYmxlV2lkZ2V0U3R5bGVPcHRpb25zLFxuICBQb2xhclN0eWxlT3B0aW9ucyxcbiAgUG9sYXJTdWJ0eXBlLFxuICBSYW5nZUNoYXJ0RGF0YU9wdGlvbnMsXG4gIFJhbmdlQ2hhcnRUeXBlLFxuICBSYW5nZURhdGFDb2xvck9wdGlvbnMsXG4gIFNjYXR0ZXJDaGFydERhdGFPcHRpb25zLFxuICBTY2F0dGVyQ2hhcnRUeXBlLFxuICBTY2F0dGVyRGF0YVBvaW50LFxuICBTY2F0dGVybWFwQ2hhcnREYXRhT3B0aW9ucyxcbiAgU2NhdHRlcm1hcENoYXJ0VHlwZSxcbiAgU2NhdHRlcm1hcExvY2F0aW9uTGV2ZWwsXG4gIFNjYXR0ZXJtYXBNYXJrZXJzLFxuICBTY2F0dGVybWFwU3R5bGVPcHRpb25zLFxuICBTY2F0dGVyTWFya2VyU2l6ZSxcbiAgU2NhdHRlclN0eWxlT3B0aW9ucyxcbiAgU2VyaWVzQ2hhcnRUeXBlLFxuICBTZXJpZXNMYWJlbHMsXG4gIFNvcnREaXJlY3Rpb24sXG4gIFN0YWNrYWJsZVN0eWxlT3B0aW9ucyxcbiAgU3RhY2thYmxlU3VidHlwZSxcbiAgU3R5bGVkQ29sdW1uLFxuICBTdHlsZWRNZWFzdXJlQ29sdW1uLFxuICBTdHJlYW1ncmFwaFN0eWxlT3B0aW9ucyxcbiAgU3VuYnVyc3RTdHlsZU9wdGlvbnMsXG4gIFRhYmxlRGF0YU9wdGlvbnMsXG4gIFRhYmxlU3R5bGVPcHRpb25zLFxuICBUYWJsZVR5cGUsXG4gIFRhYnVsYXJXaWRnZXRUeXBlLFxuICBUaGVtZU9pZCxcbiAgVGhlbWVTZXR0aW5ncyxcbiAgVHJhbnNsYXRpb25Db25maWcsXG4gIFRyZWVtYXBTdHlsZU9wdGlvbnMsXG4gIFVuaWZvcm1EYXRhQ29sb3JPcHRpb25zLFxuICBWYWx1ZVRvQ29sb3JNYXAsXG4gIFdpZGdldEJ5SWRTdHlsZU9wdGlvbnMsXG4gIFdpZGdldERhdGFPcHRpb25zLFxuICBXaWRnZXRJZCxcbiAgLy8gTW9kZWxzOlxuICBXaWRnZXRNb2RlbCxcbiAgV2lkZ2V0c09wdGlvbnMsXG4gIFdpZGdldHNQYW5lbENvbHVtbkxheW91dCxcbiAgV2lkZ2V0c1BhbmVsTGF5b3V0LFxuICBXaWRnZXRTdHlsZU9wdGlvbnMsXG4gIFdpZGdldFR5cGUsXG4gIFgyVGl0bGUsXG59IGZyb20gJ0BzaXNlbnNlL3Nkay11aS1wcmVhY3QnO1xuIl19
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2RrLXVpLWNvcmUtZXhwb3J0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9saWIvc2RrLXVpLWNvcmUtZXhwb3J0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxzRUFBc0U7QUFFdEUsK0NBQStDO0FBQy9DLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVGhpcyBmaWxlIHJlLWV4cG9ydHMgY29tbW9uIHR5cGVzL3V0aWxzIGZyb20gQHNpc2Vuc2Uvc2RrLXVpLXByZWFjdFxuXG4vLyBSZS1leHBvcnRzIHV0aWxzIGZyb20gQHNpc2Vuc2Uvc2RrLXVpLXByZWFjdFxuZXhwb3J0IHsgYm94V2hpc2tlclByb2Nlc3NSZXN1bHQsIGV4dHJhY3REaW1lbnNpb25zQW5kTWVhc3VyZXMgfSBmcm9tICdAc2lzZW5zZS9zZGstdWktcHJlYWN0JztcblxuLy8gUmUtZXhwb3J0cyB0eXBlcyBmcm9tIEBzaXNlbnNlL3Nkay11aS1wcmVhY3RcbmV4cG9ydCB0eXBlIHtcbiAgLy8gR2VuZXJhbCAoT3RoZXJzKTpcbiAgQXBwQ29uZmlnLFxuICBBcmVhbWFwQ2hhcnREYXRhT3B0aW9ucyxcbiAgQXJlYW1hcENoYXJ0VHlwZSxcbiAgQXJlYW1hcFN0eWxlT3B0aW9ucyxcbiAgQXJlYVJhbmdlU3R5bGVPcHRpb25zLFxuICBBcmVhU3R5bGVPcHRpb25zLFxuICBBcmVhU3VidHlwZSxcbiAgQXhpc0xhYmVsLFxuICAvLyBDaGFydHMgcmVsYXRlZDpcbiAgQmVmb3JlUmVuZGVySGFuZGxlcixcbiAgQm94cGxvdENoYXJ0Q3VzdG9tRGF0YU9wdGlvbnMsXG4gIEJveHBsb3RDaGFydERhdGFPcHRpb25zLFxuICBCb3hwbG90Q2hhcnRUeXBlLFxuICBCb3hwbG90RGF0YVBvaW50LFxuICBCb3hwbG90U3R5bGVPcHRpb25zLFxuICBCb3hwbG90U3VidHlwZSxcbiAgQm94V2hpc2tlclR5cGUsXG4gIENhbGVuZGFyRGF5T2ZXZWVrLFxuICBDYWxlbmRhckhlYXRtYXBDaGFydERhdGFPcHRpb25zLFxuICBDYWxlbmRhckhlYXRtYXBDaGFydFR5cGUsXG4gIENhbGVuZGFySGVhdG1hcERhdGFQb2ludCxcbiAgQ2FsZW5kYXJIZWF0bWFwU3R5bGVPcHRpb25zLFxuICBDYWxlbmRhckhlYXRtYXBTdWJ0eXBlLFxuICBDYWxlbmRhckhlYXRtYXBWaWV3VHlwZSxcbiAgQ2FydGVzaWFuQ2hhcnREYXRhT3B0aW9ucyxcbiAgQ2FydGVzaWFuQ2hhcnRUeXBlLFxuICBDYXJ0ZXNpYW5XaWRnZXRUeXBlLFxuICBDYXRlZ29yaWNhbENoYXJ0RGF0YU9wdGlvbnMsXG4gIENhdGVnb3JpY2FsQ2hhcnRUeXBlLFxuICBDYXRlZ29yaWNhbFdpZGdldFR5cGUsXG4gIC8vIERhdGEgT3B0aW9uczpcbiAgQ2hhcnREYXRhT3B0aW9ucyxcbiAgLy8gU3R5bGUgT3B0aW9uczpcbiAgQ2hhcnRTdHlsZU9wdGlvbnMsXG4gIENoYXJ0VHlwZSxcbiAgQ2hhcnRXaWRnZXRTdHlsZU9wdGlvbnMsXG4gIENvbG9yLFxuICBDb2xvclBhbGV0dGVUaGVtZSxcbiAgLy8gUHJvcHM6XG4gIENvbW1vbldpZGdldFByb3BzLFxuICBDb25kaXRpb25hbERhdGFDb2xvck9wdGlvbnMsXG4gIENvbnZvbHV0aW9uLFxuICAvLyBEYXNoYm9hcmQ6XG4gIERhc2hib2FyZExheW91dE9wdGlvbnMsXG4gIERhc2hib2FyZE1vZGVsLFxuICBEYXNoU3R5bGUsXG4gIERhdGFDb2xvckNvbmRpdGlvbixcbiAgRGF0YUNvbG9yT3B0aW9ucyxcbiAgLy8gU3R5bGUgcmVsYXRlZDpcbiAgRGF0YUxpbWl0cyxcbiAgRGF0YU9wdGlvbkxvY2F0aW9uLFxuICBEYXRhUG9pbnQsXG4gIERhdGVDb25maWcsXG4gIERhdGVMZXZlbCxcbiAgRGF5T2ZXZWVrLFxuICBEZWNpbWFsU2NhbGUsXG4gIERyaWxsZG93bk9wdGlvbnMsXG4gIERyaWxsZG93blNlbGVjdGlvbixcbiAgRW5kQ2FwVHlwZSxcbiAgRmlsdGVyVmFyaWFudCxcbiAgRnVubmVsU3R5bGVPcHRpb25zLFxuICBHYXVnZUluZGljYXRvclN0eWxlT3B0aW9ucyxcbiAgR2V0RGFzaGJvYXJkTW9kZWxPcHRpb25zLFxuICBHZXREYXNoYm9hcmRNb2RlbHNPcHRpb25zLFxuICBIaWVyYXJjaHksXG4gIEhpZXJhcmNoeU1vZGVsLFxuICBIaWdoY2hhcnRzT3B0aW9ucyxcbiAgSW5kaWNhdG9yQmVmb3JlUmVuZGVySGFuZGxlcixcbiAgSW5kaWNhdG9yQ2hhcnREYXRhT3B0aW9ucyxcbiAgSW5kaWNhdG9yQ2hhcnRUeXBlLFxuICBJbmRpY2F0b3JDb21wb25lbnRzLFxuICBJbmRpY2F0b3JEYXRhUG9pbnQsXG4gIEluZGljYXRvclJlbmRlck9wdGlvbnMsXG4gIEluZGljYXRvclN0eWxlT3B0aW9ucyxcbiAgTGFiZWxzLFxuICBMZWdlbmQsXG4gIExpbmVPcHRpb25zLFxuICBMaW5lU3R5bGVPcHRpb25zLFxuICBMaW5lU3VidHlwZSxcbiAgTGluZVdpZHRoLFxuICBNYXJrZXJzLFxuICBNZW1iZXIsXG4gIE1lbnVJdGVtU2VjdGlvbixcbiAgTWVudVBvc2l0aW9uLFxuICBNb250aE9mWWVhcixcbiAgTXVsdGlDb2x1bW5WYWx1ZVRvQ29sb3JNYXAsXG4gIE5hdmlnYXRvcixcbiAgLy8gRGF0YSBPcHRpb25zIHJlbGF0ZWQ6XG4gIE51bWJlckZvcm1hdENvbmZpZyxcbiAgTnVtZXJpY0JhckluZGljYXRvclN0eWxlT3B0aW9ucyxcbiAgTnVtZXJpY1NpbXBsZUluZGljYXRvclN0eWxlT3B0aW9ucyxcbiAgUGllU3R5bGVPcHRpb25zLFxuICBQaWVTdWJ0eXBlLFxuICBQaXZvdFJvd3NTb3J0LFxuICBQaXZvdFRhYmxlRGF0YU9wdGlvbnMsXG4gIFBpdm90VGFibGVEcmlsbGRvd25PcHRpb25zLFxuICBQaXZvdFRhYmxlTm9uU2VsZWN0YWJsZURyaWxsZG93bk9wdGlvbnMsXG4gIFBpdm90VGFibGVTZWxlY3RhYmxlRHJpbGxkb3duT3B0aW9ucyxcbiAgUGl2b3RUYWJsZVN0eWxlT3B0aW9ucyxcbiAgUGl2b3RUYWJsZVdpZGdldFN0eWxlT3B0aW9ucyxcbiAgUG9sYXJTdHlsZU9wdGlvbnMsXG4gIFBvbGFyU3VidHlwZSxcbiAgUmFuZ2VDaGFydERhdGFPcHRpb25zLFxuICBSYW5nZUNoYXJ0VHlwZSxcbiAgUmFuZ2VEYXRhQ29sb3JPcHRpb25zLFxuICBTY2F0dGVyQ2hhcnREYXRhT3B0aW9ucyxcbiAgU2NhdHRlckNoYXJ0VHlwZSxcbiAgU2NhdHRlckRhdGFQb2ludCxcbiAgU2NhdHRlcm1hcENoYXJ0RGF0YU9wdGlvbnMsXG4gIFNjYXR0ZXJtYXBDaGFydFR5cGUsXG4gIFNjYXR0ZXJtYXBMb2NhdGlvbkxldmVsLFxuICBTY2F0dGVybWFwTWFya2VycyxcbiAgU2NhdHRlcm1hcFN0eWxlT3B0aW9ucyxcbiAgU2NhdHRlck1hcmtlclNpemUsXG4gIFNjYXR0ZXJTdHlsZU9wdGlvbnMsXG4gIFNlcmllc0NoYXJ0VHlwZSxcbiAgU2VyaWVzTGFiZWxzLFxuICBTb3J0RGlyZWN0aW9uLFxuICBTdGFja2FibGVTdHlsZU9wdGlvbnMsXG4gIFN0YWNrYWJsZVN1YnR5cGUsXG4gIFN0eWxlZENvbHVtbixcbiAgU3R5bGVkTWVhc3VyZUNvbHVtbixcbiAgU3RyZWFtZ3JhcGhTdHlsZU9wdGlvbnMsXG4gIFN1bmJ1cnN0U3R5bGVPcHRpb25zLFxuICBUYWJsZURhdGFPcHRpb25zLFxuICBUYWJsZVN0eWxlT3B0aW9ucyxcbiAgVGFibGVUeXBlLFxuICBUYWJ1bGFyV2lkZ2V0VHlwZSxcbiAgVGhlbWVPaWQsXG4gIFRoZW1lU2V0dGluZ3MsXG4gIFRyYW5zbGF0aW9uQ29uZmlnLFxuICBUcmVlbWFwU3R5bGVPcHRpb25zLFxuICBVbmlmb3JtRGF0YUNvbG9yT3B0aW9ucyxcbiAgVmFsdWVUb0NvbG9yTWFwLFxuICBXaWRnZXRCeUlkU3R5bGVPcHRpb25zLFxuICBXaWRnZXREYXRhT3B0aW9ucyxcbiAgV2lkZ2V0SWQsXG4gIEp1bXBUb0Rhc2hib2FyZENvbmZpZyxcbiAgSnVtcFRvRGFzaGJvYXJkQ29uZmlnRm9yUGl2b3QsXG4gIC8vIE1vZGVsczpcbiAgV2lkZ2V0TW9kZWwsXG4gIFdpZGdldHNPcHRpb25zLFxuICBXaWRnZXRzUGFuZWxDb2x1bW5MYXlvdXQsXG4gIFdpZGdldHNQYW5lbExheW91dCxcbiAgV2lkZ2V0U3R5bGVPcHRpb25zLFxuICBXaWRnZXRUeXBlLFxuICBYMlRpdGxlLFxufSBmcm9tICdAc2lzZW5zZS9zZGstdWktcHJlYWN0JztcbiJdfQ==
@@ -77,7 +77,7 @@ let DashboardService = class DashboardService {
77
77
  *
78
78
  * ```ts
79
79
  // Component behavior in example.component.ts
80
- import { Component } from '@angular/core';
80
+ import { Component, OnDestroy } from '@angular/core';
81
81
  import { BehaviorSubject } from 'rxjs';
82
82
  import { DashboardService, type DashboardProps } from '@sisense/sdk-ui-angular';
83
83
 
@@ -86,15 +86,20 @@ let DashboardService = class DashboardService {
86
86
  templateUrl: './example.component.html',
87
87
  styleUrls: ['./example.component.scss'],
88
88
  })
89
- export class ExampleComponent {
89
+ export class ExampleComponent implements OnDestroy {
90
90
  dashboard$: BehaviorSubject<DashboardProps> | undefined;
91
+ private composedDashboard: ReturnType<DashboardService['createComposedDashboard']> | undefined;
91
92
 
92
93
  constructor(private dashboardService: DashboardService) {}
93
94
 
94
95
  ngOnInit() {
95
96
  const initialDashboard: DashboardProps = { ... };
96
- const composedDashboard = this.dashboardService.createComposedDashboard(initialDashboard);
97
- this.dashboard$ = composedDashboard.dashboard$;
97
+ this.composedDashboard = this.dashboardService.createComposedDashboard(initialDashboard);
98
+ this.dashboard$ = this.composedDashboard.dashboard$;
99
+ }
100
+
101
+ ngOnDestroy() {
102
+ this.composedDashboard?.destroy();
98
103
  }
99
104
 
100
105
  trackByIndex = (index: number) => index;
@@ -104,7 +109,9 @@ let DashboardService = class DashboardService {
104
109
  * ```
105
110
  * @param initialDashboard - Initial dashboard
106
111
  * @param options - Configuration options
107
- * @returns Reactive composed dashboard object and API methods for interacting with it
112
+ * @returns Reactive composed dashboard object and API methods for interacting with it.
113
+ * The returned object includes a `destroy()` method that should be called when
114
+ * the dashboard is no longer needed to prevent memory leaks (e.g., in `ngOnDestroy`).
108
115
  */
109
116
  createComposedDashboard(initialDashboard, options = {}) {
110
117
  const hookAdapter = new HookAdapter((useComposedDashboardInternal), [createSisenseContextConnector(this.sisenseContextService)]);
@@ -115,10 +122,15 @@ let DashboardService = class DashboardService {
115
122
  hookAdapter.run(translateToPreactDashboardProps(initialDashboard), options);
116
123
  const setFilters = createHookApiFacade(hookAdapter, 'setFilters', true);
117
124
  const setWidgetsLayout = createHookApiFacade(hookAdapter, 'setWidgetsLayout', true);
125
+ const destroy = () => {
126
+ hookAdapter.destroy();
127
+ dashboard$.complete();
128
+ };
118
129
  return {
119
130
  dashboard$,
120
131
  setFilters,
121
132
  setWidgetsLayout,
133
+ destroy,
122
134
  };
123
135
  }
124
136
  };
@@ -134,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
134
146
  providedIn: 'root',
135
147
  }]
136
148
  }], ctorParameters: function () { return [{ type: i1.SisenseContextService }]; } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.service.js","sourceRoot":"","sources":["../../../../src/lib/services/dashboard.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAEL,mBAAmB,EAEnB,iBAAiB,EAEjB,kBAAkB,EAElB,WAAW,EACX,4BAA4B,GAG7B,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AAEvC,OAAO,EAAE,6BAA6B,EAAE,MAAM,8BAA8B,CAAC;AAG7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EACL,iCAAiC,EACjC,+BAA+B,GAChC,MAAM,8CAA8C,CAAC;;;AAOtD;;;;;;;GAOG;AAKI,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAC3B,YAAoB,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;IAAG,CAAC;IAEpE;;;;;;OAMG;IACH,KAAK,CAAC,iBAAiB,CAAC,YAAoB,EAAE,OAAkC;QAC9E,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,CAAC;QACtD,OAAO,iBAAiB,CAAC,GAAG,CAAC,UAAU,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC;IAClE,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,kBAAkB,CAAC,OAAmC;QAC1D,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,CAAC;QACtD,OAAO,kBAAkB,CAAC,GAAG,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAiEG;IACH,uBAAuB,CACrB,gBAAmB,EACnB,UAAuC,EAAE;QAMzC,MAAM,WAAW,GAAG,IAAI,WAAW,CACjC,CAAA,4BAAmF,CAAA,EACnF,CAAC,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAC5D,CAAC;QACF,MAAM,UAAU,GAAG,IAAI,eAAe,CAAI,gBAAgB,CAAC,CAAC;QAE5D,WAAW,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE;YACtC,UAAU,CAAC,IAAI,CAAC,iCAAiC,CAAC,SAAS,CAAM,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;QAEH,WAAW,CAAC,GAAG,CACb,+BAA+B,CAAC,gBAAgB,CAExB,EACxB,OAAO,CACR,CAAC;QAEF,MAAM,UAAU,GAAG,mBAAmB,CAAC,WAAW,EAAE,YAAY,EAAE,IAAI,CAAC,CAAC;QACxE,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,WAAW,EAAE,kBAAkB,EAAE,IAAI,CAAC,CAAC;QAEpF,OAAO;YACL,UAAU;YACV,UAAU;YACV,gBAAgB;SACjB,CAAC;IACJ,CAAC;;8GA7HU,gBAAgB;kHAAhB,gBAAgB,cAHf,MAAM;AAGP,gBAAgB;IAD5B,gBAAgB,CAAmB,CAAC,mBAAmB,EAAE,oBAAoB,CAAC,CAAC;GACnE,gBAAgB,CA8H5B;SA9HY,gBAAgB;4FAAhB,gBAAgB;kBAJ5B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Filter, FilterRelations } from '@sisense/sdk-data';\nimport {\n  type ComposableDashboardProps as ComposableDashboardPropsPreact,\n  createHookApiFacade,\n  type DashboardProps as DashboardPropsPreact,\n  getDashboardModel,\n  type GetDashboardModelOptions,\n  getDashboardModels,\n  type GetDashboardModelsOptions,\n  HookAdapter,\n  useComposedDashboardInternal,\n  UseComposedDashboardOptions,\n  WidgetsPanelLayout,\n} from '@sisense/sdk-ui-preact';\nimport { BehaviorSubject } from 'rxjs';\n\nimport { createSisenseContextConnector } from '../component-wrapper-helpers';\nimport { type DashboardProps } from '../components/dashboard/dashboard.component';\nimport { type WidgetProps } from '../components/widgets/widget.component';\nimport { TrackableService } from '../decorators/trackable.decorator';\nimport {\n  translateFromPreactDashboardProps,\n  translateToPreactDashboardProps,\n} from '../helpers/dashboard-props-preact-translator';\nimport { SisenseContextService } from './sisense-context.service';\n\nexport interface ComposableDashboardProps extends Omit<ComposableDashboardPropsPreact, 'widgets'> {\n  widgets: WidgetProps[];\n}\n\n/**\n * Service for working with Sisense Fusion dashboards.\n *\n * **Note:** Dashboard and Widget extensions based on JS scripts and add-ons in Fusion – for example, Blox and Jump To Dashboard – are not supported.\n *\n * @group Fusion Assets\n * @fusionEmbed\n */\n@Injectable({\n  providedIn: 'root',\n})\n@TrackableService<DashboardService>(['getDashboardModel', 'getDashboardModels'])\nexport class DashboardService {\n  constructor(private sisenseContextService: SisenseContextService) {}\n\n  /**\n   * Retrieves an existing dashboard model from the Sisense instance.\n   *\n   * @param dashboardOid - Identifier of the dashboard\n   * @param options - Advanced configuration options\n   * @returns Dashboard model\n   */\n  async getDashboardModel(dashboardOid: string, options?: GetDashboardModelOptions) {\n    const app = await this.sisenseContextService.getApp();\n    return getDashboardModel(app.httpClient, dashboardOid, options);\n  }\n\n  /**\n   * Retrieves existing dashboard models from the Sisense instance.\n   *\n   * @param options - Advanced configuration options\n   * @returns Dashboard models array\n   */\n  async getDashboardModels(options?: GetDashboardModelsOptions) {\n    const app = await this.sisenseContextService.getApp();\n    return getDashboardModels(app.httpClient, options);\n  }\n\n  /**\n   * Сomposes dashboard or separate dashboard elements into a coordinated dashboard\n   * with cross filtering, and change detection.\n   *\n   * @example\n   * An example of using the `createComposedDashboard` to construct a composed dashboard and render it:\n   * ```html\n    <!--Component HTML template in example.component.html-->\n    <div *ngIf=\"dashboard$ | async as dashboard\">\n      <csdk-filter-tile\n        *ngFor=\"let filter of getDashboardFilters(dashboard); trackBy: trackByIndex\"\n        [filter]=\"filter\"\n      />\n      <csdk-widget\n        *ngFor=\"let widget of dashboard.widgets; trackBy: trackByIndex\"\n        [id]=\"widget.id\"\n        [widgetType]=\"widget.widgetType\"\n        [chartType]=\"widget.chartType\"\n        [customWidgetType]=\"widget.customWidgetType\"\n        [dataSource]=\"widget.dataSource\"\n        [dataOptions]=\"widget.dataOptions\"\n        [filters]=\"widget.filters\"\n        [highlights]=\"widget.highlights\"\n        [styleOptions]=\"widget.styleOptions\"\n        [drilldownOptions]=\"widget.drilldownOptions\"\n        [title]=\"widget.title\"\n        [description]=\"widget.description\"\n        [beforeMenuOpen]=\"widget.beforeMenuOpen\"\n        (dataPointClick)=\"widget.dataPointClick?.($event)\"\n        (dataPointContextMenu)=\"widget.dataPointContextMenu?.($event)\"\n        (dataPointsSelect)=\"widget.dataPointsSelect?.($event)\"\n      />\n    </div>\n   * ```\n   *\n   * ```ts\n    // Component behavior in example.component.ts\n    import { Component } from '@angular/core';\n    import { BehaviorSubject } from 'rxjs';\n    import { DashboardService, type DashboardProps } from '@sisense/sdk-ui-angular';\n\n    @Component({\n      selector: 'example',\n      templateUrl: './example.component.html',\n      styleUrls: ['./example.component.scss'],\n    })\n    export class ExampleComponent {\n      dashboard$: BehaviorSubject<DashboardProps> | undefined;\n\n      constructor(private dashboardService: DashboardService) {}\n\n      ngOnInit() {\n        const initialDashboard: DashboardProps = { ... };\n        const composedDashboard = this.dashboardService.createComposedDashboard(initialDashboard);\n        this.dashboard$ = composedDashboard.dashboard$;\n      }\n\n      trackByIndex = (index: number) => index;\n\n      getDashboardFilters = ({ filters }: DashboardProps) => Array.isArray(filters) ? filters : [];\n    }\n   * ```\n   * @param initialDashboard - Initial dashboard\n   * @param options - Configuration options\n   * @returns Reactive composed dashboard object and API methods for interacting with it\n   */\n  createComposedDashboard<D extends ComposableDashboardProps | DashboardProps>(\n    initialDashboard: D,\n    options: UseComposedDashboardOptions = {},\n  ): {\n    dashboard$: BehaviorSubject<D>;\n    setFilters: (filters: Filter[] | FilterRelations) => Promise<void>;\n    setWidgetsLayout: (newLayout: WidgetsPanelLayout) => Promise<void>;\n  } {\n    const hookAdapter = new HookAdapter(\n      useComposedDashboardInternal<ComposableDashboardPropsPreact | DashboardPropsPreact>,\n      [createSisenseContextConnector(this.sisenseContextService)],\n    );\n    const dashboard$ = new BehaviorSubject<D>(initialDashboard);\n\n    hookAdapter.subscribe(({ dashboard }) => {\n      dashboard$.next(translateFromPreactDashboardProps(dashboard) as D);\n    });\n\n    hookAdapter.run(\n      translateToPreactDashboardProps(initialDashboard) as\n        | ComposableDashboardPropsPreact\n        | DashboardPropsPreact,\n      options,\n    );\n\n    const setFilters = createHookApiFacade(hookAdapter, 'setFilters', true);\n    const setWidgetsLayout = createHookApiFacade(hookAdapter, 'setWidgetsLayout', true);\n\n    return {\n      dashboard$,\n      setFilters,\n      setWidgetsLayout,\n    };\n  }\n}\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.service.js","sourceRoot":"","sources":["../../../../src/lib/services/dashboard.service.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EAEL,mBAAmB,EAEnB,iBAAiB,EAEjB,kBAAkB,EAElB,WAAW,EACX,4BAA4B,GAG7B,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;AAEvC,OAAO,EAAE,6BAA6B,EAAE,MAAM,8BAA8B,CAAC;AAG7E,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EACL,iCAAiC,EACjC,+BAA+B,GAChC,MAAM,8CAA8C,CAAC;;;AAOtD;;;;;;;GAOG;AAKI,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAC3B,YAAoB,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;IAAG,CAAC;IAEpE;;;;;;OAMG;IACH,KAAK,CAAC,iBAAiB,CAAC,YAAoB,EAAE,OAAkC;QAC9E,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,CAAC;QACtD,OAAO,iBAAiB,CAAC,GAAG,CAAC,UAAU,EAAE,YAAY,EAAE,OAAO,CAAC,CAAC;IAClE,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,kBAAkB,CAAC,OAAmC;QAC1D,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,CAAC;QACtD,OAAO,kBAAkB,CAAC,GAAG,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;IACrD,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAwEG;IACH,uBAAuB,CACrB,gBAAmB,EACnB,UAAuC,EAAE;QAOzC,MAAM,WAAW,GAAG,IAAI,WAAW,CACjC,CAAA,4BAAmF,CAAA,EACnF,CAAC,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAC5D,CAAC;QACF,MAAM,UAAU,GAAG,IAAI,eAAe,CAAI,gBAAgB,CAAC,CAAC;QAE5D,WAAW,CAAC,SAAS,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE;YACtC,UAAU,CAAC,IAAI,CAAC,iCAAiC,CAAC,SAAS,CAAM,CAAC,CAAC;QACrE,CAAC,CAAC,CAAC;QAEH,WAAW,CAAC,GAAG,CACb,+BAA+B,CAAC,gBAAgB,CAExB,EACxB,OAAO,CACR,CAAC;QAEF,MAAM,UAAU,GAAG,mBAAmB,CAAC,WAAW,EAAE,YAAY,EAAE,IAAI,CAAC,CAAC;QACxE,MAAM,gBAAgB,GAAG,mBAAmB,CAAC,WAAW,EAAE,kBAAkB,EAAE,IAAI,CAAC,CAAC;QAEpF,MAAM,OAAO,GAAG,GAAG,EAAE;YACnB,WAAW,CAAC,OAAO,EAAE,CAAC;YACtB,UAAU,CAAC,QAAQ,EAAE,CAAC;QACxB,CAAC,CAAC;QAEF,OAAO;YACL,UAAU;YACV,UAAU;YACV,gBAAgB;YAChB,OAAO;SACR,CAAC;IACJ,CAAC;;8GA3IU,gBAAgB;kHAAhB,gBAAgB,cAHf,MAAM;AAGP,gBAAgB;IAD5B,gBAAgB,CAAmB,CAAC,mBAAmB,EAAE,oBAAoB,CAAC,CAAC;GACnE,gBAAgB,CA4I5B;SA5IY,gBAAgB;4FAAhB,gBAAgB;kBAJ5B,UAAU;mBAAC;oBACV,UAAU,EAAE,MAAM;iBACnB","sourcesContent":["import { Injectable } from '@angular/core';\nimport { Filter, FilterRelations } from '@sisense/sdk-data';\nimport {\n  type ComposableDashboardProps as ComposableDashboardPropsPreact,\n  createHookApiFacade,\n  type DashboardProps as DashboardPropsPreact,\n  getDashboardModel,\n  type GetDashboardModelOptions,\n  getDashboardModels,\n  type GetDashboardModelsOptions,\n  HookAdapter,\n  useComposedDashboardInternal,\n  UseComposedDashboardOptions,\n  WidgetsPanelLayout,\n} from '@sisense/sdk-ui-preact';\nimport { BehaviorSubject } from 'rxjs';\n\nimport { createSisenseContextConnector } from '../component-wrapper-helpers';\nimport { type DashboardProps } from '../components/dashboard/dashboard.component';\nimport { type WidgetProps } from '../components/widgets/widget.component';\nimport { TrackableService } from '../decorators/trackable.decorator';\nimport {\n  translateFromPreactDashboardProps,\n  translateToPreactDashboardProps,\n} from '../helpers/dashboard-props-preact-translator';\nimport { SisenseContextService } from './sisense-context.service';\n\nexport interface ComposableDashboardProps extends Omit<ComposableDashboardPropsPreact, 'widgets'> {\n  widgets: WidgetProps[];\n}\n\n/**\n * Service for working with Sisense Fusion dashboards.\n *\n * **Note:** Dashboard and Widget extensions based on JS scripts and add-ons in Fusion – for example, Blox and Jump To Dashboard – are not supported.\n *\n * @group Fusion Assets\n * @fusionEmbed\n */\n@Injectable({\n  providedIn: 'root',\n})\n@TrackableService<DashboardService>(['getDashboardModel', 'getDashboardModels'])\nexport class DashboardService {\n  constructor(private sisenseContextService: SisenseContextService) {}\n\n  /**\n   * Retrieves an existing dashboard model from the Sisense instance.\n   *\n   * @param dashboardOid - Identifier of the dashboard\n   * @param options - Advanced configuration options\n   * @returns Dashboard model\n   */\n  async getDashboardModel(dashboardOid: string, options?: GetDashboardModelOptions) {\n    const app = await this.sisenseContextService.getApp();\n    return getDashboardModel(app.httpClient, dashboardOid, options);\n  }\n\n  /**\n   * Retrieves existing dashboard models from the Sisense instance.\n   *\n   * @param options - Advanced configuration options\n   * @returns Dashboard models array\n   */\n  async getDashboardModels(options?: GetDashboardModelsOptions) {\n    const app = await this.sisenseContextService.getApp();\n    return getDashboardModels(app.httpClient, options);\n  }\n\n  /**\n   * Сomposes dashboard or separate dashboard elements into a coordinated dashboard\n   * with cross filtering, and change detection.\n   *\n   * @example\n   * An example of using the `createComposedDashboard` to construct a composed dashboard and render it:\n   * ```html\n    <!--Component HTML template in example.component.html-->\n    <div *ngIf=\"dashboard$ | async as dashboard\">\n      <csdk-filter-tile\n        *ngFor=\"let filter of getDashboardFilters(dashboard); trackBy: trackByIndex\"\n        [filter]=\"filter\"\n      />\n      <csdk-widget\n        *ngFor=\"let widget of dashboard.widgets; trackBy: trackByIndex\"\n        [id]=\"widget.id\"\n        [widgetType]=\"widget.widgetType\"\n        [chartType]=\"widget.chartType\"\n        [customWidgetType]=\"widget.customWidgetType\"\n        [dataSource]=\"widget.dataSource\"\n        [dataOptions]=\"widget.dataOptions\"\n        [filters]=\"widget.filters\"\n        [highlights]=\"widget.highlights\"\n        [styleOptions]=\"widget.styleOptions\"\n        [drilldownOptions]=\"widget.drilldownOptions\"\n        [title]=\"widget.title\"\n        [description]=\"widget.description\"\n        [beforeMenuOpen]=\"widget.beforeMenuOpen\"\n        (dataPointClick)=\"widget.dataPointClick?.($event)\"\n        (dataPointContextMenu)=\"widget.dataPointContextMenu?.($event)\"\n        (dataPointsSelect)=\"widget.dataPointsSelect?.($event)\"\n      />\n    </div>\n   * ```\n   *\n   * ```ts\n    // Component behavior in example.component.ts\n    import { Component, OnDestroy } from '@angular/core';\n    import { BehaviorSubject } from 'rxjs';\n    import { DashboardService, type DashboardProps } from '@sisense/sdk-ui-angular';\n\n    @Component({\n      selector: 'example',\n      templateUrl: './example.component.html',\n      styleUrls: ['./example.component.scss'],\n    })\n    export class ExampleComponent implements OnDestroy {\n      dashboard$: BehaviorSubject<DashboardProps> | undefined;\n      private composedDashboard: ReturnType<DashboardService['createComposedDashboard']> | undefined;\n\n      constructor(private dashboardService: DashboardService) {}\n\n      ngOnInit() {\n        const initialDashboard: DashboardProps = { ... };\n        this.composedDashboard = this.dashboardService.createComposedDashboard(initialDashboard);\n        this.dashboard$ = this.composedDashboard.dashboard$;\n      }\n\n      ngOnDestroy() {\n        this.composedDashboard?.destroy();\n      }\n\n      trackByIndex = (index: number) => index;\n\n      getDashboardFilters = ({ filters }: DashboardProps) => Array.isArray(filters) ? filters : [];\n    }\n   * ```\n   * @param initialDashboard - Initial dashboard\n   * @param options - Configuration options\n   * @returns Reactive composed dashboard object and API methods for interacting with it.\n   * The returned object includes a `destroy()` method that should be called when\n   * the dashboard is no longer needed to prevent memory leaks (e.g., in `ngOnDestroy`).\n   */\n  createComposedDashboard<D extends ComposableDashboardProps | DashboardProps>(\n    initialDashboard: D,\n    options: UseComposedDashboardOptions = {},\n  ): {\n    dashboard$: BehaviorSubject<D>;\n    setFilters: (filters: Filter[] | FilterRelations) => Promise<void>;\n    setWidgetsLayout: (newLayout: WidgetsPanelLayout) => Promise<void>;\n    destroy: () => void;\n  } {\n    const hookAdapter = new HookAdapter(\n      useComposedDashboardInternal<ComposableDashboardPropsPreact | DashboardPropsPreact>,\n      [createSisenseContextConnector(this.sisenseContextService)],\n    );\n    const dashboard$ = new BehaviorSubject<D>(initialDashboard);\n\n    hookAdapter.subscribe(({ dashboard }) => {\n      dashboard$.next(translateFromPreactDashboardProps(dashboard) as D);\n    });\n\n    hookAdapter.run(\n      translateToPreactDashboardProps(initialDashboard) as\n        | ComposableDashboardPropsPreact\n        | DashboardPropsPreact,\n      options,\n    );\n\n    const setFilters = createHookApiFacade(hookAdapter, 'setFilters', true);\n    const setWidgetsLayout = createHookApiFacade(hookAdapter, 'setWidgetsLayout', true);\n\n    const destroy = () => {\n      hookAdapter.destroy();\n      dashboard$.complete();\n    };\n\n    return {\n      dashboard$,\n      setFilters,\n      setWidgetsLayout,\n      destroy,\n    };\n  }\n}\n"]}
@@ -61,7 +61,6 @@ let QueryService = class QueryService {
61
61
  *
62
62
  * @param params - Pivot query parameters
63
63
  * @return Pivot query result
64
- * @beta
65
64
  */
66
65
  async executePivotQuery(params) {
67
66
  const { dataSource, rows, columns, values, grandTotals, filters, highlights, count, offset, beforeQuery, } = params;
@@ -155,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
155
154
  providedIn: 'root',
156
155
  }]
157
156
  }], ctorParameters: function () { return [{ type: i1.SisenseContextService }]; } });
158
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query.service.js","sourceRoot":"","sources":["../../../../src/lib/services/query.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { getFilterListAndRelationsJaql, QueryResultData } from '@sisense/sdk-data';\nimport {\n  type ExecuteCsvQueryParams as ExecuteCsvQueryParamsPreact,\n  type ExecuteCustomWidgetQueryParams as ExecuteCustomWidgetQueryParamsPreact,\n  executePivotQuery,\n  type ExecutePivotQueryParams as ExecutePivotQueryParamsPreact,\n  executeQuery,\n  executeQueryByWidgetId,\n  type ExecuteQueryByWidgetIdParams as ExecuteQueryByWidgetIdParamsPreact,\n  type ExecuteQueryParams as ExecuteQueryParamsPreact,\n  HookAdapter,\n  useExecuteCsvQueryInternal,\n  useExecuteCustomWidgetQueryInternal,\n} from '@sisense/sdk-ui-preact';\n\nimport { createSisenseContextConnector } from '../component-wrapper-helpers';\nimport { TrackableService } from '../decorators/trackable.decorator';\nimport { SisenseContextService } from './sisense-context.service';\n\ninterface ExecuteQueryHandlers {\n  /** Sync or async callback that allows to modify the JAQL payload before it is sent to the server. */\n  beforeQuery?: ExecuteQueryParamsPreact['onBeforeQuery'];\n}\n\n/**\n * Parameters for data query execution.\n */\nexport interface ExecuteQueryParams\n  extends Omit<ExecuteQueryParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Parameters for data query by widget id execution.\n */\nexport interface ExecuteQueryByWidgetIdParams\n  extends Omit<ExecuteQueryByWidgetIdParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Parameters for pivot data query execution.\n */\nexport interface ExecutePivotQueryParams\n  extends Omit<ExecutePivotQueryParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Parameters for CSV data query execution.\n */\nexport interface ExecuteCsvQueryParams\n  extends Omit<ExecuteCsvQueryParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Parameters for custom widget query execution.\n */\nexport interface ExecuteCustomWidgetQueryParams\n  extends Omit<ExecuteCustomWidgetQueryParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Service for executing data queries.\n *\n * @group Queries\n */\n@Injectable({\n  providedIn: 'root',\n})\n@TrackableService<QueryService>([\n  'executeQuery',\n  'executeQueryByWidgetId',\n  'executePivotQuery',\n  'executeCustomWidgetQuery',\n])\nexport class QueryService {\n  constructor(private sisenseContextService: SisenseContextService) {}\n\n  /**\n   * Executes a data query. If you want to display the query results, you can use\n   * them to populate Compose SDK UI elements or third party UI elements.\n   *\n   * To learn how to populate third party UI elements with query results, see the\n   * [External Charts Guide](/guides/sdk/guides/charts/guide-external-charts.html#query)\n   *\n   * @param params - Query parameters\n   * @return Query result\n   */\n  async executeQuery(params: ExecuteQueryParams) {\n    const {\n      dataSource,\n      dimensions,\n      measures,\n      filters,\n      highlights,\n      count,\n      offset,\n      ungroup,\n      beforeQuery,\n    } = params;\n    const app = await this.sisenseContextService.getApp();\n    const { filters: filterList, relations: filterRelations } =\n      getFilterListAndRelationsJaql(filters);\n    const data = await executeQuery(\n      {\n        dataSource,\n        dimensions,\n        measures,\n        filters: filterList,\n        filterRelations,\n        highlights,\n        count,\n        offset,\n        ungroup,\n      },\n      app,\n      { onBeforeQuery: beforeQuery },\n    );\n\n    return { data };\n  }\n\n  /**\n   * Executes a data query extracted from an existing widget in the Sisense instance.\n   *\n   * @param params - Parameters to identify the target widget\n   * @returns Query result\n   */\n  async executeQueryByWidgetId(params: ExecuteQueryByWidgetIdParams) {\n    const app = await this.sisenseContextService.getApp();\n\n    return executeQueryByWidgetId({\n      ...params,\n      app,\n      onBeforeQuery: params.beforeQuery,\n    });\n  }\n\n  /**\n   * Executes a data query for a pivot table.\n   *\n   * @param params - Pivot query parameters\n   * @return Pivot query result\n   * @beta\n   */\n  async executePivotQuery(params: ExecutePivotQueryParams) {\n    const {\n      dataSource,\n      rows,\n      columns,\n      values,\n      grandTotals,\n      filters,\n      highlights,\n      count,\n      offset,\n      beforeQuery,\n    } = params;\n    const { filters: filterList, relations: filterRelations } =\n      getFilterListAndRelationsJaql(filters);\n\n    const app = await this.sisenseContextService.getApp();\n    const data = await executePivotQuery(\n      {\n        dataSource,\n        rows,\n        columns,\n        values,\n        grandTotals,\n        filters: filterList,\n        filterRelations,\n        highlights,\n        count,\n        offset,\n      },\n      app,\n      { onBeforeQuery: beforeQuery },\n    );\n\n    return { data };\n  }\n\n  /**\n   * Executes a CSV data query.\n   * Similar to {@link QueryService.executeQuery}, but returns the data in CSV format as text or as a stream.\n   *\n   * @param params - CSV query parameters\n   * @return CSV query result\n   */\n  async executeCsvQuery(params: ExecuteCsvQueryParams) {\n    const hookAdapter = new HookAdapter(useExecuteCsvQueryInternal, [\n      createSisenseContextConnector(this.sisenseContextService),\n    ]);\n\n    const resultPromise = new Promise<{ data: Blob | string }>((resolve, reject) => {\n      hookAdapter.subscribe((res) => {\n        const { data, isSuccess, isError, error } = res;\n        if (isSuccess) {\n          resolve({ data });\n        } else if (isError) {\n          reject(error);\n        }\n      });\n    });\n\n    hookAdapter.run(params);\n\n    return resultPromise.finally(() => {\n      hookAdapter.destroy();\n    });\n  }\n\n  /**\n   * Executes a data query from custom widget component props.\n   *\n   * This method takes custom widget props (dataSource, dataOptions, filters, etc.)\n   * and executes the appropriate data query\n   *\n   * @param params - Custom widget component props containing data source, data options, filters, etc.\n   * @returns Promise resolving to query result with formatted data\n   */\n  async executeCustomWidgetQuery(params: ExecuteCustomWidgetQueryParams) {\n    const hookAdapter = new HookAdapter(useExecuteCustomWidgetQueryInternal, [\n      createSisenseContextConnector(this.sisenseContextService),\n    ]);\n\n    const resultPromise = new Promise<{ data: QueryResultData }>((resolve, reject) => {\n      hookAdapter.subscribe((res) => {\n        const { data, isSuccess, isError, error } = res;\n        if (isSuccess) {\n          resolve({ data });\n        } else if (isError) {\n          reject(error);\n        }\n      });\n    });\n\n    hookAdapter.run(params);\n\n    return resultPromise.finally(() => {\n      hookAdapter.destroy();\n    });\n  }\n}\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query.service.js","sourceRoot":"","sources":["../../../../src/lib/services/query.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { getFilterListAndRelationsJaql, QueryResultData } from '@sisense/sdk-data';\nimport {\n  type ExecuteCsvQueryParams as ExecuteCsvQueryParamsPreact,\n  type ExecuteCustomWidgetQueryParams as ExecuteCustomWidgetQueryParamsPreact,\n  executePivotQuery,\n  type ExecutePivotQueryParams as ExecutePivotQueryParamsPreact,\n  executeQuery,\n  executeQueryByWidgetId,\n  type ExecuteQueryByWidgetIdParams as ExecuteQueryByWidgetIdParamsPreact,\n  type ExecuteQueryParams as ExecuteQueryParamsPreact,\n  HookAdapter,\n  useExecuteCsvQueryInternal,\n  useExecuteCustomWidgetQueryInternal,\n} from '@sisense/sdk-ui-preact';\n\nimport { createSisenseContextConnector } from '../component-wrapper-helpers';\nimport { TrackableService } from '../decorators/trackable.decorator';\nimport { SisenseContextService } from './sisense-context.service';\n\ninterface ExecuteQueryHandlers {\n  /** Sync or async callback that allows to modify the JAQL payload before it is sent to the server. */\n  beforeQuery?: ExecuteQueryParamsPreact['onBeforeQuery'];\n}\n\n/**\n * Parameters for data query execution.\n */\nexport interface ExecuteQueryParams\n  extends Omit<ExecuteQueryParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Parameters for data query by widget id execution.\n */\nexport interface ExecuteQueryByWidgetIdParams\n  extends Omit<ExecuteQueryByWidgetIdParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Parameters for pivot data query execution.\n */\nexport interface ExecutePivotQueryParams\n  extends Omit<ExecutePivotQueryParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Parameters for CSV data query execution.\n */\nexport interface ExecuteCsvQueryParams\n  extends Omit<ExecuteCsvQueryParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Parameters for custom widget query execution.\n */\nexport interface ExecuteCustomWidgetQueryParams\n  extends Omit<ExecuteCustomWidgetQueryParamsPreact, 'enabled' | 'onBeforeQuery'>,\n    ExecuteQueryHandlers {}\n\n/**\n * Service for executing data queries.\n *\n * @group Queries\n */\n@Injectable({\n  providedIn: 'root',\n})\n@TrackableService<QueryService>([\n  'executeQuery',\n  'executeQueryByWidgetId',\n  'executePivotQuery',\n  'executeCustomWidgetQuery',\n])\nexport class QueryService {\n  constructor(private sisenseContextService: SisenseContextService) {}\n\n  /**\n   * Executes a data query. If you want to display the query results, you can use\n   * them to populate Compose SDK UI elements or third party UI elements.\n   *\n   * To learn how to populate third party UI elements with query results, see the\n   * [External Charts Guide](/guides/sdk/guides/charts/guide-external-charts.html#query)\n   *\n   * @param params - Query parameters\n   * @return Query result\n   */\n  async executeQuery(params: ExecuteQueryParams) {\n    const {\n      dataSource,\n      dimensions,\n      measures,\n      filters,\n      highlights,\n      count,\n      offset,\n      ungroup,\n      beforeQuery,\n    } = params;\n    const app = await this.sisenseContextService.getApp();\n    const { filters: filterList, relations: filterRelations } =\n      getFilterListAndRelationsJaql(filters);\n    const data = await executeQuery(\n      {\n        dataSource,\n        dimensions,\n        measures,\n        filters: filterList,\n        filterRelations,\n        highlights,\n        count,\n        offset,\n        ungroup,\n      },\n      app,\n      { onBeforeQuery: beforeQuery },\n    );\n\n    return { data };\n  }\n\n  /**\n   * Executes a data query extracted from an existing widget in the Sisense instance.\n   *\n   * @param params - Parameters to identify the target widget\n   * @returns Query result\n   */\n  async executeQueryByWidgetId(params: ExecuteQueryByWidgetIdParams) {\n    const app = await this.sisenseContextService.getApp();\n\n    return executeQueryByWidgetId({\n      ...params,\n      app,\n      onBeforeQuery: params.beforeQuery,\n    });\n  }\n\n  /**\n   * Executes a data query for a pivot table.\n   *\n   * @param params - Pivot query parameters\n   * @return Pivot query result\n   */\n  async executePivotQuery(params: ExecutePivotQueryParams) {\n    const {\n      dataSource,\n      rows,\n      columns,\n      values,\n      grandTotals,\n      filters,\n      highlights,\n      count,\n      offset,\n      beforeQuery,\n    } = params;\n    const { filters: filterList, relations: filterRelations } =\n      getFilterListAndRelationsJaql(filters);\n\n    const app = await this.sisenseContextService.getApp();\n    const data = await executePivotQuery(\n      {\n        dataSource,\n        rows,\n        columns,\n        values,\n        grandTotals,\n        filters: filterList,\n        filterRelations,\n        highlights,\n        count,\n        offset,\n      },\n      app,\n      { onBeforeQuery: beforeQuery },\n    );\n\n    return { data };\n  }\n\n  /**\n   * Executes a CSV data query.\n   * Similar to {@link QueryService.executeQuery}, but returns the data in CSV format as text or as a stream.\n   *\n   * @param params - CSV query parameters\n   * @return CSV query result\n   */\n  async executeCsvQuery(params: ExecuteCsvQueryParams) {\n    const hookAdapter = new HookAdapter(useExecuteCsvQueryInternal, [\n      createSisenseContextConnector(this.sisenseContextService),\n    ]);\n\n    const resultPromise = new Promise<{ data: Blob | string }>((resolve, reject) => {\n      hookAdapter.subscribe((res) => {\n        const { data, isSuccess, isError, error } = res;\n        if (isSuccess) {\n          resolve({ data });\n        } else if (isError) {\n          reject(error);\n        }\n      });\n    });\n\n    hookAdapter.run(params);\n\n    return resultPromise.finally(() => {\n      hookAdapter.destroy();\n    });\n  }\n\n  /**\n   * Executes a data query from custom widget component props.\n   *\n   * This method takes custom widget props (dataSource, dataOptions, filters, etc.)\n   * and executes the appropriate data query\n   *\n   * @param params - Custom widget component props containing data source, data options, filters, etc.\n   * @returns Promise resolving to query result with formatted data\n   */\n  async executeCustomWidgetQuery(params: ExecuteCustomWidgetQueryParams) {\n    const hookAdapter = new HookAdapter(useExecuteCustomWidgetQueryInternal, [\n      createSisenseContextConnector(this.sisenseContextService),\n    ]);\n\n    const resultPromise = new Promise<{ data: QueryResultData }>((resolve, reject) => {\n      hookAdapter.subscribe((res) => {\n        const { data, isSuccess, isError, error } = res;\n        if (isSuccess) {\n          resolve({ data });\n        } else if (isError) {\n          reject(error);\n        }\n      });\n    });\n\n    hookAdapter.run(params);\n\n    return resultPromise.finally(() => {\n      hookAdapter.destroy();\n    });\n  }\n}\n"]}