@sisense/sdk-ui-angular 2.22.0 → 2.24.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 (42) hide show
  1. package/dist/esm2020/ai/lib/components/chatbot.component.mjs +3 -2
  2. package/dist/esm2020/ai/lib/components/get-nlg-insights.component.mjs +3 -2
  3. package/dist/esm2020/lib/component-wrapper-helpers/context-connectors.mjs +29 -2
  4. package/dist/esm2020/lib/components/charts/chart.component.mjs +3 -2
  5. package/dist/esm2020/lib/components/charts/pivot-table.component.mjs +3 -2
  6. package/dist/esm2020/lib/components/charts/table.component.mjs +3 -2
  7. package/dist/esm2020/lib/components/context-menu.component.mjs +3 -2
  8. package/dist/esm2020/lib/components/dashboard/dashboard-by-id.component.mjs +3 -2
  9. package/dist/esm2020/lib/components/dashboard/dashboard.component.mjs +3 -2
  10. package/dist/esm2020/lib/components/drilldown-breadcrumbs.component.mjs +3 -2
  11. package/dist/esm2020/lib/components/filters/criteria-filter-tile.component.mjs +3 -2
  12. package/dist/esm2020/lib/components/filters/date-range-filter-tile.component.mjs +3 -2
  13. package/dist/esm2020/lib/components/filters/filter-tile.component.mjs +3 -2
  14. package/dist/esm2020/lib/components/filters/member-filter-tile.component.mjs +3 -2
  15. package/dist/esm2020/lib/components/filters/relative-date-filter-tile.component.mjs +3 -2
  16. package/dist/esm2020/lib/components/widgets/chart-widget.component.mjs +3 -2
  17. package/dist/esm2020/lib/components/widgets/drilldown-widget.component.mjs +3 -2
  18. package/dist/esm2020/lib/components/widgets/pivot-table-widget.component.mjs +3 -2
  19. package/dist/esm2020/lib/components/widgets/table-widget.component.mjs +3 -2
  20. package/dist/esm2020/lib/components/widgets/widget-by-id.component.mjs +3 -2
  21. package/dist/esm2020/lib/components/widgets/widget.component.mjs +3 -2
  22. package/dist/esm2020/lib/services/dashboard.service.mjs +6 -3
  23. package/dist/esm2020/lib/services/filter.service.mjs +3 -2
  24. package/dist/esm2020/lib/services/formula.service.mjs +3 -2
  25. package/dist/esm2020/lib/services/query.service.mjs +4 -2
  26. package/dist/esm2020/lib/services/sisense-context.service.mjs +2 -2
  27. package/dist/esm2020/lib/services/widget.service.mjs +3 -2
  28. package/dist/esm2020/public-api.mjs +2 -2
  29. package/dist/esm2020/version.mjs +2 -2
  30. package/dist/fesm2015/sisense-sdk-ui-angular-ai.mjs +3 -1
  31. package/dist/fesm2015/sisense-sdk-ui-angular-ai.mjs.map +1 -1
  32. package/dist/fesm2015/sisense-sdk-ui-angular.mjs +60 -5
  33. package/dist/fesm2015/sisense-sdk-ui-angular.mjs.map +1 -1
  34. package/dist/fesm2020/sisense-sdk-ui-angular-ai.mjs +3 -1
  35. package/dist/fesm2020/sisense-sdk-ui-angular-ai.mjs.map +1 -1
  36. package/dist/fesm2020/sisense-sdk-ui-angular.mjs +58 -5
  37. package/dist/fesm2020/sisense-sdk-ui-angular.mjs.map +1 -1
  38. package/dist/lib/component-wrapper-helpers/context-connectors.d.ts +8 -1
  39. package/dist/package.json +1 -1
  40. package/dist/public-api.d.ts +1 -1
  41. package/dist/version.d.ts +1 -1
  42. package/package.json +4 -4
@@ -1,6 +1,6 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
2
  import { ComponentAdapter, PivotTableWidget as PivotTableWidgetPreact, } from '@sisense/sdk-ui-preact';
3
- import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
3
+ import { createPluginContextConnector, createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "../../services";
6
6
  /**
@@ -77,6 +77,7 @@ export class PivotTableWidgetComponent {
77
77
  */
78
78
  this.dataPointContextMenu = new EventEmitter();
79
79
  this.componentAdapter = new ComponentAdapter(PivotTableWidgetPreact, [
80
+ createPluginContextConnector(this.sisenseContextService),
80
81
  createSisenseContextConnector(this.sisenseContextService),
81
82
  createThemeContextConnector(this.themeService),
82
83
  ]);
@@ -139,4 +140,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
139
140
  }], dataPointContextMenu: [{
140
141
  type: Output
141
142
  }] } });
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"]}
143
+ //# 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":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  PivotTableWidget as PivotTableWidgetPreact,\n  type PivotTableWidgetProps as PivotTableWidgetPropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createPluginContextConnector,\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      createPluginContextConnector(this.sisenseContextService),\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"]}
@@ -1,6 +1,6 @@
1
1
  import { Component, Input, ViewChild, } from '@angular/core';
2
2
  import { ComponentAdapter, TableWidget as TableWidgetPreact, } from '@sisense/sdk-ui-preact';
3
- import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
3
+ import { createPluginContextConnector, createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "../../services/sisense-context.service";
6
6
  import * as i2 from "../../services/theme.service";
@@ -49,6 +49,7 @@ export class TableWidgetComponent {
49
49
  this.sisenseContextService = sisenseContextService;
50
50
  this.themeService = themeService;
51
51
  this.componentAdapter = new ComponentAdapter(TableWidgetPreact, [
52
+ createPluginContextConnector(this.sisenseContextService),
52
53
  createSisenseContextConnector(this.sisenseContextService),
53
54
  createThemeContextConnector(this.themeService),
54
55
  ]);
@@ -96,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
96
97
  }], description: [{
97
98
  type: Input
98
99
  }] } });
99
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtd2lkZ2V0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy93aWRnZXRzL3RhYmxlLXdpZGdldC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxLQUFLLEVBR0wsU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxnQkFBZ0IsRUFDaEIsV0FBVyxJQUFJLGlCQUFpQixHQUVqQyxNQUFNLHdCQUF3QixDQUFDO0FBRWhDLE9BQU8sRUFDTCw2QkFBNkIsRUFDN0IsMkJBQTJCLEVBQzNCLE1BQU0sRUFDTixNQUFNLEVBQ04sUUFBUSxHQUNULE1BQU0saUNBQWlDLENBQUM7Ozs7QUFXekM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVDRztBQU1ILE1BQU0sT0FBTyxvQkFBb0I7SUF1RC9CLFlBQ1UscUJBQTRDLEVBQzVDLFlBQTBCO1FBRDFCLDBCQUFxQixHQUFyQixxQkFBcUIsQ0FBdUI7UUFDNUMsaUJBQVksR0FBWixZQUFZLENBQWM7UUFFbEMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksZ0JBQWdCLENBQUMsaUJBQWlCLEVBQUU7WUFDOUQsNkJBQTZCLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDO1lBQ3pELDJCQUEyQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUM7U0FDL0MsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxDQUFDLENBQUM7SUFDN0YsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQyxDQUFDO1NBQzVGO0lBQ0gsQ0FBQztJQUVPLHVCQUF1QjtRQUM3QixPQUFPO1lBQ0wsVUFBVSxFQUFFLElBQUksQ0FBQyxVQUFVO1lBQzNCLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVztZQUM3QixPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87WUFDckIsWUFBWSxFQUFFLElBQUksQ0FBQyxZQUFZO1lBQy9CLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSztZQUNqQixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7U0FDOUIsQ0FBQztJQUNKLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2xDLENBQUM7O2tIQXhGVSxvQkFBb0I7c0dBQXBCLG9CQUFvQjs0RkFBcEIsb0JBQW9CO2tCQUxoQyxTQUFTOytCQUNFLG1CQUFtQixZQUM3QixRQUFRO3VJQU1SLFNBQVM7c0JBRFIsU0FBUzt1QkFBQyxNQUFNO2dCQVNqQixVQUFVO3NCQURULEtBQUs7Z0JBU04sV0FBVztzQkFEVixLQUFLO2dCQVNOLE9BQU87c0JBRE4sS0FBSztnQkFTTixZQUFZO3NCQURYLEtBQUs7Z0JBU04sS0FBSztzQkFESixLQUFLO2dCQVNOLFdBQVc7c0JBRFYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT25EZXN0cm95LFxuICBWaWV3Q2hpbGQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgQ29tcG9uZW50QWRhcHRlcixcbiAgVGFibGVXaWRnZXQgYXMgVGFibGVXaWRnZXRQcmVhY3QsXG4gIHR5cGUgVGFibGVXaWRnZXRQcm9wcyBhcyBUYWJsZVdpZGdldFByb3BzUHJlYWN0LFxufSBmcm9tICdAc2lzZW5zZS9zZGstdWktcHJlYWN0JztcblxuaW1wb3J0IHtcbiAgY3JlYXRlU2lzZW5zZUNvbnRleHRDb25uZWN0b3IsXG4gIGNyZWF0ZVRoZW1lQ29udGV4dENvbm5lY3RvcixcbiAgcm9vdElkLFxuICBzdHlsZXMsXG4gIHRlbXBsYXRlLFxufSBmcm9tICcuLi8uLi9jb21wb25lbnQtd3JhcHBlci1oZWxwZXJzJztcbmltcG9ydCB7IFNpc2Vuc2VDb250ZXh0U2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL3Npc2Vuc2UtY29udGV4dC5zZXJ2aWNlJztcbmltcG9ydCB7IFRoZW1lU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL3RoZW1lLnNlcnZpY2UnO1xuXG4vKipcbiAqIFByb3BzIG9mIHRoZSB7QGxpbmsgVGFibGVXaWRnZXRDb21wb25lbnR9LlxuICpcbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRhYmxlV2lkZ2V0UHJvcHMgZXh0ZW5kcyBUYWJsZVdpZGdldFByb3BzUHJlYWN0IHt9XG5cbi8qKlxuICogVGhlIFRhYmxlIFdpZGdldCBjb21wb25lbnQgZXh0ZW5kaW5nIHtAbGluayBUYWJsZUNvbXBvbmVudH0gY29tcG9uZW50IHRvIHN1cHBvcnQgd2lkZ2V0IHN0eWxlIG9wdGlvbnMuXG4gKlxuICogQGV4YW1wbGVcbiAqIGBgYGh0bWxcbiAqICA8Y3Nkay10YWJsZS13aWRnZXRcbiAqICAgIFtkYXRhU291cmNlXT1cInRhYmxlLmRhdGFTZXRcIlxuICogICAgW2RhdGFPcHRpb25zXT1cInRhYmxlLmRhdGFPcHRpb25zXCJcbiAqICAgIFtmaWx0ZXJzXT1cImZpbHRlcnNcIlxuICogICAgW3RpdGxlXT1cInRhYmxlLnRpdGxlXCJcbiAqICAgIFtkZXNjcmlwdGlvbl09XCJ0YWJsZS5kZXNjcmlwdGlvblwiXG4gKiAgLz5cbiAqIGBgYFxuICogYGBgdHNcbiAqIGltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuICogaW1wb3J0IHsgQ2hhcnRUeXBlIH0gZnJvbSAnQHNpc2Vuc2Uvc2RrLXVpLWFuZ3VsYXInO1xuICogaW1wb3J0IHsgZmlsdGVyRmFjdG9yeSwgbWVhc3VyZUZhY3RvcnkgfSBmcm9tICdAc2lzZW5zZS9zZGstZGF0YSc7XG4gKiBpbXBvcnQgKiBhcyBETSBmcm9tICcuLi8uLi9hc3NldHMvc2FtcGxlLWhlYWx0aGNhcmUtbW9kZWwnO1xuICpcbiAqIEBDb21wb25lbnQoe1xuICogIHNlbGVjdG9yOiAnYXBwLXdpZGdldHMnLFxuICogdGVtcGxhdGVVcmw6ICcuL3dpZGdldHMuY29tcG9uZW50Lmh0bWwnLFxuICogc3R5bGVVcmxzOiBbJy4vd2lkZ2V0cy5jb21wb25lbnQuc2NzcyddLFxuICogfSlcbiAqIGV4cG9ydCBjbGFzcyBXaWRnZXRzQ29tcG9uZW50IHtcbiAqIGZpbHRlcnMgPSBbZmlsdGVyRmFjdG9yeS5tZW1iZXJzKERNLkRpdmlzaW9ucy5EaXZpc29uX25hbWUsIFsnQ2FyZGlvbG9neScsICdOZXVyb2xvZ3knXSldO1xuICpcbiAqIHRhYmxlID0ge1xuICogICAgZGF0YVNldDogRE0uRGF0YVNvdXJjZSxcbiAqICAgIGRhdGFPcHRpb25zOiB7XG4gKiAgICAgIGNvbHVtbnM6IFtETS5BZG1pc3Npb25zLlBhdGllbnRfSUQsIG1lYXN1cmVGYWN0b3J5LnN1bShETS5BZG1pc3Npb25zLkNvc3Rfb2ZfYWRtaXNzaW9uKV0sXG4gKiAgICB9XG4gKiAgICB0aXRsZTogJ1dpZGdldCBUaXRsZScsXG4gKiAgICBkZXNjcmlwdGlvbjogJ1dpZGdldCBEZXNjcmlwdGlvbicsXG4gKiAgfTtcbiAqIH1cbiAqIGBgYFxuICogPGltZyBzcmM9XCJtZWRpYTovL2FuZ3VsYXItdGFibGUtd2lkZ2V0LWV4YW1wbGUucG5nXCIgd2lkdGg9XCI4MDBweFwiIC8+XG4gKiBAaW50ZXJuYWxcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnY3Nkay10YWJsZS13aWRnZXQnLFxuICB0ZW1wbGF0ZSxcbiAgc3R5bGVzLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZVdpZGdldENvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBAVmlld0NoaWxkKHJvb3RJZClcbiAgcHJlYWN0UmVmITogRWxlbWVudFJlZjxIVE1MRGl2RWxlbWVudD47XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy5kYXRhU291cmNlfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgRGF0YVxuICAgKi9cbiAgQElucHV0KClcbiAgZGF0YVNvdXJjZTogVGFibGVXaWRnZXRQcm9wc1snZGF0YVNvdXJjZSddO1xuXG4gIC8qKlxuICAgKiB7QGluaGVyaXREb2MgQHNpc2Vuc2Uvc2RrLXVpIVRhYmxlV2lkZ2V0UHJvcHMuZGF0YU9wdGlvbnN9XG4gICAqXG4gICAqIEBjYXRlZ29yeSBEYXRhXG4gICAqL1xuICBASW5wdXQoKVxuICBkYXRhT3B0aW9ucyE6IFRhYmxlV2lkZ2V0UHJvcHNbJ2RhdGFPcHRpb25zJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy5maWx0ZXJzfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgRGF0YVxuICAgKi9cbiAgQElucHV0KClcbiAgZmlsdGVyczogVGFibGVXaWRnZXRQcm9wc1snZmlsdGVycyddO1xuXG4gIC8qKlxuICAgKiB7QGluaGVyaXREb2MgQHNpc2Vuc2Uvc2RrLXVpIVRhYmxlV2lkZ2V0UHJvcHMuc3R5bGVPcHRpb25zfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgUmVwcmVzZW50YXRpb25cbiAgICovXG4gIEBJbnB1dCgpXG4gIHN0eWxlT3B0aW9uczogVGFibGVXaWRnZXRQcm9wc1snc3R5bGVPcHRpb25zJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy50aXRsZX1cbiAgICpcbiAgICogQGNhdGVnb3J5IFdpZGdldFxuICAgKi9cbiAgQElucHV0KClcbiAgdGl0bGU6IFRhYmxlV2lkZ2V0UHJvcHNbJ3RpdGxlJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy5kZXNjcmlwdGlvbn1cbiAgICpcbiAgICogQGNhdGVnb3J5IFdpZGdldFxuICAgKi9cbiAgQElucHV0KClcbiAgZGVzY3JpcHRpb246IFRhYmxlV2lkZ2V0UHJvcHNbJ2Rlc2NyaXB0aW9uJ107XG5cbiAgcHJpdmF0ZSBjb21wb25lbnRBZGFwdGVyOiBDb21wb25lbnRBZGFwdGVyPHR5cGVvZiBUYWJsZVdpZGdldFByZWFjdD47XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBzaXNlbnNlQ29udGV4dFNlcnZpY2U6IFNpc2Vuc2VDb250ZXh0U2VydmljZSxcbiAgICBwcml2YXRlIHRoZW1lU2VydmljZTogVGhlbWVTZXJ2aWNlLFxuICApIHtcbiAgICB0aGlzLmNvbXBvbmVudEFkYXB0ZXIgPSBuZXcgQ29tcG9uZW50QWRhcHRlcihUYWJsZVdpZGdldFByZWFjdCwgW1xuICAgICAgY3JlYXRlU2lzZW5zZUNvbnRleHRDb25uZWN0b3IodGhpcy5zaXNlbnNlQ29udGV4dFNlcnZpY2UpLFxuICAgICAgY3JlYXRlVGhlbWVDb250ZXh0Q29ubmVjdG9yKHRoaXMudGhlbWVTZXJ2aWNlKSxcbiAgICBdKTtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICB0aGlzLmNvbXBvbmVudEFkYXB0ZXIucmVuZGVyKHRoaXMucHJlYWN0UmVmLm5hdGl2ZUVsZW1lbnQsIHRoaXMuZ2V0UHJlYWN0Q29tcG9uZW50UHJvcHMoKSk7XG4gIH1cblxuICBuZ09uQ2hhbmdlcygpIHtcbiAgICBpZiAodGhpcy5wcmVhY3RSZWYpIHtcbiAgICAgIHRoaXMuY29tcG9uZW50QWRhcHRlci5yZW5kZXIodGhpcy5wcmVhY3RSZWYubmF0aXZlRWxlbWVudCwgdGhpcy5nZXRQcmVhY3RDb21wb25lbnRQcm9wcygpKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGdldFByZWFjdENvbXBvbmVudFByb3BzKCkge1xuICAgIHJldHVybiB7XG4gICAgICBkYXRhU291cmNlOiB0aGlzLmRhdGFTb3VyY2UsXG4gICAgICBkYXRhT3B0aW9uczogdGhpcy5kYXRhT3B0aW9ucyxcbiAgICAgIGZpbHRlcnM6IHRoaXMuZmlsdGVycyxcbiAgICAgIHN0eWxlT3B0aW9uczogdGhpcy5zdHlsZU9wdGlvbnMsXG4gICAgICB0aXRsZTogdGhpcy50aXRsZSxcbiAgICAgIGRlc2NyaXB0aW9uOiB0aGlzLmRlc2NyaXB0aW9uLFxuICAgIH07XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmNvbXBvbmVudEFkYXB0ZXIuZGVzdHJveSgpO1xuICB9XG59XG4iXX0=
100
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtd2lkZ2V0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy93aWRnZXRzL3RhYmxlLXdpZGdldC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxLQUFLLEVBR0wsU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxnQkFBZ0IsRUFDaEIsV0FBVyxJQUFJLGlCQUFpQixHQUVqQyxNQUFNLHdCQUF3QixDQUFDO0FBRWhDLE9BQU8sRUFDTCw0QkFBNEIsRUFDNUIsNkJBQTZCLEVBQzdCLDJCQUEyQixFQUMzQixNQUFNLEVBQ04sTUFBTSxFQUNOLFFBQVEsR0FDVCxNQUFNLGlDQUFpQyxDQUFDOzs7O0FBV3pDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F1Q0c7QUFNSCxNQUFNLE9BQU8sb0JBQW9CO0lBdUQvQixZQUNVLHFCQUE0QyxFQUM1QyxZQUEwQjtRQUQxQiwwQkFBcUIsR0FBckIscUJBQXFCLENBQXVCO1FBQzVDLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBRWxDLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLGdCQUFnQixDQUFDLGlCQUFpQixFQUFFO1lBQzlELDRCQUE0QixDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztZQUN4RCw2QkFBNkIsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUM7WUFDekQsMkJBQTJCLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQztTQUMvQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUMsQ0FBQztJQUM3RixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRTtZQUNsQixJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyx1QkFBdUIsRUFBRSxDQUFDLENBQUM7U0FDNUY7SUFDSCxDQUFDO0lBRU8sdUJBQXVCO1FBQzdCLE9BQU87WUFDTCxVQUFVLEVBQUUsSUFBSSxDQUFDLFVBQVU7WUFDM0IsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO1lBQzdCLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixZQUFZLEVBQUUsSUFBSSxDQUFDLFlBQVk7WUFDL0IsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLO1lBQ2pCLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVztTQUM5QixDQUFDO0lBQ0osQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbEMsQ0FBQzs7a0hBekZVLG9CQUFvQjtzR0FBcEIsb0JBQW9COzRGQUFwQixvQkFBb0I7a0JBTGhDLFNBQVM7K0JBQ0UsbUJBQW1CLFlBQzdCLFFBQVE7dUlBTVIsU0FBUztzQkFEUixTQUFTO3VCQUFDLE1BQU07Z0JBU2pCLFVBQVU7c0JBRFQsS0FBSztnQkFTTixXQUFXO3NCQURWLEtBQUs7Z0JBU04sT0FBTztzQkFETixLQUFLO2dCQVNOLFlBQVk7c0JBRFgsS0FBSztnQkFTTixLQUFLO3NCQURKLEtBQUs7Z0JBU04sV0FBVztzQkFEVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgQ29tcG9uZW50LFxuICBFbGVtZW50UmVmLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPbkRlc3Ryb3ksXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBDb21wb25lbnRBZGFwdGVyLFxuICBUYWJsZVdpZGdldCBhcyBUYWJsZVdpZGdldFByZWFjdCxcbiAgdHlwZSBUYWJsZVdpZGdldFByb3BzIGFzIFRhYmxlV2lkZ2V0UHJvcHNQcmVhY3QsXG59IGZyb20gJ0BzaXNlbnNlL3Nkay11aS1wcmVhY3QnO1xuXG5pbXBvcnQge1xuICBjcmVhdGVQbHVnaW5Db250ZXh0Q29ubmVjdG9yLFxuICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3RvcixcbiAgY3JlYXRlVGhlbWVDb250ZXh0Q29ubmVjdG9yLFxuICByb290SWQsXG4gIHN0eWxlcyxcbiAgdGVtcGxhdGUsXG59IGZyb20gJy4uLy4uL2NvbXBvbmVudC13cmFwcGVyLWhlbHBlcnMnO1xuaW1wb3J0IHsgU2lzZW5zZUNvbnRleHRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvc2lzZW5zZS1jb250ZXh0LnNlcnZpY2UnO1xuaW1wb3J0IHsgVGhlbWVTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdGhlbWUuc2VydmljZSc7XG5cbi8qKlxuICogUHJvcHMgb2YgdGhlIHtAbGluayBUYWJsZVdpZGdldENvbXBvbmVudH0uXG4gKlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVXaWRnZXRQcm9wcyBleHRlbmRzIFRhYmxlV2lkZ2V0UHJvcHNQcmVhY3Qge31cblxuLyoqXG4gKiBUaGUgVGFibGUgV2lkZ2V0IGNvbXBvbmVudCBleHRlbmRpbmcge0BsaW5rIFRhYmxlQ29tcG9uZW50fSBjb21wb25lbnQgdG8gc3VwcG9ydCB3aWRnZXQgc3R5bGUgb3B0aW9ucy5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgaHRtbFxuICogIDxjc2RrLXRhYmxlLXdpZGdldFxuICogICAgW2RhdGFTb3VyY2VdPVwidGFibGUuZGF0YVNldFwiXG4gKiAgICBbZGF0YU9wdGlvbnNdPVwidGFibGUuZGF0YU9wdGlvbnNcIlxuICogICAgW2ZpbHRlcnNdPVwiZmlsdGVyc1wiXG4gKiAgICBbdGl0bGVdPVwidGFibGUudGl0bGVcIlxuICogICAgW2Rlc2NyaXB0aW9uXT1cInRhYmxlLmRlc2NyaXB0aW9uXCJcbiAqICAvPlxuICogYGBgXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG4gKiBpbXBvcnQgeyBDaGFydFR5cGUgfSBmcm9tICdAc2lzZW5zZS9zZGstdWktYW5ndWxhcic7XG4gKiBpbXBvcnQgeyBmaWx0ZXJGYWN0b3J5LCBtZWFzdXJlRmFjdG9yeSB9IGZyb20gJ0BzaXNlbnNlL3Nkay1kYXRhJztcbiAqIGltcG9ydCAqIGFzIERNIGZyb20gJy4uLy4uL2Fzc2V0cy9zYW1wbGUtaGVhbHRoY2FyZS1tb2RlbCc7XG4gKlxuICogQENvbXBvbmVudCh7XG4gKiAgc2VsZWN0b3I6ICdhcHAtd2lkZ2V0cycsXG4gKiB0ZW1wbGF0ZVVybDogJy4vd2lkZ2V0cy5jb21wb25lbnQuaHRtbCcsXG4gKiBzdHlsZVVybHM6IFsnLi93aWRnZXRzLmNvbXBvbmVudC5zY3NzJ10sXG4gKiB9KVxuICogZXhwb3J0IGNsYXNzIFdpZGdldHNDb21wb25lbnQge1xuICogZmlsdGVycyA9IFtmaWx0ZXJGYWN0b3J5Lm1lbWJlcnMoRE0uRGl2aXNpb25zLkRpdmlzb25fbmFtZSwgWydDYXJkaW9sb2d5JywgJ05ldXJvbG9neSddKV07XG4gKlxuICogdGFibGUgPSB7XG4gKiAgICBkYXRhU2V0OiBETS5EYXRhU291cmNlLFxuICogICAgZGF0YU9wdGlvbnM6IHtcbiAqICAgICAgY29sdW1uczogW0RNLkFkbWlzc2lvbnMuUGF0aWVudF9JRCwgbWVhc3VyZUZhY3Rvcnkuc3VtKERNLkFkbWlzc2lvbnMuQ29zdF9vZl9hZG1pc3Npb24pXSxcbiAqICAgIH1cbiAqICAgIHRpdGxlOiAnV2lkZ2V0IFRpdGxlJyxcbiAqICAgIGRlc2NyaXB0aW9uOiAnV2lkZ2V0IERlc2NyaXB0aW9uJyxcbiAqICB9O1xuICogfVxuICogYGBgXG4gKiA8aW1nIHNyYz1cIm1lZGlhOi8vYW5ndWxhci10YWJsZS13aWRnZXQtZXhhbXBsZS5wbmdcIiB3aWR0aD1cIjgwMHB4XCIgLz5cbiAqIEBpbnRlcm5hbFxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjc2RrLXRhYmxlLXdpZGdldCcsXG4gIHRlbXBsYXRlLFxuICBzdHlsZXMsXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlV2lkZ2V0Q29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCwgT25DaGFuZ2VzLCBPbkRlc3Ryb3kge1xuICAvKiogQGludGVybmFsICovXG4gIEBWaWV3Q2hpbGQocm9vdElkKVxuICBwcmVhY3RSZWYhOiBFbGVtZW50UmVmPEhUTUxEaXZFbGVtZW50PjtcblxuICAvKipcbiAgICoge0Bpbmhlcml0RG9jIEBzaXNlbnNlL3Nkay11aSFUYWJsZVdpZGdldFByb3BzLmRhdGFTb3VyY2V9XG4gICAqXG4gICAqIEBjYXRlZ29yeSBEYXRhXG4gICAqL1xuICBASW5wdXQoKVxuICBkYXRhU291cmNlOiBUYWJsZVdpZGdldFByb3BzWydkYXRhU291cmNlJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy5kYXRhT3B0aW9uc31cbiAgICpcbiAgICogQGNhdGVnb3J5IERhdGFcbiAgICovXG4gIEBJbnB1dCgpXG4gIGRhdGFPcHRpb25zITogVGFibGVXaWRnZXRQcm9wc1snZGF0YU9wdGlvbnMnXTtcblxuICAvKipcbiAgICoge0Bpbmhlcml0RG9jIEBzaXNlbnNlL3Nkay11aSFUYWJsZVdpZGdldFByb3BzLmZpbHRlcnN9XG4gICAqXG4gICAqIEBjYXRlZ29yeSBEYXRhXG4gICAqL1xuICBASW5wdXQoKVxuICBmaWx0ZXJzOiBUYWJsZVdpZGdldFByb3BzWydmaWx0ZXJzJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy5zdHlsZU9wdGlvbnN9XG4gICAqXG4gICAqIEBjYXRlZ29yeSBSZXByZXNlbnRhdGlvblxuICAgKi9cbiAgQElucHV0KClcbiAgc3R5bGVPcHRpb25zOiBUYWJsZVdpZGdldFByb3BzWydzdHlsZU9wdGlvbnMnXTtcblxuICAvKipcbiAgICoge0Bpbmhlcml0RG9jIEBzaXNlbnNlL3Nkay11aSFUYWJsZVdpZGdldFByb3BzLnRpdGxlfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgV2lkZ2V0XG4gICAqL1xuICBASW5wdXQoKVxuICB0aXRsZTogVGFibGVXaWRnZXRQcm9wc1sndGl0bGUnXTtcblxuICAvKipcbiAgICoge0Bpbmhlcml0RG9jIEBzaXNlbnNlL3Nkay11aSFUYWJsZVdpZGdldFByb3BzLmRlc2NyaXB0aW9ufVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgV2lkZ2V0XG4gICAqL1xuICBASW5wdXQoKVxuICBkZXNjcmlwdGlvbjogVGFibGVXaWRnZXRQcm9wc1snZGVzY3JpcHRpb24nXTtcblxuICBwcml2YXRlIGNvbXBvbmVudEFkYXB0ZXI6IENvbXBvbmVudEFkYXB0ZXI8dHlwZW9mIFRhYmxlV2lkZ2V0UHJlYWN0PjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHNpc2Vuc2VDb250ZXh0U2VydmljZTogU2lzZW5zZUNvbnRleHRTZXJ2aWNlLFxuICAgIHByaXZhdGUgdGhlbWVTZXJ2aWNlOiBUaGVtZVNlcnZpY2UsXG4gICkge1xuICAgIHRoaXMuY29tcG9uZW50QWRhcHRlciA9IG5ldyBDb21wb25lbnRBZGFwdGVyKFRhYmxlV2lkZ2V0UHJlYWN0LCBbXG4gICAgICBjcmVhdGVQbHVnaW5Db250ZXh0Q29ubmVjdG9yKHRoaXMuc2lzZW5zZUNvbnRleHRTZXJ2aWNlKSxcbiAgICAgIGNyZWF0ZVNpc2Vuc2VDb250ZXh0Q29ubmVjdG9yKHRoaXMuc2lzZW5zZUNvbnRleHRTZXJ2aWNlKSxcbiAgICAgIGNyZWF0ZVRoZW1lQ29udGV4dENvbm5lY3Rvcih0aGlzLnRoZW1lU2VydmljZSksXG4gICAgXSk7XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5jb21wb25lbnRBZGFwdGVyLnJlbmRlcih0aGlzLnByZWFjdFJlZi5uYXRpdmVFbGVtZW50LCB0aGlzLmdldFByZWFjdENvbXBvbmVudFByb3BzKCkpO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoKSB7XG4gICAgaWYgKHRoaXMucHJlYWN0UmVmKSB7XG4gICAgICB0aGlzLmNvbXBvbmVudEFkYXB0ZXIucmVuZGVyKHRoaXMucHJlYWN0UmVmLm5hdGl2ZUVsZW1lbnQsIHRoaXMuZ2V0UHJlYWN0Q29tcG9uZW50UHJvcHMoKSk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBnZXRQcmVhY3RDb21wb25lbnRQcm9wcygpIHtcbiAgICByZXR1cm4ge1xuICAgICAgZGF0YVNvdXJjZTogdGhpcy5kYXRhU291cmNlLFxuICAgICAgZGF0YU9wdGlvbnM6IHRoaXMuZGF0YU9wdGlvbnMsXG4gICAgICBmaWx0ZXJzOiB0aGlzLmZpbHRlcnMsXG4gICAgICBzdHlsZU9wdGlvbnM6IHRoaXMuc3R5bGVPcHRpb25zLFxuICAgICAgdGl0bGU6IHRoaXMudGl0bGUsXG4gICAgICBkZXNjcmlwdGlvbjogdGhpcy5kZXNjcmlwdGlvbixcbiAgICB9O1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5jb21wb25lbnRBZGFwdGVyLmRlc3Ryb3koKTtcbiAgfVxufVxuIl19
@@ -1,6 +1,6 @@
1
1
  import { Component, Input, ViewChild, } from '@angular/core';
2
2
  import { ComponentAdapter, WidgetById as WidgetByIdPreact, } from '@sisense/sdk-ui-preact';
3
- import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
3
+ import { createPluginContextConnector, createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "../../services/sisense-context.service";
6
6
  import * as i2 from "../../services/theme.service";
@@ -40,6 +40,7 @@ export class WidgetByIdComponent {
40
40
  this.sisenseContextService = sisenseContextService;
41
41
  this.themeService = themeService;
42
42
  this.componentAdapter = new ComponentAdapter(WidgetByIdPreact, [
43
+ createPluginContextConnector(this.sisenseContextService),
43
44
  createSisenseContextConnector(this.sisenseContextService),
44
45
  createThemeContextConnector(this.themeService),
45
46
  ]);
@@ -109,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
109
110
  }], dataReady: [{
110
111
  type: Input
111
112
  }] } });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-by-id.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/widget-by-id.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;;;;AAYzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AAMH,MAAM,OAAO,mBAAmB;IAmG9B,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;IAED,gBAAgB;IACR,uBAAuB;QAC7B,OAAO;YACL,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;YAC/C,uBAAuB,EAAE,IAAI,CAAC,uBAAuB;YACrD,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,0BAA0B,EAAE,IAAI,CAAC,0BAA0B;YAC3D,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,WAAW,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC;SACxC,CAAC;IACJ,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;iHA9IU,mBAAmB;qGAAnB,mBAAmB;4FAAnB,mBAAmB;kBAL/B,SAAS;+BACE,mBAAmB,YAC7B,QAAQ;uIAMR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBASjB,SAAS;sBADR,KAAK;gBASN,YAAY;sBADX,KAAK;gBASN,OAAO;sBADN,KAAK;gBASN,UAAU;sBADT,KAAK;gBASN,oBAAoB;sBADnB,KAAK;gBASN,uBAAuB;sBADtB,KAAK;gBASN,KAAK;sBADJ,KAAK;gBASN,WAAW;sBADV,KAAK;gBASN,YAAY;sBADX,KAAK;gBASN,0BAA0B;sBADzB,KAAK;gBAKN,gBAAgB;sBADf,KAAK;gBASN,SAAS;sBADR,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  WidgetById as WidgetByIdPreact,\n  type WidgetByIdProps as WidgetByIdPropsPreact,\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/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport { BaseChartEventProps, WithoutPreactChartEventProps } from '../../types';\n\n/**\n * Props of the {@link WidgetByIdComponent}.\n */\nexport interface WidgetByIdProps\n  extends WithoutPreactChartEventProps<WidgetByIdPropsPreact>,\n    BaseChartEventProps {}\n\n/**\n * The `WidgetById` component, which is a thin wrapper on {@link ChartWidgetComponent},\n * is used to render a widget created in a Sisense Fusion instance.\n *\n * To learn more about using Sisense Fusion Widgets in Compose SDK, see\n * [Sisense Fusion Widgets](https://developer.sisense.com/guides/sdk/guides/charts/guide-fusion-widgets.html).\n *\n * @example\n * ```html\n * <csdk-widget-by-id\n *    [widgetOid]=\"widgetOid\"\n *    [dashboardOid]=\"dashboardOid\"\n *    [includeDashboardFilters]=\"true\"\n * />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n *\n * @Component({\n *  selector: 'app-widgets',\n *  templateUrl: './widgets.component.html',\n *  styleUrls: ['./widgets.component.scss'],\n * })\n * export class WidgetsComponent {\n *  widgetOid: string = '60f3e3e3e4b0e3e3e4b0e3e3';\n *  dashboardOid: string = '60f3e3e3e4b0e3e3e4b0e3e3';\n * }\n * ```\n * @group Fusion Assets\n * @fusionEmbed\n */\n@Component({\n  selector: 'csdk-widget-by-id',\n  template,\n  styles,\n})\nexport class WidgetByIdComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.widgetOid}\n   *\n   * @category Widget\n   */\n  @Input()\n  widgetOid!: WidgetByIdProps['widgetOid'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.dashboardOid}\n   *\n   * @category Widget\n   */\n  @Input()\n  dashboardOid!: WidgetByIdProps['dashboardOid'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: WidgetByIdProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: WidgetByIdProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.filtersMergeStrategy}\n   *\n   * @category Data\n   */\n  @Input()\n  filtersMergeStrategy: WidgetByIdProps['filtersMergeStrategy'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.includeDashboardFilters}\n   *\n   * @category Data\n   */\n  @Input()\n  includeDashboardFilters: WidgetByIdProps['includeDashboardFilters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: WidgetByIdProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: WidgetByIdProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: WidgetByIdProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   */\n  @Input()\n  highlightSelectionDisabled: WidgetByIdProps['highlightSelectionDisabled'];\n\n  /** @internal */\n  @Input()\n  drilldownOptions: WidgetByIdProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc  @sisense/sdk-ui!WidgetByIdProps.onDataReady}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  dataReady: WidgetByIdProps['dataReady'];\n\n  private componentAdapter: ComponentAdapter<typeof WidgetByIdPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(WidgetByIdPreact, [\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  /** @internal */\n  private getPreactComponentProps(): WidgetByIdPropsPreact {\n    return {\n      widgetOid: this.widgetOid,\n      dashboardOid: this.dashboardOid,\n      filters: this.filters,\n      highlights: this.highlights,\n      filtersMergeStrategy: this.filtersMergeStrategy,\n      includeDashboardFilters: this.includeDashboardFilters,\n      title: this.title,\n      description: this.description,\n      styleOptions: this.styleOptions,\n      highlightSelectionDisabled: this.highlightSelectionDisabled,\n      drilldownOptions: this.drilldownOptions,\n      onDataReady: this.dataReady?.bind(this),\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget-by-id.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/widget-by-id.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,4BAA4B,EAC5B,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;;AAYzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AAMH,MAAM,OAAO,mBAAmB;IAmG9B,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,4BAA4B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACxD,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;IAED,gBAAgB;IACR,uBAAuB;QAC7B,OAAO;YACL,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;YAC/C,uBAAuB,EAAE,IAAI,CAAC,uBAAuB;YACrD,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,0BAA0B,EAAE,IAAI,CAAC,0BAA0B;YAC3D,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;YACvC,WAAW,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC;SACxC,CAAC;IACJ,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;iHA/IU,mBAAmB;qGAAnB,mBAAmB;4FAAnB,mBAAmB;kBAL/B,SAAS;+BACE,mBAAmB,YAC7B,QAAQ;uIAMR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBASjB,SAAS;sBADR,KAAK;gBASN,YAAY;sBADX,KAAK;gBASN,OAAO;sBADN,KAAK;gBASN,UAAU;sBADT,KAAK;gBASN,oBAAoB;sBADnB,KAAK;gBASN,uBAAuB;sBADtB,KAAK;gBASN,KAAK;sBADJ,KAAK;gBASN,WAAW;sBADV,KAAK;gBASN,YAAY;sBADX,KAAK;gBASN,0BAA0B;sBADzB,KAAK;gBAKN,gBAAgB;sBADf,KAAK;gBASN,SAAS;sBADR,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  WidgetById as WidgetByIdPreact,\n  type WidgetByIdProps as WidgetByIdPropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createPluginContextConnector,\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport { BaseChartEventProps, WithoutPreactChartEventProps } from '../../types';\n\n/**\n * Props of the {@link WidgetByIdComponent}.\n */\nexport interface WidgetByIdProps\n  extends WithoutPreactChartEventProps<WidgetByIdPropsPreact>,\n    BaseChartEventProps {}\n\n/**\n * The `WidgetById` component, which is a thin wrapper on {@link ChartWidgetComponent},\n * is used to render a widget created in a Sisense Fusion instance.\n *\n * To learn more about using Sisense Fusion Widgets in Compose SDK, see\n * [Sisense Fusion Widgets](https://developer.sisense.com/guides/sdk/guides/charts/guide-fusion-widgets.html).\n *\n * @example\n * ```html\n * <csdk-widget-by-id\n *    [widgetOid]=\"widgetOid\"\n *    [dashboardOid]=\"dashboardOid\"\n *    [includeDashboardFilters]=\"true\"\n * />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n *\n * @Component({\n *  selector: 'app-widgets',\n *  templateUrl: './widgets.component.html',\n *  styleUrls: ['./widgets.component.scss'],\n * })\n * export class WidgetsComponent {\n *  widgetOid: string = '60f3e3e3e4b0e3e3e4b0e3e3';\n *  dashboardOid: string = '60f3e3e3e4b0e3e3e4b0e3e3';\n * }\n * ```\n * @group Fusion Assets\n * @fusionEmbed\n */\n@Component({\n  selector: 'csdk-widget-by-id',\n  template,\n  styles,\n})\nexport class WidgetByIdComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.widgetOid}\n   *\n   * @category Widget\n   */\n  @Input()\n  widgetOid!: WidgetByIdProps['widgetOid'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.dashboardOid}\n   *\n   * @category Widget\n   */\n  @Input()\n  dashboardOid!: WidgetByIdProps['dashboardOid'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: WidgetByIdProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: WidgetByIdProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.filtersMergeStrategy}\n   *\n   * @category Data\n   */\n  @Input()\n  filtersMergeStrategy: WidgetByIdProps['filtersMergeStrategy'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.includeDashboardFilters}\n   *\n   * @category Data\n   */\n  @Input()\n  includeDashboardFilters: WidgetByIdProps['includeDashboardFilters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: WidgetByIdProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: WidgetByIdProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: WidgetByIdProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!WidgetByIdProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   */\n  @Input()\n  highlightSelectionDisabled: WidgetByIdProps['highlightSelectionDisabled'];\n\n  /** @internal */\n  @Input()\n  drilldownOptions: WidgetByIdProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc  @sisense/sdk-ui!WidgetByIdProps.onDataReady}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  dataReady: WidgetByIdProps['dataReady'];\n\n  private componentAdapter: ComponentAdapter<typeof WidgetByIdPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(WidgetByIdPreact, [\n      createPluginContextConnector(this.sisenseContextService),\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  /** @internal */\n  private getPreactComponentProps(): WidgetByIdPropsPreact {\n    return {\n      widgetOid: this.widgetOid,\n      dashboardOid: this.dashboardOid,\n      filters: this.filters,\n      highlights: this.highlights,\n      filtersMergeStrategy: this.filtersMergeStrategy,\n      includeDashboardFilters: this.includeDashboardFilters,\n      title: this.title,\n      description: this.description,\n      styleOptions: this.styleOptions,\n      highlightSelectionDisabled: this.highlightSelectionDisabled,\n      drilldownOptions: this.drilldownOptions,\n      onDataReady: this.dataReady?.bind(this),\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
2
  import { ComponentAdapter, Widget as WidgetPreact, } from '@sisense/sdk-ui-preact';
3
- import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
3
+ import { createPluginContextConnector, createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
4
4
  import { toPreactWidgetProps } from '../../helpers/widget-props-preact-translator';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "../../services/sisense-context.service";
@@ -72,6 +72,7 @@ export class WidgetComponent {
72
72
  */
73
73
  this.dataPointsSelect = new EventEmitter();
74
74
  this.componentAdapter = new ComponentAdapter(WidgetPreact, [
75
+ createPluginContextConnector(this.sisenseContextService),
75
76
  createSisenseContextConnector(this.sisenseContextService),
76
77
  createThemeContextConnector(this.themeService),
77
78
  ]);
@@ -161,4 +162,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
161
162
  }], dataPointsSelect: [{
162
163
  type: Output
163
164
  }] } });
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 { toPreactWidgetProps } 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 toPreactWidgetProps({\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"]}
165
+ //# 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  createPluginContextConnector,\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { toPreactWidgetProps } 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      createPluginContextConnector(this.sisenseContextService),\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 toPreactWidgetProps({\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"]}
@@ -2,7 +2,7 @@ import { __decorate } from "tslib";
2
2
  import { Injectable } from '@angular/core';
3
3
  import { createHookApiFacade, getDashboardModel, getDashboardModels, HookAdapter, useComposedDashboardInternal, } from '@sisense/sdk-ui-preact';
4
4
  import { BehaviorSubject } from 'rxjs';
5
- import { createSisenseContextConnector } from '../component-wrapper-helpers';
5
+ import { createPluginContextConnector, createSisenseContextConnector, } from '../component-wrapper-helpers';
6
6
  import { TrackableService } from '../decorators/trackable.decorator';
7
7
  import { toDashboardProps, toPreactDashboardProps, } from '../helpers/dashboard-props-preact-translator';
8
8
  import * as i0 from "@angular/core";
@@ -114,7 +114,10 @@ let DashboardService = class DashboardService {
114
114
  * the dashboard is no longer needed to prevent memory leaks (e.g., in `ngOnDestroy`).
115
115
  */
116
116
  createComposedDashboard(initialDashboard, options = {}) {
117
- const hookAdapter = new HookAdapter((useComposedDashboardInternal), [createSisenseContextConnector(this.sisenseContextService)]);
117
+ const hookAdapter = new HookAdapter((useComposedDashboardInternal), [
118
+ createPluginContextConnector(this.sisenseContextService),
119
+ createSisenseContextConnector(this.sisenseContextService),
120
+ ]);
118
121
  const dashboard$ = new BehaviorSubject(initialDashboard);
119
122
  hookAdapter.subscribe(({ dashboard }) => {
120
123
  dashboard$.next(toDashboardProps(dashboard));
@@ -146,4 +149,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
146
149
  providedIn: 'root',
147
150
  }]
148
151
  }], ctorParameters: function () { return [{ type: i1.SisenseContextService }]; } });
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,gBAAgB,EAChB,sBAAsB,GACvB,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,gBAAgB,CAAC,SAAS,CAAM,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;QAEH,WAAW,CAAC,GAAG,CACb,sBAAsB,CAAC,gBAAgB,CAEf,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  toDashboardProps,\n  toPreactDashboardProps,\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(toDashboardProps(dashboard) as D);\n    });\n\n    hookAdapter.run(\n      toPreactDashboardProps(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"]}
152
+ //# 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,EACL,4BAA4B,EAC5B,6BAA6B,GAC9B,MAAM,8BAA8B,CAAC;AAGtC,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EACL,gBAAgB,EAChB,sBAAsB,GACvB,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;YACE,4BAA4B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACxD,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;SAC1D,CACF,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,gBAAgB,CAAC,SAAS,CAAM,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;QAEH,WAAW,CAAC,GAAG,CACb,sBAAsB,CAAC,gBAAgB,CAEf,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;;8GA9IU,gBAAgB;kHAAhB,gBAAgB,cAHf,MAAM;AAGP,gBAAgB;IAD5B,gBAAgB,CAAmB,CAAC,mBAAmB,EAAE,oBAAoB,CAAC,CAAC;GACnE,gBAAgB,CA+I5B;SA/IY,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 {\n  createPluginContextConnector,\n  createSisenseContextConnector,\n} 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  toDashboardProps,\n  toPreactDashboardProps,\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      [\n        createPluginContextConnector(this.sisenseContextService),\n        createSisenseContextConnector(this.sisenseContextService),\n      ],\n    );\n    const dashboard$ = new BehaviorSubject<D>(initialDashboard);\n\n    hookAdapter.subscribe(({ dashboard }) => {\n      dashboard$.next(toDashboardProps(dashboard) as D);\n    });\n\n    hookAdapter.run(\n      toPreactDashboardProps(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"]}
@@ -1,7 +1,7 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { Injectable } from '@angular/core';
3
3
  import { HookAdapter, useGetFilterMembers, } from '@sisense/sdk-ui-preact';
4
- import { createSisenseContextConnector } from '../component-wrapper-helpers';
4
+ import { createPluginContextConnector, createSisenseContextConnector, } from '../component-wrapper-helpers';
5
5
  import { TrackableService } from '../decorators/trackable.decorator';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "./sisense-context.service";
@@ -41,6 +41,7 @@ let FilterService = class FilterService {
41
41
  */
42
42
  async getFilterMembers(params) {
43
43
  const hookAdapter = new HookAdapter(useGetFilterMembers, [
44
+ createPluginContextConnector(this.sisenseContextService),
44
45
  createSisenseContextConnector(this.sisenseContextService),
45
46
  ]);
46
47
  const resultPromise = new Promise((resolve, reject) => {
@@ -72,4 +73,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
72
73
  providedIn: 'root',
73
74
  }]
74
75
  }], ctorParameters: function () { return [{ type: i1.SisenseContextService }]; } });
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL2ZpbHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFJTCxXQUFXLEVBQ1gsbUJBQW1CLEdBQ3BCLE1BQU0sd0JBQXdCLENBQUM7QUFFaEMsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDN0UsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7OztBQVVyRTs7OztHQUlHO0FBS0ksSUFBTSxhQUFhLEdBQW5CLE1BQU0sYUFBYTtJQUN4QixZQUFvQixxQkFBNEM7UUFBNUMsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUF1QjtJQUFHLENBQUM7SUFFcEU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztPQXdCRztJQUNILEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQyxNQUE4QjtRQUNuRCxNQUFNLFdBQVcsR0FBRyxJQUFJLFdBQVcsQ0FBQyxtQkFBbUIsRUFBRTtZQUN2RCw2QkFBNkIsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUM7U0FDMUQsQ0FBQyxDQUFDO1FBRUgsTUFBTSxhQUFhLEdBQUcsSUFBSSxPQUFPLENBQXVCLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFO1lBQzFFLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFpQyxFQUFFLEVBQUU7Z0JBQzFELE1BQU0sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxHQUFHLEdBQUcsQ0FBQztnQkFFMUMsSUFBSSxPQUFPLEVBQUU7b0JBQ1gsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO2lCQUNmO3FCQUFNLElBQUksU0FBUyxFQUFFO29CQUNwQixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO2lCQUNuQjtZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxXQUFXLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRXhCLE9BQU8sYUFBYSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUU7WUFDaEMsV0FBVyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ3hCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7MkdBbERVLGFBQWE7K0dBQWIsYUFBYSxjQUhaLE1BQU07QUFHUCxhQUFhO0lBRHpCLGdCQUFnQixDQUFnQixDQUFDLGtCQUFrQixDQUFDLENBQUM7R0FDekMsYUFBYSxDQW1EekI7U0FuRFksYUFBYTs0RkFBYixhQUFhO2tCQUp6QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIHR5cGUgR2V0RmlsdGVyTWVtYmVyc0RhdGEsXG4gIHR5cGUgR2V0RmlsdGVyTWVtYmVyc1BhcmFtcyBhcyBHZXRGaWx0ZXJNZW1iZXJzUGFyYW1zUHJlYWN0LFxuICB0eXBlIEdldEZpbHRlck1lbWJlcnNSZXN1bHQgYXMgR2V0RmlsdGVyTWVtYmVyc1Jlc3VsdFByZWFjdCxcbiAgSG9va0FkYXB0ZXIsXG4gIHVzZUdldEZpbHRlck1lbWJlcnMsXG59IGZyb20gJ0BzaXNlbnNlL3Nkay11aS1wcmVhY3QnO1xuXG5pbXBvcnQgeyBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3RvciB9IGZyb20gJy4uL2NvbXBvbmVudC13cmFwcGVyLWhlbHBlcnMnO1xuaW1wb3J0IHsgVHJhY2thYmxlU2VydmljZSB9IGZyb20gJy4uL2RlY29yYXRvcnMvdHJhY2thYmxlLmRlY29yYXRvcic7XG5pbXBvcnQgeyBTaXNlbnNlQ29udGV4dFNlcnZpY2UgfSBmcm9tICcuL3Npc2Vuc2UtY29udGV4dC5zZXJ2aWNlJztcblxuZXhwb3J0IHR5cGUgeyBHZXRGaWx0ZXJNZW1iZXJzRGF0YSB9O1xuXG4vKipcbiAqIFBhcmFtZXRlcnMgZm9yIHJldHJpZXZpbmcgZmlsdGVyIG1lbWJlcnMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgR2V0RmlsdGVyTWVtYmVyc1BhcmFtcyBleHRlbmRzIE9taXQ8R2V0RmlsdGVyTWVtYmVyc1BhcmFtc1ByZWFjdCwgJ2VuYWJsZWQnPiB7fVxuXG4vKipcbiAqIFNlcnZpY2UgZm9yIHdvcmtpbmcgd2l0aCBmaWx0ZXIuXG4gKlxuICogQGdyb3VwIEZpbHRlcnNcbiAqL1xuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuQFRyYWNrYWJsZVNlcnZpY2U8RmlsdGVyU2VydmljZT4oWydnZXRGaWx0ZXJNZW1iZXJzJ10pXG5leHBvcnQgY2xhc3MgRmlsdGVyU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2lzZW5zZUNvbnRleHRTZXJ2aWNlOiBTaXNlbnNlQ29udGV4dFNlcnZpY2UpIHt9XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlcyBtZW1iZXJzIG9mIHRoZSBwcm92aWRlZCBmaWx0ZXIuXG4gICAqXG4gICAqIFRob3NlIG1lbWJlcnMgY2FuIGJlIHVzZWQgdG8gZGlzcGxheSBhIGxpc3Qgb2YgbWVtYmVycyBpbiBhIHRoaXJkLXBhcnR5IGZpbHRlciBjb21wb25lbnQgc3VjaCBhcyBNYXRlcmlhbCBVSSBTZWxlY3QuXG4gICAqXG4gICAqICMjIEV4YW1wbGVcbiAgICpcbiAgICogUmV0cmlldmUgc2VsZWN0ZWQgbWVtYmVycyBmcm9tIGEgRmlsdGVyIG9uIENvdW50cnkgb2YgdGhlIFNhbXBsZSBFQ29tbWVyY2UgZGF0YSBtb2RlbC5cbiAgICpcbiAgICogYGBgdHNcbiAgICogdHJ5IHtcbiAgICogICBjb25zdCBkYXRhID0gYXdhaXQgZmlsdGVyU2VydmljZS5nZXRGaWx0ZXJNZW1iZXJzKHtcbiAgICogICAgIGZpbHRlcjogZmlsdGVyRmFjdG9yeS5tZW1iZXJzKERNLkNvdW50cnkuQ291bnRyeSwgWydVbml0ZWQgU3RhdGVzJywgJ0NhbmFkYSddKVxuICAgKiAgIH0pO1xuICAgKlxuICAgKiAgIGNvbnN0IHsgc2VsZWN0ZWRNZW1iZXJzLCBhbGxNZW1iZXJzLCBleGNsdWRlTWVtYmVycywgZW5hYmxlTXVsdGlTZWxlY3Rpb24gfSA9IGRhdGE7XG4gICAqICAgY29uc29sZS5sb2coJ3NlbGVjdGVkTWVtYmVycycsIHNlbGVjdGVkTWVtYmVycyk7XG4gICAqIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAqICAgY29uc29sZS5lcnJvcignRXJyb3I6JywgZXJyb3IpO1xuICAgKiB9XG4gICAqIGBgYFxuICAgKlxuICAgKiBAcGFyYW0gcGFyYW1zIC0gUGFyYW1ldGVycyBmb3IgcmV0cmlldmluZyBmaWx0ZXIgbWVtYmVyc1xuICAgKiBAcmV0dXJucyBQcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIGZpbHRlciBtZW1iZXJzIGRhdGFcbiAgICovXG4gIGFzeW5jIGdldEZpbHRlck1lbWJlcnMocGFyYW1zOiBHZXRGaWx0ZXJNZW1iZXJzUGFyYW1zKTogUHJvbWlzZTxHZXRGaWx0ZXJNZW1iZXJzRGF0YT4ge1xuICAgIGNvbnN0IGhvb2tBZGFwdGVyID0gbmV3IEhvb2tBZGFwdGVyKHVzZUdldEZpbHRlck1lbWJlcnMsIFtcbiAgICAgIGNyZWF0ZVNpc2Vuc2VDb250ZXh0Q29ubmVjdG9yKHRoaXMuc2lzZW5zZUNvbnRleHRTZXJ2aWNlKSxcbiAgICBdKTtcblxuICAgIGNvbnN0IHJlc3VsdFByb21pc2UgPSBuZXcgUHJvbWlzZTxHZXRGaWx0ZXJNZW1iZXJzRGF0YT4oKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgICAgaG9va0FkYXB0ZXIuc3Vic2NyaWJlKChyZXM6IEdldEZpbHRlck1lbWJlcnNSZXN1bHRQcmVhY3QpID0+IHtcbiAgICAgICAgY29uc3QgeyBpc0Vycm9yLCBpc1N1Y2Nlc3MsIGVycm9yIH0gPSByZXM7XG5cbiAgICAgICAgaWYgKGlzRXJyb3IpIHtcbiAgICAgICAgICByZWplY3QoZXJyb3IpO1xuICAgICAgICB9IGVsc2UgaWYgKGlzU3VjY2Vzcykge1xuICAgICAgICAgIHJlc29sdmUocmVzLmRhdGEpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9KTtcblxuICAgIGhvb2tBZGFwdGVyLnJ1bihwYXJhbXMpO1xuXG4gICAgcmV0dXJuIHJlc3VsdFByb21pc2UuZmluYWxseSgoKSA9PiB7XG4gICAgICBob29rQWRhcHRlci5kZXN0cm95KCk7XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NlcnZpY2VzL2ZpbHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzNDLE9BQU8sRUFJTCxXQUFXLEVBQ1gsbUJBQW1CLEdBQ3BCLE1BQU0sd0JBQXdCLENBQUM7QUFFaEMsT0FBTyxFQUNMLDRCQUE0QixFQUM1Qiw2QkFBNkIsR0FDOUIsTUFBTSw4QkFBOEIsQ0FBQztBQUN0QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7O0FBVXJFOzs7O0dBSUc7QUFLSSxJQUFNLGFBQWEsR0FBbkIsTUFBTSxhQUFhO0lBQ3hCLFlBQW9CLHFCQUE0QztRQUE1QywwQkFBcUIsR0FBckIscUJBQXFCLENBQXVCO0lBQUcsQ0FBQztJQUVwRTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O09Bd0JHO0lBQ0gsS0FBSyxDQUFDLGdCQUFnQixDQUFDLE1BQThCO1FBQ25ELE1BQU0sV0FBVyxHQUFHLElBQUksV0FBVyxDQUFDLG1CQUFtQixFQUFFO1lBQ3ZELDRCQUE0QixDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztZQUN4RCw2QkFBNkIsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUM7U0FDMUQsQ0FBQyxDQUFDO1FBRUgsTUFBTSxhQUFhLEdBQUcsSUFBSSxPQUFPLENBQXVCLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFO1lBQzFFLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFpQyxFQUFFLEVBQUU7Z0JBQzFELE1BQU0sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxHQUFHLEdBQUcsQ0FBQztnQkFFMUMsSUFBSSxPQUFPLEVBQUU7b0JBQ1gsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO2lCQUNmO3FCQUFNLElBQUksU0FBUyxFQUFFO29CQUNwQixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDO2lCQUNuQjtZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxXQUFXLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRXhCLE9BQU8sYUFBYSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUU7WUFDaEMsV0FBVyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ3hCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7MkdBbkRVLGFBQWE7K0dBQWIsYUFBYSxjQUhaLE1BQU07QUFHUCxhQUFhO0lBRHpCLGdCQUFnQixDQUFnQixDQUFDLGtCQUFrQixDQUFDLENBQUM7R0FDekMsYUFBYSxDQW9EekI7U0FwRFksYUFBYTs0RkFBYixhQUFhO2tCQUp6QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIHR5cGUgR2V0RmlsdGVyTWVtYmVyc0RhdGEsXG4gIHR5cGUgR2V0RmlsdGVyTWVtYmVyc1BhcmFtcyBhcyBHZXRGaWx0ZXJNZW1iZXJzUGFyYW1zUHJlYWN0LFxuICB0eXBlIEdldEZpbHRlck1lbWJlcnNSZXN1bHQgYXMgR2V0RmlsdGVyTWVtYmVyc1Jlc3VsdFByZWFjdCxcbiAgSG9va0FkYXB0ZXIsXG4gIHVzZUdldEZpbHRlck1lbWJlcnMsXG59IGZyb20gJ0BzaXNlbnNlL3Nkay11aS1wcmVhY3QnO1xuXG5pbXBvcnQge1xuICBjcmVhdGVQbHVnaW5Db250ZXh0Q29ubmVjdG9yLFxuICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3Rvcixcbn0gZnJvbSAnLi4vY29tcG9uZW50LXdyYXBwZXItaGVscGVycyc7XG5pbXBvcnQgeyBUcmFja2FibGVTZXJ2aWNlIH0gZnJvbSAnLi4vZGVjb3JhdG9ycy90cmFja2FibGUuZGVjb3JhdG9yJztcbmltcG9ydCB7IFNpc2Vuc2VDb250ZXh0U2VydmljZSB9IGZyb20gJy4vc2lzZW5zZS1jb250ZXh0LnNlcnZpY2UnO1xuXG5leHBvcnQgdHlwZSB7IEdldEZpbHRlck1lbWJlcnNEYXRhIH07XG5cbi8qKlxuICogUGFyYW1ldGVycyBmb3IgcmV0cmlldmluZyBmaWx0ZXIgbWVtYmVycy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBHZXRGaWx0ZXJNZW1iZXJzUGFyYW1zIGV4dGVuZHMgT21pdDxHZXRGaWx0ZXJNZW1iZXJzUGFyYW1zUHJlYWN0LCAnZW5hYmxlZCc+IHt9XG5cbi8qKlxuICogU2VydmljZSBmb3Igd29ya2luZyB3aXRoIGZpbHRlci5cbiAqXG4gKiBAZ3JvdXAgRmlsdGVyc1xuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5AVHJhY2thYmxlU2VydmljZTxGaWx0ZXJTZXJ2aWNlPihbJ2dldEZpbHRlck1lbWJlcnMnXSlcbmV4cG9ydCBjbGFzcyBGaWx0ZXJTZXJ2aWNlIHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBzaXNlbnNlQ29udGV4dFNlcnZpY2U6IFNpc2Vuc2VDb250ZXh0U2VydmljZSkge31cblxuICAvKipcbiAgICogUmV0cmlldmVzIG1lbWJlcnMgb2YgdGhlIHByb3ZpZGVkIGZpbHRlci5cbiAgICpcbiAgICogVGhvc2UgbWVtYmVycyBjYW4gYmUgdXNlZCB0byBkaXNwbGF5IGEgbGlzdCBvZiBtZW1iZXJzIGluIGEgdGhpcmQtcGFydHkgZmlsdGVyIGNvbXBvbmVudCBzdWNoIGFzIE1hdGVyaWFsIFVJIFNlbGVjdC5cbiAgICpcbiAgICogIyMgRXhhbXBsZVxuICAgKlxuICAgKiBSZXRyaWV2ZSBzZWxlY3RlZCBtZW1iZXJzIGZyb20gYSBGaWx0ZXIgb24gQ291bnRyeSBvZiB0aGUgU2FtcGxlIEVDb21tZXJjZSBkYXRhIG1vZGVsLlxuICAgKlxuICAgKiBgYGB0c1xuICAgKiB0cnkge1xuICAgKiAgIGNvbnN0IGRhdGEgPSBhd2FpdCBmaWx0ZXJTZXJ2aWNlLmdldEZpbHRlck1lbWJlcnMoe1xuICAgKiAgICAgZmlsdGVyOiBmaWx0ZXJGYWN0b3J5Lm1lbWJlcnMoRE0uQ291bnRyeS5Db3VudHJ5LCBbJ1VuaXRlZCBTdGF0ZXMnLCAnQ2FuYWRhJ10pXG4gICAqICAgfSk7XG4gICAqXG4gICAqICAgY29uc3QgeyBzZWxlY3RlZE1lbWJlcnMsIGFsbE1lbWJlcnMsIGV4Y2x1ZGVNZW1iZXJzLCBlbmFibGVNdWx0aVNlbGVjdGlvbiB9ID0gZGF0YTtcbiAgICogICBjb25zb2xlLmxvZygnc2VsZWN0ZWRNZW1iZXJzJywgc2VsZWN0ZWRNZW1iZXJzKTtcbiAgICogfSBjYXRjaCAoZXJyb3IpIHtcbiAgICogICBjb25zb2xlLmVycm9yKCdFcnJvcjonLCBlcnJvcik7XG4gICAqIH1cbiAgICogYGBgXG4gICAqXG4gICAqIEBwYXJhbSBwYXJhbXMgLSBQYXJhbWV0ZXJzIGZvciByZXRyaWV2aW5nIGZpbHRlciBtZW1iZXJzXG4gICAqIEByZXR1cm5zIFByb21pc2UgdGhhdCByZXNvbHZlcyB0byB0aGUgZmlsdGVyIG1lbWJlcnMgZGF0YVxuICAgKi9cbiAgYXN5bmMgZ2V0RmlsdGVyTWVtYmVycyhwYXJhbXM6IEdldEZpbHRlck1lbWJlcnNQYXJhbXMpOiBQcm9taXNlPEdldEZpbHRlck1lbWJlcnNEYXRhPiB7XG4gICAgY29uc3QgaG9va0FkYXB0ZXIgPSBuZXcgSG9va0FkYXB0ZXIodXNlR2V0RmlsdGVyTWVtYmVycywgW1xuICAgICAgY3JlYXRlUGx1Z2luQ29udGV4dENvbm5lY3Rvcih0aGlzLnNpc2Vuc2VDb250ZXh0U2VydmljZSksXG4gICAgICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3Rvcih0aGlzLnNpc2Vuc2VDb250ZXh0U2VydmljZSksXG4gICAgXSk7XG5cbiAgICBjb25zdCByZXN1bHRQcm9taXNlID0gbmV3IFByb21pc2U8R2V0RmlsdGVyTWVtYmVyc0RhdGE+KChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGhvb2tBZGFwdGVyLnN1YnNjcmliZSgocmVzOiBHZXRGaWx0ZXJNZW1iZXJzUmVzdWx0UHJlYWN0KSA9PiB7XG4gICAgICAgIGNvbnN0IHsgaXNFcnJvciwgaXNTdWNjZXNzLCBlcnJvciB9ID0gcmVzO1xuXG4gICAgICAgIGlmIChpc0Vycm9yKSB7XG4gICAgICAgICAgcmVqZWN0KGVycm9yKTtcbiAgICAgICAgfSBlbHNlIGlmIChpc1N1Y2Nlc3MpIHtcbiAgICAgICAgICByZXNvbHZlKHJlcy5kYXRhKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfSk7XG5cbiAgICBob29rQWRhcHRlci5ydW4ocGFyYW1zKTtcblxuICAgIHJldHVybiByZXN1bHRQcm9taXNlLmZpbmFsbHkoKCkgPT4ge1xuICAgICAgaG9va0FkYXB0ZXIuZGVzdHJveSgpO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
@@ -1,7 +1,7 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { Injectable } from '@angular/core';
3
3
  import { HookAdapter, useGetSharedFormulaInternal, } from '@sisense/sdk-ui-preact';
4
- import { createSisenseContextConnector } from '../component-wrapper-helpers';
4
+ import { createPluginContextConnector, createSisenseContextConnector, } from '../component-wrapper-helpers';
5
5
  import { TrackableService } from '../decorators/trackable.decorator';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "./sisense-context.service";
@@ -68,6 +68,7 @@ let FormulaService = class FormulaService {
68
68
  */
69
69
  async getSharedFormula(params) {
70
70
  const hookAdapter = new HookAdapter(useGetSharedFormulaInternal, [
71
+ createPluginContextConnector(this.sisenseContextService),
71
72
  createSisenseContextConnector(this.sisenseContextService),
72
73
  ]);
73
74
  const resultPromise = new Promise((resolve, reject) => {
@@ -99,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
99
100
  providedIn: 'root',
100
101
  }]
101
102
  }], ctorParameters: function () { return [{ type: i1.SisenseContextService }]; } });
102
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybXVsYS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9zZXJ2aWNlcy9mb3JtdWxhLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsT0FBTyxFQUNMLFdBQVcsRUFFWCwyQkFBMkIsR0FFNUIsTUFBTSx3QkFBd0IsQ0FBQztBQUVoQyxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUM3RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7O0FBUXJFOzs7OztHQUtHO0FBS0ksSUFBTSxjQUFjLEdBQXBCLE1BQU0sY0FBYztJQUN6QixZQUFvQixxQkFBNEM7UUFBNUMsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUF1QjtJQUFHLENBQUM7SUFFcEU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O09Ba0RHO0lBQ0gsS0FBSyxDQUFDLGdCQUFnQixDQUFDLE1BQThCO1FBQ25ELE1BQU0sV0FBVyxHQUFHLElBQUksV0FBVyxDQUFDLDJCQUEyQixFQUFFO1lBQy9ELDZCQUE2QixDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztTQUMxRCxDQUFDLENBQUM7UUFFSCxNQUFNLGFBQWEsR0FBRyxJQUFJLE9BQU8sQ0FBMkIsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDOUUsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQXVCLEVBQUUsRUFBRTtnQkFDaEQsTUFBTSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxHQUFHLEdBQUcsQ0FBQztnQkFFbkQsSUFBSSxPQUFPLEVBQUU7b0JBQ1gsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO2lCQUNmO3FCQUFNLElBQUksU0FBUyxFQUFFO29CQUNwQixPQUFPLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxDQUFDO2lCQUMxQjtZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxXQUFXLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRXhCLE9BQU8sYUFBYSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUU7WUFDaEMsV0FBVyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ3hCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7NEdBNUVVLGNBQWM7Z0hBQWQsY0FBYyxjQUhiLE1BQU07QUFHUCxjQUFjO0lBRDFCLGdCQUFnQixDQUFpQixDQUFDLGtCQUFrQixDQUFDLENBQUM7R0FDMUMsY0FBYyxDQTZFMUI7U0E3RVksY0FBYzs0RkFBZCxjQUFjO2tCQUoxQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHsgQ2FsY3VsYXRlZE1lYXN1cmUgfSBmcm9tICdAc2lzZW5zZS9zZGstZGF0YSc7XG5pbXBvcnQge1xuICBIb29rQWRhcHRlcixcbiAgdHlwZSBTaGFyZWRGb3JtdWxhU3RhdGUsXG4gIHVzZUdldFNoYXJlZEZvcm11bGFJbnRlcm5hbCxcbiAgdHlwZSBVc2VHZXRTaGFyZWRGb3JtdWxhUGFyYW1zIGFzIFVzZUdldFNoYXJlZEZvcm11bGFQYXJhbXNQcmVhY3QsXG59IGZyb20gJ0BzaXNlbnNlL3Nkay11aS1wcmVhY3QnO1xuXG5pbXBvcnQgeyBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3RvciB9IGZyb20gJy4uL2NvbXBvbmVudC13cmFwcGVyLWhlbHBlcnMnO1xuaW1wb3J0IHsgVHJhY2thYmxlU2VydmljZSB9IGZyb20gJy4uL2RlY29yYXRvcnMvdHJhY2thYmxlLmRlY29yYXRvcic7XG5pbXBvcnQgeyBTaXNlbnNlQ29udGV4dFNlcnZpY2UgfSBmcm9tICcuL3Npc2Vuc2UtY29udGV4dC5zZXJ2aWNlJztcblxuLyoqXG4gKiBQYXJhbWV0ZXJzIGZvciByZXRyaWV2aW5nIGEgc2hhcmVkIGZvcm11bGEuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgR2V0U2hhcmVkRm9ybXVsYVBhcmFtcyBleHRlbmRzIE9taXQ8VXNlR2V0U2hhcmVkRm9ybXVsYVBhcmFtc1ByZWFjdCwgJ2VuYWJsZWQnPiB7fVxuXG4vKipcbiAqIFNlcnZpY2UgZm9yIHdvcmtpbmcgd2l0aCBzaGFyZWQgZm9ybXVsYXMuXG4gKlxuICogQGdyb3VwIEZ1c2lvbiBBc3NldHNcbiAqIEBmdXNpb25FbWJlZFxuICovXG5ASW5qZWN0YWJsZSh7XG4gIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5AVHJhY2thYmxlU2VydmljZTxGb3JtdWxhU2VydmljZT4oWydnZXRTaGFyZWRGb3JtdWxhJ10pXG5leHBvcnQgY2xhc3MgRm9ybXVsYVNlcnZpY2Uge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHNpc2Vuc2VDb250ZXh0U2VydmljZTogU2lzZW5zZUNvbnRleHRTZXJ2aWNlKSB7fVxuXG4gIC8qKlxuICAgKiBGZXRjaCBhIFtzaGFyZWQgZm9ybXVsYV0oaHR0cHM6Ly9kb2NzLnNpc2Vuc2UuY29tL21haW4vU2lzZW5zZUxpbnV4L3NoYXJlZC1mb3JtdWxhcy5odG0pIGZyb20gYSBGdXNpb24gaW5zdGFuY2UuXG4gICAqXG4gICAqIFRoZSBmb3JtdWxhIGNhbiBiZSBpZGVudGlmaWVkIGVpdGhlciBieSBgb2lkYCBvciBieSBgbmFtZWAgYW5kIGBkYXRhU291cmNlYCBwYWlyLlxuICAgKlxuICAgKiBXaGVuIHRoZSByZXRyaWV2YWwgaXMgc3VjY2Vzc2Z1bCBidXQgdGhlIHNoYXJlZCBmb3JtdWxhIGlzIG5vdCBmb3VuZCwgdGhlIHJlc3VsdCBpcyBgbnVsbGAuIFdoZW4gdGhlIHJldHJpZXZhbCBpcyBub3Qgc3VjY2Vzc2Z1bCwgdGhlIHByb21pc2UgaXMgcmVqZWN0ZWQgd2l0aCBhbiBlcnJvci5cbiAgICpcbiAgICogIyMgRXhhbXBsZVxuICAgKlxuICAgKiBSZXRyaWV2ZSBhIHNoYXJlZCBmb3JtdWxhIGJ5IG9pZDpcbiAgICpcbiAgICogYGBgdHNcbiAgICogdHJ5IHtcbiAgICogICBjb25zdCBmb3JtdWxhID0gYXdhaXQgZm9ybXVsYVNlcnZpY2UuZ2V0U2hhcmVkRm9ybXVsYSh7XG4gICAqICAgICBvaWQ6ICdkNjFjMzM3Yi1mYWJjLTRlOWUtYjRjYy1hMzAxMTY4NTcxNTMnLFxuICAgKiAgIH0pO1xuICAgKlxuICAgKiAgIGlmIChmb3JtdWxhKSB7XG4gICAqICAgICBjb25zb2xlLmxvZygnRm9ybXVsYSBmb3VuZDonLCBmb3JtdWxhKTtcbiAgICogICB9IGVsc2Uge1xuICAgKiAgICAgY29uc29sZS5sb2coJ0Zvcm11bGEgbm90IGZvdW5kJyk7XG4gICAqICAgfVxuICAgKiB9IGNhdGNoIChlcnJvcikge1xuICAgKiAgIGNvbnNvbGUuZXJyb3IoJ0Vycm9yOicsIGVycm9yKTtcbiAgICogfVxuICAgKiBgYGBcbiAgICpcbiAgICogIyMgRXhhbXBsZVxuICAgKlxuICAgKiBSZXRyaWV2ZSBhIHNoYXJlZCBmb3JtdWxhIGJ5IG5hbWUgYW5kIGRhdGEgc291cmNlOlxuICAgKlxuICAgKiBgYGB0c1xuICAgKiB0cnkge1xuICAgKiAgIGNvbnN0IGZvcm11bGEgPSBhd2FpdCBmb3JtdWxhU2VydmljZS5nZXRTaGFyZWRGb3JtdWxhKHtcbiAgICogICAgIG5hbWU6ICdNeSBTaGFyZWQgRm9ybXVsYScsXG4gICAqICAgICBkYXRhU291cmNlOiBETS5EYXRhU291cmNlLFxuICAgKiAgIH0pO1xuICAgKlxuICAgKiAgIGlmIChmb3JtdWxhKSB7XG4gICAqICAgICBjb25zb2xlLmxvZygnRm9ybXVsYSBmb3VuZDonLCBmb3JtdWxhKTtcbiAgICogICB9IGVsc2Uge1xuICAgKiAgICAgY29uc29sZS5sb2coJ0Zvcm11bGEgbm90IGZvdW5kJyk7XG4gICAqICAgfVxuICAgKiB9IGNhdGNoIChlcnJvcikge1xuICAgKiAgIGNvbnNvbGUuZXJyb3IoJ0Vycm9yOicsIGVycm9yKTtcbiAgICogfVxuICAgKiBgYGBcbiAgICpcbiAgICogQHBhcmFtIHBhcmFtcyAtIFBhcmFtZXRlcnMgZm9yIHJldHJpZXZpbmcgdGhlIHNoYXJlZCBmb3JtdWxhLiBNdXN0IGluY2x1ZGUgZWl0aGVyIGBvaWRgIG9yIGJvdGggYG5hbWVgIGFuZCBgZGF0YVNvdXJjZWAuXG4gICAqIEByZXR1cm5zIFByb21pc2UgdGhhdCByZXNvbHZlcyB0byB0aGUgc2hhcmVkIGZvcm11bGEsIG9yIGBudWxsYCBpZiBub3QgZm91bmRcbiAgICovXG4gIGFzeW5jIGdldFNoYXJlZEZvcm11bGEocGFyYW1zOiBHZXRTaGFyZWRGb3JtdWxhUGFyYW1zKTogUHJvbWlzZTxDYWxjdWxhdGVkTWVhc3VyZSB8IG51bGw+IHtcbiAgICBjb25zdCBob29rQWRhcHRlciA9IG5ldyBIb29rQWRhcHRlcih1c2VHZXRTaGFyZWRGb3JtdWxhSW50ZXJuYWwsIFtcbiAgICAgIGNyZWF0ZVNpc2Vuc2VDb250ZXh0Q29ubmVjdG9yKHRoaXMuc2lzZW5zZUNvbnRleHRTZXJ2aWNlKSxcbiAgICBdKTtcblxuICAgIGNvbnN0IHJlc3VsdFByb21pc2UgPSBuZXcgUHJvbWlzZTxDYWxjdWxhdGVkTWVhc3VyZSB8IG51bGw+KChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGhvb2tBZGFwdGVyLnN1YnNjcmliZSgocmVzOiBTaGFyZWRGb3JtdWxhU3RhdGUpID0+IHtcbiAgICAgICAgY29uc3QgeyBmb3JtdWxhLCBpc0Vycm9yLCBpc1N1Y2Nlc3MsIGVycm9yIH0gPSByZXM7XG5cbiAgICAgICAgaWYgKGlzRXJyb3IpIHtcbiAgICAgICAgICByZWplY3QoZXJyb3IpO1xuICAgICAgICB9IGVsc2UgaWYgKGlzU3VjY2Vzcykge1xuICAgICAgICAgIHJlc29sdmUoZm9ybXVsYSA/PyBudWxsKTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfSk7XG5cbiAgICBob29rQWRhcHRlci5ydW4ocGFyYW1zKTtcblxuICAgIHJldHVybiByZXN1bHRQcm9taXNlLmZpbmFsbHkoKCkgPT4ge1xuICAgICAgaG9va0FkYXB0ZXIuZGVzdHJveSgpO1xuICAgIH0pO1xuICB9XG59XG4iXX0=
103
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybXVsYS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9zZXJ2aWNlcy9mb3JtdWxhLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFM0MsT0FBTyxFQUNMLFdBQVcsRUFFWCwyQkFBMkIsR0FFNUIsTUFBTSx3QkFBd0IsQ0FBQztBQUVoQyxPQUFPLEVBQ0wsNEJBQTRCLEVBQzVCLDZCQUE2QixHQUM5QixNQUFNLDhCQUE4QixDQUFDO0FBQ3RDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDOzs7QUFRckU7Ozs7O0dBS0c7QUFLSSxJQUFNLGNBQWMsR0FBcEIsTUFBTSxjQUFjO0lBQ3pCLFlBQW9CLHFCQUE0QztRQUE1QywwQkFBcUIsR0FBckIscUJBQXFCLENBQXVCO0lBQUcsQ0FBQztJQUVwRTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7T0FrREc7SUFDSCxLQUFLLENBQUMsZ0JBQWdCLENBQUMsTUFBOEI7UUFDbkQsTUFBTSxXQUFXLEdBQUcsSUFBSSxXQUFXLENBQUMsMkJBQTJCLEVBQUU7WUFDL0QsNEJBQTRCLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDO1lBQ3hELDZCQUE2QixDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztTQUMxRCxDQUFDLENBQUM7UUFFSCxNQUFNLGFBQWEsR0FBRyxJQUFJLE9BQU8sQ0FBMkIsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7WUFDOUUsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQXVCLEVBQUUsRUFBRTtnQkFDaEQsTUFBTSxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxHQUFHLEdBQUcsQ0FBQztnQkFFbkQsSUFBSSxPQUFPLEVBQUU7b0JBQ1gsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO2lCQUNmO3FCQUFNLElBQUksU0FBUyxFQUFFO29CQUNwQixPQUFPLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxDQUFDO2lCQUMxQjtZQUNILENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7UUFFSCxXQUFXLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRXhCLE9BQU8sYUFBYSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUU7WUFDaEMsV0FBVyxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ3hCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7NEdBN0VVLGNBQWM7Z0hBQWQsY0FBYyxjQUhiLE1BQU07QUFHUCxjQUFjO0lBRDFCLGdCQUFnQixDQUFpQixDQUFDLGtCQUFrQixDQUFDLENBQUM7R0FDMUMsY0FBYyxDQThFMUI7U0E5RVksY0FBYzs0RkFBZCxjQUFjO2tCQUoxQixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHsgQ2FsY3VsYXRlZE1lYXN1cmUgfSBmcm9tICdAc2lzZW5zZS9zZGstZGF0YSc7XG5pbXBvcnQge1xuICBIb29rQWRhcHRlcixcbiAgdHlwZSBTaGFyZWRGb3JtdWxhU3RhdGUsXG4gIHVzZUdldFNoYXJlZEZvcm11bGFJbnRlcm5hbCxcbiAgdHlwZSBVc2VHZXRTaGFyZWRGb3JtdWxhUGFyYW1zIGFzIFVzZUdldFNoYXJlZEZvcm11bGFQYXJhbXNQcmVhY3QsXG59IGZyb20gJ0BzaXNlbnNlL3Nkay11aS1wcmVhY3QnO1xuXG5pbXBvcnQge1xuICBjcmVhdGVQbHVnaW5Db250ZXh0Q29ubmVjdG9yLFxuICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3Rvcixcbn0gZnJvbSAnLi4vY29tcG9uZW50LXdyYXBwZXItaGVscGVycyc7XG5pbXBvcnQgeyBUcmFja2FibGVTZXJ2aWNlIH0gZnJvbSAnLi4vZGVjb3JhdG9ycy90cmFja2FibGUuZGVjb3JhdG9yJztcbmltcG9ydCB7IFNpc2Vuc2VDb250ZXh0U2VydmljZSB9IGZyb20gJy4vc2lzZW5zZS1jb250ZXh0LnNlcnZpY2UnO1xuXG4vKipcbiAqIFBhcmFtZXRlcnMgZm9yIHJldHJpZXZpbmcgYSBzaGFyZWQgZm9ybXVsYS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBHZXRTaGFyZWRGb3JtdWxhUGFyYW1zIGV4dGVuZHMgT21pdDxVc2VHZXRTaGFyZWRGb3JtdWxhUGFyYW1zUHJlYWN0LCAnZW5hYmxlZCc+IHt9XG5cbi8qKlxuICogU2VydmljZSBmb3Igd29ya2luZyB3aXRoIHNoYXJlZCBmb3JtdWxhcy5cbiAqXG4gKiBAZ3JvdXAgRnVzaW9uIEFzc2V0c1xuICogQGZ1c2lvbkVtYmVkXG4gKi9cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbkBUcmFja2FibGVTZXJ2aWNlPEZvcm11bGFTZXJ2aWNlPihbJ2dldFNoYXJlZEZvcm11bGEnXSlcbmV4cG9ydCBjbGFzcyBGb3JtdWxhU2VydmljZSB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc2lzZW5zZUNvbnRleHRTZXJ2aWNlOiBTaXNlbnNlQ29udGV4dFNlcnZpY2UpIHt9XG5cbiAgLyoqXG4gICAqIEZldGNoIGEgW3NoYXJlZCBmb3JtdWxhXShodHRwczovL2RvY3Muc2lzZW5zZS5jb20vbWFpbi9TaXNlbnNlTGludXgvc2hhcmVkLWZvcm11bGFzLmh0bSkgZnJvbSBhIEZ1c2lvbiBpbnN0YW5jZS5cbiAgICpcbiAgICogVGhlIGZvcm11bGEgY2FuIGJlIGlkZW50aWZpZWQgZWl0aGVyIGJ5IGBvaWRgIG9yIGJ5IGBuYW1lYCBhbmQgYGRhdGFTb3VyY2VgIHBhaXIuXG4gICAqXG4gICAqIFdoZW4gdGhlIHJldHJpZXZhbCBpcyBzdWNjZXNzZnVsIGJ1dCB0aGUgc2hhcmVkIGZvcm11bGEgaXMgbm90IGZvdW5kLCB0aGUgcmVzdWx0IGlzIGBudWxsYC4gV2hlbiB0aGUgcmV0cmlldmFsIGlzIG5vdCBzdWNjZXNzZnVsLCB0aGUgcHJvbWlzZSBpcyByZWplY3RlZCB3aXRoIGFuIGVycm9yLlxuICAgKlxuICAgKiAjIyBFeGFtcGxlXG4gICAqXG4gICAqIFJldHJpZXZlIGEgc2hhcmVkIGZvcm11bGEgYnkgb2lkOlxuICAgKlxuICAgKiBgYGB0c1xuICAgKiB0cnkge1xuICAgKiAgIGNvbnN0IGZvcm11bGEgPSBhd2FpdCBmb3JtdWxhU2VydmljZS5nZXRTaGFyZWRGb3JtdWxhKHtcbiAgICogICAgIG9pZDogJ2Q2MWMzMzdiLWZhYmMtNGU5ZS1iNGNjLWEzMDExNjg1NzE1MycsXG4gICAqICAgfSk7XG4gICAqXG4gICAqICAgaWYgKGZvcm11bGEpIHtcbiAgICogICAgIGNvbnNvbGUubG9nKCdGb3JtdWxhIGZvdW5kOicsIGZvcm11bGEpO1xuICAgKiAgIH0gZWxzZSB7XG4gICAqICAgICBjb25zb2xlLmxvZygnRm9ybXVsYSBub3QgZm91bmQnKTtcbiAgICogICB9XG4gICAqIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAqICAgY29uc29sZS5lcnJvcignRXJyb3I6JywgZXJyb3IpO1xuICAgKiB9XG4gICAqIGBgYFxuICAgKlxuICAgKiAjIyBFeGFtcGxlXG4gICAqXG4gICAqIFJldHJpZXZlIGEgc2hhcmVkIGZvcm11bGEgYnkgbmFtZSBhbmQgZGF0YSBzb3VyY2U6XG4gICAqXG4gICAqIGBgYHRzXG4gICAqIHRyeSB7XG4gICAqICAgY29uc3QgZm9ybXVsYSA9IGF3YWl0IGZvcm11bGFTZXJ2aWNlLmdldFNoYXJlZEZvcm11bGEoe1xuICAgKiAgICAgbmFtZTogJ015IFNoYXJlZCBGb3JtdWxhJyxcbiAgICogICAgIGRhdGFTb3VyY2U6IERNLkRhdGFTb3VyY2UsXG4gICAqICAgfSk7XG4gICAqXG4gICAqICAgaWYgKGZvcm11bGEpIHtcbiAgICogICAgIGNvbnNvbGUubG9nKCdGb3JtdWxhIGZvdW5kOicsIGZvcm11bGEpO1xuICAgKiAgIH0gZWxzZSB7XG4gICAqICAgICBjb25zb2xlLmxvZygnRm9ybXVsYSBub3QgZm91bmQnKTtcbiAgICogICB9XG4gICAqIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAqICAgY29uc29sZS5lcnJvcignRXJyb3I6JywgZXJyb3IpO1xuICAgKiB9XG4gICAqIGBgYFxuICAgKlxuICAgKiBAcGFyYW0gcGFyYW1zIC0gUGFyYW1ldGVycyBmb3IgcmV0cmlldmluZyB0aGUgc2hhcmVkIGZvcm11bGEuIE11c3QgaW5jbHVkZSBlaXRoZXIgYG9pZGAgb3IgYm90aCBgbmFtZWAgYW5kIGBkYXRhU291cmNlYC5cbiAgICogQHJldHVybnMgUHJvbWlzZSB0aGF0IHJlc29sdmVzIHRvIHRoZSBzaGFyZWQgZm9ybXVsYSwgb3IgYG51bGxgIGlmIG5vdCBmb3VuZFxuICAgKi9cbiAgYXN5bmMgZ2V0U2hhcmVkRm9ybXVsYShwYXJhbXM6IEdldFNoYXJlZEZvcm11bGFQYXJhbXMpOiBQcm9taXNlPENhbGN1bGF0ZWRNZWFzdXJlIHwgbnVsbD4ge1xuICAgIGNvbnN0IGhvb2tBZGFwdGVyID0gbmV3IEhvb2tBZGFwdGVyKHVzZUdldFNoYXJlZEZvcm11bGFJbnRlcm5hbCwgW1xuICAgICAgY3JlYXRlUGx1Z2luQ29udGV4dENvbm5lY3Rvcih0aGlzLnNpc2Vuc2VDb250ZXh0U2VydmljZSksXG4gICAgICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3Rvcih0aGlzLnNpc2Vuc2VDb250ZXh0U2VydmljZSksXG4gICAgXSk7XG5cbiAgICBjb25zdCByZXN1bHRQcm9taXNlID0gbmV3IFByb21pc2U8Q2FsY3VsYXRlZE1lYXN1cmUgfCBudWxsPigocmVzb2x2ZSwgcmVqZWN0KSA9PiB7XG4gICAgICBob29rQWRhcHRlci5zdWJzY3JpYmUoKHJlczogU2hhcmVkRm9ybXVsYVN0YXRlKSA9PiB7XG4gICAgICAgIGNvbnN0IHsgZm9ybXVsYSwgaXNFcnJvciwgaXNTdWNjZXNzLCBlcnJvciB9ID0gcmVzO1xuXG4gICAgICAgIGlmIChpc0Vycm9yKSB7XG4gICAgICAgICAgcmVqZWN0KGVycm9yKTtcbiAgICAgICAgfSBlbHNlIGlmIChpc1N1Y2Nlc3MpIHtcbiAgICAgICAgICByZXNvbHZlKGZvcm11bGEgPz8gbnVsbCk7XG4gICAgICAgIH1cbiAgICAgIH0pO1xuICAgIH0pO1xuXG4gICAgaG9va0FkYXB0ZXIucnVuKHBhcmFtcyk7XG5cbiAgICByZXR1cm4gcmVzdWx0UHJvbWlzZS5maW5hbGx5KCgpID0+IHtcbiAgICAgIGhvb2tBZGFwdGVyLmRlc3Ryb3koKTtcbiAgICB9KTtcbiAgfVxufVxuIl19
@@ -2,7 +2,7 @@ import { __decorate } from "tslib";
2
2
  import { Injectable } from '@angular/core';
3
3
  import { getFilterListAndRelationsJaql } from '@sisense/sdk-data';
4
4
  import { executePivotQuery, executeQuery, executeQueryByWidgetId, HookAdapter, useExecuteCsvQueryInternal, useExecuteCustomWidgetQueryInternal, } from '@sisense/sdk-ui-preact';
5
- import { createSisenseContextConnector } from '../component-wrapper-helpers';
5
+ import { createPluginContextConnector, createSisenseContextConnector, } from '../component-wrapper-helpers';
6
6
  import { TrackableService } from '../decorators/trackable.decorator';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "./sisense-context.service";
@@ -89,6 +89,7 @@ let QueryService = class QueryService {
89
89
  */
90
90
  async executeCsvQuery(params) {
91
91
  const hookAdapter = new HookAdapter(useExecuteCsvQueryInternal, [
92
+ createPluginContextConnector(this.sisenseContextService),
92
93
  createSisenseContextConnector(this.sisenseContextService),
93
94
  ]);
94
95
  const resultPromise = new Promise((resolve, reject) => {
@@ -118,6 +119,7 @@ let QueryService = class QueryService {
118
119
  */
119
120
  async executeCustomWidgetQuery(params) {
120
121
  const hookAdapter = new HookAdapter(useExecuteCustomWidgetQueryInternal, [
122
+ createPluginContextConnector(this.sisenseContextService),
121
123
  createSisenseContextConnector(this.sisenseContextService),
122
124
  ]);
123
125
  const resultPromise = new Promise((resolve, reject) => {
@@ -154,4 +156,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
154
156
  providedIn: 'root',
155
157
  }]
156
158
  }], ctorParameters: function () { return [{ type: i1.SisenseContextService }]; } });
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"]}
159
+ //# 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 {\n  createPluginContextConnector,\n  createSisenseContextConnector,\n} 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      createPluginContextConnector(this.sisenseContextService),\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      createPluginContextConnector(this.sisenseContextService),\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"]}