UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

536 lines • 44.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { CommonModule } from '@angular/common'; import { Component, ContentChildren, ChangeDetectorRef, EventEmitter, HostBinding, Input, NgModule, Output, QueryList, Renderer2, ViewChildren } from '@angular/core'; import { Subject } from 'rxjs'; import { IgxButtonDirective, IgxButtonModule } from '../directives/button/button.directive'; import { IgxRippleModule } from '../directives/ripple/ripple.directive'; import { IgxIconModule } from '../icon/index'; import { takeUntil } from 'rxjs/operators'; /** @enum {number} */ const ButtonGroupAlignment = { horizontal: 0, vertical: 1, }; export { ButtonGroupAlignment }; ButtonGroupAlignment[ButtonGroupAlignment.horizontal] = 'horizontal'; ButtonGroupAlignment[ButtonGroupAlignment.vertical] = 'vertical'; /** @type {?} */ let NEXT_ID = 0; /** * **Ignite UI for Angular Button Group** - * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/buttongroup.html) * * The Ignite UI Button Group displays a group of buttons either vertically or horizontally. The group supports * single, multiple and toggle selection. * * Example: * ```html * <igx-buttongroup multiSelection="true" [values]="fontOptions"> * </igx-buttongroup> * ``` * The `fontOptions` value shown above is defined as: * ```typescript * this.fontOptions = [ * { icon: 'format_bold', selected: false }, * { icon: 'format_italic', selected: false }, * { icon: 'format_underlined', selected: false }]; * ``` */ export class IgxButtonGroupComponent { /** * @param {?} _cdr * @param {?} _renderer */ constructor(_cdr, _renderer) { this._cdr = _cdr; this._renderer = _renderer; this._disabled = false; this.buttonClickNotifier$ = new Subject(); this.queryListNotifier$ = new Subject(); /** * An \@Input property that sets the value of the `id` attribute. If not set it will be automatically generated. * ```html * <igx-buttongroup [id]="'igx-dialog-56'" [multiSelection]="!multi" [values]="alignOptions"> * ``` */ this.id = `igx-buttongroup-${NEXT_ID++}`; /** * An \@Input property that enables selecting multiple buttons. By default, multi-selection is false. * ```html * <igx-buttongroup [multiSelection]="false" [alignment]="alignment"></igx-buttongroup> * ``` */ this.multiSelection = false; /** * @hidden */ this.selectedIndexes = []; /** * An \@Ouput property that emits an event when a button is selected. * ```typescript * \@ViewChild("toast") * private toast: IgxToastComponent; * public onSelect(buttongroup){ * this.toast.show() * } * //... * ``` * ```html * <igx-buttongroup #MyChild [multiSelection]="!multi" (onSelect)="onSelect($event)"></igx-buttongroup> * <igx-toast #toast message="You have made a selection!"></igx-toast> * ``` */ this.onSelect = new EventEmitter(); /** * An \@Ouput property that emits an event when a button is deselected. * ```typescript * \@ViewChild("toast") * private toast: IgxToastComponent; * public onUnselect(buttongroup){ * this.toast.show() * } * //... * ``` * ```html * igx-buttongroup #MyChild [multiSelection]="multi" (onUnselect)="onUnselect($event)"></igx-buttongroup> * <igx-toast #toast message="You have deselected a button!"></igx-toast> * ``` */ this.onUnselect = new EventEmitter(); } /** * A collection containing all buttons inside the button group. * @return {?} */ get buttons() { return [...this.viewButtons.toArray(), ...this.templateButtons.toArray()]; } /** * Allows you to set a style using the `itemContentCssClass` input. * The value should be the CSS class name that will be applied to the button group. * ```typescript * public style1 = "styleClass"; * //.. * ``` * ```html * <igx-buttongroup [itemContentCssClass]="style1" [multiSelection]="!multi" [values]="alignOptions"> * ``` * @param {?} value * @return {?} */ set itemContentCssClass(value) { this._itemContentCssClass = value || this._itemContentCssClass; } /** * Returns the CSS class of the item content of the `IgxButtonGroup`. * ```typescript * \@ViewChild("MyChild") * public buttonG: IgxButtonGroupComponent; * ngAfterViewInit(){ * let buttonSelect = this.buttonG.itemContentCssClass; * } * ``` * @return {?} */ get itemContentCssClass() { return this._itemContentCssClass; } /** * An \@Input property that allows you to disable the `igx-buttongroup` component. By default it's false. * ```html * <igx-buttongroup [disabled]="true" [multiSelection]="multi" [values]="fontOptions"></igx-buttongroup> * ``` * @return {?} */ get disabled() { return this._disabled; } /** * @param {?} value * @return {?} */ set disabled(value) { if (this._disabled !== value) { this._disabled = value; if (this.viewButtons && this.templateButtons) { this.buttons.forEach((b) => b.disabled = this._disabled); } } } /** * Allows you to set the button group alignment. * Available options are `ButtonGroupAlignment.horizontal` (default) and `ButtonGroupAlignment.vertical`. * ```typescript * public alignment = ButtonGroupAlignment.vertical; * //.. * ``` * ```html * <igx-buttongroup [multiSelection]="false" [values]="cities" [alignment]="alignment"></igx-buttongroup> * ``` * @param {?} value * @return {?} */ set alignment(value) { this._isVertical = value === ButtonGroupAlignment.vertical; } /** * Returns the alignment of the `igx-buttongroup`. * ```typescript * \@ViewChild("MyChild") * public buttonG: IgxButtonGroupComponent; * ngAfterViewInit(){ * let buttonAlignment = this.buttonG.alignment; * } * ``` * @return {?} */ get alignment() { return this._isVertical ? ButtonGroupAlignment.vertical : ButtonGroupAlignment.horizontal; } /** * Returns true if the `igx-buttongroup` alignment is vertical. * Note that in order for the accessor to work correctly the property should be set explicitly. * ```html * <igx-buttongroup #MyChild [alignment]="alignment" [values]="alignOptions"> * ``` * ```typescript * //... * \@ViewChild("MyChild") * private buttonG: IgxButtonGroupComponent; * ngAfterViewInit(){ * let orientation = this.buttonG.isVertical; * } * ``` * @return {?} */ get isVertical() { return this._isVertical; } /** * Gets the selected button/buttons. * ```typescript * \@ViewChild("MyChild") * private buttonG: IgxButtonGroupComponent; * ngAfterViewInit(){ * let selectedButton = this.buttonG.selectedButtons; * } * ``` * @return {?} */ get selectedButtons() { return this.buttons.filter((b, i) => { return this.selectedIndexes.indexOf(i) !== -1; }); } /** * Selects a button by its index. * \@memberOf {\@link IgxButtonGroupComponent} * ```typescript * \@ViewChild("MyChild") * private buttonG: IgxButtonGroupComponent; * ngAfterViewInit(){ * this.buttonG.selectButton(2); * this.cdr.detectChanges(); * } * ``` * @param {?} index * @return {?} */ selectButton(index) { if (index >= this.buttons.length || index < 0) { return; } /** @type {?} */ const button = this.buttons[index]; /** @type {?} */ const buttonElement = button.nativeElement; if (buttonElement.classList.contains('igx-button--disabled')) { return; } this.selectedIndexes.push(index); button.selected = true; this._renderer.setAttribute(buttonElement, 'aria-pressed', 'true'); this._renderer.addClass(buttonElement, 'igx-button-group__item--selected'); this.onSelect.emit({ button: button, index: index }); /** @type {?} */ const indexInViewButtons = this.viewButtons.toArray().indexOf(button); if (indexInViewButtons !== -1) { this.values[indexInViewButtons].selected = true; } // deselect other buttons if multiSelection is not enabled if (!this.multiSelection && this.selectedIndexes.length > 1) { this.buttons.forEach((b, i) => { if (i !== index && this.selectedIndexes.indexOf(i) !== -1) { this.deselectButton(i); } }); } } /** * Deselects a button by its index. * \@memberOf {\@link IgxButtonGroupComponent} * ```typescript * \@ViewChild("MyChild") * private buttonG: IgxButtonGroupComponent; * ngAfterViewInit(){ * this.buttonG.deselectButton(2); * this.cdr.detectChanges(); * } * ``` * @param {?} index * @return {?} */ deselectButton(index) { if (index >= this.buttons.length || index < 0) { return; } /** @type {?} */ const button = this.buttons[index]; /** @type {?} */ const buttonElement = button.nativeElement; if (buttonElement.classList.contains('igx-button--disabled')) { return; } this.selectedIndexes.splice(this.selectedIndexes.indexOf(index), 1); button.selected = false; this._renderer.setAttribute(buttonElement, 'aria-pressed', 'false'); this._renderer.removeClass(buttonElement, 'igx-button-group__item--selected'); this.onUnselect.emit({ button: button, index: index }); /** @type {?} */ const indexInViewButtons = this.viewButtons.toArray().indexOf(button); if (indexInViewButtons !== -1) { this.values[indexInViewButtons].selected = false; } } /** * @hidden * @return {?} */ ngAfterViewInit() { /** @type {?} */ const initButtons = () => { // Cancel any existing buttonClick subscriptions this.buttonClickNotifier$.next(); this.selectedIndexes.splice(0, this.selectedIndexes.length); // initial configuration this.buttons.forEach((button, index) => { /** @type {?} */ const buttonElement = button.nativeElement; if (this.disabled) { button.disabled = true; } if (!button.disabled && button.selected) { this.selectButton(index); } button.buttonClick.pipe(takeUntil(this.buttonClickNotifier$)).subscribe((ev) => this._clickHandler(ev, index)); this._renderer.addClass(buttonElement, 'igx-button-group__item'); }); }; this.viewButtons.changes.pipe(takeUntil(this.queryListNotifier$)).subscribe(() => initButtons()); this.templateButtons.changes.pipe(takeUntil(this.queryListNotifier$)).subscribe(() => initButtons()); initButtons(); this._cdr.detectChanges(); } /** * @hidden * @return {?} */ ngOnDestroy() { this.buttonClickNotifier$.next(); this.buttonClickNotifier$.complete(); this.queryListNotifier$.next(); this.queryListNotifier$.complete(); } /** * @hidden * @param {?} event * @param {?} i * @return {?} */ _clickHandler(event, i) { if (this.selectedIndexes.indexOf(i) !== -1) { this.deselectButton(i); } else { this.selectButton(i); } } } IgxButtonGroupComponent.decorators = [ { type: Component, args: [{ selector: 'igx-buttongroup', template: "<div class=\"igx-button-group\" role=\"group\" [class.igx-button-group--vertical]=\"isVertical\">\n <span *ngFor=\"let button of values; let i = 'index'\" type=\"button\" igxButton=\"flat\" [selected]=\"button.selected\"\n [attr.data-togglable]=\"button.togglable\" [disabled]=\"disabled || button.disabled\" [igxButtonColor]=\"button.color\"\n [igxButtonBackground]=\"button.bgcolor\" [igxLabel]=\"button.label\" [igxRipple]=\"button.ripple\">\n <div class=\"igx-button-group__item-content {{ itemContentCssClass }}\">\n <igx-icon *ngIf=\"button.icon\" fontSet=\"material\">{{button.icon}}</igx-icon>\n <span *ngIf=\"button.label\">{{button.label}}</span>\n </div>\n </span>\n <ng-content></ng-content>\n</div>\n" }] } ]; /** @nocollapse */ IgxButtonGroupComponent.ctorParameters = () => [ { type: ChangeDetectorRef }, { type: Renderer2 } ]; IgxButtonGroupComponent.propDecorators = { viewButtons: [{ type: ViewChildren, args: [IgxButtonDirective,] }], templateButtons: [{ type: ContentChildren, args: [IgxButtonDirective,] }], id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }], itemContentCssClass: [{ type: Input }], multiSelection: [{ type: Input }], values: [{ type: Input }], disabled: [{ type: Input }], alignment: [{ type: Input }], onSelect: [{ type: Output }], onUnselect: [{ type: Output }] }; if (false) { /** * @type {?} * @private */ IgxButtonGroupComponent.prototype._disabled; /** * @type {?} * @protected */ IgxButtonGroupComponent.prototype.buttonClickNotifier$; /** * @type {?} * @protected */ IgxButtonGroupComponent.prototype.queryListNotifier$; /** * @type {?} * @private */ IgxButtonGroupComponent.prototype.viewButtons; /** * @type {?} * @private */ IgxButtonGroupComponent.prototype.templateButtons; /** * An \@Input property that sets the value of the `id` attribute. If not set it will be automatically generated. * ```html * <igx-buttongroup [id]="'igx-dialog-56'" [multiSelection]="!multi" [values]="alignOptions"> * ``` * @type {?} */ IgxButtonGroupComponent.prototype.id; /** * An \@Input property that enables selecting multiple buttons. By default, multi-selection is false. * ```html * <igx-buttongroup [multiSelection]="false" [alignment]="alignment"></igx-buttongroup> * ``` * @type {?} */ IgxButtonGroupComponent.prototype.multiSelection; /** * An \@Input property that allows setting the buttons in the button group. * ```typescript * public ngOnInit() { * this.cities = [ * new Button({ * label: "Sofia" * }), * new Button({ * label: "London" * }), * new Button({ * label: "New York", * selected: true * }), * new Button({ * label: "Tokyo" * }) * ]; * } * //.. * ``` * ```html * <igx-buttongroup [multiSelection]="false" [values]="cities"></igx-buttongroup> * ``` * @type {?} */ IgxButtonGroupComponent.prototype.values; /** * @hidden * @type {?} */ IgxButtonGroupComponent.prototype.selectedIndexes; /** * An \@Ouput property that emits an event when a button is selected. * ```typescript * \@ViewChild("toast") * private toast: IgxToastComponent; * public onSelect(buttongroup){ * this.toast.show() * } * //... * ``` * ```html * <igx-buttongroup #MyChild [multiSelection]="!multi" (onSelect)="onSelect($event)"></igx-buttongroup> * <igx-toast #toast message="You have made a selection!"></igx-toast> * ``` * @type {?} */ IgxButtonGroupComponent.prototype.onSelect; /** * An \@Ouput property that emits an event when a button is deselected. * ```typescript * \@ViewChild("toast") * private toast: IgxToastComponent; * public onUnselect(buttongroup){ * this.toast.show() * } * //... * ``` * ```html * igx-buttongroup #MyChild [multiSelection]="multi" (onUnselect)="onUnselect($event)"></igx-buttongroup> * <igx-toast #toast message="You have deselected a button!"></igx-toast> * ``` * @type {?} */ IgxButtonGroupComponent.prototype.onUnselect; /** * @type {?} * @private */ IgxButtonGroupComponent.prototype._isVertical; /** * @type {?} * @private */ IgxButtonGroupComponent.prototype._itemContentCssClass; /** * @type {?} * @private */ IgxButtonGroupComponent.prototype._cdr; /** * @type {?} * @private */ IgxButtonGroupComponent.prototype._renderer; } /** * @record */ export function IButtonGroupEventArgs() { } if (false) { /** @type {?} */ IButtonGroupEventArgs.prototype.button; /** @type {?} */ IButtonGroupEventArgs.prototype.index; } /** * @hidden */ export class IgxButtonGroupModule { } IgxButtonGroupModule.decorators = [ { type: NgModule, args: [{ declarations: [IgxButtonGroupComponent], exports: [IgxButtonGroupComponent], imports: [IgxButtonModule, CommonModule, IgxRippleModule, IgxIconModule] },] } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"buttonGroup.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/buttonGroup/buttonGroup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterViewInit,\n    Component,\n    ContentChildren,\n    ChangeDetectorRef,\n    EventEmitter,\n    HostBinding,\n    Input,\n    NgModule,\n    Output,\n    QueryList,\n    Renderer2,\n    ViewChildren,\n    OnDestroy\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { IgxButtonDirective, IgxButtonModule } from '../directives/button/button.directive';\nimport { IgxRippleModule } from '../directives/ripple/ripple.directive';\nimport { IgxIconModule } from '../icon/index';\nimport { takeUntil } from 'rxjs/operators';\n\nexport enum ButtonGroupAlignment { horizontal, vertical }\nlet NEXT_ID = 0;\n\n/**\n * **Ignite UI for Angular Button Group** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/buttongroup.html)\n *\n * The Ignite UI Button Group displays a group of buttons either vertically or horizontally.  The group supports\n * single, multiple and toggle selection.\n *\n * Example:\n * ```html\n * <igx-buttongroup multiSelection=\"true\" [values]=\"fontOptions\">\n * </igx-buttongroup>\n * ```\n * The `fontOptions` value shown above is defined as:\n * ```typescript\n * this.fontOptions = [\n *   { icon: 'format_bold', selected: false },\n *   { icon: 'format_italic', selected: false },\n *   { icon: 'format_underlined', selected: false }];\n * ```\n */\n@Component({\n    selector: 'igx-buttongroup',\n    templateUrl: 'buttongroup-content.component.html'\n})\n\nexport class IgxButtonGroupComponent implements AfterViewInit, OnDestroy {\n    private _disabled = false;\n    protected buttonClickNotifier$ = new Subject<boolean>();\n    protected queryListNotifier$ = new Subject<boolean>();\n\n    @ViewChildren(IgxButtonDirective) private viewButtons: QueryList<IgxButtonDirective>;\n    @ContentChildren(IgxButtonDirective) private templateButtons: QueryList<IgxButtonDirective>;\n\n    /**\n     * A collection containing all buttons inside the button group.\n     */\n    public get buttons(): IgxButtonDirective[] {\n        return [...this.viewButtons.toArray(), ...this.templateButtons.toArray()];\n    }\n\n    /**\n     * An @Input property that sets the value of the `id` attribute. If not set it will be automatically generated.\n     * ```html\n     *  <igx-buttongroup [id]=\"'igx-dialog-56'\" [multiSelection]=\"!multi\" [values]=\"alignOptions\">\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-buttongroup-${NEXT_ID++}`;\n\n    /**\n     * Allows you to set a style using the `itemContentCssClass` input.\n     * The value should be the CSS class name that will be applied to the button group.\n     *```typescript\n     *public style1 = \"styleClass\";\n     * //..\n     *```\n     * ```html\n     *<igx-buttongroup [itemContentCssClass]=\"style1\" [multiSelection]=\"!multi\" [values]=\"alignOptions\">\n     *```\n     */\n    @Input() set itemContentCssClass(value: string) {\n        this._itemContentCssClass = value || this._itemContentCssClass;\n    }\n\n    /**\n     * Returns the CSS class of the item content of the `IgxButtonGroup`.\n     *```typescript\n     *@ViewChild(\"MyChild\")\n     *public buttonG: IgxButtonGroupComponent;\n     *ngAfterViewInit(){\n     *   let buttonSelect = this.buttonG.itemContentCssClass;\n     *}\n     *```\n     */\n    get itemContentCssClass(): string {\n        return this._itemContentCssClass;\n    }\n\n    /**\n     * An @Input property that enables selecting multiple buttons. By default, multi-selection is false.\n     * ```html\n     * <igx-buttongroup [multiSelection]=\"false\" [alignment]=\"alignment\"></igx-buttongroup>\n     * ```\n     */\n    @Input() public multiSelection = false;\n    /**\n     * An @Input property that allows setting the buttons in the button group.\n     * ```typescript\n     *  public ngOnInit() {\n     *      this.cities = [\n     *        new Button({\n     *          label: \"Sofia\"\n     *      }),\n     *        new Button({\n     *          label: \"London\"\n     *      }),\n     *        new Button({\n     *          label: \"New York\",\n     *          selected: true\n     *      }),\n     *        new Button({\n     *          label: \"Tokyo\"\n     *      })\n     *  ];\n     *  }\n     *  //..\n     * ```\n     * ```html\n     *  <igx-buttongroup [multiSelection]=\"false\" [values]=\"cities\"></igx-buttongroup>\n     * ```\n     */\n    @Input() public values: any;\n    /**\n     * An @Input property that allows you to disable the `igx-buttongroup` component. By default it's false.\n     * ```html\n     * <igx-buttongroup [disabled]=\"true\" [multiSelection]=\"multi\" [values]=\"fontOptions\"></igx-buttongroup>\n     * ```\n     */\n    @Input()\n    public get disabled(): boolean {\n        return this._disabled;\n    }\n    public set disabled(value: boolean) {\n        if (this._disabled !== value) {\n            this._disabled = value;\n\n            if (this.viewButtons && this.templateButtons) {\n                this.buttons.forEach((b) => b.disabled = this._disabled);\n            }\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public selectedIndexes: number[] = [];\n\n    /**\n     * Allows you to set the button group alignment.\n     * Available options are `ButtonGroupAlignment.horizontal` (default) and `ButtonGroupAlignment.vertical`.\n     * ```typescript\n     *public alignment = ButtonGroupAlignment.vertical;\n     * //..\n     * ```\n     * ```html\n     *<igx-buttongroup [multiSelection]=\"false\" [values]=\"cities\" [alignment]=\"alignment\"></igx-buttongroup>\n     * ```\n     */\n    @Input() set alignment(value: ButtonGroupAlignment) {\n        this._isVertical = value === ButtonGroupAlignment.vertical;\n    }\n    /**\n     * Returns the alignment of the `igx-buttongroup`.\n     *```typescript\n     *@ViewChild(\"MyChild\")\n     *public buttonG: IgxButtonGroupComponent;\n     *ngAfterViewInit(){\n     *    let buttonAlignment = this.buttonG.alignment;\n     *}\n     *```\n     */\n    get alignment(): ButtonGroupAlignment {\n        return this._isVertical ? ButtonGroupAlignment.vertical : ButtonGroupAlignment.horizontal;\n    }\n\n    /**\n     * An @Ouput property that emits an event when a button is selected.\n     *```typescript\n     *@ViewChild(\"toast\")\n     *private toast: IgxToastComponent;\n     *public onSelect(buttongroup){\n     *    this.toast.show()\n     *}\n     * //...\n     *```\n     *```html\n     * <igx-buttongroup #MyChild [multiSelection]=\"!multi\" (onSelect)=\"onSelect($event)\"></igx-buttongroup>\n     *<igx-toast #toast message=\"You have made a selection!\"></igx-toast>\n     *```\n     */\n    @Output() public onSelect = new EventEmitter<IButtonGroupEventArgs>();\n\n    /**\n     * An @Ouput property that emits an event when a button is deselected.\n     *```typescript\n     *@ViewChild(\"toast\")\n     *private toast: IgxToastComponent;\n     *public onUnselect(buttongroup){\n     *    this.toast.show()\n     *}\n     * //...\n     *```\n     *```html\n     * igx-buttongroup #MyChild [multiSelection]=\"multi\" (onUnselect)=\"onUnselect($event)\"></igx-buttongroup>\n     *<igx-toast #toast message=\"You have deselected a button!\"></igx-toast>\n     *```\n     */\n    @Output() public onUnselect = new EventEmitter<IButtonGroupEventArgs>();\n\n    /**\n     * Returns true if the `igx-buttongroup` alignment is vertical.\n     * Note that in order for the accessor to work correctly the property should be set explicitly.\n     * ```html\n     * <igx-buttongroup #MyChild [alignment]=\"alignment\" [values]=\"alignOptions\">\n     * ```\n     * ```typescript\n     * //...\n     *@ViewChild(\"MyChild\")\n     *private buttonG: IgxButtonGroupComponent;\n     *ngAfterViewInit(){\n     *    let orientation = this.buttonG.isVertical;\n     *}\n     *```\n     */\n    public get isVertical(): boolean {\n        return this._isVertical;\n    }\n    private _isVertical: boolean;\n    private _itemContentCssClass: string;\n\n    constructor(private _cdr: ChangeDetectorRef, private _renderer: Renderer2) {\n    }\n\n    /**\n     * Gets the selected button/buttons.\n     *```typescript\n     *@ViewChild(\"MyChild\")\n     *private buttonG: IgxButtonGroupComponent;\n     *ngAfterViewInit(){\n     *    let selectedButton = this.buttonG.selectedButtons;\n     *}\n     *```\n     */\n    get selectedButtons(): IgxButtonDirective[] {\n        return this.buttons.filter((b, i) => {\n            return this.selectedIndexes.indexOf(i) !== -1;\n        });\n\n    }\n\n    /**\n     * Selects a button by its index.\n     * @memberOf {@link IgxButtonGroupComponent}\n     *```typescript\n     *@ViewChild(\"MyChild\")\n     *private buttonG: IgxButtonGroupComponent;\n     *ngAfterViewInit(){\n     *    this.buttonG.selectButton(2);\n     *    this.cdr.detectChanges();\n     *}\n     *```\n     */\n    public selectButton(index: number) {\n        if (index >= this.buttons.length || index < 0) {\n            return;\n        }\n\n        const button = this.buttons[index];\n        const buttonElement = button.nativeElement;\n\n        if (buttonElement.classList.contains('igx-button--disabled')) {\n            return;\n        }\n\n        this.selectedIndexes.push(index);\n        button.selected = true;\n\n        this._renderer.setAttribute(buttonElement, 'aria-pressed', 'true');\n        this._renderer.addClass(buttonElement, 'igx-button-group__item--selected');\n\n        this.onSelect.emit({ button: button, index: index });\n\n        const indexInViewButtons = this.viewButtons.toArray().indexOf(button);\n        if (indexInViewButtons !== -1) {\n            this.values[indexInViewButtons].selected = true;\n        }\n\n        // deselect other buttons if multiSelection is not enabled\n        if (!this.multiSelection && this.selectedIndexes.length > 1) {\n            this.buttons.forEach((b, i) => {\n                if (i !== index && this.selectedIndexes.indexOf(i) !== -1) {\n                    this.deselectButton(i);\n                }\n            });\n        }\n    }\n\n    /**\n     * Deselects a button by its index.\n     * @memberOf {@link IgxButtonGroupComponent}\n     * ```typescript\n     *@ViewChild(\"MyChild\")\n     *private buttonG: IgxButtonGroupComponent;\n     *ngAfterViewInit(){\n     *    this.buttonG.deselectButton(2);\n     *    this.cdr.detectChanges();\n     *}\n     * ```\n     */\n    public deselectButton(index: number) {\n        if (index >= this.buttons.length || index < 0) {\n            return;\n        }\n\n        const button = this.buttons[index];\n        const buttonElement = button.nativeElement;\n\n        if (buttonElement.classList.contains('igx-button--disabled')) {\n            return;\n        }\n\n        this.selectedIndexes.splice(this.selectedIndexes.indexOf(index), 1);\n        button.selected = false;\n\n        this._renderer.setAttribute(buttonElement, 'aria-pressed', 'false');\n        this._renderer.removeClass(buttonElement, 'igx-button-group__item--selected');\n\n        this.onUnselect.emit({ button: button, index: index });\n\n        const indexInViewButtons = this.viewButtons.toArray().indexOf(button);\n        if (indexInViewButtons !== -1) {\n            this.values[indexInViewButtons].selected = false;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public ngAfterViewInit() {\n        const initButtons = () => {\n            // Cancel any existing buttonClick subscriptions\n            this.buttonClickNotifier$.next();\n\n            this.selectedIndexes.splice(0, this.selectedIndexes.length);\n\n            // initial configuration\n            this.buttons.forEach((button, index) => {\n                const buttonElement = button.nativeElement;\n\n                if (this.disabled) {\n                    button.disabled = true;\n                }\n\n                if (!button.disabled && button.selected) {\n                    this.selectButton(index);\n                }\n\n                button.buttonClick.pipe(takeUntil(this.buttonClickNotifier$)).subscribe((ev) => this._clickHandler(ev, index));\n                this._renderer.addClass(buttonElement, 'igx-button-group__item');\n            });\n        };\n\n        this.viewButtons.changes.pipe(takeUntil(this.queryListNotifier$)).subscribe(() => initButtons());\n        this.templateButtons.changes.pipe(takeUntil(this.queryListNotifier$)).subscribe(() => initButtons());\n        initButtons();\n\n        this._cdr.detectChanges();\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnDestroy() {\n        this.buttonClickNotifier$.next();\n        this.buttonClickNotifier$.complete();\n\n        this.queryListNotifier$.next();\n        this.queryListNotifier$.complete();\n    }\n\n    /**\n     *@hidden\n     */\n    public _clickHandler(event, i) {\n        if (this.selectedIndexes.indexOf(i) !== -1) {\n            this.deselectButton(i);\n        } else {\n            this.selectButton(i);\n        }\n    }\n}\n\nexport interface IButtonGroupEventArgs {\n    button: IgxButtonDirective;\n    index: number;\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxButtonGroupComponent],\n    exports: [IgxButtonGroupComponent],\n    imports: [IgxButtonModule, CommonModule, IgxRippleModule, IgxIconModule]\n})\n\nexport class IgxButtonGroupModule {\n}\n"]}