@acorex/components 3.0.52 → 3.0.53

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.
@@ -235,7 +235,7 @@ __decorate([
235
235
  ], AXBaseTextComponent.prototype, "placeholder", void 0);
236
236
  __decorate([
237
237
  Input(),
238
- __metadata("design:type", Boolean)
238
+ __metadata("design:type", String)
239
239
  ], AXBaseTextComponent.prototype, "autocomplete", void 0);
240
240
  __decorate([
241
241
  Input(),
@@ -325,4 +325,4 @@ __decorate([
325
325
  Input(),
326
326
  __metadata("design:type", Boolean)
327
327
  ], AXBaseDropdownComponent.prototype, "showDropDownButton", void 0);
328
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.class.js","sourceRoot":"ng://@acorex/components/","sources":["lib/base/element.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef, ViewChild, ElementRef, ContentChild } from '@angular/core';\r\nimport { AXValidationComponent, AXValidation } from '../validation/validation.component';\r\nimport { AXValidationRuleResult } from '../validation/validation.class';\r\nimport { AXHtmlUtil } from '@acorex/core';\r\nimport { AXEvent, AXHtmlEvent, AXValueEvent } from './events.class';\r\n\r\nexport type AXElementSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\r\n\r\nexport abstract class AXBaseComponent {\r\n  @Input() cssClass: string;\r\n  uid: string = AXHtmlUtil.getUID();\r\n  constructor() {\r\n  }\r\n}\r\n\r\n\r\nexport class AXBaseInputChangeEvent extends AXValueEvent<any> {\r\n  isUserChange?: boolean;\r\n}\r\n\r\nexport interface AXBaseSizableComponent {\r\n  size: AXElementSize;\r\n}\r\n\r\nexport interface AXBaseInteractiveComponent {\r\n  disabled: boolean;\r\n  tabIndex: number;\r\n}\r\n\r\nexport interface AXBaseInputComponent extends AXBaseInteractiveComponent {\r\n  readonly: boolean;\r\n  focus(): void;\r\n}\r\n\r\n\r\nexport interface AXBaseValueComponent<T> extends AXBaseInputComponent {\r\n  onValueChanged?: EventEmitter<AXValueEvent<T>>;\r\n  valueChange?: EventEmitter<T>;\r\n  value: T;\r\n}\r\n\r\nexport interface AXBaseClickableComponent extends AXBaseInteractiveComponent {\r\n  click: EventEmitter<AXHtmlEvent<MouseEvent>>;\r\n}\r\n\r\nexport abstract class AXValidatableComponent extends AXBaseComponent {\r\n\r\n  private __valueField: string = 'value';\r\n  private __nativeElement: HTMLElement;\r\n  private __validation: AXValidation;\r\n\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  protected initValidation(\r\n    elementRef: ElementRef,\r\n    valueField: string,\r\n    validation: AXValidation\r\n  ) {\r\n    this.__nativeElement = elementRef.nativeElement;\r\n    this.__valueField = valueField;\r\n    this.__validation = validation;\r\n    const value = this[this.__valueField]\r\n    if ((!Array.isArray(value) && value) || (Array.isArray(value) && value.length > 0))\r\n      this.validate();\r\n  }\r\n\r\n  get validation() {\r\n    return this.__validation;\r\n  }\r\n\r\n  validate(): Promise<AXValidationRuleResult> {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const result = this.__validation.validate(this[this.__valueField]);\r\n      result.then(c => {\r\n        if (c.result) {\r\n          this.clearValidationStyle(this.__nativeElement);\r\n        }\r\n        else {\r\n          this.applyValidationStyle(this.__nativeElement, c);\r\n        }\r\n      });\r\n      return result;\r\n    }\r\n    else {\r\n      return Promise.resolve({ result: true });\r\n    }\r\n  }\r\n\r\n\r\n  protected clearValidationStyle(element: HTMLElement, clear: boolean = false) {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const formGroup = element.closest('.form-group');\r\n      const formItem = formGroup?.querySelector('.form-item') || element.closest('.form-item') || element.querySelector('.form-item');;\r\n      const label = formGroup?.querySelector('.form-group-label');\r\n      const parent = formItem?.parentElement || element.parentElement;\r\n\r\n      formItem?.classList.remove('success-state');\r\n      formItem?.classList.remove('error-state');\r\n      //formItem?.classList.remove('required-state');\r\n      if (!clear) {\r\n        formItem?.classList.add('success-state');\r\n      }\r\n      // label?.classList.remove('error-text');\r\n      if (parent.querySelector('span.error-text')) {\r\n        parent.removeChild(parent.querySelector('span.error-text'));\r\n      }\r\n    }\r\n  }\r\n\r\n  protected applyValidationStyle(element: HTMLElement, v: AXValidationRuleResult): void {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const formGroup = element.closest('.form-group');\r\n      const formItem = formGroup?.querySelector('.form-item') || element.closest('.form-item') || element.querySelector('.form-item');\r\n      const label = formGroup?.querySelector('.form-group-label');\r\n      const parent = formItem?.parentElement || element.parentElement;\r\n      formItem?.classList.add('error-state');\r\n      formItem?.classList.remove('success-state');\r\n      if (parent.querySelector('span.error-text')) {\r\n        parent.removeChild(parent.querySelector('span.error-text'));\r\n      }\r\n      if (this.__validation.showMessage) {\r\n        const span = document.createElement('span');\r\n        span.innerText = v.message;\r\n        span.classList.add('ax', 'error-text');\r\n        parent.appendChild(span);\r\n      }\r\n      // label?.classList.add('error-text');\r\n    }\r\n  }\r\n}\r\n\r\n\r\n\r\n\r\nexport abstract class AXBaseTextComponent extends AXValidatableComponent implements AXBaseSizableComponent, AXBaseValueComponent<string> {\r\n\r\n  ngAfterViewInit() {\r\n    if (this.input) {\r\n      this.input.nativeElement.onkeyup = (e) => {\r\n        this.userChange = true;\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n      this.input.nativeElement.onkeydown = (e) => {\r\n        this.userChange = true;\r\n\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n      this.input.nativeElement.onkeypress = (e) => {\r\n        this.userChange = true;\r\n\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n    }\r\n  }\r\n\r\n\r\n  ngAfterContentInit(): void {\r\n    this.initValidation(this.ref, 'value', this.validation);\r\n  }\r\n\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  @ViewChild('input', { static: true })\r\n  @ContentChild('input', { static: true })\r\n  input: ElementRef<HTMLInputElement>;\r\n\r\n  @ContentChild(AXValidation, { static: true })\r\n  private _contentValidation: AXValidation;\r\n\r\n  private _validation: AXValidation;\r\n\r\n  @Input()\r\n  public get validation(): AXValidation {\r\n    return this._validation ? this._validation : this._contentValidation;\r\n  }\r\n\r\n  public set validation(v: AXValidation) {\r\n    this._validation = v;\r\n    this.initValidation(this.ref, 'value', v);\r\n  }\r\n\r\n\r\n  @Input()\r\n  disabled: boolean = false;\r\n\r\n  @Input()\r\n  readonly: boolean = false;\r\n\r\n  @Input()\r\n  textAlign: 'right' | 'left' | null = null;\r\n\r\n  @Input()\r\n  size: 'xs' | 'sm' | 'md' | 'lg' | 'xl' = 'md';\r\n\r\n  @Input()\r\n  placeholder: string;\r\n\r\n\r\n  @Input()\r\n  autocomplete: boolean;\r\n\r\n  @Input()\r\n  name: string;\r\n\r\n  userChange: boolean = false;\r\n\r\n  constructor(protected cdr: ChangeDetectorRef, protected ref: ElementRef) {\r\n    super();\r\n  }\r\n\r\n  @Output()\r\n  public onkey: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\r\n\r\n  @Output()\r\n  public onBlur: EventEmitter<AXHtmlEvent<Event>> = new EventEmitter<AXHtmlEvent<Event>>();\r\n\r\n  @Output()\r\n  public onFocus: EventEmitter<AXHtmlEvent<Event>> = new EventEmitter<AXHtmlEvent<Event>>();\r\n\r\n  @Output()\r\n  public onValueChanged: EventEmitter<AXBaseInputChangeEvent> = new EventEmitter<AXBaseInputChangeEvent>();\r\n\r\n  @Output()\r\n  valueChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n  @Input()\r\n  icon: string = '';\r\n\r\n  @Input()\r\n  allowClear: boolean = false;\r\n\r\n  private _value: string;\r\n  @Input()\r\n  public get value(): string {\r\n    return this._value;\r\n  }\r\n  public set value(v: string) {\r\n    if (v !== this._value) {\r\n      const old = this._value;\r\n      this._value = v;\r\n\r\n      this.valueChange.emit(v);\r\n      this.onValueChanged.emit({\r\n        component: this,\r\n        value: v,\r\n        oldValue: old,\r\n        isUserChange: this.userChange\r\n      });\r\n      this.userChange = false;\r\n      this.clearValidationStyle(this.input.nativeElement, v ? false : true);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  focus() {\r\n    this.input.nativeElement.focus();\r\n  }\r\n\r\n  clear() {\r\n    this.userChange = true;\r\n\r\n    this.value = null;\r\n    this.input.nativeElement.value = null;\r\n  }\r\n\r\n  isFocused(): boolean {\r\n    return this.input.nativeElement === document.activeElement;\r\n  }\r\n\r\n  setTextAlign() {\r\n    if (this.textAlign === 'left') {\r\n      return 'text-left';\r\n    }\r\n    if (this.textAlign === 'right') {\r\n      return 'text-right';\r\n    }\r\n  }\r\n\r\n  handleInputBlur(e: Event) {\r\n    this.onBlur.emit({\r\n      component: this,\r\n      htmlElement: this.ref.nativeElement,\r\n      htmlEvent: e\r\n    });\r\n  }\r\n\r\n  handleInputFocus(e: Event) {\r\n    this.onFocus.emit({\r\n      component: this,\r\n      htmlElement: this.ref.nativeElement,\r\n      htmlEvent: e\r\n    });\r\n  }\r\n}\r\n\r\nexport abstract class AXBaseButtonComponent extends AXBaseComponent implements AXBaseClickableComponent, AXBaseSizableComponent {\r\n\r\n  @Input()\r\n  disabled: boolean;\r\n\r\n  @Output()\r\n  click: EventEmitter<AXHtmlEvent<MouseEvent>> = new EventEmitter<AXHtmlEvent<MouseEvent>>();\r\n\r\n  @Input()\r\n  size: AXElementSize;\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n}\r\n\r\nexport abstract class AXBaseDropdownComponent extends AXBaseComponent implements AXBaseInteractiveComponent, AXBaseSizableComponent {\r\n\r\n  @Input()\r\n  disabled: boolean;\r\n\r\n  @Input()\r\n  size: AXElementSize;\r\n\r\n  @Input()\r\n  fitParent: boolean = true;\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  @Input()\r\n  showDropDownButton: boolean = true;\r\n\r\n  abstract close();\r\n  abstract open();\r\n}\r\n"]}
328
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.class.js","sourceRoot":"ng://@acorex/components/","sources":["lib/base/element.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef, ViewChild, ElementRef, ContentChild } from '@angular/core';\r\nimport { AXValidationComponent, AXValidation } from '../validation/validation.component';\r\nimport { AXValidationRuleResult } from '../validation/validation.class';\r\nimport { AXHtmlUtil } from '@acorex/core';\r\nimport { AXEvent, AXHtmlEvent, AXValueEvent } from './events.class';\r\n\r\nexport type AXElementSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\r\n\r\nexport abstract class AXBaseComponent {\r\n  @Input() cssClass: string;\r\n  uid: string = AXHtmlUtil.getUID();\r\n  constructor() {\r\n  }\r\n}\r\n\r\n\r\nexport class AXBaseInputChangeEvent extends AXValueEvent<any> {\r\n  isUserChange?: boolean;\r\n}\r\n\r\nexport interface AXBaseSizableComponent {\r\n  size: AXElementSize;\r\n}\r\n\r\nexport interface AXBaseInteractiveComponent {\r\n  disabled: boolean;\r\n  tabIndex: number;\r\n}\r\n\r\nexport interface AXBaseInputComponent extends AXBaseInteractiveComponent {\r\n  readonly: boolean;\r\n  focus(): void;\r\n}\r\n\r\n\r\nexport interface AXBaseValueComponent<T> extends AXBaseInputComponent {\r\n  onValueChanged?: EventEmitter<AXValueEvent<T>>;\r\n  valueChange?: EventEmitter<T>;\r\n  value: T;\r\n}\r\n\r\nexport interface AXBaseClickableComponent extends AXBaseInteractiveComponent {\r\n  click: EventEmitter<AXHtmlEvent<MouseEvent>>;\r\n}\r\n\r\nexport abstract class AXValidatableComponent extends AXBaseComponent {\r\n\r\n  private __valueField: string = 'value';\r\n  private __nativeElement: HTMLElement;\r\n  private __validation: AXValidation;\r\n\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  protected initValidation(\r\n    elementRef: ElementRef,\r\n    valueField: string,\r\n    validation: AXValidation\r\n  ) {\r\n    this.__nativeElement = elementRef.nativeElement;\r\n    this.__valueField = valueField;\r\n    this.__validation = validation;\r\n    const value = this[this.__valueField]\r\n    if ((!Array.isArray(value) && value) || (Array.isArray(value) && value.length > 0))\r\n      this.validate();\r\n  }\r\n\r\n  get validation() {\r\n    return this.__validation;\r\n  }\r\n\r\n  validate(): Promise<AXValidationRuleResult> {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const result = this.__validation.validate(this[this.__valueField]);\r\n      result.then(c => {\r\n        if (c.result) {\r\n          this.clearValidationStyle(this.__nativeElement);\r\n        }\r\n        else {\r\n          this.applyValidationStyle(this.__nativeElement, c);\r\n        }\r\n      });\r\n      return result;\r\n    }\r\n    else {\r\n      return Promise.resolve({ result: true });\r\n    }\r\n  }\r\n\r\n\r\n  protected clearValidationStyle(element: HTMLElement, clear: boolean = false) {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const formGroup = element.closest('.form-group');\r\n      const formItem = formGroup?.querySelector('.form-item') || element.closest('.form-item') || element.querySelector('.form-item');;\r\n      const label = formGroup?.querySelector('.form-group-label');\r\n      const parent = formItem?.parentElement || element.parentElement;\r\n\r\n      formItem?.classList.remove('success-state');\r\n      formItem?.classList.remove('error-state');\r\n      //formItem?.classList.remove('required-state');\r\n      if (!clear) {\r\n        formItem?.classList.add('success-state');\r\n      }\r\n      // label?.classList.remove('error-text');\r\n      if (parent.querySelector('span.error-text')) {\r\n        parent.removeChild(parent.querySelector('span.error-text'));\r\n      }\r\n    }\r\n  }\r\n\r\n  protected applyValidationStyle(element: HTMLElement, v: AXValidationRuleResult): void {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const formGroup = element.closest('.form-group');\r\n      const formItem = formGroup?.querySelector('.form-item') || element.closest('.form-item') || element.querySelector('.form-item');\r\n      const label = formGroup?.querySelector('.form-group-label');\r\n      const parent = formItem?.parentElement || element.parentElement;\r\n      formItem?.classList.add('error-state');\r\n      formItem?.classList.remove('success-state');\r\n      if (parent.querySelector('span.error-text')) {\r\n        parent.removeChild(parent.querySelector('span.error-text'));\r\n      }\r\n      if (this.__validation.showMessage) {\r\n        const span = document.createElement('span');\r\n        span.innerText = v.message;\r\n        span.classList.add('ax', 'error-text');\r\n        parent.appendChild(span);\r\n      }\r\n      // label?.classList.add('error-text');\r\n    }\r\n  }\r\n}\r\n\r\n\r\n\r\n\r\nexport abstract class AXBaseTextComponent extends AXValidatableComponent implements AXBaseSizableComponent, AXBaseValueComponent<string> {\r\n\r\n  ngAfterViewInit() {\r\n    if (this.input) {\r\n      this.input.nativeElement.onkeyup = (e) => {\r\n        this.userChange = true;\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n      this.input.nativeElement.onkeydown = (e) => {\r\n        this.userChange = true;\r\n\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n      this.input.nativeElement.onkeypress = (e) => {\r\n        this.userChange = true;\r\n\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n    }\r\n  }\r\n\r\n\r\n  ngAfterContentInit(): void {\r\n    this.initValidation(this.ref, 'value', this.validation);\r\n  }\r\n\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  @ViewChild('input', { static: true })\r\n  @ContentChild('input', { static: true })\r\n  input: ElementRef<HTMLInputElement>;\r\n\r\n  @ContentChild(AXValidation, { static: true })\r\n  private _contentValidation: AXValidation;\r\n\r\n  private _validation: AXValidation;\r\n\r\n  @Input()\r\n  public get validation(): AXValidation {\r\n    return this._validation ? this._validation : this._contentValidation;\r\n  }\r\n\r\n  public set validation(v: AXValidation) {\r\n    this._validation = v;\r\n    this.initValidation(this.ref, 'value', v);\r\n  }\r\n\r\n\r\n  @Input()\r\n  disabled: boolean = false;\r\n\r\n  @Input()\r\n  readonly: boolean = false;\r\n\r\n  @Input()\r\n  textAlign: 'right' | 'left' | null = null;\r\n\r\n  @Input()\r\n  size: 'xs' | 'sm' | 'md' | 'lg' | 'xl' = 'md';\r\n\r\n  @Input()\r\n  placeholder: string;\r\n\r\n\r\n  @Input()\r\n  autocomplete: \"on\" | \"off\";\r\n\r\n  @Input()\r\n  name: string;\r\n\r\n  userChange: boolean = false;\r\n\r\n  constructor(protected cdr: ChangeDetectorRef, protected ref: ElementRef) {\r\n    super();\r\n  }\r\n\r\n  @Output()\r\n  public onkey: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\r\n\r\n  @Output()\r\n  public onBlur: EventEmitter<AXHtmlEvent<Event>> = new EventEmitter<AXHtmlEvent<Event>>();\r\n\r\n  @Output()\r\n  public onFocus: EventEmitter<AXHtmlEvent<Event>> = new EventEmitter<AXHtmlEvent<Event>>();\r\n\r\n  @Output()\r\n  public onValueChanged: EventEmitter<AXBaseInputChangeEvent> = new EventEmitter<AXBaseInputChangeEvent>();\r\n\r\n  @Output()\r\n  valueChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n  @Input()\r\n  icon: string = '';\r\n\r\n  @Input()\r\n  allowClear: boolean = false;\r\n\r\n  private _value: string;\r\n  @Input()\r\n  public get value(): string {\r\n    return this._value;\r\n  }\r\n  public set value(v: string) {\r\n    if (v !== this._value) {\r\n      const old = this._value;\r\n      this._value = v;\r\n\r\n      this.valueChange.emit(v);\r\n      this.onValueChanged.emit({\r\n        component: this,\r\n        value: v,\r\n        oldValue: old,\r\n        isUserChange: this.userChange\r\n      });\r\n      this.userChange = false;\r\n      this.clearValidationStyle(this.input.nativeElement, v ? false : true);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  focus() {\r\n    this.input.nativeElement.focus();\r\n  }\r\n\r\n  clear() {\r\n    this.userChange = true;\r\n\r\n    this.value = null;\r\n    this.input.nativeElement.value = null;\r\n  }\r\n\r\n  isFocused(): boolean {\r\n    return this.input.nativeElement === document.activeElement;\r\n  }\r\n\r\n  setTextAlign() {\r\n    if (this.textAlign === 'left') {\r\n      return 'text-left';\r\n    }\r\n    if (this.textAlign === 'right') {\r\n      return 'text-right';\r\n    }\r\n  }\r\n\r\n  handleInputBlur(e: Event) {\r\n    this.onBlur.emit({\r\n      component: this,\r\n      htmlElement: this.ref.nativeElement,\r\n      htmlEvent: e\r\n    });\r\n  }\r\n\r\n  handleInputFocus(e: Event) {\r\n    this.onFocus.emit({\r\n      component: this,\r\n      htmlElement: this.ref.nativeElement,\r\n      htmlEvent: e\r\n    });\r\n  }\r\n}\r\n\r\nexport abstract class AXBaseButtonComponent extends AXBaseComponent implements AXBaseClickableComponent, AXBaseSizableComponent {\r\n\r\n  @Input()\r\n  disabled: boolean;\r\n\r\n  @Output()\r\n  click: EventEmitter<AXHtmlEvent<MouseEvent>> = new EventEmitter<AXHtmlEvent<MouseEvent>>();\r\n\r\n  @Input()\r\n  size: AXElementSize;\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n}\r\n\r\nexport abstract class AXBaseDropdownComponent extends AXBaseComponent implements AXBaseInteractiveComponent, AXBaseSizableComponent {\r\n\r\n  @Input()\r\n  disabled: boolean;\r\n\r\n  @Input()\r\n  size: AXElementSize;\r\n\r\n  @Input()\r\n  fitParent: boolean = true;\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  @Input()\r\n  showDropDownButton: boolean = true;\r\n\r\n  abstract close();\r\n  abstract open();\r\n}\r\n"]}
@@ -263,7 +263,7 @@ var AXBaseTextComponent = /** @class */ (function (_super) {
263
263
  ], AXBaseTextComponent.prototype, "placeholder", void 0);
264
264
  __decorate([
265
265
  Input(),
266
- __metadata("design:type", Boolean)
266
+ __metadata("design:type", String)
267
267
  ], AXBaseTextComponent.prototype, "autocomplete", void 0);
268
268
  __decorate([
269
269
  Input(),
@@ -364,4 +364,4 @@ var AXBaseDropdownComponent = /** @class */ (function (_super) {
364
364
  return AXBaseDropdownComponent;
365
365
  }(AXBaseComponent));
366
366
  export { AXBaseDropdownComponent };
367
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.class.js","sourceRoot":"ng://@acorex/components/","sources":["lib/base/element.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef, ViewChild, ElementRef, ContentChild } from '@angular/core';\r\nimport { AXValidationComponent, AXValidation } from '../validation/validation.component';\r\nimport { AXValidationRuleResult } from '../validation/validation.class';\r\nimport { AXHtmlUtil } from '@acorex/core';\r\nimport { AXEvent, AXHtmlEvent, AXValueEvent } from './events.class';\r\n\r\nexport type AXElementSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\r\n\r\nexport abstract class AXBaseComponent {\r\n  @Input() cssClass: string;\r\n  uid: string = AXHtmlUtil.getUID();\r\n  constructor() {\r\n  }\r\n}\r\n\r\n\r\nexport class AXBaseInputChangeEvent extends AXValueEvent<any> {\r\n  isUserChange?: boolean;\r\n}\r\n\r\nexport interface AXBaseSizableComponent {\r\n  size: AXElementSize;\r\n}\r\n\r\nexport interface AXBaseInteractiveComponent {\r\n  disabled: boolean;\r\n  tabIndex: number;\r\n}\r\n\r\nexport interface AXBaseInputComponent extends AXBaseInteractiveComponent {\r\n  readonly: boolean;\r\n  focus(): void;\r\n}\r\n\r\n\r\nexport interface AXBaseValueComponent<T> extends AXBaseInputComponent {\r\n  onValueChanged?: EventEmitter<AXValueEvent<T>>;\r\n  valueChange?: EventEmitter<T>;\r\n  value: T;\r\n}\r\n\r\nexport interface AXBaseClickableComponent extends AXBaseInteractiveComponent {\r\n  click: EventEmitter<AXHtmlEvent<MouseEvent>>;\r\n}\r\n\r\nexport abstract class AXValidatableComponent extends AXBaseComponent {\r\n\r\n  private __valueField: string = 'value';\r\n  private __nativeElement: HTMLElement;\r\n  private __validation: AXValidation;\r\n\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  protected initValidation(\r\n    elementRef: ElementRef,\r\n    valueField: string,\r\n    validation: AXValidation\r\n  ) {\r\n    this.__nativeElement = elementRef.nativeElement;\r\n    this.__valueField = valueField;\r\n    this.__validation = validation;\r\n    const value = this[this.__valueField]\r\n    if ((!Array.isArray(value) && value) || (Array.isArray(value) && value.length > 0))\r\n      this.validate();\r\n  }\r\n\r\n  get validation() {\r\n    return this.__validation;\r\n  }\r\n\r\n  validate(): Promise<AXValidationRuleResult> {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const result = this.__validation.validate(this[this.__valueField]);\r\n      result.then(c => {\r\n        if (c.result) {\r\n          this.clearValidationStyle(this.__nativeElement);\r\n        }\r\n        else {\r\n          this.applyValidationStyle(this.__nativeElement, c);\r\n        }\r\n      });\r\n      return result;\r\n    }\r\n    else {\r\n      return Promise.resolve({ result: true });\r\n    }\r\n  }\r\n\r\n\r\n  protected clearValidationStyle(element: HTMLElement, clear: boolean = false) {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const formGroup = element.closest('.form-group');\r\n      const formItem = formGroup?.querySelector('.form-item') || element.closest('.form-item') || element.querySelector('.form-item');;\r\n      const label = formGroup?.querySelector('.form-group-label');\r\n      const parent = formItem?.parentElement || element.parentElement;\r\n\r\n      formItem?.classList.remove('success-state');\r\n      formItem?.classList.remove('error-state');\r\n      //formItem?.classList.remove('required-state');\r\n      if (!clear) {\r\n        formItem?.classList.add('success-state');\r\n      }\r\n      // label?.classList.remove('error-text');\r\n      if (parent.querySelector('span.error-text')) {\r\n        parent.removeChild(parent.querySelector('span.error-text'));\r\n      }\r\n    }\r\n  }\r\n\r\n  protected applyValidationStyle(element: HTMLElement, v: AXValidationRuleResult): void {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const formGroup = element.closest('.form-group');\r\n      const formItem = formGroup?.querySelector('.form-item') || element.closest('.form-item') || element.querySelector('.form-item');\r\n      const label = formGroup?.querySelector('.form-group-label');\r\n      const parent = formItem?.parentElement || element.parentElement;\r\n      formItem?.classList.add('error-state');\r\n      formItem?.classList.remove('success-state');\r\n      if (parent.querySelector('span.error-text')) {\r\n        parent.removeChild(parent.querySelector('span.error-text'));\r\n      }\r\n      if (this.__validation.showMessage) {\r\n        const span = document.createElement('span');\r\n        span.innerText = v.message;\r\n        span.classList.add('ax', 'error-text');\r\n        parent.appendChild(span);\r\n      }\r\n      // label?.classList.add('error-text');\r\n    }\r\n  }\r\n}\r\n\r\n\r\n\r\n\r\nexport abstract class AXBaseTextComponent extends AXValidatableComponent implements AXBaseSizableComponent, AXBaseValueComponent<string> {\r\n\r\n  ngAfterViewInit() {\r\n    if (this.input) {\r\n      this.input.nativeElement.onkeyup = (e) => {\r\n        this.userChange = true;\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n      this.input.nativeElement.onkeydown = (e) => {\r\n        this.userChange = true;\r\n\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n      this.input.nativeElement.onkeypress = (e) => {\r\n        this.userChange = true;\r\n\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n    }\r\n  }\r\n\r\n\r\n  ngAfterContentInit(): void {\r\n    this.initValidation(this.ref, 'value', this.validation);\r\n  }\r\n\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  @ViewChild('input', { static: true })\r\n  @ContentChild('input', { static: true })\r\n  input: ElementRef<HTMLInputElement>;\r\n\r\n  @ContentChild(AXValidation, { static: true })\r\n  private _contentValidation: AXValidation;\r\n\r\n  private _validation: AXValidation;\r\n\r\n  @Input()\r\n  public get validation(): AXValidation {\r\n    return this._validation ? this._validation : this._contentValidation;\r\n  }\r\n\r\n  public set validation(v: AXValidation) {\r\n    this._validation = v;\r\n    this.initValidation(this.ref, 'value', v);\r\n  }\r\n\r\n\r\n  @Input()\r\n  disabled: boolean = false;\r\n\r\n  @Input()\r\n  readonly: boolean = false;\r\n\r\n  @Input()\r\n  textAlign: 'right' | 'left' | null = null;\r\n\r\n  @Input()\r\n  size: 'xs' | 'sm' | 'md' | 'lg' | 'xl' = 'md';\r\n\r\n  @Input()\r\n  placeholder: string;\r\n\r\n\r\n  @Input()\r\n  autocomplete: boolean;\r\n\r\n  @Input()\r\n  name: string;\r\n\r\n  userChange: boolean = false;\r\n\r\n  constructor(protected cdr: ChangeDetectorRef, protected ref: ElementRef) {\r\n    super();\r\n  }\r\n\r\n  @Output()\r\n  public onkey: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\r\n\r\n  @Output()\r\n  public onBlur: EventEmitter<AXHtmlEvent<Event>> = new EventEmitter<AXHtmlEvent<Event>>();\r\n\r\n  @Output()\r\n  public onFocus: EventEmitter<AXHtmlEvent<Event>> = new EventEmitter<AXHtmlEvent<Event>>();\r\n\r\n  @Output()\r\n  public onValueChanged: EventEmitter<AXBaseInputChangeEvent> = new EventEmitter<AXBaseInputChangeEvent>();\r\n\r\n  @Output()\r\n  valueChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n  @Input()\r\n  icon: string = '';\r\n\r\n  @Input()\r\n  allowClear: boolean = false;\r\n\r\n  private _value: string;\r\n  @Input()\r\n  public get value(): string {\r\n    return this._value;\r\n  }\r\n  public set value(v: string) {\r\n    if (v !== this._value) {\r\n      const old = this._value;\r\n      this._value = v;\r\n\r\n      this.valueChange.emit(v);\r\n      this.onValueChanged.emit({\r\n        component: this,\r\n        value: v,\r\n        oldValue: old,\r\n        isUserChange: this.userChange\r\n      });\r\n      this.userChange = false;\r\n      this.clearValidationStyle(this.input.nativeElement, v ? false : true);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  focus() {\r\n    this.input.nativeElement.focus();\r\n  }\r\n\r\n  clear() {\r\n    this.userChange = true;\r\n\r\n    this.value = null;\r\n    this.input.nativeElement.value = null;\r\n  }\r\n\r\n  isFocused(): boolean {\r\n    return this.input.nativeElement === document.activeElement;\r\n  }\r\n\r\n  setTextAlign() {\r\n    if (this.textAlign === 'left') {\r\n      return 'text-left';\r\n    }\r\n    if (this.textAlign === 'right') {\r\n      return 'text-right';\r\n    }\r\n  }\r\n\r\n  handleInputBlur(e: Event) {\r\n    this.onBlur.emit({\r\n      component: this,\r\n      htmlElement: this.ref.nativeElement,\r\n      htmlEvent: e\r\n    });\r\n  }\r\n\r\n  handleInputFocus(e: Event) {\r\n    this.onFocus.emit({\r\n      component: this,\r\n      htmlElement: this.ref.nativeElement,\r\n      htmlEvent: e\r\n    });\r\n  }\r\n}\r\n\r\nexport abstract class AXBaseButtonComponent extends AXBaseComponent implements AXBaseClickableComponent, AXBaseSizableComponent {\r\n\r\n  @Input()\r\n  disabled: boolean;\r\n\r\n  @Output()\r\n  click: EventEmitter<AXHtmlEvent<MouseEvent>> = new EventEmitter<AXHtmlEvent<MouseEvent>>();\r\n\r\n  @Input()\r\n  size: AXElementSize;\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n}\r\n\r\nexport abstract class AXBaseDropdownComponent extends AXBaseComponent implements AXBaseInteractiveComponent, AXBaseSizableComponent {\r\n\r\n  @Input()\r\n  disabled: boolean;\r\n\r\n  @Input()\r\n  size: AXElementSize;\r\n\r\n  @Input()\r\n  fitParent: boolean = true;\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  @Input()\r\n  showDropDownButton: boolean = true;\r\n\r\n  abstract close();\r\n  abstract open();\r\n}\r\n"]}
367
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element.class.js","sourceRoot":"ng://@acorex/components/","sources":["lib/base/element.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { Input, Output, EventEmitter, ChangeDetectorRef, ViewChild, ElementRef, ContentChild } from '@angular/core';\r\nimport { AXValidationComponent, AXValidation } from '../validation/validation.component';\r\nimport { AXValidationRuleResult } from '../validation/validation.class';\r\nimport { AXHtmlUtil } from '@acorex/core';\r\nimport { AXEvent, AXHtmlEvent, AXValueEvent } from './events.class';\r\n\r\nexport type AXElementSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\r\n\r\nexport abstract class AXBaseComponent {\r\n  @Input() cssClass: string;\r\n  uid: string = AXHtmlUtil.getUID();\r\n  constructor() {\r\n  }\r\n}\r\n\r\n\r\nexport class AXBaseInputChangeEvent extends AXValueEvent<any> {\r\n  isUserChange?: boolean;\r\n}\r\n\r\nexport interface AXBaseSizableComponent {\r\n  size: AXElementSize;\r\n}\r\n\r\nexport interface AXBaseInteractiveComponent {\r\n  disabled: boolean;\r\n  tabIndex: number;\r\n}\r\n\r\nexport interface AXBaseInputComponent extends AXBaseInteractiveComponent {\r\n  readonly: boolean;\r\n  focus(): void;\r\n}\r\n\r\n\r\nexport interface AXBaseValueComponent<T> extends AXBaseInputComponent {\r\n  onValueChanged?: EventEmitter<AXValueEvent<T>>;\r\n  valueChange?: EventEmitter<T>;\r\n  value: T;\r\n}\r\n\r\nexport interface AXBaseClickableComponent extends AXBaseInteractiveComponent {\r\n  click: EventEmitter<AXHtmlEvent<MouseEvent>>;\r\n}\r\n\r\nexport abstract class AXValidatableComponent extends AXBaseComponent {\r\n\r\n  private __valueField: string = 'value';\r\n  private __nativeElement: HTMLElement;\r\n  private __validation: AXValidation;\r\n\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  protected initValidation(\r\n    elementRef: ElementRef,\r\n    valueField: string,\r\n    validation: AXValidation\r\n  ) {\r\n    this.__nativeElement = elementRef.nativeElement;\r\n    this.__valueField = valueField;\r\n    this.__validation = validation;\r\n    const value = this[this.__valueField]\r\n    if ((!Array.isArray(value) && value) || (Array.isArray(value) && value.length > 0))\r\n      this.validate();\r\n  }\r\n\r\n  get validation() {\r\n    return this.__validation;\r\n  }\r\n\r\n  validate(): Promise<AXValidationRuleResult> {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const result = this.__validation.validate(this[this.__valueField]);\r\n      result.then(c => {\r\n        if (c.result) {\r\n          this.clearValidationStyle(this.__nativeElement);\r\n        }\r\n        else {\r\n          this.applyValidationStyle(this.__nativeElement, c);\r\n        }\r\n      });\r\n      return result;\r\n    }\r\n    else {\r\n      return Promise.resolve({ result: true });\r\n    }\r\n  }\r\n\r\n\r\n  protected clearValidationStyle(element: HTMLElement, clear: boolean = false) {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const formGroup = element.closest('.form-group');\r\n      const formItem = formGroup?.querySelector('.form-item') || element.closest('.form-item') || element.querySelector('.form-item');;\r\n      const label = formGroup?.querySelector('.form-group-label');\r\n      const parent = formItem?.parentElement || element.parentElement;\r\n\r\n      formItem?.classList.remove('success-state');\r\n      formItem?.classList.remove('error-state');\r\n      //formItem?.classList.remove('required-state');\r\n      if (!clear) {\r\n        formItem?.classList.add('success-state');\r\n      }\r\n      // label?.classList.remove('error-text');\r\n      if (parent.querySelector('span.error-text')) {\r\n        parent.removeChild(parent.querySelector('span.error-text'));\r\n      }\r\n    }\r\n  }\r\n\r\n  protected applyValidationStyle(element: HTMLElement, v: AXValidationRuleResult): void {\r\n    if (this.__validation !== undefined && (this.__validation.rules || []).length > 0) {\r\n      const formGroup = element.closest('.form-group');\r\n      const formItem = formGroup?.querySelector('.form-item') || element.closest('.form-item') || element.querySelector('.form-item');\r\n      const label = formGroup?.querySelector('.form-group-label');\r\n      const parent = formItem?.parentElement || element.parentElement;\r\n      formItem?.classList.add('error-state');\r\n      formItem?.classList.remove('success-state');\r\n      if (parent.querySelector('span.error-text')) {\r\n        parent.removeChild(parent.querySelector('span.error-text'));\r\n      }\r\n      if (this.__validation.showMessage) {\r\n        const span = document.createElement('span');\r\n        span.innerText = v.message;\r\n        span.classList.add('ax', 'error-text');\r\n        parent.appendChild(span);\r\n      }\r\n      // label?.classList.add('error-text');\r\n    }\r\n  }\r\n}\r\n\r\n\r\n\r\n\r\nexport abstract class AXBaseTextComponent extends AXValidatableComponent implements AXBaseSizableComponent, AXBaseValueComponent<string> {\r\n\r\n  ngAfterViewInit() {\r\n    if (this.input) {\r\n      this.input.nativeElement.onkeyup = (e) => {\r\n        this.userChange = true;\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n      this.input.nativeElement.onkeydown = (e) => {\r\n        this.userChange = true;\r\n\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n      this.input.nativeElement.onkeypress = (e) => {\r\n        this.userChange = true;\r\n\r\n        this.value = (e.target as any).value;\r\n        this.onkey.emit(e);\r\n      };\r\n    }\r\n  }\r\n\r\n\r\n  ngAfterContentInit(): void {\r\n    this.initValidation(this.ref, 'value', this.validation);\r\n  }\r\n\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  @ViewChild('input', { static: true })\r\n  @ContentChild('input', { static: true })\r\n  input: ElementRef<HTMLInputElement>;\r\n\r\n  @ContentChild(AXValidation, { static: true })\r\n  private _contentValidation: AXValidation;\r\n\r\n  private _validation: AXValidation;\r\n\r\n  @Input()\r\n  public get validation(): AXValidation {\r\n    return this._validation ? this._validation : this._contentValidation;\r\n  }\r\n\r\n  public set validation(v: AXValidation) {\r\n    this._validation = v;\r\n    this.initValidation(this.ref, 'value', v);\r\n  }\r\n\r\n\r\n  @Input()\r\n  disabled: boolean = false;\r\n\r\n  @Input()\r\n  readonly: boolean = false;\r\n\r\n  @Input()\r\n  textAlign: 'right' | 'left' | null = null;\r\n\r\n  @Input()\r\n  size: 'xs' | 'sm' | 'md' | 'lg' | 'xl' = 'md';\r\n\r\n  @Input()\r\n  placeholder: string;\r\n\r\n\r\n  @Input()\r\n  autocomplete: \"on\" | \"off\";\r\n\r\n  @Input()\r\n  name: string;\r\n\r\n  userChange: boolean = false;\r\n\r\n  constructor(protected cdr: ChangeDetectorRef, protected ref: ElementRef) {\r\n    super();\r\n  }\r\n\r\n  @Output()\r\n  public onkey: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\r\n\r\n  @Output()\r\n  public onBlur: EventEmitter<AXHtmlEvent<Event>> = new EventEmitter<AXHtmlEvent<Event>>();\r\n\r\n  @Output()\r\n  public onFocus: EventEmitter<AXHtmlEvent<Event>> = new EventEmitter<AXHtmlEvent<Event>>();\r\n\r\n  @Output()\r\n  public onValueChanged: EventEmitter<AXBaseInputChangeEvent> = new EventEmitter<AXBaseInputChangeEvent>();\r\n\r\n  @Output()\r\n  valueChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n  @Input()\r\n  icon: string = '';\r\n\r\n  @Input()\r\n  allowClear: boolean = false;\r\n\r\n  private _value: string;\r\n  @Input()\r\n  public get value(): string {\r\n    return this._value;\r\n  }\r\n  public set value(v: string) {\r\n    if (v !== this._value) {\r\n      const old = this._value;\r\n      this._value = v;\r\n\r\n      this.valueChange.emit(v);\r\n      this.onValueChanged.emit({\r\n        component: this,\r\n        value: v,\r\n        oldValue: old,\r\n        isUserChange: this.userChange\r\n      });\r\n      this.userChange = false;\r\n      this.clearValidationStyle(this.input.nativeElement, v ? false : true);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  focus() {\r\n    this.input.nativeElement.focus();\r\n  }\r\n\r\n  clear() {\r\n    this.userChange = true;\r\n\r\n    this.value = null;\r\n    this.input.nativeElement.value = null;\r\n  }\r\n\r\n  isFocused(): boolean {\r\n    return this.input.nativeElement === document.activeElement;\r\n  }\r\n\r\n  setTextAlign() {\r\n    if (this.textAlign === 'left') {\r\n      return 'text-left';\r\n    }\r\n    if (this.textAlign === 'right') {\r\n      return 'text-right';\r\n    }\r\n  }\r\n\r\n  handleInputBlur(e: Event) {\r\n    this.onBlur.emit({\r\n      component: this,\r\n      htmlElement: this.ref.nativeElement,\r\n      htmlEvent: e\r\n    });\r\n  }\r\n\r\n  handleInputFocus(e: Event) {\r\n    this.onFocus.emit({\r\n      component: this,\r\n      htmlElement: this.ref.nativeElement,\r\n      htmlEvent: e\r\n    });\r\n  }\r\n}\r\n\r\nexport abstract class AXBaseButtonComponent extends AXBaseComponent implements AXBaseClickableComponent, AXBaseSizableComponent {\r\n\r\n  @Input()\r\n  disabled: boolean;\r\n\r\n  @Output()\r\n  click: EventEmitter<AXHtmlEvent<MouseEvent>> = new EventEmitter<AXHtmlEvent<MouseEvent>>();\r\n\r\n  @Input()\r\n  size: AXElementSize;\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n}\r\n\r\nexport abstract class AXBaseDropdownComponent extends AXBaseComponent implements AXBaseInteractiveComponent, AXBaseSizableComponent {\r\n\r\n  @Input()\r\n  disabled: boolean;\r\n\r\n  @Input()\r\n  size: AXElementSize;\r\n\r\n  @Input()\r\n  fitParent: boolean = true;\r\n\r\n  @Input()\r\n  tabIndex: number = 0;\r\n\r\n  @Input()\r\n  showDropDownButton: boolean = true;\r\n\r\n  abstract close();\r\n  abstract open();\r\n}\r\n"]}
@@ -448,7 +448,7 @@ __decorate([
448
448
  ], AXBaseTextComponent.prototype, "placeholder", void 0);
449
449
  __decorate([
450
450
  Input(),
451
- __metadata("design:type", Boolean)
451
+ __metadata("design:type", String)
452
452
  ], AXBaseTextComponent.prototype, "autocomplete", void 0);
453
453
  __decorate([
454
454
  Input(),