@rivet-health/design-system 2.12.0 → 2.14.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/input/button/button.component.mjs +94 -0
- package/esm2020/lib/input/single-select/single-select.component.mjs +99 -0
- package/esm2020/lib/load/loading/loading.component.mjs +49 -0
- package/esm2020/lib/load/loading-cover/loading-cover.component.mjs +23 -0
- package/esm2020/lib/modal/help/help.component.mjs +15 -0
- package/esm2020/lib/riv.module.mjs +38 -8
- package/esm2020/lib/visualization/highlight/highlight.component.mjs +45 -0
- package/esm2020/lib/visualization/metric/metric.component.mjs +7 -3
- package/esm2020/public-api.mjs +7 -1
- package/fesm2015/rivet-health-design-system.mjs +351 -31
- package/fesm2015/rivet-health-design-system.mjs.map +1 -1
- package/fesm2020/rivet-health-design-system.mjs +356 -31
- package/fesm2020/rivet-health-design-system.mjs.map +1 -1
- package/lib/input/button/button.component.d.ts +26 -0
- package/lib/input/single-select/single-select.component.d.ts +46 -0
- package/lib/load/loading/loading.component.d.ts +20 -0
- package/lib/load/loading-cover/loading-cover.component.d.ts +9 -0
- package/lib/modal/help/help.component.d.ts +6 -0
- package/lib/riv.module.d.ts +31 -25
- package/lib/visualization/highlight/highlight.component.d.ts +16 -0
- package/lib/visualization/metric/metric.component.d.ts +2 -1
- package/package.json +2 -1
- package/public-api.d.ts +6 -0
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { Component, HostBinding, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../../icon/icon.component";
|
|
5
|
+
import * as i3 from "../../load/loading/loading.component";
|
|
6
|
+
export class ButtonComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.locked = false;
|
|
9
|
+
this.disabled = false;
|
|
10
|
+
this.loading = false;
|
|
11
|
+
this.full = false;
|
|
12
|
+
this.size = 'medium';
|
|
13
|
+
this.variant = 'basic';
|
|
14
|
+
this.iconPosition = 'first';
|
|
15
|
+
}
|
|
16
|
+
get classes() {
|
|
17
|
+
return Object.entries({
|
|
18
|
+
button: true,
|
|
19
|
+
disabled: this.disabled || this.locked,
|
|
20
|
+
full: this.full,
|
|
21
|
+
loading: this.loading,
|
|
22
|
+
[this.variant]: true,
|
|
23
|
+
[this.size]: true,
|
|
24
|
+
})
|
|
25
|
+
.filter(([_, v]) => v)
|
|
26
|
+
.map(([k]) => k)
|
|
27
|
+
.join(' ');
|
|
28
|
+
}
|
|
29
|
+
getLoadingVariant() {
|
|
30
|
+
switch (this.variant) {
|
|
31
|
+
case 'basic':
|
|
32
|
+
case 'caution':
|
|
33
|
+
case 'ghost':
|
|
34
|
+
return 'dark';
|
|
35
|
+
case 'danger':
|
|
36
|
+
case 'primary':
|
|
37
|
+
return 'light';
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
getIconSize() {
|
|
41
|
+
switch (this.size) {
|
|
42
|
+
case 'xsmall':
|
|
43
|
+
case 'small':
|
|
44
|
+
return 16;
|
|
45
|
+
case 'medium':
|
|
46
|
+
case 'large':
|
|
47
|
+
case 'xlarge':
|
|
48
|
+
return 24;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
ButtonComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
+
ButtonComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ButtonComponent, selector: "[rivButton]", inputs: { locked: "locked", disabled: "disabled", loading: "loading", full: "full", size: "size", variant: "variant", icon: "icon", iconPosition: "iconPosition" }, host: { properties: { "class": "this.classes" } }, ngImport: i0, template: "<riv-icon\n *ngIf=\"!locked && icon && iconPosition === 'first'\"\n [name]=\"icon\"\n [size]=\"getIconSize()\"\n></riv-icon>\n<span><ng-content></ng-content></span>\n<riv-icon *ngIf=\"locked\" [name]=\"'Lock'\" [size]=\"getIconSize()\"></riv-icon>\n<riv-icon\n *ngIf=\"!locked && icon && iconPosition === 'last'\"\n [name]=\"icon\"\n [size]=\"getIconSize()\"\n></riv-icon>\n<riv-loading\n *ngIf=\"loading\"\n [size]=\"16\"\n [variant]=\"getLoadingVariant()\"\n></riv-loading>\n", styles: [":host{border-radius:var(--border-radius-small);transition:background-color var(--medium-transition);display:inline-flex;align-items:center;cursor:pointer;text-decoration:none}:host:disabled,:host.disabled{cursor:default}:host.basic{color:var(--purp-80);background-color:var(--black-10);border:var(--border-width) solid var(--border-light-blend)}:host.basic:hover{background-color:var(--black-20)}:host.basic:active{background-color:var(--black-30)}:host.basic:disabled,:host.basic.disabled{border-color:transparent;background-color:var(--black-10);color:var(--type-light-disabled)}:host.primary{color:var(--white-90);background-color:var(--purp-60);border:var(--border-width) solid var(--border-dark-blend)}:host.primary:hover{background-color:var(--purp-70)}:host.primary:active{background-color:var(--purp-80)}:host.primary:disabled,:host.primary.disabled{border-color:transparent;background-color:var(--purp-10);color:var(--type-light-disabled)}:host.ghost{color:var(--purp-80);background-color:transparent;border:var(--border-width) solid transparent}:host.ghost:hover{background-color:var(--black-20)}:host.ghost:active{background-color:var(--black-40)}:host.ghost:disabled,:host.ghost.disabled{color:var(--type-light-disabled);background-color:transparent}:host.caution{color:var(--type-light-caution);background-color:var(--surface-light-caution);border:var(--border-width) solid transparent}:host.caution:hover{background-color:var(--black-20)}:host.caution:active{background-color:var(--black-40)}:host.caution:disabled,:host.caution.disabled{border-color:transparent;background-color:var(--arnge-10);color:var(--type-light-disabled)}:host.danger{color:var(--white-90);background-color:var(--fyre-50);border:var(--border-width) solid var(--border-dark-blend)}:host.danger:hover{background-color:var(--fyre-70)}:host.danger:active{background-color:var(--fyre-90)}:host.danger:disabled,:host.danger.disabled{border-color:transparent;background-color:var(--fyre-10);color:var(--type-light-disabled)}:host.xsmall{font-size:var(--type-1-font-size);line-height:var(--type-1-line-height-0);padding:calc(var(--base-grid-size) * 1.5) calc(var(--base-grid-size) * 2)}:host.xsmall riv-icon{margin:calc(var(--base-grid-size) / -2) calc(var(--base-grid-size) * -1)}:host.xsmall riv-icon:has(+ span:not(:empty)){margin-right:var(--base-grid-size)}:host.xsmall span:not(:empty)+riv-icon{margin-left:var(--base-grid-size)}:host.small{font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);padding:calc(var(--base-grid-size) * 1.5) calc(var(--base-grid-size) * 3)}:host.small riv-icon{margin:0 calc(var(--base-grid-size) * -1.5)}:host.small riv-icon:has(+ span:not(:empty)){margin-right:calc(var(--base-grid-size) * 1.5)}:host.small span:not(:empty)+riv-icon{margin-left:calc(var(--base-grid-size) * 1.5)}:host.medium{font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);padding:calc(var(--base-grid-size) * 2) calc(var(--base-grid-size) * 3)}:host.medium riv-icon{margin:calc(var(--base-grid-size) * -1) calc(var(--base-grid-size) * -2)}:host.medium riv-icon:has(+ span:not(:empty)){margin-right:calc(var(--base-grid-size))}:host.medium span:not(:empty)+riv-icon{margin-left:calc(var(--base-grid-size) * 2)}:host.large{font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);padding:calc(var(--base-grid-size) * 3) calc(var(--base-grid-size) * 5)}:host.large riv-icon{margin:calc(var(--base-grid-size) * -1) calc(var(--base-grid-size) * -3)}:host.large riv-icon:has(+ span:not(:empty)){margin-right:calc(var(--base-grid-size) * 3)}:host.large span:not(:empty)+riv-icon{margin-left:calc(var(--base-grid-size) * 3)}:host.xlarge{font-size:var(--type-3-font-size);line-height:var(--type-3-line-height-0);padding:calc(var(--base-grid-size) * 4) calc(var(--base-grid-size) * 6)}:host.xlarge riv-icon{margin:calc(var(--base-grid-size) * -1) calc(var(--base-grid-size) * -3)}:host.xlarge riv-icon:has(+ span:not(:empty)){margin-right:calc(var(--base-grid-size) * 3)}:host.xlarge span:not(:empty)+riv-icon{margin-left:calc(var(--base-grid-size) * 3)}:host.full{width:100%;justify-content:center}:host.loading{color:transparent;position:relative}:host.loading riv-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "component", type: i3.LoadingComponent, selector: "riv-loading", inputs: ["size", "variant"] }] });
|
|
54
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ButtonComponent, decorators: [{
|
|
55
|
+
type: Component,
|
|
56
|
+
args: [{ selector: '[rivButton]', template: "<riv-icon\n *ngIf=\"!locked && icon && iconPosition === 'first'\"\n [name]=\"icon\"\n [size]=\"getIconSize()\"\n></riv-icon>\n<span><ng-content></ng-content></span>\n<riv-icon *ngIf=\"locked\" [name]=\"'Lock'\" [size]=\"getIconSize()\"></riv-icon>\n<riv-icon\n *ngIf=\"!locked && icon && iconPosition === 'last'\"\n [name]=\"icon\"\n [size]=\"getIconSize()\"\n></riv-icon>\n<riv-loading\n *ngIf=\"loading\"\n [size]=\"16\"\n [variant]=\"getLoadingVariant()\"\n></riv-loading>\n", styles: [":host{border-radius:var(--border-radius-small);transition:background-color var(--medium-transition);display:inline-flex;align-items:center;cursor:pointer;text-decoration:none}:host:disabled,:host.disabled{cursor:default}:host.basic{color:var(--purp-80);background-color:var(--black-10);border:var(--border-width) solid var(--border-light-blend)}:host.basic:hover{background-color:var(--black-20)}:host.basic:active{background-color:var(--black-30)}:host.basic:disabled,:host.basic.disabled{border-color:transparent;background-color:var(--black-10);color:var(--type-light-disabled)}:host.primary{color:var(--white-90);background-color:var(--purp-60);border:var(--border-width) solid var(--border-dark-blend)}:host.primary:hover{background-color:var(--purp-70)}:host.primary:active{background-color:var(--purp-80)}:host.primary:disabled,:host.primary.disabled{border-color:transparent;background-color:var(--purp-10);color:var(--type-light-disabled)}:host.ghost{color:var(--purp-80);background-color:transparent;border:var(--border-width) solid transparent}:host.ghost:hover{background-color:var(--black-20)}:host.ghost:active{background-color:var(--black-40)}:host.ghost:disabled,:host.ghost.disabled{color:var(--type-light-disabled);background-color:transparent}:host.caution{color:var(--type-light-caution);background-color:var(--surface-light-caution);border:var(--border-width) solid transparent}:host.caution:hover{background-color:var(--black-20)}:host.caution:active{background-color:var(--black-40)}:host.caution:disabled,:host.caution.disabled{border-color:transparent;background-color:var(--arnge-10);color:var(--type-light-disabled)}:host.danger{color:var(--white-90);background-color:var(--fyre-50);border:var(--border-width) solid var(--border-dark-blend)}:host.danger:hover{background-color:var(--fyre-70)}:host.danger:active{background-color:var(--fyre-90)}:host.danger:disabled,:host.danger.disabled{border-color:transparent;background-color:var(--fyre-10);color:var(--type-light-disabled)}:host.xsmall{font-size:var(--type-1-font-size);line-height:var(--type-1-line-height-0);padding:calc(var(--base-grid-size) * 1.5) calc(var(--base-grid-size) * 2)}:host.xsmall riv-icon{margin:calc(var(--base-grid-size) / -2) calc(var(--base-grid-size) * -1)}:host.xsmall riv-icon:has(+ span:not(:empty)){margin-right:var(--base-grid-size)}:host.xsmall span:not(:empty)+riv-icon{margin-left:var(--base-grid-size)}:host.small{font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);padding:calc(var(--base-grid-size) * 1.5) calc(var(--base-grid-size) * 3)}:host.small riv-icon{margin:0 calc(var(--base-grid-size) * -1.5)}:host.small riv-icon:has(+ span:not(:empty)){margin-right:calc(var(--base-grid-size) * 1.5)}:host.small span:not(:empty)+riv-icon{margin-left:calc(var(--base-grid-size) * 1.5)}:host.medium{font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);padding:calc(var(--base-grid-size) * 2) calc(var(--base-grid-size) * 3)}:host.medium riv-icon{margin:calc(var(--base-grid-size) * -1) calc(var(--base-grid-size) * -2)}:host.medium riv-icon:has(+ span:not(:empty)){margin-right:calc(var(--base-grid-size))}:host.medium span:not(:empty)+riv-icon{margin-left:calc(var(--base-grid-size) * 2)}:host.large{font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);padding:calc(var(--base-grid-size) * 3) calc(var(--base-grid-size) * 5)}:host.large riv-icon{margin:calc(var(--base-grid-size) * -1) calc(var(--base-grid-size) * -3)}:host.large riv-icon:has(+ span:not(:empty)){margin-right:calc(var(--base-grid-size) * 3)}:host.large span:not(:empty)+riv-icon{margin-left:calc(var(--base-grid-size) * 3)}:host.xlarge{font-size:var(--type-3-font-size);line-height:var(--type-3-line-height-0);padding:calc(var(--base-grid-size) * 4) calc(var(--base-grid-size) * 6)}:host.xlarge riv-icon{margin:calc(var(--base-grid-size) * -1) calc(var(--base-grid-size) * -3)}:host.xlarge riv-icon:has(+ span:not(:empty)){margin-right:calc(var(--base-grid-size) * 3)}:host.xlarge span:not(:empty)+riv-icon{margin-left:calc(var(--base-grid-size) * 3)}:host.full{width:100%;justify-content:center}:host.loading{color:transparent;position:relative}:host.loading riv-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}\n"] }]
|
|
57
|
+
}], propDecorators: { locked: [{
|
|
58
|
+
type: Input
|
|
59
|
+
}], disabled: [{
|
|
60
|
+
type: Input
|
|
61
|
+
}], loading: [{
|
|
62
|
+
type: Input
|
|
63
|
+
}], full: [{
|
|
64
|
+
type: Input
|
|
65
|
+
}], size: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], variant: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}], icon: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}], iconPosition: [{
|
|
72
|
+
type: Input
|
|
73
|
+
}], classes: [{
|
|
74
|
+
type: HostBinding,
|
|
75
|
+
args: ['class']
|
|
76
|
+
}] } });
|
|
77
|
+
(function (ButtonComponent) {
|
|
78
|
+
ButtonComponent.Sizes = [
|
|
79
|
+
'xsmall',
|
|
80
|
+
'small',
|
|
81
|
+
'medium',
|
|
82
|
+
'large',
|
|
83
|
+
'xlarge',
|
|
84
|
+
];
|
|
85
|
+
ButtonComponent.Variants = [
|
|
86
|
+
'basic',
|
|
87
|
+
'ghost',
|
|
88
|
+
'primary',
|
|
89
|
+
'danger',
|
|
90
|
+
'caution',
|
|
91
|
+
];
|
|
92
|
+
ButtonComponent.IconPositions = ['first', 'last'];
|
|
93
|
+
})(ButtonComponent || (ButtonComponent = {}));
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Jpdi9zcmMvbGliL2lucHV0L2J1dHRvbi9idXR0b24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcml2L3NyYy9saWIvaW5wdXQvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBUzlELE1BQU0sT0FBTyxlQUFlO0lBTDVCO1FBT0UsV0FBTSxHQUFZLEtBQUssQ0FBQztRQUd4QixhQUFRLEdBQVksS0FBSyxDQUFDO1FBRzFCLFlBQU8sR0FBWSxLQUFLLENBQUM7UUFHekIsU0FBSSxHQUFZLEtBQUssQ0FBQztRQUd0QixTQUFJLEdBQXlCLFFBQVEsQ0FBQztRQUd0QyxZQUFPLEdBQTRCLE9BQU8sQ0FBQztRQU0zQyxpQkFBWSxHQUFpQyxPQUFPLENBQUM7S0F3Q3REO0lBdENDLElBQ0ksT0FBTztRQUNULE9BQU8sTUFBTSxDQUFDLE9BQU8sQ0FBQztZQUNwQixNQUFNLEVBQUUsSUFBSTtZQUNaLFFBQVEsRUFBRSxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxNQUFNO1lBQ3RDLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsRUFBRSxJQUFJO1lBQ3BCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUk7U0FDbEIsQ0FBQzthQUNDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7YUFDckIsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDO2FBQ2YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2YsQ0FBQztJQUVELGlCQUFpQjtRQUNmLFFBQVEsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNwQixLQUFLLE9BQU8sQ0FBQztZQUNiLEtBQUssU0FBUyxDQUFDO1lBQ2YsS0FBSyxPQUFPO2dCQUNWLE9BQU8sTUFBTSxDQUFDO1lBQ2hCLEtBQUssUUFBUSxDQUFDO1lBQ2QsS0FBSyxTQUFTO2dCQUNaLE9BQU8sT0FBTyxDQUFDO1NBQ2xCO0lBQ0gsQ0FBQztJQUVELFdBQVc7UUFDVCxRQUFRLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDakIsS0FBSyxRQUFRLENBQUM7WUFDZCxLQUFLLE9BQU87Z0JBQ1YsT0FBTyxFQUFFLENBQUM7WUFDWixLQUFLLFFBQVEsQ0FBQztZQUNkLEtBQUssT0FBTyxDQUFDO1lBQ2IsS0FBSyxRQUFRO2dCQUNYLE9BQU8sRUFBRSxDQUFDO1NBQ2I7SUFDSCxDQUFDOzs0R0E5RFUsZUFBZTtnR0FBZixlQUFlLDBRQ1Q1Qix3ZUFpQkE7MkZEUmEsZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxhQUFhOzhCQU12QixNQUFNO3NCQURMLEtBQUs7Z0JBSU4sUUFBUTtzQkFEUCxLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJTixJQUFJO3NCQURILEtBQUs7Z0JBSU4sSUFBSTtzQkFESCxLQUFLO2dCQUlOLE9BQU87c0JBRE4sS0FBSztnQkFJTixJQUFJO3NCQURILEtBQUs7Z0JBSU4sWUFBWTtzQkFEWCxLQUFLO2dCQUlGLE9BQU87c0JBRFYsV0FBVzt1QkFBQyxPQUFPOztBQXdDdEIsV0FBaUIsZUFBZTtJQUNqQixxQkFBSyxHQUFHO1FBQ25CLFFBQVE7UUFDUixPQUFPO1FBQ1AsUUFBUTtRQUNSLE9BQU87UUFDUCxRQUFRO0tBQ0EsQ0FBQztJQUdFLHdCQUFRLEdBQUc7UUFDdEIsT0FBTztRQUNQLE9BQU87UUFDUCxTQUFTO1FBQ1QsUUFBUTtRQUNSLFNBQVM7S0FDRCxDQUFDO0lBR0UsNkJBQWEsR0FBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQVUsQ0FBQztBQUUxRCxDQUFDLEVBckJnQixlQUFlLEtBQWYsZUFBZSxRQXFCL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTG9hZGluZ0NvbXBvbmVudCB9IGZyb20gJy4uLy4uL2xvYWQvbG9hZGluZy9sb2FkaW5nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJY29uTmFtZXMsIEljb25TaXplIH0gZnJvbSAnLi4vLi4vaWNvbi9pY29ucyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ1tyaXZCdXR0b25dJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2J1dHRvbi5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2J1dHRvbi5jb21wb25lbnQuY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEJ1dHRvbkNvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIGxvY2tlZDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpXG4gIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgQElucHV0KClcbiAgbG9hZGluZzogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpXG4gIGZ1bGw6IGJvb2xlYW4gPSBmYWxzZTtcblxuICBASW5wdXQoKVxuICBzaXplOiBCdXR0b25Db21wb25lbnQuU2l6ZSA9ICdtZWRpdW0nO1xuXG4gIEBJbnB1dCgpXG4gIHZhcmlhbnQ6IEJ1dHRvbkNvbXBvbmVudC5WYXJpYW50ID0gJ2Jhc2ljJztcblxuICBASW5wdXQoKVxuICBpY29uPzogSWNvbk5hbWVzO1xuXG4gIEBJbnB1dCgpXG4gIGljb25Qb3NpdGlvbjogQnV0dG9uQ29tcG9uZW50Lkljb25Qb3NpdGlvbiA9ICdmaXJzdCc7XG5cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gIGdldCBjbGFzc2VzKCkge1xuICAgIHJldHVybiBPYmplY3QuZW50cmllcyh7XG4gICAgICBidXR0b246IHRydWUsXG4gICAgICBkaXNhYmxlZDogdGhpcy5kaXNhYmxlZCB8fCB0aGlzLmxvY2tlZCxcbiAgICAgIGZ1bGw6IHRoaXMuZnVsbCxcbiAgICAgIGxvYWRpbmc6IHRoaXMubG9hZGluZyxcbiAgICAgIFt0aGlzLnZhcmlhbnRdOiB0cnVlLFxuICAgICAgW3RoaXMuc2l6ZV06IHRydWUsXG4gICAgfSlcbiAgICAgIC5maWx0ZXIoKFtfLCB2XSkgPT4gdilcbiAgICAgIC5tYXAoKFtrXSkgPT4gaylcbiAgICAgIC5qb2luKCcgJyk7XG4gIH1cblxuICBnZXRMb2FkaW5nVmFyaWFudCgpOiBMb2FkaW5nQ29tcG9uZW50LlZhcmlhbnQge1xuICAgIHN3aXRjaCAodGhpcy52YXJpYW50KSB7XG4gICAgICBjYXNlICdiYXNpYyc6XG4gICAgICBjYXNlICdjYXV0aW9uJzpcbiAgICAgIGNhc2UgJ2dob3N0JzpcbiAgICAgICAgcmV0dXJuICdkYXJrJztcbiAgICAgIGNhc2UgJ2Rhbmdlcic6XG4gICAgICBjYXNlICdwcmltYXJ5JzpcbiAgICAgICAgcmV0dXJuICdsaWdodCc7XG4gICAgfVxuICB9XG5cbiAgZ2V0SWNvblNpemUoKTogSWNvblNpemUge1xuICAgIHN3aXRjaCAodGhpcy5zaXplKSB7XG4gICAgICBjYXNlICd4c21hbGwnOlxuICAgICAgY2FzZSAnc21hbGwnOlxuICAgICAgICByZXR1cm4gMTY7XG4gICAgICBjYXNlICdtZWRpdW0nOlxuICAgICAgY2FzZSAnbGFyZ2UnOlxuICAgICAgY2FzZSAneGxhcmdlJzpcbiAgICAgICAgcmV0dXJuIDI0O1xuICAgIH1cbiAgfVxufVxuXG5leHBvcnQgbmFtZXNwYWNlIEJ1dHRvbkNvbXBvbmVudCB7XG4gIGV4cG9ydCBjb25zdCBTaXplcyA9IFtcbiAgICAneHNtYWxsJyxcbiAgICAnc21hbGwnLFxuICAgICdtZWRpdW0nLFxuICAgICdsYXJnZScsXG4gICAgJ3hsYXJnZScsXG4gIF0gYXMgY29uc3Q7XG4gIGV4cG9ydCB0eXBlIFNpemUgPSAodHlwZW9mIFNpemVzKVtudW1iZXJdO1xuXG4gIGV4cG9ydCBjb25zdCBWYXJpYW50cyA9IFtcbiAgICAnYmFzaWMnLFxuICAgICdnaG9zdCcsXG4gICAgJ3ByaW1hcnknLFxuICAgICdkYW5nZXInLFxuICAgICdjYXV0aW9uJyxcbiAgXSBhcyBjb25zdDtcbiAgZXhwb3J0IHR5cGUgVmFyaWFudCA9ICh0eXBlb2YgVmFyaWFudHMpW251bWJlcl07XG5cbiAgZXhwb3J0IGNvbnN0IEljb25Qb3NpdGlvbnMgPSBbJ2ZpcnN0JywgJ2xhc3QnXSBhcyBjb25zdDtcbiAgZXhwb3J0IHR5cGUgSWNvblBvc2l0aW9uID0gKHR5cGVvZiBJY29uUG9zaXRpb25zKVtudW1iZXJdO1xufVxuIiwiPHJpdi1pY29uXG4gICpuZ0lmPVwiIWxvY2tlZCAmJiBpY29uICYmIGljb25Qb3NpdGlvbiA9PT0gJ2ZpcnN0J1wiXG4gIFtuYW1lXT1cImljb25cIlxuICBbc2l6ZV09XCJnZXRJY29uU2l6ZSgpXCJcbj48L3Jpdi1pY29uPlxuPHNwYW4+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50Pjwvc3Bhbj5cbjxyaXYtaWNvbiAqbmdJZj1cImxvY2tlZFwiIFtuYW1lXT1cIidMb2NrJ1wiIFtzaXplXT1cImdldEljb25TaXplKClcIj48L3Jpdi1pY29uPlxuPHJpdi1pY29uXG4gICpuZ0lmPVwiIWxvY2tlZCAmJiBpY29uICYmIGljb25Qb3NpdGlvbiA9PT0gJ2xhc3QnXCJcbiAgW25hbWVdPVwiaWNvblwiXG4gIFtzaXplXT1cImdldEljb25TaXplKClcIlxuPjwvcml2LWljb24+XG48cml2LWxvYWRpbmdcbiAgKm5nSWY9XCJsb2FkaW5nXCJcbiAgW3NpemVdPVwiMTZcIlxuICBbdmFyaWFudF09XCJnZXRMb2FkaW5nVmFyaWFudCgpXCJcbj48L3Jpdi1sb2FkaW5nPlxuIl19
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
+
import { debounceTime, from, map, pairwise, startWith, switchMap, } from 'rxjs';
|
|
3
|
+
import Fuse from 'fuse.js';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "../../modal/callout/callout.component";
|
|
7
|
+
import * as i3 from "../../visualization/highlight/highlight.component";
|
|
8
|
+
import * as i4 from "../../icon/icon.component";
|
|
9
|
+
import * as i5 from "../../load/loading-cover/loading-cover.component";
|
|
10
|
+
export class SingleSelectComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.options = [];
|
|
13
|
+
this.selectedOption = null;
|
|
14
|
+
this.filterabilityOptions = {
|
|
15
|
+
enabled: false,
|
|
16
|
+
};
|
|
17
|
+
this.loading = false;
|
|
18
|
+
this.noOptionsMessage = 'No available options';
|
|
19
|
+
this.placeholder = 'Select...';
|
|
20
|
+
this.filterQuery = '';
|
|
21
|
+
this.filterQueryChange = new EventEmitter();
|
|
22
|
+
this.selectedOptionChange = new EventEmitter();
|
|
23
|
+
this.open = false;
|
|
24
|
+
}
|
|
25
|
+
getFilterPlaceholder() {
|
|
26
|
+
if (this.filterabilityOptions.enabled &&
|
|
27
|
+
this.filterabilityOptions.placeholder) {
|
|
28
|
+
return this.filterabilityOptions.placeholder;
|
|
29
|
+
}
|
|
30
|
+
return 'Filter options...';
|
|
31
|
+
}
|
|
32
|
+
getNodes() {
|
|
33
|
+
return this.options.map(option => ({
|
|
34
|
+
...option,
|
|
35
|
+
selected: option.id === this.selectedOption?.id,
|
|
36
|
+
}));
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
SingleSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SingleSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
40
|
+
SingleSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SingleSelectComponent, selector: "riv-single-select", inputs: { options: "options", selectedOption: "selectedOption", filterabilityOptions: "filterabilityOptions", loading: "loading", noOptionsMessage: "noOptionsMessage", nodeTemplate: "nodeTemplate", placeholder: "placeholder" }, outputs: { filterQueryChange: "filterQueryChange", selectedOptionChange: "selectedOptionChange" }, ngImport: i0, template: "<button #trigger class=\"trigger\" (click)=\"open = true\">\n <ng-container *ngIf=\"selectedOption; else placeholderValue\">\n <span class=\"value\">{{ selectedOption.title }}</span>\n </ng-container>\n <ng-template #placeholderValue>\n <span class=\"value placeholder\">{{ placeholder }}</span>\n </ng-template>\n <span class=\"chevron\">\n <riv-icon [name]=\"'ChevronDown'\" [size]=\"16\"></riv-icon>\n </span>\n</button>\n\n<riv-callout\n *ngIf=\"open\"\n [anchor]=\"trigger\"\n [theme]=\"'light'\"\n [showCaret]=\"false\"\n [allowedPositions]=\"[\n 'top-left',\n 'top-center',\n 'top-right',\n 'bottom-right',\n 'bottom-center',\n 'bottom-left'\n ]\"\n (close)=\"open = false\"\n>\n <input\n *ngIf=\"filterabilityOptions.enabled\"\n #filter\n class=\"filter\"\n [placeholder]=\"getFilterPlaceholder()\"\n [value]=\"filterQuery\"\n (input)=\"filterQuery = filter.value; filterQueryChange.emit(filterQuery)\"\n />\n <div class=\"options\">\n <riv-loading-cover [loading]=\"loading\">\n <ng-container *ngIf=\"getNodes(); let nodes\">\n <ng-container *ngIf=\"nodes.length > 0; else empty\">\n <ng-container *ngFor=\"let node of nodes\">\n <ng-container *ngIf=\"nodeTemplate; else standardTemplate\">\n <button\n class=\"custom-single-select-node\"\n [disabled]=\"node.disabled\"\n (click)=\"selectedOptionChange.emit(node); open = false\"\n >\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplate\"\n [ngTemplateOutletContext]=\"{ node: node }\"\n ></ng-container>\n </button>\n </ng-container>\n <ng-template #standardTemplate>\n <button\n class=\"single-select-node\"\n [class.selected]=\"node?.selected\"\n [class.disabled]=\"node?.disabled\"\n (click)=\"selectedOptionChange.emit(node); open = false\"\n >\n <riv-icon\n [name]=\"'Check'\"\n *ngIf=\"node?.selected\"\n [size]=\"16\"\n ></riv-icon>\n <span class=\"label\">\n <span class=\"label-title\">\n <riv-highlight\n [text]=\"node?.title || ''\"\n [indices]=\"node?.titleHighlightIndices || []\"\n ></riv-highlight>\n </span>\n <span *ngIf=\"node?.subtitle\" class=\"label-subtitle\">\n <riv-highlight\n [text]=\"node?.subtitle || ''\"\n [indices]=\"node?.subtitleHighlightIndices || []\"\n ></riv-highlight>\n </span>\n </span>\n </button>\n </ng-template>\n </ng-container>\n </ng-container>\n <ng-template #empty>\n <div class=\"empty\">\n {{ noOptionsMessage }}\n </div>\n </ng-template>\n </ng-container>\n </riv-loading-cover>\n </div>\n</riv-callout>\n", styles: [".trigger{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);display:flex;gap:var(--size-small)}.trigger:focus{outline:none;border:var(--border-width) solid var(--purp-60)}.trigger:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}.value{font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);color:var(--type-light-high-contrast);padding:var(--size-small);flex-grow:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:pre}.value.placeholder{color:var(--type-light-disabled)}.chevron{display:flex;justify-content:center;align-items:center;padding:var(--size-small);background-color:var(--surface-light-2);border-left:var(--border-width) solid var(--border-light)}.filter{width:100%;outline:none;border:none;border-bottom:var(--border-width) solid var(--border-light);font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);color:var(--type-light-high-contrast);padding:var(--size-small)}.filter::placeholder{color:var(--type-light-disabled)}.options{max-height:calc(var(--base-grid-size) * 200);max-width:calc(var(--base-grid-size) * 150);overflow-y:scroll}.single-select-node{display:flex;align-items:center;overflow:hidden;flex-grow:1;text-align:left;padding:var(--size-xsmall) var(--size-xsmall) var(--size-xsmall) calc(var(--base-grid-size) * 6);width:100%}.single-select-node.selected{padding-left:var(--size-small)}.single-select-node:hover{background-color:var(--surface-light-2)}.single-select-node.disabled{cursor:default;background-color:var(--surface-light-0)}.single-select-node.disabled .label,.single-select-node.disabled .label-subtitle{color:var(--type-light-disabled)}.single-select-node riv-icon{flex-shrink:0}.single-select-node .label{font-size:calc(var(--base-grid-size) * 4);line-height:calc(var(--base-grid-size) * 6);overflow:hidden;text-overflow:ellipsis;white-space:pre;flex-grow:1;padding:0 calc(var(--base-grid-size) * 2)}.single-select-node .label-subtitle{padding-left:var(--base-grid-size);color:var(--type-light-low-contrast)}.custom-single-select-node{display:block;width:100%;text-align:left}.empty{padding:var(--size-medium);text-align:center;color:var(--type-light-disabled)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.CalloutComponent, selector: "riv-callout", inputs: ["anchor", "isModal", "preferredPosition", "allowedPositions", "fallbackDirection", "showCaret", "theme"], outputs: ["close"] }, { kind: "component", type: i3.HighlightComponent, selector: "riv-highlight", inputs: ["text", "indices"] }, { kind: "component", type: i4.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "component", type: i5.LoadingCoverComponent, selector: "riv-loading-cover", inputs: ["loading", "loadingSize", "errorMessage"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
41
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SingleSelectComponent, decorators: [{
|
|
42
|
+
type: Component,
|
|
43
|
+
args: [{ selector: 'riv-single-select', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button #trigger class=\"trigger\" (click)=\"open = true\">\n <ng-container *ngIf=\"selectedOption; else placeholderValue\">\n <span class=\"value\">{{ selectedOption.title }}</span>\n </ng-container>\n <ng-template #placeholderValue>\n <span class=\"value placeholder\">{{ placeholder }}</span>\n </ng-template>\n <span class=\"chevron\">\n <riv-icon [name]=\"'ChevronDown'\" [size]=\"16\"></riv-icon>\n </span>\n</button>\n\n<riv-callout\n *ngIf=\"open\"\n [anchor]=\"trigger\"\n [theme]=\"'light'\"\n [showCaret]=\"false\"\n [allowedPositions]=\"[\n 'top-left',\n 'top-center',\n 'top-right',\n 'bottom-right',\n 'bottom-center',\n 'bottom-left'\n ]\"\n (close)=\"open = false\"\n>\n <input\n *ngIf=\"filterabilityOptions.enabled\"\n #filter\n class=\"filter\"\n [placeholder]=\"getFilterPlaceholder()\"\n [value]=\"filterQuery\"\n (input)=\"filterQuery = filter.value; filterQueryChange.emit(filterQuery)\"\n />\n <div class=\"options\">\n <riv-loading-cover [loading]=\"loading\">\n <ng-container *ngIf=\"getNodes(); let nodes\">\n <ng-container *ngIf=\"nodes.length > 0; else empty\">\n <ng-container *ngFor=\"let node of nodes\">\n <ng-container *ngIf=\"nodeTemplate; else standardTemplate\">\n <button\n class=\"custom-single-select-node\"\n [disabled]=\"node.disabled\"\n (click)=\"selectedOptionChange.emit(node); open = false\"\n >\n <ng-container\n [ngTemplateOutlet]=\"nodeTemplate\"\n [ngTemplateOutletContext]=\"{ node: node }\"\n ></ng-container>\n </button>\n </ng-container>\n <ng-template #standardTemplate>\n <button\n class=\"single-select-node\"\n [class.selected]=\"node?.selected\"\n [class.disabled]=\"node?.disabled\"\n (click)=\"selectedOptionChange.emit(node); open = false\"\n >\n <riv-icon\n [name]=\"'Check'\"\n *ngIf=\"node?.selected\"\n [size]=\"16\"\n ></riv-icon>\n <span class=\"label\">\n <span class=\"label-title\">\n <riv-highlight\n [text]=\"node?.title || ''\"\n [indices]=\"node?.titleHighlightIndices || []\"\n ></riv-highlight>\n </span>\n <span *ngIf=\"node?.subtitle\" class=\"label-subtitle\">\n <riv-highlight\n [text]=\"node?.subtitle || ''\"\n [indices]=\"node?.subtitleHighlightIndices || []\"\n ></riv-highlight>\n </span>\n </span>\n </button>\n </ng-template>\n </ng-container>\n </ng-container>\n <ng-template #empty>\n <div class=\"empty\">\n {{ noOptionsMessage }}\n </div>\n </ng-template>\n </ng-container>\n </riv-loading-cover>\n </div>\n</riv-callout>\n", styles: [".trigger{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);display:flex;gap:var(--size-small)}.trigger:focus{outline:none;border:var(--border-width) solid var(--purp-60)}.trigger:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}.value{font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);color:var(--type-light-high-contrast);padding:var(--size-small);flex-grow:1;text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:pre}.value.placeholder{color:var(--type-light-disabled)}.chevron{display:flex;justify-content:center;align-items:center;padding:var(--size-small);background-color:var(--surface-light-2);border-left:var(--border-width) solid var(--border-light)}.filter{width:100%;outline:none;border:none;border-bottom:var(--border-width) solid var(--border-light);font-size:var(--type-2-font-size);line-height:var(--type-2-line-height-0);color:var(--type-light-high-contrast);padding:var(--size-small)}.filter::placeholder{color:var(--type-light-disabled)}.options{max-height:calc(var(--base-grid-size) * 200);max-width:calc(var(--base-grid-size) * 150);overflow-y:scroll}.single-select-node{display:flex;align-items:center;overflow:hidden;flex-grow:1;text-align:left;padding:var(--size-xsmall) var(--size-xsmall) var(--size-xsmall) calc(var(--base-grid-size) * 6);width:100%}.single-select-node.selected{padding-left:var(--size-small)}.single-select-node:hover{background-color:var(--surface-light-2)}.single-select-node.disabled{cursor:default;background-color:var(--surface-light-0)}.single-select-node.disabled .label,.single-select-node.disabled .label-subtitle{color:var(--type-light-disabled)}.single-select-node riv-icon{flex-shrink:0}.single-select-node .label{font-size:calc(var(--base-grid-size) * 4);line-height:calc(var(--base-grid-size) * 6);overflow:hidden;text-overflow:ellipsis;white-space:pre;flex-grow:1;padding:0 calc(var(--base-grid-size) * 2)}.single-select-node .label-subtitle{padding-left:var(--base-grid-size);color:var(--type-light-low-contrast)}.custom-single-select-node{display:block;width:100%;text-align:left}.empty{padding:var(--size-medium);text-align:center;color:var(--type-light-disabled)}\n"] }]
|
|
44
|
+
}], propDecorators: { options: [{
|
|
45
|
+
type: Input
|
|
46
|
+
}], selectedOption: [{
|
|
47
|
+
type: Input
|
|
48
|
+
}], filterabilityOptions: [{
|
|
49
|
+
type: Input
|
|
50
|
+
}], loading: [{
|
|
51
|
+
type: Input
|
|
52
|
+
}], noOptionsMessage: [{
|
|
53
|
+
type: Input
|
|
54
|
+
}], nodeTemplate: [{
|
|
55
|
+
type: Input
|
|
56
|
+
}], placeholder: [{
|
|
57
|
+
type: Input
|
|
58
|
+
}], filterQueryChange: [{
|
|
59
|
+
type: Output
|
|
60
|
+
}], selectedOptionChange: [{
|
|
61
|
+
type: Output
|
|
62
|
+
}] } });
|
|
63
|
+
(function (SingleSelectComponent) {
|
|
64
|
+
function getFilterSync(options, exact = false) {
|
|
65
|
+
const fuse = new Fuse(options, {
|
|
66
|
+
keys: ['title', 'subtitle'],
|
|
67
|
+
includeMatches: true,
|
|
68
|
+
shouldSort: true,
|
|
69
|
+
threshold: exact ? 0.0 : 0.6,
|
|
70
|
+
});
|
|
71
|
+
return function filter(query) {
|
|
72
|
+
if (!query)
|
|
73
|
+
return options;
|
|
74
|
+
const matches = fuse.search(query);
|
|
75
|
+
return matches.map(match => {
|
|
76
|
+
return {
|
|
77
|
+
...match.item,
|
|
78
|
+
titleHighlightIndices: [
|
|
79
|
+
...(match.matches?.find(result => result.key === 'title')
|
|
80
|
+
?.indices || []),
|
|
81
|
+
],
|
|
82
|
+
subtitleHighlightIndices: [
|
|
83
|
+
...(match.matches?.find(result => result.key === 'subtitle')
|
|
84
|
+
?.indices || []),
|
|
85
|
+
],
|
|
86
|
+
};
|
|
87
|
+
});
|
|
88
|
+
};
|
|
89
|
+
}
|
|
90
|
+
SingleSelectComponent.getFilterSync = getFilterSync;
|
|
91
|
+
function getFilterAsync(query$, fetcher, debounceInput = 300) {
|
|
92
|
+
return query$.pipe(debounceTime(debounceInput), switchMap(query => from(fetcher(query)).pipe(map(options => ({ loading: false, options })), startWith({ loading: true, options: [] }))), pairwise(), map(([previous, next]) => ({
|
|
93
|
+
loading: next.loading,
|
|
94
|
+
options: next.loading ? previous.options : next.options,
|
|
95
|
+
})), startWith({ loading: false, options: [] }));
|
|
96
|
+
}
|
|
97
|
+
SingleSelectComponent.getFilterAsync = getFilterAsync;
|
|
98
|
+
})(SingleSelectComponent || (SingleSelectComponent = {}));
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-select.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/input/single-select/single-select.component.ts","../../../../../../projects/riv/src/lib/input/single-select/single-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n} from '@angular/core';\nimport {\n  Observable,\n  debounceTime,\n  from,\n  map,\n  pairwise,\n  startWith,\n  switchMap,\n} from 'rxjs';\nimport Fuse from 'fuse.js';\nimport { HighlightComponent } from '../../visualization/highlight/highlight.component';\n\n@Component({\n  selector: 'riv-single-select',\n  templateUrl: './single-select.component.html',\n  styleUrls: ['./single-select.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SingleSelectComponent {\n  @Input()\n  options: SingleSelectComponent.Option[] = [];\n\n  @Input()\n  selectedOption: SingleSelectComponent.Option | null = null;\n\n  @Input()\n  filterabilityOptions: SingleSelectComponent.FilterabilityOptions = {\n    enabled: false,\n  };\n\n  @Input()\n  loading: boolean = false;\n\n  @Input()\n  noOptionsMessage: string = 'No available options';\n\n  @Input()\n  nodeTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  placeholder: string = 'Select...';\n\n  filterQuery: string = '';\n\n  @Output()\n  filterQueryChange = new EventEmitter<string>();\n\n  @Output()\n  selectedOptionChange = new EventEmitter<SingleSelectComponent.Option>();\n\n  getFilterPlaceholder(): string {\n    if (\n      this.filterabilityOptions.enabled &&\n      this.filterabilityOptions.placeholder\n    ) {\n      return this.filterabilityOptions.placeholder;\n    }\n    return 'Filter options...';\n  }\n\n  getNodes(): SingleSelectComponent.Node[] {\n    return this.options.map(option => ({\n      ...option,\n      selected: option.id === this.selectedOption?.id,\n    }));\n  }\n\n  open: boolean = false;\n}\n\nexport namespace SingleSelectComponent {\n  export type Option = {\n    id: string;\n    title: string;\n    subtitle?: string;\n    count?: number;\n    disabled?: boolean;\n    titleHighlightIndices?: HighlightComponent.HighlightIndices[];\n    subtitleHighlightIndices?: HighlightComponent.HighlightIndices[];\n  };\n\n  export type Node = Option & {\n    selected: boolean;\n  };\n\n  export type FilterabilityOptions =\n    | {\n        enabled: false;\n      }\n    | {\n        enabled: true;\n        placeholder?: string;\n      };\n\n  export function getFilterSync(\n    options: SingleSelectComponent.Option[],\n    exact: boolean = false,\n  ): (query: string) => SingleSelectComponent.Option[] {\n    const fuse = new Fuse(options, {\n      keys: ['title', 'subtitle'],\n      includeMatches: true,\n      shouldSort: true,\n      threshold: exact ? 0.0 : 0.6,\n    });\n\n    return function filter(query: string) {\n      if (!query) return options;\n      const matches = fuse.search(query);\n      return matches.map(match => {\n        return {\n          ...match.item,\n          titleHighlightIndices: [\n            ...(match.matches?.find(result => result.key === 'title')\n              ?.indices || []),\n          ],\n          subtitleHighlightIndices: [\n            ...(match.matches?.find(result => result.key === 'subtitle')\n              ?.indices || []),\n          ],\n        };\n      });\n    };\n  }\n\n  export function getFilterAsync(\n    query$: Observable<string>,\n    fetcher: (query: string) => Promise<SingleSelectComponent.Option[]>,\n    debounceInput: number = 300,\n  ): Observable<{\n    loading: boolean;\n    options: SingleSelectComponent.Option[];\n  }> {\n    return query$.pipe(\n      debounceTime(debounceInput),\n      switchMap(query =>\n        from(fetcher(query)).pipe(\n          map(options => ({ loading: false, options })),\n          startWith({ loading: true, options: [] }),\n        ),\n      ),\n      pairwise(),\n      map(([previous, next]) => ({\n        loading: next.loading,\n        options: next.loading ? previous.options : next.options,\n      })),\n      startWith({ loading: false, options: [] }),\n    );\n  }\n}\n","<button #trigger class=\"trigger\" (click)=\"open = true\">\n  <ng-container *ngIf=\"selectedOption; else placeholderValue\">\n    <span class=\"value\">{{ selectedOption.title }}</span>\n  </ng-container>\n  <ng-template #placeholderValue>\n    <span class=\"value placeholder\">{{ placeholder }}</span>\n  </ng-template>\n  <span class=\"chevron\">\n    <riv-icon [name]=\"'ChevronDown'\" [size]=\"16\"></riv-icon>\n  </span>\n</button>\n\n<riv-callout\n  *ngIf=\"open\"\n  [anchor]=\"trigger\"\n  [theme]=\"'light'\"\n  [showCaret]=\"false\"\n  [allowedPositions]=\"[\n    'top-left',\n    'top-center',\n    'top-right',\n    'bottom-right',\n    'bottom-center',\n    'bottom-left'\n  ]\"\n  (close)=\"open = false\"\n>\n  <input\n    *ngIf=\"filterabilityOptions.enabled\"\n    #filter\n    class=\"filter\"\n    [placeholder]=\"getFilterPlaceholder()\"\n    [value]=\"filterQuery\"\n    (input)=\"filterQuery = filter.value; filterQueryChange.emit(filterQuery)\"\n  />\n  <div class=\"options\">\n    <riv-loading-cover [loading]=\"loading\">\n      <ng-container *ngIf=\"getNodes(); let nodes\">\n        <ng-container *ngIf=\"nodes.length > 0; else empty\">\n          <ng-container *ngFor=\"let node of nodes\">\n            <ng-container *ngIf=\"nodeTemplate; else standardTemplate\">\n              <button\n                class=\"custom-single-select-node\"\n                [disabled]=\"node.disabled\"\n                (click)=\"selectedOptionChange.emit(node); open = false\"\n              >\n                <ng-container\n                  [ngTemplateOutlet]=\"nodeTemplate\"\n                  [ngTemplateOutletContext]=\"{ node: node }\"\n                ></ng-container>\n              </button>\n            </ng-container>\n            <ng-template #standardTemplate>\n              <button\n                class=\"single-select-node\"\n                [class.selected]=\"node?.selected\"\n                [class.disabled]=\"node?.disabled\"\n                (click)=\"selectedOptionChange.emit(node); open = false\"\n              >\n                <riv-icon\n                  [name]=\"'Check'\"\n                  *ngIf=\"node?.selected\"\n                  [size]=\"16\"\n                ></riv-icon>\n                <span class=\"label\">\n                  <span class=\"label-title\">\n                    <riv-highlight\n                      [text]=\"node?.title || ''\"\n                      [indices]=\"node?.titleHighlightIndices || []\"\n                    ></riv-highlight>\n                  </span>\n                  <span *ngIf=\"node?.subtitle\" class=\"label-subtitle\">\n                    <riv-highlight\n                      [text]=\"node?.subtitle || ''\"\n                      [indices]=\"node?.subtitleHighlightIndices || []\"\n                    ></riv-highlight>\n                  </span>\n                </span>\n              </button>\n            </ng-template>\n          </ng-container>\n        </ng-container>\n        <ng-template #empty>\n          <div class=\"empty\">\n            {{ noOptionsMessage }}\n          </div>\n        </ng-template>\n      </ng-container>\n    </riv-loading-cover>\n  </div>\n</riv-callout>\n"]}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
export class LoadingComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
this.size = 40;
|
|
7
|
+
this.variant = 'dark';
|
|
8
|
+
}
|
|
9
|
+
getHalfSize() {
|
|
10
|
+
return this.size / 2;
|
|
11
|
+
}
|
|
12
|
+
getStrokeWidth() {
|
|
13
|
+
return LoadingComponent.STROKE_WIDTH;
|
|
14
|
+
}
|
|
15
|
+
getHalfStroke() {
|
|
16
|
+
return LoadingComponent.STROKE_WIDTH / 2;
|
|
17
|
+
}
|
|
18
|
+
getRadius() {
|
|
19
|
+
return this.getHalfSize() - this.getHalfStroke();
|
|
20
|
+
}
|
|
21
|
+
getArcData() {
|
|
22
|
+
const halfSize = this.getHalfSize();
|
|
23
|
+
const radius = this.getRadius();
|
|
24
|
+
const mx = halfSize + radius * Math.sin(LoadingComponent.ARC_START_RADIANS);
|
|
25
|
+
const my = halfSize - radius * Math.cos(LoadingComponent.ARC_START_RADIANS);
|
|
26
|
+
const ax = halfSize;
|
|
27
|
+
const ay = halfSize;
|
|
28
|
+
const x = halfSize + radius;
|
|
29
|
+
const y = halfSize;
|
|
30
|
+
return `M${mx},${my} A${ax},${ay} 0 0,1 ${x},${y}`;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
LoadingComponent.STROKE_WIDTH = 1.5;
|
|
34
|
+
LoadingComponent.ARC_START_RADIANS = (Math.PI * 22.5) / 180;
|
|
35
|
+
LoadingComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LoadingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
36
|
+
LoadingComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: LoadingComponent, selector: "riv-loading", inputs: { size: "size", variant: "variant" }, ngImport: i0, template: "<svg\n [ngClass]=\"{\n dark: variant === 'dark',\n light: variant === 'light',\n small: size === 16,\n medium: size === 40,\n large: size === 80\n }\"\n xmlns=\"http://www.w3.org/2000/svg\"\n [attr.width]=\"size\"\n [attr.height]=\"size\"\n [attr.viewBox]=\"'0 0 ' + size + ' ' + size\"\n fill=\"none\"\n>\n <circle\n [attr.cx]=\"getHalfSize()\"\n [attr.cy]=\"getHalfSize()\"\n [attr.r]=\"getRadius()\"\n [attr.stroke-width]=\"getStrokeWidth()\"\n opacity=\".1\"\n />\n <path [attr.stroke-width]=\"getStrokeWidth()\" [attr.d]=\"getArcData()\"></path>\n</svg>\n", styles: [":host{display:inline-block;font-size:0;line-height:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dark path,.dark circle{stroke:var(--brand)}.light path,.light circle{stroke:var(--white-90)}.small{animation:.7s linear spin infinite}.medium{animation:.75s linear spin infinite}.large{animation:.9s linear spin infinite}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
37
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LoadingComponent, decorators: [{
|
|
38
|
+
type: Component,
|
|
39
|
+
args: [{ selector: 'riv-loading', changeDetection: ChangeDetectionStrategy.OnPush, template: "<svg\n [ngClass]=\"{\n dark: variant === 'dark',\n light: variant === 'light',\n small: size === 16,\n medium: size === 40,\n large: size === 80\n }\"\n xmlns=\"http://www.w3.org/2000/svg\"\n [attr.width]=\"size\"\n [attr.height]=\"size\"\n [attr.viewBox]=\"'0 0 ' + size + ' ' + size\"\n fill=\"none\"\n>\n <circle\n [attr.cx]=\"getHalfSize()\"\n [attr.cy]=\"getHalfSize()\"\n [attr.r]=\"getRadius()\"\n [attr.stroke-width]=\"getStrokeWidth()\"\n opacity=\".1\"\n />\n <path [attr.stroke-width]=\"getStrokeWidth()\" [attr.d]=\"getArcData()\"></path>\n</svg>\n", styles: [":host{display:inline-block;font-size:0;line-height:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dark path,.dark circle{stroke:var(--brand)}.light path,.light circle{stroke:var(--white-90)}.small{animation:.7s linear spin infinite}.medium{animation:.75s linear spin infinite}.large{animation:.9s linear spin infinite}\n"] }]
|
|
40
|
+
}], propDecorators: { size: [{
|
|
41
|
+
type: Input
|
|
42
|
+
}], variant: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}] } });
|
|
45
|
+
(function (LoadingComponent) {
|
|
46
|
+
LoadingComponent.Sizes = [16, 40, 80];
|
|
47
|
+
LoadingComponent.Variants = ['light', 'dark'];
|
|
48
|
+
})(LoadingComponent || (LoadingComponent = {}));
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yaXYvc3JjL2xpYi9sb2FkL2xvYWRpbmcvbG9hZGluZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yaXYvc3JjL2xpYi9sb2FkL2xvYWRpbmcvbG9hZGluZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBUTFFLE1BQU0sT0FBTyxnQkFBZ0I7SUFON0I7UUFXRSxTQUFJLEdBQTBCLEVBQUUsQ0FBQztRQUdqQyxZQUFPLEdBQTZCLE1BQU0sQ0FBQztLQTZCNUM7SUEzQkMsV0FBVztRQUNULE9BQU8sSUFBSSxDQUFDLElBQUksR0FBRyxDQUFDLENBQUM7SUFDdkIsQ0FBQztJQUVELGNBQWM7UUFDWixPQUFPLGdCQUFnQixDQUFDLFlBQVksQ0FBQztJQUN2QyxDQUFDO0lBRUQsYUFBYTtRQUNYLE9BQU8sZ0JBQWdCLENBQUMsWUFBWSxHQUFHLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRUQsU0FBUztRQUNQLE9BQU8sSUFBSSxDQUFDLFdBQVcsRUFBRSxHQUFHLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUNuRCxDQUFDO0lBRUQsVUFBVTtRQUNSLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNwQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDaEMsTUFBTSxFQUFFLEdBQUcsUUFBUSxHQUFHLE1BQU0sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDNUUsTUFBTSxFQUFFLEdBQUcsUUFBUSxHQUFHLE1BQU0sR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLGdCQUFnQixDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDNUUsTUFBTSxFQUFFLEdBQUcsUUFBUSxDQUFDO1FBQ3BCLE1BQU0sRUFBRSxHQUFHLFFBQVEsQ0FBQztRQUNwQixNQUFNLENBQUMsR0FBRyxRQUFRLEdBQUcsTUFBTSxDQUFDO1FBQzVCLE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQztRQUNuQixPQUFPLElBQUksRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztJQUNyRCxDQUFDOztBQW5DZSw2QkFBWSxHQUFHLEdBQUksQ0FBQTtBQUNuQixrQ0FBaUIsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFLEdBQUcsSUFBSSxDQUFDLEdBQUcsR0FBSSxDQUFBOzZHQUZoRCxnQkFBZ0I7aUdBQWhCLGdCQUFnQixpR0NSN0IsMGxCQXVCQTsyRkRmYSxnQkFBZ0I7a0JBTjVCLFNBQVM7K0JBQ0UsYUFBYSxtQkFHTix1QkFBdUIsQ0FBQyxNQUFNOzhCQU8vQyxJQUFJO3NCQURILEtBQUs7Z0JBSU4sT0FBTztzQkFETixLQUFLOztBQWdDUixXQUFpQixnQkFBZ0I7SUFDbEIsc0JBQUssR0FBRyxDQUFDLEVBQUUsRUFBRSxFQUFFLEVBQUUsRUFBRSxDQUFVLENBQUM7SUFHOUIseUJBQVEsR0FBRyxDQUFDLE9BQU8sRUFBRSxNQUFNLENBQVUsQ0FBQztBQUVyRCxDQUFDLEVBTmdCLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFNaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyaXYtbG9hZGluZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9sb2FkaW5nLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vbG9hZGluZy5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBMb2FkaW5nQ29tcG9uZW50IHtcbiAgc3RhdGljIHJlYWRvbmx5IFNUUk9LRV9XSURUSCA9IDEuNTtcbiAgc3RhdGljIHJlYWRvbmx5IEFSQ19TVEFSVF9SQURJQU5TID0gKE1hdGguUEkgKiAyMi41KSAvIDE4MDtcblxuICBASW5wdXQoKVxuICBzaXplOiBMb2FkaW5nQ29tcG9uZW50LlNpemUgPSA0MDtcblxuICBASW5wdXQoKVxuICB2YXJpYW50OiBMb2FkaW5nQ29tcG9uZW50LlZhcmlhbnQgPSAnZGFyayc7XG5cbiAgZ2V0SGFsZlNpemUoKSB7XG4gICAgcmV0dXJuIHRoaXMuc2l6ZSAvIDI7XG4gIH1cblxuICBnZXRTdHJva2VXaWR0aCgpIHtcbiAgICByZXR1cm4gTG9hZGluZ0NvbXBvbmVudC5TVFJPS0VfV0lEVEg7XG4gIH1cblxuICBnZXRIYWxmU3Ryb2tlKCkge1xuICAgIHJldHVybiBMb2FkaW5nQ29tcG9uZW50LlNUUk9LRV9XSURUSCAvIDI7XG4gIH1cblxuICBnZXRSYWRpdXMoKSB7XG4gICAgcmV0dXJuIHRoaXMuZ2V0SGFsZlNpemUoKSAtIHRoaXMuZ2V0SGFsZlN0cm9rZSgpO1xuICB9XG5cbiAgZ2V0QXJjRGF0YSgpIHtcbiAgICBjb25zdCBoYWxmU2l6ZSA9IHRoaXMuZ2V0SGFsZlNpemUoKTtcbiAgICBjb25zdCByYWRpdXMgPSB0aGlzLmdldFJhZGl1cygpO1xuICAgIGNvbnN0IG14ID0gaGFsZlNpemUgKyByYWRpdXMgKiBNYXRoLnNpbihMb2FkaW5nQ29tcG9uZW50LkFSQ19TVEFSVF9SQURJQU5TKTtcbiAgICBjb25zdCBteSA9IGhhbGZTaXplIC0gcmFkaXVzICogTWF0aC5jb3MoTG9hZGluZ0NvbXBvbmVudC5BUkNfU1RBUlRfUkFESUFOUyk7XG4gICAgY29uc3QgYXggPSBoYWxmU2l6ZTtcbiAgICBjb25zdCBheSA9IGhhbGZTaXplO1xuICAgIGNvbnN0IHggPSBoYWxmU2l6ZSArIHJhZGl1cztcbiAgICBjb25zdCB5ID0gaGFsZlNpemU7XG4gICAgcmV0dXJuIGBNJHtteH0sJHtteX0gQSR7YXh9LCR7YXl9IDAgMCwxICR7eH0sJHt5fWA7XG4gIH1cbn1cblxuZXhwb3J0IG5hbWVzcGFjZSBMb2FkaW5nQ29tcG9uZW50IHtcbiAgZXhwb3J0IGNvbnN0IFNpemVzID0gWzE2LCA0MCwgODBdIGFzIGNvbnN0O1xuICBleHBvcnQgdHlwZSBTaXplID0gKHR5cGVvZiBMb2FkaW5nQ29tcG9uZW50LlNpemVzKVtudW1iZXJdO1xuXG4gIGV4cG9ydCBjb25zdCBWYXJpYW50cyA9IFsnbGlnaHQnLCAnZGFyayddIGFzIGNvbnN0O1xuICBleHBvcnQgdHlwZSBWYXJpYW50ID0gKHR5cGVvZiBMb2FkaW5nQ29tcG9uZW50LlZhcmlhbnRzKVtudW1iZXJdO1xufVxuIiwiPHN2Z1xuICBbbmdDbGFzc109XCJ7XG4gICAgZGFyazogdmFyaWFudCA9PT0gJ2RhcmsnLFxuICAgIGxpZ2h0OiB2YXJpYW50ID09PSAnbGlnaHQnLFxuICAgIHNtYWxsOiBzaXplID09PSAxNixcbiAgICBtZWRpdW06IHNpemUgPT09IDQwLFxuICAgIGxhcmdlOiBzaXplID09PSA4MFxuICB9XCJcbiAgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiXG4gIFthdHRyLndpZHRoXT1cInNpemVcIlxuICBbYXR0ci5oZWlnaHRdPVwic2l6ZVwiXG4gIFthdHRyLnZpZXdCb3hdPVwiJzAgMCAnICsgc2l6ZSArICcgJyArIHNpemVcIlxuICBmaWxsPVwibm9uZVwiXG4+XG4gIDxjaXJjbGVcbiAgICBbYXR0ci5jeF09XCJnZXRIYWxmU2l6ZSgpXCJcbiAgICBbYXR0ci5jeV09XCJnZXRIYWxmU2l6ZSgpXCJcbiAgICBbYXR0ci5yXT1cImdldFJhZGl1cygpXCJcbiAgICBbYXR0ci5zdHJva2Utd2lkdGhdPVwiZ2V0U3Ryb2tlV2lkdGgoKVwiXG4gICAgb3BhY2l0eT1cIi4xXCJcbiAgLz5cbiAgPHBhdGggW2F0dHIuc3Ryb2tlLXdpZHRoXT1cImdldFN0cm9rZVdpZHRoKClcIiBbYXR0ci5kXT1cImdldEFyY0RhdGEoKVwiPjwvcGF0aD5cbjwvc3ZnPlxuIl19
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common";
|
|
4
|
+
import * as i2 from "../loading/loading.component";
|
|
5
|
+
export class LoadingCoverComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.loading = false;
|
|
8
|
+
this.loadingSize = 40;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
LoadingCoverComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LoadingCoverComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
LoadingCoverComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: LoadingCoverComponent, selector: "riv-loading-cover", inputs: { loading: "loading", loadingSize: "loadingSize", errorMessage: "errorMessage" }, ngImport: i0, template: "<ng-content></ng-content>\n<div *ngIf=\"loading\" class=\"cover\">\n <riv-loading [size]=\"loadingSize\"></riv-loading>\n</div>\n<div *ngIf=\"errorMessage\" class=\"cover\">\n <span class=\"error-icon\">\uD83D\uDE41</span>\n <span>{{ errorMessage }}</span>\n</div>\n", styles: [":host{display:block;max-width:100%;position:relative}.cover{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--size-xsmall);background-color:var(--white-90);border-radius:var(--border-radius-medium);text-align:center;color:var(--type-light-low-contrast);z-index:var(--loadable-z-index)}.error-icon{font-size:var(--type-5-font-size)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.LoadingComponent, selector: "riv-loading", inputs: ["size", "variant"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: LoadingCoverComponent, decorators: [{
|
|
14
|
+
type: Component,
|
|
15
|
+
args: [{ selector: 'riv-loading-cover', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content></ng-content>\n<div *ngIf=\"loading\" class=\"cover\">\n <riv-loading [size]=\"loadingSize\"></riv-loading>\n</div>\n<div *ngIf=\"errorMessage\" class=\"cover\">\n <span class=\"error-icon\">\uD83D\uDE41</span>\n <span>{{ errorMessage }}</span>\n</div>\n", styles: [":host{display:block;max-width:100%;position:relative}.cover{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--size-xsmall);background-color:var(--white-90);border-radius:var(--border-radius-medium);text-align:center;color:var(--type-light-low-contrast);z-index:var(--loadable-z-index)}.error-icon{font-size:var(--type-5-font-size)}\n"] }]
|
|
16
|
+
}], propDecorators: { loading: [{
|
|
17
|
+
type: Input
|
|
18
|
+
}], loadingSize: [{
|
|
19
|
+
type: Input
|
|
20
|
+
}], errorMessage: [{
|
|
21
|
+
type: Input
|
|
22
|
+
}] } });
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy1jb3Zlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yaXYvc3JjL2xpYi9sb2FkL2xvYWRpbmctY292ZXIvbG9hZGluZy1jb3Zlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yaXYvc3JjL2xpYi9sb2FkL2xvYWRpbmctY292ZXIvbG9hZGluZy1jb3Zlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQVMxRSxNQUFNLE9BQU8scUJBQXFCO0lBTmxDO1FBUUUsWUFBTyxHQUFZLEtBQUssQ0FBQztRQUd6QixnQkFBVyxHQUEwQixFQUFFLENBQUM7S0FJekM7O2tIQVRZLHFCQUFxQjtzR0FBckIscUJBQXFCLG1KQ1RsQywrUUFRQTsyRkRDYSxxQkFBcUI7a0JBTmpDLFNBQVM7K0JBQ0UsbUJBQW1CLG1CQUdaLHVCQUF1QixDQUFDLE1BQU07OEJBSS9DLE9BQU87c0JBRE4sS0FBSztnQkFJTixXQUFXO3NCQURWLEtBQUs7Z0JBSU4sWUFBWTtzQkFEWCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IExvYWRpbmdDb21wb25lbnQgfSBmcm9tICcuLi9sb2FkaW5nL2xvYWRpbmcuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncml2LWxvYWRpbmctY292ZXInLFxuICB0ZW1wbGF0ZVVybDogJy4vbG9hZGluZy1jb3Zlci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2xvYWRpbmctY292ZXIuY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgTG9hZGluZ0NvdmVyQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgbG9hZGluZzogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpXG4gIGxvYWRpbmdTaXplOiBMb2FkaW5nQ29tcG9uZW50LlNpemUgPSA0MDtcblxuICBASW5wdXQoKVxuICBlcnJvck1lc3NhZ2U/OiBzdHJpbmc7XG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48ZGl2ICpuZ0lmPVwibG9hZGluZ1wiIGNsYXNzPVwiY292ZXJcIj5cbiAgPHJpdi1sb2FkaW5nIFtzaXplXT1cImxvYWRpbmdTaXplXCI+PC9yaXYtbG9hZGluZz5cbjwvZGl2PlxuPGRpdiAqbmdJZj1cImVycm9yTWVzc2FnZVwiIGNsYXNzPVwiY292ZXJcIj5cbiAgPHNwYW4gY2xhc3M9XCJlcnJvci1pY29uXCI+8J+ZgTwvc3Bhbj5cbiAgPHNwYW4+e3sgZXJyb3JNZXNzYWdlIH19PC9zcGFuPlxuPC9kaXY+XG4iXX0=
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "../../icon/icon.component";
|
|
4
|
+
import * as i2 from "../tooltip/tooltip.directive";
|
|
5
|
+
export class HelpComponent {
|
|
6
|
+
}
|
|
7
|
+
HelpComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HelpComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
|
+
HelpComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: HelpComponent, selector: "riv-help", inputs: { help: "help" }, ngImport: i0, template: "<riv-icon [rivTooltip]=\"help\" [name]=\"'Info'\" [size]=\"16\"></riv-icon>\n", styles: ["riv-icon{line-height:0}\n"], dependencies: [{ kind: "component", type: i1.IconComponent, selector: "riv-icon", inputs: ["name", "size", "customSize", "strokeWidth"] }, { kind: "directive", type: i2.TooltipDirective, selector: "[rivTooltip]", inputs: ["rivTooltip", "rivTooltipTheme", "rivTooltipMaxWidth", "rivTooltipPreferredPosition", "rivTooltipCloseDelay"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
9
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: HelpComponent, decorators: [{
|
|
10
|
+
type: Component,
|
|
11
|
+
args: [{ selector: 'riv-help', changeDetection: ChangeDetectionStrategy.OnPush, template: "<riv-icon [rivTooltip]=\"help\" [name]=\"'Info'\" [size]=\"16\"></riv-icon>\n", styles: ["riv-icon{line-height:0}\n"] }]
|
|
12
|
+
}], propDecorators: { help: [{
|
|
13
|
+
type: Input
|
|
14
|
+
}] } });
|
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yaXYvc3JjL2xpYi9tb2RhbC9oZWxwL2hlbHAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcml2L3NyYy9saWIvbW9kYWwvaGVscC9oZWxwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBUTFFLE1BQU0sT0FBTyxhQUFhOzswR0FBYixhQUFhOzhGQUFiLGFBQWEsMEVDUjFCLCtFQUNBOzJGRE9hLGFBQWE7a0JBTnpCLFNBQVM7K0JBQ0UsVUFBVSxtQkFHSCx1QkFBdUIsQ0FBQyxNQUFNOzhCQUd0QyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyaXYtaGVscCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9oZWxwLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vaGVscC5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBIZWxwQ29tcG9uZW50IHtcbiAgQElucHV0KCkgaGVscD86IHN0cmluZztcbn1cbiIsIjxyaXYtaWNvbiBbcml2VG9vbHRpcF09XCJoZWxwXCIgW25hbWVdPVwiJ0luZm8nXCIgW3NpemVdPVwiMTZcIj48L3Jpdi1pY29uPlxuIl19
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { ButtonComponent } from './input/button/button.component';
|
|
1
2
|
import { CalloutComponent } from './modal/callout/callout.component';
|
|
2
3
|
import { CalloutDirective } from './modal/callout/callout.directive';
|
|
3
4
|
import { CalloutOutletComponent } from './modal/callout/callout-outlet.component';
|
|
@@ -9,12 +10,17 @@ import { DataTableRowComponent } from './visualization/data-table/data-table-row
|
|
|
9
10
|
import { DaysPipe } from './format/pipes/days.pipe';
|
|
10
11
|
import { DollarsPipe } from './format/pipes/dollars.pipe';
|
|
11
12
|
import { DonutComponent } from './visualization/donut/donut.component';
|
|
12
|
-
import {
|
|
13
|
+
import { HelpComponent } from './modal/help/help.component';
|
|
14
|
+
import { HighlightComponent } from './visualization/highlight/highlight.component';
|
|
15
|
+
import { IconComponent } from './icon/icon.component';
|
|
13
16
|
import { LegendItemComponent } from './visualization/legend-item/legend-item.component';
|
|
17
|
+
import { LoadingComponent } from './load/loading/loading.component';
|
|
18
|
+
import { LoadingCoverComponent } from './load/loading-cover/loading-cover.component';
|
|
14
19
|
import { MetricComponent } from './visualization/metric/metric.component';
|
|
15
20
|
import { NgModule } from '@angular/core';
|
|
16
21
|
import { NumberPipe } from './format/pipes/number.pipe';
|
|
17
22
|
import { PercentagePipe } from './format/pipes/percentage.pipe';
|
|
23
|
+
import { SingleSelectComponent } from './input/single-select/single-select.component';
|
|
18
24
|
import { SmallCurrencyPipe } from './format/pipes/small-currency.pipe';
|
|
19
25
|
import { StackedColumnComponent } from './visualization/stacked-column/stacked-column.component';
|
|
20
26
|
import { TextToggleComponent } from './content-toggle/text-toggle/text-toggle.component';
|
|
@@ -27,7 +33,8 @@ import * as i0 from "@angular/core";
|
|
|
27
33
|
export class RivModule {
|
|
28
34
|
}
|
|
29
35
|
RivModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RivModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
30
|
-
RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: RivModule, declarations: [
|
|
36
|
+
RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: RivModule, declarations: [ButtonComponent,
|
|
37
|
+
CalloutComponent,
|
|
31
38
|
CalloutDirective,
|
|
32
39
|
CalloutOutletComponent,
|
|
33
40
|
DataTableCellComponent,
|
|
@@ -37,19 +44,25 @@ RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.
|
|
|
37
44
|
DaysPipe,
|
|
38
45
|
DollarsPipe,
|
|
39
46
|
DonutComponent,
|
|
47
|
+
HelpComponent,
|
|
48
|
+
HighlightComponent,
|
|
40
49
|
IconComponent,
|
|
41
50
|
LegendItemComponent,
|
|
51
|
+
LoadingComponent,
|
|
52
|
+
LoadingCoverComponent,
|
|
42
53
|
MetricComponent,
|
|
43
54
|
NumberPipe,
|
|
44
55
|
PercentagePipe,
|
|
45
|
-
|
|
56
|
+
SingleSelectComponent,
|
|
46
57
|
SmallCurrencyPipe,
|
|
47
58
|
StackedColumnComponent,
|
|
48
59
|
TextToggleComponent,
|
|
49
60
|
TimeSeriesComponent,
|
|
50
61
|
TooltipComponent,
|
|
51
62
|
TooltipDirective,
|
|
52
|
-
|
|
63
|
+
TrendComponent,
|
|
64
|
+
ZeroStateComponent], imports: [CommonModule], exports: [ButtonComponent,
|
|
65
|
+
CalloutComponent,
|
|
53
66
|
CalloutDirective,
|
|
54
67
|
CalloutOutletComponent,
|
|
55
68
|
DataTableCellComponent,
|
|
@@ -59,24 +72,30 @@ RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.
|
|
|
59
72
|
DaysPipe,
|
|
60
73
|
DollarsPipe,
|
|
61
74
|
DonutComponent,
|
|
75
|
+
HelpComponent,
|
|
76
|
+
HighlightComponent,
|
|
62
77
|
IconComponent,
|
|
63
78
|
LegendItemComponent,
|
|
79
|
+
LoadingComponent,
|
|
80
|
+
LoadingCoverComponent,
|
|
64
81
|
MetricComponent,
|
|
65
82
|
NumberPipe,
|
|
66
83
|
PercentagePipe,
|
|
67
|
-
|
|
84
|
+
SingleSelectComponent,
|
|
68
85
|
SmallCurrencyPipe,
|
|
69
86
|
StackedColumnComponent,
|
|
70
87
|
TextToggleComponent,
|
|
71
88
|
TimeSeriesComponent,
|
|
72
89
|
TooltipComponent,
|
|
73
90
|
TooltipDirective,
|
|
91
|
+
TrendComponent,
|
|
74
92
|
ZeroStateComponent] });
|
|
75
93
|
RivModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RivModule, imports: [CommonModule] });
|
|
76
94
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RivModule, decorators: [{
|
|
77
95
|
type: NgModule,
|
|
78
96
|
args: [{
|
|
79
97
|
declarations: [
|
|
98
|
+
ButtonComponent,
|
|
80
99
|
CalloutComponent,
|
|
81
100
|
CalloutDirective,
|
|
82
101
|
CalloutOutletComponent,
|
|
@@ -87,21 +106,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
87
106
|
DaysPipe,
|
|
88
107
|
DollarsPipe,
|
|
89
108
|
DonutComponent,
|
|
109
|
+
HelpComponent,
|
|
110
|
+
HighlightComponent,
|
|
90
111
|
IconComponent,
|
|
91
112
|
LegendItemComponent,
|
|
113
|
+
LoadingComponent,
|
|
114
|
+
LoadingCoverComponent,
|
|
92
115
|
MetricComponent,
|
|
93
116
|
NumberPipe,
|
|
94
117
|
PercentagePipe,
|
|
95
|
-
|
|
118
|
+
SingleSelectComponent,
|
|
96
119
|
SmallCurrencyPipe,
|
|
97
120
|
StackedColumnComponent,
|
|
98
121
|
TextToggleComponent,
|
|
99
122
|
TimeSeriesComponent,
|
|
100
123
|
TooltipComponent,
|
|
101
124
|
TooltipDirective,
|
|
125
|
+
TrendComponent,
|
|
102
126
|
ZeroStateComponent,
|
|
103
127
|
],
|
|
104
128
|
exports: [
|
|
129
|
+
ButtonComponent,
|
|
105
130
|
CalloutComponent,
|
|
106
131
|
CalloutDirective,
|
|
107
132
|
CalloutOutletComponent,
|
|
@@ -112,21 +137,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
112
137
|
DaysPipe,
|
|
113
138
|
DollarsPipe,
|
|
114
139
|
DonutComponent,
|
|
140
|
+
HelpComponent,
|
|
141
|
+
HighlightComponent,
|
|
115
142
|
IconComponent,
|
|
116
143
|
LegendItemComponent,
|
|
144
|
+
LoadingComponent,
|
|
145
|
+
LoadingCoverComponent,
|
|
117
146
|
MetricComponent,
|
|
118
147
|
NumberPipe,
|
|
119
148
|
PercentagePipe,
|
|
120
|
-
|
|
149
|
+
SingleSelectComponent,
|
|
121
150
|
SmallCurrencyPipe,
|
|
122
151
|
StackedColumnComponent,
|
|
123
152
|
TextToggleComponent,
|
|
124
153
|
TimeSeriesComponent,
|
|
125
154
|
TooltipComponent,
|
|
126
155
|
TooltipDirective,
|
|
156
|
+
TrendComponent,
|
|
127
157
|
ZeroStateComponent,
|
|
128
158
|
],
|
|
129
159
|
imports: [CommonModule],
|
|
130
160
|
}]
|
|
131
161
|
}] });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"riv.module.js","sourceRoot":"","sources":["../../../../projects/riv/src/lib/riv.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { ButtonComponent } from './input/button/button.component';\nimport { CalloutComponent } from './modal/callout/callout.component';\nimport { CalloutDirective } from './modal/callout/callout.directive';\nimport { CalloutOutletComponent } from './modal/callout/callout-outlet.component';\nimport { CommonModule } from '@angular/common';\nimport { DataTableCellComponent } from './visualization/data-table/data-table-cell.component';\nimport { DataTableComponent } from './visualization/data-table/data-table.component';\nimport { DataTableHeaderCellComponent } from './visualization/data-table/data-table-header-cell.component';\nimport { DataTableRowComponent } from './visualization/data-table/data-table-row.component';\nimport { DaysPipe } from './format/pipes/days.pipe';\nimport { DollarsPipe } from './format/pipes/dollars.pipe';\nimport { DonutComponent } from './visualization/donut/donut.component';\nimport { HelpComponent } from './modal/help/help.component';\nimport { HighlightComponent } from './visualization/highlight/highlight.component';\nimport { IconComponent } from './icon/icon.component';\nimport { LegendItemComponent } from './visualization/legend-item/legend-item.component';\nimport { LoadingComponent } from './load/loading/loading.component';\nimport { LoadingCoverComponent } from './load/loading-cover/loading-cover.component';\nimport { MetricComponent } from './visualization/metric/metric.component';\nimport { NgModule } from '@angular/core';\nimport { NumberPipe } from './format/pipes/number.pipe';\nimport { PercentagePipe } from './format/pipes/percentage.pipe';\nimport { SingleSelectComponent } from './input/single-select/single-select.component';\nimport { SmallCurrencyPipe } from './format/pipes/small-currency.pipe';\nimport { StackedColumnComponent } from './visualization/stacked-column/stacked-column.component';\nimport { TextToggleComponent } from './content-toggle/text-toggle/text-toggle.component';\nimport { TimeSeriesComponent } from './visualization/time-series/time-series.component';\nimport { TooltipComponent } from './modal/tooltip/tooltip.component';\nimport { TooltipDirective } from './modal/tooltip/tooltip.directive';\nimport { TrendComponent } from './visualization/trend/trend.component';\nimport { ZeroStateComponent } from './visualization/zero-state/zero-state.component';\n\n@NgModule({\n  declarations: [\n    ButtonComponent,\n    CalloutComponent,\n    CalloutDirective,\n    CalloutOutletComponent,\n    DataTableCellComponent,\n    DataTableComponent,\n    DataTableHeaderCellComponent,\n    DataTableRowComponent,\n    DaysPipe,\n    DollarsPipe,\n    DonutComponent,\n    HelpComponent,\n    HighlightComponent,\n    IconComponent,\n    LegendItemComponent,\n    LoadingComponent,\n    LoadingCoverComponent,\n    MetricComponent,\n    NumberPipe,\n    PercentagePipe,\n    SingleSelectComponent,\n    SmallCurrencyPipe,\n    StackedColumnComponent,\n    TextToggleComponent,\n    TimeSeriesComponent,\n    TooltipComponent,\n    TooltipDirective,\n    TrendComponent,\n    ZeroStateComponent,\n  ],\n  exports: [\n    ButtonComponent,\n    CalloutComponent,\n    CalloutDirective,\n    CalloutOutletComponent,\n    DataTableCellComponent,\n    DataTableComponent,\n    DataTableHeaderCellComponent,\n    DataTableRowComponent,\n    DaysPipe,\n    DollarsPipe,\n    DonutComponent,\n    HelpComponent,\n    HighlightComponent,\n    IconComponent,\n    LegendItemComponent,\n    LoadingComponent,\n    LoadingCoverComponent,\n    MetricComponent,\n    NumberPipe,\n    PercentagePipe,\n    SingleSelectComponent,\n    SmallCurrencyPipe,\n    StackedColumnComponent,\n    TextToggleComponent,\n    TimeSeriesComponent,\n    TooltipComponent,\n    TooltipDirective,\n    TrendComponent,\n    ZeroStateComponent,\n  ],\n  imports: [CommonModule],\n})\nexport class RivModule {}\n"]}
|