@ngutil/layout 0.0.63 → 0.0.64

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.
@@ -1,6 +1,6 @@
1
1
  import * as i0 from "@angular/core";
2
2
  export declare class DockingBackdropComponent {
3
- state: "visible" | "hidden";
3
+ readonly visible: import("@angular/core").InputSignal<unknown>;
4
4
  static ɵfac: i0.ɵɵFactoryDeclaration<DockingBackdropComponent, never>;
5
- static ɵcmp: i0.ɵɵComponentDeclaration<DockingBackdropComponent, "nu-docking-backdrop", never, {}, {}, never, never, true, never>;
5
+ static ɵcmp: i0.ɵɵComponentDeclaration<DockingBackdropComponent, "nu-docking-backdrop", never, { "visible": { "alias": "visible"; "required": true; "isSignal": true; }; }, {}, never, never, true, never>;
6
6
  }
@@ -1,24 +1,18 @@
1
- import { AfterViewInit, ElementRef, OnChanges, QueryList, SimpleChanges } from "@angular/core";
2
- import { Observable } from "rxjs";
3
- import { Destructible } from "@ngutil/common";
4
- import { DockingContentComponent } from "./docking-content.component";
5
1
  import { DockingPanelComponent } from "./docking-panel.component";
6
2
  import * as i0 from "@angular/core";
7
3
  type DockingVerticalPosition = "top" | "middle" | "bottom";
8
4
  type DockingHorizontalPositon = "left" | "center" | "right";
9
5
  type DockingPosition = `${DockingVerticalPosition}:${DockingHorizontalPositon}`;
10
6
  export type DockingRange = DockingVerticalPosition | DockingHorizontalPositon | DockingPosition | `${DockingPosition}-${DockingPosition}`;
11
- export declare class DockingLayoutComponent extends Destructible implements AfterViewInit, OnChanges {
12
- #private;
13
- contentOnly: boolean;
14
- contentComponent?: DockingContentComponent;
15
- backdropEl?: ElementRef<HTMLElement>;
16
- dockingPanels: QueryList<DockingPanelComponent>;
17
- readonly panels: Observable<Array<DockingPanelComponent>>;
18
- ngAfterViewInit(): void;
19
- ngOnChanges(changes: SimpleChanges): void;
20
- onHideBackdropPanel(event: Event): void;
7
+ export declare class DockingLayoutComponent {
8
+ /**
9
+ * True if u want to animate panel open/close with `mode="side"`
10
+ */
11
+ readonly panels: import("@angular/core").Signal<readonly DockingPanelComponent[]>;
12
+ readonly activeOverPanel: import("@angular/core").Signal<DockingPanelComponent | undefined>;
13
+ readonly backdropVisible: import("@angular/core").Signal<boolean>;
14
+ doCloseActiveOverPanel(): void;
21
15
  static ɵfac: i0.ɵɵFactoryDeclaration<DockingLayoutComponent, never>;
22
- static ɵcmp: i0.ɵɵComponentDeclaration<DockingLayoutComponent, "nu-docking", never, { "contentOnly": { "alias": "contentOnly"; "required": false; }; }, {}, ["contentComponent", "dockingPanels"], ["nu-docking-panel", "*", "nu-docking-content"], true, never>;
16
+ static ɵcmp: i0.ɵɵComponentDeclaration<DockingLayoutComponent, "nu-docking", ["nuDocking"], {}, {}, ["panels"], ["*"], true, never>;
23
17
  }
24
18
  export {};
@@ -1,47 +1,27 @@
1
- import { AfterViewInit, ElementRef } from "@angular/core";
2
- import { BehaviorSubject, Observable } from "rxjs";
3
- import { BooleanInput, Destructible, NumberWithUnit, NumberWithUnitInput } from "@ngutil/common";
4
- import { L9Range, L9RangeName } from "../l9/range";
1
+ import { ElementRef } from "@angular/core";
2
+ import { L9Range } from "../l9/range";
5
3
  import * as i0 from "@angular/core";
6
4
  export type DockingPanelState = "full" | "mini" | "hidden";
7
5
  export type DockingPanelMode = "over" | "push" | "rigid";
8
- export declare class DockingPanelComponent extends Destructible implements AfterViewInit {
6
+ export type BackdropMode = boolean | "full" | "panel-size";
7
+ export declare class DockingPanelComponent {
9
8
  #private;
10
9
  readonly el: ElementRef<any>;
11
- readonly content: ElementRef<HTMLElement>;
12
- set positionInput(val: L9Range | L9RangeName);
13
- readonly position: BehaviorSubject<L9Range>;
14
- set stateInput(val: DockingPanelState);
15
- readonly state: BehaviorSubject<DockingPanelState>;
16
- set modeInput(val: DockingPanelMode);
17
- readonly mode: BehaviorSubject<DockingPanelMode>;
18
- set fullSizeInput(val: NumberWithUnitInput);
19
- set miniSizeInput(val: NumberWithUnitInput);
20
- set minimizable(val: BooleanInput);
21
- get minimizable(): boolean;
22
- set backdrop(val: BooleanInput);
23
- get backdrop(): boolean;
24
- readonly fullSize: Observable<NumberWithUnit>;
25
- readonly miniSize: Observable<NumberWithUnit>;
26
- readonly changes: Observable<{
27
- position: L9Range;
28
- state: DockingPanelState;
29
- mode: DockingPanelMode;
30
- fullSize: NumberWithUnit;
31
- miniSize: NumberWithUnit;
32
- contentSize: {
33
- width: NumberWithUnit;
34
- height: NumberWithUnit;
35
- };
36
- }>;
37
- constructor();
38
- ngAfterViewInit(): void;
10
+ readonly position: import("@angular/core").InputSignalWithTransform<L9Range, import("../l9/range").L9RangeName | L9Range>;
11
+ readonly opened: import("@angular/core").ModelSignal<boolean>;
12
+ readonly _opened: import("@angular/core").Signal<boolean>;
13
+ readonly mode: import("@angular/core").InputSignal<DockingPanelMode>;
14
+ readonly maxSize: import("@angular/core").InputSignal<number | null | undefined>;
15
+ readonly backdrop: import("@angular/core").InputSignal<BackdropMode>;
16
+ readonly gridArea: import("@angular/core").Signal<string>;
17
+ readonly orient: import("@angular/core").Signal<import("../l9/range").L9Orient>;
18
+ readonly side: import("@angular/core").Signal<"top" | "middle" | "bottom" | "left" | "center" | "right">;
19
+ readonly content: import("@angular/core").Signal<ElementRef<any>>;
20
+ readonly dimension$: import("rxjs").Observable<import("@ngutil/style").Dimension>;
21
+ readonly dimension: import("@angular/core").Signal<import("@ngutil/style").Dimension | undefined>;
22
+ readonly contentSize: import("@angular/core").Signal<number>;
39
23
  open(): void;
40
24
  close(): void;
41
- minimize(): void;
42
25
  static ɵfac: i0.ɵɵFactoryDeclaration<DockingPanelComponent, never>;
43
- static ɵcmp: i0.ɵɵComponentDeclaration<DockingPanelComponent, "nu-docking-panel", ["nuDockingPanel"], { "positionInput": { "alias": "position"; "required": false; }; "stateInput": { "alias": "state"; "required": false; }; "modeInput": { "alias": "mode"; "required": false; }; "fullSizeInput": { "alias": "fullSize"; "required": false; }; "miniSizeInput": { "alias": "miniSize"; "required": false; }; "minimizable": { "alias": "minimizable"; "required": false; }; "backdrop": { "alias": "backdrop"; "required": false; }; }, { "state": "stateChanges"; }, never, ["*"], true, never>;
26
+ static ɵcmp: i0.ɵɵComponentDeclaration<DockingPanelComponent, "nu-docking-panel", ["nuDockingPanel"], { "position": { "alias": "position"; "required": false; "isSignal": true; }; "opened": { "alias": "opened"; "required": false; "isSignal": true; }; "mode": { "alias": "mode"; "required": false; "isSignal": true; }; "maxSize": { "alias": "maxSize"; "required": false; "isSignal": true; }; "backdrop": { "alias": "backdrop"; "required": false; "isSignal": true; }; }, { "opened": "openedChange"; }, never, ["*"], true, never>;
44
27
  }
45
- type ChangesObservable = typeof DockingPanelComponent.prototype.changes;
46
- export type DockingPanelChanges = ChangesObservable extends Observable<infer T> ? T : never;
47
- export {};
@@ -1,17 +1,16 @@
1
- import { Component, HostBinding } from "@angular/core";
1
+ import { Component, input } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  export class DockingBackdropComponent {
4
4
  constructor() {
5
- this.state = "hidden";
5
+ this.visible = input.required();
6
6
  }
7
7
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DockingBackdropComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
8
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: DockingBackdropComponent, isStandalone: true, selector: "nu-docking-backdrop", host: { properties: { "[attr.state]": "this.state" } }, ngImport: i0, template: ``, isInline: true, styles: [":host{display:flex;flex-direction:column;align-items:stretch;position:absolute;inset:0;transition:opacity var(---docking-layout-anim-duration) var(---docking-layout-anim-ease);z-index:-1;background-color:var(---docking-layout-backdrop-color)}:host[state=hidden]{animation:var(---docking-layout-anim-duration) var(---docking-layout-anim-ease) hide;animation-fill-mode:forwards;pointer-events:none;touch-action:none;opacity:0}:host[state=visible]{visibility:visible;opacity:.3}@keyframes hide{99%{visibility:visible}to{visibility:hidden}}\n"] }); }
8
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.6", type: DockingBackdropComponent, isStandalone: true, selector: "nu-docking-backdrop", inputs: { visible: { classPropertyName: "visible", publicName: "visible", isSignal: true, isRequired: true, transformFunction: null } }, host: { properties: { "attr.state": "visible() ? 'visible' : 'hidden'" } }, ngImport: i0, template: ``, isInline: true, styles: [":host{display:flex;flex-direction:column;align-items:stretch;position:absolute;inset:0;transition:opacity .2s cubic-bezier(0,0,.2,1);z-index:200;background-color:#000}:host[state=hidden]{animation:.2s cubic-bezier(0,0,.2,1) hide;animation-fill-mode:forwards;pointer-events:none;touch-action:none;opacity:0}:host[state=visible]{visibility:visible;opacity:.7}@keyframes hide{99%{visibility:visible}to{visibility:hidden}}\n"] }); }
9
9
  }
10
10
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DockingBackdropComponent, decorators: [{
11
11
  type: Component,
12
- args: [{ standalone: true, selector: "nu-docking-backdrop", template: ``, styles: [":host{display:flex;flex-direction:column;align-items:stretch;position:absolute;inset:0;transition:opacity var(---docking-layout-anim-duration) var(---docking-layout-anim-ease);z-index:-1;background-color:var(---docking-layout-backdrop-color)}:host[state=hidden]{animation:var(---docking-layout-anim-duration) var(---docking-layout-anim-ease) hide;animation-fill-mode:forwards;pointer-events:none;touch-action:none;opacity:0}:host[state=visible]{visibility:visible;opacity:.3}@keyframes hide{99%{visibility:visible}to{visibility:hidden}}\n"] }]
13
- }], propDecorators: { state: [{
14
- type: HostBinding,
15
- args: ["[attr.state]"]
16
- }] } });
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1iYWNrZHJvcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sYXlvdXQvc3JjL2RvY2tpbmcvZG9ja2luZy1iYWNrZHJvcC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBUXRELE1BQU0sT0FBTyx3QkFBd0I7SUFOckM7UUFRSSxVQUFLLEdBQXlCLFFBQVEsQ0FBQTtLQUN6Qzs4R0FIWSx3QkFBd0I7a0dBQXhCLHdCQUF3Qix1SUFGdkIsRUFBRTs7MkZBRUgsd0JBQXdCO2tCQU5wQyxTQUFTO2lDQUNNLElBQUksWUFDTixxQkFBcUIsWUFFckIsRUFBRTs4QkFJWixLQUFLO3NCQURKLFdBQVc7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSG9zdEJpbmRpbmcgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiXG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6IFwibnUtZG9ja2luZy1iYWNrZHJvcFwiLFxuICAgIHN0eWxlVXJsOiBcIi4vZG9ja2luZy1iYWNrZHJvcC5jb21wb25lbnQuc2Nzc1wiLFxuICAgIHRlbXBsYXRlOiBgYFxufSlcbmV4cG9ydCBjbGFzcyBEb2NraW5nQmFja2Ryb3BDb21wb25lbnQge1xuICAgIEBIb3N0QmluZGluZyhcIlthdHRyLnN0YXRlXVwiKVxuICAgIHN0YXRlOiBcInZpc2libGVcIiB8IFwiaGlkZGVuXCIgPSBcImhpZGRlblwiXG59XG4iXX0=
12
+ args: [{ standalone: true, selector: "nu-docking-backdrop", host: {
13
+ "[attr.state]": "visible() ? 'visible' : 'hidden'"
14
+ }, template: ``, styles: [":host{display:flex;flex-direction:column;align-items:stretch;position:absolute;inset:0;transition:opacity .2s cubic-bezier(0,0,.2,1);z-index:200;background-color:#000}:host[state=hidden]{animation:.2s cubic-bezier(0,0,.2,1) hide;animation-fill-mode:forwards;pointer-events:none;touch-action:none;opacity:0}:host[state=visible]{visibility:visible;opacity:.7}@keyframes hide{99%{visibility:visible}to{visibility:hidden}}\n"] }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1iYWNrZHJvcC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9sYXlvdXQvc3JjL2RvY2tpbmcvZG9ja2luZy1iYWNrZHJvcC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBV2hELE1BQU0sT0FBTyx3QkFBd0I7SUFUckM7UUFVYSxZQUFPLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFBO0tBQ3RDOzhHQUZZLHdCQUF3QjtrR0FBeEIsd0JBQXdCLG9TQUZ2QixFQUFFOzsyRkFFSCx3QkFBd0I7a0JBVHBDLFNBQVM7aUNBQ00sSUFBSSxZQUNOLHFCQUFxQixRQUN6Qjt3QkFDRixjQUFjLEVBQUUsa0NBQWtDO3FCQUNyRCxZQUVTLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGlucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiBcIm51LWRvY2tpbmctYmFja2Ryb3BcIixcbiAgICBob3N0OiB7XG4gICAgICAgIFwiW2F0dHIuc3RhdGVdXCI6IFwidmlzaWJsZSgpID8gJ3Zpc2libGUnIDogJ2hpZGRlbidcIlxuICAgIH0sXG4gICAgc3R5bGVVcmw6IFwiLi9kb2NraW5nLWJhY2tkcm9wLmNvbXBvbmVudC5zY3NzXCIsXG4gICAgdGVtcGxhdGU6IGBgXG59KVxuZXhwb3J0IGNsYXNzIERvY2tpbmdCYWNrZHJvcENvbXBvbmVudCB7XG4gICAgcmVhZG9ubHkgdmlzaWJsZSA9IGlucHV0LnJlcXVpcmVkKClcbn1cbiJdfQ==
@@ -2,10 +2,10 @@ import { Component } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  export class DockingContentComponent {
4
4
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DockingContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: DockingContentComponent, isStandalone: true, selector: "nu-docking-content", exportAs: ["nuDockingContent"], ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [":host{display:flex;flex-flow:column nowrap;align-items:stretch;box-sizing:border-box;flex:1;overflow:hidden}\n"] }); }
5
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.6", type: DockingContentComponent, isStandalone: true, selector: "nu-docking-content", exportAs: ["nuDockingContent"], ngImport: i0, template: `<ng-content></ng-content>`, isInline: true, styles: [":host{grid-column:2;grid-row:2;display:grid;grid-template-columns:1fr;grid-template-rows:1fr;align-items:stretch;justify-items:stretch;overflow:hidden;position:relative;z-index:10}\n"] }); }
6
6
  }
7
7
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DockingContentComponent, decorators: [{
8
8
  type: Component,
9
- args: [{ standalone: true, selector: "nu-docking-content", exportAs: "nuDockingContent", template: `<ng-content></ng-content>`, styles: [":host{display:flex;flex-flow:column nowrap;align-items:stretch;box-sizing:border-box;flex:1;overflow:hidden}\n"] }]
9
+ args: [{ selector: "nu-docking-content", exportAs: "nuDockingContent", standalone: true, template: `<ng-content></ng-content>`, styles: [":host{grid-column:2;grid-row:2;display:grid;grid-template-columns:1fr;grid-template-rows:1fr;align-items:stretch;justify-items:stretch;overflow:hidden;position:relative;z-index:10}\n"] }]
10
10
  }] });
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xheW91dC9zcmMvZG9ja2luZy9kb2NraW5nLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBU3pDLE1BQU0sT0FBTyx1QkFBdUI7OEdBQXZCLHVCQUF1QjtrR0FBdkIsdUJBQXVCLDhHQUZ0QiwyQkFBMkI7OzJGQUU1Qix1QkFBdUI7a0JBUG5DLFNBQVM7aUNBQ00sSUFBSSxZQUNOLG9CQUFvQixZQUNwQixrQkFBa0IsWUFFbEIsMkJBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiBcIm51LWRvY2tpbmctY29udGVudFwiLFxuICAgIGV4cG9ydEFzOiBcIm51RG9ja2luZ0NvbnRlbnRcIixcbiAgICBzdHlsZVVybDogXCIuL2RvY2tpbmctY29udGVudC5jb21wb25lbnQuc2Nzc1wiLFxuICAgIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PmBcbn0pXG5leHBvcnQgY2xhc3MgRG9ja2luZ0NvbnRlbnRDb21wb25lbnQge31cbiJdfQ==
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1jb250ZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2xheW91dC9zcmMvZG9ja2luZy9kb2NraW5nLWNvbnRlbnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUE7O0FBU3pDLE1BQU0sT0FBTyx1QkFBdUI7OEdBQXZCLHVCQUF1QjtrR0FBdkIsdUJBQXVCLDhHQUZ0QiwyQkFBMkI7OzJGQUU1Qix1QkFBdUI7a0JBUG5DLFNBQVM7K0JBQ0ksb0JBQW9CLFlBQ3BCLGtCQUFrQixjQUNoQixJQUFJLFlBRU4sMkJBQTJCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJudS1kb2NraW5nLWNvbnRlbnRcIixcbiAgICBleHBvcnRBczogXCJudURvY2tpbmdDb250ZW50XCIsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzdHlsZVVybDogXCIuL2RvY2tpbmctY29udGVudC5jb21wb25lbnQuc2Nzc1wiLFxuICAgIHRlbXBsYXRlOiBgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PmBcbn0pXG5leHBvcnQgY2xhc3MgRG9ja2luZ0NvbnRlbnRDb21wb25lbnQge31cbiJdfQ==
@@ -1,171 +1,40 @@
1
- import { ChangeDetectionStrategy, Component, ContentChild, ContentChildren, ElementRef, inject, Input, QueryList, ViewChild } from "@angular/core";
2
- import { combineLatest, map, shareReplay, startWith, Subject, switchMap } from "rxjs";
3
- import { Destructible, FastDOM } from "@ngutil/common";
1
+ import { Component, computed, contentChildren } from "@angular/core";
4
2
  import { DockingBackdropComponent } from "./docking-backdrop.component";
5
- import { DockingContentComponent } from "./docking-content.component";
6
3
  import { DockingPanelComponent } from "./docking-panel.component";
7
4
  import * as i0 from "@angular/core";
8
- const RIGID_ZINDEX = 100;
9
- const OVER_ZINDEX = RIGID_ZINDEX * 2;
10
- const BACKDROP_ZINDEX = 10000;
11
- export class DockingLayoutComponent extends Destructible {
5
+ export class DockingLayoutComponent {
12
6
  constructor() {
13
- super(...arguments);
14
- this.#el = inject((ElementRef));
15
- this.contentOnly = false;
16
- this.#reflow = new Subject();
17
- this.#backdropPanel = null;
7
+ /**
8
+ * True if u want to animate panel open/close with `mode="side"`
9
+ */
10
+ // readonly animateSide = input(false)
11
+ this.panels = contentChildren(DockingPanelComponent);
12
+ this.activeOverPanel = computed(() => {
13
+ const panels = this.panels();
14
+ return panels.find(panel => panel.mode() === "over" && panel.opened());
15
+ });
16
+ this.backdropVisible = computed(() => {
17
+ const active = this.activeOverPanel();
18
+ return active != null ? active.backdrop() !== false : false;
19
+ });
18
20
  }
19
- #el;
20
- #reflow;
21
- #backdropPanel;
22
- ngAfterViewInit() {
23
- // eslint-disable-next-line prettier/prettier
24
- this.panels = this.dockingPanels.changes.pipe(startWith(null), map(() => this.dockingPanels.toArray()), shareReplay(1));
25
- this.d
26
- .sub(combineLatest({ panels: this.panels, reflow: this.#reflow.pipe(startWith(null)) }))
27
- .pipe(switchMap(({ panels }) => combineLatest(panels.map(panel => panel.changes.pipe(map(changes => {
28
- return { panel, changes };
29
- }))))))
30
- .subscribe(this.#layout.bind(this));
31
- }
32
- ngOnChanges(changes) {
33
- if ("contentOnly" in changes || "positionMode" in changes) {
34
- this.#reflow.next();
35
- }
36
- }
37
- #layout(entries) {
38
- let paddingTop = 0;
39
- let paddingRight = 0;
40
- let paddingBottom = 0;
41
- let paddingLeft = 0;
42
- let rigidZIndex = RIGID_ZINDEX;
43
- let overZIndex = OVER_ZINDEX;
44
- let backdropZIndex = -1;
45
- this.#backdropPanel = null;
46
- if (this.contentOnly) {
47
- // TODO:...
48
- }
49
- else {
50
- for (const entry of entries) {
51
- const panelState = entry.changes;
52
- const panelSize = panelState.state === "full"
53
- ? panelState.fullSize.value
54
- : panelState.state === "mini"
55
- ? panelState.miniSize.value
56
- : 0;
57
- const isHorizontal = panelState.position.orient === "horizontal";
58
- const isRigid = panelState.mode === "rigid";
59
- let panelTop = null;
60
- let panelRight = null;
61
- let panelBottom = null;
62
- let panelLeft = null;
63
- if (isHorizontal) {
64
- panelLeft = 0;
65
- panelRight = 0;
66
- if (panelState.position.cells[0].v === "top") {
67
- if (isRigid) {
68
- paddingTop = Math.max(paddingTop, panelSize);
69
- }
70
- panelTop = 0;
71
- }
72
- else if (panelState.position.cells[0].v === "bottom") {
73
- if (isRigid) {
74
- paddingBottom = Math.max(paddingBottom, panelSize);
75
- }
76
- panelBottom = 0;
77
- }
78
- }
79
- else {
80
- panelTop = 0;
81
- panelBottom = 0;
82
- if (panelState.position.cells[0].h === "left") {
83
- if (isRigid) {
84
- paddingLeft = Math.max(paddingLeft, panelSize);
85
- }
86
- panelLeft = 0;
87
- }
88
- else if (panelState.position.cells[0].h === "right") {
89
- if (isRigid) {
90
- paddingRight = Math.max(paddingRight, panelSize);
91
- }
92
- panelRight = 0;
93
- }
94
- }
95
- let panelZIndex = isRigid ? (rigidZIndex += 2) : (overZIndex += 2);
96
- if (panelState.state !== "hidden" && entry.panel.backdrop) {
97
- backdropZIndex = BACKDROP_ZINDEX;
98
- panelZIndex = backdropZIndex + 1;
99
- this.#backdropPanel = entry.panel;
100
- }
101
- FastDOM.setStyle(entry.panel.el.nativeElement, {
102
- "z-index": `${panelZIndex}`,
103
- "--docking-panel-t": panelTop != null ? `${panelTop}px` : null,
104
- "--docking-panel-r": panelRight != null ? `${panelRight}px` : null,
105
- "--docking-panel-b": panelBottom != null ? `${panelBottom}px` : null,
106
- "--docking-panel-l": panelLeft != null ? `${panelLeft}px` : null
107
- });
108
- }
109
- FastDOM.setStyle(this.#el.nativeElement, {
110
- "--docking-layout-top": `${paddingTop}px`,
111
- "--docking-layout-right": `${paddingRight}px`,
112
- "--docking-layout-bottom": `${paddingBottom}px`,
113
- "--docking-layout-left": `${paddingLeft}px`
114
- });
115
- if (this.backdropEl) {
116
- FastDOM.setAttributes(this.backdropEl.nativeElement, {
117
- state: backdropZIndex < 0 ? "hidden" : "visible"
118
- });
119
- FastDOM.setStyle(this.backdropEl.nativeElement, { "z-index": `${backdropZIndex}` });
120
- }
21
+ doCloseActiveOverPanel() {
22
+ const activePanel = this.activeOverPanel();
23
+ if (activePanel) {
24
+ activePanel.close();
121
25
  }
122
26
  }
123
- onHideBackdropPanel(event) {
124
- event.preventDefault();
125
- if (this.#backdropPanel) {
126
- this.#backdropPanel.close();
127
- }
128
- }
129
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DockingLayoutComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
130
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.6", type: DockingLayoutComponent, isStandalone: true, selector: "nu-docking", inputs: { contentOnly: "contentOnly" }, queries: [{ propertyName: "contentComponent", first: true, predicate: DockingContentComponent, descendants: true }, { propertyName: "dockingPanels", predicate: DockingPanelComponent }], viewQueries: [{ propertyName: "backdropEl", first: true, predicate: ["backdrop"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: `
131
- <ng-content select="nu-docking-panel"></ng-content>
132
-
133
- @if (!contentComponent) {
134
- <nu-docking-content>
135
- <ng-content></ng-content>
136
- </nu-docking-content>
137
- } @else {
138
- <ng-content select="nu-docking-content"></ng-content>
139
- }
140
-
141
- <nu-docking-backdrop #backdrop (click)="onHideBackdropPanel($event)" />
142
- `, isInline: true, styles: [":host{---docking-layout-top: var(--docking-layout-top, 0px);---docking-layout-right: var(--docking-layout-right, 0px);---docking-layout-bottom: var(--docking-layout-bottom, 0px);---docking-layout-left: var(--docking-layout-left, 0px);---docking-layout-anim-duration: var(--docking-layout-anim-duration, .3s);---docking-layout-anim-ease: var(--docking-layout-anim-ease, cubic-bezier(.4, 0, .2, 1));---docking-layout-backdrop-color: var(--docking-layout-backdrop-color, #000);display:flex;flex-flow:column nowrap;align-items:stretch;position:relative;overflow:hidden;box-sizing:border-box;z-index:0;padding:var(---docking-layout-top) var(---docking-layout-right) var(---docking-layout-bottom) var(---docking-layout-left);transition:padding var(---docking-layout-anim-duration) var(---docking-layout-anim-ease)}\n"], dependencies: [{ kind: "component", type: DockingContentComponent, selector: "nu-docking-content", exportAs: ["nuDockingContent"] }, { kind: "component", type: DockingBackdropComponent, selector: "nu-docking-backdrop" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
27
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DockingLayoutComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
28
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.6", type: DockingLayoutComponent, isStandalone: true, selector: "nu-docking", queries: [{ propertyName: "panels", predicate: DockingPanelComponent, isSignal: true }], exportAs: ["nuDocking"], ngImport: i0, template: `
29
+ <ng-content />
30
+ <nu-docking-backdrop [visible]="backdropVisible()" (click)="doCloseActiveOverPanel()"></nu-docking-backdrop>
31
+ `, isInline: true, styles: [":host{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto 1fr auto;position:relative;align-items:stretch;justify-items:stretch;overflow:clip}\n"], dependencies: [{ kind: "component", type: DockingBackdropComponent, selector: "nu-docking-backdrop", inputs: ["visible"] }] }); }
143
32
  }
144
33
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImport: i0, type: DockingLayoutComponent, decorators: [{
145
34
  type: Component,
146
- args: [{ selector: "nu-docking", standalone: true, imports: [DockingContentComponent, DockingBackdropComponent], template: `
147
- <ng-content select="nu-docking-panel"></ng-content>
148
-
149
- @if (!contentComponent) {
150
- <nu-docking-content>
151
- <ng-content></ng-content>
152
- </nu-docking-content>
153
- } @else {
154
- <ng-content select="nu-docking-content"></ng-content>
155
- }
156
-
157
- <nu-docking-backdrop #backdrop (click)="onHideBackdropPanel($event)" />
158
- `, changeDetection: ChangeDetectionStrategy.OnPush, styles: [":host{---docking-layout-top: var(--docking-layout-top, 0px);---docking-layout-right: var(--docking-layout-right, 0px);---docking-layout-bottom: var(--docking-layout-bottom, 0px);---docking-layout-left: var(--docking-layout-left, 0px);---docking-layout-anim-duration: var(--docking-layout-anim-duration, .3s);---docking-layout-anim-ease: var(--docking-layout-anim-ease, cubic-bezier(.4, 0, .2, 1));---docking-layout-backdrop-color: var(--docking-layout-backdrop-color, #000);display:flex;flex-flow:column nowrap;align-items:stretch;position:relative;overflow:hidden;box-sizing:border-box;z-index:0;padding:var(---docking-layout-top) var(---docking-layout-right) var(---docking-layout-bottom) var(---docking-layout-left);transition:padding var(---docking-layout-anim-duration) var(---docking-layout-anim-ease)}\n"] }]
159
- }], propDecorators: { contentOnly: [{
160
- type: Input
161
- }], contentComponent: [{
162
- type: ContentChild,
163
- args: [DockingContentComponent]
164
- }], backdropEl: [{
165
- type: ViewChild,
166
- args: ["backdrop", { read: ElementRef, static: true }]
167
- }], dockingPanels: [{
168
- type: ContentChildren,
169
- args: [DockingPanelComponent]
170
- }] } });
171
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docking-layout.component.js","sourceRoot":"","sources":["../../../../../packages/layout/src/docking/docking-layout.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    inject,\n    Input,\n    OnChanges,\n    QueryList,\n    SimpleChanges,\n    ViewChild\n} from \"@angular/core\"\n\nimport { combineLatest, map, Observable, shareReplay, startWith, Subject, switchMap } from \"rxjs\"\n\nimport { Destructible, FastDOM } from \"@ngutil/common\"\n\nimport { DockingBackdropComponent } from \"./docking-backdrop.component\"\nimport { DockingContentComponent } from \"./docking-content.component\"\nimport { type DockingPanelChanges, DockingPanelComponent } from \"./docking-panel.component\"\n\ntype DockingVerticalPosition = \"top\" | \"middle\" | \"bottom\"\ntype DockingHorizontalPositon = \"left\" | \"center\" | \"right\"\ntype DockingPosition = `${DockingVerticalPosition}:${DockingHorizontalPositon}`\nexport type DockingRange =\n    | DockingVerticalPosition\n    | DockingHorizontalPositon\n    | DockingPosition\n    | `${DockingPosition}-${DockingPosition}`\n\nconst RIGID_ZINDEX = 100\nconst OVER_ZINDEX = RIGID_ZINDEX * 2\nconst BACKDROP_ZINDEX = 10000\n\ntype PanelsChanges = Array<{ panel: DockingPanelComponent; changes: DockingPanelChanges }>\n\n@Component({\n    selector: \"nu-docking\",\n    standalone: true,\n    imports: [DockingContentComponent, DockingBackdropComponent],\n    template: `\n        <ng-content select=\"nu-docking-panel\"></ng-content>\n\n        @if (!contentComponent) {\n            <nu-docking-content>\n                <ng-content></ng-content>\n            </nu-docking-content>\n        } @else {\n            <ng-content select=\"nu-docking-content\"></ng-content>\n        }\n\n        <nu-docking-backdrop #backdrop (click)=\"onHideBackdropPanel($event)\" />\n    `,\n    styleUrl: \"./docking-layout.component.scss\",\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DockingLayoutComponent extends Destructible implements AfterViewInit, OnChanges {\n    readonly #el = inject(ElementRef<HTMLElement>)\n\n    @Input() contentOnly = false\n\n    @ContentChild(DockingContentComponent) contentComponent?: DockingContentComponent\n    @ViewChild(\"backdrop\", { read: ElementRef, static: true })\n    backdropEl?: ElementRef<HTMLElement>\n    @ContentChildren(DockingPanelComponent) dockingPanels!: QueryList<DockingPanelComponent>\n\n    // readonly panels = new BehaviorSubject<PanelRef[]>([])\n    readonly panels!: Observable<Array<DockingPanelComponent>>\n\n    #reflow = new Subject<void>()\n    #backdropPanel: DockingPanelComponent | null = null\n\n    ngAfterViewInit(): void {\n        // eslint-disable-next-line prettier/prettier\n        (this as { panels: Observable<Array<DockingPanelComponent>> }).panels = this.dockingPanels.changes.pipe(\n            startWith(null),\n            map(() => this.dockingPanels.toArray()),\n            shareReplay(1)\n        )\n\n        this.d\n            .sub(combineLatest({ panels: this.panels, reflow: this.#reflow.pipe(startWith(null)) }))\n            .pipe(\n                switchMap(({ panels }) =>\n                    combineLatest(\n                        panels.map(panel =>\n                            panel.changes.pipe(\n                                map(changes => {\n                                    return { panel, changes }\n                                })\n                            )\n                        )\n                    )\n                )\n            )\n            .subscribe(this.#layout.bind(this))\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (\"contentOnly\" in changes || \"positionMode\" in changes) {\n            this.#reflow.next()\n        }\n    }\n\n    #layout(entries: PanelsChanges) {\n        let paddingTop = 0\n        let paddingRight = 0\n        let paddingBottom = 0\n        let paddingLeft = 0\n        let rigidZIndex = RIGID_ZINDEX\n        let overZIndex = OVER_ZINDEX\n        let backdropZIndex = -1\n\n        this.#backdropPanel = null\n\n        if (this.contentOnly) {\n            // TODO:...\n        } else {\n            for (const entry of entries) {\n                const panelState = entry.changes\n                const panelSize =\n                    panelState.state === \"full\"\n                        ? panelState.fullSize.value\n                        : panelState.state === \"mini\"\n                          ? panelState.miniSize.value\n                          : 0\n\n                const isHorizontal = panelState.position.orient === \"horizontal\"\n                const isRigid = panelState.mode === \"rigid\"\n\n                let panelTop = null\n                let panelRight = null\n                let panelBottom = null\n                let panelLeft = null\n\n                if (isHorizontal) {\n                    panelLeft = 0\n                    panelRight = 0\n                    if (panelState.position.cells[0].v === \"top\") {\n                        if (isRigid) {\n                            paddingTop = Math.max(paddingTop, panelSize)\n                        }\n                        panelTop = 0\n                    } else if (panelState.position.cells[0].v === \"bottom\") {\n                        if (isRigid) {\n                            paddingBottom = Math.max(paddingBottom, panelSize)\n                        }\n                        panelBottom = 0\n                    }\n                } else {\n                    panelTop = 0\n                    panelBottom = 0\n\n                    if (panelState.position.cells[0].h === \"left\") {\n                        if (isRigid) {\n                            paddingLeft = Math.max(paddingLeft, panelSize)\n                        }\n                        panelLeft = 0\n                    } else if (panelState.position.cells[0].h === \"right\") {\n                        if (isRigid) {\n                            paddingRight = Math.max(paddingRight, panelSize)\n                        }\n                        panelRight = 0\n                    }\n                }\n\n                let panelZIndex = isRigid ? (rigidZIndex += 2) : (overZIndex += 2)\n                if (panelState.state !== \"hidden\" && entry.panel.backdrop) {\n                    backdropZIndex = BACKDROP_ZINDEX\n                    panelZIndex = backdropZIndex + 1\n                    this.#backdropPanel = entry.panel\n                }\n\n                FastDOM.setStyle(entry.panel.el.nativeElement, {\n                    \"z-index\": `${panelZIndex}`,\n                    \"--docking-panel-t\": panelTop != null ? `${panelTop}px` : null,\n                    \"--docking-panel-r\": panelRight != null ? `${panelRight}px` : null,\n                    \"--docking-panel-b\": panelBottom != null ? `${panelBottom}px` : null,\n                    \"--docking-panel-l\": panelLeft != null ? `${panelLeft}px` : null\n                })\n            }\n\n            FastDOM.setStyle(this.#el.nativeElement, {\n                \"--docking-layout-top\": `${paddingTop}px`,\n                \"--docking-layout-right\": `${paddingRight}px`,\n                \"--docking-layout-bottom\": `${paddingBottom}px`,\n                \"--docking-layout-left\": `${paddingLeft}px`\n            })\n\n            if (this.backdropEl) {\n                FastDOM.setAttributes(this.backdropEl.nativeElement, {\n                    state: backdropZIndex < 0 ? \"hidden\" : \"visible\"\n                })\n                FastDOM.setStyle(this.backdropEl.nativeElement, { \"z-index\": `${backdropZIndex}` })\n            }\n        }\n    }\n\n    onHideBackdropPanel(event: Event) {\n        event.preventDefault()\n        if (this.#backdropPanel) {\n            this.#backdropPanel.close()\n        }\n    }\n}\n"]}
35
+ args: [{ selector: "nu-docking", exportAs: "nuDocking", standalone: true, imports: [DockingBackdropComponent], template: `
36
+ <ng-content />
37
+ <nu-docking-backdrop [visible]="backdropVisible()" (click)="doCloseActiveOverPanel()"></nu-docking-backdrop>
38
+ `, styles: [":host{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto 1fr auto;position:relative;align-items:stretch;justify-items:stretch;overflow:clip}\n"] }]
39
+ }] });
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9ja2luZy1sYXlvdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvbGF5b3V0L3NyYy9kb2NraW5nL2RvY2tpbmctbGF5b3V0LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxlQUFlLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFFcEUsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sOEJBQThCLENBQUE7QUFDdkUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkJBQTJCLENBQUE7O0FBc0JqRSxNQUFNLE9BQU8sc0JBQXNCO0lBWG5DO1FBWUk7O1dBRUc7UUFDSCxzQ0FBc0M7UUFFN0IsV0FBTSxHQUFHLGVBQWUsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFBO1FBRS9DLG9CQUFlLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNyQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUE7WUFDNUIsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxLQUFLLE1BQU0sSUFBSSxLQUFLLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQTtRQUMxRSxDQUFDLENBQUMsQ0FBQTtRQUVPLG9CQUFlLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUNyQyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUE7WUFDckMsT0FBTyxNQUFNLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsUUFBUSxFQUFFLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUE7UUFDL0QsQ0FBQyxDQUFDLENBQUE7S0FRTDtJQU5HLHNCQUFzQjtRQUNsQixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUE7UUFDMUMsSUFBSSxXQUFXLEVBQUUsQ0FBQztZQUNkLFdBQVcsQ0FBQyxLQUFLLEVBQUUsQ0FBQTtRQUN2QixDQUFDO0lBQ0wsQ0FBQzs4R0F2QlEsc0JBQXNCO2tHQUF0QixzQkFBc0IsNkZBTUcscUJBQXFCLHNFQVg3Qzs7O0tBR1QsOE9BTFMsd0JBQXdCOzsyRkFPekIsc0JBQXNCO2tCQVhsQyxTQUFTOytCQUNJLFlBQVksWUFDWixXQUFXLGNBQ1QsSUFBSSxXQUNQLENBQUMsd0JBQXdCLENBQUMsWUFFekI7OztLQUdUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBjb21wdXRlZCwgY29udGVudENoaWxkcmVuIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIlxuXG5pbXBvcnQgeyBEb2NraW5nQmFja2Ryb3BDb21wb25lbnQgfSBmcm9tIFwiLi9kb2NraW5nLWJhY2tkcm9wLmNvbXBvbmVudFwiXG5pbXBvcnQgeyBEb2NraW5nUGFuZWxDb21wb25lbnQgfSBmcm9tIFwiLi9kb2NraW5nLXBhbmVsLmNvbXBvbmVudFwiXG5cbnR5cGUgRG9ja2luZ1ZlcnRpY2FsUG9zaXRpb24gPSBcInRvcFwiIHwgXCJtaWRkbGVcIiB8IFwiYm90dG9tXCJcbnR5cGUgRG9ja2luZ0hvcml6b250YWxQb3NpdG9uID0gXCJsZWZ0XCIgfCBcImNlbnRlclwiIHwgXCJyaWdodFwiXG50eXBlIERvY2tpbmdQb3NpdGlvbiA9IGAke0RvY2tpbmdWZXJ0aWNhbFBvc2l0aW9ufToke0RvY2tpbmdIb3Jpem9udGFsUG9zaXRvbn1gXG5leHBvcnQgdHlwZSBEb2NraW5nUmFuZ2UgPVxuICAgIHwgRG9ja2luZ1ZlcnRpY2FsUG9zaXRpb25cbiAgICB8IERvY2tpbmdIb3Jpem9udGFsUG9zaXRvblxuICAgIHwgRG9ja2luZ1Bvc2l0aW9uXG4gICAgfCBgJHtEb2NraW5nUG9zaXRpb259LSR7RG9ja2luZ1Bvc2l0aW9ufWBcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwibnUtZG9ja2luZ1wiLFxuICAgIGV4cG9ydEFzOiBcIm51RG9ja2luZ1wiLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0RvY2tpbmdCYWNrZHJvcENvbXBvbmVudF0sXG4gICAgc3R5bGVVcmw6IFwiLi9kb2NraW5nLWxheW91dC5jb21wb25lbnQuc2Nzc1wiLFxuICAgIHRlbXBsYXRlOiBgXG4gICAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgICAgIDxudS1kb2NraW5nLWJhY2tkcm9wIFt2aXNpYmxlXT1cImJhY2tkcm9wVmlzaWJsZSgpXCIgKGNsaWNrKT1cImRvQ2xvc2VBY3RpdmVPdmVyUGFuZWwoKVwiPjwvbnUtZG9ja2luZy1iYWNrZHJvcD5cbiAgICBgXG59KVxuZXhwb3J0IGNsYXNzIERvY2tpbmdMYXlvdXRDb21wb25lbnQge1xuICAgIC8qKlxuICAgICAqIFRydWUgaWYgdSB3YW50IHRvIGFuaW1hdGUgcGFuZWwgb3Blbi9jbG9zZSB3aXRoIGBtb2RlPVwic2lkZVwiYFxuICAgICAqL1xuICAgIC8vIHJlYWRvbmx5IGFuaW1hdGVTaWRlID0gaW5wdXQoZmFsc2UpXG5cbiAgICByZWFkb25seSBwYW5lbHMgPSBjb250ZW50Q2hpbGRyZW4oRG9ja2luZ1BhbmVsQ29tcG9uZW50KVxuXG4gICAgcmVhZG9ubHkgYWN0aXZlT3ZlclBhbmVsID0gY29tcHV0ZWQoKCkgPT4ge1xuICAgICAgICBjb25zdCBwYW5lbHMgPSB0aGlzLnBhbmVscygpXG4gICAgICAgIHJldHVybiBwYW5lbHMuZmluZChwYW5lbCA9PiBwYW5lbC5tb2RlKCkgPT09IFwib3ZlclwiICYmIHBhbmVsLm9wZW5lZCgpKVxuICAgIH0pXG5cbiAgICByZWFkb25seSBiYWNrZHJvcFZpc2libGUgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgICAgIGNvbnN0IGFjdGl2ZSA9IHRoaXMuYWN0aXZlT3ZlclBhbmVsKClcbiAgICAgICAgcmV0dXJuIGFjdGl2ZSAhPSBudWxsID8gYWN0aXZlLmJhY2tkcm9wKCkgIT09IGZhbHNlIDogZmFsc2VcbiAgICB9KVxuXG4gICAgZG9DbG9zZUFjdGl2ZU92ZXJQYW5lbCgpIHtcbiAgICAgICAgY29uc3QgYWN0aXZlUGFuZWwgPSB0aGlzLmFjdGl2ZU92ZXJQYW5lbCgpXG4gICAgICAgIGlmIChhY3RpdmVQYW5lbCkge1xuICAgICAgICAgICAgYWN0aXZlUGFuZWwuY2xvc2UoKVxuICAgICAgICB9XG4gICAgfVxufVxuIl19