@siemens/ix-angular 2.6.0 → 2.7.0

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.
@@ -19,7 +19,7 @@ export class TextValueAccessorDirective extends ValueAccessor {
19
19
  }
20
20
  }
21
21
  /** @nocollapse */ TextValueAccessorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TextValueAccessorDirective, deps: [{ token: i0.Injector }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
22
- /** @nocollapse */ TextValueAccessorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: TextValueAccessorDirective, selector: "ix-input,ix-number-field,ix-textarea-field", host: { listeners: { "input": "handleInputEvent($event.target)", "valueChange": "handleInputEvent($event.target)" } }, providers: [
22
+ /** @nocollapse */ TextValueAccessorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: TextValueAccessorDirective, selector: "ix-input,ix-number-input,ix-textarea", host: { listeners: { "input": "handleInputEvent($event.target)", "valueChange": "handleInputEvent($event.target)" } }, providers: [
23
23
  {
24
24
  provide: NG_VALUE_ACCESSOR,
25
25
  useExisting: TextValueAccessorDirective,
@@ -29,7 +29,7 @@ export class TextValueAccessorDirective extends ValueAccessor {
29
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TextValueAccessorDirective, decorators: [{
30
30
  type: Directive,
31
31
  args: [{
32
- selector: 'ix-input,ix-number-field,ix-textarea-field',
32
+ selector: 'ix-input,ix-number-input,ix-textarea',
33
33
  providers: [
34
34
  {
35
35
  provide: NG_VALUE_ACCESSOR,
@@ -45,4 +45,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
45
45
  type: HostListener,
46
46
  args: ['valueChange', ['$event.target']]
47
47
  }] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC12YWx1ZS1hY2Nlc3Nvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sLXZhbHVlLWFjY2Vzc29ycy90ZXh0LXZhbHVlLWFjY2Vzc29yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0dBT0c7QUFDSCxPQUFPLEVBQXdCLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDOztBQVlqRCxNQUFNLE9BQU8sMEJBQTJCLFNBQVEsYUFBYTtJQUMzRCxZQUFZLFFBQWtCLEVBQUUsRUFBYztRQUM1QyxLQUFLLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7SUFJRCxnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7OzBJQVRVLDBCQUEwQjs4SEFBMUIsMEJBQTBCLDRMQVIxQjtRQUNUO1lBQ0UsT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixXQUFXLEVBQUUsMEJBQTBCO1lBQ3ZDLEtBQUssRUFBRSxJQUFJO1NBQ1o7S0FDRjsyRkFFVSwwQkFBMEI7a0JBVnRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLDRDQUE0QztvQkFDdEQsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsNEJBQTRCOzRCQUN2QyxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRjtpQkFDRjt3SEFRQyxnQkFBZ0I7c0JBRmYsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxlQUFlLENBQUM7O3NCQUN2QyxZQUFZO3VCQUFDLGFBQWEsRUFBRSxDQUFDLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBTUERYLUZpbGVDb3B5cmlnaHRUZXh0OiAyMDI0IFNpZW1lbnMgQUdcbiAqXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTUlUXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cbmltcG9ydCB7IEVsZW1lbnRSZWYsIEluamVjdG9yLCBEaXJlY3RpdmUsIEhvc3RMaXN0ZW5lciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBWYWx1ZUFjY2Vzc29yIH0gZnJvbSAnLi92YWx1ZS1hY2Nlc3Nvcic7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ2l4LWlucHV0LGl4LW51bWJlci1maWVsZCxpeC10ZXh0YXJlYS1maWVsZCcsXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgdXNlRXhpc3Rpbmc6IFRleHRWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVGV4dFZhbHVlQWNjZXNzb3JEaXJlY3RpdmUgZXh0ZW5kcyBWYWx1ZUFjY2Vzc29yIHtcbiAgY29uc3RydWN0b3IoaW5qZWN0b3I6IEluamVjdG9yLCBlbDogRWxlbWVudFJlZikge1xuICAgIHN1cGVyKGluamVjdG9yLCBlbCk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdpbnB1dCcsIFsnJGV2ZW50LnRhcmdldCddKVxuICBASG9zdExpc3RlbmVyKCd2YWx1ZUNoYW5nZScsIFsnJGV2ZW50LnRhcmdldCddKVxuICBoYW5kbGVJbnB1dEV2ZW50KGVsOiBhbnkpOiB2b2lkIHtcbiAgICBzdXBlci5oYW5kbGVWYWx1ZUNoYW5nZShlbCwgZWwudmFsdWUpO1xuICB9XG59XG4iXX0=
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC12YWx1ZS1hY2Nlc3Nvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250cm9sLXZhbHVlLWFjY2Vzc29ycy90ZXh0LXZhbHVlLWFjY2Vzc29yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7Ozs7O0dBT0c7QUFDSCxPQUFPLEVBQXdCLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDOztBQVlqRCxNQUFNLE9BQU8sMEJBQTJCLFNBQVEsYUFBYTtJQUMzRCxZQUFZLFFBQWtCLEVBQUUsRUFBYztRQUM1QyxLQUFLLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7SUFJRCxnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7OzBJQVRVLDBCQUEwQjs4SEFBMUIsMEJBQTBCLHNMQVIxQjtRQUNUO1lBQ0UsT0FBTyxFQUFFLGlCQUFpQjtZQUMxQixXQUFXLEVBQUUsMEJBQTBCO1lBQ3ZDLEtBQUssRUFBRSxJQUFJO1NBQ1o7S0FDRjsyRkFFVSwwQkFBMEI7a0JBVnRDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHNDQUFzQztvQkFDaEQsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsNEJBQTRCOzRCQUN2QyxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRjtpQkFDRjt3SEFRQyxnQkFBZ0I7c0JBRmYsWUFBWTt1QkFBQyxPQUFPLEVBQUUsQ0FBQyxlQUFlLENBQUM7O3NCQUN2QyxZQUFZO3VCQUFDLGFBQWEsRUFBRSxDQUFDLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBTUERYLUZpbGVDb3B5cmlnaHRUZXh0OiAyMDI0IFNpZW1lbnMgQUdcbiAqXG4gKiBTUERYLUxpY2Vuc2UtSWRlbnRpZmllcjogTUlUXG4gKlxuICogVGhpcyBzb3VyY2UgY29kZSBpcyBsaWNlbnNlZCB1bmRlciB0aGUgTUlUIGxpY2Vuc2UgZm91bmQgaW4gdGhlXG4gKiBMSUNFTlNFIGZpbGUgaW4gdGhlIHJvb3QgZGlyZWN0b3J5IG9mIHRoaXMgc291cmNlIHRyZWUuXG4gKi9cbmltcG9ydCB7IEVsZW1lbnRSZWYsIEluamVjdG9yLCBEaXJlY3RpdmUsIEhvc3RMaXN0ZW5lciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBWYWx1ZUFjY2Vzc29yIH0gZnJvbSAnLi92YWx1ZS1hY2Nlc3Nvcic7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ2l4LWlucHV0LGl4LW51bWJlci1pbnB1dCxpeC10ZXh0YXJlYScsXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxuICAgICAgdXNlRXhpc3Rpbmc6IFRleHRWYWx1ZUFjY2Vzc29yRGlyZWN0aXZlLFxuICAgICAgbXVsdGk6IHRydWUsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVGV4dFZhbHVlQWNjZXNzb3JEaXJlY3RpdmUgZXh0ZW5kcyBWYWx1ZUFjY2Vzc29yIHtcbiAgY29uc3RydWN0b3IoaW5qZWN0b3I6IEluamVjdG9yLCBlbDogRWxlbWVudFJlZikge1xuICAgIHN1cGVyKGluamVjdG9yLCBlbCk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCdpbnB1dCcsIFsnJGV2ZW50LnRhcmdldCddKVxuICBASG9zdExpc3RlbmVyKCd2YWx1ZUNoYW5nZScsIFsnJGV2ZW50LnRhcmdldCddKVxuICBoYW5kbGVJbnB1dEV2ZW50KGVsOiBhbnkpOiB2b2lkIHtcbiAgICBzdXBlci5oYW5kbGVWYWx1ZUNoYW5nZShlbCwgZWwudmFsdWUpO1xuICB9XG59XG4iXX0=
@@ -22,7 +22,7 @@ export class ValueAccessor {
22
22
  }
23
23
  writeValue(value) {
24
24
  this.elementRef.nativeElement.value = this.lastValue = value;
25
- mapNgToIxClassNames(this.elementRef);
25
+ this.setClasses();
26
26
  }
27
27
  handleValueChange(el, value) {
28
28
  if (el === this.elementRef.nativeElement) {
@@ -30,13 +30,13 @@ export class ValueAccessor {
30
30
  this.lastValue = value;
31
31
  this.onChange(value);
32
32
  }
33
- mapNgToIxClassNames(this.elementRef);
33
+ this.setClasses();
34
34
  }
35
35
  }
36
36
  _handleBlurEvent(el) {
37
37
  if (el === this.elementRef.nativeElement) {
38
38
  this.onTouched();
39
- mapNgToIxClassNames(this.elementRef);
39
+ this.setClasses();
40
40
  }
41
41
  }
42
42
  registerOnChange(fn) {
@@ -54,22 +54,33 @@ export class ValueAccessor {
54
54
  }
55
55
  }
56
56
  ngAfterViewInit() {
57
- let ngControl;
57
+ let ngControl = this.getAssignedNgControl();
58
+ if (!ngControl) {
59
+ return;
60
+ }
61
+ if (ngControl.statusChanges) {
62
+ this.statusChanges = ngControl.statusChanges.subscribe(() => {
63
+ this.setClasses();
64
+ });
65
+ }
66
+ detourFormControlMethods(ngControl, this.elementRef);
67
+ }
68
+ getAssignedNgControl() {
69
+ let ngControl = null;
58
70
  try {
59
71
  ngControl = this.injector.get(NgControl);
60
72
  }
61
73
  catch {
62
74
  /* No FormControl or ngModel binding */
63
75
  }
76
+ return ngControl;
77
+ }
78
+ setClasses() {
79
+ const ngControl = this.getAssignedNgControl();
64
80
  if (!ngControl) {
65
81
  return;
66
82
  }
67
- if (ngControl.statusChanges) {
68
- this.statusChanges = ngControl.statusChanges.subscribe(() => {
69
- mapNgToIxClassNames(this.elementRef);
70
- });
71
- }
72
- detourFormControlMethods(ngControl, this.elementRef);
83
+ mapNgToIxClassNames(this.elementRef);
73
84
  }
74
85
  }
75
86
  ValueAccessor.ANGULAR_CLASS_PREFIX = 'ng-';
@@ -102,8 +113,8 @@ const detourFormControlMethods = (ngControl, elementRef) => {
102
113
  });
103
114
  }
104
115
  };
105
- export const mapNgToIxClassNames = (element) => {
106
- setTimeout(() => {
116
+ export const mapNgToIxClassNames = async (element) => {
117
+ setTimeout(async () => {
107
118
  const input = element.nativeElement;
108
119
  const classes = getClasses(input);
109
120
  const classList = input.classList;
@@ -122,4 +133,4 @@ const getClasses = (element) => {
122
133
  }
123
134
  return classes;
124
135
  };
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"value-accessor.js","sourceRoot":"","sources":["../../../src/control-value-accessors/value-accessor.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport {\n  AfterViewInit,\n  ElementRef,\n  Injector,\n  OnDestroy,\n  Directive,\n  HostListener,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\n@Directive()\nexport class ValueAccessor\n  implements ControlValueAccessor, AfterViewInit, OnDestroy\n{\n  public static readonly ANGULAR_CLASS_PREFIX = 'ng-';\n\n  private onChange: (value: any) => void = () => {\n    /**/\n  };\n  private onTouched: () => void = () => {\n    /**/\n  };\n  protected lastValue: any;\n  private statusChanges?: Subscription;\n\n  constructor(protected injector: Injector, protected elementRef: ElementRef) {}\n\n  writeValue(value: any): void {\n    this.elementRef.nativeElement.value = this.lastValue = value;\n    mapNgToIxClassNames(this.elementRef);\n  }\n\n  handleValueChange(el: HTMLElement, value: any): void {\n    if (el === this.elementRef.nativeElement) {\n      if (value !== this.lastValue) {\n        this.lastValue = value;\n        this.onChange(value);\n      }\n      mapNgToIxClassNames(this.elementRef);\n    }\n  }\n\n  @HostListener('ixBlur', ['$event.target'])\n  _handleBlurEvent(el: any): void {\n    if (el === this.elementRef.nativeElement) {\n      this.onTouched();\n      mapNgToIxClassNames(this.elementRef);\n    }\n  }\n\n  registerOnChange(fn: (value: any) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.elementRef.nativeElement.disabled = isDisabled;\n  }\n\n  ngOnDestroy(): void {\n    if (this.statusChanges) {\n      this.statusChanges.unsubscribe();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    let ngControl;\n    try {\n      ngControl = this.injector.get<NgControl>(NgControl);\n    } catch {\n      /* No FormControl or ngModel binding */\n    }\n\n    if (!ngControl) {\n      return;\n    }\n\n    if (ngControl.statusChanges) {\n      this.statusChanges = ngControl.statusChanges.subscribe(() => {\n        mapNgToIxClassNames(this.elementRef);\n      });\n    }\n\n    detourFormControlMethods(ngControl, this.elementRef);\n  }\n}\n\nconst detourFormControlMethods = (\n  ngControl: NgControl,\n  elementRef: ElementRef\n) => {\n  const formControl = ngControl.control as any;\n  if (formControl) {\n    const methodsToPatch = [\n      'markAsTouched',\n      'markAllAsTouched',\n      'markAsUntouched',\n      'markAsDirty',\n      'markAsPristine',\n    ];\n    methodsToPatch.forEach((method) => {\n      if (typeof formControl[method] !== 'undefined') {\n        const oldFn = formControl[method].bind(formControl);\n        formControl[method] = (...params: any[]) => {\n          oldFn(...params);\n          mapNgToIxClassNames(elementRef);\n        };\n      }\n    });\n  }\n};\n\nexport const mapNgToIxClassNames = (element: ElementRef): void => {\n  setTimeout(() => {\n    const input = element.nativeElement as HTMLInputElement;\n    const classes = getClasses(input);\n    const classList = input.classList;\n    classList.remove(\n      'ix-valid',\n      'ix-invalid',\n      'ix-touched',\n      'ix-untouched',\n      'ix-dirty',\n      'ix-pristine'\n    );\n    classList.add(...classes);\n  });\n};\n\nconst getClasses = (element: HTMLElement) => {\n  const classList = element.classList;\n  const classes: string[] = [];\n  for (let i = 0; i < classList.length; i++) {\n    const item = classList.item(i);\n    if (item?.startsWith(ValueAccessor.ANGULAR_CLASS_PREFIX)) {\n      classes.push(`ix-${item.substring(3)}`);\n    }\n  }\n  return classes;\n};\n"]}
136
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"value-accessor.js","sourceRoot":"","sources":["../../../src/control-value-accessors/value-accessor.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * SPDX-FileCopyrightText: 2024 Siemens AG\n *\n * SPDX-License-Identifier: MIT\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\nimport {\n  AfterViewInit,\n  ElementRef,\n  Injector,\n  OnDestroy,\n  Directive,\n  HostListener,\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { Subscription } from 'rxjs';\n\n@Directive()\nexport class ValueAccessor\n  implements ControlValueAccessor, AfterViewInit, OnDestroy\n{\n  public static readonly ANGULAR_CLASS_PREFIX = 'ng-';\n\n  private onChange: (value: any) => void = () => {\n    /**/\n  };\n  private onTouched: () => void = () => {\n    /**/\n  };\n  protected lastValue: any;\n  private statusChanges?: Subscription;\n\n  constructor(protected injector: Injector, protected elementRef: ElementRef) {}\n\n  writeValue(value: any): void {\n    this.elementRef.nativeElement.value = this.lastValue = value;\n    this.setClasses();\n  }\n\n  handleValueChange(el: HTMLElement, value: any): void {\n    if (el === this.elementRef.nativeElement) {\n      if (value !== this.lastValue) {\n        this.lastValue = value;\n        this.onChange(value);\n      }\n      this.setClasses();\n    }\n  }\n\n  @HostListener('ixBlur', ['$event.target'])\n  _handleBlurEvent(el: any): void {\n    if (el === this.elementRef.nativeElement) {\n      this.onTouched();\n      this.setClasses();\n    }\n  }\n\n  registerOnChange(fn: (value: any) => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.elementRef.nativeElement.disabled = isDisabled;\n  }\n\n  ngOnDestroy(): void {\n    if (this.statusChanges) {\n      this.statusChanges.unsubscribe();\n    }\n  }\n\n  ngAfterViewInit(): void {\n    let ngControl = this.getAssignedNgControl();\n\n    if (!ngControl) {\n      return;\n    }\n\n    if (ngControl.statusChanges) {\n      this.statusChanges = ngControl.statusChanges.subscribe(() => {\n        this.setClasses();\n      });\n    }\n\n    detourFormControlMethods(ngControl, this.elementRef);\n  }\n\n  getAssignedNgControl(): NgControl | null {\n    let ngControl: NgControl | null = null;\n    try {\n      ngControl = this.injector.get<NgControl>(NgControl);\n    } catch {\n      /* No FormControl or ngModel binding */\n    }\n\n    return ngControl;\n  }\n\n  setClasses() {\n    const ngControl = this.getAssignedNgControl();\n    if (!ngControl) {\n      return;\n    }\n    mapNgToIxClassNames(this.elementRef);\n  }\n}\n\nconst detourFormControlMethods = (\n  ngControl: NgControl,\n  elementRef: ElementRef\n) => {\n  const formControl = ngControl.control as any;\n  if (formControl) {\n    const methodsToPatch = [\n      'markAsTouched',\n      'markAllAsTouched',\n      'markAsUntouched',\n      'markAsDirty',\n      'markAsPristine',\n    ];\n    methodsToPatch.forEach((method) => {\n      if (typeof formControl[method] !== 'undefined') {\n        const oldFn = formControl[method].bind(formControl);\n        formControl[method] = (...params: any[]) => {\n          oldFn(...params);\n          mapNgToIxClassNames(elementRef);\n        };\n      }\n    });\n  }\n};\n\nexport const mapNgToIxClassNames = async (\n  element: ElementRef\n): Promise<void> => {\n  setTimeout(async () => {\n    const input = element.nativeElement;\n\n    const classes = getClasses(input);\n    const classList = input.classList;\n    classList.remove(\n      'ix-valid',\n      'ix-invalid',\n      'ix-touched',\n      'ix-untouched',\n      'ix-dirty',\n      'ix-pristine'\n    );\n    classList.add(...classes);\n  });\n};\n\nconst getClasses = (element: HTMLElement) => {\n  const classList = element.classList;\n  const classes: string[] = [];\n  for (let i = 0; i < classList.length; i++) {\n    const item = classList.item(i);\n    if (item?.startsWith(ValueAccessor.ANGULAR_CLASS_PREFIX)) {\n      classes.push(`ix-${item.substring(3)}`);\n    }\n  }\n  return classes;\n};\n"]}
@@ -119,7 +119,7 @@ let IxApplicationHeader = class IxApplicationHeader {
119
119
  this.z = z;
120
120
  c.detach();
121
121
  this.el = r.nativeElement;
122
- proxyOutputs(this, this.el, ['menuToggle']);
122
+ proxyOutputs(this, this.el, ['menuToggle', 'openAppSwitch']);
123
123
  }
124
124
  };
125
125
  /** @nocollapse */ IxApplicationHeader.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: IxApplicationHeader, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
@@ -605,10 +605,10 @@ let IxDateDropdown = class IxDateDropdown {
605
605
  }
606
606
  };
607
607
  /** @nocollapse */ IxDateDropdown.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: IxDateDropdown, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
608
- /** @nocollapse */ IxDateDropdown.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: IxDateDropdown, selector: "ix-date-dropdown", inputs: { customRangeAllowed: "customRangeAllowed", dateRangeId: "dateRangeId", dateRangeOptions: "dateRangeOptions", disabled: "disabled", format: "format", from: "from", i18nCustomItem: "i18nCustomItem", i18nDone: "i18nDone", i18nNoRange: "i18nNoRange", locale: "locale", maxDate: "maxDate", minDate: "minDate", range: "range", to: "to", weekStartIndex: "weekStartIndex" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
608
+ /** @nocollapse */ IxDateDropdown.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: IxDateDropdown, selector: "ix-date-dropdown", inputs: { customRangeAllowed: "customRangeAllowed", dateRangeId: "dateRangeId", dateRangeOptions: "dateRangeOptions", disabled: "disabled", format: "format", from: "from", ghost: "ghost", i18nCustomItem: "i18nCustomItem", i18nDone: "i18nDone", i18nNoRange: "i18nNoRange", loading: "loading", locale: "locale", maxDate: "maxDate", minDate: "minDate", outline: "outline", range: "range", to: "to", variant: "variant", weekStartIndex: "weekStartIndex" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
609
609
  IxDateDropdown = __decorate([
610
610
  ProxyCmp({
611
- inputs: ['customRangeAllowed', 'dateRangeId', 'dateRangeOptions', 'disabled', 'format', 'from', 'i18nCustomItem', 'i18nDone', 'i18nNoRange', 'locale', 'maxDate', 'minDate', 'range', 'to', 'weekStartIndex'],
611
+ inputs: ['customRangeAllowed', 'dateRangeId', 'dateRangeOptions', 'disabled', 'format', 'from', 'ghost', 'i18nCustomItem', 'i18nDone', 'i18nNoRange', 'loading', 'locale', 'maxDate', 'minDate', 'outline', 'range', 'to', 'variant', 'weekStartIndex'],
612
612
  methods: ['getDateRange']
613
613
  })
614
614
  ], IxDateDropdown);
@@ -619,7 +619,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
619
619
  changeDetection: ChangeDetectionStrategy.OnPush,
620
620
  template: '<ng-content></ng-content>',
621
621
  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property
622
- inputs: ['customRangeAllowed', 'dateRangeId', 'dateRangeOptions', 'disabled', 'format', 'from', 'i18nCustomItem', 'i18nDone', 'i18nNoRange', 'locale', 'maxDate', 'minDate', 'range', 'to', 'weekStartIndex'],
622
+ inputs: ['customRangeAllowed', 'dateRangeId', 'dateRangeOptions', 'disabled', 'format', 'from', 'ghost', 'i18nCustomItem', 'i18nDone', 'i18nNoRange', 'loading', 'locale', 'maxDate', 'minDate', 'outline', 'range', 'to', 'variant', 'weekStartIndex'],
623
623
  }]
624
624
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.NgZone }]; } });
625
625
  let IxDateInput = class IxDateInput {
@@ -951,10 +951,10 @@ let IxExpandingSearch = class IxExpandingSearch {
951
951
  }
952
952
  };
953
953
  /** @nocollapse */ IxExpandingSearch.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: IxExpandingSearch, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
954
- /** @nocollapse */ IxExpandingSearch.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: IxExpandingSearch, selector: "ix-expanding-search", inputs: { fullWidth: "fullWidth", icon: "icon", placeholder: "placeholder", value: "value" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
954
+ /** @nocollapse */ IxExpandingSearch.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: IxExpandingSearch, selector: "ix-expanding-search", inputs: { fullWidth: "fullWidth", ghost: "ghost", icon: "icon", outline: "outline", placeholder: "placeholder", value: "value", variant: "variant" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
955
955
  IxExpandingSearch = __decorate([
956
956
  ProxyCmp({
957
- inputs: ['fullWidth', 'icon', 'placeholder', 'value']
957
+ inputs: ['fullWidth', 'ghost', 'icon', 'outline', 'placeholder', 'value', 'variant']
958
958
  })
959
959
  ], IxExpandingSearch);
960
960
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: IxExpandingSearch, decorators: [{
@@ -964,7 +964,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
964
964
  changeDetection: ChangeDetectionStrategy.OnPush,
965
965
  template: '<ng-content></ng-content>',
966
966
  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property
967
- inputs: ['fullWidth', 'icon', 'placeholder', 'value'],
967
+ inputs: ['fullWidth', 'ghost', 'icon', 'outline', 'placeholder', 'value', 'variant'],
968
968
  }]
969
969
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.NgZone }]; } });
970
970
  let IxFieldLabel = class IxFieldLabel {
@@ -1455,7 +1455,7 @@ let IxMenu = class IxMenu {
1455
1455
  this.z = z;
1456
1456
  c.detach();
1457
1457
  this.el = r.nativeElement;
1458
- proxyOutputs(this, this.el, ['expandChange', 'mapExpandChange']);
1458
+ proxyOutputs(this, this.el, ['expandChange', 'mapExpandChange', 'openAppSwitch']);
1459
1459
  }
1460
1460
  };
1461
1461
  /** @nocollapse */ IxMenu.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: IxMenu, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
@@ -2048,10 +2048,10 @@ let IxSelect = class IxSelect {
2048
2048
  }
2049
2049
  };
2050
2050
  /** @nocollapse */ IxSelect.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: IxSelect, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
2051
- /** @nocollapse */ IxSelect.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: IxSelect, selector: "ix-select", inputs: { allowClear: "allowClear", disabled: "disabled", editable: "editable", helperText: "helperText", hideListHeader: "hideListHeader", i18nNoMatches: "i18nNoMatches", i18nPlaceholder: "i18nPlaceholder", i18nPlaceholderEditable: "i18nPlaceholderEditable", i18nSelectListHeader: "i18nSelectListHeader", infoText: "infoText", invalidText: "invalidText", label: "label", mode: "mode", name: "name", readonly: "readonly", required: "required", selectedIndices: "selectedIndices", showTextAsTooltip: "showTextAsTooltip", validText: "validText", value: "value", warningText: "warningText" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
2051
+ /** @nocollapse */ IxSelect.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: IxSelect, selector: "ix-select", inputs: { allowClear: "allowClear", disabled: "disabled", dropdownMaxWidth: "dropdownMaxWidth", dropdownWidth: "dropdownWidth", editable: "editable", helperText: "helperText", hideListHeader: "hideListHeader", i18nNoMatches: "i18nNoMatches", i18nPlaceholder: "i18nPlaceholder", i18nPlaceholderEditable: "i18nPlaceholderEditable", i18nSelectListHeader: "i18nSelectListHeader", infoText: "infoText", invalidText: "invalidText", label: "label", mode: "mode", name: "name", readonly: "readonly", required: "required", selectedIndices: "selectedIndices", showTextAsTooltip: "showTextAsTooltip", validText: "validText", value: "value", warningText: "warningText" }, ngImport: i0, template: '<ng-content></ng-content>', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
2052
2052
  IxSelect = __decorate([
2053
2053
  ProxyCmp({
2054
- inputs: ['allowClear', 'disabled', 'editable', 'helperText', 'hideListHeader', 'i18nNoMatches', 'i18nPlaceholder', 'i18nPlaceholderEditable', 'i18nSelectListHeader', 'infoText', 'invalidText', 'label', 'mode', 'name', 'readonly', 'required', 'selectedIndices', 'showTextAsTooltip', 'validText', 'value', 'warningText'],
2054
+ inputs: ['allowClear', 'disabled', 'dropdownMaxWidth', 'dropdownWidth', 'editable', 'helperText', 'hideListHeader', 'i18nNoMatches', 'i18nPlaceholder', 'i18nPlaceholderEditable', 'i18nSelectListHeader', 'infoText', 'invalidText', 'label', 'mode', 'name', 'readonly', 'required', 'selectedIndices', 'showTextAsTooltip', 'validText', 'value', 'warningText'],
2055
2055
  methods: ['getNativeInputElement', 'focusInput']
2056
2056
  })
2057
2057
  ], IxSelect);
@@ -2062,7 +2062,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
2062
2062
  changeDetection: ChangeDetectionStrategy.OnPush,
2063
2063
  template: '<ng-content></ng-content>',
2064
2064
  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property
2065
- inputs: ['allowClear', 'disabled', 'editable', 'helperText', 'hideListHeader', 'i18nNoMatches', 'i18nPlaceholder', 'i18nPlaceholderEditable', 'i18nSelectListHeader', 'infoText', 'invalidText', 'label', 'mode', 'name', 'readonly', 'required', 'selectedIndices', 'showTextAsTooltip', 'validText', 'value', 'warningText'],
2065
+ inputs: ['allowClear', 'disabled', 'dropdownMaxWidth', 'dropdownWidth', 'editable', 'helperText', 'hideListHeader', 'i18nNoMatches', 'i18nPlaceholder', 'i18nPlaceholderEditable', 'i18nSelectListHeader', 'infoText', 'invalidText', 'label', 'mode', 'name', 'readonly', 'required', 'selectedIndices', 'showTextAsTooltip', 'validText', 'value', 'warningText'],
2066
2066
  }]
2067
2067
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i0.NgZone }]; } });
2068
2068
  let IxSelectItem = class IxSelectItem {
@@ -2767,14 +2767,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
2767
2767
  * LICENSE file in the root directory of this source tree.
2768
2768
  */
2769
2769
 
2770
- /*
2771
- * SPDX-FileCopyrightText: 2024 Siemens AG
2772
- *
2773
- * SPDX-License-Identifier: MIT
2774
- *
2775
- * This source code is licensed under the MIT license found in the
2776
- * LICENSE file in the root directory of this source tree.
2777
- */
2778
2770
  class ValueAccessor {
2779
2771
  constructor(injector, elementRef) {
2780
2772
  this.injector = injector;
@@ -2788,7 +2780,7 @@ class ValueAccessor {
2788
2780
  }
2789
2781
  writeValue(value) {
2790
2782
  this.elementRef.nativeElement.value = this.lastValue = value;
2791
- mapNgToIxClassNames(this.elementRef);
2783
+ this.setClasses();
2792
2784
  }
2793
2785
  handleValueChange(el, value) {
2794
2786
  if (el === this.elementRef.nativeElement) {
@@ -2796,13 +2788,13 @@ class ValueAccessor {
2796
2788
  this.lastValue = value;
2797
2789
  this.onChange(value);
2798
2790
  }
2799
- mapNgToIxClassNames(this.elementRef);
2791
+ this.setClasses();
2800
2792
  }
2801
2793
  }
2802
2794
  _handleBlurEvent(el) {
2803
2795
  if (el === this.elementRef.nativeElement) {
2804
2796
  this.onTouched();
2805
- mapNgToIxClassNames(this.elementRef);
2797
+ this.setClasses();
2806
2798
  }
2807
2799
  }
2808
2800
  registerOnChange(fn) {
@@ -2820,22 +2812,33 @@ class ValueAccessor {
2820
2812
  }
2821
2813
  }
2822
2814
  ngAfterViewInit() {
2823
- let ngControl;
2815
+ let ngControl = this.getAssignedNgControl();
2816
+ if (!ngControl) {
2817
+ return;
2818
+ }
2819
+ if (ngControl.statusChanges) {
2820
+ this.statusChanges = ngControl.statusChanges.subscribe(() => {
2821
+ this.setClasses();
2822
+ });
2823
+ }
2824
+ detourFormControlMethods(ngControl, this.elementRef);
2825
+ }
2826
+ getAssignedNgControl() {
2827
+ let ngControl = null;
2824
2828
  try {
2825
2829
  ngControl = this.injector.get(NgControl);
2826
2830
  }
2827
2831
  catch (_a) {
2828
2832
  /* No FormControl or ngModel binding */
2829
2833
  }
2834
+ return ngControl;
2835
+ }
2836
+ setClasses() {
2837
+ const ngControl = this.getAssignedNgControl();
2830
2838
  if (!ngControl) {
2831
2839
  return;
2832
2840
  }
2833
- if (ngControl.statusChanges) {
2834
- this.statusChanges = ngControl.statusChanges.subscribe(() => {
2835
- mapNgToIxClassNames(this.elementRef);
2836
- });
2837
- }
2838
- detourFormControlMethods(ngControl, this.elementRef);
2841
+ mapNgToIxClassNames(this.elementRef);
2839
2842
  }
2840
2843
  }
2841
2844
  ValueAccessor.ANGULAR_CLASS_PREFIX = 'ng-';
@@ -2868,15 +2871,15 @@ const detourFormControlMethods = (ngControl, elementRef) => {
2868
2871
  });
2869
2872
  }
2870
2873
  };
2871
- const mapNgToIxClassNames = (element) => {
2872
- setTimeout(() => {
2874
+ const mapNgToIxClassNames = (element) => __awaiter(void 0, void 0, void 0, function* () {
2875
+ setTimeout(() => __awaiter(void 0, void 0, void 0, function* () {
2873
2876
  const input = element.nativeElement;
2874
2877
  const classes = getClasses(input);
2875
2878
  const classList = input.classList;
2876
2879
  classList.remove('ix-valid', 'ix-invalid', 'ix-touched', 'ix-untouched', 'ix-dirty', 'ix-pristine');
2877
2880
  classList.add(...classes);
2878
- });
2879
- };
2881
+ }));
2882
+ });
2880
2883
  const getClasses = (element) => {
2881
2884
  const classList = element.classList;
2882
2885
  const classes = [];
@@ -2906,7 +2909,7 @@ class TextValueAccessorDirective extends ValueAccessor {
2906
2909
  }
2907
2910
  }
2908
2911
  /** @nocollapse */ TextValueAccessorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TextValueAccessorDirective, deps: [{ token: i0.Injector }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
2909
- /** @nocollapse */ TextValueAccessorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: TextValueAccessorDirective, selector: "ix-input,ix-number-field,ix-textarea-field", host: { listeners: { "input": "handleInputEvent($event.target)", "valueChange": "handleInputEvent($event.target)" } }, providers: [
2912
+ /** @nocollapse */ TextValueAccessorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: TextValueAccessorDirective, selector: "ix-input,ix-number-input,ix-textarea", host: { listeners: { "input": "handleInputEvent($event.target)", "valueChange": "handleInputEvent($event.target)" } }, providers: [
2910
2913
  {
2911
2914
  provide: NG_VALUE_ACCESSOR,
2912
2915
  useExisting: TextValueAccessorDirective,
@@ -2916,7 +2919,7 @@ class TextValueAccessorDirective extends ValueAccessor {
2916
2919
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: TextValueAccessorDirective, decorators: [{
2917
2920
  type: Directive,
2918
2921
  args: [{
2919
- selector: 'ix-input,ix-number-field,ix-textarea-field',
2922
+ selector: 'ix-input,ix-number-input,ix-textarea',
2920
2923
  providers: [
2921
2924
  {
2922
2925
  provide: NG_VALUE_ACCESSOR,