@acorex/components 17.1.2 → 17.1.4

Sign up to get free protection for your applications and to get access to all the features.
Files changed (30) hide show
  1. package/common/lib/classes/components.class.d.ts +3 -2
  2. package/common/lib/components/value-component.class.d.ts +2 -1
  3. package/esm2022/collapse/lib/collapse-group.component.mjs +11 -9
  4. package/esm2022/common/lib/classes/components.class.mjs +1 -1
  5. package/esm2022/common/lib/components/selection-base.component.class.mjs +2 -2
  6. package/esm2022/common/lib/components/value-component.class.mjs +5 -2
  7. package/esm2022/form/lib/form-field.component.mjs +3 -4
  8. package/esm2022/form/lib/form.component.mjs +7 -4
  9. package/esm2022/list/lib/list.component.mjs +3 -3
  10. package/esm2022/number-box/lib/number-box.component.mjs +8 -28
  11. package/esm2022/otp/lib/otp.component.mjs +3 -3
  12. package/esm2022/select-box/lib/select-box.component.mjs +17 -11
  13. package/fesm2022/acorex-components-collapse.mjs +9 -7
  14. package/fesm2022/acorex-components-collapse.mjs.map +1 -1
  15. package/fesm2022/acorex-components-common.mjs +5 -2
  16. package/fesm2022/acorex-components-common.mjs.map +1 -1
  17. package/fesm2022/acorex-components-form.mjs +8 -6
  18. package/fesm2022/acorex-components-form.mjs.map +1 -1
  19. package/fesm2022/acorex-components-list.mjs +2 -2
  20. package/fesm2022/acorex-components-list.mjs.map +1 -1
  21. package/fesm2022/acorex-components-number-box.mjs +7 -27
  22. package/fesm2022/acorex-components-number-box.mjs.map +1 -1
  23. package/fesm2022/acorex-components-otp.mjs +2 -2
  24. package/fesm2022/acorex-components-otp.mjs.map +1 -1
  25. package/fesm2022/acorex-components-select-box.mjs +16 -10
  26. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  27. package/form/lib/form.component.d.ts +2 -1
  28. package/number-box/lib/number-box.component.d.ts +1 -1
  29. package/otp/lib/otp.component.d.ts +1 -1
  30. package/package.json +1 -1
@@ -1,6 +1,6 @@
1
+ import { AXValidationRuleOptions, AXValidationSummary } from '@acorex/core/validation';
1
2
  import { EventEmitter } from '@angular/core';
2
3
  import { AXEvent, AXValueChangedEvent } from './events.class';
3
- import { AXValidationRuleOptions, AXValidationSummary } from '@acorex/core/validation';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare const TAB_META_KEY = "__meta__";
6
6
  export declare class AXComponentCloseEvent extends AXEvent {
@@ -58,7 +58,8 @@ export declare abstract class AXValuableComponent extends AXComponent {
58
58
  abstract addValidationRule(rule: AXFormValidationRule): any;
59
59
  abstract removeValidationRule(rule: AXFormValidationRule): any;
60
60
  abstract validate(): Promise<AXValidationSummary>;
61
- abstract clear(e: boolean): void;
61
+ abstract reset(e: boolean): void;
62
+ abstract resetErrors(): void;
62
63
  static ɵfac: i0.ɵɵFactoryDeclaration<AXValuableComponent, never>;
63
64
  static ɵprov: i0.ɵɵInjectableDeclaration<AXValuableComponent>;
64
65
  }
@@ -61,7 +61,8 @@ export declare class MXValueComponent<T = any> extends MXInteractiveComponent im
61
61
  registerOnChange(fn: (value: T) => void): void;
62
62
  writeValue(value: T): void;
63
63
  commitValue(value: T, u?: boolean): void;
64
- clear(e?: boolean): void;
64
+ reset(e?: boolean): void;
65
+ resetErrors(): void;
65
66
  static ɵfac: i0.ɵɵFactoryDeclaration<MXValueComponent<any>, never>;
66
67
  static ɵprov: i0.ɵɵInjectableDeclaration<MXValueComponent<any>>;
67
68
  }
@@ -1,4 +1,4 @@
1
- import { MXBaseComponent, MXLookComponent, MXLookableComponent, } from '@acorex/components/common';
1
+ import { MXBaseComponent, MXLookComponent, MXLookableComponent } from '@acorex/components/common';
2
2
  import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, HostBinding, Input, Output, QueryList, ViewEncapsulation, } from '@angular/core';
3
3
  import { classes } from 'polytype';
4
4
  import { AXCollapseComponent } from './collapse.component';
@@ -23,10 +23,12 @@ export class AXCollapseGroupComponent extends classes(MXBaseComponent, MXLookCom
23
23
  name: 'accordion',
24
24
  value,
25
25
  afterCallback: (oldValue, newValue) => {
26
- if (newValue)
26
+ if (newValue) {
27
27
  this.applyAccordion();
28
- else
28
+ }
29
+ else {
29
30
  this.removeAccordion();
31
+ }
30
32
  },
31
33
  });
32
34
  }
@@ -55,13 +57,15 @@ export class AXCollapseGroupComponent extends classes(MXBaseComponent, MXLookCom
55
57
  });
56
58
  }
57
59
  ngAfterViewInit() {
58
- this.applyAccordion();
60
+ if (this.accordion) {
61
+ this.applyAccordion();
62
+ }
59
63
  }
60
64
  applyAccordion() {
61
65
  if (!this.look)
62
66
  return;
63
67
  if (this._items && this._items.length > 1) {
64
- const activeIndex = this._items.get(this.activeIndex) || this._items[0];
68
+ const activeIndex = this._items.get(this.activeIndex) || this._items.get(0);
65
69
  this._items.forEach((c) => (c.isCollapsed = true));
66
70
  if (activeIndex)
67
71
  activeIndex.isCollapsed = false;
@@ -72,9 +76,7 @@ export class AXCollapseGroupComponent extends classes(MXBaseComponent, MXLookCom
72
76
  c1.onClick.subscribe((e) => {
73
77
  if (!e.handled) {
74
78
  this._activeIndex = list.indexOf(c1);
75
- list
76
- .filter((c2) => c2 != c1)
77
- .forEach((c) => (c.isCollapsed = true));
79
+ list.filter((c2) => c2 != c1).forEach((c) => (c.isCollapsed = true));
78
80
  }
79
81
  }));
80
82
  });
@@ -128,4 +130,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
128
130
  type: HostBinding,
129
131
  args: ['class']
130
132
  }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collapse-group.component.js","sourceRoot":"","sources":["../../../../../../libs/components/collapse/src/lib/collapse-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  MXBaseComponent,\n  MXLookComponent,\n  MXLookableComponent,\n} from '@acorex/components/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { classes } from 'polytype';\nimport { Subscription } from 'rxjs';\nimport { AXCollapseComponent } from './collapse.component';\n\n@Component({\n  selector: 'ax-collapse-group',\n  inputs: ['look'],\n  template: `<ng-content select=\"ax-collapse\"></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: MXLookableComponent,\n      useExisting: AXCollapseGroupComponent,\n    },\n  ],\n})\nexport class AXCollapseGroupComponent\n  extends classes(MXBaseComponent, MXLookComponent)\n  implements AfterViewInit, OnDestroy\n{\n  @Output()\n  accordionChange: EventEmitter<boolean> = new EventEmitter();\n  private _accordion?: boolean = false;\n\n  /**\n   *  Enables accordion behavior, allowing only one collapsible item to be expanded at a time\n   */\n  @Input()\n  get accordion(): boolean | undefined {\n    return this._accordion;\n  }\n  set accordion(value: boolean) {\n    this.setOption({\n      name: 'accordion',\n      value,\n      afterCallback: (oldValue, newValue) => {\n        if (newValue) this.applyAccordion();\n        else this.removeAccordion();\n      },\n    });\n  }\n\n  @Output()\n  activeIndexChange: EventEmitter<number> = new EventEmitter<number>();\n  private _activeIndex = 0;\n  /**\n   *  Index of the currently active item within the group\n   */\n  @Input()\n  get activeIndex(): number {\n    return this._activeIndex;\n  }\n  set activeIndex(value: number) {\n    this.setOption({\n      name: 'activeIndex',\n      value,\n      beforeCallback: (oldValue, newValue) => {\n        const len = this._items?.length || 0;\n        if (newValue < 0) newValue = 0;\n        if (len > 0 && newValue >= len) {\n          newValue = len - 1;\n        }\n        return newValue;\n      },\n      afterCallback: () => {\n        this.applyAccordion();\n      },\n    });\n  }\n\n  @ContentChildren(AXCollapseComponent)\n  private _items: QueryList<AXCollapseComponent>;\n\n  private _subs: Subscription[] = [];\n\n  ngAfterViewInit(): void {\n    this.applyAccordion();\n  }\n\n  private applyAccordion() {\n    if (!this.look) return;\n    if (this._items && this._items.length > 1) {\n      const activeIndex = this._items.get(this.activeIndex) || this._items[0];\n      this._items.forEach((c) => (c.isCollapsed = true));\n      if (activeIndex) activeIndex.isCollapsed = false;\n      this._items.forEach((c1: AXCollapseComponent) => {\n        const list = this._items.toArray();\n\n        this._subs.push(\n          // TODO: add and use a new event for status changes\n          c1.onClick.subscribe((e) => {\n            if (!e.handled) {\n              this._activeIndex = list.indexOf(c1);\n              list\n                .filter((c2) => c2 != c1)\n                .forEach((c) => (c.isCollapsed = true));\n            }\n          })\n        );\n      });\n    }\n  }\n\n  private removeAccordion() {\n    this._subs.forEach((s) => s.unsubscribe());\n    this._subs = [];\n  }\n\n  ngOnDestroy(): void {\n    this.removeAccordion();\n  }\n\n  @HostBinding('class')\n  private get __hostClass(): string[] {\n    return ['ax-collapse-group', `ax-look-${this.look}`];\n  }\n}\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collapse-group.component.js","sourceRoot":"","sources":["../../../../../../libs/components/collapse/src/lib/collapse-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { MXBaseComponent, MXLookComponent, MXLookableComponent } from '@acorex/components/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  HostBinding,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { classes } from 'polytype';\nimport { Subscription } from 'rxjs';\nimport { AXCollapseComponent } from './collapse.component';\n\n@Component({\n  selector: 'ax-collapse-group',\n  inputs: ['look'],\n  template: `<ng-content select=\"ax-collapse\"></ng-content>`,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: MXLookableComponent,\n      useExisting: AXCollapseGroupComponent,\n    },\n  ],\n})\nexport class AXCollapseGroupComponent extends classes(MXBaseComponent, MXLookComponent) implements AfterViewInit, OnDestroy {\n  @Output()\n  accordionChange: EventEmitter<boolean> = new EventEmitter();\n  private _accordion?: boolean = false;\n\n  /**\n   *  Enables accordion behavior, allowing only one collapsible item to be expanded at a time\n   */\n  @Input()\n  get accordion(): boolean | undefined {\n    return this._accordion;\n  }\n  set accordion(value: boolean) {\n    this.setOption({\n      name: 'accordion',\n      value,\n      afterCallback: (oldValue, newValue) => {\n        if (newValue) {\n          this.applyAccordion();\n        } else {\n          this.removeAccordion();\n        }\n      },\n    });\n  }\n\n  @Output()\n  activeIndexChange: EventEmitter<number> = new EventEmitter<number>();\n  private _activeIndex = 0;\n  /**\n   *  Index of the currently active item within the group\n   */\n  @Input()\n  get activeIndex(): number {\n    return this._activeIndex;\n  }\n  set activeIndex(value: number) {\n    this.setOption({\n      name: 'activeIndex',\n      value,\n      beforeCallback: (oldValue, newValue) => {\n        const len = this._items?.length || 0;\n        if (newValue < 0) newValue = 0;\n        if (len > 0 && newValue >= len) {\n          newValue = len - 1;\n        }\n        return newValue;\n      },\n      afterCallback: () => {\n        this.applyAccordion();\n      },\n    });\n  }\n\n  @ContentChildren(AXCollapseComponent)\n  private _items: QueryList<AXCollapseComponent>;\n\n  private _subs: Subscription[] = [];\n\n  ngAfterViewInit(): void {\n    if (this.accordion) {\n      this.applyAccordion();\n    }\n  }\n\n  private applyAccordion() {\n    if (!this.look) return;\n    if (this._items && this._items.length > 1) {\n      const activeIndex = this._items.get(this.activeIndex) || this._items.get(0);\n      this._items.forEach((c) => (c.isCollapsed = true));\n      if (activeIndex) activeIndex.isCollapsed = false;\n      this._items.forEach((c1: AXCollapseComponent) => {\n        const list = this._items.toArray();\n\n        this._subs.push(\n          // TODO: add and use a new event for status changes\n          c1.onClick.subscribe((e) => {\n            if (!e.handled) {\n              this._activeIndex = list.indexOf(c1);\n              list.filter((c2) => c2 != c1).forEach((c) => (c.isCollapsed = true));\n            }\n          }),\n        );\n      });\n    }\n  }\n\n  private removeAccordion() {\n    this._subs.forEach((s) => s.unsubscribe());\n    this._subs = [];\n  }\n\n  ngOnDestroy(): void {\n    this.removeAccordion();\n  }\n\n  @HostBinding('class')\n  private get __hostClass(): string[] {\n    return ['ax-collapse-group', `ax-look-${this.look}`];\n  }\n}\n"]}
@@ -73,4 +73,4 @@ export class AXPagedComponent extends AXComponent {
73
73
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXPagedComponent, decorators: [{
74
74
  type: Injectable
75
75
  }] });
76
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb21tb24vc3JjL2xpYi9jbGFzc2VzL2NvbXBvbmVudHMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFnQixVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLE9BQU8sRUFBdUIsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFNOUQsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLFVBQVUsQ0FBQztBQUV2QyxNQUFNLE9BQU8scUJBQXNCLFNBQVEsT0FBTztDQUVqRDtBQUNELE1BQU0sT0FBTyxrQkFBa0I7SUFBL0I7UUFDRSxXQUFNLEdBQUcsS0FBSyxDQUFDO0lBRWpCLENBQUM7Q0FBQTtBQUVELE1BQU0sT0FBTyxpQkFBaUI7Q0FHN0I7QUFPRDs7R0FFRztBQUNILE1BQU0sT0FBTyx3QkFBeUIsU0FBUSxPQUEwQjtJQUV0RSxZQUNFLFFBS1M7UUFFVCxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbEIsQ0FBQztJQUVNLEtBQUs7UUFDVixJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNyQixJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDckIsQ0FBQztJQUNILENBQUM7Q0FDRjtBQUdELE1BQU0sT0FBZ0IsV0FBVzs4R0FBWCxXQUFXO2tIQUFYLFdBQVc7OzJGQUFYLFdBQVc7a0JBRGhDLFVBQVU7O0FBSVgsTUFBTSxPQUFnQixtQkFBb0IsU0FBUSxXQUFXOzhHQUF2QyxtQkFBbUI7a0hBQW5CLG1CQUFtQjs7MkZBQW5CLG1CQUFtQjtrQkFEeEMsVUFBVTs7QUFNWCxNQUFNLE9BQWdCLG9CQUFxQixTQUFRLFdBQVc7OEdBQXhDLG9CQUFvQjtrSEFBcEIsb0JBQW9COzsyRkFBcEIsb0JBQW9CO2tCQUR6QyxVQUFVOztBQVNYLE1BQU0sT0FBZ0IscUJBQXNCLFNBQVEsV0FBVzs4R0FBekMscUJBQXFCO2tIQUFyQixxQkFBcUI7OzJGQUFyQixxQkFBcUI7a0JBRDFDLFVBQVU7O0FBTVgsTUFBTSxPQUFnQixtQkFBb0IsU0FBUSxXQUFXOzhHQUF2QyxtQkFBbUI7a0hBQW5CLG1CQUFtQjs7MkZBQW5CLG1CQUFtQjtrQkFEeEMsVUFBVTs7QUFrQlgsTUFBTSxPQUFnQixvQkFBcUIsU0FBUSxXQUFXOzhHQUF4QyxvQkFBb0I7a0hBQXBCLG9CQUFvQjs7MkZBQXBCLG9CQUFvQjtrQkFEekMsVUFBVTs7QUFhWCxNQUFNLE9BQWdCLGdCQUNwQixTQUFRLFdBQVc7OEdBREMsZ0JBQWdCO2tIQUFoQixnQkFBZ0I7OzJGQUFoQixnQkFBZ0I7a0JBRHJDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFdmVudEVtaXR0ZXIsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYRXZlbnQsIEFYVmFsdWVDaGFuZ2VkRXZlbnQgfSBmcm9tICcuL2V2ZW50cy5jbGFzcyc7XG5pbXBvcnQge1xuICBBWFZhbGlkYXRpb25SdWxlT3B0aW9ucyxcbiAgQVhWYWxpZGF0aW9uU3VtbWFyeSxcbn0gZnJvbSAnQGFjb3JleC9jb3JlL3ZhbGlkYXRpb24nO1xuXG5leHBvcnQgY29uc3QgVEFCX01FVEFfS0VZID0gJ19fbWV0YV9fJztcblxuZXhwb3J0IGNsYXNzIEFYQ29tcG9uZW50Q2xvc2VFdmVudCBleHRlbmRzIEFYRXZlbnQge1xuICBkYXRhPzogYW55O1xufVxuZXhwb3J0IGNsYXNzIEFYQ29tcG9uZW50Q2xvc2luZyB7XG4gIGNhbmNlbCA9IGZhbHNlO1xuICBkYXRhPzogYW55O1xufVxuXG5leHBvcnQgY2xhc3MgQVhDb21wb25lbnRSZXN1bHQge1xuICBzZW5kZXI6IGFueTtcbiAgZGF0YT86IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBWEZvcm1WYWxpZGF0aW9uUnVsZSB7XG4gIHJ1bGU6IHN0cmluZztcbiAgb3B0aW9ucz86IEFYVmFsaWRhdGlvblJ1bGVPcHRpb25zO1xufVxuXG4vKipcbiAqICBEZWZpbmVzIGEgQ1NTIGNsYXNz4oCUb3IgbXVsdGlwbGUgY2xhc3NlcyBzZXBhcmF0ZWQgYnkgc3BhY2Vz4oCUIHdoaWNoIGFyZSBhcHBsaWVkIHRvIGEgc3BhbiBlbGVtZW50IGluc2lkZSB0aGUgQnV0dG9uLiBBbGxvd3MgdGhlIHVzYWdlIG9mIGN1c3RvbSBpY29ucyBhZnRlciB0aGUgcHJpbWFyeSB0ZXh0LlxuICovXG5leHBvcnQgY2xhc3MgQVhDb21wb25lbnRDbG9zZWRQcm9taXNlIGV4dGVuZHMgUHJvbWlzZTxBWENvbXBvbmVudFJlc3VsdD4ge1xuICBwcml2YXRlIGNsb3NlTWV0aG9kOiAoKSA9PiB2b2lkO1xuICBjb25zdHJ1Y3RvcihcbiAgICBleGVjdXRvcjogKFxuICAgICAgcmVzb2x2ZTogKFxuICAgICAgICB2YWx1ZT86IEFYQ29tcG9uZW50UmVzdWx0IHwgUHJvbWlzZUxpa2U8QVhDb21wb25lbnRSZXN1bHQ+XG4gICAgICApID0+IHZvaWQsXG4gICAgICByZWplY3Q6IChyZWFzb24/OiBhbnkpID0+IHZvaWRcbiAgICApID0+IHZvaWRcbiAgKSB7XG4gICAgc3VwZXIoZXhlY3V0b3IpO1xuICB9XG5cbiAgcHVibGljIGNsb3NlKCkge1xuICAgIGlmICh0aGlzLmNsb3NlTWV0aG9kKSB7XG4gICAgICB0aGlzLmNsb3NlTWV0aG9kKCk7XG4gICAgfVxuICB9XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBWENvbXBvbmVudCB7fVxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQVhDbG9zYmFsZUNvbXBvbmVudCBleHRlbmRzIEFYQ29tcG9uZW50IHtcbiAgYWJzdHJhY3QgY2xvc2UoKTogdm9pZDtcbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFYQ2xlYXJhYmxlQ29tcG9uZW50IGV4dGVuZHMgQVhDb21wb25lbnQge1xuICBhYnN0cmFjdCBjbGVhcih1OiBib29sZWFuKTogdm9pZDtcbiAgYWJzdHJhY3QgZ2V0IHJlYWRvbmx5KCk6IGJvb2xlYW47XG4gIGFic3RyYWN0IGdldCBkaXNhYmxlZCgpOiBib29sZWFuO1xuICBhYnN0cmFjdCBnZXQgdmFsdWUoKTogdW5rbm93bjtcbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFYU2VhcmNoYWJsZUNvbXBvbmVudCBleHRlbmRzIEFYQ29tcG9uZW50IHtcbiAgYWJzdHJhY3Qgc2VhcmNoKHZhbHVlOiBzdHJpbmcpOiB2b2lkO1xufVxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQVhWYWx1YWJsZUNvbXBvbmVudCBleHRlbmRzIEFYQ29tcG9uZW50IHtcbiAgYWJzdHJhY3QgZ2V0IGlzUmVxdWlyZWQoKTogYm9vbGVhbjtcbiAgdmFsaWRhdGlvblJ1bGVzQ2hhbmdlOiBFdmVudEVtaXR0ZXI8QVhGb3JtVmFsaWRhdGlvblJ1bGVbXT47XG4gIGFic3RyYWN0IGdldCBuYW1lKCk6IHN0cmluZztcbiAgYWJzdHJhY3QgZ2V0IHZhbHVlKCk6IHVua25vd247XG4gIGFic3RyYWN0IG9uVmFsdWVDaGFuZ2VkOiBFdmVudEVtaXR0ZXI8QVhWYWx1ZUNoYW5nZWRFdmVudDx1bmtub3duPj47XG4gIGFic3RyYWN0IGNvbW1pdFZhbHVlKHZhbHVlOiB1bmtub3duLCB1OiBib29sZWFuKTtcblxuICBhYnN0cmFjdCBhZGRWYWxpZGF0aW9uUnVsZShydWxlOiBBWEZvcm1WYWxpZGF0aW9uUnVsZSk7XG5cbiAgYWJzdHJhY3QgcmVtb3ZlVmFsaWRhdGlvblJ1bGUocnVsZTogQVhGb3JtVmFsaWRhdGlvblJ1bGUpO1xuXG4gIGFic3RyYWN0IHZhbGlkYXRlKCk6IFByb21pc2U8QVhWYWxpZGF0aW9uU3VtbWFyeT47XG4gIGFic3RyYWN0IGNsZWFyKGU6IGJvb2xlYW4pOiB2b2lkO1xufVxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQVhGb2N1c2FibGVDb21wb25lbnQgZXh0ZW5kcyBBWENvbXBvbmVudCB7XG4gIGFic3RyYWN0IGZvY3VzKCk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVhQYWdlZENvbXBvbmVudEludGVyZmFjZSB7XG4gIGdvVG9QYWdlKHBhZ2U6IG51bWJlcik7XG4gIGdldCB0b3RhbENvdW50KCk6IG51bWJlcjtcbiAgZ2V0IHBhZ2VTaXplKCk6IG51bWJlcjtcbiAgb25QYWdlQ2hhbmdlZDogRXZlbnRFbWl0dGVyPEFYVmFsdWVDaGFuZ2VkRXZlbnQ8bnVtYmVyPj47XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBWFBhZ2VkQ29tcG9uZW50XG4gIGV4dGVuZHMgQVhDb21wb25lbnRcbiAgaW1wbGVtZW50cyBBWFBhZ2VkQ29tcG9uZW50SW50ZXJmYWNlXG57XG4gIGFic3RyYWN0IGdvVG9QYWdlKHBhZ2U6IG51bWJlcik7XG4gIGFic3RyYWN0IGdldCB0b3RhbENvdW50KCk6IG51bWJlcjtcbiAgYWJzdHJhY3QgcGFnZVNpemU6IG51bWJlcjtcbiAgYWJzdHJhY3Qgb25QYWdlQ2hhbmdlZDogRXZlbnRFbWl0dGVyPEFYVmFsdWVDaGFuZ2VkRXZlbnQ8bnVtYmVyPj47XG59XG4iXX0=
76
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb21tb24vc3JjL2xpYi9jbGFzc2VzL2NvbXBvbmVudHMuY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFnQixVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFFLE9BQU8sRUFBdUIsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFFOUQsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLFVBQVUsQ0FBQztBQUV2QyxNQUFNLE9BQU8scUJBQXNCLFNBQVEsT0FBTztDQUVqRDtBQUNELE1BQU0sT0FBTyxrQkFBa0I7SUFBL0I7UUFDRSxXQUFNLEdBQUcsS0FBSyxDQUFDO0lBRWpCLENBQUM7Q0FBQTtBQUVELE1BQU0sT0FBTyxpQkFBaUI7Q0FHN0I7QUFPRDs7R0FFRztBQUNILE1BQU0sT0FBTyx3QkFBeUIsU0FBUSxPQUEwQjtJQUV0RSxZQUNFLFFBQWlJO1FBRWpJLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNsQixDQUFDO0lBRU0sS0FBSztRQUNWLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUNyQixDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBR0QsTUFBTSxPQUFnQixXQUFXOzhHQUFYLFdBQVc7a0hBQVgsV0FBVzs7MkZBQVgsV0FBVztrQkFEaEMsVUFBVTs7QUFJWCxNQUFNLE9BQWdCLG1CQUFvQixTQUFRLFdBQVc7OEdBQXZDLG1CQUFtQjtrSEFBbkIsbUJBQW1COzsyRkFBbkIsbUJBQW1CO2tCQUR4QyxVQUFVOztBQU1YLE1BQU0sT0FBZ0Isb0JBQXFCLFNBQVEsV0FBVzs4R0FBeEMsb0JBQW9CO2tIQUFwQixvQkFBb0I7OzJGQUFwQixvQkFBb0I7a0JBRHpDLFVBQVU7O0FBU1gsTUFBTSxPQUFnQixxQkFBc0IsU0FBUSxXQUFXOzhHQUF6QyxxQkFBcUI7a0hBQXJCLHFCQUFxQjs7MkZBQXJCLHFCQUFxQjtrQkFEMUMsVUFBVTs7QUFNWCxNQUFNLE9BQWdCLG1CQUFvQixTQUFRLFdBQVc7OEdBQXZDLG1CQUFtQjtrSEFBbkIsbUJBQW1COzsyRkFBbkIsbUJBQW1CO2tCQUR4QyxVQUFVOztBQW1CWCxNQUFNLE9BQWdCLG9CQUFxQixTQUFRLFdBQVc7OEdBQXhDLG9CQUFvQjtrSEFBcEIsb0JBQW9COzsyRkFBcEIsb0JBQW9CO2tCQUR6QyxVQUFVOztBQWFYLE1BQU0sT0FBZ0IsZ0JBQWlCLFNBQVEsV0FBVzs4R0FBcEMsZ0JBQWdCO2tIQUFoQixnQkFBZ0I7OzJGQUFoQixnQkFBZ0I7a0JBRHJDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWFZhbGlkYXRpb25SdWxlT3B0aW9ucywgQVhWYWxpZGF0aW9uU3VtbWFyeSB9IGZyb20gJ0BhY29yZXgvY29yZS92YWxpZGF0aW9uJztcbmltcG9ydCB7IEV2ZW50RW1pdHRlciwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVhFdmVudCwgQVhWYWx1ZUNoYW5nZWRFdmVudCB9IGZyb20gJy4vZXZlbnRzLmNsYXNzJztcblxuZXhwb3J0IGNvbnN0IFRBQl9NRVRBX0tFWSA9ICdfX21ldGFfXyc7XG5cbmV4cG9ydCBjbGFzcyBBWENvbXBvbmVudENsb3NlRXZlbnQgZXh0ZW5kcyBBWEV2ZW50IHtcbiAgZGF0YT86IGFueTtcbn1cbmV4cG9ydCBjbGFzcyBBWENvbXBvbmVudENsb3Npbmcge1xuICBjYW5jZWwgPSBmYWxzZTtcbiAgZGF0YT86IGFueTtcbn1cblxuZXhwb3J0IGNsYXNzIEFYQ29tcG9uZW50UmVzdWx0IHtcbiAgc2VuZGVyOiBhbnk7XG4gIGRhdGE/OiBhbnk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVhGb3JtVmFsaWRhdGlvblJ1bGUge1xuICBydWxlOiBzdHJpbmc7XG4gIG9wdGlvbnM/OiBBWFZhbGlkYXRpb25SdWxlT3B0aW9ucztcbn1cblxuLyoqXG4gKiAgRGVmaW5lcyBhIENTUyBjbGFzc+KAlG9yIG11bHRpcGxlIGNsYXNzZXMgc2VwYXJhdGVkIGJ5IHNwYWNlc+KAlCB3aGljaCBhcmUgYXBwbGllZCB0byBhIHNwYW4gZWxlbWVudCBpbnNpZGUgdGhlIEJ1dHRvbi4gQWxsb3dzIHRoZSB1c2FnZSBvZiBjdXN0b20gaWNvbnMgYWZ0ZXIgdGhlIHByaW1hcnkgdGV4dC5cbiAqL1xuZXhwb3J0IGNsYXNzIEFYQ29tcG9uZW50Q2xvc2VkUHJvbWlzZSBleHRlbmRzIFByb21pc2U8QVhDb21wb25lbnRSZXN1bHQ+IHtcbiAgcHJpdmF0ZSBjbG9zZU1ldGhvZDogKCkgPT4gdm9pZDtcbiAgY29uc3RydWN0b3IoXG4gICAgZXhlY3V0b3I6IChyZXNvbHZlOiAodmFsdWU/OiBBWENvbXBvbmVudFJlc3VsdCB8IFByb21pc2VMaWtlPEFYQ29tcG9uZW50UmVzdWx0PikgPT4gdm9pZCwgcmVqZWN0OiAocmVhc29uPzogYW55KSA9PiB2b2lkKSA9PiB2b2lkLFxuICApIHtcbiAgICBzdXBlcihleGVjdXRvcik7XG4gIH1cblxuICBwdWJsaWMgY2xvc2UoKSB7XG4gICAgaWYgKHRoaXMuY2xvc2VNZXRob2QpIHtcbiAgICAgIHRoaXMuY2xvc2VNZXRob2QoKTtcbiAgICB9XG4gIH1cbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFYQ29tcG9uZW50IHt9XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBWENsb3NiYWxlQ29tcG9uZW50IGV4dGVuZHMgQVhDb21wb25lbnQge1xuICBhYnN0cmFjdCBjbG9zZSgpOiB2b2lkO1xufVxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQVhDbGVhcmFibGVDb21wb25lbnQgZXh0ZW5kcyBBWENvbXBvbmVudCB7XG4gIGFic3RyYWN0IGNsZWFyKHU6IGJvb2xlYW4pOiB2b2lkO1xuICBhYnN0cmFjdCBnZXQgcmVhZG9ubHkoKTogYm9vbGVhbjtcbiAgYWJzdHJhY3QgZ2V0IGRpc2FibGVkKCk6IGJvb2xlYW47XG4gIGFic3RyYWN0IGdldCB2YWx1ZSgpOiB1bmtub3duO1xufVxuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQVhTZWFyY2hhYmxlQ29tcG9uZW50IGV4dGVuZHMgQVhDb21wb25lbnQge1xuICBhYnN0cmFjdCBzZWFyY2godmFsdWU6IHN0cmluZyk6IHZvaWQ7XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBWFZhbHVhYmxlQ29tcG9uZW50IGV4dGVuZHMgQVhDb21wb25lbnQge1xuICBhYnN0cmFjdCBnZXQgaXNSZXF1aXJlZCgpOiBib29sZWFuO1xuICB2YWxpZGF0aW9uUnVsZXNDaGFuZ2U6IEV2ZW50RW1pdHRlcjxBWEZvcm1WYWxpZGF0aW9uUnVsZVtdPjtcbiAgYWJzdHJhY3QgZ2V0IG5hbWUoKTogc3RyaW5nO1xuICBhYnN0cmFjdCBnZXQgdmFsdWUoKTogdW5rbm93bjtcbiAgYWJzdHJhY3Qgb25WYWx1ZUNoYW5nZWQ6IEV2ZW50RW1pdHRlcjxBWFZhbHVlQ2hhbmdlZEV2ZW50PHVua25vd24+PjtcbiAgYWJzdHJhY3QgY29tbWl0VmFsdWUodmFsdWU6IHVua25vd24sIHU6IGJvb2xlYW4pO1xuXG4gIGFic3RyYWN0IGFkZFZhbGlkYXRpb25SdWxlKHJ1bGU6IEFYRm9ybVZhbGlkYXRpb25SdWxlKTtcblxuICBhYnN0cmFjdCByZW1vdmVWYWxpZGF0aW9uUnVsZShydWxlOiBBWEZvcm1WYWxpZGF0aW9uUnVsZSk7XG5cbiAgYWJzdHJhY3QgdmFsaWRhdGUoKTogUHJvbWlzZTxBWFZhbGlkYXRpb25TdW1tYXJ5PjtcbiAgYWJzdHJhY3QgcmVzZXQoZTogYm9vbGVhbik6IHZvaWQ7XG4gIGFic3RyYWN0IHJlc2V0RXJyb3JzKCk6IHZvaWQ7XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBWEZvY3VzYWJsZUNvbXBvbmVudCBleHRlbmRzIEFYQ29tcG9uZW50IHtcbiAgYWJzdHJhY3QgZm9jdXMoKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBWFBhZ2VkQ29tcG9uZW50SW50ZXJmYWNlIHtcbiAgZ29Ub1BhZ2UocGFnZTogbnVtYmVyKTtcbiAgZ2V0IHRvdGFsQ291bnQoKTogbnVtYmVyO1xuICBnZXQgcGFnZVNpemUoKTogbnVtYmVyO1xuICBvblBhZ2VDaGFuZ2VkOiBFdmVudEVtaXR0ZXI8QVhWYWx1ZUNoYW5nZWRFdmVudDxudW1iZXI+Pjtcbn1cblxuQEluamVjdGFibGUoKVxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEFYUGFnZWRDb21wb25lbnQgZXh0ZW5kcyBBWENvbXBvbmVudCBpbXBsZW1lbnRzIEFYUGFnZWRDb21wb25lbnRJbnRlcmZhY2Uge1xuICBhYnN0cmFjdCBnb1RvUGFnZShwYWdlOiBudW1iZXIpO1xuICBhYnN0cmFjdCBnZXQgdG90YWxDb3VudCgpOiBudW1iZXI7XG4gIGFic3RyYWN0IHBhZ2VTaXplOiBudW1iZXI7XG4gIGFic3RyYWN0IG9uUGFnZUNoYW5nZWQ6IEV2ZW50RW1pdHRlcjxBWFZhbHVlQ2hhbmdlZEV2ZW50PG51bWJlcj4+O1xufVxuIl19
@@ -58,7 +58,7 @@ export class MXSelectionValueComponent extends MXValueComponent {
58
58
  name: 'multiple',
59
59
  value: v,
60
60
  afterCallback: () => {
61
- this.clear(false);
61
+ this.reset(false);
62
62
  },
63
63
  });
64
64
  }
@@ -193,4 +193,4 @@ export class MXSelectionValueComponent extends MXValueComponent {
193
193
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: MXSelectionValueComponent, decorators: [{
194
194
  type: Injectable
195
195
  }] });
196
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-base.component.class.js","sourceRoot":"","sources":["../../../../../../../libs/components/common/src/lib/components/selection-base.component.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { Injectable, InjectionToken, inject } from '@angular/core';\nimport { MXValueComponent } from './value-component.class';\n\n@Injectable()\nexport class MXSelectionBridgeService {\n  public selectedItems: unknown[] = [];\n  public cacheList: { [key: string | number]: unknown } = {};\n}\n\nexport const AX_SELECTION_DATA_TOKEN = new InjectionToken<MXSelectionBridgeService>('AX_SELECTION_DATA_TOKEN');\n\n@Injectable()\nexport abstract class MXSelectionValueComponent<T = unknown> extends MXValueComponent<unknown> {\n  private dataService = inject(AX_SELECTION_DATA_TOKEN);\n\n  disabledCallback: (e: { item: T; index: number }) => boolean;\n\n  private _valueField = 'id';\n  public get valueField(): string {\n    return this._valueField;\n  }\n  public set valueField(v: string) {\n    this.setOption({\n      name: 'valueField',\n      value: v,\n    });\n  }\n\n  private _textField = 'text';\n  public get textField(): string {\n    return this._textField;\n  }\n  public set textField(v: string) {\n    this.setOption({\n      name: 'textField',\n      value: v,\n    });\n  }\n\n  private _disabledField = 'disabled';\n  public get disabledField(): string {\n    return this._disabledField;\n  }\n  public set disabledField(v: string) {\n    this.setOption({\n      name: 'disabledField',\n      value: v,\n    });\n  }\n\n  private _multiple = false;\n  public get multiple(): boolean {\n    return this._multiple;\n  }\n  public set multiple(v: boolean) {\n    this.setOption({\n      name: 'multiple',\n      value: v,\n      afterCallback: () => {\n        this.clear(false);\n      },\n    });\n  }\n\n  get selectedItems(): unknown[] {\n    return this.dataService.selectedItems || [];\n  }\n\n  override internalSetValue(value: unknown) {\n    const isArray = Array.isArray(value);\n    if (value == null || (isArray && value.length == 0)) {\n      return this.multiple ? [] : null;\n    }\n    const normalizedItems = isArray ? this.normalizeItemsList(value, true) : this.normalizeItemsList([value], true);\n\n    if (normalizedItems.length == 0) {\n      return this.multiple ? [] : null;\n    }\n    const result = this.multiple ? normalizedItems.map((c) => c[this.valueField]) : normalizedItems[0][this.valueField];\n    return result;\n  }\n\n  override emitOnValueChangedEvent(oldValue?: unknown, newValue?: unknown) {\n    this._normalizeSelectedItems();\n    super.emitOnValueChangedEvent(oldValue, newValue);\n  }\n\n  abstract getItemByKey(key: unknown): unknown | Promise<unknown>;\n\n  protected normalizeItemsList(items: unknown[], findBykey = false): unknown[] {\n    if (items == null) return [];\n    return items.filter((c) => c != null).map((i) => this.normalizeItem(i, findBykey));\n  }\n\n  private normalizeItem(item: unknown, findBykey = false): unknown {\n    const complex = typeof item == 'object';\n    const key = complex ? item[this.valueField] : `${item}`;\n    const cacheKey = `k-${key}`;\n    const hasText = !complex || item[this.textField] != null;\n    //\n    if (this.dataService.cacheList[cacheKey] && this.dataService.cacheList[cacheKey][this.textField])\n      return this.dataService.cacheList[cacheKey];\n    //\n    const obj: unknown = {};\n    if (complex && hasText) {\n      Object.assign(obj, item);\n    } else {\n      const existsItem = findBykey ? this.getItemByKey(key) : null;\n      if (existsItem && existsItem instanceof Promise) {\n        obj[this.valueField] = key;\n        obj['isLoading'] = true;\n        //\n        existsItem\n          .then((r) => {\n            if (typeof r === 'object') {\n              obj[this.valueField] = r[this.valueField];\n              obj[this.textField] = r[this.textField];\n            } else {\n              obj[this.valueField] = r || key;\n            }\n          })\n          .finally(() => {\n            obj['isLoading'] = false;\n            this.dataService.cacheList[cacheKey] = obj;\n            this.cdr.markForCheck();\n          });\n      } else if (existsItem) {\n        obj[this.valueField] = complex ? existsItem[this.valueField] : existsItem;\n      } else {\n        obj[this.valueField] = complex ? item[this.valueField] : item;\n      }\n    }\n    this.dataService.cacheList[cacheKey] = obj;\n    return obj;\n  }\n\n  private _normalizeSelectedItems() {\n    const values = Array.isArray(this.value) ? this.value : this.value != null ? [this.value] : [];\n    this.dataService.selectedItems = values.map((v) => this.normalizeItem(v));\n  }\n\n  public unselectItems(...items: T[]) {\n    if (!items || items.length === 0) {\n      this.commitValue([], true);\n      return;\n    }\n    const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];\n    const newSelectedItems = this.selectedItems.filter((i) => !normalizeItems.some((n) => n[this.valueField] == i[this.valueField]));\n    this.commitValue(newSelectedItems, true);\n  }\n\n  public selectItems(...items: T[]) {\n    if (items && items.length) {\n      let newSelectedItems = Array.isArray(this.value) ? this.value : [this.value];\n      const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];\n      if (this.multiple) {\n        newSelectedItems = [...newSelectedItems, ...normalizeItems];\n      } else {\n        newSelectedItems = normalizeItems;\n      }\n      this.commitValue(newSelectedItems, true);\n    }\n  }\n\n  public toggleSelect(...items: T[]) {\n    items?.forEach((item) => {\n      if (this.multiple) {\n        this.isItemSelected(item) ? this.unselectItems(item) : this.selectItems(item);\n      } else {\n        this.selectItems(item);\n      }\n    });\n  }\n\n  public isItemSelected(item: T): boolean {\n    return this.selectedItems.some((c) => c[this.valueField] === this.normalizeItem(item)[this.valueField]);\n  }\n\n  public isItemDisabled(item: T): boolean {\n    return (\n      this.disabled ||\n      coerceBooleanProperty(item[this.disabledField]) === true ||\n      (this.disabledCallback ? this.disabledCallback({ item, index: -1 }) : false)\n    );\n  }\n\n  protected getDisplayText(item: T) {\n    const normalizeItem = this.normalizeItem(item) as any;\n    return normalizeItem[this.textField] || normalizeItem[this.valueField];\n  }\n\n  protected getValue(item: T) {\n    const normalizeItem = this.normalizeItem(item) as any;\n    return normalizeItem[this.valueField];\n  }\n\n  protected clearSelectionCache() {\n    this.dataService.cacheList = {};\n    this.dataService.selectedItems = [];\n  }\n}\n"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-base.component.class.js","sourceRoot":"","sources":["../../../../../../../libs/components/common/src/lib/components/selection-base.component.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { Injectable, InjectionToken, inject } from '@angular/core';\nimport { MXValueComponent } from './value-component.class';\n\n@Injectable()\nexport class MXSelectionBridgeService {\n  public selectedItems: unknown[] = [];\n  public cacheList: { [key: string | number]: unknown } = {};\n}\n\nexport const AX_SELECTION_DATA_TOKEN = new InjectionToken<MXSelectionBridgeService>('AX_SELECTION_DATA_TOKEN');\n\n@Injectable()\nexport abstract class MXSelectionValueComponent<T = unknown> extends MXValueComponent<unknown> {\n  private dataService = inject(AX_SELECTION_DATA_TOKEN);\n\n  disabledCallback: (e: { item: T; index: number }) => boolean;\n\n  private _valueField = 'id';\n  public get valueField(): string {\n    return this._valueField;\n  }\n  public set valueField(v: string) {\n    this.setOption({\n      name: 'valueField',\n      value: v,\n    });\n  }\n\n  private _textField = 'text';\n  public get textField(): string {\n    return this._textField;\n  }\n  public set textField(v: string) {\n    this.setOption({\n      name: 'textField',\n      value: v,\n    });\n  }\n\n  private _disabledField = 'disabled';\n  public get disabledField(): string {\n    return this._disabledField;\n  }\n  public set disabledField(v: string) {\n    this.setOption({\n      name: 'disabledField',\n      value: v,\n    });\n  }\n\n  private _multiple = false;\n  public get multiple(): boolean {\n    return this._multiple;\n  }\n  public set multiple(v: boolean) {\n    this.setOption({\n      name: 'multiple',\n      value: v,\n      afterCallback: () => {\n        this.reset(false);\n      },\n    });\n  }\n\n  get selectedItems(): unknown[] {\n    return this.dataService.selectedItems || [];\n  }\n\n  override internalSetValue(value: unknown) {\n    const isArray = Array.isArray(value);\n    if (value == null || (isArray && value.length == 0)) {\n      return this.multiple ? [] : null;\n    }\n    const normalizedItems = isArray ? this.normalizeItemsList(value, true) : this.normalizeItemsList([value], true);\n\n    if (normalizedItems.length == 0) {\n      return this.multiple ? [] : null;\n    }\n    const result = this.multiple ? normalizedItems.map((c) => c[this.valueField]) : normalizedItems[0][this.valueField];\n    return result;\n  }\n\n  override emitOnValueChangedEvent(oldValue?: unknown, newValue?: unknown) {\n    this._normalizeSelectedItems();\n    super.emitOnValueChangedEvent(oldValue, newValue);\n  }\n\n  abstract getItemByKey(key: unknown): unknown | Promise<unknown>;\n\n  protected normalizeItemsList(items: unknown[], findBykey = false): unknown[] {\n    if (items == null) return [];\n    return items.filter((c) => c != null).map((i) => this.normalizeItem(i, findBykey));\n  }\n\n  private normalizeItem(item: unknown, findBykey = false): unknown {\n    const complex = typeof item == 'object';\n    const key = complex ? item[this.valueField] : `${item}`;\n    const cacheKey = `k-${key}`;\n    const hasText = !complex || item[this.textField] != null;\n    //\n    if (this.dataService.cacheList[cacheKey] && this.dataService.cacheList[cacheKey][this.textField])\n      return this.dataService.cacheList[cacheKey];\n    //\n    const obj: unknown = {};\n    if (complex && hasText) {\n      Object.assign(obj, item);\n    } else {\n      const existsItem = findBykey ? this.getItemByKey(key) : null;\n      if (existsItem && existsItem instanceof Promise) {\n        obj[this.valueField] = key;\n        obj['isLoading'] = true;\n        //\n        existsItem\n          .then((r) => {\n            if (typeof r === 'object') {\n              obj[this.valueField] = r[this.valueField];\n              obj[this.textField] = r[this.textField];\n            } else {\n              obj[this.valueField] = r || key;\n            }\n          })\n          .finally(() => {\n            obj['isLoading'] = false;\n            this.dataService.cacheList[cacheKey] = obj;\n            this.cdr.markForCheck();\n          });\n      } else if (existsItem) {\n        obj[this.valueField] = complex ? existsItem[this.valueField] : existsItem;\n      } else {\n        obj[this.valueField] = complex ? item[this.valueField] : item;\n      }\n    }\n    this.dataService.cacheList[cacheKey] = obj;\n    return obj;\n  }\n\n  private _normalizeSelectedItems() {\n    const values = Array.isArray(this.value) ? this.value : this.value != null ? [this.value] : [];\n    this.dataService.selectedItems = values.map((v) => this.normalizeItem(v));\n  }\n\n  public unselectItems(...items: T[]) {\n    if (!items || items.length === 0) {\n      this.commitValue([], true);\n      return;\n    }\n    const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];\n    const newSelectedItems = this.selectedItems.filter((i) => !normalizeItems.some((n) => n[this.valueField] == i[this.valueField]));\n    this.commitValue(newSelectedItems, true);\n  }\n\n  public selectItems(...items: T[]) {\n    if (items && items.length) {\n      let newSelectedItems = Array.isArray(this.value) ? this.value : [this.value];\n      const normalizeItems = Array.isArray(items) ? this.normalizeItemsList(items) : [this.normalizeItem(items)];\n      if (this.multiple) {\n        newSelectedItems = [...newSelectedItems, ...normalizeItems];\n      } else {\n        newSelectedItems = normalizeItems;\n      }\n      this.commitValue(newSelectedItems, true);\n    }\n  }\n\n  public toggleSelect(...items: T[]) {\n    items?.forEach((item) => {\n      if (this.multiple) {\n        this.isItemSelected(item) ? this.unselectItems(item) : this.selectItems(item);\n      } else {\n        this.selectItems(item);\n      }\n    });\n  }\n\n  public isItemSelected(item: T): boolean {\n    return this.selectedItems.some((c) => c[this.valueField] === this.normalizeItem(item)[this.valueField]);\n  }\n\n  public isItemDisabled(item: T): boolean {\n    return (\n      this.disabled ||\n      coerceBooleanProperty(item[this.disabledField]) === true ||\n      (this.disabledCallback ? this.disabledCallback({ item, index: -1 }) : false)\n    );\n  }\n\n  protected getDisplayText(item: T) {\n    const normalizeItem = this.normalizeItem(item) as any;\n    return normalizeItem[this.textField] || normalizeItem[this.valueField];\n  }\n\n  protected getValue(item: T) {\n    const normalizeItem = this.normalizeItem(item) as any;\n    return normalizeItem[this.valueField];\n  }\n\n  protected clearSelectionCache() {\n    this.dataService.cacheList = {};\n    this.dataService.selectedItems = [];\n  }\n}\n"]}
@@ -211,13 +211,16 @@ export class MXValueComponent extends MXInteractiveComponent {
211
211
  }
212
212
  this.writeValue(value);
213
213
  }
214
- clear(e = false) {
214
+ reset(e = false) {
215
215
  this.commitValue(null, e);
216
216
  }
217
+ resetErrors() {
218
+ this.setState('clear');
219
+ }
217
220
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: MXValueComponent, deps: null, target: i0.ɵɵFactoryTarget.Injectable }); }
218
221
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: MXValueComponent }); }
219
222
  }
220
223
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: MXValueComponent, decorators: [{
221
224
  type: Injectable
222
225
  }] });
223
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"value-component.class.js","sourceRoot":"","sources":["../../../../../../../libs/components/common/src/lib/components/value-component.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { isBrowser } from '@acorex/core/platform';\nimport { AXValidationService, AXValidationSummary } from '@acorex/core/validation';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { EventEmitter, Injectable, inject } from '@angular/core';\nimport { ControlValueAccessor } from '@angular/forms';\nimport { clone, isEqual } from 'lodash-es';\nimport { noop } from 'rxjs';\nimport { AXFormValidationRule } from '../classes/components.class';\nimport { AXValueChangedEvent } from '../classes/events.class';\nimport { AXComponentState } from './base-component.class';\nimport { MXInteractiveComponent } from './interactive-component.class';\n\n@Injectable()\nexport class MXValueComponent<T = any> extends MXInteractiveComponent implements ControlValueAccessor {\n  /**\n   *  Fires each time the user press a key.\n   *  @event\n   */\n  onValueChanged: EventEmitter<AXValueChangedEvent<any>> = new EventEmitter<AXValueChangedEvent<any>>();\n\n  /**\n   * @deprecated The event should not be used, use ngModelChange instead\n   */\n  valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  readonlyChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n  private _readonly = false;\n  /**\n   *  If set to true, user cannot change the value of component.\n   */\n  get readonly() {\n    return this._readonly;\n  }\n  set readonly(value: boolean) {\n    value = coerceBooleanProperty(value);\n    this.setOption({\n      name: 'readonly',\n      value,\n      afterCallback: () => {\n        this.cdr.markForCheck();\n      },\n    });\n  }\n\n  private _name: string;\n  get name() {\n    return this._name;\n  }\n  set name(value: string) {\n    this._name = value;\n  }\n\n  private _dirty = false;\n  public get dirty() {\n    return this._dirty;\n  }\n\n  markAsDirty() {\n    this._dirty = true;\n  }\n\n  private _isUserInteraction = false;\n\n  initValue: T;\n  defaultValue: T;\n\n  private _value: T;\n  /**\n   * @deprecated The property should not be used, use ngModel instead\n   */\n  get value(): T {\n    return this.internalGetValue(this._value) ?? this.defaultValue;\n  }\n  set value(v: T) {\n    v = this.internalSetValue(v);\n    const old = clone(this.value);\n    if (!isEqual(old, v)) {\n      this._value = v;\n      this.emitOnValueChangedEvent(old, this.value);\n\n      this.internalValueChanged(this.value);\n    }\n    if (v == null || v == undefined || v == '' || (Array.isArray(v) && v.length == 0)) {\n      this.setState('clear');\n    }\n  }\n\n  stateChange: EventEmitter<AXComponentState> = new EventEmitter<AXComponentState>();\n\n  private _state: AXComponentState = 'clear';\n\n  get state(): AXComponentState {\n    return this._state;\n  }\n\n  set state(value: AXComponentState) {\n    this.setState(value);\n    this.stateChange.emit(value);\n  }\n\n  protected emitOnValueChangedEvent(oldValue?: any, newValue?: any) {\n    this.valueChange.emit(newValue);\n    this.onValueChanged.emit({\n      component: this,\n      value: newValue,\n      oldValue: oldValue,\n      name: this.name,\n      isUserInteraction: this._isUserInteraction,\n    });\n    this.onChangeCallback(newValue);\n    this.cdr.markForCheck();\n    this._isUserInteraction = false;\n  }\n\n  protected internalSetValue(value: any): T {\n    return value;\n  }\n\n  protected internalGetValue(value: any): T {\n    return value;\n  }\n\n  protected internalValueChanged(value: any): void {}\n\n  protected override ngOnInit(): void {\n    super.ngOnInit();\n    //\n    this.registerValidation();\n  }\n\n  protected ngOnDestroy() {\n    this.onValueChanged?.unsubscribe();\n    this.onOptionChanged?.unsubscribe();\n  }\n\n  protected registerValidation() {\n    const a = this.getHostElement().querySelectorAll('[ax-form-item=\"true\"]');\n    a.forEach((c) => {\n      c.removeAttribute('ax-form-item');\n    });\n    this.getHostElement().setAttribute('ax-form-item', 'true');\n  }\n\n  private validationService = inject(AXValidationService);\n\n  public validationRulesChange: EventEmitter<AXFormValidationRule[]> = new EventEmitter<AXFormValidationRule[]>();\n  private validationRules: AXFormValidationRule[] = [];\n\n  public get isRequired(): boolean {\n    return this.validationRules?.some((c) => c.rule == 'required');\n  }\n\n  addValidationRule(rule: AXFormValidationRule) {\n    this.validationRules.push(rule);\n    this.validationRulesChange.emit(this.validationRules);\n  }\n\n  removeValidationRule(rule: AXFormValidationRule) {\n    this.validationRules = this.validationRules.filter((r) => r.rule !== rule.rule || !isEqual(r.options, rule.options));\n    this.validationRulesChange.emit(this.validationRules);\n  }\n\n  async validate(): Promise<AXValidationSummary> {\n    const container_classes = ['ax-editor-container', 'ax-checkbox', 'ax-radio'];\n    const container = container_classes.some((c) => this.getHostElement().classList.contains(c))\n      ? this.getHostElement()\n      : this.getHostElement().querySelector('.ax-editor-container');\n    const formField = container?.closest('ax-form-field') || container?.closest('ax-checkbox');\n    const label = formField?.querySelector('ax-label') || formField?.querySelector('label');\n    //\n    const rules = this.validationService.ruleFor(this.value);\n    this.validationRules.forEach((r) => {\n      r.options['title'] = (label?.firstChild?.textContent ?? this.name)?.replace('*', '').trim();\n      rules.addRule(r.rule as any, r.options);\n    });\n    const result = await rules.validate();\n    if (result.result) {\n      this.setState('clear');\n    } else {\n      const message = result.rules.find((c) => !c.result).message;\n      this.setState('error', message);\n    }\n    return result;\n  }\n\n  protected setState(state: AXComponentState, ...args) {\n    //TODO: find a better solution\n    if (isBrowser()) {\n      const container = this.getHostElement().classList.contains('ax-editor-container')\n        ? this.getHostElement()\n        : this.getHostElement().querySelector('.ax-editor-container');\n      const formField = container?.closest('ax-form-field');\n      const label = formField?.querySelector('ax-label') || formField?.querySelector('label');\n      let target = container || this.getHostElement().firstElementChild;\n      if (target?.querySelector('.ax-error-container')) {\n        target = target.querySelector('.ax-error-container');\n      }\n      const parent = target?.parentElement;\n      if (!target || !parent) return;\n\n      switch (state) {\n        case 'clear':\n          this._state = 'clear';\n          if (parent.querySelector('span.ax-error-message')) {\n            parent.removeChild(parent.querySelector('span.ax-error-message')!);\n          }\n          label?.classList.remove('ax-state-error');\n          target.classList.remove('ax-state-error', 'ax-state-success');\n          break;\n        case 'success':\n          this.setState('clear');\n          target.classList.add('ax-state-success');\n          this._state = 'success';\n          break;\n        case 'error':\n          this.setState('clear');\n          if (args[0]) {\n            const span = document.createElement('span');\n            span.innerHTML = args[0];\n            span.classList.add('ax-error-message');\n            parent.appendChild(span);\n          }\n          label?.classList.add('ax-state-error');\n          target.classList.add('ax-state-error');\n\n          this._state = 'error';\n          break;\n      }\n      this.cdr.markForCheck();\n    }\n  }\n\n  protected onChangeCallback: (value: T) => void = noop;\n\n  registerOnChange(fn: (value: T) => void): void {\n    this.onChangeCallback = fn;\n  }\n\n  writeValue(value: T): void {\n    this.value = value;\n  }\n\n  public commitValue(value: T, u = false) {\n    if (u) {\n      this.markAsTouched();\n      this.markAsDirty();\n      this._isUserInteraction = true;\n    }\n    this.writeValue(value);\n  }\n\n  clear(e = false) {\n    this.commitValue(null, e);\n  }\n}\n"]}
226
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"value-component.class.js","sourceRoot":"","sources":["../../../../../../../libs/components/common/src/lib/components/value-component.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { isBrowser } from '@acorex/core/platform';\nimport { AXValidationService, AXValidationSummary } from '@acorex/core/validation';\nimport { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { EventEmitter, Injectable, inject } from '@angular/core';\nimport { ControlValueAccessor } from '@angular/forms';\nimport { clone, isEqual } from 'lodash-es';\nimport { noop } from 'rxjs';\nimport { AXFormValidationRule } from '../classes/components.class';\nimport { AXValueChangedEvent } from '../classes/events.class';\nimport { AXComponentState } from './base-component.class';\nimport { MXInteractiveComponent } from './interactive-component.class';\n\n@Injectable()\nexport class MXValueComponent<T = any> extends MXInteractiveComponent implements ControlValueAccessor {\n  /**\n   *  Fires each time the user press a key.\n   *  @event\n   */\n  onValueChanged: EventEmitter<AXValueChangedEvent<any>> = new EventEmitter<AXValueChangedEvent<any>>();\n\n  /**\n   * @deprecated The event should not be used, use ngModelChange instead\n   */\n  valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  readonlyChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n  private _readonly = false;\n  /**\n   *  If set to true, user cannot change the value of component.\n   */\n  get readonly() {\n    return this._readonly;\n  }\n  set readonly(value: boolean) {\n    value = coerceBooleanProperty(value);\n    this.setOption({\n      name: 'readonly',\n      value,\n      afterCallback: () => {\n        this.cdr.markForCheck();\n      },\n    });\n  }\n\n  private _name: string;\n  get name() {\n    return this._name;\n  }\n  set name(value: string) {\n    this._name = value;\n  }\n\n  private _dirty = false;\n  public get dirty() {\n    return this._dirty;\n  }\n\n  markAsDirty() {\n    this._dirty = true;\n  }\n\n  private _isUserInteraction = false;\n\n  initValue: T;\n  defaultValue: T;\n\n  private _value: T;\n  /**\n   * @deprecated The property should not be used, use ngModel instead\n   */\n  get value(): T {\n    return this.internalGetValue(this._value) ?? this.defaultValue;\n  }\n  set value(v: T) {\n    v = this.internalSetValue(v);\n    const old = clone(this.value);\n    if (!isEqual(old, v)) {\n      this._value = v;\n      this.emitOnValueChangedEvent(old, this.value);\n\n      this.internalValueChanged(this.value);\n    }\n    if (v == null || v == undefined || v == '' || (Array.isArray(v) && v.length == 0)) {\n      this.setState('clear');\n    }\n  }\n\n  stateChange: EventEmitter<AXComponentState> = new EventEmitter<AXComponentState>();\n\n  private _state: AXComponentState = 'clear';\n\n  get state(): AXComponentState {\n    return this._state;\n  }\n\n  set state(value: AXComponentState) {\n    this.setState(value);\n    this.stateChange.emit(value);\n  }\n\n  protected emitOnValueChangedEvent(oldValue?: any, newValue?: any) {\n    this.valueChange.emit(newValue);\n    this.onValueChanged.emit({\n      component: this,\n      value: newValue,\n      oldValue: oldValue,\n      name: this.name,\n      isUserInteraction: this._isUserInteraction,\n    });\n    this.onChangeCallback(newValue);\n    this.cdr.markForCheck();\n    this._isUserInteraction = false;\n  }\n\n  protected internalSetValue(value: any): T {\n    return value;\n  }\n\n  protected internalGetValue(value: any): T {\n    return value;\n  }\n\n  protected internalValueChanged(value: any): void {}\n\n  protected override ngOnInit(): void {\n    super.ngOnInit();\n    //\n    this.registerValidation();\n  }\n\n  protected ngOnDestroy() {\n    this.onValueChanged?.unsubscribe();\n    this.onOptionChanged?.unsubscribe();\n  }\n\n  protected registerValidation() {\n    const a = this.getHostElement().querySelectorAll('[ax-form-item=\"true\"]');\n    a.forEach((c) => {\n      c.removeAttribute('ax-form-item');\n    });\n    this.getHostElement().setAttribute('ax-form-item', 'true');\n  }\n\n  private validationService = inject(AXValidationService);\n\n  public validationRulesChange: EventEmitter<AXFormValidationRule[]> = new EventEmitter<AXFormValidationRule[]>();\n  private validationRules: AXFormValidationRule[] = [];\n\n  public get isRequired(): boolean {\n    return this.validationRules?.some((c) => c.rule == 'required');\n  }\n\n  addValidationRule(rule: AXFormValidationRule) {\n    this.validationRules.push(rule);\n    this.validationRulesChange.emit(this.validationRules);\n  }\n\n  removeValidationRule(rule: AXFormValidationRule) {\n    this.validationRules = this.validationRules.filter((r) => r.rule !== rule.rule || !isEqual(r.options, rule.options));\n    this.validationRulesChange.emit(this.validationRules);\n  }\n\n  async validate(): Promise<AXValidationSummary> {\n    const container_classes = ['ax-editor-container', 'ax-checkbox', 'ax-radio'];\n    const container = container_classes.some((c) => this.getHostElement().classList.contains(c))\n      ? this.getHostElement()\n      : this.getHostElement().querySelector('.ax-editor-container');\n    const formField = container?.closest('ax-form-field') || container?.closest('ax-checkbox');\n    const label = formField?.querySelector('ax-label') || formField?.querySelector('label');\n    //\n    const rules = this.validationService.ruleFor(this.value);\n    this.validationRules.forEach((r) => {\n      r.options['title'] = (label?.firstChild?.textContent ?? this.name)?.replace('*', '').trim();\n      rules.addRule(r.rule as any, r.options);\n    });\n    const result = await rules.validate();\n    if (result.result) {\n      this.setState('clear');\n    } else {\n      const message = result.rules.find((c) => !c.result).message;\n      this.setState('error', message);\n    }\n    return result;\n  }\n\n  protected setState(state: AXComponentState, ...args) {\n    //TODO: find a better solution\n    if (isBrowser()) {\n      const container = this.getHostElement().classList.contains('ax-editor-container')\n        ? this.getHostElement()\n        : this.getHostElement().querySelector('.ax-editor-container');\n      const formField = container?.closest('ax-form-field');\n      const label = formField?.querySelector('ax-label') || formField?.querySelector('label');\n      let target = container || this.getHostElement().firstElementChild;\n      if (target?.querySelector('.ax-error-container')) {\n        target = target.querySelector('.ax-error-container');\n      }\n      const parent = target?.parentElement;\n      if (!target || !parent) return;\n\n      switch (state) {\n        case 'clear':\n          this._state = 'clear';\n          if (parent.querySelector('span.ax-error-message')) {\n            parent.removeChild(parent.querySelector('span.ax-error-message')!);\n          }\n          label?.classList.remove('ax-state-error');\n          target.classList.remove('ax-state-error', 'ax-state-success');\n          break;\n        case 'success':\n          this.setState('clear');\n          target.classList.add('ax-state-success');\n          this._state = 'success';\n          break;\n        case 'error':\n          this.setState('clear');\n          if (args[0]) {\n            const span = document.createElement('span');\n            span.innerHTML = args[0];\n            span.classList.add('ax-error-message');\n            parent.appendChild(span);\n          }\n          label?.classList.add('ax-state-error');\n          target.classList.add('ax-state-error');\n\n          this._state = 'error';\n          break;\n      }\n      this.cdr.markForCheck();\n    }\n  }\n\n  protected onChangeCallback: (value: T) => void = noop;\n\n  registerOnChange(fn: (value: T) => void): void {\n    this.onChangeCallback = fn;\n  }\n\n  writeValue(value: T): void {\n    this.value = value;\n  }\n\n  public commitValue(value: T, u = false) {\n    if (u) {\n      this.markAsTouched();\n      this.markAsDirty();\n      this._isUserInteraction = true;\n    }\n    this.writeValue(value);\n  }\n\n  reset(e = false) {\n    this.commitValue(null, e);\n  }\n\n  resetErrors() {\n    this.setState('clear');\n  }\n}\n"]}
@@ -20,7 +20,6 @@ export class AXFormFieldComponent extends MXBaseComponent {
20
20
  });
21
21
  effect(() => {
22
22
  this.setLabelMode();
23
- console.log('setLabelMode');
24
23
  }, { allowSignalWrites: true });
25
24
  }
26
25
  calcIndentSize() {
@@ -74,11 +73,11 @@ export class AXFormFieldComponent extends MXBaseComponent {
74
73
  return [`ax-state-${this._labelMode()}-label`, `${this.input.value ? 'ax-state-has-value' : ''}`];
75
74
  }
76
75
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXFormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
77
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.2", type: AXFormFieldComponent, selector: "ax-form-field", inputs: { labelMode: { classPropertyName: "labelMode", publicName: "labelMode", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.__hostClass" } }, providers: [AXUnsubscriber], queries: [{ propertyName: "input", first: true, predicate: AXValuableComponent, descendants: true }, { propertyName: "label", first: true, predicate: AXLabelComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [".ax-dark ax-form.ax-form-normal .ax-error-message{border-color:rgba(var(--ax-color-danger-500));background-color:rgba(var(--ax-color-danger-200));color:rgba(var(--ax-color-danger-fore-tint))}.ax-dark ax-form.ax-form-normal .ax-error-message:before,.ax-dark ax-form.ax-form-normal .ax-error-message:after{border-bottom-color:rgba(var(--ax-color-danger-500))}.ax-dark ax-form.ax-form-normal .ax-error-message:before{border-bottom-color:rgba(var(--ax-color-danger-500))}.ax-dark ax-form form.ax-float-error .ax-error-message{border-color:rgba(var(--ax-color-danger-700));background-color:rgba(var(--ax-color-danger-700));color:rgba(var(--ax-color-danger-fore))}.ax-dark ax-form form.ax-float-error .ax-error-message:before,.ax-dark ax-form form.ax-float-error .ax-error-message:after{border-bottom-color:rgba(var(--ax-color-danger-700))}.ax-dark ax-form form.ax-float-error .ax-error-message:before{border-bottom-color:rgba(var(--ax-color-danger-700))}ax-form-field{position:relative;display:block;width:100%}ax-form-field.ax-state-floating-label{--ax-size-default: 3.5rem}ax-form-field.ax-state-floating-label>ax-label{position:absolute;top:50%;transform:translateY(-50%);inset-inline-start:1rem;pointer-events:none;z-index:10;transition:all .15s ease-in-out;display:inline-grid}ax-form-field.ax-state-floating-label>ax-label label{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}ax-form-field.ax-state-floating-label .ax-input::placeholder{opacity:0}ax-form-field.ax-state-floating-label.ax-state-focused>ax-label,ax-form-field.ax-state-floating-label.ax-state-has-value>ax-label{top:10%;transform:translateY(-10%);inset-inline-start:.25rem;padding:0 .5rem}ax-form-field.ax-state-floating-label.ax-state-focused>ax-label label,ax-form-field.ax-state-floating-label.ax-state-has-value>ax-label label{font-size:.75rem}ax-form-field.ax-state-floating-label.ax-state-focused .ax-input,ax-form-field.ax-state-floating-label.ax-state-focused .ax-content,ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-input,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-content,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area{padding-top:.875rem}ax-form-field.ax-state-floating-label.ax-state-focused .ax-input::placeholder,ax-form-field.ax-state-floating-label.ax-state-focused .ax-content::placeholder,ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-input::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-content::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area::placeholder{opacity:1}ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area textarea,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area textarea{padding-top:1.5rem!important}ax-form-field.ax-state-over-label{--ax-size-default: 3.5rem}ax-form-field.ax-state-over-label>ax-label{position:absolute;pointer-events:none;z-index:10;transition:all .15s ease-in-out;display:inline-grid;top:10%;transform:translateY(-10%);inset-inline-start:.25rem;padding:0 .5rem}ax-form-field.ax-state-over-label>ax-label label{margin:0;overflow:hidden;text-overflow:ellipsis;font-size:.75rem;white-space:nowrap}ax-form-field.ax-state-over-label .ax-input::placeholder{opacity:0}ax-form-field.ax-state-over-label.ax-state-focused .ax-input,ax-form-field.ax-state-over-label.ax-state-focused .ax-content,ax-form-field.ax-state-over-label.ax-state-focused ax-text-area,ax-form-field.ax-state-over-label.ax-state-has-value .ax-input,ax-form-field.ax-state-over-label.ax-state-has-value .ax-content,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area{padding-top:1rem}ax-form-field.ax-state-over-label.ax-state-focused .ax-input::placeholder,ax-form-field.ax-state-over-label.ax-state-focused .ax-content::placeholder,ax-form-field.ax-state-over-label.ax-state-focused ax-text-area::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value .ax-input::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value .ax-content::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area::placeholder{opacity:1}ax-form-field.ax-state-over-label.ax-state-focused ax-text-area textarea,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area textarea{padding-top:1.5rem!important}ax-form-field.ax-state-floating-label .ax-select-box-selection,ax-form-field.ax-state-over-label .ax-select-box-selection{padding-top:1.5rem!important}ax-form-field.ax-state-floating-label .ax-select-box-selection.ax-multiple,ax-form-field.ax-state-over-label .ax-select-box-selection.ax-multiple{padding-inline-start:.75rem}ax-form-field .ax-error-message{margin-top:.25rem;margin-bottom:.25rem;display:block;font-size:.75rem;line-height:1rem}ax-form{width:100%}ax-form form.ax-bottom-error .ax-error-message{color:rgba(var(--ax-color-danger-500))}ax-form form.ax-float-error .ax-error-message{position:absolute;bottom:-2.5rem;z-index:20;display:block;width:fit-content;border-radius:.375rem;border-width:1px;border-color:rgba(var(--ax-color-danger-500));background-color:rgba(var(--ax-color-danger-500));padding:.25rem .5rem;font-weight:400;color:rgba(var(--ax-color-danger-fore))}ax-form form.ax-float-error .ax-error-message:before,ax-form form.ax-float-error .ax-error-message:after{pointer-events:none;position:absolute;bottom:100%;inset-inline-start:.75rem;z-index:20;height:0px;width:0px;border-bottom-color:rgba(var(--ax-color-danger-500));border-inline-end-color:transparent;border-inline-start-color:transparent;border-top-color:transparent;content:\"\"}ax-form form.ax-float-error .ax-error-message:before{margin-inline-start:-1px;border-width:4px;border-bottom-color:rgba(var(--ax-color-danger-500))}ax-form form.ax-float-error .ax-error-message:after{border-width:4px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
76
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.2", type: AXFormFieldComponent, selector: "ax-form-field", inputs: { labelMode: { classPropertyName: "labelMode", publicName: "labelMode", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.__hostClass" } }, providers: [AXUnsubscriber], queries: [{ propertyName: "input", first: true, predicate: AXValuableComponent, descendants: true }, { propertyName: "label", first: true, predicate: AXLabelComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [".ax-dark ax-form.ax-form-normal .ax-error-message{border-color:rgba(var(--ax-color-danger-500));background-color:rgba(var(--ax-color-danger-200));color:rgba(var(--ax-color-danger-fore-tint))}.ax-dark ax-form.ax-form-normal .ax-error-message:before,.ax-dark ax-form.ax-form-normal .ax-error-message:after{border-bottom-color:rgba(var(--ax-color-danger-500))}.ax-dark ax-form.ax-form-normal .ax-error-message:before{border-bottom-color:rgba(var(--ax-color-danger-500))}.ax-dark ax-form form.ax-float-error .ax-error-message{border-color:rgba(var(--ax-color-danger-700));background-color:rgba(var(--ax-color-danger-700));color:rgba(var(--ax-color-danger-fore))}.ax-dark ax-form form.ax-float-error .ax-error-message:before,.ax-dark ax-form form.ax-float-error .ax-error-message:after{border-bottom-color:rgba(var(--ax-color-danger-700))}.ax-dark ax-form form.ax-float-error .ax-error-message:before{border-bottom-color:rgba(var(--ax-color-danger-700))}ax-form-field{position:relative;display:block;width:100%}ax-form-field.ax-state-floating-label{--ax-size-default: 3.5rem}ax-form-field.ax-state-floating-label>ax-label{position:absolute;top:50%;transform:translateY(-50%);inset-inline-start:1rem;pointer-events:none;z-index:10;transition:all .15s ease-in-out;display:inline-grid}ax-form-field.ax-state-floating-label>ax-label label{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}ax-form-field.ax-state-floating-label .ax-input::placeholder{opacity:0}ax-form-field.ax-state-floating-label.ax-state-focused>ax-label,ax-form-field.ax-state-floating-label.ax-state-has-value>ax-label{top:10%;transform:translateY(-10%);inset-inline-start:.25rem;padding:0 .5rem}ax-form-field.ax-state-floating-label.ax-state-focused>ax-label label,ax-form-field.ax-state-floating-label.ax-state-has-value>ax-label label{font-size:.75rem;color:rgba(var(--ax-color-text-default),.5)}ax-form-field.ax-state-floating-label.ax-state-focused .ax-input,ax-form-field.ax-state-floating-label.ax-state-focused .ax-content,ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-input,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-content,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area{padding-top:.875rem}ax-form-field.ax-state-floating-label.ax-state-focused .ax-input::placeholder,ax-form-field.ax-state-floating-label.ax-state-focused .ax-content::placeholder,ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-input::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-content::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area::placeholder{opacity:1}ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area textarea,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area textarea{padding-top:1.5rem!important}ax-form-field.ax-state-over-label{--ax-size-default: 3.5rem}ax-form-field.ax-state-over-label>ax-label{position:absolute;pointer-events:none;z-index:10;transition:all .15s ease-in-out;display:inline-grid;top:10%;transform:translateY(-10%);inset-inline-start:.25rem;padding:0 .5rem}ax-form-field.ax-state-over-label>ax-label label{margin:0;overflow:hidden;text-overflow:ellipsis;font-size:.75rem;white-space:nowrap}ax-form-field.ax-state-over-label .ax-input::placeholder{opacity:0}ax-form-field.ax-state-over-label.ax-state-focused .ax-input,ax-form-field.ax-state-over-label.ax-state-focused .ax-content,ax-form-field.ax-state-over-label.ax-state-focused ax-text-area,ax-form-field.ax-state-over-label.ax-state-has-value .ax-input,ax-form-field.ax-state-over-label.ax-state-has-value .ax-content,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area{padding-top:1rem}ax-form-field.ax-state-over-label.ax-state-focused .ax-input::placeholder,ax-form-field.ax-state-over-label.ax-state-focused .ax-content::placeholder,ax-form-field.ax-state-over-label.ax-state-focused ax-text-area::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value .ax-input::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value .ax-content::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area::placeholder{opacity:1}ax-form-field.ax-state-over-label.ax-state-focused ax-text-area textarea,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area textarea{padding-top:1.5rem!important}ax-form-field.ax-state-floating-label .ax-select-box-selection.ax-multiple,ax-form-field.ax-state-over-label .ax-select-box-selection.ax-multiple{padding-top:1.5rem!important;padding-inline-start:.75rem}ax-form-field .ax-error-message{margin-top:.25rem;margin-bottom:.25rem;display:block;font-size:.75rem;line-height:1rem}ax-form{width:100%}ax-form form.ax-bottom-error .ax-error-message{color:rgba(var(--ax-color-danger-500))}ax-form form.ax-float-error .ax-error-message{position:absolute;bottom:-2.5rem;z-index:20;display:block;width:fit-content;border-radius:.375rem;border-width:1px;border-color:rgba(var(--ax-color-danger-500));background-color:rgba(var(--ax-color-danger-500));padding:.25rem .5rem;font-weight:400;color:rgba(var(--ax-color-danger-fore))}ax-form form.ax-float-error .ax-error-message:before,ax-form form.ax-float-error .ax-error-message:after{pointer-events:none;position:absolute;bottom:100%;inset-inline-start:.75rem;z-index:20;height:0px;width:0px;border-bottom-color:rgba(var(--ax-color-danger-500));border-inline-end-color:transparent;border-inline-start-color:transparent;border-top-color:transparent;content:\"\"}ax-form form.ax-float-error .ax-error-message:before{margin-inline-start:-1px;border-width:4px;border-bottom-color:rgba(var(--ax-color-danger-500))}ax-form form.ax-float-error .ax-error-message:after{border-width:4px}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
78
77
  }
79
78
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImport: i0, type: AXFormFieldComponent, decorators: [{
80
79
  type: Component,
81
- args: [{ selector: 'ax-form-field', template: `<ng-content></ng-content>`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [AXUnsubscriber], styles: [".ax-dark ax-form.ax-form-normal .ax-error-message{border-color:rgba(var(--ax-color-danger-500));background-color:rgba(var(--ax-color-danger-200));color:rgba(var(--ax-color-danger-fore-tint))}.ax-dark ax-form.ax-form-normal .ax-error-message:before,.ax-dark ax-form.ax-form-normal .ax-error-message:after{border-bottom-color:rgba(var(--ax-color-danger-500))}.ax-dark ax-form.ax-form-normal .ax-error-message:before{border-bottom-color:rgba(var(--ax-color-danger-500))}.ax-dark ax-form form.ax-float-error .ax-error-message{border-color:rgba(var(--ax-color-danger-700));background-color:rgba(var(--ax-color-danger-700));color:rgba(var(--ax-color-danger-fore))}.ax-dark ax-form form.ax-float-error .ax-error-message:before,.ax-dark ax-form form.ax-float-error .ax-error-message:after{border-bottom-color:rgba(var(--ax-color-danger-700))}.ax-dark ax-form form.ax-float-error .ax-error-message:before{border-bottom-color:rgba(var(--ax-color-danger-700))}ax-form-field{position:relative;display:block;width:100%}ax-form-field.ax-state-floating-label{--ax-size-default: 3.5rem}ax-form-field.ax-state-floating-label>ax-label{position:absolute;top:50%;transform:translateY(-50%);inset-inline-start:1rem;pointer-events:none;z-index:10;transition:all .15s ease-in-out;display:inline-grid}ax-form-field.ax-state-floating-label>ax-label label{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}ax-form-field.ax-state-floating-label .ax-input::placeholder{opacity:0}ax-form-field.ax-state-floating-label.ax-state-focused>ax-label,ax-form-field.ax-state-floating-label.ax-state-has-value>ax-label{top:10%;transform:translateY(-10%);inset-inline-start:.25rem;padding:0 .5rem}ax-form-field.ax-state-floating-label.ax-state-focused>ax-label label,ax-form-field.ax-state-floating-label.ax-state-has-value>ax-label label{font-size:.75rem}ax-form-field.ax-state-floating-label.ax-state-focused .ax-input,ax-form-field.ax-state-floating-label.ax-state-focused .ax-content,ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-input,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-content,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area{padding-top:.875rem}ax-form-field.ax-state-floating-label.ax-state-focused .ax-input::placeholder,ax-form-field.ax-state-floating-label.ax-state-focused .ax-content::placeholder,ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-input::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-content::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area::placeholder{opacity:1}ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area textarea,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area textarea{padding-top:1.5rem!important}ax-form-field.ax-state-over-label{--ax-size-default: 3.5rem}ax-form-field.ax-state-over-label>ax-label{position:absolute;pointer-events:none;z-index:10;transition:all .15s ease-in-out;display:inline-grid;top:10%;transform:translateY(-10%);inset-inline-start:.25rem;padding:0 .5rem}ax-form-field.ax-state-over-label>ax-label label{margin:0;overflow:hidden;text-overflow:ellipsis;font-size:.75rem;white-space:nowrap}ax-form-field.ax-state-over-label .ax-input::placeholder{opacity:0}ax-form-field.ax-state-over-label.ax-state-focused .ax-input,ax-form-field.ax-state-over-label.ax-state-focused .ax-content,ax-form-field.ax-state-over-label.ax-state-focused ax-text-area,ax-form-field.ax-state-over-label.ax-state-has-value .ax-input,ax-form-field.ax-state-over-label.ax-state-has-value .ax-content,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area{padding-top:1rem}ax-form-field.ax-state-over-label.ax-state-focused .ax-input::placeholder,ax-form-field.ax-state-over-label.ax-state-focused .ax-content::placeholder,ax-form-field.ax-state-over-label.ax-state-focused ax-text-area::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value .ax-input::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value .ax-content::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area::placeholder{opacity:1}ax-form-field.ax-state-over-label.ax-state-focused ax-text-area textarea,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area textarea{padding-top:1.5rem!important}ax-form-field.ax-state-floating-label .ax-select-box-selection,ax-form-field.ax-state-over-label .ax-select-box-selection{padding-top:1.5rem!important}ax-form-field.ax-state-floating-label .ax-select-box-selection.ax-multiple,ax-form-field.ax-state-over-label .ax-select-box-selection.ax-multiple{padding-inline-start:.75rem}ax-form-field .ax-error-message{margin-top:.25rem;margin-bottom:.25rem;display:block;font-size:.75rem;line-height:1rem}ax-form{width:100%}ax-form form.ax-bottom-error .ax-error-message{color:rgba(var(--ax-color-danger-500))}ax-form form.ax-float-error .ax-error-message{position:absolute;bottom:-2.5rem;z-index:20;display:block;width:fit-content;border-radius:.375rem;border-width:1px;border-color:rgba(var(--ax-color-danger-500));background-color:rgba(var(--ax-color-danger-500));padding:.25rem .5rem;font-weight:400;color:rgba(var(--ax-color-danger-fore))}ax-form form.ax-float-error .ax-error-message:before,ax-form form.ax-float-error .ax-error-message:after{pointer-events:none;position:absolute;bottom:100%;inset-inline-start:.75rem;z-index:20;height:0px;width:0px;border-bottom-color:rgba(var(--ax-color-danger-500));border-inline-end-color:transparent;border-inline-start-color:transparent;border-top-color:transparent;content:\"\"}ax-form form.ax-float-error .ax-error-message:before{margin-inline-start:-1px;border-width:4px;border-bottom-color:rgba(var(--ax-color-danger-500))}ax-form form.ax-float-error .ax-error-message:after{border-width:4px}\n"] }]
80
+ args: [{ selector: 'ax-form-field', template: `<ng-content></ng-content>`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [AXUnsubscriber], styles: [".ax-dark ax-form.ax-form-normal .ax-error-message{border-color:rgba(var(--ax-color-danger-500));background-color:rgba(var(--ax-color-danger-200));color:rgba(var(--ax-color-danger-fore-tint))}.ax-dark ax-form.ax-form-normal .ax-error-message:before,.ax-dark ax-form.ax-form-normal .ax-error-message:after{border-bottom-color:rgba(var(--ax-color-danger-500))}.ax-dark ax-form.ax-form-normal .ax-error-message:before{border-bottom-color:rgba(var(--ax-color-danger-500))}.ax-dark ax-form form.ax-float-error .ax-error-message{border-color:rgba(var(--ax-color-danger-700));background-color:rgba(var(--ax-color-danger-700));color:rgba(var(--ax-color-danger-fore))}.ax-dark ax-form form.ax-float-error .ax-error-message:before,.ax-dark ax-form form.ax-float-error .ax-error-message:after{border-bottom-color:rgba(var(--ax-color-danger-700))}.ax-dark ax-form form.ax-float-error .ax-error-message:before{border-bottom-color:rgba(var(--ax-color-danger-700))}ax-form-field{position:relative;display:block;width:100%}ax-form-field.ax-state-floating-label{--ax-size-default: 3.5rem}ax-form-field.ax-state-floating-label>ax-label{position:absolute;top:50%;transform:translateY(-50%);inset-inline-start:1rem;pointer-events:none;z-index:10;transition:all .15s ease-in-out;display:inline-grid}ax-form-field.ax-state-floating-label>ax-label label{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}ax-form-field.ax-state-floating-label .ax-input::placeholder{opacity:0}ax-form-field.ax-state-floating-label.ax-state-focused>ax-label,ax-form-field.ax-state-floating-label.ax-state-has-value>ax-label{top:10%;transform:translateY(-10%);inset-inline-start:.25rem;padding:0 .5rem}ax-form-field.ax-state-floating-label.ax-state-focused>ax-label label,ax-form-field.ax-state-floating-label.ax-state-has-value>ax-label label{font-size:.75rem;color:rgba(var(--ax-color-text-default),.5)}ax-form-field.ax-state-floating-label.ax-state-focused .ax-input,ax-form-field.ax-state-floating-label.ax-state-focused .ax-content,ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-input,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-content,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area{padding-top:.875rem}ax-form-field.ax-state-floating-label.ax-state-focused .ax-input::placeholder,ax-form-field.ax-state-floating-label.ax-state-focused .ax-content::placeholder,ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-input::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value .ax-content::placeholder,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area::placeholder{opacity:1}ax-form-field.ax-state-floating-label.ax-state-focused ax-text-area textarea,ax-form-field.ax-state-floating-label.ax-state-has-value ax-text-area textarea{padding-top:1.5rem!important}ax-form-field.ax-state-over-label{--ax-size-default: 3.5rem}ax-form-field.ax-state-over-label>ax-label{position:absolute;pointer-events:none;z-index:10;transition:all .15s ease-in-out;display:inline-grid;top:10%;transform:translateY(-10%);inset-inline-start:.25rem;padding:0 .5rem}ax-form-field.ax-state-over-label>ax-label label{margin:0;overflow:hidden;text-overflow:ellipsis;font-size:.75rem;white-space:nowrap}ax-form-field.ax-state-over-label .ax-input::placeholder{opacity:0}ax-form-field.ax-state-over-label.ax-state-focused .ax-input,ax-form-field.ax-state-over-label.ax-state-focused .ax-content,ax-form-field.ax-state-over-label.ax-state-focused ax-text-area,ax-form-field.ax-state-over-label.ax-state-has-value .ax-input,ax-form-field.ax-state-over-label.ax-state-has-value .ax-content,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area{padding-top:1rem}ax-form-field.ax-state-over-label.ax-state-focused .ax-input::placeholder,ax-form-field.ax-state-over-label.ax-state-focused .ax-content::placeholder,ax-form-field.ax-state-over-label.ax-state-focused ax-text-area::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value .ax-input::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value .ax-content::placeholder,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area::placeholder{opacity:1}ax-form-field.ax-state-over-label.ax-state-focused ax-text-area textarea,ax-form-field.ax-state-over-label.ax-state-has-value ax-text-area textarea{padding-top:1.5rem!important}ax-form-field.ax-state-floating-label .ax-select-box-selection.ax-multiple,ax-form-field.ax-state-over-label .ax-select-box-selection.ax-multiple{padding-top:1.5rem!important;padding-inline-start:.75rem}ax-form-field .ax-error-message{margin-top:.25rem;margin-bottom:.25rem;display:block;font-size:.75rem;line-height:1rem}ax-form{width:100%}ax-form form.ax-bottom-error .ax-error-message{color:rgba(var(--ax-color-danger-500))}ax-form form.ax-float-error .ax-error-message{position:absolute;bottom:-2.5rem;z-index:20;display:block;width:fit-content;border-radius:.375rem;border-width:1px;border-color:rgba(var(--ax-color-danger-500));background-color:rgba(var(--ax-color-danger-500));padding:.25rem .5rem;font-weight:400;color:rgba(var(--ax-color-danger-fore))}ax-form form.ax-float-error .ax-error-message:before,ax-form form.ax-float-error .ax-error-message:after{pointer-events:none;position:absolute;bottom:100%;inset-inline-start:.75rem;z-index:20;height:0px;width:0px;border-bottom-color:rgba(var(--ax-color-danger-500));border-inline-end-color:transparent;border-inline-start-color:transparent;border-top-color:transparent;content:\"\"}ax-form form.ax-float-error .ax-error-message:before{margin-inline-start:-1px;border-width:4px;border-bottom-color:rgba(var(--ax-color-danger-500))}ax-form form.ax-float-error .ax-error-message:after{border-width:4px}\n"] }]
82
81
  }], ctorParameters: () => [], propDecorators: { input: [{
83
82
  type: ContentChild,
84
83
  args: [AXValuableComponent]
@@ -89,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
89
88
  type: HostBinding,
90
89
  args: ['class']
91
90
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.component.js","sourceRoot":"","sources":["../../../../../../libs/components/form/src/lib/form-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXValuableComponent, MXBaseComponent } from '@acorex/components/common';\nimport { AXLabelComponent } from '@acorex/components/label';\nimport { AXUnsubscriber } from '@acorex/core/utils';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  HostBinding,\n  ViewContainerRef,\n  ViewEncapsulation,\n  WritableSignal,\n  afterNextRender,\n  effect,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { AXFormComponent, AXLabelMode } from './form.component';\n\n@Component({\n  selector: 'ax-form-field',\n  template: `<ng-content></ng-content>`,\n  styleUrls: ['./form-field.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [AXUnsubscriber],\n})\nexport class AXFormFieldComponent extends MXBaseComponent {\n  labelMode = input<AXLabelMode>('static');\n\n  protected _labelMode: WritableSignal<AXLabelMode> = signal(this.labelMode());\n\n  private unsubscriber = inject(AXUnsubscriber);\n\n  @ContentChild(AXValuableComponent)\n  private input: AXValuableComponent;\n\n  @ContentChild(AXLabelComponent)\n  private label: AXLabelComponent;\n\n  form = inject(AXFormComponent, { optional: true });\n\n  host = inject(ViewContainerRef);\n\n  prefix: HTMLElement;\n\n  constructor() {\n    super();\n\n    afterNextRender(() => {\n      this.calcIndentSize();\n      this.setRequired();\n      this.setLabelMode();\n      this.listeningEvent();\n    });\n\n    effect(\n      () => {\n        this.setLabelMode();\n        console.log('setLabelMode');\n      },\n      { allowSignalWrites: true },\n    );\n  }\n\n  calcIndentSize() {\n    const prefix = (this.input as any).getHostElement().querySelector('ax-prefix') as HTMLElement;\n    this.label.getHostElement().style.insetInlineStart = prefix?.clientWidth + 'px';\n  }\n\n  setRequired() {\n    this.autoSetRequired();\n    this.input?.validationRulesChange.pipe(this.unsubscriber.takeUntilDestroy).subscribe(() => {\n      this.autoSetRequired();\n    });\n  }\n\n  setLabelMode() {\n    this._labelMode.set(this.form?.labelMode());\n  }\n\n  listeningEvent() {\n    const focusEvent = this.input['onFocus'] as Subject<any>;\n    focusEvent?.subscribe((e) => {\n      // this.handleFloating('focus');\n      this.host.element.nativeElement.classList.add('ax-state-focused');\n    });\n    //\n    const blurEvent = this.input['onBlur'] as Subject<any>;\n    blurEvent?.subscribe((e) => {\n      // this.handleFloating('blur');\n      this.host.element.nativeElement.classList.remove('ax-state-focused');\n    });\n  }\n  // protected handleFloating(mode: 'focus' | 'blur') {\n  //   const _host = this.host.element.nativeElement as HTMLElement;\n  //   const placeholder = this.input;\n\n  //   switch (mode) {\n  //     case 'focus':\n  //       _host.classList.add('ax-state-floating');\n  //       this.label.getHostElement().style.insetInlineStart = 'inherit';\n\n  //       break;\n  //     case 'blur':\n  //       _host.classList.remove('ax-state-floating');\n\n  //       break;\n  //   }\n  // }\n\n  private autoSetRequired() {\n    if (this.label && this.input) {\n      if (this.label.required == null || this.label['autoSetRequired']) {\n        this.label.required = this.input.isRequired;\n        this.label['autoSetRequired'] = true;\n      }\n    }\n  }\n\n  @HostBinding('class')\n  get __hostClass(): string[] {\n    return [`ax-state-${this._labelMode()}-label`, `${this.input.value ? 'ax-state-has-value' : ''}`];\n  }\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.component.js","sourceRoot":"","sources":["../../../../../../libs/components/form/src/lib/form-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXValuableComponent, MXBaseComponent } from '@acorex/components/common';\nimport { AXLabelComponent } from '@acorex/components/label';\nimport { AXUnsubscriber } from '@acorex/core/utils';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  HostBinding,\n  ViewContainerRef,\n  ViewEncapsulation,\n  WritableSignal,\n  afterNextRender,\n  effect,\n  inject,\n  input,\n  signal,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { AXFormComponent, AXLabelMode } from './form.component';\n\n@Component({\n  selector: 'ax-form-field',\n  template: `<ng-content></ng-content>`,\n  styleUrls: ['./form-field.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [AXUnsubscriber],\n})\nexport class AXFormFieldComponent extends MXBaseComponent {\n  labelMode = input<AXLabelMode>('static');\n\n  protected _labelMode: WritableSignal<AXLabelMode> = signal(this.labelMode());\n\n  private unsubscriber = inject(AXUnsubscriber);\n\n  @ContentChild(AXValuableComponent)\n  private input: AXValuableComponent;\n\n  @ContentChild(AXLabelComponent)\n  private label: AXLabelComponent;\n\n  form = inject(AXFormComponent, { optional: true });\n\n  host = inject(ViewContainerRef);\n\n  prefix: HTMLElement;\n\n  constructor() {\n    super();\n\n    afterNextRender(() => {\n      this.calcIndentSize();\n      this.setRequired();\n      this.setLabelMode();\n      this.listeningEvent();\n    });\n\n    effect(\n      () => {\n        this.setLabelMode();\n      },\n      { allowSignalWrites: true },\n    );\n  }\n\n  calcIndentSize() {\n    const prefix = (this.input as any).getHostElement().querySelector('ax-prefix') as HTMLElement;\n    this.label.getHostElement().style.insetInlineStart = prefix?.clientWidth + 'px';\n  }\n\n  setRequired() {\n    this.autoSetRequired();\n    this.input?.validationRulesChange.pipe(this.unsubscriber.takeUntilDestroy).subscribe(() => {\n      this.autoSetRequired();\n    });\n  }\n\n  setLabelMode() {\n    this._labelMode.set(this.form?.labelMode());\n  }\n\n  listeningEvent() {\n    const focusEvent = this.input['onFocus'] as Subject<any>;\n    focusEvent?.subscribe((e) => {\n      // this.handleFloating('focus');\n      this.host.element.nativeElement.classList.add('ax-state-focused');\n    });\n    //\n    const blurEvent = this.input['onBlur'] as Subject<any>;\n    blurEvent?.subscribe((e) => {\n      // this.handleFloating('blur');\n      this.host.element.nativeElement.classList.remove('ax-state-focused');\n    });\n  }\n  // protected handleFloating(mode: 'focus' | 'blur') {\n  //   const _host = this.host.element.nativeElement as HTMLElement;\n  //   const placeholder = this.input;\n\n  //   switch (mode) {\n  //     case 'focus':\n  //       _host.classList.add('ax-state-floating');\n  //       this.label.getHostElement().style.insetInlineStart = 'inherit';\n\n  //       break;\n  //     case 'blur':\n  //       _host.classList.remove('ax-state-floating');\n\n  //       break;\n  //   }\n  // }\n\n  private autoSetRequired() {\n    if (this.label && this.input) {\n      if (this.label.required == null || this.label['autoSetRequired']) {\n        this.label.required = this.input.isRequired;\n        this.label['autoSetRequired'] = true;\n      }\n    }\n  }\n\n  @HostBinding('class')\n  get __hostClass(): string[] {\n    return [`ax-state-${this._labelMode()}-label`, `${this.input.value ? 'ax-state-has-value' : ''}`];\n  }\n}\n"]}
@@ -30,7 +30,7 @@ export class AXFormComponent extends MXBaseComponent {
30
30
  await this.validate();
31
31
  }
32
32
  _handleReset() {
33
- this.clear();
33
+ this.reset();
34
34
  }
35
35
  constructor() {
36
36
  super();
@@ -91,8 +91,11 @@ export class AXFormComponent extends MXBaseComponent {
91
91
  htmlElement: this.getHostElement(),
92
92
  });
93
93
  }
94
- clear() {
95
- this.fields.forEach((c) => c.clear(false));
94
+ reset() {
95
+ this.fields.forEach((c) => c.reset(false));
96
+ }
97
+ resetErrors() {
98
+ this.fields.forEach((c) => c.resetErrors());
96
99
  }
97
100
  ngOnDestroy() {
98
101
  this._clearSubs();
@@ -119,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.2", ngImpor
119
122
  }], updateOn: [{
120
123
  type: Input
121
124
  }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../libs/components/form/src/lib/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXEvent, AXValuableComponent, MXBaseComponent } from '@acorex/components/common';\nimport { AXValidationSummary } from '@acorex/core/validation';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  InputSignal,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n  input,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n/**\n *  Contains native event\n * @category Events\n */\nexport class AXFormValidationEvent extends AXEvent {\n  result: AXValidationSummary;\n}\n\n/**\n *  Contains native event\n * @category Events\n */\nexport type AXFormUpdateOn = 'change' | 'blur' | 'submit';\nexport type AXFormMessageStyle = 'bottom' | 'float';\nexport type AXLabelMode = 'static' | 'floating' | 'over';\n\n/**\n * The AXForm is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-form',\n  template: `<form (submit)=\"_handleSubmit($event)\" (reset)=\"_handleReset()\" class=\"ax-{{ messageStyle() }}-error\">\n    <ng-content></ng-content>\n  </form>`,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXFormComponent extends MXBaseComponent implements OnDestroy {\n  labelMode = input<AXLabelMode>('static');\n\n  messageStyle: InputSignal<AXFormMessageStyle> = input<AXFormMessageStyle>('bottom');\n\n  @Output()\n  onValidate: EventEmitter<AXFormValidationEvent> = new EventEmitter<AXFormValidationEvent>();\n\n  @Output()\n  updateOnChange: EventEmitter<AXFormUpdateOn> = new EventEmitter<AXFormUpdateOn>();\n\n  private _updateOn: AXFormUpdateOn = 'blur';\n  @Input()\n  public get updateOn(): AXFormUpdateOn {\n    return this._updateOn;\n  }\n  public set updateOn(v: AXFormUpdateOn) {\n    this.setOption({\n      name: 'updateOn',\n      value: v,\n      afterCallback: () => {\n        //this._bindEvents();\n      },\n    });\n  }\n\n  private _subs: Subscription[] = [];\n\n  protected async _handleSubmit(e: SubmitEvent) {\n    e.preventDefault();\n    await this.validate();\n  }\n\n  protected _handleReset() {\n    this.clear();\n  }\n\n  constructor() {\n    super();\n  }\n\n  //TODO: check update on\n\n  // ngAfterViewInit(): void {\n  //   //this._bindEvents();\n  // }\n\n  // private _bindEvents() {\n  //   this._clearSubs();\n  //   const widgets = this._getComponenets();\n  //   //\n  //   widgets.forEach((w) => {\n  //     if (this.updateOn == 'change') {\n  //       this._subs.push(\n  //         w.onValueChanged?.subscribe((v: AXValueChangedEvent) => {\n  //           if (v.isUserInteraction) w.validate();\n  //         }),\n  //       );\n  //     } else if (this.updateOn == 'blur') {\n  //       this._subs.push(\n  //         w.onBlur?.subscribe((v) => {\n  //           w.validate();\n  //         }),\n  //       );\n  //     }\n  //   });\n  // }\n\n  private _clearSubs() {\n    this._subs.forEach((c) => c?.unsubscribe());\n    this._subs = [];\n  }\n\n  private get fields(): AXValuableComponent[] {\n    return Array.from(this.getHostElement().querySelectorAll('[ax-form-item=\"true\"]'))\n      .map((c) => (c as any).__axContext__)\n      .filter((c) => c != null);\n  }\n\n  async validate(...names: string[]): Promise<AXValidationSummary> {\n    const results = await Promise.all(\n      this.fields.filter((c) => names == null || names.length == 0 || names.includes(c.name)).map((field) => field.validate()),\n    );\n    // Merge all validation summaries into one\n    const mergedSummary: AXValidationSummary = {\n      result: results.every((res) => res.result),\n      rules: results.flatMap((res) => res.rules),\n    };\n    this._emitOnValidateEvent(mergedSummary);\n    return mergedSummary;\n  }\n\n  private _emitOnValidateEvent(e: AXValidationSummary) {\n    this.onValidate.emit({\n      component: this,\n      result: e,\n      htmlElement: this.getHostElement(),\n    });\n  }\n\n  clear() {\n    this.fields.forEach((c) => c.clear(false));\n  }\n\n  ngOnDestroy(): void {\n    this._clearSubs();\n  }\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../libs/components/form/src/lib/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXEvent, AXValuableComponent, MXBaseComponent } from '@acorex/components/common';\nimport { AXValidationSummary } from '@acorex/core/validation';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  InputSignal,\n  OnDestroy,\n  Output,\n  ViewEncapsulation,\n  input,\n} from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n/**\n *  Contains native event\n * @category Events\n */\nexport class AXFormValidationEvent extends AXEvent {\n  result: AXValidationSummary;\n}\n\n/**\n *  Contains native event\n * @category Events\n */\nexport type AXFormUpdateOn = 'change' | 'blur' | 'submit';\nexport type AXFormMessageStyle = 'bottom' | 'float';\nexport type AXLabelMode = 'static' | 'floating' | 'over';\n\n/**\n * The AXForm is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-form',\n  template: `<form (submit)=\"_handleSubmit($event)\" (reset)=\"_handleReset()\" class=\"ax-{{ messageStyle() }}-error\">\n    <ng-content></ng-content>\n  </form>`,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AXFormComponent extends MXBaseComponent implements OnDestroy {\n  labelMode = input<AXLabelMode>('static');\n\n  messageStyle: InputSignal<AXFormMessageStyle> = input<AXFormMessageStyle>('bottom');\n\n  @Output()\n  onValidate: EventEmitter<AXFormValidationEvent> = new EventEmitter<AXFormValidationEvent>();\n\n  @Output()\n  updateOnChange: EventEmitter<AXFormUpdateOn> = new EventEmitter<AXFormUpdateOn>();\n\n  private _updateOn: AXFormUpdateOn = 'blur';\n  @Input()\n  public get updateOn(): AXFormUpdateOn {\n    return this._updateOn;\n  }\n  public set updateOn(v: AXFormUpdateOn) {\n    this.setOption({\n      name: 'updateOn',\n      value: v,\n      afterCallback: () => {\n        //this._bindEvents();\n      },\n    });\n  }\n\n  private _subs: Subscription[] = [];\n\n  protected async _handleSubmit(e: SubmitEvent) {\n    e.preventDefault();\n    await this.validate();\n  }\n\n  protected _handleReset() {\n    this.reset();\n  }\n\n  constructor() {\n    super();\n  }\n\n  //TODO: check update on\n\n  // ngAfterViewInit(): void {\n  //   //this._bindEvents();\n  // }\n\n  // private _bindEvents() {\n  //   this._clearSubs();\n  //   const widgets = this._getComponenets();\n  //   //\n  //   widgets.forEach((w) => {\n  //     if (this.updateOn == 'change') {\n  //       this._subs.push(\n  //         w.onValueChanged?.subscribe((v: AXValueChangedEvent) => {\n  //           if (v.isUserInteraction) w.validate();\n  //         }),\n  //       );\n  //     } else if (this.updateOn == 'blur') {\n  //       this._subs.push(\n  //         w.onBlur?.subscribe((v) => {\n  //           w.validate();\n  //         }),\n  //       );\n  //     }\n  //   });\n  // }\n\n  private _clearSubs() {\n    this._subs.forEach((c) => c?.unsubscribe());\n    this._subs = [];\n  }\n\n  private get fields(): AXValuableComponent[] {\n    return Array.from(this.getHostElement().querySelectorAll('[ax-form-item=\"true\"]'))\n      .map((c) => (c as any).__axContext__)\n      .filter((c) => c != null);\n  }\n\n  async validate(...names: string[]): Promise<AXValidationSummary> {\n    const results = await Promise.all(\n      this.fields.filter((c) => names == null || names.length == 0 || names.includes(c.name)).map((field) => field.validate()),\n    );\n    // Merge all validation summaries into one\n    const mergedSummary: AXValidationSummary = {\n      result: results.every((res) => res.result),\n      rules: results.flatMap((res) => res.rules),\n    };\n    this._emitOnValidateEvent(mergedSummary);\n    return mergedSummary;\n  }\n\n  private _emitOnValidateEvent(e: AXValidationSummary) {\n    this.onValidate.emit({\n      component: this,\n      result: e,\n      htmlElement: this.getHostElement(),\n    });\n  }\n\n  reset() {\n    this.fields.forEach((c) => c.reset(false));\n  }\n\n  resetErrors() {\n    this.fields.forEach((c) => c.resetErrors());\n  }\n\n  ngOnDestroy(): void {\n    this._clearSubs();\n  }\n}\n"]}