@dereekb/dbx-form 9.18.4 → 9.18.6

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.
@@ -24,6 +24,7 @@ export class AbstractDbxSearchableValueFieldDirective extends FieldType {
24
24
  this.inputCtrl = new FormControl('');
25
25
  this._formControlObs = new BehaviorSubject(undefined);
26
26
  this.formControl$ = this._formControlObs.pipe(filterMaybe());
27
+ this._clearDisplayHashMapSub = new SubscriptionObject();
27
28
  this._displayHashMap = new BehaviorSubject(new Map());
28
29
  this.inputValue$ = this.inputCtrl.valueChanges.pipe(startWith(this.inputCtrl.value), map((x) => x || ''));
29
30
  this.inputValueString$ = this.inputValue$.pipe(debounceTime(200), distinctUntilChanged());
@@ -86,6 +87,12 @@ export class AbstractDbxSearchableValueFieldDirective extends FieldType {
86
87
  get showClearValue() {
87
88
  return this.searchableField.showClearValue ?? true;
88
89
  }
90
+ get searchLabel() {
91
+ return this.searchableField.searchLabel ?? 'Search';
92
+ }
93
+ get refreshDisplayValues$() {
94
+ return this.searchableField.refreshDisplayValues$;
95
+ }
89
96
  loadDisplayValuesForValues(values) {
90
97
  return this.loadDisplayValuesForFieldValues(values.map((value) => ({ value })));
91
98
  }
@@ -136,6 +143,9 @@ export class AbstractDbxSearchableValueFieldDirective extends FieldType {
136
143
  }
137
144
  ngOnInit() {
138
145
  this._formControlObs.next(this.formControl);
146
+ if (this.refreshDisplayValues$ != null) {
147
+ this._clearDisplayHashMapSub.subscription = this.refreshDisplayValues$.subscribe(() => this._displayHashMap.next(new Map()));
148
+ }
139
149
  if (this.searchableField.textInputValidator) {
140
150
  this.inputCtrl.setValidators(this.searchableField.textInputValidator);
141
151
  }
@@ -157,6 +167,7 @@ export class AbstractDbxSearchableValueFieldDirective extends FieldType {
157
167
  super.ngOnDestroy();
158
168
  this._displayHashMap.complete();
159
169
  this._formControlObs.complete();
170
+ this._clearDisplayHashMapSub.destroy();
160
171
  this.searchContext.destroy();
161
172
  }
162
173
  /**
@@ -247,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
247
258
  type: ViewChild,
248
259
  args: ['textInput']
249
260
  }] } });
250
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchable.field.directive.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/selection/searchable/searchable.field.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArrayOrValue, Maybe, convertMaybeToArray, findUnique, lastValue, PrimativeKey } from '@dereekb/util';\nimport { DbxInjectionComponentConfig, mergeDbxInjectionComponentConfigs } from '@dereekb/dbx-core';\nimport { filterMaybe, SubscriptionObject, LoadingState, LoadingStateContextInstance, successResult, startWithBeginLoading } from '@dereekb/rxjs';\nimport { ChangeDetectorRef, Directive, ElementRef, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { AbstractControl, FormControl, ValidatorFn } from '@angular/forms';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { debounceTime, distinctUntilChanged, first, map, mergeMap, shareReplay, startWith, switchMap, BehaviorSubject, of, Observable } from 'rxjs';\nimport { SearchableValueFieldHashFn, SearchableValueFieldStringSearchFn, SearchableValueFieldDisplayFn, SearchableValueFieldDisplayValue, SearchableValueFieldValue, SearchableValueFieldAnchorFn, ConfiguredSearchableValueFieldDisplayValue } from './searchable';\nimport { DbxDefaultSearchableFieldDisplayComponent } from './searchable.field.autocomplete.item.component';\nimport { camelCase } from 'change-case';\n\nexport interface StringValueFieldsFieldProps extends FormlyFieldProps {\n  /**\n   * Custom input validators.\n   */\n  textInputValidator?: ValidatorFn | ValidatorFn[];\n}\n\nexport interface SearchableValueFieldsFieldProps<T, M = unknown, H extends PrimativeKey = PrimativeKey> extends FormlyFieldProps, StringValueFieldsFieldProps {\n  /**\n   * Whether or not to allow string values to be used directly, or if values can only be chosen from searching.\n   */\n  allowStringValues?: boolean;\n  /**\n   * Optional conversion function. If provided, allowStringValues is considered true.\n   */\n  convertStringValue?: (text: string) => T;\n  /**\n   * Used for hashing display values and omitting repeat values.\n   *\n   * If hashForValue is not provided, the value's value will be used as is.\n   */\n  hashForValue?: SearchableValueFieldHashFn<T, H>;\n  /**\n   * Performs a search.\n   */\n  search: SearchableValueFieldStringSearchFn<T, M>;\n  /**\n   * Whether or not to allow searches on empty text. Is false by default.\n   */\n  searchOnEmptyText?: boolean;\n  /**\n   * Default injected config to use for display values.\n   */\n  display?: Partial<DbxInjectionComponentConfig>;\n  /**\n   * Used for building a display value given the input.\n   */\n  displayForValue: SearchableValueFieldDisplayFn<T, M>;\n  /**\n   * Whether or not to use the anchor field on value elements.\n   *\n   * This has no default effect if a component class is provided.\n   */\n  useAnchor?: boolean;\n  /**\n   * Used for retrieving an anchor value for values that have no anchor value set.\n   *\n   * Only used when useAnchor is true.\n   */\n  anchorForValue?: SearchableValueFieldAnchorFn<T, M>;\n  /**\n   * Whether or not to show \"Clear\" in the autcomplete list.\n   */\n  showClearValue?: boolean;\n}\n\n/**\n * Abstract searchable field that provides a feature for searching for values, and for displaying values using Observables.\n *\n * Display values are cached for performance.\n */\n@Directive()\nexport abstract class AbstractDbxSearchableValueFieldDirective<T, M = unknown, H extends PrimativeKey = PrimativeKey, C extends SearchableValueFieldsFieldProps<T, M, H> = SearchableValueFieldsFieldProps<T, M, H>> extends FieldType<FieldTypeConfig<C>> implements OnInit, OnDestroy {\n  /**\n   * Whether or not to set/get values as an array.\n   */\n  multiSelect = true;\n\n  /**\n   * Optional override set by the parent class for picking a default display for this directive.\n   */\n  defaultDisplay?: DbxInjectionComponentConfig;\n\n  @ViewChild('textInput')\n  textInput!: ElementRef<HTMLInputElement>;\n\n  readonly inputCtrl = new FormControl<string>('');\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  private _displayHashMap = new BehaviorSubject<Map<H, ConfiguredSearchableValueFieldDisplayValue<T, M>>>(new Map());\n\n  readonly inputValue$: Observable<string> = this.inputCtrl.valueChanges.pipe(\n    startWith(this.inputCtrl.value),\n    map((x) => x || '')\n  );\n  readonly inputValueString$: Observable<string> = this.inputValue$.pipe(debounceTime(200), distinctUntilChanged());\n\n  readonly searchResultsState$: Observable<LoadingState<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>> = this.inputValueString$.pipe(\n    switchMap((text) =>\n      (text || this.searchOnEmptyText ? this.search(text ?? '') : of([])).pipe(\n        switchMap((x) => this.loadDisplayValuesForFieldValues(x)),\n        // Return begin loading to setup the loading state.\n        startWithBeginLoading()\n      )\n    ),\n    shareReplay(1)\n  );\n\n  readonly singleValueSyncSubscription = new SubscriptionObject();\n\n  readonly searchContext = new LoadingStateContextInstance({ obs: this.searchResultsState$, showLoadingOnNoValue: false });\n\n  readonly searchResults$: Observable<ConfiguredSearchableValueFieldDisplayValue<T, M>[]> = this.searchResultsState$.pipe(map((x) => x?.value ?? []));\n\n  readonly _formControlValue$: Observable<T | T[]> = this.formControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value), shareReplay(1))));\n\n  readonly values$: Observable<T[]> = this._formControlValue$.pipe(map(convertMaybeToArray), shareReplay(1));\n\n  readonly displayValuesState$: Observable<LoadingState<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>> = this.values$.pipe(\n    distinctUntilChanged(),\n    switchMap((values: T[]) => this.loadDisplayValuesForValues(values)),\n    shareReplay(1)\n  );\n\n  readonly displayValues$: Observable<ConfiguredSearchableValueFieldDisplayValue<T, M>[]> = this.displayValuesState$.pipe(map((x) => x?.value ?? []));\n\n  get name(): string {\n    return this.field.name ?? camelCase(this.label ?? (this.key as string));\n  }\n\n  get label(): Maybe<string> {\n    return this.props.label;\n  }\n\n  get readonly(): Maybe<boolean> {\n    return this.props.readonly;\n  }\n\n  get searchableField(): SearchableValueFieldsFieldProps<T, M, H> {\n    return this.props;\n  }\n\n  get searchOnEmptyText(): boolean {\n    return this.searchableField.searchOnEmptyText ?? false;\n  }\n\n  get autocomplete(): string {\n    return (this.props.attributes?.['autocomplete'] ?? this.key) as string;\n  }\n\n  get hashForValue(): SearchableValueFieldHashFn<T, H> {\n    return this.searchableField.hashForValue ?? ((x) => x as unknown as H);\n  }\n\n  get displayForValue(): SearchableValueFieldDisplayFn<T, M> {\n    return this.searchableField.displayForValue;\n  }\n\n  get useAnchor(): Maybe<boolean> {\n    return this.searchableField.useAnchor;\n  }\n\n  get anchorForValue(): Maybe<SearchableValueFieldAnchorFn<T, M>> {\n    return this.searchableField.anchorForValue;\n  }\n\n  get display(): Maybe<Partial<DbxInjectionComponentConfig>> {\n    return this.searchableField.display;\n  }\n\n  get search(): SearchableValueFieldStringSearchFn<T, M> {\n    return this.searchableField.search;\n  }\n\n  get values(): T[] {\n    return this._getValueOnFormControl(this.formControl.value) ?? [];\n  }\n\n  get allowStringValues(): boolean {\n    return this.searchableField.allowStringValues ?? Boolean(this.convertStringValue);\n  }\n\n  get convertStringValue(): Maybe<(text: string) => T> {\n    return this.searchableField.convertStringValue;\n  }\n\n  get showClearValue(): boolean {\n    return this.searchableField.showClearValue ?? true;\n  }\n\n  loadDisplayValuesForValues(values: T[]): Observable<LoadingState<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>> {\n    return this.loadDisplayValuesForFieldValues(values.map((value) => ({ value })));\n  }\n\n  loadDisplayValuesForFieldValues(values: SearchableValueFieldValue<T, M>[]): Observable<LoadingState<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>> {\n    return this.getDisplayValuesForFieldValues(values).pipe(\n      map((displayValues: ConfiguredSearchableValueFieldDisplayValue<T, M>[]) => successResult(displayValues)),\n      startWithBeginLoading(),\n      shareReplay(1)\n    );\n  }\n\n  getDisplayValuesForFieldValues(values: SearchableValueFieldValue<T, M>[]): Observable<ConfiguredSearchableValueFieldDisplayValue<T, M>[]> {\n    return this._displayHashMap.pipe(\n      mergeMap((displayMap) => {\n        const mappingResult = values.map((x) => [x, this.hashForValue(x.value)] as [SearchableValueFieldValue<T, M>, H]).map(([x, hash], i) => [i, hash, x, displayMap.get(hash)] as [number, H, SearchableValueFieldValue<T, M>, ConfiguredSearchableValueFieldDisplayValue<T, M>]);\n\n        const hasDisplay = mappingResult.filter((x) => Boolean(x[3]));\n        const needsDisplay = mappingResult.filter((x) => !x[3]);\n        let obs: Observable<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>;\n\n        if (needsDisplay.length > 0) {\n          // Go get the display value.\n          const displayValuesObs = this.displayForValue(needsDisplay.map((x) => x[2]));\n          const defaultDisplay = mergeDbxInjectionComponentConfigs([this.defaultDisplay, this.display]);\n          const anchorForValue = this.useAnchor && this.anchorForValue;\n\n          obs = displayValuesObs.pipe(\n            first(),\n            map((displayResults) => {\n              // Assign the default component classes to complete configuration.\n              displayResults.forEach((x) => {\n                if (!x.display) {\n                  x.display = defaultDisplay;\n                } else {\n                  x.display = mergeDbxInjectionComponentConfigs([defaultDisplay, x.display]);\n                }\n\n                if (!x.anchor && anchorForValue) {\n                  x.anchor = anchorForValue(x);\n                }\n              });\n\n              // Create a map to re-join values later.\n              const displayResultsMapping: [ConfiguredSearchableValueFieldDisplayValue<T, M>, H][] = (displayResults as ConfiguredSearchableValueFieldDisplayValue<T, M>[]).map((x) => [x, this.hashForValue(x.value)]);\n              const valueIndexHashMap = new Map(displayResultsMapping.map(([x, hash]) => [hash, x]));\n\n              // Update displayMap. No need to push an update notification.\n              displayResultsMapping.forEach(([x, hash]) => displayMap.set(hash, x));\n\n              // Zip values back together.\n              const newDisplayValues = mappingResult.map((x) => x[3] ?? valueIndexHashMap.get(x[1]));\n\n              // Return display values.\n              return newDisplayValues;\n            })\n          );\n        } else {\n          // If all display values are hashed return that.\n          obs = of(hasDisplay.map((x) => x[3]));\n        }\n\n        return obs;\n      })\n    );\n  }\n\n  constructor(readonly cdRef: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    if (this.searchableField.textInputValidator) {\n      this.inputCtrl.setValidators(this.searchableField.textInputValidator);\n    }\n\n    if (!this.defaultDisplay?.componentClass) {\n      this.defaultDisplay = {\n        ...this.defaultDisplay,\n        componentClass: DbxDefaultSearchableFieldDisplayComponent\n      };\n    }\n\n    if (this.multiSelect === false) {\n      this.singleValueSyncSubscription.subscription = this.displayValues$.subscribe((x) => {\n        if (x[0]) {\n          this._syncSingleValue(x[0]);\n        }\n      });\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._displayHashMap.complete();\n    this._formControlObs.complete();\n    this.searchContext.destroy();\n  }\n\n  /**\n   * Used to sync the input control with the selected value.\n   *\n   * Only used when multiSelect is false.\n   */\n  protected _syncSingleValue(value: SearchableValueFieldDisplayValue<T>): void {\n    this.inputCtrl.setValue(value.label);\n  }\n\n  protected _addWithTextValue(text: string): void {\n    if (!this.searchableField.allowStringValues) {\n      return;\n    }\n\n    if (text) {\n      text = (text || '').trim();\n      this.inputCtrl.setValue(text.trim());\n    }\n\n    // console.log('Add: ', text, this.inputCtrl.valid);\n\n    if (!this.inputCtrl.valid) {\n      return;\n    }\n\n    if (text) {\n      const value = this.convertStringValue ? this.convertStringValue(text) : (text as unknown as T);\n      this.addValue(value);\n    }\n  }\n\n  addWithDisplayValue(displayValue: SearchableValueFieldDisplayValue<T>): void {\n    this.addValue(displayValue.value);\n  }\n\n  removeWithDisplayValue(displayValue: SearchableValueFieldDisplayValue<T>): void {\n    this.removeValue(displayValue.value);\n  }\n\n  _tryAddCurrentInputValue(): boolean {\n    let addedValue = false;\n\n    if (this.allowStringValues) {\n      const value = this.inputCtrl.value || '';\n\n      if ((value || '').trim()) {\n        this._addWithTextValue(value);\n        addedValue = true;\n      }\n    }\n\n    return addedValue;\n  }\n\n  addValue(value: T): void {\n    this.textInput.nativeElement.value = '';\n    this.inputCtrl.setValue(null);\n    this.setValues([...this.values, value]);\n  }\n\n  removeValue(value: T): void {\n    let values;\n\n    if (this.hashForValue) {\n      const hashToFilter = this.hashForValue(value);\n      values = this.values.filter((x) => this.hashForValue(x) !== hashToFilter);\n    } else {\n      values = this.values.filter((x) => x !== value);\n    }\n\n    this.setValues(values);\n  }\n\n  clearValues(): void {\n    this.setValues([]);\n  }\n\n  setValues(values: T[]): void {\n    // Use to filter non-unique values.\n    if (this.hashForValue) {\n      values = findUnique(values, this.hashForValue);\n    }\n\n    this._setValueOnFormControl(values);\n  }\n\n  // MARK: Internal\n  protected _getValueOnFormControl(valueOnFormControl: ArrayOrValue<T>): T[] {\n    const value = valueOnFormControl != null ? ([] as T[]).concat(valueOnFormControl) : []; // Always return an array.\n    return value as T[];\n  }\n\n  protected _setValueOnFormControl(values: T[]): void {\n    const value = this.multiSelect ? values : lastValue(values); // pick last value, as the last value added is the newest value.\n    this.formControl.setValue(value);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n  }\n}\n"]}
261
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchable.field.directive.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/selection/searchable/searchable.field.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ArrayOrValue, Maybe, convertMaybeToArray, findUnique, lastValue, PrimativeKey } from '@dereekb/util';\nimport { DbxInjectionComponentConfig, mergeDbxInjectionComponentConfigs } from '@dereekb/dbx-core';\nimport { filterMaybe, SubscriptionObject, LoadingState, LoadingStateContextInstance, successResult, startWithBeginLoading } from '@dereekb/rxjs';\nimport { ChangeDetectorRef, Directive, ElementRef, OnDestroy, OnInit, ViewChild } from '@angular/core';\nimport { AbstractControl, FormControl, ValidatorFn } from '@angular/forms';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { debounceTime, distinctUntilChanged, first, map, mergeMap, shareReplay, startWith, switchMap, BehaviorSubject, of, Observable } from 'rxjs';\nimport { SearchableValueFieldHashFn, SearchableValueFieldStringSearchFn, SearchableValueFieldDisplayFn, SearchableValueFieldDisplayValue, SearchableValueFieldValue, SearchableValueFieldAnchorFn, ConfiguredSearchableValueFieldDisplayValue } from './searchable';\nimport { DbxDefaultSearchableFieldDisplayComponent } from './searchable.field.autocomplete.item.component';\nimport { camelCase } from 'change-case';\n\nexport interface StringValueFieldsFieldProps extends FormlyFieldProps {\n  /**\n   * Custom input validators.\n   */\n  textInputValidator?: ValidatorFn | ValidatorFn[];\n}\n\nexport interface SearchableValueFieldsFieldProps<T, M = unknown, H extends PrimativeKey = PrimativeKey> extends FormlyFieldProps, StringValueFieldsFieldProps {\n  /**\n   * Whether or not to allow string values to be used directly, or if values can only be chosen from searching.\n   */\n  allowStringValues?: boolean;\n  /**\n   * Optional conversion function. If provided, allowStringValues is considered true.\n   */\n  convertStringValue?: (text: string) => T;\n  /**\n   * Used for hashing display values and omitting repeat values.\n   *\n   * If hashForValue is not provided, the value's value will be used as is.\n   */\n  hashForValue?: SearchableValueFieldHashFn<T, H>;\n  /**\n   * Performs a search.\n   */\n  search: SearchableValueFieldStringSearchFn<T, M>;\n  /**\n   * Whether or not to allow searches on empty text. Is false by default.\n   */\n  searchOnEmptyText?: boolean;\n  /**\n   * Default injected config to use for display values.\n   */\n  display?: Partial<DbxInjectionComponentConfig>;\n  /**\n   * Used for building a display value given the input.\n   */\n  displayForValue: SearchableValueFieldDisplayFn<T, M>;\n  /**\n   * Whether or not to use the anchor field on value elements.\n   *\n   * This has no default effect if a component class is provided.\n   */\n  useAnchor?: boolean;\n  /**\n   * Used for retrieving an anchor value for values that have no anchor value set.\n   *\n   * Only used when useAnchor is true.\n   */\n  anchorForValue?: SearchableValueFieldAnchorFn<T, M>;\n  /**\n   * Whether or not to show \"Clear\" in the autcomplete list.\n   */\n  showClearValue?: boolean;\n  /**\n   * Label for the search input.\n   *\n   * Defaults to \"Search\"\n   */\n  searchLabel?: string;\n  /**\n   * (Optional) observable that will trigger the clearing of all cached display values.\n   */\n  refreshDisplayValues$?: Observable<unknown>;\n}\n\n/**\n * Abstract searchable field that provides a feature for searching for values, and for displaying values using Observables.\n *\n * Display values are cached for performance.\n */\n@Directive()\nexport abstract class AbstractDbxSearchableValueFieldDirective<T, M = unknown, H extends PrimativeKey = PrimativeKey, C extends SearchableValueFieldsFieldProps<T, M, H> = SearchableValueFieldsFieldProps<T, M, H>> extends FieldType<FieldTypeConfig<C>> implements OnInit, OnDestroy {\n  /**\n   * Whether or not to set/get values as an array.\n   */\n  multiSelect = true;\n\n  /**\n   * Optional override set by the parent class for picking a default display for this directive.\n   */\n  defaultDisplay?: DbxInjectionComponentConfig;\n\n  @ViewChild('textInput')\n  textInput!: ElementRef<HTMLInputElement>;\n\n  readonly inputCtrl = new FormControl<string>('');\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  private _clearDisplayHashMapSub = new SubscriptionObject();\n  private _displayHashMap = new BehaviorSubject<Map<H, ConfiguredSearchableValueFieldDisplayValue<T, M>>>(new Map());\n\n  readonly inputValue$: Observable<string> = this.inputCtrl.valueChanges.pipe(\n    startWith(this.inputCtrl.value),\n    map((x) => x || '')\n  );\n  readonly inputValueString$: Observable<string> = this.inputValue$.pipe(debounceTime(200), distinctUntilChanged());\n\n  readonly searchResultsState$: Observable<LoadingState<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>> = this.inputValueString$.pipe(\n    switchMap((text) =>\n      (text || this.searchOnEmptyText ? this.search(text ?? '') : of([])).pipe(\n        switchMap((x) => this.loadDisplayValuesForFieldValues(x)),\n        // Return begin loading to setup the loading state.\n        startWithBeginLoading()\n      )\n    ),\n    shareReplay(1)\n  );\n\n  readonly singleValueSyncSubscription = new SubscriptionObject();\n\n  readonly searchContext = new LoadingStateContextInstance({ obs: this.searchResultsState$, showLoadingOnNoValue: false });\n\n  readonly searchResults$: Observable<ConfiguredSearchableValueFieldDisplayValue<T, M>[]> = this.searchResultsState$.pipe(map((x) => x?.value ?? []));\n\n  readonly _formControlValue$: Observable<T | T[]> = this.formControl$.pipe(switchMap((control) => control.valueChanges.pipe(startWith(control.value), shareReplay(1))));\n\n  readonly values$: Observable<T[]> = this._formControlValue$.pipe(map(convertMaybeToArray), shareReplay(1));\n\n  readonly displayValuesState$: Observable<LoadingState<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>> = this.values$.pipe(\n    distinctUntilChanged(),\n    switchMap((values: T[]) => this.loadDisplayValuesForValues(values)),\n    shareReplay(1)\n  );\n\n  readonly displayValues$: Observable<ConfiguredSearchableValueFieldDisplayValue<T, M>[]> = this.displayValuesState$.pipe(map((x) => x?.value ?? []));\n\n  get name(): string {\n    return this.field.name ?? camelCase(this.label ?? (this.key as string));\n  }\n\n  get label(): Maybe<string> {\n    return this.props.label;\n  }\n\n  get readonly(): Maybe<boolean> {\n    return this.props.readonly;\n  }\n\n  get searchableField(): SearchableValueFieldsFieldProps<T, M, H> {\n    return this.props;\n  }\n\n  get searchOnEmptyText(): boolean {\n    return this.searchableField.searchOnEmptyText ?? false;\n  }\n\n  get autocomplete(): string {\n    return (this.props.attributes?.['autocomplete'] ?? this.key) as string;\n  }\n\n  get hashForValue(): SearchableValueFieldHashFn<T, H> {\n    return this.searchableField.hashForValue ?? ((x) => x as unknown as H);\n  }\n\n  get displayForValue(): SearchableValueFieldDisplayFn<T, M> {\n    return this.searchableField.displayForValue;\n  }\n\n  get useAnchor(): Maybe<boolean> {\n    return this.searchableField.useAnchor;\n  }\n\n  get anchorForValue(): Maybe<SearchableValueFieldAnchorFn<T, M>> {\n    return this.searchableField.anchorForValue;\n  }\n\n  get display(): Maybe<Partial<DbxInjectionComponentConfig>> {\n    return this.searchableField.display;\n  }\n\n  get search(): SearchableValueFieldStringSearchFn<T, M> {\n    return this.searchableField.search;\n  }\n\n  get values(): T[] {\n    return this._getValueOnFormControl(this.formControl.value) ?? [];\n  }\n\n  get allowStringValues(): boolean {\n    return this.searchableField.allowStringValues ?? Boolean(this.convertStringValue);\n  }\n\n  get convertStringValue(): Maybe<(text: string) => T> {\n    return this.searchableField.convertStringValue;\n  }\n\n  get showClearValue(): boolean {\n    return this.searchableField.showClearValue ?? true;\n  }\n\n  get searchLabel() {\n    return this.searchableField.searchLabel ?? 'Search';\n  }\n\n  get refreshDisplayValues$() {\n    return this.searchableField.refreshDisplayValues$;\n  }\n\n  loadDisplayValuesForValues(values: T[]): Observable<LoadingState<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>> {\n    return this.loadDisplayValuesForFieldValues(values.map((value) => ({ value })));\n  }\n\n  loadDisplayValuesForFieldValues(values: SearchableValueFieldValue<T, M>[]): Observable<LoadingState<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>> {\n    return this.getDisplayValuesForFieldValues(values).pipe(\n      map((displayValues: ConfiguredSearchableValueFieldDisplayValue<T, M>[]) => successResult(displayValues)),\n      startWithBeginLoading(),\n      shareReplay(1)\n    );\n  }\n\n  getDisplayValuesForFieldValues(values: SearchableValueFieldValue<T, M>[]): Observable<ConfiguredSearchableValueFieldDisplayValue<T, M>[]> {\n    return this._displayHashMap.pipe(\n      mergeMap((displayMap) => {\n        const mappingResult = values.map((x) => [x, this.hashForValue(x.value)] as [SearchableValueFieldValue<T, M>, H]).map(([x, hash], i) => [i, hash, x, displayMap.get(hash)] as [number, H, SearchableValueFieldValue<T, M>, ConfiguredSearchableValueFieldDisplayValue<T, M>]);\n\n        const hasDisplay = mappingResult.filter((x) => Boolean(x[3]));\n        const needsDisplay = mappingResult.filter((x) => !x[3]);\n        let obs: Observable<ConfiguredSearchableValueFieldDisplayValue<T, M>[]>;\n\n        if (needsDisplay.length > 0) {\n          // Go get the display value.\n          const displayValuesObs = this.displayForValue(needsDisplay.map((x) => x[2]));\n          const defaultDisplay = mergeDbxInjectionComponentConfigs([this.defaultDisplay, this.display]);\n          const anchorForValue = this.useAnchor && this.anchorForValue;\n\n          obs = displayValuesObs.pipe(\n            first(),\n            map((displayResults) => {\n              // Assign the default component classes to complete configuration.\n              displayResults.forEach((x) => {\n                if (!x.display) {\n                  x.display = defaultDisplay;\n                } else {\n                  x.display = mergeDbxInjectionComponentConfigs([defaultDisplay, x.display]);\n                }\n\n                if (!x.anchor && anchorForValue) {\n                  x.anchor = anchorForValue(x);\n                }\n              });\n\n              // Create a map to re-join values later.\n              const displayResultsMapping: [ConfiguredSearchableValueFieldDisplayValue<T, M>, H][] = (displayResults as ConfiguredSearchableValueFieldDisplayValue<T, M>[]).map((x) => [x, this.hashForValue(x.value)]);\n              const valueIndexHashMap = new Map(displayResultsMapping.map(([x, hash]) => [hash, x]));\n\n              // Update displayMap. No need to push an update notification.\n              displayResultsMapping.forEach(([x, hash]) => displayMap.set(hash, x));\n\n              // Zip values back together.\n              const newDisplayValues = mappingResult.map((x) => x[3] ?? valueIndexHashMap.get(x[1]));\n\n              // Return display values.\n              return newDisplayValues;\n            })\n          );\n        } else {\n          // If all display values are hashed return that.\n          obs = of(hasDisplay.map((x) => x[3]));\n        }\n\n        return obs;\n      })\n    );\n  }\n\n  constructor(readonly cdRef: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n\n    if (this.refreshDisplayValues$ != null) {\n      this._clearDisplayHashMapSub.subscription = this.refreshDisplayValues$.subscribe(() => this._displayHashMap.next(new Map()));\n    }\n\n    if (this.searchableField.textInputValidator) {\n      this.inputCtrl.setValidators(this.searchableField.textInputValidator);\n    }\n\n    if (!this.defaultDisplay?.componentClass) {\n      this.defaultDisplay = {\n        ...this.defaultDisplay,\n        componentClass: DbxDefaultSearchableFieldDisplayComponent\n      };\n    }\n\n    if (this.multiSelect === false) {\n      this.singleValueSyncSubscription.subscription = this.displayValues$.subscribe((x) => {\n        if (x[0]) {\n          this._syncSingleValue(x[0]);\n        }\n      });\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._displayHashMap.complete();\n    this._formControlObs.complete();\n    this._clearDisplayHashMapSub.destroy();\n    this.searchContext.destroy();\n  }\n\n  /**\n   * Used to sync the input control with the selected value.\n   *\n   * Only used when multiSelect is false.\n   */\n  protected _syncSingleValue(value: SearchableValueFieldDisplayValue<T>): void {\n    this.inputCtrl.setValue(value.label);\n  }\n\n  protected _addWithTextValue(text: string): void {\n    if (!this.searchableField.allowStringValues) {\n      return;\n    }\n\n    if (text) {\n      text = (text || '').trim();\n      this.inputCtrl.setValue(text.trim());\n    }\n\n    // console.log('Add: ', text, this.inputCtrl.valid);\n\n    if (!this.inputCtrl.valid) {\n      return;\n    }\n\n    if (text) {\n      const value = this.convertStringValue ? this.convertStringValue(text) : (text as unknown as T);\n      this.addValue(value);\n    }\n  }\n\n  addWithDisplayValue(displayValue: SearchableValueFieldDisplayValue<T>): void {\n    this.addValue(displayValue.value);\n  }\n\n  removeWithDisplayValue(displayValue: SearchableValueFieldDisplayValue<T>): void {\n    this.removeValue(displayValue.value);\n  }\n\n  _tryAddCurrentInputValue(): boolean {\n    let addedValue = false;\n\n    if (this.allowStringValues) {\n      const value = this.inputCtrl.value || '';\n\n      if ((value || '').trim()) {\n        this._addWithTextValue(value);\n        addedValue = true;\n      }\n    }\n\n    return addedValue;\n  }\n\n  addValue(value: T): void {\n    this.textInput.nativeElement.value = '';\n    this.inputCtrl.setValue(null);\n    this.setValues([...this.values, value]);\n  }\n\n  removeValue(value: T): void {\n    let values;\n\n    if (this.hashForValue) {\n      const hashToFilter = this.hashForValue(value);\n      values = this.values.filter((x) => this.hashForValue(x) !== hashToFilter);\n    } else {\n      values = this.values.filter((x) => x !== value);\n    }\n\n    this.setValues(values);\n  }\n\n  clearValues(): void {\n    this.setValues([]);\n  }\n\n  setValues(values: T[]): void {\n    // Use to filter non-unique values.\n    if (this.hashForValue) {\n      values = findUnique(values, this.hashForValue);\n    }\n\n    this._setValueOnFormControl(values);\n  }\n\n  // MARK: Internal\n  protected _getValueOnFormControl(valueOnFormControl: ArrayOrValue<T>): T[] {\n    const value = valueOnFormControl != null ? ([] as T[]).concat(valueOnFormControl) : []; // Always return an array.\n    return value as T[];\n  }\n\n  protected _setValueOnFormControl(values: T[]): void {\n    const value = this.multiSelect ? values : lastValue(values); // pick last value, as the last value added is the newest value.\n    this.formControl.setValue(value);\n    this.formControl.markAsDirty();\n    this.formControl.markAsTouched();\n  }\n}\n"]}
@@ -46,9 +46,9 @@ export class DbxSearchableTextFieldComponent extends AbstractDbxSearchableValueF
46
46
  }
47
47
  }
48
48
  DbxSearchableTextFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxSearchableTextFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
49
- DbxSearchableTextFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxSearchableTextFieldComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-searchable-text-field\" [ngClass]=\"{ 'dbx-searchable-text-field-has-value': (hasValue$ | async), 'dbx-searchable-text-field-show-value': showSelectedValue }\">\n <!-- Result View -->\n <div class=\"dbx-searchable-text-field-value mat-option mat-option-text\" *ngIf=\"showSelectedDisplayValue$ | async\">\n <dbx-searchable-field-autocomplete-item [displayValue]=\"(selectedDisplayValue$ | async)!\"></dbx-searchable-field-autocomplete-item>\n </div>\n <div class=\"dbx-searchable-text-field-input\">\n <div class=\"dbx-label\">Search</div>\n <!-- View -->\n <input type=\"search\" [name]=\"name\" matInput #textInput [placeholder]=\"placeholder\" [formControl]=\"inputCtrl\" [matAutocomplete]=\"auto\" [matAutocompleteDisabled]=\"readonly\" autocomplete=\"{{ autocomplete }}\" />\n <div class=\"searchable-field-form-loading\">\n <dbx-loading [linear]=\"true\" [context]=\"searchContext\"></dbx-loading>\n </div>\n </div>\n</div>\n\n<!-- Autocomplete -->\n<mat-autocomplete class=\"dbx-searchable-text-field-autocomplete\" #auto (optionSelected)=\"selected($event)\">\n <mat-option *ngFor=\"let displayValue of searchResults$ | async\" [value]=\"displayValue\">\n <dbx-searchable-field-autocomplete-item [displayValue]=\"displayValue\"></dbx-searchable-field-autocomplete-item>\n </mat-option>\n <!-- Add/Pick String Value -->\n <mat-option *ngIf=\"allowStringValues && (inputValue$ | async)\" [value]=\"{ value: (inputValue$ | async) }\">\n <p class=\"dbx-clear-hint text-center\">\"{{ inputValue$ | async }}\"</p>\n </mat-option>\n <!-- Show clear value -->\n <mat-option *ngIf=\"showClearValue && (hasValue$ | async)\" value=\"\">\n <p class=\"dbx-clear-hint text-center\">Clear</p>\n </mat-option>\n</mat-autocomplete>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DbxLoadingComponent, selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "context", "loading", "error"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i5.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i7.DbxSearchableFieldAutocompleteItemComponent, selector: "dbx-searchable-field-autocomplete-item", inputs: ["displayValue"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
49
+ DbxSearchableTextFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: DbxSearchableTextFieldComponent, selector: "ng-component", usesInheritance: true, ngImport: i0, template: "<div class=\"dbx-searchable-text-field\" [ngClass]=\"{ 'dbx-searchable-text-field-has-value': (hasValue$ | async), 'dbx-searchable-text-field-show-value': showSelectedValue }\">\n <!-- Result View -->\n <div class=\"dbx-searchable-text-field-value mat-option mat-option-text\" *ngIf=\"showSelectedDisplayValue$ | async\">\n <dbx-searchable-field-autocomplete-item [displayValue]=\"(selectedDisplayValue$ | async)!\"></dbx-searchable-field-autocomplete-item>\n </div>\n <div class=\"dbx-searchable-text-field-input\">\n <div *ngIf=\"searchLabel\" class=\"dbx-label\">{{ searchLabel }}</div>\n <!-- View -->\n <input type=\"search\" [name]=\"name\" matInput #textInput [placeholder]=\"placeholder\" [formControl]=\"inputCtrl\" [matAutocomplete]=\"auto\" [matAutocompleteDisabled]=\"readonly\" autocomplete=\"{{ autocomplete }}\" />\n <div class=\"searchable-field-form-loading\">\n <dbx-loading [linear]=\"true\" [context]=\"searchContext\"></dbx-loading>\n </div>\n </div>\n</div>\n\n<!-- Autocomplete -->\n<mat-autocomplete class=\"dbx-searchable-text-field-autocomplete\" #auto (optionSelected)=\"selected($event)\">\n <mat-option *ngFor=\"let displayValue of searchResults$ | async\" [value]=\"displayValue\">\n <dbx-searchable-field-autocomplete-item [displayValue]=\"displayValue\"></dbx-searchable-field-autocomplete-item>\n </mat-option>\n <!-- Add/Pick String Value -->\n <mat-option *ngIf=\"allowStringValues && (inputValue$ | async)\" [value]=\"{ value: (inputValue$ | async) }\">\n <p class=\"dbx-clear-hint text-center\">\"{{ inputValue$ | async }}\"</p>\n </mat-option>\n <!-- Show clear value -->\n <mat-option *ngIf=\"showClearValue && (hasValue$ | async)\" value=\"\">\n <p class=\"dbx-clear-hint text-center\">Clear</p>\n </mat-option>\n</mat-autocomplete>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.DbxLoadingComponent, selector: "dbx-loading", inputs: ["show", "text", "mode", "color", "diameter", "linear", "context", "loading", "error"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i5.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i6.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i7.DbxSearchableFieldAutocompleteItemComponent, selector: "dbx-searchable-field-autocomplete-item", inputs: ["displayValue"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }] });
50
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxSearchableTextFieldComponent, decorators: [{
51
51
  type: Component,
52
- args: [{ template: "<div class=\"dbx-searchable-text-field\" [ngClass]=\"{ 'dbx-searchable-text-field-has-value': (hasValue$ | async), 'dbx-searchable-text-field-show-value': showSelectedValue }\">\n <!-- Result View -->\n <div class=\"dbx-searchable-text-field-value mat-option mat-option-text\" *ngIf=\"showSelectedDisplayValue$ | async\">\n <dbx-searchable-field-autocomplete-item [displayValue]=\"(selectedDisplayValue$ | async)!\"></dbx-searchable-field-autocomplete-item>\n </div>\n <div class=\"dbx-searchable-text-field-input\">\n <div class=\"dbx-label\">Search</div>\n <!-- View -->\n <input type=\"search\" [name]=\"name\" matInput #textInput [placeholder]=\"placeholder\" [formControl]=\"inputCtrl\" [matAutocomplete]=\"auto\" [matAutocompleteDisabled]=\"readonly\" autocomplete=\"{{ autocomplete }}\" />\n <div class=\"searchable-field-form-loading\">\n <dbx-loading [linear]=\"true\" [context]=\"searchContext\"></dbx-loading>\n </div>\n </div>\n</div>\n\n<!-- Autocomplete -->\n<mat-autocomplete class=\"dbx-searchable-text-field-autocomplete\" #auto (optionSelected)=\"selected($event)\">\n <mat-option *ngFor=\"let displayValue of searchResults$ | async\" [value]=\"displayValue\">\n <dbx-searchable-field-autocomplete-item [displayValue]=\"displayValue\"></dbx-searchable-field-autocomplete-item>\n </mat-option>\n <!-- Add/Pick String Value -->\n <mat-option *ngIf=\"allowStringValues && (inputValue$ | async)\" [value]=\"{ value: (inputValue$ | async) }\">\n <p class=\"dbx-clear-hint text-center\">\"{{ inputValue$ | async }}\"</p>\n </mat-option>\n <!-- Show clear value -->\n <mat-option *ngIf=\"showClearValue && (hasValue$ | async)\" value=\"\">\n <p class=\"dbx-clear-hint text-center\">Clear</p>\n </mat-option>\n</mat-autocomplete>\n" }]
52
+ args: [{ template: "<div class=\"dbx-searchable-text-field\" [ngClass]=\"{ 'dbx-searchable-text-field-has-value': (hasValue$ | async), 'dbx-searchable-text-field-show-value': showSelectedValue }\">\n <!-- Result View -->\n <div class=\"dbx-searchable-text-field-value mat-option mat-option-text\" *ngIf=\"showSelectedDisplayValue$ | async\">\n <dbx-searchable-field-autocomplete-item [displayValue]=\"(selectedDisplayValue$ | async)!\"></dbx-searchable-field-autocomplete-item>\n </div>\n <div class=\"dbx-searchable-text-field-input\">\n <div *ngIf=\"searchLabel\" class=\"dbx-label\">{{ searchLabel }}</div>\n <!-- View -->\n <input type=\"search\" [name]=\"name\" matInput #textInput [placeholder]=\"placeholder\" [formControl]=\"inputCtrl\" [matAutocomplete]=\"auto\" [matAutocompleteDisabled]=\"readonly\" autocomplete=\"{{ autocomplete }}\" />\n <div class=\"searchable-field-form-loading\">\n <dbx-loading [linear]=\"true\" [context]=\"searchContext\"></dbx-loading>\n </div>\n </div>\n</div>\n\n<!-- Autocomplete -->\n<mat-autocomplete class=\"dbx-searchable-text-field-autocomplete\" #auto (optionSelected)=\"selected($event)\">\n <mat-option *ngFor=\"let displayValue of searchResults$ | async\" [value]=\"displayValue\">\n <dbx-searchable-field-autocomplete-item [displayValue]=\"displayValue\"></dbx-searchable-field-autocomplete-item>\n </mat-option>\n <!-- Add/Pick String Value -->\n <mat-option *ngIf=\"allowStringValues && (inputValue$ | async)\" [value]=\"{ value: (inputValue$ | async) }\">\n <p class=\"dbx-clear-hint text-center\">\"{{ inputValue$ | async }}\"</p>\n </mat-option>\n <!-- Show clear value -->\n <mat-option *ngIf=\"showClearValue && (hasValue$ | async)\" value=\"\">\n <p class=\"dbx-clear-hint text-center\">Clear</p>\n </mat-option>\n</mat-autocomplete>\n" }]
53
53
  }] });
54
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchable.text.field.component.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/selection/searchable/searchable.text.field.component.ts","../../../../../../../../../packages/dbx-form/src/lib/formly/field/selection/searchable/searchable.text.field.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,SAAS,EAAqB,MAAM,eAAe,CAAC;AAE7D,OAAO,EAAE,wCAAwC,EAAmC,MAAM,8BAA8B,CAAC;AACzH,OAAO,EAAE,GAAG,EAAE,WAAW,EAAE,SAAS,EAAE,oBAAoB,EAAE,MAAM,MAAM,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;;AAOrD;;GAEG;AAIH,MAAM,OAAO,+BAAuF,SAAQ,wCAA+F;IAH3M;;QAIW,0BAAqB,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CACvD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAChB,WAAW,CAAC,CAAC,CAAC,EACd,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAC7B,CAAC;QAEO,cAAS,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpE,8BAAyB,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAClE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,EAChD,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,EACd,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAC7B,CAAC;QAUgB,gBAAW,GAAG,KAAK,CAAC;QAE9B,mBAAc,GAAG,IAAI,kBAAkB,EAAE,CAAC;KAoBnD;IA9BC,IAAa,eAAe;QAC1B,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,eAAe,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,6DAA6D;IACzI,CAAC;IAMQ,QAAQ;QACf,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,IAAI,CAAC,cAAc,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC7F,IAAI,CAAC,CAAC,EAAE;gBACN,sBAAsB;aACvB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;IAChC,CAAC;IAED,QAAQ,CAAC,KAAmC;QAC1C,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;;6HA5CU,+BAA+B;iHAA/B,+BAA+B,2EClB5C,4vDA6BA;4FDXa,+BAA+B;kBAH3C,SAAS","sourcesContent":["import { SubscriptionObject } from '@dereekb/rxjs';\nimport { Component, OnDestroy, OnInit } from '@angular/core';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { AbstractDbxSearchableValueFieldDirective, SearchableValueFieldsFieldProps } from './searchable.field.directive';\nimport { map, shareReplay, skipWhile, distinctUntilChanged } from 'rxjs';\nimport { tapDetectChanges } from '@dereekb/dbx-core';\nimport { PrimativeKey } from '@dereekb/util';\n\nexport interface SearchableTextValueFieldsFieldProps<T, M = unknown, H extends PrimativeKey = PrimativeKey> extends SearchableValueFieldsFieldProps<T, M, H> {\n  showSelectedValue?: boolean;\n}\n\n/**\n * Display component for selecting a single item/value.\n */\n@Component({\n  templateUrl: 'searchable.text.field.component.html'\n})\nexport class DbxSearchableTextFieldComponent<T, M = unknown, H extends PrimativeKey = PrimativeKey> extends AbstractDbxSearchableValueFieldDirective<T, M, H, SearchableTextValueFieldsFieldProps<T, M, H>> implements OnInit, OnDestroy {\n  readonly selectedDisplayValue$ = this.displayValues$.pipe(\n    map((x) => x[0]),\n    shareReplay(1),\n    tapDetectChanges(this.cdRef)\n  );\n\n  readonly hasValue$ = this.selectedDisplayValue$.pipe(map((x) => Boolean(x)));\n  readonly showSelectedDisplayValue$ = this.selectedDisplayValue$.pipe(\n    map((x) => this.showSelectedValue && Boolean(x)),\n    distinctUntilChanged(),\n    shareReplay(1),\n    tapDetectChanges(this.cdRef)\n  );\n\n  override get searchableField(): SearchableTextValueFieldsFieldProps<T, M, H> {\n    return this.props;\n  }\n\n  get showSelectedValue() {\n    return this.searchableField.showSelectedValue ?? !this.allowStringValues; // Show the selected value only if string values are allowed.\n  }\n\n  override readonly multiSelect = false;\n\n  private _clearInputSub = new SubscriptionObject();\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n\n    this._clearInputSub.subscription = this.inputValue$.pipe(skipWhile((x) => !x)).subscribe((x) => {\n      if (!x) {\n        // this.clearValues();\n      }\n    });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._clearInputSub.destroy();\n  }\n\n  selected(event: MatAutocompleteSelectedEvent): void {\n    this.addWithDisplayValue(event.option.value);\n  }\n}\n","<div class=\"dbx-searchable-text-field\" [ngClass]=\"{ 'dbx-searchable-text-field-has-value': (hasValue$ | async), 'dbx-searchable-text-field-show-value': showSelectedValue }\">\n  <!-- Result View -->\n  <div class=\"dbx-searchable-text-field-value mat-option mat-option-text\" *ngIf=\"showSelectedDisplayValue$ | async\">\n    <dbx-searchable-field-autocomplete-item [displayValue]=\"(selectedDisplayValue$ | async)!\"></dbx-searchable-field-autocomplete-item>\n  </div>\n  <div class=\"dbx-searchable-text-field-input\">\n    <div class=\"dbx-label\">Search</div>\n    <!-- View -->\n    <input type=\"search\" [name]=\"name\" matInput #textInput [placeholder]=\"placeholder\" [formControl]=\"inputCtrl\" [matAutocomplete]=\"auto\" [matAutocompleteDisabled]=\"readonly\" autocomplete=\"{{ autocomplete }}\" />\n    <div class=\"searchable-field-form-loading\">\n      <dbx-loading [linear]=\"true\" [context]=\"searchContext\"></dbx-loading>\n    </div>\n  </div>\n</div>\n\n<!-- Autocomplete -->\n<mat-autocomplete class=\"dbx-searchable-text-field-autocomplete\" #auto (optionSelected)=\"selected($event)\">\n  <mat-option *ngFor=\"let displayValue of searchResults$ | async\" [value]=\"displayValue\">\n    <dbx-searchable-field-autocomplete-item [displayValue]=\"displayValue\"></dbx-searchable-field-autocomplete-item>\n  </mat-option>\n  <!-- Add/Pick String Value -->\n  <mat-option *ngIf=\"allowStringValues && (inputValue$ | async)\" [value]=\"{ value: (inputValue$ | async) }\">\n    <p class=\"dbx-clear-hint text-center\">\"{{ inputValue$ | async }}\"</p>\n  </mat-option>\n  <!-- Show clear value -->\n  <mat-option *ngIf=\"showClearValue && (hasValue$ | async)\" value=\"\">\n    <p class=\"dbx-clear-hint text-center\">Clear</p>\n  </mat-option>\n</mat-autocomplete>\n"]}
54
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"searchable.text.field.component.js","sourceRoot":"","sources":["../../../../../../../../../packages/dbx-form/src/lib/formly/field/selection/searchable/searchable.text.field.component.ts","../../../../../../../../../packages/dbx-form/src/lib/formly/field/selection/searchable/searchable.text.field.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,SAAS,EAAqB,MAAM,eAAe,CAAC;AAE7D,OAAO,EAAE,wCAAwC,EAAmC,MAAM,8BAA8B,CAAC;AACzH,OAAO,EAAE,GAAG,EAAE,WAAW,EAAE,SAAS,EAAE,oBAAoB,EAAE,MAAM,MAAM,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;;;;;;;;;AAOrD;;GAEG;AAIH,MAAM,OAAO,+BAAuF,SAAQ,wCAA+F;IAH3M;;QAIW,0BAAqB,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CACvD,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAChB,WAAW,CAAC,CAAC,CAAC,EACd,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAC7B,CAAC;QAEO,cAAS,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpE,8BAAyB,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAClE,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,EAChD,oBAAoB,EAAE,EACtB,WAAW,CAAC,CAAC,CAAC,EACd,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAC7B,CAAC;QAUgB,gBAAW,GAAG,KAAK,CAAC;QAE9B,mBAAc,GAAG,IAAI,kBAAkB,EAAE,CAAC;KAoBnD;IA9BC,IAAa,eAAe;QAC1B,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,eAAe,CAAC,iBAAiB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,6DAA6D;IACzI,CAAC;IAMQ,QAAQ;QACf,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,IAAI,CAAC,cAAc,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC7F,IAAI,CAAC,CAAC,EAAE;gBACN,sBAAsB;aACvB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC;IAChC,CAAC;IAED,QAAQ,CAAC,KAAmC;QAC1C,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;;6HA5CU,+BAA+B;iHAA/B,+BAA+B,2EClB5C,6xDA6BA;4FDXa,+BAA+B;kBAH3C,SAAS","sourcesContent":["import { SubscriptionObject } from '@dereekb/rxjs';\nimport { Component, OnDestroy, OnInit } from '@angular/core';\nimport { MatAutocompleteSelectedEvent } from '@angular/material/autocomplete';\nimport { AbstractDbxSearchableValueFieldDirective, SearchableValueFieldsFieldProps } from './searchable.field.directive';\nimport { map, shareReplay, skipWhile, distinctUntilChanged } from 'rxjs';\nimport { tapDetectChanges } from '@dereekb/dbx-core';\nimport { PrimativeKey } from '@dereekb/util';\n\nexport interface SearchableTextValueFieldsFieldProps<T, M = unknown, H extends PrimativeKey = PrimativeKey> extends SearchableValueFieldsFieldProps<T, M, H> {\n  showSelectedValue?: boolean;\n}\n\n/**\n * Display component for selecting a single item/value.\n */\n@Component({\n  templateUrl: 'searchable.text.field.component.html'\n})\nexport class DbxSearchableTextFieldComponent<T, M = unknown, H extends PrimativeKey = PrimativeKey> extends AbstractDbxSearchableValueFieldDirective<T, M, H, SearchableTextValueFieldsFieldProps<T, M, H>> implements OnInit, OnDestroy {\n  readonly selectedDisplayValue$ = this.displayValues$.pipe(\n    map((x) => x[0]),\n    shareReplay(1),\n    tapDetectChanges(this.cdRef)\n  );\n\n  readonly hasValue$ = this.selectedDisplayValue$.pipe(map((x) => Boolean(x)));\n  readonly showSelectedDisplayValue$ = this.selectedDisplayValue$.pipe(\n    map((x) => this.showSelectedValue && Boolean(x)),\n    distinctUntilChanged(),\n    shareReplay(1),\n    tapDetectChanges(this.cdRef)\n  );\n\n  override get searchableField(): SearchableTextValueFieldsFieldProps<T, M, H> {\n    return this.props;\n  }\n\n  get showSelectedValue() {\n    return this.searchableField.showSelectedValue ?? !this.allowStringValues; // Show the selected value only if string values are allowed.\n  }\n\n  override readonly multiSelect = false;\n\n  private _clearInputSub = new SubscriptionObject();\n\n  override ngOnInit(): void {\n    super.ngOnInit();\n\n    this._clearInputSub.subscription = this.inputValue$.pipe(skipWhile((x) => !x)).subscribe((x) => {\n      if (!x) {\n        // this.clearValues();\n      }\n    });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._clearInputSub.destroy();\n  }\n\n  selected(event: MatAutocompleteSelectedEvent): void {\n    this.addWithDisplayValue(event.option.value);\n  }\n}\n","<div class=\"dbx-searchable-text-field\" [ngClass]=\"{ 'dbx-searchable-text-field-has-value': (hasValue$ | async), 'dbx-searchable-text-field-show-value': showSelectedValue }\">\n  <!-- Result View -->\n  <div class=\"dbx-searchable-text-field-value mat-option mat-option-text\" *ngIf=\"showSelectedDisplayValue$ | async\">\n    <dbx-searchable-field-autocomplete-item [displayValue]=\"(selectedDisplayValue$ | async)!\"></dbx-searchable-field-autocomplete-item>\n  </div>\n  <div class=\"dbx-searchable-text-field-input\">\n    <div *ngIf=\"searchLabel\" class=\"dbx-label\">{{ searchLabel }}</div>\n    <!-- View -->\n    <input type=\"search\" [name]=\"name\" matInput #textInput [placeholder]=\"placeholder\" [formControl]=\"inputCtrl\" [matAutocomplete]=\"auto\" [matAutocompleteDisabled]=\"readonly\" autocomplete=\"{{ autocomplete }}\" />\n    <div class=\"searchable-field-form-loading\">\n      <dbx-loading [linear]=\"true\" [context]=\"searchContext\"></dbx-loading>\n    </div>\n  </div>\n</div>\n\n<!-- Autocomplete -->\n<mat-autocomplete class=\"dbx-searchable-text-field-autocomplete\" #auto (optionSelected)=\"selected($event)\">\n  <mat-option *ngFor=\"let displayValue of searchResults$ | async\" [value]=\"displayValue\">\n    <dbx-searchable-field-autocomplete-item [displayValue]=\"displayValue\"></dbx-searchable-field-autocomplete-item>\n  </mat-option>\n  <!-- Add/Pick String Value -->\n  <mat-option *ngIf=\"allowStringValues && (inputValue$ | async)\" [value]=\"{ value: (inputValue$ | async) }\">\n    <p class=\"dbx-clear-hint text-center\">\"{{ inputValue$ | async }}\"</p>\n  </mat-option>\n  <!-- Show clear value -->\n  <mat-option *ngIf=\"showClearValue && (hasValue$ | async)\" value=\"\">\n    <p class=\"dbx-clear-hint text-center\">Clear</p>\n  </mat-option>\n</mat-autocomplete>\n"]}
@@ -89,7 +89,9 @@ export class DbxFormMapboxLatLngFieldComponent extends FieldType {
89
89
  this._sub.subscription = this.dbxMapboxMapStore.center$.subscribe((center) => {
90
90
  this.dbxMapboxMapStore.centerGivenMargin$.pipe(first()).subscribe(() => {
91
91
  if (!this.isReadonlyOrDisabled) {
92
- this.ngZone.run(() => this.setValue(center));
92
+ this.ngZone.run(() => {
93
+ this.setValue(center);
94
+ });
93
95
  }
94
96
  });
95
97
  });
@@ -119,6 +121,8 @@ export class DbxFormMapboxLatLngFieldComponent extends FieldType {
119
121
  }
120
122
  setValue(latLng) {
121
123
  this.formControl.setValue(latLng ? this._latLngStringFunction(latLng) : latLng);
124
+ this.formControl.markAsTouched();
125
+ this.formControl.markAsDirty();
122
126
  }
123
127
  }
124
128
  DbxFormMapboxLatLngFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.GeolocationService }, { token: i3.DbxMapboxMapStore }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
@@ -163,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
163
167
  }], ctorParameters: function () { return [{ type: i1.CompactContextStore, decorators: [{
164
168
  type: Optional
165
169
  }] }, { type: i2.GeolocationService }, { type: i3.DbxMapboxMapStore }, { type: i0.NgZone }]; } });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"latlng.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/mapbox/src/lib/field/latlng/latlng.field.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC1E,OAAO,EAAE,SAAS,EAAE,MAAM,EAAqB,QAAQ,EAAE,MAAM,eAAe,CAAC;AAE/E,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,EAAE,WAAW,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAc,YAAY,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AACzI,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAChE,OAAO,EAAuE,oBAAoB,EAAgB,mBAAmB,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,MAAM,eAAe,CAAC;AACvM,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAE9D,OAAO,EAAE,iBAAiB,EAAiC,uCAAuC,EAAE,MAAM,yBAAyB,CAAC;;;;;;;;;;;;AA4CpI,MAAM,OAAO,iCAA6H,SAAQ,SAA6B;IAuC7K,YAAiC,OAA4B,EAAmB,YAAgC,EAAW,iBAAoC,EAAW,MAAc;QACtL,KAAK,EAAE,CAAC;QADuB,YAAO,GAAP,OAAO,CAAqB;QAAmB,iBAAY,GAAZ,YAAY,CAAoB;QAAW,sBAAiB,GAAjB,iBAAiB,CAAmB;QAAW,WAAM,GAAN,MAAM,CAAQ;QArChL,yBAAoB,GAAG,mBAAmB,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;QAE5E,kBAAa,GAAG,iBAAiB,CAAC,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE;YAC9D,OAAO,EAAE,gCAAgC;SAC1C,CAAC,CAAC;QAEK,SAAI,GAAG,IAAI,kBAAkB,EAAE,CAAC;QAChC,YAAO,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACnC,eAAU,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACtC,UAAK,GAAG,IAAI,eAAe,CAAkB,EAAE,CAAC,CAAC;QAEjD,oBAAe,GAAG,IAAI,eAAe,CAAyB,SAAS,CAAC,CAAC;QACxE,iBAAY,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAExD,WAAM,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CACtC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAC3E,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,YAAO,GAA4B,IAAI,CAAC,MAAM,CAAC,IAAI,CAC1D,WAAW,EAAE,EACb,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,EACxC,WAAW,CAAC,CAAC,CAAC,CACf,CAAC;QAEO,YAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI;QAClC;;;;WAIG;QACH,SAAS,CAAC,oBAAoB,CAAC,EAC/B,MAAM,CAAC,kBAAkB,CAAC,CAC3B,CAAC;QAEO,UAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;IAI3C,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,GAAa,CAAC;IAClC,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,IAAiB,CAAC;IAChC,CAAC;IAED,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC;IACjC,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC;IAChC,CAAC;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC;IAC9C,CAAC;IAED,IAAI,OAAO;QACT,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,IAAI,IAAI,CAAC;IAC1C,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,IAAI,EAAE,GAAG,IAAI,CAAC;IACpD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,qBAAqB,GAAG,oBAAoB,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,IAAI,IAAI,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,QAAQ,IAAI,KAAK,EAAE,CAAC,CAAC;QACxM,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC5C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE3B,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAE/C,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,mCAAmC;YACnC,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAE3C,wBAAwB;YACxB,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE;gBACzB,IAAI,CAAC,UAAU,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;oBACzK,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAC3B,IAAI,CAAC,OAAO,CAAC,IAAI,CACf,KAAK,EAAE,EACP,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAmB,CAAA,CAAC,CAC5C,CACF,CAAC;gBACJ,CAAC,CAAC,CAAC;aACJ;SACF;aAAM;YACL,6CAA6C;YAC7C,IAAI,CAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC3E,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;oBACrE,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE;wBAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;qBAC9C;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;YACvB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;SAC5B;IACH,CAAC;IAEQ,WAAW;QAClB,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;QACpB,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QACtB,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;QAChC,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAC;IAC5B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACjF,IAAI,QAAQ,EAAE;gBACZ,MAAM,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,QAAQ,CAAC,MAAM,CAAC;gBAC1D,IAAI,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;aAC7B;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,eAAe,CAAC,MAAc;QAC5B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;IACpC,CAAC;IAED,QAAQ,CAAC,MAA2B;QAClC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IAClF,CAAC;;+HAzIU,iCAAiC;mHAAjC,iCAAiC,uCAHjC,CAAC,uCAAuC,EAAE,CAAC,iDAlB5C;;;;;;;;;;;;;;;;;GAiBT;4FAIU,iCAAiC;kBAtB7C,SAAS;+BACE;;;;;;;;;;;;;;;;;GAiBT,aACU,CAAC,uCAAuC,EAAE,CAAC;;0BA0CzC,QAAQ","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';\nimport { Component, NgZone, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { skip, first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map, Observable, throttleTime, skipWhile } from 'rxjs';\nimport { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { Maybe, LatLngPoint, LatLngPointFunctionConfig, LatLngStringFunction, latLngStringFunction, Milliseconds, latLngPointFunction, isDefaultLatLngPoint, isValidLatLngPoint } from '@dereekb/util';\nimport { GeolocationService } from '@ng-web-apis/geolocation';\nimport { Marker } from 'mapbox-gl';\nimport { DbxMapboxMapStore, MapboxEaseTo, MapboxZoomLevel, provideMapboxStoreIfParentIsUnavailable } from '@dereekb/dbx-web/mapbox';\n\nexport interface DbxFormMapboxLatLngComponentFieldProps extends FormlyFieldProps {\n  /**\n   * (Optional) Whether or not the show the map. If the map is not shown, relies on the center of the parent map to determine position.\n   *\n   * Defaults to true.\n   *\n   * Cases where this would be set false is if another map is being used.\n   */\n  showMap?: boolean;\n  /**\n   * (Optional) Zoom to start the map at. Ignored if the showMap is false.\n   */\n  zoom?: MapboxZoomLevel;\n  /**\n   * Time until recentering on the marker. If the time is 0 then the recentering is disabled.\n   */\n  recenterTime?: Milliseconds;\n  latLngConfig?: LatLngPointFunctionConfig;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-mapbox-input-field\" [ngClass]=\"(compactClass$ | async) ?? ''\" [formGroup]=\"formGroup\">\n      <div *ngIf=\"showMap\" class=\"dbx-mapbox-input-field-map\">\n        <mgl-map dbxMapboxMap>\n          <mgl-marker [lngLat]=\"(latLng$ | async) || [0, 0]\" [draggable]=\"!isReadonlyOrDisabled\" (markerDragEnd)=\"onMarkerDragEnd($event)\"></mgl-marker>\n        </mgl-map>\n      </div>\n      <div class=\"dbx-mapbox-input-field-input\">\n        <button mat-icon-button (click)=\"useCurrentLocation()\" [disabled]=\"isReadonlyOrDisabled\">\n          <mat-icon>my_location</mat-icon>\n        </button>\n        <mat-form-field class=\"dbx-mapbox-input-field-input-field\">\n          <mat-label>Coordinates</mat-label>\n          <input type=\"text\" matInput [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n        </mat-form-field>\n      </div>\n    </div>\n  `,\n  providers: [provideMapboxStoreIfParentIsUnavailable()],\n  styleUrls: ['../mapbox.field.component.scss']\n})\nexport class DbxFormMapboxLatLngFieldComponent<T extends DbxFormMapboxLatLngComponentFieldProps = DbxFormMapboxLatLngComponentFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _latLngStringFunction!: LatLngStringFunction;\n  private _latLngPointFunction = latLngPointFunction({ wrap: false, validate: false });\n\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-mapbox-input-field-compact'\n  });\n\n  private _sub = new SubscriptionObject();\n  private _geoSub = new SubscriptionObject();\n  private _centerSub = new SubscriptionObject();\n  private _zoom = new BehaviorSubject<MapboxZoomLevel>(12);\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly latLng$: Observable<LatLngPoint> = this.value$.pipe(\n    filterMaybe(),\n    map((x) => this._latLngPointFunction(x)),\n    shareReplay(1)\n  );\n\n  readonly center$ = this.latLng$.pipe(\n    /**\n     * Center observable passed to the store. Do not pass invalid points.\n     *\n     * Also skip any initial 0,0 values so the center doesn't potentially \"whip\" from 0,0 to a final loaded value.\n     */\n    skipWhile(isDefaultLatLngPoint),\n    filter(isValidLatLngPoint)\n  );\n\n  readonly zoom$ = this._zoom.asObservable();\n\n  constructor(@Optional() readonly compact: CompactContextStore, private readonly geolocation$: GeolocationService, readonly dbxMapboxMapStore: DbxMapboxMapStore, readonly ngZone: NgZone) {\n    super();\n  }\n\n  get zoom(): MapboxZoomLevel {\n    return Math.min(this.field.props.zoom || 12, 18);\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  get showMap(): boolean {\n    return this.field.props.showMap ?? true;\n  }\n\n  get recenterTime(): Milliseconds {\n    return this.field.props.recenterTime || 10 * 1000;\n  }\n\n  ngOnInit(): void {\n    this._latLngStringFunction = latLngStringFunction({ ...this.field.props.latLngConfig, wrap: this.field.props.latLngConfig?.wrap || false, validate: this.field.props.latLngConfig?.validate || false });\n    this._formControlObs.next(this.formControl);\n    this._zoom.next(this.zoom);\n\n    this.dbxMapboxMapStore.setCenter(this.center$);\n\n    if (this.showMap) {\n      // Set zoom only if showMap is true\n      this.dbxMapboxMapStore.setZoom(this.zoom$);\n\n      // recenter periodically\n      if (this.recenterTime > 0) {\n        this._centerSub.subscription = this.dbxMapboxMapStore.center$.pipe(skip(1), throttleTime(this.recenterTime, undefined, { leading: false, trailing: true })).subscribe(() => {\n          this.dbxMapboxMapStore.easeTo(\n            this.center$.pipe(\n              first(),\n              map((x) => ({ center: x } as MapboxEaseTo))\n            )\n          );\n        });\n      }\n    } else {\n      // use the center of the map to set locations\n      this._sub.subscription = this.dbxMapboxMapStore.center$.subscribe((center) => {\n        this.dbxMapboxMapStore.centerGivenMargin$.pipe(first()).subscribe(() => {\n          if (!this.isReadonlyOrDisabled) {\n            this.ngZone.run(() => this.setValue(center));\n          }\n        });\n      });\n    }\n\n    if (this.props.readonly) {\n      this.formControl.disable();\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._sub.destroy();\n    this._geoSub.destroy();\n    this._zoom.complete();\n    this._formControlObs.complete();\n    this._centerSub.destroy();\n  }\n\n  useCurrentLocation() {\n    this._geoSub.subscription = this.geolocation$.pipe(first()).subscribe((position) => {\n      if (position) {\n        const { latitude: lat, longitude: lng } = position.coords;\n        this.setValue({ lat, lng });\n      }\n    });\n  }\n\n  onMarkerDragEnd(marker: Marker) {\n    this.setValue(marker.getLngLat());\n  }\n\n  setValue(latLng?: Maybe<LatLngPoint>) {\n    this.formControl.setValue(latLng ? this._latLngStringFunction(latLng) : latLng);\n  }\n}\n"]}
170
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"latlng.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/mapbox/src/lib/field/latlng/latlng.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';\nimport { Component, NgZone, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { skip, first, BehaviorSubject, filter, shareReplay, startWith, switchMap, map, Observable, throttleTime, skipWhile } from 'rxjs';\nimport { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { Maybe, LatLngPoint, LatLngPointFunctionConfig, LatLngStringFunction, latLngStringFunction, Milliseconds, latLngPointFunction, isDefaultLatLngPoint, isValidLatLngPoint } from '@dereekb/util';\nimport { GeolocationService } from '@ng-web-apis/geolocation';\nimport { Marker } from 'mapbox-gl';\nimport { DbxMapboxMapStore, MapboxEaseTo, MapboxZoomLevel, provideMapboxStoreIfParentIsUnavailable } from '@dereekb/dbx-web/mapbox';\n\nexport interface DbxFormMapboxLatLngComponentFieldProps extends FormlyFieldProps {\n  /**\n   * (Optional) Whether or not the show the map. If the map is not shown, relies on the center of the parent map to determine position.\n   *\n   * Defaults to true.\n   *\n   * Cases where this would be set false is if another map is being used.\n   */\n  showMap?: boolean;\n  /**\n   * (Optional) Zoom to start the map at. Ignored if the showMap is false.\n   */\n  zoom?: MapboxZoomLevel;\n  /**\n   * Time until recentering on the marker. If the time is 0 then the recentering is disabled.\n   */\n  recenterTime?: Milliseconds;\n  latLngConfig?: LatLngPointFunctionConfig;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-mapbox-input-field\" [ngClass]=\"(compactClass$ | async) ?? ''\" [formGroup]=\"formGroup\">\n      <div *ngIf=\"showMap\" class=\"dbx-mapbox-input-field-map\">\n        <mgl-map dbxMapboxMap>\n          <mgl-marker [lngLat]=\"(latLng$ | async) || [0, 0]\" [draggable]=\"!isReadonlyOrDisabled\" (markerDragEnd)=\"onMarkerDragEnd($event)\"></mgl-marker>\n        </mgl-map>\n      </div>\n      <div class=\"dbx-mapbox-input-field-input\">\n        <button mat-icon-button (click)=\"useCurrentLocation()\" [disabled]=\"isReadonlyOrDisabled\">\n          <mat-icon>my_location</mat-icon>\n        </button>\n        <mat-form-field class=\"dbx-mapbox-input-field-input-field\">\n          <mat-label>Coordinates</mat-label>\n          <input type=\"text\" matInput [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n        </mat-form-field>\n      </div>\n    </div>\n  `,\n  providers: [provideMapboxStoreIfParentIsUnavailable()],\n  styleUrls: ['../mapbox.field.component.scss']\n})\nexport class DbxFormMapboxLatLngFieldComponent<T extends DbxFormMapboxLatLngComponentFieldProps = DbxFormMapboxLatLngComponentFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _latLngStringFunction!: LatLngStringFunction;\n  private _latLngPointFunction = latLngPointFunction({ wrap: false, validate: false });\n\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-mapbox-input-field-compact'\n  });\n\n  private _sub = new SubscriptionObject();\n  private _geoSub = new SubscriptionObject();\n  private _centerSub = new SubscriptionObject();\n  private _zoom = new BehaviorSubject<MapboxZoomLevel>(12);\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly latLng$: Observable<LatLngPoint> = this.value$.pipe(\n    filterMaybe(),\n    map((x) => this._latLngPointFunction(x)),\n    shareReplay(1)\n  );\n\n  readonly center$ = this.latLng$.pipe(\n    /**\n     * Center observable passed to the store. Do not pass invalid points.\n     *\n     * Also skip any initial 0,0 values so the center doesn't potentially \"whip\" from 0,0 to a final loaded value.\n     */\n    skipWhile(isDefaultLatLngPoint),\n    filter(isValidLatLngPoint)\n  );\n\n  readonly zoom$ = this._zoom.asObservable();\n\n  constructor(@Optional() readonly compact: CompactContextStore, private readonly geolocation$: GeolocationService, readonly dbxMapboxMapStore: DbxMapboxMapStore, readonly ngZone: NgZone) {\n    super();\n  }\n\n  get zoom(): MapboxZoomLevel {\n    return Math.min(this.field.props.zoom || 12, 18);\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  get showMap(): boolean {\n    return this.field.props.showMap ?? true;\n  }\n\n  get recenterTime(): Milliseconds {\n    return this.field.props.recenterTime || 10 * 1000;\n  }\n\n  ngOnInit(): void {\n    this._latLngStringFunction = latLngStringFunction({ ...this.field.props.latLngConfig, wrap: this.field.props.latLngConfig?.wrap || false, validate: this.field.props.latLngConfig?.validate || false });\n    this._formControlObs.next(this.formControl);\n    this._zoom.next(this.zoom);\n\n    this.dbxMapboxMapStore.setCenter(this.center$);\n\n    if (this.showMap) {\n      // Set zoom only if showMap is true\n      this.dbxMapboxMapStore.setZoom(this.zoom$);\n\n      // recenter periodically\n      if (this.recenterTime > 0) {\n        this._centerSub.subscription = this.dbxMapboxMapStore.center$.pipe(skip(1), throttleTime(this.recenterTime, undefined, { leading: false, trailing: true })).subscribe(() => {\n          this.dbxMapboxMapStore.easeTo(\n            this.center$.pipe(\n              first(),\n              map((x) => ({ center: x } as MapboxEaseTo))\n            )\n          );\n        });\n      }\n    } else {\n      // use the center of the map to set locations\n      this._sub.subscription = this.dbxMapboxMapStore.center$.subscribe((center) => {\n        this.dbxMapboxMapStore.centerGivenMargin$.pipe(first()).subscribe(() => {\n          if (!this.isReadonlyOrDisabled) {\n            this.ngZone.run(() => {\n              this.setValue(center);\n            });\n          }\n        });\n      });\n    }\n\n    if (this.props.readonly) {\n      this.formControl.disable();\n    }\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._sub.destroy();\n    this._geoSub.destroy();\n    this._zoom.complete();\n    this._formControlObs.complete();\n    this._centerSub.destroy();\n  }\n\n  useCurrentLocation() {\n    this._geoSub.subscription = this.geolocation$.pipe(first()).subscribe((position) => {\n      if (position) {\n        const { latitude: lat, longitude: lng } = position.coords;\n        this.setValue({ lat, lng });\n      }\n    });\n  }\n\n  onMarkerDragEnd(marker: Marker) {\n    this.setValue(marker.getLngLat());\n  }\n\n  setValue(latLng?: Maybe<LatLngPoint>) {\n    this.formControl.setValue(latLng ? this._latLngStringFunction(latLng) : latLng);\n    this.formControl.markAsTouched();\n    this.formControl.markAsDirty();\n  }\n}\n"]}
@@ -53,6 +53,9 @@ export class DbxFormMapboxZoomFieldComponent extends FieldType {
53
53
  get showMap() {
54
54
  return this.field.props.showMap ?? true;
55
55
  }
56
+ get lockMapToZoomLevels() {
57
+ return this.field.props.lockMapToZoomLevels ?? false;
58
+ }
56
59
  get minZoom() {
57
60
  return mapboxZoomLevel(this.field.props.minZoom || MAPBOX_MIN_ZOOM_LEVEL);
58
61
  }
@@ -79,8 +82,8 @@ export class DbxFormMapboxZoomFieldComponent extends FieldType {
79
82
  this.dbxMapboxMapStore.setZoomDisabled();
80
83
  }
81
84
  }
82
- else {
83
- // set zoom limits
85
+ else if (this.lockMapToZoomLevels) {
86
+ // set zoom limits on the map
84
87
  this.dbxMapboxMapStore.setZoomRange({ min: this.minZoom, max: this.maxZoom });
85
88
  // flat to undo them later if not using the same map
86
89
  this._undoZoomLimit = !this.showMap;
@@ -104,6 +107,8 @@ export class DbxFormMapboxZoomFieldComponent extends FieldType {
104
107
  }
105
108
  setValue(zoom) {
106
109
  this.formControl.setValue(zoom);
110
+ this.formControl.markAsTouched();
111
+ this.formControl.markAsDirty();
107
112
  }
108
113
  }
109
114
  DbxFormMapboxZoomFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxZoomFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.DbxMapboxService }, { token: i2.DbxMapboxMapStore }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
@@ -138,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
138
143
  }], ctorParameters: function () { return [{ type: i1.CompactContextStore, decorators: [{
139
144
  type: Optional
140
145
  }] }, { type: i2.DbxMapboxService }, { type: i2.DbxMapboxMapStore }, { type: i0.NgZone }]; } });
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zoom.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/mapbox/src/lib/field/zoom/zoom.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';\nimport { Component, NgZone, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { BehaviorSubject, shareReplay, startWith, switchMap, Observable } from 'rxjs';\nimport { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { ZoomLevel, Maybe, LatLngPoint, latLngPoint } from '@dereekb/util';\nimport { DbxMapboxService, DbxMapboxMapStore, MapboxZoomLevel, provideMapboxStoreIfParentIsUnavailable, mapboxZoomLevel, MAPBOX_MAX_ZOOM_LEVEL, MAPBOX_MIN_ZOOM_LEVEL } from '@dereekb/dbx-web/mapbox';\n\nexport interface DbxFormMapboxZoomComponentFieldProps extends Omit<FormlyFieldProps, 'min' | 'max'> {\n  /**\n   * (Optional) Whether or not the show the map. Cases where this would be set false is if another map is being used.\n   *\n   * Defaults to true.\n   */\n  showMap?: boolean;\n  /**\n   * Default center\n   */\n  center?: LatLngPoint;\n  /**\n   * Min zoom level allowed\n   */\n  minZoom?: MapboxZoomLevel;\n  /**\n   * Max zoom level allowed.\n   */\n  maxZoom?: MapboxZoomLevel;\n  /**\n   * Step size when using arrow keys.\n   */\n  zoomStep?: number;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-mapbox-input-field\" [ngClass]=\"(compactClass$ | async) ?? ''\" [formGroup]=\"formGroup\">\n      <div *ngIf=\"showMap\" class=\"dbx-mapbox-input-field-map\">\n        <mgl-map dbxMapboxMap></mgl-map>\n      </div>\n      <div class=\"dbx-mapbox-input-field-input\">\n        <mat-form-field class=\"dbx-mapbox-input-field-input-field\">\n          <mat-label>Zoom Level</mat-label>\n          <input type=\"number\" matInput [min]=\"minZoom\" [max]=\"maxZoom\" [step]=\"zoomStep\" [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n        </mat-form-field>\n      </div>\n    </div>\n  `,\n  providers: [provideMapboxStoreIfParentIsUnavailable()],\n  styleUrls: ['../mapbox.field.component.scss']\n})\nexport class DbxFormMapboxZoomFieldComponent<T extends DbxFormMapboxZoomComponentFieldProps = DbxFormMapboxZoomComponentFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _undoZoomLimit = false;\n\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-mapbox-input-field-compact'\n  });\n\n  private _sub = new SubscriptionObject();\n  private _center = new BehaviorSubject<Maybe<LatLngPoint>>(undefined);\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly zoom$: Observable<MapboxZoomLevel> = this.value$.pipe(filterMaybe(), shareReplay(1));\n  readonly center$ = this._center.pipe(filterMaybe());\n\n  constructor(@Optional() readonly compact: CompactContextStore, readonly dbxMapboxService: DbxMapboxService, readonly dbxMapboxMapStore: DbxMapboxMapStore, readonly ngZone: NgZone) {\n    super();\n  }\n\n  get center(): LatLngPoint {\n    return this.field.props.center || latLngPoint(this.dbxMapboxService.defaultCenter);\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  get showMap(): boolean {\n    return this.field.props.showMap ?? true;\n  }\n\n  get minZoom(): MapboxZoomLevel {\n    return mapboxZoomLevel(this.field.props.minZoom || MAPBOX_MIN_ZOOM_LEVEL);\n  }\n\n  get maxZoom(): MapboxZoomLevel {\n    return mapboxZoomLevel(this.field.props.maxZoom || MAPBOX_MAX_ZOOM_LEVEL);\n  }\n\n  get zoomStep(): number {\n    return mapboxZoomLevel(this.field.props.zoomStep || 1);\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n    this._center.next(this.center);\n\n    // set/sync props for error messages\n    (this.props as FormlyFieldProps).min = this.minZoom;\n    (this.props as FormlyFieldProps).max = this.maxZoom;\n\n    this.dbxMapboxMapStore.setZoom(this.zoom$);\n\n    // Set center only if showMap is false.\n    if (this.showMap) {\n      this.dbxMapboxMapStore.setCenter(this.center$);\n    }\n\n    if (this.props.readonly) {\n      this.formControl.disable();\n\n      if (this.showMap) {\n        this.dbxMapboxMapStore.setZoomDisabled();\n      }\n    } else {\n      // set zoom limits\n      this.dbxMapboxMapStore.setZoomRange({ min: this.minZoom, max: this.maxZoom });\n\n      // flat to undo them later if not using the same map\n      this._undoZoomLimit = !this.showMap;\n    }\n\n    this._sub.subscription = this.dbxMapboxMapStore.zoom$.subscribe((zoom) => {\n      if (!this.isReadonlyOrDisabled) {\n        this.ngZone.run(() => {\n          this.setValue(zoom);\n        });\n      }\n    });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._formControlObs.complete();\n    this._center.complete();\n    this._sub.destroy();\n\n    if (!this._undoZoomLimit) {\n      this.dbxMapboxMapStore.setZoomRange({});\n    }\n  }\n\n  setValue(zoom?: Maybe<ZoomLevel>) {\n    this.formControl.setValue(zoom);\n  }\n}\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zoom.field.component.js","sourceRoot":"","sources":["../../../../../../../../packages/dbx-form/mapbox/src/lib/field/zoom/zoom.field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AbstractControl, FormGroup } from '@angular/forms';\nimport { CompactContextStore, mapCompactModeObs } from '@dereekb/dbx-web';\nimport { Component, NgZone, OnDestroy, OnInit, Optional } from '@angular/core';\nimport { FieldTypeConfig, FormlyFieldProps } from '@ngx-formly/core';\nimport { FieldType } from '@ngx-formly/material';\nimport { BehaviorSubject, shareReplay, startWith, switchMap, Observable } from 'rxjs';\nimport { filterMaybe, SubscriptionObject } from '@dereekb/rxjs';\nimport { ZoomLevel, Maybe, LatLngPoint, latLngPoint } from '@dereekb/util';\nimport { DbxMapboxService, DbxMapboxMapStore, MapboxZoomLevel, provideMapboxStoreIfParentIsUnavailable, mapboxZoomLevel, MAPBOX_MAX_ZOOM_LEVEL, MAPBOX_MIN_ZOOM_LEVEL } from '@dereekb/dbx-web/mapbox';\n\nexport interface DbxFormMapboxZoomComponentFieldProps extends Omit<FormlyFieldProps, 'min' | 'max'> {\n  /**\n   * (Optional) Whether or not the show the map. Cases where this would be set false is if another map is being used.\n   *\n   * Defaults to true.\n   */\n  showMap?: boolean;\n  /**\n   * Default center\n   */\n  center?: LatLngPoint;\n  /**\n   * Whether or not to lock the map itself to the min and max zoom levels.\n   */\n  lockMapToZoomLevels?: boolean;\n  /**\n   * Min zoom level allowed\n   */\n  minZoom?: MapboxZoomLevel;\n  /**\n   * Max zoom level allowed.\n   */\n  maxZoom?: MapboxZoomLevel;\n  /**\n   * Step size when using arrow keys.\n   */\n  zoomStep?: number;\n}\n\n@Component({\n  template: `\n    <div class=\"dbx-mapbox-input-field\" [ngClass]=\"(compactClass$ | async) ?? ''\" [formGroup]=\"formGroup\">\n      <div *ngIf=\"showMap\" class=\"dbx-mapbox-input-field-map\">\n        <mgl-map dbxMapboxMap></mgl-map>\n      </div>\n      <div class=\"dbx-mapbox-input-field-input\">\n        <mat-form-field class=\"dbx-mapbox-input-field-input-field\">\n          <mat-label>Zoom Level</mat-label>\n          <input type=\"number\" matInput [min]=\"minZoom\" [max]=\"maxZoom\" [step]=\"zoomStep\" [placeholder]=\"placeholder\" [formControl]=\"formControl\" />\n        </mat-form-field>\n      </div>\n    </div>\n  `,\n  providers: [provideMapboxStoreIfParentIsUnavailable()],\n  styleUrls: ['../mapbox.field.component.scss']\n})\nexport class DbxFormMapboxZoomFieldComponent<T extends DbxFormMapboxZoomComponentFieldProps = DbxFormMapboxZoomComponentFieldProps> extends FieldType<FieldTypeConfig<T>> implements OnInit, OnDestroy {\n  private _undoZoomLimit = false;\n\n  readonly compactClass$ = mapCompactModeObs(this.compact?.mode$, {\n    compact: 'dbx-mapbox-input-field-compact'\n  });\n\n  private _sub = new SubscriptionObject();\n  private _center = new BehaviorSubject<Maybe<LatLngPoint>>(undefined);\n\n  private _formControlObs = new BehaviorSubject<Maybe<AbstractControl>>(undefined);\n  readonly formControl$ = this._formControlObs.pipe(filterMaybe());\n\n  readonly value$ = this.formControl$.pipe(\n    switchMap((control) => control.valueChanges.pipe(startWith(control.value))),\n    shareReplay(1)\n  );\n\n  readonly zoom$: Observable<MapboxZoomLevel> = this.value$.pipe(filterMaybe(), shareReplay(1));\n  readonly center$ = this._center.pipe(filterMaybe());\n\n  constructor(@Optional() readonly compact: CompactContextStore, readonly dbxMapboxService: DbxMapboxService, readonly dbxMapboxMapStore: DbxMapboxMapStore, readonly ngZone: NgZone) {\n    super();\n  }\n\n  get center(): LatLngPoint {\n    return this.field.props.center || latLngPoint(this.dbxMapboxService.defaultCenter);\n  }\n\n  get formGroupName(): string {\n    return this.field.key as string;\n  }\n\n  get formGroup(): FormGroup {\n    return this.form as FormGroup;\n  }\n\n  get label(): Maybe<string> {\n    return this.field.props?.label;\n  }\n\n  get description(): Maybe<string> {\n    return this.props.description;\n  }\n\n  get isReadonlyOrDisabled() {\n    return this.props.readonly || this.disabled;\n  }\n\n  get showMap(): boolean {\n    return this.field.props.showMap ?? true;\n  }\n\n  get lockMapToZoomLevels(): boolean {\n    return this.field.props.lockMapToZoomLevels ?? false;\n  }\n\n  get minZoom(): MapboxZoomLevel {\n    return mapboxZoomLevel(this.field.props.minZoom || MAPBOX_MIN_ZOOM_LEVEL);\n  }\n\n  get maxZoom(): MapboxZoomLevel {\n    return mapboxZoomLevel(this.field.props.maxZoom || MAPBOX_MAX_ZOOM_LEVEL);\n  }\n\n  get zoomStep(): number {\n    return mapboxZoomLevel(this.field.props.zoomStep || 1);\n  }\n\n  ngOnInit(): void {\n    this._formControlObs.next(this.formControl);\n    this._center.next(this.center);\n\n    // set/sync props for error messages\n    (this.props as FormlyFieldProps).min = this.minZoom;\n    (this.props as FormlyFieldProps).max = this.maxZoom;\n\n    this.dbxMapboxMapStore.setZoom(this.zoom$);\n\n    // Set center only if showMap is false.\n    if (this.showMap) {\n      this.dbxMapboxMapStore.setCenter(this.center$);\n    }\n\n    if (this.props.readonly) {\n      this.formControl.disable();\n\n      if (this.showMap) {\n        this.dbxMapboxMapStore.setZoomDisabled();\n      }\n    } else if (this.lockMapToZoomLevels) {\n      // set zoom limits on the map\n      this.dbxMapboxMapStore.setZoomRange({ min: this.minZoom, max: this.maxZoom });\n\n      // flat to undo them later if not using the same map\n      this._undoZoomLimit = !this.showMap;\n    }\n\n    this._sub.subscription = this.dbxMapboxMapStore.zoom$.subscribe((zoom) => {\n      if (!this.isReadonlyOrDisabled) {\n        this.ngZone.run(() => {\n          this.setValue(zoom);\n        });\n      }\n    });\n  }\n\n  override ngOnDestroy(): void {\n    super.ngOnDestroy();\n    this._formControlObs.complete();\n    this._center.complete();\n    this._sub.destroy();\n\n    if (!this._undoZoomLimit) {\n      this.dbxMapboxMapStore.setZoomRange({});\n    }\n  }\n\n  setValue(zoom?: Maybe<ZoomLevel>) {\n    this.formControl.setValue(zoom);\n    this.formControl.markAsTouched();\n    this.formControl.markAsDirty();\n  }\n}\n"]}
@@ -124,7 +124,9 @@ class DbxFormMapboxLatLngFieldComponent extends FieldType {
124
124
  this._sub.subscription = this.dbxMapboxMapStore.center$.subscribe((center) => {
125
125
  this.dbxMapboxMapStore.centerGivenMargin$.pipe(first()).subscribe(() => {
126
126
  if (!this.isReadonlyOrDisabled) {
127
- this.ngZone.run(() => this.setValue(center));
127
+ this.ngZone.run(() => {
128
+ this.setValue(center);
129
+ });
128
130
  }
129
131
  });
130
132
  });
@@ -154,6 +156,8 @@ class DbxFormMapboxLatLngFieldComponent extends FieldType {
154
156
  }
155
157
  setValue(latLng) {
156
158
  this.formControl.setValue(latLng ? this._latLngStringFunction(latLng) : latLng);
159
+ this.formControl.markAsTouched();
160
+ this.formControl.markAsDirty();
157
161
  }
158
162
  }
159
163
  DbxFormMapboxLatLngFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxLatLngFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2.GeolocationService }, { token: i2$1.DbxMapboxMapStore }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
@@ -305,6 +309,10 @@ class DbxFormMapboxZoomFieldComponent extends FieldType {
305
309
  var _a;
306
310
  return (_a = this.field.props.showMap) !== null && _a !== void 0 ? _a : true;
307
311
  }
312
+ get lockMapToZoomLevels() {
313
+ var _a;
314
+ return (_a = this.field.props.lockMapToZoomLevels) !== null && _a !== void 0 ? _a : false;
315
+ }
308
316
  get minZoom() {
309
317
  return mapboxZoomLevel(this.field.props.minZoom || MAPBOX_MIN_ZOOM_LEVEL);
310
318
  }
@@ -331,8 +339,8 @@ class DbxFormMapboxZoomFieldComponent extends FieldType {
331
339
  this.dbxMapboxMapStore.setZoomDisabled();
332
340
  }
333
341
  }
334
- else {
335
- // set zoom limits
342
+ else if (this.lockMapToZoomLevels) {
343
+ // set zoom limits on the map
336
344
  this.dbxMapboxMapStore.setZoomRange({ min: this.minZoom, max: this.maxZoom });
337
345
  // flat to undo them later if not using the same map
338
346
  this._undoZoomLimit = !this.showMap;
@@ -356,6 +364,8 @@ class DbxFormMapboxZoomFieldComponent extends FieldType {
356
364
  }
357
365
  setValue(zoom) {
358
366
  this.formControl.setValue(zoom);
367
+ this.formControl.markAsTouched();
368
+ this.formControl.markAsDirty();
359
369
  }
360
370
  }
361
371
  DbxFormMapboxZoomFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: DbxFormMapboxZoomFieldComponent, deps: [{ token: i1.CompactContextStore, optional: true }, { token: i2$1.DbxMapboxService }, { token: i2$1.DbxMapboxMapStore }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });