asksuite-citrus 3.15.7-beta.1 → 3.15.7-beta.3

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 (34) hide show
  1. package/esm2022/lib/components/accordion/extendable-panel/extendable-panel.component.mjs +2 -2
  2. package/esm2022/lib/components/arrow-tag/arrow-tag.component.mjs +2 -2
  3. package/esm2022/lib/components/autocomplete/autocomplete.component.mjs +2 -2
  4. package/esm2022/lib/components/avatar/avatar.component.mjs +2 -2
  5. package/esm2022/lib/components/box/box.component.mjs +2 -2
  6. package/esm2022/lib/components/button/button.component.mjs +2 -2
  7. package/esm2022/lib/components/character-counter/character-counter.component.mjs +2 -2
  8. package/esm2022/lib/components/checkbox/checkbox.component.mjs +2 -2
  9. package/esm2022/lib/components/chips/chips.component.mjs +2 -2
  10. package/esm2022/lib/components/date-picker/date-picker-calendar/date-picker-calendar.component.mjs +2 -2
  11. package/esm2022/lib/components/date-picker/date-picker.component.mjs +2 -2
  12. package/esm2022/lib/components/dropdown-container/dropdown-container.component.mjs +2 -2
  13. package/esm2022/lib/components/input/input.component.mjs +2 -2
  14. package/esm2022/lib/components/modal/confirmation-modal/confirmation-modal.component.mjs +2 -2
  15. package/esm2022/lib/components/modal/modal.component.mjs +2 -2
  16. package/esm2022/lib/components/pagination/pagination.component.mjs +2 -2
  17. package/esm2022/lib/components/phone-ddi/phone-ddi.component.mjs +2 -2
  18. package/esm2022/lib/components/richtext-toolbox/richtext-toolbox.component.mjs +2 -2
  19. package/esm2022/lib/components/richtext-url-prompt/richtext-url-prompt.component.mjs +2 -2
  20. package/esm2022/lib/components/select/select.component.mjs +2 -2
  21. package/esm2022/lib/components/tab-group/tab/tab.component.mjs +2 -2
  22. package/esm2022/lib/components/tab-group/tab-group.component.mjs +2 -2
  23. package/esm2022/lib/components/table/table.component.mjs +2 -2
  24. package/esm2022/lib/components/toast/toast.component.mjs +2 -2
  25. package/esm2022/lib/services/dynamic-dropdown/dynamic-dropdown.service.mjs +9 -4
  26. package/esm2022/lib/services/theme/theme.service.mjs +1 -1
  27. package/fesm2022/asksuite-citrus.mjs +56 -51
  28. package/fesm2022/asksuite-citrus.mjs.map +1 -1
  29. package/lib/services/dynamic-dropdown/dynamic-dropdown.service.d.ts +2 -2
  30. package/lib/services/theme/theme.service.d.ts +2 -1
  31. package/package.json +1 -1
  32. package/styles/colors-dark.scss +1 -0
  33. package/styles/colors-light.scss +2 -0
  34. package/styles/old-theme.scss +1 -0
@@ -14,8 +14,7 @@ export class DynamicDropdownService {
14
14
  * Opens a new modal with the given configuration.
15
15
  */
16
16
  open(config) {
17
- const positionParams = Array.isArray(config.positionParams) ? config.positionParams : [config.positionParams];
18
- const overlayRef = this.createOverlay(config.referenceElement, positionParams, config.closeOnOutsideClick);
17
+ const overlayRef = this.createOverlay(config.referenceElement, config.positionParams, config.closeOnOutsideClick);
19
18
  this.overlayRefs.push(overlayRef);
20
19
  const portal = this.attachTemplateToOverlay(config.templateToRender, config.viewContainerRef, overlayRef);
21
20
  const afterClosed$ = this.createAfterClosedSubject();
@@ -34,10 +33,16 @@ export class DynamicDropdownService {
34
33
  * Creates a flexible position strategy for the modal based on the base element.
35
34
  */
36
35
  createPositionStrategy(baseElement, positionParams) {
36
+ const a = [
37
+ // { panelClass: 'ask-dropdown-top-right', originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top' },
38
+ // { panelClass: 'ask-dropdown-top-left', originX: 'start', originY: 'top', overlayX: 'end', overlayY: 'top' },
39
+ { panelClass: 'ask-dropdown-bottom-right', originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top' },
40
+ // { panelClass: 'ask-dropdown-bottom-left', originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top' }
41
+ ];
37
42
  return this.overlay
38
43
  .position()
39
44
  .flexibleConnectedTo(baseElement)
40
- .withPositions(positionParams)
45
+ .withPositions(a)
41
46
  .withFlexibleDimensions(false)
42
47
  .withPush(false);
43
48
  }
@@ -117,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
117
122
  providedIn: 'root',
118
123
  }]
119
124
  }], ctorParameters: () => [{ type: i1.Overlay }] });
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-dropdown.service.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/services/dynamic-dropdown/dynamic-dropdown.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, TemplateRef, ViewContainerRef, Injector } from '@angular/core';\nimport { Overlay, OverlayRef, PositionStrategy, OverlayConfig, ConnectedPosition } from '@angular/cdk/overlay';\nimport { ComponentPortal, TemplatePortal } from '@angular/cdk/portal';\nimport { Subject } from 'rxjs';\nimport { DropdownContainerComponent } from '../../components/dropdown-container/dropdown-container.component';\n\nexport interface DropdownConfig {\n  templateToRender: TemplateRef<any>;\n  viewContainerRef: ViewContainerRef;\n  referenceElement: HTMLElement;\n  positionParams: ConnectedPosition | ConnectedPosition[];\n  closeOnOutsideClick?: boolean;\n}\n\nexport interface DropdownRef {\n  close: (result?: any) => void;\n  afterClosed: Subject<any>;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class DynamicDropdownService {\n  private overlayRefs: OverlayRef[] = [];\n\n  constructor(private overlay: Overlay) {}\n\n  /**\n   * Opens a new modal with the given configuration.\n   */\n  open(config: DropdownConfig): DropdownRef {\n    const positionParams = Array.isArray(config.positionParams) ? config.positionParams : [config.positionParams];\n    const overlayRef = this.createOverlay(config.referenceElement, positionParams, config.closeOnOutsideClick!);\n    this.overlayRefs.push(overlayRef);\n\n    const portal = this.attachTemplateToOverlay(config.templateToRender, config.viewContainerRef, overlayRef);\n    const afterClosed$ = this.createAfterClosedSubject();\n\n    this.setupOverlayListeners(overlayRef, config.closeOnOutsideClick!, afterClosed$);\n\n    return this.createModalRef(overlayRef, afterClosed$);\n  }\n\n  /**\n   * Creates an overlay with the specified position and configuration.\n   */\n  private createOverlay(baseElement: HTMLElement, positionParams: ConnectedPosition[], closeOnOutsideClick: boolean): OverlayRef {\n    const positionStrategy = this.createPositionStrategy(baseElement, positionParams);\n    const overlayConfig = this.createOverlayConfig(positionStrategy, closeOnOutsideClick);\n\n    return this.overlay.create(overlayConfig);\n  }\n\n  /**\n   * Creates a flexible position strategy for the modal based on the base element.\n   */\n  private createPositionStrategy(baseElement: HTMLElement, positionParams: ConnectedPosition[]): PositionStrategy {\n    return this.overlay\n      .position()\n      .flexibleConnectedTo(baseElement)\n      .withPositions(positionParams)\n      .withFlexibleDimensions(false)\n      .withPush(false);\n  }\n\n  /**\n   * Creates the configuration for the overlay.\n   */\n  private createOverlayConfig(positionStrategy: PositionStrategy, closeOnOutsideClick: boolean): OverlayConfig {\n    return new OverlayConfig({\n      hasBackdrop: closeOnOutsideClick,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n    });\n  }\n\n  /**\n   * Attaches the specified template to the overlay.\n   */\n  private attachTemplateToOverlay(\n    templateRef: TemplateRef<any>,\n    viewContainerRef: ViewContainerRef,\n    overlayRef: OverlayRef,\n  ) {\n    const portal = new ComponentPortal(DropdownContainerComponent, viewContainerRef)\n    const componentRef = overlayRef.attach(portal);\n    componentRef.instance.content = templateRef;\n    return portal;\n  }\n\n  /**\n   * Sets up listeners for the overlay, such as closing on backdrop click or escape key.\n   */\n  private setupOverlayListeners(overlayRef: OverlayRef, closeOnOutsideClick: boolean, afterClosed$: Subject<any>): void {\n    if (closeOnOutsideClick) {\n      overlayRef.backdropClick().subscribe(() => this.closeModal(overlayRef, null, afterClosed$));\n    }\n\n    overlayRef.keydownEvents().subscribe((event) => {\n      if (event.key === 'Escape') {\n        this.closeModal(overlayRef, null, afterClosed$);\n      }\n    });\n  }\n\n  /**\n   * Creates a subject that will emit when the modal is closed.\n   */\n  private createAfterClosedSubject(): Subject<any> {\n    return new Subject<any>();\n  }\n\n  /**\n   * Creates a reference for the modal that can be used to control the modal's lifecycle.\n   */\n  private createModalRef(overlayRef: OverlayRef, afterClosed$: Subject<any>): DropdownRef {\n    return {\n      close: (result?: any) => this.closeModal(overlayRef, result, afterClosed$),\n      afterClosed: afterClosed$,\n    };\n  }\n\n  /**\n   * Closes the modal and cleans up resources.\n   */\n  private closeModal(overlayRef: OverlayRef, result: any, subject: Subject<any>): void {\n    const index = this.overlayRefs.indexOf(overlayRef);\n    if (index > -1) {\n      this.overlayRefs.splice(index, 1);\n    }\n    overlayRef.dispose();\n    subject.next(result);\n    subject.complete();\n  }\n\n  /**\n   * Closes all open modals.\n   */\n  closeAll(): void {\n    this.overlayRefs.forEach(ref => ref.dispose());\n    this.overlayRefs = [];\n  }\n}\n"]}
125
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-dropdown.service.js","sourceRoot":"","sources":["../../../../../../projects/asksuite-citrus/src/lib/services/dynamic-dropdown/dynamic-dropdown.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, TemplateRef, ViewContainerRef, Injector } from '@angular/core';\nimport { Overlay, OverlayRef, PositionStrategy, OverlayConfig, ConnectedPosition } from '@angular/cdk/overlay';\nimport { ComponentPortal, TemplatePortal } from '@angular/cdk/portal';\nimport { Subject } from 'rxjs';\nimport { DropdownContainerComponent } from '../../components/dropdown-container/dropdown-container.component';\n\nexport interface DropdownConfig {\n  templateToRender: TemplateRef<any>;\n  viewContainerRef: ViewContainerRef;\n  referenceElement: HTMLElement;\n  positionParams: any;\n  closeOnOutsideClick?: boolean;\n}\n\nexport interface DropdownRef {\n  close: (result?: any) => void;\n  afterClosed: Subject<any>;\n}\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class DynamicDropdownService {\n  private overlayRefs: OverlayRef[] = [];\n\n  constructor(private overlay: Overlay) {}\n\n  /**\n   * Opens a new modal with the given configuration.\n   */\n  open(config: DropdownConfig): DropdownRef {\n    const overlayRef = this.createOverlay(config.referenceElement, config.positionParams, config.closeOnOutsideClick!);\n    this.overlayRefs.push(overlayRef);\n\n    const portal = this.attachTemplateToOverlay(config.templateToRender, config.viewContainerRef, overlayRef);\n    const afterClosed$ = this.createAfterClosedSubject();\n\n    this.setupOverlayListeners(overlayRef, config.closeOnOutsideClick!, afterClosed$);\n\n    return this.createModalRef(overlayRef, afterClosed$);\n  }\n\n  /**\n   * Creates an overlay with the specified position and configuration.\n   */\n  private createOverlay(baseElement: HTMLElement, positionParams: any, closeOnOutsideClick: boolean): OverlayRef {\n    const positionStrategy = this.createPositionStrategy(baseElement, positionParams);\n    const overlayConfig = this.createOverlayConfig(positionStrategy, closeOnOutsideClick);\n\n    return this.overlay.create(overlayConfig);\n  }\n\n  /**\n   * Creates a flexible position strategy for the modal based on the base element.\n   */\n  private createPositionStrategy(baseElement: HTMLElement, positionParams: any): PositionStrategy {\n     const a:ConnectedPosition[] = [\n      // { panelClass: 'ask-dropdown-top-right', originX: 'end', originY: 'top', overlayX: 'start', overlayY: 'top' },\n      // { panelClass: 'ask-dropdown-top-left', originX: 'start', originY: 'top', overlayX: 'end', overlayY: 'top' },\n      { panelClass: 'ask-dropdown-bottom-right', originX: 'end', originY: 'bottom', overlayX: 'end', overlayY: 'top' },\n      // { panelClass: 'ask-dropdown-bottom-left', originX: 'start', originY: 'bottom', overlayX: 'start', overlayY: 'top' }\n    ]\n\n\n    return this.overlay\n      .position()\n      .flexibleConnectedTo(baseElement)\n      .withPositions(a)\n      .withFlexibleDimensions(false)\n      .withPush(false);\n  }\n\n  /**\n   * Creates the configuration for the overlay.\n   */\n  private createOverlayConfig(positionStrategy: PositionStrategy, closeOnOutsideClick: boolean): OverlayConfig {\n    return new OverlayConfig({\n      hasBackdrop: closeOnOutsideClick,\n      backdropClass: 'cdk-overlay-transparent-backdrop',\n      positionStrategy,\n      scrollStrategy: this.overlay.scrollStrategies.block(),\n    });\n  }\n\n  /**\n   * Attaches the specified template to the overlay.\n   */\n  private attachTemplateToOverlay(\n    templateRef: TemplateRef<any>,\n    viewContainerRef: ViewContainerRef,\n    overlayRef: OverlayRef,\n  ) {\n    const portal = new ComponentPortal(DropdownContainerComponent, viewContainerRef)\n    const componentRef = overlayRef.attach(portal);\n    componentRef.instance.content = templateRef;\n    return portal;\n  }\n\n  /**\n   * Sets up listeners for the overlay, such as closing on backdrop click or escape key.\n   */\n  private setupOverlayListeners(overlayRef: OverlayRef, closeOnOutsideClick: boolean, afterClosed$: Subject<any>): void {\n    if (closeOnOutsideClick) {\n      overlayRef.backdropClick().subscribe(() => this.closeModal(overlayRef, null, afterClosed$));\n    }\n\n    overlayRef.keydownEvents().subscribe((event) => {\n      if (event.key === 'Escape') {\n        this.closeModal(overlayRef, null, afterClosed$);\n      }\n    });\n  }\n\n  /**\n   * Creates a subject that will emit when the modal is closed.\n   */\n  private createAfterClosedSubject(): Subject<any> {\n    return new Subject<any>();\n  }\n\n  /**\n   * Creates a reference for the modal that can be used to control the modal's lifecycle.\n   */\n  private createModalRef(overlayRef: OverlayRef, afterClosed$: Subject<any>): DropdownRef {\n    return {\n      close: (result?: any) => this.closeModal(overlayRef, result, afterClosed$),\n      afterClosed: afterClosed$,\n    };\n  }\n\n  /**\n   * Closes the modal and cleans up resources.\n   */\n  private closeModal(overlayRef: OverlayRef, result: any, subject: Subject<any>): void {\n    const index = this.overlayRefs.indexOf(overlayRef);\n    if (index > -1) {\n      this.overlayRefs.splice(index, 1);\n    }\n    overlayRef.dispose();\n    subject.next(result);\n    subject.complete();\n  }\n\n  /**\n   * Closes all open modals.\n   */\n  closeAll(): void {\n    this.overlayRefs.forEach(ref => ref.dispose());\n    this.overlayRefs = [];\n  }\n}\n"]}
@@ -34,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
34
34
  providedIn: 'root'
35
35
  }]
36
36
  }], ctorParameters: () => [{ type: i1.StorageUtilService }] });
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fza3N1aXRlLWNpdHJ1cy9zcmMvbGliL3NlcnZpY2VzL3RoZW1lL3RoZW1lLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7QUFPdkMsTUFBTSxPQUFPLFlBQVk7SUFJdkIsWUFBNkIsa0JBQTZDO1FBQTdDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBMkI7UUFIMUUsYUFBUSxHQUFHLHNCQUFzQixDQUFDO1FBQ2xDLFdBQU0sR0FBRyxJQUFJLGVBQWUsQ0FBUSxPQUFPLENBQUMsQ0FBQztRQUczQyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxPQUFPLENBQUM7UUFDeEUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztJQUMzQixDQUFDO0lBRUQsUUFBUSxDQUFDLEtBQVk7UUFDbkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxpQkFBaUI7UUFDZixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDcEMsQ0FBQztJQUVPLFNBQVM7UUFDZixRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQTtRQUMzQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUNuRSxDQUFDOzhHQTFCVSxZQUFZO2tIQUFaLFlBQVksY0FGWCxNQUFNOzsyRkFFUCxZQUFZO2tCQUh4QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN0b3JhZ2VVdGlsU2VydmljZX0gZnJvbSBcIi4uL3N0b3JhZ2Uvc3RvcmFnZS11dGlsLnNlcnZpY2VcIjtcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgdHlwZSBUaGVtZSA9ICdkYXJrJyB8ICdsaWdodCc7XG5cbkBJbmplY3RhYmxlKHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXG59KVxuZXhwb3J0IGNsYXNzIFRoZW1lU2VydmljZSB7XG4gIHRoZW1lS2V5ID0gJ2Fza3N1aXRlLXRoZW1lLWNvbG9yJztcbiAgdGhlbWUkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxUaGVtZT4oJ2xpZ2h0Jyk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBzdG9yYWdlVXRpbFNlcnZpY2U6IFN0b3JhZ2VVdGlsU2VydmljZTxUaGVtZT4pIHtcbiAgICBjb25zdCB0aGVtZSA9IHRoaXMuc3RvcmFnZVV0aWxTZXJ2aWNlLmdldEl0ZW0odGhpcy50aGVtZUtleSkgfHwgJ2xpZ2h0JztcbiAgICB0aGlzLnRoZW1lJC5uZXh0KHRoZW1lKTtcbiAgICB0aGlzLnNhdmVUaGVtZSgpO1xuICB9XG5cbiAgZ2V0VGhlbWUoKXtcbiAgICByZXR1cm4gdGhpcy50aGVtZSQudmFsdWU7XG4gIH1cblxuICBzZXRUaGVtZSh0aGVtZTogVGhlbWUpIHtcbiAgICB0aGlzLnRoZW1lJC5uZXh0KHRoZW1lKTtcbiAgICB0aGlzLnNhdmVUaGVtZSgpO1xuICB9XG5cbiAgbGlzdGVuVGhlbWVDaGFuZ2UoKXtcbiAgICByZXR1cm4gdGhpcy50aGVtZSQuYXNPYnNlcnZhYmxlKCk7XG4gIH1cblxuICBwcml2YXRlIHNhdmVUaGVtZSgpe1xuICAgIGRvY3VtZW50LmJvZHkuY2xhc3NOYW1lID0gdGhpcy50aGVtZSQudmFsdWVcbiAgICB0aGlzLnN0b3JhZ2VVdGlsU2VydmljZS5zZXRJdGVtKHRoaXMudGhlbWVLZXksIHRoaXMudGhlbWUkLnZhbHVlKVxuICB9XG59XG4iXX0=
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Fza3N1aXRlLWNpdHJ1cy9zcmMvbGliL3NlcnZpY2VzL3RoZW1lL3RoZW1lLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sTUFBTSxDQUFDOzs7QUFPdkMsTUFBTSxPQUFPLFlBQVk7SUFJdkIsWUFBNkIsa0JBQTZDO1FBQTdDLHVCQUFrQixHQUFsQixrQkFBa0IsQ0FBMkI7UUFIMUUsYUFBUSxHQUFHLHNCQUFzQixDQUFDO1FBQ2xDLFdBQU0sR0FBRyxJQUFJLGVBQWUsQ0FBUSxPQUFPLENBQUMsQ0FBQztRQUczQyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxPQUFPLENBQUM7UUFDeEUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQztJQUMzQixDQUFDO0lBRUQsUUFBUSxDQUFDLEtBQVk7UUFDbkIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDeEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFRCxpQkFBaUI7UUFDZixPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDcEMsQ0FBQztJQUVPLFNBQVM7UUFDZixRQUFRLENBQUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQTtRQUMzQyxJQUFJLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQTtJQUNuRSxDQUFDOzhHQTFCVSxZQUFZO2tIQUFaLFlBQVksY0FGWCxNQUFNOzsyRkFFUCxZQUFZO2tCQUh4QixVQUFVO21CQUFDO29CQUNWLFVBQVUsRUFBRSxNQUFNO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN0b3JhZ2VVdGlsU2VydmljZX0gZnJvbSBcIi4uL3N0b3JhZ2Uvc3RvcmFnZS11dGlsLnNlcnZpY2VcIjtcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuXG50eXBlIFRoZW1lID0gJ2RhcmsnIHwgJ2xpZ2h0JztcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgVGhlbWVTZXJ2aWNlIHtcbiAgdGhlbWVLZXkgPSAnYXNrc3VpdGUtdGhlbWUtY29sb3InO1xuICB0aGVtZSQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFRoZW1lPignbGlnaHQnKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHN0b3JhZ2VVdGlsU2VydmljZTogU3RvcmFnZVV0aWxTZXJ2aWNlPFRoZW1lPikge1xuICAgIGNvbnN0IHRoZW1lID0gdGhpcy5zdG9yYWdlVXRpbFNlcnZpY2UuZ2V0SXRlbSh0aGlzLnRoZW1lS2V5KSB8fCAnbGlnaHQnO1xuICAgIHRoaXMudGhlbWUkLm5leHQodGhlbWUpO1xuICAgIHRoaXMuc2F2ZVRoZW1lKCk7XG4gIH1cblxuICBnZXRUaGVtZSgpe1xuICAgIHJldHVybiB0aGlzLnRoZW1lJC52YWx1ZTtcbiAgfVxuXG4gIHNldFRoZW1lKHRoZW1lOiBUaGVtZSkge1xuICAgIHRoaXMudGhlbWUkLm5leHQodGhlbWUpO1xuICAgIHRoaXMuc2F2ZVRoZW1lKCk7XG4gIH1cblxuICBsaXN0ZW5UaGVtZUNoYW5nZSgpe1xuICAgIHJldHVybiB0aGlzLnRoZW1lJC5hc09ic2VydmFibGUoKTtcbiAgfVxuXG4gIHByaXZhdGUgc2F2ZVRoZW1lKCl7XG4gICAgZG9jdW1lbnQuYm9keS5jbGFzc05hbWUgPSB0aGlzLnRoZW1lJC52YWx1ZVxuICAgIHRoaXMuc3RvcmFnZVV0aWxTZXJ2aWNlLnNldEl0ZW0odGhpcy50aGVtZUtleSwgdGhpcy50aGVtZSQudmFsdWUpXG4gIH1cbn1cbiJdfQ==