@nova-ui/bits
Version:
SolarWinds Nova Framework
188 lines • 35.6 kB
JavaScript
// © 2022 SolarWinds Worldwide, LLC. All rights reserved.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
import { Component, ComponentFactoryResolver, ContentChildren, ElementRef, HostBinding, Input, QueryList, Renderer2, ViewChild, ViewContainerRef, } from "@angular/core";
import { ResizeDirection, ResizeUnit, } from "../../../common/directives/resizer/public-api";
import { LayoutResizerComponent } from "../layout-resizer/layout-resizer.component";
import { SheetComponent } from "../sheet/sheet.component";
import * as i0 from "@angular/core";
// <example-url>./../examples/index.html#/layout</example-url>
export class SheetGroupComponent {
// workaround for issue when @ContentChildren can select host component - https://github.com/angular/angular/issues/10098;
// TODO: remove when it'll be fixed in Ivy
filterGroups(sheetGroupList) {
return sheetGroupList.filter((group) => group !== this);
}
addResizers(resizableList) {
resizableList.forEach((resizableItem, index) => {
if (index === resizableList.length - 1) {
return;
}
this.appendResizer(LayoutResizerComponent, resizableItem);
});
// make it such that it's valid even when resizer isn't added
this.calculateFlexBasis(resizableList, resizableList.length);
}
appendResizer(factory, resizeEl) {
const componentRef = this.componentFactoryResolver.resolveComponentFactory(factory);
const ref = this.resizerPlaceholder.createComponent(componentRef);
ref.instance.resizeElement = resizeEl;
ref.instance.resizeDirection =
this.resizeDirection;
ref.instance.resizeUnit = this.resizeUnit;
ref.instance.enableSeparateOffsetSize =
this.sheetsType === "separate";
ref.changeDetectorRef.detectChanges();
this.resizersList.push(ref);
}
calculateFlexBasis(resizableList, numOfItems) {
let availableSpace = "100%";
const hasInitSize = resizableList.some((element) => !!element.initialSizeValue);
const fitContent = resizableList.some((element) => !!element.fitContent);
const itemsToRender = [];
let itemsWithSize;
let itemsWithoutSize;
if (hasInitSize) {
// calculation for init size
// filter element so that those with size are dealt with first
itemsWithSize = resizableList.filter((element) => !!element.initialSizeValue && !element.fitContent);
itemsWithoutSize = resizableList.filter((element) => !element.initialSizeValue && !element.fitContent);
itemsWithSize.forEach((element) => {
availableSpace = `(${availableSpace} - ${element.initialSizeValue})`;
itemsToRender.push({
item: element,
value: `${element.initialSizeValue}`,
});
numOfItems--;
});
itemsWithoutSize.forEach((element) => {
availableSpace = `${availableSpace} / ${numOfItems}`;
itemsToRender.push({ item: element, value: availableSpace });
numOfItems--;
});
}
else if (!fitContent) {
// normal flow of calculation
resizableList.forEach((resizableItem) => {
itemsToRender.push({
item: resizableItem,
value: `${availableSpace} / ${numOfItems}`,
});
});
}
// rendering of calculation
itemsToRender.forEach(({ item, value }) => {
this.renderer.setStyle(item.elRef.nativeElement, "flexBasis", `calc(${value})`);
});
}
constructor(elRef, renderer, componentFactoryResolver) {
this.elRef = elRef;
this.renderer = renderer;
this.componentFactoryResolver = componentFactoryResolver;
/**
* Set resize unit of child elements(pixel, percent). By default pixels are used.
*/
this.resizeUnit = ResizeUnit.pixel;
/**
* Determines the way sheets links each other. Can be 'joined' or 'separate'.
*/
this.sheetsType = "joined";
/**
* Direction of layout elements. Can be 'row' or 'column'.
*/
this.direction = "row";
this.applyDirectionColumnClass = false;
this.applyDirectionRowClass = true;
this.resizersList = [];
}
ngOnInit() {
this.applyJoinedSheetsClass =
(this.applyJoinedSheetsClass && !this.applySeparateSheetsClass) ||
this.sheetsType === "joined";
this.applySeparateSheetsClass =
(!this.applyJoinedSheetsClass && this.applySeparateSheetsClass) ||
this.sheetsType === "separate";
this.applyDirectionColumnClass = this.direction === "column";
this.applyDirectionRowClass = this.direction === "row";
this.resizeDirection =
this.direction === "row"
? ResizeDirection.right
: ResizeDirection.bottom;
}
ngAfterViewInit() {
// 2 addResizers needed for correct handling sheetGroups and sheets elements,
// f.e. flex basis calculation or detection last element of correspondent type
if (this.isResizable) {
this.addResizers(this.sheetList);
this.addResizers(this.filterGroups(this.sheetGroupList));
}
else {
this.calculateFlexBasis(this.sheetList, this.sheetList.length);
this.calculateFlexBasis(this.filterGroups(this.sheetGroupList), this.filterGroups(this.sheetGroupList).length);
}
}
ngOnDestroy() {
if (this.resizersList.length > 0) {
this.resizersList.forEach((resizer) => {
resizer.destroy();
});
}
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SheetGroupComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i0.ComponentFactoryResolver }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SheetGroupComponent, selector: "nui-sheet-group", inputs: { isResizable: "isResizable", resizeUnit: "resizeUnit", sheetsType: "sheetsType", direction: "direction", initialSizeValue: "initialSizeValue" }, host: { properties: { "class.nui-sheet-group--resizable": "this.isResizable", "class.nui-sheet-group--joined-sheets": "this.applyJoinedSheetsClass", "class.nui-sheet-group--separate-sheets": "this.applySeparateSheetsClass", "class.sheet-group-direction-column": "this.applyDirectionColumnClass", "class.sheet-group-direction-row": "this.applyDirectionRowClass" }, classAttribute: "nui-sheet-group" }, queries: [{ propertyName: "sheetList", predicate: SheetComponent }, { propertyName: "sheetGroupList", predicate: SheetGroupComponent }], viewQueries: [{ propertyName: "resizerPlaceholder", first: true, predicate: ["resizerPlaceholder"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<ng-content></ng-content>\n<ng-template #resizerPlaceholder></ng-template>\n", styles: [":host{position:relative;display:flex;width:100%;height:100%;min-height:50px;background-color:transparent;flex-grow:1}:host.nui-sheet-group--joined-sheets{box-shadow:0 0 5px 0 var(--nui-shadow-color, rgba(17, 17, 17, .3))}:host.nui-sheet-group--joined-sheets.sheet-group-direction-row{flex-direction:row}:host.nui-sheet-group--joined-sheets.sheet-group-direction-column{flex-direction:column}:host.nui-sheet-group--separate-sheets.sheet-group-direction-row{flex-direction:row}:host.nui-sheet-group--separate-sheets.sheet-group-direction-column{flex-direction:column}:host-context(.nui-sheet-group--joined-sheets) :host.nui-sheet-group--joined-sheets{box-shadow:none}:host-context(.nui-sheet-group--resizable) nui-sheet-group{width:auto;height:auto}:host-context(.nui-sheet-group--separate-sheets.sheet-group-direction-column >):not(:last-of-type){margin-bottom:15px}:host-context(.nui-sheet-group--separate-sheets.sheet-group-direction-row >):not(:last-of-type){margin-right:15px}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-column >):not(:last-of-type):not(:first-of-type){border-bottom-color:var(--nui-color-line-dark,#999999);border-bottom-width:var(--nui-line-default,1px);border-bottom-style:solid;border-top-color:var(--nui-color-line-default,#d9d9d9);border-top-width:var(--nui-line-default,1px);border-top-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-column >):last-of-type{border-top-color:var(--nui-color-line-default,#d9d9d9);border-top-width:var(--nui-line-default,1px);border-top-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-column >):first-of-type{border-bottom-color:var(--nui-color-line-dark,#999999);border-bottom-width:var(--nui-line-default,1px);border-bottom-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-column >):only-child{border:none}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-row >):not(:last-of-type):not(:first-of-type){border-right-color:var(--nui-color-line-dark,#999999);border-right-width:var(--nui-line-default,1px);border-right-style:solid;border-left-color:var(--nui-color-line-default,#d9d9d9);border-left-width:var(--nui-line-default,1px);border-left-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-row >):last-of-type{border-left-color:var(--nui-color-line-default,#d9d9d9);border-left-width:var(--nui-line-default,1px);border-left-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-row >):first-of-type{border-right-color:var(--nui-color-line-dark,#999999);border-right-width:var(--nui-line-default,1px);border-right-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-row >):only-child{border:none}\n"] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SheetGroupComponent, decorators: [{
type: Component,
args: [{ selector: "nui-sheet-group", host: { class: "nui-sheet-group" }, template: "<ng-content></ng-content>\n<ng-template #resizerPlaceholder></ng-template>\n", styles: [":host{position:relative;display:flex;width:100%;height:100%;min-height:50px;background-color:transparent;flex-grow:1}:host.nui-sheet-group--joined-sheets{box-shadow:0 0 5px 0 var(--nui-shadow-color, rgba(17, 17, 17, .3))}:host.nui-sheet-group--joined-sheets.sheet-group-direction-row{flex-direction:row}:host.nui-sheet-group--joined-sheets.sheet-group-direction-column{flex-direction:column}:host.nui-sheet-group--separate-sheets.sheet-group-direction-row{flex-direction:row}:host.nui-sheet-group--separate-sheets.sheet-group-direction-column{flex-direction:column}:host-context(.nui-sheet-group--joined-sheets) :host.nui-sheet-group--joined-sheets{box-shadow:none}:host-context(.nui-sheet-group--resizable) nui-sheet-group{width:auto;height:auto}:host-context(.nui-sheet-group--separate-sheets.sheet-group-direction-column >):not(:last-of-type){margin-bottom:15px}:host-context(.nui-sheet-group--separate-sheets.sheet-group-direction-row >):not(:last-of-type){margin-right:15px}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-column >):not(:last-of-type):not(:first-of-type){border-bottom-color:var(--nui-color-line-dark,#999999);border-bottom-width:var(--nui-line-default,1px);border-bottom-style:solid;border-top-color:var(--nui-color-line-default,#d9d9d9);border-top-width:var(--nui-line-default,1px);border-top-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-column >):last-of-type{border-top-color:var(--nui-color-line-default,#d9d9d9);border-top-width:var(--nui-line-default,1px);border-top-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-column >):first-of-type{border-bottom-color:var(--nui-color-line-dark,#999999);border-bottom-width:var(--nui-line-default,1px);border-bottom-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-column >):only-child{border:none}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-row >):not(:last-of-type):not(:first-of-type){border-right-color:var(--nui-color-line-dark,#999999);border-right-width:var(--nui-line-default,1px);border-right-style:solid;border-left-color:var(--nui-color-line-default,#d9d9d9);border-left-width:var(--nui-line-default,1px);border-left-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-row >):last-of-type{border-left-color:var(--nui-color-line-default,#d9d9d9);border-left-width:var(--nui-line-default,1px);border-left-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-row >):first-of-type{border-right-color:var(--nui-color-line-dark,#999999);border-right-width:var(--nui-line-default,1px);border-right-style:solid}:host-context(.nui-sheet-group--joined-sheets.sheet-group-direction-row >):only-child{border:none}\n"] }]
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ComponentFactoryResolver }], propDecorators: { isResizable: [{
type: HostBinding,
args: ["class.nui-sheet-group--resizable"]
}, {
type: Input
}], resizeUnit: [{
type: Input
}], sheetsType: [{
type: Input
}], direction: [{
type: Input
}], initialSizeValue: [{
type: Input
}], applyJoinedSheetsClass: [{
type: HostBinding,
args: ["class.nui-sheet-group--joined-sheets"]
}], applySeparateSheetsClass: [{
type: HostBinding,
args: ["class.nui-sheet-group--separate-sheets"]
}], applyDirectionColumnClass: [{
type: HostBinding,
args: ["class.sheet-group-direction-column"]
}], applyDirectionRowClass: [{
type: HostBinding,
args: ["class.sheet-group-direction-row"]
}], resizerPlaceholder: [{
type: ViewChild,
args: ["resizerPlaceholder", { read: ViewContainerRef }]
}], sheetList: [{
type: ContentChildren,
args: [SheetComponent]
}], sheetGroupList: [{
type: ContentChildren,
args: [SheetGroupComponent, { descendants: false }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sheet-group.component.js","sourceRoot":"","sources":["../../../../../src/lib/layout/sheet-group/sheet-group.component.ts","../../../../../src/lib/layout/sheet-group/sheet-group.component.html"],"names":[],"mappings":"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","sourcesContent":["// © 2022 SolarWinds Worldwide, LLC. All rights reserved.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n//  of this software and associated documentation files (the \"Software\"), to\n//  deal in the Software without restriction, including without limitation the\n//  rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n//  sell copies of the Software, and to permit persons to whom the Software is\n//  furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n//  all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n//  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n//  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n//  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n//  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n//  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n//  THE SOFTWARE.\n\nimport {\n    AfterViewInit,\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    ContentChildren,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n    QueryList,\n    Renderer2,\n    ViewChild,\n    ViewContainerRef,\n} from \"@angular/core\";\n\nimport {\n    ResizeDirection,\n    ResizeUnit,\n} from \"../../../common/directives/resizer/public-api\";\nimport { LayoutResizerComponent } from \"../layout-resizer/layout-resizer.component\";\nimport { ILayoutElementDirection, ISheetType } from \"../public-api\";\nimport { SheetComponent } from \"../sheet/sheet.component\";\n\ntype Element = SheetComponent | SheetGroupComponent;\ninterface IElementInfo {\n    item: Element;\n    value: string;\n}\n\n// <example-url>./../examples/index.html#/layout</example-url>\n@Component({\n    selector: \"nui-sheet-group\",\n    templateUrl: \"./sheet-group.component.html\",\n    host: { class: \"nui-sheet-group\" },\n    styleUrls: [\"./sheet-group.component.less\"],\n})\nexport class SheetGroupComponent implements OnInit, AfterViewInit, OnDestroy {\n    /**\n     * Set whether the child elements can be resizable.\n     */\n    @HostBinding(\"class.nui-sheet-group--resizable\")\n    @Input()\n    isResizable: boolean;\n\n    /**\n     * Set resize unit of child elements(pixel, percent). By default pixels are used.\n     */\n    @Input() resizeUnit = ResizeUnit.pixel;\n\n    /**\n     * Determines the way sheets links each other. Can be 'joined' or 'separate'.\n     */\n    @Input() sheetsType: ISheetType = \"joined\";\n\n    /**\n     * Direction of layout elements. Can be 'row' or 'column'.\n     */\n    @Input() direction: ILayoutElementDirection = \"row\";\n    /**\n     * Value for flexBasis of SheetComponent or SheetGroupComponent.\n     * Can be in 'px' or '%'\n     */\n    @Input() initialSizeValue: string;\n\n    @HostBinding(\"class.nui-sheet-group--joined-sheets\")\n    applyJoinedSheetsClass: boolean;\n    @HostBinding(\"class.nui-sheet-group--separate-sheets\")\n    applySeparateSheetsClass: boolean;\n\n    @HostBinding(\"class.sheet-group-direction-column\")\n    applyDirectionColumnClass = false;\n    @HostBinding(\"class.sheet-group-direction-row\") applyDirectionRowClass =\n        true;\n\n    @ViewChild(\"resizerPlaceholder\", { read: ViewContainerRef })\n    public resizerPlaceholder: ViewContainerRef;\n    @ContentChildren(SheetComponent) sheetList: QueryList<SheetComponent>;\n    @ContentChildren(SheetGroupComponent, { descendants: false })\n    sheetGroupList: QueryList<SheetGroupComponent>;\n\n    public resizersList: ComponentRef<any>[] = [];\n    public resizeDirection: ResizeDirection;\n\n    // workaround for issue when @ContentChildren can select host component - https://github.com/angular/angular/issues/10098;\n    // TODO: remove when it'll be fixed in Ivy\n    private filterGroups(sheetGroupList: any) {\n        return sheetGroupList.filter(\n            (group: SheetGroupComponent) => group !== this\n        );\n    }\n\n    public addResizers(resizableList: QueryList<any>): void {\n        resizableList.forEach((resizableItem, index) => {\n            if (index === resizableList.length - 1) {\n                return;\n            }\n            this.appendResizer(LayoutResizerComponent, resizableItem);\n        });\n        // make it such that it's valid even when resizer isn't added\n        this.calculateFlexBasis(resizableList, resizableList.length);\n    }\n\n    public appendResizer(factory: any, resizeEl: any): void {\n        const componentRef =\n            this.componentFactoryResolver.resolveComponentFactory(factory);\n\n        const ref = this.resizerPlaceholder.createComponent(componentRef);\n        (<LayoutResizerComponent>ref.instance).resizeElement = resizeEl;\n        (<LayoutResizerComponent>ref.instance).resizeDirection =\n            this.resizeDirection;\n        (<LayoutResizerComponent>ref.instance).resizeUnit = this.resizeUnit;\n        (<LayoutResizerComponent>ref.instance).enableSeparateOffsetSize =\n            this.sheetsType === \"separate\";\n        ref.changeDetectorRef.detectChanges();\n        this.resizersList.push(ref);\n    }\n\n    public calculateFlexBasis(\n        resizableList: QueryList<Element>,\n        numOfItems: number\n    ): void {\n        let availableSpace: string = \"100%\";\n        const hasInitSize = resizableList.some(\n            (element: Element) => !!element.initialSizeValue\n        );\n        const fitContent = resizableList.some(\n            (element: Element) => !!(element as any).fitContent\n        );\n        const itemsToRender: IElementInfo[] = [];\n        let itemsWithSize: Element[];\n        let itemsWithoutSize: Element[];\n\n        if (hasInitSize) {\n            // calculation for init size\n            // filter element so that those with size are dealt with first\n            itemsWithSize = resizableList.filter(\n                (element: Element) =>\n                    !!element.initialSizeValue && !(element as any).fitContent\n            );\n            itemsWithoutSize = resizableList.filter(\n                (element: Element) =>\n                    !element.initialSizeValue && !(element as any).fitContent\n            );\n\n            itemsWithSize.forEach((element: Element) => {\n                availableSpace = `(${availableSpace} - ${element.initialSizeValue})`;\n                itemsToRender.push({\n                    item: element,\n                    value: `${element.initialSizeValue}`,\n                });\n                numOfItems--;\n            });\n            itemsWithoutSize.forEach((element: Element) => {\n                availableSpace = `${availableSpace} / ${numOfItems}`;\n                itemsToRender.push({ item: element, value: availableSpace });\n                numOfItems--;\n            });\n        } else if (!fitContent) {\n            // normal flow of calculation\n            resizableList.forEach((resizableItem: Element) => {\n                itemsToRender.push({\n                    item: resizableItem,\n                    value: `${availableSpace} / ${numOfItems}`,\n                });\n            });\n        }\n\n        // rendering of calculation\n        itemsToRender.forEach(({ item, value }) => {\n            this.renderer.setStyle(\n                item.elRef.nativeElement,\n                \"flexBasis\",\n                `calc(${value})`\n            );\n        });\n    }\n\n    constructor(\n        public elRef: ElementRef,\n        private renderer: Renderer2,\n        private componentFactoryResolver: ComponentFactoryResolver\n    ) {}\n\n    public ngOnInit(): void {\n        this.applyJoinedSheetsClass =\n            (this.applyJoinedSheetsClass && !this.applySeparateSheetsClass) ||\n            this.sheetsType === \"joined\";\n        this.applySeparateSheetsClass =\n            (!this.applyJoinedSheetsClass && this.applySeparateSheetsClass) ||\n            this.sheetsType === \"separate\";\n        this.applyDirectionColumnClass = this.direction === \"column\";\n        this.applyDirectionRowClass = this.direction === \"row\";\n        this.resizeDirection =\n            this.direction === \"row\"\n                ? ResizeDirection.right\n                : ResizeDirection.bottom;\n    }\n\n    public ngAfterViewInit(): void {\n        // 2 addResizers needed for correct handling sheetGroups and sheets elements,\n        // f.e. flex basis calculation or detection last element of correspondent type\n        if (this.isResizable) {\n            this.addResizers(this.sheetList);\n            this.addResizers(this.filterGroups(this.sheetGroupList));\n        } else {\n            this.calculateFlexBasis(this.sheetList, this.sheetList.length);\n            this.calculateFlexBasis(\n                this.filterGroups(this.sheetGroupList),\n                this.filterGroups(this.sheetGroupList).length\n            );\n        }\n    }\n\n    public ngOnDestroy(): void {\n        if (this.resizersList.length > 0) {\n            this.resizersList.forEach((resizer) => {\n                resizer.destroy();\n            });\n        }\n    }\n}\n","<ng-content></ng-content>\n<ng-template #resizerPlaceholder></ng-template>\n"]}