@alauda/ui 6.4.1-beta.8 → 6.4.2-beta
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.
- package/autocomplete/autocomplete.directive.d.ts +1 -1
- package/esm2020/accordion/accordion-item/accordion-item.component.mjs +2 -2
- package/esm2020/anchor/anchor.component.mjs +2 -3
- package/esm2020/anchor/anchor.directive.mjs +2 -3
- package/esm2020/autocomplete/autocomplete.component.mjs +9 -6
- package/esm2020/autocomplete/autocomplete.directive.mjs +2 -3
- package/esm2020/autocomplete/suggestion/suggestion.component.mjs +5 -6
- package/esm2020/autocomplete/suggestion-group/suggestion-group.component.mjs +4 -4
- package/esm2020/back-top/back-top.component.mjs +2 -3
- package/esm2020/breadcrumb/breadcrumb-item.component.mjs +2 -2
- package/esm2020/checkbox/checkbox.component.mjs +2 -3
- package/esm2020/dialog/confirm-dialog/confirm-dialog.component.mjs +3 -4
- package/esm2020/drawer/component/drawer.component.mjs +2 -3
- package/esm2020/drawer/drawer.service.mjs +2 -3
- package/esm2020/dropdown/dropdown.directive.mjs +2 -2
- package/esm2020/form/form-item/form-item.component.mjs +4 -4
- package/esm2020/form/form.directive.mjs +2 -3
- package/esm2020/icon/icon-register.service.mjs +8 -5
- package/esm2020/input/autosize.directive.mjs +2 -3
- package/esm2020/radio/base-radio.mjs +2 -3
- package/esm2020/radio/radio-button/radio-button.component.mjs +2 -2
- package/esm2020/radio/radio-group/radio-group.component.mjs +2 -3
- package/esm2020/scrolling/fixed-size-table-virtual-scroll-strategy.mjs +2 -3
- package/esm2020/scrolling/fixed-size-table-virtual-scroll.directive.mjs +2 -3
- package/esm2020/select/base-select.mjs +7 -8
- package/esm2020/select/multi-select/multi-select.component.mjs +5 -6
- package/esm2020/select/option/option.component.mjs +5 -6
- package/esm2020/select/option-group/option-group.component.mjs +4 -4
- package/esm2020/select/select.component.mjs +5 -6
- package/esm2020/steps/steps.component.mjs +2 -3
- package/esm2020/table/table-scroll.directive.mjs +2 -3
- package/esm2020/table/table.component.mjs +2 -2
- package/esm2020/table-of-contents/toc-container.directive.mjs +2 -3
- package/esm2020/tabs/tab-context.service.mjs +2 -3
- package/esm2020/tabs/tab-header.component.mjs +2 -3
- package/esm2020/theme/theme.pipe.mjs +2 -3
- package/esm2020/theme/theme.service.mjs +2 -3
- package/esm2020/tooltip/base-tooltip.mjs +2 -3
- package/esm2020/tooltip/tooltip.component.mjs +7 -8
- package/esm2020/tree-select/tree-select.component.mjs +6 -6
- package/esm2020/utils/index.mjs +2 -1
- package/esm2020/utils/operators.mjs +12 -0
- package/esm2020/utils/watch-content-exist.mjs +4 -3
- package/fesm2015/alauda-ui.mjs +71 -55
- package/fesm2015/alauda-ui.mjs.map +1 -1
- package/fesm2020/alauda-ui.mjs +71 -55
- package/fesm2020/alauda-ui.mjs.map +1 -1
- package/package.json +1 -1
- package/theme/_pattern.scss +1 -0
- package/utils/index.d.ts +1 -0
- package/utils/operators.d.ts +8 -0
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Inject, Input, Optional, ViewChild, ViewEncapsulation, forwardRef, } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { BehaviorSubject, Subject, combineLatest } from 'rxjs';
|
|
4
|
-
import { map, takeUntil } from 'rxjs/operators';
|
|
3
|
+
import { BehaviorSubject, Subject, combineLatest, map, takeUntil } from 'rxjs';
|
|
5
4
|
import { CommonFormControl } from '../form';
|
|
6
5
|
import { CheckboxGroupComponent } from './checkbox-group/checkbox-group.component';
|
|
7
6
|
import * as i0 from "@angular/core";
|
|
@@ -109,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
109
108
|
type: ViewChild,
|
|
110
109
|
args: ['elRef', { static: true }]
|
|
111
110
|
}] } });
|
|
112
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../src/checkbox/checkbox.component.ts","../../../src/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor } from '@angular/cdk/a11y';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnDestroy,\n  Optional,\n  ViewChild,\n  ViewEncapsulation,\n  forwardRef,\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { BehaviorSubject, Subject, combineLatest, map, takeUntil } from 'rxjs';\n\nimport { CommonFormControl } from '../form';\n\nimport { CheckboxGroupComponent } from './checkbox-group/checkbox-group.component';\n\nlet uniqueId = 0;\n@Component({\n  selector: 'aui-checkbox',\n  templateUrl: './checkbox.component.html',\n  styleUrls: ['./checkbox.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => CheckboxComponent),\n      multi: true,\n    },\n  ],\n})\nexport class CheckboxComponent<T>\n  extends CommonFormControl<boolean>\n  implements AfterViewInit, OnDestroy\n{\n  id = `aui-checkbox-${uniqueId++}`;\n\n  @Input()\n  name = '';\n\n  @Input()\n  type = 'label';\n\n  @Input()\n  get label() {\n    return this._label;\n  }\n\n  set label(val) {\n    this._label = val;\n    this.label$$.next(val);\n  }\n\n  @Input()\n  get indeterminate(): boolean {\n    return this._indeterminate;\n  }\n\n  set indeterminate(value: boolean) {\n    this._indeterminate = value;\n  }\n\n  @ViewChild('elRef', { static: true })\n  elRef: ElementRef;\n\n  private readonly checkboxGroup: CheckboxGroupComponent<T>;\n  private _label: T;\n  private readonly label$$ = new BehaviorSubject(this.label);\n  private _indeterminate = false;\n  private readonly destroy$$ = new Subject<void>();\n\n  constructor(\n    cdr: ChangeDetectorRef,\n    @Optional()\n    @Inject(forwardRef(() => CheckboxGroupComponent))\n    checkboxGroup: CheckboxGroupComponent<T>,\n    private readonly focusMonitor: FocusMonitor,\n  ) {\n    super(cdr);\n    this.checkboxGroup = checkboxGroup;\n    if (this.checkboxGroup) {\n      combineLatest([this.checkboxGroup.model$, this.label$$])\n        .pipe(\n          takeUntil(this.destroy$$),\n          map(([values, label]) => {\n            if (this.checkboxGroup.trackFn) {\n              return values?.some(\n                v =>\n                  this.checkboxGroup.trackFn(v) ===\n                  this.checkboxGroup.trackFn(label),\n              );\n            }\n            return values?.includes(label);\n          }),\n        )\n        .subscribe(checked => {\n          this.writeValue(!!checked);\n        });\n    }\n  }\n\n  ngAfterViewInit() {\n    this.focusMonitor.monitor(this.elRef.nativeElement, true);\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.focusMonitor.stopMonitoring(this.elRef.nativeElement);\n  }\n\n  onClick() {\n    if (this.disabled) {\n      return;\n    }\n    if (this.indeterminate) {\n      this._indeterminate = false;\n    }\n    this.emitValue(!this.model);\n    if (this.checkboxGroup) {\n      this.checkboxGroup.onCheckboxChange(this);\n    }\n  }\n\n  onBlur() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n    if (this.checkboxGroup) {\n      this.checkboxGroup.onCheckboxBlur();\n    }\n  }\n}\n","<div\n  #elRef\n  class=\"aui-checkbox\"\n  [class.isDisabled]=\"disabled\"\n  [class.isChecked]=\"model\"\n  [class.isIndeterminate]=\"indeterminate\"\n  [class.isTag]=\"type === 'tag'\"\n>\n  <input\n    [name]=\"name\"\n    [id]=\"id\"\n    class=\"aui-checkbox__input\"\n    type=\"checkbox\"\n    [checked]=\"model\"\n    [disabled]=\"disabled\"\n    (click)=\"onClick()\"\n    (blur)=\"onBlur()\"\n  />\n  <label\n    class=\"aui-checkbox__label\"\n    [for]=\"id\"\n  >\n    <i class=\"aui-checkbox__pointer\">\n      <aui-icon\n        [icon]=\"indeterminate ? 'square_s' : 'check_s'\"\n        [hidden]=\"!model && !indeterminate\"\n      ></aui-icon>\n    </i>\n    <span class=\"aui-checkbox__content\"><ng-content></ng-content></span>\n  </label>\n</div>\n"]}
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ViewEncapsulation, } from '@angular/core';
|
|
2
|
-
import { Observable } from 'rxjs';
|
|
3
|
-
import { first } from 'rxjs/operators';
|
|
2
|
+
import { firstValueFrom, Observable } from 'rxjs';
|
|
4
3
|
import { buildBem } from '../../utils';
|
|
5
4
|
import { ConfirmType, } from '../dialog.types';
|
|
6
5
|
import { ConfirmDialogConfig } from './confirm-dialog-config';
|
|
@@ -70,7 +69,7 @@ export class ConfirmDialogComponent {
|
|
|
70
69
|
}
|
|
71
70
|
const result = beforeAction();
|
|
72
71
|
if (result instanceof Observable) {
|
|
73
|
-
return result
|
|
72
|
+
return firstValueFrom(result);
|
|
74
73
|
}
|
|
75
74
|
return result;
|
|
76
75
|
}
|
|
@@ -81,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
81
80
|
type: Component,
|
|
82
81
|
args: [{ selector: 'aui-confirm-dialog', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, preserveWhitespaces: false, template: "<div [class]=\"bem.block()\">\n <div [class]=\"bem.element('title')\">\n <span [class]=\"bem.element('icon', config.confirmType + '')\">\n <aui-icon\n [icon]=\"iconMap(config.confirmType)\"\n [background]=\"\n iconMap(config.confirmType).endsWith('_triangle_s')\n ? 'triangle'\n : 'circle'\n \"\n ></aui-icon>\n </span>\n <span>{{ config.title }}</span>\n </div>\n <div [class]=\"bem.element('content')\">{{ config.content }}</div>\n <div [class]=\"bem.element('button-wrapper')\">\n <div>\n <button\n [aui-button]=\"config.confirmType\"\n [ngClass]=\"bem.element('confirm-button')\"\n [loading]=\"waitConfirm\"\n [disabled]=\"waitConfirm || waitCancel\"\n (click)=\"confirm()\"\n >\n {{ config.confirmText }}\n </button>\n <button\n *ngIf=\"config.cancelButton\"\n aui-button\n [ngClass]=\"bem.element('cancel-button')\"\n [loading]=\"waitCancel\"\n [disabled]=\"waitConfirm || waitCancel\"\n (click)=\"cancel()\"\n >\n {{ config.cancelText }}\n </button>\n </div>\n </div>\n</div>\n", styles: [".aui-confirm-dialog{margin:auto;padding:32px 32px 20px;border-radius:var(--aui-border-radius-m);min-width:400px;max-width:600px;background-color:rgb(var(--aui-color-n-10))}.aui-confirm-dialog__title{margin-bottom:var(--aui-spacing-m);font-size:var(--aui-font-size-xl);line-height:var(--aui-line-height-xl);color:rgb(var(--aui-color-main-text));font-weight:var(--aui-font-weight-bold);display:flex;word-wrap:break-word;word-break:break-all}.aui-confirm-dialog__icon{margin-right:var(--aui-spacing-m);font-size:var(--aui-icon-size-xl)}.aui-confirm-dialog__icon--primary,.aui-confirm-dialog__icon--warning{color:rgb(var(--aui-color-yellow))}.aui-confirm-dialog__icon--success{color:rgb(var(--aui-color-green))}.aui-confirm-dialog__icon--danger{color:rgb(var(--aui-color-red))}.aui-confirm-dialog__content{padding-left:calc(var(--aui-spacing-m) + var(--aui-icon-size-xl));font-size:var(--aui-font-size-m);line-height:var(--aui-line-height-m);color:rgb(var(--aui-color-secondary-text));word-wrap:break-word;word-break:break-all}.aui-confirm-dialog__button-wrapper{margin:20px -12px 0 0;display:flex;flex-direction:row-reverse}\n"] }]
|
|
83
82
|
}], ctorParameters: function () { return [{ type: i1.DialogRef }, { type: i0.ChangeDetectorRef }]; } });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"confirm-dialog.component.js","sourceRoot":"","sources":["../../../../src/dialog/confirm-dialog/confirm-dialog.component.ts","../../../../src/dialog/confirm-dialog/confirm-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { firstValueFrom, Observable } from 'rxjs';\n\nimport { Bem, buildBem } from '../../utils';\nimport { DialogRef } from '../dialog-ref';\nimport {\n  BeforeAction,\n  ConfirmType,\n  CustomBeforeAction,\n  PromiseExecutor,\n} from '../dialog.types';\n\nimport { ConfirmDialogConfig } from './confirm-dialog-config';\n\n@Component({\n  selector: 'aui-confirm-dialog',\n  templateUrl: './confirm-dialog.component.html',\n  styleUrls: ['./confirm-dialog.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class ConfirmDialogComponent<T = unknown, R = unknown> {\n  bem: Bem = buildBem('aui-confirm-dialog');\n\n  config: ConfirmDialogConfig<T, R>;\n\n  waitConfirm = false;\n  waitCancel = false;\n\n  constructor(\n    private readonly dialogRef: DialogRef<any>,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  setConfig(config: ConfirmDialogConfig<T, R>) {\n    this.config = { ...new ConfirmDialogConfig(), ...config };\n  }\n\n  iconMap(type: ConfirmType) {\n    switch (type) {\n      case ConfirmType.Success:\n        return 'check_circle_s';\n      case ConfirmType.Danger:\n        return 'exclamation_triangle_s';\n      default:\n        return 'exclamation_circle_s';\n    }\n  }\n\n  async confirm() {\n    if (!this.config.beforeConfirm) {\n      this.dialogRef.close({ confirm: true, result: null });\n      return;\n    }\n    this.waitConfirm = true;\n    try {\n      const result = await this.toPromise(this.config.beforeConfirm);\n      this.dialogRef.close({ confirm: true, result });\n    } catch {\n    } finally {\n      this.waitConfirm = false;\n      this.cdr.markForCheck();\n    }\n  }\n\n  async cancel() {\n    if (!this.config.beforeCancel) {\n      this.dialogRef.close({ confirm: false, result: null });\n      return;\n    }\n    this.waitCancel = true;\n    try {\n      const result = await this.toPromise(this.config.beforeCancel);\n      this.dialogRef.close({ confirm: false, result });\n    } catch {\n    } finally {\n      this.waitCancel = false;\n      this.cdr.markForCheck();\n    }\n  }\n\n  private toPromise<T>(beforeAction: BeforeAction<T>) {\n    if (beforeAction.length) {\n      return new Promise(beforeAction as PromiseExecutor<T>);\n    }\n\n    const result = (beforeAction as CustomBeforeAction<T>)();\n\n    if (result instanceof Observable) {\n      return firstValueFrom(result);\n    }\n\n    return result;\n  }\n}\n","<div [class]=\"bem.block()\">\n  <div [class]=\"bem.element('title')\">\n    <span [class]=\"bem.element('icon', config.confirmType + '')\">\n      <aui-icon\n        [icon]=\"iconMap(config.confirmType)\"\n        [background]=\"\n          iconMap(config.confirmType).endsWith('_triangle_s')\n            ? 'triangle'\n            : 'circle'\n        \"\n      ></aui-icon>\n    </span>\n    <span>{{ config.title }}</span>\n  </div>\n  <div [class]=\"bem.element('content')\">{{ config.content }}</div>\n  <div [class]=\"bem.element('button-wrapper')\">\n    <div>\n      <button\n        [aui-button]=\"config.confirmType\"\n        [ngClass]=\"bem.element('confirm-button')\"\n        [loading]=\"waitConfirm\"\n        [disabled]=\"waitConfirm || waitCancel\"\n        (click)=\"confirm()\"\n      >\n        {{ config.confirmText }}\n      </button>\n      <button\n        *ngIf=\"config.cancelButton\"\n        aui-button\n        [ngClass]=\"bem.element('cancel-button')\"\n        [loading]=\"waitCancel\"\n        [disabled]=\"waitConfirm || waitCancel\"\n        (click)=\"cancel()\"\n      >\n        {{ config.cancelText }}\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { OverlayConfig, } from '@angular/cdk/overlay';
|
|
2
2
|
import { CdkPortalOutlet, ComponentPortal, TemplatePortal, } from '@angular/cdk/portal';
|
|
3
3
|
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, InjectionToken, Injector, Input, Output, TemplateRef, Type, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
4
|
-
import { Subject } from 'rxjs';
|
|
5
|
-
import { takeUntil } from 'rxjs/operators';
|
|
4
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
6
5
|
import { isTemplateRef } from '../../utils';
|
|
7
6
|
import { DrawerRef, DrawerSize } from './drawer-ref';
|
|
8
7
|
import { DrawerContentDirective, DrawerFooterDirective, DrawerHeaderDirective, } from './helper-directives';
|
|
@@ -228,4 +227,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
228
227
|
type: ContentChild,
|
|
229
228
|
args: [DrawerFooterDirective, { read: TemplateRef }]
|
|
230
229
|
}] } });
|
|
231
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.component.js","sourceRoot":"","sources":["../../../../src/drawer/component/drawer.component.ts","../../../../src/drawer/component/drawer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentType,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n} from '@angular/cdk/overlay';\nimport {\n  CdkPortalOutlet,\n  ComponentPortal,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  InjectionToken,\n  Injector,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { isTemplateRef } from '../../utils';\n\nimport { DrawerRef, DrawerSize } from './drawer-ref';\nimport {\n  DrawerContentDirective,\n  DrawerFooterDirective,\n  DrawerHeaderDirective,\n} from './helper-directives';\n\nexport const DATA = new InjectionToken('drawer-data');\n\nconst DRAWER_OVERLAY_CLASS = 'aui-drawer-overlay';\n\nconst SIZE_MAPPER = {\n  [DrawerSize.Small]: 400,\n  [DrawerSize.Medium]: 600,\n  [DrawerSize.Big]: 800,\n};\n\n@Component({\n  selector: 'aui-drawer',\n  templateUrl: './drawer.component.html',\n  styleUrls: ['./drawer.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrawerComponent<\n    T = ComponentType<unknown>,\n    R = unknown,\n    D = unknown,\n  >\n  extends DrawerRef<T, R>\n  implements OnInit, AfterViewInit, OnChanges, OnDestroy\n{\n  @Input()\n  title: string | TemplateRef<unknown>;\n\n  @Input()\n  footer: string | TemplateRef<unknown>;\n\n  @Input()\n  size: DrawerSize = DrawerSize.Medium;\n\n  @Input()\n  offsetY = '0px';\n\n  @Input() visible: boolean;\n\n  @Input()\n  content: TemplateRef<T> | ComponentType<T>;\n\n  @Input()\n  hideOnClickOutside = false;\n\n  @Input()\n  showClose = true;\n\n  @Input()\n  drawerClass: string;\n\n  @Input()\n  mask: boolean;\n\n  @Input()\n  maskClosable: boolean;\n\n  @Input()\n  divider = true;\n\n  private _value = SIZE_MAPPER[DrawerSize.Medium];\n  @Input()\n  set width(value: number) {\n    this._value = value;\n  }\n\n  get width() {\n    return this._value;\n  }\n\n  get drawerClasses(): Record<string, boolean> {\n    return {\n      'aui-drawer': true,\n      hasDivider: this.divider,\n      ...(!this.drawerClass ? null : { [this.drawerClass]: true }),\n    };\n  }\n\n  private readonly afterClosed$ = new Subject<R>();\n\n  get afterClosed(): Observable<R> {\n    return this.afterClosed$.asObservable();\n  }\n\n  private readonly afterOpen$ = new Subject<void>();\n\n  get afterOpen(): Observable<void> {\n    return this.afterOpen$.asObservable();\n  }\n\n  @Output()\n  drawerViewInit = new EventEmitter<void>();\n\n  @Output() readonly close = new EventEmitter<MouseEvent>();\n\n  @ViewChild('drawerTemplate', { static: true })\n  drawerTemplate: TemplateRef<void>;\n\n  @ViewChild(CdkPortalOutlet, { static: false })\n  bodyPortalOutlet: CdkPortalOutlet;\n\n  @ContentChild(DrawerHeaderDirective, { read: TemplateRef })\n  titleTemplate: TemplateRef<T>;\n\n  @ContentChild(DrawerContentDirective, { read: TemplateRef })\n  contentTemplate: TemplateRef<T> | ComponentType<T>;\n\n  @ContentChild(DrawerFooterDirective, { read: TemplateRef })\n  footerTemplate: TemplateRef<T>;\n\n  onDestroy$ = new Subject<void>();\n\n  isTemplateRef = isTemplateRef;\n\n  componentInstance: T | null = null;\n\n  contentParams: D;\n  overlayRef: OverlayRef;\n  portal: TemplatePortal;\n  templateContext = {};\n  get transform() {\n    return `translateX(${this.visible ? 0 : '100%'})`;\n  }\n\n  constructor(\n    private readonly viewContainerRef: ViewContainerRef,\n    private readonly overlay: Overlay,\n    private readonly injector: Injector,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    super();\n  }\n\n  ngOnInit() {\n    this.attachOverlay();\n    this.updateBodyOverflow();\n    this.templateContext = { $implicit: this.contentParams };\n    this.cdr.detectChanges();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { visible } = changes;\n    if (visible) {\n      const value = visible.currentValue;\n      if (value) {\n        this.open();\n      } else {\n        this.dispose();\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    this.attachBodyContent();\n    setTimeout(() => {\n      this.drawerViewInit.emit();\n    }, 0);\n  }\n\n  private attachOverlay() {\n    if (!this.overlayRef) {\n      this.portal = new TemplatePortal(\n        this.drawerTemplate,\n        this.viewContainerRef,\n      );\n      this.overlayRef = this.overlay.create(this.getOverlayConfig());\n    }\n    if (this.overlayRef) {\n      this.overlayRef.attach(this.portal);\n      this.overlayRef\n        .outsidePointerEvents()\n        .pipe(takeUntil(this.onDestroy$))\n        .subscribe(event => {\n          // 判断鼠标点击事件的 target 是否为 overlay-container 的子节点，如果是，则不关闭 drawer。\n          // 为了避免点击 drawer 里的 tooltip 后 drawer 被关闭。\n          if (\n            this.visible &&\n            this.hideOnClickOutside &&\n            event.target instanceof Node &&\n            !this.overlayRef.hostElement?.parentNode?.contains(event.target)\n          ) {\n            event.stopPropagation();\n            event.preventDefault();\n            this.dispose();\n          }\n        });\n    }\n  }\n\n  private getOverlayConfig(): OverlayConfig {\n    return new OverlayConfig({\n      panelClass: DRAWER_OVERLAY_CLASS,\n      positionStrategy: this.overlay.position().global(),\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n    });\n  }\n\n  private attachBodyContent(): void {\n    this.bodyPortalOutlet?.dispose();\n    const content = this.content || this.contentTemplate;\n    if (content instanceof Type) {\n      const componentPortal = new ComponentPortal<T>(\n        content,\n        null,\n        Injector.create({\n          providers: [\n            {\n              provide: DATA,\n              useValue: this.contentParams,\n            },\n          ],\n          parent: this.injector,\n        }),\n      );\n      const componentRef =\n        this.bodyPortalOutlet?.attachComponentPortal(componentPortal);\n      this.componentInstance = componentRef.instance;\n      Object.assign(componentRef.instance, this.contentParams);\n      componentRef.changeDetectorRef.detectChanges();\n    }\n  }\n\n  private updateBodyOverflow(): void {\n    if (this.overlayRef) {\n      if (this.visible) {\n        this.overlayRef.getConfig().scrollStrategy.enable();\n      } else {\n        this.overlayRef.getConfig().scrollStrategy.disable();\n      }\n    }\n  }\n\n  open() {\n    this.visible = true;\n    this.afterOpen$.next();\n    this.afterOpen$.complete();\n    this.updateBodyOverflow();\n    this.cdr.markForCheck();\n  }\n\n  dispose(result: R = null) {\n    this.visible = false;\n    this.close.emit();\n    this.afterClosed$.next(result);\n    this.afterClosed$.complete();\n    this.updateBodyOverflow();\n    this.cdr.markForCheck();\n  }\n\n  private disposeOverlay(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n    }\n    this.overlayRef = null;\n  }\n\n  maskClick() {\n    if (this.maskClosable && this.mask) {\n      this.dispose();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy$.next();\n    this.disposeOverlay();\n  }\n}\n","<ng-template #drawerTemplate>\n  <div\n    *ngIf=\"mask\"\n    class=\"aui-drawer-mask\"\n    [class.isOpen]=\"visible\"\n    (click)=\"maskClick()\"\n  ></div>\n  <div\n    [style.marginTop]=\"offsetY\"\n    [ngClass]=\"drawerClasses\"\n    [class.isOpen]=\"visible\"\n    [ngStyle]=\"{\n      transform: transform,\n      width: width + 'px'\n    }\"\n  >\n    <div class=\"aui-drawer__content\">\n      <div class=\"aui-drawer__body-wrapper\">\n        <div class=\"aui-drawer__header\">\n          <div class=\"aui-drawer__title\">\n            <ng-container\n              *ngIf=\"!isTemplateRef(title || titleTemplate); else elseTemplate\"\n            >\n              {{ title }}\n            </ng-container>\n            <ng-template #elseTemplate>\n              <ng-container\n                *ngIf=\"title || titleTemplate\"\n                [ngTemplateOutlet]=\"$any(title || titleTemplate)\"\n                [ngTemplateOutletContext]=\"templateContext\"\n              ></ng-container>\n            </ng-template>\n          </div>\n          <div\n            class=\"aui-drawer__close\"\n            *ngIf=\"showClose\"\n            (click)=\"dispose()\"\n          >\n            <aui-icon icon=\"close\"></aui-icon>\n          </div>\n        </div>\n\n        <div class=\"aui-drawer__body\">\n          <ng-template cdkPortalOutlet></ng-template>\n          <ng-container *ngIf=\"isTemplateRef(content || contentTemplate)\">\n            <ng-container\n              *ngTemplateOutlet=\"\n                $any(content || contentTemplate);\n                context: templateContext\n              \"\n            >\n            </ng-container>\n          </ng-container>\n        </div>\n\n        <div\n          *ngIf=\"footer || footerTemplate\"\n          class=\"aui-drawer__footer\"\n        >\n          <ng-container\n            *ngIf=\"!isTemplateRef(footer || footerTemplate); else elseTemplate\"\n          >\n            {{ footer }}\n          </ng-container>\n          <ng-template #elseTemplate>\n            <ng-container\n              *ngIf=\"footer || footerTemplate\"\n              [ngTemplateOutlet]=\"$any(footer || footerTemplate)\"\n              [ngTemplateOutletContext]=\"templateContext\"\n            ></ng-container>\n          </ng-template>\n        </div>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drawer.component.js","sourceRoot":"","sources":["../../../../src/drawer/component/drawer.component.ts","../../../../src/drawer/component/drawer.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ComponentType,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n} from '@angular/cdk/overlay';\nimport {\n  CdkPortalOutlet,\n  ComponentPortal,\n  TemplatePortal,\n} from '@angular/cdk/portal';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  InjectionToken,\n  Injector,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Observable, Subject, takeUntil } from 'rxjs';\n\nimport { isTemplateRef } from '../../utils';\n\nimport { DrawerRef, DrawerSize } from './drawer-ref';\nimport {\n  DrawerContentDirective,\n  DrawerFooterDirective,\n  DrawerHeaderDirective,\n} from './helper-directives';\n\nexport const DATA = new InjectionToken('drawer-data');\n\nconst DRAWER_OVERLAY_CLASS = 'aui-drawer-overlay';\n\nconst SIZE_MAPPER = {\n  [DrawerSize.Small]: 400,\n  [DrawerSize.Medium]: 600,\n  [DrawerSize.Big]: 800,\n};\n\n@Component({\n  selector: 'aui-drawer',\n  templateUrl: './drawer.component.html',\n  styleUrls: ['./drawer.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class DrawerComponent<\n    T = ComponentType<unknown>,\n    R = unknown,\n    D = unknown,\n  >\n  extends DrawerRef<T, R>\n  implements OnInit, AfterViewInit, OnChanges, OnDestroy\n{\n  @Input()\n  title: string | TemplateRef<unknown>;\n\n  @Input()\n  footer: string | TemplateRef<unknown>;\n\n  @Input()\n  size: DrawerSize = DrawerSize.Medium;\n\n  @Input()\n  offsetY = '0px';\n\n  @Input() visible: boolean;\n\n  @Input()\n  content: TemplateRef<T> | ComponentType<T>;\n\n  @Input()\n  hideOnClickOutside = false;\n\n  @Input()\n  showClose = true;\n\n  @Input()\n  drawerClass: string;\n\n  @Input()\n  mask: boolean;\n\n  @Input()\n  maskClosable: boolean;\n\n  @Input()\n  divider = true;\n\n  private _value = SIZE_MAPPER[DrawerSize.Medium];\n  @Input()\n  set width(value: number) {\n    this._value = value;\n  }\n\n  get width() {\n    return this._value;\n  }\n\n  get drawerClasses(): Record<string, boolean> {\n    return {\n      'aui-drawer': true,\n      hasDivider: this.divider,\n      ...(!this.drawerClass ? null : { [this.drawerClass]: true }),\n    };\n  }\n\n  private readonly afterClosed$ = new Subject<R>();\n\n  get afterClosed(): Observable<R> {\n    return this.afterClosed$.asObservable();\n  }\n\n  private readonly afterOpen$ = new Subject<void>();\n\n  get afterOpen(): Observable<void> {\n    return this.afterOpen$.asObservable();\n  }\n\n  @Output()\n  drawerViewInit = new EventEmitter<void>();\n\n  @Output() readonly close = new EventEmitter<MouseEvent>();\n\n  @ViewChild('drawerTemplate', { static: true })\n  drawerTemplate: TemplateRef<void>;\n\n  @ViewChild(CdkPortalOutlet, { static: false })\n  bodyPortalOutlet: CdkPortalOutlet;\n\n  @ContentChild(DrawerHeaderDirective, { read: TemplateRef })\n  titleTemplate: TemplateRef<T>;\n\n  @ContentChild(DrawerContentDirective, { read: TemplateRef })\n  contentTemplate: TemplateRef<T> | ComponentType<T>;\n\n  @ContentChild(DrawerFooterDirective, { read: TemplateRef })\n  footerTemplate: TemplateRef<T>;\n\n  onDestroy$ = new Subject<void>();\n\n  isTemplateRef = isTemplateRef;\n\n  componentInstance: T | null = null;\n\n  contentParams: D;\n  overlayRef: OverlayRef;\n  portal: TemplatePortal;\n  templateContext = {};\n  get transform() {\n    return `translateX(${this.visible ? 0 : '100%'})`;\n  }\n\n  constructor(\n    private readonly viewContainerRef: ViewContainerRef,\n    private readonly overlay: Overlay,\n    private readonly injector: Injector,\n    private readonly cdr: ChangeDetectorRef,\n  ) {\n    super();\n  }\n\n  ngOnInit() {\n    this.attachOverlay();\n    this.updateBodyOverflow();\n    this.templateContext = { $implicit: this.contentParams };\n    this.cdr.detectChanges();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const { visible } = changes;\n    if (visible) {\n      const value = visible.currentValue;\n      if (value) {\n        this.open();\n      } else {\n        this.dispose();\n      }\n    }\n  }\n\n  ngAfterViewInit() {\n    this.attachBodyContent();\n    setTimeout(() => {\n      this.drawerViewInit.emit();\n    }, 0);\n  }\n\n  private attachOverlay() {\n    if (!this.overlayRef) {\n      this.portal = new TemplatePortal(\n        this.drawerTemplate,\n        this.viewContainerRef,\n      );\n      this.overlayRef = this.overlay.create(this.getOverlayConfig());\n    }\n    if (this.overlayRef) {\n      this.overlayRef.attach(this.portal);\n      this.overlayRef\n        .outsidePointerEvents()\n        .pipe(takeUntil(this.onDestroy$))\n        .subscribe(event => {\n          // 判断鼠标点击事件的 target 是否为 overlay-container 的子节点，如果是，则不关闭 drawer。\n          // 为了避免点击 drawer 里的 tooltip 后 drawer 被关闭。\n          if (\n            this.visible &&\n            this.hideOnClickOutside &&\n            event.target instanceof Node &&\n            !this.overlayRef.hostElement?.parentNode?.contains(event.target)\n          ) {\n            event.stopPropagation();\n            event.preventDefault();\n            this.dispose();\n          }\n        });\n    }\n  }\n\n  private getOverlayConfig(): OverlayConfig {\n    return new OverlayConfig({\n      panelClass: DRAWER_OVERLAY_CLASS,\n      positionStrategy: this.overlay.position().global(),\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n    });\n  }\n\n  private attachBodyContent(): void {\n    this.bodyPortalOutlet?.dispose();\n    const content = this.content || this.contentTemplate;\n    if (content instanceof Type) {\n      const componentPortal = new ComponentPortal<T>(\n        content,\n        null,\n        Injector.create({\n          providers: [\n            {\n              provide: DATA,\n              useValue: this.contentParams,\n            },\n          ],\n          parent: this.injector,\n        }),\n      );\n      const componentRef =\n        this.bodyPortalOutlet?.attachComponentPortal(componentPortal);\n      this.componentInstance = componentRef.instance;\n      Object.assign(componentRef.instance, this.contentParams);\n      componentRef.changeDetectorRef.detectChanges();\n    }\n  }\n\n  private updateBodyOverflow(): void {\n    if (this.overlayRef) {\n      if (this.visible) {\n        this.overlayRef.getConfig().scrollStrategy.enable();\n      } else {\n        this.overlayRef.getConfig().scrollStrategy.disable();\n      }\n    }\n  }\n\n  open() {\n    this.visible = true;\n    this.afterOpen$.next();\n    this.afterOpen$.complete();\n    this.updateBodyOverflow();\n    this.cdr.markForCheck();\n  }\n\n  dispose(result: R = null) {\n    this.visible = false;\n    this.close.emit();\n    this.afterClosed$.next(result);\n    this.afterClosed$.complete();\n    this.updateBodyOverflow();\n    this.cdr.markForCheck();\n  }\n\n  private disposeOverlay(): void {\n    if (this.overlayRef) {\n      this.overlayRef.dispose();\n    }\n    this.overlayRef = null;\n  }\n\n  maskClick() {\n    if (this.maskClosable && this.mask) {\n      this.dispose();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy$.next();\n    this.disposeOverlay();\n  }\n}\n","<ng-template #drawerTemplate>\n  <div\n    *ngIf=\"mask\"\n    class=\"aui-drawer-mask\"\n    [class.isOpen]=\"visible\"\n    (click)=\"maskClick()\"\n  ></div>\n  <div\n    [style.marginTop]=\"offsetY\"\n    [ngClass]=\"drawerClasses\"\n    [class.isOpen]=\"visible\"\n    [ngStyle]=\"{\n      transform: transform,\n      width: width + 'px'\n    }\"\n  >\n    <div class=\"aui-drawer__content\">\n      <div class=\"aui-drawer__body-wrapper\">\n        <div class=\"aui-drawer__header\">\n          <div class=\"aui-drawer__title\">\n            <ng-container\n              *ngIf=\"!isTemplateRef(title || titleTemplate); else elseTemplate\"\n            >\n              {{ title }}\n            </ng-container>\n            <ng-template #elseTemplate>\n              <ng-container\n                *ngIf=\"title || titleTemplate\"\n                [ngTemplateOutlet]=\"$any(title || titleTemplate)\"\n                [ngTemplateOutletContext]=\"templateContext\"\n              ></ng-container>\n            </ng-template>\n          </div>\n          <div\n            class=\"aui-drawer__close\"\n            *ngIf=\"showClose\"\n            (click)=\"dispose()\"\n          >\n            <aui-icon icon=\"close\"></aui-icon>\n          </div>\n        </div>\n\n        <div class=\"aui-drawer__body\">\n          <ng-template cdkPortalOutlet></ng-template>\n          <ng-container *ngIf=\"isTemplateRef(content || contentTemplate)\">\n            <ng-container\n              *ngTemplateOutlet=\"\n                $any(content || contentTemplate);\n                context: templateContext\n              \"\n            >\n            </ng-container>\n          </ng-container>\n        </div>\n\n        <div\n          *ngIf=\"footer || footerTemplate\"\n          class=\"aui-drawer__footer\"\n        >\n          <ng-container\n            *ngIf=\"!isTemplateRef(footer || footerTemplate); else elseTemplate\"\n          >\n            {{ footer }}\n          </ng-container>\n          <ng-template #elseTemplate>\n            <ng-container\n              *ngIf=\"footer || footerTemplate\"\n              [ngTemplateOutlet]=\"$any(footer || footerTemplate)\"\n              [ngTemplateOutletContext]=\"templateContext\"\n            ></ng-container>\n          </ng-template>\n        </div>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { ComponentPortal } from '@angular/cdk/portal';
|
|
2
2
|
import { Injectable } from '@angular/core';
|
|
3
|
-
import { Subject } from 'rxjs';
|
|
4
|
-
import { takeUntil } from 'rxjs/operators';
|
|
3
|
+
import { Subject, takeUntil } from 'rxjs';
|
|
5
4
|
import { DrawerComponent } from './component/drawer.component';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "@angular/cdk/overlay";
|
|
@@ -42,4 +41,4 @@ DrawerService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", versio
|
|
|
42
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: DrawerService, decorators: [{
|
|
43
42
|
type: Injectable
|
|
44
43
|
}], ctorParameters: function () { return [{ type: i1.Overlay }]; } });
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhd2VyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZHJhd2VyL2RyYXdlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxlQUFlLEVBQWlCLE1BQU0scUJBQXFCLENBQUM7QUFDckUsT0FBTyxFQUFnQixVQUFVLEVBQWUsTUFBTSxlQUFlLENBQUM7QUFDdEUsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFMUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDhCQUE4QixDQUFDOzs7QUFxQi9ELE1BQU0sT0FBTyxhQUFhO0lBS3hCLFlBQTZCLE9BQWdCO1FBQWhCLFlBQU8sR0FBUCxPQUFPLENBQVM7UUFGNUIsaUJBQVksR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO0lBRUosQ0FBQztJQUVqRCxJQUFJLENBQWMsT0FBeUI7UUFDekMsSUFBSSxDQUFDLFNBQVMsRUFBRSxRQUFRLEVBQUUsT0FBTyxFQUFFLENBQUM7UUFDcEMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUIsT0FBTyxJQUFJLENBQUMsU0FBUyxFQUFFLFFBQVEsQ0FBQztJQUNsQyxDQUFDO0lBRUQsYUFBYSxDQUFDLE9BQXNCO1FBQ2xDLE1BQU0sQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVPLFlBQVk7UUFDbEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxDQUFDO1FBQ3hDLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQ3JDLElBQUksZUFBZSxDQUFDLGVBQWUsQ0FBQyxDQUNyQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsY0FBYzthQUNuQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQzthQUNsQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDakMsQ0FBQyxDQUFDLENBQUM7UUFFTCxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxXQUFXO2FBQ2hDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO2FBQ2xDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sRUFBRSxDQUFDO1lBQzFCLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1lBQ3RCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDekIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUMvQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7OzBHQXJDVSxhQUFhOzhHQUFiLGFBQWE7MkZBQWIsYUFBYTtrQkFEekIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXksIE92ZXJsYXlSZWYgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBDb21wb25lbnRQb3J0YWwsIENvbXBvbmVudFR5cGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcbmltcG9ydCB7IENvbXBvbmVudFJlZiwgSW5qZWN0YWJsZSwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN1YmplY3QsIHRha2VVbnRpbCB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBEcmF3ZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudC9kcmF3ZXIuY29tcG9uZW50JztcblxuaW1wb3J0IHsgRHJhd2VyU2l6ZSB9IGZyb20gJy4nO1xuXG5leHBvcnQgaW50ZXJmYWNlIERyYXdlck9wdGlvbnM8VCA9IGFueSwgRCA9IGFueT4ge1xuICB0aXRsZT86IHN0cmluZyB8IFRlbXBsYXRlUmVmPHVua25vd24+O1xuICB3aWR0aD86IG51bWJlcjtcbiAgY29udGVudD86IENvbXBvbmVudFR5cGU8VD4gfCBUZW1wbGF0ZVJlZjxUPjtcbiAgY29udGVudFBhcmFtcz86IEQ7XG4gIGZvb3Rlcj86IHN0cmluZyB8IFRlbXBsYXRlUmVmPHVua25vd24+O1xuICBvZmZzZXRZPzogc3RyaW5nO1xuICBkaXZpZGVyPzogYm9vbGVhbjtcbiAgZHJhd2VyQ2xhc3M/OiBzdHJpbmc7XG4gIHNpemU/OiBEcmF3ZXJTaXplO1xuICB2aXNpYmxlPzogYm9vbGVhbjtcbiAgaGlkZU9uQ2xpY2tPdXRzaWRlPzogYm9vbGVhbjtcbiAgc2hvd0Nsb3NlPzogYm9vbGVhbjtcbiAgbWFzaz86IGJvb2xlYW47XG4gIG1hc2tDbG9zYWJsZT86IGJvb2xlYW47XG59XG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRHJhd2VyU2VydmljZSB7XG4gIHByaXZhdGUgZHJhd2VyUmVmOiBDb21wb25lbnRSZWY8RHJhd2VyQ29tcG9uZW50PjtcbiAgcHJpdmF0ZSBvdmVybGF5UmVmOiBPdmVybGF5UmVmO1xuICBwcml2YXRlIHJlYWRvbmx5IHVuc3Vic2NyaWJlJCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBvdmVybGF5OiBPdmVybGF5KSB7fVxuXG4gIG9wZW48VCA9IHVua25vd24+KG9wdGlvbnM6IERyYXdlck9wdGlvbnM8VD4pIHtcbiAgICB0aGlzLmRyYXdlclJlZj8uaW5zdGFuY2U/LmRpc3Bvc2UoKTtcbiAgICB0aGlzLmNyZWF0ZURyYXdlcigpO1xuICAgIHRoaXMudXBkYXRlT3B0aW9ucyhvcHRpb25zKTtcbiAgICByZXR1cm4gdGhpcy5kcmF3ZXJSZWY/Lmluc3RhbmNlO1xuICB9XG5cbiAgdXBkYXRlT3B0aW9ucyhvcHRpb25zOiBEcmF3ZXJPcHRpb25zKTogdm9pZCB7XG4gICAgT2JqZWN0LmFzc2lnbih0aGlzLmRyYXdlclJlZi5pbnN0YW5jZSwgb3B0aW9ucyk7XG4gIH1cblxuICBwcml2YXRlIGNyZWF0ZURyYXdlcigpOiB2b2lkIHtcbiAgICB0aGlzLm92ZXJsYXlSZWYgPSB0aGlzLm92ZXJsYXkuY3JlYXRlKCk7XG4gICAgdGhpcy5kcmF3ZXJSZWYgPSB0aGlzLm92ZXJsYXlSZWYuYXR0YWNoKFxuICAgICAgbmV3IENvbXBvbmVudFBvcnRhbChEcmF3ZXJDb21wb25lbnQpLFxuICAgICk7XG4gICAgdGhpcy5kcmF3ZXJSZWYuaW5zdGFuY2UuZHJhd2VyVmlld0luaXRcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLnVuc3Vic2NyaWJlJCkpXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgdGhpcy5kcmF3ZXJSZWYuaW5zdGFuY2Uub3BlbigpO1xuICAgICAgfSk7XG5cbiAgICB0aGlzLmRyYXdlclJlZi5pbnN0YW5jZS5hZnRlckNsb3NlZFxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMudW5zdWJzY3JpYmUkKSlcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLm92ZXJsYXlSZWYuZGlzcG9zZSgpO1xuICAgICAgICB0aGlzLmRyYXdlclJlZiA9IG51bGw7XG4gICAgICAgIHRoaXMudW5zdWJzY3JpYmUkLm5leHQoKTtcbiAgICAgICAgdGhpcy51bnN1YnNjcmliZSQuY29tcGxldGUoKTtcbiAgICAgIH0pO1xuICB9XG59XG4iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Directive, EventEmitter, Input, Output, } from '@angular/core';
|
|
2
|
-
import { debounceTime } from 'rxjs
|
|
2
|
+
import { debounceTime } from 'rxjs';
|
|
3
3
|
import { BaseTooltip, TooltipTrigger, TooltipType } from '../tooltip';
|
|
4
4
|
import { DropdownActiveDirective } from './dropdown-active.directive';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -80,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
80
80
|
type: Output,
|
|
81
81
|
args: ['auiDropdownHide']
|
|
82
82
|
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2Ryb3Bkb3duL2Ryb3Bkb3duLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBRUwsU0FBUyxFQUVULFlBQVksRUFDWixLQUFLLEVBR0wsTUFBTSxHQUdQLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFcEMsT0FBTyxFQUFFLFdBQVcsRUFBRSxjQUFjLEVBQUUsV0FBVyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBRXRFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDOzs7QUFtQnRFLE1BQU0sT0FBTyxpQkFBa0IsU0FBUSxXQUFXO0lBNEJoRCxZQUNFLE9BQWdCLEVBQ2hCLGdCQUFrQyxFQUNsQyxLQUFpQixFQUNqQixRQUFtQixFQUNuQixHQUFzQixFQUN0QixNQUFjO1FBRWQsS0FBSyxDQUFDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQztRQWxCeEQsZ0JBQVcsR0FBRyxJQUFJLENBQUM7UUFHbkIsU0FBSSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFHaEMsU0FBSSxHQUFHLElBQUksWUFBWSxFQUFRLENBQUM7UUFhdkMsSUFBSSx1QkFBdUIsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLFFBQVEsQ0FBQyxDQUFDLFdBQVcsR0FBRyxVQUFVLENBQUM7UUFDNUUsSUFBSSxDQUFDLElBQUksR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDO1FBQzlCLElBQUksQ0FBQyxRQUFRLEdBQUcsWUFBWSxDQUFDO1FBQzdCLElBQUksQ0FBQyxPQUFPLEdBQUcsY0FBYyxDQUFDLEtBQUssQ0FBQztJQUN0QyxDQUFDO0lBeENELElBQ0ksSUFBSTtRQUNOLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUNwQixDQUFDO0lBRUQsSUFBSSxJQUFJLENBQUMsS0FBSztRQUNaLElBQUksS0FBSyxLQUFLLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDeEIsT0FBTztTQUNSO1FBQ0QsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFDbkIsSUFBSSxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxDQUFDO0lBQ2hDLENBQUM7SUErQkQsUUFBUTtRQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDN0MsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtnQkFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO2dCQUN0RCxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7YUFDdkI7UUFDSCxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUN2QixJQUFJLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO2dCQUN6QixJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsQ0FBQzthQUNoQztRQUNILENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7OEdBeERVLGlCQUFpQjtrR0FBakIsaUJBQWlCLDRiQVBqQjtRQUNUO1lBQ0UsT0FBTyxFQUFFLFdBQVc7WUFDcEIsV0FBVyxFQUFFLGlCQUFpQjtTQUMvQjtLQUNGOzJGQUVVLGlCQUFpQjtrQkFoQjdCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGVBQWU7b0JBQ3pCLFFBQVEsRUFBRSxhQUFhO29CQUN2QixNQUFNLEVBQUU7d0JBQ04sd0JBQXdCO3dCQUN4Qiw4QkFBOEI7d0JBQzlCLDhCQUE4Qjt3QkFDOUIsNEJBQTRCO3FCQUM3QjtvQkFDRCxTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLFdBQVc7NEJBQ3BCLFdBQVcsbUJBQW1CO3lCQUMvQjtxQkFDRjtpQkFDRjttT0FHSyxJQUFJO3NCQURQLEtBQUs7dUJBQUMsYUFBYTtnQkFjcEIsa0JBQWtCO3NCQURqQixLQUFLO3VCQUFDLG9CQUFvQjtnQkFJbEIsV0FBVztzQkFEbkIsS0FBSzt1QkFBQyx3QkFBd0I7Z0JBSXRCLElBQUk7c0JBRFosTUFBTTt1QkFBQyxpQkFBaUI7Z0JBSWhCLElBQUk7c0JBRFosTUFBTTt1QkFBQyxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gIERpcmVjdGl2ZSxcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgTmdab25lLFxuICBPbkluaXQsXG4gIE91dHB1dCxcbiAgUmVuZGVyZXIyLFxuICBWaWV3Q29udGFpbmVyUmVmLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGRlYm91bmNlVGltZSB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBCYXNlVG9vbHRpcCwgVG9vbHRpcFRyaWdnZXIsIFRvb2x0aXBUeXBlIH0gZnJvbSAnLi4vdG9vbHRpcCc7XG5cbmltcG9ydCB7IERyb3Bkb3duQWN0aXZlRGlyZWN0aXZlIH0gZnJvbSAnLi9kcm9wZG93bi1hY3RpdmUuZGlyZWN0aXZlJztcbmltcG9ydCB7IE1lbnVDb21wb25lbnQgfSBmcm9tICcuL21lbnUvbWVudS5jb21wb25lbnQnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdbYXVpRHJvcGRvd25dJyxcbiAgZXhwb3J0QXM6ICdhdWlEcm9wZG93bicsXG4gIGlucHV0czogW1xuICAgICdjbGFzczphdWlEcm9wZG93bkNsYXNzJyxcbiAgICAnZGlzYWJsZWQ6YXVpRHJvcGRvd25EaXNhYmxlZCcsXG4gICAgJ3Bvc2l0aW9uOmF1aURyb3Bkb3duUG9zaXRpb24nLFxuICAgICd0cmlnZ2VyOmF1aURyb3Bkb3duVHJpZ2dlcicsXG4gIF0sXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IEJhc2VUb29sdGlwLFxuICAgICAgdXNlRXhpc3Rpbmc6IERyb3Bkb3duRGlyZWN0aXZlLFxuICAgIH0sXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIERyb3Bkb3duRGlyZWN0aXZlIGV4dGVuZHMgQmFzZVRvb2x0aXAgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoJ2F1aURyb3Bkb3duJylcbiAgZ2V0IG1lbnUoKSB7XG4gICAgcmV0dXJuIHRoaXMuX21lbnU7XG4gIH1cblxuICBzZXQgbWVudSh2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSA9PT0gdGhpcy5fbWVudSkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICB0aGlzLl9tZW51ID0gdmFsdWU7XG4gICAgdGhpcy5jb250ZW50ID0gdmFsdWUudGVtcGxhdGU7XG4gIH1cblxuICBASW5wdXQoJ2F1aURyb3Bkb3duQ29udGV4dCcpXG4gIGxhenlDb250ZW50Q29udGV4dDogYW55O1xuXG4gIEBJbnB1dCgnYXVpRHJvcGRvd25IaWRlT25DbGljaycpXG4gIG92ZXJyaWRlIGhpZGVPbkNsaWNrID0gdHJ1ZTtcblxuICBAT3V0cHV0KCdhdWlEcm9wZG93blNob3cnKVxuICBvdmVycmlkZSBzaG93ID0gbmV3IEV2ZW50RW1pdHRlcjx2b2lkPigpO1xuXG4gIEBPdXRwdXQoJ2F1aURyb3Bkb3duSGlkZScpXG4gIG92ZXJyaWRlIGhpZGUgPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XG5cbiAgcHJpdmF0ZSBfbWVudTogTWVudUNvbXBvbmVudDtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBvdmVybGF5OiBPdmVybGF5LFxuICAgIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYsXG4gICAgZWxSZWY6IEVsZW1lbnRSZWYsXG4gICAgcmVuZGVyZXI6IFJlbmRlcmVyMixcbiAgICBjZHI6IENoYW5nZURldGVjdG9yUmVmLFxuICAgIG5nWm9uZTogTmdab25lLFxuICApIHtcbiAgICBzdXBlcihvdmVybGF5LCB2aWV3Q29udGFpbmVyUmVmLCBlbFJlZiwgcmVuZGVyZXIsIGNkciwgbmdab25lKTtcbiAgICBuZXcgRHJvcGRvd25BY3RpdmVEaXJlY3RpdmUodGhpcywgZWxSZWYsIHJlbmRlcmVyKS5jdXN0b21DbGFzcyA9ICdpc0FjdGl2ZSc7XG4gICAgdGhpcy50eXBlID0gVG9vbHRpcFR5cGUuUGxhaW47XG4gICAgdGhpcy5wb3NpdGlvbiA9ICdib3R0b20gZW5kJztcbiAgICB0aGlzLnRyaWdnZXIgPSBUb29sdGlwVHJpZ2dlci5DbGljaztcbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuc2hvdy5waXBlKGRlYm91bmNlVGltZSgwKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgIGlmICh0aGlzLm1lbnUubGF6eUNvbnRlbnQpIHtcbiAgICAgICAgdGhpcy5tZW51LmxhenlDb250ZW50LmF0dGFjaCh0aGlzLmxhenlDb250ZW50Q29udGV4dCk7XG4gICAgICAgIHRoaXMudXBkYXRlUG9zaXRpb24oKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICAgIHRoaXMuaGlkZS5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgaWYgKHRoaXMubWVudS5sYXp5Q29udGVudCkge1xuICAgICAgICB0aGlzLm1lbnUubGF6eUNvbnRlbnQuZGV0YWNoKCk7XG4gICAgICB9XG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, Input, Optional, ViewEncapsulation, } from '@angular/core';
|
|
2
2
|
import { NgControl } from '@angular/forms';
|
|
3
|
-
import { Subject, combineLatest, merge, map,
|
|
4
|
-
import { buildBem } from '../../utils';
|
|
3
|
+
import { Subject, combineLatest, merge, map, startWith, switchMap, takeUntil, } from 'rxjs';
|
|
4
|
+
import { buildBem, publishRef } from '../../utils';
|
|
5
5
|
import { LabelPosition } from '../form.types';
|
|
6
6
|
import { FormItemAddonDirective, FormItemControlDirective, FormItemErrorDirective, FormItemHintDirective, FormItemLabelDirective, } from '../helper-directives';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
@@ -59,7 +59,7 @@ export class FormItemComponent {
|
|
|
59
59
|
control.statusChanges.pipe(startWith(control.status)),
|
|
60
60
|
merge(this.parentForm.statusChanges.pipe(startWith(this.parentForm.status)), this.parentForm.ngSubmit),
|
|
61
61
|
]).pipe(map(([status]) => status))
|
|
62
|
-
: control.statusChanges).pipe(map((status) => status === 'INVALID' && (control.dirty || this.parentForm?.submitted)),
|
|
62
|
+
: control.statusChanges).pipe(map((status) => status === 'INVALID' && (control.dirty || this.parentForm?.submitted)), publishRef());
|
|
63
63
|
}
|
|
64
64
|
ngOnDestroy() {
|
|
65
65
|
this.destroy$$.next();
|
|
@@ -105,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
105
105
|
type: ContentChildren,
|
|
106
106
|
args: [FormItemHintDirective]
|
|
107
107
|
}] } });
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-item.component.js","sourceRoot":"","sources":["../../../../src/form/form-item/form-item.component.ts","../../../../src/form/form-item/form-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Input,\n  OnDestroy,\n  Optional,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormGroupDirective, NgControl, NgForm } from '@angular/forms';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  merge,\n  map,\n  publishReplay,\n  refCount,\n  startWith,\n  switchMap,\n  takeUntil,\n} from 'rxjs';\n\nimport { Bem, buildBem } from '../../utils';\nimport { FormDirective } from '../form.directive';\nimport { FormItemWidth, LabelPosition } from '../form.types';\nimport {\n  FormItemAddonDirective,\n  FormItemControlDirective,\n  FormItemErrorDirective,\n  FormItemHintDirective,\n  FormItemLabelDirective,\n} from '../helper-directives';\n\n@Component({\n  selector: 'aui-form-item',\n  templateUrl: './form-item.component.html',\n  styleUrls: ['./form-item.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class FormItemComponent implements AfterContentInit, OnDestroy {\n  bem: Bem = buildBem('aui-form-item');\n\n  @Input()\n  labelWidth: string = null;\n\n  @Input()\n  width: FormItemWidth;\n\n  @Input()\n  labelPosition: LabelPosition = LabelPosition.Right;\n\n  @Input()\n  emptyAddon = false;\n\n  @Input()\n  plain = false;\n\n  @ContentChild(FormItemLabelDirective, { static: false })\n  itemLabel: FormItemLabelDirective;\n\n  @ContentChild(FormItemControlDirective, { static: false })\n  itemControl: FormItemControlDirective;\n\n  @ContentChildren(NgControl, { descendants: true })\n  ngControls: QueryList<NgControl>;\n\n  @ContentChildren(FormItemAddonDirective)\n  addons: QueryList<FormItemAddonDirective>;\n\n  @ContentChildren(FormItemErrorDirective)\n  errors: QueryList<FormItemErrorDirective>;\n\n  @ContentChildren(FormItemHintDirective)\n  hints: QueryList<FormItemHintDirective>;\n\n  hasError$: Observable<boolean>;\n  errorCount$: Observable<number>;\n  hintCount$: Observable<number>;\n  parentForm: NgForm | FormGroupDirective;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  get formItemWidthClass() {\n    return this.width\n      ? this.bem.element('content', { [this.width]: true })\n      : '';\n  }\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    @Optional() private readonly auiForm: FormDirective,\n    @Optional() ngForm: NgForm,\n    @Optional() formGroup: FormGroupDirective,\n  ) {\n    this.parentForm = formGroup || ngForm;\n    if (this.auiForm) {\n      this.subscribeInputsFromParent();\n    }\n  }\n\n  ngAfterContentInit() {\n    this.hasError$ = this.ngControls.changes.pipe(\n      startWith(this.ngControls),\n      switchMap((controls: QueryList<NgControl>) =>\n        combineLatest(\n          controls.map(control => this.mapControlStatus(control)),\n        ).pipe(map(statuses => statuses.some(Boolean))),\n      ),\n    );\n\n    this.errorCount$ = this.errors.changes.pipe(\n      map(errors => errors.length),\n      startWith(this.errors.length),\n    );\n\n    this.hintCount$ = this.hints.changes.pipe(\n      map(hints => hints.length),\n      startWith(this.hints.length),\n    );\n  }\n\n  subscribeInputsFromParent() {\n    this.auiForm.labelWidth$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(width => {\n        this.labelWidth = width;\n        this.cdr.markForCheck();\n      });\n    this.auiForm.labelPosition$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(position => {\n        this.labelPosition = position;\n        this.cdr.markForCheck();\n      });\n    this.auiForm.emptyAddon$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(emptyAddon => {\n        this.emptyAddon = emptyAddon;\n        this.cdr.markForCheck();\n      });\n  }\n\n  mapControlStatus(control: NgControl) {\n    return (\n      this.parentForm\n        ? combineLatest([\n            control.statusChanges.pipe(startWith(control.status)),\n            merge(\n              this.parentForm.statusChanges.pipe(\n                startWith(this.parentForm.status),\n              ),\n              this.parentForm.ngSubmit,\n            ),\n          ]).pipe(map(([status]: string[]) => status))\n        : control.statusChanges\n    ).pipe(\n      map(\n        (status: string) =>\n          status === 'INVALID' && (control.dirty || this.parentForm?.submitted),\n      ),\n      publishReplay(1),\n      refCount(),\n    );\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n","<div\n  [class]=\"bem.block(labelPosition)\"\n  [class.isPlain]=\"plain\"\n  [class.hasError]=\"hasError$ | async\"\n>\n  <div\n    [ngClass]=\"\n      bem.element(\n        'label-wrapper',\n        { required: !!itemControl?.required },\n        labelPosition\n      )\n    \"\n    [class.hasLabel]=\"!!itemLabel\"\n    [style.width]=\"labelWidth\"\n  >\n    <ng-content select=\"label[auiFormItemLabel]\"></ng-content>\n  </div>\n  <div class=\"aui-form-item__container\">\n    <div\n      class=\"aui-form-item__content\"\n      [ngClass]=\"formItemWidthClass\"\n    >\n      <ng-content></ng-content>\n      <div\n        *ngIf=\"emptyAddon || addons?.length\"\n        class=\"aui-form-item__addon-wrapper\"\n      >\n        <ng-content select=\"[auiFormItemAddon]\"></ng-content>\n      </div>\n    </div>\n    <div\n      *ngIf=\"(hasError$ | async) && (errorCount$ | async)\"\n      class=\"aui-form-item__error-wrapper\"\n    >\n      <ng-content select=\"[auiFormItemError]\"></ng-content>\n    </div>\n    <div\n      *ngIf=\"hintCount$ | async\"\n      class=\"aui-form-item__hint-wrapper\"\n    >\n      <ng-content select=\"[auiFormItemHint]\"></ng-content>\n    </div>\n  </div>\n</div>\n"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-item.component.js","sourceRoot":"","sources":["../../../../src/form/form-item/form-item.component.ts","../../../../src/form/form-item/form-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  Input,\n  OnDestroy,\n  Optional,\n  QueryList,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { FormGroupDirective, NgControl, NgForm } from '@angular/forms';\nimport {\n  Observable,\n  Subject,\n  combineLatest,\n  merge,\n  map,\n  startWith,\n  switchMap,\n  takeUntil,\n} from 'rxjs';\n\nimport { Bem, buildBem, publishRef } from '../../utils';\nimport { FormDirective } from '../form.directive';\nimport { FormItemWidth, LabelPosition } from '../form.types';\nimport {\n  FormItemAddonDirective,\n  FormItemControlDirective,\n  FormItemErrorDirective,\n  FormItemHintDirective,\n  FormItemLabelDirective,\n} from '../helper-directives';\n\n@Component({\n  selector: 'aui-form-item',\n  templateUrl: './form-item.component.html',\n  styleUrls: ['./form-item.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: false,\n})\nexport class FormItemComponent implements AfterContentInit, OnDestroy {\n  bem: Bem = buildBem('aui-form-item');\n\n  @Input()\n  labelWidth: string = null;\n\n  @Input()\n  width: FormItemWidth;\n\n  @Input()\n  labelPosition: LabelPosition = LabelPosition.Right;\n\n  @Input()\n  emptyAddon = false;\n\n  @Input()\n  plain = false;\n\n  @ContentChild(FormItemLabelDirective, { static: false })\n  itemLabel: FormItemLabelDirective;\n\n  @ContentChild(FormItemControlDirective, { static: false })\n  itemControl: FormItemControlDirective;\n\n  @ContentChildren(NgControl, { descendants: true })\n  ngControls: QueryList<NgControl>;\n\n  @ContentChildren(FormItemAddonDirective)\n  addons: QueryList<FormItemAddonDirective>;\n\n  @ContentChildren(FormItemErrorDirective)\n  errors: QueryList<FormItemErrorDirective>;\n\n  @ContentChildren(FormItemHintDirective)\n  hints: QueryList<FormItemHintDirective>;\n\n  hasError$: Observable<boolean>;\n  errorCount$: Observable<number>;\n  hintCount$: Observable<number>;\n  parentForm: NgForm | FormGroupDirective;\n\n  private readonly destroy$$ = new Subject<void>();\n\n  get formItemWidthClass() {\n    return this.width\n      ? this.bem.element('content', { [this.width]: true })\n      : '';\n  }\n\n  constructor(\n    private readonly cdr: ChangeDetectorRef,\n    @Optional() private readonly auiForm: FormDirective,\n    @Optional() ngForm: NgForm,\n    @Optional() formGroup: FormGroupDirective,\n  ) {\n    this.parentForm = formGroup || ngForm;\n    if (this.auiForm) {\n      this.subscribeInputsFromParent();\n    }\n  }\n\n  ngAfterContentInit() {\n    this.hasError$ = this.ngControls.changes.pipe(\n      startWith(this.ngControls),\n      switchMap((controls: QueryList<NgControl>) =>\n        combineLatest(\n          controls.map(control => this.mapControlStatus(control)),\n        ).pipe(map(statuses => statuses.some(Boolean))),\n      ),\n    );\n\n    this.errorCount$ = this.errors.changes.pipe(\n      map(errors => errors.length),\n      startWith(this.errors.length),\n    );\n\n    this.hintCount$ = this.hints.changes.pipe(\n      map(hints => hints.length),\n      startWith(this.hints.length),\n    );\n  }\n\n  subscribeInputsFromParent() {\n    this.auiForm.labelWidth$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(width => {\n        this.labelWidth = width;\n        this.cdr.markForCheck();\n      });\n    this.auiForm.labelPosition$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(position => {\n        this.labelPosition = position;\n        this.cdr.markForCheck();\n      });\n    this.auiForm.emptyAddon$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(emptyAddon => {\n        this.emptyAddon = emptyAddon;\n        this.cdr.markForCheck();\n      });\n  }\n\n  mapControlStatus(control: NgControl) {\n    return (\n      this.parentForm\n        ? combineLatest([\n            control.statusChanges.pipe(startWith(control.status)),\n            merge(\n              this.parentForm.statusChanges.pipe(\n                startWith(this.parentForm.status),\n              ),\n              this.parentForm.ngSubmit,\n            ),\n          ]).pipe(map(([status]: string[]) => status))\n        : control.statusChanges\n    ).pipe(\n      map(\n        (status: string) =>\n          status === 'INVALID' && (control.dirty || this.parentForm?.submitted),\n      ),\n      publishRef(),\n    );\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n","<div\n  [class]=\"bem.block(labelPosition)\"\n  [class.isPlain]=\"plain\"\n  [class.hasError]=\"hasError$ | async\"\n>\n  <div\n    [ngClass]=\"\n      bem.element(\n        'label-wrapper',\n        { required: !!itemControl?.required },\n        labelPosition\n      )\n    \"\n    [class.hasLabel]=\"!!itemLabel\"\n    [style.width]=\"labelWidth\"\n  >\n    <ng-content select=\"label[auiFormItemLabel]\"></ng-content>\n  </div>\n  <div class=\"aui-form-item__container\">\n    <div\n      class=\"aui-form-item__content\"\n      [ngClass]=\"formItemWidthClass\"\n    >\n      <ng-content></ng-content>\n      <div\n        *ngIf=\"emptyAddon || addons?.length\"\n        class=\"aui-form-item__addon-wrapper\"\n      >\n        <ng-content select=\"[auiFormItemAddon]\"></ng-content>\n      </div>\n    </div>\n    <div\n      *ngIf=\"(hasError$ | async) && (errorCount$ | async)\"\n      class=\"aui-form-item__error-wrapper\"\n    >\n      <ng-content select=\"[auiFormItemError]\"></ng-content>\n    </div>\n    <div\n      *ngIf=\"hintCount$ | async\"\n      class=\"aui-form-item__hint-wrapper\"\n    >\n      <ng-content select=\"[auiFormItemHint]\"></ng-content>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { Directive, Inject, Input, Optional } from '@angular/core';
|
|
2
2
|
import { ControlContainer } from '@angular/forms';
|
|
3
|
-
import { BehaviorSubject } from 'rxjs';
|
|
4
|
-
import { distinctUntilChanged } from 'rxjs/operators';
|
|
3
|
+
import { BehaviorSubject, distinctUntilChanged } from 'rxjs';
|
|
5
4
|
import { LabelPosition } from './form.types';
|
|
6
5
|
import * as i0 from "@angular/core";
|
|
7
6
|
import * as i1 from "@angular/forms";
|
|
@@ -67,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
67
66
|
type: Input,
|
|
68
67
|
args: ['auiFormInline']
|
|
69
68
|
}] } });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZm9ybS9mb3JtLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25FLE9BQU8sRUFBRSxnQkFBZ0IsRUFBOEIsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5RSxPQUFPLEVBQUUsZUFBZSxFQUFjLG9CQUFvQixFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRXpFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxjQUFjLENBQUM7OztBQVc3QyxNQUFNLE9BQU8sYUFBYTtJQTJDeEIsWUFHUyxnQkFBbUM7UUFBbkMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFtQjtRQXhDM0IsaUJBQVksR0FBRyxJQUFJLGVBQWUsQ0FBUyxJQUFJLENBQUMsQ0FBQztRQUNqRCxvQkFBZSxHQUFHLElBQUksZUFBZSxDQUNwRCxhQUFhLENBQUMsS0FBSyxDQUNwQixDQUFDO1FBRWUsaUJBQVksR0FBRyxJQUFJLGVBQWUsQ0FBVSxLQUFLLENBQUMsQ0FBQztRQWtCcEUsV0FBTSxHQUFHLEtBQUssQ0FBQztRQUVmLGdCQUFXLEdBQXVCLElBQUksQ0FBQyxZQUFZO2FBQ2hELFlBQVksRUFBRTthQUNkLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDLENBQUM7UUFFaEMsbUJBQWMsR0FBOEIsSUFBSSxDQUFDLGVBQWU7YUFDN0QsWUFBWSxFQUFFO2FBQ2QsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUMsQ0FBQztRQUVoQyxnQkFBVyxHQUF3QixJQUFJLENBQUMsWUFBWTthQUNqRCxZQUFZLEVBQUU7YUFDZCxJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQyxDQUFDO0lBTTdCLENBQUM7SUE5Q0osSUFBSSxnQkFBZ0I7UUFDbEIsT0FBUSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsYUFBNkM7YUFDekUsU0FBUyxDQUFDO0lBQ2YsQ0FBQztJQVNELElBQ0ksVUFBVSxDQUFDLEdBQVc7UUFDeEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDOUIsQ0FBQztJQUVELElBQ0ksYUFBYSxDQUFDLEdBQWtCO1FBQ2xDLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFFRCxJQUNJLFVBQVUsQ0FBQyxHQUFZO1FBQ3pCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLENBQUM7OzBHQTFCVSxhQUFhLGtCQTRDZCxnQkFBZ0I7OEZBNUNmLGFBQWE7MkZBQWIsYUFBYTtrQkFUekIsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZUFBZTtvQkFDekIsUUFBUSxFQUFFLFNBQVM7b0JBQ25CLElBQUksRUFBRTt3QkFDSixrQkFBa0IsRUFBRSxNQUFNO3dCQUMxQiwwQkFBMEIsRUFBRSxRQUFRO3dCQUNwQyxzQkFBc0IsRUFBRSxrQkFBa0I7cUJBQzNDO2lCQUNGOzswQkE2Q0ksTUFBTTsyQkFBQyxnQkFBZ0I7OzBCQUN2QixRQUFROzRDQS9CUCxVQUFVO3NCQURiLEtBQUs7dUJBQUMsbUJBQW1CO2dCQU10QixhQUFhO3NCQURoQixLQUFLO3VCQUFDLHNCQUFzQjtnQkFNekIsVUFBVTtzQkFEYixLQUFLO3VCQUFDLG1CQUFtQjtnQkFNMUIsTUFBTTtzQkFETCxLQUFLO3VCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEluamVjdCwgSW5wdXQsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb250cm9sQ29udGFpbmVyLCBGb3JtR3JvdXBEaXJlY3RpdmUsIE5nRm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgT2JzZXJ2YWJsZSwgZGlzdGluY3RVbnRpbENoYW5nZWQgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgTGFiZWxQb3NpdGlvbiB9IGZyb20gJy4vZm9ybS50eXBlcyc7XG5cbkBEaXJlY3RpdmUoe1xuICBzZWxlY3RvcjogJ2Zvcm1bYXVpRm9ybV0nLFxuICBleHBvcnRBczogJ2F1aUZvcm0nLFxuICBob3N0OiB7XG4gICAgJ1tjbGFzcy5hdWktZm9ybV0nOiAndHJ1ZScsXG4gICAgJ1tjbGFzcy5hdWktZm9ybS0taW5saW5lXSc6ICdpbmxpbmUnLFxuICAgICdbY2xhc3Mubmctc3VibWl0dGVkXSc6ICduZ0NsYXNzU3VibWl0dGVkJyxcbiAgfSxcbn0pXG5leHBvcnQgY2xhc3MgRm9ybURpcmVjdGl2ZSB7XG4gIGdldCBuZ0NsYXNzU3VibWl0dGVkKCkge1xuICAgIHJldHVybiAodGhpcy5jb250cm9sQ29udGFpbmVyPy5mb3JtRGlyZWN0aXZlIGFzIE5nRm9ybSB8IEZvcm1Hcm91cERpcmVjdGl2ZSlcbiAgICAgIC5zdWJtaXR0ZWQ7XG4gIH1cblxuICBwcml2YXRlIHJlYWRvbmx5IGxhYmVsV2lkdGgkJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c3RyaW5nPihudWxsKTtcbiAgcHJpdmF0ZSByZWFkb25seSBsYWJlbFBvc2l0aW9uJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PExhYmVsUG9zaXRpb24+KFxuICAgIExhYmVsUG9zaXRpb24uUmlnaHQsXG4gICk7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBlbXB0eUFkZG9uJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4+KGZhbHNlKTtcblxuICBASW5wdXQoJ2F1aUZvcm1MYWJlbFdpZHRoJylcbiAgc2V0IGxhYmVsV2lkdGgodmFsOiBzdHJpbmcpIHtcbiAgICB0aGlzLmxhYmVsV2lkdGgkJC5uZXh0KHZhbCk7XG4gIH1cblxuICBASW5wdXQoJ2F1aUZvcm1MYWJlbFBvc2l0aW9uJylcbiAgc2V0IGxhYmVsUG9zaXRpb24odmFsOiBMYWJlbFBvc2l0aW9uKSB7XG4gICAgdGhpcy5sYWJlbFBvc2l0aW9uJCQubmV4dCh2YWwpO1xuICB9XG5cbiAgQElucHV0KCdhdWlGb3JtRW1wdHlBZGRvbicpXG4gIHNldCBlbXB0eUFkZG9uKHZhbDogYm9vbGVhbikge1xuICAgIHRoaXMuZW1wdHlBZGRvbiQkLm5leHQodmFsKTtcbiAgfVxuXG4gIEBJbnB1dCgnYXVpRm9ybUlubGluZScpXG4gIGlubGluZSA9IGZhbHNlO1xuXG4gIGxhYmVsV2lkdGgkOiBPYnNlcnZhYmxlPHN0cmluZz4gPSB0aGlzLmxhYmVsV2lkdGgkJFxuICAgIC5hc09ic2VydmFibGUoKVxuICAgIC5waXBlKGRpc3RpbmN0VW50aWxDaGFuZ2VkKCkpO1xuXG4gIGxhYmVsUG9zaXRpb24kOiBPYnNlcnZhYmxlPExhYmVsUG9zaXRpb24+ID0gdGhpcy5sYWJlbFBvc2l0aW9uJCRcbiAgICAuYXNPYnNlcnZhYmxlKClcbiAgICAucGlwZShkaXN0aW5jdFVudGlsQ2hhbmdlZCgpKTtcblxuICBlbXB0eUFkZG9uJDogT2JzZXJ2YWJsZTxib29sZWFuPiA9IHRoaXMuZW1wdHlBZGRvbiQkXG4gICAgLmFzT2JzZXJ2YWJsZSgpXG4gICAgLnBpcGUoZGlzdGluY3RVbnRpbENoYW5nZWQoKSk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChDb250cm9sQ29udGFpbmVyKVxuICAgIEBPcHRpb25hbCgpXG4gICAgcHVibGljIGNvbnRyb2xDb250YWluZXI/OiBDb250cm9sQ29udGFpbmVyLFxuICApIHt9XG59XG4iXX0=
|
|
@@ -26,10 +26,13 @@ export class IconRegisterService {
|
|
|
26
26
|
.get(url, {
|
|
27
27
|
responseType: 'text',
|
|
28
28
|
})
|
|
29
|
-
.subscribe(
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
29
|
+
.subscribe({
|
|
30
|
+
next: res => {
|
|
31
|
+
this.registerSvgSymbolsByString(res);
|
|
32
|
+
},
|
|
33
|
+
error() {
|
|
34
|
+
throw getAuiIconFailedToLoadCustomIconFile(url);
|
|
35
|
+
},
|
|
33
36
|
});
|
|
34
37
|
}
|
|
35
38
|
registerSvgSymbolsByString(str) {
|
|
@@ -68,4 +71,4 @@ export const ICON_REGISTER_SERVICE_PROVIDER = {
|
|
|
68
71
|
],
|
|
69
72
|
useFactory: ICON_REGISTER_PROVIDER_FACTORY,
|
|
70
73
|
};
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1yZWdpc3Rlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2ljb24vaWNvbi1yZWdpc3Rlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDbEQsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV2RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sU0FBUyxDQUFDO0FBQ25DLE9BQU8sRUFDTCxvQ0FBb0MsRUFDcEMsNkJBQTZCLEdBQzlCLE1BQU0sU0FBUyxDQUFDOzs7QUFHakIsTUFBTSxPQUFPLG1CQUFtQjtJQUk5QixZQUdFLFFBQWEsRUFDZ0IsVUFBc0I7UUFBdEIsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQVA3QyxzQkFBaUIsR0FBRyxVQUFVLENBQUM7UUFTckMsSUFBSSxDQUFDLEdBQUcsR0FBRyxRQUFRLENBQUM7UUFDcEIsSUFBSSxDQUFDLDBCQUEwQixDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRCxvQkFBb0I7UUFDbEIsT0FBTyxJQUFJLENBQUMsaUJBQWlCLENBQUM7SUFDaEMsQ0FBQztJQUVELHdCQUF3QixDQUFDLE1BQWM7UUFDckMsSUFBSSxDQUFDLGlCQUFpQixHQUFHLE1BQU0sQ0FBQztJQUNsQyxDQUFDO0lBRUQsdUJBQXVCLENBQUMsR0FBVztRQUNqQyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNwQixNQUFNLDZCQUE2QixFQUFFLENBQUM7U0FDdkM7UUFDRCxJQUFJLENBQUMsVUFBVTthQUNaLEdBQUcsQ0FBQyxHQUFHLEVBQUU7WUFDUixZQUFZLEVBQUUsTUFBTTtTQUNyQixDQUFDO2FBQ0QsU0FBUyxDQUFDO1lBQ1QsSUFBSSxFQUFFLEdBQUcsQ0FBQyxFQUFFO2dCQUNWLElBQUksQ0FBQywwQkFBMEIsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUN2QyxDQUFDO1lBQ0QsS0FBSztnQkFDSCxNQUFNLG9DQUFvQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2xELENBQUM7U0FDRixDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsMEJBQTBCLENBQUMsR0FBVztRQUNwQyxJQUFJLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7SUFFTyxTQUFTLENBQUMsU0FBaUI7UUFDakMsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDNUMsS0FBSyxDQUFDLFNBQVMsR0FBRyxjQUFjLENBQUM7UUFDakMsS0FBSyxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsTUFBTSxDQUFDO1FBQzdCLEtBQUssQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1FBQzVCLElBQUksQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QixDQUFDOztnSEFsRFUsbUJBQW1CLGtCQU1wQixRQUFRO29IQU5QLG1CQUFtQjsyRkFBbkIsbUJBQW1CO2tCQUQvQixVQUFVOzswQkFNTixRQUFROzswQkFDUixNQUFNOzJCQUFDLFFBQVE7OzBCQUVmLFFBQVE7O0FBNkNiLCtDQUErQztBQUMvQyxNQUFNLFVBQVUsOEJBQThCLENBQzVDLGNBQW1DLEVBQ25DLFFBQWtCLEVBQ2xCLFVBQXNCO0lBRXRCLE9BQU8sY0FBYyxJQUFJLElBQUksbUJBQW1CLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0FBQ3pFLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSw4QkFBOEIsR0FBRztJQUM1QyxPQUFPLEVBQUUsbUJBQW1CO0lBQzVCLElBQUksRUFBRTtRQUNKLENBQUMsSUFBSSxRQUFRLEVBQUUsRUFBRSxJQUFJLFFBQVEsRUFBRSxFQUFFLG1CQUFtQixDQUFDO1FBQ3JELENBQUMsSUFBSSxRQUFRLEVBQUUsRUFBRSxRQUFRLENBQUM7UUFDMUIsQ0FBQyxJQUFJLFFBQVEsRUFBRSxFQUFFLFVBQVUsQ0FBQztLQUM3QjtJQUNELFVBQVUsRUFBRSw4QkFBOEI7Q0FDM0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEh0dHBDbGllbnQgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUsIE9wdGlvbmFsLCBTa2lwU2VsZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBhdWlJY29ucyB9IGZyb20gJy4vaWNvbnMnO1xuaW1wb3J0IHtcbiAgZ2V0QXVpSWNvbkZhaWxlZFRvTG9hZEN1c3RvbUljb25GaWxlLFxuICBnZXRBdWlJY29uTm9IdHRwUHJvdmlkZXJFcnJvcixcbn0gZnJvbSAnLi91dGlscyc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBJY29uUmVnaXN0ZXJTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBkZWZhdWx0SWNvblByZWZpeCA9ICdhdWktaWNvbic7XG4gIHByaXZhdGUgcmVhZG9ubHkgZG9jOiBEb2N1bWVudDtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBAT3B0aW9uYWwoKVxuICAgIEBJbmplY3QoRE9DVU1FTlQpXG4gICAgZG9jdW1lbnQ6IGFueSxcbiAgICBAT3B0aW9uYWwoKSBwcml2YXRlIHJlYWRvbmx5IGh0dHBDbGllbnQ6IEh0dHBDbGllbnQsXG4gICkge1xuICAgIHRoaXMuZG9jID0gZG9jdW1lbnQ7XG4gICAgdGhpcy5yZWdpc3RlclN2Z1N5bWJvbHNCeVN0cmluZyhhdWlJY29ucyk7XG4gIH1cblxuICBnZXREZWZhdWx0SWNvblByZWZpeCgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLmRlZmF1bHRJY29uUHJlZml4O1xuICB9XG5cbiAgcmVwbGFjZURlZmF1bHRJY29uUHJlZml4KHByZWZpeDogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5kZWZhdWx0SWNvblByZWZpeCA9IHByZWZpeDtcbiAgfVxuXG4gIHJlZ2lzdGVyU3ZnU3ltYm9sc0J5VXJsKHVybDogc3RyaW5nKSB7XG4gICAgaWYgKCF0aGlzLmh0dHBDbGllbnQpIHtcbiAgICAgIHRocm93IGdldEF1aUljb25Ob0h0dHBQcm92aWRlckVycm9yKCk7XG4gICAgfVxuICAgIHRoaXMuaHR0cENsaWVudFxuICAgICAgLmdldCh1cmwsIHtcbiAgICAgICAgcmVzcG9uc2VUeXBlOiAndGV4dCcsXG4gICAgICB9KVxuICAgICAgLnN1YnNjcmliZSh7XG4gICAgICAgIG5leHQ6IHJlcyA9PiB7XG4gICAgICAgICAgdGhpcy5yZWdpc3RlclN2Z1N5bWJvbHNCeVN0cmluZyhyZXMpO1xuICAgICAgICB9LFxuICAgICAgICBlcnJvcigpIHtcbiAgICAgICAgICB0aHJvdyBnZXRBdWlJY29uRmFpbGVkVG9Mb2FkQ3VzdG9tSWNvbkZpbGUodXJsKTtcbiAgICAgICAgfSxcbiAgICAgIH0pO1xuICB9XG5cbiAgcmVnaXN0ZXJTdmdTeW1ib2xzQnlTdHJpbmcoc3RyOiBzdHJpbmcpIHtcbiAgICB0aGlzLmFwcGVuZFN2ZyhzdHIpO1xuICB9XG5cbiAgcHJpdmF0ZSBhcHBlbmRTdmcoc3ZnU3RyaW5nOiBzdHJpbmcpIHtcbiAgICBjb25zdCBzZXRFbCA9IHRoaXMuZG9jLmNyZWF0ZUVsZW1lbnQoJ2RpdicpO1xuICAgIHNldEVsLmNsYXNzTmFtZSA9ICdhdWktaWNvbi1zZXQnO1xuICAgIHNldEVsLnN0eWxlLmRpc3BsYXkgPSAnbm9uZSc7XG4gICAgc2V0RWwuaW5uZXJIVE1MID0gc3ZnU3RyaW5nO1xuICAgIHRoaXMuZG9jLmJvZHkuYXBwZW5kKHNldEVsKTtcbiAgfVxufVxuXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgc29uYXIvZnVuY3Rpb24tbmFtZVxuZXhwb3J0IGZ1bmN0aW9uIElDT05fUkVHSVNURVJfUFJPVklERVJfRkFDVE9SWShcbiAgcGFyZW50UmVnaXN0ZXI6IEljb25SZWdpc3RlclNlcnZpY2UsXG4gIGRvY3VtZW50OiBEb2N1bWVudCxcbiAgaHR0cENsaWVudDogSHR0cENsaWVudCxcbikge1xuICByZXR1cm4gcGFyZW50UmVnaXN0ZXIgfHwgbmV3IEljb25SZWdpc3RlclNlcnZpY2UoZG9jdW1lbnQsIGh0dHBDbGllbnQpO1xufVxuXG5leHBvcnQgY29uc3QgSUNPTl9SRUdJU1RFUl9TRVJWSUNFX1BST1ZJREVSID0ge1xuICBwcm92aWRlOiBJY29uUmVnaXN0ZXJTZXJ2aWNlLFxuICBkZXBzOiBbXG4gICAgW25ldyBPcHRpb25hbCgpLCBuZXcgU2tpcFNlbGYoKSwgSWNvblJlZ2lzdGVyU2VydmljZV0sXG4gICAgW25ldyBPcHRpb25hbCgpLCBET0NVTUVOVF0sXG4gICAgW25ldyBPcHRpb25hbCgpLCBIdHRwQ2xpZW50XSxcbiAgXSxcbiAgdXNlRmFjdG9yeTogSUNPTl9SRUdJU1RFUl9QUk9WSURFUl9GQUNUT1JZLFxufTtcbiJdfQ==
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Directive, Input, } from '@angular/core';
|
|
2
|
-
import { Subject } from 'rxjs';
|
|
3
|
-
import { startWith, takeUntil } from 'rxjs/operators';
|
|
2
|
+
import { Subject, startWith, takeUntil } from 'rxjs';
|
|
4
3
|
import { calcTextareaHeight } from './utils';
|
|
5
4
|
import * as i0 from "@angular/core";
|
|
6
5
|
import * as i1 from "@angular/forms";
|
|
@@ -57,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
57
56
|
type: Input,
|
|
58
57
|
args: ['autosize']
|
|
59
58
|
}] } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b3NpemUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2lucHV0L2F1dG9zaXplLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBRUwsU0FBUyxFQUVULEtBQUssR0FFTixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFFckQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sU0FBUyxDQUFDOzs7QUFFN0MsTUFBTSxhQUFhLEdBQUc7SUFDcEIsT0FBTyxFQUFFLENBQUM7SUFDVixPQUFPLEVBQUUsQ0FBQztDQUNYLENBQUM7QUFPRjs7R0FFRztBQU9ILE1BQU0sT0FBTyxpQkFBaUI7SUFrQjVCLFlBQ21CLEtBQXNDLEVBQ3RDLFNBQW9CO1FBRHBCLFVBQUssR0FBTCxLQUFLLENBQWlDO1FBQ3RDLGNBQVMsR0FBVCxTQUFTLENBQVc7UUFuQi9CLGNBQVMsR0FBa0IsYUFBYSxDQUFDO1FBRWhDLGNBQVMsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO0lBa0I5QyxDQUFDO0lBaEJKLElBQ0ksUUFBUTtRQUNWLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsSUFBSSxRQUFRLENBQUMsS0FBeUI7UUFDcEMsSUFBSSxDQUFDLEtBQUssRUFBRTtZQUNWLEtBQUssR0FBRyxhQUFhLENBQUM7U0FDdkI7UUFDRCxJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztRQUN2QixJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQU9ELGNBQWM7UUFDWixNQUFNLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQztRQUNwQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDO1FBQ2hDLE1BQU0sQ0FBQyxNQUFNLENBQ1gsRUFBRSxDQUFDLEtBQUssRUFDUixrQkFBa0IsQ0FDaEIsRUFBRSxFQUNGLFFBQVEsQ0FBQyxPQUFPLElBQUksYUFBYSxDQUFDLE9BQU8sRUFDekMsUUFBUSxDQUFDLE9BQU8sSUFBSSxhQUFhLENBQUMsT0FBTyxDQUMxQyxDQUNGLENBQUM7SUFDSixDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWTthQUN4QixJQUFJLENBQUMsU0FBUyxDQUFDLElBQVksQ0FBQyxFQUFFLFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7YUFDeEQsU0FBUyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN0QixJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQzVCLENBQUM7OzhHQTdDVSxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQU43QixTQUFTO21CQUFDO29CQUNULFFBQVE7b0JBQ04sOERBQThEO29CQUM5RCxpR0FBaUc7b0JBQ25HLFFBQVEsRUFBRSxrQkFBa0I7aUJBQzdCO3lIQU9LLFFBQVE7c0JBRFgsS0FBSzt1QkFBQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQWZ0ZXJWaWV3SW5pdCxcbiAgRGlyZWN0aXZlLFxuICBFbGVtZW50UmVmLFxuICBJbnB1dCxcbiAgT25EZXN0cm95LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nQ29udHJvbCB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFN1YmplY3QsIHN0YXJ0V2l0aCwgdGFrZVVudGlsIH0gZnJvbSAncnhqcyc7XG5cbmltcG9ydCB7IGNhbGNUZXh0YXJlYUhlaWdodCB9IGZyb20gJy4vdXRpbHMnO1xuXG5jb25zdCBERUZBVUxUX1ZBTFVFID0ge1xuICBtaW5Sb3dzOiAzLFxuICBtYXhSb3dzOiA2LFxufTtcblxuZXhwb3J0IGludGVyZmFjZSBBdXRvU2l6ZVZhbHVlIHtcbiAgbWluUm93czogbnVtYmVyO1xuICBtYXhSb3dzPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIERpcmVjdGl2ZSB0byBhdXRvbWF0aWNhbGx5IHJlc2l6ZSBhIHRleHRhcmVhIHRvIGZpdCBpdHMgY29udGVudC5cbiAqL1xuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOlxuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvZGlyZWN0aXZlLXNlbGVjdG9yXG4gICAgJ3RleHRhcmVhW2F1dG9zaXplXVtuZ01vZGVsXSx0ZXh0YXJlYVthdXRvc2l6ZV1bZm9ybUNvbnRyb2xdLHRleHRhcmVhW2F1dG9zaXplXVtmb3JtQ29udHJvbE5hbWVdJyxcbiAgZXhwb3J0QXM6ICdUZXh0YXJlYUF1dG9zaXplJyxcbn0pXG5leHBvcnQgY2xhc3MgQXV0b3NpemVEaXJlY3RpdmUgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xuICBwcml2YXRlIF9hdXRvU2l6ZTogQXV0b1NpemVWYWx1ZSA9IERFRkFVTFRfVkFMVUU7XG5cbiAgcHJpdmF0ZSByZWFkb25seSBkZXN0cm95JCQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gIEBJbnB1dCgnYXV0b3NpemUnKVxuICBnZXQgYXV0b1NpemUoKSB7XG4gICAgcmV0dXJuIHRoaXMuX2F1dG9TaXplO1xuICB9XG5cbiAgc2V0IGF1dG9TaXplKHZhbHVlOiBBdXRvU2l6ZVZhbHVlIHwgJycpIHtcbiAgICBpZiAoIXZhbHVlKSB7XG4gICAgICB2YWx1ZSA9IERFRkFVTFRfVkFMVUU7XG4gICAgfVxuICAgIHRoaXMuX2F1dG9TaXplID0gdmFsdWU7XG4gICAgdGhpcy5yZXNpemVUZXh0YXJlYSgpO1xuICB9XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSByZWFkb25seSBlbFJlZjogRWxlbWVudFJlZjxIVE1MVGV4dEFyZWFFbGVtZW50PixcbiAgICBwcml2YXRlIHJlYWRvbmx5IG5nQ29udHJvbDogTmdDb250cm9sLFxuICApIHt9XG5cbiAgcmVzaXplVGV4dGFyZWEoKSB7XG4gICAgY29uc3QgZWwgPSB0aGlzLmVsUmVmLm5hdGl2ZUVsZW1lbnQ7XG4gICAgY29uc3QgYXV0b1NpemUgPSB0aGlzLl9hdXRvU2l6ZTtcbiAgICBPYmplY3QuYXNzaWduKFxuICAgICAgZWwuc3R5bGUsXG4gICAgICBjYWxjVGV4dGFyZWFIZWlnaHQoXG4gICAgICAgIGVsLFxuICAgICAgICBhdXRvU2l6ZS5taW5Sb3dzID8/IERFRkFVTFRfVkFMVUUubWluUm93cyxcbiAgICAgICAgYXV0b1NpemUubWF4Um93cyB8fCBERUZBVUxUX1ZBTFVFLm1heFJvd3MsIC8vIDAgaXMgdW5hY2NlcHRhYmxlXG4gICAgICApLFxuICAgICk7XG4gIH1cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgdGhpcy5uZ0NvbnRyb2wudmFsdWVDaGFuZ2VzXG4gICAgICAucGlwZShzdGFydFdpdGgobnVsbCBhcyB2b2lkKSwgdGFrZVVudGlsKHRoaXMuZGVzdHJveSQkKSlcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4gdGhpcy5yZXNpemVUZXh0YXJlYSgpKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCkge1xuICAgIHRoaXMuZGVzdHJveSQkLm5leHQoKTtcbiAgICB0aGlzLmRlc3Ryb3kkJC5jb21wbGV0ZSgpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { Directive, Input, ViewChild, } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject, Subject, combineLatest } from 'rxjs';
|
|
3
|
-
import { map, takeUntil } from 'rxjs/operators';
|
|
2
|
+
import { BehaviorSubject, Subject, combineLatest, map, takeUntil } from 'rxjs';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
import * as i1 from "./radio-group/radio-group.component";
|
|
6
5
|
import * as i2 from "@angular/cdk/a11y";
|
|
@@ -65,4 +64,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
65
64
|
type: ViewChild,
|
|
66
65
|
args: ['elRef', { static: true }]
|
|
67
66
|
}] } });
|
|
68
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1yYWRpby5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9yYWRpby9iYXNlLXJhZGlvLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFHTCxTQUFTLEVBRVQsS0FBSyxFQUdMLFNBQVMsR0FDVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsZUFBZSxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7OztBQUkvRSxJQUFJLFFBQVEsR0FBRyxDQUFDLENBQUM7QUFHakIsTUFBTSxPQUFPLFNBQVM7SUEwQnBCLFlBQ1ksVUFBK0IsRUFDL0IsWUFBMEIsRUFDMUIsR0FBc0I7UUFGdEIsZUFBVSxHQUFWLFVBQVUsQ0FBcUI7UUFDL0IsaUJBQVksR0FBWixZQUFZLENBQWM7UUFDMUIsUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUE1QmxDLE9BQUUsR0FBRyxhQUFhLFFBQVEsRUFBRSxFQUFFLENBQUM7UUFHL0IsYUFBUSxHQUFpQixLQUFLLENBQUM7UUFlL0IsWUFBTyxHQUFHLEtBQUssQ0FBQztRQUNoQixTQUFJLEdBQUcsRUFBRSxDQUFDO1FBR1MsWUFBTyxHQUFHLElBQUksZUFBZSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNuRCxjQUFTLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQU12QyxDQUFDO0lBeEJKLElBQ0ksS0FBSztRQUNQLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUNyQixDQUFDO0lBRUQsSUFBSSxLQUFLLENBQUMsR0FBRztRQUNYLElBQUksQ0FBQyxNQUFNLEdBQUcsR0FBRyxDQUFDO1FBQ2xCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3pCLENBQUM7SUFrQkQsUUFBUTtRQUNOLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3JFLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDMUIsQ0FBQyxDQUFDLENBQUM7UUFFSCxhQUFhLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsT0FBTyxDQUFDLENBQUM7YUFDbEQsSUFBSSxDQUNILFNBQVMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQ3pCLEdBQUcsQ0FBQyxDQUFDLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxVQUFVLEtBQUssU0FBUyxDQUFDLENBQzNEO2FBQ0EsU0FBUyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQ25CLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDMUIsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsZUFBZTtRQUNiLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsYUFBYSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQzVELENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUN0QixJQUFJLENBQUMsWUFBWSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFRCxPQUFPO1FBQ0wsSUFBSSxJQUFJLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDakMsT0FBTztTQUNSO1FBQ0QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFFRCxNQUFNO1FBQ0osSUFBSSxDQUFDLFVBQVUsQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNoQyxDQUFDOztzR0FuRVUsU0FBUzswRkFBVCxTQUFTOzJGQUFULFNBQVM7a0JBRHJCLFNBQVM7cUtBS1IsUUFBUTtzQkFEUCxLQUFLO2dCQUlGLEtBQUs7c0JBRFIsS0FBSztnQkFXTixLQUFLO3NCQURKLFNBQVM7dUJBQUMsT0FBTyxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEZvY3VzTW9uaXRvciB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9hMTF5JztcbmltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENoYW5nZURldGVjdG9yUmVmLFxuICBEaXJlY3RpdmUsXG4gIEVsZW1lbnRSZWYsXG4gIElucHV0LFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbiAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgU3ViamVjdCwgY29tYmluZUxhdGVzdCwgbWFwLCB0YWtlVW50aWwgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgUmFkaW9Hcm91cENvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8tZ3JvdXAvcmFkaW8tZ3JvdXAuY29tcG9uZW50JztcblxubGV0IHVuaXF1ZUlkID0gMDtcblxuQERpcmVjdGl2ZSgpXG5leHBvcnQgY2xhc3MgQmFzZVJhZGlvIGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xuICBpZCA9IGBhdWktcmFkaW8tJHt1bmlxdWVJZCsrfWA7XG5cbiAgQElucHV0KClcbiAgZGlzYWJsZWQ6IGJvb2xlYW4gfCAnJyA9IGZhbHNlO1xuXG4gIEBJbnB1dCgpXG4gIGdldCB2YWx1ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fdmFsdWU7XG4gIH1cblxuICBzZXQgdmFsdWUodmFsKSB7XG4gICAgdGhpcy5fdmFsdWUgPSB2YWw7XG4gICAgdGhpcy52YWx1ZSQkLm5leHQodmFsKTtcbiAgfVxuXG4gIEBWaWV3Q2hpbGQoJ2VsUmVmJywgeyBzdGF0aWM6IHRydWUgfSlcbiAgZWxSZWY6IEVsZW1lbnRSZWY7XG5cbiAgY2hlY2tlZCA9IGZhbHNlO1xuICBuYW1lID0gJyc7XG5cbiAgcHJvdGVjdGVkIF92YWx1ZTogdW5rbm93bjtcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHZhbHVlJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0KHRoaXMudmFsdWUpO1xuICBwcm90ZWN0ZWQgZGVzdHJveSQkID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcm90ZWN0ZWQgcmFkaW9Hcm91cDogUmFkaW9Hcm91cENvbXBvbmVudCxcbiAgICBwcm90ZWN0ZWQgZm9jdXNNb25pdG9yOiBGb2N1c01vbml0b3IsXG4gICAgcHJvdGVjdGVkIGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYsXG4gICkge31cblxuICBuZ09uSW5pdCgpIHtcbiAgICB0aGlzLnJhZGlvR3JvdXAubmFtZSQucGlwZSh0YWtlVW50aWwodGhpcy5kZXN0cm95JCQpKS5zdWJzY3JpYmUobmFtZSA9PiB7XG4gICAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICAgICAgdGhpcy5jZHIubWFya0ZvckNoZWNrKCk7XG4gICAgfSk7XG5cbiAgICBjb21iaW5lTGF0ZXN0KFt0aGlzLnJhZGlvR3JvdXAubW9kZWwkLCB0aGlzLnZhbHVlJCRdKVxuICAgICAgLnBpcGUoXG4gICAgICAgIHRha2VVbnRpbCh0aGlzLmRlc3Ryb3kkJCksXG4gICAgICAgIG1hcCgoW2dyb3VwVmFsdWUsIHNlbGZWYWx1ZV0pID0+IGdyb3VwVmFsdWUgPT09IHNlbGZWYWx1ZSksXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKGNoZWNrZWQgPT4ge1xuICAgICAgICB0aGlzLmNoZWNrZWQgPSBjaGVja2VkO1xuICAgICAgICB0aGlzLmNkci5tYXJrRm9yQ2hlY2soKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgbmdBZnRlclZpZXdJbml0KCkge1xuICAgIHRoaXMuZm9jdXNNb25pdG9yLm1vbml0b3IodGhpcy5lbFJlZi5uYXRpdmVFbGVtZW50LCB0cnVlKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCkge1xuICAgIHRoaXMuZGVzdHJveSQkLm5leHQoKTtcbiAgICB0aGlzLmZvY3VzTW9uaXRvci5zdG9wTW9uaXRvcmluZyh0aGlzLmVsUmVmLm5hdGl2ZUVsZW1lbnQpO1xuICB9XG5cbiAgb25DbGljaygpIHtcbiAgICBpZiAodGhpcy5jaGVja2VkIHx8IHRoaXMuZGlzYWJsZWQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy5yYWRpb0dyb3VwLm9uUmFkaW9DaGFuZ2UodGhpcy52YWx1ZSk7XG4gIH1cblxuICBvbkJsdXIoKSB7XG4gICAgdGhpcy5yYWRpb0dyb3VwLm9uUmFkaW9CbHVyKCk7XG4gIH1cbn1cbiJdfQ==
|