@openmrs/ngx-formentry 5.0.1-pre.380 → 5.0.1-pre.383

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.
@@ -3,9 +3,11 @@ import { ControlValueAccessor } from '@angular/forms';
3
3
  import { Observable, Subject } from 'rxjs';
4
4
  import { SelectOption } from '../../form-entry/question-models/interfaces/select-option';
5
5
  import { DataSource } from '../../form-entry/question-models/interfaces/data-source';
6
+ import { TranslateService } from '@ngx-translate/core';
6
7
  import * as i0 from "@angular/core";
7
8
  export declare class RemoteSelectComponent implements OnInit, ControlValueAccessor {
8
9
  private renderer;
10
+ private translate;
9
11
  remoteOptions$: Observable<SelectOption[]>;
10
12
  remoteOptionsLoading: boolean;
11
13
  remoteOptionInput$: Subject<string>;
@@ -14,16 +16,17 @@ export declare class RemoteSelectComponent implements OnInit, ControlValueAccess
14
16
  value: any[];
15
17
  loading: boolean;
16
18
  searchText: string;
17
- notFoundMsg: string;
18
- placeholder: string;
19
+ notFoundMsg: any;
20
+ placeholder: any;
19
21
  componentID: string;
20
22
  disabled: boolean;
21
23
  theme: string;
24
+ invalid: string;
22
25
  done: EventEmitter<any>;
23
26
  private _dataSource;
24
27
  get dataSource(): DataSource;
25
28
  set dataSource(v: DataSource);
26
- constructor(renderer: Renderer2);
29
+ constructor(renderer: Renderer2, translate: TranslateService);
27
30
  ngOnInit(): void;
28
31
  subscribeToDataSourceDataChanges(): void;
29
32
  writeValue(value: any): void;
@@ -36,5 +39,5 @@ export declare class RemoteSelectComponent implements OnInit, ControlValueAccess
36
39
  trackByFn(item: SelectOption): any;
37
40
  private loadOptions;
38
41
  static ɵfac: i0.ɵɵFactoryDeclaration<RemoteSelectComponent, never>;
39
- static ɵcmp: i0.ɵɵComponentDeclaration<RemoteSelectComponent, "ofe-remote-select", never, { "placeholder": { "alias": "placeholder"; "required": false; }; "componentID": { "alias": "componentID"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "theme": { "alias": "theme"; "required": false; }; "dataSource": { "alias": "dataSource"; "required": false; }; }, { "done": "done"; }, never, never, false, never>;
42
+ static ɵcmp: i0.ɵɵComponentDeclaration<RemoteSelectComponent, "ofe-remote-select", never, { "placeholder": { "alias": "placeholder"; "required": false; }; "componentID": { "alias": "componentID"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "theme": { "alias": "theme"; "required": false; }; "invalid": { "alias": "invalid"; "required": false; }; "dataSource": { "alias": "dataSource"; "required": false; }; }, { "done": "done"; }, never, never, false, never>;
40
43
  }
@@ -39,10 +39,14 @@ export declare class NumberInputComponent implements ControlValueAccessor {
39
39
  * The unique id for the number component.
40
40
  */
41
41
  id: string;
42
+ /**
43
+ * Sets the placeholder attribute on the `input` element.
44
+ */
45
+ placeholder: string;
42
46
  /**
43
47
  * Number input field render size
44
48
  */
45
- size: 'sm' | 'md' | 'xl';
49
+ size: 'sm' | 'md' | 'lg';
46
50
  /**
47
51
  * Reflects the required attribute of the `input` element.
48
52
  */
@@ -155,5 +159,5 @@ export declare class NumberInputComponent implements ControlValueAccessor {
155
159
  onNumberInputChange(event: any): void;
156
160
  isTemplate(value: any): boolean;
157
161
  static ɵfac: i0.ɵɵFactoryDeclaration<NumberInputComponent, never>;
158
- static ɵcmp: i0.ɵɵComponentDeclaration<NumberInputComponent, "ofe-number-input", never, { "theme": { "alias": "theme"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "skeleton": { "alias": "skeleton"; "required": false; }; "invalid": { "alias": "invalid"; "required": false; }; "id": { "alias": "id"; "required": false; }; "size": { "alias": "size"; "required": false; }; "required": { "alias": "required"; "required": false; }; "value": { "alias": "value"; "required": false; }; "min": { "alias": "min"; "required": false; }; "max": { "alias": "max"; "required": false; }; "maxlength": { "alias": "maxlength"; "required": false; }; "minlength": { "alias": "minlength"; "required": false; }; "label": { "alias": "label"; "required": false; }; "helperText": { "alias": "helperText"; "required": false; }; "invalidText": { "alias": "invalidText"; "required": false; }; "step": { "alias": "step"; "required": false; }; "precision": { "alias": "precision"; "required": false; }; "warn": { "alias": "warn"; "required": false; }; "warnText": { "alias": "warnText"; "required": false; }; "decrementLabel": { "alias": "decrementLabel"; "required": false; }; "incrementLabel": { "alias": "incrementLabel"; "required": false; }; }, { "numberChange": "numberChange"; }, never, never, false, never>;
162
+ static ɵcmp: i0.ɵɵComponentDeclaration<NumberInputComponent, "ofe-number-input", never, { "theme": { "alias": "theme"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "skeleton": { "alias": "skeleton"; "required": false; }; "invalid": { "alias": "invalid"; "required": false; }; "id": { "alias": "id"; "required": false; }; "placeholder": { "alias": "placeholder"; "required": false; }; "size": { "alias": "size"; "required": false; }; "required": { "alias": "required"; "required": false; }; "value": { "alias": "value"; "required": false; }; "min": { "alias": "min"; "required": false; }; "max": { "alias": "max"; "required": false; }; "maxlength": { "alias": "maxlength"; "required": false; }; "minlength": { "alias": "minlength"; "required": false; }; "label": { "alias": "label"; "required": false; }; "helperText": { "alias": "helperText"; "required": false; }; "invalidText": { "alias": "invalidText"; "required": false; }; "step": { "alias": "step"; "required": false; }; "precision": { "alias": "precision"; "required": false; }; "warn": { "alias": "warn"; "required": false; }; "warnText": { "alias": "warnText"; "required": false; }; "decrementLabel": { "alias": "decrementLabel"; "required": false; }; "incrementLabel": { "alias": "incrementLabel"; "required": false; }; }, { "numberChange": "numberChange"; }, never, never, false, never>;
159
163
  }
@@ -2,11 +2,12 @@ import { Component, Input, forwardRef, Output, EventEmitter, Renderer2 } from '@
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { concat, of, Subject } from 'rxjs';
4
4
  import { catchError, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';
5
+ import { TranslateService } from '@ngx-translate/core';
5
6
  import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/common";
7
- import * as i2 from "@ng-select/ng-select";
8
- import * as i3 from "@angular/forms";
9
- import * as i4 from "@ngx-translate/core";
7
+ import * as i1 from "@ngx-translate/core";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "@ng-select/ng-select";
10
+ import * as i4 from "@angular/forms";
10
11
  export class RemoteSelectComponent {
11
12
  get dataSource() {
12
13
  return this._dataSource;
@@ -17,18 +18,20 @@ export class RemoteSelectComponent {
17
18
  this.subscribeToDataSourceDataChanges();
18
19
  }
19
20
  }
20
- constructor(renderer) {
21
+ constructor(renderer, translate) {
21
22
  this.renderer = renderer;
23
+ this.translate = translate;
22
24
  this.remoteOptionsLoading = false;
23
25
  this.remoteOptionInput$ = new Subject();
24
26
  this.items = [];
25
27
  this.value = [];
26
28
  this.loading = false;
27
29
  this.searchText = '';
28
- this.notFoundMsg = 'match no found';
29
- this.placeholder = 'Search...';
30
+ this.notFoundMsg = this.translate.instant('matchNotFound');
31
+ this.placeholder = this.translate.instant('search');
30
32
  this.disabled = false;
31
33
  this.theme = 'dark';
34
+ this.invalid = 'false';
32
35
  this.done = new EventEmitter();
33
36
  this.compareItems = (item, selected) => {
34
37
  if (item.value && selected.value) {
@@ -51,7 +54,7 @@ export class RemoteSelectComponent {
51
54
  this.notFoundMsg = '';
52
55
  }
53
56
  else {
54
- this.notFoundMsg = 'Not found';
57
+ this.notFoundMsg = 'Match not found';
55
58
  this.items = [];
56
59
  }
57
60
  });
@@ -98,14 +101,14 @@ export class RemoteSelectComponent {
98
101
  }), switchMap((term) => this.dataSource.searchOptions(term).pipe(catchError(() => of([])), // empty list on error
99
102
  tap(() => (this.loading = false))))));
100
103
  }
101
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RemoteSelectComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
102
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RemoteSelectComponent, selector: "ofe-remote-select", inputs: { placeholder: "placeholder", componentID: "componentID", disabled: "disabled", theme: "theme", dataSource: "dataSource" }, outputs: { done: "done" }, providers: [
104
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RemoteSelectComponent, deps: [{ token: i0.Renderer2 }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
105
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: RemoteSelectComponent, selector: "ofe-remote-select", inputs: { placeholder: "placeholder", componentID: "componentID", disabled: "disabled", theme: "theme", invalid: "invalid", dataSource: "dataSource" }, outputs: { done: "done" }, providers: [
103
106
  {
104
107
  provide: NG_VALUE_ACCESSOR,
105
108
  useExisting: forwardRef(() => RemoteSelectComponent),
106
109
  multi: true
107
110
  }
108
- ], ngImport: i0, template: "<div>\n <ng-select\n [ngClass]=\"{ 'afe-custom': theme === 'light' }\"\n [disabled]=\"disabled\"\n [items]=\"remoteOptions$ | async\"\n bindLabel=\"label\"\n bindValue=\"value\"\n [multiple]=\"false\"\n [hideSelected]=\"true\"\n [compareWith]=\"compareItems\"\n [trackByFn]=\"trackByFn\"\n [loading]=\"loading\"\n typeToSearchText=\"{{ 'enterMoreCharacters' | translate }}\"\n [typeahead]=\"remoteOptionInput$\"\n [(ngModel)]=\"selectedRemoteOptions\"\n [appendTo]=\"'form'\"\n (ngModelChange)=\"selected($event)\"\n >\n </ng-select>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }] }); }
111
+ ], ngImport: i0, template: "<ng-select\n [ngClass]=\"{\n 'afe-custom': theme === 'light',\n 'invalid': invalid ? true : null,\n }\"\n [disabled]=\"disabled\"\n [items]=\"remoteOptions$ | async\"\n bindLabel=\"label\"\n bindValue=\"value\"\n [multiple]=\"false\"\n [hideSelected]=\"true\"\n [compareWith]=\"compareItems\"\n [trackByFn]=\"trackByFn\"\n [loading]=\"loading\"\n typeToSearchText=\"{{ 'enterMoreCharacters' | translate }}\"\n [typeahead]=\"remoteOptionInput$\"\n [(ngModel)]=\"selectedRemoteOptions\"\n [appendTo]=\"'form'\"\n (ngModelChange)=\"selected($event)\"\n>\n</ng-select>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
109
112
  }
110
113
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: RemoteSelectComponent, decorators: [{
111
114
  type: Component,
@@ -115,8 +118,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
115
118
  useExisting: forwardRef(() => RemoteSelectComponent),
116
119
  multi: true
117
120
  }
118
- ], template: "<div>\n <ng-select\n [ngClass]=\"{ 'afe-custom': theme === 'light' }\"\n [disabled]=\"disabled\"\n [items]=\"remoteOptions$ | async\"\n bindLabel=\"label\"\n bindValue=\"value\"\n [multiple]=\"false\"\n [hideSelected]=\"true\"\n [compareWith]=\"compareItems\"\n [trackByFn]=\"trackByFn\"\n [loading]=\"loading\"\n typeToSearchText=\"{{ 'enterMoreCharacters' | translate }}\"\n [typeahead]=\"remoteOptionInput$\"\n [(ngModel)]=\"selectedRemoteOptions\"\n [appendTo]=\"'form'\"\n (ngModelChange)=\"selected($event)\"\n >\n </ng-select>\n</div>\n" }]
119
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }]; }, propDecorators: { placeholder: [{
121
+ ], template: "<ng-select\n [ngClass]=\"{\n 'afe-custom': theme === 'light',\n 'invalid': invalid ? true : null,\n }\"\n [disabled]=\"disabled\"\n [items]=\"remoteOptions$ | async\"\n bindLabel=\"label\"\n bindValue=\"value\"\n [multiple]=\"false\"\n [hideSelected]=\"true\"\n [compareWith]=\"compareItems\"\n [trackByFn]=\"trackByFn\"\n [loading]=\"loading\"\n typeToSearchText=\"{{ 'enterMoreCharacters' | translate }}\"\n [typeahead]=\"remoteOptionInput$\"\n [(ngModel)]=\"selectedRemoteOptions\"\n [appendTo]=\"'form'\"\n (ngModelChange)=\"selected($event)\"\n>\n</ng-select>\n" }]
122
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i1.TranslateService }]; }, propDecorators: { placeholder: [{
120
123
  type: Input
121
124
  }], componentID: [{
122
125
  type: Input
@@ -124,9 +127,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
124
127
  type: Input
125
128
  }], theme: [{
126
129
  type: Input
130
+ }], invalid: [{
131
+ type: Input
127
132
  }], done: [{
128
133
  type: Output
129
134
  }], dataSource: [{
130
135
  type: Input
131
136
  }] } });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-remote-select.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-formentry/src/components/ngx-remote-select/ngx-remote-select.component.ts","../../../../../projects/ngx-formentry/src/components/ngx-remote-select/remote-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  forwardRef,\n  Output,\n  EventEmitter,\n  Renderer2\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { concat, Observable, of, Subject } from 'rxjs';\nimport {\n  catchError,\n  distinctUntilChanged,\n  switchMap,\n  tap\n} from 'rxjs/operators';\nimport { SelectOption } from '../../form-entry/question-models/interfaces/select-option';\n\nimport { DataSource } from '../../form-entry/question-models/interfaces/data-source';\nimport * as _ from 'lodash';\n@Component({\n  selector: 'ofe-remote-select',\n  templateUrl: 'remote-select.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => RemoteSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class RemoteSelectComponent implements OnInit, ControlValueAccessor {\n  // @Input() dataSource: DataSource;\n  remoteOptions$: Observable<SelectOption[]>;\n  remoteOptionsLoading = false;\n  remoteOptionInput$ = new Subject<string>();\n  selectedRemoteOptions: SelectOption;\n  items = [];\n  value = [];\n  loading = false;\n  searchText = '';\n  notFoundMsg = 'match no found';\n  @Input() placeholder = 'Search...';\n  @Input() componentID: string;\n  @Input() disabled = false;\n  @Input() theme = 'dark';\n  @Output() done: EventEmitter<any> = new EventEmitter<any>();\n\n  private _dataSource: DataSource;\n  @Input()\n  public get dataSource(): DataSource {\n    return this._dataSource;\n  }\n  public set dataSource(v: DataSource) {\n    this._dataSource = v;\n    if (this._dataSource && this._dataSource.dataFromSourceChanged) {\n      this.subscribeToDataSourceDataChanges();\n    }\n  }\n\n  constructor(private renderer: Renderer2) {}\n\n  ngOnInit() {\n    this.loadOptions();\n  }\n\n  subscribeToDataSourceDataChanges() {\n    this._dataSource.dataFromSourceChanged.subscribe((results) => {\n      if (results.length > 0) {\n        this.items = results;\n        this.notFoundMsg = '';\n      } else {\n        this.notFoundMsg = 'Not found';\n        this.items = [];\n      }\n    });\n  }\n\n  // this is the initial value set to the component\n  public writeValue(value: any) {\n    if (value && value !== '') {\n      if (this.dataSource) {\n        this.loading = true;\n        this.dataSource.resolveSelectedValue(value).subscribe(\n          (result: any) => {\n            this.items = [result];\n            this.selectedRemoteOptions = result;\n            this.loading = false;\n          },\n          (error) => {\n            this.loading = false;\n          }\n        );\n      }\n    }\n  }\n  // registers 'fn' that will be fired when changes are made\n  // this is how we emit the changes back to the form\n  public registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  // not used, used for touch input\n  public registerOnTouched() {}\n  // change events from the textarea\n  onChange(event) {\n    this.propagateChange(event.id);\n    // .....\n    // update the form\n    // this.propagateChange(this.data);\n  }\n  selected(event) {\n    this.propagateChange(event);\n  }\n\n  compareItems = (item, selected) => {\n    if (item.value && selected.value) {\n      return item.value === selected.value;\n    }\n    return false;\n  };\n\n  // the method set in registerOnChange, it is just\n  // a placeholder for a method that takes one parameter,\n  // we use it to emit changes back to the form\n  private propagateChange = (change: any) => {};\n\n  trackByFn(item: SelectOption) {\n    return item.value;\n  }\n\n  private loadOptions() {\n    this.remoteOptions$ = concat(\n      of([]), // default items\n      this.remoteOptionInput$.pipe(\n        distinctUntilChanged(),\n        tap(() => {\n          this.loading = true;\n        }),\n        switchMap((term) =>\n          this.dataSource.searchOptions(term).pipe(\n            catchError(() => of([])), // empty list on error\n            tap(() => (this.loading = false))\n          )\n        )\n      )\n    );\n  }\n}\n","<div>\n  <ng-select\n    [ngClass]=\"{ 'afe-custom': theme === 'light' }\"\n    [disabled]=\"disabled\"\n    [items]=\"remoteOptions$ | async\"\n    bindLabel=\"label\"\n    bindValue=\"value\"\n    [multiple]=\"false\"\n    [hideSelected]=\"true\"\n    [compareWith]=\"compareItems\"\n    [trackByFn]=\"trackByFn\"\n    [loading]=\"loading\"\n    typeToSearchText=\"{{ 'enterMoreCharacters' | translate }}\"\n    [typeahead]=\"remoteOptionInput$\"\n    [(ngModel)]=\"selectedRemoteOptions\"\n    [appendTo]=\"'form'\"\n    (ngModelChange)=\"selected($event)\"\n  >\n  </ng-select>\n</div>\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-remote-select.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-formentry/src/components/ngx-remote-select/ngx-remote-select.component.ts","../../../../../projects/ngx-formentry/src/components/ngx-remote-select/remote-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  forwardRef,\n  Output,\n  EventEmitter,\n  Renderer2\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { concat, Observable, of, Subject } from 'rxjs';\nimport {\n  catchError,\n  distinctUntilChanged,\n  switchMap,\n  tap\n} from 'rxjs/operators';\nimport { SelectOption } from '../../form-entry/question-models/interfaces/select-option';\n\nimport { DataSource } from '../../form-entry/question-models/interfaces/data-source';\nimport * as _ from 'lodash';\nimport { TranslateService } from '@ngx-translate/core';\n\n@Component({\n  selector: 'ofe-remote-select',\n  templateUrl: 'remote-select.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => RemoteSelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class RemoteSelectComponent implements OnInit, ControlValueAccessor {\n  // @Input() dataSource: DataSource;\n  remoteOptions$: Observable<SelectOption[]>;\n  remoteOptionsLoading = false;\n  remoteOptionInput$ = new Subject<string>();\n  selectedRemoteOptions: SelectOption;\n  items = [];\n  value = [];\n  loading = false;\n  searchText = '';\n  notFoundMsg = this.translate.instant('matchNotFound');\n  @Input() placeholder = this.translate.instant('search');\n  @Input() componentID: string;\n  @Input() disabled = false;\n  @Input() theme = 'dark';\n  @Input() invalid = 'false';\n  @Output() done: EventEmitter<any> = new EventEmitter<any>();\n\n  private _dataSource: DataSource;\n  @Input()\n  public get dataSource(): DataSource {\n    return this._dataSource;\n  }\n  public set dataSource(v: DataSource) {\n    this._dataSource = v;\n    if (this._dataSource && this._dataSource.dataFromSourceChanged) {\n      this.subscribeToDataSourceDataChanges();\n    }\n  }\n\n  constructor(\n    private renderer: Renderer2,\n    private translate: TranslateService\n  ) {}\n\n  ngOnInit() {\n    this.loadOptions();\n  }\n\n  subscribeToDataSourceDataChanges() {\n    this._dataSource.dataFromSourceChanged.subscribe((results) => {\n      if (results.length > 0) {\n        this.items = results;\n        this.notFoundMsg = '';\n      } else {\n        this.notFoundMsg = 'Match not found';\n        this.items = [];\n      }\n    });\n  }\n\n  // this is the initial value set to the component\n  public writeValue(value: any) {\n    if (value && value !== '') {\n      if (this.dataSource) {\n        this.loading = true;\n        this.dataSource.resolveSelectedValue(value).subscribe(\n          (result: any) => {\n            this.items = [result];\n            this.selectedRemoteOptions = result;\n            this.loading = false;\n          },\n          (error) => {\n            this.loading = false;\n          }\n        );\n      }\n    }\n  }\n  // registers 'fn' that will be fired when changes are made\n  // this is how we emit the changes back to the form\n  public registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  // not used, used for touch input\n  public registerOnTouched() {}\n  // change events from the textarea\n  onChange(event) {\n    this.propagateChange(event.id);\n    // .....\n    // update the form\n    // this.propagateChange(this.data);\n  }\n  selected(event) {\n    this.propagateChange(event);\n  }\n\n  compareItems = (item, selected) => {\n    if (item.value && selected.value) {\n      return item.value === selected.value;\n    }\n    return false;\n  };\n\n  // the method set in registerOnChange, it is just\n  // a placeholder for a method that takes one parameter,\n  // we use it to emit changes back to the form\n  private propagateChange = (change: any) => {};\n\n  trackByFn(item: SelectOption) {\n    return item.value;\n  }\n\n  private loadOptions() {\n    this.remoteOptions$ = concat(\n      of([]), // default items\n      this.remoteOptionInput$.pipe(\n        distinctUntilChanged(),\n        tap(() => {\n          this.loading = true;\n        }),\n        switchMap((term) =>\n          this.dataSource.searchOptions(term).pipe(\n            catchError(() => of([])), // empty list on error\n            tap(() => (this.loading = false))\n          )\n        )\n      )\n    );\n  }\n}\n","<ng-select\n  [ngClass]=\"{\n      'afe-custom': theme === 'light',\n      'invalid': invalid ? true : null,\n    }\"\n  [disabled]=\"disabled\"\n  [items]=\"remoteOptions$ | async\"\n  bindLabel=\"label\"\n  bindValue=\"value\"\n  [multiple]=\"false\"\n  [hideSelected]=\"true\"\n  [compareWith]=\"compareItems\"\n  [trackByFn]=\"trackByFn\"\n  [loading]=\"loading\"\n  typeToSearchText=\"{{ 'enterMoreCharacters' | translate }}\"\n  [typeahead]=\"remoteOptionInput$\"\n  [(ngModel)]=\"selectedRemoteOptions\"\n  [appendTo]=\"'form'\"\n  (ngModelChange)=\"selected($event)\"\n>\n</ng-select>\n"]}
@@ -50,6 +50,10 @@ export class NumberInputComponent {
50
50
  * The unique id for the number component.
51
51
  */
52
52
  this.id = `number-${NumberInputComponent.numberCount}`;
53
+ /**
54
+ * Sets the placeholder attribute on the `input` element.
55
+ */
56
+ this.placeholder = '';
53
57
  /**
54
58
  * Number input field render size
55
59
  */
@@ -85,11 +89,11 @@ export class NumberInputComponent {
85
89
  /**
86
90
  * Sets the decrement label text
87
91
  */
88
- this.decrementLabel = 'Decrease';
92
+ this.decrementLabel = 'Decrement';
89
93
  /**
90
94
  * Sets the increment label text
91
95
  */
92
- this.incrementLabel = 'Increase';
96
+ this.incrementLabel = 'Increment';
93
97
  this._value = 0;
94
98
  /**
95
99
  * Called when number input is blurred. Needed to properly implement `ControlValueAccessor`.
@@ -180,13 +184,13 @@ export class NumberInputComponent {
180
184
  return value instanceof TemplateRef;
181
185
  }
182
186
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NumberInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
183
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NumberInputComponent, selector: "ofe-number-input", inputs: { theme: "theme", disabled: "disabled", skeleton: "skeleton", invalid: "invalid", id: "id", size: "size", required: "required", value: "value", min: "min", max: "max", maxlength: "maxlength", minlength: "minlength", label: "label", helperText: "helperText", invalidText: "invalidText", step: "step", precision: "precision", warn: "warn", warnText: "warnText", decrementLabel: "decrementLabel", incrementLabel: "incrementLabel" }, outputs: { numberChange: "numberChange" }, host: { listeners: { "focusout": "focusOut()" } }, providers: [
187
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: NumberInputComponent, selector: "ofe-number-input", inputs: { theme: "theme", disabled: "disabled", skeleton: "skeleton", invalid: "invalid", id: "id", placeholder: "placeholder", size: "size", required: "required", value: "value", min: "min", max: "max", maxlength: "maxlength", minlength: "minlength", label: "label", helperText: "helperText", invalidText: "invalidText", step: "step", precision: "precision", warn: "warn", warnText: "warnText", decrementLabel: "decrementLabel", incrementLabel: "incrementLabel" }, outputs: { numberChange: "numberChange" }, host: { listeners: { "focusout": "focusOut()" } }, providers: [
184
188
  {
185
189
  provide: NG_VALUE_ACCESSOR,
186
190
  useExisting: forwardRef(() => NumberInputComponent),
187
191
  multi: true
188
192
  }
189
- ], ngImport: i0, template: "<div\n data-numberinput\n [attr.data-invalid]=\"invalid ? true : null\"\n class=\"cds--number\"\n [ngClass]=\"{\n 'cds--number--light': theme === 'light',\n 'cds--number--nolabel': !label,\n 'cds--number--helpertext': helperText,\n 'cds--skeleton': skeleton,\n 'cds--number--sm': size === 'sm',\n 'cds--number--xl': size === 'xl'\n }\"\n>\n <div\n class=\"cds--number__input-wrapper\"\n [ngClass]=\"{\n 'cds--number__input-wrapper--warning': warn\n }\"\n >\n <input\n type=\"number\"\n [id]=\"id\"\n ofeNumberScroll\n [value]=\"value\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [attr.step]=\"step\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n (input)=\"onNumberInputChange($event)\"\n />\n <div class=\"cds--number__controls\">\n <button\n type=\"button\"\n class=\"cds--number__control-btn down-icon\"\n (click)=\"onDecrement()\"\n title=\"Decrement number\"\n [attr.aria-label]=\"decrementLabel\"\n tabindex=\"-1\"\n >\n <svg\n focusable=\"false\"\n preserveAspectRatio=\"xMidYMid meet\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 32 32\"\n aria-hidden=\"true\"\n class=\"down-icon\"\n >\n <path d=\"M8 15H24V17H8z\"></path>\n </svg>\n </button>\n <div class=\"cds--number__rule-divider\"></div>\n <button\n type=\"button\"\n class=\"cds--number__control-btn up-icon\"\n (click)=\"onIncrement()\"\n title=\"Increment number\"\n [attr.aria-label]=\"incrementLabel\"\n tabindex=\"-1\"\n >\n <svg\n focusable=\"false\"\n preserveAspectRatio=\"xMidYMid meet\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 32 32\"\n aria-hidden=\"true\"\n class=\"up-icon\"\n >\n <path\n d=\"M17 15L17 8 15 8 15 15 8 15 8 17 15 17 15 24 17 24 17 17 24 17 24 15z\"\n ></path>\n </svg>\n </button>\n <div class=\"cds--number__rule-divider\"></div>\n </div>\n </div>\n <div *ngIf=\"helperText && !invalid && !warn\" class=\"cds--form__helper-text\">\n <ng-container *ngIf=\"!isTemplate(helperText)\">{{\n helperText\n }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(helperText)\"\n [ngTemplateOutlet]=\"helperText\"\n ></ng-template>\n </div>\n <div *ngIf=\"!warn && invalid\" class=\"cds--form-requirement\">\n <ng-container *ngIf=\"!isTemplate(invalidText)\">{{\n invalidText\n }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(invalidText)\"\n [ngTemplateOutlet]=\"invalidText\"\n ></ng-template>\n </div>\n <div *ngIf=\"!invalid && warn\" class=\"cds--form-requirement\">\n <ng-container *ngIf=\"!isTemplate(warnText)\">{{ warnText }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(warnText)\"\n [ngTemplateOutlet]=\"warnText\"\n ></ng-template>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NumberInputDirective, selector: "[ofeNumberScroll]" }] }); }
193
+ ], ngImport: i0, template: "<div\n data-numberinput\n [attr.data-invalid]=\"invalid ? true : null\"\n class=\"cds--number\"\n [ngClass]=\"{\n 'cds--number--light': theme === 'light',\n 'cds--number--nolabel': !label,\n 'cds--number--helpertext': helperText,\n 'cds--skeleton': skeleton,\n 'cds--number--sm': size === 'sm',\n 'cds--number--md': size === 'md',\n 'cds--number--lg': size === 'lg'\n }\"\n>\n <div\n class=\"cds--number__input-wrapper\"\n [ngClass]=\"{\n 'cds--number__input-wrapper--warning': warn\n }\"\n >\n <input\n ofeNumberScroll\n type=\"number\"\n [id]=\"id\"\n [value]=\"value\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [attr.step]=\"step\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [attr.data-invalid]=\"invalid ? invalid : null\"\n [placeholder]=\"placeholder\"\n (input)=\"onNumberInputChange($event)\"\n />\n <svg\n *ngIf=\"!skeleton && !warn && invalid\"\n cdsIcon=\"warning--filled\"\n size=\"16\"\n class=\"cds--number__invalid\"\n ></svg>\n <svg\n *ngIf=\"!skeleton && !invalid && warn\"\n cdsIcon=\"warning--alt--filled\"\n size=\"16\"\n class=\"cds--number__invalid cds--number__invalid--warning\"\n ></svg>\n <div class=\"cds--number__controls\">\n <button\n type=\"button\"\n class=\"cds--number__control-btn down-icon\"\n (click)=\"onDecrement()\"\n title=\"Decrement number\"\n [attr.aria-label]=\"decrementLabel\"\n tabindex=\"-1\"\n >\n <svg\n focusable=\"false\"\n preserveAspectRatio=\"xMidYMid meet\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 32 32\"\n aria-hidden=\"true\"\n class=\"down-icon\"\n >\n <path d=\"M8 15H24V17H8z\"></path>\n </svg>\n </button>\n <div class=\"cds--number__rule-divider\"></div>\n <button\n type=\"button\"\n class=\"cds--number__control-btn up-icon\"\n (click)=\"onIncrement()\"\n title=\"Increment number\"\n [attr.aria-label]=\"incrementLabel\"\n tabindex=\"-1\"\n >\n <svg\n focusable=\"false\"\n preserveAspectRatio=\"xMidYMid meet\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 32 32\"\n aria-hidden=\"true\"\n class=\"up-icon\"\n >\n <path\n d=\"M17 15L17 8 15 8 15 15 8 15 8 17 15 17 15 24 17 24 17 17 24 17 24 15z\"\n ></path>\n </svg>\n </button>\n <div class=\"cds--number__rule-divider\"></div>\n </div>\n </div>\n <div *ngIf=\"helperText && !invalid && !warn\" class=\"cds--form__helper-text\">\n <ng-container *ngIf=\"!isTemplate(helperText)\">{{\n helperText\n }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(helperText)\"\n [ngTemplateOutlet]=\"helperText\"\n ></ng-template>\n </div>\n <div *ngIf=\"!warn && invalid\" class=\"cds--form-requirement\">\n <ng-container *ngIf=\"!isTemplate(invalidText)\">{{\n invalidText\n }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(invalidText)\"\n [ngTemplateOutlet]=\"invalidText\"\n ></ng-template>\n </div>\n <div *ngIf=\"!invalid && warn\" class=\"cds--form-requirement\">\n <ng-container *ngIf=\"!isTemplate(warnText)\">{{ warnText }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(warnText)\"\n [ngTemplateOutlet]=\"warnText\"\n ></ng-template>\n </div>\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NumberInputDirective, selector: "[ofeNumberScroll]" }] }); }
190
194
  }
191
195
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NumberInputComponent, decorators: [{
192
196
  type: Component,
@@ -196,7 +200,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
196
200
  useExisting: forwardRef(() => NumberInputComponent),
197
201
  multi: true
198
202
  }
199
- ], template: "<div\n data-numberinput\n [attr.data-invalid]=\"invalid ? true : null\"\n class=\"cds--number\"\n [ngClass]=\"{\n 'cds--number--light': theme === 'light',\n 'cds--number--nolabel': !label,\n 'cds--number--helpertext': helperText,\n 'cds--skeleton': skeleton,\n 'cds--number--sm': size === 'sm',\n 'cds--number--xl': size === 'xl'\n }\"\n>\n <div\n class=\"cds--number__input-wrapper\"\n [ngClass]=\"{\n 'cds--number__input-wrapper--warning': warn\n }\"\n >\n <input\n type=\"number\"\n [id]=\"id\"\n ofeNumberScroll\n [value]=\"value\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [attr.step]=\"step\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n (input)=\"onNumberInputChange($event)\"\n />\n <div class=\"cds--number__controls\">\n <button\n type=\"button\"\n class=\"cds--number__control-btn down-icon\"\n (click)=\"onDecrement()\"\n title=\"Decrement number\"\n [attr.aria-label]=\"decrementLabel\"\n tabindex=\"-1\"\n >\n <svg\n focusable=\"false\"\n preserveAspectRatio=\"xMidYMid meet\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 32 32\"\n aria-hidden=\"true\"\n class=\"down-icon\"\n >\n <path d=\"M8 15H24V17H8z\"></path>\n </svg>\n </button>\n <div class=\"cds--number__rule-divider\"></div>\n <button\n type=\"button\"\n class=\"cds--number__control-btn up-icon\"\n (click)=\"onIncrement()\"\n title=\"Increment number\"\n [attr.aria-label]=\"incrementLabel\"\n tabindex=\"-1\"\n >\n <svg\n focusable=\"false\"\n preserveAspectRatio=\"xMidYMid meet\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 32 32\"\n aria-hidden=\"true\"\n class=\"up-icon\"\n >\n <path\n d=\"M17 15L17 8 15 8 15 15 8 15 8 17 15 17 15 24 17 24 17 17 24 17 24 15z\"\n ></path>\n </svg>\n </button>\n <div class=\"cds--number__rule-divider\"></div>\n </div>\n </div>\n <div *ngIf=\"helperText && !invalid && !warn\" class=\"cds--form__helper-text\">\n <ng-container *ngIf=\"!isTemplate(helperText)\">{{\n helperText\n }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(helperText)\"\n [ngTemplateOutlet]=\"helperText\"\n ></ng-template>\n </div>\n <div *ngIf=\"!warn && invalid\" class=\"cds--form-requirement\">\n <ng-container *ngIf=\"!isTemplate(invalidText)\">{{\n invalidText\n }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(invalidText)\"\n [ngTemplateOutlet]=\"invalidText\"\n ></ng-template>\n </div>\n <div *ngIf=\"!invalid && warn\" class=\"cds--form-requirement\">\n <ng-container *ngIf=\"!isTemplate(warnText)\">{{ warnText }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(warnText)\"\n [ngTemplateOutlet]=\"warnText\"\n ></ng-template>\n </div>\n</div>\n" }]
203
+ ], template: "<div\n data-numberinput\n [attr.data-invalid]=\"invalid ? true : null\"\n class=\"cds--number\"\n [ngClass]=\"{\n 'cds--number--light': theme === 'light',\n 'cds--number--nolabel': !label,\n 'cds--number--helpertext': helperText,\n 'cds--skeleton': skeleton,\n 'cds--number--sm': size === 'sm',\n 'cds--number--md': size === 'md',\n 'cds--number--lg': size === 'lg'\n }\"\n>\n <div\n class=\"cds--number__input-wrapper\"\n [ngClass]=\"{\n 'cds--number__input-wrapper--warning': warn\n }\"\n >\n <input\n ofeNumberScroll\n type=\"number\"\n [id]=\"id\"\n [value]=\"value\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.maxlength]=\"maxlength\"\n [attr.minlength]=\"minlength\"\n [attr.step]=\"step\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [attr.data-invalid]=\"invalid ? invalid : null\"\n [placeholder]=\"placeholder\"\n (input)=\"onNumberInputChange($event)\"\n />\n <svg\n *ngIf=\"!skeleton && !warn && invalid\"\n cdsIcon=\"warning--filled\"\n size=\"16\"\n class=\"cds--number__invalid\"\n ></svg>\n <svg\n *ngIf=\"!skeleton && !invalid && warn\"\n cdsIcon=\"warning--alt--filled\"\n size=\"16\"\n class=\"cds--number__invalid cds--number__invalid--warning\"\n ></svg>\n <div class=\"cds--number__controls\">\n <button\n type=\"button\"\n class=\"cds--number__control-btn down-icon\"\n (click)=\"onDecrement()\"\n title=\"Decrement number\"\n [attr.aria-label]=\"decrementLabel\"\n tabindex=\"-1\"\n >\n <svg\n focusable=\"false\"\n preserveAspectRatio=\"xMidYMid meet\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 32 32\"\n aria-hidden=\"true\"\n class=\"down-icon\"\n >\n <path d=\"M8 15H24V17H8z\"></path>\n </svg>\n </button>\n <div class=\"cds--number__rule-divider\"></div>\n <button\n type=\"button\"\n class=\"cds--number__control-btn up-icon\"\n (click)=\"onIncrement()\"\n title=\"Increment number\"\n [attr.aria-label]=\"incrementLabel\"\n tabindex=\"-1\"\n >\n <svg\n focusable=\"false\"\n preserveAspectRatio=\"xMidYMid meet\"\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"currentColor\"\n width=\"16\"\n height=\"16\"\n viewBox=\"0 0 32 32\"\n aria-hidden=\"true\"\n class=\"up-icon\"\n >\n <path\n d=\"M17 15L17 8 15 8 15 15 8 15 8 17 15 17 15 24 17 24 17 17 24 17 24 15z\"\n ></path>\n </svg>\n </button>\n <div class=\"cds--number__rule-divider\"></div>\n </div>\n </div>\n <div *ngIf=\"helperText && !invalid && !warn\" class=\"cds--form__helper-text\">\n <ng-container *ngIf=\"!isTemplate(helperText)\">{{\n helperText\n }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(helperText)\"\n [ngTemplateOutlet]=\"helperText\"\n ></ng-template>\n </div>\n <div *ngIf=\"!warn && invalid\" class=\"cds--form-requirement\">\n <ng-container *ngIf=\"!isTemplate(invalidText)\">{{\n invalidText\n }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(invalidText)\"\n [ngTemplateOutlet]=\"invalidText\"\n ></ng-template>\n </div>\n <div *ngIf=\"!invalid && warn\" class=\"cds--form-requirement\">\n <ng-container *ngIf=\"!isTemplate(warnText)\">{{ warnText }}</ng-container>\n <ng-template\n *ngIf=\"isTemplate(warnText)\"\n [ngTemplateOutlet]=\"warnText\"\n ></ng-template>\n </div>\n</div>\n" }]
200
204
  }], ctorParameters: function () { return []; }, propDecorators: { theme: [{
201
205
  type: Input
202
206
  }], disabled: [{
@@ -207,6 +211,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
207
211
  type: Input
208
212
  }], id: [{
209
213
  type: Input
214
+ }], placeholder: [{
215
+ type: Input
210
216
  }], size: [{
211
217
  type: Input
212
218
  }], required: [{
@@ -245,4 +251,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
245
251
  type: HostListener,
246
252
  args: ['focusout']
247
253
  }] } });
248
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-formentry/src/components/number-input/number-input.component.ts","../../../../../projects/ngx-formentry/src/components/number-input/number-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  Input,\n  Output,\n  TemplateRef\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\n\n/**\n * Used to emit changes performed on number input components.\n */\nexport class NumberChangeEvent {\n  /**\n   * Contains the `NumberInputComponent` that has been changed.\n   */\n  source: NumberInputComponent;\n  /**\n   * The value of the `NumberInputComponent` field encompassed in the `NumberChange` class.\n   */\n  value: number;\n}\n\n@Component({\n  selector: 'ofe-number-input',\n  templateUrl: 'number-input.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NumberInputComponent),\n      multi: true\n    }\n  ]\n})\nexport class NumberInputComponent implements ControlValueAccessor {\n  /**\n   * Variable used for creating unique ids for number input components.\n   */\n  static numberCount = 0;\n\n  /**\n   * `light` or `dark` number input theme.\n   */\n  @Input() theme: 'light' | 'dark' = 'dark';\n  /**\n   * Set to `true` for a disabled number input.\n   */\n  @Input() disabled = false;\n  /**\n   * Set to `true` for a loading number component.\n   */\n  @Input() skeleton = false;\n  /**\n   * Set to `true` for an invalid number component.\n   */\n  @Input() invalid = false;\n  /**\n   * The unique id for the number component.\n   */\n  @Input() id = `number-${NumberInputComponent.numberCount}`;\n  /**\n   * Number input field render size\n   */\n  @Input() size: 'sm' | 'md' | 'xl' = 'md';\n  /**\n   * Reflects the required attribute of the `input` element.\n   */\n  @Input() required: boolean;\n  /**\n   * Sets the value attribute on the `input` element.\n   */\n  @Input() set value(v: any) {\n    if (v === '' || v === null) {\n      this._value = null;\n      return;\n    }\n    this._value = Number(v);\n  }\n\n  get value() {\n    return this._value;\n  }\n  /**\n   * Sets the min attribute on the `input` element.\n   */\n  @Input() min = null;\n  /**\n   * Sets the max attribute on the `input` element.\n   */\n  @Input() max = null;\n  /**\n   * Sets the max length attribute on the `input` element.\n   */\n  @Input() maxlength = null;\n  /**\n   * Sets the min length attribute on the `input` element.\n   */\n  @Input() minlength = null;\n  /**\n   * Sets the text inside the `label` tag.\n   */\n  @Input() label: string | TemplateRef<any>;\n  /**\n   * Sets the optional helper text.\n   */\n  @Input() helperText: string | TemplateRef<any>;\n  /**\n   * Sets the invalid text.\n   */\n  @Input() invalidText: string | TemplateRef<any>;\n  /**\n   * Sets the amount the number controls increment and decrement by.\n   */\n  @Input() step = 1;\n  /**\n   * If `step` is a decimal, we may want precision to be set to go around floating point precision.\n   */\n  @Input() precision: number;\n  /**\n   * Set to `true` to show a warning (contents set by warningText)\n   */\n  @Input() warn = false;\n  /**\n   * Sets the warning text\n   */\n  @Input() warnText: string | TemplateRef<any>;\n  /**\n   * Emits event notifying other classes when a change in state occurs in the input.\n   */\n  @Output() numberChange = new EventEmitter<NumberChangeEvent>();\n  /**\n   * Sets the decrement label text\n   */\n  @Input() decrementLabel = 'Decrease';\n  /**\n   * Sets the increment label text\n   */\n  @Input() incrementLabel = 'Increase';\n\n  protected _value = 0;\n\n  /**\n   * Creates an instance of `Number`.\n   */\n  constructor() {\n    NumberInputComponent.numberCount++;\n  }\n\n  /**\n   * This is the initial value set to the component\n   * @param value The input value.\n   */\n  public writeValue(value: any) {\n    this.value = value;\n  }\n\n  /**\n   * Sets a method in order to propagate changes back to the form.\n   */\n  public registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  /**\n   * Registers a callback to be triggered when the control has been touched.\n   * @param fn Callback to be triggered when the number input is touched.\n   */\n  public registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  @HostListener('focusout')\n  focusOut() {\n    this.onTouched();\n  }\n\n  /**\n   * Sets the disabled state through the model\n   */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /**\n   * Called when number input is blurred. Needed to properly implement `ControlValueAccessor`.\n   */\n  onTouched: () => any = () => {};\n\n  /**\n   * Method set in `registerOnChange` to propagate changes back to the form.\n   */\n  propagateChange = (_: any) => {};\n\n  /**\n   * Adds `step` to the current `value`.\n   */\n  onIncrement(): void {\n    const val = this._value || 0;\n\n    if (this.max === null || val + this.step <= this.max) {\n      this.value = parseFloat((val + this.step).toPrecision(this.precision));\n    }\n\n    if (this.max && this.max > 0 && this.value > this.max) {\n      this.value = this.max;\n    }\n    if (this.max === undefined || this.max === '') {\n      this.value = val + this.step;\n    }\n\n    this.emitChangeEvent();\n  }\n\n  /**\n   * Subtracts `step` to the current `value`.\n   */\n  onDecrement(): void {\n    const val = this._value || 0;\n\n    if (this.min === null || val - this.step >= this.min) {\n      this.value = parseFloat((val - this.step).toPrecision(this.precision));\n    }\n\n    if (this.min && this.min > 0 && this.value < this.min) {\n      this.value = this.min;\n    }\n\n    if (this.min === undefined || this.min === '') {\n      this.value = val - this.step;\n    }\n\n    this.emitChangeEvent();\n  }\n\n  /**\n   * Creates a class of `NumberChange` to emit the change in the `Number`.\n   */\n  emitChangeEvent(): void {\n    const event = new NumberChangeEvent();\n    event.source = this;\n    event.value = this.value;\n    this.numberChange.emit(event);\n    this.propagateChange(this.value);\n  }\n\n  onNumberInputChange(event) {\n    this.value = event.target.value;\n    this.emitChangeEvent();\n  }\n\n  public isTemplate(value) {\n    return value instanceof TemplateRef;\n  }\n}\n","<div\n  data-numberinput\n  [attr.data-invalid]=\"invalid ? true : null\"\n  class=\"cds--number\"\n  [ngClass]=\"{\n    'cds--number--light': theme === 'light',\n    'cds--number--nolabel': !label,\n    'cds--number--helpertext': helperText,\n    'cds--skeleton': skeleton,\n    'cds--number--sm': size === 'sm',\n    'cds--number--xl': size === 'xl'\n  }\"\n>\n  <div\n    class=\"cds--number__input-wrapper\"\n    [ngClass]=\"{\n      'cds--number__input-wrapper--warning': warn\n    }\"\n  >\n    <input\n      type=\"number\"\n      [id]=\"id\"\n      ofeNumberScroll\n      [value]=\"value\"\n      [attr.min]=\"min\"\n      [attr.max]=\"max\"\n      [attr.maxlength]=\"maxlength\"\n      [attr.minlength]=\"minlength\"\n      [attr.step]=\"step\"\n      [disabled]=\"disabled\"\n      [required]=\"required\"\n      (input)=\"onNumberInputChange($event)\"\n    />\n    <div class=\"cds--number__controls\">\n      <button\n        type=\"button\"\n        class=\"cds--number__control-btn down-icon\"\n        (click)=\"onDecrement()\"\n        title=\"Decrement number\"\n        [attr.aria-label]=\"decrementLabel\"\n        tabindex=\"-1\"\n      >\n        <svg\n          focusable=\"false\"\n          preserveAspectRatio=\"xMidYMid meet\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          fill=\"currentColor\"\n          width=\"16\"\n          height=\"16\"\n          viewBox=\"0 0 32 32\"\n          aria-hidden=\"true\"\n          class=\"down-icon\"\n        >\n          <path d=\"M8 15H24V17H8z\"></path>\n        </svg>\n      </button>\n      <div class=\"cds--number__rule-divider\"></div>\n      <button\n        type=\"button\"\n        class=\"cds--number__control-btn up-icon\"\n        (click)=\"onIncrement()\"\n        title=\"Increment number\"\n        [attr.aria-label]=\"incrementLabel\"\n        tabindex=\"-1\"\n      >\n        <svg\n          focusable=\"false\"\n          preserveAspectRatio=\"xMidYMid meet\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          fill=\"currentColor\"\n          width=\"16\"\n          height=\"16\"\n          viewBox=\"0 0 32 32\"\n          aria-hidden=\"true\"\n          class=\"up-icon\"\n        >\n          <path\n            d=\"M17 15L17 8 15 8 15 15 8 15 8 17 15 17 15 24 17 24 17 17 24 17 24 15z\"\n          ></path>\n        </svg>\n      </button>\n      <div class=\"cds--number__rule-divider\"></div>\n    </div>\n  </div>\n  <div *ngIf=\"helperText && !invalid && !warn\" class=\"cds--form__helper-text\">\n    <ng-container *ngIf=\"!isTemplate(helperText)\">{{\n      helperText\n    }}</ng-container>\n    <ng-template\n      *ngIf=\"isTemplate(helperText)\"\n      [ngTemplateOutlet]=\"helperText\"\n    ></ng-template>\n  </div>\n  <div *ngIf=\"!warn && invalid\" class=\"cds--form-requirement\">\n    <ng-container *ngIf=\"!isTemplate(invalidText)\">{{\n      invalidText\n    }}</ng-container>\n    <ng-template\n      *ngIf=\"isTemplate(invalidText)\"\n      [ngTemplateOutlet]=\"invalidText\"\n    ></ng-template>\n  </div>\n  <div *ngIf=\"!invalid && warn\" class=\"cds--form-requirement\">\n    <ng-container *ngIf=\"!isTemplate(warnText)\">{{ warnText }}</ng-container>\n    <ng-template\n      *ngIf=\"isTemplate(warnText)\"\n      [ngTemplateOutlet]=\"warnText\"\n    ></ng-template>\n  </div>\n</div>\n"]}
254
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-input.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-formentry/src/components/number-input/number-input.component.ts","../../../../../projects/ngx-formentry/src/components/number-input/number-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  forwardRef,\n  HostListener,\n  Input,\n  Output,\n  TemplateRef\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR, ControlValueAccessor } from '@angular/forms';\n\n/**\n * Used to emit changes performed on number input components.\n */\nexport class NumberChangeEvent {\n  /**\n   * Contains the `NumberInputComponent` that has been changed.\n   */\n  source: NumberInputComponent;\n  /**\n   * The value of the `NumberInputComponent` field encompassed in the `NumberChange` class.\n   */\n  value: number;\n}\n\n@Component({\n  selector: 'ofe-number-input',\n  templateUrl: 'number-input.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => NumberInputComponent),\n      multi: true\n    }\n  ]\n})\nexport class NumberInputComponent implements ControlValueAccessor {\n  /**\n   * Variable used for creating unique ids for number input components.\n   */\n  static numberCount = 0;\n\n  /**\n   * `light` or `dark` number input theme.\n   */\n  @Input() theme: 'light' | 'dark' = 'dark';\n  /**\n   * Set to `true` for a disabled number input.\n   */\n  @Input() disabled = false;\n  /**\n   * Set to `true` for a loading number component.\n   */\n  @Input() skeleton = false;\n  /**\n   * Set to `true` for an invalid number component.\n   */\n  @Input() invalid = false;\n  /**\n   * The unique id for the number component.\n   */\n  @Input() id = `number-${NumberInputComponent.numberCount}`;\n  /**\n   * Sets the placeholder attribute on the `input` element.\n   */\n  @Input() placeholder = '';\n  /**\n   * Number input field render size\n   */\n  @Input() size: 'sm' | 'md' | 'lg' = 'md';\n  /**\n   * Reflects the required attribute of the `input` element.\n   */\n  @Input() required: boolean;\n  /**\n   * Sets the value attribute on the `input` element.\n   */\n  @Input() set value(v: any) {\n    if (v === '' || v === null) {\n      this._value = null;\n      return;\n    }\n    this._value = Number(v);\n  }\n\n  get value() {\n    return this._value;\n  }\n  /**\n   * Sets the min attribute on the `input` element.\n   */\n  @Input() min = null;\n  /**\n   * Sets the max attribute on the `input` element.\n   */\n  @Input() max = null;\n  /**\n   * Sets the max length attribute on the `input` element.\n   */\n  @Input() maxlength = null;\n  /**\n   * Sets the min length attribute on the `input` element.\n   */\n  @Input() minlength = null;\n  /**\n   * Sets the text inside the `label` tag.\n   */\n  @Input() label: string | TemplateRef<any>;\n  /**\n   * Sets the optional helper text.\n   */\n  @Input() helperText: string | TemplateRef<any>;\n  /**\n   * Sets the invalid text.\n   */\n  @Input() invalidText: string | TemplateRef<any>;\n  /**\n   * Sets the amount the number controls increment and decrement by.\n   */\n  @Input() step = 1;\n  /**\n   * If `step` is a decimal, we may want precision to be set to go around floating point precision.\n   */\n  @Input() precision: number;\n  /**\n   * Set to `true` to show a warning (contents set by warningText)\n   */\n  @Input() warn = false;\n  /**\n   * Sets the warning text\n   */\n  @Input() warnText: string | TemplateRef<any>;\n  /**\n   * Emits event notifying other classes when a change in state occurs in the input.\n   */\n  @Output() numberChange = new EventEmitter<NumberChangeEvent>();\n  /**\n   * Sets the decrement label text\n   */\n  @Input() decrementLabel = 'Decrement';\n  /**\n   * Sets the increment label text\n   */\n  @Input() incrementLabel = 'Increment';\n\n  protected _value = 0;\n\n  /**\n   * Creates an instance of `Number`.\n   */\n  constructor() {\n    NumberInputComponent.numberCount++;\n  }\n\n  /**\n   * This is the initial value set to the component\n   * @param value The input value.\n   */\n  public writeValue(value: any) {\n    this.value = value;\n  }\n\n  /**\n   * Sets a method in order to propagate changes back to the form.\n   */\n  public registerOnChange(fn: any) {\n    this.propagateChange = fn;\n  }\n\n  /**\n   * Registers a callback to be triggered when the control has been touched.\n   * @param fn Callback to be triggered when the number input is touched.\n   */\n  public registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  @HostListener('focusout')\n  focusOut() {\n    this.onTouched();\n  }\n\n  /**\n   * Sets the disabled state through the model\n   */\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n  }\n\n  /**\n   * Called when number input is blurred. Needed to properly implement `ControlValueAccessor`.\n   */\n  onTouched: () => any = () => {};\n\n  /**\n   * Method set in `registerOnChange` to propagate changes back to the form.\n   */\n  propagateChange = (_: any) => {};\n\n  /**\n   * Adds `step` to the current `value`.\n   */\n  onIncrement(): void {\n    const val = this._value || 0;\n\n    if (this.max === null || val + this.step <= this.max) {\n      this.value = parseFloat((val + this.step).toPrecision(this.precision));\n    }\n\n    if (this.max && this.max > 0 && this.value > this.max) {\n      this.value = this.max;\n    }\n    if (this.max === undefined || this.max === '') {\n      this.value = val + this.step;\n    }\n\n    this.emitChangeEvent();\n  }\n\n  /**\n   * Subtracts `step` to the current `value`.\n   */\n  onDecrement(): void {\n    const val = this._value || 0;\n\n    if (this.min === null || val - this.step >= this.min) {\n      this.value = parseFloat((val - this.step).toPrecision(this.precision));\n    }\n\n    if (this.min && this.min > 0 && this.value < this.min) {\n      this.value = this.min;\n    }\n\n    if (this.min === undefined || this.min === '') {\n      this.value = val - this.step;\n    }\n\n    this.emitChangeEvent();\n  }\n\n  /**\n   * Creates a class of `NumberChange` to emit the change in the `Number`.\n   */\n  emitChangeEvent(): void {\n    const event = new NumberChangeEvent();\n    event.source = this;\n    event.value = this.value;\n    this.numberChange.emit(event);\n    this.propagateChange(this.value);\n  }\n\n  onNumberInputChange(event) {\n    this.value = event.target.value;\n    this.emitChangeEvent();\n  }\n\n  public isTemplate(value) {\n    return value instanceof TemplateRef;\n  }\n}\n","<div\n  data-numberinput\n  [attr.data-invalid]=\"invalid ? true : null\"\n  class=\"cds--number\"\n  [ngClass]=\"{\n    'cds--number--light': theme === 'light',\n    'cds--number--nolabel': !label,\n    'cds--number--helpertext': helperText,\n    'cds--skeleton': skeleton,\n    'cds--number--sm': size === 'sm',\n    'cds--number--md': size === 'md',\n    'cds--number--lg': size === 'lg'\n  }\"\n>\n  <div\n    class=\"cds--number__input-wrapper\"\n    [ngClass]=\"{\n      'cds--number__input-wrapper--warning': warn\n    }\"\n  >\n    <input\n      ofeNumberScroll\n      type=\"number\"\n      [id]=\"id\"\n      [value]=\"value\"\n      [attr.min]=\"min\"\n      [attr.max]=\"max\"\n      [attr.maxlength]=\"maxlength\"\n      [attr.minlength]=\"minlength\"\n      [attr.step]=\"step\"\n      [disabled]=\"disabled\"\n      [required]=\"required\"\n      [attr.data-invalid]=\"invalid ? invalid : null\"\n      [placeholder]=\"placeholder\"\n      (input)=\"onNumberInputChange($event)\"\n    />\n    <svg\n      *ngIf=\"!skeleton && !warn && invalid\"\n      cdsIcon=\"warning--filled\"\n      size=\"16\"\n      class=\"cds--number__invalid\"\n    ></svg>\n    <svg\n      *ngIf=\"!skeleton && !invalid && warn\"\n      cdsIcon=\"warning--alt--filled\"\n      size=\"16\"\n      class=\"cds--number__invalid cds--number__invalid--warning\"\n    ></svg>\n    <div class=\"cds--number__controls\">\n      <button\n        type=\"button\"\n        class=\"cds--number__control-btn down-icon\"\n        (click)=\"onDecrement()\"\n        title=\"Decrement number\"\n        [attr.aria-label]=\"decrementLabel\"\n        tabindex=\"-1\"\n      >\n        <svg\n          focusable=\"false\"\n          preserveAspectRatio=\"xMidYMid meet\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          fill=\"currentColor\"\n          width=\"16\"\n          height=\"16\"\n          viewBox=\"0 0 32 32\"\n          aria-hidden=\"true\"\n          class=\"down-icon\"\n        >\n          <path d=\"M8 15H24V17H8z\"></path>\n        </svg>\n      </button>\n      <div class=\"cds--number__rule-divider\"></div>\n      <button\n        type=\"button\"\n        class=\"cds--number__control-btn up-icon\"\n        (click)=\"onIncrement()\"\n        title=\"Increment number\"\n        [attr.aria-label]=\"incrementLabel\"\n        tabindex=\"-1\"\n      >\n        <svg\n          focusable=\"false\"\n          preserveAspectRatio=\"xMidYMid meet\"\n          xmlns=\"http://www.w3.org/2000/svg\"\n          fill=\"currentColor\"\n          width=\"16\"\n          height=\"16\"\n          viewBox=\"0 0 32 32\"\n          aria-hidden=\"true\"\n          class=\"up-icon\"\n        >\n          <path\n            d=\"M17 15L17 8 15 8 15 15 8 15 8 17 15 17 15 24 17 24 17 17 24 17 24 15z\"\n          ></path>\n        </svg>\n      </button>\n      <div class=\"cds--number__rule-divider\"></div>\n    </div>\n  </div>\n  <div *ngIf=\"helperText && !invalid && !warn\" class=\"cds--form__helper-text\">\n    <ng-container *ngIf=\"!isTemplate(helperText)\">{{\n      helperText\n    }}</ng-container>\n    <ng-template\n      *ngIf=\"isTemplate(helperText)\"\n      [ngTemplateOutlet]=\"helperText\"\n    ></ng-template>\n  </div>\n  <div *ngIf=\"!warn && invalid\" class=\"cds--form-requirement\">\n    <ng-container *ngIf=\"!isTemplate(invalidText)\">{{\n      invalidText\n    }}</ng-container>\n    <ng-template\n      *ngIf=\"isTemplate(invalidText)\"\n      [ngTemplateOutlet]=\"invalidText\"\n    ></ng-template>\n  </div>\n  <div *ngIf=\"!invalid && warn\" class=\"cds--form-requirement\">\n    <ng-container *ngIf=\"!isTemplate(warnText)\">{{ warnText }}</ng-container>\n    <ng-template\n      *ngIf=\"isTemplate(warnText)\"\n      [ngTemplateOutlet]=\"warnText\"\n    ></ng-template>\n  </div>\n</div>\n"]}