@sisense/sdk-ui-angular 2.1.0 → 2.2.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.
- package/dist/ai/lib/component-wrapper-helpers/template.d.ts +1 -0
- package/dist/esm2020/ai/lib/component-wrapper-helpers/template.mjs +8 -2
- package/dist/esm2020/ai/lib/components/chatbot.component.mjs +4 -8
- package/dist/esm2020/ai/lib/components/get-nlg-insights.component.mjs +4 -8
- package/dist/esm2020/lib/component-wrapper-helpers/template.mjs +10 -4
- package/dist/esm2020/lib/components/charts/chart.component.mjs +4 -8
- package/dist/esm2020/lib/components/charts/pivot-table.component.mjs +4 -8
- package/dist/esm2020/lib/components/charts/table.component.mjs +4 -8
- package/dist/esm2020/lib/components/context-menu.component.mjs +4 -8
- package/dist/esm2020/lib/components/dashboard/dashboard-by-id.component.mjs +4 -8
- package/dist/esm2020/lib/components/dashboard/dashboard.component.mjs +20 -11
- package/dist/esm2020/lib/components/drilldown-breadcrumbs.component.mjs +4 -8
- package/dist/esm2020/lib/components/filters/criteria-filter-tile.component.mjs +4 -8
- package/dist/esm2020/lib/components/filters/date-range-filter-tile.component.mjs +4 -8
- package/dist/esm2020/lib/components/filters/filter-tile.component.mjs +4 -8
- package/dist/esm2020/lib/components/filters/member-filter-tile.component.mjs +4 -8
- package/dist/esm2020/lib/components/filters/relative-date-filter-tile.component.mjs +4 -8
- package/dist/esm2020/lib/components/widgets/chart-widget.component.mjs +4 -8
- package/dist/esm2020/lib/components/widgets/drilldown-widget.component.mjs +4 -8
- package/dist/esm2020/lib/components/widgets/pivot-table-widget.component.mjs +4 -8
- package/dist/esm2020/lib/components/widgets/table-widget.component.mjs +4 -8
- package/dist/esm2020/lib/components/widgets/widget-by-id.component.mjs +4 -8
- package/dist/esm2020/lib/components/widgets/widget.component.mjs +4 -8
- package/dist/esm2020/version.mjs +2 -2
- package/dist/fesm2015/sisense-sdk-ui-angular-ai.mjs +11 -11
- package/dist/fesm2015/sisense-sdk-ui-angular-ai.mjs.map +1 -1
- package/dist/fesm2015/sisense-sdk-ui-angular.mjs +61 -97
- package/dist/fesm2015/sisense-sdk-ui-angular.mjs.map +1 -1
- package/dist/fesm2020/sisense-sdk-ui-angular-ai.mjs +11 -11
- package/dist/fesm2020/sisense-sdk-ui-angular-ai.mjs.map +1 -1
- package/dist/fesm2020/sisense-sdk-ui-angular.mjs +61 -97
- package/dist/fesm2020/sisense-sdk-ui-angular.mjs.map +1 -1
- package/dist/lib/component-wrapper-helpers/template.d.ts +1 -0
- package/dist/lib/components/dashboard/dashboard.component.d.ts +23 -2
- package/dist/package.json +4 -4
- package/dist/version.d.ts +1 -1
- package/package.json +4 -4
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { Component, Input, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ComponentAdapter, Dashboard as DashboardPreact, } from '@sisense/sdk-ui-preact';
|
|
3
|
-
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
-
import { rootId, template } from '../../component-wrapper-helpers/template';
|
|
3
|
+
import { createPluginsContextConnector, createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
|
|
5
4
|
import { translateToPreactDashboardProps } from '../../helpers/dashboard-props-preact-translator';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "../../services/sisense-context.service";
|
|
8
7
|
import * as i2 from "../../services/theme.service";
|
|
8
|
+
import * as i3 from "../../services/plugins.service";
|
|
9
9
|
/**
|
|
10
10
|
* An Angular component used for easily rendering a dashboard created in Sisense Fusion.
|
|
11
11
|
*
|
|
@@ -72,12 +72,21 @@ export class DashboardComponent {
|
|
|
72
72
|
*
|
|
73
73
|
* @category Constructor
|
|
74
74
|
*/
|
|
75
|
-
themeService
|
|
75
|
+
themeService,
|
|
76
|
+
/**
|
|
77
|
+
* Plugin service
|
|
78
|
+
*
|
|
79
|
+
* @internal
|
|
80
|
+
* @category Constructor
|
|
81
|
+
*/
|
|
82
|
+
pluginService) {
|
|
76
83
|
this.sisenseContextService = sisenseContextService;
|
|
77
84
|
this.themeService = themeService;
|
|
85
|
+
this.pluginService = pluginService;
|
|
78
86
|
this.componentAdapter = new ComponentAdapter(DashboardPreact, [
|
|
79
87
|
createSisenseContextConnector(this.sisenseContextService),
|
|
80
88
|
createThemeContextConnector(this.themeService),
|
|
89
|
+
createPluginsContextConnector(this.pluginService),
|
|
81
90
|
]);
|
|
82
91
|
}
|
|
83
92
|
/**
|
|
@@ -104,6 +113,7 @@ export class DashboardComponent {
|
|
|
104
113
|
defaultDataSource: this.defaultDataSource,
|
|
105
114
|
widgetsOptions: this.widgetsOptions,
|
|
106
115
|
styleOptions: this.styleOptions,
|
|
116
|
+
tabbersOptions: this.tabbersOptions,
|
|
107
117
|
});
|
|
108
118
|
}
|
|
109
119
|
/**
|
|
@@ -113,15 +123,12 @@ export class DashboardComponent {
|
|
|
113
123
|
this.componentAdapter.destroy();
|
|
114
124
|
}
|
|
115
125
|
}
|
|
116
|
-
DashboardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
117
|
-
DashboardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DashboardComponent, selector: "csdk-dashboard", inputs: { title: "title", layoutOptions: "layoutOptions", config: "config", widgets: "widgets", filters: "filters", defaultDataSource: "defaultDataSource", widgetsOptions: "widgetsOptions", styleOptions: "styleOptions" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact
|
|
126
|
+
DashboardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }, { token: i3.PluginsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
127
|
+
DashboardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DashboardComponent, selector: "csdk-dashboard", inputs: { title: "title", layoutOptions: "layoutOptions", config: "config", widgets: "widgets", filters: "filters", defaultDataSource: "defaultDataSource", widgetsOptions: "widgetsOptions", styleOptions: "styleOptions", tabbersOptions: "tabbersOptions" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
|
|
118
128
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardComponent, decorators: [{
|
|
119
129
|
type: Component,
|
|
120
|
-
args: [{
|
|
121
|
-
|
|
122
|
-
template,
|
|
123
|
-
}]
|
|
124
|
-
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
130
|
+
args: [{ selector: 'csdk-dashboard', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
|
|
131
|
+
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }, { type: i3.PluginsService }]; }, propDecorators: { preactRef: [{
|
|
125
132
|
type: ViewChild,
|
|
126
133
|
args: [rootId]
|
|
127
134
|
}], title: [{
|
|
@@ -140,5 +147,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
140
147
|
type: Input
|
|
141
148
|
}], styleOptions: [{
|
|
142
149
|
type: Input
|
|
150
|
+
}], tabbersOptions: [{
|
|
151
|
+
type: Input
|
|
143
152
|
}] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/dashboard/dashboard.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,SAAS,IAAI,eAAe,GAE7B,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,GAC5B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,0CAA0C,CAAC;AAC5E,OAAO,EAAE,+BAA+B,EAAE,MAAM,iDAAiD,CAAC;;;;AAoBlG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AAKH,MAAM,OAAO,kBAAkB;IAyD7B;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QAEjC,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,eAAe,EAAE;YAC5D,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,OAAO,+BAA+B,CAAC;YACrC,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,YAAY,EAAE,IAAI,CAAC,YAAY;SAChC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;gHArHU,kBAAkB;oGAAlB,kBAAkB;4FAAlB,kBAAkB;kBAJ9B,SAAS;mBAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ;iBACT;uIAMC,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,aAAa;sBADZ,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,OAAO;sBADN,KAAK;gBAON,OAAO;sBADN,KAAK;gBAON,iBAAiB;sBADhB,KAAK;gBAON,cAAc;sBADb,KAAK;gBAON,YAAY;sBADX,KAAK","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  Dashboard as DashboardPreact,\n  type DashboardProps as DashboardPropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { rootId, template } from '../../component-wrapper-helpers/template';\nimport { translateToPreactDashboardProps } from '../../helpers/dashboard-props-preact-translator';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { DashboardConfig } from '../../types';\nimport { WidgetProps } from '../widgets/widget.component';\n\n/**\n * Props of the {@link DashboardComponent}.\n */\nexport interface DashboardProps extends Omit<DashboardPropsPreact, 'widgets'> {\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.config}\n   */\n  config?: DashboardConfig;\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.widgets}\n   */\n  widgets: WidgetProps[];\n}\n\n/**\n * An Angular component used for easily rendering a dashboard created in Sisense Fusion.\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 * @example\n * ```html\n * <csdk-dashboard\n *  *ngIf=\"dashboard\"\n *  [title]=\"dashboard.title\"\n *  [layoutOptions]=\"dashboard.layoutOptions\"\n *  [widgets]=\"dashboard.widgets\"\n *  [filters]=\"dashboard.filters\"\n *  [defaultDataSource]=\"dashboard.defaultDataSource\"\n *  [widgetsOptions]=\"dashboard.widgetsOptions\"\n * />\n * ```\n *\n * ```ts\n * import { Component } from '@angular/core';\n * import {\n *   type DashboardProps,\n *   DashboardService,\n *   dashboardModelTranslator,\n * } from '@sisense/sdk-ui-angular';\n *\n * @Component({\n *  selector: 'app-dashboard',\n *  templateUrl: './dashboard.component.html',\n *  styleUrls: ['./dashboard.component.scss'],\n * })\n * export class DashboardComponent {\n *\n *  dashboard: DashboardProps | null = null;\n *\n *  constructor(private dashboardService: DashboardService) {}\n *\n *  async ngOnInit(): Promise<void> {\n *    const dashboardModel = await this.dashboardService.getDashboardModel('your-dashboard-oid', { includeWidgets: true, includeFilters: true });\n *    this.dashboard = dashboardModelTranslator.toDashboardProps(dashboardModel);\n *  }\n * ```\n *\n * To learn more about this and related dashboard components,\n * see [Embedded Dashboards](/guides/sdk/guides/dashboards/index.html).\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-dashboard',\n  template,\n})\nexport class DashboardComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.title}\n   */\n  @Input()\n  title: DashboardProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.layoutOptions}\n   */\n  @Input()\n  layoutOptions: DashboardProps['layoutOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.config}\n   */\n  @Input()\n  config: DashboardProps['config'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.widgets}\n   */\n  @Input()\n  widgets!: DashboardProps['widgets'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.filters}\n   */\n  @Input()\n  filters: DashboardProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.defaultDataSource}\n   */\n  @Input()\n  defaultDataSource: DashboardProps['defaultDataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.widgetsOptions}\n   */\n  @Input()\n  widgetsOptions: DashboardProps['widgetsOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.styleOptions}\n   */\n  @Input()\n  styleOptions: DashboardProps['styleOptions'];\n\n  private componentAdapter: ComponentAdapter<typeof DashboardPreact>;\n\n  /**\n   * Constructor for the `Dashboard` component.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(DashboardPreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): DashboardPropsPreact {\n    return translateToPreactDashboardProps({\n      title: this.title,\n      layoutOptions: this.layoutOptions,\n      config: this.config,\n      widgets: this.widgets,\n      filters: this.filters,\n      defaultDataSource: this.defaultDataSource,\n      widgetsOptions: this.widgetsOptions,\n      styleOptions: this.styleOptions,\n    });\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/dashboard/dashboard.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,SAAS,IAAI,eAAe,GAE7B,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,+BAA+B,EAAE,MAAM,iDAAiD,CAAC;;;;;AAqBlG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CG;AAMH,MAAM,OAAO,kBAAkB;IAiE7B;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;IACjC;;;;;OAKG;IACI,aAA6B;QAb7B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QAO1B,kBAAa,GAAb,aAAa,CAAgB;QAEpC,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,eAAe,EAAE;YAC5D,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;YAC9C,6BAA6B,CAAC,IAAI,CAAC,aAAa,CAAC;SAClD,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,OAAO,+BAA+B,CAAC;YACrC,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,aAAa,EAAE,IAAI,CAAC,aAAa;YACjC,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,cAAc,EAAE,IAAI,CAAC,cAAc;YACnC,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;gHAtIU,kBAAkB;oGAAlB,kBAAkB;4FAAlB,kBAAkB;kBAL9B,SAAS;+BACE,gBAAgB,YAC1B,QAAQ;oKAQR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,aAAa;sBADZ,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,OAAO;sBADN,KAAK;gBAON,OAAO;sBADN,KAAK;gBAON,iBAAiB;sBADhB,KAAK;gBAON,cAAc;sBADb,KAAK;gBAON,YAAY;sBADX,KAAK;gBASN,cAAc;sBADb,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  Dashboard as DashboardPreact,\n  type DashboardProps as DashboardPropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createPluginsContextConnector,\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { translateToPreactDashboardProps } from '../../helpers/dashboard-props-preact-translator';\nimport { PluginsService } from '../../services/plugins.service';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { DashboardConfig } from '../../types';\nimport { WidgetProps } from '../widgets/widget.component';\n\n/**\n * Props of the {@link DashboardComponent}.\n */\nexport interface DashboardProps extends Omit<DashboardPropsPreact, 'widgets'> {\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.config}\n   */\n  config?: DashboardConfig;\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.widgets}\n   */\n  widgets: WidgetProps[];\n}\n\n/**\n * An Angular component used for easily rendering a dashboard created in Sisense Fusion.\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 * @example\n * ```html\n * <csdk-dashboard\n *  *ngIf=\"dashboard\"\n *  [title]=\"dashboard.title\"\n *  [layoutOptions]=\"dashboard.layoutOptions\"\n *  [widgets]=\"dashboard.widgets\"\n *  [filters]=\"dashboard.filters\"\n *  [defaultDataSource]=\"dashboard.defaultDataSource\"\n *  [widgetsOptions]=\"dashboard.widgetsOptions\"\n * />\n * ```\n *\n * ```ts\n * import { Component } from '@angular/core';\n * import {\n *   type DashboardProps,\n *   DashboardService,\n *   dashboardModelTranslator,\n * } from '@sisense/sdk-ui-angular';\n *\n * @Component({\n *  selector: 'app-dashboard',\n *  templateUrl: './dashboard.component.html',\n *  styleUrls: ['./dashboard.component.scss'],\n * })\n * export class DashboardComponent {\n *\n *  dashboard: DashboardProps | null = null;\n *\n *  constructor(private dashboardService: DashboardService) {}\n *\n *  async ngOnInit(): Promise<void> {\n *    const dashboardModel = await this.dashboardService.getDashboardModel('your-dashboard-oid', { includeWidgets: true, includeFilters: true });\n *    this.dashboard = dashboardModelTranslator.toDashboardProps(dashboardModel);\n *  }\n * ```\n *\n * To learn more about this and related dashboard components,\n * see [Embedded Dashboards](/guides/sdk/guides/dashboards/index.html).\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-dashboard',\n  template,\n  styles,\n})\nexport class DashboardComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.title}\n   */\n  @Input()\n  title: DashboardProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.layoutOptions}\n   */\n  @Input()\n  layoutOptions: DashboardProps['layoutOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.config}\n   */\n  @Input()\n  config: DashboardProps['config'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.widgets}\n   */\n  @Input()\n  widgets!: DashboardProps['widgets'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.filters}\n   */\n  @Input()\n  filters: DashboardProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.defaultDataSource}\n   */\n  @Input()\n  defaultDataSource: DashboardProps['defaultDataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.widgetsOptions}\n   */\n  @Input()\n  widgetsOptions: DashboardProps['widgetsOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.styleOptions}\n   */\n  @Input()\n  styleOptions: DashboardProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardProps.tabbersOptions}\n   *\n   * @internal\n   */\n  @Input()\n  tabbersOptions: DashboardProps['tabbersOptions'];\n\n  private componentAdapter: ComponentAdapter<typeof DashboardPreact>;\n\n  /**\n   * Constructor for the `Dashboard` component.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n    /**\n     * Plugin service\n     *\n     * @internal\n     * @category Constructor\n     */\n    public pluginService: PluginsService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(DashboardPreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n      createPluginsContextConnector(this.pluginService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): DashboardPropsPreact {\n    return translateToPreactDashboardProps({\n      title: this.title,\n      layoutOptions: this.layoutOptions,\n      config: this.config,\n      widgets: this.widgets,\n      filters: this.filters,\n      defaultDataSource: this.defaultDataSource,\n      widgetsOptions: this.widgetsOptions,\n      styleOptions: this.styleOptions,\n      tabbersOptions: this.tabbersOptions,\n    });\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ComponentAdapter, DrilldownBreadcrumbs as DrilldownBreadcrumbsPreact, } from '@sisense/sdk-ui-preact';
|
|
3
|
-
import { createSisenseContextConnector, createThemeContextConnector, } from '../component-wrapper-helpers';
|
|
4
|
-
import { rootId, template } from '../component-wrapper-helpers/template';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../component-wrapper-helpers';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "../services/sisense-context.service";
|
|
7
6
|
import * as i2 from "../services/theme.service";
|
|
@@ -79,13 +78,10 @@ export class DrilldownBreadcrumbsComponent {
|
|
|
79
78
|
}
|
|
80
79
|
}
|
|
81
80
|
DrilldownBreadcrumbsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DrilldownBreadcrumbsComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
82
|
-
DrilldownBreadcrumbsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DrilldownBreadcrumbsComponent, selector: "csdk-drilldown-breadcrumbs", inputs: { filtersDisplayValues: "filtersDisplayValues", currentDimension: "currentDimension" }, outputs: { drilldownSelectionsClear: "drilldownSelectionsClear", drilldownSelectionsSlice: "drilldownSelectionsSlice" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact
|
|
81
|
+
DrilldownBreadcrumbsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DrilldownBreadcrumbsComponent, selector: "csdk-drilldown-breadcrumbs", inputs: { filtersDisplayValues: "filtersDisplayValues", currentDimension: "currentDimension" }, outputs: { drilldownSelectionsClear: "drilldownSelectionsClear", drilldownSelectionsSlice: "drilldownSelectionsSlice" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
|
|
83
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DrilldownBreadcrumbsComponent, decorators: [{
|
|
84
83
|
type: Component,
|
|
85
|
-
args: [{
|
|
86
|
-
selector: 'csdk-drilldown-breadcrumbs',
|
|
87
|
-
template,
|
|
88
|
-
}]
|
|
84
|
+
args: [{ selector: 'csdk-drilldown-breadcrumbs', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
|
|
89
85
|
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
90
86
|
type: ViewChild,
|
|
91
87
|
args: [rootId]
|
|
@@ -98,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
98
94
|
}], drilldownSelectionsSlice: [{
|
|
99
95
|
type: Output
|
|
100
96
|
}] } });
|
|
101
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJpbGxkb3duLWJyZWFkY3J1bWJzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9kcmlsbGRvd24tYnJlYWRjcnVtYnMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxTQUFTLEVBRVQsWUFBWSxFQUNaLEtBQUssRUFHTCxNQUFNLEVBQ04sU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxnQkFBZ0IsRUFDaEIsb0JBQW9CLElBQUksMEJBQTBCLEdBRW5ELE1BQU0sd0JBQXdCLENBQUM7QUFFaEMsT0FBTyxFQUNMLDZCQUE2QixFQUM3QiwyQkFBMkIsRUFDM0IsTUFBTSxFQUNOLE1BQU0sRUFDTixRQUFRLEdBQ1QsTUFBTSw4QkFBOEIsQ0FBQzs7OztBQWdCdEM7Ozs7R0FJRztBQU1ILE1BQU0sT0FBTyw2QkFBNkI7SUE2Q3hDOzs7OztPQUtHO0lBQ0g7SUFDRTs7OztPQUlHO0lBQ0kscUJBQTRDO0lBQ25EOzs7O09BSUc7SUFDSSxZQUEwQjtRQU4xQiwwQkFBcUIsR0FBckIscUJBQXFCLENBQXVCO1FBTTVDLGlCQUFZLEdBQVosWUFBWSxDQUFjO1FBeENuQzs7OztXQUlHO1FBRUgsNkJBQXdCLEdBQUcsSUFBSSxZQUFZLEVBRXhDLENBQUM7UUFFSjs7OztXQUlHO1FBRUgsNkJBQXdCLEdBQUcsSUFBSSxZQUFZLEVBRXhDLENBQUM7UUF3QkYsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksZ0JBQWdCLENBQUMsMEJBQTBCLEVBQUU7WUFDdkUsNkJBQTZCLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDO1lBQ3pELDJCQUEyQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUM7U0FDL0MsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOztPQUVHO0lBQ0gsZUFBZTtRQUNiLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUMsQ0FBQztJQUM3RixDQUFDO0lBRUQ7O09BRUc7SUFDSCxXQUFXO1FBQ1QsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFO1lBQ2xCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLHVCQUF1QixFQUFFLENBQUMsQ0FBQztTQUM1RjtJQUNILENBQUM7SUFFTyx1QkFBdUI7UUFDN0IsT0FBTztZQUNMLG9CQUFvQixFQUFFLElBQUksQ0FBQyxvQkFBb0I7WUFDL0MsZ0JBQWdCLEVBQUUsSUFBSSxDQUFDLGdCQUFnQjtZQUN2Qyx3QkFBd0IsRUFBRSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsd0JBQXdCLENBQUMsSUFBSSxFQUFFO1lBQ3BFLHdCQUF3QixFQUFFLENBQ3hCLENBQXNFLEVBQ3RFLEVBQUUsQ0FBQyxJQUFJLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztTQUMzQyxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsV0FBVztRQUNULElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLEVBQUUsQ0FBQztJQUNsQyxDQUFDOzsySEF2R1UsNkJBQTZCOytHQUE3Qiw2QkFBNkI7NEZBQTdCLDZCQUE2QjtrQkFMekMsU0FBUzsrQkFDRSw0QkFBNEIsWUFDdEMsUUFBUTt1SUFRUixTQUFTO3NCQURSLFNBQVM7dUJBQUMsTUFBTTtnQkFTakIsb0JBQW9CO3NCQURuQixLQUFLO2dCQVNOLGdCQUFnQjtzQkFEZixLQUFLO2dCQVNOLHdCQUF3QjtzQkFEdkIsTUFBTTtnQkFXUCx3QkFBd0I7c0JBRHZCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT25EZXN0cm95LFxuICBPdXRwdXQsXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBDb21wb25lbnRBZGFwdGVyLFxuICBEcmlsbGRvd25CcmVhZGNydW1icyBhcyBEcmlsbGRvd25CcmVhZGNydW1ic1ByZWFjdCxcbiAgdHlwZSBEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzIGFzIERyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHNQcmVhY3QsXG59IGZyb20gJ0BzaXNlbnNlL3Nkay11aS1wcmVhY3QnO1xuXG5pbXBvcnQge1xuICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3RvcixcbiAgY3JlYXRlVGhlbWVDb250ZXh0Q29ubmVjdG9yLFxuICByb290SWQsXG4gIHN0eWxlcyxcbiAgdGVtcGxhdGUsXG59IGZyb20gJy4uL2NvbXBvbmVudC13cmFwcGVyLWhlbHBlcnMnO1xuaW1wb3J0IHsgU2lzZW5zZUNvbnRleHRTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvc2lzZW5zZS1jb250ZXh0LnNlcnZpY2UnO1xuaW1wb3J0IHsgVGhlbWVTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvdGhlbWUuc2VydmljZSc7XG5pbXBvcnQgdHlwZSB7IEFyZ3VtZW50cywgQXJndW1lbnRzQXNPYmplY3QgfSBmcm9tICcuLi90eXBlcy91dGlsaXR5LXR5cGVzJztcblxuLyoqXG4gKiBQcm9wcyBvZiB0aGUge0BsaW5rIERyaWxsZG93bkJyZWFkY3J1bWJzQ29tcG9uZW50fS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzXG4gIGV4dGVuZHMgT21pdDxEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzUHJlYWN0LCAnY2xlYXJEcmlsbGRvd25TZWxlY3Rpb25zJz4ge1xuICBkcmlsbGRvd25TZWxlY3Rpb25zQ2xlYXI/OiAoKSA9PiB2b2lkO1xuICBkcmlsbGRvd25TZWxlY3Rpb25zU2xpY2U/OiAoZXZlbnQ6IHtcbiAgICBpOiBBcmd1bWVudHM8RHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wc1ByZWFjdFsnc2xpY2VEcmlsbGRvd25TZWxlY3Rpb25zJ10+WzBdO1xuICB9KSA9PiB2b2lkO1xufVxuXG4vKipcbiAqIERyaWxsZG93biBCcmVhZGNydW1icyBDb21wb25lbnRcbiAqXG4gKiBAZ3JvdXAgRHJpbGxkb3duXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2NzZGstZHJpbGxkb3duLWJyZWFkY3J1bWJzJyxcbiAgdGVtcGxhdGUsXG4gIHN0eWxlcyxcbn0pXG5leHBvcnQgY2xhc3MgRHJpbGxkb3duQnJlYWRjcnVtYnNDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkNoYW5nZXMsIE9uRGVzdHJveSB7XG4gIC8qKlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIEBWaWV3Q2hpbGQocm9vdElkKVxuICBwcmVhY3RSZWYhOiBFbGVtZW50UmVmPEhUTUxEaXZFbGVtZW50PjtcblxuICAvKipcbiAgICoge0Bpbmhlcml0RG9jIEBzaXNlbnNlL3Nkay11aSFEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzLmZpbHRlcnNEaXNwbGF5VmFsdWVzfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgV2lkZ2V0XG4gICAqL1xuICBASW5wdXQoKVxuICBmaWx0ZXJzRGlzcGxheVZhbHVlcyE6IERyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHNbJ2ZpbHRlcnNEaXNwbGF5VmFsdWVzJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhRHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wcy5jdXJyZW50RGltZW5zaW9ufVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgV2lkZ2V0XG4gICAqL1xuICBASW5wdXQoKVxuICBjdXJyZW50RGltZW5zaW9uITogRHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wc1snY3VycmVudERpbWVuc2lvbiddO1xuXG4gIC8qKlxuICAgKiB7QGluaGVyaXREb2MgQHNpc2Vuc2Uvc2RrLXVpIURyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHMuY2xlYXJEcmlsbGRvd25TZWxlY3Rpb25zfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgV2lkZ2V0XG4gICAqL1xuICBAT3V0cHV0KClcbiAgZHJpbGxkb3duU2VsZWN0aW9uc0NsZWFyID0gbmV3IEV2ZW50RW1pdHRlcjxcbiAgICBBcmd1bWVudHNBc09iamVjdDxEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzUHJlYWN0WydjbGVhckRyaWxsZG93blNlbGVjdGlvbnMnXSwgW10+XG4gID4oKTtcblxuICAvKipcbiAgICoge0Bpbmhlcml0RG9jIEBzaXNlbnNlL3Nkay11aSFEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzLnNsaWNlRHJpbGxkb3duU2VsZWN0aW9uc31cbiAgICpcbiAgICogQGNhdGVnb3J5IFdpZGdldFxuICAgKi9cbiAgQE91dHB1dCgpXG4gIGRyaWxsZG93blNlbGVjdGlvbnNTbGljZSA9IG5ldyBFdmVudEVtaXR0ZXI8XG4gICAgQXJndW1lbnRzPERyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHNQcmVhY3RbJ3NsaWNlRHJpbGxkb3duU2VsZWN0aW9ucyddPlswXVxuICA+KCk7XG5cbiAgcHJpdmF0ZSBjb21wb25lbnRBZGFwdGVyOiBDb21wb25lbnRBZGFwdGVyPHR5cGVvZiBEcmlsbGRvd25CcmVhZGNydW1ic1ByZWFjdD47XG5cbiAgLyoqXG4gICAqIENvbnN0cnVjdG9yIGZvciB0aGUgYERyaWxsZG93bkJyZWFkY3J1bWJzQ29tcG9uZW50YC5cbiAgICpcbiAgICogQHBhcmFtIHNpc2Vuc2VDb250ZXh0U2VydmljZSAtIFNpc2Vuc2UgY29udGV4dCBzZXJ2aWNlXG4gICAqIEBwYXJhbSB0aGVtZVNlcnZpY2UgLSBUaGVtZSBzZXJ2aWNlXG4gICAqL1xuICBjb25zdHJ1Y3RvcihcbiAgICAvKipcbiAgICAgKiBTaXNlbnNlIGNvbnRleHQgc2VydmljZVxuICAgICAqXG4gICAgICogQGNhdGVnb3J5IENvbnN0cnVjdG9yXG4gICAgICovXG4gICAgcHVibGljIHNpc2Vuc2VDb250ZXh0U2VydmljZTogU2lzZW5zZUNvbnRleHRTZXJ2aWNlLFxuICAgIC8qKlxuICAgICAqIFRoZW1lIHNlcnZpY2VcbiAgICAgKlxuICAgICAqIEBjYXRlZ29yeSBDb25zdHJ1Y3RvclxuICAgICAqL1xuICAgIHB1YmxpYyB0aGVtZVNlcnZpY2U6IFRoZW1lU2VydmljZSxcbiAgKSB7XG4gICAgdGhpcy5jb21wb25lbnRBZGFwdGVyID0gbmV3IENvbXBvbmVudEFkYXB0ZXIoRHJpbGxkb3duQnJlYWRjcnVtYnNQcmVhY3QsIFtcbiAgICAgIGNyZWF0ZVNpc2Vuc2VDb250ZXh0Q29ubmVjdG9yKHRoaXMuc2lzZW5zZUNvbnRleHRTZXJ2aWNlKSxcbiAgICAgIGNyZWF0ZVRoZW1lQ29udGV4dENvbm5lY3Rvcih0aGlzLnRoZW1lU2VydmljZSksXG4gICAgXSk7XG4gIH1cblxuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5jb21wb25lbnRBZGFwdGVyLnJlbmRlcih0aGlzLnByZWFjdFJlZi5uYXRpdmVFbGVtZW50LCB0aGlzLmdldFByZWFjdENvbXBvbmVudFByb3BzKCkpO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgbmdPbkNoYW5nZXMoKSB7XG4gICAgaWYgKHRoaXMucHJlYWN0UmVmKSB7XG4gICAgICB0aGlzLmNvbXBvbmVudEFkYXB0ZXIucmVuZGVyKHRoaXMucHJlYWN0UmVmLm5hdGl2ZUVsZW1lbnQsIHRoaXMuZ2V0UHJlYWN0Q29tcG9uZW50UHJvcHMoKSk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBnZXRQcmVhY3RDb21wb25lbnRQcm9wcygpOiBEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzUHJlYWN0IHtcbiAgICByZXR1cm4ge1xuICAgICAgZmlsdGVyc0Rpc3BsYXlWYWx1ZXM6IHRoaXMuZmlsdGVyc0Rpc3BsYXlWYWx1ZXMsXG4gICAgICBjdXJyZW50RGltZW5zaW9uOiB0aGlzLmN1cnJlbnREaW1lbnNpb24sXG4gICAgICBjbGVhckRyaWxsZG93blNlbGVjdGlvbnM6ICgpID0+IHRoaXMuZHJpbGxkb3duU2VsZWN0aW9uc0NsZWFyLmVtaXQoKSxcbiAgICAgIHNsaWNlRHJpbGxkb3duU2VsZWN0aW9uczogKFxuICAgICAgICBpOiBBcmd1bWVudHM8RHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wc1snc2xpY2VEcmlsbGRvd25TZWxlY3Rpb25zJ10+WzBdLFxuICAgICAgKSA9PiB0aGlzLmRyaWxsZG93blNlbGVjdGlvbnNTbGljZS5lbWl0KGkpLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmNvbXBvbmVudEFkYXB0ZXIuZGVzdHJveSgpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ComponentAdapter, CriteriaFilterTile as CriteriaFilterTilePreact, } from '@sisense/sdk-ui-preact';
|
|
3
|
-
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
-
import { rootId, template } from '../../component-wrapper-helpers/template';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "../../services/sisense-context.service";
|
|
7
6
|
import * as i2 from "../../services/theme.service";
|
|
@@ -104,13 +103,10 @@ export class CriteriaFilterTileComponent {
|
|
|
104
103
|
}
|
|
105
104
|
}
|
|
106
105
|
CriteriaFilterTileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CriteriaFilterTileComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
107
|
-
CriteriaFilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CriteriaFilterTileComponent, selector: "csdk-criteria-filter-tile", inputs: { title: "title", filter: "filter", arrangement: "arrangement", measures: "measures", tileDesignOptions: "tileDesignOptions" }, outputs: { filterChange: "filterChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact
|
|
106
|
+
CriteriaFilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CriteriaFilterTileComponent, selector: "csdk-criteria-filter-tile", inputs: { title: "title", filter: "filter", arrangement: "arrangement", measures: "measures", tileDesignOptions: "tileDesignOptions" }, outputs: { filterChange: "filterChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
|
|
108
107
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CriteriaFilterTileComponent, decorators: [{
|
|
109
108
|
type: Component,
|
|
110
|
-
args: [{
|
|
111
|
-
selector: 'csdk-criteria-filter-tile',
|
|
112
|
-
template,
|
|
113
|
-
}]
|
|
109
|
+
args: [{ selector: 'csdk-criteria-filter-tile', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
|
|
114
110
|
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
115
111
|
type: ViewChild,
|
|
116
112
|
args: [rootId]
|
|
@@ -127,4 +123,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
127
123
|
}], filterChange: [{
|
|
128
124
|
type: Output
|
|
129
125
|
}] } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"criteria-filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/criteria-filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,kBAAkB,IAAI,wBAAwB,GAE/C,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;;AAYzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAmCG;AAMH,MAAM,OAAO,2BAA2B;IA6CtC;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QA5BnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAE5B,CAAC;QAwBF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,wBAAwB,EAAE;YACrE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAAuD,EAAE,EAAE,CAC9E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;SACrC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;yHAxGU,2BAA2B;6GAA3B,2BAA2B;4FAA3B,2BAA2B;kBALvC,SAAS;+BACE,2BAA2B,YACrC,QAAQ;uIAQR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,WAAW;sBADV,KAAK;gBAON,QAAQ;sBADP,KAAK;gBAKN,iBAAiB;sBADhB,KAAK;gBAON,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  CriteriaFilterTile as CriteriaFilterTilePreact,\n  type CriteriaFilterTileProps as CriteriaFilterTilePropsPreact,\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 type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\n\n/**\n * Props of the {@link CriteriaFilterTileComponent}.\n */\nexport interface CriteriaFilterTileProps extends Omit<CriteriaFilterTilePropsPreact, 'onUpdate'> {\n  filterChange?: (filter: Arguments<CriteriaFilterTilePropsPreact['onUpdate']>[0]) => void;\n}\n\n/**\n * Criteria Filter Tile Component\n *\n * @example\n * ```html\n *     <csdk-criteria-filter-tile\n *       [title]=\"criteriaFilterTileProps.title\"\n *       [filter]=\"criteriaFilterTileProps.filter\"\n *       (filterChange)=\"criteriaFilterTileProps.setFilter($event)\"\n *     />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { Filter, filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-filters',\n *   templateUrl: './filters.component.html',\n *   styleUrls: ['./filters.component.scss'],\n * })\n * export class FiltersComponent {\n *   DM = DM;\n *   title: 'Room Number',\n *   filter: filterFactory.lessThan(DM.Rooms.Room_number, 200) ,\n *   setFilter({ filter }: { filter: Filter | null }) {\n *     console.log(filter);\n *     if (filter) {\n *       this.filter = filter ;\n *     }\n *   },\n * }\n * ```\n * <img src=\"media://angular-criteria-filter-tile-example.png\" width=\"400px\" />\n * @group Filter Tiles\n */\n@Component({\n  selector: 'csdk-criteria-filter-tile',\n  template,\n  styles,\n})\nexport class CriteriaFilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!CriteriaFilterTileProps.title}\n   */\n  @Input()\n  title!: CriteriaFilterTileProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!CriteriaFilterTileProps.filter}\n   */\n  @Input()\n  filter!: CriteriaFilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!CriteriaFilterTileProps.arrangement}\n   */\n  @Input()\n  arrangement: CriteriaFilterTileProps['arrangement'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!CriteriaFilterTileProps.measures}\n   */\n  @Input()\n  measures: CriteriaFilterTileProps['measures'];\n\n  /** @internal */\n  @Input()\n  tileDesignOptions: CriteriaFilterTileProps['tileDesignOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!CriteriaFilterTileProps.onUpdate}\n   */\n  @Output()\n  filterChange = new EventEmitter<\n    ArgumentsAsObject<CriteriaFilterTilePropsPreact['onUpdate'], ['filter']>\n  >();\n\n  private componentAdapter: ComponentAdapter<typeof CriteriaFilterTilePreact>;\n\n  /**\n   * Constructor for the `CriteriaFilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(CriteriaFilterTilePreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): CriteriaFilterTilePropsPreact {\n    return {\n      title: this.title,\n      filter: this.filter,\n      arrangement: this.arrangement,\n      measures: this.measures,\n      tileDesignOptions: this.tileDesignOptions,\n      onUpdate: (...[filter]: Arguments<CriteriaFilterTilePropsPreact['onUpdate']>) =>\n        this.filterChange.emit({ filter }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ComponentAdapter, DateRangeFilterTile as DateRangeFilterTilePreact, } from '@sisense/sdk-ui-preact';
|
|
3
|
-
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
-
import { rootId, template } from '../../component-wrapper-helpers/template';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "../../services/sisense-context.service";
|
|
7
6
|
import * as i2 from "../../services/theme.service";
|
|
@@ -110,13 +109,10 @@ export class DateRangeFilterTileComponent {
|
|
|
110
109
|
}
|
|
111
110
|
}
|
|
112
111
|
DateRangeFilterTileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateRangeFilterTileComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
113
|
-
DateRangeFilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateRangeFilterTileComponent, selector: "csdk-date-range-filter-tile", inputs: { title: "title", attribute: "attribute", dataSource: "dataSource", filter: "filter", earliestDate: "earliestDate", lastDate: "lastDate" }, outputs: { filterChange: "filterChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact
|
|
112
|
+
DateRangeFilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateRangeFilterTileComponent, selector: "csdk-date-range-filter-tile", inputs: { title: "title", attribute: "attribute", dataSource: "dataSource", filter: "filter", earliestDate: "earliestDate", lastDate: "lastDate" }, outputs: { filterChange: "filterChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
|
|
114
113
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateRangeFilterTileComponent, decorators: [{
|
|
115
114
|
type: Component,
|
|
116
|
-
args: [{
|
|
117
|
-
selector: 'csdk-date-range-filter-tile',
|
|
118
|
-
template,
|
|
119
|
-
}]
|
|
115
|
+
args: [{ selector: 'csdk-date-range-filter-tile', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
|
|
120
116
|
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
121
117
|
type: ViewChild,
|
|
122
118
|
args: [rootId]
|
|
@@ -135,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
135
131
|
}], filterChange: [{
|
|
136
132
|
type: Output
|
|
137
133
|
}] } });
|
|
138
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range-filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/date-range-filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,mBAAmB,IAAI,yBAAyB,GAEjD,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;;AAYzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAMH,MAAM,OAAO,4BAA4B;IAqDvC;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QA5BnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAE5B,CAAC;QAwBF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,yBAAyB,EAAE;YACtE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,QAAQ,EAAE,IAAI,CAAC,QAAQ;YACvB,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAAwD,EAAE,EAAE,CAC/E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;SACrC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;0HAjHU,4BAA4B;8GAA5B,4BAA4B;4FAA5B,4BAA4B;kBALxC,SAAS;+BACE,6BAA6B,YACvC,QAAQ;uIAQR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,SAAS;sBADR,KAAK;gBAON,UAAU;sBADT,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,YAAY;sBADX,KAAK;gBAON,QAAQ;sBADP,KAAK;gBAON,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  DateRangeFilterTile as DateRangeFilterTilePreact,\n  type DateRangeFilterTileProps as DateRangeFilterTilePropsPreact,\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 type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\n\n/**\n * Props of the {@link DateRangeFilterTileComponent}.\n */\nexport interface DateRangeFilterTileProps extends Omit<DateRangeFilterTilePropsPreact, 'onChange'> {\n  filterChange?: (filter: Arguments<DateRangeFilterTilePropsPreact['onChange']>[0]) => void;\n}\n\n/**\n * Date Range Filter Tile Component\n *\n * @example\n * ```html\n * <csdk-date-range-filter-tile\n *       [title]=\"dateRangeFilterTileProps.title\"\n *       [attribute]=\"dateRangeFilterTileProps.attribute\"\n *       [filter]=\"dateRangeFilterTileProps.filter\"\n *       (filterChange)=\"dateRangeFilterTileProps.setFilter($event)\"\n *     />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { Filter, filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-filters',\n *   templateUrl: './filters.component.html',\n *   styleUrls: ['./filters.component.scss'],\n * })\n * export class FiltersComponent {\n *   DM = DM;\n\n *   dateRangeFilterTileProps = {\n *     title: 'Range Filter',\n *     attribute: DM.ER.Date.Years,\n *     filter: filterFactory.dateRange(DM.ER.Date.Years),\n *     setFilter({ filter }: { filter: Filter | null }) {\n *       console.log(filter);\n *       if (filter) {\n *         this.filter = filter;\n *       }\n *     },\n *   };\n * }\n * ```\n * <img src=\"media://angular-date-range-filter-tile-example.png\" width=\"600px\" />\n * @group Filter Tiles\n */\n@Component({\n  selector: 'csdk-date-range-filter-tile',\n  template,\n  styles,\n})\nexport class DateRangeFilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DateRangeFilterTileProps.title}\n   */\n  @Input()\n  title!: DateRangeFilterTileProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DateRangeFilterTileProps.attribute}\n   */\n  @Input()\n  attribute!: DateRangeFilterTileProps['attribute'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DateRangeFilterTileProps.dataSource}\n   */\n  @Input()\n  dataSource: DateRangeFilterTileProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DateRangeFilterTileProps.filter}\n   */\n  @Input()\n  filter!: DateRangeFilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DateRangeFilterTileProps.earliestDate}\n   */\n  @Input()\n  earliestDate: DateRangeFilterTileProps['earliestDate'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DateRangeFilterTileProps.lastDate}\n   */\n  @Input()\n  lastDate: DateRangeFilterTileProps['lastDate'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DateRangeFilterTileProps.onChange}\n   */\n  @Output()\n  filterChange = new EventEmitter<\n    ArgumentsAsObject<DateRangeFilterTilePropsPreact['onChange'], ['filter']>\n  >();\n\n  private componentAdapter: ComponentAdapter<typeof DateRangeFilterTilePreact>;\n\n  /**\n   * Constructor for the `DateRangeFilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(DateRangeFilterTilePreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): DateRangeFilterTilePropsPreact {\n    return {\n      title: this.title,\n      attribute: this.attribute,\n      dataSource: this.dataSource,\n      filter: this.filter,\n      earliestDate: this.earliestDate,\n      lastDate: this.lastDate,\n      onChange: (...[filter]: Arguments<DateRangeFilterTilePropsPreact['onChange']>) =>\n        this.filterChange.emit({ filter }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ComponentAdapter, FilterTile as FilterTilePreact, } from '@sisense/sdk-ui-preact';
|
|
3
|
-
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
-
import { rootId, template } from '../../component-wrapper-helpers/template';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
|
|
5
4
|
import { EventEmitterWithHasListeners } from '../../helpers';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "../../services/sisense-context.service";
|
|
@@ -123,13 +122,10 @@ export class FilterTileComponent {
|
|
|
123
122
|
}
|
|
124
123
|
}
|
|
125
124
|
FilterTileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FilterTileComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
126
|
-
FilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: FilterTileComponent, selector: "csdk-filter-tile", inputs: { filter: "filter", defaultDataSource: "defaultDataSource" }, outputs: { filterChange: "filterChange", filterEdit: "filterEdit", filterDelete: "filterDelete" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact
|
|
125
|
+
FilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: FilterTileComponent, selector: "csdk-filter-tile", inputs: { filter: "filter", defaultDataSource: "defaultDataSource" }, outputs: { filterChange: "filterChange", filterEdit: "filterEdit", filterDelete: "filterDelete" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
|
|
127
126
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: FilterTileComponent, decorators: [{
|
|
128
127
|
type: Component,
|
|
129
|
-
args: [{
|
|
130
|
-
selector: 'csdk-filter-tile',
|
|
131
|
-
template,
|
|
132
|
-
}]
|
|
128
|
+
args: [{ selector: 'csdk-filter-tile', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
|
|
133
129
|
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
134
130
|
type: ViewChild,
|
|
135
131
|
args: [rootId]
|
|
@@ -144,4 +140,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
144
140
|
}], filterDelete: [{
|
|
145
141
|
type: Output
|
|
146
142
|
}] } });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,UAAU,IAAI,gBAAgB,GAE/B,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,4BAA4B,EAAE,MAAM,eAAe,CAAC;;;;AAiB7D;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAMH,MAAM,OAAO,mBAAmB;IAuC9B;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QAtCnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAAqB,CAAC;QAErD;;WAEG;QAEH,eAAU,GAAkC,IAAI,4BAA4B,EAAmB,CAAC;QAEhG;;WAEG;QAEH,iBAAY,GAAuB,IAAI,4BAA4B,EAAE,CAAC;QAwBpE,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;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,MAAM,sBAAsB,GAAI,IAAI,CAAC,UAAoD;aACtF,YAAY,CAAC;QAChB,MAAM,wBAAwB,GAAI,IAAI,CAAC,YAAsD;aAC1F,YAAY,CAAC;QAEhB,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,iBAAiB,EAAE,IAAI,CAAC,iBAAiB;YACzC,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAA+C,EAAE,EAAE,CACtE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;YACpC,GAAG,CAAC,sBAAsB,IAAI;gBAC5B,MAAM,EAAE,CAAC,GAAG,CAAC,UAAU,CAA6C,EAAE,EAAE,CACtE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,CAAC;aACvC,CAAC;YACF,GAAG,CAAC,wBAAwB,IAAI,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC;SAC9E,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;iHAzGU,mBAAmB;qGAAnB,mBAAmB;4FAAnB,mBAAmB;kBAL/B,SAAS;+BACE,kBAAkB,YAC5B,QAAQ;uIAQR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,MAAM;sBADL,KAAK;gBAON,iBAAiB;sBADhB,KAAK;gBAON,YAAY;sBADX,MAAM;gBAOP,UAAU;sBADT,MAAM;gBAOP,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  FilterTile as FilterTilePreact,\n  type FilterTileProps as FilterTilePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { EventEmitterWithHasListeners } from '../../helpers';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type {\n  Arguments,\n  BaseFilterTileEventProps,\n  FilterChangeEvent,\n  FilterEditEvent,\n} from '../../types';\n\n/**\n * Props of the {@link FilterTileComponent}.\n */\nexport interface FilterTileProps\n  extends Omit<FilterTilePropsPreact, 'onChange' | 'onEdit' | 'onDelete'>,\n    BaseFilterTileEventProps {}\n\n/**\n * UI component that renders a filter tile based on filter type\n *\n * @example\n * Here’s how to render a filter model as a filter tile.\n *\n * ```html\n<!--Component HTML template in example.component.html-->\n<csdk-filter-tile\n  [filter]=\"filterTileProps.filter\"\n  (filterChange)=\"filterTileProps.filterChange($event)\"\n/>\n * ```\n *\n * ```ts\n// Component behavior in example.component.ts\nimport { Component } from '@angular/core';\nimport { type FilterTileProps } from '@sisense/sdk-ui-angular';\nimport { filterFactory } from '@sisense/sdk-data';\nimport * as DM from '../../assets/sample-healthcare-model';\n\n@Component({\n  selector: 'example',\n  templateUrl: './example.component.html',\n  styleUrls: ['./example.component.scss'],\n})\nexport class ExampleComponent {\n  filterTileProps: FilterTileProps = {\n    filter: filterFactory.members(DM.ER.Date.Years, ['2013-01-01T00:00:00']),\n    filterChange({ filter }) {\n      if (filter) {\n        this.filter = filter;\n      }\n    },\n  };\n}\n * ```\n * <img src=\"media://angular-member-filter-tile-example.png\" width=\"225px\" />\n * @group Filter Tiles\n * @shortDescription Facade component rendering a filter tile based on filter type\n */\n@Component({\n  selector: 'csdk-filter-tile',\n  template,\n  styles,\n})\nexport class FilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!FilterTileProps.filter}\n   */\n  @Input()\n  filter!: FilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!FilterTileProps.defaultDataSource}\n   */\n  @Input()\n  defaultDataSource: FilterTileProps['defaultDataSource'];\n\n  /**\n   * {@inheritDoc FilterTileProps.filterChange}\n   */\n  @Output()\n  filterChange = new EventEmitter<FilterChangeEvent>();\n\n  /**\n   * {@inheritDoc FilterTileProps.filterEdit}\n   */\n  @Output()\n  filterEdit: EventEmitter<FilterEditEvent> = new EventEmitterWithHasListeners<FilterEditEvent>();\n\n  /**\n   * {@inheritDoc FilterTileProps.filterDelete}\n   */\n  @Output()\n  filterDelete: EventEmitter<void> = new EventEmitterWithHasListeners();\n\n  private componentAdapter: ComponentAdapter<typeof FilterTilePreact>;\n\n  /**\n   * Constructor for the `FilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(FilterTilePreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): FilterTilePropsPreact {\n    const hasFilterEditListeners = (this.filterEdit as EventEmitterWithHasListeners<unknown>)\n      .hasListeners;\n    const hasFilterDeleteListeners = (this.filterDelete as EventEmitterWithHasListeners<unknown>)\n      .hasListeners;\n\n    return {\n      filter: this.filter,\n      defaultDataSource: this.defaultDataSource,\n      onChange: (...[filter]: Arguments<FilterTilePropsPreact['onChange']>) =>\n        this.filterChange.emit({ filter }),\n      ...(hasFilterEditListeners && {\n        onEdit: (...[levelIndex]: Arguments<FilterTilePropsPreact['onEdit']>) =>\n          this.filterEdit.emit({ levelIndex }),\n      }),\n      ...(hasFilterDeleteListeners && { onDelete: () => this.filterDelete.emit() }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ComponentAdapter, MemberFilterTile as MemberFilterTilePreact, } from '@sisense/sdk-ui-preact';
|
|
3
|
-
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
-
import { rootId, template } from '../../component-wrapper-helpers/template';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "../../services/sisense-context.service";
|
|
7
6
|
import * as i2 from "../../services/theme.service";
|
|
@@ -104,13 +103,10 @@ export class MemberFilterTileComponent {
|
|
|
104
103
|
}
|
|
105
104
|
}
|
|
106
105
|
MemberFilterTileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MemberFilterTileComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
107
|
-
MemberFilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MemberFilterTileComponent, selector: "csdk-member-filter-tile", inputs: { title: "title", dataSource: "dataSource", attribute: "attribute", filter: "filter" }, outputs: { filterChange: "filterChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact
|
|
106
|
+
MemberFilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MemberFilterTileComponent, selector: "csdk-member-filter-tile", inputs: { title: "title", dataSource: "dataSource", attribute: "attribute", filter: "filter" }, outputs: { filterChange: "filterChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
|
|
108
107
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MemberFilterTileComponent, decorators: [{
|
|
109
108
|
type: Component,
|
|
110
|
-
args: [{
|
|
111
|
-
selector: 'csdk-member-filter-tile',
|
|
112
|
-
template,
|
|
113
|
-
}]
|
|
109
|
+
args: [{ selector: 'csdk-member-filter-tile', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
|
|
114
110
|
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
115
111
|
type: ViewChild,
|
|
116
112
|
args: [rootId]
|
|
@@ -125,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
125
121
|
}], filterChange: [{
|
|
126
122
|
type: Output
|
|
127
123
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"member-filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/member-filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,gBAAgB,IAAI,sBAAsB,GAE3C,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;;AAYzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoCG;AAMH,MAAM,OAAO,yBAAyB;IAyCpC;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QA5BnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAE5B,CAAC;QAwBF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,sBAAsB,EAAE;YACnE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAAqD,EAAE,EAAE,CAC5E,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;SACrC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;uHAnGU,yBAAyB;2GAAzB,yBAAyB;4FAAzB,yBAAyB;kBALrC,SAAS;+BACE,yBAAyB,YACnC,QAAQ;uIAQR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,UAAU;sBADT,KAAK;gBAON,SAAS;sBADR,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  MemberFilterTile as MemberFilterTilePreact,\n  type MemberFilterTileProps as MemberFilterTilePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\n\n/**\n * Props of the {@link MemberFilterTileComponent}.\n */\nexport interface MemberFilterTileProps extends Omit<MemberFilterTilePropsPreact, 'onChange'> {\n  filterChange?: (filter: Arguments<MemberFilterTilePropsPreact['onChange']>[0]) => void;\n}\n\n/**\n * Member Filter Tile Component\n *\n * @example\n * ```html\n *     <csdk-member-filter-tile\n *       title=\"Years Filter\"\n *       [attribute]=\"DM.ER.Date.Years\"\n *       [filter]=\"memberFilterTileProps.yearFilter\"\n *       (filterChange)=\"memberFilterTileProps.setYearFilter($event)\"\n *     />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { Filter, filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-filters',\n *   templateUrl: './filters.component.html',\n *   styleUrls: ['./filters.component.scss'],\n * })\n * export class FiltersComponent {\n *   DM = DM;\n *   memberFilterTileProps = {\n *     yearFilter: filterFactory.members(DM.ER.Date.Years, ['2013-01-01T00:00:00']),\n *     setYearFilter({ filter }: { filter: Filter | null }) {\n *       if (filter) {\n *         this.yearFilter = filter;\n *       }\n *     },\n *   };\n * }\n * ```\n * <img src=\"media://angular-member-filter-tile-example.png\" width=\"225px\" />\n * @group Filter Tiles\n */\n@Component({\n  selector: 'csdk-member-filter-tile',\n  template,\n  styles,\n})\nexport class MemberFilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.title}\n   */\n  @Input()\n  title!: MemberFilterTileProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.dataSource}\n   */\n  @Input()\n  dataSource: MemberFilterTileProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.attribute}\n   */\n  @Input()\n  attribute!: MemberFilterTileProps['attribute'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.filter}\n   */\n  @Input()\n  filter!: MemberFilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!MemberFilterTileProps.onChange}\n   */\n  @Output()\n  filterChange = new EventEmitter<\n    ArgumentsAsObject<MemberFilterTilePropsPreact['onChange'], ['filter']>\n  >();\n\n  private componentAdapter: ComponentAdapter<typeof MemberFilterTilePreact>;\n\n  /**\n   * Constructor for the `MemberFilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(MemberFilterTilePreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): MemberFilterTilePropsPreact {\n    return {\n      title: this.title,\n      dataSource: this.dataSource,\n      attribute: this.attribute,\n      filter: this.filter,\n      onChange: (...[filter]: Arguments<MemberFilterTilePropsPreact['onChange']>) =>\n        this.filterChange.emit({ filter }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ComponentAdapter, RelativeDateFilterTile as RelativeDateFilterTilePreact, } from '@sisense/sdk-ui-preact';
|
|
3
|
-
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
-
import { rootId, template } from '../../component-wrapper-helpers/template';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "../../services/sisense-context.service";
|
|
7
6
|
import * as i2 from "../../services/theme.service";
|
|
@@ -108,13 +107,10 @@ export class RelativeDateFilterTileComponent {
|
|
|
108
107
|
}
|
|
109
108
|
}
|
|
110
109
|
RelativeDateFilterTileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RelativeDateFilterTileComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
111
|
-
RelativeDateFilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: RelativeDateFilterTileComponent, selector: "csdk-relative-date-filter-tile", inputs: { title: "title", filter: "filter", arrangement: "arrangement", limit: "limit" }, outputs: { filterChange: "filterChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact
|
|
110
|
+
RelativeDateFilterTileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: RelativeDateFilterTileComponent, selector: "csdk-relative-date-filter-tile", inputs: { title: "title", filter: "filter", arrangement: "arrangement", limit: "limit" }, outputs: { filterChange: "filterChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact class=\"csdk-full-size-container\"></div>\n", isInline: true, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] });
|
|
112
111
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: RelativeDateFilterTileComponent, decorators: [{
|
|
113
112
|
type: Component,
|
|
114
|
-
args: [{
|
|
115
|
-
selector: 'csdk-relative-date-filter-tile',
|
|
116
|
-
template,
|
|
117
|
-
}]
|
|
113
|
+
args: [{ selector: 'csdk-relative-date-filter-tile', template: template, styles: [".csdk-full-size-container{width:100%;height:100%}\n"] }]
|
|
118
114
|
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
119
115
|
type: ViewChild,
|
|
120
116
|
args: [rootId]
|
|
@@ -129,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
129
125
|
}], filterChange: [{
|
|
130
126
|
type: Output
|
|
131
127
|
}] } });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
128
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relative-date-filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/relative-date-filter-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EACN,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,gBAAgB,EAChB,sBAAsB,IAAI,4BAA4B,GAEvD,MAAM,wBAAwB,CAAC;AAEhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,MAAM,EACN,MAAM,EACN,QAAQ,GACT,MAAM,iCAAiC,CAAC;;;;AAazC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCG;AAMH,MAAM,OAAO,+BAA+B;IAyC1C;;;;;OAKG;IACH;IACE;;;;OAIG;IACI,qBAA4C;IACnD;;;;OAIG;IACI,YAA0B;QAN1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAM5C,iBAAY,GAAZ,YAAY,CAAc;QA5BnC;;WAEG;QAEH,iBAAY,GAAG,IAAI,YAAY,EAE5B,CAAC;QAwBF,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,4BAA4B,EAAE;YACzE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;IAC7F,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,EAAE,IAAI,CAAC,uBAAuB,EAAE,CAAC,CAAC;SAC5F;IACH,CAAC;IAEO,uBAAuB;QAC7B,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,QAAQ,EAAE,CAAC,GAAG,CAAC,MAAM,CAA2D,EAAE,EAAE,CAClF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;SACrC,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;6HAnGU,+BAA+B;iHAA/B,+BAA+B;4FAA/B,+BAA+B;kBAL3C,SAAS;+BACE,gCAAgC,YAC1C,QAAQ;uIAQR,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAOjB,KAAK;sBADJ,KAAK;gBAON,MAAM;sBADL,KAAK;gBAON,WAAW;sBADV,KAAK;gBAON,KAAK;sBADJ,KAAK;gBAON,YAAY;sBADX,MAAM","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  RelativeDateFilterTile as RelativeDateFilterTilePreact,\n  type RelativeDateFilterTileProps as RelativeDateFilterTilePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\n\n/**\n * Props of the {@link RelativeDateFilterTileComponent}.\n */\nexport interface RelativeDateFilterTileProps\n  extends Omit<RelativeDateFilterTilePropsPreact, 'onUpdate'> {\n  filterChange?: (filter: Arguments<RelativeDateFilterTilePropsPreact['onUpdate']>[0]) => void;\n}\n\n/**\n * Relative Date Filter Tile Component\n *\n * @example\n * ```html\n * <csdk-relative-date-filter-tile\n *       [title]=\"relativeDateFilterTileProps.title\"\n *       [arrangement]=\"relativeDateFilterTileProps.arrangement\"\n *       [filter]=\"relativeDateFilterTileProps.filter\"\n *       (filterChange)=\"relativeDateFilterTileProps.setFilter($event)\"\n *     />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { Filter, filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-filters',\n *   templateUrl: './filters.component.html',\n *   styleUrls: ['./filters.component.scss'],\n * })\n * export class FiltersComponent {\n *   DM = DM;\n *\n *   relativeDateFilterTileProps = {\n *     title: 'Relative Date Filter',\n *     arrangement: 'vertical',\n *     filter: filterFactory.dateRelativeTo(DM.ER.Date.Days, 0, 150),\n *     setFilter({ filter }: { filter: Filter | null }) {\n *       console.log(filter);\n *       if (filter) {\n *         this.filter = filter;\n *       }\n *     },\n *   };\n * }\n * ```\n * <img src=\"media://angular-relative-date-filter-tile-example.png\" width=\"600px\" />\n * @group Filter Tiles\n */\n@Component({\n  selector: 'csdk-relative-date-filter-tile',\n  template,\n  styles,\n})\nexport class RelativeDateFilterTileComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.title}\n   */\n  @Input()\n  title!: RelativeDateFilterTileProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.filter}\n   */\n  @Input()\n  filter!: RelativeDateFilterTileProps['filter'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.arrangement}\n   */\n  @Input()\n  arrangement: RelativeDateFilterTileProps['arrangement'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.limit}\n   */\n  @Input()\n  limit: RelativeDateFilterTileProps['limit'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!RelativeDateFilterTileProps.onUpdate}\n   */\n  @Output()\n  filterChange = new EventEmitter<\n    ArgumentsAsObject<RelativeDateFilterTilePropsPreact['onUpdate'], ['filter']>\n  >();\n\n  private componentAdapter: ComponentAdapter<typeof RelativeDateFilterTilePreact>;\n\n  /**\n   * Constructor for the `RelativeDateFilterTileComponent`.\n   *\n   * @param sisenseContextService - Sisense context service\n   * @param themeService - Theme service\n   */\n  constructor(\n    /**\n     * Sisense context service\n     *\n     * @category Constructor\n     */\n    public sisenseContextService: SisenseContextService,\n    /**\n     * Theme service\n     *\n     * @category Constructor\n     */\n    public themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(RelativeDateFilterTilePreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): RelativeDateFilterTilePropsPreact {\n    return {\n      title: this.title,\n      filter: this.filter,\n      arrangement: this.arrangement,\n      limit: this.limit,\n      onUpdate: (...[filter]: Arguments<RelativeDateFilterTilePropsPreact['onUpdate']>) =>\n        this.filterChange.emit({ filter }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|