UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

112 lines 25.3 kB
// © 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 { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, } from "@angular/core"; import { expandV2 } from "../../animations/expand"; import { KEYBOARD_CODE } from "../../constants/keycode.constants"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "../icon/icon.component"; /** * <example-url>./../examples/index.html#/expander</example-url> */ export class ExpanderComponent { /** * Use this to have expander opened by default. */ set open(value) { const previousValue = this.state === "expanded"; if (previousValue !== value) { this.state = value ? "expanded" : "collapsed"; } } get open() { return this.state === "expanded"; } constructor(cdRef) { this.cdRef = cdRef; /** * Adds "disabled" attribute to expander */ this.disabled = false; /** * Adds icon to expander's header */ this.icon = ""; /** * Adds title to expander's header */ this.header = ""; /** * Hides left dotted border of expander. */ this.hideLeftBorder = false; /** * Is emitted when expander is expanded/collapsed */ this.openChange = new EventEmitter(); this.state = "collapsed"; this.isCustomHeaderContentEmpty = false; this.actionKeys = [KEYBOARD_CODE.SPACE, KEYBOARD_CODE.ENTER].map(String); } ngAfterContentInit() { this.isCustomHeaderContentEmpty = this.customHeaderContent.nativeElement.childNodes.length === 0; } toggle() { if (!this.disabled) { this.open = !this.open; this.openChange.emit(this.open); this.cdRef.detectChanges(); } } getIconColor() { return this.disabled ? "gray" : "primary-blue"; } onKeyDown(event) { if (this.actionKeys.includes(event.code)) { if (event.target === event.currentTarget) { event.preventDefault(); this.toggle(); } } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExpanderComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ExpanderComponent, selector: "nui-expander", inputs: { disabled: "disabled", icon: "icon", header: "header", hideLeftBorder: "hideLeftBorder", open: "open" }, outputs: { openChange: "openChange" }, viewQueries: [{ propertyName: "customHeaderContent", first: true, predicate: ["customHeaderContent"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"nui-expander\" [class.nui-expander--expanded]=\"state === 'expanded'\">\n <div\n class=\"nui-expander__header\"\n tabindex=\"0\"\n role=\"button\"\n aria-label=\"Expander toggle\"\n [attr.aria-expanded]=\"state === 'expanded'\"\n [attr.aria-disabled]=\"disabled\"\n [class.nui-expander__header--empty]=\"\n !header && isCustomHeaderContentEmpty\n \"\n (keydown)=\"onKeyDown($event)\"\n (click)=\"toggle()\"\n >\n <nui-icon\n class=\"nui-expander__header-icon\"\n [iconColor]=\"getIconColor()\"\n aria-hidden=\"true\"\n icon=\"{{ open ? 'triangle-down' : 'triangle-right' }}\"\n ></nui-icon>\n <div\n class=\"nui-expander__header-content-wrapper\"\n [class.nui-expander__custom-header--empty]=\"\n isCustomHeaderContentEmpty\n \"\n >\n <div\n #customHeaderContent\n class=\"nui-expander__custom-header\"\n [class.nui-expander__custom-header--empty]=\"\n isCustomHeaderContentEmpty\n \"\n >\n <ng-content select=\"[nuiExpanderHeader]\"></ng-content>\n </div>\n <div\n class=\"nui-expander__header-content\"\n *ngIf=\"isCustomHeaderContentEmpty\"\n [class.nui-expander__header-content--with-icon]=\"!!icon\"\n >\n <nui-icon\n class=\"nui-expander__header-content-icon\"\n [icon]=\"icon\"\n *ngIf=\"!!icon\"\n ></nui-icon>\n <span class=\"nui-expander__header-title\">{{ header }}</span>\n </div>\n </div>\n </div>\n <div\n class=\"nui-expander__body-wrapper\"\n role=\"region\"\n [attr.aria-label]=\"header || null\"\n >\n <div\n class=\"nui-expander__body\"\n [class.hide-left-border]=\"hideLeftBorder\"\n *ngIf=\"open\"\n @expandContent\n >\n <ng-content></ng-content>\n </div>\n </div>\n</div>\n", styles: [".nui-expander--expanded{padding-bottom:5px}.nui-expander__icon{align-items:center;align-self:flex-start;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px;margin-left:-7px}.nui-expander__header{align-items:center;border-radius:3px;cursor:pointer;display:flex;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.nui-expander__header:hover{background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui-expander__header-title{white-space:nowrap;overflow:hidden;-ms-text-overflow:ellipsis;-o-text-overflow:ellipsis;text-overflow:ellipsis;line-height:18px;font-size:13px;font-weight:600;color:#111;color:var(--nui-color-text-default,#111)}.nui-expander__header-icon{align-items:center;align-self:flex-start;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.nui-expander__header-content{align-items:center;display:flex;flex-grow:2;justify-content:flex-start;padding-left:5px;min-width:0;padding-right:5px}.nui-expander__header-content-icon{align-items:center;align-self:flex-start;flex-shrink:0;height:30px;justify-content:center;width:30px}.nui-expander__header-content--with-icon{padding-left:0}.nui-expander__header-content-wrapper{display:flex;flex-grow:2;min-width:0;width:100%}.nui-expander__header.nui-expander__header--empty.nui-expander__header{display:inline-flex}.nui-expander__header.nui-expander__header--empty .nui-expander__header-content{padding-left:0;padding-right:0}.nui-expander__custom-header{width:100%}.nui-expander__custom-header--empty{display:flex;width:auto}.nui-expander__body{border:none;border-left:dotted 2px #d9d9d9;border-left:dotted 2px var(--nui-color-line-default, #d9d9d9);color:#111;color:var(--nui-color-text-default, #111);margin-left:14px;padding-left:14px}.nui-expander__body.hide-left-border{border-left:0}.nui-expander__body.ng-animating{overflow:hidden}.nui-expander__header:focus{outline:none;box-shadow:0 0 0 2px #00c4d280}.nui-expander p{margin:0}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IconComponent, selector: "nui-icon", inputs: ["iconColor", "brushType", "iconHoverColor", "iconSize", "cssClass", "fillContainer", "status", "childStatus", "icon", "counter"] }], animations: [expandV2], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ExpanderComponent, decorators: [{ type: Component, args: [{ selector: "nui-expander", animations: [expandV2], encapsulation: ViewEncapsulation.None, template: "<div class=\"nui-expander\" [class.nui-expander--expanded]=\"state === 'expanded'\">\n <div\n class=\"nui-expander__header\"\n tabindex=\"0\"\n role=\"button\"\n aria-label=\"Expander toggle\"\n [attr.aria-expanded]=\"state === 'expanded'\"\n [attr.aria-disabled]=\"disabled\"\n [class.nui-expander__header--empty]=\"\n !header && isCustomHeaderContentEmpty\n \"\n (keydown)=\"onKeyDown($event)\"\n (click)=\"toggle()\"\n >\n <nui-icon\n class=\"nui-expander__header-icon\"\n [iconColor]=\"getIconColor()\"\n aria-hidden=\"true\"\n icon=\"{{ open ? 'triangle-down' : 'triangle-right' }}\"\n ></nui-icon>\n <div\n class=\"nui-expander__header-content-wrapper\"\n [class.nui-expander__custom-header--empty]=\"\n isCustomHeaderContentEmpty\n \"\n >\n <div\n #customHeaderContent\n class=\"nui-expander__custom-header\"\n [class.nui-expander__custom-header--empty]=\"\n isCustomHeaderContentEmpty\n \"\n >\n <ng-content select=\"[nuiExpanderHeader]\"></ng-content>\n </div>\n <div\n class=\"nui-expander__header-content\"\n *ngIf=\"isCustomHeaderContentEmpty\"\n [class.nui-expander__header-content--with-icon]=\"!!icon\"\n >\n <nui-icon\n class=\"nui-expander__header-content-icon\"\n [icon]=\"icon\"\n *ngIf=\"!!icon\"\n ></nui-icon>\n <span class=\"nui-expander__header-title\">{{ header }}</span>\n </div>\n </div>\n </div>\n <div\n class=\"nui-expander__body-wrapper\"\n role=\"region\"\n [attr.aria-label]=\"header || null\"\n >\n <div\n class=\"nui-expander__body\"\n [class.hide-left-border]=\"hideLeftBorder\"\n *ngIf=\"open\"\n @expandContent\n >\n <ng-content></ng-content>\n </div>\n </div>\n</div>\n", styles: [".nui-expander--expanded{padding-bottom:5px}.nui-expander__icon{align-items:center;align-self:flex-start;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px;margin-left:-7px}.nui-expander__header{align-items:center;border-radius:3px;cursor:pointer;display:flex;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.nui-expander__header:hover{background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui-expander__header-title{white-space:nowrap;overflow:hidden;-ms-text-overflow:ellipsis;-o-text-overflow:ellipsis;text-overflow:ellipsis;line-height:18px;font-size:13px;font-weight:600;color:#111;color:var(--nui-color-text-default,#111)}.nui-expander__header-icon{align-items:center;align-self:flex-start;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.nui-expander__header-content{align-items:center;display:flex;flex-grow:2;justify-content:flex-start;padding-left:5px;min-width:0;padding-right:5px}.nui-expander__header-content-icon{align-items:center;align-self:flex-start;flex-shrink:0;height:30px;justify-content:center;width:30px}.nui-expander__header-content--with-icon{padding-left:0}.nui-expander__header-content-wrapper{display:flex;flex-grow:2;min-width:0;width:100%}.nui-expander__header.nui-expander__header--empty.nui-expander__header{display:inline-flex}.nui-expander__header.nui-expander__header--empty .nui-expander__header-content{padding-left:0;padding-right:0}.nui-expander__custom-header{width:100%}.nui-expander__custom-header--empty{display:flex;width:auto}.nui-expander__body{border:none;border-left:dotted 2px #d9d9d9;border-left:dotted 2px var(--nui-color-line-default, #d9d9d9);color:#111;color:var(--nui-color-text-default, #111);margin-left:14px;padding-left:14px}.nui-expander__body.hide-left-border{border-left:0}.nui-expander__body.ng-animating{overflow:hidden}.nui-expander__header:focus{outline:none;box-shadow:0 0 0 2px #00c4d280}.nui-expander p{margin:0}\n"] }] }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { disabled: [{ type: Input }], icon: [{ type: Input }], header: [{ type: Input }], hideLeftBorder: [{ type: Input }], open: [{ type: Input }], openChange: [{ type: Output }], customHeaderContent: [{ type: ViewChild, args: ["customHeaderContent", { static: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expander.component.js","sourceRoot":"","sources":["../../../../src/lib/expander/expander.component.ts","../../../../src/lib/expander/expander.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    AfterContentInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Output,\n    ViewChild,\n    ViewEncapsulation,\n} from \"@angular/core\";\n\nimport { expandV2 } from \"../../animations/expand\";\nimport { KEYBOARD_CODE } from \"../../constants/keycode.constants\";\n\n/**\n * <example-url>./../examples/index.html#/expander</example-url>\n */\n@Component({\n    selector: \"nui-expander\",\n    templateUrl: \"./expander.component.html\",\n    animations: [expandV2],\n    styleUrls: [\"./expander.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class ExpanderComponent implements AfterContentInit {\n    /**\n     * Adds \"disabled\" attribute to expander\n     */\n    @Input() disabled: boolean = false;\n    /**\n     * Adds icon to expander's header\n     */\n    @Input() icon: string = \"\";\n    /**\n     * Adds title to expander's header\n     */\n    @Input() header: string = \"\";\n    /**\n     * Hides left dotted border of expander.\n     */\n    @Input() hideLeftBorder: boolean = false;\n    /**\n     * Use this to have expander opened by default.\n     */\n    @Input() set open(value: boolean) {\n        const previousValue: boolean = this.state === \"expanded\";\n        if (previousValue !== value) {\n            this.state = value ? \"expanded\" : \"collapsed\";\n        }\n    }\n\n    get open(): boolean {\n        return this.state === \"expanded\";\n    }\n    /**\n     * Is emitted when expander is expanded/collapsed\n     */\n    @Output() openChange: EventEmitter<boolean> = new EventEmitter<boolean>();\n\n    @ViewChild(\"customHeaderContent\", { static: true })\n    public customHeaderContent: ElementRef;\n\n    public state: \"expanded\" | \"collapsed\" = \"collapsed\";\n    public isCustomHeaderContentEmpty: boolean = false;\n\n    private actionKeys = [KEYBOARD_CODE.SPACE, KEYBOARD_CODE.ENTER].map(String);\n\n    constructor(private cdRef: ChangeDetectorRef) {}\n\n    public ngAfterContentInit(): void {\n        this.isCustomHeaderContentEmpty =\n            this.customHeaderContent.nativeElement.childNodes.length === 0;\n    }\n\n    public toggle(): void {\n        if (!this.disabled) {\n            this.open = !this.open;\n            this.openChange.emit(this.open);\n            this.cdRef.detectChanges();\n        }\n    }\n\n    public getIconColor(): string {\n        return this.disabled ? \"gray\" : \"primary-blue\";\n    }\n\n    public onKeyDown(event: KeyboardEvent): void {\n        if (this.actionKeys.includes(event.code)) {\n            if (event.target === event.currentTarget) {\n                event.preventDefault();\n                this.toggle();\n            }\n        }\n    }\n}\n","<div class=\"nui-expander\" [class.nui-expander--expanded]=\"state === 'expanded'\">\n    <div\n        class=\"nui-expander__header\"\n        tabindex=\"0\"\n        role=\"button\"\n        aria-label=\"Expander toggle\"\n        [attr.aria-expanded]=\"state === 'expanded'\"\n        [attr.aria-disabled]=\"disabled\"\n        [class.nui-expander__header--empty]=\"\n            !header && isCustomHeaderContentEmpty\n        \"\n        (keydown)=\"onKeyDown($event)\"\n        (click)=\"toggle()\"\n    >\n        <nui-icon\n            class=\"nui-expander__header-icon\"\n            [iconColor]=\"getIconColor()\"\n            aria-hidden=\"true\"\n            icon=\"{{ open ? 'triangle-down' : 'triangle-right' }}\"\n        ></nui-icon>\n        <div\n            class=\"nui-expander__header-content-wrapper\"\n            [class.nui-expander__custom-header--empty]=\"\n                isCustomHeaderContentEmpty\n            \"\n        >\n            <div\n                #customHeaderContent\n                class=\"nui-expander__custom-header\"\n                [class.nui-expander__custom-header--empty]=\"\n                    isCustomHeaderContentEmpty\n                \"\n            >\n                <ng-content select=\"[nuiExpanderHeader]\"></ng-content>\n            </div>\n            <div\n                class=\"nui-expander__header-content\"\n                *ngIf=\"isCustomHeaderContentEmpty\"\n                [class.nui-expander__header-content--with-icon]=\"!!icon\"\n            >\n                <nui-icon\n                    class=\"nui-expander__header-content-icon\"\n                    [icon]=\"icon\"\n                    *ngIf=\"!!icon\"\n                ></nui-icon>\n                <span class=\"nui-expander__header-title\">{{ header }}</span>\n            </div>\n        </div>\n    </div>\n    <div\n        class=\"nui-expander__body-wrapper\"\n        role=\"region\"\n        [attr.aria-label]=\"header || null\"\n    >\n        <div\n            class=\"nui-expander__body\"\n            [class.hide-left-border]=\"hideLeftBorder\"\n            *ngIf=\"open\"\n            @expandContent\n        >\n            <ng-content></ng-content>\n        </div>\n    </div>\n</div>\n"]}