UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

158 lines 22.5 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 { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, forwardRef, Input, Output, QueryList, Renderer2, } from "@angular/core"; import { NG_VALUE_ACCESSOR } from "@angular/forms"; import _remove from "lodash/remove"; import { CheckboxComponent } from "./checkbox.component"; import { NuiFormFieldControl } from "../form-field/public-api"; import * as i0 from "@angular/core"; /** * Component for combining of nui-checkbox components in to group * <example-url>./../examples/index.html#/checkbox-group</example-url> */ export class CheckboxGroupComponent { constructor(renderer) { this.renderer = renderer; /** * Is emitted when nui-checkbox is selected */ this.valuesChange = new EventEmitter(); /** * Input to set aria label text */ this.ariaLabel = "Checkbox Group"; /** * Input to set aria label text */ this.ariaLabeledby = ""; this.subscriptionsArray = new Array(); this.disabled = false; } /** * Subscribe to nui-checkbox-group children values change */ ngAfterViewInit() { this.children.toArray().forEach((child) => { this.renderer.setAttribute(child.inputViewContainer.element.nativeElement, "name", this.name); this.subscriptionsArray.push(this.subscribeToCheckboxEvent(child)); setTimeout(() => { child.checked = this.values.indexOf(child.value) > -1; child.disabled = child.disabled || this.disabled; }); }); this.children.changes.subscribe((checkboxComponentQueryList) => { // verify that there are no observers on checkboxes as we are creating new. this.subscriptionsArray.forEach((sub) => sub.unsubscribe()); checkboxComponentQueryList .toArray() .forEach((checkbox) => { this.renderer.setAttribute(checkbox.inputViewContainer.element.nativeElement, "name", this.name); this.subscriptionsArray.push(this.subscribeToCheckboxEvent(checkbox)); setTimeout(() => { checkbox.checked = this.values.indexOf(checkbox.value) > -1; checkbox.disabled = checkbox.disabled || this.disabled; }); }); }); } onChange(value) { } onTouched() { } writeValue(value) { this.values = value; } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } setDisabledState(isDisabled) { this.disabled = isDisabled; if (this.children) { this.children .toArray() .forEach((child) => (child.disabled = this.disabled)); } } /** * Unsubscribe from valuesChange event */ ngOnDestroy() { this.subscriptionsArray.forEach((sub) => sub.unsubscribe()); } subscribeToCheckboxEvent(checkbox) { return checkbox.valueChange.subscribe((event) => { if (event.target.checked) { this.values = [...this.values, event.target.value]; } else { _remove(this.values, (x) => x === event.target.value); } this.valuesChange.emit(this.values); this.onChange(this.values); this.onTouched(); this.writeValue(this.values); }); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CheckboxGroupComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CheckboxGroupComponent, selector: "nui-checkbox-group", inputs: { name: "name", values: "values", ariaLabel: "ariaLabel", ariaLabeledby: "ariaLabeledby" }, outputs: { valuesChange: "valuesChange" }, host: { attributes: { "role": "group" } }, providers: [ { provide: NuiFormFieldControl, useExisting: forwardRef(() => CheckboxGroupComponent), multi: true, }, { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => CheckboxGroupComponent), multi: true, }, ], queries: [{ propertyName: "children", predicate: CheckboxComponent, descendants: true }], ngImport: i0, template: "<div\n class=\"nui-checkbox-group\"\n [attr.aria-label]=\"ariaLabel || null\"\n [attr.aria-labeledby]=\"ariaLabeledby || null\"\n>\n <ng-content></ng-content>\n</div>\n", changeDetection: i0.ChangeDetectionStrategy.OnPush }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CheckboxGroupComponent, decorators: [{ type: Component, args: [{ selector: "nui-checkbox-group", changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: NuiFormFieldControl, useExisting: forwardRef(() => CheckboxGroupComponent), multi: true, }, { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => CheckboxGroupComponent), multi: true, }, ], host: { role: "group" }, template: "<div\n class=\"nui-checkbox-group\"\n [attr.aria-label]=\"ariaLabel || null\"\n [attr.aria-labeledby]=\"ariaLabeledby || null\"\n>\n <ng-content></ng-content>\n</div>\n" }] }], ctorParameters: () => [{ type: i0.Renderer2 }], propDecorators: { name: [{ type: Input }], values: [{ type: Input }], valuesChange: [{ type: Output }], children: [{ type: ContentChildren, args: [CheckboxComponent, { descendants: true }] }], ariaLabel: [{ type: Input }], ariaLabeledby: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-group.component.js","sourceRoot":"","sources":["../../../../src/lib/checkbox/checkbox-group.component.ts","../../../../src/lib/checkbox/checkbox-group.component.html"],"names":[],"mappings":"AAAA,yDAAyD;AACzD,EAAE;AACF,+EAA+E;AAC/E,4EAA4E;AAC5E,8EAA8E;AAC9E,+EAA+E;AAC/E,8EAA8E;AAC9E,4DAA4D;AAC5D,EAAE;AACF,6EAA6E;AAC7E,uDAAuD;AACvD,EAAE;AACF,6EAA6E;AAC7E,4EAA4E;AAC5E,+EAA+E;AAC/E,0EAA0E;AAC1E,iFAAiF;AACjF,6EAA6E;AAC7E,iBAAiB;AAEjB,OAAO,EAEH,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,YAAY,EACZ,UAAU,EACV,KAAK,EAEL,MAAM,EACN,SAAS,EACT,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,OAAO,MAAM,eAAe,CAAC;AAGpC,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAEzD,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;;AAoB/D;;;GAGG;AACH,MAAM,OAAO,sBAAsB;IAqC/B,YAAoB,QAAmB;QAAnB,aAAQ,GAAR,QAAQ,CAAW;QAxBvC;;WAEG;QACc,iBAAY,GAAG,IAAI,YAAY,EAAS,CAAC;QAQ1D;;WAEG;QACa,cAAS,GAAG,gBAAgB,CAAC;QAE7C;;WAEG;QACa,kBAAa,GAAG,EAAE,CAAC;QAE3B,uBAAkB,GAAG,IAAI,KAAK,EAAgB,CAAC;QAC/C,aAAQ,GAAY,KAAK,CAAC;IAEQ,CAAC;IAE3C;;OAEG;IACI,eAAe;QAClB,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC,KAAyB,EAAE,EAAE;YAC1D,IAAI,CAAC,QAAQ,CAAC,YAAY,CACtB,KAAK,CAAC,kBAAkB,CAAC,OAAO,CAAC,aAAa,EAC9C,MAAM,EACN,IAAI,CAAC,IAAI,CACZ,CAAC;YACF,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC,CAAC,CAAC;YACnE,UAAU,CAAC,GAAG,EAAE;gBACZ,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;gBACtD,KAAK,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC;YACrD,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,CAC3B,CAAC,0BAAyD,EAAE,EAAE;YAC1D,2EAA2E;YAC3E,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;YAC5D,0BAA0B;iBACrB,OAAO,EAAE;iBACT,OAAO,CAAC,CAAC,QAA4B,EAAE,EAAE;gBACtC,IAAI,CAAC,QAAQ,CAAC,YAAY,CACtB,QAAQ,CAAC,kBAAkB,CAAC,OAAO,CAAC,aAAa,EACjD,MAAM,EACN,IAAI,CAAC,IAAI,CACZ,CAAC;gBACF,IAAI,CAAC,kBAAkB,CAAC,IAAI,CACxB,IAAI,CAAC,wBAAwB,CAAC,QAAQ,CAAC,CAC1C,CAAC;gBACF,UAAU,CAAC,GAAG,EAAE;oBACZ,QAAQ,CAAC,OAAO;wBACZ,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;oBAC7C,QAAQ,CAAC,QAAQ;wBACb,QAAQ,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC;gBAC3C,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC;QACX,CAAC,CACJ,CAAC;IACN,CAAC;IAEM,QAAQ,CAAC,KAAY,IAAS,CAAC;IAE/B,SAAS,KAAU,CAAC;IAEpB,UAAU,CAAC,KAAU;QACxB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAEM,gBAAgB,CAAC,EAA0B;QAC9C,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAEM,iBAAiB,CAAC,EAAc;QACnC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAEM,gBAAgB,CAAC,UAAmB;QACvC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,QAAQ;iBACR,OAAO,EAAE;iBACT,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC;SAC7D;IACL,CAAC;IAED;;OAEG;IACI,WAAW;QACd,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,CAAC;IAChE,CAAC;IAEO,wBAAwB,CAC5B,QAA4B;QAE5B,OAAO,QAAQ,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,KAA0B,EAAE,EAAE;YACjE,IAAI,KAAK,CAAC,MAAM,CAAC,OAAO,EAAE;gBACtB,IAAI,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;aACtD;iBAAM;gBACH,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;aAC9D;YACD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC3B,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;IACP,CAAC;+GAhIQ,sBAAsB;mGAAtB,sBAAsB,uOAlBpB;YACP;gBACI,OAAO,EAAE,mBAAmB;gBAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;gBACrD,KAAK,EAAE,IAAI;aACd;YACD;gBACI,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC;gBACrD,KAAK,EAAE,IAAI;aACd;SACJ,mDA4BgB,iBAAiB,gDCpFtC,sLAOA;;4FDwDa,sBAAsB;kBAtBlC,SAAS;+BACI,oBAAoB,mBAEb,uBAAuB,CAAC,MAAM,aACpC;wBACP;4BACI,OAAO,EAAE,mBAAmB;4BAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACd;wBACD;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC;4BACrD,KAAK,EAAE,IAAI;yBACd;qBACJ,QACK,EAAE,IAAI,EAAE,OAAO,EAAE;8EAYP,IAAI;sBAAnB,KAAK;gBAKU,MAAM;sBAArB,KAAK;gBAKW,YAAY;sBAA5B,MAAM;gBAMC,QAAQ;sBADf,eAAe;uBAAC,iBAAiB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAMzC,SAAS;sBAAxB,KAAK;gBAKU,aAAa;sBAA5B,KAAK","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    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    EventEmitter,\n    forwardRef,\n    Input,\n    OnDestroy,\n    Output,\n    QueryList,\n    Renderer2,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport _remove from \"lodash/remove\";\nimport { Subscription } from \"rxjs\";\n\nimport { CheckboxComponent } from \"./checkbox.component\";\nimport { CheckboxChangeEvent, ICheckboxComponent } from \"./public-api\";\nimport { NuiFormFieldControl } from \"../form-field/public-api\";\n\n@Component({\n    selector: \"nui-checkbox-group\",\n    templateUrl: \"./checkbox-group.component.html\",\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NuiFormFieldControl,\n            useExisting: forwardRef(() => CheckboxGroupComponent),\n            multi: true,\n        },\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => CheckboxGroupComponent),\n            multi: true,\n        },\n    ],\n    host: { role: \"group\" },\n})\n/**\n * Component for combining of nui-checkbox components in to group\n * <example-url>./../examples/index.html#/checkbox-group</example-url>\n */\nexport class CheckboxGroupComponent\n    implements AfterViewInit, OnDestroy, ControlValueAccessor\n{\n    /**\n     * Sets \"name\" attribute for inner input element of nui-checkbox\n     */\n    @Input() public name: string;\n\n    /**\n     * Stores values from selected nui-checkboxes children components\n     */\n    @Input() public values: any[];\n\n    /**\n     * Is emitted when nui-checkbox is selected\n     */\n    @Output() public valuesChange = new EventEmitter<any[]>();\n\n    /**\n     * CheckboxGroupComponent children array from CheckboxComponent items\n     */\n    @ContentChildren(CheckboxComponent, { descendants: true })\n    private children: QueryList<CheckboxComponent>;\n\n    /**\n     * Input to set aria label text\n     */\n    @Input() public ariaLabel = \"Checkbox Group\";\n\n    /**\n     * Input to set aria label text\n     */\n    @Input() public ariaLabeledby = \"\";\n\n    private subscriptionsArray = new Array<Subscription>();\n    private disabled: boolean = false;\n\n    constructor(private renderer: Renderer2) {}\n\n    /**\n     * Subscribe to nui-checkbox-group children values change\n     */\n    public ngAfterViewInit(): void {\n        this.children.toArray().forEach((child: ICheckboxComponent) => {\n            this.renderer.setAttribute(\n                child.inputViewContainer.element.nativeElement,\n                \"name\",\n                this.name\n            );\n            this.subscriptionsArray.push(this.subscribeToCheckboxEvent(child));\n            setTimeout(() => {\n                child.checked = this.values.indexOf(child.value) > -1;\n                child.disabled = child.disabled || this.disabled;\n            });\n        });\n\n        this.children.changes.subscribe(\n            (checkboxComponentQueryList: QueryList<ICheckboxComponent>) => {\n                // verify that there are no observers on checkboxes as we are creating new.\n                this.subscriptionsArray.forEach((sub) => sub.unsubscribe());\n                checkboxComponentQueryList\n                    .toArray()\n                    .forEach((checkbox: ICheckboxComponent) => {\n                        this.renderer.setAttribute(\n                            checkbox.inputViewContainer.element.nativeElement,\n                            \"name\",\n                            this.name\n                        );\n                        this.subscriptionsArray.push(\n                            this.subscribeToCheckboxEvent(checkbox)\n                        );\n                        setTimeout(() => {\n                            checkbox.checked =\n                                this.values.indexOf(checkbox.value) > -1;\n                            checkbox.disabled =\n                                checkbox.disabled || this.disabled;\n                        });\n                    });\n            }\n        );\n    }\n\n    public onChange(value: any[]): void {}\n\n    public onTouched(): void {}\n\n    public writeValue(value: any): void {\n        this.values = value;\n    }\n\n    public registerOnChange(fn: (value: any[]) => void): void {\n        this.onChange = fn;\n    }\n\n    public registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    public setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n        if (this.children) {\n            this.children\n                .toArray()\n                .forEach((child) => (child.disabled = this.disabled));\n        }\n    }\n\n    /**\n     * Unsubscribe from valuesChange event\n     */\n    public ngOnDestroy(): void {\n        this.subscriptionsArray.forEach((sub) => sub.unsubscribe());\n    }\n\n    private subscribeToCheckboxEvent(\n        checkbox: ICheckboxComponent\n    ): Subscription {\n        return checkbox.valueChange.subscribe((event: CheckboxChangeEvent) => {\n            if (event.target.checked) {\n                this.values = [...this.values, event.target.value];\n            } else {\n                _remove(this.values, (x: any) => x === event.target.value);\n            }\n            this.valuesChange.emit(this.values);\n            this.onChange(this.values);\n            this.onTouched();\n            this.writeValue(this.values);\n        });\n    }\n}\n","<div\n    class=\"nui-checkbox-group\"\n    [attr.aria-label]=\"ariaLabel || null\"\n    [attr.aria-labeledby]=\"ariaLabeledby || null\"\n>\n    <ng-content></ng-content>\n</div>\n"]}