@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.
@@ -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 { IconComponent } from '../public-api';
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: [CalloutComponent,
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
- TrendComponent,
56
+ SingleSelectComponent,
46
57
  SmallCurrencyPipe,
47
58
  StackedColumnComponent,
48
59
  TextToggleComponent,
49
60
  TimeSeriesComponent,
50
61
  TooltipComponent,
51
62
  TooltipDirective,
52
- ZeroStateComponent], imports: [CommonModule], exports: [CalloutComponent,
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
- TrendComponent,
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
- TrendComponent,
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
- TrendComponent,
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicml2Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3Jpdi9zcmMvbGliL3Jpdi5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDckUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDckUsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDbEYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQzlGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQ3JGLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQzNHLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQzVGLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUNwRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDeEYsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3hELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUN2RSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5REFBeUQsQ0FBQztBQUNqRyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxvREFBb0QsQ0FBQztBQUN6RixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUN4RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUNyRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDdkUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saURBQWlELENBQUM7O0FBdURyRixNQUFNLE9BQU8sU0FBUzs7c0dBQVQsU0FBUzt1R0FBVCxTQUFTLGlCQW5EbEIsZ0JBQWdCO1FBQ2hCLGdCQUFnQjtRQUNoQixzQkFBc0I7UUFDdEIsc0JBQXNCO1FBQ3RCLGtCQUFrQjtRQUNsQiw0QkFBNEI7UUFDNUIscUJBQXFCO1FBQ3JCLFFBQVE7UUFDUixXQUFXO1FBQ1gsY0FBYztRQUNkLGFBQWE7UUFDYixtQkFBbUI7UUFDbkIsZUFBZTtRQUNmLFVBQVU7UUFDVixjQUFjO1FBQ2QsY0FBYztRQUNkLGlCQUFpQjtRQUNqQixzQkFBc0I7UUFDdEIsbUJBQW1CO1FBQ25CLG1CQUFtQjtRQUNuQixnQkFBZ0I7UUFDaEIsZ0JBQWdCO1FBQ2hCLGtCQUFrQixhQTJCVixZQUFZLGFBeEJwQixnQkFBZ0I7UUFDaEIsZ0JBQWdCO1FBQ2hCLHNCQUFzQjtRQUN0QixzQkFBc0I7UUFDdEIsa0JBQWtCO1FBQ2xCLDRCQUE0QjtRQUM1QixxQkFBcUI7UUFDckIsUUFBUTtRQUNSLFdBQVc7UUFDWCxjQUFjO1FBQ2QsYUFBYTtRQUNiLG1CQUFtQjtRQUNuQixlQUFlO1FBQ2YsVUFBVTtRQUNWLGNBQWM7UUFDZCxjQUFjO1FBQ2QsaUJBQWlCO1FBQ2pCLHNCQUFzQjtRQUN0QixtQkFBbUI7UUFDbkIsbUJBQW1CO1FBQ25CLGdCQUFnQjtRQUNoQixnQkFBZ0I7UUFDaEIsa0JBQWtCO3VHQUlULFNBQVMsWUFGVixZQUFZOzJGQUVYLFNBQVM7a0JBckRyQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsc0JBQXNCO3dCQUN0QixzQkFBc0I7d0JBQ3RCLGtCQUFrQjt3QkFDbEIsNEJBQTRCO3dCQUM1QixxQkFBcUI7d0JBQ3JCLFFBQVE7d0JBQ1IsV0FBVzt3QkFDWCxjQUFjO3dCQUNkLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQixlQUFlO3dCQUNmLFVBQVU7d0JBQ1YsY0FBYzt3QkFDZCxjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsc0JBQXNCO3dCQUN0QixtQkFBbUI7d0JBQ25CLG1CQUFtQjt3QkFDbkIsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLGtCQUFrQjtxQkFDbkI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGdCQUFnQjt3QkFDaEIsZ0JBQWdCO3dCQUNoQixzQkFBc0I7d0JBQ3RCLHNCQUFzQjt3QkFDdEIsa0JBQWtCO3dCQUNsQiw0QkFBNEI7d0JBQzVCLHFCQUFxQjt3QkFDckIsUUFBUTt3QkFDUixXQUFXO3dCQUNYLGNBQWM7d0JBQ2QsYUFBYTt3QkFDYixtQkFBbUI7d0JBQ25CLGVBQWU7d0JBQ2YsVUFBVTt3QkFDVixjQUFjO3dCQUNkLGNBQWM7d0JBQ2QsaUJBQWlCO3dCQUNqQixzQkFBc0I7d0JBQ3RCLG1CQUFtQjt3QkFDbkIsbUJBQW1CO3dCQUNuQixnQkFBZ0I7d0JBQ2hCLGdCQUFnQjt3QkFDaEIsa0JBQWtCO3FCQUNuQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7aUJBQ3hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2FsbG91dENvbXBvbmVudCB9IGZyb20gJy4vbW9kYWwvY2FsbG91dC9jYWxsb3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDYWxsb3V0RGlyZWN0aXZlIH0gZnJvbSAnLi9tb2RhbC9jYWxsb3V0L2NhbGxvdXQuZGlyZWN0aXZlJztcbmltcG9ydCB7IENhbGxvdXRPdXRsZXRDb21wb25lbnQgfSBmcm9tICcuL21vZGFsL2NhbGxvdXQvY2FsbG91dC1vdXRsZXQuY29tcG9uZW50JztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEYXRhVGFibGVDZWxsQ29tcG9uZW50IH0gZnJvbSAnLi92aXN1YWxpemF0aW9uL2RhdGEtdGFibGUvZGF0YS10YWJsZS1jZWxsLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYXRhVGFibGVDb21wb25lbnQgfSBmcm9tICcuL3Zpc3VhbGl6YXRpb24vZGF0YS10YWJsZS9kYXRhLXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYXRhVGFibGVIZWFkZXJDZWxsQ29tcG9uZW50IH0gZnJvbSAnLi92aXN1YWxpemF0aW9uL2RhdGEtdGFibGUvZGF0YS10YWJsZS1oZWFkZXItY2VsbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRGF0YVRhYmxlUm93Q29tcG9uZW50IH0gZnJvbSAnLi92aXN1YWxpemF0aW9uL2RhdGEtdGFibGUvZGF0YS10YWJsZS1yb3cuY29tcG9uZW50JztcbmltcG9ydCB7IERheXNQaXBlIH0gZnJvbSAnLi9mb3JtYXQvcGlwZXMvZGF5cy5waXBlJztcbmltcG9ydCB7IERvbGxhcnNQaXBlIH0gZnJvbSAnLi9mb3JtYXQvcGlwZXMvZG9sbGFycy5waXBlJztcbmltcG9ydCB7IERvbnV0Q29tcG9uZW50IH0gZnJvbSAnLi92aXN1YWxpemF0aW9uL2RvbnV0L2RvbnV0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJY29uQ29tcG9uZW50IH0gZnJvbSAnLi4vcHVibGljLWFwaSc7XG5pbXBvcnQgeyBMZWdlbmRJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi92aXN1YWxpemF0aW9uL2xlZ2VuZC1pdGVtL2xlZ2VuZC1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNZXRyaWNDb21wb25lbnQgfSBmcm9tICcuL3Zpc3VhbGl6YXRpb24vbWV0cmljL21ldHJpYy5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE51bWJlclBpcGUgfSBmcm9tICcuL2Zvcm1hdC9waXBlcy9udW1iZXIucGlwZSc7XG5pbXBvcnQgeyBQZXJjZW50YWdlUGlwZSB9IGZyb20gJy4vZm9ybWF0L3BpcGVzL3BlcmNlbnRhZ2UucGlwZSc7XG5pbXBvcnQgeyBTbWFsbEN1cnJlbmN5UGlwZSB9IGZyb20gJy4vZm9ybWF0L3BpcGVzL3NtYWxsLWN1cnJlbmN5LnBpcGUnO1xuaW1wb3J0IHsgU3RhY2tlZENvbHVtbkNvbXBvbmVudCB9IGZyb20gJy4vdmlzdWFsaXphdGlvbi9zdGFja2VkLWNvbHVtbi9zdGFja2VkLWNvbHVtbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgVGV4dFRvZ2dsZUNvbXBvbmVudCB9IGZyb20gJy4vY29udGVudC10b2dnbGUvdGV4dC10b2dnbGUvdGV4dC10b2dnbGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRpbWVTZXJpZXNDb21wb25lbnQgfSBmcm9tICcuL3Zpc3VhbGl6YXRpb24vdGltZS1zZXJpZXMvdGltZS1zZXJpZXMuY29tcG9uZW50JztcbmltcG9ydCB7IFRvb2x0aXBDb21wb25lbnQgfSBmcm9tICcuL21vZGFsL3Rvb2x0aXAvdG9vbHRpcC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVG9vbHRpcERpcmVjdGl2ZSB9IGZyb20gJy4vbW9kYWwvdG9vbHRpcC90b29sdGlwLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBUcmVuZENvbXBvbmVudCB9IGZyb20gJy4vdmlzdWFsaXphdGlvbi90cmVuZC90cmVuZC5jb21wb25lbnQnO1xuaW1wb3J0IHsgWmVyb1N0YXRlQ29tcG9uZW50IH0gZnJvbSAnLi92aXN1YWxpemF0aW9uL3plcm8tc3RhdGUvemVyby1zdGF0ZS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBDYWxsb3V0Q29tcG9uZW50LFxuICAgIENhbGxvdXREaXJlY3RpdmUsXG4gICAgQ2FsbG91dE91dGxldENvbXBvbmVudCxcbiAgICBEYXRhVGFibGVDZWxsQ29tcG9uZW50LFxuICAgIERhdGFUYWJsZUNvbXBvbmVudCxcbiAgICBEYXRhVGFibGVIZWFkZXJDZWxsQ29tcG9uZW50LFxuICAgIERhdGFUYWJsZVJvd0NvbXBvbmVudCxcbiAgICBEYXlzUGlwZSxcbiAgICBEb2xsYXJzUGlwZSxcbiAgICBEb251dENvbXBvbmVudCxcbiAgICBJY29uQ29tcG9uZW50LFxuICAgIExlZ2VuZEl0ZW1Db21wb25lbnQsXG4gICAgTWV0cmljQ29tcG9uZW50LFxuICAgIE51bWJlclBpcGUsXG4gICAgUGVyY2VudGFnZVBpcGUsXG4gICAgVHJlbmRDb21wb25lbnQsXG4gICAgU21hbGxDdXJyZW5jeVBpcGUsXG4gICAgU3RhY2tlZENvbHVtbkNvbXBvbmVudCxcbiAgICBUZXh0VG9nZ2xlQ29tcG9uZW50LFxuICAgIFRpbWVTZXJpZXNDb21wb25lbnQsXG4gICAgVG9vbHRpcENvbXBvbmVudCxcbiAgICBUb29sdGlwRGlyZWN0aXZlLFxuICAgIFplcm9TdGF0ZUNvbXBvbmVudCxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIENhbGxvdXRDb21wb25lbnQsXG4gICAgQ2FsbG91dERpcmVjdGl2ZSxcbiAgICBDYWxsb3V0T3V0bGV0Q29tcG9uZW50LFxuICAgIERhdGFUYWJsZUNlbGxDb21wb25lbnQsXG4gICAgRGF0YVRhYmxlQ29tcG9uZW50LFxuICAgIERhdGFUYWJsZUhlYWRlckNlbGxDb21wb25lbnQsXG4gICAgRGF0YVRhYmxlUm93Q29tcG9uZW50LFxuICAgIERheXNQaXBlLFxuICAgIERvbGxhcnNQaXBlLFxuICAgIERvbnV0Q29tcG9uZW50LFxuICAgIEljb25Db21wb25lbnQsXG4gICAgTGVnZW5kSXRlbUNvbXBvbmVudCxcbiAgICBNZXRyaWNDb21wb25lbnQsXG4gICAgTnVtYmVyUGlwZSxcbiAgICBQZXJjZW50YWdlUGlwZSxcbiAgICBUcmVuZENvbXBvbmVudCxcbiAgICBTbWFsbEN1cnJlbmN5UGlwZSxcbiAgICBTdGFja2VkQ29sdW1uQ29tcG9uZW50LFxuICAgIFRleHRUb2dnbGVDb21wb25lbnQsXG4gICAgVGltZVNlcmllc0NvbXBvbmVudCxcbiAgICBUb29sdGlwQ29tcG9uZW50LFxuICAgIFRvb2x0aXBEaXJlY3RpdmUsXG4gICAgWmVyb1N0YXRlQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgUml2TW9kdWxlIHt9XG4iXX0=
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"]}