@acorex/components 7.17.21 → 7.17.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/check-box/lib/check-box.component.d.ts +3 -3
  2. package/common/lib/classes/components.class.d.ts +11 -0
  3. package/common/lib/components/value-component.class.d.ts +10 -4
  4. package/data-table/lib/data-table.component.d.ts +1 -1
  5. package/datetime-box/lib/datetime-box.component.d.ts +1 -1
  6. package/esm2022/calendar/lib/calendar-range.component.mjs +1 -2
  7. package/esm2022/calendar/lib/calendar.component.mjs +10 -2
  8. package/esm2022/check-box/lib/check-box.component.mjs +9 -4
  9. package/esm2022/color-palette/lib/color-palette.component.mjs +4 -2
  10. package/esm2022/common/lib/classes/components.class.mjs +1 -1
  11. package/esm2022/common/lib/components/value-component.class.mjs +38 -65
  12. package/esm2022/data-pager/lib/data-pager.component.mjs +1 -2
  13. package/esm2022/data-table/lib/data-table.component.mjs +6 -4
  14. package/esm2022/datetime-box/lib/datetime-box.component.mjs +5 -4
  15. package/esm2022/dialog/lib/dialog.module.mjs +4 -4
  16. package/esm2022/form/index.mjs +2 -3
  17. package/esm2022/form/lib/form-field.component.mjs +34 -6
  18. package/esm2022/form/lib/form.component.mjs +44 -86
  19. package/esm2022/form/lib/form.config.mjs +3 -23
  20. package/esm2022/form/lib/form.module.mjs +9 -8
  21. package/esm2022/form/lib/validation-rule.directive.mjs +33 -0
  22. package/esm2022/form/lib/validation-summary.component.mjs +19 -13
  23. package/esm2022/label/lib/label.component.mjs +21 -10
  24. package/esm2022/number-box/lib/number-box.component.mjs +8 -3
  25. package/esm2022/otp/lib/otp.component.mjs +1 -1
  26. package/esm2022/password-box/lib/password-box.component.mjs +4 -2
  27. package/esm2022/radio/lib/radio.component.mjs +2 -2
  28. package/esm2022/select-box/lib/select-box.component.mjs +1 -2
  29. package/esm2022/selection-list/lib/selection-list.component.mjs +8 -8
  30. package/fesm2022/acorex-components-calendar.mjs +9 -2
  31. package/fesm2022/acorex-components-calendar.mjs.map +1 -1
  32. package/fesm2022/acorex-components-check-box.mjs +8 -3
  33. package/fesm2022/acorex-components-check-box.mjs.map +1 -1
  34. package/fesm2022/acorex-components-color-palette.mjs +3 -1
  35. package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
  36. package/fesm2022/acorex-components-common.mjs +36 -63
  37. package/fesm2022/acorex-components-common.mjs.map +1 -1
  38. package/fesm2022/acorex-components-data-pager.mjs +0 -1
  39. package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
  40. package/fesm2022/acorex-components-data-table.mjs +4 -2
  41. package/fesm2022/acorex-components-data-table.mjs.map +1 -1
  42. package/fesm2022/acorex-components-datetime-box.mjs +4 -3
  43. package/fesm2022/acorex-components-datetime-box.mjs.map +1 -1
  44. package/fesm2022/acorex-components-dialog.mjs +3 -3
  45. package/fesm2022/acorex-components-dialog.mjs.map +1 -1
  46. package/fesm2022/acorex-components-form.mjs +135 -250
  47. package/fesm2022/acorex-components-form.mjs.map +1 -1
  48. package/fesm2022/acorex-components-label.mjs +19 -8
  49. package/fesm2022/acorex-components-label.mjs.map +1 -1
  50. package/fesm2022/acorex-components-number-box.mjs +7 -2
  51. package/fesm2022/acorex-components-number-box.mjs.map +1 -1
  52. package/fesm2022/acorex-components-otp.mjs.map +1 -1
  53. package/fesm2022/acorex-components-password-box.mjs +3 -1
  54. package/fesm2022/acorex-components-password-box.mjs.map +1 -1
  55. package/fesm2022/acorex-components-radio.mjs +1 -1
  56. package/fesm2022/acorex-components-radio.mjs.map +1 -1
  57. package/fesm2022/acorex-components-select-box.mjs +0 -1
  58. package/fesm2022/acorex-components-select-box.mjs.map +1 -1
  59. package/fesm2022/acorex-components-selection-list.mjs +6 -6
  60. package/fesm2022/acorex-components-selection-list.mjs.map +1 -1
  61. package/form/index.d.ts +1 -2
  62. package/form/lib/form-field.component.d.ts +8 -2
  63. package/form/lib/form.component.d.ts +9 -13
  64. package/form/lib/form.config.d.ts +0 -10
  65. package/form/lib/form.module.d.ts +3 -2
  66. package/form/lib/validation-rule.directive.d.ts +16 -0
  67. package/form/lib/validation-summary.component.d.ts +8 -5
  68. package/label/lib/label.component.d.ts +6 -6
  69. package/package.json +1 -1
  70. package/selection-list/lib/selection-list.component.d.ts +2 -2
  71. package/esm2022/form/lib/validation-rule.widget.mjs +0 -124
  72. package/esm2022/form/lib/validation.class.mjs +0 -2
  73. package/form/lib/validation-rule.widget.d.ts +0 -23
  74. package/form/lib/validation.class.d.ts +0 -18
@@ -2,9 +2,9 @@ import { AXDataSource, AXListDataSource, AXPagedComponent, MXBaseComponent, conv
2
2
  import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, NgZone, Output, QueryList, TemplateRef, ViewChild, ViewEncapsulation, inject, } from '@angular/core';
3
3
  import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
4
4
  import sum from 'lodash-es/sum';
5
+ import { Subject, buffer, debounceTime, filter } from 'rxjs';
5
6
  import { AXDataTableColumnComponent } from './columns/data-table-column';
6
7
  import { AXDataTableTextColumnComponent } from './columns/data-text-column.component';
7
- import { Subject, buffer, debounceTime, filter } from 'rxjs';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@angular/common";
10
10
  import * as i2 from "@angular/cdk/scrolling";
@@ -23,7 +23,7 @@ export class AXDataTableComponent extends MXBaseComponent {
23
23
  this.fetchDataMode = 'auto';
24
24
  this.dataSource = convertArrayToDataSource([]);
25
25
  this.loading = {
26
- enbaled: true,
26
+ enabled: true,
27
27
  animation: true,
28
28
  };
29
29
  this.isLoading = true;
@@ -95,7 +95,9 @@ export class AXDataTableComponent extends MXBaseComponent {
95
95
  }, 100);
96
96
  });
97
97
  //
98
- this.clickSubject.pipe(buffer(this.clickSubject.pipe(debounceTime(250))), filter(clickArray => clickArray.length === 2)).subscribe(clickArray => {
98
+ this.clickSubject
99
+ .pipe(buffer(this.clickSubject.pipe(debounceTime(250))), filter((clickArray) => clickArray.length === 2))
100
+ .subscribe((clickArray) => {
99
101
  this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);
100
102
  });
101
103
  }
@@ -276,4 +278,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
276
278
  type: ViewChild,
277
279
  args: ['scrolling', { static: true }]
278
280
  }] } });
279
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../libs/components/data-table/src/lib/data-table.component.ts","../../../../../../libs/components/data-table/src/lib/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AXDataSource,\n  AXEvent,\n  AXListDataSource,\n  AXPagedComponent,\n  AXValueChangedEvent,\n  MXBaseComponent,\n  convertArrayToDataSource,\n} from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\n\nimport { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport sum from 'lodash-es/sum';\nimport { AXDataTableColumnComponent } from './columns/data-table-column';\nimport { AXDataTableTextColumnComponent } from './columns/data-text-column.component';\nimport { Subject, buffer, debounceTime, filter, map } from 'rxjs';\n\nexport interface AXDataTableScrollIndexChanged extends AXEvent {\n  index: number;\n}\n\nexport interface AXDataTableRowClick extends AXEvent {\n  data?: any;\n}\n\nexport interface AXDataTableRowDbClick extends AXDataTableRowClick {\n}\n\n@Component({\n  selector: 'ax-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }],\n})\nexport class AXDataTableComponent extends MXBaseComponent implements OnInit, DoCheck {\n  private ngZone = inject(NgZone);\n\n  @ContentChildren(AXDataTableColumnComponent)\n  protected columns: QueryList<AXDataTableColumnComponent>;\n\n  protected startFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => c.fixed == 'start') ?? [];\n  }\n\n  protected endFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => c.fixed == 'end') ?? [];\n  }\n\n  protected notFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => !c.fixed) ?? [];\n  }\n\n  protected notFixedColumnCount(): number {\n    return this.columns?.toArray().filter((c) => !c.fixed).length ?? 0;\n  }\n\n  protected fixedColumnCount(): number {\n    return this.columns?.toArray().filter((c) => c.fixed).length ?? 0;\n  }\n\n  @Output()\n  onPageChanged: EventEmitter<AXValueChangedEvent<number>> = new EventEmitter<AXValueChangedEvent<number>>();\n\n\n\n  private clickSubject = new Subject<{ event: MouseEvent, item: any }>();\n\n  @Output()\n  onRowClick: EventEmitter<AXDataTableRowClick> = new EventEmitter<AXDataTableRowClick>();\n\n  @Output()\n  onRowDbClick: EventEmitter<AXDataTableRowDbClick> = new EventEmitter<AXDataTableRowDbClick>();\n\n  @Input()\n  rowTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  emptyTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  showHeader = true;\n\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n  @Input()\n  dataSource: AXDataSource<unknown> = convertArrayToDataSource([]);\n\n  @Input()\n  loading: { enbaled: boolean; animation: boolean; loadingTemplate?: TemplateRef<unknown> } = {\n    enbaled: true,\n    animation: true,\n  };\n\n  protected listDataSource: AXListDataSource<unknown>;\n  protected isLoading = true;\n  protected hasItems = false;\n  protected totalRows = 0;\n  protected currentPage = 0;\n  protected totalPages = 0;\n  protected startRowIndex = 0;\n  private lastIndex = 0;\n\n  @Output()\n  focusedRowChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  private _focusedRow: unknown;\n  @Input()\n  public get focusedRow(): unknown {\n    return this._focusedRow;\n  }\n  public set focusedRow(v: unknown) {\n    this._focusedRow = v;\n    this.focusedRowChange.emit(v);\n  }\n\n  @Output()\n  selectedRowsChange: EventEmitter<unknown[]> = new EventEmitter<unknown[]>();\n\n  private _selectedRows: unknown[] = [];\n  @Input()\n  public get selectedRows(): unknown[] {\n    return this._selectedRows;\n  }\n  public set selectedRows(v: unknown[]) {\n    this._selectedRows = v;\n    this.selectedRowsChange.emit(v);\n  }\n\n  public selectRows(...rows: unknown[]) {\n    this.selectedRows = [...this.selectedRows, ...rows];\n  }\n\n  public unSelectRows(...rows: unknown[]) {\n    this.selectedRows = this.selectedRows.filter((c) => !rows.includes(c));\n  }\n\n  @Input()\n  itemHeight: number | 'auto' = 40;\n\n  protected width = '100%';\n  protected height = '100%';\n\n  @ViewChild(CdkVirtualScrollViewport, { static: true })\n  private viewport: CdkVirtualScrollViewport;\n\n  @Output()\n  onScrolledIndexChanged: EventEmitter<AXDataTableScrollIndexChanged> =\n    new EventEmitter<AXDataTableScrollIndexChanged>();\n\n  trackByIdx(i) {\n    return i;\n  }\n\n  ngOnInit() {\n    super.ngOnInit();\n    this.listDataSource = new AXListDataSource<unknown>({\n      source: this.dataSource,\n    });\n    this.listDataSource.source.onLoadingChanged.subscribe((data) => {\n      this.isLoading = data;\n    });\n    this.listDataSource.source.onChanged.subscribe((data) => {\n      this.totalRows = data.totalCount;\n      this.hasItems = data.totalCount > 0;\n      setTimeout(() => {\n        this.render();\n      }, 100);\n    });\n\n    //\n    this.clickSubject.pipe(\n      buffer(this.clickSubject.pipe(debounceTime(250))),\n      filter(clickArray => clickArray.length === 2)\n    ).subscribe(clickArray => {\n      this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);\n    });\n\n  }\n  @ViewChild('headerContainer') headerContainer: ElementRef<HTMLDivElement>;\n  @ViewChild('footerContainer') footerContainer: ElementRef;\n  @ViewChild('scrolling', { static: true }) scrollableContainer: ElementRef<HTMLDivElement>;\n\n  protected _handleOnscrolledIndexChange(e: number) {\n    this.lastIndex = e;\n    this.onScrolledIndexChanged.emit({\n      component: this,\n      index: this.lastIndex,\n      isUserInteraction: true,\n    });\n  }\n\n  ngDoCheck() {\n    //this.copyFixedColumns();\n    this.updateHScroll();\n    //\n    this.updateWidth();\n    this.updateHeight();\n    //\n    this.updateTotalCount();\n  }\n\n  private updateTotalCount() {\n    this.startRowIndex = this.lastIndex;\n    if (this.startRowIndex < 1) this.startRowIndex = 1;\n    if (this.startRowIndex > this.totalRows) this.startRowIndex = this.totalRows;\n  }\n\n  private updateHeight() {\n    this.height = `calc(100% - ${(this.headerContainer?.nativeElement.clientHeight ?? 0) +\n      (this.footerContainer?.nativeElement.clientHeight ?? 0)\n      }px)`;\n  }\n\n  private updateWidth() {\n    if (this.columns && this.columns.length) {\n      const sumPx = sum(\n        this.columns\n          .toArray()\n          .map((c) => (typeof c.width == 'number' ? c.width : Number(c.width.replace('px', '')))),\n      );\n      this.width = `${Math.max(sumPx, this.getHostElement().clientWidth - 5)}px`;\n    }\n  }\n\n  private updateHScroll() {\n    this.ngZone.runOutsideAngular(() => {\n      if (this.headerContainer) {\n        const headerContainer = this.headerContainer.nativeElement;\n        const left = this.scrollableContainer.nativeElement.scrollLeft;\n        headerContainer.style.transform = `translateX(${-left}px)`;\n      }\n    });\n  }\n\n  // Function to copy fixed columns\n  private copyFixedColumns() {\n    const originalRows = Array.from(this.viewport._contentWrapper.nativeElement.querySelectorAll('tr'));\n    const fixedColumnTable = this.getHostElement().querySelector<HTMLTableElement>(\n      '.ax-body-fixed-columns > table > tbody',\n    );\n    fixedColumnTable.querySelectorAll('tr').forEach((n) => n.remove());\n    for (const row of originalRows) {\n      const fixedCells = Array.from(row.querySelectorAll('[data-fixed=\"start\"]'));\n      const fixedRow = document.createElement('tr');\n      for (const cell of fixedCells) {\n        const clonedCell = cell.cloneNode(true);\n        fixedRow.appendChild(clonedCell);\n      }\n      fixedColumnTable.appendChild(fixedRow);\n    }\n    const scrollTop = this.getHostElement().querySelector('.cdk-virtual-scrollable').scrollTop;\n    fixedColumnTable.style.transform = `translateY(${-scrollTop}px)`;\n  }\n\n  public render() {\n    this.viewport.checkViewportSize();\n    this.viewport.scrollToIndex(this.lastIndex);\n    this.cdr.markForCheck();\n  }\n\n  public refresh() {\n    this.lastIndex = 0;\n    this.dataSource.refresh();\n  }\n\n  protected handleRowClick(event: MouseEvent, item: unknown) {\n    this.handleRowSingleClick(event, item);\n    this.clickSubject.next({ event, item });\n  }\n\n  private handleRowSingleClick(event: Event, item: any): void {\n    if (this.focusedRow == item) {\n      this.focusedRow = null;\n    } else {\n      this.focusedRow = item;\n    }\n    //\n    this.onRowClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  protected handleRowDoubleClick(e: MouseEvent, item: unknown) {\n    this.focusedRow = item;\n    //\n    this.onRowDbClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent) {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      if (!sort) {\n        this.dataSource.query.sort.push({ field: column.dataField, dir: 'asc' });\n      } else {\n        if (sort.dir == 'asc') {\n          sort.dir = 'desc';\n        } else {\n          this.dataSource.query.sort = this.dataSource.query.sort.filter((c) => c != sort);\n        }\n      }\n      this.refresh();\n    }\n  }\n\n  protected getSort(column: AXDataTableColumnComponent): string | undefined {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      return sort ? (sort.dir == 'asc' ? 'ax-icon-arrow-long-down' : 'ax-icon-arrow-long-up') : undefined;\n    }\n    return undefined;\n  }\n\n  protected _handleOnScroll(e: Event) {\n    this.updateHScroll();\n  }\n}\n","<ng-content select=\"ax-header\"> </ng-content>\n<!------------------- Header contents ------------------->\n<div class=\"ax-header-content\" *ngIf=\"showHeader\">\n  <div class=\"ax-header-columns ax-header-fixed-columns\" *ngIf=\"false\">\n    <table tabindex=\"0\" [style.width]=\"width\">\n      <colgroup>\n        <!------------------- start fixed column ------------------->\n        <col *ngFor=\"let c of startFixedColumn()\" [style.width]=\"c.width\" />\n        <!------------------- not fixed column ------------------->\n        <col *ngFor=\"let c of notFixedColumn()\" [style.width]=\"c.width\" />\n        <col style=\"width: 10px\" />\n      </colgroup>\n      <thead>\n        <tr>\n          <!------------------- start fixed column ------------------->\n          <th *ngFor=\"let c of startFixedColumn()\" [class.ax-interactive]=\"c.allowSorting\"\n            (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\" class=\"ax-column-fixed\">\n            <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n              <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n            </ng-template>\n            <ng-template #captionTpl>\n              <div class=\"ax-caption\">\n                {{ c.caption }}\n                <ax-icon *ngIf=\"getSort(c)\" icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n              </div>\n            </ng-template>\n          </th>\n          <!------------------- not fixed column ------------------->\n          <th [attr.colspan]=\"notFixedColumnCount()\"></th>\n        </tr>\n      </thead>\n    </table>\n  </div>\n  <div class=\"ax-header-columns\">\n    <table tabindex=\"0\" [style.width]=\"width\" #headerContainer>\n      <colgroup>\n        <col *ngFor=\"let c of startFixedColumn()\" [style.width]=\"c.width\" />\n        <col *ngFor=\"let c of notFixedColumn()\" [style.width]=\"c.width\" />\n        <col style=\"width: auto\" />\n      </colgroup>\n      <thead>\n        <tr>\n          <th *ngFor=\"let c of startFixedColumn()\"></th>\n          <th *ngFor=\"let c of notFixedColumn()\" [class.ax-interactive]=\"c.allowSorting\"\n            (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\">\n            <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n              <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n            </ng-template>\n            <ng-template #captionTpl>\n              <div class=\"ax-caption\">\n                {{ c.caption }}\n                <ax-icon *ngIf=\"getSort(c)\" icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n              </div>\n            </ng-template>\n          </th>\n          <th></th>\n        </tr>\n      </thead>\n    </table>\n  </div>\n</div>\n<!------------------- Body contents ------------------->\n<div [style.height]=\"height\" class=\"ax-body-content\">\n  <!-- <div class=\"ax-body-columns ax-body-fixed-columns\" *ngIf=\"false\">\n    <table tabindex=\"0\" class=\"ax-table-body\" [style.width]=\"width\">\n      <colgroup>\n        ------------------ start fixed column -------------------\n        <col *ngFor=\"let c of startFixedColumn()\" [style.width]=\"c.width\">\n        ------------------- not fixed column ------------------\n        <col *ngFor=\"let c of notFixedColumn()\" [style.width]=\"c.width\">\n        <col>\n      </colgroup>\n      <tbody>\n      </tbody>\n    </table>\n  </div> -->\n  <div class=\"ax-body-columns\">\n    <div cdkVirtualScrollingElement #scrolling [style.height]=\"'100%'\" (scroll)=\"_handleOnScroll($event)\">\n      <cdk-virtual-scroll-viewport [itemSize]=\"itemHeight\" [style.--item-height]=\"itemHeight + 'px'\"\n        (scrolledIndexChange)=\"_handleOnscrolledIndexChange($event)\">\n        <table tabindex=\"0\" class=\"ax-table-body\" [style.width]=\"width\">\n          <colgroup>\n            <!------------------- start fixed column ------------------->\n            <!-- <col *ngFor=\"let c of startFixedColumn()\" [style.width]=\"c.width\"> -->\n            <!------------------- not fixed column ------------------->\n            <col *ngFor=\"let c of notFixedColumn()\" [style.width]=\"c.width\" />\n            <col />\n          </colgroup>\n          <tbody>\n            <ng-container *cdkVirtualFor=\"\n                let item of listDataSource;\n                templateCacheSize: 100;\n                let i = index;\n                trackBy: trackByIdx;\n                let rIndex = index\n              \">\n              <!------------------- custom row template------------------->\n              @if (rowTemplate != null) {\n              <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: item, rowIndex: rIndex } }\">\n              </ng-container>\n              } @else {\n              <!------------------- normal row template------------------->\n              <tr [class.ax-state-focused]=\"focusedRow && item === focusedRow\" [attr.data-index]=\"rIndex\"\n                [class.ax-state-selected]=\"selectedRows.includes(item)\" (click)=\"handleRowClick($event, item)\">\n                <!------------------- start fixed column ------------------->\n                <!-- <ng-container *ngFor=\"let c of startFixedColumn()\">\n                    <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\n                      <div class=\"ax-content\">\n                        <ng-container\n                          *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:item,rowIndex:rIndex} }\">\n                        </ng-container>\n                      </div>\n                    </ng-template>\n                    <ng-template #cellTpl>\n                      <td [attr.data-label]=\"c.caption\" tabindex=\"0\" [class]=\"c.cssClass\" [attr.data-fixed]=\"c.fixed\"\n                        class=\"ax-column-fixed\">\n                        <div class=\"ax-content\">\n                          <ng-container *ngIf=\"item || !c.skeleton;else loadingTpl\">\n                            <ng-container\n                              *ngTemplateOutlet=\"c.template; context: { $implicit: {data:item,rowIndex:rIndex} }\"></ng-container>\n                          </ng-container>\n                        </div>\n                      </td>\n                    </ng-template>\n                  </ng-container> -->\n                <!------------------- Not fixed column ------------------->\n                @for (c of notFixedColumn(); track c.name) {\n                <!------------------- custom cell template ------------------->\n                @if (c.cellTemplate) {\n                <ng-container *ngTemplateOutlet=\"\n                          c.cellTemplate;\n                          context: { $implicit: { data: item, rowIndex: rIndex } }\n                        \">\n                </ng-container>\n                } @else {\n                <!------------------- default cell template ------------------->\n                <td [attr.data-label]=\"c.caption\" tabindex=\"0\" [class]=\"c.cssClass\">\n                  @if (item) {\n                  <!------------------- render cell ------------------->\n                  <ng-container *ngTemplateOutlet=\"\n                              c.template;\n                              context: { $implicit: { data: item, rowIndex: rIndex } }\n                            \"></ng-container>\n                  } @else {\n                  <!------------------- render loading ------------------->\n                  @if (c.loadingEnabled && loading) {\n                  <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                  }\n                  }\n                </td>\n                }\n                }\n                <td></td>\n              </tr>\n              }\n            </ng-container>\n          </tbody>\n        </table>\n      </cdk-virtual-scroll-viewport>\n    </div>\n  </div>\n</div>\n<div class=\"ax-table-footer\" #footerContainer>\n  <div class=\"ax-table-info\">\n    <div>Showing {{ startRowIndex }} of {{ totalRows }} items</div>\n    <ax-button look=\"blank\" class=\"ax-sm\" (onClick)=\"refresh()\">\n      <ax-icon icon=\"ax-icon ax-icon-refresh\"></ax-icon>\n    </ax-button>\n  </div>\n  <ng-content select=\"ax-footer\"> </ng-content>\n</div>"]}
281
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table.component.js","sourceRoot":"","sources":["../../../../../../libs/components/data-table/src/lib/data-table.component.ts","../../../../../../libs/components/data-table/src/lib/data-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AXDataSource,\n  AXEvent,\n  AXListDataSource,\n  AXPagedComponent,\n  AXValueChangedEvent,\n  MXBaseComponent,\n  convertArrayToDataSource,\n} from '@acorex/components/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  inject,\n} from '@angular/core';\n\nimport { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport sum from 'lodash-es/sum';\nimport { Subject, buffer, debounceTime, filter } from 'rxjs';\nimport { AXDataTableColumnComponent } from './columns/data-table-column';\nimport { AXDataTableTextColumnComponent } from './columns/data-text-column.component';\n\nexport interface AXDataTableScrollIndexChanged extends AXEvent {\n  index: number;\n}\n\nexport interface AXDataTableRowClick extends AXEvent {\n  data?: any;\n}\n\nexport interface AXDataTableRowDbClick extends AXDataTableRowClick {}\n\n@Component({\n  selector: 'ax-data-table',\n  templateUrl: './data-table.component.html',\n  styleUrls: ['./data-table.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [{ provide: AXPagedComponent, useExisting: AXDataTableComponent }],\n})\nexport class AXDataTableComponent extends MXBaseComponent implements OnInit, DoCheck {\n  private ngZone = inject(NgZone);\n\n  @ContentChildren(AXDataTableColumnComponent)\n  protected columns: QueryList<AXDataTableColumnComponent>;\n\n  protected startFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => c.fixed == 'start') ?? [];\n  }\n\n  protected endFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => c.fixed == 'end') ?? [];\n  }\n\n  protected notFixedColumn(): AXDataTableColumnComponent[] {\n    return this.columns?.toArray().filter((c) => !c.fixed) ?? [];\n  }\n\n  protected notFixedColumnCount(): number {\n    return this.columns?.toArray().filter((c) => !c.fixed).length ?? 0;\n  }\n\n  protected fixedColumnCount(): number {\n    return this.columns?.toArray().filter((c) => c.fixed).length ?? 0;\n  }\n\n  @Output()\n  onPageChanged: EventEmitter<AXValueChangedEvent<number>> = new EventEmitter<AXValueChangedEvent<number>>();\n\n  private clickSubject = new Subject<{ event: MouseEvent; item: any }>();\n\n  @Output()\n  onRowClick: EventEmitter<AXDataTableRowClick> = new EventEmitter<AXDataTableRowClick>();\n\n  @Output()\n  onRowDbClick: EventEmitter<AXDataTableRowDbClick> = new EventEmitter<AXDataTableRowDbClick>();\n\n  @Input()\n  rowTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  emptyTemplate?: TemplateRef<unknown>;\n\n  @Input()\n  showHeader = true;\n\n  @Input()\n  fetchDataMode: 'auto' | 'manual' = 'auto';\n\n  @Input()\n  dataSource: AXDataSource<unknown> = convertArrayToDataSource([]);\n\n  @Input()\n  loading: { enabled: boolean; animation: boolean; loadingTemplate?: TemplateRef<unknown> } = {\n    enabled: true,\n    animation: true,\n  };\n\n  protected listDataSource: AXListDataSource<unknown>;\n  protected isLoading = true;\n  protected hasItems = false;\n  protected totalRows = 0;\n  protected currentPage = 0;\n  protected totalPages = 0;\n  protected startRowIndex = 0;\n  private lastIndex = 0;\n\n  @Output()\n  focusedRowChange: EventEmitter<unknown> = new EventEmitter<unknown>();\n\n  private _focusedRow: unknown;\n  @Input()\n  public get focusedRow(): unknown {\n    return this._focusedRow;\n  }\n  public set focusedRow(v: unknown) {\n    this._focusedRow = v;\n    this.focusedRowChange.emit(v);\n  }\n\n  @Output()\n  selectedRowsChange: EventEmitter<unknown[]> = new EventEmitter<unknown[]>();\n\n  private _selectedRows: unknown[] = [];\n  @Input()\n  public get selectedRows(): unknown[] {\n    return this._selectedRows;\n  }\n  public set selectedRows(v: unknown[]) {\n    this._selectedRows = v;\n    this.selectedRowsChange.emit(v);\n  }\n\n  public selectRows(...rows: unknown[]) {\n    this.selectedRows = [...this.selectedRows, ...rows];\n  }\n\n  public unSelectRows(...rows: unknown[]) {\n    this.selectedRows = this.selectedRows.filter((c) => !rows.includes(c));\n  }\n\n  @Input()\n  itemHeight: number | 'auto' = 40;\n\n  protected width = '100%';\n  protected height = '100%';\n\n  @ViewChild(CdkVirtualScrollViewport, { static: true })\n  private viewport: CdkVirtualScrollViewport;\n\n  @Output()\n  onScrolledIndexChanged: EventEmitter<AXDataTableScrollIndexChanged> =\n    new EventEmitter<AXDataTableScrollIndexChanged>();\n\n  trackByIdx(i) {\n    return i;\n  }\n\n  ngOnInit() {\n    super.ngOnInit();\n    this.listDataSource = new AXListDataSource<unknown>({\n      source: this.dataSource,\n    });\n    this.listDataSource.source.onLoadingChanged.subscribe((data) => {\n      this.isLoading = data;\n    });\n    this.listDataSource.source.onChanged.subscribe((data) => {\n      this.totalRows = data.totalCount;\n      this.hasItems = data.totalCount > 0;\n      setTimeout(() => {\n        this.render();\n      }, 100);\n    });\n\n    //\n    this.clickSubject\n      .pipe(\n        buffer(this.clickSubject.pipe(debounceTime(250))),\n        filter((clickArray) => clickArray.length === 2),\n      )\n      .subscribe((clickArray) => {\n        this.handleRowDoubleClick(clickArray[0].event, clickArray[0].item);\n      });\n  }\n  @ViewChild('headerContainer') headerContainer: ElementRef<HTMLDivElement>;\n  @ViewChild('footerContainer') footerContainer: ElementRef;\n  @ViewChild('scrolling', { static: true }) scrollableContainer: ElementRef<HTMLDivElement>;\n\n  protected _handleOnscrolledIndexChange(e: number) {\n    this.lastIndex = e;\n    this.onScrolledIndexChanged.emit({\n      component: this,\n      index: this.lastIndex,\n      isUserInteraction: true,\n    });\n  }\n\n  ngDoCheck() {\n    //this.copyFixedColumns();\n    this.updateHScroll();\n    //\n    this.updateWidth();\n    this.updateHeight();\n    //\n    this.updateTotalCount();\n  }\n\n  private updateTotalCount() {\n    this.startRowIndex = this.lastIndex;\n    if (this.startRowIndex < 1) this.startRowIndex = 1;\n    if (this.startRowIndex > this.totalRows) this.startRowIndex = this.totalRows;\n  }\n\n  private updateHeight() {\n    this.height = `calc(100% - ${\n      (this.headerContainer?.nativeElement.clientHeight ?? 0) +\n      (this.footerContainer?.nativeElement.clientHeight ?? 0)\n    }px)`;\n  }\n\n  private updateWidth() {\n    if (this.columns && this.columns.length) {\n      const sumPx = sum(\n        this.columns\n          .toArray()\n          .map((c) => (typeof c.width == 'number' ? c.width : Number(c.width.replace('px', '')))),\n      );\n      this.width = `${Math.max(sumPx, this.getHostElement().clientWidth - 5)}px`;\n    }\n  }\n\n  private updateHScroll() {\n    this.ngZone.runOutsideAngular(() => {\n      if (this.headerContainer) {\n        const headerContainer = this.headerContainer.nativeElement;\n        const left = this.scrollableContainer.nativeElement.scrollLeft;\n        headerContainer.style.transform = `translateX(${-left}px)`;\n      }\n    });\n  }\n\n  // Function to copy fixed columns\n  private copyFixedColumns() {\n    const originalRows = Array.from(this.viewport._contentWrapper.nativeElement.querySelectorAll('tr'));\n    const fixedColumnTable = this.getHostElement().querySelector<HTMLTableElement>(\n      '.ax-body-fixed-columns > table > tbody',\n    );\n    fixedColumnTable.querySelectorAll('tr').forEach((n) => n.remove());\n    for (const row of originalRows) {\n      const fixedCells = Array.from(row.querySelectorAll('[data-fixed=\"start\"]'));\n      const fixedRow = document.createElement('tr');\n      for (const cell of fixedCells) {\n        const clonedCell = cell.cloneNode(true);\n        fixedRow.appendChild(clonedCell);\n      }\n      fixedColumnTable.appendChild(fixedRow);\n    }\n    const scrollTop = this.getHostElement().querySelector('.cdk-virtual-scrollable').scrollTop;\n    fixedColumnTable.style.transform = `translateY(${-scrollTop}px)`;\n  }\n\n  public render() {\n    this.viewport.checkViewportSize();\n    this.viewport.scrollToIndex(this.lastIndex);\n    this.cdr.markForCheck();\n  }\n\n  public refresh() {\n    this.lastIndex = 0;\n    this.dataSource.refresh();\n  }\n\n  protected handleRowClick(event: MouseEvent, item: unknown) {\n    this.handleRowSingleClick(event, item);\n    this.clickSubject.next({ event, item });\n  }\n\n  private handleRowSingleClick(event: Event, item: any): void {\n    if (this.focusedRow == item) {\n      this.focusedRow = null;\n    } else {\n      this.focusedRow = item;\n    }\n    //\n    this.onRowClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  protected handleRowDoubleClick(e: MouseEvent, item: unknown) {\n    this.focusedRow = item;\n    //\n    this.onRowDbClick.emit({\n      component: this,\n      data: item,\n      isUserInteraction: true,\n    });\n  }\n\n  handleColumnClick(e: MouseEvent, column: AXDataTableColumnComponent) {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      if (!sort) {\n        this.dataSource.query.sort.push({ field: column.dataField, dir: 'asc' });\n      } else {\n        if (sort.dir == 'asc') {\n          sort.dir = 'desc';\n        } else {\n          this.dataSource.query.sort = this.dataSource.query.sort.filter((c) => c != sort);\n        }\n      }\n      this.refresh();\n    }\n  }\n\n  protected getSort(column: AXDataTableColumnComponent): string | undefined {\n    if (column instanceof AXDataTableTextColumnComponent) {\n      const sort = this.dataSource.query.sort.find((c) => c.field == column.dataField);\n      return sort ? (sort.dir == 'asc' ? 'ax-icon-arrow-long-down' : 'ax-icon-arrow-long-up') : undefined;\n    }\n    return undefined;\n  }\n\n  protected _handleOnScroll(e: Event) {\n    this.updateHScroll();\n  }\n}\n","<ng-content select=\"ax-header\"> </ng-content>\n<!------------------- Header contents ------------------->\n<div class=\"ax-header-content\" *ngIf=\"showHeader\">\n  <div class=\"ax-header-columns ax-header-fixed-columns\" *ngIf=\"false\">\n    <table tabindex=\"0\" [style.width]=\"width\">\n      <colgroup>\n        <!------------------- start fixed column ------------------->\n        <col *ngFor=\"let c of startFixedColumn()\" [style.width]=\"c.width\" />\n        <!------------------- not fixed column ------------------->\n        <col *ngFor=\"let c of notFixedColumn()\" [style.width]=\"c.width\" />\n        <col style=\"width: 10px\" />\n      </colgroup>\n      <thead>\n        <tr>\n          <!------------------- start fixed column ------------------->\n          <th *ngFor=\"let c of startFixedColumn()\" [class.ax-interactive]=\"c.allowSorting\"\n            (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\" class=\"ax-column-fixed\">\n            <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n              <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n            </ng-template>\n            <ng-template #captionTpl>\n              <div class=\"ax-caption\">\n                {{ c.caption }}\n                <ax-icon *ngIf=\"getSort(c)\" icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n              </div>\n            </ng-template>\n          </th>\n          <!------------------- not fixed column ------------------->\n          <th [attr.colspan]=\"notFixedColumnCount()\"></th>\n        </tr>\n      </thead>\n    </table>\n  </div>\n  <div class=\"ax-header-columns\">\n    <table tabindex=\"0\" [style.width]=\"width\" #headerContainer>\n      <colgroup>\n        <col *ngFor=\"let c of startFixedColumn()\" [style.width]=\"c.width\" />\n        <col *ngFor=\"let c of notFixedColumn()\" [style.width]=\"c.width\" />\n        <col style=\"width: auto\" />\n      </colgroup>\n      <thead>\n        <tr>\n          <th *ngFor=\"let c of startFixedColumn()\"></th>\n          <th *ngFor=\"let c of notFixedColumn()\" [class.ax-interactive]=\"c.allowSorting\"\n            (click)=\"c.allowSorting ? handleColumnClick($event, c) : null\">\n            <ng-template [ngIf]=\"c.headerTemplate\" [ngIfElse]=\"captionTpl\">\n              <ng-container *ngTemplateOutlet=\"c.headerTemplate\"></ng-container>\n            </ng-template>\n            <ng-template #captionTpl>\n              <div class=\"ax-caption\">\n                {{ c.caption }}\n                <ax-icon *ngIf=\"getSort(c)\" icon=\"ax-icon {{ getSort(c) }}\"></ax-icon>\n              </div>\n            </ng-template>\n          </th>\n          <th></th>\n        </tr>\n      </thead>\n    </table>\n  </div>\n</div>\n<!------------------- Body contents ------------------->\n<div [style.height]=\"height\" class=\"ax-body-content\">\n  <!-- <div class=\"ax-body-columns ax-body-fixed-columns\" *ngIf=\"false\">\n    <table tabindex=\"0\" class=\"ax-table-body\" [style.width]=\"width\">\n      <colgroup>\n        ------------------ start fixed column -------------------\n        <col *ngFor=\"let c of startFixedColumn()\" [style.width]=\"c.width\">\n        ------------------- not fixed column ------------------\n        <col *ngFor=\"let c of notFixedColumn()\" [style.width]=\"c.width\">\n        <col>\n      </colgroup>\n      <tbody>\n      </tbody>\n    </table>\n  </div> -->\n  <div class=\"ax-body-columns\">\n    <div cdkVirtualScrollingElement #scrolling [style.height]=\"'100%'\" (scroll)=\"_handleOnScroll($event)\">\n      <cdk-virtual-scroll-viewport [itemSize]=\"itemHeight\" [style.--item-height]=\"itemHeight + 'px'\"\n        (scrolledIndexChange)=\"_handleOnscrolledIndexChange($event)\">\n        <table tabindex=\"0\" class=\"ax-table-body\" [style.width]=\"width\">\n          <colgroup>\n            <!------------------- start fixed column ------------------->\n            <!-- <col *ngFor=\"let c of startFixedColumn()\" [style.width]=\"c.width\"> -->\n            <!------------------- not fixed column ------------------->\n            <col *ngFor=\"let c of notFixedColumn()\" [style.width]=\"c.width\" />\n            <col />\n          </colgroup>\n          <tbody>\n            <ng-container *cdkVirtualFor=\"\n                let item of listDataSource;\n                templateCacheSize: 100;\n                let i = index;\n                trackBy: trackByIdx;\n                let rIndex = index\n              \">\n              <!------------------- custom row template------------------->\n              @if (rowTemplate != null) {\n              <ng-container *ngTemplateOutlet=\"rowTemplate; context: { $implicit: { data: item, rowIndex: rIndex } }\">\n              </ng-container>\n              } @else {\n              <!------------------- normal row template------------------->\n              <tr [class.ax-state-focused]=\"focusedRow && item === focusedRow\" [attr.data-index]=\"rIndex\"\n                [class.ax-state-selected]=\"selectedRows.includes(item)\" (click)=\"handleRowClick($event, item)\">\n                <!------------------- start fixed column ------------------->\n                <!-- <ng-container *ngFor=\"let c of startFixedColumn()\">\n                    <ng-template [ngIf]=\"c.cellTemplate\" [ngIfElse]=\"cellTpl\">\n                      <div class=\"ax-content\">\n                        <ng-container\n                          *ngTemplateOutlet=\"c.cellTemplate;context: { $implicit: {data:item,rowIndex:rIndex} }\">\n                        </ng-container>\n                      </div>\n                    </ng-template>\n                    <ng-template #cellTpl>\n                      <td [attr.data-label]=\"c.caption\" tabindex=\"0\" [class]=\"c.cssClass\" [attr.data-fixed]=\"c.fixed\"\n                        class=\"ax-column-fixed\">\n                        <div class=\"ax-content\">\n                          <ng-container *ngIf=\"item || !c.skeleton;else loadingTpl\">\n                            <ng-container\n                              *ngTemplateOutlet=\"c.template; context: { $implicit: {data:item,rowIndex:rIndex} }\"></ng-container>\n                          </ng-container>\n                        </div>\n                      </td>\n                    </ng-template>\n                  </ng-container> -->\n                <!------------------- Not fixed column ------------------->\n                @for (c of notFixedColumn(); track c.name) {\n                <!------------------- custom cell template ------------------->\n                @if (c.cellTemplate) {\n                <ng-container *ngTemplateOutlet=\"\n                          c.cellTemplate;\n                          context: { $implicit: { data: item, rowIndex: rIndex } }\n                        \">\n                </ng-container>\n                } @else {\n                <!------------------- default cell template ------------------->\n                <td [attr.data-label]=\"c.caption\" tabindex=\"0\" [class]=\"c.cssClass\">\n                  @if (item) {\n                  <!------------------- render cell ------------------->\n                  <ng-container *ngTemplateOutlet=\"\n                              c.template;\n                              context: { $implicit: { data: item, rowIndex: rIndex } }\n                            \"></ng-container>\n                  } @else {\n                  <!------------------- render loading ------------------->\n                  @if (c.loadingEnabled && loading) {\n                  <ax-skeleton [animated]=\"loading.animation\"></ax-skeleton>\n                  }\n                  }\n                </td>\n                }\n                }\n                <td></td>\n              </tr>\n              }\n            </ng-container>\n          </tbody>\n        </table>\n      </cdk-virtual-scroll-viewport>\n    </div>\n  </div>\n</div>\n<div class=\"ax-table-footer\" #footerContainer>\n  <div class=\"ax-table-info\">\n    <div>Showing {{ startRowIndex }} of {{ totalRows }} items</div>\n    <ax-button look=\"blank\" class=\"ax-sm\" (onClick)=\"refresh()\">\n      <ax-icon icon=\"ax-icon ax-icon-refresh\"></ax-icon>\n    </ax-button>\n  </div>\n  <ng-content select=\"ax-footer\"> </ng-content>\n</div>"]}
@@ -54,7 +54,7 @@ export class AXDateTimeBoxComponent extends classes((MXInputBaseValueComponent),
54
54
  this.close();
55
55
  }
56
56
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXDateTimeBoxComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
57
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXDateTimeBoxComponent, selector: "ax-datetime-box", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", placeholder: "placeholder", minValue: "minValue", maxValue: "maxValue", value: "value", state: "state", name: "name", id: "id", type: "type", look: "look", format: "format" }, outputs: { valueChange: "valueChange", stateChange: "stateChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", readonlyChange: "readonlyChange", disabledChange: "disabledChange", formatChange: "formatChange" }, providers: [
57
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXDateTimeBoxComponent, selector: "ax-datetime-box", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", placeholder: "placeholder", minValue: "minValue", maxValue: "maxValue", value: "value", state: "state", name: "name", depth: "depth", id: "id", type: "type", look: "look", format: "format" }, outputs: { valueChange: "valueChange", stateChange: "stateChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus", readonlyChange: "readonlyChange", disabledChange: "disabledChange", formatChange: "formatChange" }, providers: [
58
58
  { provide: AXComponent, useExisting: AXDateTimeBoxComponent },
59
59
  { provide: AXFocusableComponent, useExisting: AXDateTimeBoxComponent },
60
60
  { provide: AXValuableComponent, useExisting: AXDateTimeBoxComponent },
@@ -64,7 +64,7 @@ export class AXDateTimeBoxComponent extends classes((MXInputBaseValueComponent),
64
64
  useExisting: forwardRef(() => AXDateTimeBoxComponent),
65
65
  multi: true,
66
66
  },
67
- ], viewQueries: [{ propertyName: "input", first: true, predicate: AXDateTimeInputComponent, descendants: true }, { propertyName: "picker", first: true, predicate: AXDateTimePickerComponent, descendants: true }, { propertyName: "dropdown", first: true, predicate: AXDropdownBoxComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ax-dropdown-box [disabled]=\"disabled\" (onOpened)=\"_handleOnOpenedEvent()\" (onClosed)=\"_handleOnClosedEvent()\"\n [look]=\"look\">\n <ng-container input>\n <ng-content select=\"ax-prefix\"> </ng-content>\n <ax-datetime-input id=\"{{ id }}-input\" [ngModel]=\"value\" (ngModelChange)=\"_handleInputModelChange($event)\"\n [placeholder]=\"placeholder\" [format]=\"format\" [disabled]=\"disabled\" [readonly]=\"readonly\" [type]=\"type\"\n (onFocus)=\"emitOnFocusEvent($event.nativeEvent)\" (onBlur)=\"emitOnBlurEvent($event.nativeEvent)\"\n (onClick)=\"_handleInputOnClick()\"></ax-datetime-input>\n <ng-content select=\"ax-clear-button\"></ng-content>\n <button type=\"button\" class=\"ax-general-button ax-button-icon\" [tabIndex]=\"-1\" [disabled]=\"disabled\"\n (click)=\"toggle()\">\n <span class=\"ax-icon ax-icon-calendar\"></span>\n </button>\n <ng-content select=\"ax-suffix\"> </ng-content>\n </ng-container>\n <ng-container panel>\n <ax-datetime-picker id=\"{{ id }}-picker\" #picker [ngModel]=\"value\"\n (ngModelChange)=\"_handlePickerModelChange($event)\" [disabled]=\"disabled\" [readonly]=\"readonly\"\n [minValue]=\"minValue\" [maxValue]=\"maxValue\" [format]=\"format\" [disabledDates]=\"disabledDates\"\n [holidayDates]=\"holidayDates\" [depth]=\"depth\" [type]=\"type\"\n (onNavigate)=\"_handleCalendarOnNavigate($event)\"></ax-datetime-picker>\n </ng-container>\n</ax-dropdown-box>\n<ng-content select=\"ax-validation-rule\"> </ng-content>", dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.AXDateTimeInputComponent, selector: "ax-datetime-input", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "value", "state", "name", "id", "type", "minValue", "maxValue", "format"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "onClick", "readonlyChange", "disabledChange", "formatChange"] }, { kind: "component", type: i3.AXDropdownBoxComponent, selector: "ax-dropdown-box", inputs: ["disabled", "look"], outputs: ["disabledChange", "onBlur", "onFocus", "onClick", "onOpened", "onClosed"] }, { kind: "component", type: i4.AXDateTimePickerComponent, selector: "ax-datetime-picker", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "value", "state", "name", "id", "depth", "activeView", "minValue", "maxValue", "disabledDates", "holidayDates", "type", "cellTemplate", "cellClass", "showNavigation", "currentTimeButton", "format"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "onClick", "readonlyChange", "disabledChange", "depthChange", "typeChange", "activeViewChange", "disabledDatesChange", "holidayDatesChange", "onNavigate", "onSlotClick", "formatChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
67
+ ], viewQueries: [{ propertyName: "input", first: true, predicate: AXDateTimeInputComponent, descendants: true }, { propertyName: "picker", first: true, predicate: AXDateTimePickerComponent, descendants: true }, { propertyName: "dropdown", first: true, predicate: AXDropdownBoxComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ax-dropdown-box [disabled]=\"disabled\" (onOpened)=\"_handleOnOpenedEvent()\" (onClosed)=\"_handleOnClosedEvent()\"\n [look]=\"look\">\n <ng-container input>\n <ng-content select=\"ax-prefix\"> </ng-content>\n <ax-datetime-input id=\"{{ id }}-input\" [ngModel]=\"value\" (ngModelChange)=\"_handleInputModelChange($event)\"\n [placeholder]=\"placeholder\" [format]=\"format\" [disabled]=\"disabled\" [readonly]=\"readonly\" [type]=\"type\"\n (onFocus)=\"emitOnFocusEvent($event.nativeEvent)\" (onBlur)=\"emitOnBlurEvent($event.nativeEvent)\"\n (onClick)=\"_handleInputOnClick()\"></ax-datetime-input>\n <ng-content select=\"ax-clear-button\"></ng-content>\n <button type=\"button\" class=\"ax-general-button ax-button-icon\" [tabIndex]=\"-1\" [disabled]=\"disabled\"\n (click)=\"toggle()\">\n <span class=\"ax-icon ax-icon-calendar\"></span>\n </button>\n <ng-content select=\"ax-suffix\"> </ng-content>\n </ng-container>\n <ng-container panel>\n <ax-datetime-picker [depth]=\"depth\" id=\"{{ id }}-picker\" #picker [ngModel]=\"value\"\n (ngModelChange)=\"_handlePickerModelChange($event)\" [disabled]=\"disabled\" [readonly]=\"readonly\"\n [minValue]=\"minValue\" [maxValue]=\"maxValue\" [format]=\"format\" [disabledDates]=\"disabledDates\"\n [holidayDates]=\"holidayDates\" [depth]=\"depth\" [type]=\"type\"\n (onNavigate)=\"_handleCalendarOnNavigate($event)\"></ax-datetime-picker>\n </ng-container>\n</ax-dropdown-box>\n<ng-content select=\"ax-validation-rule\"> </ng-content>", dependencies: [{ kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.AXDateTimeInputComponent, selector: "ax-datetime-input", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "value", "state", "name", "id", "type", "minValue", "maxValue", "format"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "onClick", "readonlyChange", "disabledChange", "formatChange"] }, { kind: "component", type: i3.AXDropdownBoxComponent, selector: "ax-dropdown-box", inputs: ["disabled", "look"], outputs: ["disabledChange", "onBlur", "onFocus", "onClick", "onOpened", "onClosed"] }, { kind: "component", type: i4.AXDateTimePickerComponent, selector: "ax-datetime-picker", inputs: ["disabled", "readonly", "tabIndex", "placeholder", "value", "state", "name", "id", "depth", "activeView", "minValue", "maxValue", "disabledDates", "holidayDates", "type", "cellTemplate", "cellClass", "showNavigation", "currentTimeButton", "format"], outputs: ["valueChange", "stateChange", "onValueChanged", "onBlur", "onFocus", "onClick", "readonlyChange", "disabledChange", "depthChange", "typeChange", "activeViewChange", "disabledDatesChange", "holidayDatesChange", "onNavigate", "onSlotClick", "formatChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
68
68
  }
69
69
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXDateTimeBoxComponent, decorators: [{
70
70
  type: Component,
@@ -78,6 +78,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
78
78
  'value',
79
79
  'state',
80
80
  'name',
81
+ 'depth',
81
82
  'id',
82
83
  'type',
83
84
  'look',
@@ -99,7 +100,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
99
100
  useExisting: forwardRef(() => AXDateTimeBoxComponent),
100
101
  multi: true,
101
102
  },
102
- ], template: "<ax-dropdown-box [disabled]=\"disabled\" (onOpened)=\"_handleOnOpenedEvent()\" (onClosed)=\"_handleOnClosedEvent()\"\n [look]=\"look\">\n <ng-container input>\n <ng-content select=\"ax-prefix\"> </ng-content>\n <ax-datetime-input id=\"{{ id }}-input\" [ngModel]=\"value\" (ngModelChange)=\"_handleInputModelChange($event)\"\n [placeholder]=\"placeholder\" [format]=\"format\" [disabled]=\"disabled\" [readonly]=\"readonly\" [type]=\"type\"\n (onFocus)=\"emitOnFocusEvent($event.nativeEvent)\" (onBlur)=\"emitOnBlurEvent($event.nativeEvent)\"\n (onClick)=\"_handleInputOnClick()\"></ax-datetime-input>\n <ng-content select=\"ax-clear-button\"></ng-content>\n <button type=\"button\" class=\"ax-general-button ax-button-icon\" [tabIndex]=\"-1\" [disabled]=\"disabled\"\n (click)=\"toggle()\">\n <span class=\"ax-icon ax-icon-calendar\"></span>\n </button>\n <ng-content select=\"ax-suffix\"> </ng-content>\n </ng-container>\n <ng-container panel>\n <ax-datetime-picker id=\"{{ id }}-picker\" #picker [ngModel]=\"value\"\n (ngModelChange)=\"_handlePickerModelChange($event)\" [disabled]=\"disabled\" [readonly]=\"readonly\"\n [minValue]=\"minValue\" [maxValue]=\"maxValue\" [format]=\"format\" [disabledDates]=\"disabledDates\"\n [holidayDates]=\"holidayDates\" [depth]=\"depth\" [type]=\"type\"\n (onNavigate)=\"_handleCalendarOnNavigate($event)\"></ax-datetime-picker>\n </ng-container>\n</ax-dropdown-box>\n<ng-content select=\"ax-validation-rule\"> </ng-content>" }]
103
+ ], template: "<ax-dropdown-box [disabled]=\"disabled\" (onOpened)=\"_handleOnOpenedEvent()\" (onClosed)=\"_handleOnClosedEvent()\"\n [look]=\"look\">\n <ng-container input>\n <ng-content select=\"ax-prefix\"> </ng-content>\n <ax-datetime-input id=\"{{ id }}-input\" [ngModel]=\"value\" (ngModelChange)=\"_handleInputModelChange($event)\"\n [placeholder]=\"placeholder\" [format]=\"format\" [disabled]=\"disabled\" [readonly]=\"readonly\" [type]=\"type\"\n (onFocus)=\"emitOnFocusEvent($event.nativeEvent)\" (onBlur)=\"emitOnBlurEvent($event.nativeEvent)\"\n (onClick)=\"_handleInputOnClick()\"></ax-datetime-input>\n <ng-content select=\"ax-clear-button\"></ng-content>\n <button type=\"button\" class=\"ax-general-button ax-button-icon\" [tabIndex]=\"-1\" [disabled]=\"disabled\"\n (click)=\"toggle()\">\n <span class=\"ax-icon ax-icon-calendar\"></span>\n </button>\n <ng-content select=\"ax-suffix\"> </ng-content>\n </ng-container>\n <ng-container panel>\n <ax-datetime-picker [depth]=\"depth\" id=\"{{ id }}-picker\" #picker [ngModel]=\"value\"\n (ngModelChange)=\"_handlePickerModelChange($event)\" [disabled]=\"disabled\" [readonly]=\"readonly\"\n [minValue]=\"minValue\" [maxValue]=\"maxValue\" [format]=\"format\" [disabledDates]=\"disabledDates\"\n [holidayDates]=\"holidayDates\" [depth]=\"depth\" [type]=\"type\"\n (onNavigate)=\"_handleCalendarOnNavigate($event)\"></ax-datetime-picker>\n </ng-container>\n</ax-dropdown-box>\n<ng-content select=\"ax-validation-rule\"> </ng-content>" }]
103
104
  }], propDecorators: { input: [{
104
105
  type: ViewChild,
105
106
  args: [AXDateTimeInputComponent]
@@ -114,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
114
115
  }], format: [{
115
116
  type: Input
116
117
  }] } });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-box.component.js","sourceRoot":"","sources":["../../../../../../libs/components/datetime-box/src/lib/datetime-box.component.ts","../../../../../../libs/components/datetime-box/src/lib/datetime-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXCalendarNavigateEvent, MXCalendarBaseComponent } from '@acorex/components/calendar';\nimport {\n  AXClearableComponent,\n  AXComponent,\n  AXFocusableComponent,\n  AXValuableComponent,\n  MXInputBaseValueComponent,\n  MXLookComponent,\n} from '@acorex/components/common';\nimport { AXDateTimeInputComponent } from '@acorex/components/datetime-input';\nimport { AXDateTimePickerComponent } from '@acorex/components/datetime-picker';\nimport { AXDropdownBoxComponent, MXDropdownBoxBaseComponent } from '@acorex/components/dropdown';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { classes } from 'polytype';\n\n/**\n * The Button is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-datetime-box',\n  templateUrl: './datetime-box.component.html',\n  inputs: [\n    'disabled',\n    'readonly',\n    'tabIndex',\n    'placeholder',\n    'minValue',\n    'maxValue',\n    'value',\n    'state',\n    'name',\n    'id',\n    'type',\n    'look',\n  ],\n  outputs: [\n    'valueChange',\n    'stateChange',\n    'onValueChanged',\n    'onBlur',\n    'onFocus',\n    'readonlyChange',\n    'disabledChange',\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    { provide: AXComponent, useExisting: AXDateTimeBoxComponent },\n    { provide: AXFocusableComponent, useExisting: AXDateTimeBoxComponent },\n    { provide: AXValuableComponent, useExisting: AXDateTimeBoxComponent },\n    { provide: AXClearableComponent, useExisting: AXDateTimeBoxComponent },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AXDateTimeBoxComponent),\n      multi: true,\n    },\n  ],\n})\nexport class AXDateTimeBoxComponent extends classes(\n  MXInputBaseValueComponent<Date>,\n  MXCalendarBaseComponent,\n  MXDropdownBoxBaseComponent,\n  MXLookComponent,\n) {\n  @ViewChild(AXDateTimeInputComponent)\n  protected input: AXDateTimeInputComponent;\n\n  @ViewChild(AXDateTimePickerComponent)\n  protected picker: AXDateTimePickerComponent;\n\n  @ViewChild(AXDropdownBoxComponent)\n  protected dropdown: AXDropdownBoxComponent;\n\n  @Output()\n  formatChange = new EventEmitter<string>();\n\n  private _format = this.calendarService.calendar.formats.dateTimeInput;\n  @Input()\n  public get format(): string {\n    return this._format;\n  }\n  public set format(v: string) {\n    this.setOption({\n      name: 'format',\n      value: v,\n    });\n  }\n\n  protected _handleInputModelChange(value: Date | null) {\n    this.commitValue(value, true);\n  }\n\n  protected _handlePickerModelChange(value: Date | null) {\n    if (this.isOpen) this.commitValue(value, true);\n  }\n\n  protected _handleOnOpenedEvent() {\n    this.picker?.refresh();\n  }\n\n  protected _handleOnClosedEvent() {\n    this.input.focus();\n  }\n\n  protected _handleCalendarOnNavigate(e: AXCalendarNavigateEvent) {\n    this.onNavigate.emit(e);\n  }\n\n  override internalValueChanged(): void {\n    this.close();\n  }\n\n  protected _handleInputOnClick() {\n    this.close();\n  }\n}\n","<ax-dropdown-box [disabled]=\"disabled\" (onOpened)=\"_handleOnOpenedEvent()\" (onClosed)=\"_handleOnClosedEvent()\"\n  [look]=\"look\">\n  <ng-container input>\n    <ng-content select=\"ax-prefix\"> </ng-content>\n    <ax-datetime-input id=\"{{ id }}-input\" [ngModel]=\"value\" (ngModelChange)=\"_handleInputModelChange($event)\"\n      [placeholder]=\"placeholder\" [format]=\"format\" [disabled]=\"disabled\" [readonly]=\"readonly\" [type]=\"type\"\n      (onFocus)=\"emitOnFocusEvent($event.nativeEvent)\" (onBlur)=\"emitOnBlurEvent($event.nativeEvent)\"\n      (onClick)=\"_handleInputOnClick()\"></ax-datetime-input>\n    <ng-content select=\"ax-clear-button\"></ng-content>\n    <button type=\"button\" class=\"ax-general-button ax-button-icon\" [tabIndex]=\"-1\" [disabled]=\"disabled\"\n      (click)=\"toggle()\">\n      <span class=\"ax-icon ax-icon-calendar\"></span>\n    </button>\n    <ng-content select=\"ax-suffix\"> </ng-content>\n  </ng-container>\n  <ng-container panel>\n    <ax-datetime-picker id=\"{{ id }}-picker\" #picker [ngModel]=\"value\"\n      (ngModelChange)=\"_handlePickerModelChange($event)\" [disabled]=\"disabled\" [readonly]=\"readonly\"\n      [minValue]=\"minValue\" [maxValue]=\"maxValue\" [format]=\"format\" [disabledDates]=\"disabledDates\"\n      [holidayDates]=\"holidayDates\" [depth]=\"depth\" [type]=\"type\"\n      (onNavigate)=\"_handleCalendarOnNavigate($event)\"></ax-datetime-picker>\n  </ng-container>\n</ax-dropdown-box>\n<ng-content select=\"ax-validation-rule\"> </ng-content>"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datetime-box.component.js","sourceRoot":"","sources":["../../../../../../libs/components/datetime-box/src/lib/datetime-box.component.ts","../../../../../../libs/components/datetime-box/src/lib/datetime-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXCalendarNavigateEvent, MXCalendarBaseComponent } from '@acorex/components/calendar';\nimport {\n  AXClearableComponent,\n  AXComponent,\n  AXFocusableComponent,\n  AXValuableComponent,\n  MXInputBaseValueComponent,\n  MXLookComponent,\n} from '@acorex/components/common';\nimport { AXDateTimeInputComponent } from '@acorex/components/datetime-input';\nimport { AXDateTimePickerComponent } from '@acorex/components/datetime-picker';\nimport { AXDropdownBoxComponent, MXDropdownBoxBaseComponent } from '@acorex/components/dropdown';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { classes } from 'polytype';\n\n/**\n * The Button is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-datetime-box',\n  templateUrl: './datetime-box.component.html',\n  inputs: [\n    'disabled',\n    'readonly',\n    'tabIndex',\n    'placeholder',\n    'minValue',\n    'maxValue',\n    'value',\n    'state',\n    'name',\n    'depth',\n    'id',\n    'type',\n    'look',\n  ],\n  outputs: [\n    'valueChange',\n    'stateChange',\n    'onValueChanged',\n    'onBlur',\n    'onFocus',\n    'readonlyChange',\n    'disabledChange',\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    { provide: AXComponent, useExisting: AXDateTimeBoxComponent },\n    { provide: AXFocusableComponent, useExisting: AXDateTimeBoxComponent },\n    { provide: AXValuableComponent, useExisting: AXDateTimeBoxComponent },\n    { provide: AXClearableComponent, useExisting: AXDateTimeBoxComponent },\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AXDateTimeBoxComponent),\n      multi: true,\n    },\n  ],\n})\nexport class AXDateTimeBoxComponent extends classes(\n  MXInputBaseValueComponent<Date>,\n  MXCalendarBaseComponent,\n  MXDropdownBoxBaseComponent,\n  MXLookComponent,\n) {\n  @ViewChild(AXDateTimeInputComponent)\n  protected input: AXDateTimeInputComponent;\n\n  @ViewChild(AXDateTimePickerComponent)\n  protected picker: AXDateTimePickerComponent;\n\n  @ViewChild(AXDropdownBoxComponent)\n  protected dropdown: AXDropdownBoxComponent;\n\n  @Output()\n  formatChange = new EventEmitter<string>();\n\n  private _format = this.calendarService.calendar.formats.dateTimeInput;\n  @Input()\n  public get format(): string {\n    return this._format;\n  }\n  public set format(v: string) {\n    this.setOption({\n      name: 'format',\n      value: v,\n    });\n  }\n\n  protected _handleInputModelChange(value: Date | null) {\n    this.commitValue(value, true);\n  }\n\n  protected _handlePickerModelChange(value: Date | null) {\n    if (this.isOpen) this.commitValue(value, true);\n  }\n\n  protected _handleOnOpenedEvent() {\n    this.picker?.refresh();\n  }\n\n  protected _handleOnClosedEvent() {\n    this.input.focus();\n  }\n\n  protected _handleCalendarOnNavigate(e: AXCalendarNavigateEvent) {\n    this.onNavigate.emit(e);\n  }\n\n  override internalValueChanged(): void {\n    this.close();\n  }\n\n  protected _handleInputOnClick() {\n    this.close();\n  }\n}\n","<ax-dropdown-box [disabled]=\"disabled\" (onOpened)=\"_handleOnOpenedEvent()\" (onClosed)=\"_handleOnClosedEvent()\"\n  [look]=\"look\">\n  <ng-container input>\n    <ng-content select=\"ax-prefix\"> </ng-content>\n    <ax-datetime-input id=\"{{ id }}-input\" [ngModel]=\"value\" (ngModelChange)=\"_handleInputModelChange($event)\"\n      [placeholder]=\"placeholder\" [format]=\"format\" [disabled]=\"disabled\" [readonly]=\"readonly\" [type]=\"type\"\n      (onFocus)=\"emitOnFocusEvent($event.nativeEvent)\" (onBlur)=\"emitOnBlurEvent($event.nativeEvent)\"\n      (onClick)=\"_handleInputOnClick()\"></ax-datetime-input>\n    <ng-content select=\"ax-clear-button\"></ng-content>\n    <button type=\"button\" class=\"ax-general-button ax-button-icon\" [tabIndex]=\"-1\" [disabled]=\"disabled\"\n      (click)=\"toggle()\">\n      <span class=\"ax-icon ax-icon-calendar\"></span>\n    </button>\n    <ng-content select=\"ax-suffix\"> </ng-content>\n  </ng-container>\n  <ng-container panel>\n    <ax-datetime-picker [depth]=\"depth\" id=\"{{ id }}-picker\" #picker [ngModel]=\"value\"\n      (ngModelChange)=\"_handlePickerModelChange($event)\" [disabled]=\"disabled\" [readonly]=\"readonly\"\n      [minValue]=\"minValue\" [maxValue]=\"maxValue\" [format]=\"format\" [disabledDates]=\"disabledDates\"\n      [holidayDates]=\"holidayDates\" [depth]=\"depth\" [type]=\"type\"\n      (onNavigate)=\"_handleCalendarOnNavigate($event)\"></ax-datetime-picker>\n  </ng-container>\n</ax-dropdown-box>\n<ng-content select=\"ax-validation-rule\"> </ng-content>"]}
@@ -1,5 +1,5 @@
1
1
  import { AXButtonModule } from '@acorex/components/button';
2
- import { AXCommonModule } from '@acorex/components/common';
2
+ import { AXCommonModule, AXHotkeysService } from '@acorex/components/common';
3
3
  import { AXDecoratorModule } from '@acorex/components/decorators';
4
4
  import { AXLoadingModule } from '@acorex/components/loading';
5
5
  import { A11yModule } from '@angular/cdk/a11y';
@@ -31,7 +31,7 @@ export class AXDialogModule {
31
31
  AXDecoratorModule,
32
32
  AXLoadingModule,
33
33
  DialogModule], exports: [AXDialogComponent] }); }
34
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXDialogModule, providers: [AXDialogService], imports: [MODULES] }); }
34
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXDialogModule, providers: [AXDialogService, AXHotkeysService], imports: [MODULES] }); }
35
35
  }
36
36
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXDialogModule, decorators: [{
37
37
  type: NgModule,
@@ -39,7 +39,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
39
39
  declarations: [...COMPONENT],
40
40
  imports: [...MODULES],
41
41
  exports: [...COMPONENT],
42
- providers: [AXDialogService],
42
+ providers: [AXDialogService, AXHotkeysService],
43
43
  }]
44
44
  }] });
45
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9kaWFsb2cvc3JjL2xpYi9kaWFsb2cubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzdELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3hELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFFbkQsTUFBTSxTQUFTLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBQ3RDLE1BQU0sT0FBTyxHQUFHO0lBQ2QsWUFBWTtJQUNaLGNBQWM7SUFDZCxjQUFjO0lBQ2QsVUFBVTtJQUNWLGNBQWM7SUFDZCxpQkFBaUI7SUFDakIsZUFBZTtJQUNmLFlBQVk7Q0FDYixDQUFDO0FBUUYsTUFBTSxPQUFPLGNBQWM7OEdBQWQsY0FBYzsrR0FBZCxjQUFjLGlCQWxCUixpQkFBaUIsYUFFbEMsWUFBWTtZQUNaLGNBQWM7WUFDZCxjQUFjO1lBQ2QsVUFBVTtZQUNWLGNBQWM7WUFDZCxpQkFBaUI7WUFDakIsZUFBZTtZQUNmLFlBQVksYUFUSyxpQkFBaUI7K0dBa0J2QixjQUFjLGFBRmQsQ0FBQyxlQUFlLENBQUMsWUFGZixPQUFPOzsyRkFJVCxjQUFjO2tCQU4xQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUM1QixPQUFPLEVBQUUsQ0FBQyxHQUFHLE9BQU8sQ0FBQztvQkFDckIsT0FBTyxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUM7b0JBQ3ZCLFNBQVMsRUFBRSxDQUFDLGVBQWUsQ0FBQztpQkFDN0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9idXR0b24nO1xuaW1wb3J0IHsgQVhDb21tb25Nb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvY29tbW9uJztcbmltcG9ydCB7IEFYRGVjb3JhdG9yTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2RlY29yYXRvcnMnO1xuaW1wb3J0IHsgQVhMb2FkaW5nTW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2xvYWRpbmcnO1xuaW1wb3J0IHsgQTExeU1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7IERpYWxvZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kaWFsb2cnO1xuaW1wb3J0IHsgRHJhZ0Ryb3BNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvZHJhZy1kcm9wJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVhEaWFsb2dDb21wb25lbnQgfSBmcm9tICcuL2RpYWxvZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgQVhEaWFsb2dTZXJ2aWNlIH0gZnJvbSAnLi9kaWFsb2cuc2VydmljZSc7XG5cbmNvbnN0IENPTVBPTkVOVCA9IFtBWERpYWxvZ0NvbXBvbmVudF07XG5jb25zdCBNT0RVTEVTID0gW1xuICBDb21tb25Nb2R1bGUsXG4gIEFYQ29tbW9uTW9kdWxlLFxuICBEcmFnRHJvcE1vZHVsZSxcbiAgQTExeU1vZHVsZSxcbiAgQVhCdXR0b25Nb2R1bGUsXG4gIEFYRGVjb3JhdG9yTW9kdWxlLFxuICBBWExvYWRpbmdNb2R1bGUsXG4gIERpYWxvZ01vZHVsZSxcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogWy4uLkNPTVBPTkVOVF0sXG4gIGltcG9ydHM6IFsuLi5NT0RVTEVTXSxcbiAgZXhwb3J0czogWy4uLkNPTVBPTkVOVF0sXG4gIHByb3ZpZGVyczogW0FYRGlhbG9nU2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIEFYRGlhbG9nTW9kdWxlIHt9XG4iXX0=
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9kaWFsb2cvc3JjL2xpYi9kaWFsb2cubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsY0FBYyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0UsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQzdELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbkQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ3hELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFFbkQsTUFBTSxTQUFTLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBQ3RDLE1BQU0sT0FBTyxHQUFHO0lBQ2QsWUFBWTtJQUNaLGNBQWM7SUFDZCxjQUFjO0lBQ2QsVUFBVTtJQUNWLGNBQWM7SUFDZCxpQkFBaUI7SUFDakIsZUFBZTtJQUNmLFlBQVk7Q0FDYixDQUFDO0FBUUYsTUFBTSxPQUFPLGNBQWM7OEdBQWQsY0FBYzsrR0FBZCxjQUFjLGlCQWxCUixpQkFBaUIsYUFFbEMsWUFBWTtZQUNaLGNBQWM7WUFDZCxjQUFjO1lBQ2QsVUFBVTtZQUNWLGNBQWM7WUFDZCxpQkFBaUI7WUFDakIsZUFBZTtZQUNmLFlBQVksYUFUSyxpQkFBaUI7K0dBa0J2QixjQUFjLGFBRmQsQ0FBQyxlQUFlLEVBQUUsZ0JBQWdCLENBQUMsWUFGakMsT0FBTzs7MkZBSVQsY0FBYztrQkFOMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDNUIsT0FBTyxFQUFFLENBQUMsR0FBRyxPQUFPLENBQUM7b0JBQ3JCLE9BQU8sRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUN2QixTQUFTLEVBQUUsQ0FBQyxlQUFlLEVBQUUsZ0JBQWdCLENBQUM7aUJBQy9DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVhCdXR0b25Nb2R1bGUgfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvYnV0dG9uJztcbmltcG9ydCB7IEFYQ29tbW9uTW9kdWxlLCBBWEhvdGtleXNTZXJ2aWNlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XG5pbXBvcnQgeyBBWERlY29yYXRvck1vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9kZWNvcmF0b3JzJztcbmltcG9ydCB7IEFYTG9hZGluZ01vZHVsZSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9sb2FkaW5nJztcbmltcG9ydCB7IEExMXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvYTExeSc7XG5pbXBvcnQgeyBEaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvZGlhbG9nJztcbmltcG9ydCB7IERyYWdEcm9wTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2RyYWctZHJvcCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9kaWFsb2cuY29tcG9uZW50JztcbmltcG9ydCB7IEFYRGlhbG9nU2VydmljZSB9IGZyb20gJy4vZGlhbG9nLnNlcnZpY2UnO1xuXG5jb25zdCBDT01QT05FTlQgPSBbQVhEaWFsb2dDb21wb25lbnRdO1xuY29uc3QgTU9EVUxFUyA9IFtcbiAgQ29tbW9uTW9kdWxlLFxuICBBWENvbW1vbk1vZHVsZSxcbiAgRHJhZ0Ryb3BNb2R1bGUsXG4gIEExMXlNb2R1bGUsXG4gIEFYQnV0dG9uTW9kdWxlLFxuICBBWERlY29yYXRvck1vZHVsZSxcbiAgQVhMb2FkaW5nTW9kdWxlLFxuICBEaWFsb2dNb2R1bGUsXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFsuLi5DT01QT05FTlRdLFxuICBpbXBvcnRzOiBbLi4uTU9EVUxFU10sXG4gIGV4cG9ydHM6IFsuLi5DT01QT05FTlRdLFxuICBwcm92aWRlcnM6IFtBWERpYWxvZ1NlcnZpY2UsIEFYSG90a2V5c1NlcnZpY2VdLFxufSlcbmV4cG9ydCBjbGFzcyBBWERpYWxvZ01vZHVsZSB7fVxuIl19
@@ -2,7 +2,6 @@ export * from './lib/form-field.component';
2
2
  export * from './lib/form.component';
3
3
  export * from './lib/form.config';
4
4
  export * from './lib/form.module';
5
- export * from './lib/validation-rule.widget';
5
+ export * from './lib/validation-rule.directive';
6
6
  export * from './lib/validation-summary.component';
7
- export * from './lib/validation.class';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZm9ybS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0tZmllbGQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0uY29uZmlnJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZhbGlkYXRpb24tcnVsZS53aWRnZXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdmFsaWRhdGlvbi1zdW1tYXJ5LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92YWxpZGF0aW9uLmNsYXNzJztcbiJdfQ==
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZm9ybS9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsb0NBQW9DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtLWZpZWxkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtLmNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi92YWxpZGF0aW9uLXJ1bGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZhbGlkYXRpb24tc3VtbWFyeS5jb21wb25lbnQnO1xuIl19
@@ -1,12 +1,40 @@
1
- import { MXBaseComponent } from '@acorex/components/common';
2
- import { ChangeDetectionStrategy, Component, ViewEncapsulation } from '@angular/core';
1
+ import { AXValuableComponent, MXBaseComponent } from '@acorex/components/common';
2
+ import { AXLabelComponent } from '@acorex/components/label';
3
+ import { AXUnsubscriber } from '@acorex/core/utils';
4
+ import { ChangeDetectionStrategy, Component, ContentChild, ViewEncapsulation, inject } from '@angular/core';
3
5
  import * as i0 from "@angular/core";
4
6
  export class AXFormFieldComponent extends MXBaseComponent {
7
+ constructor() {
8
+ super(...arguments);
9
+ this.unsubscriber = inject(AXUnsubscriber);
10
+ }
11
+ ngAfterContentInit() {
12
+ this.autoSetRequired();
13
+ this.input?.validationRulesChange
14
+ .pipe(this.unsubscriber.takeUntilDestroy)
15
+ .subscribe(() => {
16
+ this.autoSetRequired();
17
+ });
18
+ }
19
+ autoSetRequired() {
20
+ if (this.label && this.input) {
21
+ if (this.label.required == null || this.label['autoSetRequired']) {
22
+ this.label.required = this.input.isRequired;
23
+ this.label['autoSetRequired'] = true;
24
+ }
25
+ }
26
+ }
5
27
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXFormFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
6
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXFormFieldComponent, selector: "ax-form-field", 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-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:10;display:block;width:-webkit-fit-content;width:-moz-fit-content;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{-webkit-margin-start:-1px;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 }); }
28
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: AXFormFieldComponent, selector: "ax-form-field", 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-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:10;display:block;width:-webkit-fit-content;width:-moz-fit-content;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{-webkit-margin-start:-1px;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 }); }
7
29
  }
8
30
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AXFormFieldComponent, decorators: [{
9
31
  type: Component,
10
- args: [{ selector: 'ax-form-field', template: `<ng-content></ng-content>`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, 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-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:10;display:block;width:-webkit-fit-content;width:-moz-fit-content;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{-webkit-margin-start:-1px;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"] }]
11
- }] });
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZm9ybS9zcmMvbGliL2Zvcm0tZmllbGQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVN0RixNQUFNLE9BQU8sb0JBQXFCLFNBQVEsZUFBZTs4R0FBNUMsb0JBQW9CO2tHQUFwQixvQkFBb0IsNEVBTHJCLDJCQUEyQjs7MkZBSzFCLG9CQUFvQjtrQkFQaEMsU0FBUzsrQkFDRSxlQUFlLFlBQ2YsMkJBQTJCLGlCQUV0QixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTVhCYXNlQ29tcG9uZW50IH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdheC1mb3JtLWZpZWxkJyxcbiAgdGVtcGxhdGU6IGA8bmctY29udGVudD48L25nLWNvbnRlbnQ+YCxcbiAgc3R5bGVVcmxzOiBbJy4vZm9ybS1maWVsZC5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQVhGb3JtRmllbGRDb21wb25lbnQgZXh0ZW5kcyBNWEJhc2VDb21wb25lbnQge31cbiJdfQ==
32
+ 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-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:10;display:block;width:-webkit-fit-content;width:-moz-fit-content;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{-webkit-margin-start:-1px;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"] }]
33
+ }], propDecorators: { input: [{
34
+ type: ContentChild,
35
+ args: [AXValuableComponent]
36
+ }], label: [{
37
+ type: ContentChild,
38
+ args: [AXLabelComponent]
39
+ }] } });
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1maWVsZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZm9ybS9zcmMvbGliL2Zvcm0tZmllbGQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUNqRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDcEQsT0FBTyxFQUFvQix1QkFBdUIsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFpQixpQkFBaUIsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBVTdJLE1BQU0sT0FBTyxvQkFBcUIsU0FBUSxlQUFlO0lBUnpEOztRQVdVLGlCQUFZLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDO0tBOEIvQztJQXJCQyxrQkFBa0I7UUFDaEIsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxLQUFLLEVBQUUscUJBQXFCO2FBQzlCLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLGdCQUFnQixDQUFDO2FBQ3hDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDekIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBS08sZUFBZTtRQUNyQixJQUFJLElBQUksQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUM1QixJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLGlCQUFpQixDQUFDLEVBQUU7Z0JBQ2hFLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDO2dCQUM1QyxJQUFJLENBQUMsS0FBSyxDQUFDLGlCQUFpQixDQUFDLEdBQUcsSUFBSSxDQUFDO2FBQ3RDO1NBQ0Y7SUFDSCxDQUFDOzhHQS9CVSxvQkFBb0I7a0dBQXBCLG9CQUFvQix3Q0FGcEIsQ0FBQyxjQUFjLENBQUMsNkRBT2IsbUJBQW1CLHdFQUduQixnQkFBZ0IsdUVBZHBCLDJCQUEyQjs7MkZBTTFCLG9CQUFvQjtrQkFSaEMsU0FBUzsrQkFDRSxlQUFlLFlBQ2YsMkJBQTJCLGlCQUV0QixpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDLENBQUMsY0FBYyxDQUFDOzhCQVFuQixLQUFLO3NCQURaLFlBQVk7dUJBQUMsbUJBQW1CO2dCQUl6QixLQUFLO3NCQURaLFlBQVk7dUJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVhWYWx1YWJsZUNvbXBvbmVudCwgTVhCYXNlQ29tcG9uZW50IH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2NvbW1vbic7XG5pbXBvcnQgeyBBWExhYmVsQ29tcG9uZW50IH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2xhYmVsJztcbmltcG9ydCB7IEFYVW5zdWJzY3JpYmVyIH0gZnJvbSAnQGFjb3JleC9jb3JlL3V0aWxzJztcbmltcG9ydCB7IEFmdGVyQ29udGVudEluaXQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIENvbnRlbnRDaGlsZCwgU2ltcGxlQ2hhbmdlcywgVmlld0VuY2Fwc3VsYXRpb24sIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdheC1mb3JtLWZpZWxkJyxcbiAgdGVtcGxhdGU6IGA8bmctY29udGVudD48L25nLWNvbnRlbnQ+YCxcbiAgc3R5bGVVcmxzOiBbJy4vZm9ybS1maWVsZC5jb21wb25lbnQuc2NzcyddLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgcHJvdmlkZXJzOiBbQVhVbnN1YnNjcmliZXJdXG59KVxuZXhwb3J0IGNsYXNzIEFYRm9ybUZpZWxkQ29tcG9uZW50IGV4dGVuZHMgTVhCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJDb250ZW50SW5pdCB7XG5cblxuICBwcml2YXRlIHVuc3Vic2NyaWJlciA9IGluamVjdChBWFVuc3Vic2NyaWJlcik7XG5cbiAgQENvbnRlbnRDaGlsZChBWFZhbHVhYmxlQ29tcG9uZW50KVxuICBwcml2YXRlIGlucHV0OiBBWFZhbHVhYmxlQ29tcG9uZW50O1xuXG4gIEBDb250ZW50Q2hpbGQoQVhMYWJlbENvbXBvbmVudClcbiAgcHJpdmF0ZSBsYWJlbDogQVhMYWJlbENvbXBvbmVudDtcblxuXG4gIG5nQWZ0ZXJDb250ZW50SW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLmF1dG9TZXRSZXF1aXJlZCgpO1xuICAgIHRoaXMuaW5wdXQ/LnZhbGlkYXRpb25SdWxlc0NoYW5nZVxuICAgICAgLnBpcGUodGhpcy51bnN1YnNjcmliZXIudGFrZVVudGlsRGVzdHJveSlcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLmF1dG9TZXRSZXF1aXJlZCgpO1xuICAgICAgfSk7XG4gIH1cblxuXG5cblxuICBwcml2YXRlIGF1dG9TZXRSZXF1aXJlZCgpIHtcbiAgICBpZiAodGhpcy5sYWJlbCAmJiB0aGlzLmlucHV0KSB7XG4gICAgICBpZiAodGhpcy5sYWJlbC5yZXF1aXJlZCA9PSBudWxsIHx8IHRoaXMubGFiZWxbJ2F1dG9TZXRSZXF1aXJlZCddKSB7XG4gICAgICAgIHRoaXMubGFiZWwucmVxdWlyZWQgPSB0aGlzLmlucHV0LmlzUmVxdWlyZWQ7XG4gICAgICAgIHRoaXMubGFiZWxbJ2F1dG9TZXRSZXF1aXJlZCddID0gdHJ1ZTtcbiAgICAgIH1cbiAgICB9XG4gIH1cblxufVxuIl19