@nova-ui/bits
Version:
SolarWinds Nova Framework
154 lines • 28.9 kB
JavaScript
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, } from "@angular/core";
import { Subject } from "rxjs";
import { debounceTime, takeUntil } from "rxjs/operators";
import { CheckboxStatus, SelectionType } from "./public-api";
import { CheckboxComponent } from "../checkbox/checkbox.component";
import { OVERLAY_WITH_POPUP_STYLES_CLASS } from "../overlay/constants";
import { OverlayComponent } from "../overlay/overlay-component/overlay.component";
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "../checkbox/checkbox.component";
import * as i3 from "../menu/menu-popup/menu-popup.component";
import * as i4 from "../button/button.component";
import * as i5 from "../overlay/overlay-component/overlay.component";
/**
* @ignore
* <example-url>./../examples/index.html#/selector</example-url>
*/
/**
* __Name :__
* NUI Selector component.
*
* __Usage :__
* Component provides different options to select elements
* by emmiting appropriate event.
* Checkbox and droplist allow to select "All" or "None" items.
* Droplist has additional option to select "All pages". Component
* has indication about which selection option is active now and
* binding property to set indeterminate state.
*/
export class SelectorComponent {
constructor() {
this.ariaLabel = "Selector";
this.selectionChange = new EventEmitter();
this.checkboxChecked = false;
this.indeterminate = false;
this.onDestroy$ = new Subject();
this.overlayConfig = {
panelClass: [OVERLAY_WITH_POPUP_STYLES_CLASS],
};
this.selectionHasChanged = false;
}
ngOnChanges(changes) {
if (changes["checkboxStatus"]) {
const checkboxStatus = changes["checkboxStatus"].currentValue;
this.indeterminate =
checkboxStatus === CheckboxStatus.Indeterminate;
this.checkboxChecked = checkboxStatus === CheckboxStatus.Checked;
}
if (changes.appendToBody) {
this.customContainer = changes.appendToBody.currentValue
? undefined
: this.popupArea;
}
}
ngAfterViewInit() {
const debounceTimeValue = 10;
this.checkbox.valueChange
.pipe(debounceTime(debounceTimeValue))
.subscribe(this.onCheckboxValueChange.bind(this));
this.overlay.clickOutside
.pipe(takeUntil(this.onDestroy$))
.subscribe((_) => this.overlay.hide());
// TODO: should change programmatically in scope of NUI-5937
this.checkbox.checkboxLabel.nativeElement.setAttribute("tabindex", "-1");
}
ngOnDestroy() {
this.checkbox.valueChange.unsubscribe();
this.onDestroy$.next();
this.onDestroy$.complete();
}
getFilters() {
const response = {
type: "selector",
value: {
selectorState: {
checkboxStatus: this.checkboxStatus,
selectorItems: this.items,
},
status: this.status,
selectionHasChanged: this.selectionHasChanged,
},
};
this.selectionHasChanged = false;
return response;
}
handleSelectorClick(event) {
if (event.currentTarget !== event.target) {
return;
}
this.indeterminate = false;
this.checkboxChecked = !this.checkboxChecked;
const selection = this.checkboxChecked
? SelectionType.All
: SelectionType.None;
this.status = selection;
this.selectionChange.emit(selection);
}
onCheckboxValueChange(event) {
this.indeterminate = false;
this.checkboxChecked = !this.checkboxChecked;
this.status = this.checkboxChecked
? SelectionType.All
: SelectionType.None;
this.selectionHasChanged = true;
if (event.target.checked) {
// gives control to "selectionChange" stream
this.selectionChange.emit(SelectionType.All);
}
else {
// gives control to "selectionChange" stream
this.selectionChange.emit(SelectionType.UnselectAll);
}
}
handleItemClick(item) {
const selection = item.value || item.title;
this.checkboxChecked =
selection === SelectionType.All ||
selection === SelectionType.AllPages;
this.status = selection;
this.selectionHasChanged = true;
// propagate selection
this.selectionChange.emit(selection);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: SelectorComponent, selector: "nui-selector", inputs: { checkboxStatus: "checkboxStatus", items: "items", appendToBody: "appendToBody", ariaLabel: "ariaLabel" }, outputs: { selectionChange: "selectionChange" }, host: { attributes: { "tabindex": "-1" }, properties: { "attr.aria-label": "ariaLabel" }, classAttribute: "nui-selector" }, viewQueries: [{ propertyName: "checkbox", first: true, predicate: ["checkbox"], descendants: true }, { propertyName: "popupArea", first: true, predicate: ["popupArea"], descendants: true, static: true }, { propertyName: "overlay", first: true, predicate: OverlayComponent, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"btn-group\" #toggleButton>\n <button\n nui-button\n type=\"button\"\n role=\"checkbox\"\n [attr.aria-checked]=\"checkboxChecked\"\n class=\"nui-selector__checkbox-button\"\n [displayStyle]=\"'default'\"\n (click)=\"handleSelectorClick($event)\"\n >\n <div class=\"nui-selector__checkbox-container\">\n <nui-checkbox\n #checkbox\n [checked]=\"checkboxChecked\"\n [indeterminate]=\"indeterminate\"\n >\n </nui-checkbox>\n </div>\n </button>\n <button\n nui-button\n *ngIf=\"items?.length\"\n type=\"button\"\n class=\"nui-selector__toggle\"\n ariaLabel=\"Open Selector Menu\"\n [displayStyle]=\"'default'\"\n [icon]=\"'caret-down'\"\n (click)=\"overlay.toggle()\"\n ></button>\n</div>\n\n<div #popupArea></div>\n\n<nui-overlay\n #overlay\n [toggleReference]=\"toggleButton\"\n [overlayConfig]=\"overlayConfig\"\n [customContainer]=\"customContainer\"\n>\n <nui-menu-popup\n [itemsSource]=\"items\"\n (menuItemClicked)=\"handleItemClick($event)\"\n ></nui-menu-popup>\n</nui-overlay>\n", styles: [".nui .nui-selector{max-height:30px;min-width:67px}.nui .nui-selector__checkbox-button{border:1px solid #d9d9d9;border:1px solid var(--nui-color-line-default, #d9d9d9);border-top-left-radius:3px;border-bottom-left-radius:3px}.nui .nui-selector__checkbox-button.btn{min-width:35px;width:35px;padding:0;border-width:0}.nui .nui-selector__checkbox-button.btn:focus{outline:none}.nui .nui-selector .nui-button__content{width:100%}.nui .nui-selector .nui-checkbox__label{width:100%;border-radius:3px 0 0 3px;border:1px solid;border-color:var(--nui-color-line-default,#d9d9d9)}.nui .nui-selector .nui-checkbox__label .nui-checkbox__mark{margin:-1px 0}.nui .nui-selector .nui-checkbox__label:hover{background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui .nui-selector__toggle{margin-right:0;border:1px solid #0079aa;border:1px solid var(--nui-color-line-active, #0079aa);border-bottom-left-radius:0;border-top-left-radius:0;padding:0 19px;height:auto}.nui .nui-selector__toggle.btn:focus{outline:none}.nui .nui-selector__toggle.nui-button.icon-left .nui-icon{float:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.CheckboxComponent, selector: "nui-checkbox", inputs: ["ariaLabel", "ariaLabelledby", "ariaDescribedby", "name", "title", "value", "hovered", "checked", "required", "hint", "disabled", "indeterminate"], outputs: ["valueChange"] }, { kind: "component", type: i3.MenuPopupComponent, selector: "nui-menu-popup", inputs: ["itemsSource", "size"], outputs: ["menuItemClicked"] }, { kind: "component", type: i4.ButtonComponent, selector: "[nui-button]", inputs: ["displayStyle", "icon", "iconColor", "iconRight", "isBusy", "isEmpty", "ariaLabel", "isRepeat", "size"] }, { kind: "component", type: i5.OverlayComponent, selector: "nui-overlay", inputs: ["overlayConfig", "toggleReference", "viewportMargin", "customContainer", "roleAttr"], outputs: ["clickOutside"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: SelectorComponent, decorators: [{
type: Component,
args: [{ selector: "nui-selector", host: {
class: "nui-selector",
tabindex: "-1",
"[attr.aria-label]": "ariaLabel",
}, encapsulation: ViewEncapsulation.None, template: "<div class=\"btn-group\" #toggleButton>\n <button\n nui-button\n type=\"button\"\n role=\"checkbox\"\n [attr.aria-checked]=\"checkboxChecked\"\n class=\"nui-selector__checkbox-button\"\n [displayStyle]=\"'default'\"\n (click)=\"handleSelectorClick($event)\"\n >\n <div class=\"nui-selector__checkbox-container\">\n <nui-checkbox\n #checkbox\n [checked]=\"checkboxChecked\"\n [indeterminate]=\"indeterminate\"\n >\n </nui-checkbox>\n </div>\n </button>\n <button\n nui-button\n *ngIf=\"items?.length\"\n type=\"button\"\n class=\"nui-selector__toggle\"\n ariaLabel=\"Open Selector Menu\"\n [displayStyle]=\"'default'\"\n [icon]=\"'caret-down'\"\n (click)=\"overlay.toggle()\"\n ></button>\n</div>\n\n<div #popupArea></div>\n\n<nui-overlay\n #overlay\n [toggleReference]=\"toggleButton\"\n [overlayConfig]=\"overlayConfig\"\n [customContainer]=\"customContainer\"\n>\n <nui-menu-popup\n [itemsSource]=\"items\"\n (menuItemClicked)=\"handleItemClick($event)\"\n ></nui-menu-popup>\n</nui-overlay>\n", styles: [".nui .nui-selector{max-height:30px;min-width:67px}.nui .nui-selector__checkbox-button{border:1px solid #d9d9d9;border:1px solid var(--nui-color-line-default, #d9d9d9);border-top-left-radius:3px;border-bottom-left-radius:3px}.nui .nui-selector__checkbox-button.btn{min-width:35px;width:35px;padding:0;border-width:0}.nui .nui-selector__checkbox-button.btn:focus{outline:none}.nui .nui-selector .nui-button__content{width:100%}.nui .nui-selector .nui-checkbox__label{width:100%;border-radius:3px 0 0 3px;border:1px solid;border-color:var(--nui-color-line-default,#d9d9d9)}.nui .nui-selector .nui-checkbox__label .nui-checkbox__mark{margin:-1px 0}.nui .nui-selector .nui-checkbox__label:hover{background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui .nui-selector__toggle{margin-right:0;border:1px solid #0079aa;border:1px solid var(--nui-color-line-active, #0079aa);border-bottom-left-radius:0;border-top-left-radius:0;padding:0 19px;height:auto}.nui .nui-selector__toggle.btn:focus{outline:none}.nui .nui-selector__toggle.nui-button.icon-left .nui-icon{float:none}\n"] }]
}], propDecorators: { checkboxStatus: [{
type: Input
}], items: [{
type: Input
}], appendToBody: [{
type: Input
}], ariaLabel: [{
type: Input
}], selectionChange: [{
type: Output
}], checkbox: [{
type: ViewChild,
args: ["checkbox"]
}], popupArea: [{
type: ViewChild,
args: ["popupArea", { static: true }]
}], overlay: [{
type: ViewChild,
args: [OverlayComponent]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selector.component.js","sourceRoot":"","sources":["../../../../src/lib/selector/selector.component.ts","../../../../src/lib/selector/selector.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 { OverlayConfig } from \"@angular/cdk/overlay\";\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Output,\n    SimpleChanges,\n    ViewChild,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport { Subject } from \"rxjs\";\nimport { debounceTime, takeUntil } from \"rxjs/operators\";\n\nimport { CheckboxStatus, SelectionType } from \"./public-api\";\nimport {\n    IFilter,\n    IFilterPub,\n    ISelectorFilter,\n} from \"../../services/data-source/public-api\";\nimport { CheckboxComponent } from \"../checkbox/checkbox.component\";\nimport { CheckboxChangeEvent } from \"../checkbox/public-api\";\nimport { IMenuGroup, IMenuItem } from \"../menu/public-api\";\nimport { OVERLAY_WITH_POPUP_STYLES_CLASS } from \"../overlay/constants\";\nimport { OverlayComponent } from \"../overlay/overlay-component/overlay.component\";\n\n/**\n * @ignore\n * <example-url>./../examples/index.html#/selector</example-url>\n */\n\n/**\n * __Name :__\n * NUI Selector component.\n *\n * __Usage :__\n * Component provides different options to select elements\n * by emmiting appropriate event.\n * Checkbox and droplist allow to select \"All\" or \"None\" items.\n * Droplist has additional option to select \"All pages\". Component\n * has indication about which selection option is active now and\n * binding property to set indeterminate state.\n */\n@Component({\n    selector: \"nui-selector\",\n    host: {\n        class: \"nui-selector\",\n        tabindex: \"-1\",\n        \"[attr.aria-label]\": \"ariaLabel\",\n    },\n    templateUrl: \"./selector.component.html\",\n    styleUrls: [\"./selector.component.less\"],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class SelectorComponent\n    implements OnChanges, AfterViewInit, OnDestroy, IFilterPub\n{\n    /**\n     * resets selection, makes component appearance indeterminate\n     */\n    @Input()\n    public checkboxStatus: CheckboxStatus;\n\n    @Input()\n    public items: IMenuGroup[];\n\n    @Input()\n    public appendToBody: boolean;\n\n    @Input()\n    public ariaLabel: string = \"Selector\";\n\n    @Output()\n    public selectionChange = new EventEmitter<SelectionType>();\n\n    @ViewChild(\"checkbox\")\n    public checkbox: CheckboxComponent;\n\n    @ViewChild(\"popupArea\", { static: true }) popupArea: ElementRef;\n\n    @ViewChild(OverlayComponent) public overlay: OverlayComponent;\n\n    public customContainer: ElementRef | undefined;\n    public checkboxChecked = false;\n    public indeterminate = false;\n    public onDestroy$ = new Subject<void>();\n    public overlayConfig: OverlayConfig = {\n        panelClass: [OVERLAY_WITH_POPUP_STYLES_CLASS],\n    };\n\n    private status: SelectionType;\n\n    private selectionHasChanged = false;\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (changes[\"checkboxStatus\"]) {\n            const checkboxStatus = changes[\"checkboxStatus\"].currentValue;\n            this.indeterminate =\n                checkboxStatus === CheckboxStatus.Indeterminate;\n            this.checkboxChecked = checkboxStatus === CheckboxStatus.Checked;\n        }\n        if (changes.appendToBody) {\n            this.customContainer = changes.appendToBody.currentValue\n                ? undefined\n                : this.popupArea;\n        }\n    }\n\n    public ngAfterViewInit(): void {\n        const debounceTimeValue = 10;\n\n        this.checkbox.valueChange\n            .pipe(debounceTime(debounceTimeValue))\n            .subscribe(this.onCheckboxValueChange.bind(this));\n        this.overlay.clickOutside\n            .pipe(takeUntil(this.onDestroy$))\n            .subscribe((_) => this.overlay.hide());\n        // TODO: should change programmatically in scope of NUI-5937\n        this.checkbox.checkboxLabel.nativeElement.setAttribute(\n            \"tabindex\",\n            \"-1\"\n        );\n    }\n\n    public ngOnDestroy(): void {\n        this.checkbox.valueChange.unsubscribe();\n        this.onDestroy$.next();\n        this.onDestroy$.complete();\n    }\n\n    public getFilters(): IFilter<ISelectorFilter> {\n        const response = {\n            type: \"selector\",\n            value: {\n                selectorState: {\n                    checkboxStatus: this.checkboxStatus,\n                    selectorItems: this.items,\n                },\n                status: this.status,\n                selectionHasChanged: this.selectionHasChanged,\n            },\n        };\n        this.selectionHasChanged = false;\n\n        return response;\n    }\n\n    public handleSelectorClick(event: MouseEvent): void {\n        if (event.currentTarget !== event.target) {\n            return;\n        }\n\n        this.indeterminate = false;\n        this.checkboxChecked = !this.checkboxChecked;\n\n        const selection = this.checkboxChecked\n            ? SelectionType.All\n            : SelectionType.None;\n        this.status = selection;\n\n        this.selectionChange.emit(selection);\n    }\n\n    private onCheckboxValueChange(event: CheckboxChangeEvent): void {\n        this.indeterminate = false;\n        this.checkboxChecked = !this.checkboxChecked;\n\n        this.status = this.checkboxChecked\n            ? SelectionType.All\n            : SelectionType.None;\n\n        this.selectionHasChanged = true;\n\n        if (event.target.checked) {\n            // gives control to \"selectionChange\" stream\n            this.selectionChange.emit(SelectionType.All);\n        } else {\n            // gives control to \"selectionChange\" stream\n            this.selectionChange.emit(SelectionType.UnselectAll);\n        }\n    }\n\n    public handleItemClick(item: IMenuItem): void {\n        const selection = item.value || (item.title as SelectionType);\n        this.checkboxChecked =\n            selection === SelectionType.All ||\n            selection === SelectionType.AllPages;\n        this.status = selection;\n\n        this.selectionHasChanged = true;\n\n        // propagate selection\n        this.selectionChange.emit(selection);\n    }\n}\n","<div class=\"btn-group\" #toggleButton>\n    <button\n        nui-button\n        type=\"button\"\n        role=\"checkbox\"\n        [attr.aria-checked]=\"checkboxChecked\"\n        class=\"nui-selector__checkbox-button\"\n        [displayStyle]=\"'default'\"\n        (click)=\"handleSelectorClick($event)\"\n    >\n        <div class=\"nui-selector__checkbox-container\">\n            <nui-checkbox\n                #checkbox\n                [checked]=\"checkboxChecked\"\n                [indeterminate]=\"indeterminate\"\n            >\n            </nui-checkbox>\n        </div>\n    </button>\n    <button\n        nui-button\n        *ngIf=\"items?.length\"\n        type=\"button\"\n        class=\"nui-selector__toggle\"\n        ariaLabel=\"Open Selector Menu\"\n        [displayStyle]=\"'default'\"\n        [icon]=\"'caret-down'\"\n        (click)=\"overlay.toggle()\"\n    ></button>\n</div>\n\n<div #popupArea></div>\n\n<nui-overlay\n    #overlay\n    [toggleReference]=\"toggleButton\"\n    [overlayConfig]=\"overlayConfig\"\n    [customContainer]=\"customContainer\"\n>\n    <nui-menu-popup\n        [itemsSource]=\"items\"\n        (menuItemClicked)=\"handleItemClick($event)\"\n    ></nui-menu-popup>\n</nui-overlay>\n"]}