@rivet-health/design-system 11.4.0 → 12.0.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/esm2020/lib/table/table-csv-export/table-csv-export.component.mjs +4 -3
- package/esm2020/lib/visualization/chart/chart.mjs +36 -5
- package/fesm2015/rivet-health-design-system.mjs +37 -9
- package/fesm2015/rivet-health-design-system.mjs.map +1 -1
- package/fesm2020/rivet-health-design-system.mjs +37 -6
- package/fesm2020/rivet-health-design-system.mjs.map +1 -1
- package/lib/visualization/chart/chart.d.ts +10 -2
- package/lib/visualization/intervals.d.ts +1 -1
- package/package.json +1 -1
|
@@ -4,6 +4,7 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
import * as i1 from "../../download/download.service";
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
6
6
|
import * as i3 from "../../input/button/button.component";
|
|
7
|
+
import * as i4 from "../../modal/tooltip/tooltip.directive";
|
|
7
8
|
export class TableCsvExportComponent {
|
|
8
9
|
constructor(downloadService, cdr) {
|
|
9
10
|
this.downloadService = downloadService;
|
|
@@ -24,11 +25,11 @@ export class TableCsvExportComponent {
|
|
|
24
25
|
}
|
|
25
26
|
}
|
|
26
27
|
TableCsvExportComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableCsvExportComponent, deps: [{ token: i1.DownloadService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
27
|
-
TableCsvExportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableCsvExportComponent, selector: "riv-table-csv-export", inputs: { manager: "manager" }, ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <button\n type=\"button\"\n rivButton\n [icon]=\"'DownloadCloud'\"\n [loading]=\"loading\"\n (click)=\"downloadCsv(s)\"\n ></button>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
28
|
+
TableCsvExportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableCsvExportComponent, selector: "riv-table-csv-export", inputs: { manager: "manager" }, ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <button\n type=\"button\"\n rivButton\n [rivTooltip]=\"'Export CSV'\"\n [icon]=\"'DownloadCloud'\"\n [loading]=\"loading\"\n (click)=\"downloadCsv(s)\"\n ></button>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition"] }, { kind: "directive", type: i4.TooltipDirective, selector: "[rivTooltip]", inputs: ["rivTooltip", "rivTooltipTheme", "rivTooltipMaxWidth", "rivTooltipPreferredPosition", "rivTooltipCloseDelay"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
28
29
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableCsvExportComponent, decorators: [{
|
|
29
30
|
type: Component,
|
|
30
|
-
args: [{ selector: 'riv-table-csv-export', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <button\n type=\"button\"\n rivButton\n [icon]=\"'DownloadCloud'\"\n [loading]=\"loading\"\n (click)=\"downloadCsv(s)\"\n ></button>\n</ng-container>\n" }]
|
|
31
|
+
args: [{ selector: 'riv-table-csv-export', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <button\n type=\"button\"\n rivButton\n [rivTooltip]=\"'Export CSV'\"\n [icon]=\"'DownloadCloud'\"\n [loading]=\"loading\"\n (click)=\"downloadCsv(s)\"\n ></button>\n</ng-container>\n" }]
|
|
31
32
|
}], ctorParameters: function () { return [{ type: i1.DownloadService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { manager: [{
|
|
32
33
|
type: Input
|
|
33
34
|
}] } });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY3N2LWV4cG9ydC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yaXYvc3JjL2xpYi90YWJsZS90YWJsZS1jc3YtZXhwb3J0L3RhYmxlLWNzdi1leHBvcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcml2L3NyYy9saWIvdGFibGUvdGFibGUtY3N2LWV4cG9ydC90YWJsZS1jc3YtZXhwb3J0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFFdkIsU0FBUyxFQUNULEtBQUssR0FDTixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEtBQUssQ0FBQyxNQUFNLFdBQVcsQ0FBQzs7Ozs7O0FBUy9CLE1BQU0sT0FBTyx1QkFBdUI7SUFRbEMsWUFDbUIsZUFBZ0MsRUFDaEMsR0FBc0I7UUFEdEIsb0JBQWUsR0FBZixlQUFlLENBQWlCO1FBQ2hDLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBR3pDLFlBQU8sR0FBRyxLQUFLLENBQUM7SUFGYixDQUFDO0lBSUosS0FBSyxDQUFDLFdBQVcsQ0FBQyxLQUFrQztRQUNsRCxJQUFJLEtBQUssRUFBRSxNQUFNLE1BQU0sSUFBSSxLQUFLLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxFQUFFO1lBQ2pELElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFO2dCQUNoQixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQzthQUNyQjtpQkFBTTtnQkFDTCxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsWUFBWSxDQUNyQyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLENBQUMsRUFDeEQsS0FBSyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQ3pCLENBQUM7Z0JBQ0YsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUM7YUFDdEI7WUFDRCxJQUFJLENBQUMsR0FBRyxDQUFDLFlBQVksRUFBRSxDQUFDO1NBQ3pCO0lBQ0gsQ0FBQzs7b0hBNUJVLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLDRGQ2ZwQyxzUUFVQTsyRkRLYSx1QkFBdUI7a0JBTG5DLFNBQVM7K0JBQ0Usc0JBQXNCLG1CQUVmLHVCQUF1QixDQUFDLE1BQU07c0lBUS9DLE9BQU87c0JBRE4sS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBJbnB1dCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgKiBhcyBwIGZyb20gJ3BhcGFwYXJzZSc7XG5pbXBvcnQgeyBEb3dubG9hZFNlcnZpY2UgfSBmcm9tICcuLi8uLi9kb3dubG9hZC9kb3dubG9hZC5zZXJ2aWNlJztcbmltcG9ydCB7IFJpdlRhYmxlIH0gZnJvbSAnLi4vc3RhdGUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyaXYtdGFibGUtY3N2LWV4cG9ydCcsXG4gIHRlbXBsYXRlVXJsOiAnLi90YWJsZS1jc3YtZXhwb3J0LmNvbXBvbmVudC5odG1sJyxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlQ3N2RXhwb3J0Q29tcG9uZW50PFxuICBSIGV4dGVuZHMgUml2VGFibGUuUm93LFxuICBDIGV4dGVuZHMgUml2VGFibGUuQ29sdW1uLFxuICBGIGV4dGVuZHMgUml2VGFibGUuRmlsdGVycyxcbj4ge1xuICBASW5wdXQoKVxuICBtYW5hZ2VyPzogUml2VGFibGUuTWFuYWdlcjxSLCBDLCBGPjtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRvd25sb2FkU2VydmljZTogRG93bmxvYWRTZXJ2aWNlLFxuICAgIHByaXZhdGUgcmVhZG9ubHkgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZixcbiAgKSB7fVxuXG4gIGxvYWRpbmcgPSBmYWxzZTtcblxuICBhc3luYyBkb3dubG9hZENzdihzdGF0ZTogUml2VGFibGUuRnVsbFN0YXRlPFIsIEMsIEY+KSB7XG4gICAgZm9yIGF3YWl0IChjb25zdCBvdXRwdXQgb2Ygc3RhdGUucmVzdWx0LmNzdkRhdGEoKSkge1xuICAgICAgaWYgKCFvdXRwdXQuZGF0YSkge1xuICAgICAgICB0aGlzLmxvYWRpbmcgPSB0cnVlO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgYXdhaXQgdGhpcy5kb3dubG9hZFNlcnZpY2UuZG93bmxvYWRCbG9iKFxuICAgICAgICAgIG5ldyBCbG9iKFtwLnVucGFyc2Uob3V0cHV0LmRhdGEpXSwgeyB0eXBlOiAndGV4dC9jc3YnIH0pLFxuICAgICAgICAgIHN0YXRlLnJlc3VsdC5jc3ZGaWxlbmFtZSxcbiAgICAgICAgKTtcbiAgICAgICAgdGhpcy5sb2FkaW5nID0gZmFsc2U7XG4gICAgICB9XG4gICAgICB0aGlzLmNkci5tYXJrRm9yQ2hlY2soKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxuZy1jb250YWluZXIgKm5nSWY9XCJtYW5hZ2VyPy5zdGF0ZSB8IGFzeW5jOyBsZXQgc1wiPlxuICA8YnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgcml2QnV0dG9uXG4gICAgW3JpdlRvb2x0aXBdPVwiJ0V4cG9ydCBDU1YnXCJcbiAgICBbaWNvbl09XCInRG93bmxvYWRDbG91ZCdcIlxuICAgIFtsb2FkaW5nXT1cImxvYWRpbmdcIlxuICAgIChjbGljayk9XCJkb3dubG9hZENzdihzKVwiXG4gID48L2J1dHRvbj5cbjwvbmctY29udGFpbmVyPlxuIl19
|
|
@@ -2,6 +2,7 @@ import { CurrencyPipe } from '@angular/common';
|
|
|
2
2
|
import { scaleLinear, scaleUtc } from 'd3-scale';
|
|
3
3
|
import { area, line } from 'd3-shape';
|
|
4
4
|
import { utcFormat } from 'd3-time-format';
|
|
5
|
+
import { DaysPipe } from 'projects/riv/src/public-api';
|
|
5
6
|
import { NumberPipe } from '../../format/pipes/number.pipe';
|
|
6
7
|
import { PercentagePipe } from '../../format/pipes/percentage.pipe';
|
|
7
8
|
import { SmallCurrencyPipe } from '../../format/pipes/small-currency.pipe';
|
|
@@ -41,7 +42,7 @@ export var Chart;
|
|
|
41
42
|
function lines(config, allData, dimensions) {
|
|
42
43
|
const { data, visibleIndices } = hide(allData);
|
|
43
44
|
const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));
|
|
44
|
-
const format = config.
|
|
45
|
+
const format = (date) => formatedDate(config.dateFormat || 'day', date);
|
|
45
46
|
const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({
|
|
46
47
|
x: xScale(tick),
|
|
47
48
|
label: format(tick),
|
|
@@ -61,6 +62,7 @@ export var Chart;
|
|
|
61
62
|
const visibleYIndex = findNearestIndex(data.ys.map(y => y.values[xIndex]), yScale.invert(pos.y));
|
|
62
63
|
const yIndex = visibleIndices[visibleYIndex];
|
|
63
64
|
const ys = data.ys.map(y => yScale(y.values[xIndex]));
|
|
65
|
+
const format = (date) => formatedDate(config.dateFormat || 'day', date);
|
|
64
66
|
const anchor = new DOMRect(pos.rect.x + x, pos.rect.y + ys[visibleYIndex], 8, 0);
|
|
65
67
|
return {
|
|
66
68
|
x,
|
|
@@ -70,7 +72,7 @@ export var Chart;
|
|
|
70
72
|
visibleYIndex,
|
|
71
73
|
tooltip: {
|
|
72
74
|
anchor,
|
|
73
|
-
date:
|
|
75
|
+
date: format(new Date(data.x[xIndex])),
|
|
74
76
|
metrics: data.ys
|
|
75
77
|
.map((y, index) => ({
|
|
76
78
|
color: colors[index % colors.length],
|
|
@@ -88,7 +90,7 @@ export var Chart;
|
|
|
88
90
|
const { data: unstackedData, visibleIndices } = hide(allData);
|
|
89
91
|
const data = stack(unstackedData);
|
|
90
92
|
const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));
|
|
91
|
-
const format = config.
|
|
93
|
+
const format = (date) => formatedDate(config.dateFormat || 'day', date);
|
|
92
94
|
const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({
|
|
93
95
|
x: xScale(tick),
|
|
94
96
|
label: format(tick),
|
|
@@ -144,7 +146,7 @@ export var Chart;
|
|
|
144
146
|
const { range: xRange, binSize } = barXRange(dimensions, data);
|
|
145
147
|
const halfBinSize = binSize / 2;
|
|
146
148
|
const xScale = scaleUtc(timeseriesDomain(data), xRange);
|
|
147
|
-
const format = config.
|
|
149
|
+
const format = (date) => formatedDate(config.dateFormat || 'day', date);
|
|
148
150
|
const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({
|
|
149
151
|
x: xScale(tick),
|
|
150
152
|
label: format(tick),
|
|
@@ -216,6 +218,7 @@ export var Chart;
|
|
|
216
218
|
zeroStateMessage: 'No data to display.',
|
|
217
219
|
valueType: 'currency',
|
|
218
220
|
truncateLegend: true,
|
|
221
|
+
dateFormat: 'day',
|
|
219
222
|
};
|
|
220
223
|
function timeseriesDomain(data) {
|
|
221
224
|
return [Math.min(...data.x), Math.max(...data.x)];
|
|
@@ -290,8 +293,36 @@ export var Chart;
|
|
|
290
293
|
const pipe = new PercentagePipe();
|
|
291
294
|
return { pipe, fullPipe: pipe };
|
|
292
295
|
}
|
|
296
|
+
case 'days': {
|
|
297
|
+
const pipe = new DaysPipe();
|
|
298
|
+
return { pipe, fullPipe: pipe };
|
|
299
|
+
}
|
|
293
300
|
}
|
|
294
301
|
}
|
|
295
302
|
Chart.getPipes = getPipes;
|
|
303
|
+
Chart.intervals = ['year', 'quarter', 'month', 'week', 'day'];
|
|
304
|
+
function formatedDate(dateFormat, date) {
|
|
305
|
+
if (dateFormat == 'quarter') {
|
|
306
|
+
const quarter = Math.ceil((date.getUTCMonth() + 1) / 3);
|
|
307
|
+
const year = utcFormat(getTimeIntervalFormat('year'))(date);
|
|
308
|
+
return `Q${quarter} ${year}`;
|
|
309
|
+
}
|
|
310
|
+
const format = getTimeIntervalFormat(dateFormat);
|
|
311
|
+
return utcFormat(format)(date);
|
|
312
|
+
}
|
|
313
|
+
Chart.formatedDate = formatedDate;
|
|
314
|
+
function getTimeIntervalFormat(interval) {
|
|
315
|
+
switch (interval) {
|
|
316
|
+
case 'day':
|
|
317
|
+
case 'week':
|
|
318
|
+
return '%m/%d/%Y';
|
|
319
|
+
case 'month':
|
|
320
|
+
case 'quarter':
|
|
321
|
+
return '%b %Y';
|
|
322
|
+
case 'year':
|
|
323
|
+
return '%Y';
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
Chart.getTimeIntervalFormat = getTimeIntervalFormat;
|
|
296
327
|
})(Chart || (Chart = {}));
|
|
297
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/visualization/chart/chart.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe } from '@angular/common';\nimport { scaleLinear, scaleUtc } from 'd3-scale';\nimport { area, line } from 'd3-shape';\nimport { utcFormat } from 'd3-time-format';\nimport { NumberPipe } from '../../format/pipes/number.pipe';\nimport { PercentagePipe } from '../../format/pipes/percentage.pipe';\nimport { SmallCurrencyPipe } from '../../format/pipes/small-currency.pipe';\n\nexport namespace Chart {\n  export const defaultColorPalette = [\n    //Base colors\n    '--baja-blast-50',\n    '--teal-diamond-50',\n    '--fyre-50',\n    '--tang-50',\n    '--purp-60',\n    '--rosi-70',\n    //Shift lighter from base by -20\n    '--baja-blast-30',\n    '--teal-diamond-30',\n    '--fyre-30',\n    '--tang-30',\n    '--purp-40',\n    '--rosi-50',\n    //Shift darker from base by +20\n    '--baja-blast-70',\n    '--teal-diamond-70',\n    '--fyre-70',\n    '--tang-70',\n    '--purp-80',\n    '--rosi-90',\n  ];\n\n  export function chart(config: Config, data: Data, dimensions: Dimensions) {\n    return config.type == 'line'\n      ? lines(config, data, dimensions)\n      : config.type == 'area'\n      ? areas(config, data, dimensions)\n      : bars(config, data, dimensions);\n  }\n  export function lines(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data, visibleIndices } = hide(allData);\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));\n    const format = config.xTickLabels ?? xScale.tickFormat();\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const indices = data.x.map((_, i) => i);\n    const lines = data.ys.map(y =>\n      line<number>(\n        i => xScale(data.x[i]),\n        i => yScale(y.values[i]),\n      )(indices),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const visibleYIndex = findNearestIndex(\n        data.ys.map(y => y.values[xIndex]),\n        yScale.invert(pos.y),\n      );\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        8,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return { xTicks, yTicks, colors, lines, hover, bars: [], areas: [] };\n  }\n\n  export function areas(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const data = stack(unstackedData);\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));\n    const format = config.xTickLabels ?? xScale.tickFormat();\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n\n    const indices = data.x.map((_, i) => i);\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const areas = data.ys.map((y, yIndex) =>\n      area<number>(\n        i => xScale(data.x[i]),\n        i => yScale(yIndex == 0 ? 0 : data.ys[yIndex - 1].values[i]),\n        i => yScale(y.values[i]),\n      )(indices),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const yValue = yScale.invert(pos.y);\n      let visibleYIndex = data.ys\n        .map(y => y.values[xIndex])\n        .findIndex(y => y > yValue);\n      if (visibleYIndex == -1) {\n        visibleYIndex = data.ys.length - 1;\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n      const padding = 8;\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        padding,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(unstackedData.x[xIndex])),\n          metrics: unstackedData.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return { xTicks, yTicks, colors, areas, lines: [], hover, bars: [] };\n  }\n\n  export function bars(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const data = stack(unstackedData);\n    const { range: xRange, binSize } = barXRange(dimensions, data);\n    const halfBinSize = binSize / 2;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange);\n    const format = config.xTickLabels ?? xScale.tickFormat();\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const bars = data.ys.map((y, yIndex) =>\n      y.values.map((value, index) => {\n        const yValue = yScale(value);\n        return {\n          x: xScale(data.x[index]) - halfBinSize,\n          y: yValue,\n          width: binSize,\n          height:\n            (yIndex == 0\n              ? yScale(0)\n              : yScale(data.ys[yIndex - 1].values[index])) - yValue,\n        };\n      }),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const yValue = yScale.invert(pos.y);\n      let visibleYIndex = data.ys\n        .map(y => y.values[xIndex])\n        .findIndex(y => y > yValue);\n      if (visibleYIndex == -1) {\n        visibleYIndex = data.ys.length - 1;\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n      const padding = 8;\n      const anchor = new DOMRect(\n        pos.rect.x + bars[visibleYIndex][xIndex].x - padding,\n        pos.rect.y + ys[visibleYIndex],\n        bars[visibleYIndex][xIndex].width + padding * 2,\n        (visibleYIndex == 0 ? yScale(0) : ys[visibleYIndex - 1]) -\n          ys[visibleYIndex],\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(unstackedData.x[xIndex])),\n          metrics: unstackedData.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return { xTicks, yTicks, colors, bars, lines: [], areas: [], hover };\n  }\n\n  const LEFT_PADDING = 48;\n  const RIGHT_PADDING = 24;\n  const TOP_PADDING = 16;\n  const BOTTOM_PADDING = 24;\n\n  export type Data = {\n    ys: {\n      label: string;\n      hidden?: boolean;\n      values: number[];\n    }[];\n    x: number[];\n  };\n\n  export type Dimensions = {\n    width: number;\n    height: number;\n  };\n\n  export type Config = {\n    type: 'line' | 'area' | 'bar';\n    groupedTooltip: boolean;\n    colors: string[];\n    allowLegendToggle: boolean;\n    zeroStateMessage: string;\n    valueType: ValueType;\n    truncateLegend: boolean;\n    xTickLabels?: (date: Date) => string;\n  };\n\n  export const defaultConfig: Config = {\n    type: 'line',\n    groupedTooltip: true,\n    colors: defaultColorPalette,\n    allowLegendToggle: false,\n    zeroStateMessage: 'No data to display.',\n    valueType: 'currency',\n    truncateLegend: true,\n  };\n\n  export type Area = {\n    path: string | null;\n    fill: string;\n  };\n\n  export type XTick = {\n    x: number;\n    label: string;\n  };\n\n  export type YTick = {\n    y: number;\n    label: string;\n  };\n\n  type Rect = {\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n  };\n\n  export type BarSeries = {\n    fill: string;\n    rects: Rect[];\n  };\n\n  // Hover is a function that takes a viewport x and y and returns a rich\n  // set of information about what values are being hovered and what the tooltip\n  // should look like\n  export type Hover = (pos: { rect: DOMRect; x: number; y: number }) => {\n    // the indices into the data of the closest point\n    xIndex: number;\n    // we want to know which visible y index is hovered\n    // and which actual y index is hovered\n    yIndex: number;\n    visibleYIndex: number;\n\n    // the viewport x and ys of the hovered items\n    x: number;\n    ys: number[];\n\n    tooltip: {\n      anchor: DOMRect;\n      date: string;\n      metrics: {\n        color: string;\n        label: string;\n        value: string;\n      }[];\n    };\n  };\n\n  // RenderedChart represents all of the parts of a chart\n  // that end up on screen. Every chart has x and y ticks\n  // and hover functionality, even though they might be\n  // different from chart to chart.\n  type RenderedChart = {\n    xTicks: XTick[];\n    yTicks: YTick[];\n    hover: Hover;\n    colors: string[];\n    lines: (string | null)[];\n    areas: (string | null)[];\n    bars: Rect[][];\n  };\n\n  function timeseriesDomain(data: Data) {\n    return [Math.min(...data.x), Math.max(...data.x)];\n  }\n\n  function yDomain(data: Data) {\n    const max = Math.max(...data.ys.map(y => Math.max(...y.values)));\n    return [0, max == 0 ? 1 : max];\n  }\n\n  function xRange(dimensions: Dimensions) {\n    return [LEFT_PADDING, dimensions.width - RIGHT_PADDING];\n  }\n\n  function barXRange(dimensions: Dimensions, data: Data) {\n    const left = LEFT_PADDING;\n    const right = dimensions.width - RIGHT_PADDING;\n    const width = right - left;\n    const binSize = width / (data.x.length || 1);\n    const halfBinSize = binSize / 2;\n    const range = [left + halfBinSize, right - halfBinSize];\n    return { binSize: Math.min(binSize * 0.7, 80), range };\n  }\n\n  function yRange(dimensions: Dimensions) {\n    return [dimensions.height - BOTTOM_PADDING, TOP_PADDING];\n  }\n\n  function findNearestIndex(values: number[], input: number) {\n    return values.reduce((nearestIndex, value, index) => {\n      return Math.abs(value - input) < Math.abs(values[nearestIndex] - input)\n        ? index\n        : nearestIndex;\n    }, 0);\n  }\n\n  // stack returns a new data where each set of yValues is stacked\n  // on top of the previous.\n  function stack(data: Data): Data {\n    const stacked: Data = {\n      ...data,\n      ys: data.ys.map(y => ({ label: y.label, values: [] })),\n    };\n    for (let i = 0; i < data.x.length; i++) {\n      let from = 0;\n      for (let j = 0; j < data.ys.length; j++) {\n        const to = from + data.ys[j].values[i];\n        stacked.ys[j].values.push(to);\n        from = to;\n      }\n    }\n    return stacked;\n  }\n\n  // hide strips out hidden y values while retaining the original indices\n  // for the remaining visible values\n  function hide(data: Data): { data: Data; visibleIndices: number[] } {\n    const visibleIndices = data.ys\n      .map((y, i) => ({ y, i }))\n      .filter(({ y }) => !y.hidden)\n      .map(({ i }) => i);\n    return {\n      data: { ...data, ys: visibleIndices.map(i => data.ys[i]) },\n      visibleIndices,\n    };\n  }\n\n  type ValueType = 'count' | 'currency' | 'percentage';\n\n  export function getPipes(valueType: ValueType) {\n    switch (valueType) {\n      case 'count': {\n        const pipe = new NumberPipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'currency':\n        return {\n          pipe: new SmallCurrencyPipe(),\n          fullPipe: new CurrencyPipe('en-us'),\n        };\n      case 'percentage': {\n        const pipe = new PercentagePipe();\n        return { pipe, fullPipe: pipe };\n      }\n    }\n  }\n}\n"]}
|
|
328
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/visualization/chart/chart.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe } from '@angular/common';\nimport { scaleLinear, scaleUtc } from 'd3-scale';\nimport { area, line } from 'd3-shape';\nimport { utcFormat } from 'd3-time-format';\nimport { DaysPipe } from 'projects/riv/src/public-api';\nimport { NumberPipe } from '../../format/pipes/number.pipe';\nimport { PercentagePipe } from '../../format/pipes/percentage.pipe';\nimport { SmallCurrencyPipe } from '../../format/pipes/small-currency.pipe';\n\nexport namespace Chart {\n  export const defaultColorPalette = [\n    //Base colors\n    '--baja-blast-50',\n    '--teal-diamond-50',\n    '--fyre-50',\n    '--tang-50',\n    '--purp-60',\n    '--rosi-70',\n    //Shift lighter from base by -20\n    '--baja-blast-30',\n    '--teal-diamond-30',\n    '--fyre-30',\n    '--tang-30',\n    '--purp-40',\n    '--rosi-50',\n    //Shift darker from base by +20\n    '--baja-blast-70',\n    '--teal-diamond-70',\n    '--fyre-70',\n    '--tang-70',\n    '--purp-80',\n    '--rosi-90',\n  ];\n\n  export function chart(config: Config, data: Data, dimensions: Dimensions) {\n    return config.type == 'line'\n      ? lines(config, data, dimensions)\n      : config.type == 'area'\n      ? areas(config, data, dimensions)\n      : bars(config, data, dimensions);\n  }\n  export function lines(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data, visibleIndices } = hide(allData);\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const indices = data.x.map((_, i) => i);\n    const lines = data.ys.map(y =>\n      line<number>(\n        i => xScale(data.x[i]),\n        i => yScale(y.values[i]),\n      )(indices),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const visibleYIndex = findNearestIndex(\n        data.ys.map(y => y.values[xIndex]),\n        yScale.invert(pos.y),\n      );\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n\n      const format = (date: Date) =>\n        formatedDate(config.dateFormat || 'day', date);\n\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        8,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: format(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return { xTicks, yTicks, colors, lines, hover, bars: [], areas: [] };\n  }\n\n  export function areas(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const data = stack(unstackedData);\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n\n    const indices = data.x.map((_, i) => i);\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const areas = data.ys.map((y, yIndex) =>\n      area<number>(\n        i => xScale(data.x[i]),\n        i => yScale(yIndex == 0 ? 0 : data.ys[yIndex - 1].values[i]),\n        i => yScale(y.values[i]),\n      )(indices),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const yValue = yScale.invert(pos.y);\n      let visibleYIndex = data.ys\n        .map(y => y.values[xIndex])\n        .findIndex(y => y > yValue);\n      if (visibleYIndex == -1) {\n        visibleYIndex = data.ys.length - 1;\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n      const padding = 8;\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        padding,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(unstackedData.x[xIndex])),\n          metrics: unstackedData.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return { xTicks, yTicks, colors, areas, lines: [], hover, bars: [] };\n  }\n\n  export function bars(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const data = stack(unstackedData);\n    const { range: xRange, binSize } = barXRange(dimensions, data);\n    const halfBinSize = binSize / 2;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange);\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({\n      x: xScale(tick),\n      label: format(tick),\n    }));\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const yScale = scaleLinear(yDomain(data), yRange(dimensions));\n    const yTicks = yScale.ticks(5).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n    }));\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const bars = data.ys.map((y, yIndex) =>\n      y.values.map((value, index) => {\n        const yValue = yScale(value);\n        return {\n          x: xScale(data.x[index]) - halfBinSize,\n          y: yValue,\n          width: binSize,\n          height:\n            (yIndex == 0\n              ? yScale(0)\n              : yScale(data.ys[yIndex - 1].values[index])) - yValue,\n        };\n      }),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const yValue = yScale.invert(pos.y);\n      let visibleYIndex = data.ys\n        .map(y => y.values[xIndex])\n        .findIndex(y => y > yValue);\n      if (visibleYIndex == -1) {\n        visibleYIndex = data.ys.length - 1;\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map(y => yScale(y.values[xIndex]));\n      const padding = 8;\n      const anchor = new DOMRect(\n        pos.rect.x + bars[visibleYIndex][xIndex].x - padding,\n        pos.rect.y + ys[visibleYIndex],\n        bars[visibleYIndex][xIndex].width + padding * 2,\n        (visibleYIndex == 0 ? yScale(0) : ys[visibleYIndex - 1]) -\n          ys[visibleYIndex],\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(unstackedData.x[xIndex])),\n          metrics: unstackedData.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return { xTicks, yTicks, colors, bars, lines: [], areas: [], hover };\n  }\n\n  const LEFT_PADDING = 48;\n  const RIGHT_PADDING = 24;\n  const TOP_PADDING = 16;\n  const BOTTOM_PADDING = 24;\n\n  export type Data = {\n    ys: {\n      label: string;\n      hidden?: boolean;\n      values: number[];\n    }[];\n    x: number[];\n  };\n\n  export type Dimensions = {\n    width: number;\n    height: number;\n  };\n\n  export type Config = {\n    type: 'line' | 'area' | 'bar';\n    groupedTooltip: boolean;\n    colors: string[];\n    allowLegendToggle: boolean;\n    zeroStateMessage: string;\n    valueType: ValueType;\n    truncateLegend: boolean;\n    dateFormat?: Interval;\n  };\n\n  export const defaultConfig: Config = {\n    type: 'line',\n    groupedTooltip: true,\n    colors: defaultColorPalette,\n    allowLegendToggle: false,\n    zeroStateMessage: 'No data to display.',\n    valueType: 'currency',\n    truncateLegend: true,\n    dateFormat: 'day',\n  };\n\n  export type Area = {\n    path: string | null;\n    fill: string;\n  };\n\n  export type XTick = {\n    x: number;\n    label: string;\n  };\n\n  export type YTick = {\n    y: number;\n    label: string;\n  };\n\n  type Rect = {\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n  };\n\n  export type BarSeries = {\n    fill: string;\n    rects: Rect[];\n  };\n\n  // Hover is a function that takes a viewport x and y and returns a rich\n  // set of information about what values are being hovered and what the tooltip\n  // should look like\n  export type Hover = (pos: { rect: DOMRect; x: number; y: number }) => {\n    // the indices into the data of the closest point\n    xIndex: number;\n    // we want to know which visible y index is hovered\n    // and which actual y index is hovered\n    yIndex: number;\n    visibleYIndex: number;\n\n    // the viewport x and ys of the hovered items\n    x: number;\n    ys: number[];\n\n    tooltip: {\n      anchor: DOMRect;\n      date: string;\n      metrics: {\n        color: string;\n        label: string;\n        value: string;\n      }[];\n    };\n  };\n\n  // RenderedChart represents all of the parts of a chart\n  // that end up on screen. Every chart has x and y ticks\n  // and hover functionality, even though they might be\n  // different from chart to chart.\n  type RenderedChart = {\n    xTicks: XTick[];\n    yTicks: YTick[];\n    hover: Hover;\n    colors: string[];\n    lines: (string | null)[];\n    areas: (string | null)[];\n    bars: Rect[][];\n  };\n\n  function timeseriesDomain(data: Data) {\n    return [Math.min(...data.x), Math.max(...data.x)];\n  }\n\n  function yDomain(data: Data) {\n    const max = Math.max(...data.ys.map(y => Math.max(...y.values)));\n    return [0, max == 0 ? 1 : max];\n  }\n\n  function xRange(dimensions: Dimensions) {\n    return [LEFT_PADDING, dimensions.width - RIGHT_PADDING];\n  }\n\n  function barXRange(dimensions: Dimensions, data: Data) {\n    const left = LEFT_PADDING;\n    const right = dimensions.width - RIGHT_PADDING;\n    const width = right - left;\n    const binSize = width / (data.x.length || 1);\n    const halfBinSize = binSize / 2;\n    const range = [left + halfBinSize, right - halfBinSize];\n    return { binSize: Math.min(binSize * 0.7, 80), range };\n  }\n\n  function yRange(dimensions: Dimensions) {\n    return [dimensions.height - BOTTOM_PADDING, TOP_PADDING];\n  }\n\n  function findNearestIndex(values: number[], input: number) {\n    return values.reduce((nearestIndex, value, index) => {\n      return Math.abs(value - input) < Math.abs(values[nearestIndex] - input)\n        ? index\n        : nearestIndex;\n    }, 0);\n  }\n\n  // stack returns a new data where each set of yValues is stacked\n  // on top of the previous.\n  function stack(data: Data): Data {\n    const stacked: Data = {\n      ...data,\n      ys: data.ys.map(y => ({ label: y.label, values: [] })),\n    };\n    for (let i = 0; i < data.x.length; i++) {\n      let from = 0;\n      for (let j = 0; j < data.ys.length; j++) {\n        const to = from + data.ys[j].values[i];\n        stacked.ys[j].values.push(to);\n        from = to;\n      }\n    }\n    return stacked;\n  }\n\n  // hide strips out hidden y values while retaining the original indices\n  // for the remaining visible values\n  function hide(data: Data): { data: Data; visibleIndices: number[] } {\n    const visibleIndices = data.ys\n      .map((y, i) => ({ y, i }))\n      .filter(({ y }) => !y.hidden)\n      .map(({ i }) => i);\n    return {\n      data: { ...data, ys: visibleIndices.map(i => data.ys[i]) },\n      visibleIndices,\n    };\n  }\n\n  type ValueType = 'count' | 'currency' | 'percentage' | 'days';\n\n  export function getPipes(valueType: ValueType) {\n    switch (valueType) {\n      case 'count': {\n        const pipe = new NumberPipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'currency':\n        return {\n          pipe: new SmallCurrencyPipe(),\n          fullPipe: new CurrencyPipe('en-us'),\n        };\n      case 'percentage': {\n        const pipe = new PercentagePipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'days': {\n        const pipe = new DaysPipe();\n        return { pipe, fullPipe: pipe };\n      }\n    }\n  }\n\n  export const intervals = ['year', 'quarter', 'month', 'week', 'day'] as const;\n  export type Interval = (typeof intervals)[number];\n\n  export function formatedDate(dateFormat: Interval, date: Date) {\n    if (dateFormat == 'quarter') {\n      const quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n      const year = utcFormat(getTimeIntervalFormat('year'))(date);\n      return `Q${quarter} ${year}`;\n    }\n    const format = getTimeIntervalFormat(dateFormat);\n    return utcFormat(format)(date);\n  }\n\n  export function getTimeIntervalFormat(interval: Interval): string {\n    switch (interval) {\n      case 'day':\n      case 'week':\n        return '%m/%d/%Y';\n      case 'month':\n      case 'quarter':\n        return '%b %Y';\n      case 'year':\n        return '%Y';\n    }\n  }\n}\n"]}
|
|
@@ -11,6 +11,7 @@ import * as p from 'papaparse';
|
|
|
11
11
|
import { debounce, defaultsDeep, orderBy, isEqual, range, difference, union } from 'lodash';
|
|
12
12
|
import { scaleUtc, scaleLinear, scaleBand } from 'd3-scale';
|
|
13
13
|
import { line, area, pie, arc, stack } from 'd3-shape';
|
|
14
|
+
import { DaysPipe as DaysPipe$1 } from 'projects/riv/src/public-api';
|
|
14
15
|
import { index, union as union$1 } from 'd3-array';
|
|
15
16
|
|
|
16
17
|
/**
|
|
@@ -3016,10 +3017,10 @@ class TableCsvExportComponent {
|
|
|
3016
3017
|
}
|
|
3017
3018
|
}
|
|
3018
3019
|
TableCsvExportComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableCsvExportComponent, deps: [{ token: DownloadService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
3019
|
-
TableCsvExportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableCsvExportComponent, selector: "riv-table-csv-export", inputs: { manager: "manager" }, ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <button\n type=\"button\"\n rivButton\n [icon]=\"'DownloadCloud'\"\n [loading]=\"loading\"\n (click)=\"downloadCsv(s)\"\n ></button>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
3020
|
+
TableCsvExportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableCsvExportComponent, selector: "riv-table-csv-export", inputs: { manager: "manager" }, ngImport: i0, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <button\n type=\"button\"\n rivButton\n [rivTooltip]=\"'Export CSV'\"\n [icon]=\"'DownloadCloud'\"\n [loading]=\"loading\"\n (click)=\"downloadCsv(s)\"\n ></button>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ButtonComponent, selector: "[rivButton]", inputs: ["locked", "disabled", "loading", "full", "size", "variant", "icon", "iconPosition"] }, { kind: "directive", type: TooltipDirective, selector: "[rivTooltip]", inputs: ["rivTooltip", "rivTooltipTheme", "rivTooltipMaxWidth", "rivTooltipPreferredPosition", "rivTooltipCloseDelay"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
3020
3021
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableCsvExportComponent, decorators: [{
|
|
3021
3022
|
type: Component,
|
|
3022
|
-
args: [{ selector: 'riv-table-csv-export', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <button\n type=\"button\"\n rivButton\n [icon]=\"'DownloadCloud'\"\n [loading]=\"loading\"\n (click)=\"downloadCsv(s)\"\n ></button>\n</ng-container>\n" }]
|
|
3023
|
+
args: [{ selector: 'riv-table-csv-export', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"manager?.state | async; let s\">\n <button\n type=\"button\"\n rivButton\n [rivTooltip]=\"'Export CSV'\"\n [icon]=\"'DownloadCloud'\"\n [loading]=\"loading\"\n (click)=\"downloadCsv(s)\"\n ></button>\n</ng-container>\n" }]
|
|
3023
3024
|
}], ctorParameters: function () { return [{ type: DownloadService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { manager: [{
|
|
3024
3025
|
type: Input
|
|
3025
3026
|
}] } });
|
|
@@ -3710,10 +3711,9 @@ var Chart;
|
|
|
3710
3711
|
}
|
|
3711
3712
|
Chart.chart = chart;
|
|
3712
3713
|
function lines(config, allData, dimensions) {
|
|
3713
|
-
var _a;
|
|
3714
3714
|
const { data, visibleIndices } = hide(allData);
|
|
3715
3715
|
const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));
|
|
3716
|
-
const format = (
|
|
3716
|
+
const format = (date) => formatedDate(config.dateFormat || 'day', date);
|
|
3717
3717
|
const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({
|
|
3718
3718
|
x: xScale(tick),
|
|
3719
3719
|
label: format(tick),
|
|
@@ -3733,6 +3733,7 @@ var Chart;
|
|
|
3733
3733
|
const visibleYIndex = findNearestIndex(data.ys.map(y => y.values[xIndex]), yScale.invert(pos.y));
|
|
3734
3734
|
const yIndex = visibleIndices[visibleYIndex];
|
|
3735
3735
|
const ys = data.ys.map(y => yScale(y.values[xIndex]));
|
|
3736
|
+
const format = (date) => formatedDate(config.dateFormat || 'day', date);
|
|
3736
3737
|
const anchor = new DOMRect(pos.rect.x + x, pos.rect.y + ys[visibleYIndex], 8, 0);
|
|
3737
3738
|
return {
|
|
3738
3739
|
x,
|
|
@@ -3742,7 +3743,7 @@ var Chart;
|
|
|
3742
3743
|
visibleYIndex,
|
|
3743
3744
|
tooltip: {
|
|
3744
3745
|
anchor,
|
|
3745
|
-
date:
|
|
3746
|
+
date: format(new Date(data.x[xIndex])),
|
|
3746
3747
|
metrics: data.ys
|
|
3747
3748
|
.map((y, index) => {
|
|
3748
3749
|
var _a;
|
|
@@ -3760,11 +3761,10 @@ var Chart;
|
|
|
3760
3761
|
}
|
|
3761
3762
|
Chart.lines = lines;
|
|
3762
3763
|
function areas(config, allData, dimensions) {
|
|
3763
|
-
var _a;
|
|
3764
3764
|
const { data: unstackedData, visibleIndices } = hide(allData);
|
|
3765
3765
|
const data = stack(unstackedData);
|
|
3766
3766
|
const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions));
|
|
3767
|
-
const format = (
|
|
3767
|
+
const format = (date) => formatedDate(config.dateFormat || 'day', date);
|
|
3768
3768
|
const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({
|
|
3769
3769
|
x: xScale(tick),
|
|
3770
3770
|
label: format(tick),
|
|
@@ -3818,13 +3818,12 @@ var Chart;
|
|
|
3818
3818
|
}
|
|
3819
3819
|
Chart.areas = areas;
|
|
3820
3820
|
function bars(config, allData, dimensions) {
|
|
3821
|
-
var _a;
|
|
3822
3821
|
const { data: unstackedData, visibleIndices } = hide(allData);
|
|
3823
3822
|
const data = stack(unstackedData);
|
|
3824
3823
|
const { range: xRange, binSize } = barXRange(dimensions, data);
|
|
3825
3824
|
const halfBinSize = binSize / 2;
|
|
3826
3825
|
const xScale = scaleUtc(timeseriesDomain(data), xRange);
|
|
3827
|
-
const format = (
|
|
3826
|
+
const format = (date) => formatedDate(config.dateFormat || 'day', date);
|
|
3828
3827
|
const xTicks = xScale.ticks(Math.min(5, data.x.length)).map(tick => ({
|
|
3829
3828
|
x: xScale(tick),
|
|
3830
3829
|
label: format(tick),
|
|
@@ -3899,6 +3898,7 @@ var Chart;
|
|
|
3899
3898
|
zeroStateMessage: 'No data to display.',
|
|
3900
3899
|
valueType: 'currency',
|
|
3901
3900
|
truncateLegend: true,
|
|
3901
|
+
dateFormat: 'day',
|
|
3902
3902
|
};
|
|
3903
3903
|
function timeseriesDomain(data) {
|
|
3904
3904
|
return [Math.min(...data.x), Math.max(...data.x)];
|
|
@@ -3970,9 +3970,37 @@ var Chart;
|
|
|
3970
3970
|
const pipe = new PercentagePipe();
|
|
3971
3971
|
return { pipe, fullPipe: pipe };
|
|
3972
3972
|
}
|
|
3973
|
+
case 'days': {
|
|
3974
|
+
const pipe = new DaysPipe$1();
|
|
3975
|
+
return { pipe, fullPipe: pipe };
|
|
3976
|
+
}
|
|
3973
3977
|
}
|
|
3974
3978
|
}
|
|
3975
3979
|
Chart.getPipes = getPipes;
|
|
3980
|
+
Chart.intervals = ['year', 'quarter', 'month', 'week', 'day'];
|
|
3981
|
+
function formatedDate(dateFormat, date) {
|
|
3982
|
+
if (dateFormat == 'quarter') {
|
|
3983
|
+
const quarter = Math.ceil((date.getUTCMonth() + 1) / 3);
|
|
3984
|
+
const year = utcFormat(getTimeIntervalFormat('year'))(date);
|
|
3985
|
+
return `Q${quarter} ${year}`;
|
|
3986
|
+
}
|
|
3987
|
+
const format = getTimeIntervalFormat(dateFormat);
|
|
3988
|
+
return utcFormat(format)(date);
|
|
3989
|
+
}
|
|
3990
|
+
Chart.formatedDate = formatedDate;
|
|
3991
|
+
function getTimeIntervalFormat(interval) {
|
|
3992
|
+
switch (interval) {
|
|
3993
|
+
case 'day':
|
|
3994
|
+
case 'week':
|
|
3995
|
+
return '%m/%d/%Y';
|
|
3996
|
+
case 'month':
|
|
3997
|
+
case 'quarter':
|
|
3998
|
+
return '%b %Y';
|
|
3999
|
+
case 'year':
|
|
4000
|
+
return '%Y';
|
|
4001
|
+
}
|
|
4002
|
+
}
|
|
4003
|
+
Chart.getTimeIntervalFormat = getTimeIntervalFormat;
|
|
3976
4004
|
})(Chart || (Chart = {}));
|
|
3977
4005
|
|
|
3978
4006
|
class LegendItemComponent {
|