@rivet-health/design-system 7.1.0 → 7.2.1

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,48 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { TextFieldComponent } from '../text-field/text-field.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../input-label/input-label.component";
5
+ export class AlphabeticFieldComponent extends TextFieldComponent {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.valueChange = new EventEmitter();
9
+ }
10
+ set value(v) {
11
+ if (AlphabeticFieldComponent.clean(v, this.casing) ===
12
+ AlphabeticFieldComponent.clean(this._text, this.casing))
13
+ return;
14
+ this._text = AlphabeticFieldComponent.format(v, this.casing);
15
+ }
16
+ set text(t) {
17
+ this._text = t;
18
+ this.valueChange.emit(AlphabeticFieldComponent.clean(t, this.casing));
19
+ }
20
+ get text() {
21
+ return this._text;
22
+ }
23
+ blur() {
24
+ this._text = AlphabeticFieldComponent.format(this._text, this.casing);
25
+ }
26
+ }
27
+ AlphabeticFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AlphabeticFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
28
+ AlphabeticFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: AlphabeticFieldComponent, selector: "riv-alphabetic-field", inputs: { value: "value" }, outputs: { valueChange: "valueChange" }, usesInheritance: true, ngImport: i0, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <input\n #input\n [placeholder]=\"placeholder\"\n [type]=\"type\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [attr.maxlength]=\"maxLength\"\n [attr.minlength]=\"minLength\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n</riv-input-label>\n", styles: ["input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"], dependencies: [{ kind: "component", type: i1.InputLabelComponent, selector: "riv-input-label", inputs: ["label", "help", "required", "labelActionText"], outputs: ["labelAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: AlphabeticFieldComponent, decorators: [{
30
+ type: Component,
31
+ args: [{ selector: 'riv-alphabetic-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <input\n #input\n [placeholder]=\"placeholder\"\n [type]=\"type\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [attr.maxlength]=\"maxLength\"\n [attr.minlength]=\"minLength\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n</riv-input-label>\n", styles: ["input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"] }]
32
+ }], propDecorators: { value: [{
33
+ type: Input
34
+ }], valueChange: [{
35
+ type: Output
36
+ }] } });
37
+ (function (AlphabeticFieldComponent) {
38
+ function clean(v, casing) {
39
+ const cleaned = v.replaceAll(/[^A-Za-z]/g, '');
40
+ return TextFieldComponent.clean(cleaned, casing);
41
+ }
42
+ AlphabeticFieldComponent.clean = clean;
43
+ function format(v, casing) {
44
+ return clean(v, casing);
45
+ }
46
+ AlphabeticFieldComponent.format = format;
47
+ })(AlphabeticFieldComponent || (AlphabeticFieldComponent = {}));
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxwaGFiZXRpYy1maWVsZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yaXYvc3JjL2xpYi9pbnB1dC9hbHBoYWJldGljLWZpZWxkL2FscGhhYmV0aWMtZmllbGQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcml2L3NyYy9saWIvaW5wdXQvdGV4dC1maWVsZC90ZXh0LWZpZWxkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixLQUFLLEVBQ0wsTUFBTSxHQUNQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDOzs7QUFReEUsTUFBTSxPQUFPLHdCQUF5QixTQUFRLGtCQUFrQjtJQU5oRTs7UUFrQlcsZ0JBQVcsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0tBYW5EO0lBeEJDLElBQ2EsS0FBSyxDQUFDLENBQVM7UUFDMUIsSUFDRSx3QkFBd0IsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUM7WUFDOUMsd0JBQXdCLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQztZQUV2RCxPQUFPO1FBQ1QsSUFBSSxDQUFDLEtBQUssR0FBRyx3QkFBd0IsQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMvRCxDQUFDO0lBS0QsSUFBYSxJQUFJLENBQUMsQ0FBUztRQUN6QixJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLHdCQUF3QixDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7SUFDeEUsQ0FBQztJQUNELElBQWEsSUFBSTtRQUNmLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUNwQixDQUFDO0lBRVEsSUFBSTtRQUNYLElBQUksQ0FBQyxLQUFLLEdBQUcsd0JBQXdCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3hFLENBQUM7O3FIQXhCVSx3QkFBd0I7eUdBQXhCLHdCQUF3Qix3SkNmckMsd3NCQTJCQTsyRkRaYSx3QkFBd0I7a0JBTnBDLFNBQVM7K0JBQ0Usc0JBQXNCLG1CQUdmLHVCQUF1QixDQUFDLE1BQU07OEJBSWxDLEtBQUs7c0JBRGpCLEtBQUs7Z0JBV0csV0FBVztzQkFEbkIsTUFBTTs7QUFnQlQsV0FBaUIsd0JBQXdCO0lBQ3ZDLFNBQWdCLEtBQUssQ0FBQyxDQUFTLEVBQUUsTUFBaUM7UUFDaEUsTUFBTSxPQUFPLEdBQUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQyxZQUFZLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDL0MsT0FBTyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ25ELENBQUM7SUFIZSw4QkFBSyxRQUdwQixDQUFBO0lBRUQsU0FBZ0IsTUFBTSxDQUFDLENBQVMsRUFBRSxNQUFpQztRQUNqRSxPQUFPLEtBQUssQ0FBQyxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQUZlLCtCQUFNLFNBRXJCLENBQUE7QUFDSCxDQUFDLEVBVGdCLHdCQUF3QixLQUF4Qix3QkFBd0IsUUFTeEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVGV4dEZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi4vdGV4dC1maWVsZC90ZXh0LWZpZWxkLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3Jpdi1hbHBoYWJldGljLWZpZWxkJyxcbiAgdGVtcGxhdGVVcmw6ICcuLi90ZXh0LWZpZWxkL3RleHQtZmllbGQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi4vdGV4dC1maWVsZC90ZXh0LWZpZWxkLmNvbXBvbmVudC5jc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIEFscGhhYmV0aWNGaWVsZENvbXBvbmVudCBleHRlbmRzIFRleHRGaWVsZENvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIG92ZXJyaWRlIHNldCB2YWx1ZSh2OiBzdHJpbmcpIHtcbiAgICBpZiAoXG4gICAgICBBbHBoYWJldGljRmllbGRDb21wb25lbnQuY2xlYW4odiwgdGhpcy5jYXNpbmcpID09PVxuICAgICAgQWxwaGFiZXRpY0ZpZWxkQ29tcG9uZW50LmNsZWFuKHRoaXMuX3RleHQsIHRoaXMuY2FzaW5nKVxuICAgIClcbiAgICAgIHJldHVybjtcbiAgICB0aGlzLl90ZXh0ID0gQWxwaGFiZXRpY0ZpZWxkQ29tcG9uZW50LmZvcm1hdCh2LCB0aGlzLmNhc2luZyk7XG4gIH1cblxuICBAT3V0cHV0KClcbiAgb3ZlcnJpZGUgdmFsdWVDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBvdmVycmlkZSBzZXQgdGV4dCh0OiBzdHJpbmcpIHtcbiAgICB0aGlzLl90ZXh0ID0gdDtcbiAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQoQWxwaGFiZXRpY0ZpZWxkQ29tcG9uZW50LmNsZWFuKHQsIHRoaXMuY2FzaW5nKSk7XG4gIH1cbiAgb3ZlcnJpZGUgZ2V0IHRleHQoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5fdGV4dDtcbiAgfVxuXG4gIG92ZXJyaWRlIGJsdXIoKSB7XG4gICAgdGhpcy5fdGV4dCA9IEFscGhhYmV0aWNGaWVsZENvbXBvbmVudC5mb3JtYXQodGhpcy5fdGV4dCwgdGhpcy5jYXNpbmcpO1xuICB9XG59XG5cbmV4cG9ydCBuYW1lc3BhY2UgQWxwaGFiZXRpY0ZpZWxkQ29tcG9uZW50IHtcbiAgZXhwb3J0IGZ1bmN0aW9uIGNsZWFuKHY6IHN0cmluZywgY2FzaW5nOiBUZXh0RmllbGRDb21wb25lbnQuQ2FzaW5nKTogc3RyaW5nIHtcbiAgICBjb25zdCBjbGVhbmVkID0gdi5yZXBsYWNlQWxsKC9bXkEtWmEtel0vZywgJycpO1xuICAgIHJldHVybiBUZXh0RmllbGRDb21wb25lbnQuY2xlYW4oY2xlYW5lZCwgY2FzaW5nKTtcbiAgfVxuXG4gIGV4cG9ydCBmdW5jdGlvbiBmb3JtYXQodjogc3RyaW5nLCBjYXNpbmc6IFRleHRGaWVsZENvbXBvbmVudC5DYXNpbmcpOiBzdHJpbmcge1xuICAgIHJldHVybiBjbGVhbih2LCBjYXNpbmcpO1xuICB9XG59XG4iLCI8cml2LWlucHV0LWxhYmVsXG4gIFtsYWJlbF09XCJsYWJlbFwiXG4gIFtoZWxwXT1cImhlbHBcIlxuICBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIlxuICBbbGFiZWxBY3Rpb25UZXh0XT1cImxhYmVsQWN0aW9uVGV4dFwiXG4gIChsYWJlbEFjdGlvbik9XCJsYWJlbEFjdGlvbi5lbWl0KCRldmVudClcIlxuPlxuICA8aW5wdXRcbiAgICAjaW5wdXRcbiAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxuICAgIFt0eXBlXT1cInR5cGVcIlxuICAgIFtyZXF1aXJlZF09XCJyZXF1aXJlZFwiXG4gICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcbiAgICBbcmVhZG9ubHldPVwicmVhZG9ubHlcIlxuICAgIFt2YWx1ZV09XCJ0ZXh0XCJcbiAgICAoaW5wdXQpPVwidGV4dCA9IGlucHV0LnZhbHVlXCJcbiAgICBbYXR0ci5tYXhsZW5ndGhdPVwibWF4TGVuZ3RoXCJcbiAgICBbYXR0ci5taW5sZW5ndGhdPVwibWluTGVuZ3RoXCJcbiAgICBbY2xhc3Mud2FybmluZ109XCJzdGF0ZSA9PT0gJ3dhcm5pbmcnXCJcbiAgICBbY2xhc3MuZXJyb3JdPVwic3RhdGUgPT09ICdlcnJvcidcIlxuICAgIGF1dG9jb21wbGV0ZT1cIm9mZlwiXG4gICAgYXV0b2NvcnJlY3Q9XCJvZmZcIlxuICAgIGF1dG9jYXBpdGFsaXplPVwib2ZmXCJcbiAgICBzcGVsbGNoZWNrPVwiZmFsc2VcIlxuICAgIChibHVyKT1cImJsdXIoKVwiXG4gIC8+XG48L3Jpdi1pbnB1dC1sYWJlbD5cbiJdfQ==
@@ -0,0 +1,25 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { NumberFieldComponent } from '../number-field/number-field.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../input-label/input-label.component";
5
+ export class CurrencyFieldComponent extends NumberFieldComponent {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.placeholder = '0.00';
9
+ this.minimumFractionDigits = 2;
10
+ this.maximumFractionDigits = 2;
11
+ }
12
+ }
13
+ CurrencyFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CurrencyFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
14
+ CurrencyFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CurrencyFieldComponent, selector: "riv-currency-field", inputs: { placeholder: "placeholder", minimumFractionDigits: "minimumFractionDigits", maximumFractionDigits: "maximumFractionDigits" }, usesInheritance: true, ngImport: i0, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <span class=\"prefix\">$</span>\n <input\n #input\n [placeholder]=\"placeholder\"\n type=\"text\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n [style.textAlign]=\"align\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n</riv-input-label>\n", styles: [":host{position:relative}.prefix{position:absolute;font:var(--input-medium);padding:var(--size-small)}input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small) var(--size-small) var(--size-small) var(--size-xlarge)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"], dependencies: [{ kind: "component", type: i1.InputLabelComponent, selector: "riv-input-label", inputs: ["label", "help", "required", "labelActionText"], outputs: ["labelAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CurrencyFieldComponent, decorators: [{
16
+ type: Component,
17
+ args: [{ selector: 'riv-currency-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <span class=\"prefix\">$</span>\n <input\n #input\n [placeholder]=\"placeholder\"\n type=\"text\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n [style.textAlign]=\"align\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n</riv-input-label>\n", styles: [":host{position:relative}.prefix{position:absolute;font:var(--input-medium);padding:var(--size-small)}input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small) var(--size-small) var(--size-small) var(--size-xlarge)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"] }]
18
+ }], propDecorators: { placeholder: [{
19
+ type: Input
20
+ }], minimumFractionDigits: [{
21
+ type: Input
22
+ }], maximumFractionDigits: [{
23
+ type: Input
24
+ }] } });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVuY3ktZmllbGQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcml2L3NyYy9saWIvaW5wdXQvY3VycmVuY3ktZmllbGQvY3VycmVuY3ktZmllbGQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcml2L3NyYy9saWIvaW5wdXQvY3VycmVuY3ktZmllbGQvY3VycmVuY3ktZmllbGQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7OztBQVE5RSxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsb0JBQW9CO0lBTmhFOztRQVFXLGdCQUFXLEdBQVcsTUFBTSxDQUFDO1FBRzdCLDBCQUFxQixHQUFXLENBQUMsQ0FBQztRQUdsQywwQkFBcUIsR0FBVyxDQUFDLENBQUM7S0FDNUM7O21IQVRZLHNCQUFzQjt1R0FBdEIsc0JBQXNCLHlOQ1RuQyxrc0JBMkJBOzJGRGxCYSxzQkFBc0I7a0JBTmxDLFNBQVM7K0JBQ0Usb0JBQW9CLG1CQUdiLHVCQUF1QixDQUFDLE1BQU07OEJBSXRDLFdBQVc7c0JBRG5CLEtBQUs7Z0JBSUcscUJBQXFCO3NCQUQ3QixLQUFLO2dCQUlHLHFCQUFxQjtzQkFEN0IsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOdW1iZXJGaWVsZENvbXBvbmVudCB9IGZyb20gJy4uL251bWJlci1maWVsZC9udW1iZXItZmllbGQuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncml2LWN1cnJlbmN5LWZpZWxkJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2N1cnJlbmN5LWZpZWxkLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY3VycmVuY3ktZmllbGQuY29tcG9uZW50LmNzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQ3VycmVuY3lGaWVsZENvbXBvbmVudCBleHRlbmRzIE51bWJlckZpZWxkQ29tcG9uZW50IHtcbiAgQElucHV0KClcbiAgb3ZlcnJpZGUgcGxhY2Vob2xkZXI6IHN0cmluZyA9ICcwLjAwJztcblxuICBASW5wdXQoKVxuICBvdmVycmlkZSBtaW5pbXVtRnJhY3Rpb25EaWdpdHM6IG51bWJlciA9IDI7XG5cbiAgQElucHV0KClcbiAgb3ZlcnJpZGUgbWF4aW11bUZyYWN0aW9uRGlnaXRzOiBudW1iZXIgPSAyO1xufVxuIiwiPHJpdi1pbnB1dC1sYWJlbFxuICBbbGFiZWxdPVwibGFiZWxcIlxuICBbaGVscF09XCJoZWxwXCJcbiAgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCJcbiAgW2xhYmVsQWN0aW9uVGV4dF09XCJsYWJlbEFjdGlvblRleHRcIlxuICAobGFiZWxBY3Rpb24pPVwibGFiZWxBY3Rpb24uZW1pdCgkZXZlbnQpXCJcbj5cbiAgPHNwYW4gY2xhc3M9XCJwcmVmaXhcIj4kPC9zcGFuPlxuICA8aW5wdXRcbiAgICAjaW5wdXRcbiAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxuICAgIHR5cGU9XCJ0ZXh0XCJcbiAgICBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIlxuICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgW3JlYWRvbmx5XT1cInJlYWRvbmx5XCJcbiAgICBbdmFsdWVdPVwidGV4dFwiXG4gICAgKGlucHV0KT1cInRleHQgPSBpbnB1dC52YWx1ZVwiXG4gICAgW2NsYXNzLndhcm5pbmddPVwic3RhdGUgPT09ICd3YXJuaW5nJ1wiXG4gICAgW2NsYXNzLmVycm9yXT1cInN0YXRlID09PSAnZXJyb3InXCJcbiAgICBbc3R5bGUudGV4dEFsaWduXT1cImFsaWduXCJcbiAgICBhdXRvY29tcGxldGU9XCJvZmZcIlxuICAgIGF1dG9jb3JyZWN0PVwib2ZmXCJcbiAgICBhdXRvY2FwaXRhbGl6ZT1cIm9mZlwiXG4gICAgc3BlbGxjaGVjaz1cImZhbHNlXCJcbiAgICAoYmx1cik9XCJibHVyKClcIlxuICAvPlxuPC9yaXYtaW5wdXQtbGFiZWw+XG4iXX0=
@@ -0,0 +1,101 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { InputLabelComponent } from '../input-label/input-label.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../input-label/input-label.component";
5
+ export class NumberFieldComponent extends InputLabelComponent {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.disabled = false;
9
+ this.readonly = false;
10
+ this.placeholder = '';
11
+ this.state = 'valid';
12
+ this.maximumFractionDigits = 0;
13
+ this.minimumFractionDigits = 0;
14
+ this.min = -Infinity;
15
+ this.max = Infinity;
16
+ this.align = 'left';
17
+ this.valueChange = new EventEmitter();
18
+ this._text = '';
19
+ }
20
+ set value(v) {
21
+ if (NumberFieldComponent.clean(v, this.maximumFractionDigits, this.min, this.max) ===
22
+ NumberFieldComponent.clean(this._text, this.maximumFractionDigits, this.min, this.max))
23
+ return;
24
+ this._text = NumberFieldComponent.format(v, this.minimumFractionDigits, this.maximumFractionDigits, this.min, this.max);
25
+ }
26
+ set text(t) {
27
+ this._text = t;
28
+ this.valueChange.emit(NumberFieldComponent.clean(t, this.maximumFractionDigits, this.min, this.max));
29
+ }
30
+ get text() {
31
+ return this._text;
32
+ }
33
+ blur() {
34
+ this._text = NumberFieldComponent.format(this._text, this.minimumFractionDigits, this.maximumFractionDigits, this.min, this.max);
35
+ }
36
+ }
37
+ NumberFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NumberFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
38
+ NumberFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: NumberFieldComponent, selector: "riv-number-field", inputs: { disabled: "disabled", readonly: "readonly", placeholder: "placeholder", state: "state", maximumFractionDigits: "maximumFractionDigits", minimumFractionDigits: "minimumFractionDigits", min: "min", max: "max", align: "align", value: "value" }, outputs: { valueChange: "valueChange" }, usesInheritance: true, ngImport: i0, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <input\n #input\n [placeholder]=\"placeholder\"\n type=\"text\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n [style.textAlign]=\"align\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n</riv-input-label>\n", styles: ["input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"], dependencies: [{ kind: "component", type: i1.InputLabelComponent, selector: "riv-input-label", inputs: ["label", "help", "required", "labelActionText"], outputs: ["labelAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
39
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: NumberFieldComponent, decorators: [{
40
+ type: Component,
41
+ args: [{ selector: 'riv-number-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <input\n #input\n [placeholder]=\"placeholder\"\n type=\"text\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n [style.textAlign]=\"align\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n</riv-input-label>\n", styles: ["input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"] }]
42
+ }], propDecorators: { disabled: [{
43
+ type: Input
44
+ }], readonly: [{
45
+ type: Input
46
+ }], placeholder: [{
47
+ type: Input
48
+ }], state: [{
49
+ type: Input
50
+ }], maximumFractionDigits: [{
51
+ type: Input
52
+ }], minimumFractionDigits: [{
53
+ type: Input
54
+ }], min: [{
55
+ type: Input
56
+ }], max: [{
57
+ type: Input
58
+ }], align: [{
59
+ type: Input
60
+ }], value: [{
61
+ type: Input
62
+ }], valueChange: [{
63
+ type: Output
64
+ }] } });
65
+ (function (NumberFieldComponent) {
66
+ NumberFieldComponent.Alignments = ['left', 'center', 'right'];
67
+ function clean(v, maximumFractionDigits, min, max) {
68
+ function digitsOnly(str) {
69
+ return str.replace(/\D/g, '');
70
+ }
71
+ if (!v)
72
+ return null;
73
+ const decimalPointIdx = v.indexOf('.');
74
+ const signIdx = v.indexOf('-');
75
+ const cleanedString = (signIdx > -1 ? '-' : '') +
76
+ (decimalPointIdx > -1
77
+ ? digitsOnly(v.substring(0, decimalPointIdx)) +
78
+ '.' +
79
+ digitsOnly(v.substring(decimalPointIdx + 1))
80
+ : digitsOnly(v));
81
+ if (cleanedString === '.' ||
82
+ cleanedString === '-' ||
83
+ cleanedString === '-.') {
84
+ return null;
85
+ }
86
+ const cleaned = Number(Number(cleanedString).toFixed(maximumFractionDigits));
87
+ return Math.max(min, Math.min(max, cleaned));
88
+ }
89
+ NumberFieldComponent.clean = clean;
90
+ function format(v, minimumFractionDigits, maximumFractionDigits, min, max) {
91
+ const cleaned = clean(v, maximumFractionDigits, min, max);
92
+ if (cleaned === null)
93
+ return '';
94
+ return new Intl.NumberFormat('en-US', {
95
+ minimumFractionDigits,
96
+ maximumFractionDigits,
97
+ }).format(cleaned);
98
+ }
99
+ NumberFieldComponent.format = format;
100
+ })(NumberFieldComponent || (NumberFieldComponent = {}));
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-field.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/input/number-field/number-field.component.ts","../../../../../../projects/riv/src/lib/input/number-field/number-field.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;;;AAS3E,MAAM,OAAO,oBAAqB,SAAQ,mBAAmB;IAN7D;;QAQE,aAAQ,GAAY,KAAK,CAAC;QAG1B,aAAQ,GAAY,KAAK,CAAC;QAG1B,gBAAW,GAAW,EAAE,CAAC;QAGzB,UAAK,GAA6B,OAAO,CAAC;QAG1C,0BAAqB,GAAW,CAAC,CAAC;QAGlC,0BAAqB,GAAW,CAAC,CAAC;QAGlC,QAAG,GAAW,CAAC,QAAQ,CAAC;QAGxB,QAAG,GAAW,QAAQ,CAAC;QAGvB,UAAK,GAAmC,MAAM,CAAC;QA6B/C,gBAAW,GAAG,IAAI,YAAY,EAAiB,CAAC;QAEtC,UAAK,GAAW,EAAE,CAAC;KA0B9B;IAvDC,IACI,KAAK,CAAC,CAAgB;QACxB,IACE,oBAAoB,CAAC,KAAK,CACxB,CAAC,EACD,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,GAAG,CACT;YACD,oBAAoB,CAAC,KAAK,CACxB,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,GAAG,CACT;YAED,OAAO;QACT,IAAI,CAAC,KAAK,GAAG,oBAAoB,CAAC,MAAM,CACtC,CAAC,EACD,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,GAAG,CACT,CAAC;IACJ,CAAC;IAOD,IAAI,IAAI,CAAC,CAAS;QAChB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,WAAW,CAAC,IAAI,CACnB,oBAAoB,CAAC,KAAK,CACxB,CAAC,EACD,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,GAAG,CACT,CACF,CAAC;IACJ,CAAC;IACD,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI;QACF,IAAI,CAAC,KAAK,GAAG,oBAAoB,CAAC,MAAM,CACtC,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,qBAAqB,EAC1B,IAAI,CAAC,GAAG,EACR,IAAI,CAAC,GAAG,CACT,CAAC;IACJ,CAAC;;iHAlFU,oBAAoB;qGAApB,oBAAoB,oXChBjC,+pBA0BA;2FDVa,oBAAoB;kBANhC,SAAS;+BACE,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM;8BAI/C,QAAQ;sBADP,KAAK;gBAIN,QAAQ;sBADP,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIN,KAAK;sBADJ,KAAK;gBAIN,qBAAqB;sBADpB,KAAK;gBAIN,qBAAqB;sBADpB,KAAK;gBAIN,GAAG;sBADF,KAAK;gBAIN,GAAG;sBADF,KAAK;gBAIN,KAAK;sBADJ,KAAK;gBAIF,KAAK;sBADR,KAAK;gBA2BN,WAAW;sBADV,MAAM;;AA+BT,WAAiB,oBAAoB;IACtB,+BAAU,GAAG,CAAC,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAU,CAAC;IAG/D,SAAgB,KAAK,CACnB,CAAgB,EAChB,qBAA6B,EAC7B,GAAW,EACX,GAAW;QAEX,SAAS,UAAU,CAAC,GAAW;YAC7B,OAAO,GAAG,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAChC,CAAC;QAED,IAAI,CAAC,CAAC;YAAE,OAAO,IAAI,CAAC;QACpB,MAAM,eAAe,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACvC,MAAM,OAAO,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAC/B,MAAM,aAAa,GACjB,CAAC,OAAO,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;YACzB,CAAC,eAAe,GAAG,CAAC,CAAC;gBACnB,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC;oBAC3C,GAAG;oBACH,UAAU,CAAC,CAAC,CAAC,SAAS,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC;gBAC9C,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;QACrB,IACE,aAAa,KAAK,GAAG;YACrB,aAAa,KAAK,GAAG;YACrB,aAAa,KAAK,IAAI,EACtB;YACA,OAAO,IAAI,CAAC;SACb;QACD,MAAM,OAAO,GAAG,MAAM,CACpB,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,CAAC,qBAAqB,CAAC,CACrD,CAAC;QACF,OAAO,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC;IAC/C,CAAC;IA/Be,0BAAK,QA+BpB,CAAA;IAED,SAAgB,MAAM,CACpB,CAAgB,EAChB,qBAA6B,EAC7B,qBAA6B,EAC7B,GAAW,EACX,GAAW;QAEX,MAAM,OAAO,GAAG,KAAK,CAAC,CAAC,EAAE,qBAAqB,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QAC1D,IAAI,OAAO,KAAK,IAAI;YAAE,OAAO,EAAE,CAAC;QAChC,OAAO,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE;YACpC,qBAAqB;YACrB,qBAAqB;SACtB,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACrB,CAAC;IAbe,2BAAM,SAarB,CAAA;AACH,CAAC,EAnDgB,oBAAoB,KAApB,oBAAoB,QAmDpC","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { InputLabelComponent } from '../input-label/input-label.component';\nimport { TextFieldComponent } from '../text-field/text-field.component';\n\n@Component({\n  selector: 'riv-number-field',\n  templateUrl: './number-field.component.html',\n  styleUrls: ['./number-field.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class NumberFieldComponent extends InputLabelComponent {\n  @Input()\n  disabled: boolean = false;\n\n  @Input()\n  readonly: boolean = false;\n\n  @Input()\n  placeholder: string = '';\n\n  @Input()\n  state: TextFieldComponent.State = 'valid';\n\n  @Input()\n  maximumFractionDigits: number = 0;\n\n  @Input()\n  minimumFractionDigits: number = 0;\n\n  @Input()\n  min: number = -Infinity;\n\n  @Input()\n  max: number = Infinity;\n\n  @Input()\n  align: NumberFieldComponent.Alignment = 'left';\n\n  @Input()\n  set value(v: string | null) {\n    if (\n      NumberFieldComponent.clean(\n        v,\n        this.maximumFractionDigits,\n        this.min,\n        this.max,\n      ) ===\n      NumberFieldComponent.clean(\n        this._text,\n        this.maximumFractionDigits,\n        this.min,\n        this.max,\n      )\n    )\n      return;\n    this._text = NumberFieldComponent.format(\n      v,\n      this.minimumFractionDigits,\n      this.maximumFractionDigits,\n      this.min,\n      this.max,\n    );\n  }\n\n  @Output()\n  valueChange = new EventEmitter<number | null>();\n\n  protected _text: string = '';\n\n  set text(t: string) {\n    this._text = t;\n    this.valueChange.emit(\n      NumberFieldComponent.clean(\n        t,\n        this.maximumFractionDigits,\n        this.min,\n        this.max,\n      ),\n    );\n  }\n  get text(): string {\n    return this._text;\n  }\n\n  blur() {\n    this._text = NumberFieldComponent.format(\n      this._text,\n      this.minimumFractionDigits,\n      this.maximumFractionDigits,\n      this.min,\n      this.max,\n    );\n  }\n}\n\nexport namespace NumberFieldComponent {\n  export const Alignments = ['left', 'center', 'right'] as const;\n  export type Alignment = (typeof Alignments)[number];\n\n  export function clean(\n    v: string | null,\n    maximumFractionDigits: number,\n    min: number,\n    max: number,\n  ): number | null {\n    function digitsOnly(str: string): string {\n      return str.replace(/\\D/g, '');\n    }\n\n    if (!v) return null;\n    const decimalPointIdx = v.indexOf('.');\n    const signIdx = v.indexOf('-');\n    const cleanedString: string =\n      (signIdx > -1 ? '-' : '') +\n      (decimalPointIdx > -1\n        ? digitsOnly(v.substring(0, decimalPointIdx)) +\n          '.' +\n          digitsOnly(v.substring(decimalPointIdx + 1))\n        : digitsOnly(v));\n    if (\n      cleanedString === '.' ||\n      cleanedString === '-' ||\n      cleanedString === '-.'\n    ) {\n      return null;\n    }\n    const cleaned = Number(\n      Number(cleanedString).toFixed(maximumFractionDigits),\n    );\n    return Math.max(min, Math.min(max, cleaned));\n  }\n\n  export function format(\n    v: string | null,\n    minimumFractionDigits: number,\n    maximumFractionDigits: number,\n    min: number,\n    max: number,\n  ): string {\n    const cleaned = clean(v, maximumFractionDigits, min, max);\n    if (cleaned === null) return '';\n    return new Intl.NumberFormat('en-US', {\n      minimumFractionDigits,\n      maximumFractionDigits,\n    }).format(cleaned);\n  }\n}\n","<riv-input-label\n  [label]=\"label\"\n  [help]=\"help\"\n  [required]=\"required\"\n  [labelActionText]=\"labelActionText\"\n  (labelAction)=\"labelAction.emit($event)\"\n>\n  <input\n    #input\n    [placeholder]=\"placeholder\"\n    type=\"text\"\n    [required]=\"required\"\n    [disabled]=\"disabled\"\n    [readonly]=\"readonly\"\n    [value]=\"text\"\n    (input)=\"text = input.value\"\n    [class.warning]=\"state === 'warning'\"\n    [class.error]=\"state === 'error'\"\n    [style.textAlign]=\"align\"\n    autocomplete=\"off\"\n    autocorrect=\"off\"\n    autocapitalize=\"off\"\n    spellcheck=\"false\"\n    (blur)=\"blur()\"\n  />\n</riv-input-label>\n"]}
@@ -0,0 +1,19 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { NumberFieldComponent } from '../number-field/number-field.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../input-label/input-label.component";
5
+ export class PercentageFieldComponent extends NumberFieldComponent {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.align = 'right';
9
+ }
10
+ }
11
+ PercentageFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PercentageFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
12
+ PercentageFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PercentageFieldComponent, selector: "riv-percentage-field", inputs: { align: "align" }, usesInheritance: true, ngImport: i0, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <input\n #input\n [placeholder]=\"placeholder\"\n type=\"text\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n [style.textAlign]=\"align\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n <span class=\"suffix\">%</span>\n</riv-input-label>\n", styles: [":host{position:relative}.suffix{position:absolute;right:0;font:var(--input-medium);padding:var(--size-small)}input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small) var(--size-xlarge) var(--size-small) var(--size-small)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"], dependencies: [{ kind: "component", type: i1.InputLabelComponent, selector: "riv-input-label", inputs: ["label", "help", "required", "labelActionText"], outputs: ["labelAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
13
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PercentageFieldComponent, decorators: [{
14
+ type: Component,
15
+ args: [{ selector: 'riv-percentage-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <input\n #input\n [placeholder]=\"placeholder\"\n type=\"text\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n [style.textAlign]=\"align\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n <span class=\"suffix\">%</span>\n</riv-input-label>\n", styles: [":host{position:relative}.suffix{position:absolute;right:0;font:var(--input-medium);padding:var(--size-small)}input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small) var(--size-xlarge) var(--size-small) var(--size-small)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"] }]
16
+ }], propDecorators: { align: [{
17
+ type: Input
18
+ }] } });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyY2VudGFnZS1maWVsZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9yaXYvc3JjL2xpYi9pbnB1dC9wZXJjZW50YWdlLWZpZWxkL3BlcmNlbnRhZ2UtZmllbGQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcml2L3NyYy9saWIvaW5wdXQvcGVyY2VudGFnZS1maWVsZC9wZXJjZW50YWdlLWZpZWxkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzFFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHdDQUF3QyxDQUFDOzs7QUFROUUsTUFBTSxPQUFPLHdCQUF5QixTQUFRLG9CQUFvQjtJQU5sRTs7UUFRVyxVQUFLLEdBQW1DLE9BQU8sQ0FBQztLQUMxRDs7cUhBSFksd0JBQXdCO3lHQUF4Qix3QkFBd0IsK0dDVHJDLGtzQkEyQkE7MkZEbEJhLHdCQUF3QjtrQkFOcEMsU0FBUzsrQkFDRSxzQkFBc0IsbUJBR2YsdUJBQXVCLENBQUMsTUFBTTs4QkFJdEMsS0FBSztzQkFEYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE51bWJlckZpZWxkQ29tcG9uZW50IH0gZnJvbSAnLi4vbnVtYmVyLWZpZWxkL251bWJlci1maWVsZC5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdyaXYtcGVyY2VudGFnZS1maWVsZCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9wZXJjZW50YWdlLWZpZWxkLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcGVyY2VudGFnZS1maWVsZC5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBQZXJjZW50YWdlRmllbGRDb21wb25lbnQgZXh0ZW5kcyBOdW1iZXJGaWVsZENvbXBvbmVudCB7XG4gIEBJbnB1dCgpXG4gIG92ZXJyaWRlIGFsaWduOiBOdW1iZXJGaWVsZENvbXBvbmVudC5BbGlnbm1lbnQgPSAncmlnaHQnO1xufVxuIiwiPHJpdi1pbnB1dC1sYWJlbFxuICBbbGFiZWxdPVwibGFiZWxcIlxuICBbaGVscF09XCJoZWxwXCJcbiAgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCJcbiAgW2xhYmVsQWN0aW9uVGV4dF09XCJsYWJlbEFjdGlvblRleHRcIlxuICAobGFiZWxBY3Rpb24pPVwibGFiZWxBY3Rpb24uZW1pdCgkZXZlbnQpXCJcbj5cbiAgPGlucHV0XG4gICAgI2lucHV0XG4gICAgW3BsYWNlaG9sZGVyXT1cInBsYWNlaG9sZGVyXCJcbiAgICB0eXBlPVwidGV4dFwiXG4gICAgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCJcbiAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxuICAgIFtyZWFkb25seV09XCJyZWFkb25seVwiXG4gICAgW3ZhbHVlXT1cInRleHRcIlxuICAgIChpbnB1dCk9XCJ0ZXh0ID0gaW5wdXQudmFsdWVcIlxuICAgIFtjbGFzcy53YXJuaW5nXT1cInN0YXRlID09PSAnd2FybmluZydcIlxuICAgIFtjbGFzcy5lcnJvcl09XCJzdGF0ZSA9PT0gJ2Vycm9yJ1wiXG4gICAgW3N0eWxlLnRleHRBbGlnbl09XCJhbGlnblwiXG4gICAgYXV0b2NvbXBsZXRlPVwib2ZmXCJcbiAgICBhdXRvY29ycmVjdD1cIm9mZlwiXG4gICAgYXV0b2NhcGl0YWxpemU9XCJvZmZcIlxuICAgIHNwZWxsY2hlY2s9XCJmYWxzZVwiXG4gICAgKGJsdXIpPVwiYmx1cigpXCJcbiAgLz5cbiAgPHNwYW4gY2xhc3M9XCJzdWZmaXhcIj4lPC9zcGFuPlxuPC9yaXYtaW5wdXQtbGFiZWw+XG4iXX0=
@@ -0,0 +1,100 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
+ import { InputLabelComponent } from '../input-label/input-label.component';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../input-label/input-label.component";
5
+ export class TextFieldComponent extends InputLabelComponent {
6
+ constructor() {
7
+ super(...arguments);
8
+ this.disabled = false;
9
+ this.readonly = false;
10
+ this.placeholder = '';
11
+ this.state = 'valid';
12
+ this.casing = 'user';
13
+ this.type = 'text';
14
+ this.valueChange = new EventEmitter();
15
+ this._text = '';
16
+ }
17
+ set value(v) {
18
+ // The parent component is setting the value. If the cleaned version of this
19
+ // value is the same as the cleaned version of the value we have in the
20
+ // input, we won't touch the input's text, as this would interrupt the user
21
+ // and reset their cursor position.
22
+ if (TextFieldComponent.clean(v, this.casing) ===
23
+ TextFieldComponent.clean(this._text, this.casing))
24
+ return;
25
+ this._text = TextFieldComponent.format(v, this.casing);
26
+ }
27
+ set text(t) {
28
+ // The user is setting the value. We'll keep the internal state exactly as
29
+ // the user has typed it, but emit the clean value. Even if the cleaned
30
+ // value is passed directly back to us, we won't override the user's work
31
+ // (see comment in value setter above).
32
+ this._text = t;
33
+ this.valueChange.emit(TextFieldComponent.clean(t, this.casing));
34
+ }
35
+ get text() {
36
+ return this._text;
37
+ }
38
+ blur() {
39
+ // Now that the user is done editing and has left the field, we can safely
40
+ // update the internal state to match the cleaned/formatted version of
41
+ // their input.
42
+ this._text = TextFieldComponent.format(this._text, this.casing);
43
+ }
44
+ }
45
+ TextFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TextFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
46
+ TextFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TextFieldComponent, selector: "riv-text-field", inputs: { disabled: "disabled", readonly: "readonly", placeholder: "placeholder", state: "state", casing: "casing", type: "type", minLength: "minLength", maxLength: "maxLength", value: "value" }, outputs: { valueChange: "valueChange" }, usesInheritance: true, ngImport: i0, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <input\n #input\n [placeholder]=\"placeholder\"\n [type]=\"type\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [attr.maxlength]=\"maxLength\"\n [attr.minlength]=\"minLength\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n</riv-input-label>\n", styles: ["input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"], dependencies: [{ kind: "component", type: i1.InputLabelComponent, selector: "riv-input-label", inputs: ["label", "help", "required", "labelActionText"], outputs: ["labelAction"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TextFieldComponent, decorators: [{
48
+ type: Component,
49
+ args: [{ selector: 'riv-text-field', changeDetection: ChangeDetectionStrategy.OnPush, template: "<riv-input-label\n [label]=\"label\"\n [help]=\"help\"\n [required]=\"required\"\n [labelActionText]=\"labelActionText\"\n (labelAction)=\"labelAction.emit($event)\"\n>\n <input\n #input\n [placeholder]=\"placeholder\"\n [type]=\"type\"\n [required]=\"required\"\n [disabled]=\"disabled\"\n [readonly]=\"readonly\"\n [value]=\"text\"\n (input)=\"text = input.value\"\n [attr.maxlength]=\"maxLength\"\n [attr.minlength]=\"minLength\"\n [class.warning]=\"state === 'warning'\"\n [class.error]=\"state === 'error'\"\n autocomplete=\"off\"\n autocorrect=\"off\"\n autocapitalize=\"off\"\n spellcheck=\"false\"\n (blur)=\"blur()\"\n />\n</riv-input-label>\n", styles: ["input{width:100%;border:var(--border-width) solid var(--border-light);border-radius:var(--border-radius-small);font:var(--input-medium);color:var(--type-light-high-contrast);padding:var(--size-small)}input::placeholder{color:var(--type-light-disabled)}input:disabled{color:var(--type-light-disabled);background-color:var(--surface-light-1)}input:read-only{background-color:var(--surface-light-1)}input:focus{outline:none;border:var(--border-width) solid var(--purp-60)}input.warning{border-color:var(--surface-dark-caution)}input.error{border-color:var(--surface-dark-danger)}\n"] }]
50
+ }], propDecorators: { disabled: [{
51
+ type: Input
52
+ }], readonly: [{
53
+ type: Input
54
+ }], placeholder: [{
55
+ type: Input
56
+ }], state: [{
57
+ type: Input
58
+ }], casing: [{
59
+ type: Input
60
+ }], type: [{
61
+ type: Input
62
+ }], minLength: [{
63
+ type: Input
64
+ }], maxLength: [{
65
+ type: Input
66
+ }], value: [{
67
+ type: Input
68
+ }], valueChange: [{
69
+ type: Output
70
+ }] } });
71
+ (function (TextFieldComponent) {
72
+ TextFieldComponent.Casings = ['user', 'upper', 'lower'];
73
+ TextFieldComponent.Types = [
74
+ 'text',
75
+ 'email',
76
+ 'password',
77
+ 'search',
78
+ 'tel',
79
+ 'url',
80
+ ];
81
+ TextFieldComponent.States = ['valid', 'warning', 'error'];
82
+ function clean(v, casing) {
83
+ switch (casing) {
84
+ case 'lower':
85
+ return v.toLowerCase();
86
+ case 'upper':
87
+ return v.toUpperCase();
88
+ case 'user':
89
+ return v;
90
+ }
91
+ }
92
+ TextFieldComponent.clean = clean;
93
+ // For the basic text component, formatting is a simple pass-through to
94
+ // clean(). More advanced inputs will implement more complicated formatting.
95
+ function format(v, casing) {
96
+ return clean(v, casing);
97
+ }
98
+ TextFieldComponent.format = format;
99
+ })(TextFieldComponent || (TextFieldComponent = {}));
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-field.component.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/input/text-field/text-field.component.ts","../../../../../../projects/riv/src/lib/input/text-field/text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core';\nimport { InputLabelComponent } from '../input-label/input-label.component';\n\n@Component({\n  selector: 'riv-text-field',\n  templateUrl: './text-field.component.html',\n  styleUrls: ['./text-field.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TextFieldComponent extends InputLabelComponent {\n  @Input()\n  disabled: boolean = false;\n\n  @Input()\n  readonly: boolean = false;\n\n  @Input()\n  placeholder: string = '';\n\n  @Input()\n  state: TextFieldComponent.State = 'valid';\n\n  @Input()\n  casing: TextFieldComponent.Casing = 'user';\n\n  @Input()\n  type: TextFieldComponent.Type = 'text';\n\n  @Input()\n  minLength?: number;\n\n  @Input()\n  maxLength?: number;\n\n  @Input()\n  set value(v: string) {\n    // The parent component is setting the value. If the cleaned version of this\n    // value is the same as the cleaned version of the value we have in the\n    // input, we won't touch the input's text, as this would interrupt the user\n    // and reset their cursor position.\n    if (\n      TextFieldComponent.clean(v, this.casing) ===\n      TextFieldComponent.clean(this._text, this.casing)\n    )\n      return;\n    this._text = TextFieldComponent.format(v, this.casing);\n  }\n\n  @Output()\n  valueChange = new EventEmitter<string>();\n\n  protected _text: string = '';\n\n  set text(t: string) {\n    // The user is setting the value. We'll keep the internal state exactly as\n    // the user has typed it, but emit the clean value. Even if the cleaned\n    // value is passed directly back to us, we won't override the user's work\n    // (see comment in value setter above).\n    this._text = t;\n    this.valueChange.emit(TextFieldComponent.clean(t, this.casing));\n  }\n  get text(): string {\n    return this._text;\n  }\n\n  blur() {\n    // Now that the user is done editing and has left the field, we can safely\n    // update the internal state to match the cleaned/formatted version of\n    // their input.\n    this._text = TextFieldComponent.format(this._text, this.casing);\n  }\n}\n\nexport namespace TextFieldComponent {\n  export const Casings = ['user', 'upper', 'lower'] as const;\n  export type Casing = (typeof Casings)[number];\n\n  export const Types = [\n    'text',\n    'email',\n    'password',\n    'search',\n    'tel',\n    'url',\n  ] as const;\n  export type Type = (typeof Types)[number];\n\n  export const States = ['valid', 'warning', 'error'] as const;\n  export type State = (typeof States)[number];\n\n  export function clean(v: string, casing: Casing): string {\n    switch (casing) {\n      case 'lower':\n        return v.toLowerCase();\n      case 'upper':\n        return v.toUpperCase();\n      case 'user':\n        return v;\n    }\n  }\n\n  // For the basic text component, formatting is a simple pass-through to\n  // clean(). More advanced inputs will implement more complicated formatting.\n  export function format(v: string, casing: Casing): string {\n    return clean(v, casing);\n  }\n}\n","<riv-input-label\n  [label]=\"label\"\n  [help]=\"help\"\n  [required]=\"required\"\n  [labelActionText]=\"labelActionText\"\n  (labelAction)=\"labelAction.emit($event)\"\n>\n  <input\n    #input\n    [placeholder]=\"placeholder\"\n    [type]=\"type\"\n    [required]=\"required\"\n    [disabled]=\"disabled\"\n    [readonly]=\"readonly\"\n    [value]=\"text\"\n    (input)=\"text = input.value\"\n    [attr.maxlength]=\"maxLength\"\n    [attr.minlength]=\"minLength\"\n    [class.warning]=\"state === 'warning'\"\n    [class.error]=\"state === 'error'\"\n    autocomplete=\"off\"\n    autocorrect=\"off\"\n    autocapitalize=\"off\"\n    spellcheck=\"false\"\n    (blur)=\"blur()\"\n  />\n</riv-input-label>\n"]}
@@ -11,15 +11,20 @@ import { SmallCurrencyPipe } from './format/pipes/small-currency.pipe';
11
11
  import { SVGTextTruncateDirective } from './format/svg-text-truncate/svg-text-truncate.directive';
12
12
  import { TruncateComponent } from './format/truncate/truncate.component';
13
13
  import { IconComponent } from './icon/icon.component';
14
+ import { AlphabeticFieldComponent } from './input/alphabetic-field/alphabetic-field.component';
14
15
  import { ButtonComponent } from './input/button/button.component';
15
16
  import { CalendarComponent } from './input/calendar/calendar.component';
16
17
  import { CardCheckboxComponent } from './input/card-checkbox/card-checkbox.component';
17
18
  import { CheckboxComponent } from './input/checkbox/checkbox.component';
19
+ import { CurrencyFieldComponent } from './input/currency-field/currency-field.component';
18
20
  import { DateRangeComponent } from './input/date-range/date-range.component';
19
21
  import { DateComponent } from './input/date/date.component';
20
22
  import { InputLabelComponent } from './input/input-label/input-label.component';
23
+ import { NumberFieldComponent } from './input/number-field/number-field.component';
24
+ import { PercentageFieldComponent } from './input/percentage-field/percentage-field.component';
21
25
  import { SingleSelectComponent } from './input/single-select/single-select.component';
22
26
  import { SwitchCheckboxComponent } from './input/switch-checkbox/switch-checkbox.component';
27
+ import { TextFieldComponent } from './input/text-field/text-field.component';
23
28
  import { FocusOnInitDirective } from './interaction/focus-on-init.directive';
24
29
  import { LoadingCoverComponent } from './load/loading-cover/loading-cover.component';
25
30
  import { LoadingComponent } from './load/loading/loading.component';
@@ -52,7 +57,8 @@ import * as i0 from "@angular/core";
52
57
  export class RivModule {
53
58
  }
54
59
  RivModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: RivModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
55
- RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: RivModule, declarations: [BadgeComponent,
60
+ RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: RivModule, declarations: [AlphabeticFieldComponent,
61
+ BadgeComponent,
56
62
  ButtonComponent,
57
63
  CalendarComponent,
58
64
  CalloutComponent,
@@ -60,6 +66,7 @@ RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.
60
66
  CalloutOutletComponent,
61
67
  CardCheckboxComponent,
62
68
  CheckboxComponent,
69
+ CurrencyFieldComponent,
63
70
  DataTableCellComponent,
64
71
  DataTableComponent,
65
72
  DataTableHeaderCellComponent,
@@ -83,8 +90,10 @@ RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.
83
90
  LoadingCoverComponent,
84
91
  LockScrollDirective,
85
92
  MetricComponent,
93
+ NumberFieldComponent,
86
94
  NumberPipe,
87
95
  OptionGroupPipe,
96
+ PercentageFieldComponent,
88
97
  PercentagePipe,
89
98
  SingleSelectComponent,
90
99
  SizeDirective,
@@ -93,19 +102,22 @@ RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.
93
102
  StackedRowComponent,
94
103
  SVGTextTruncateDirective,
95
104
  SwitchCheckboxComponent,
105
+ TextFieldComponent,
96
106
  TextToggleComponent,
97
107
  TimeSeriesComponent,
98
108
  TooltipComponent,
99
109
  TooltipDirective,
100
110
  TrendComponent,
101
111
  TruncateComponent,
102
- ZeroStateComponent], imports: [CommonModule], exports: [BadgeComponent,
112
+ ZeroStateComponent], imports: [CommonModule], exports: [AlphabeticFieldComponent,
113
+ BadgeComponent,
103
114
  ButtonComponent,
104
115
  CalloutComponent,
105
116
  CalloutDirective,
106
117
  CalloutOutletComponent,
107
118
  CardCheckboxComponent,
108
119
  CheckboxComponent,
120
+ CurrencyFieldComponent,
109
121
  DataTableCellComponent,
110
122
  DataTableComponent,
111
123
  DataTableHeaderCellComponent,
@@ -128,8 +140,10 @@ RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.
128
140
  LoadingComponent,
129
141
  LoadingCoverComponent,
130
142
  MetricComponent,
143
+ NumberFieldComponent,
131
144
  NumberPipe,
132
145
  OptionGroupPipe,
146
+ PercentageFieldComponent,
133
147
  PercentagePipe,
134
148
  SingleSelectComponent,
135
149
  SizeDirective,
@@ -138,6 +152,7 @@ RivModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.
138
152
  StackedRowComponent,
139
153
  SVGTextTruncateDirective,
140
154
  SwitchCheckboxComponent,
155
+ TextFieldComponent,
141
156
  TextToggleComponent,
142
157
  TimeSeriesComponent,
143
158
  TooltipComponent,
@@ -150,6 +165,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
150
165
  type: NgModule,
151
166
  args: [{
152
167
  declarations: [
168
+ AlphabeticFieldComponent,
153
169
  BadgeComponent,
154
170
  ButtonComponent,
155
171
  CalendarComponent,
@@ -158,6 +174,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
158
174
  CalloutOutletComponent,
159
175
  CardCheckboxComponent,
160
176
  CheckboxComponent,
177
+ CurrencyFieldComponent,
161
178
  DataTableCellComponent,
162
179
  DataTableComponent,
163
180
  DataTableHeaderCellComponent,
@@ -181,8 +198,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
181
198
  LoadingCoverComponent,
182
199
  LockScrollDirective,
183
200
  MetricComponent,
201
+ NumberFieldComponent,
184
202
  NumberPipe,
185
203
  OptionGroupPipe,
204
+ PercentageFieldComponent,
186
205
  PercentagePipe,
187
206
  SingleSelectComponent,
188
207
  SizeDirective,
@@ -191,6 +210,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
191
210
  StackedRowComponent,
192
211
  SVGTextTruncateDirective,
193
212
  SwitchCheckboxComponent,
213
+ TextFieldComponent,
194
214
  TextToggleComponent,
195
215
  TimeSeriesComponent,
196
216
  TooltipComponent,
@@ -200,6 +220,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
200
220
  ZeroStateComponent,
201
221
  ],
202
222
  exports: [
223
+ AlphabeticFieldComponent,
203
224
  BadgeComponent,
204
225
  ButtonComponent,
205
226
  CalloutComponent,
@@ -207,6 +228,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
207
228
  CalloutOutletComponent,
208
229
  CardCheckboxComponent,
209
230
  CheckboxComponent,
231
+ CurrencyFieldComponent,
210
232
  DataTableCellComponent,
211
233
  DataTableComponent,
212
234
  DataTableHeaderCellComponent,
@@ -229,8 +251,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
229
251
  LoadingComponent,
230
252
  LoadingCoverComponent,
231
253
  MetricComponent,
254
+ NumberFieldComponent,
232
255
  NumberPipe,
233
256
  OptionGroupPipe,
257
+ PercentageFieldComponent,
234
258
  PercentagePipe,
235
259
  SingleSelectComponent,
236
260
  SizeDirective,
@@ -239,6 +263,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
239
263
  StackedRowComponent,
240
264
  SVGTextTruncateDirective,
241
265
  SwitchCheckboxComponent,
266
+ TextFieldComponent,
242
267
  TextToggleComponent,
243
268
  TimeSeriesComponent,
244
269
  TooltipComponent,
@@ -250,4 +275,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
250
275
  imports: [CommonModule],
251
276
  }]
252
277
  }] });
253
- //# 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 { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { TextToggleComponent } from './content-toggle/text-toggle/text-toggle.component';\nimport { DatePipe } from './format/pipes/date.pipe';\nimport { DaysPipe } from './format/pipes/days.pipe';\nimport { DollarsPipe } from './format/pipes/dollars.pipe';\nimport { NumberPipe } from './format/pipes/number.pipe';\nimport { OptionGroupPipe } from './format/pipes/option-group.pipe';\nimport { PercentagePipe } from './format/pipes/percentage.pipe';\nimport { SmallCurrencyPipe } from './format/pipes/small-currency.pipe';\nimport { SVGTextTruncateDirective } from './format/svg-text-truncate/svg-text-truncate.directive';\nimport { TruncateComponent } from './format/truncate/truncate.component';\nimport { IconComponent } from './icon/icon.component';\nimport { ButtonComponent } from './input/button/button.component';\nimport { CalendarComponent } from './input/calendar/calendar.component';\nimport { CardCheckboxComponent } from './input/card-checkbox/card-checkbox.component';\nimport { CheckboxComponent } from './input/checkbox/checkbox.component';\nimport { DateRangeComponent } from './input/date-range/date-range.component';\nimport { DateComponent } from './input/date/date.component';\nimport { InputLabelComponent } from './input/input-label/input-label.component';\nimport { SingleSelectComponent } from './input/single-select/single-select.component';\nimport { SwitchCheckboxComponent } from './input/switch-checkbox/switch-checkbox.component';\nimport { FocusOnInitDirective } from './interaction/focus-on-init.directive';\nimport { LoadingCoverComponent } from './load/loading-cover/loading-cover.component';\nimport { LoadingComponent } from './load/loading/loading.component';\nimport { CalloutOutletComponent } from './modal/callout/callout-outlet.component';\nimport { CalloutComponent } from './modal/callout/callout.component';\nimport { CalloutDirective } from './modal/callout/callout.directive';\nimport { LockScrollDirective } from './modal/callout/lock-scroll.directive';\nimport { HelpComponent } from './modal/help/help.component';\nimport { TooltipComponent } from './modal/tooltip/tooltip.component';\nimport { TooltipDirective } from './modal/tooltip/tooltip.directive';\nimport { LinkComponent } from './navigation/link/link.component';\nimport { BadgeComponent } from './notification/badge/badge.component';\nimport { SizeDirective } from './size/size.directive';\nimport { DataTableCellComponent } from './visualization/data-table/data-table-cell.component';\nimport { DataTableHeaderCellComponent } from './visualization/data-table/data-table-header-cell.component';\nimport { DataTableRowComponent } from './visualization/data-table/data-table-row.component';\nimport { DataTableComponent } from './visualization/data-table/data-table.component';\nimport { DonutComponent } from './visualization/donut/donut.component';\nimport { FunnelChartComponent } from './visualization/funnel-chart/funnel-chart.component';\nimport { HighlightComponent } from './visualization/highlight/highlight.component';\nimport { IssueComponent } from './visualization/issue/issue.component';\nimport { LegendItemComponent } from './visualization/legend-item/legend-item.component';\nimport { MetricComponent } from './visualization/metric/metric.component';\nimport { StackedColumnComponent } from './visualization/stacked-column/stacked-column.component';\nimport { StackedRowComponent } from './visualization/stacked-row/stacked-row.component';\nimport { TimeSeriesComponent } from './visualization/time-series/time-series.component';\nimport { TrendComponent } from './visualization/trend/trend.component';\nimport { ZeroStateComponent } from './visualization/zero-state/zero-state.component';\n\n@NgModule({\n  declarations: [\n    BadgeComponent,\n    ButtonComponent,\n    CalendarComponent,\n    CalloutComponent,\n    CalloutDirective,\n    CalloutOutletComponent,\n    CardCheckboxComponent,\n    CheckboxComponent,\n    DataTableCellComponent,\n    DataTableComponent,\n    DataTableHeaderCellComponent,\n    DataTableRowComponent,\n    DateComponent,\n    DatePipe,\n    DateRangeComponent,\n    DaysPipe,\n    DollarsPipe,\n    DonutComponent,\n    FocusOnInitDirective,\n    FunnelChartComponent,\n    HelpComponent,\n    HighlightComponent,\n    IconComponent,\n    InputLabelComponent,\n    IssueComponent,\n    LegendItemComponent,\n    LinkComponent,\n    LoadingComponent,\n    LoadingCoverComponent,\n    LockScrollDirective,\n    MetricComponent,\n    NumberPipe,\n    OptionGroupPipe,\n    PercentagePipe,\n    SingleSelectComponent,\n    SizeDirective,\n    SmallCurrencyPipe,\n    StackedColumnComponent,\n    StackedRowComponent,\n    SVGTextTruncateDirective,\n    SwitchCheckboxComponent,\n    TextToggleComponent,\n    TimeSeriesComponent,\n    TooltipComponent,\n    TooltipDirective,\n    TrendComponent,\n    TruncateComponent,\n    ZeroStateComponent,\n  ],\n  exports: [\n    BadgeComponent,\n    ButtonComponent,\n    CalloutComponent,\n    CalloutDirective,\n    CalloutOutletComponent,\n    CardCheckboxComponent,\n    CheckboxComponent,\n    DataTableCellComponent,\n    DataTableComponent,\n    DataTableHeaderCellComponent,\n    DataTableRowComponent,\n    DateComponent,\n    DatePipe,\n    DateRangeComponent,\n    DaysPipe,\n    DollarsPipe,\n    DonutComponent,\n    FocusOnInitDirective,\n    FunnelChartComponent,\n    HelpComponent,\n    HighlightComponent,\n    IconComponent,\n    InputLabelComponent,\n    IssueComponent,\n    LegendItemComponent,\n    LinkComponent,\n    LoadingComponent,\n    LoadingCoverComponent,\n    MetricComponent,\n    NumberPipe,\n    OptionGroupPipe,\n    PercentagePipe,\n    SingleSelectComponent,\n    SizeDirective,\n    SmallCurrencyPipe,\n    StackedColumnComponent,\n    StackedRowComponent,\n    SVGTextTruncateDirective,\n    SwitchCheckboxComponent,\n    TextToggleComponent,\n    TimeSeriesComponent,\n    TooltipComponent,\n    TooltipDirective,\n    TrendComponent,\n    TruncateComponent,\n    ZeroStateComponent,\n  ],\n  imports: [CommonModule],\n})\nexport class RivModule {}\n"]}
278
+ //# 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 { CommonModule } from '@angular/common';\nimport { NgModule } from '@angular/core';\nimport { TextToggleComponent } from './content-toggle/text-toggle/text-toggle.component';\nimport { DatePipe } from './format/pipes/date.pipe';\nimport { DaysPipe } from './format/pipes/days.pipe';\nimport { DollarsPipe } from './format/pipes/dollars.pipe';\nimport { NumberPipe } from './format/pipes/number.pipe';\nimport { OptionGroupPipe } from './format/pipes/option-group.pipe';\nimport { PercentagePipe } from './format/pipes/percentage.pipe';\nimport { SmallCurrencyPipe } from './format/pipes/small-currency.pipe';\nimport { SVGTextTruncateDirective } from './format/svg-text-truncate/svg-text-truncate.directive';\nimport { TruncateComponent } from './format/truncate/truncate.component';\nimport { IconComponent } from './icon/icon.component';\nimport { AlphabeticFieldComponent } from './input/alphabetic-field/alphabetic-field.component';\nimport { ButtonComponent } from './input/button/button.component';\nimport { CalendarComponent } from './input/calendar/calendar.component';\nimport { CardCheckboxComponent } from './input/card-checkbox/card-checkbox.component';\nimport { CheckboxComponent } from './input/checkbox/checkbox.component';\nimport { CurrencyFieldComponent } from './input/currency-field/currency-field.component';\nimport { DateRangeComponent } from './input/date-range/date-range.component';\nimport { DateComponent } from './input/date/date.component';\nimport { InputLabelComponent } from './input/input-label/input-label.component';\nimport { NumberFieldComponent } from './input/number-field/number-field.component';\nimport { PercentageFieldComponent } from './input/percentage-field/percentage-field.component';\nimport { SingleSelectComponent } from './input/single-select/single-select.component';\nimport { SwitchCheckboxComponent } from './input/switch-checkbox/switch-checkbox.component';\nimport { TextFieldComponent } from './input/text-field/text-field.component';\nimport { FocusOnInitDirective } from './interaction/focus-on-init.directive';\nimport { LoadingCoverComponent } from './load/loading-cover/loading-cover.component';\nimport { LoadingComponent } from './load/loading/loading.component';\nimport { CalloutOutletComponent } from './modal/callout/callout-outlet.component';\nimport { CalloutComponent } from './modal/callout/callout.component';\nimport { CalloutDirective } from './modal/callout/callout.directive';\nimport { LockScrollDirective } from './modal/callout/lock-scroll.directive';\nimport { HelpComponent } from './modal/help/help.component';\nimport { TooltipComponent } from './modal/tooltip/tooltip.component';\nimport { TooltipDirective } from './modal/tooltip/tooltip.directive';\nimport { LinkComponent } from './navigation/link/link.component';\nimport { BadgeComponent } from './notification/badge/badge.component';\nimport { SizeDirective } from './size/size.directive';\nimport { DataTableCellComponent } from './visualization/data-table/data-table-cell.component';\nimport { DataTableHeaderCellComponent } from './visualization/data-table/data-table-header-cell.component';\nimport { DataTableRowComponent } from './visualization/data-table/data-table-row.component';\nimport { DataTableComponent } from './visualization/data-table/data-table.component';\nimport { DonutComponent } from './visualization/donut/donut.component';\nimport { FunnelChartComponent } from './visualization/funnel-chart/funnel-chart.component';\nimport { HighlightComponent } from './visualization/highlight/highlight.component';\nimport { IssueComponent } from './visualization/issue/issue.component';\nimport { LegendItemComponent } from './visualization/legend-item/legend-item.component';\nimport { MetricComponent } from './visualization/metric/metric.component';\nimport { StackedColumnComponent } from './visualization/stacked-column/stacked-column.component';\nimport { StackedRowComponent } from './visualization/stacked-row/stacked-row.component';\nimport { TimeSeriesComponent } from './visualization/time-series/time-series.component';\nimport { TrendComponent } from './visualization/trend/trend.component';\nimport { ZeroStateComponent } from './visualization/zero-state/zero-state.component';\n\n@NgModule({\n  declarations: [\n    AlphabeticFieldComponent,\n    BadgeComponent,\n    ButtonComponent,\n    CalendarComponent,\n    CalloutComponent,\n    CalloutDirective,\n    CalloutOutletComponent,\n    CardCheckboxComponent,\n    CheckboxComponent,\n    CurrencyFieldComponent,\n    DataTableCellComponent,\n    DataTableComponent,\n    DataTableHeaderCellComponent,\n    DataTableRowComponent,\n    DateComponent,\n    DatePipe,\n    DateRangeComponent,\n    DaysPipe,\n    DollarsPipe,\n    DonutComponent,\n    FocusOnInitDirective,\n    FunnelChartComponent,\n    HelpComponent,\n    HighlightComponent,\n    IconComponent,\n    InputLabelComponent,\n    IssueComponent,\n    LegendItemComponent,\n    LinkComponent,\n    LoadingComponent,\n    LoadingCoverComponent,\n    LockScrollDirective,\n    MetricComponent,\n    NumberFieldComponent,\n    NumberPipe,\n    OptionGroupPipe,\n    PercentageFieldComponent,\n    PercentagePipe,\n    SingleSelectComponent,\n    SizeDirective,\n    SmallCurrencyPipe,\n    StackedColumnComponent,\n    StackedRowComponent,\n    SVGTextTruncateDirective,\n    SwitchCheckboxComponent,\n    TextFieldComponent,\n    TextToggleComponent,\n    TimeSeriesComponent,\n    TooltipComponent,\n    TooltipDirective,\n    TrendComponent,\n    TruncateComponent,\n    ZeroStateComponent,\n  ],\n  exports: [\n    AlphabeticFieldComponent,\n    BadgeComponent,\n    ButtonComponent,\n    CalloutComponent,\n    CalloutDirective,\n    CalloutOutletComponent,\n    CardCheckboxComponent,\n    CheckboxComponent,\n    CurrencyFieldComponent,\n    DataTableCellComponent,\n    DataTableComponent,\n    DataTableHeaderCellComponent,\n    DataTableRowComponent,\n    DateComponent,\n    DatePipe,\n    DateRangeComponent,\n    DaysPipe,\n    DollarsPipe,\n    DonutComponent,\n    FocusOnInitDirective,\n    FunnelChartComponent,\n    HelpComponent,\n    HighlightComponent,\n    IconComponent,\n    InputLabelComponent,\n    IssueComponent,\n    LegendItemComponent,\n    LinkComponent,\n    LoadingComponent,\n    LoadingCoverComponent,\n    MetricComponent,\n    NumberFieldComponent,\n    NumberPipe,\n    OptionGroupPipe,\n    PercentageFieldComponent,\n    PercentagePipe,\n    SingleSelectComponent,\n    SizeDirective,\n    SmallCurrencyPipe,\n    StackedColumnComponent,\n    StackedRowComponent,\n    SVGTextTruncateDirective,\n    SwitchCheckboxComponent,\n    TextFieldComponent,\n    TextToggleComponent,\n    TimeSeriesComponent,\n    TooltipComponent,\n    TooltipDirective,\n    TrendComponent,\n    TruncateComponent,\n    ZeroStateComponent,\n  ],\n  imports: [CommonModule],\n})\nexport class RivModule {}\n"]}