@sisense/sdk-ui-angular 1.5.0 → 1.7.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/lib/component-wrapper-helpers/context-connectors.mjs +13 -1
- package/dist/esm2020/lib/components/charts/area-chart.component.mjs +137 -0
- package/dist/esm2020/lib/components/charts/areamap-chart.component.mjs +100 -0
- package/dist/esm2020/lib/components/charts/bar-chart.component.mjs +136 -0
- package/dist/esm2020/lib/components/charts/boxplot-chart.component.mjs +129 -0
- package/dist/esm2020/lib/components/charts/chart.component.mjs +171 -0
- package/dist/esm2020/lib/components/charts/column-chart.component.mjs +137 -0
- package/dist/esm2020/lib/components/charts/funnel-chart.component.mjs +135 -0
- package/dist/esm2020/lib/components/charts/index.mjs +18 -0
- package/dist/esm2020/lib/components/charts/indicator-chart.component.mjs +107 -0
- package/dist/esm2020/lib/components/charts/line-chart.component.mjs +135 -0
- package/dist/esm2020/lib/components/charts/pie-chart.component.mjs +137 -0
- package/dist/esm2020/lib/components/charts/pivot-table.component.mjs +116 -0
- package/dist/esm2020/lib/components/charts/polar-chart.component.mjs +136 -0
- package/dist/esm2020/lib/components/charts/scatter-chart.component.mjs +140 -0
- package/dist/esm2020/lib/components/charts/scattermap-chart.component.mjs +108 -0
- package/dist/esm2020/lib/components/charts/sunburst-chart.component.mjs +137 -0
- package/dist/esm2020/lib/components/charts/table.component.mjs +94 -0
- package/dist/esm2020/lib/components/{treemap-chart.component.mjs → charts/treemap-chart.component.mjs} +52 -1
- package/dist/esm2020/lib/components/context-menu.component.mjs +3 -1
- package/dist/esm2020/lib/components/drilldown-breadcrumbs.component.mjs +3 -1
- package/dist/esm2020/lib/components/filters/basic-member-filter-tile.component.mjs +62 -0
- package/dist/esm2020/lib/components/filters/date-range-filter-tile.component.mjs +141 -0
- package/dist/esm2020/lib/components/filters/index.mjs +4 -0
- package/dist/esm2020/lib/components/filters/member-filter-tile.component.mjs +131 -0
- package/dist/esm2020/lib/components/index.mjs +4 -25
- package/dist/esm2020/lib/components/widgets/chart-widget.component.mjs +167 -0
- package/dist/esm2020/lib/components/widgets/dashboard-widget.component.mjs +116 -0
- package/dist/esm2020/lib/components/widgets/drilldown-widget.component.mjs +174 -0
- package/dist/esm2020/lib/components/widgets/index.mjs +5 -0
- package/dist/esm2020/lib/components/widgets/table-widget.component.mjs +104 -0
- package/dist/esm2020/lib/sdk-ui.module.mjs +3 -1
- package/dist/esm2020/lib/services/dashboard.service.mjs +7 -1
- package/dist/esm2020/lib/services/query.service.mjs +7 -2
- package/dist/esm2020/lib/services/sisense-context.service.mjs +7 -1
- package/dist/esm2020/lib/services/theme.service.mjs +7 -1
- package/dist/esm2020/public-api.mjs +9 -2
- package/dist/esm2020/version.mjs +2 -2
- package/dist/fesm2015/sisense-sdk-ui-angular.mjs +1723 -709
- package/dist/fesm2015/sisense-sdk-ui-angular.mjs.map +1 -1
- package/dist/fesm2020/sisense-sdk-ui-angular.mjs +1724 -710
- package/dist/fesm2020/sisense-sdk-ui-angular.mjs.map +1 -1
- package/dist/lib/component-wrapper-helpers/context-connectors.d.ts +12 -0
- package/dist/lib/components/{area-chart.component.d.ts → charts/area-chart.component.d.ts} +53 -2
- package/dist/lib/components/{areamap-chart.component.d.ts → charts/areamap-chart.component.d.ts} +40 -1
- package/dist/lib/components/{bar-chart.component.d.ts → charts/bar-chart.component.d.ts} +52 -2
- package/dist/lib/components/{boxplot-chart.component.d.ts → charts/boxplot-chart.component.d.ts} +45 -2
- package/dist/lib/components/{chart.component.d.ts → charts/chart.component.d.ts} +6 -4
- package/dist/lib/components/{column-chart.component.d.ts → charts/column-chart.component.d.ts} +53 -2
- package/dist/lib/components/{funnel-chart.component.d.ts → charts/funnel-chart.component.d.ts} +52 -2
- package/dist/lib/components/charts/index.d.ts +17 -0
- package/dist/lib/components/{indicator-chart.component.d.ts → charts/indicator-chart.component.d.ts} +57 -1
- package/dist/lib/components/{line-chart.component.d.ts → charts/line-chart.component.d.ts} +52 -2
- package/dist/lib/components/{pie-chart.component.d.ts → charts/pie-chart.component.d.ts} +53 -2
- package/dist/lib/components/{pivot-table.component.d.ts → charts/pivot-table.component.d.ts} +53 -2
- package/dist/lib/components/{polar-chart.component.d.ts → charts/polar-chart.component.d.ts} +53 -2
- package/dist/lib/components/{scatter-chart.component.d.ts → charts/scatter-chart.component.d.ts} +50 -2
- package/dist/lib/components/{scattermap-chart.component.d.ts → charts/scattermap-chart.component.d.ts} +49 -2
- package/dist/lib/components/{sunburst-chart.component.d.ts → charts/sunburst-chart.component.d.ts} +53 -2
- package/dist/lib/components/{table.component.d.ts → charts/table.component.d.ts} +32 -2
- package/dist/lib/components/{treemap-chart.component.d.ts → charts/treemap-chart.component.d.ts} +53 -2
- package/dist/lib/components/context-menu.component.d.ts +2 -0
- package/dist/lib/components/drilldown-breadcrumbs.component.d.ts +2 -0
- package/dist/lib/components/{date-range-filter-tile.component.d.ts → filters/date-range-filter-tile.component.d.ts} +43 -3
- package/dist/lib/components/filters/index.d.ts +3 -0
- package/dist/lib/components/{member-filter-tile.component.d.ts → filters/member-filter-tile.component.d.ts} +39 -3
- package/dist/lib/components/index.d.ts +3 -24
- package/dist/lib/components/{chart-widget.component.d.ts → widgets/chart-widget.component.d.ts} +58 -3
- package/dist/lib/components/{dashboard-widget.component.d.ts → widgets/dashboard-widget.component.d.ts} +27 -2
- package/dist/lib/components/{drilldown-widget.component.d.ts → widgets/drilldown-widget.component.d.ts} +5 -2
- package/dist/lib/components/widgets/index.d.ts +4 -0
- package/dist/lib/components/{table-widget.component.d.ts → widgets/table-widget.component.d.ts} +37 -2
- package/dist/lib/sdk-ui.module.d.ts +26 -24
- package/dist/lib/services/dashboard.service.d.ts +6 -0
- package/dist/lib/services/query.service.d.ts +6 -1
- package/dist/lib/services/sisense-context.service.d.ts +6 -0
- package/dist/lib/services/theme.service.d.ts +6 -0
- package/dist/package.json +1 -1
- package/dist/public-api.d.ts +8 -1
- package/dist/version.d.ts +1 -1
- package/package.json +4 -4
- package/dist/esm2020/lib/components/area-chart.component.mjs +0 -86
- package/dist/esm2020/lib/components/areamap-chart.component.mjs +0 -61
- package/dist/esm2020/lib/components/bar-chart.component.mjs +0 -86
- package/dist/esm2020/lib/components/basic-member-filter-tile.component.mjs +0 -62
- package/dist/esm2020/lib/components/boxplot-chart.component.mjs +0 -86
- package/dist/esm2020/lib/components/chart-widget.component.mjs +0 -112
- package/dist/esm2020/lib/components/chart.component.mjs +0 -169
- package/dist/esm2020/lib/components/column-chart.component.mjs +0 -86
- package/dist/esm2020/lib/components/dashboard-widget.component.mjs +0 -91
- package/dist/esm2020/lib/components/date-range-filter-tile.component.mjs +0 -101
- package/dist/esm2020/lib/components/drilldown-widget.component.mjs +0 -171
- package/dist/esm2020/lib/components/funnel-chart.component.mjs +0 -85
- package/dist/esm2020/lib/components/indicator-chart.component.mjs +0 -51
- package/dist/esm2020/lib/components/line-chart.component.mjs +0 -85
- package/dist/esm2020/lib/components/member-filter-tile.component.mjs +0 -95
- package/dist/esm2020/lib/components/pie-chart.component.mjs +0 -86
- package/dist/esm2020/lib/components/pivot-table.component.mjs +0 -65
- package/dist/esm2020/lib/components/polar-chart.component.mjs +0 -85
- package/dist/esm2020/lib/components/scatter-chart.component.mjs +0 -92
- package/dist/esm2020/lib/components/scattermap-chart.component.mjs +0 -61
- package/dist/esm2020/lib/components/sunburst-chart.component.mjs +0 -86
- package/dist/esm2020/lib/components/table-widget.component.mjs +0 -69
- package/dist/esm2020/lib/components/table.component.mjs +0 -64
- /package/dist/lib/components/{basic-member-filter-tile.component.d.ts → filters/basic-member-filter-tile.component.d.ts} +0 -0
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { ChartWidget, ComponentAdapter, createElement, } from '@sisense/sdk-ui-preact';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
+
import { template, rootId } from '../../component-wrapper-helpers/template';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/sisense-context.service";
|
|
7
|
+
import * as i2 from "../../services/theme.service";
|
|
8
|
+
/**
|
|
9
|
+
* The Chart Widget component extending {@link ChartComponent} to support widget style options.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```html
|
|
13
|
+
* <csdk-chart-widget
|
|
14
|
+
* [chartType]="chartWidget.chartType"
|
|
15
|
+
* [dataSource]="chartWidget.dataSource"
|
|
16
|
+
* [dataOptions]="chartWidget.dataOptions"
|
|
17
|
+
* [highlights]="filters"
|
|
18
|
+
* [title]="chartWidget.title"
|
|
19
|
+
* [description]="chartWidget.description"
|
|
20
|
+
* [beforeRender]="onBeforeRender"
|
|
21
|
+
* (dataPointClick)="logArguments($event)"
|
|
22
|
+
* (dataPointContextMenu)="logArguments($event)"
|
|
23
|
+
* (dataPointsSelect)="logArguments($event)"
|
|
24
|
+
* />
|
|
25
|
+
* ```
|
|
26
|
+
* ```ts
|
|
27
|
+
* import { Component } from '@angular/core';
|
|
28
|
+
* import { ChartType } from '@sisense/sdk-ui-angular';
|
|
29
|
+
* import { filterFactory } from '@sisense/sdk-data';
|
|
30
|
+
* import * as DM from '../../assets/sample-healthcare-model';
|
|
31
|
+
*
|
|
32
|
+
* @Component({
|
|
33
|
+
* selector: 'app-widgets',
|
|
34
|
+
* templateUrl: './widgets.component.html',
|
|
35
|
+
* styleUrls: ['./widgets.component.scss'],
|
|
36
|
+
* })
|
|
37
|
+
* export class WidgetsComponent {
|
|
38
|
+
* filters = [filterFactory.members(DM.Divisions.Divison_name, ['Cardiology', 'Neurology'])];
|
|
39
|
+
* chartWidget = {
|
|
40
|
+
* chartType: 'column' as ChartType,
|
|
41
|
+
* dataSource: DM.DataSource,
|
|
42
|
+
* dataOptions: {
|
|
43
|
+
* category: [DM.Divisions.Divison_name],
|
|
44
|
+
* value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],
|
|
45
|
+
* breakBy: [],
|
|
46
|
+
* },
|
|
47
|
+
* title: 'Chart Title',
|
|
48
|
+
* description: 'Chart Description',
|
|
49
|
+
* };
|
|
50
|
+
* logArguments(...args: any[]) {
|
|
51
|
+
* console.log(args);
|
|
52
|
+
* }
|
|
53
|
+
*
|
|
54
|
+
* onBeforeRender(options: any) {
|
|
55
|
+
* console.log('beforeRender');
|
|
56
|
+
* console.log(options);
|
|
57
|
+
* return options;
|
|
58
|
+
* }
|
|
59
|
+
*
|
|
60
|
+
* }
|
|
61
|
+
* ```
|
|
62
|
+
* <img src="media://angular-chart-widget-example.png" width="800px" />
|
|
63
|
+
*
|
|
64
|
+
* @group Chart Utilities
|
|
65
|
+
*/
|
|
66
|
+
export class ChartWidgetComponent {
|
|
67
|
+
constructor(sisenseContextService, themeService) {
|
|
68
|
+
this.sisenseContextService = sisenseContextService;
|
|
69
|
+
this.themeService = themeService;
|
|
70
|
+
/**
|
|
71
|
+
* {@inheritDoc @sisense/sdk-ui!ChartProps.onDataPointClick}
|
|
72
|
+
*
|
|
73
|
+
* @category Callbacks
|
|
74
|
+
*/
|
|
75
|
+
this.dataPointClick = new EventEmitter();
|
|
76
|
+
/**
|
|
77
|
+
* {@inheritDoc @sisense/sdk-ui!ChartProps.onDataPointContextMenu}
|
|
78
|
+
*
|
|
79
|
+
* @category Callbacks
|
|
80
|
+
*/
|
|
81
|
+
this.dataPointContextMenu = new EventEmitter();
|
|
82
|
+
/**
|
|
83
|
+
* {@inheritDoc @sisense/sdk-ui!ChartProps.onDataPointsSelected}
|
|
84
|
+
*
|
|
85
|
+
* @category Callbacks
|
|
86
|
+
*/
|
|
87
|
+
this.dataPointsSelect = new EventEmitter();
|
|
88
|
+
this.componentAdapter = new ComponentAdapter(() => this.createPreactComponent(), [
|
|
89
|
+
createSisenseContextConnector(this.sisenseContextService),
|
|
90
|
+
createThemeContextConnector(this.themeService),
|
|
91
|
+
]);
|
|
92
|
+
}
|
|
93
|
+
/** @internal */
|
|
94
|
+
ngAfterViewInit() {
|
|
95
|
+
this.componentAdapter.render(this.preactRef.nativeElement);
|
|
96
|
+
}
|
|
97
|
+
/** @internal */
|
|
98
|
+
ngOnChanges() {
|
|
99
|
+
if (this.preactRef) {
|
|
100
|
+
this.componentAdapter.render(this.preactRef.nativeElement);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
createPreactComponent() {
|
|
104
|
+
const props = {
|
|
105
|
+
chartType: this.chartType,
|
|
106
|
+
dataSource: this.dataSource,
|
|
107
|
+
dataOptions: this.dataOptions,
|
|
108
|
+
filters: this.filters,
|
|
109
|
+
highlights: this.highlights,
|
|
110
|
+
styleOptions: this.styleOptions,
|
|
111
|
+
drilldownOptions: this.drilldownOptions,
|
|
112
|
+
title: this.title,
|
|
113
|
+
description: this.description,
|
|
114
|
+
highlightSelectionDisabled: this.highlightSelectionDisabled,
|
|
115
|
+
onBeforeRender: this.beforeRender?.bind(this),
|
|
116
|
+
onDataPointClick: (...[point, nativeEvent]) => this.dataPointClick.emit({ point, nativeEvent }),
|
|
117
|
+
onDataPointContextMenu: (...[point, nativeEvent]) => this.dataPointContextMenu.emit({ point, nativeEvent }),
|
|
118
|
+
onDataPointsSelected: (...[points, nativeEvent]) => this.dataPointsSelect.emit({ points, nativeEvent }),
|
|
119
|
+
};
|
|
120
|
+
return createElement(ChartWidget, props);
|
|
121
|
+
}
|
|
122
|
+
/** @internal */
|
|
123
|
+
ngOnDestroy() {
|
|
124
|
+
this.componentAdapter.destroy();
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
ChartWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ChartWidgetComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
128
|
+
ChartWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ChartWidgetComponent, selector: "csdk-chart-widget", inputs: { chartType: "chartType", dataSource: "dataSource", dataOptions: "dataOptions", filters: "filters", highlights: "highlights", styleOptions: "styleOptions", drilldownOptions: "drilldownOptions", title: "title", description: "description", highlightSelectionDisabled: "highlightSelectionDisabled", beforeRender: "beforeRender" }, outputs: { dataPointClick: "dataPointClick", dataPointContextMenu: "dataPointContextMenu", dataPointsSelect: "dataPointsSelect" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact style=\"width: 100%; height: 100%\"></div>\n", isInline: true });
|
|
129
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ChartWidgetComponent, decorators: [{
|
|
130
|
+
type: Component,
|
|
131
|
+
args: [{
|
|
132
|
+
selector: 'csdk-chart-widget',
|
|
133
|
+
template,
|
|
134
|
+
}]
|
|
135
|
+
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
136
|
+
type: ViewChild,
|
|
137
|
+
args: [rootId]
|
|
138
|
+
}], chartType: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], dataSource: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], dataOptions: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], filters: [{
|
|
145
|
+
type: Input
|
|
146
|
+
}], highlights: [{
|
|
147
|
+
type: Input
|
|
148
|
+
}], styleOptions: [{
|
|
149
|
+
type: Input
|
|
150
|
+
}], drilldownOptions: [{
|
|
151
|
+
type: Input
|
|
152
|
+
}], title: [{
|
|
153
|
+
type: Input
|
|
154
|
+
}], description: [{
|
|
155
|
+
type: Input
|
|
156
|
+
}], highlightSelectionDisabled: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], beforeRender: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}], dataPointClick: [{
|
|
161
|
+
type: Output
|
|
162
|
+
}], dataPointContextMenu: [{
|
|
163
|
+
type: Output
|
|
164
|
+
}], dataPointsSelect: [{
|
|
165
|
+
type: Output
|
|
166
|
+
}] } });
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/chart-widget.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  ChartWidget,\n  type ChartWidgetProps,\n  ComponentAdapter,\n  createElement,\n} from '@sisense/sdk-ui-preact';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments, ArgumentsAsObject } from '../../types/utility-types';\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { template, rootId } from '../../component-wrapper-helpers/template';\n\n/**\n * The Chart Widget component extending {@link ChartComponent} to support widget style options.\n *\n * @example\n * ```html\n * <csdk-chart-widget\n *   [chartType]=\"chartWidget.chartType\"\n *   [dataSource]=\"chartWidget.dataSource\"\n *   [dataOptions]=\"chartWidget.dataOptions\"\n *   [highlights]=\"filters\"\n *   [title]=\"chartWidget.title\"\n *   [description]=\"chartWidget.description\"\n *   [beforeRender]=\"onBeforeRender\"\n *   (dataPointClick)=\"logArguments($event)\"\n *   (dataPointContextMenu)=\"logArguments($event)\"\n *   (dataPointsSelect)=\"logArguments($event)\"\n * />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { ChartType } from '@sisense/sdk-ui-angular';\n * import { filterFactory } from '@sisense/sdk-data';\n * import * as DM from '../../assets/sample-healthcare-model';\n *\n * @Component({\n *   selector: 'app-widgets',\n *   templateUrl: './widgets.component.html',\n *   styleUrls: ['./widgets.component.scss'],\n * })\n * export class WidgetsComponent {\n *   filters = [filterFactory.members(DM.Divisions.Divison_name, ['Cardiology', 'Neurology'])];\n *   chartWidget = {\n *     chartType: 'column' as ChartType,\n *     dataSource: DM.DataSource,\n *     dataOptions: {\n *       category: [DM.Divisions.Divison_name],\n *       value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],\n *       breakBy: [],\n *     },\n *     title: 'Chart Title',\n *     description: 'Chart Description',\n *   };\n *  logArguments(...args: any[]) {\n *   console.log(args);\n * }\n *\n * onBeforeRender(options: any) {\n *   console.log('beforeRender');\n *   console.log(options);\n *   return options;\n * }\n *\n * }\n * ```\n * <img src=\"media://angular-chart-widget-example.png\" width=\"800px\" />\n *\n * @group Chart Utilities\n */\n@Component({\n  selector: 'csdk-chart-widget',\n  template,\n})\nexport class ChartWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.chartType}\n   *\n   * @category Chart\n   */\n  @Input()\n  chartType!: ChartWidgetProps['chartType'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataSource}\n   *\n   * @category Data\n   */\n  @Input()\n  dataSource: ChartWidgetProps['dataSource'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.dataOptions}\n   *\n   * @category Chart\n   */\n  @Input()\n  dataOptions!: ChartWidgetProps['dataOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: ChartWidgetProps['filters'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlights}\n   *\n   * @category Data\n   */\n  @Input()\n  highlights: ChartWidgetProps['highlights'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: ChartWidgetProps['styleOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.drilldownOptions}\n   *\n   * @category Widget\n   * @internal\n   */\n  @Input()\n  drilldownOptions: ChartWidgetProps['drilldownOptions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.title}\n   *\n   * @category Widget\n   */\n  @Input()\n  title: ChartWidgetProps['title'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.description}\n   *\n   * @category Widget\n   */\n  @Input()\n  description: ChartWidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartWidgetProps.highlightSelectionDisabled}\n   *\n   * @category Widget\n   */\n  @Input()\n  highlightSelectionDisabled: ChartWidgetProps['highlightSelectionDisabled'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartProps.onBeforeRender}\n   *\n   * @category Callbacks\n   */\n  @Input()\n  beforeRender: ChartWidgetProps['onBeforeRender'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartProps.onDataPointClick}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointClick = new EventEmitter<\n    ArgumentsAsObject<ChartWidgetProps['onDataPointClick'], ['point', 'nativeEvent']>\n  >();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartProps.onDataPointContextMenu}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointContextMenu = new EventEmitter<\n    ArgumentsAsObject<ChartWidgetProps['onDataPointContextMenu'], ['point', 'nativeEvent']>\n  >();\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartProps.onDataPointsSelected}\n   *\n   * @category Callbacks\n   */\n  @Output()\n  dataPointsSelect = new EventEmitter<\n    ArgumentsAsObject<ChartWidgetProps['onDataPointsSelected'], ['points', 'nativeEvent']>\n  >();\n\n  private componentAdapter: ComponentAdapter;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(\n      () => this.createPreactComponent(),\n      [\n        createSisenseContextConnector(this.sisenseContextService),\n        createThemeContextConnector(this.themeService),\n      ],\n    );\n  }\n\n  /** @internal */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement);\n  }\n\n  /** @internal */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement);\n    }\n  }\n\n  private createPreactComponent() {\n    const props = {\n      chartType: this.chartType,\n      dataSource: this.dataSource,\n      dataOptions: this.dataOptions,\n      filters: this.filters,\n      highlights: this.highlights,\n      styleOptions: this.styleOptions,\n      drilldownOptions: this.drilldownOptions,\n      title: this.title,\n      description: this.description,\n      highlightSelectionDisabled: this.highlightSelectionDisabled,\n      onBeforeRender: this.beforeRender?.bind(this),\n      onDataPointClick: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetProps['onDataPointClick']>\n      ) => this.dataPointClick.emit({ point, nativeEvent }),\n      onDataPointContextMenu: (\n        ...[point, nativeEvent]: Arguments<ChartWidgetProps['onDataPointContextMenu']>\n      ) => this.dataPointContextMenu.emit({ point, nativeEvent }),\n      onDataPointsSelected: (\n        ...[points, nativeEvent]: Arguments<ChartWidgetProps['onDataPointsSelected']>\n      ) => this.dataPointsSelect.emit({ points, nativeEvent }),\n    };\n\n    return createElement(ChartWidget, props);\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { Component, Input, ViewChild, } from '@angular/core';
|
|
2
|
+
import { DashboardWidget, ComponentAdapter, createElement, } from '@sisense/sdk-ui-preact';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
+
import { template, rootId } from '../../component-wrapper-helpers/template';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/sisense-context.service";
|
|
7
|
+
import * as i2 from "../../services/theme.service";
|
|
8
|
+
/**
|
|
9
|
+
* The Dashboard Widget component, which is a thin wrapper on {@link ChartWidgetComponent},
|
|
10
|
+
* is used to render a widget created in a Sisense Fusion instance.
|
|
11
|
+
*
|
|
12
|
+
* To learn more about using Sisense Fusion Widgets in Compose SDK, see
|
|
13
|
+
* [Sisense Fusion Widgets](https://sisense.dev/guides/sdk/guides/charts/guide-fusion-widgets.html).
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```html
|
|
17
|
+
* <csdk-dashboard-widget
|
|
18
|
+
* [widgetOid]="widgetOid"
|
|
19
|
+
* [dashboardOid]="dashboardOid"
|
|
20
|
+
* [includeDashboardFilters]="true"
|
|
21
|
+
* />
|
|
22
|
+
* ```
|
|
23
|
+
* ```ts
|
|
24
|
+
* import { Component } from '@angular/core';
|
|
25
|
+
* import { ChartType } from '@sisense/sdk-ui-angular';
|
|
26
|
+
* import { filterFactory, measureFactory } from '@sisense/sdk-data';
|
|
27
|
+
* import * as DM from '../../assets/sample-healthcare-model';
|
|
28
|
+
*
|
|
29
|
+
* @Component({
|
|
30
|
+
* selector: 'app-widgets',
|
|
31
|
+
* templateUrl: './widgets.component.html',
|
|
32
|
+
* styleUrls: ['./widgets.component.scss'],
|
|
33
|
+
* })
|
|
34
|
+
* export class WidgetsComponent {
|
|
35
|
+
* widgetOid: string = '60f3e3e3e4b0e3e3e4b0e3e3';
|
|
36
|
+
* dashboardOid: string = '60f3e3e3e4b0e3e3e4b0e3e3';
|
|
37
|
+
* ```
|
|
38
|
+
* @group Fusion Embed
|
|
39
|
+
* @fusionEmbed
|
|
40
|
+
*/
|
|
41
|
+
export class DashboardWidgetComponent {
|
|
42
|
+
constructor(sisenseContextService, themeService) {
|
|
43
|
+
this.sisenseContextService = sisenseContextService;
|
|
44
|
+
this.themeService = themeService;
|
|
45
|
+
this.componentAdapter = new ComponentAdapter(() => this.createPreactComponent(), [
|
|
46
|
+
createSisenseContextConnector(this.sisenseContextService),
|
|
47
|
+
createThemeContextConnector(this.themeService),
|
|
48
|
+
]);
|
|
49
|
+
}
|
|
50
|
+
/** @internal */
|
|
51
|
+
ngAfterViewInit() {
|
|
52
|
+
this.componentAdapter.render(this.preactRef.nativeElement);
|
|
53
|
+
}
|
|
54
|
+
/** @internal */
|
|
55
|
+
ngOnChanges() {
|
|
56
|
+
if (this.preactRef) {
|
|
57
|
+
this.componentAdapter.render(this.preactRef.nativeElement);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
/** @internal */
|
|
61
|
+
createPreactComponent() {
|
|
62
|
+
const props = {
|
|
63
|
+
widgetOid: this.widgetOid,
|
|
64
|
+
dashboardOid: this.dashboardOid,
|
|
65
|
+
filters: this.filters,
|
|
66
|
+
highlights: this.highlights,
|
|
67
|
+
filtersMergeStrategy: this.filtersMergeStrategy,
|
|
68
|
+
includeDashboardFilters: this.includeDashboardFilters,
|
|
69
|
+
title: this.title,
|
|
70
|
+
description: this.description,
|
|
71
|
+
styleOptions: this.styleOptions,
|
|
72
|
+
highlightSelectionDisabled: this.highlightSelectionDisabled,
|
|
73
|
+
drilldownOptions: this.drilldownOptions,
|
|
74
|
+
};
|
|
75
|
+
return createElement(DashboardWidget, props);
|
|
76
|
+
}
|
|
77
|
+
/** @internal */
|
|
78
|
+
ngOnDestroy() {
|
|
79
|
+
this.componentAdapter.destroy();
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
DashboardWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
83
|
+
DashboardWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DashboardWidgetComponent, selector: "csdk-dashboard-widget", inputs: { widgetOid: "widgetOid", dashboardOid: "dashboardOid", filters: "filters", highlights: "highlights", filtersMergeStrategy: "filtersMergeStrategy", includeDashboardFilters: "includeDashboardFilters", title: "title", description: "description", styleOptions: "styleOptions", highlightSelectionDisabled: "highlightSelectionDisabled", drilldownOptions: "drilldownOptions" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact style=\"width: 100%; height: 100%\"></div>\n", isInline: true });
|
|
84
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DashboardWidgetComponent, decorators: [{
|
|
85
|
+
type: Component,
|
|
86
|
+
args: [{
|
|
87
|
+
selector: 'csdk-dashboard-widget',
|
|
88
|
+
template,
|
|
89
|
+
}]
|
|
90
|
+
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
91
|
+
type: ViewChild,
|
|
92
|
+
args: [rootId]
|
|
93
|
+
}], widgetOid: [{
|
|
94
|
+
type: Input
|
|
95
|
+
}], dashboardOid: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}], filters: [{
|
|
98
|
+
type: Input
|
|
99
|
+
}], highlights: [{
|
|
100
|
+
type: Input
|
|
101
|
+
}], filtersMergeStrategy: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}], includeDashboardFilters: [{
|
|
104
|
+
type: Input
|
|
105
|
+
}], title: [{
|
|
106
|
+
type: Input
|
|
107
|
+
}], description: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], styleOptions: [{
|
|
110
|
+
type: Input
|
|
111
|
+
}], highlightSelectionDisabled: [{
|
|
112
|
+
type: Input
|
|
113
|
+
}], drilldownOptions: [{
|
|
114
|
+
type: Input
|
|
115
|
+
}] } });
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dashboard-widget.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/widgets/dashboard-widget.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,eAAe,EAEf,gBAAgB,EAChB,aAAa,GACd,MAAM,wBAAwB,CAAC;AAGhC,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,GAC5B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,0CAA0C,CAAC;;;;AAE5E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AAKH,MAAM,OAAO,wBAAwB;IAmDnC,YACU,qBAA4C,EAC5C,YAA0B;QAD1B,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,iBAAY,GAAZ,YAAY,CAAc;QAElC,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAC1C,GAAG,EAAE,CAAC,IAAI,CAAC,qBAAqB,EAAE,EAClC;YACE,6BAA6B,CAAC,IAAI,CAAC,qBAAqB,CAAC;YACzD,2BAA2B,CAAC,IAAI,CAAC,YAAY,CAAC;SAC/C,CACF,CAAC;IACJ,CAAC;IAED,gBAAgB;IAChB,eAAe;QACb,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;IAC7D,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;SAC5D;IACH,CAAC;IAED,gBAAgB;IACR,qBAAqB;QAC3B,MAAM,KAAK,GAAG;YACZ,SAAS,EAAE,IAAI,CAAC,SAAS;YACzB,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;YAC/C,uBAAuB,EAAE,IAAI,CAAC,uBAAuB;YACrD,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,YAAY,EAAE,IAAI,CAAC,YAAY;YAC/B,0BAA0B,EAAE,IAAI,CAAC,0BAA0B;YAC3D,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;SACxC,CAAC;QAEF,OAAO,aAAa,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;IAC/C,CAAC;IAED,gBAAgB;IAChB,WAAW;QACT,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;IAClC,CAAC;;sHAlGU,wBAAwB;0GAAxB,wBAAwB;4FAAxB,wBAAwB;kBAJpC,SAAS;mBAAC;oBACT,QAAQ,EAAE,uBAAuB;oBACjC,QAAQ;iBACT;uIAIC,SAAS;sBADR,SAAS;uBAAC,MAAM;gBAIjB,SAAS;sBADR,KAAK;gBAIN,YAAY;sBADX,KAAK;gBASN,OAAO;sBADN,KAAK;gBAIN,UAAU;sBADT,KAAK;gBAIN,oBAAoB;sBADnB,KAAK;gBAIN,uBAAuB;sBADtB,KAAK;gBAIN,KAAK;sBADJ,KAAK;gBAIN,WAAW;sBADV,KAAK;gBASN,YAAY;sBADX,KAAK;gBAIN,0BAA0B;sBADzB,KAAK;gBAKN,gBAAgB;sBADf,KAAK","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  ElementRef,\n  Input,\n  OnChanges,\n  OnDestroy,\n  ViewChild,\n} from '@angular/core';\nimport {\n  DashboardWidget,\n  type DashboardWidgetProps,\n  ComponentAdapter,\n  createElement,\n} from '@sisense/sdk-ui-preact';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport { template, rootId } from '../../component-wrapper-helpers/template';\n\n/**\n * The Dashboard Widget component, which is a thin wrapper on {@link ChartWidgetComponent},\n * is used to render a widget created in a Sisense Fusion instance.\n *\n * To learn more about using Sisense Fusion Widgets in Compose SDK, see\n * [Sisense Fusion Widgets](https://sisense.dev/guides/sdk/guides/charts/guide-fusion-widgets.html).\n *\n * @example\n * ```html\n * <csdk-dashboard-widget\n *    [widgetOid]=\"widgetOid\"\n *    [dashboardOid]=\"dashboardOid\"\n *    [includeDashboardFilters]=\"true\"\n * />\n * ```\n * ```ts\n * import { Component } from '@angular/core';\n * import { ChartType } from '@sisense/sdk-ui-angular';\n * import { filterFactory, measureFactory } 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 *  widgetOid: string = '60f3e3e3e4b0e3e3e4b0e3e3';\n *  dashboardOid: string = '60f3e3e3e4b0e3e3e4b0e3e3';\n * ```\n * @group Fusion Embed\n * @fusionEmbed\n */\n@Component({\n  selector: 'csdk-dashboard-widget',\n  template,\n})\nexport class DashboardWidgetComponent implements AfterViewInit, OnChanges, OnDestroy {\n  /** @internal */\n  @ViewChild(rootId)\n  preactRef!: ElementRef<HTMLDivElement>;\n\n  @Input()\n  widgetOid!: DashboardWidgetProps['widgetOid'];\n\n  @Input()\n  dashboardOid!: DashboardWidgetProps['dashboardOid'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!ChartProps.filters}\n   *\n   * @category Data\n   */\n  @Input()\n  filters: DashboardWidgetProps['filters'];\n\n  @Input()\n  highlights: DashboardWidgetProps['highlights'];\n\n  @Input()\n  filtersMergeStrategy: DashboardWidgetProps['filtersMergeStrategy'];\n\n  @Input()\n  includeDashboardFilters: DashboardWidgetProps['includeDashboardFilters'];\n\n  @Input()\n  title: DashboardWidgetProps['title'];\n\n  @Input()\n  description: DashboardWidgetProps['description'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DashboardWidgetProps.styleOptions}\n   *\n   * @category Widget\n   */\n  @Input()\n  styleOptions: DashboardWidgetProps['styleOptions'];\n\n  @Input()\n  highlightSelectionDisabled: DashboardWidgetProps['highlightSelectionDisabled'];\n\n  /** @internal */\n  @Input()\n  drilldownOptions: DashboardWidgetProps['drilldownOptions'];\n\n  private componentAdapter: ComponentAdapter;\n\n  constructor(\n    private sisenseContextService: SisenseContextService,\n    private themeService: ThemeService,\n  ) {\n    this.componentAdapter = new ComponentAdapter(\n      () => this.createPreactComponent(),\n      [\n        createSisenseContextConnector(this.sisenseContextService),\n        createThemeContextConnector(this.themeService),\n      ],\n    );\n  }\n\n  /** @internal */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement);\n  }\n\n  /** @internal */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement);\n    }\n  }\n\n  /** @internal */\n  private createPreactComponent() {\n    const props = {\n      widgetOid: this.widgetOid,\n      dashboardOid: this.dashboardOid,\n      filters: this.filters,\n      highlights: this.highlights,\n      filtersMergeStrategy: this.filtersMergeStrategy,\n      includeDashboardFilters: this.includeDashboardFilters,\n      title: this.title,\n      description: this.description,\n      styleOptions: this.styleOptions,\n      highlightSelectionDisabled: this.highlightSelectionDisabled,\n      drilldownOptions: this.drilldownOptions,\n    };\n\n    return createElement(DashboardWidget, props);\n  }\n\n  /** @internal */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { ComponentAdapter, createElement, DrilldownWidget, createWrapperElement, createWrapperElementHandler, createComponentRenderer, } from '@sisense/sdk-ui-preact';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
+
import { templateWithContent, rootId, rootContentId, } from '../../component-wrapper-helpers/template';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/sisense-context.service";
|
|
7
|
+
import * as i2 from "../../services/theme.service";
|
|
8
|
+
/**
|
|
9
|
+
* An Angular component designed to add drilldown functionality to any type of chart.
|
|
10
|
+
*
|
|
11
|
+
* It acts as a wrapper around a given chart component, enhancing it with drilldown capabilities
|
|
12
|
+
*
|
|
13
|
+
* The widget offers several features including:
|
|
14
|
+
* - A context menu for initiating drilldown actions (can be provided as a custom component)
|
|
15
|
+
* - Breadcrumbs that not only allow for drilldown selection slicing but also
|
|
16
|
+
* provide an option to clear the selection (can be provided as a custom component)
|
|
17
|
+
* - Filters specifically created for drilldown operation
|
|
18
|
+
* - An option to navigate to the next drilldown dimension
|
|
19
|
+
*
|
|
20
|
+
* When an `initialDimension` is specified, the `drilldownDimension` will automatically inherit its value,
|
|
21
|
+
* even before any points on the chart are selected.
|
|
22
|
+
* This allows for complete control over the chart's dimensions to be handed over to the DrilldownWidget
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* An example of using the `csdk-drilldown-widget` component to plot a `csdk-column-chart`
|
|
26
|
+
* over the Sample Healthcare data source hosted in a Sisense instance:
|
|
27
|
+
* ```ts
|
|
28
|
+
* // Component behavior in .component.ts
|
|
29
|
+
* chart = {
|
|
30
|
+
* dataOptions: {
|
|
31
|
+
* category: [DM.Divisions.Divison_name],
|
|
32
|
+
* value: [measureFactory.sum(DM.Admissions.Cost_of_admission)],
|
|
33
|
+
* breakBy: [],
|
|
34
|
+
* },
|
|
35
|
+
* dataPointContextMenu: ({ point, nativeEvent }: { point: any; nativeEvent: MouseEvent }) => {
|
|
36
|
+
* this.drilldownResult?.onDataPointsSelected?.([point], nativeEvent);
|
|
37
|
+
* this.drilldownResult?.onContextMenu({
|
|
38
|
+
* left: nativeEvent.clientX,
|
|
39
|
+
* top: nativeEvent.clientY,
|
|
40
|
+
* });
|
|
41
|
+
* }
|
|
42
|
+
* }
|
|
43
|
+
*
|
|
44
|
+
* drilldownResult?: CustomDrilldownResult;
|
|
45
|
+
*
|
|
46
|
+
* drilldown = {
|
|
47
|
+
* drilldownDimensions: [DM.Patients.Gender, DM.Admissions.Surgical_Procedure],
|
|
48
|
+
* initialDimension: DM.Divisions.Divison_name,
|
|
49
|
+
* drilldownChange: (drilldownResult: CustomDrilldownResult) => {
|
|
50
|
+
* this.drilldownResult = drilldownResult;
|
|
51
|
+
* this.chart.dataOptions = {
|
|
52
|
+
* ...this.chart.dataOptions,
|
|
53
|
+
* category: [drilldownResult.drilldownDimension]
|
|
54
|
+
* }
|
|
55
|
+
* }
|
|
56
|
+
* };
|
|
57
|
+
* ```
|
|
58
|
+
* ```html
|
|
59
|
+
* <!--Component HTML template in .component.html-->
|
|
60
|
+
* <csdk-drilldown-widget
|
|
61
|
+
* [drilldownDimensions]="drilldown.drilldownDimensions"
|
|
62
|
+
* [initialDimension]="drilldown.initialDimension"
|
|
63
|
+
* (drilldownResultChange)="drilldown.drilldownChange($event)"
|
|
64
|
+
* >
|
|
65
|
+
* <csdk-column-chart
|
|
66
|
+
* [dataSet]="DM.DataSource"
|
|
67
|
+
* [dataOptions]="chart.dataOptions"
|
|
68
|
+
* [filters]="drilldownResult?.drilldownFilters || []"
|
|
69
|
+
* (dataPointContextMenu)="chart.dataPointContextMenu($event)"
|
|
70
|
+
* />
|
|
71
|
+
* </csdk-drilldown-widget>
|
|
72
|
+
* ```
|
|
73
|
+
* <img src="media://angular-drilldown-widget-example.png" width="800px" />
|
|
74
|
+
*
|
|
75
|
+
* @group Drilldown
|
|
76
|
+
*/
|
|
77
|
+
export class DrilldownWidgetComponent {
|
|
78
|
+
/**
|
|
79
|
+
* Constructor for the `DrilldownWidgetComponent`.
|
|
80
|
+
*
|
|
81
|
+
* @param sisenseContextService - Sisense context service
|
|
82
|
+
* @param themeService - Theme service
|
|
83
|
+
*/
|
|
84
|
+
constructor(
|
|
85
|
+
/**
|
|
86
|
+
* Sisense context service
|
|
87
|
+
*
|
|
88
|
+
* @category Constructor
|
|
89
|
+
*/
|
|
90
|
+
sisenseContextService,
|
|
91
|
+
/**
|
|
92
|
+
* Theme service
|
|
93
|
+
*
|
|
94
|
+
* @category Constructor
|
|
95
|
+
*/
|
|
96
|
+
themeService) {
|
|
97
|
+
this.sisenseContextService = sisenseContextService;
|
|
98
|
+
this.themeService = themeService;
|
|
99
|
+
this.drilldownResultChange = new EventEmitter();
|
|
100
|
+
this.componentAdapter = new ComponentAdapter(() => this.createPreactComponent(), [
|
|
101
|
+
createSisenseContextConnector(this.sisenseContextService),
|
|
102
|
+
createThemeContextConnector(this.themeService),
|
|
103
|
+
]);
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* @internal
|
|
107
|
+
*/
|
|
108
|
+
ngAfterViewInit() {
|
|
109
|
+
this.componentAdapter.render(this.preactRef.nativeElement);
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* @internal
|
|
113
|
+
*/
|
|
114
|
+
ngOnChanges() {
|
|
115
|
+
if (this.preactRef) {
|
|
116
|
+
this.componentAdapter.render(this.preactRef.nativeElement);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
createPreactComponent() {
|
|
120
|
+
const props = {
|
|
121
|
+
drilldownDimensions: this.drilldownDimensions,
|
|
122
|
+
initialDimension: this.initialDimension,
|
|
123
|
+
config: {
|
|
124
|
+
...this.config,
|
|
125
|
+
...(this.config?.breadcrumbsComponent && {
|
|
126
|
+
breadcrumbsComponent: createWrapperElementHandler(this.config.breadcrumbsComponent),
|
|
127
|
+
}),
|
|
128
|
+
...(this.config?.contextMenuComponent && {
|
|
129
|
+
contextMenuComponent: (contextMenuProps) => createWrapperElement(this.config.contextMenuComponent(contextMenuProps)),
|
|
130
|
+
}),
|
|
131
|
+
},
|
|
132
|
+
};
|
|
133
|
+
return createElement(DrilldownWidget, props, (customDrilldownResult) => {
|
|
134
|
+
const { breadcrumbsComponent } = customDrilldownResult;
|
|
135
|
+
this.drilldownResultChange.emit({
|
|
136
|
+
...customDrilldownResult,
|
|
137
|
+
...(breadcrumbsComponent && {
|
|
138
|
+
breadcrumbsComponent: { render: createComponentRenderer(breadcrumbsComponent) },
|
|
139
|
+
}),
|
|
140
|
+
});
|
|
141
|
+
return createWrapperElement(this.preactContentRef.nativeElement);
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* @internal
|
|
146
|
+
*/
|
|
147
|
+
ngOnDestroy() {
|
|
148
|
+
this.componentAdapter.destroy();
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
DrilldownWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DrilldownWidgetComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
152
|
+
DrilldownWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DrilldownWidgetComponent, selector: "csdk-drilldown-widget", inputs: { drilldownDimensions: "drilldownDimensions", initialDimension: "initialDimension", config: "config" }, outputs: { drilldownResultChange: "drilldownResultChange" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }, { propertyName: "preactContentRef", first: true, predicate: ["preactContent"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact style=\"width: 100%; height: 100%\">\n <div #preactContent style=\"width: 100%; height: 100%\">\n <ng-content></ng-content>\n </div>\n </div>\n", isInline: true });
|
|
153
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DrilldownWidgetComponent, decorators: [{
|
|
154
|
+
type: Component,
|
|
155
|
+
args: [{
|
|
156
|
+
selector: 'csdk-drilldown-widget',
|
|
157
|
+
template: templateWithContent,
|
|
158
|
+
}]
|
|
159
|
+
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
160
|
+
type: ViewChild,
|
|
161
|
+
args: [rootId]
|
|
162
|
+
}], preactContentRef: [{
|
|
163
|
+
type: ViewChild,
|
|
164
|
+
args: [rootContentId]
|
|
165
|
+
}], drilldownDimensions: [{
|
|
166
|
+
type: Input
|
|
167
|
+
}], initialDimension: [{
|
|
168
|
+
type: Input
|
|
169
|
+
}], config: [{
|
|
170
|
+
type: Input
|
|
171
|
+
}], drilldownResultChange: [{
|
|
172
|
+
type: Output
|
|
173
|
+
}] } });
|
|
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  createElement,\n  DrilldownWidget,\n  type DrilldownWidgetProps,\n  type ContextMenuProps,\n  type CustomDrilldownResult as CustomDrilldownResultBase,\n  type ComponentRenderer,\n  DrilldownBreadcrumbsProps,\n  createWrapperElement,\n  createWrapperElementHandler,\n  createComponentRenderer,\n} from '@sisense/sdk-ui-preact';\nimport { SisenseContextService } from '../../services/sisense-context.service';\nimport { ThemeService } from '../../services/theme.service';\nimport type { Arguments } from '../../types/utility-types';\nimport {\n  createSisenseContextConnector,\n  createThemeContextConnector,\n} from '../../component-wrapper-helpers';\nimport {\n  templateWithContent,\n  rootId,\n  rootContentId,\n} from '../../component-wrapper-helpers/template';\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 *   drilldownDimensions: [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 *   [drilldownDimensions]=\"drilldown.drilldownDimensions\"\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 *\n * @group Drilldown\n */\n@Component({\n  selector: 'csdk-drilldown-widget',\n  template: templateWithContent,\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.drilldownDimensions}\n   */\n  @Input()\n  drilldownDimensions!: DrilldownWidgetProps['drilldownDimensions'];\n\n  /**\n   * {@inheritDoc @sisense/sdk-ui!DrilldownWidgetProps.initialDimension}\n   */\n  @Input()\n  initialDimension!: DrilldownWidgetProps['initialDimension'];\n\n  @Input()\n  config?: Omit<DrilldownWidgetProps['config'], 'breadcrumbsComponent | contextMenuComponent'> & {\n    breadcrumbsComponent?: (drilldownBreadcrumbsProps: DrilldownBreadcrumbsProps) => HTMLDivElement;\n    contextMenuComponent?: (contextMenuProps: ContextMenuProps) => HTMLDivElement;\n  };\n\n  @Output()\n  drilldownResultChange = new EventEmitter<CustomDrilldownResult>();\n\n  private componentAdapter: ComponentAdapter;\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(\n      () => this.createPreactComponent(),\n      [\n        createSisenseContextConnector(this.sisenseContextService),\n        createThemeContextConnector(this.themeService),\n      ],\n    );\n  }\n\n  /**\n   * @internal\n   */\n  ngAfterViewInit() {\n    this.componentAdapter.render(this.preactRef.nativeElement);\n  }\n\n  /**\n   * @internal\n   */\n  ngOnChanges() {\n    if (this.preactRef) {\n      this.componentAdapter.render(this.preactRef.nativeElement);\n    }\n  }\n\n  private createPreactComponent() {\n    const props = {\n      drilldownDimensions: this.drilldownDimensions,\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    } as DrilldownWidgetProps;\n\n    return createElement(\n      DrilldownWidget,\n      props,\n      (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    );\n  }\n\n  /**\n   * @internal\n   */\n  ngOnDestroy() {\n    this.componentAdapter.destroy();\n  }\n}\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './table-widget.component';
|
|
2
|
+
export * from './dashboard-widget.component';
|
|
3
|
+
export * from './drilldown-widget.component';
|
|
4
|
+
export * from './chart-widget.component';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvd2lkZ2V0cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90YWJsZS13aWRnZXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZGFzaGJvYXJkLXdpZGdldC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9kcmlsbGRvd24td2lkZ2V0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NoYXJ0LXdpZGdldC5jb21wb25lbnQnO1xuIl19
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { Component, Input, ViewChild, } from '@angular/core';
|
|
2
|
+
import { TableWidget, ComponentAdapter, createElement, } from '@sisense/sdk-ui-preact';
|
|
3
|
+
import { createSisenseContextConnector, createThemeContextConnector, } from '../../component-wrapper-helpers';
|
|
4
|
+
import { template, rootId } from '../../component-wrapper-helpers/template';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../../services/sisense-context.service";
|
|
7
|
+
import * as i2 from "../../services/theme.service";
|
|
8
|
+
/**
|
|
9
|
+
* The Table Widget component extending {@link TableComponent} component to support widget style options.
|
|
10
|
+
*
|
|
11
|
+
* @example
|
|
12
|
+
* ```html
|
|
13
|
+
* <csdk-table-widget
|
|
14
|
+
* [dataSource]="table.dataSet"
|
|
15
|
+
* [dataOptions]="table.dataOptions"
|
|
16
|
+
* [filters]="filters"
|
|
17
|
+
* [title]="table.title"
|
|
18
|
+
* [description]="table.description"
|
|
19
|
+
* />
|
|
20
|
+
* ```
|
|
21
|
+
* ```ts
|
|
22
|
+
* import { Component } from '@angular/core';
|
|
23
|
+
* import { ChartType } from '@sisense/sdk-ui-angular';
|
|
24
|
+
* import { filterFactory, measureFactory } from '@sisense/sdk-data';
|
|
25
|
+
* import * as DM from '../../assets/sample-healthcare-model';
|
|
26
|
+
*
|
|
27
|
+
* @Component({
|
|
28
|
+
* selector: 'app-widgets',
|
|
29
|
+
* templateUrl: './widgets.component.html',
|
|
30
|
+
* styleUrls: ['./widgets.component.scss'],
|
|
31
|
+
* })
|
|
32
|
+
* export class WidgetsComponent {
|
|
33
|
+
* filters = [filterFactory.members(DM.Divisions.Divison_name, ['Cardiology', 'Neurology'])];
|
|
34
|
+
*
|
|
35
|
+
* table = {
|
|
36
|
+
* dataSet: DM.DataSource,
|
|
37
|
+
* dataOptions: {
|
|
38
|
+
* columns: [DM.Admissions.Patient_ID, measureFactory.sum(DM.Admissions.Cost_of_admission)],
|
|
39
|
+
* }
|
|
40
|
+
* title: 'Widget Title',
|
|
41
|
+
* description: 'Widget Description',
|
|
42
|
+
* };
|
|
43
|
+
* }
|
|
44
|
+
* ```
|
|
45
|
+
* <img src="media://angular-table-widget-example.png" width="800px" />
|
|
46
|
+
* @internal
|
|
47
|
+
*/
|
|
48
|
+
export class TableWidgetComponent {
|
|
49
|
+
constructor(sisenseContextService, themeService) {
|
|
50
|
+
this.sisenseContextService = sisenseContextService;
|
|
51
|
+
this.themeService = themeService;
|
|
52
|
+
this.componentAdapter = new ComponentAdapter(() => this.createPreactComponent(), [
|
|
53
|
+
createSisenseContextConnector(this.sisenseContextService),
|
|
54
|
+
createThemeContextConnector(this.themeService),
|
|
55
|
+
]);
|
|
56
|
+
}
|
|
57
|
+
ngAfterViewInit() {
|
|
58
|
+
this.componentAdapter.render(this.preactRef.nativeElement);
|
|
59
|
+
}
|
|
60
|
+
ngOnChanges() {
|
|
61
|
+
if (this.preactRef) {
|
|
62
|
+
this.componentAdapter.render(this.preactRef.nativeElement);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
createPreactComponent() {
|
|
66
|
+
const props = {
|
|
67
|
+
dataSource: this.dataSource,
|
|
68
|
+
dataOptions: this.dataOptions,
|
|
69
|
+
filters: this.filters,
|
|
70
|
+
styleOptions: this.styleOptions,
|
|
71
|
+
title: this.title,
|
|
72
|
+
description: this.description,
|
|
73
|
+
};
|
|
74
|
+
return createElement(TableWidget, props);
|
|
75
|
+
}
|
|
76
|
+
ngOnDestroy() {
|
|
77
|
+
this.componentAdapter.destroy();
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
TableWidgetComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TableWidgetComponent, deps: [{ token: i1.SisenseContextService }, { token: i2.ThemeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
81
|
+
TableWidgetComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TableWidgetComponent, selector: "csdk-table-widget", inputs: { dataSource: "dataSource", dataOptions: "dataOptions", filters: "filters", styleOptions: "styleOptions", title: "title", description: "description" }, viewQueries: [{ propertyName: "preactRef", first: true, predicate: ["preact"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\n <div #preact style=\"width: 100%; height: 100%\"></div>\n", isInline: true });
|
|
82
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TableWidgetComponent, decorators: [{
|
|
83
|
+
type: Component,
|
|
84
|
+
args: [{
|
|
85
|
+
selector: 'csdk-table-widget',
|
|
86
|
+
template,
|
|
87
|
+
}]
|
|
88
|
+
}], ctorParameters: function () { return [{ type: i1.SisenseContextService }, { type: i2.ThemeService }]; }, propDecorators: { preactRef: [{
|
|
89
|
+
type: ViewChild,
|
|
90
|
+
args: [rootId]
|
|
91
|
+
}], dataSource: [{
|
|
92
|
+
type: Input
|
|
93
|
+
}], dataOptions: [{
|
|
94
|
+
type: Input
|
|
95
|
+
}], filters: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}], styleOptions: [{
|
|
98
|
+
type: Input
|
|
99
|
+
}], title: [{
|
|
100
|
+
type: Input
|
|
101
|
+
}], description: [{
|
|
102
|
+
type: Input
|
|
103
|
+
}] } });
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtd2lkZ2V0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy93aWRnZXRzL3RhYmxlLXdpZGdldC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxLQUFLLEVBR0wsU0FBUyxHQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFDTCxXQUFXLEVBRVgsZ0JBQWdCLEVBQ2hCLGFBQWEsR0FDZCxNQUFNLHdCQUF3QixDQUFDO0FBR2hDLE9BQU8sRUFDTCw2QkFBNkIsRUFDN0IsMkJBQTJCLEdBQzVCLE1BQU0saUNBQWlDLENBQUM7QUFDekMsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQzs7OztBQUU1RTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBdUNHO0FBS0gsTUFBTSxPQUFPLG9CQUFvQjtJQXVEL0IsWUFDVSxxQkFBNEMsRUFDNUMsWUFBMEI7UUFEMUIsMEJBQXFCLEdBQXJCLHFCQUFxQixDQUF1QjtRQUM1QyxpQkFBWSxHQUFaLFlBQVksQ0FBYztRQUVsQyxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxnQkFBZ0IsQ0FDMUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLHFCQUFxQixFQUFFLEVBQ2xDO1lBQ0UsNkJBQTZCLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDO1lBQ3pELDJCQUEyQixDQUFDLElBQUksQ0FBQyxZQUFZLENBQUM7U0FDL0MsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxDQUFDO1NBQzVEO0lBQ0gsQ0FBQztJQUVPLHFCQUFxQjtRQUMzQixNQUFNLEtBQUssR0FBRztZQUNaLFVBQVUsRUFBRSxJQUFJLENBQUMsVUFBVTtZQUMzQixXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDN0IsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO1lBQ3JCLFlBQVksRUFBRSxJQUFJLENBQUMsWUFBWTtZQUMvQixLQUFLLEVBQUUsSUFBSSxDQUFDLEtBQUs7WUFDakIsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO1NBQzlCLENBQUM7UUFFRixPQUFPLGFBQWEsQ0FBQyxXQUFXLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDbEMsQ0FBQzs7a0hBN0ZVLG9CQUFvQjtzR0FBcEIsb0JBQW9COzRGQUFwQixvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG1CQUFtQjtvQkFDN0IsUUFBUTtpQkFDVDt1SUFJQyxTQUFTO3NCQURSLFNBQVM7dUJBQUMsTUFBTTtnQkFTakIsVUFBVTtzQkFEVCxLQUFLO2dCQVNOLFdBQVc7c0JBRFYsS0FBSztnQkFTTixPQUFPO3NCQUROLEtBQUs7Z0JBU04sWUFBWTtzQkFEWCxLQUFLO2dCQVNOLEtBQUs7c0JBREosS0FBSztnQkFTTixXQUFXO3NCQURWLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBBZnRlclZpZXdJbml0LFxuICBDb21wb25lbnQsXG4gIEVsZW1lbnRSZWYsXG4gIElucHV0LFxuICBPbkNoYW5nZXMsXG4gIE9uRGVzdHJveSxcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIFRhYmxlV2lkZ2V0LFxuICB0eXBlIFRhYmxlV2lkZ2V0UHJvcHMsXG4gIENvbXBvbmVudEFkYXB0ZXIsXG4gIGNyZWF0ZUVsZW1lbnQsXG59IGZyb20gJ0BzaXNlbnNlL3Nkay11aS1wcmVhY3QnO1xuaW1wb3J0IHsgU2lzZW5zZUNvbnRleHRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvc2lzZW5zZS1jb250ZXh0LnNlcnZpY2UnO1xuaW1wb3J0IHsgVGhlbWVTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvdGhlbWUuc2VydmljZSc7XG5pbXBvcnQge1xuICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3RvcixcbiAgY3JlYXRlVGhlbWVDb250ZXh0Q29ubmVjdG9yLFxufSBmcm9tICcuLi8uLi9jb21wb25lbnQtd3JhcHBlci1oZWxwZXJzJztcbmltcG9ydCB7IHRlbXBsYXRlLCByb290SWQgfSBmcm9tICcuLi8uLi9jb21wb25lbnQtd3JhcHBlci1oZWxwZXJzL3RlbXBsYXRlJztcblxuLyoqXG4gKiBUaGUgVGFibGUgV2lkZ2V0IGNvbXBvbmVudCBleHRlbmRpbmcge0BsaW5rIFRhYmxlQ29tcG9uZW50fSBjb21wb25lbnQgdG8gc3VwcG9ydCB3aWRnZXQgc3R5bGUgb3B0aW9ucy5cbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgaHRtbFxuICogIDxjc2RrLXRhYmxlLXdpZGdldFxuICogICAgW2RhdGFTb3VyY2VdPVwidGFibGUuZGF0YVNldFwiXG4gKiAgICBbZGF0YU9wdGlvbnNdPVwidGFibGUuZGF0YU9wdGlvbnNcIlxuICogICAgW2ZpbHRlcnNdPVwiZmlsdGVyc1wiXG4gKiAgICBbdGl0bGVdPVwidGFibGUudGl0bGVcIlxuICogICAgW2Rlc2NyaXB0aW9uXT1cInRhYmxlLmRlc2NyaXB0aW9uXCJcbiAqICAvPlxuICogYGBgXG4gKiBgYGB0c1xuICogaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG4gKiBpbXBvcnQgeyBDaGFydFR5cGUgfSBmcm9tICdAc2lzZW5zZS9zZGstdWktYW5ndWxhcic7XG4gKiBpbXBvcnQgeyBmaWx0ZXJGYWN0b3J5LCBtZWFzdXJlRmFjdG9yeSB9IGZyb20gJ0BzaXNlbnNlL3Nkay1kYXRhJztcbiAqIGltcG9ydCAqIGFzIERNIGZyb20gJy4uLy4uL2Fzc2V0cy9zYW1wbGUtaGVhbHRoY2FyZS1tb2RlbCc7XG4gKlxuICogQENvbXBvbmVudCh7XG4gKiAgc2VsZWN0b3I6ICdhcHAtd2lkZ2V0cycsXG4gKiB0ZW1wbGF0ZVVybDogJy4vd2lkZ2V0cy5jb21wb25lbnQuaHRtbCcsXG4gKiBzdHlsZVVybHM6IFsnLi93aWRnZXRzLmNvbXBvbmVudC5zY3NzJ10sXG4gKiB9KVxuICogZXhwb3J0IGNsYXNzIFdpZGdldHNDb21wb25lbnQge1xuICogZmlsdGVycyA9IFtmaWx0ZXJGYWN0b3J5Lm1lbWJlcnMoRE0uRGl2aXNpb25zLkRpdmlzb25fbmFtZSwgWydDYXJkaW9sb2d5JywgJ05ldXJvbG9neSddKV07XG4gKlxuICogdGFibGUgPSB7XG4gKiAgICBkYXRhU2V0OiBETS5EYXRhU291cmNlLFxuICogICAgZGF0YU9wdGlvbnM6IHtcbiAqICAgICAgY29sdW1uczogW0RNLkFkbWlzc2lvbnMuUGF0aWVudF9JRCwgbWVhc3VyZUZhY3Rvcnkuc3VtKERNLkFkbWlzc2lvbnMuQ29zdF9vZl9hZG1pc3Npb24pXSxcbiAqICAgIH1cbiAqICAgIHRpdGxlOiAnV2lkZ2V0IFRpdGxlJyxcbiAqICAgIGRlc2NyaXB0aW9uOiAnV2lkZ2V0IERlc2NyaXB0aW9uJyxcbiAqICB9O1xuICogfVxuICogYGBgXG4gKiA8aW1nIHNyYz1cIm1lZGlhOi8vYW5ndWxhci10YWJsZS13aWRnZXQtZXhhbXBsZS5wbmdcIiB3aWR0aD1cIjgwMHB4XCIgLz5cbiAqIEBpbnRlcm5hbFxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjc2RrLXRhYmxlLXdpZGdldCcsXG4gIHRlbXBsYXRlLFxufSlcbmV4cG9ydCBjbGFzcyBUYWJsZVdpZGdldENvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQsIE9uQ2hhbmdlcywgT25EZXN0cm95IHtcbiAgLyoqIEBpbnRlcm5hbCAqL1xuICBAVmlld0NoaWxkKHJvb3RJZClcbiAgcHJlYWN0UmVmITogRWxlbWVudFJlZjxIVE1MRGl2RWxlbWVudD47XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy5kYXRhU291cmNlfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgRGF0YVxuICAgKi9cbiAgQElucHV0KClcbiAgZGF0YVNvdXJjZTogVGFibGVXaWRnZXRQcm9wc1snZGF0YVNvdXJjZSddO1xuXG4gIC8qKlxuICAgKiB7QGluaGVyaXREb2MgQHNpc2Vuc2Uvc2RrLXVpIVRhYmxlV2lkZ2V0UHJvcHMuZGF0YU9wdGlvbnN9XG4gICAqXG4gICAqIEBjYXRlZ29yeSBEYXRhXG4gICAqL1xuICBASW5wdXQoKVxuICBkYXRhT3B0aW9ucyE6IFRhYmxlV2lkZ2V0UHJvcHNbJ2RhdGFPcHRpb25zJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy5maWx0ZXJzfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgRGF0YVxuICAgKi9cbiAgQElucHV0KClcbiAgZmlsdGVyczogVGFibGVXaWRnZXRQcm9wc1snZmlsdGVycyddO1xuXG4gIC8qKlxuICAgKiB7QGluaGVyaXREb2MgQHNpc2Vuc2Uvc2RrLXVpIVRhYmxlV2lkZ2V0UHJvcHMuc3R5bGVPcHRpb25zfVxuICAgKlxuICAgKiBAY2F0ZWdvcnkgUmVwcmVzZW50YXRpb25cbiAgICovXG4gIEBJbnB1dCgpXG4gIHN0eWxlT3B0aW9uczogVGFibGVXaWRnZXRQcm9wc1snc3R5bGVPcHRpb25zJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy50aXRsZX1cbiAgICpcbiAgICogQGNhdGVnb3J5IFdpZGdldFxuICAgKi9cbiAgQElucHV0KClcbiAgdGl0bGU6IFRhYmxlV2lkZ2V0UHJvcHNbJ3RpdGxlJ107XG5cbiAgLyoqXG4gICAqIHtAaW5oZXJpdERvYyBAc2lzZW5zZS9zZGstdWkhVGFibGVXaWRnZXRQcm9wcy5kZXNjcmlwdGlvbn1cbiAgICpcbiAgICogQGNhdGVnb3J5IFdpZGdldFxuICAgKi9cbiAgQElucHV0KClcbiAgZGVzY3JpcHRpb246IFRhYmxlV2lkZ2V0UHJvcHNbJ2Rlc2NyaXB0aW9uJ107XG5cbiAgcHJpdmF0ZSBjb21wb25lbnRBZGFwdGVyOiBDb21wb25lbnRBZGFwdGVyO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgc2lzZW5zZUNvbnRleHRTZXJ2aWNlOiBTaXNlbnNlQ29udGV4dFNlcnZpY2UsXG4gICAgcHJpdmF0ZSB0aGVtZVNlcnZpY2U6IFRoZW1lU2VydmljZSxcbiAgKSB7XG4gICAgdGhpcy5jb21wb25lbnRBZGFwdGVyID0gbmV3IENvbXBvbmVudEFkYXB0ZXIoXG4gICAgICAoKSA9PiB0aGlzLmNyZWF0ZVByZWFjdENvbXBvbmVudCgpLFxuICAgICAgW1xuICAgICAgICBjcmVhdGVTaXNlbnNlQ29udGV4dENvbm5lY3Rvcih0aGlzLnNpc2Vuc2VDb250ZXh0U2VydmljZSksXG4gICAgICAgIGNyZWF0ZVRoZW1lQ29udGV4dENvbm5lY3Rvcih0aGlzLnRoZW1lU2VydmljZSksXG4gICAgICBdLFxuICAgICk7XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5jb21wb25lbnRBZGFwdGVyLnJlbmRlcih0aGlzLnByZWFjdFJlZi5uYXRpdmVFbGVtZW50KTtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKCkge1xuICAgIGlmICh0aGlzLnByZWFjdFJlZikge1xuICAgICAgdGhpcy5jb21wb25lbnRBZGFwdGVyLnJlbmRlcih0aGlzLnByZWFjdFJlZi5uYXRpdmVFbGVtZW50KTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZVByZWFjdENvbXBvbmVudCgpIHtcbiAgICBjb25zdCBwcm9wcyA9IHtcbiAgICAgIGRhdGFTb3VyY2U6IHRoaXMuZGF0YVNvdXJjZSxcbiAgICAgIGRhdGFPcHRpb25zOiB0aGlzLmRhdGFPcHRpb25zLFxuICAgICAgZmlsdGVyczogdGhpcy5maWx0ZXJzLFxuICAgICAgc3R5bGVPcHRpb25zOiB0aGlzLnN0eWxlT3B0aW9ucyxcbiAgICAgIHRpdGxlOiB0aGlzLnRpdGxlLFxuICAgICAgZGVzY3JpcHRpb246IHRoaXMuZGVzY3JpcHRpb24sXG4gICAgfTtcblxuICAgIHJldHVybiBjcmVhdGVFbGVtZW50KFRhYmxlV2lkZ2V0LCBwcm9wcyk7XG4gIH1cblxuICBuZ09uRGVzdHJveSgpIHtcbiAgICB0aGlzLmNvbXBvbmVudEFkYXB0ZXIuZGVzdHJveSgpO1xuICB9XG59XG4iXX0=
|