@sisense/sdk-ui-angular 2.23.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.
- package/dist/esm2020/ai/lib/components/chatbot.component.mjs +3 -2
- package/dist/esm2020/ai/lib/components/get-nlg-insights.component.mjs +3 -2
- package/dist/esm2020/lib/component-wrapper-helpers/context-connectors.mjs +29 -2
- package/dist/esm2020/lib/components/charts/chart.component.mjs +3 -2
- package/dist/esm2020/lib/components/charts/pivot-table.component.mjs +3 -2
- package/dist/esm2020/lib/components/charts/table.component.mjs +3 -2
- package/dist/esm2020/lib/components/context-menu.component.mjs +3 -2
- package/dist/esm2020/lib/components/dashboard/dashboard-by-id.component.mjs +3 -2
- package/dist/esm2020/lib/components/dashboard/dashboard.component.mjs +3 -2
- package/dist/esm2020/lib/components/drilldown-breadcrumbs.component.mjs +3 -2
- package/dist/esm2020/lib/components/filters/criteria-filter-tile.component.mjs +3 -2
- package/dist/esm2020/lib/components/filters/date-range-filter-tile.component.mjs +3 -2
- package/dist/esm2020/lib/components/filters/filter-tile.component.mjs +3 -2
- package/dist/esm2020/lib/components/filters/member-filter-tile.component.mjs +3 -2
- package/dist/esm2020/lib/components/filters/relative-date-filter-tile.component.mjs +3 -2
- package/dist/esm2020/lib/components/widgets/chart-widget.component.mjs +3 -2
- package/dist/esm2020/lib/components/widgets/drilldown-widget.component.mjs +3 -2
- package/dist/esm2020/lib/components/widgets/pivot-table-widget.component.mjs +3 -2
- package/dist/esm2020/lib/components/widgets/table-widget.component.mjs +3 -2
- package/dist/esm2020/lib/components/widgets/widget-by-id.component.mjs +3 -2
- package/dist/esm2020/lib/components/widgets/widget.component.mjs +3 -2
- package/dist/esm2020/lib/services/dashboard.service.mjs +6 -3
- package/dist/esm2020/lib/services/filter.service.mjs +3 -2
- package/dist/esm2020/lib/services/formula.service.mjs +3 -2
- package/dist/esm2020/lib/services/query.service.mjs +4 -2
- package/dist/esm2020/lib/services/widget.service.mjs +3 -2
- package/dist/esm2020/public-api.mjs +2 -2
- package/dist/esm2020/version.mjs +2 -2
- package/dist/fesm2015/sisense-sdk-ui-angular-ai.mjs +3 -1
- package/dist/fesm2015/sisense-sdk-ui-angular-ai.mjs.map +1 -1
- package/dist/fesm2015/sisense-sdk-ui-angular.mjs +59 -4
- package/dist/fesm2015/sisense-sdk-ui-angular.mjs.map +1 -1
- package/dist/fesm2020/sisense-sdk-ui-angular-ai.mjs +3 -1
- package/dist/fesm2020/sisense-sdk-ui-angular-ai.mjs.map +1 -1
- package/dist/fesm2020/sisense-sdk-ui-angular.mjs +57 -4
- package/dist/fesm2020/sisense-sdk-ui-angular.mjs.map +1 -1
- package/dist/lib/component-wrapper-helpers/context-connectors.d.ts +8 -1
- package/dist/package.json +1 -1
- package/dist/public-api.d.ts +1 -1
- package/dist/version.d.ts +1 -1
- package/package.json +4 -4
|
@@ -1,6 +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, 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";
|
|
@@ -44,6 +44,7 @@ export class DrilldownBreadcrumbsComponent {
|
|
|
44
44
|
*/
|
|
45
45
|
this.drilldownSelectionsSlice = new EventEmitter();
|
|
46
46
|
this.componentAdapter = new ComponentAdapter(DrilldownBreadcrumbsPreact, [
|
|
47
|
+
createPluginContextConnector(this.sisenseContextService),
|
|
47
48
|
createSisenseContextConnector(this.sisenseContextService),
|
|
48
49
|
createThemeContextConnector(this.themeService),
|
|
49
50
|
]);
|
|
@@ -94,4 +95,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
94
95
|
}], drilldownSelectionsSlice: [{
|
|
95
96
|
type: Output
|
|
96
97
|
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
98
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJpbGxkb3duLWJyZWFkY3J1bWJzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9kcmlsbGRvd24tYnJlYWRjcnVtYnMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxTQUFTLEVBRVQsWUFBWSxFQUNaLEtBQUssRUFHTCxNQUFNLEVBQ04sU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxnQkFBZ0IsRUFDaEIsb0JBQW9CLElBQUksMEJBQTBCLEdBRW5ELE1BQU0sd0JBQXdCLENBQUM7QUFFaEMsT0FBTyxFQUNMLDRCQUE0QixFQUM1Qiw2QkFBNkIsRUFDN0IsMkJBQTJCLEVBQzNCLE1BQU0sRUFDTixNQUFNLEVBQ04sUUFBUSxHQUNULE1BQU0sOEJBQThCLENBQUM7Ozs7QUFnQnRDOzs7O0dBSUc7QUFNSCxNQUFNLE9BQU8sNkJBQTZCO0lBNkN4Qzs7Ozs7T0FLRztJQUNIO0lBQ0U7Ozs7T0FJRztJQUNJLHFCQUE0QztJQUNuRDs7OztPQUlHO0lBQ0ksWUFBMEI7UUFOMUIsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUF1QjtRQU01QyxpQkFBWSxHQUFaLFlBQVksQ0FBYztRQXhDbkM7Ozs7V0FJRztRQUVILDZCQUF3QixHQUFHLElBQUksWUFBWSxFQUV4QyxDQUFDO1FBRUo7Ozs7V0FJRztRQUVILDZCQUF3QixHQUFHLElBQUksWUFBWSxFQUV4QyxDQUFDO1FBd0JGLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxJQUFJLGdCQUFnQixDQUFDLDBCQUEwQixFQUFFO1lBQ3ZFLDRCQUE0QixDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQztZQUN4RCw2QkFBNkIsQ0FBQyxJQUFJLENBQUMscUJBQXFCLENBQUM7WUFDekQsMkJBQTJCLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQztTQUMvQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQ7O09BRUc7SUFDSCxlQUFlO1FBQ2IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQyxDQUFDO0lBQzdGLENBQUM7SUFFRDs7T0FFRztJQUNILFdBQVc7UUFDVCxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsRUFBRSxJQUFJLENBQUMsdUJBQXVCLEVBQUUsQ0FBQyxDQUFDO1NBQzVGO0lBQ0gsQ0FBQztJQUVPLHVCQUF1QjtRQUM3QixPQUFPO1lBQ0wsb0JBQW9CLEVBQUUsSUFBSSxDQUFDLG9CQUFvQjtZQUMvQyxnQkFBZ0IsRUFBRSxJQUFJLENBQUMsZ0JBQWdCO1lBQ3ZDLHdCQUF3QixFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLEVBQUU7WUFDcEUsd0JBQXdCLEVBQUUsQ0FDeEIsQ0FBc0UsRUFDdEUsRUFBRSxDQUFDLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDO1NBQzNDLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSCxXQUFXO1FBQ1QsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQ2xDLENBQUM7OzJIQXhHVSw2QkFBNkI7K0dBQTdCLDZCQUE2Qjs0RkFBN0IsNkJBQTZCO2tCQUx6QyxTQUFTOytCQUNFLDRCQUE0QixZQUN0QyxRQUFRO3VJQVFSLFNBQVM7c0JBRFIsU0FBUzt1QkFBQyxNQUFNO2dCQVNqQixvQkFBb0I7c0JBRG5CLEtBQUs7Z0JBU04sZ0JBQWdCO3NCQURmLEtBQUs7Z0JBU04sd0JBQXdCO3NCQUR2QixNQUFNO2dCQVdQLHdCQUF3QjtzQkFEdkIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxuICBPbkRlc3Ryb3ksXG4gIE91dHB1dCxcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIENvbXBvbmVudEFkYXB0ZXIsXG4gIERyaWxsZG93bkJyZWFkY3J1bWJzIGFzIERyaWxsZG93bkJyZWFkY3J1bWJzUHJlYWN0LFxuICB0eXBlIERyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHMgYXMgRHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wc1ByZWFjdCxcbn0gZnJvbSAnQHNpc2Vuc2Uvc2RrLXVpLXByZWFjdCc7XG5cbmltcG9ydCB7XG4gIGNyZWF0ZVBsdWdpbkNvbnRleHRDb25uZWN0b3IsXG4gIGNyZWF0ZVNpc2Vuc2VDb250ZXh0Q29ubmVjdG9yLFxuICBjcmVhdGVUaGVtZUNvbnRleHRDb25uZWN0b3IsXG4gIHJvb3RJZCxcbiAgc3R5bGVzLFxuICB0ZW1wbGF0ZSxcbn0gZnJvbSAnLi4vY29tcG9uZW50LXdyYXBwZXItaGVscGVycyc7XG5pbXBvcnQgeyBTaXNlbnNlQ29udGV4dFNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9zaXNlbnNlLWNvbnRleHQuc2VydmljZSc7XG5pbXBvcnQgeyBUaGVtZVNlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy90aGVtZS5zZXJ2aWNlJztcbmltcG9ydCB0eXBlIHsgQXJndW1lbnRzLCBBcmd1bWVudHNBc09iamVjdCB9IGZyb20gJy4uL3R5cGVzL3V0aWxpdHktdHlwZXMnO1xuXG4vKipcbiAqIFByb3BzIG9mIHRoZSB7QGxpbmsgRHJpbGxkb3duQnJlYWRjcnVtYnNDb21wb25lbnR9LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHNcbiAgZXh0ZW5kcyBPbWl0PERyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHNQcmVhY3QsICdjbGVhckRyaWxsZG93blNlbGVjdGlvbnMnPiB7XG4gIGRyaWxsZG93blNlbGVjdGlvbnNDbGVhcj86ICgpID0+IHZvaWQ7XG4gIGRyaWxsZG93blNlbGVjdGlvbnNTbGljZT86IChldmVudDoge1xuICAgIGk6IEFyZ3VtZW50czxEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzUHJlYWN0WydzbGljZURyaWxsZG93blNlbGVjdGlvbnMnXT5bMF07XG4gIH0pID0+IHZvaWQ7XG59XG5cbi8qKlxuICogRHJpbGxkb3duIEJyZWFkY3J1bWJzIENvbXBvbmVudFxuICpcbiAqIEBncm91cCBEcmlsbGRvd25cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnY3Nkay1kcmlsbGRvd24tYnJlYWRjcnVtYnMnLFxuICB0ZW1wbGF0ZSxcbiAgc3R5bGVzLFxufSlcbmV4cG9ydCBjbGFzcyBEcmlsbGRvd25CcmVhZGNydW1ic0NvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgQFZpZXdDaGlsZChyb290SWQpXG4gIHByZWFjdFJlZiE6IEVsZW1lbnRSZWY8SFRNTERpdkVsZW1lbnQ+O1xuXG4gIC8qKlxuICAgKiB7QGluaGVyaXREb2MgQHNpc2Vuc2Uvc2RrLXVpIURyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHMuZmlsdGVyc0Rpc3BsYXlWYWx1ZXN9XG4gICAqXG4gICAqIEBjYXRlZ29yeSBXaWRnZXRcbiAgICovXG4gIEBJbnB1dCgpXG4gIGZpbHRlcnNEaXNwbGF5VmFsdWVzITogRHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wc1snZmlsdGVyc0Rpc3BsYXlWYWx1ZXMnXTtcblxuICAvKipcbiAgICoge0Bpbmhlcml0RG9jIEBzaXNlbnNlL3Nkay11aSFEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzLmN1cnJlbnREaW1lbnNpb259XG4gICAqXG4gICAqIEBjYXRlZ29yeSBXaWRnZXRcbiAgICovXG4gIEBJbnB1dCgpXG4gIGN1cnJlbnREaW1lbnNpb24hOiBEcmlsbGRvd25CcmVhZGNydW1ic1Byb3BzWydjdXJyZW50RGltZW5zaW9uJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhRHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wcy5jbGVhckRyaWxsZG93blNlbGVjdGlvbnN9XG4gICAqXG4gICAqIEBjYXRlZ29yeSBXaWRnZXRcbiAgICovXG4gIEBPdXRwdXQoKVxuICBkcmlsbGRvd25TZWxlY3Rpb25zQ2xlYXIgPSBuZXcgRXZlbnRFbWl0dGVyPFxuICAgIEFyZ3VtZW50c0FzT2JqZWN0PERyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHNQcmVhY3RbJ2NsZWFyRHJpbGxkb3duU2VsZWN0aW9ucyddLCBbXT5cbiAgPigpO1xuXG4gIC8qKlxuICAgKiB7QGluaGVyaXREb2MgQHNpc2Vuc2Uvc2RrLXVpIURyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHMuc2xpY2VEcmlsbGRvd25TZWxlY3Rpb25zfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgV2lkZ2V0XG4gICAqL1xuICBAT3V0cHV0KClcbiAgZHJpbGxkb3duU2VsZWN0aW9uc1NsaWNlID0gbmV3IEV2ZW50RW1pdHRlcjxcbiAgICBBcmd1bWVudHM8RHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wc1ByZWFjdFsnc2xpY2VEcmlsbGRvd25TZWxlY3Rpb25zJ10+WzBdXG4gID4oKTtcblxuICBwcml2YXRlIGNvbXBvbmVudEFkYXB0ZXI6IENvbXBvbmVudEFkYXB0ZXI8dHlwZW9mIERyaWxsZG93bkJyZWFkY3J1bWJzUHJlYWN0PjtcblxuICAvKipcbiAgICogQ29uc3RydWN0b3IgZm9yIHRoZSBgRHJpbGxkb3duQnJlYWRjcnVtYnNDb21wb25lbnRgLlxuICAgKlxuICAgKiBAcGFyYW0gc2lzZW5zZUNvbnRleHRTZXJ2aWNlIC0gU2lzZW5zZSBjb250ZXh0IHNlcnZpY2VcbiAgICogQHBhcmFtIHRoZW1lU2VydmljZSAtIFRoZW1lIHNlcnZpY2VcbiAgICovXG4gIGNvbnN0cnVjdG9yKFxuICAgIC8qKlxuICAgICAqIFNpc2Vuc2UgY29udGV4dCBzZXJ2aWNlXG4gICAgICpcbiAgICAgKiBAY2F0ZWdvcnkgQ29uc3RydWN0b3JcbiAgICAgKi9cbiAgICBwdWJsaWMgc2lzZW5zZUNvbnRleHRTZXJ2aWNlOiBTaXNlbnNlQ29udGV4dFNlcnZpY2UsXG4gICAgLyoqXG4gICAgICogVGhlbWUgc2VydmljZVxuICAgICAqXG4gICAgICogQGNhdGVnb3J5IENvbnN0cnVjdG9yXG4gICAgICovXG4gICAgcHVibGljIHRoZW1lU2VydmljZTogVGhlbWVTZXJ2aWNlLFxuICApIHtcbiAgICB0aGlzLmNvbXBvbmVudEFkYXB0ZXIgPSBuZXcgQ29tcG9uZW50QWRhcHRlcihEcmlsbGRvd25CcmVhZGNydW1ic1ByZWFjdCwgW1xuICAgICAgY3JlYXRlUGx1Z2luQ29udGV4dENvbm5lY3Rvcih0aGlzLnNpc2Vuc2VDb250ZXh0U2VydmljZSksXG4gICAgICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3Rvcih0aGlzLnNpc2Vuc2VDb250ZXh0U2VydmljZSksXG4gICAgICBjcmVhdGVUaGVtZUNvbnRleHRDb25uZWN0b3IodGhpcy50aGVtZVNlcnZpY2UpLFxuICAgIF0pO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIHRoaXMuY29tcG9uZW50QWRhcHRlci5yZW5kZXIodGhpcy5wcmVhY3RSZWYubmF0aXZlRWxlbWVudCwgdGhpcy5nZXRQcmVhY3RDb21wb25lbnRQcm9wcygpKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIG5nT25DaGFuZ2VzKCkge1xuICAgIGlmICh0aGlzLnByZWFjdFJlZikge1xuICAgICAgdGhpcy5jb21wb25lbnRBZGFwdGVyLnJlbmRlcih0aGlzLnByZWFjdFJlZi5uYXRpdmVFbGVtZW50LCB0aGlzLmdldFByZWFjdENvbXBvbmVudFByb3BzKCkpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgZ2V0UHJlYWN0Q29tcG9uZW50UHJvcHMoKTogRHJpbGxkb3duQnJlYWRjcnVtYnNQcm9wc1ByZWFjdCB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGZpbHRlcnNEaXNwbGF5VmFsdWVzOiB0aGlzLmZpbHRlcnNEaXNwbGF5VmFsdWVzLFxuICAgICAgY3VycmVudERpbWVuc2lvbjogdGhpcy5jdXJyZW50RGltZW5zaW9uLFxuICAgICAgY2xlYXJEcmlsbGRvd25TZWxlY3Rpb25zOiAoKSA9PiB0aGlzLmRyaWxsZG93blNlbGVjdGlvbnNDbGVhci5lbWl0KCksXG4gICAgICBzbGljZURyaWxsZG93blNlbGVjdGlvbnM6IChcbiAgICAgICAgaTogQXJndW1lbnRzPERyaWxsZG93bkJyZWFkY3J1bWJzUHJvcHNbJ3NsaWNlRHJpbGxkb3duU2VsZWN0aW9ucyddPlswXSxcbiAgICAgICkgPT4gdGhpcy5kcmlsbGRvd25TZWxlY3Rpb25zU2xpY2UuZW1pdChpKSxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5jb21wb25lbnRBZGFwdGVyLmRlc3Ryb3koKTtcbiAgfVxufVxuIl19
|
|
@@ -1,6 +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, 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";
|
|
@@ -67,6 +67,7 @@ export class CriteriaFilterTileComponent {
|
|
|
67
67
|
*/
|
|
68
68
|
this.filterChange = new EventEmitter();
|
|
69
69
|
this.componentAdapter = new ComponentAdapter(CriteriaFilterTilePreact, [
|
|
70
|
+
createPluginContextConnector(this.sisenseContextService),
|
|
70
71
|
createSisenseContextConnector(this.sisenseContextService),
|
|
71
72
|
createThemeContextConnector(this.themeService),
|
|
72
73
|
]);
|
|
@@ -123,4 +124,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
123
124
|
}], filterChange: [{
|
|
124
125
|
type: Output
|
|
125
126
|
}] } });
|
|
126
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
127
|
+
//# 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,4BAA4B,EAC5B,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,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;;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;;yHAzGU,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  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 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=\"225px\" />\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      createPluginContextConnector(this.sisenseContextService),\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,6 +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, 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";
|
|
@@ -72,6 +72,7 @@ export class DateRangeFilterTileComponent {
|
|
|
72
72
|
*/
|
|
73
73
|
this.filterChange = new EventEmitter();
|
|
74
74
|
this.componentAdapter = new ComponentAdapter(DateRangeFilterTilePreact, [
|
|
75
|
+
createPluginContextConnector(this.sisenseContextService),
|
|
75
76
|
createSisenseContextConnector(this.sisenseContextService),
|
|
76
77
|
createThemeContextConnector(this.themeService),
|
|
77
78
|
]);
|
|
@@ -131,4 +132,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
131
132
|
}], filterChange: [{
|
|
132
133
|
type: Output
|
|
133
134
|
}] } });
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
135
|
+
//# 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,4BAA4B,EAC5B,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,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;;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;;0HAlHU,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  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 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=\"450px\" />\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      createPluginContextConnector(this.sisenseContextService),\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,6 +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, rootId, styles, template, } from '../../component-wrapper-helpers';
|
|
3
|
+
import { createPluginContextConnector, createSisenseContextConnector, createThemeContextConnector, rootId, styles, template, } from '../../component-wrapper-helpers';
|
|
4
4
|
import { EventEmitterWithHasListeners } from '../../helpers';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "../../services/sisense-context.service";
|
|
@@ -81,6 +81,7 @@ export class FilterTileComponent {
|
|
|
81
81
|
*/
|
|
82
82
|
this.filterDelete = new EventEmitterWithHasListeners();
|
|
83
83
|
this.componentAdapter = new ComponentAdapter(FilterTilePreact, [
|
|
84
|
+
createPluginContextConnector(this.sisenseContextService),
|
|
84
85
|
createSisenseContextConnector(this.sisenseContextService),
|
|
85
86
|
createThemeContextConnector(this.themeService),
|
|
86
87
|
]);
|
|
@@ -140,4 +141,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
140
141
|
}], filterDelete: [{
|
|
141
142
|
type: Output
|
|
142
143
|
}] } });
|
|
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"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-tile.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/filters/filter-tile.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ComponentAdapter,\n  FilterTile as FilterTilePreact,\n  type FilterTileProps as FilterTilePropsPreact,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createPluginContextConnector,\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      createPluginContextConnector(this.sisenseContextService),\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,6 +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, 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";
|
|
@@ -68,6 +68,7 @@ export class MemberFilterTileComponent {
|
|
|
68
68
|
*/
|
|
69
69
|
this.filterChange = new EventEmitter();
|
|
70
70
|
this.componentAdapter = new ComponentAdapter(MemberFilterTilePreact, [
|
|
71
|
+
createPluginContextConnector(this.sisenseContextService),
|
|
71
72
|
createSisenseContextConnector(this.sisenseContextService),
|
|
72
73
|
createThemeContextConnector(this.themeService),
|
|
73
74
|
]);
|
|
@@ -121,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
121
122
|
}], filterChange: [{
|
|
122
123
|
type: Output
|
|
123
124
|
}] } });
|
|
124
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
125
|
+
//# 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,4BAA4B,EAC5B,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,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;;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;;uHApGU,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  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 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      createPluginContextConnector(this.sisenseContextService),\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,6 +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, 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";
|
|
@@ -72,6 +72,7 @@ export class RelativeDateFilterTileComponent {
|
|
|
72
72
|
*/
|
|
73
73
|
this.filterChange = new EventEmitter();
|
|
74
74
|
this.componentAdapter = new ComponentAdapter(RelativeDateFilterTilePreact, [
|
|
75
|
+
createPluginContextConnector(this.sisenseContextService),
|
|
75
76
|
createSisenseContextConnector(this.sisenseContextService),
|
|
76
77
|
createThemeContextConnector(this.themeService),
|
|
77
78
|
]);
|
|
@@ -125,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
125
126
|
}], filterChange: [{
|
|
126
127
|
type: Output
|
|
127
128
|
}] } });
|
|
128
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
129
|
+
//# 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,4BAA4B,EAC5B,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,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;;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;;6HApGU,+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  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 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=\"225px\" />\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      createPluginContextConnector(this.sisenseContextService),\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): RelativeDateFilterTilePropsPreact {\n    return {\n      title: this.title,\n      filter: this.filter,\n      arrangement: this.arrangement,\n      limit: this.limit,\n      onUpdate: (...[filter]: Arguments<RelativeDateFilterTilePropsPreact['onUpdate']>) =>\n        this.filterChange.emit({ filter }),\n    };\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ChartWidget as ChartWidgetPreact, ComponentAdapter, } 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";
|
|
@@ -84,6 +84,7 @@ export class ChartWidgetComponent {
|
|
|
84
84
|
*/
|
|
85
85
|
this.dataPointsSelect = new EventEmitter();
|
|
86
86
|
this.componentAdapter = new ComponentAdapter(ChartWidgetPreact, [
|
|
87
|
+
createPluginContextConnector(this.sisenseContextService),
|
|
87
88
|
createSisenseContextConnector(this.sisenseContextService),
|
|
88
89
|
createThemeContextConnector(this.themeService),
|
|
89
90
|
]);
|
|
@@ -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":"chart-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/chart-widget.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ChartWidget as ChartWidgetPreact,\n  type ChartWidgetProps as ChartWidgetPropsPreact,\n  ComponentAdapter,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootId,\n  styles,\n  template,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport { ChartEventProps, WithoutPreactChartEventProps } from '../../types/chart-event-props';\nimport {\n  ChartDataPointClickEvent,\n  ChartDataPointContextMenuEvent,\n  ChartDataPointsEvent,\n} from '../../types/data-point';\nimport type { Arguments } from '../../types/utility-types';\n\n/**\n * Props of the {@link ChartWidgetComponent}.\n */\nexport interface ChartWidgetProps\n  extends WithoutPreactChartEventProps<ChartWidgetPropsPreact>,\n    ChartEventProps {}\n\n/**\n * The Chart Widget component extending {@link ChartComponent} to support widget style options.\n *\n * @example\n * ```html\n * <csdk-chart-widget\n *   [chartType]=\"chartWidget.chartType\"\n *   [dataSource]=\"chartWidget.dataSource\"\n *   [dataOptions]=\"chartWidget.dataOptions\"\n *   [highlights]=\"filters\"\n *   [title]=\"chartWidget.title\"\n *   [description]=\"chartWidget.description\"\n *   [beforeRender]=\"onBeforeRender\"\n *   (dataPointClick)=\"logArguments($event)\"\n *   (dataPointContextMenu)=\"logArguments($event)\"\n *   (dataPointsSelect)=\"logArguments($event)\"\n * />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { ChartType } from '@sisense/sdk-ui-angular';\n * import { filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-widgets',\n *   templateUrl: './widgets.component.html',\n *   styleUrls: ['./widgets.component.scss'],\n * })\n * export class WidgetsComponent {\n *   filters = [filterFactory.members(DM.Divisions.Divison_name, ['Cardiology', 'Neurology'])];\n *   chartWidget = {\n *     chartType: 'column' as ChartType,\n *     dataSource: DM.DataSource,\n *     dataOptions: {\n *       category: [DM.Divisions.Divison_name],\n *       value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],\n *       breakBy: [],\n *     },\n *     title: 'Chart Title',\n *     description: 'Chart Description',\n *   };\n *  logArguments(...args: any[]) {\n *   console.log(args);\n * }\n *\n * onBeforeRender(options: any) {\n *   console.log('beforeRender');\n *   console.log(options);\n *   return options;\n * }\n *\n * }\n * ```\n * <img src=\"media://angular-chart-widget-example.png\" width=\"500px\" />\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-chart-widget',\n  template,\n  styles,\n})\nexport class ChartWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.chartType}\n   *\n   * @category Chart\n   */\n  @Input()\n  chartType!: ChartWidgetProps['chartType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: ChartWidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataOptions}\n   *\n   * @category Chart\n   */\n  @Input()\n  dataOptions!: ChartWidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: ChartWidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: ChartWidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: ChartWidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.drilldownOptions}\n   *\n   * @category Widget\n   * @internal\n   */\n  @Input()\n  drilldownOptions: ChartWidgetProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: ChartWidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: ChartWidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   */\n  @Input()\n  highlightSelectionDisabled: ChartWidgetProps['highlightSelectionDisabled'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onBeforeRender}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  beforeRender: ChartWidgetProps['beforeRender'];\n\n  /**\n   * {@inheritDoc  @sisense/sdk-ui!ChartWidgetProps.onDataReady}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  dataReady: ChartWidgetProps['dataReady'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointClick}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointClick = new EventEmitter<ChartDataPointClickEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointContextMenu}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointContextMenu = new EventEmitter<ChartDataPointContextMenuEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointsSelected}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointsSelect = new EventEmitter<ChartDataPointsEvent>();\n\n  private componentAdapter: ComponentAdapter<typeof ChartWidgetPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(ChartWidgetPreact, [\n      createSisenseContextConnector(this.sisenseContextService),\n      createThemeContextConnector(this.themeService),\n    ]);\n  }\n\n  /** @internal */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n  }\n\n  /** @internal */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement, this.getPreactComponentProps());\n    }\n  }\n\n  private getPreactComponentProps(): ChartWidgetPropsPreact {\n    return {\n      chartType: this.chartType,\n      dataSource: this.dataSource,\n      dataOptions: this.dataOptions,\n      filters: this.filters,\n      highlights: this.highlights,\n      styleOptions: this.styleOptions,\n      drilldownOptions: this.drilldownOptions,\n      title: this.title,\n      description: this.description,\n      highlightSelectionDisabled: this.highlightSelectionDisabled,\n      onBeforeRender: this.beforeRender?.bind(this),\n      onDataReady: this.dataReady?.bind(this),\n      onDataPointClick: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointClick']>\n      ) => this.dataPointClick.emit({ point, nativeEvent } as ChartDataPointClickEvent),\n      onDataPointContextMenu: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointContextMenu']>\n      ) => this.dataPointContextMenu.emit({ point, nativeEvent } as ChartDataPointContextMenuEvent),\n      onDataPointsSelected: (\n        ...[points, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointsSelected']>\n      ) => this.dataPointsSelect.emit({ points, nativeEvent } as ChartDataPointsEvent),\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/chart-widget.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ChartWidget as ChartWidgetPreact,\n  type ChartWidgetProps as ChartWidgetPropsPreact,\n  ComponentAdapter,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  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 { ChartEventProps, WithoutPreactChartEventProps } from '../../types/chart-event-props';\nimport {\n  ChartDataPointClickEvent,\n  ChartDataPointContextMenuEvent,\n  ChartDataPointsEvent,\n} from '../../types/data-point';\nimport type { Arguments } from '../../types/utility-types';\n\n/**\n * Props of the {@link ChartWidgetComponent}.\n */\nexport interface ChartWidgetProps\n  extends WithoutPreactChartEventProps<ChartWidgetPropsPreact>,\n    ChartEventProps {}\n\n/**\n * The Chart Widget component extending {@link ChartComponent} to support widget style options.\n *\n * @example\n * ```html\n * <csdk-chart-widget\n *   [chartType]=\"chartWidget.chartType\"\n *   [dataSource]=\"chartWidget.dataSource\"\n *   [dataOptions]=\"chartWidget.dataOptions\"\n *   [highlights]=\"filters\"\n *   [title]=\"chartWidget.title\"\n *   [description]=\"chartWidget.description\"\n *   [beforeRender]=\"onBeforeRender\"\n *   (dataPointClick)=\"logArguments($event)\"\n *   (dataPointContextMenu)=\"logArguments($event)\"\n *   (dataPointsSelect)=\"logArguments($event)\"\n * />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { ChartType } from '@sisense/sdk-ui-angular';\n * import { filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-widgets',\n *   templateUrl: './widgets.component.html',\n *   styleUrls: ['./widgets.component.scss'],\n * })\n * export class WidgetsComponent {\n *   filters = [filterFactory.members(DM.Divisions.Divison_name, ['Cardiology', 'Neurology'])];\n *   chartWidget = {\n *     chartType: 'column' as ChartType,\n *     dataSource: DM.DataSource,\n *     dataOptions: {\n *       category: [DM.Divisions.Divison_name],\n *       value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],\n *       breakBy: [],\n *     },\n *     title: 'Chart Title',\n *     description: 'Chart Description',\n *   };\n *  logArguments(...args: any[]) {\n *   console.log(args);\n * }\n *\n * onBeforeRender(options: any) {\n *   console.log('beforeRender');\n *   console.log(options);\n *   return options;\n * }\n *\n * }\n * ```\n * <img src=\"media://angular-chart-widget-example.png\" width=\"500px\" />\n * @group Dashboards\n */\n@Component({\n  selector: 'csdk-chart-widget',\n  template,\n  styles,\n})\nexport class ChartWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.chartType}\n   *\n   * @category Chart\n   */\n  @Input()\n  chartType!: ChartWidgetProps['chartType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: ChartWidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataOptions}\n   *\n   * @category Chart\n   */\n  @Input()\n  dataOptions!: ChartWidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: ChartWidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: ChartWidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: ChartWidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.drilldownOptions}\n   *\n   * @category Widget\n   * @internal\n   */\n  @Input()\n  drilldownOptions: ChartWidgetProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: ChartWidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: ChartWidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   */\n  @Input()\n  highlightSelectionDisabled: ChartWidgetProps['highlightSelectionDisabled'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onBeforeRender}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  beforeRender: ChartWidgetProps['beforeRender'];\n\n  /**\n   * {@inheritDoc  @sisense/sdk-ui!ChartWidgetProps.onDataReady}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  dataReady: ChartWidgetProps['dataReady'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointClick}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointClick = new EventEmitter<ChartDataPointClickEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointContextMenu}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointContextMenu = new EventEmitter<ChartDataPointContextMenuEvent>();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.onDataPointsSelected}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointsSelect = new EventEmitter<ChartDataPointsEvent>();\n\n  private componentAdapter: ComponentAdapter<typeof ChartWidgetPreact>;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(ChartWidgetPreact, [\n      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(): ChartWidgetPropsPreact {\n    return {\n      chartType: this.chartType,\n      dataSource: this.dataSource,\n      dataOptions: this.dataOptions,\n      filters: this.filters,\n      highlights: this.highlights,\n      styleOptions: this.styleOptions,\n      drilldownOptions: this.drilldownOptions,\n      title: this.title,\n      description: this.description,\n      highlightSelectionDisabled: this.highlightSelectionDisabled,\n      onBeforeRender: this.beforeRender?.bind(this),\n      onDataReady: this.dataReady?.bind(this),\n      onDataPointClick: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointClick']>\n      ) => this.dataPointClick.emit({ point, nativeEvent } as ChartDataPointClickEvent),\n      onDataPointContextMenu: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointContextMenu']>\n      ) => this.dataPointContextMenu.emit({ point, nativeEvent } as ChartDataPointContextMenuEvent),\n      onDataPointsSelected: (\n        ...[points, nativeEvent]: Arguments<ChartWidgetPropsPreact['onDataPointsSelected']>\n      ) => this.dataPointsSelect.emit({ points, nativeEvent } as ChartDataPointsEvent),\n    };\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
2
|
import { ComponentAdapter, createComponentRenderer, createWrapperElement, createWrapperElementHandler, DrilldownWidget as DrilldownWidgetPreact, } from '@sisense/sdk-ui-preact';
|
|
3
|
-
import { createSisenseContextConnector, createThemeContextConnector, rootContentId, rootId, styles, templateWithContent, } from '../../component-wrapper-helpers';
|
|
3
|
+
import { createPluginContextConnector, createSisenseContextConnector, createThemeContextConnector, rootContentId, rootId, styles, templateWithContent, } 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";
|
|
@@ -101,6 +101,7 @@ export class DrilldownWidgetComponent {
|
|
|
101
101
|
*/
|
|
102
102
|
this.drilldownResultChange = new EventEmitter();
|
|
103
103
|
this.componentAdapter = new ComponentAdapter(DrilldownWidgetPreact, [
|
|
104
|
+
createPluginContextConnector(this.sisenseContextService),
|
|
104
105
|
createSisenseContextConnector(this.sisenseContextService),
|
|
105
106
|
createThemeContextConnector(this.themeService),
|
|
106
107
|
]);
|
|
@@ -171,4 +172,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
171
172
|
}], drilldownResultChange: [{
|
|
172
173
|
type: Output
|
|
173
174
|
}] } });
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drilldown-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/drilldown-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  type ComponentRenderer,\n  type ContextMenuProps,\n  createComponentRenderer,\n  createWrapperElement,\n  createWrapperElementHandler,\n  type CustomDrilldownResult as CustomDrilldownResultBase,\n  DrilldownBreadcrumbsProps,\n  DrilldownWidget as DrilldownWidgetPreact,\n  type DrilldownWidgetProps,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootContentId,\n  rootId,\n  styles,\n  templateWithContent,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments } from '../../types/utility-types';\n\nexport type CustomDrilldownResult = CustomDrilldownResultBase & {\n  breadcrumbsComponent?: {\n    render: ComponentRenderer;\n  };\n};\n\n/**\n * An Angular component designed to add drilldown functionality to any type of chart.\n *\n * It acts as a wrapper around a given chart component, enhancing it with drilldown capabilities\n *\n * The widget offers several features including:\n * - A context menu for initiating drilldown actions (can be provided as a custom component)\n * - Breadcrumbs that not only allow for drilldown selection slicing but also\n * provide an option to clear the selection (can be provided as a custom component)\n * - Filters specifically created for drilldown operation\n * - An option to navigate to the next drilldown dimension\n *\n * When an `initialDimension` is specified, the `drilldownDimension` will automatically inherit its value,\n * even before any points on the chart are selected.\n * This allows for complete control over the chart's dimensions to be handed over to the DrilldownWidget\n *\n * @example\n * An example of using the `csdk-drilldown-widget` component to plot a `csdk-column-chart`\n * over the Sample Healthcare data source hosted in a Sisense instance:\n * ```ts\n * // Component behavior in .component.ts\n * chart = {\n *   dataOptions: {\n *     category: [DM.Divisions.Divison_name],\n *     value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],\n *     breakBy: [],\n *   },\n *   dataPointContextMenu: ({ point, nativeEvent }: { point: any; nativeEvent: MouseEvent }) => {\n *     this.drilldownResult?.onDataPointsSelected?.([point], nativeEvent);\n *     this.drilldownResult?.onContextMenu({\n *       left: nativeEvent.clientX,\n *       top: nativeEvent.clientY,\n *     });\n *   }\n * }\n *\n * drilldownResult?: CustomDrilldownResult;\n *\n * drilldown = {\n *   drilldownPaths: [DM.Patients.Gender, DM.Admissions.Surgical_Procedure],\n *   initialDimension: DM.Divisions.Divison_name,\n *   drilldownChange: (drilldownResult: CustomDrilldownResult) => {\n *     this.drilldownResult = drilldownResult;\n *     this.chart.dataOptions = {\n *       ...this.chart.dataOptions,\n *       category: [drilldownResult.drilldownDimension]\n *     }\n *   }\n * };\n * ```\n * ```html\n * <!--Component HTML template in .component.html-->\n * <csdk-drilldown-widget\n *   [drilldownPaths]=\"drilldown.drilldownPaths\"\n *   [initialDimension]=\"drilldown.initialDimension\"\n *   (drilldownResultChange)=\"drilldown.drilldownChange($event)\"\n * >\n *   <csdk-column-chart\n *     [dataSet]=\"DM.DataSource\"\n *     [dataOptions]=\"chart.dataOptions\"\n *     [filters]=\"drilldownResult?.drilldownFilters || []\"\n *     (dataPointContextMenu)=\"chart.dataPointContextMenu($event)\"\n *   />\n * </csdk-drilldown-widget>\n * ```\n * <img src=\"media://angular-drilldown-widget-example.png\" width=\"800px\" />\n * @group Drilldown\n */\n@Component({\n  selector: 'csdk-drilldown-widget',\n  template: templateWithContent,\n  styles,\n})\nexport class DrilldownWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * @internal\n   */\n  @ViewChild(rootContentId)\n  preactContentRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DrilldownWidgetProps.drilldownPaths}\n   *\n   * @category Widget\n   */\n  @Input()\n  drilldownPaths: DrilldownWidgetProps['drilldownPaths'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DrilldownWidgetProps.initialDimension}\n   *\n   * @category Widget\n   */\n  @Input()\n  initialDimension!: DrilldownWidgetProps['initialDimension'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DrilldownWidgetProps.config}\n   *\n   * @category Widget\n   */\n  @Input()\n  config?: Omit<DrilldownWidgetProps['config'], 'breadcrumbsComponent | contextMenuComponent'> & {\n    breadcrumbsComponent?: (drilldownBreadcrumbsProps: DrilldownBreadcrumbsProps) => HTMLDivElement;\n    contextMenuComponent?: (contextMenuProps: ContextMenuProps) => HTMLDivElement;\n  };\n\n  /**\n   * Drilldown result change handler callback\n   *\n   * @category Callbacks\n   */\n  @Output()\n  drilldownResultChange = new EventEmitter<CustomDrilldownResult>();\n\n  private componentAdapter: ComponentAdapter<typeof DrilldownWidgetPreact>;\n\n  /**\n   * Constructor for the `DrilldownWidgetComponent`.\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(DrilldownWidgetPreact, [\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(): DrilldownWidgetProps {\n    return {\n      drilldownPaths: this.drilldownPaths,\n      initialDimension: this.initialDimension,\n      config: {\n        ...this.config,\n        ...(this.config?.breadcrumbsComponent && {\n          breadcrumbsComponent: createWrapperElementHandler(this.config.breadcrumbsComponent),\n        }),\n        ...(this.config?.contextMenuComponent && {\n          contextMenuComponent: (contextMenuProps: ContextMenuProps) =>\n            createWrapperElement(this.config!.contextMenuComponent!(contextMenuProps)),\n        }),\n      },\n      children: (customDrilldownResult: Arguments<DrilldownWidgetProps['children']>[0]) => {\n        const { breadcrumbsComponent } = customDrilldownResult;\n        this.drilldownResultChange.emit({\n          ...customDrilldownResult,\n          ...(breadcrumbsComponent && {\n            breadcrumbsComponent: { render: createComponentRenderer(breadcrumbsComponent) },\n          }),\n        } as CustomDrilldownResult);\n        return createWrapperElement(this.preactContentRef.nativeElement);\n      },\n    } as DrilldownWidgetProps;\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
175
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drilldown-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/drilldown-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  type ComponentRenderer,\n  type ContextMenuProps,\n  createComponentRenderer,\n  createWrapperElement,\n  createWrapperElementHandler,\n  type CustomDrilldownResult as CustomDrilldownResultBase,\n  DrilldownBreadcrumbsProps,\n  DrilldownWidget as DrilldownWidgetPreact,\n  type DrilldownWidgetProps,\n} from '@sisense/sdk-ui-preact';\n\nimport {\n  createPluginContextConnector,\n  createSisenseContextConnector,\n  createThemeContextConnector,\n  rootContentId,\n  rootId,\n  styles,\n  templateWithContent,\n} from '../../component-wrapper-helpers';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments } from '../../types/utility-types';\n\nexport type CustomDrilldownResult = CustomDrilldownResultBase & {\n  breadcrumbsComponent?: {\n    render: ComponentRenderer;\n  };\n};\n\n/**\n * An Angular component designed to add drilldown functionality to any type of chart.\n *\n * It acts as a wrapper around a given chart component, enhancing it with drilldown capabilities\n *\n * The widget offers several features including:\n * - A context menu for initiating drilldown actions (can be provided as a custom component)\n * - Breadcrumbs that not only allow for drilldown selection slicing but also\n * provide an option to clear the selection (can be provided as a custom component)\n * - Filters specifically created for drilldown operation\n * - An option to navigate to the next drilldown dimension\n *\n * When an `initialDimension` is specified, the `drilldownDimension` will automatically inherit its value,\n * even before any points on the chart are selected.\n * This allows for complete control over the chart's dimensions to be handed over to the DrilldownWidget\n *\n * @example\n * An example of using the `csdk-drilldown-widget` component to plot a `csdk-column-chart`\n * over the Sample Healthcare data source hosted in a Sisense instance:\n * ```ts\n * // Component behavior in .component.ts\n * chart = {\n *   dataOptions: {\n *     category: [DM.Divisions.Divison_name],\n *     value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],\n *     breakBy: [],\n *   },\n *   dataPointContextMenu: ({ point, nativeEvent }: { point: any; nativeEvent: MouseEvent }) => {\n *     this.drilldownResult?.onDataPointsSelected?.([point], nativeEvent);\n *     this.drilldownResult?.onContextMenu({\n *       left: nativeEvent.clientX,\n *       top: nativeEvent.clientY,\n *     });\n *   }\n * }\n *\n * drilldownResult?: CustomDrilldownResult;\n *\n * drilldown = {\n *   drilldownPaths: [DM.Patients.Gender, DM.Admissions.Surgical_Procedure],\n *   initialDimension: DM.Divisions.Divison_name,\n *   drilldownChange: (drilldownResult: CustomDrilldownResult) => {\n *     this.drilldownResult = drilldownResult;\n *     this.chart.dataOptions = {\n *       ...this.chart.dataOptions,\n *       category: [drilldownResult.drilldownDimension]\n *     }\n *   }\n * };\n * ```\n * ```html\n * <!--Component HTML template in .component.html-->\n * <csdk-drilldown-widget\n *   [drilldownPaths]=\"drilldown.drilldownPaths\"\n *   [initialDimension]=\"drilldown.initialDimension\"\n *   (drilldownResultChange)=\"drilldown.drilldownChange($event)\"\n * >\n *   <csdk-column-chart\n *     [dataSet]=\"DM.DataSource\"\n *     [dataOptions]=\"chart.dataOptions\"\n *     [filters]=\"drilldownResult?.drilldownFilters || []\"\n *     (dataPointContextMenu)=\"chart.dataPointContextMenu($event)\"\n *   />\n * </csdk-drilldown-widget>\n * ```\n * <img src=\"media://angular-drilldown-widget-example.png\" width=\"800px\" />\n * @group Drilldown\n */\n@Component({\n  selector: 'csdk-drilldown-widget',\n  template: templateWithContent,\n  styles,\n})\nexport class DrilldownWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /**\n   * @internal\n   */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * @internal\n   */\n  @ViewChild(rootContentId)\n  preactContentRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DrilldownWidgetProps.drilldownPaths}\n   *\n   * @category Widget\n   */\n  @Input()\n  drilldownPaths: DrilldownWidgetProps['drilldownPaths'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DrilldownWidgetProps.initialDimension}\n   *\n   * @category Widget\n   */\n  @Input()\n  initialDimension!: DrilldownWidgetProps['initialDimension'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DrilldownWidgetProps.config}\n   *\n   * @category Widget\n   */\n  @Input()\n  config?: Omit<DrilldownWidgetProps['config'], 'breadcrumbsComponent | contextMenuComponent'> & {\n    breadcrumbsComponent?: (drilldownBreadcrumbsProps: DrilldownBreadcrumbsProps) => HTMLDivElement;\n    contextMenuComponent?: (contextMenuProps: ContextMenuProps) => HTMLDivElement;\n  };\n\n  /**\n   * Drilldown result change handler callback\n   *\n   * @category Callbacks\n   */\n  @Output()\n  drilldownResultChange = new EventEmitter<CustomDrilldownResult>();\n\n  private componentAdapter: ComponentAdapter<typeof DrilldownWidgetPreact>;\n\n  /**\n   * Constructor for the `DrilldownWidgetComponent`.\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(DrilldownWidgetPreact, [\n      createPluginContextConnector(this.sisenseContextService),\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(): DrilldownWidgetProps {\n    return {\n      drilldownPaths: this.drilldownPaths,\n      initialDimension: this.initialDimension,\n      config: {\n        ...this.config,\n        ...(this.config?.breadcrumbsComponent && {\n          breadcrumbsComponent: createWrapperElementHandler(this.config.breadcrumbsComponent),\n        }),\n        ...(this.config?.contextMenuComponent && {\n          contextMenuComponent: (contextMenuProps: ContextMenuProps) =>\n            createWrapperElement(this.config!.contextMenuComponent!(contextMenuProps)),\n        }),\n      },\n      children: (customDrilldownResult: Arguments<DrilldownWidgetProps['children']>[0]) => {\n        const { breadcrumbsComponent } = customDrilldownResult;\n        this.drilldownResultChange.emit({\n          ...customDrilldownResult,\n          ...(breadcrumbsComponent && {\n            breadcrumbsComponent: { render: createComponentRenderer(breadcrumbsComponent) },\n          }),\n        } as CustomDrilldownResult);\n        return createWrapperElement(this.preactContentRef.nativeElement);\n      },\n    } as DrilldownWidgetProps;\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|