@elderbyte/ngx-starter 15.6.1 → 15.6.2
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.
- package/esm2020/lib/common/forms/elder-form-field-control-base.directive.mjs +4 -1
- package/fesm2015/elderbyte-ngx-starter.mjs +3 -1
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +3 -1
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -80,18 +80,21 @@ export class ElderFormFieldControlBase extends ValueAccessorBase {
|
|
|
80
80
|
}
|
|
81
81
|
set required(value) {
|
|
82
82
|
this._required = coerceBooleanProperty(value);
|
|
83
|
+
this.emitStateChange();
|
|
83
84
|
}
|
|
84
85
|
get required() {
|
|
85
86
|
return this._required;
|
|
86
87
|
}
|
|
87
88
|
set disabled(value) {
|
|
88
89
|
this._disabled = coerceBooleanProperty(value);
|
|
90
|
+
this.emitStateChange();
|
|
89
91
|
}
|
|
90
92
|
get disabled() {
|
|
91
93
|
return this._disabled;
|
|
92
94
|
}
|
|
93
95
|
set readonly(value) {
|
|
94
96
|
this._readonly = coerceBooleanProperty(value);
|
|
97
|
+
this.emitStateChange();
|
|
95
98
|
}
|
|
96
99
|
get readonly() {
|
|
97
100
|
return this._readonly;
|
|
@@ -175,4 +178,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImpor
|
|
|
175
178
|
}], readonly: [{
|
|
176
179
|
type: Input
|
|
177
180
|
}] } });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-form-field-control-base.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/forms/elder-form-field-control-base.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {MatFormFieldControl} from '@angular/material/form-field';\nimport {ValueAccessorBase} from './value-accessor-base';\nimport {mergeWith, Observable, Subject} from 'rxjs';\nimport {AbstractControl, AbstractControlDirective, NgControl, ValidationErrors, Validator} from '@angular/forms';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {ContentChild, Directive, ElementRef, HostBinding, Input, OnDestroy} from '@angular/core';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {FocusMonitor} from '@angular/cdk/a11y';\nimport {TranslateService} from '@ngx-translate/core';\n\n/**\n * Base for custom material form field controls.\n * https://material.angular.io/guide/creating-a-custom-form-field-control\n *\n * Implementors must provide the MatFormFieldControl:\n * providers: [{provide: MatFormFieldControl, useExisting: MyCoolInput}]\n */\n@Directive()\nexport abstract class ElderFormFieldControlBase<T>\n  extends ValueAccessorBase<T>\n  implements MatFormFieldControl<T>, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private static nextId = 0;\n\n  private readonly _focusMonitor: FocusMonitor;\n  private readonly _translate: TranslateService;\n\n  private _placeholder: string;\n  private _disabled = false;\n  private _required = false;\n  private _readonly = false;\n\n  private _focused = false;\n  private readonly stateChangePusher$ = new Subject<void>();\n\n  protected readonly destroy$ = new Subject<void>();\n\n  @HostBinding() public readonly id: string;\n  public readonly ngControl: NgControl | AbstractControlDirective | null;\n  public controlType: string;\n\n  // TODO ...\n  readonly autofilled: boolean;\n  readonly userAriaDescribedBy: string;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly hostRef: ElementRef,\n    controlType: string,\n    focusMonitor: FocusMonitor,\n    translateService: TranslateService,\n    ngControl?: NgControl\n  ) {\n    super();\n    this._focusMonitor = focusMonitor;\n    this._translate = translateService;\n    this.controlType = controlType;\n    this.ngControl = ngControl;\n    this.id = `elder-control-${this.controlType}-${ElderFormFieldControlBase.nextId++}`;\n    if (this.ngControl) {\n      ngControl.valueAccessor = this;\n    }\n    this.initFocusMonitor();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  private initFocusMonitor(): void {\n    this._focusMonitor\n      .monitor(this.hostRef, true)\n      .pipe(\n        takeUntil(this.destroy$)\n      ).subscribe(\n      focusOrigin => {\n        if (focusOrigin) {\n          this.onFocusInternal();\n        }else{\n          this.onBlurInternal();\n        }\n      }\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set placeholder(value: string) {\n    if(value){\n      this._translate.get(value).subscribe(\n        {\n          next: translated => this._placeholder = translated\n        }\n      );\n    } else {\n      this._placeholder = value;\n    }\n  }\n\n  public get placeholder(): string {\n    return this._placeholder;\n  }\n\n  @Input()\n  public set required(value: BooleanInput) {\n    this._required = coerceBooleanProperty(value);\n  }\n  public get required(): boolean {\n    return this._required;\n  }\n\n  @Input()\n  public set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanProperty(value);\n  }\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n\n  @Input()\n  public set readonly(value: BooleanInput) {\n    this._readonly = coerceBooleanProperty(value);\n  }\n  public get readonly(): boolean {\n    return this._readonly;\n  }\n\n  public get isLocked(): boolean {\n    return this._disabled || this._readonly;\n  }\n\n  public get stateChanges(): Observable<void> {\n    return this.value$.pipe(\n      map(x => <any>x),\n      mergeWith(this.stateChangePusher$)\n    );\n  }\n\n  public get errorState(): boolean {\n    return this.ngControl?.invalid && this.ngControl?.dirty;\n  }\n\n  public get empty(): boolean {\n    return (this.value === undefined) || (this.value === null) || (<any>this.value === '');\n  }\n\n  public get shouldLabelFloat(): boolean {\n    return !this.empty || this._focused;\n  }\n\n  public get focused(): boolean {\n    return this._focused;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onContainerClick(event: MouseEvent): void {\n    this.focus();\n  }\n\n  public setDescribedByIds(ids: string[]): void {\n    if (ids.length) {\n      // this._elementRef.nativeElement.setAttribute('aria-describedby', ids.join(' '));\n    } else {\n      // this._elementRef.nativeElement.removeAttribute('aria-describedby');\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Focus this control.\n   * @param options\n   */\n  public abstract focus(options?: FocusOptions): void;\n\n  /**\n   * Blur this control.\n   */\n  public abstract blur(): void;\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  protected emitStateChange(): void {\n    this.stateChangePusher$.next();\n  }\n\n  protected writeToControl(value: T): void { }\n\n  protected onFocusInternal(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.emitStateChange();\n    }\n  }\n\n  protected onBlurInternal(): void {\n    this._focused = false;\n    if (!this.disabled) {\n      // this._onTouched();\n      // this._changeDetectorRef.markForCheck();\n      this.emitStateChange();\n    }\n  }\n}\n"]}
|
|
181
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-form-field-control-base.directive.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/forms/elder-form-field-control-base.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {MatFormFieldControl} from '@angular/material/form-field';\nimport {ValueAccessorBase} from './value-accessor-base';\nimport {mergeWith, Observable, Subject} from 'rxjs';\nimport {AbstractControl, AbstractControlDirective, NgControl, ValidationErrors, Validator} from '@angular/forms';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {ContentChild, Directive, ElementRef, HostBinding, Input, OnDestroy} from '@angular/core';\nimport {BooleanInput, coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {FocusMonitor} from '@angular/cdk/a11y';\nimport {TranslateService} from '@ngx-translate/core';\n\n/**\n * Base for custom material form field controls.\n * https://material.angular.io/guide/creating-a-custom-form-field-control\n *\n * Implementors must provide the MatFormFieldControl:\n * providers: [{provide: MatFormFieldControl, useExisting: MyCoolInput}]\n */\n@Directive()\nexport abstract class ElderFormFieldControlBase<T>\n  extends ValueAccessorBase<T>\n  implements MatFormFieldControl<T>, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private static nextId = 0;\n\n  private readonly _focusMonitor: FocusMonitor;\n  private readonly _translate: TranslateService;\n\n  private _placeholder: string;\n  private _disabled = false;\n  private _required = false;\n  private _readonly = false;\n\n  private _focused = false;\n  private readonly stateChangePusher$ = new Subject<void>();\n\n  protected readonly destroy$ = new Subject<void>();\n\n  @HostBinding() public readonly id: string;\n  public readonly ngControl: NgControl | AbstractControlDirective | null;\n  public controlType: string;\n\n  // TODO ...\n  readonly autofilled: boolean;\n  readonly userAriaDescribedBy: string;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    private readonly hostRef: ElementRef,\n    controlType: string,\n    focusMonitor: FocusMonitor,\n    translateService: TranslateService,\n    ngControl?: NgControl\n  ) {\n    super();\n    this._focusMonitor = focusMonitor;\n    this._translate = translateService;\n    this.controlType = controlType;\n    this.ngControl = ngControl;\n    this.id = `elder-control-${this.controlType}-${ElderFormFieldControlBase.nextId++}`;\n    if (this.ngControl) {\n      ngControl.valueAccessor = this;\n    }\n    this.initFocusMonitor();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  private initFocusMonitor(): void {\n    this._focusMonitor\n      .monitor(this.hostRef, true)\n      .pipe(\n        takeUntil(this.destroy$)\n      ).subscribe(\n      focusOrigin => {\n        if (focusOrigin) {\n          this.onFocusInternal();\n        }else{\n          this.onBlurInternal();\n        }\n      }\n    );\n  }\n\n  public ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set placeholder(value: string) {\n    if(value){\n      this._translate.get(value).subscribe(\n        {\n          next: translated => this._placeholder = translated\n        }\n      );\n    } else {\n      this._placeholder = value;\n    }\n  }\n\n  public get placeholder(): string {\n    return this._placeholder;\n  }\n\n  @Input()\n  public set required(value: BooleanInput) {\n    this._required = coerceBooleanProperty(value);\n    this.emitStateChange();\n  }\n  public get required(): boolean {\n    return this._required;\n  }\n\n  @Input()\n  public set disabled(value: BooleanInput) {\n    this._disabled = coerceBooleanProperty(value);\n    this.emitStateChange();\n  }\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n\n  @Input()\n  public set readonly(value: BooleanInput) {\n    this._readonly = coerceBooleanProperty(value);\n    this.emitStateChange();\n  }\n  public get readonly(): boolean {\n    return this._readonly;\n  }\n\n  public get isLocked(): boolean {\n    return this._disabled || this._readonly;\n  }\n\n  public get stateChanges(): Observable<void> {\n    return this.value$.pipe(\n      map(x => <any>x),\n      mergeWith(this.stateChangePusher$)\n    );\n  }\n\n  public get errorState(): boolean {\n    return this.ngControl?.invalid && this.ngControl?.dirty;\n  }\n\n  public get empty(): boolean {\n    return (this.value === undefined) || (this.value === null) || (<any>this.value === '');\n  }\n\n  public get shouldLabelFloat(): boolean {\n    return !this.empty || this._focused;\n  }\n\n  public get focused(): boolean {\n    return this._focused;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onContainerClick(event: MouseEvent): void {\n    this.focus();\n  }\n\n  public setDescribedByIds(ids: string[]): void {\n    if (ids.length) {\n      // this._elementRef.nativeElement.setAttribute('aria-describedby', ids.join(' '));\n    } else {\n      // this._elementRef.nativeElement.removeAttribute('aria-describedby');\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Focus this control.\n   * @param options\n   */\n  public abstract focus(options?: FocusOptions): void;\n\n  /**\n   * Blur this control.\n   */\n  public abstract blur(): void;\n\n  /***************************************************************************\n   *                                                                         *\n   * Internal API                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  protected emitStateChange(): void {\n    this.stateChangePusher$.next();\n  }\n\n  protected writeToControl(value: T): void { }\n\n  protected onFocusInternal(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.emitStateChange();\n    }\n  }\n\n  protected onBlurInternal(): void {\n    this._focused = false;\n    if (!this.disabled) {\n      // this._onTouched();\n      // this._changeDetectorRef.markForCheck();\n      this.emitStateChange();\n    }\n  }\n}\n"]}
|
|
@@ -6245,18 +6245,21 @@ class ElderFormFieldControlBase extends ValueAccessorBase {
|
|
|
6245
6245
|
}
|
|
6246
6246
|
set required(value) {
|
|
6247
6247
|
this._required = coerceBooleanProperty(value);
|
|
6248
|
+
this.emitStateChange();
|
|
6248
6249
|
}
|
|
6249
6250
|
get required() {
|
|
6250
6251
|
return this._required;
|
|
6251
6252
|
}
|
|
6252
6253
|
set disabled(value) {
|
|
6253
6254
|
this._disabled = coerceBooleanProperty(value);
|
|
6255
|
+
this.emitStateChange();
|
|
6254
6256
|
}
|
|
6255
6257
|
get disabled() {
|
|
6256
6258
|
return this._disabled;
|
|
6257
6259
|
}
|
|
6258
6260
|
set readonly(value) {
|
|
6259
6261
|
this._readonly = coerceBooleanProperty(value);
|
|
6262
|
+
this.emitStateChange();
|
|
6260
6263
|
}
|
|
6261
6264
|
get readonly() {
|
|
6262
6265
|
return this._readonly;
|
|
@@ -29047,4 +29050,3 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.2", ngImpor
|
|
|
29047
29050
|
|
|
29048
29051
|
export { AuditedEntity, AutoStartSpec, BlobUrl, BytesFormat, BytesPerSecondFormat, BytesPipe, CardDropEvent, CardOrganizerData, CardStack, CollectionUtil, ComparatorBuilder, ConfirmDialogConfig, ContinuableListing, CsvColumnSpec, CsvSerializer, CsvSpec, CsvStreamExporter, CsvStreamExporterBuilder, CsvStreamExporterBuilderService, Currency, CurrencyCode, CurrencyUnit, CurrencyUnitRegistry, CustomDateAdapter, DataContextActivePage, DataContextAutoStarter, DataContextBase, DataContextBuilder, DataContextContinuableBase, DataContextContinuablePaged, DataContextContinuableToken, DataContextLifeCycleBinding, DataContextSelectionDirective, DataContextSimple, DataContextSnapshot, DataContextSourceEventBinding, DataContextStateIndicatorComponent, DataContextStatus, DataSourceAdapter, DataSourceBase, DataSourceChangeEvent, DataSourceChangeType, DataSourceProcessor, DataTransferFactory, DataTransferProgress, DataTransferProgressAggregate, DataTransferState, DataTransferStatus, DataViewIframeAdapterDirective, DataViewIframeComponent, DataViewMessage, DataViewOptionsProviderBinding, DataViewSelection, DataViewSelectionInit, DateUtil, DelegateContinuableDataSource, DelegateDataSource, DelegateListDataSource, DelegatePagedDataSource, Dimensions, DrawerOutletBinding, DurationBucket, DurationFormat, ELDER_DATA_VIEW, ELDER_SELECT_BASE, ElderAccessDeniedComponent, ElderAccessDeniedModule, ElderAppHeaderComponent, ElderAuditModule, ElderAuditedEntityComponent, ElderAutoSelectFirstDirective, ElderAutocompleteComponent, ElderAutocompleteDirective, ElderAutocompleteManyDirective, ElderAutocompleteModule, ElderBlobViewerComponent, ElderBreadCrumbsComponent, ElderBreadCrumbsModule, ElderButtonGroupComponent, ElderButtonGroupModule, ElderCardComponent, ElderCardContentDirective, ElderCardHeaderActionsDirective, ElderCardHeaderComponent, ElderCardModule, ElderCardOrganizerComponent, ElderCardOrganizerModule, ElderCardPanelComponent, ElderCardStackComponent, ElderCardSubtitleDirective, ElderCardTitleDirective, ElderCheckboxState, ElderChipLabelDirective, ElderChipListSelectComponent, ElderChipListSelectModule, ElderChipsModule, ElderClearSelectDirective, ElderClipboardPutDirective, ElderClipboardService, ElderConfirmDialogComponent, ElderConnectivityModule, ElderConnectivityService, ElderContainersModule, ElderCsvExportBtnComponent, ElderCsvModule, ElderCurrencyModule, ElderCurrencyPipe, ElderDataCommonModule, ElderDataToolbarComponent, ElderDataTransferModule, ElderDataTransferService, ElderDataViewBaseComponent, ElderDataViewOptions, ElderDataViewOptionsProvider, ElderDateSwitcherComponent, ElderDateTimeInputComponent, ElderDelayedFocusDirective, ElderDialogConfig, ElderDialogModule, ElderDialogPanelComponent, ElderDialogService, ElderDimensionsInputComponent, ElderDurationInputComponent, ElderEntityValueAccessorUtil, ElderEnumTranslationService, ElderErrorModule, ElderEventSourceService, ElderExceptionDetailComponent, ElderExpandToggleButtonComponent, ElderExpandToggleButtonModule, ElderFileDropZoneDirective, ElderFileModule, ElderFileSelectComponent, ElderFileSelectDirective, ElderFileUploadComponent, ElderFormFieldControlBase, ElderFormFieldDenseDirective, ElderFormFieldLabelDirective, ElderFormFieldNoHintDirective, ElderFormFieldNoSpinnerDirective, ElderFormsDirectivesModule, ElderFormsModule, ElderFromFieldBase, ElderFromFieldEntityBase, ElderFromFieldMultiEntityBase, ElderGlobalSearchComponent, ElderGlobalSearchModule, ElderGlobalSearchService, ElderGridComponent, ElderGridModule, ElderGridTileDirective, ElderGridToolbarDirective, ElderHeaderComponent, ElderHeaderModule, ElderHttpClient, ElderI18nEntitiesModule, ElderIFrameModule, ElderInfiniteAutocompleteDirective, ElderInfiniteScrollDirective, ElderInfiniteScrollLegacyDirective, ElderInfiniteScrollModule, ElderInputPatternDirective, ElderIntervalInputComponent, ElderKeyEventDirective, ElderLabelInputComponent, ElderLabelsModule, ElderLanguageConfig, ElderLanguageInterceptor, ElderLanguageModule, ElderLanguageService, ElderLanguageSwitcherComponent, ElderLocalDateInputComponent, ElderLocalTimeInputComponent, ElderLocalesDeChModule, ElderLocalizedInputComponent, ElderLocalizedInputDialogComponent, ElderLocalizedInputDialogService, ElderLocalizedInputTableComponent, ElderLocalizedTextColumnDirective, ElderLocalizedTextsDirective, ElderMaxValidator, ElderMeasuresModule, ElderMinValidator, ElderMultiEntityValueAccessorUtil, ElderMultiSelectBase, ElderMultiSelectChipsComponent, ElderMultiSelectFormField, ElderMultipleOfUtil, ElderMultipleOfValidator, ElderNavGroupComponent, ElderNavLinkComponent, ElderNavListComponent, ElderNavModule, ElderNextFocusableDirective, ElderNumberCellDirective, ElderOfflineIndicatorComponent, ElderOverlayComponent, ElderOverlayModule, ElderOverlayOriginDirective, ElderOverlayTriggerDirective, ElderPaddingDirective, ElderPanelComponent, ElderPanelModule, ElderPeriodInputComponent, ElderPipesModule, ElderPlugParentFormDirective, ElderProgressBarComponent, ElderProgressBarModule, ElderQuantityFormFieldComponent, ElderQuantityInputControlComponent, ElderQuantityModule, ElderQuantityPipe, ElderQuantityRangeValidator, ElderQuantityService, ElderQuantityTransformPipe, ElderQuestionDialogComponent, ElderRepeatPipe, ElderRepeatPipeLegacy, ElderRequiredDimensionsValidator, ElderRequiredIgnoreZeroValidator, ElderRequiredQuantityValidator, ElderRoundPipe, ElderRouteOutletDrawerService, ElderRouterOutletService, ElderRouterService, ElderSafeUrlPipe, ElderScrollContainerComponent, ElderScrollbarDirective, ElderScrollbarModule, ElderSearchBoxComponent, ElderSearchContextDirective, ElderSearchInputDirective, ElderSearchModule, ElderSearchPanelComponent, ElderSelectBase, ElderSelectChipAvatarDirective, ElderSelectChipDirective, ElderSelectComponent, ElderSelectComponentState, ElderSelectCustomInputDirective, ElderSelectFormField, ElderSelectModule, ElderSelectOnTabDirective, ElderSelectValueDirective, ElderSelectionDialogComponent, ElderSelectionDialogDirective, ElderSelectionMasterCheckboxComponent, ElderSelectionPopupTriggerAdapterDirective, ElderShellCenterDirective, ElderShellComponent, ElderShellModule, ElderShellNavigationToggleComponent, ElderShellService, ElderShellSideLeftDirective, ElderShellSideRightDirective, ElderShellSlotDirective, ElderSimpleSelectionViewComponent, ElderSimpleSelectionViewModule, ElderSingleSortComponent, ElderStackCardDirective, ElderStopEventPropagationDirective, ElderSvgViewerComponent, ElderTabDirective, ElderTabFocusTrapDirective, ElderTabGroupRoutingDirective, ElderTabModule, ElderTableActivationDirective, ElderTableComponent, ElderTableExtensionDirective, ElderTableGroup, ElderTableModel, ElderTableModelCdkTableBinding, ElderTableModelQueryGroup, ElderTableModule, ElderTableProviders, ElderTableRootDirective, ElderTableSortDirective, ElderTableToolbarDirective, ElderThemeApplierDirective, ElderThemeDirective, ElderThemeModule, ElderThemePreferenceService, ElderThemeService, ElderThemeToggleComponent, ElderTimeModule, ElderToastModule, ElderToastService, ElderTogglePanelComponent, ElderTogglePanelPrimaryDirective, ElderTogglePanelSecondaryDirective, ElderTogglePanelTriggerDirective, ElderToolbarColumnDirective, ElderToolbarComponent, ElderToolbarContentDirective, ElderToolbarModule, ElderToolbarService, ElderToolbarTitleComponent, ElderToolbarTitleService, ElderTouchedDirective, ElderTrimPipe, ElderTripleStateCheckboxDirective, ElderTruncatePipe, ElderUnitSelectDirective, ElderUnitService, ElderUrlFragment, ElderUrlFragmentModule, ElderUrlFragmentParamsService, ElderUrlFragmentSwitcherComponent, ElderValidationErrorDirective, ElderViewersModule, EntitySetPatch, ErrorUtil, ExceptionDetailCtx, FileUploadClient, Filter, FilterContext, FilterUtil, FormFieldBaseComponent, HttpClientBuilder, HttpClientPristine, HttpDataTransfer, HttpDataTransferAggregateComponent, HttpDataTransferComponent, HttpDataTransferIndicatorComponent, HttpDataTransferOverviewComponent, HttpParamsBuilder, I18nBase, I18nPickAsyncPipe, I18nPickPipe, I18nText, IFrameState, IframeCloseDirective, IframeDialogComponent, IframeHostComponent, IframeService, IframeSideContentComponent, IndexedEntities, InternalRestClientConfig, Interval, IsoDurationPipe, IsoIntervalParsePipe, IsoIntervalPipe, JsonMapUtil, KafentConfig, KafentEvent, KafentEventService, KafentEventStream, KafentEventStreamDisabled, KafentEventStreamSse, KafentEventTransport, KafentModule, KafentSseEventChannel, KafentTokenProvider, KafentTokenProviderSessionStorage, KafentTopicSse, KnownElderThemes, KnownLocaleType, LocalListDataSource, LocalPagedDataSource, LocalisationPickerService, MasterSelectionState, MatTableDataContextBinding, MatTableDataContextBindingBuilder, MultiModelBaseComponent, NextNumberUtil, Objects, OnlineStatus, Page, PageRequest, Pageable, ParseUtil, Path, PathNode, PeriodBucket, PeriodDuration, PeriodFormat, ProcessIterationContext, ProcessState, PropertyPathUtil, Quantity, QueryListBinding, QuestionDialogConfig, ReactiveEventSource, ReactiveMap, RefreshingEntity, RestClient, RestClientConfig, RestClientContinuable, RestClientList, RestClientPaged, SearchQuery, SelectionModel, SelectionModelPopupDirective, Sets, SimpleLocalisationPicker, Sort, SortOption, SortUtil, SubBar, SuggestionProvider, TemplateCompositeControl, TemplatedSelectionDialogComponent, ThemeSpec, TimeAgoPipe, TimeDurationPipe, TimeUtil, ToIsoDateStringPipe, ToastType, TokenChunkRequest, ToolbarHeader, TranslatedEnumValue, TypedEventMessage, Unit, UnitDimension, UnitDimensionInfo, UnitInfo, UnitRegistry, UrlBuilder, UrlQueryParams, UuidUtil, ValueAccessorBase, ValueWrapper, ViewProviders, WeightPipe, alphaNumStringComparator, buildFormIntegrationProviders, createDataOptionsProvider, createSelectionModel, existingOrNewElderTableModel, isActivePagedDataContext, isContinuableDataContext, isContinuableDataSource, isDataContext, isDataSource, isElderEntityValueAccessor, isElderMultiEntityValueAccessor, isListDataSource, isPagedDataSource, naturalValueComparator, newElderTableModel, proxyControlContainer, registerLocale, runInZone, themeInit };
|
|
29049
29052
|
//# sourceMappingURL=elderbyte-ngx-starter.mjs.map
|
|
29050
|
-
//# sourceMappingURL=elderbyte-ngx-starter.mjs.map
|