UNPKG

@catull/igniteui-angular

Version:

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

113 lines 12.3 kB
import { __decorate, __metadata, __param } from "tslib"; import { Component, ElementRef, HostBinding, Inject, Input, DoCheck } from '@angular/core'; import { IgxDropDownItemComponent } from '../drop-down/drop-down-item.component'; import { IGX_DROPDOWN_BASE, Navigate } from '../drop-down/drop-down.common'; import { IgxComboAPIService } from './combo.api'; import { IgxSelectionAPIService } from '../core/selection'; /** @hidden */ let IgxComboItemComponent = class IgxComboItemComponent extends IgxDropDownItemComponent { constructor(comboAPI, dropDown, elementRef, selection) { super(dropDown, elementRef, null, selection); this.comboAPI = comboAPI; this.dropDown = dropDown; this.elementRef = elementRef; this.selection = selection; /** * Gets the height of a list item * @hidden */ this.itemHeight = ''; } /** * @hidden */ get itemID() { const valueKey = this.comboAPI.valueKey; return valueKey !== null ? this.value[valueKey] : this.value; } /** * @hidden */ get comboID() { return this.comboAPI.comboID; } /** * @hidden * @internal */ get disableTransitions() { return this.comboAPI.disableTransitions; } /** * @hidden */ get selected() { return this.comboAPI.is_item_selected(this.itemID); } set selected(value) { if (this.isHeader) { return; } this._selected = value; } /** * @hidden */ isVisible(direction) { const rect = this.element.nativeElement.getBoundingClientRect(); const parentDiv = this.element.nativeElement.parentElement.parentElement.getBoundingClientRect(); if (direction === Navigate.Down) { return rect.y + rect.height <= parentDiv.y + parentDiv.height; } return rect.y >= parentDiv.y; } clicked(event) { this.comboAPI.disableTransitions = false; if (this.disabled || this.isHeader) { const focusedItem = this.dropDown.items.find((item) => item.focused); if (this.dropDown.allowItemsFocus && focusedItem) { focusedItem.element.nativeElement.focus({ preventScroll: true }); } return; } this.dropDown.navigateItem(this.index); this.comboAPI.set_selected_item(this.itemID, event); } /** * @hidden * @internal * The event that is prevented is the click on the checkbox label element. * That is the only visible element that a user can interact with. * The click propagates to the host and the preventDefault is to stop it from * switching focus to the input it's base on. * The toggle happens in an internal handler in the drop-down on the next task queue cycle. */ disableCheck(event) { event.preventDefault(); } ngDoCheck() { } }; IgxComboItemComponent.ctorParameters = () => [ { type: IgxComboAPIService }, { type: undefined, decorators: [{ type: Inject, args: [IGX_DROPDOWN_BASE,] }] }, { type: ElementRef }, { type: IgxSelectionAPIService, decorators: [{ type: Inject, args: [IgxSelectionAPIService,] }] } ]; __decorate([ Input(), HostBinding('style.height.px'), __metadata("design:type", Object) ], IgxComboItemComponent.prototype, "itemHeight", void 0); IgxComboItemComponent = __decorate([ Component({ selector: 'igx-combo-item', template: "<ng-container *ngIf=\"!isHeader\">\n <igx-checkbox [checked]=\"selected\" disableRipple=\"true\" [disableTransitions]=\"disableTransitions\" [tabindex]=\"-1\" (click)=\"disableCheck($event)\" class=\"igx-combo__checkbox\"></igx-checkbox>\n</ng-container>\n<ng-content></ng-content>\n" }), __param(1, Inject(IGX_DROPDOWN_BASE)), __param(3, Inject(IgxSelectionAPIService)), __metadata("design:paramtypes", [IgxComboAPIService, Object, ElementRef, IgxSelectionAPIService]) ], IgxComboItemComponent); export { IgxComboItemComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combo-item.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/combo/combo-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ElementRef,\n    HostBinding,\n    Inject,\n    Input,\n    DoCheck\n} from '@angular/core';\nimport { IgxDropDownItemComponent } from '../drop-down/drop-down-item.component';\nimport { IGX_DROPDOWN_BASE, IDropDownBase, Navigate } from '../drop-down/drop-down.common';\nimport { IgxComboAPIService } from './combo.api';\nimport { IgxSelectionAPIService } from '../core/selection';\n\n/** @hidden */\n@Component({\n    selector: 'igx-combo-item',\n    templateUrl: 'combo-item.component.html'\n})\nexport class IgxComboItemComponent extends IgxDropDownItemComponent implements DoCheck {\n\n    /**\n     * Gets the height of a list item\n     * @hidden\n     */\n    @Input()\n    @HostBinding('style.height.px')\n    public itemHeight = '';\n\n    /**\n     * @hidden\n     */\n    public get itemID() {\n        const valueKey = this.comboAPI.valueKey;\n        return valueKey !== null ? this.value[valueKey] : this.value;\n    }\n\n    /**\n     * @hidden\n     */\n    public get comboID() {\n        return this.comboAPI.comboID;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get disableTransitions() {\n        return this.comboAPI.disableTransitions;\n    }\n\n    constructor(\n        protected comboAPI: IgxComboAPIService,\n        @Inject(IGX_DROPDOWN_BASE) protected dropDown: IDropDownBase,\n        protected elementRef: ElementRef,\n        @Inject(IgxSelectionAPIService) protected selection: IgxSelectionAPIService\n    ) {\n        super(dropDown, elementRef, null, selection);\n    }\n\n    /**\n     * @hidden\n     */\n    get selected(): boolean {\n        return this.comboAPI.is_item_selected(this.itemID);\n    }\n\n    set selected(value: boolean) {\n        if (this.isHeader) {\n            return;\n        }\n        this._selected = value;\n    }\n\n    /**\n     * @hidden\n     */\n    isVisible(direction: Navigate): boolean {\n        const rect = this.element.nativeElement.getBoundingClientRect();\n        const parentDiv = this.element.nativeElement.parentElement.parentElement.getBoundingClientRect();\n        if (direction === Navigate.Down) {\n            return rect.y + rect.height <= parentDiv.y + parentDiv.height;\n        }\n        return rect.y >= parentDiv.y;\n    }\n\n    clicked(event) {\n        this.comboAPI.disableTransitions = false;\n        if (this.disabled || this.isHeader) {\n            const focusedItem = this.dropDown.items.find((item) => item.focused);\n            if (this.dropDown.allowItemsFocus && focusedItem) {\n                focusedItem.element.nativeElement.focus({ preventScroll: true });\n            }\n            return;\n        }\n        this.dropDown.navigateItem(this.index);\n        this.comboAPI.set_selected_item(this.itemID, event);\n    }\n\n    /**\n     * @hidden\n     * @internal\n     * The event that is prevented is the click on the checkbox label element.\n     * That is the only visible element that a user can interact with.\n     * The click propagates to the host and the preventDefault is to stop it from\n     * switching focus to the input it's base on.\n     * The toggle happens in an internal handler in the drop-down on the next task queue cycle.\n     */\n    disableCheck(event: MouseEvent) {\n        event.preventDefault();\n    }\n\n    ngDoCheck() {\n    }\n}\n"]}