@acorex/components 3.0.55 → 3.0.59

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 (29) hide show
  1. package/acorex-components.metadata.json +1 -1
  2. package/bundles/acorex-components.umd.js +23 -14
  3. package/bundles/acorex-components.umd.js.map +1 -1
  4. package/bundles/acorex-components.umd.min.js +1 -1
  5. package/bundles/acorex-components.umd.min.js.map +1 -1
  6. package/esm2015/lib/base/element.class.js +10 -1
  7. package/esm2015/lib/dropdown/dropdown.component.js +8 -8
  8. package/esm2015/lib/form-group/form-group.component.js +2 -2
  9. package/esm2015/lib/number-box/number-box.component.js +2 -2
  10. package/esm2015/lib/password-box/password-box.component.js +2 -2
  11. package/esm2015/lib/popup/popup.component.js +1 -1
  12. package/esm2015/lib/selectbox/selectbox.component.js +2 -2
  13. package/esm2015/lib/textarea/textarea.component.js +2 -2
  14. package/esm2015/lib/textbox/textbox.component.js +2 -2
  15. package/esm5/lib/base/element.class.js +10 -1
  16. package/esm5/lib/dropdown/dropdown.component.js +8 -8
  17. package/esm5/lib/form-group/form-group.component.js +2 -2
  18. package/esm5/lib/number-box/number-box.component.js +2 -2
  19. package/esm5/lib/password-box/password-box.component.js +2 -2
  20. package/esm5/lib/popup/popup.component.js +1 -1
  21. package/esm5/lib/selectbox/selectbox.component.js +2 -2
  22. package/esm5/lib/textarea/textarea.component.js +2 -2
  23. package/esm5/lib/textbox/textbox.component.js +2 -2
  24. package/fesm2015/acorex-components.js +23 -14
  25. package/fesm2015/acorex-components.js.map +1 -1
  26. package/fesm5/acorex-components.js +23 -14
  27. package/fesm5/acorex-components.js.map +1 -1
  28. package/lib/base/element.class.d.ts +2 -0
  29. package/package.json +1 -1
@@ -261,6 +261,14 @@ var AXBaseTextComponent = /** @class */ (function (_super) {
261
261
  Input(),
262
262
  __metadata("design:type", String)
263
263
  ], AXBaseTextComponent.prototype, "placeholder", void 0);
264
+ __decorate([
265
+ Input(),
266
+ __metadata("design:type", String)
267
+ ], AXBaseTextComponent.prototype, "autocomplete", void 0);
268
+ __decorate([
269
+ Input(),
270
+ __metadata("design:type", String)
271
+ ], AXBaseTextComponent.prototype, "name", void 0);
264
272
  __decorate([
265
273
  Output(),
266
274
  __metadata("design:type", EventEmitter)
@@ -302,6 +310,7 @@ var AXBaseButtonComponent = /** @class */ (function (_super) {
302
310
  function AXBaseButtonComponent() {
303
311
  var _this = _super !== null && _super.apply(this, arguments) || this;
304
312
  _this.click = new EventEmitter();
313
+ _this.size = "md";
305
314
  _this.tabIndex = 0;
306
315
  return _this;
307
316
  }
@@ -356,4 +365,4 @@ var AXBaseDropdownComponent = /** @class */ (function (_super) {
356
365
  return AXBaseDropdownComponent;
357
366
  }(AXBaseComponent));
358
367
  export { AXBaseDropdownComponent };
359
- //# 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  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"]}
368
+ //# 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 = \"md\";\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"]}
@@ -44,13 +44,13 @@ var AXDropdownComponent = /** @class */ (function (_super) {
44
44
  }, 5);
45
45
  };
46
46
  AXDropdownComponent.prototype.ngAfterViewInit = function () {
47
+ // Todo: chech fitparent
48
+ // if (this.fitParent === true) {
49
+ // this.dropdownWidth = this.dropdownEL.nativeElement.offsetWidth;
50
+ // } else {
51
+ // this.dropdownWidth = 260;
52
+ // }
47
53
  var _this = this;
48
- if (this.fitParent === true) {
49
- this.dropdownWidth = this.dropdownEL.nativeElement.offsetWidth;
50
- }
51
- else {
52
- this.dropdownWidth = null;
53
- }
54
54
  setTimeout(function () {
55
55
  if (_this.endButtons && _this.endButtons.nativeElement.childNodes.length !== 0) {
56
56
  _this.content.nativeElement.style.paddingInlineEnd = _this.endButtons.nativeElement.clientWidth + 'px';
@@ -202,7 +202,7 @@ var AXDropdownComponent = /** @class */ (function (_super) {
202
202
  AXDropdownComponent = __decorate([
203
203
  Component({
204
204
  selector: 'ax-drop-down',
205
- template: "<div class=\"ax form-item {{size}}\" [class.readonly]=\"readonly\" [attr.id]=\"uid\" [class.disabled]=\"disabled\" #el>\r\n <div class=\"ax items-wrapper\">\r\n <ng-content select=\"[start]\">\r\n </ng-content>\r\n </div>\r\n <div class=\"content\">\r\n <ng-content select=\"ng-container[header]\">\r\n </ng-content>\r\n </div>\r\n <div class=\"ax items-wrapper\">\r\n <ax-button *ngIf=\"showDropDownButton\" [disabled]=\"disabled || readonly\" [loading]=\"loading\" icon=\"far fa-angle-down icon\"\r\n type=\"light blank\" [size]=\"size\" (click)=\"handleArrowClick($event)\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n <ng-content select=\"[end]\">\r\n </ng-content>\r\n </div>\r\n</div>\r\n\r\n<ng-template #baseTemplate>\r\n <div class=\"ax-dropdown-container-bordered\" [ngStyle]=\"{'width': dropdownWidth ? dropdownWidth + 'px' : 'unset'}\">\r\n <ng-content select=\"ng-container[panel]\">\r\n </ng-content>\r\n </div>\r\n</ng-template>",
205
+ template: "<div class=\"ax form-item {{size}}\" [class.readonly]=\"readonly\" [attr.id]=\"uid\" [class.disabled]=\"disabled\" #el>\r\n <div class=\"ax items-wrapper\">\r\n <ng-content select=\"[start]\">\r\n </ng-content>\r\n </div>\r\n <div class=\"content\">\r\n <ng-content select=\"ng-container[header]\">\r\n </ng-content>\r\n </div>\r\n <div class=\"ax items-wrapper\">\r\n <ax-button *ngIf=\"showDropDownButton\" [disabled]=\"disabled || readonly\" [loading]=\"loading\" icon=\"far fa-angle-down icon\"\r\n type=\"light blank\" [size]=\"size\" (click)=\"handleArrowClick($event)\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n <ng-content select=\"[end]\">\r\n </ng-content>\r\n </div>\r\n</div>\r\n\r\n<ng-template #baseTemplate>\r\n <!-- [ngStyle]=\"{'width': dropdownWidth ? dropdownWidth + 'px' : 'unset'}\" -->\r\n <div class=\"ax-dropdown-container-bordered\" style=\"width: 260px;\">\r\n <ng-content select=\"ng-container[panel]\">\r\n </ng-content>\r\n </div>\r\n</ng-template>",
206
206
  encapsulation: ViewEncapsulation.None,
207
207
  changeDetection: ChangeDetectionStrategy.OnPush,
208
208
  host: { style: 'display:contents;' },
@@ -216,4 +216,4 @@ var AXDropdownComponent = /** @class */ (function (_super) {
216
216
  return AXDropdownComponent;
217
217
  }(AXBaseDropdownComponent));
218
218
  export { AXDropdownComponent };
219
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"ng://@acorex/components/","sources":["lib/dropdown/dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ViewChild,\r\n  Input,\r\n  ElementRef,\r\n  AfterViewInit,\r\n  HostListener,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  ViewContainerRef,\r\n  TemplateRef,\r\n  OnDestroy,\r\n  DebugElement\r\n} from '@angular/core';\r\nimport { AXBaseDropdownComponent } from '../base/element.class';\r\nimport { AXHtmlEvent } from '../base/events.class';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { AXConfig } from '@acorex/core';\r\n\r\n@Component({\r\n  selector: 'ax-drop-down',\r\n  templateUrl: './dropdown.component.html',\r\n  styleUrls: ['./dropdown.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  host: { style: 'display:contents;' }\r\n})\r\nexport class AXDropdownComponent extends AXBaseDropdownComponent implements AfterViewInit, OnDestroy {\r\n  @ViewChild('baseTemplate') baseTemplate: TemplateRef<any>;\r\n  @ViewChild('content', { static: false }) content: ElementRef<HTMLDivElement>;\r\n  @ViewChild('endButtons', { static: false }) endButtons: ElementRef<HTMLDivElement>;\r\n  @ViewChild('el', { static: true }) dropdownEL: ElementRef<HTMLDivElement>;\r\n\r\n  @Input()\r\n  rtl: boolean = AXConfig.get('layout.rtl');\r\n\r\n  @Input()\r\n  readonly: boolean = false;\r\n\r\n  @Input()\r\n  loading: boolean = false;\r\n\r\n  @Output()\r\n  dropdownToggle: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  onButtonClick: EventEmitter<AXHtmlEvent<MouseEvent>> = new EventEmitter<AXHtmlEvent<MouseEvent>>();\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  onKeydownHandler(e: KeyboardEvent) {\r\n    if (!this.disabled && e.key === 'Enter' && e.type === 'keydown') {\r\n      if (!this.readonly) {\r\n        this.toggle();\r\n        // this.dropdownToggle.emit({ mode: 'enter' });\r\n      }\r\n    }\r\n    if (e.key === 'Escape') {\r\n      if (this.isOpen) {\r\n        this.close();\r\n        e.stopPropagation();\r\n      }\r\n    }\r\n  }\r\n\r\n  dropdownWidth: number;\r\n\r\n  private overlayRef: OverlayRef;\r\n  private templatePortal: TemplatePortal;\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private ref: ElementRef<HTMLDivElement>,\r\n    private overlay: Overlay,\r\n    private viewContainerRef: ViewContainerRef\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.rtl == null) {\r\n      this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';\r\n    }\r\n    setTimeout(() => {\r\n      this.ref.nativeElement.classList.add(this.rtl ? 'rtl' : 'ltr');\r\n      this.dropdownEL.nativeElement.classList.add(this.rtl ? 'rtl' : 'ltr');\r\n    }, 5);\r\n  }\r\n  ngAfterViewInit(): void {\r\n    if (this.fitParent === true) {\r\n      this.dropdownWidth = this.dropdownEL.nativeElement.offsetWidth;\r\n    } else {\r\n      this.dropdownWidth = null;\r\n    }\r\n\r\n    setTimeout(() => {\r\n      if (this.endButtons && this.endButtons.nativeElement.childNodes.length !== 0) {\r\n        this.content.nativeElement.style.paddingInlineEnd = this.endButtons.nativeElement.clientWidth + 'px';\r\n      }\r\n    }, 5);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.overlayRef?.detach();\r\n    this.overlayRef?.dispose();\r\n  }\r\n\r\n  handleArrowClick(e: AXHtmlEvent<MouseEvent>) {\r\n    setTimeout(() => {\r\n      this.toggle();\r\n    }, 0);\r\n  }\r\n\r\n  toggle() {\r\n    if (this.disabled !== true) {\r\n      this.isOpen ? this.close() : this.open();\r\n    }\r\n  }\r\n\r\n  close() {\r\n    if (!this.isOpen) {\r\n      return;\r\n    }\r\n    this.overlayRef?.detach();\r\n    this.dropdownToggle.emit({ mode: 'close' });\r\n  }\r\n\r\n  open() {\r\n    if (this.isOpen) {\r\n      return;\r\n    }\r\n    this.ensureOverlayCreated();\r\n    this.overlayRef.attach(this.templatePortal);\r\n    this.dropdownToggle.emit({ mode: 'open' });\r\n  }\r\n\r\n  private ensureOverlayCreated() {\r\n    if (!this.overlayRef) {\r\n      const targetEl = document.querySelector<HTMLElement>('#' + this.uid);\r\n      const positionStrategy = this.overlay\r\n        .position()\r\n        .flexibleConnectedTo(targetEl)\r\n        .withPositions([\r\n          {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top'\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom'\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'bottom',\r\n            overlayX: 'end',\r\n            overlayY: 'top'\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'bottom',\r\n            overlayX: 'end',\r\n            overlayY: 'bottom'\r\n          }\r\n        ])\r\n        .withPush(false);\r\n      this.overlayRef = this.overlay.create({\r\n        positionStrategy,\r\n\r\n        //width: this.dropdownEL.nativeElement.clientWidth,\r\n        scrollStrategy: this.overlay.scrollStrategies.reposition({\r\n          autoClose: true\r\n        }),\r\n        hasBackdrop: true,\r\n        backdropClass: 'cdk-overlay-transparent-backdrop'\r\n      });\r\n      this.overlayRef.setDirection(this.rtl ? 'rtl' : 'ltr');\r\n      this.overlayRef.backdropClick().subscribe(() => this.close());\r\n    }\r\n    if (!this.templatePortal) {\r\n      this.templatePortal = new TemplatePortal(this.baseTemplate, this.viewContainerRef);\r\n    }\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return this.overlayRef ? this.overlayRef.hasAttached() : false;\r\n  }\r\n\r\n  updatePosition(): void {\r\n    this.overlayRef?.updatePosition();\r\n  }\r\n  focus() {}\r\n}\r\n"]}
219
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"ng://@acorex/components/","sources":["lib/dropdown/dropdown.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ViewChild,\r\n  Input,\r\n  ElementRef,\r\n  AfterViewInit,\r\n  HostListener,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  ViewContainerRef,\r\n  TemplateRef,\r\n  OnDestroy,\r\n  DebugElement\r\n} from '@angular/core';\r\nimport { AXBaseDropdownComponent } from '../base/element.class';\r\nimport { AXHtmlEvent } from '../base/events.class';\r\nimport { Overlay, OverlayRef } from '@angular/cdk/overlay';\r\nimport { TemplatePortal } from '@angular/cdk/portal';\r\nimport { AXConfig } from '@acorex/core';\r\n\r\n@Component({\r\n  selector: 'ax-drop-down',\r\n  templateUrl: './dropdown.component.html',\r\n  styleUrls: ['./dropdown.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  host: { style: 'display:contents;' }\r\n})\r\nexport class AXDropdownComponent extends AXBaseDropdownComponent implements AfterViewInit, OnDestroy {\r\n  @ViewChild('baseTemplate') baseTemplate: TemplateRef<any>;\r\n  @ViewChild('content', { static: false }) content: ElementRef<HTMLDivElement>;\r\n  @ViewChild('endButtons', { static: false }) endButtons: ElementRef<HTMLDivElement>;\r\n  @ViewChild('el', { static: true }) dropdownEL: ElementRef<HTMLDivElement>;\r\n\r\n  @Input()\r\n  rtl: boolean = AXConfig.get('layout.rtl');\r\n\r\n  @Input()\r\n  readonly: boolean = false;\r\n\r\n  @Input()\r\n  loading: boolean = false;\r\n\r\n  @Output()\r\n  dropdownToggle: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  @Output()\r\n  onButtonClick: EventEmitter<AXHtmlEvent<MouseEvent>> = new EventEmitter<AXHtmlEvent<MouseEvent>>();\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  onKeydownHandler(e: KeyboardEvent) {\r\n    if (!this.disabled && e.key === 'Enter' && e.type === 'keydown') {\r\n      if (!this.readonly) {\r\n        this.toggle();\r\n        // this.dropdownToggle.emit({ mode: 'enter' });\r\n      }\r\n    }\r\n    if (e.key === 'Escape') {\r\n      if (this.isOpen) {\r\n        this.close();\r\n        e.stopPropagation();\r\n      }\r\n    }\r\n  }\r\n\r\n  dropdownWidth: number;\r\n\r\n  private overlayRef: OverlayRef;\r\n  private templatePortal: TemplatePortal;\r\n\r\n  constructor(\r\n    private cdr: ChangeDetectorRef,\r\n    private ref: ElementRef<HTMLDivElement>,\r\n    private overlay: Overlay,\r\n    private viewContainerRef: ViewContainerRef\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    if (this.rtl == null) {\r\n      this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';\r\n    }\r\n    setTimeout(() => {\r\n      this.ref.nativeElement.classList.add(this.rtl ? 'rtl' : 'ltr');\r\n      this.dropdownEL.nativeElement.classList.add(this.rtl ? 'rtl' : 'ltr');\r\n    }, 5);\r\n  }\r\n  ngAfterViewInit(): void {\r\n    // Todo: chech fitparent\r\n    // if (this.fitParent === true) {\r\n    //   this.dropdownWidth = this.dropdownEL.nativeElement.offsetWidth;\r\n    // } else {\r\n    //   this.dropdownWidth = 260;\r\n    // }\r\n\r\n    setTimeout(() => {\r\n      if (this.endButtons && this.endButtons.nativeElement.childNodes.length !== 0) {\r\n        this.content.nativeElement.style.paddingInlineEnd = this.endButtons.nativeElement.clientWidth + 'px';\r\n      }\r\n    }, 5);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.overlayRef?.detach();\r\n    this.overlayRef?.dispose();\r\n  }\r\n\r\n  handleArrowClick(e: AXHtmlEvent<MouseEvent>) {\r\n    setTimeout(() => {\r\n      this.toggle();\r\n    }, 0);\r\n  }\r\n\r\n  toggle() {\r\n    if (this.disabled !== true) {\r\n      this.isOpen ? this.close() : this.open();\r\n    }\r\n  }\r\n\r\n  close() {\r\n    if (!this.isOpen) {\r\n      return;\r\n    }\r\n    this.overlayRef?.detach();\r\n    this.dropdownToggle.emit({ mode: 'close' });\r\n  }\r\n\r\n  open() {\r\n    if (this.isOpen) {\r\n      return;\r\n    }\r\n    this.ensureOverlayCreated();\r\n    this.overlayRef.attach(this.templatePortal);\r\n    this.dropdownToggle.emit({ mode: 'open' });\r\n  }\r\n\r\n  private ensureOverlayCreated() {\r\n    if (!this.overlayRef) {\r\n      const targetEl = document.querySelector<HTMLElement>('#' + this.uid);\r\n      const positionStrategy = this.overlay\r\n        .position()\r\n        .flexibleConnectedTo(targetEl)\r\n        .withPositions([\r\n          {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'top'\r\n          },\r\n          {\r\n            originX: 'start',\r\n            originY: 'bottom',\r\n            overlayX: 'start',\r\n            overlayY: 'bottom'\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'bottom',\r\n            overlayX: 'end',\r\n            overlayY: 'top'\r\n          },\r\n          {\r\n            originX: 'end',\r\n            originY: 'bottom',\r\n            overlayX: 'end',\r\n            overlayY: 'bottom'\r\n          }\r\n        ])\r\n        .withPush(false);\r\n      this.overlayRef = this.overlay.create({\r\n        positionStrategy,\r\n\r\n        //width: this.dropdownEL.nativeElement.clientWidth,\r\n        scrollStrategy: this.overlay.scrollStrategies.reposition({\r\n          autoClose: true\r\n        }),\r\n        hasBackdrop: true,\r\n        backdropClass: 'cdk-overlay-transparent-backdrop'\r\n      });\r\n      this.overlayRef.setDirection(this.rtl ? 'rtl' : 'ltr');\r\n      this.overlayRef.backdropClick().subscribe(() => this.close());\r\n    }\r\n    if (!this.templatePortal) {\r\n      this.templatePortal = new TemplatePortal(this.baseTemplate, this.viewContainerRef);\r\n    }\r\n  }\r\n\r\n  get isOpen(): boolean {\r\n    return this.overlayRef ? this.overlayRef.hasAttached() : false;\r\n  }\r\n\r\n  updatePosition(): void {\r\n    this.overlayRef?.updatePosition();\r\n  }\r\n  focus() {}\r\n}\r\n"]}
@@ -38,11 +38,11 @@ var AXFormGroupComponent = /** @class */ (function (_super) {
38
38
  template: "<div class=\"ax form-group {{size}}\">\r\n <ng-content select=\"ax-label\"></ng-content>\r\n <div #div class=\"ax form-item\" [ngClass]=\"{'required-state': required}\">\r\n <div class=\"ax buttons start-buttons\" #startButtons>\r\n <ng-content select=\"ax-button[start]\"></ng-content>\r\n </div>\r\n <div class=\"content\" #content>\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"ax buttons end-buttons\" #endButtons>\r\n <ng-content select=\"ax-button[end]\"></ng-content>\r\n <ng-content select=\"ax-button\"></ng-content>\r\n </div>\r\n </div>\r\n</div>",
39
39
  encapsulation: ViewEncapsulation.None,
40
40
  changeDetection: ChangeDetectionStrategy.OnPush,
41
- host: { style: 'width: 100%' }
41
+ host: { style: 'width: 100%; display:contents;' }
42
42
  }),
43
43
  __metadata("design:paramtypes", [ChangeDetectorRef])
44
44
  ], AXFormGroupComponent);
45
45
  return AXFormGroupComponent;
46
46
  }(AXBaseComponent));
47
47
  export { AXFormGroupComponent };
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1ncm91cC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYWNvcmV4L2NvbXBvbmVudHMvIiwic291cmNlcyI6WyJsaWIvZm9ybS1ncm91cC9mb3JtLWdyb3VwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQzVELGlCQUFpQixFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUN2RCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsZUFBZSxFQUF5QyxzQkFBc0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBU3ZIO0lBQTBDLHdDQUFlO0lBWXZELDhCQUFvQixHQUFzQjtRQUExQyxZQUNFLGlCQUFPLFNBQ1I7UUFGbUIsU0FBRyxHQUFILEdBQUcsQ0FBbUI7UUFWMUMsVUFBSSxHQUFrQixJQUFJLENBQUM7UUFRM0IsY0FBUSxHQUFZLEtBQUssQ0FBQzs7SUFJMUIsQ0FBQztJQUdELDhDQUFlLEdBQWY7O1FBQ0UsSUFBSSxDQUFDLFFBQVEscUJBQUcsSUFBSSxDQUFDLFNBQVMsMENBQUUsVUFBVSwwQ0FBRSxLQUFLLDBDQUFFLElBQUksQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLENBQUMsQ0FBQyxJQUFJLEtBQUssVUFBVSxFQUFyQixDQUFxQixDQUFDLENBQUM7UUFDcEYsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQTtTQUV2RDtJQUNILENBQUM7O2dCQVh3QixpQkFBaUI7O0lBVjFDO1FBREMsS0FBSyxFQUFFOztzREFDbUI7SUFHM0I7UUFEQyxTQUFTLENBQUMsS0FBSyxDQUFDO2tDQUNaLFVBQVU7cURBQUE7SUFHZjtRQURDLFlBQVksQ0FBQyxzQkFBc0IsQ0FBQztrQ0FDbEIsc0JBQXNCOzJEQUFDO0lBUi9CLG9CQUFvQjtRQVBoQyxTQUFTLENBQUM7WUFDVCxRQUFRLEVBQUUsZUFBZTtZQUN6QixvcUJBQTBDO1lBQzFDLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO1lBQ3JDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO1lBQy9DLElBQUksRUFBRSxFQUFFLEtBQUssRUFBQyxhQUFhLEVBQUU7U0FDOUIsQ0FBQzt5Q0FheUIsaUJBQWlCO09BWi9CLG9CQUFvQixDQXlCaEM7SUFBRCwyQkFBQztDQUFBLEFBekJELENBQTBDLGVBQWUsR0F5QnhEO1NBekJZLG9CQUFvQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LCBJbnB1dCwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIFZpZXdFbmNhcHN1bGF0aW9uLCBDb250ZW50Q2hpbGQsIFZpZXdDaGlsZCwgRWxlbWVudFJlZlxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBWEJhc2VDb21wb25lbnQsIEFYQmFzZVNpemFibGVDb21wb25lbnQsIEFYRWxlbWVudFNpemUsIEFYVmFsaWRhdGFibGVDb21wb25lbnQgfSBmcm9tICcuLi9iYXNlL2VsZW1lbnQuY2xhc3MnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdheC1mb3JtLWdyb3VwJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZm9ybS1ncm91cC5jb21wb25lbnQuaHRtbCcsXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcclxuICBob3N0OiB7IHN0eWxlOid3aWR0aDogMTAwJScgfVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhGb3JtR3JvdXBDb21wb25lbnQgZXh0ZW5kcyBBWEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBBWEJhc2VTaXphYmxlQ29tcG9uZW50IHtcclxuICBASW5wdXQoKVxyXG4gIHNpemU6IEFYRWxlbWVudFNpemUgPSAnbWQnO1xyXG5cclxuICBAVmlld0NoaWxkKCdkaXYnKVxyXG4gIGRpdjogRWxlbWVudFJlZlxyXG5cclxuICBAQ29udGVudENoaWxkKEFYVmFsaWRhdGFibGVDb21wb25lbnQpXHJcbiAgcHJpdmF0ZSBjb21wb25lbnQ6IEFYVmFsaWRhdGFibGVDb21wb25lbnQ7XHJcblxyXG4gIHJlcXVpcmVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgc3VwZXIoKTtcclxuICB9XHJcblxyXG5cclxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLnJlcXVpcmVkID0gdGhpcy5jb21wb25lbnQ/LnZhbGlkYXRpb24/LnJ1bGVzPy5zb21lKGMgPT4gYy50eXBlID09PSAncmVxdWlyZWQnKTtcclxuICAgIGlmICh0aGlzLnJlcXVpcmVkKSB7XHJcbiAgICAgIHRoaXMuZGl2Lm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZCgncmVxdWlyZWQtc3RhdGUnKVxyXG5cclxuICAgIH1cclxuICB9XHJcblxyXG59XHJcbiJdfQ==
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1ncm91cC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AYWNvcmV4L2NvbXBvbmVudHMvIiwic291cmNlcyI6WyJsaWIvZm9ybS1ncm91cC9mb3JtLWdyb3VwLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUNMLFNBQVMsRUFBRSxLQUFLLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQzVELGlCQUFpQixFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUN2RCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsZUFBZSxFQUF5QyxzQkFBc0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBU3ZIO0lBQTBDLHdDQUFlO0lBWXZELDhCQUFvQixHQUFzQjtRQUExQyxZQUNFLGlCQUFPLFNBQ1I7UUFGbUIsU0FBRyxHQUFILEdBQUcsQ0FBbUI7UUFWMUMsVUFBSSxHQUFrQixJQUFJLENBQUM7UUFRM0IsY0FBUSxHQUFZLEtBQUssQ0FBQzs7SUFJMUIsQ0FBQztJQUdELDhDQUFlLEdBQWY7O1FBQ0UsSUFBSSxDQUFDLFFBQVEscUJBQUcsSUFBSSxDQUFDLFNBQVMsMENBQUUsVUFBVSwwQ0FBRSxLQUFLLDBDQUFFLElBQUksQ0FBQyxVQUFBLENBQUMsSUFBSSxPQUFBLENBQUMsQ0FBQyxJQUFJLEtBQUssVUFBVSxFQUFyQixDQUFxQixDQUFDLENBQUM7UUFDcEYsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsQ0FBQTtTQUV2RDtJQUNILENBQUM7O2dCQVh3QixpQkFBaUI7O0lBVjFDO1FBREMsS0FBSyxFQUFFOztzREFDbUI7SUFHM0I7UUFEQyxTQUFTLENBQUMsS0FBSyxDQUFDO2tDQUNaLFVBQVU7cURBQUE7SUFHZjtRQURDLFlBQVksQ0FBQyxzQkFBc0IsQ0FBQztrQ0FDbEIsc0JBQXNCOzJEQUFDO0lBUi9CLG9CQUFvQjtRQVBoQyxTQUFTLENBQUM7WUFDVCxRQUFRLEVBQUUsZUFBZTtZQUN6QixvcUJBQTBDO1lBQzFDLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO1lBQ3JDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO1lBQy9DLElBQUksRUFBRSxFQUFFLEtBQUssRUFBQyxnQ0FBZ0MsRUFBRTtTQUNqRCxDQUFDO3lDQWF5QixpQkFBaUI7T0FaL0Isb0JBQW9CLENBeUJoQztJQUFELDJCQUFDO0NBQUEsQUF6QkQsQ0FBMEMsZUFBZSxHQXlCeEQ7U0F6Qlksb0JBQW9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDb21wb25lbnQsIElucHV0LCBDaGFuZ2VEZXRlY3RvclJlZiwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXHJcbiAgVmlld0VuY2Fwc3VsYXRpb24sIENvbnRlbnRDaGlsZCwgVmlld0NoaWxkLCBFbGVtZW50UmVmXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFYQmFzZUNvbXBvbmVudCwgQVhCYXNlU2l6YWJsZUNvbXBvbmVudCwgQVhFbGVtZW50U2l6ZSwgQVhWYWxpZGF0YWJsZUNvbXBvbmVudCB9IGZyb20gJy4uL2Jhc2UvZWxlbWVudC5jbGFzcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2F4LWZvcm0tZ3JvdXAnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9mb3JtLWdyb3VwLmNvbXBvbmVudC5odG1sJyxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gIGhvc3Q6IHsgc3R5bGU6J3dpZHRoOiAxMDAlOyBkaXNwbGF5OmNvbnRlbnRzOycgfVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhGb3JtR3JvdXBDb21wb25lbnQgZXh0ZW5kcyBBWEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBBWEJhc2VTaXphYmxlQ29tcG9uZW50IHtcclxuICBASW5wdXQoKVxyXG4gIHNpemU6IEFYRWxlbWVudFNpemUgPSAnbWQnO1xyXG5cclxuICBAVmlld0NoaWxkKCdkaXYnKVxyXG4gIGRpdjogRWxlbWVudFJlZlxyXG5cclxuICBAQ29udGVudENoaWxkKEFYVmFsaWRhdGFibGVDb21wb25lbnQpXHJcbiAgcHJpdmF0ZSBjb21wb25lbnQ6IEFYVmFsaWRhdGFibGVDb21wb25lbnQ7XHJcblxyXG4gIHJlcXVpcmVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZikge1xyXG4gICAgc3VwZXIoKTtcclxuICB9XHJcblxyXG5cclxuICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLnJlcXVpcmVkID0gdGhpcy5jb21wb25lbnQ/LnZhbGlkYXRpb24/LnJ1bGVzPy5zb21lKGMgPT4gYy50eXBlID09PSAncmVxdWlyZWQnKTtcclxuICAgIGlmICh0aGlzLnJlcXVpcmVkKSB7XHJcbiAgICAgIHRoaXMuZGl2Lm5hdGl2ZUVsZW1lbnQuY2xhc3NMaXN0LmFkZCgncmVxdWlyZWQtc3RhdGUnKVxyXG5cclxuICAgIH1cclxuICB9XHJcblxyXG59XHJcbiJdfQ==