@quadrel-enterprise-ui/framework 18.25.1 → 18.25.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.
@@ -359,21 +359,23 @@ export class QdInputComponent {
359
359
  if (this.controlContainer) {
360
360
  if (this.formControlName) {
361
361
  this.control = this.controlContainer.control.get(this.formControlName);
362
- // TODO remove logic for support of angular FormControl with angular 18 update
363
- if (!(this.control instanceof QdFormControl)) {
362
+ // TODO remove logic for support of angular FormControl with angular 20 update
363
+ if (!(this.control instanceof QdFormControl))
364
364
  console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');
365
- }
366
365
  }
367
366
  }
368
367
  this.writeValue(this.value || getValue(this.config));
368
+ this.normalizeInitialControlValueIfNeeded();
369
369
  this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));
370
370
  this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));
371
371
  this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));
372
372
  this._subs.add(this.initOpModeSubscription());
373
373
  }
374
374
  ngOnChanges(changes) {
375
- if (changes['config'])
375
+ if (changes['config']) {
376
376
  this.updateConfig();
377
+ this.normalizeInitialControlValueIfNeeded();
378
+ }
377
379
  if (changes['value'])
378
380
  this.writeValue(this.value);
379
381
  }
@@ -382,18 +384,15 @@ export class QdInputComponent {
382
384
  }
383
385
  registerOnChange(fn) {
384
386
  const fnString = fn.toString();
385
- if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange')) {
387
+ if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange'))
386
388
  return;
387
- }
388
389
  this._onChange = fn;
389
- fn(this.hasUnits ? this._value : this._value.value);
390
390
  }
391
391
  registerOnTouched(fn) {
392
392
  this._onTouch = fn;
393
393
  }
394
394
  writeValue(value) {
395
395
  this._value = getValueWithUnit(value, this.config);
396
- this._onChange(this.hasUnits ? this._value : this._value.value);
397
396
  }
398
397
  setDisabledState(disabled) {
399
398
  this.disabled = disabled;
@@ -493,6 +492,16 @@ export class QdInputComponent {
493
492
  this.viewonly = getViewonly(this.config, topic.payload.isViewonly);
494
493
  });
495
494
  }
495
+ normalizeInitialControlValueIfNeeded() {
496
+ if (!this.control)
497
+ return;
498
+ const modelValue = this.control.value;
499
+ const normalized = getValueWithUnit(modelValue, this.config);
500
+ const target = this.hasUnits ? normalized : normalized.value;
501
+ if (!isEqual(modelValue, target))
502
+ this.control.setValue(target, { emitEvent: false });
503
+ this._value = normalized;
504
+ }
496
505
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdInputComponent, deps: [{ token: i1.QdFormsActionEmitterService }, { token: i2.QdFormOptionsResolverRegistry }, { token: i3.ControlContainer, host: true, optional: true, skipSelf: true }, { token: i4.QdEventBrokerService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
497
506
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdInputComponent, selector: "qd-input", inputs: { formControlName: "formControlName", value: "value", config: "config", isError: "isError", testId: ["data-test-id", "testId"] }, outputs: { valueChange: "valueChange", enterClick: "enterClick", clickClear: "clickClear", clickHint: "clickHint", clickReadonly: "clickReadonly", clickViewonly: "clickViewonly" }, host: { properties: { "class.qd-input-readonly": "this.readonly", "class.qd-input--readonly-action": "this.readonlyAction", "class.qd-input-viewonly": "this.viewonly", "class.qd-input--viewonly-action": "this.viewonlyAction", "class.qd-form-hint-action": "this.hintAction", "class.qd-input-hint-action": "this.hintAction", "class.qd-form-disabled": "this.disabled", "class.qd-input-disabled": "this.disabled", "class.qd-input-focus": "this.isInputFocused", "class.qd-form-error": "this.hasError", "class.qd-input-error": "this.hasError", "class.qd-input-error-from-outside": "this.isErrorFromOutside" } }, providers: [
498
507
  {
@@ -598,4 +607,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
598
607
  type: ViewChild,
599
608
  args: ['input']
600
609
  }] } });
601
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/input/input.component.ts","../../../../../../libs/qd-ui/src/lib/forms/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  SkipSelf,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isEqual } from 'lodash';\nimport { Subscription } from 'rxjs';\n\nimport { QdFocusable } from '../../core/focusable/focusable';\nimport { QD_FOCUSABLE_TOKEN } from '../../core/focusable/focusable.token';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\nimport { getValueWithUnit } from './helpers/get-value-with-unit';\n\nimport { QdPopoverSizingService } from '../../core/popover/popover-sizing.service';\nimport { QdFormOptionsResolver } from '../model/form-options-resolver';\nimport {\n  QdFormInputConfiguration,\n  QdInputMode,\n  QdInputType,\n  QdInputValue,\n  QdInputValueWithUnit\n} from '../model/forms.interface';\nimport { QdFormInputOption } from '../model/options.interface';\nimport { QdFormControl } from '../reactive-forms/controls/form-control';\nimport {\n  getClearable,\n  getDisabled,\n  getHasAutofocus,\n  getHint,\n  getHintAction,\n  getInputMode,\n  getInputType,\n  getLabel,\n  getPlaceholder,\n  getReadonly,\n  getReadonlyAction,\n  getValue,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdFormOptionsResolverRegistry } from '../shared/services/options-resolver.registry';\n\n/**\n * The **QdInput** component provides a FormElement for entering text into a UI.<br />\n * It can be used with Quadrel Reactive Forms or with model binding.\n *\n * ### **Usage with Reactive Forms**\n *\n * ```ts\n * form = new QdFormGroup({\n *   input: new QdFormControl()\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-input [formControlName]=\"input\" [config]=\"config\"></qd-input>\n * </form>\n * ```\n *\n * ### **Usage with Model Binding**\n * ```ts\n * value;\n * ```\n * ```html\n * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n * ```\n *\n * ## **Suggested Options**\n *\n * ### **Static options by config**\n *\n * Static options can be defined in the config `options` field:\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   options: [\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.import', value: 'import' },\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.export', value: 'export' },\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.transit', value: 'transit', disabled: true }\n *   ]\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * ```\n *\n * <Story id=\"components-grid-system-container--columns-6\" />\n *\n * ### **Dynamic options by resolver**\n *\n * If you want to define the options dynamically, you can inject a `QdFormOptionsResolver`\n * with the `QD_FORM_OPTIONS_RESOLVER` injection token. The resolver just has to implement the `resolver`\n * method.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   constructor(private readonly httpClient: HttpClient) {}\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError(error => {\n *           console.error('your error message');\n *\n *           return throwError(error);\n *         })\n *       );\n *   }\n * }\n * ```\n * The options resolver can be injected into a component that contains the `QdInput` or also into a parent\n * component. If you need dynamic options for the search in the section toolbar, you can inject\n * the resolver on a higher level, e.g. in the component that contains the section.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: YourFormOptionsResolver\n *     }\n *   ]\n * })\n * ```\n *\n * By default, the resolver is applied to every input that is inside the component that injects the resolver.\n * To disable the resolver for an input, you have to set the `optionsResolverName` property in the\n * input config to `null`. It's also possible to define a `name` for the resolver by setting the `name` property\n * in the resolver class. Thus, you can connect the input to a specific resolver. Below there is also a\n * description of how to use multiple inputs with different resolvers in one component.\n * <br><br>\n *\n * #### **Multiple inputs with suggested options**\n *\n * For multiple inputs with various resolvers in one component you can distinguish the resolvers by setting the\n * `name` as a property in the resolver class.\n *\n * ```ts\n * @Injectable()\n * export class FruitsFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'fruits';\n *   // ...\n * }\n * ```\n *\n * ```ts\n * @Injectable()\n * export class CountriesFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'countries';\n *   // ...\n * }\n * ```\n *\n * Then the input can be assigned to a resolver by setting the `optionsResolverName` property\n * in the input config.\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'fruits'\n * }\n *\n * config2: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'countries'\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * <qd-input [config]=\"config2\"></qd-input>\n * ```\n * To inject multiple resolvers in a component you can use the provider setting `multi: true`.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: FruitsFormOptionsResolver,\n *       multi: true\n *     },\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: CountriesFormOptionsResolver,\n *       multi: true\n *     }\n *   ]\n * })\n * ```\n *\n * #### **Custom loading and error hints**\n *\n * In the resolver you also can define custom loading and error hints with the properties `requestLoadingHint`\n * and `requestErrorHint`.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   requestLoadingHint = { i18n: 'i18n.custom.options.loading' };\n *   requestErrorHint = { i18n: 'i18n.custom.options.error' };\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     // ...\n *   }\n * }\n * ```\n * You also can update the error hint directly in the resolve method to display a more specific error\n * message when an error occurs.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   // ...\n *\n *   constructor(\n *     @Optional() @Inject(BACKEND_ERROR_CODES) private readonly backendErrorCodes\n *   ) {\n *     this.backendErrorCodes = this.backendErrorCodes || {};\n *   }\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError((error: HttpErrorResponse) => {\n *           if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)\n *             this.requestErrorHint = { i18n: 'ERROR.' + error.error.errorCode };\n *           return throwError(() => error);\n *         })\n *       );\n *   }\n * }\n * ```\n */\n@Component({\n  selector: 'qd-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdInputComponent,\n      multi: true\n    },\n    QdFormsActionEmitterService,\n    QdFormOptionsResolverRegistry,\n    // TODO: Remove when removing derived directive\n    QdPopoverSizingService,\n    {\n      provide: QD_FOCUSABLE_TOKEN,\n      useExisting: QdInputComponent\n    }\n  ]\n})\nexport class QdInputComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, QdFocusable {\n  /**\n   * The form control name can be assigned here if you want to use Reactive Forms.\n   */\n  @Input()\n  formControlName: string;\n\n  /**\n   * The current form item value, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n   */\n  @Input()\n  value;\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'label' },\n   *   placeholder: { i18n: 'placeholder' },\n   *   hint: { i18n: 'hint' }\n   * };\n   */\n  @Input()\n  config: QdFormInputConfiguration;\n\n  /**\n   * Set component to \"error\" externally. No reactive forms required. Used for components within the Quadrel UI framework. This is done by a CSS class.\n   *\n   * @default false\n   */\n  @Input()\n  isError = false;\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id')\n  testId = 'text-input';\n\n  /**\n   * Emits event when the value has changed.\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly valueChange = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the value has changed. Note: Emits on keyup (no longer on click, as before)!\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly enterClick = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the input field was lapped on click/tap on the x icon. <br />\n   * `QdFormInputConfiguration['clearable']` must be set to true for this.\n   */\n  @Output()\n  readonly clickClear = new EventEmitter();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when the readonly value is clicked/tapped. `clickReadonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when the viewonly value is clicked/tapped. `clickViewonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickViewonly = new EventEmitter();\n\n  @HostBinding('class.qd-input-readonly')\n  readonly: boolean;\n\n  @HostBinding('class.qd-input--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-input-viewonly')\n  viewonly: boolean;\n\n  @HostBinding('class.qd-input--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-input-hint-action')\n  hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  @HostBinding('class.qd-input-disabled')\n  disabled: boolean;\n\n  @HostBinding('class.qd-input-focus')\n  isInputFocused = false;\n  areUnitsOpened = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-input-error')\n  get hasError(): boolean {\n    return this.control ? this.control.touched && this.control.invalid : false;\n  }\n\n  @HostBinding('class.qd-input-error-from-outside')\n  get isErrorFromOutside(): boolean {\n    return this.isError;\n  }\n\n  @ViewChild('input')\n  inputElement: ElementRef;\n\n  inputType: QdInputType;\n  inputMode: QdInputMode;\n  placeholder: string;\n  label: string;\n  hint: string;\n  clearable: boolean;\n  hasAutofocus: boolean;\n  hasOptions = false;\n  _value: QdInputValueWithUnit = { value: '' };\n  control: AbstractControl | QdFormControl<any>;\n\n  private _optionsResolver!: QdFormOptionsResolver | null;\n  private _subs = new Subscription();\n\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  get hasOnlyUnitsError(): boolean {\n    return isEqual(Object.keys(this.control.errors), ['required']) && this._value.value !== '';\n  }\n\n  get hasUnits(): boolean {\n    return this.config?.units?.length > 0;\n  }\n\n  get numberOfCharacters(): number {\n    if (!this._value.value) return 0;\n\n    return String(this._value.value).length;\n  }\n\n  get hasMaxLength(): boolean {\n    if (!(this.control instanceof QdFormControl)) return false;\n\n    return this.control.hasMaxLength();\n  }\n\n  get maxLength(): number {\n    if (!(this.control instanceof QdFormControl)) return;\n\n    return this.control.getMaxLengthOrUndefined();\n  }\n\n  get valueAsList(): string[] {\n    return [`${this._value.value}${this._value.unit ? ' ' + this._value.unit : ''}`];\n  }\n\n  constructor(\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    private readonly resolverRegistry: QdFormOptionsResolverRegistry,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {}\n\n  ngOnInit(): void {\n    this.initializeOptionsResolver();\n    this.updateConfig();\n\n    if (this.controlContainer) {\n      if (this.formControlName) {\n        this.control = this.controlContainer.control.get(this.formControlName);\n\n        // TODO remove logic for support of angular FormControl with angular 18 update\n        if (!(this.control instanceof QdFormControl)) {\n          console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');\n        }\n      }\n    }\n\n    this.writeValue(this.value || getValue(this.config));\n\n    this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));\n    this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));\n    this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));\n    this._subs.add(this.initOpModeSubscription());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) this.updateConfig();\n    if (changes['value']) this.writeValue(this.value);\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    const fnString = fn.toString();\n\n    if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange')) {\n      return;\n    }\n\n    this._onChange = fn;\n\n    fn(this.hasUnits ? this._value : this._value.value);\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  writeValue(value: QdInputValueWithUnit | QdInputValue): void {\n    this._value = getValueWithUnit(value, this.config);\n\n    this._onChange(this.hasUnits ? this._value : this._value.value);\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n    this.clearable = getClearable(this.config) && !this.disabled;\n  }\n\n  handleInput(event): void {\n    const value = event.target.value;\n    this._value = { ...this._value, value };\n    this.emitValue();\n    this._onTouch();\n  }\n\n  handleOptionSelected(option: QdFormInputOption): void {\n    this._value = { ...this._value, value: option.i18n };\n    this.valueChange.emit(option.value);\n    this._onChange(option.value);\n    this._onTouch();\n  }\n\n  handleUnitChange(unit): void {\n    this._value = { ...this._value, unit };\n    this.emitValue();\n  }\n\n  handleInputFocus(): void {\n    this.isInputFocused = true;\n  }\n\n  handleInputBlur(): void {\n    this.isInputFocused = false;\n\n    setTimeout(() => {\n      if (!this.areUnitsOpened) this._onTouch();\n    }, 100);\n  }\n\n  handleUnitsOpened(): void {\n    this.areUnitsOpened = true;\n  }\n\n  handleUnitsClosed(): void {\n    this.areUnitsOpened = false;\n\n    if (this._value.unit && this._value.value === '') {\n      this.inputElement.nativeElement.focus();\n    } else {\n      this._onTouch();\n    }\n  }\n\n  clearInput(): void {\n    this._value = { ...this._value, value: '' };\n    this.inputElement.nativeElement.focus();\n\n    this.emitValue();\n    this.clickClear.emit();\n  }\n\n  focus(): void {\n    this.inputElement.nativeElement.focus();\n  }\n\n  emitEnterClick(): void {\n    if (this.hasUnits) {\n      this.enterClick.emit(this._value);\n    } else {\n      this.enterClick.emit(this._value.value);\n    }\n  }\n\n  private updateConfig(): void {\n    this.inputType = getInputType(this.config);\n    this.inputMode = getInputMode(this.config);\n    this.placeholder = getPlaceholder(this.config);\n    this.label = getLabel(this.config);\n    this.hint = getHint(this.config);\n    this.readonly = getReadonly(this.config, this.readonly);\n    this.viewonly = getViewonly(this.config, this.viewonly);\n    this.hintAction = getHintAction(this.config);\n    this.readonlyAction = getReadonlyAction(this.config);\n    this.viewonlyAction = getViewonlyAction(this.config);\n    this.disabled = getDisabled(this.config) || !!this.control?.disabled;\n    this.clearable = !this.disabled && getClearable(this.config);\n    this.hasAutofocus = getHasAutofocus(this.config);\n    this.hasOptions = (this.config.options && this.config.options.length > 0) || !!this._optionsResolver;\n  }\n\n  private initializeOptionsResolver(): void {\n    this.resolverRegistry.initialize(this.config?.optionsResolverName);\n    this._optionsResolver = this.resolverRegistry.findResolver();\n  }\n\n  private emitValue(): void {\n    if (this.hasUnits) {\n      this.valueChange.emit(this._value);\n      this._onChange(this._value);\n    } else {\n      this.valueChange.emit(this._value.value);\n      this._onChange(this._value.value);\n    }\n  }\n\n  private initOpModeSubscription(): Subscription | void {\n    if (!this.eventBrokerService) return;\n\n    return this.eventBrokerService.consume<{ isViewonly: boolean }>('operation_mode_changed').subscribe(topic => {\n      if (typeof this.config.viewonly === 'boolean') return;\n\n      this.viewonly = getViewonly(this.config, topic.payload.isViewonly);\n    });\n  }\n}\n","<qd-form-label\n  [label]=\"label\"\n  [readonly]=\"readonly\"\n  [viewonly]=\"viewonly\"\n  [control]=\"control\"\n  [tooltip]=\"config?.tooltip\"\n  [data-test-id]=\"testId\"\n></qd-form-label>\n\n<ng-container *ngIf=\"!readonly && !viewonly && !hasOptions\">\n  <div class=\"qd-input-input\" (keydown.enter)=\"emitEnterClick()\">\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</ng-container>\n\n<div *ngIf=\"!readonly && !viewonly && hasOptions\">\n  <div\n    class=\"qd-input-input\"\n    qdInputOptions\n    [qdPopoverMinWidth]=\"200\"\n    [config]=\"config\"\n    [value]=\"_value.value\"\n    (optionSelected)=\"handleOptionSelected($event)\"\n    (enterClick)=\"emitEnterClick()\"\n  >\n    <!-- handle (enterClick) by options directive here because event has to be fired after selection -->\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</div>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"valueAsList\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"valueAsList\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n\n<ng-template #inputBox>\n  <input\n    #input\n    [placeholder]=\"placeholder | translate\"\n    [value]=\"hasOptions ? (_value.value.toString() | translate) : _value.value\"\n    (input)=\"handleInput($event)\"\n    (focus)=\"handleInputFocus()\"\n    (blur)=\"handleInputBlur()\"\n    [disabled]=\"disabled || readonly\"\n    [type]=\"inputType\"\n    [attr.inputmode]=\"inputMode\"\n    [qdAutofocus]=\"hasAutofocus\"\n    [attr.data-test-id]=\"testId + '-input'\"\n    [step]=\"config?.step\"\n    required\n  />\n  <div class=\"qd-input-suffix\">\n    <qd-icon *ngIf=\"hasError && !hasOnlyUnitsError\" class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n    <qd-icon *ngIf=\"clearable\" class=\"qd-input-clearable-icon\" icon=\"timesLarge\" (click)=\"clearInput()\"></qd-icon>\n    <ng-content select=\"[qdIconButton]\"></ng-content>\n  </div>\n  <qd-input-units\n    *ngIf=\"hasUnits\"\n    [unit]=\"_value.unit\"\n    [config]=\"config\"\n    (unitChange)=\"handleUnitChange($event)\"\n    (opened)=\"handleUnitsOpened()\"\n    (closed)=\"handleUnitsClosed()\"\n  ></qd-input-units>\n  <div class=\"qd-input-suffix\" *ngIf=\"hasError && hasOnlyUnitsError\">\n    <qd-icon class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n  </div>\n</ng-template>\n"]}
610
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../libs/qd-ui/src/lib/forms/input/input.component.ts","../../../../../../libs/qd-ui/src/lib/forms/input/input.component.html"],"names":[],"mappings":"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","sourcesContent":["// @ts-strict-ignore\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Host,\n  HostBinding,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  SimpleChanges,\n  SkipSelf,\n  ViewChild\n} from '@angular/core';\nimport { AbstractControl, ControlContainer, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isEqual } from 'lodash';\nimport { Subscription } from 'rxjs';\n\nimport { QdFocusable } from '../../core/focusable/focusable';\nimport { QD_FOCUSABLE_TOKEN } from '../../core/focusable/focusable.token';\nimport { QdEventBrokerService } from '../../core/services/event-broker.service';\nimport { getValueWithUnit } from './helpers/get-value-with-unit';\n\nimport { QdPopoverSizingService } from '../../core/popover/popover-sizing.service';\nimport { QdFormOptionsResolver } from '../model/form-options-resolver';\nimport {\n  QdFormInputConfiguration,\n  QdInputMode,\n  QdInputType,\n  QdInputValue,\n  QdInputValueWithUnit\n} from '../model/forms.interface';\nimport { QdFormInputOption } from '../model/options.interface';\nimport { QdFormControl } from '../reactive-forms/controls/form-control';\nimport {\n  getClearable,\n  getDisabled,\n  getHasAutofocus,\n  getHint,\n  getHintAction,\n  getInputMode,\n  getInputType,\n  getLabel,\n  getPlaceholder,\n  getReadonly,\n  getReadonlyAction,\n  getValue,\n  getViewonly,\n  getViewonlyAction\n} from '../shared/helpers/forms.helpers';\nimport { QdFormsActionEmitterService } from '../shared/services/action-emitter.service';\nimport { QdFormOptionsResolverRegistry } from '../shared/services/options-resolver.registry';\n\n/**\n * The **QdInput** component provides a FormElement for entering text into a UI.<br />\n * It can be used with Quadrel Reactive Forms or with model binding.\n *\n * ### **Usage with Reactive Forms**\n *\n * ```ts\n * form = new QdFormGroup({\n *   input: new QdFormControl()\n * });\n * ```\n * ```html\n * <form [formGroup]=\"form\">\n *   <qd-input [formControlName]=\"input\" [config]=\"config\"></qd-input>\n * </form>\n * ```\n *\n * ### **Usage with Model Binding**\n * ```ts\n * value;\n * ```\n * ```html\n * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n * ```\n *\n * ## **Suggested Options**\n *\n * ### **Static options by config**\n *\n * Static options can be defined in the config `options` field:\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   options: [\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.import', value: 'import' },\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.export', value: 'export' },\n *     { i18n: 'i18n.qd.exampleFormField.goodsDeclaration.transit', value: 'transit', disabled: true }\n *   ]\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * ```\n *\n * <Story id=\"components-grid-system-container--columns-6\" />\n *\n * ### **Dynamic options by resolver**\n *\n * If you want to define the options dynamically, you can inject a `QdFormOptionsResolver`\n * with the `QD_FORM_OPTIONS_RESOLVER` injection token. The resolver just has to implement the `resolver`\n * method.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   constructor(private readonly httpClient: HttpClient) {}\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError(error => {\n *           console.error('your error message');\n *\n *           return throwError(error);\n *         })\n *       );\n *   }\n * }\n * ```\n * The options resolver can be injected into a component that contains the `QdInput` or also into a parent\n * component. If you need dynamic options for the search in the section toolbar, you can inject\n * the resolver on a higher level, e.g. in the component that contains the section.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: YourFormOptionsResolver\n *     }\n *   ]\n * })\n * ```\n *\n * By default, the resolver is applied to every input that is inside the component that injects the resolver.\n * To disable the resolver for an input, you have to set the `optionsResolverName` property in the\n * input config to `null`. It's also possible to define a `name` for the resolver by setting the `name` property\n * in the resolver class. Thus, you can connect the input to a specific resolver. Below there is also a\n * description of how to use multiple inputs with different resolvers in one component.\n * <br><br>\n *\n * #### **Multiple inputs with suggested options**\n *\n * For multiple inputs with various resolvers in one component you can distinguish the resolvers by setting the\n * `name` as a property in the resolver class.\n *\n * ```ts\n * @Injectable()\n * export class FruitsFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'fruits';\n *   // ...\n * }\n * ```\n *\n * ```ts\n * @Injectable()\n * export class CountriesFormOptionsResolver implements QdFormOptionsResolver {\n *   name = 'countries';\n *   // ...\n * }\n * ```\n *\n * Then the input can be assigned to a resolver by setting the `optionsResolverName` property\n * in the input config.\n *\n * ```ts\n * config: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'fruits'\n * }\n *\n * config2: QdFormInputConfiguration = {\n *   ...\n *   optionsResolverName: 'countries'\n * }\n * ```\n * ```html\n * <qd-input [config]=\"config\"></qd-input>\n * <qd-input [config]=\"config2\"></qd-input>\n * ```\n * To inject multiple resolvers in a component you can use the provider setting `multi: true`.\n *\n * ```ts\n * @Component({\n *   ...\n *   providers: [\n *     ...\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: FruitsFormOptionsResolver,\n *       multi: true\n *     },\n *     {\n *       provide: QD_FORM_OPTIONS_RESOLVER,\n *       useClass: CountriesFormOptionsResolver,\n *       multi: true\n *     }\n *   ]\n * })\n * ```\n *\n * #### **Custom loading and error hints**\n *\n * In the resolver you also can define custom loading and error hints with the properties `requestLoadingHint`\n * and `requestErrorHint`.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   requestLoadingHint = { i18n: 'i18n.custom.options.loading' };\n *   requestErrorHint = { i18n: 'i18n.custom.options.error' };\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     // ...\n *   }\n * }\n * ```\n * You also can update the error hint directly in the resolve method to display a more specific error\n * message when an error occurs.\n *\n * ```ts\n * @Injectable()\n * export class YourFormOptionsResolver implements QdFormOptionsResolver {\n *   // ...\n *\n *   constructor(\n *     @Optional() @Inject(BACKEND_ERROR_CODES) private readonly backendErrorCodes\n *   ) {\n *     this.backendErrorCodes = this.backendErrorCodes || {};\n *   }\n *\n *   // ...\n *\n *   resolve(value: string): Observable<QdFormInput[]> {\n *     return this.httpClient\n *       .get(yourBackendUrl)\n *       .pipe(\n *         catchError((error: HttpErrorResponse) => {\n *           if (error.error?.errorCode && error.error.errorCode in this.backendErrorCodes)\n *             this.requestErrorHint = { i18n: 'ERROR.' + error.error.errorCode };\n *           return throwError(() => error);\n *         })\n *       );\n *   }\n * }\n * ```\n */\n@Component({\n  selector: 'qd-input',\n  templateUrl: './input.component.html',\n  styleUrls: ['./input.component.scss'],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: QdInputComponent,\n      multi: true\n    },\n    QdFormsActionEmitterService,\n    QdFormOptionsResolverRegistry,\n    // TODO: Remove when removing derived directive\n    QdPopoverSizingService,\n    {\n      provide: QD_FOCUSABLE_TOKEN,\n      useExisting: QdInputComponent\n    }\n  ]\n})\nexport class QdInputComponent implements OnInit, OnChanges, OnDestroy, ControlValueAccessor, QdFocusable {\n  /**\n   * The form control name can be assigned here if you want to use Reactive Forms.\n   */\n  @Input()\n  formControlName: string;\n\n  /**\n   * The current form item value, if you are working with Model Binding.\n   *\n   * @example\n   * <qd-input [(value)]=\"value\" [config]=\"config\"></qd-input>\n   */\n  @Input()\n  value;\n\n  /**\n   * The configuration for this form item\n   *\n   * @example\n   * {\n   *   label: { i18n: 'label' },\n   *   placeholder: { i18n: 'placeholder' },\n   *   hint: { i18n: 'hint' }\n   * };\n   */\n  @Input()\n  config: QdFormInputConfiguration;\n\n  /**\n   * Set component to \"error\" externally. No reactive forms required. Used for components within the Quadrel UI framework. This is done by a CSS class.\n   *\n   * @default false\n   */\n  @Input()\n  isError = false;\n\n  /**\n   * A static test ID for integration tests can be set. <br />\n   * The value for the HTML attribute [data-test-id].\n   */\n  @Input('data-test-id')\n  testId = 'text-input';\n\n  /**\n   * Emits event when the value has changed.\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly valueChange = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the value has changed. Note: Emits on keyup (no longer on click, as before)!\n   * Optionally emits the current input value, including unit (if configured).\n   */\n  @Output()\n  readonly enterClick = new EventEmitter<QdInputValue | QdInputValueWithUnit | undefined>();\n\n  /**\n   * Emits event when the input field was lapped on click/tap on the x icon. <br />\n   * `QdFormInputConfiguration['clearable']` must be set to true for this.\n   */\n  @Output()\n  readonly clickClear = new EventEmitter();\n\n  /**\n   * Emits event when the hint is clicked/tapped. `hintAction` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickHint = new EventEmitter();\n\n  /**\n   * Emits event when the readonly value is clicked/tapped. `clickReadonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickReadonly = new EventEmitter();\n\n  /**\n   * Emits event when the viewonly value is clicked/tapped. `clickViewonly ` must be set to `true` for this.\n   */\n  @Output()\n  readonly clickViewonly = new EventEmitter();\n\n  @HostBinding('class.qd-input-readonly')\n  readonly: boolean;\n\n  @HostBinding('class.qd-input--readonly-action')\n  readonlyAction = false;\n\n  @HostBinding('class.qd-input-viewonly')\n  viewonly: boolean;\n\n  @HostBinding('class.qd-input--viewonly-action')\n  viewonlyAction = false;\n\n  @HostBinding('class.qd-form-hint-action')\n  @HostBinding('class.qd-input-hint-action')\n  hintAction = false;\n\n  @HostBinding('class.qd-form-disabled')\n  @HostBinding('class.qd-input-disabled')\n  disabled: boolean;\n\n  @HostBinding('class.qd-input-focus')\n  isInputFocused = false;\n  areUnitsOpened = false;\n\n  @HostBinding('class.qd-form-error')\n  @HostBinding('class.qd-input-error')\n  get hasError(): boolean {\n    return this.control ? this.control.touched && this.control.invalid : false;\n  }\n\n  @HostBinding('class.qd-input-error-from-outside')\n  get isErrorFromOutside(): boolean {\n    return this.isError;\n  }\n\n  @ViewChild('input')\n  inputElement: ElementRef;\n\n  inputType: QdInputType;\n  inputMode: QdInputMode;\n  placeholder: string;\n  label: string;\n  hint: string;\n  clearable: boolean;\n  hasAutofocus: boolean;\n  hasOptions = false;\n  _value: QdInputValueWithUnit = { value: '' };\n  control: AbstractControl | QdFormControl<any>;\n\n  private _optionsResolver!: QdFormOptionsResolver | null;\n  private _subs = new Subscription();\n\n  private _onChange: any = () => {};\n  private _onTouch: any = () => {};\n\n  get hasOnlyUnitsError(): boolean {\n    return isEqual(Object.keys(this.control.errors), ['required']) && this._value.value !== '';\n  }\n\n  get hasUnits(): boolean {\n    return this.config?.units?.length > 0;\n  }\n\n  get numberOfCharacters(): number {\n    if (!this._value.value) return 0;\n\n    return String(this._value.value).length;\n  }\n\n  get hasMaxLength(): boolean {\n    if (!(this.control instanceof QdFormControl)) return false;\n\n    return this.control.hasMaxLength();\n  }\n\n  get maxLength(): number {\n    if (!(this.control instanceof QdFormControl)) return;\n\n    return this.control.getMaxLengthOrUndefined();\n  }\n\n  get valueAsList(): string[] {\n    return [`${this._value.value}${this._value.unit ? ' ' + this._value.unit : ''}`];\n  }\n\n  constructor(\n    private readonly actionEmitterService: QdFormsActionEmitterService,\n    private readonly resolverRegistry: QdFormOptionsResolverRegistry,\n    @Optional() @Host() @SkipSelf() private readonly controlContainer: ControlContainer,\n    @Optional() private readonly eventBrokerService: QdEventBrokerService\n  ) {}\n\n  ngOnInit(): void {\n    this.initializeOptionsResolver();\n    this.updateConfig();\n\n    if (this.controlContainer) {\n      if (this.formControlName) {\n        this.control = this.controlContainer.control.get(this.formControlName);\n\n        // TODO remove logic for support of angular FormControl with angular 20 update\n        if (!(this.control instanceof QdFormControl))\n          console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');\n      }\n    }\n\n    this.writeValue(this.value || getValue(this.config));\n\n    this.normalizeInitialControlValueIfNeeded();\n\n    this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));\n    this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));\n    this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));\n    this._subs.add(this.initOpModeSubscription());\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['config']) {\n      this.updateConfig();\n      this.normalizeInitialControlValueIfNeeded();\n    }\n\n    if (changes['value']) this.writeValue(this.value);\n  }\n\n  ngOnDestroy(): void {\n    this._subs.unsubscribe();\n  }\n\n  registerOnChange(fn: (_: any) => void): void {\n    const fnString = fn.toString();\n\n    if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange')) return;\n\n    this._onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this._onTouch = fn;\n  }\n\n  writeValue(value: QdInputValueWithUnit | QdInputValue): void {\n    this._value = getValueWithUnit(value, this.config);\n  }\n\n  setDisabledState(disabled: boolean): void {\n    this.disabled = disabled;\n    this.clearable = getClearable(this.config) && !this.disabled;\n  }\n\n  handleInput(event): void {\n    const value = event.target.value;\n    this._value = { ...this._value, value };\n    this.emitValue();\n    this._onTouch();\n  }\n\n  handleOptionSelected(option: QdFormInputOption): void {\n    this._value = { ...this._value, value: option.i18n };\n    this.valueChange.emit(option.value);\n    this._onChange(option.value);\n    this._onTouch();\n  }\n\n  handleUnitChange(unit): void {\n    this._value = { ...this._value, unit };\n    this.emitValue();\n  }\n\n  handleInputFocus(): void {\n    this.isInputFocused = true;\n  }\n\n  handleInputBlur(): void {\n    this.isInputFocused = false;\n\n    setTimeout(() => {\n      if (!this.areUnitsOpened) this._onTouch();\n    }, 100);\n  }\n\n  handleUnitsOpened(): void {\n    this.areUnitsOpened = true;\n  }\n\n  handleUnitsClosed(): void {\n    this.areUnitsOpened = false;\n\n    if (this._value.unit && this._value.value === '') {\n      this.inputElement.nativeElement.focus();\n    } else {\n      this._onTouch();\n    }\n  }\n\n  clearInput(): void {\n    this._value = { ...this._value, value: '' };\n    this.inputElement.nativeElement.focus();\n\n    this.emitValue();\n    this.clickClear.emit();\n  }\n\n  focus(): void {\n    this.inputElement.nativeElement.focus();\n  }\n\n  emitEnterClick(): void {\n    if (this.hasUnits) {\n      this.enterClick.emit(this._value);\n    } else {\n      this.enterClick.emit(this._value.value);\n    }\n  }\n\n  private updateConfig(): void {\n    this.inputType = getInputType(this.config);\n    this.inputMode = getInputMode(this.config);\n    this.placeholder = getPlaceholder(this.config);\n    this.label = getLabel(this.config);\n    this.hint = getHint(this.config);\n    this.readonly = getReadonly(this.config, this.readonly);\n    this.viewonly = getViewonly(this.config, this.viewonly);\n    this.hintAction = getHintAction(this.config);\n    this.readonlyAction = getReadonlyAction(this.config);\n    this.viewonlyAction = getViewonlyAction(this.config);\n    this.disabled = getDisabled(this.config) || !!this.control?.disabled;\n    this.clearable = !this.disabled && getClearable(this.config);\n    this.hasAutofocus = getHasAutofocus(this.config);\n    this.hasOptions = (this.config.options && this.config.options.length > 0) || !!this._optionsResolver;\n  }\n\n  private initializeOptionsResolver(): void {\n    this.resolverRegistry.initialize(this.config?.optionsResolverName);\n    this._optionsResolver = this.resolverRegistry.findResolver();\n  }\n\n  private emitValue(): void {\n    if (this.hasUnits) {\n      this.valueChange.emit(this._value);\n      this._onChange(this._value);\n    } else {\n      this.valueChange.emit(this._value.value);\n      this._onChange(this._value.value);\n    }\n  }\n\n  private initOpModeSubscription(): Subscription | void {\n    if (!this.eventBrokerService) return;\n\n    return this.eventBrokerService.consume<{ isViewonly: boolean }>('operation_mode_changed').subscribe(topic => {\n      if (typeof this.config.viewonly === 'boolean') return;\n\n      this.viewonly = getViewonly(this.config, topic.payload.isViewonly);\n    });\n  }\n\n  private normalizeInitialControlValueIfNeeded(): void {\n    if (!this.control) return;\n\n    const modelValue = (this.control as any).value;\n    const normalized = getValueWithUnit(modelValue, this.config);\n    const target = this.hasUnits ? normalized : normalized.value;\n\n    if (!isEqual(modelValue, target)) (this.control as any).setValue(target, { emitEvent: false });\n\n    this._value = normalized;\n  }\n}\n","<qd-form-label\n  [label]=\"label\"\n  [readonly]=\"readonly\"\n  [viewonly]=\"viewonly\"\n  [control]=\"control\"\n  [tooltip]=\"config?.tooltip\"\n  [data-test-id]=\"testId\"\n></qd-form-label>\n\n<ng-container *ngIf=\"!readonly && !viewonly && !hasOptions\">\n  <div class=\"qd-input-input\" (keydown.enter)=\"emitEnterClick()\">\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</ng-container>\n\n<div *ngIf=\"!readonly && !viewonly && hasOptions\">\n  <div\n    class=\"qd-input-input\"\n    qdInputOptions\n    [qdPopoverMinWidth]=\"200\"\n    [config]=\"config\"\n    [value]=\"_value.value\"\n    (optionSelected)=\"handleOptionSelected($event)\"\n    (enterClick)=\"emitEnterClick()\"\n  >\n    <!-- handle (enterClick) by options directive here because event has to be fired after selection -->\n    <ng-container *ngTemplateOutlet=\"inputBox\"></ng-container>\n  </div>\n\n  <span class=\"qd-input-character-counter\" *ngIf=\"hasMaxLength\">{{ numberOfCharacters }} / {{ maxLength }}</span>\n\n  <qd-form-hint\n    [hint]=\"hint\"\n    [control]=\"control\"\n    [hasError]=\"hasError\"\n    [hintAction]=\"hintAction\"\n    [data-test-id]=\"testId\"\n  ></qd-form-hint>\n</div>\n\n<qd-form-readonly\n  *ngIf=\"readonly\"\n  [values]=\"valueAsList\"\n  [readonlyAction]=\"readonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-readonly>\n\n<qd-form-viewonly\n  *ngIf=\"viewonly\"\n  [values]=\"valueAsList\"\n  [viewonlyAction]=\"viewonlyAction\"\n  [data-test-id]=\"testId\"\n></qd-form-viewonly>\n\n<ng-template #inputBox>\n  <input\n    #input\n    [placeholder]=\"placeholder | translate\"\n    [value]=\"hasOptions ? (_value.value.toString() | translate) : _value.value\"\n    (input)=\"handleInput($event)\"\n    (focus)=\"handleInputFocus()\"\n    (blur)=\"handleInputBlur()\"\n    [disabled]=\"disabled || readonly\"\n    [type]=\"inputType\"\n    [attr.inputmode]=\"inputMode\"\n    [qdAutofocus]=\"hasAutofocus\"\n    [attr.data-test-id]=\"testId + '-input'\"\n    [step]=\"config?.step\"\n    required\n  />\n  <div class=\"qd-input-suffix\">\n    <qd-icon *ngIf=\"hasError && !hasOnlyUnitsError\" class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n    <qd-icon *ngIf=\"clearable\" class=\"qd-input-clearable-icon\" icon=\"timesLarge\" (click)=\"clearInput()\"></qd-icon>\n    <ng-content select=\"[qdIconButton]\"></ng-content>\n  </div>\n  <qd-input-units\n    *ngIf=\"hasUnits\"\n    [unit]=\"_value.unit\"\n    [config]=\"config\"\n    (unitChange)=\"handleUnitChange($event)\"\n    (opened)=\"handleUnitsOpened()\"\n    (closed)=\"handleUnitsClosed()\"\n  ></qd-input-units>\n  <div class=\"qd-input-suffix\" *ngIf=\"hasError && hasOnlyUnitsError\">\n    <qd-icon class=\"qd-input-error-icon\" icon=\"exclamationCircleSolid\"></qd-icon>\n  </div>\n</ng-template>\n"]}
@@ -12319,21 +12319,23 @@ class QdInputComponent {
12319
12319
  if (this.controlContainer) {
12320
12320
  if (this.formControlName) {
12321
12321
  this.control = this.controlContainer.control.get(this.formControlName);
12322
- // TODO remove logic for support of angular FormControl with angular 18 update
12323
- if (!(this.control instanceof QdFormControl)) {
12322
+ // TODO remove logic for support of angular FormControl with angular 20 update
12323
+ if (!(this.control instanceof QdFormControl))
12324
12324
  console.warn('QD-UI | QdInputComponent - Please use the QdFormControl instead of the Angular FormControl');
12325
- }
12326
12325
  }
12327
12326
  }
12328
12327
  this.writeValue(this.value || getValue(this.config));
12328
+ this.normalizeInitialControlValueIfNeeded();
12329
12329
  this._subs.add(this.actionEmitterService.hintEventEmitter$.subscribe(() => this.clickHint.emit()));
12330
12330
  this._subs.add(this.actionEmitterService.readonlyEventEmitter$.subscribe(() => this.clickReadonly.emit()));
12331
12331
  this._subs.add(this.actionEmitterService.viewonlyEventEmitter$.subscribe(() => this.clickViewonly.emit()));
12332
12332
  this._subs.add(this.initOpModeSubscription());
12333
12333
  }
12334
12334
  ngOnChanges(changes) {
12335
- if (changes['config'])
12335
+ if (changes['config']) {
12336
12336
  this.updateConfig();
12337
+ this.normalizeInitialControlValueIfNeeded();
12338
+ }
12337
12339
  if (changes['value'])
12338
12340
  this.writeValue(this.value);
12339
12341
  }
@@ -12342,18 +12344,15 @@ class QdInputComponent {
12342
12344
  }
12343
12345
  registerOnChange(fn) {
12344
12346
  const fnString = fn.toString();
12345
- if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange')) {
12347
+ if (fnString.includes('_noControlError') || fnString.includes('validateControlPresenceOnChange'))
12346
12348
  return;
12347
- }
12348
12349
  this._onChange = fn;
12349
- fn(this.hasUnits ? this._value : this._value.value);
12350
12350
  }
12351
12351
  registerOnTouched(fn) {
12352
12352
  this._onTouch = fn;
12353
12353
  }
12354
12354
  writeValue(value) {
12355
12355
  this._value = getValueWithUnit(value, this.config);
12356
- this._onChange(this.hasUnits ? this._value : this._value.value);
12357
12356
  }
12358
12357
  setDisabledState(disabled) {
12359
12358
  this.disabled = disabled;
@@ -12453,6 +12452,16 @@ class QdInputComponent {
12453
12452
  this.viewonly = getViewonly(this.config, topic.payload.isViewonly);
12454
12453
  });
12455
12454
  }
12455
+ normalizeInitialControlValueIfNeeded() {
12456
+ if (!this.control)
12457
+ return;
12458
+ const modelValue = this.control.value;
12459
+ const normalized = getValueWithUnit(modelValue, this.config);
12460
+ const target = this.hasUnits ? normalized : normalized.value;
12461
+ if (!isEqual(modelValue, target))
12462
+ this.control.setValue(target, { emitEvent: false });
12463
+ this._value = normalized;
12464
+ }
12456
12465
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: QdInputComponent, deps: [{ token: QdFormsActionEmitterService }, { token: QdFormOptionsResolverRegistry }, { token: i1$4.ControlContainer, host: true, optional: true, skipSelf: true }, { token: QdEventBrokerService, optional: true }], target: i0.ɵɵFactoryTarget.Component });
12457
12466
  static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: QdInputComponent, selector: "qd-input", inputs: { formControlName: "formControlName", value: "value", config: "config", isError: "isError", testId: ["data-test-id", "testId"] }, outputs: { valueChange: "valueChange", enterClick: "enterClick", clickClear: "clickClear", clickHint: "clickHint", clickReadonly: "clickReadonly", clickViewonly: "clickViewonly" }, host: { properties: { "class.qd-input-readonly": "this.readonly", "class.qd-input--readonly-action": "this.readonlyAction", "class.qd-input-viewonly": "this.viewonly", "class.qd-input--viewonly-action": "this.viewonlyAction", "class.qd-form-hint-action": "this.hintAction", "class.qd-input-hint-action": "this.hintAction", "class.qd-form-disabled": "this.disabled", "class.qd-input-disabled": "this.disabled", "class.qd-input-focus": "this.isInputFocused", "class.qd-form-error": "this.hasError", "class.qd-input-error": "this.hasError", "class.qd-input-error-from-outside": "this.isErrorFromOutside" } }, providers: [
12458
12467
  {