@openmrs/ngx-formentry 17.0.1-pre.472 → 17.0.1-pre.480

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.
@@ -1,11 +1,11 @@
1
- import { OnInit, EventEmitter, Renderer2 } from '@angular/core';
1
+ import { OnInit, EventEmitter, Renderer2, OnDestroy } from '@angular/core';
2
2
  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
6
  import { TranslateService } from '@ngx-translate/core';
7
7
  import * as i0 from "@angular/core";
8
- export declare class RemoteSelectComponent implements OnInit, ControlValueAccessor {
8
+ export declare class RemoteSelectComponent implements OnInit, ControlValueAccessor, OnDestroy {
9
9
  private renderer;
10
10
  private translate;
11
11
  remoteOptions$: Observable<SelectOption[]>;
@@ -38,6 +38,7 @@ export declare class RemoteSelectComponent implements OnInit, ControlValueAccess
38
38
  private propagateChange;
39
39
  trackByFn(item: SelectOption): any;
40
40
  private loadOptions;
41
+ ngOnDestroy(): void;
41
42
  static ɵfac: i0.ɵɵFactoryDeclaration<RemoteSelectComponent, never>;
42
43
  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>;
43
44
  }
@@ -1,7 +1,7 @@
1
1
  import { Component, Input, forwardRef, Output, EventEmitter, Renderer2 } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
3
  import { concat, of, Subject } from 'rxjs';
4
- import { catchError, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';
4
+ import { catchError, distinctUntilChanged, finalize, switchMap, tap } from 'rxjs/operators';
5
5
  import { TranslateService } from '@ngx-translate/core';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@ngx-translate/core";
@@ -95,11 +95,25 @@ export class RemoteSelectComponent {
95
95
  return item.value;
96
96
  }
97
97
  loadOptions() {
98
- this.remoteOptions$ = concat(of([]), // default items
98
+ this.remoteOptions$ = concat(this.dataSource
99
+ .searchOptions('', this.dataSource?.dataSourceOptions ?? {})
100
+ ?.pipe(catchError((error) => {
101
+ console.error('Error loading initial options:', error);
102
+ return of([]);
103
+ })) ?? of([]), // default items
99
104
  this.remoteOptionInput$.pipe(distinctUntilChanged(), tap(() => {
100
105
  this.loading = true;
101
- }), switchMap((term) => this.dataSource.searchOptions(term).pipe(catchError(() => of([])), // empty list on error
102
- tap(() => (this.loading = false))))));
106
+ }), switchMap((term) => this.dataSource
107
+ .searchOptions(term, this.dataSource?.dataSourceOptions ?? {})
108
+ .pipe(catchError((error) => {
109
+ console.error('Error loading options:', error);
110
+ return of([]);
111
+ }), finalize(() => {
112
+ this.loading = false;
113
+ })))));
114
+ }
115
+ ngOnDestroy() {
116
+ this.remoteOptionInput$.complete();
103
117
  }
104
118
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RemoteSelectComponent, deps: [{ token: i0.Renderer2 }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); }
105
119
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: RemoteSelectComponent, selector: "ofe-remote-select", inputs: { placeholder: "placeholder", componentID: "componentID", disabled: "disabled", theme: "theme", invalid: "invalid", dataSource: "dataSource" }, outputs: { done: "done" }, providers: [
@@ -134,4 +148,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
134
148
  }], dataSource: [{
135
149
  type: Input
136
150
  }] } });
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 ?? false\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  (ngModelChange)=\"selectedRemoteOptions = $event; selected($event)\"\n  [appendTo]=\"'form'\"\n>\n</ng-select>\n"]}
151
+ //# 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, OnDestroy\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  finalize,\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, OnDestroy {\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      this.dataSource\n        .searchOptions('', this.dataSource?.dataSourceOptions ?? {})\n        ?.pipe(\n          catchError((error) => {\n            console.error('Error loading initial options:', error);\n            return of([]);\n          })\n        ) ?? of([]), // default items\n      this.remoteOptionInput$.pipe(\n        distinctUntilChanged(),\n        tap(() => {\n          this.loading = true;\n        }),\n        switchMap((term) =>\n          this.dataSource\n            .searchOptions(term, this.dataSource?.dataSourceOptions ?? {})\n            .pipe(\n              catchError((error) => {\n                console.error('Error loading options:', error);\n                return of([]);\n              }),\n              finalize(() => {\n                this.loading = false;\n              })\n            )\n        )\n      )\n    );\n  }\n\n  ngOnDestroy() {\n    this.remoteOptionInput$.complete();\n  }\n}\n","<ng-select\n  [ngClass]=\"{\n    'afe-custom': theme === 'light',\n    'invalid': invalid ?? false\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  (ngModelChange)=\"selectedRemoteOptions = $event; selected($event)\"\n  [appendTo]=\"'form'\"\n>\n</ng-select>\n"]}