@nova-ui/bits
Version:
SolarWinds Nova Framework
237 lines • 43.3 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 { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Input, Output, Renderer2, ViewChild, ViewContainerRef, ViewEncapsulation, } from "@angular/core";
import { NG_VALUE_ACCESSOR } from "@angular/forms";
import { CHECKBOX_KEYDOWN_EVENT, DOCUMENT_CLICK_EVENT, } from "../../constants/event.constants";
import { KEYBOARD_CODE } from "../../constants/keycode.constants";
import { EventBusService } from "../../services/event-bus.service";
import { NuiFormFieldControl } from "../form-field/public-api";
import * as i0 from "@angular/core";
import * as i1 from "../../services/event-bus.service";
import * as i2 from "@angular/common";
/**
* <nui-checkbox> provides the same functionality as a native
* <input type="checkbox"> enhanced with NUI styling.
* <example-url>./../examples/index.html#/checkbox</example-url>
*/
export class CheckboxComponent {
/**
* Input to set aria label text
*/
get ariaLabel() {
return this._ariaLabel;
}
// changing the value with regular @Input doesn't trigger change detection
// so we need to do that manually in the setter
set ariaLabel(value) {
if (value !== this._ariaLabel) {
this._ariaLabel = value;
this.changeDetector.markForCheck();
}
}
/**
* Sets "checked" attribute for inner input element of nui-checkbox
*/
get checked() {
return this._checked;
}
set checked(val) {
if (this._checked !== val) {
this.changeDetector.markForCheck();
}
this._checked = val;
}
/**
* Used for disabling of nui-checkbox
*/
get disabled() {
return this._disabled;
}
set disabled(val) {
if (this._disabled !== val) {
this.changeDetector.markForCheck();
}
this._disabled = val;
}
constructor(changeDetector, eventBusService, renderer) {
this.changeDetector = changeDetector;
this.eventBusService = eventBusService;
this.renderer = renderer;
/** Users ca specify the 'aria-labelledby' which will be set to the input element */
this.ariaLabelledby = null;
/**
* Sets "title" attribute for nui-checkbox label
*/
this.title = "";
/**
* Event that is fired when nui-checkbox is toggled
*/
this.valueChange = new EventEmitter();
this._ariaLabel = "Checkbox";
this.keysAction = [KEYBOARD_CODE.SPACE, KEYBOARD_CODE.ENTER].map(String);
}
ngAfterViewInit() {
this.rendererListener = this.renderer.listen(this.checkboxLabel.nativeElement, "keydown", (event) => {
this.eventBusService
.getStream(CHECKBOX_KEYDOWN_EVENT)
.next(event);
});
this.sub = this.eventBusService
.getStream(CHECKBOX_KEYDOWN_EVENT)
.subscribe((event) => {
if (event.target === this.checkboxLabel.nativeElement) {
if (this.keysAction.includes(event.code)) {
event.stopPropagation();
event.preventDefault();
if (!this.disabled) {
this.handleKeyboardActions();
}
}
}
});
}
getAriaChecked() {
if (this.checked) {
return "true";
}
return this.indeterminate ? "mixed" : "false";
}
/**
* Used for changing of css style when nui-checkbox is hovered
*/
hoverHandler() {
this.hovered = !this.hovered;
}
/**
* nui-checkbox check/uncheck state handler
* @param event Changed nui-checkbox component
*/
changeHandler(event) {
this.valueChange.emit(event);
const checked = !!event.target?.checked;
this.onChange(checked);
this.onTouched();
this.writeValue(checked);
}
onClick(event) {
event.stopPropagation();
this.eventBusService.getStream(DOCUMENT_CLICK_EVENT).next(event);
}
onChange(value) { }
onTouched() { }
writeValue(value) {
this.checked = value;
}
registerOnChange(fn) {
this.onChange = fn;
}
registerOnTouched(fn) {
this.onTouched = fn;
}
setDisabledState(isDisabled) {
this.disabled = isDisabled;
}
ngOnDestroy() {
if (this.rendererListener) {
this.rendererListener();
}
if (this.sub) {
this.sub.unsubscribe();
}
}
handleKeyboardActions() {
if (this.indeterminate) {
this.inputViewContainer.element.nativeElement.checked = true;
this.indeterminate = false;
}
else {
this.inputViewContainer.element.nativeElement.checked =
!this.inputViewContainer.element.nativeElement.checked;
}
this.inputViewContainer.element.nativeElement.dispatchEvent(new Event("change"));
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CheckboxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.EventBusService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: CheckboxComponent, selector: "nui-checkbox", inputs: { ariaLabel: "ariaLabel", ariaLabelledby: "ariaLabelledby", ariaDescribedby: "ariaDescribedby", name: "name", title: "title", value: "value", hovered: "hovered", checked: "checked", required: "required", hint: "hint", disabled: "disabled", indeterminate: "indeterminate" }, outputs: { valueChange: "valueChange" }, host: { properties: { "class.nui-checkbox--hovered": "hovered", "class.nui-checkbox--checked": "checked" } }, providers: [
{
provide: NuiFormFieldControl,
useExisting: forwardRef(() => CheckboxComponent),
multi: true,
},
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => CheckboxComponent),
multi: true,
},
], viewQueries: [{ propertyName: "inputViewContainer", first: true, predicate: ["inputViewContainer"], descendants: true, read: ViewContainerRef }, { propertyName: "checkboxContent", first: true, predicate: ["checkboxContent"], descendants: true }, { propertyName: "checkboxLabel", first: true, predicate: ["checkboxLabel"], descendants: true }], ngImport: i0, template: "<div class=\"nui-checkbox\">\n <label\n class=\"nui-checkbox__label\"\n #checkboxLabel\n role=\"checkbox\"\n [attr.aria-label]=\"ariaLabel || null\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-checked]=\"getAriaChecked()\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n [attr.tabindex]=\"!disabled ? 0 : -1\"\n [title]=\"title\"\n [class.nui-checkbox__translucent]=\"disabled\"\n (mouseenter)=\"hoverHandler()\"\n (mouseleave)=\"hoverHandler()\"\n >\n <div class=\"nui-checkbox__content\">\n <input\n #inputViewContainer\n class=\"nui-checkbox__input\"\n type=\"checkbox\"\n [attr.name]=\"name\"\n [value]=\"value\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [indeterminate]=\"indeterminate\"\n (click)=\"onClick($event)\"\n (change)=\"changeHandler($event)\"\n />\n <div class=\"nui-checkbox__mark\">\n <i class=\"nui-checkbox__glyph\"></i>\n </div>\n <div #checkboxContent class=\"nui-checkbox__transclude\">\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"nui-help-hint\" *ngIf=\"hint\">{{ hint }}</div>\n </label>\n</div>\n", styles: [".nui-checkbox-group-inline>.nui-checkbox-group{display:inline-flex}.nui-checkbox-group-inline>.nui-checkbox-group nui-checkbox{margin-left:15px}.nui-checkbox-group-inline>.nui-checkbox-group nui-checkbox:first-child{margin-left:0}.nui-checkbox-group-inline>.nui-checkbox-group nui-checkbox .nui-checkbox_label{max-width:450px}.nui .nui-checkbox__content{align-items:center;display:inline-flex;flex-wrap:nowrap;justify-content:flex-start}.nui .nui-checkbox.nui-checkbox--has-action .nui-checkbox__mark:after{display:none}.nui .nui-checkbox__label{cursor:pointer;margin:0;position:relative;line-height:0;font-weight:400;border-radius:3px;width:fit-content;min-width:30px;min-height:30px;padding:7px}.nui .nui-checkbox__label:hover{background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui .nui-checkbox__label:focus{outline:0;box-shadow:inset 0 0 0 2px #00c4d280;background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui .nui-checkbox__translucent{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;color:var(--nui-color-text-disabled,rgba(17, 17, 17, .3));cursor:default}.nui .nui-checkbox__translucent:hover{background-color:transparent}.nui .nui-checkbox__translucent:focus{outline:none;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;background-color:var(--transparent,transparent)}.nui .nui-checkbox__mark{border:solid 2px;background:no-repeat 0 center;border-color:var(--nui-color-active,#0079aa);background-color:var(--nui-color-bg-content,#fff);background-size:16px;border-radius:3px;min-width:16px;width:16px;height:16px;transition:background-color .3s,border-color .3s}.nui .nui-checkbox__glyph{width:100%;height:100%;background-size:12px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIKCSB2aWV3Qm94PSIwIDAgMjAgMjAiIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMjAgMjA7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS54dWktY2hlY2tib3gtZ2x5cGh7ZmlsbDpub25lO3N0cm9rZTojRkZGRkZGO3N0cm9rZS13aWR0aDozO3N0cm9rZS1taXRlcmxpbWl0OjEwO3N0cm9rZS1saW5lY2FwOnJvdW5kO30KPC9zdHlsZT4KPHBvbHlsaW5lIGNsYXNzPSJ4dWktY2hlY2tib3gtZ2x5cGgiIHBvaW50cz0iMTcsNCA4LDE1IDMsOSAiLz4KPC9zdmc+);display:none}.nui .nui-checkbox__input{display:none;width:1px;height:1px;position:absolute}.nui .nui-checkbox__input:indeterminate+.nui-checkbox__mark>.nui-checkbox__glyph{display:block;border:solid 2px;border-color:var(--nui-color-bg-content,#fff);background:var(--nui-color-active,#0079aa)}.nui .nui-checkbox__input:indeterminate:disabled+.nui-checkbox__mark>.nui-checkbox__glyph{background-color:var(--nui-color-disabled,#b3b3b3);opacity:1}.nui .nui-checkbox__input:disabled+.nui-checkbox__mark{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;color:var(--nui-color-disabled,#b3b3b3);background-color:var(--nui-color-bg-content,#fff);border-color:var(--nui-color-disabled,#b3b3b3);cursor:default}.nui .nui-checkbox__input:disabled+.nui-checkbox__mark>.nui-checkbox__glyph{opacity:.7}.nui .nui-checkbox__input:checked:disabled+.nui-checkbox__mark{background-color:var(--nui-color-disabled,#b3b3b3);border-color:var(--nui-color-disabled,#b3b3b3)}.nui .nui-checkbox__input:checked:disabled+.nui-checkbox__mark>.nui-checkbox__glyph{background-color:var(--nui-color-disabled,#b3b3b3)}.nui .nui-checkbox__transclude{line-height:18px;min-width:0;margin:-1px 0 -1px 7px}.nui .nui-checkbox__transclude:empty{margin:0}.nui .nui-checkbox .nui-help-hint{line-height:18px;margin-left:23px;padding:0}.nui .nui-checkbox--checked .nui-checkbox__mark{background-color:var(--nui-color-active,#0079aa);border-color:var(--nui-color-active,#0079aa)}.nui .nui-checkbox--checked .nui-checkbox__mark>.nui-checkbox__glyph{display:block}.nui .nui-checkbox--justified .nui-checkbox,.nui .nui-checkbox--justified .nui-checkbox__label,.nui .nui-checkbox--justified .nui-checkbox__content,.nui .nui-checkbox--justified .nui-checkbox__transclude{width:100%}.nui-menu-item__default .nui-checkbox__label{padding:0;min-height:unset}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CheckboxComponent, decorators: [{
type: Component,
args: [{ selector: "nui-checkbox", changeDetection: ChangeDetectionStrategy.OnPush, providers: [
{
provide: NuiFormFieldControl,
useExisting: forwardRef(() => CheckboxComponent),
multi: true,
},
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => CheckboxComponent),
multi: true,
},
], encapsulation: ViewEncapsulation.None, host: {
"[class.nui-checkbox--hovered]": "hovered",
"[class.nui-checkbox--checked]": "checked",
}, template: "<div class=\"nui-checkbox\">\n <label\n class=\"nui-checkbox__label\"\n #checkboxLabel\n role=\"checkbox\"\n [attr.aria-label]=\"ariaLabel || null\"\n [attr.aria-labelledby]=\"ariaLabelledby\"\n [attr.aria-checked]=\"getAriaChecked()\"\n [attr.aria-describedby]=\"ariaDescribedby\"\n [attr.tabindex]=\"!disabled ? 0 : -1\"\n [title]=\"title\"\n [class.nui-checkbox__translucent]=\"disabled\"\n (mouseenter)=\"hoverHandler()\"\n (mouseleave)=\"hoverHandler()\"\n >\n <div class=\"nui-checkbox__content\">\n <input\n #inputViewContainer\n class=\"nui-checkbox__input\"\n type=\"checkbox\"\n [attr.name]=\"name\"\n [value]=\"value\"\n [checked]=\"checked\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [indeterminate]=\"indeterminate\"\n (click)=\"onClick($event)\"\n (change)=\"changeHandler($event)\"\n />\n <div class=\"nui-checkbox__mark\">\n <i class=\"nui-checkbox__glyph\"></i>\n </div>\n <div #checkboxContent class=\"nui-checkbox__transclude\">\n <ng-content></ng-content>\n </div>\n </div>\n <div class=\"nui-help-hint\" *ngIf=\"hint\">{{ hint }}</div>\n </label>\n</div>\n", styles: [".nui-checkbox-group-inline>.nui-checkbox-group{display:inline-flex}.nui-checkbox-group-inline>.nui-checkbox-group nui-checkbox{margin-left:15px}.nui-checkbox-group-inline>.nui-checkbox-group nui-checkbox:first-child{margin-left:0}.nui-checkbox-group-inline>.nui-checkbox-group nui-checkbox .nui-checkbox_label{max-width:450px}.nui .nui-checkbox__content{align-items:center;display:inline-flex;flex-wrap:nowrap;justify-content:flex-start}.nui .nui-checkbox.nui-checkbox--has-action .nui-checkbox__mark:after{display:none}.nui .nui-checkbox__label{cursor:pointer;margin:0;position:relative;line-height:0;font-weight:400;border-radius:3px;width:fit-content;min-width:30px;min-height:30px;padding:7px}.nui .nui-checkbox__label:hover{background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui .nui-checkbox__label:focus{outline:0;box-shadow:inset 0 0 0 2px #00c4d280;background-color:var(--nui-color-bg-transparent-hover,rgba(17, 17, 17, .05))}.nui .nui-checkbox__translucent{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;color:var(--nui-color-text-disabled,rgba(17, 17, 17, .3));cursor:default}.nui .nui-checkbox__translucent:hover{background-color:transparent}.nui .nui-checkbox__translucent:focus{outline:none;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none;background-color:var(--transparent,transparent)}.nui .nui-checkbox__mark{border:solid 2px;background:no-repeat 0 center;border-color:var(--nui-color-active,#0079aa);background-color:var(--nui-color-bg-content,#fff);background-size:16px;border-radius:3px;min-width:16px;width:16px;height:16px;transition:background-color .3s,border-color .3s}.nui .nui-checkbox__glyph{width:100%;height:100%;background-size:12px;background-image:url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSJMYXllcl8xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4PSIwcHgiIHk9IjBweCIKCSB2aWV3Qm94PSIwIDAgMjAgMjAiIHdpZHRoPSIyMCIgaGVpZ2h0PSIyMCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgMjAgMjA7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS54dWktY2hlY2tib3gtZ2x5cGh7ZmlsbDpub25lO3N0cm9rZTojRkZGRkZGO3N0cm9rZS13aWR0aDozO3N0cm9rZS1taXRlcmxpbWl0OjEwO3N0cm9rZS1saW5lY2FwOnJvdW5kO30KPC9zdHlsZT4KPHBvbHlsaW5lIGNsYXNzPSJ4dWktY2hlY2tib3gtZ2x5cGgiIHBvaW50cz0iMTcsNCA4LDE1IDMsOSAiLz4KPC9zdmc+);display:none}.nui .nui-checkbox__input{display:none;width:1px;height:1px;position:absolute}.nui .nui-checkbox__input:indeterminate+.nui-checkbox__mark>.nui-checkbox__glyph{display:block;border:solid 2px;border-color:var(--nui-color-bg-content,#fff);background:var(--nui-color-active,#0079aa)}.nui .nui-checkbox__input:indeterminate:disabled+.nui-checkbox__mark>.nui-checkbox__glyph{background-color:var(--nui-color-disabled,#b3b3b3);opacity:1}.nui .nui-checkbox__input:disabled+.nui-checkbox__mark{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;color:var(--nui-color-disabled,#b3b3b3);background-color:var(--nui-color-bg-content,#fff);border-color:var(--nui-color-disabled,#b3b3b3);cursor:default}.nui .nui-checkbox__input:disabled+.nui-checkbox__mark>.nui-checkbox__glyph{opacity:.7}.nui .nui-checkbox__input:checked:disabled+.nui-checkbox__mark{background-color:var(--nui-color-disabled,#b3b3b3);border-color:var(--nui-color-disabled,#b3b3b3)}.nui .nui-checkbox__input:checked:disabled+.nui-checkbox__mark>.nui-checkbox__glyph{background-color:var(--nui-color-disabled,#b3b3b3)}.nui .nui-checkbox__transclude{line-height:18px;min-width:0;margin:-1px 0 -1px 7px}.nui .nui-checkbox__transclude:empty{margin:0}.nui .nui-checkbox .nui-help-hint{line-height:18px;margin-left:23px;padding:0}.nui .nui-checkbox--checked .nui-checkbox__mark{background-color:var(--nui-color-active,#0079aa);border-color:var(--nui-color-active,#0079aa)}.nui .nui-checkbox--checked .nui-checkbox__mark>.nui-checkbox__glyph{display:block}.nui .nui-checkbox--justified .nui-checkbox,.nui .nui-checkbox--justified .nui-checkbox__label,.nui .nui-checkbox--justified .nui-checkbox__content,.nui .nui-checkbox--justified .nui-checkbox__transclude{width:100%}.nui-menu-item__default .nui-checkbox__label{padding:0;min-height:unset}\n"] }]
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.EventBusService }, { type: i0.Renderer2 }], propDecorators: { ariaLabel: [{
type: Input
}], ariaLabelledby: [{
type: Input
}], ariaDescribedby: [{
type: Input
}], name: [{
type: Input
}], title: [{
type: Input
}], value: [{
type: Input
}], valueChange: [{
type: Output
}], hovered: [{
type: Input
}], checked: [{
type: Input
}], required: [{
type: Input
}], hint: [{
type: Input
}], disabled: [{
type: Input
}], indeterminate: [{
type: Input
}], inputViewContainer: [{
type: ViewChild,
args: ["inputViewContainer", { read: ViewContainerRef }]
}], checkboxContent: [{
type: ViewChild,
args: ["checkboxContent"]
}], checkboxLabel: [{
type: ViewChild,
args: ["checkboxLabel"]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../src/lib/checkbox/checkbox.component.ts","../../../../src/lib/checkbox/checkbox.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    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    OnDestroy,\n    Output,\n    Renderer2,\n    ViewChild,\n    ViewContainerRef,\n    ViewEncapsulation,\n} from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { Subscription } from \"rxjs\";\n\nimport { CheckboxChangeEvent, ICheckboxComponent } from \"./public-api\";\nimport {\n    CHECKBOX_KEYDOWN_EVENT,\n    DOCUMENT_CLICK_EVENT,\n} from \"../../constants/event.constants\";\nimport { KEYBOARD_CODE } from \"../../constants/keycode.constants\";\nimport { EventBusService } from \"../../services/event-bus.service\";\nimport { NuiFormFieldControl } from \"../form-field/public-api\";\n\n@Component({\n    selector: \"nui-checkbox\",\n    templateUrl: \"./checkbox.component.html\",\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NuiFormFieldControl,\n            useExisting: forwardRef(() => CheckboxComponent),\n            multi: true,\n        },\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => CheckboxComponent),\n            multi: true,\n        },\n    ],\n    styleUrls: [\"./checkbox.component.less\"],\n    // TODO: turn on the view envapsulation in the scope of NUI-5823\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        \"[class.nui-checkbox--hovered]\": \"hovered\",\n        \"[class.nui-checkbox--checked]\": \"checked\",\n    },\n})\n\n/**\n * <nui-checkbox> provides the same functionality as a native\n * <input type=\"checkbox\"> enhanced with NUI styling.\n * <example-url>./../examples/index.html#/checkbox</example-url>\n */\nexport class CheckboxComponent\n    implements\n        AfterViewInit,\n        ICheckboxComponent,\n        ControlValueAccessor,\n        OnDestroy\n{\n    private _checked: boolean;\n    private _disabled: boolean;\n\n    /**\n     * Input to set aria label text\n     */\n    @Input() public get ariaLabel(): string {\n        return this._ariaLabel;\n    }\n\n    // changing the value with regular @Input doesn't trigger change detection\n    // so we need to do that manually in the setter\n    public set ariaLabel(value: string) {\n        if (value !== this._ariaLabel) {\n            this._ariaLabel = value;\n            this.changeDetector.markForCheck();\n        }\n    }\n\n    /** Users ca specify the 'aria-labelledby' which will be set to the input element */\n    @Input() ariaLabelledby: string | null = null;\n\n    /** The 'aria-describedby' attribute is read after the element's label and field type. */\n    @Input() ariaDescribedby: string;\n\n    /**\n     * Sets \"name\" attribute for inner input element of nui-checkbox\n     */\n    @Input() public name: string;\n\n    /**\n     * Sets \"title\" attribute for nui-checkbox label\n     */\n    @Input() public title = \"\";\n\n    /**\n     * Sets \"value\" attribute for inner input element of nui-checkbox\n     */\n    @Input() public value: any;\n\n    /**\n     * Event that is fired when nui-checkbox is toggled\n     */\n    @Output() public valueChange = new EventEmitter<CheckboxChangeEvent>();\n\n    /**\n     * Used for changing nui-checkbox component styles when component is hovered\n     */\n    @Input() public hovered: boolean;\n\n    /**\n     * Sets \"checked\" attribute for inner input element of nui-checkbox\n     */\n    @Input()\n    public get checked(): boolean {\n        return this._checked;\n    }\n    public set checked(val: boolean) {\n        if (this._checked !== val) {\n            this.changeDetector.markForCheck();\n        }\n        this._checked = val;\n    }\n\n    /**\n     * Sets \"required\" attribute for inner input element of nui-checkbox\n     */\n    @Input() public required: boolean;\n\n    /**\n     * Sets nui-checkbox hint that is displayed below label\n     */\n    @Input() public hint: string;\n\n    /**\n     * Used for disabling of nui-checkbox\n     */\n    @Input()\n    public get disabled(): boolean {\n        return this._disabled;\n    }\n    public set disabled(val: boolean) {\n        if (this._disabled !== val) {\n            this.changeDetector.markForCheck();\n        }\n        this._disabled = val;\n    }\n\n    /**\n     * Used for setting of nui-checkbox indeterminate state\n     */\n    @Input() public indeterminate: boolean;\n\n    /**\n     * Reference to the inner input checkbox html element\n     */\n    @ViewChild(\"inputViewContainer\", { read: ViewContainerRef })\n    public inputViewContainer: ViewContainerRef;\n\n    @ViewChild(\"checkboxContent\")\n    public checkboxContent: ElementRef;\n    @ViewChild(\"checkboxLabel\")\n    public checkboxLabel: ElementRef;\n\n    private rendererListener: Function;\n    private sub: Subscription;\n\n    private _ariaLabel: string = \"Checkbox\";\n\n    private keysAction = [KEYBOARD_CODE.SPACE, KEYBOARD_CODE.ENTER].map(String);\n\n    constructor(\n        private changeDetector: ChangeDetectorRef,\n        private eventBusService: EventBusService,\n        private renderer: Renderer2\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this.rendererListener = this.renderer.listen(\n            this.checkboxLabel.nativeElement,\n            \"keydown\",\n            (event: KeyboardEvent) => {\n                this.eventBusService\n                    .getStream(CHECKBOX_KEYDOWN_EVENT)\n                    .next(event);\n            }\n        );\n\n        this.sub = this.eventBusService\n            .getStream(CHECKBOX_KEYDOWN_EVENT)\n            .subscribe((event) => {\n                if (event.target === this.checkboxLabel.nativeElement) {\n                    if (this.keysAction.includes(event.code)) {\n                        event.stopPropagation();\n                        event.preventDefault();\n                        if (!this.disabled) {\n                            this.handleKeyboardActions();\n                        }\n                    }\n                }\n            });\n    }\n\n    public getAriaChecked(): \"true\" | \"false\" | \"mixed\" {\n        if (this.checked) {\n            return \"true\";\n        }\n\n        return this.indeterminate ? \"mixed\" : \"false\";\n    }\n\n    /**\n     * Used for changing of css style when nui-checkbox is hovered\n     */\n    public hoverHandler(): void {\n        this.hovered = !this.hovered;\n    }\n\n    /**\n     * nui-checkbox check/uncheck state handler\n     * @param event Changed nui-checkbox component\n     */\n    public changeHandler(event: CheckboxChangeEvent): void {\n        this.valueChange.emit(event);\n        const checked = !!event.target?.checked;\n        this.onChange(checked);\n        this.onTouched();\n        this.writeValue(checked);\n    }\n\n    public onClick(event: MouseEvent): void {\n        event.stopPropagation();\n        this.eventBusService.getStream(DOCUMENT_CLICK_EVENT).next(event);\n    }\n\n    public onChange(value: any): void {}\n\n    public onTouched(): void {}\n\n    public writeValue(value: any): void {\n        this.checked = value;\n    }\n\n    public registerOnChange(fn: (value: boolean) => 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    }\n\n    public ngOnDestroy(): void {\n        if (this.rendererListener) {\n            this.rendererListener();\n        }\n        if (this.sub) {\n            this.sub.unsubscribe();\n        }\n    }\n\n    private handleKeyboardActions(): void {\n        if (this.indeterminate) {\n            this.inputViewContainer.element.nativeElement.checked = true;\n            this.indeterminate = false;\n        } else {\n            this.inputViewContainer.element.nativeElement.checked =\n                !this.inputViewContainer.element.nativeElement.checked;\n        }\n        this.inputViewContainer.element.nativeElement.dispatchEvent(\n            new Event(\"change\")\n        );\n    }\n}\n","<div class=\"nui-checkbox\">\n    <label\n        class=\"nui-checkbox__label\"\n        #checkboxLabel\n        role=\"checkbox\"\n        [attr.aria-label]=\"ariaLabel || null\"\n        [attr.aria-labelledby]=\"ariaLabelledby\"\n        [attr.aria-checked]=\"getAriaChecked()\"\n        [attr.aria-describedby]=\"ariaDescribedby\"\n        [attr.tabindex]=\"!disabled ? 0 : -1\"\n        [title]=\"title\"\n        [class.nui-checkbox__translucent]=\"disabled\"\n        (mouseenter)=\"hoverHandler()\"\n        (mouseleave)=\"hoverHandler()\"\n    >\n        <div class=\"nui-checkbox__content\">\n            <input\n                #inputViewContainer\n                class=\"nui-checkbox__input\"\n                type=\"checkbox\"\n                [attr.name]=\"name\"\n                [value]=\"value\"\n                [checked]=\"checked\"\n                [disabled]=\"disabled\"\n                [required]=\"required\"\n                [indeterminate]=\"indeterminate\"\n                (click)=\"onClick($event)\"\n                (change)=\"changeHandler($event)\"\n            />\n            <div class=\"nui-checkbox__mark\">\n                <i class=\"nui-checkbox__glyph\"></i>\n            </div>\n            <div #checkboxContent class=\"nui-checkbox__transclude\">\n                <ng-content></ng-content>\n            </div>\n        </div>\n        <div class=\"nui-help-hint\" *ngIf=\"hint\">{{ hint }}</div>\n    </label>\n</div>\n"]}