UNPKG

carbon-components-angular

Version:
244 lines 25 kB
import { Component, HostBinding, Input, Output, EventEmitter, HostListener, ContentChild, Optional } from "@angular/core"; import { Subscription } from "rxjs"; import { ContextMenuComponent } from "./context-menu.component"; import * as i0 from "@angular/core"; import * as i1 from "./context-menu-selection.service"; import * as i2 from "@angular/common"; import * as i3 from "carbon-components-angular/icon"; export class ContextMenuItemComponent { constructor(elementRef, contextMenuSelectionService) { this.elementRef = elementRef; this.contextMenuSelectionService = contextMenuSelectionService; this.optionClass = true; this.role = "menuitem"; this.tabindex = -1; this.ariaHasPopup = null; this.ariaExpanded = null; this.disabled = false; this.danger = false; this.label = ""; this.info = ""; this.type = null; this.checked = false; this.icon = ""; this.value = ""; this.checkedChange = new EventEmitter(); this.itemClick = new EventEmitter(); this.hasChildren = false; this.selectable = false; this.subscriptions = new Subscription(); } get ariaChecked() { return this.type === "checkbox" ? (this.checked ? true : false) : null; } get ariaDisabled() { return this.disabled; } ngOnInit() { switch (this.type) { case "checkbox": { this.role = "menuitemcheckbox"; this.selectable = true; break; } case "radio": { this.role = "menuitemradio"; this.selectable = true; break; } default: { this.role = "menuitem"; } } if (this.type && this.contextMenuSelectionService && this.value) { const { selectionObservable } = this.contextMenuSelectionService; const subscription = selectionObservable.subscribe((value) => { if (this.type === "radio") { this.handleSelection(value === this.value); } if (this.type === "checkbox") { this.handleSelection(value.includes(this.value)); } }); this.subscriptions.add(subscription); } } ngAfterContentInit() { if (this.childContextMenu) { this.hasChildren = true; this.ariaHasPopup = true; this.ariaExpanded = false; } } handleClick(event) { event.stopPropagation(); if (this.hasChildren) { this.openSubMenu(); this.childContextMenu.focusMenu(); } if (this.type) { this.handleSelection(!this.checked); } if (this.contextMenuSelectionService) { if (this.type === "radio") { this.contextMenuSelectionService.selectRadio(this.value); } if (this.type === "checkbox") { this.contextMenuSelectionService.selectCheckbox(this.value); } } if (!this.disabled) { this.itemClick.emit({ event, label: this.label, info: this.info, value: this.value, type: this.type }); } } handleSelection(selected) { this.checked = selected; this.checkedChange.emit(this.checked); } openSubMenu() { if (this.childContextMenu) { this.childContextMenu.open = true; this.ariaExpanded = true; const dimensions = this.elementRef.nativeElement.getBoundingClientRect(); this.childContextMenu.position.left = dimensions.left + dimensions.width; // subtract 4px to account for margins this.childContextMenu.position.top = dimensions.top - 4; } } closeSubMenu() { if (this.childContextMenu) { this.childContextMenu.open = false; this.ariaExpanded = false; } } handleMouseOver() { this.openSubMenu(); } handleMouseOut() { this.closeSubMenu(); } handleFocus() { this.tabindex = 0; if (this.hasChildren && this.ariaExpanded) { this.closeSubMenu(); } } handleBlur() { this.tabindex = -1; } focusItem() { this.elementRef.nativeElement.focus(); } ngOnDestroy() { this.subscriptions.unsubscribe(); } } ContextMenuItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ContextMenuItemComponent, deps: [{ token: i0.ElementRef }, { token: i1.ContextMenuSelectionService, optional: true }], target: i0.ɵɵFactoryTarget.Component }); ContextMenuItemComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ContextMenuItemComponent, selector: "cds-menu-item, cds-context-menu-item, ibm-context-menu-item", inputs: { disabled: "disabled", danger: "danger", label: "label", info: "info", type: "type", checked: "checked", icon: "icon", value: "value" }, outputs: { checkedChange: "checkedChange", itemClick: "itemClick" }, host: { listeners: { "keydown.enter": "handleClick($event)", "keydown.space": "handleClick($event)", "click": "handleClick($event)", "mouseover": "handleMouseOver()", "mouseout": "handleMouseOut()", "focus": "handleFocus()", "blur": "handleBlur()" }, properties: { "class.cds--menu-item": "this.optionClass", "attr.role": "this.role", "attr.tabindex": "this.tabindex", "attr.aria-haspopup": "this.ariaHasPopup", "attr.aria-expanded": "this.ariaExpanded", "attr.aria-checked": "this.ariaChecked", "attr.aria-disabled": "this.ariaDisabled", "class.cds--menu-item--disabled": "this.disabled", "class.cds--menu-item--danger": "this.danger" } }, queries: [{ propertyName: "childContextMenu", first: true, predicate: ContextMenuComponent, descendants: true, static: true }], ngImport: i0, template: ` <div class="cds--menu-item__icon"> <svg *ngIf="selectable && checked" cdsIcon="checkmark" size="16"></svg> <svg *ngIf="!selectable && icon" [cdsIcon]="icon" size="16"></svg> </div> <div class="cds--menu-item__label" [title]="label">{{label}}</div> <div class="cds--menu-item__shortcut"> <ng-container *ngIf="info">{{info}}</ng-container> <svg *ngIf="hasChildren" cdsIcon="caret--right" size="16"></svg> </div> <ng-content></ng-content> `, isInline: true, styles: [":host{grid-template-columns:1rem 1fr max-content}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ContextMenuItemComponent, decorators: [{ type: Component, args: [{ selector: "cds-menu-item, cds-context-menu-item, ibm-context-menu-item", template: ` <div class="cds--menu-item__icon"> <svg *ngIf="selectable && checked" cdsIcon="checkmark" size="16"></svg> <svg *ngIf="!selectable && icon" [cdsIcon]="icon" size="16"></svg> </div> <div class="cds--menu-item__label" [title]="label">{{label}}</div> <div class="cds--menu-item__shortcut"> <ng-container *ngIf="info">{{info}}</ng-container> <svg *ngIf="hasChildren" cdsIcon="caret--right" size="16"></svg> </div> <ng-content></ng-content> `, styles: [":host{grid-template-columns:1rem 1fr max-content}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.ContextMenuSelectionService, decorators: [{ type: Optional }] }]; }, propDecorators: { optionClass: [{ type: HostBinding, args: ["class.cds--menu-item"] }], role: [{ type: HostBinding, args: ["attr.role"] }], tabindex: [{ type: HostBinding, args: ["attr.tabindex"] }], ariaHasPopup: [{ type: HostBinding, args: ["attr.aria-haspopup"] }], ariaExpanded: [{ type: HostBinding, args: ["attr.aria-expanded"] }], ariaChecked: [{ type: HostBinding, args: ["attr.aria-checked"] }], ariaDisabled: [{ type: HostBinding, args: ["attr.aria-disabled"] }], disabled: [{ type: Input }, { type: HostBinding, args: ["class.cds--menu-item--disabled"] }], danger: [{ type: Input }, { type: HostBinding, args: ["class.cds--menu-item--danger"] }], label: [{ type: Input }], info: [{ type: Input }], type: [{ type: Input }], checked: [{ type: Input }], icon: [{ type: Input }], value: [{ type: Input }], checkedChange: [{ type: Output }], itemClick: [{ type: Output }], childContextMenu: [{ type: ContentChild, args: [ContextMenuComponent, { static: true }] }], handleClick: [{ type: HostListener, args: ["keydown.enter", ["$event"]] }, { type: HostListener, args: ["keydown.space", ["$event"]] }, { type: HostListener, args: ["click", ["$event"]] }], handleMouseOver: [{ type: HostListener, args: ["mouseover"] }], handleMouseOut: [{ type: HostListener, args: ["mouseout"] }], handleFocus: [{ type: HostListener, args: ["focus"] }], handleBlur: [{ type: HostListener, args: ["blur"] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu-item.component.js","sourceRoot":"","sources":["../../../src/context-menu/context-menu-item.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,WAAW,EACX,KAAK,EACL,MAAM,EACN,YAAY,EAEZ,YAAY,EACZ,YAAY,EACZ,QAAQ,EAIR,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AAEpC,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;;;;;AAuBhE,MAAM,OAAO,wBAAwB;IA8BpC,YACW,UAAsB,EACV,2BAAwD;QADpE,eAAU,GAAV,UAAU,CAAY;QACV,gCAA2B,GAA3B,2BAA2B,CAA6B;QA/B1C,gBAAW,GAAG,IAAI,CAAC;QAC9B,SAAI,GAAG,UAAU,CAAC;QACd,aAAQ,GAAG,CAAC,CAAC,CAAC;QACT,iBAAY,GAAG,IAAI,CAAC;QACpB,iBAAY,GAAG,IAAI,CAAC;QAQC,aAAQ,GAAG,KAAK,CAAC;QACnB,WAAM,GAAG,KAAK,CAAC;QAC5D,UAAK,GAAG,EAAE,CAAC;QACX,SAAI,GAAG,EAAE,CAAC;QACV,SAAI,GAAgC,IAAI,CAAC;QACzC,YAAO,GAAG,KAAK,CAAC;QAChB,SAAI,GAAG,EAAE,CAAC;QACV,UAAK,GAAG,EAAE,CAAC;QACV,kBAAa,GAAG,IAAI,YAAY,EAAW,CAAC;QAC5C,cAAS,GAAG,IAAI,YAAY,EAAkB,CAAC;QAEzD,gBAAW,GAAG,KAAK,CAAC;QACpB,eAAU,GAAG,KAAK,CAAC;QAGX,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IAKxC,CAAC;IA3BJ,IAAsC,WAAW;QAChD,OAAO,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC;YAChC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACvC,CAAC;IACD,IAAuC,YAAY;QAClD,OAAO,IAAI,CAAC,QAAQ,CAAC;IACtB,CAAC;IAuBD,QAAQ;QACP,QAAQ,IAAI,CAAC,IAAI,EAAE;YAClB,KAAK,UAAU,CAAC,CAAC;gBAChB,IAAI,CAAC,IAAI,GAAG,kBAAkB,CAAC;gBAC/B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,MAAM;aACN;YACD,KAAK,OAAO,CAAC,CAAC;gBACb,IAAI,CAAC,IAAI,GAAG,eAAe,CAAC;gBAC5B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;gBACvB,MAAM;aACN;YACD,OAAO,CAAC,CAAC;gBACR,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;aACvB;SACD;QAED,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,2BAA2B,IAAI,IAAI,CAAC,KAAK,EAAE;YAChE,MAAM,EAAE,mBAAmB,EAAE,GAAG,IAAI,CAAC,2BAA2B,CAAC;YACjE,MAAM,YAAY,GAAG,mBAAmB,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC5D,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE;oBAC1B,IAAI,CAAC,eAAe,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC3C;gBAED,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,EAAE;oBAC7B,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;iBACjD;YACF,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;SACrC;IACF,CAAC;IAED,kBAAkB;QACjB,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAC1B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;SAC1B;IACF,CAAC;IAKD,WAAW,CAAC,KAAiC;QAC5C,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,WAAW,EAAE;YACrB,IAAI,CAAC,WAAW,EAAE,CAAC;YACnB,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC;SAClC;QAED,IAAI,IAAI,CAAC,IAAI,EAAE;YACd,IAAI,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACpC;QAED,IAAI,IAAI,CAAC,2BAA2B,EAAE;YACrC,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE;gBAC1B,IAAI,CAAC,2BAA2B,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACzD;YAED,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU,EAAE;gBAC7B,IAAI,CAAC,2BAA2B,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAC5D;SACD;QAED,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACnB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;gBACnB,KAAK;gBACL,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,IAAI,EAAE,IAAI,CAAC,IAAI;aACf,CAAC,CAAC;SACH;IACF,CAAC;IAED,eAAe,CAAC,QAAiB;QAChC,IAAI,CAAC,OAAO,GAAG,QAAQ,CAAC;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACvC,CAAC;IAED,WAAW;QACV,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAC1B,IAAI,CAAC,gBAAgB,CAAC,IAAI,GAAG,IAAI,CAAC;YAClC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC;YACzE,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,GAAG,UAAU,CAAC,IAAI,GAAG,UAAU,CAAC,KAAK,CAAC;YACzE,sCAAsC;YACtC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,GAAG,GAAG,UAAU,CAAC,GAAG,GAAG,CAAC,CAAC;SACxD;IACF,CAAC;IAED,YAAY;QACX,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAC1B,IAAI,CAAC,gBAAgB,CAAC,IAAI,GAAG,KAAK,CAAC;YACnC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;SAC1B;IACF,CAAC;IAGD,eAAe;QACd,IAAI,CAAC,WAAW,EAAE,CAAC;IACpB,CAAC;IAGD,cAAc;QACb,IAAI,CAAC,YAAY,EAAE,CAAC;IACrB,CAAC;IAGD,WAAW;QACV,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC;QAClB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,YAAY,EAAE;YAC1C,IAAI,CAAC,YAAY,EAAE,CAAC;SACpB;IACF,CAAC;IAGD,UAAU;QACT,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC;IACpB,CAAC;IAED,SAAS;QACR,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACvC,CAAC;IAED,WAAW;QACV,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IAClC,CAAC;;qHAlKW,wBAAwB;yGAAxB,wBAAwB,y+BA2BtB,oBAAoB,8DA7CxB;;;;;;;;;;;EAWT;2FAOW,wBAAwB;kBApBpC,SAAS;+BACC,6DAA6D,YAC7D;;;;;;;;;;;EAWT;;0BAuCC,QAAQ;4CA/B2B,WAAW;sBAA/C,WAAW;uBAAC,sBAAsB;gBACT,IAAI;sBAA7B,WAAW;uBAAC,WAAW;gBACM,QAAQ;sBAArC,WAAW;uBAAC,eAAe;gBACO,YAAY;sBAA9C,WAAW;uBAAC,oBAAoB;gBACE,YAAY;sBAA9C,WAAW;uBAAC,oBAAoB;gBACK,WAAW;sBAAhD,WAAW;uBAAC,mBAAmB;gBAIO,YAAY;sBAAlD,WAAW;uBAAC,oBAAoB;gBAGuB,QAAQ;sBAA/D,KAAK;;sBAAI,WAAW;uBAAC,gCAAgC;gBACA,MAAM;sBAA3D,KAAK;;sBAAI,WAAW;uBAAC,8BAA8B;gBAC3C,KAAK;sBAAb,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACI,aAAa;sBAAtB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBAK+C,gBAAgB;sBAArE,YAAY;uBAAC,oBAAoB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAmDpD,WAAW;sBAHV,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;;sBACxC,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;;sBACxC,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;gBAyDjC,eAAe;sBADd,YAAY;uBAAC,WAAW;gBAMzB,cAAc;sBADb,YAAY;uBAAC,UAAU;gBAMxB,WAAW;sBADV,YAAY;uBAAC,OAAO;gBASrB,UAAU;sBADT,YAAY;uBAAC,MAAM","sourcesContent":["import {\n\tComponent,\n\tHostBinding,\n\tInput,\n\tOutput,\n\tEventEmitter,\n\tElementRef,\n\tHostListener,\n\tContentChild,\n\tOptional,\n\tOnInit,\n\tAfterContentInit,\n\tOnDestroy\n} from \"@angular/core\";\nimport { Subscription } from \"rxjs\";\nimport { ContextMenuSelectionService } from \"./context-menu-selection.service\";\nimport { ContextMenuComponent } from \"./context-menu.component\";\nimport { ItemClickEvent } from \"./context-menu.types\";\n\n@Component({\n\tselector: \"cds-menu-item, cds-context-menu-item, ibm-context-menu-item\",\n\ttemplate: `\n\t\t<div class=\"cds--menu-item__icon\">\n\t\t\t<svg *ngIf=\"selectable && checked\" cdsIcon=\"checkmark\" size=\"16\"></svg>\n\t\t\t<svg *ngIf=\"!selectable && icon\" [cdsIcon]=\"icon\" size=\"16\"></svg>\n\t\t</div>\n\t\t<div class=\"cds--menu-item__label\" [title]=\"label\">{{label}}</div>\n\t\t<div class=\"cds--menu-item__shortcut\">\n\t\t\t<ng-container *ngIf=\"info\">{{info}}</ng-container>\n\t\t\t<svg *ngIf=\"hasChildren\" cdsIcon=\"caret--right\" size=\"16\"></svg>\n\t\t</div>\n\t\t<ng-content></ng-content>\n\t`,\n\tstyles: [`\n\t\t:host {\n\t\t\tgrid-template-columns: 1rem 1fr max-content;\n\t\t}\n\t`]\n})\nexport class ContextMenuItemComponent implements OnInit, AfterContentInit, OnDestroy {\n\t@HostBinding(\"class.cds--menu-item\") optionClass = true;\n\t@HostBinding(\"attr.role\") role = \"menuitem\";\n\t@HostBinding(\"attr.tabindex\") tabindex = -1;\n\t@HostBinding(\"attr.aria-haspopup\") ariaHasPopup = null;\n\t@HostBinding(\"attr.aria-expanded\") ariaExpanded = null;\n\t@HostBinding(\"attr.aria-checked\") get ariaChecked() {\n\t\treturn this.type === \"checkbox\" ?\n\t\t\t(this.checked ? true : false) : null;\n\t}\n\t@HostBinding(\"attr.aria-disabled\") get ariaDisabled() {\n\t\treturn this.disabled;\n\t}\n\t@Input() @HostBinding(\"class.cds--menu-item--disabled\") disabled = false;\n\t@Input() @HostBinding(\"class.cds--menu-item--danger\") danger = false;\n\t@Input() label = \"\";\n\t@Input() info = \"\";\n\t@Input() type: null | \"checkbox\" | \"radio\" = null;\n\t@Input() checked = false;\n\t@Input() icon = \"\";\n\t@Input() value = \"\";\n\t@Output() checkedChange = new EventEmitter<boolean>();\n\t@Output() itemClick = new EventEmitter<ItemClickEvent>();\n\n\thasChildren = false;\n\tselectable = false;\n\n\t@ContentChild(ContextMenuComponent, { static: true }) childContextMenu: ContextMenuComponent;\n\tprivate subscriptions = new Subscription();\n\n\tconstructor(\n\t\tprotected elementRef: ElementRef,\n\t\t@Optional() protected contextMenuSelectionService: ContextMenuSelectionService\n\t) {}\n\n\tngOnInit() {\n\t\tswitch (this.type) {\n\t\t\tcase \"checkbox\": {\n\t\t\t\tthis.role = \"menuitemcheckbox\";\n\t\t\t\tthis.selectable = true;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tcase \"radio\": {\n\t\t\t\tthis.role = \"menuitemradio\";\n\t\t\t\tthis.selectable = true;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\tthis.role = \"menuitem\";\n\t\t\t}\n\t\t}\n\n\t\tif (this.type && this.contextMenuSelectionService && this.value) {\n\t\t\tconst { selectionObservable } = this.contextMenuSelectionService;\n\t\t\tconst subscription = selectionObservable.subscribe((value) => {\n\t\t\t\tif (this.type === \"radio\") {\n\t\t\t\t\tthis.handleSelection(value === this.value);\n\t\t\t\t}\n\n\t\t\t\tif (this.type === \"checkbox\") {\n\t\t\t\t\tthis.handleSelection(value.includes(this.value));\n\t\t\t\t}\n\t\t\t});\n\t\t\tthis.subscriptions.add(subscription);\n\t\t}\n\t}\n\n\tngAfterContentInit() {\n\t\tif (this.childContextMenu) {\n\t\t\tthis.hasChildren = true;\n\t\t\tthis.ariaHasPopup = true;\n\t\t\tthis.ariaExpanded = false;\n\t\t}\n\t}\n\n\t@HostListener(\"keydown.enter\", [\"$event\"])\n\t@HostListener(\"keydown.space\", [\"$event\"])\n\t@HostListener(\"click\", [\"$event\"])\n\thandleClick(event: MouseEvent & KeyboardEvent) {\n\t\tevent.stopPropagation();\n\t\tif (this.hasChildren) {\n\t\t\tthis.openSubMenu();\n\t\t\tthis.childContextMenu.focusMenu();\n\t\t}\n\n\t\tif (this.type) {\n\t\t\tthis.handleSelection(!this.checked);\n\t\t}\n\n\t\tif (this.contextMenuSelectionService) {\n\t\t\tif (this.type === \"radio\") {\n\t\t\t\tthis.contextMenuSelectionService.selectRadio(this.value);\n\t\t\t}\n\n\t\t\tif (this.type === \"checkbox\") {\n\t\t\t\tthis.contextMenuSelectionService.selectCheckbox(this.value);\n\t\t\t}\n\t\t}\n\n\t\tif (!this.disabled) {\n\t\t\tthis.itemClick.emit({\n\t\t\t\tevent,\n\t\t\t\tlabel: this.label,\n\t\t\t\tinfo: this.info,\n\t\t\t\tvalue: this.value,\n\t\t\t\ttype: this.type\n\t\t\t});\n\t\t}\n\t}\n\n\thandleSelection(selected: boolean) {\n\t\tthis.checked = selected;\n\t\tthis.checkedChange.emit(this.checked);\n\t}\n\n\topenSubMenu() {\n\t\tif (this.childContextMenu) {\n\t\t\tthis.childContextMenu.open = true;\n\t\t\tthis.ariaExpanded = true;\n\t\t\tconst dimensions = this.elementRef.nativeElement.getBoundingClientRect();\n\t\t\tthis.childContextMenu.position.left = dimensions.left + dimensions.width;\n\t\t\t// subtract 4px to account for margins\n\t\t\tthis.childContextMenu.position.top = dimensions.top - 4;\n\t\t}\n\t}\n\n\tcloseSubMenu() {\n\t\tif (this.childContextMenu) {\n\t\t\tthis.childContextMenu.open = false;\n\t\t\tthis.ariaExpanded = false;\n\t\t}\n\t}\n\n\t@HostListener(\"mouseover\")\n\thandleMouseOver() {\n\t\tthis.openSubMenu();\n\t}\n\n\t@HostListener(\"mouseout\")\n\thandleMouseOut() {\n\t\tthis.closeSubMenu();\n\t}\n\n\t@HostListener(\"focus\")\n\thandleFocus() {\n\t\tthis.tabindex = 0;\n\t\tif (this.hasChildren && this.ariaExpanded) {\n\t\t\tthis.closeSubMenu();\n\t\t}\n\t}\n\n\t@HostListener(\"blur\")\n\thandleBlur() {\n\t\tthis.tabindex = -1;\n\t}\n\n\tfocusItem() {\n\t\tthis.elementRef.nativeElement.focus();\n\t}\n\n\tngOnDestroy() {\n\t\tthis.subscriptions.unsubscribe();\n\t}\n}\n"]}