UNPKG

@catull/igniteui-angular

Version:

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

407 lines 33.7 kB
import { __decorate, __metadata, __param } from "tslib"; import { IGX_DROPDOWN_BASE } from './drop-down.common'; import { Directive, Input, HostBinding, HostListener, ElementRef, Optional, Inject, DoCheck, Output, EventEmitter } from '@angular/core'; import { IgxSelectionAPIService } from '../core/selection'; import { DeprecateProperty, showMessage } from '../core/deprecateDecorators'; import { IgxDropDownGroupComponent } from './drop-down-group.component'; var NEXT_ID = 0; var warningShown = false; /** * An abstract class defining a drop-down item: * With properties / styles for selection, highlight, height * Bindable property for passing data (`value: any`) * Parent component (has to be used under a parent with type `IDropDownBase`) * Method for handling click on Host() */ var IgxDropDownItemBaseDirective = /** @class */ (function () { function IgxDropDownItemBaseDirective(dropDown, elementRef, group, selection) { this.dropDown = dropDown; this.elementRef = elementRef; this.group = group; this.selection = selection; /** * @hidden */ this._focused = false; this._selected = false; this._index = null; this._disabled = false; /** * Sets/gets the `id` of the item. * ```html * <igx-drop-down-item [id] = 'igx-drop-down-item-0'></igx-drop-down-item> * ``` * ```typescript * let itemId = this.item.id; * ``` * @memberof IgxSelectItemComponent */ this.id = "igx-drop-down-item-" + NEXT_ID++; /** *@hidden */ this.selectedChange = new EventEmitter(); /** * Gets/sets the `role` attribute of the item. Default is 'option'. * * ```html * <igx-drop-down-item [role]="customRole"></igx-drop-down-item> * ``` */ this.role = 'option'; } Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "hasIndex", { get: function () { return this._index !== null && this._index !== undefined; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "itemID", { /** * @hidden @internal */ get: function () { return this; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "index", { /** * The data index of the dropdown item. * * ```typescript * // get the data index of the selected dropdown item * let selectedItemIndex = this.dropdown.selectedItem.index * ``` */ get: function () { if (this._index === null) { warningShown = showMessage('IgxDropDownItemBaseDirective: Automatic index is deprecated.' + 'Bind in the template instead using `<igx-drop-down-item [index]="i"` instead.`', warningShown); return this.itemIndex; } return this._index; }, set: function (value) { this._index = value; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "itemStyle", { /** * @hidden @internal */ get: function () { return !this.isHeader; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "itemStyleCosy", { /** * @hidden @internal */ get: function () { return this.dropDown.displayDensity === 'cosy' && !this.isHeader; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "itemStyleCompact", { /** * @hidden @internal */ get: function () { return this.dropDown.displayDensity === 'compact' && !this.isHeader; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "selected", { /** * Sets/Gets if the item is the currently selected one in the dropdown * * ```typescript * let mySelectedItem = this.dropdown.selectedItem; * let isMyItemSelected = mySelectedItem.selected; // true * ``` * * Two-way data binding * ```html * <igx-drop-down-item [(selected)]='model.isSelected'></igx-drop-down-item> * ``` */ get: function () { return this._selected; }, set: function (value) { if (this.isHeader) { return; } this._selected = value; this.selectedChange.emit(this._selected); }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "isSelected", { /** * @hidden @internal */ get: function () { return this.selected; }, /** * @hidden @internal */ set: function (value) { this.selected = value; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "focused", { /** * Sets/gets if the given item is focused * ```typescript * let mySelectedItem = this.dropdown.selectedItem; * let isMyItemFocused = mySelectedItem.focused; * ``` */ get: function () { return (!this.isHeader && !this.disabled) && this._focused; }, /** * ```html * <igx-drop-down-item *ngFor="let item of items" focused={{!item.focused}}> * <div> * {{item.field}} * </div> * </igx-drop-down-item> * ``` */ set: function (value) { this._focused = value; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "isFocused", { /** * @hidden @internal */ get: function () { return this.focused; }, /** * @hidden @internal */ set: function (value) { this.focused = value; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "headerClassCosy", { /** * @hidden @internal */ get: function () { return this.isHeader && this.dropDown.displayDensity === 'cosy'; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "headerClassCompact", { /** * @hidden @internal */ get: function () { return this.isHeader && this.dropDown.displayDensity === 'compact'; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "disabled", { /** * Sets/gets if the given item is disabled * * ```typescript * // get * let mySelectedItem = this.dropdown.selectedItem; * let myItemIsDisabled = mySelectedItem.disabled; * ``` * * ```html * <igx-drop-down-item *ngFor="let item of items" disabled={{!item.disabled}}> * <div> * {{item.field}} * </div> * </igx-drop-down-item> * ``` * **NOTE:** Drop-down items inside of a disabled `IgxDropDownGroup` will always count as disabled */ get: function () { return this.group ? this.group.disabled || this._disabled : this._disabled; }, set: function (value) { this._disabled = value; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "itemIndex", { /** * Gets item index * @hidden @internal */ get: function () { return this.dropDown.items.indexOf(this); }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "elementHeight", { /** * Gets item element height * @hidden @internal */ get: function () { return this.elementRef.nativeElement.clientHeight; }, enumerable: true, configurable: true }); Object.defineProperty(IgxDropDownItemBaseDirective.prototype, "element", { /** * Get item html element * @hidden @internal */ get: function () { return this.elementRef; }, enumerable: true, configurable: true }); IgxDropDownItemBaseDirective.prototype.ngDoCheck = function () { if (this._selected) { var dropDownSelectedItem = this.dropDown.selectedItem; if (!dropDownSelectedItem) { this.dropDown.selectItem(this); } else if (this.hasIndex ? this._index !== dropDownSelectedItem.index || this.value !== dropDownSelectedItem.value : this !== dropDownSelectedItem) { this.dropDown.selectItem(this); } } }; IgxDropDownItemBaseDirective.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [IGX_DROPDOWN_BASE,] }] }, { type: ElementRef }, { type: IgxDropDownGroupComponent, decorators: [{ type: Optional }] }, { type: IgxSelectionAPIService, decorators: [{ type: Optional }, { type: Inject, args: [IgxSelectionAPIService,] }] } ]; }; __decorate([ HostBinding('attr.id'), Input(), __metadata("design:type", Object) ], IgxDropDownItemBaseDirective.prototype, "id", void 0); __decorate([ Input(), __metadata("design:type", Number), __metadata("design:paramtypes", [Object]) ], IgxDropDownItemBaseDirective.prototype, "index", null); __decorate([ Input(), __metadata("design:type", Object) ], IgxDropDownItemBaseDirective.prototype, "value", void 0); __decorate([ HostBinding('class.igx-drop-down__item'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxDropDownItemBaseDirective.prototype, "itemStyle", null); __decorate([ HostBinding('class.igx-drop-down__item--cosy'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxDropDownItemBaseDirective.prototype, "itemStyleCosy", null); __decorate([ HostBinding('class.igx-drop-down__item--compact'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxDropDownItemBaseDirective.prototype, "itemStyleCompact", null); __decorate([ Input(), HostBinding('attr.aria-selected'), HostBinding('class.igx-drop-down__item--selected'), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxDropDownItemBaseDirective.prototype, "selected", null); __decorate([ Output(), __metadata("design:type", Object) ], IgxDropDownItemBaseDirective.prototype, "selectedChange", void 0); __decorate([ Input(), DeprecateProperty("IgxDropDownItemBaseDirective `isSelected` property is deprecated.\n" + "Use `selected` instead."), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxDropDownItemBaseDirective.prototype, "isSelected", null); __decorate([ HostBinding('class.igx-drop-down__item--focused'), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxDropDownItemBaseDirective.prototype, "focused", null); __decorate([ DeprecateProperty("IgxDropDownItemBaseDirective `isFocused` property is depracated.\n" + "Use `focused` instead."), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxDropDownItemBaseDirective.prototype, "isFocused", null); __decorate([ Input(), HostBinding('class.igx-drop-down__header'), __metadata("design:type", Boolean) ], IgxDropDownItemBaseDirective.prototype, "isHeader", void 0); __decorate([ HostBinding('class.igx-drop-down__header--cosy'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxDropDownItemBaseDirective.prototype, "headerClassCosy", null); __decorate([ HostBinding('class.igx-drop-down__header--compact'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxDropDownItemBaseDirective.prototype, "headerClassCompact", null); __decorate([ Input(), HostBinding('attr.aria-disabled'), HostBinding('class.igx-drop-down__item--disabled'), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxDropDownItemBaseDirective.prototype, "disabled", null); __decorate([ Input(), HostBinding('attr.role'), __metadata("design:type", Object) ], IgxDropDownItemBaseDirective.prototype, "role", void 0); IgxDropDownItemBaseDirective = __decorate([ Directive({ selector: '[igxDropDownItemBase]' }), __param(0, Inject(IGX_DROPDOWN_BASE)), __param(2, Optional()), __param(3, Optional()), __param(3, Inject(IgxSelectionAPIService)), __metadata("design:paramtypes", [Object, ElementRef, IgxDropDownGroupComponent, IgxSelectionAPIService]) ], IgxDropDownItemBaseDirective); return IgxDropDownItemBaseDirective; }()); export { IgxDropDownItemBaseDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-down-item.base.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/drop-down/drop-down-item.base.ts"],"names":[],"mappings":"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","sourcesContent":["import { IDropDownBase, IGX_DROPDOWN_BASE } from './drop-down.common';\nimport { Directive, Input, HostBinding, HostListener, ElementRef, Optional, Inject, DoCheck, Output, EventEmitter } from '@angular/core';\nimport { IgxSelectionAPIService } from '../core/selection';\nimport { DeprecateProperty, showMessage } from '../core/deprecateDecorators';\nimport { IgxDropDownGroupComponent } from './drop-down-group.component';\n\nlet NEXT_ID = 0;\nlet warningShown = false;\n\n/**\n * An abstract class defining a drop-down item:\n * With properties / styles for selection, highlight, height\n * Bindable property for passing data (`value: any`)\n * Parent component (has to be used under a parent with type `IDropDownBase`)\n * Method for handling click on Host()\n */\n@Directive({\n    selector: '[igxDropDownItemBase]'\n})\nexport class IgxDropDownItemBaseDirective implements DoCheck {\n    /**\n     * @hidden\n     */\n    protected _focused = false;\n    protected _selected = false;\n    protected _index = null;\n    protected _disabled = false;\n    protected get hasIndex(): boolean {\n        return this._index !== null && this._index !== undefined;\n    }\n\n    /**\n     * Sets/gets the `id` of the item.\n     * ```html\n     * <igx-drop-down-item [id] = 'igx-drop-down-item-0'></igx-drop-down-item>\n     * ```\n     * ```typescript\n     * let itemId =  this.item.id;\n     * ```\n     * @memberof IgxSelectItemComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-drop-down-item-${NEXT_ID++}`;\n\n    /**\n     * @hidden @internal\n     */\n    public get itemID() {\n        return this;\n    }\n\n    /**\n     * The data index of the dropdown item.\n     *\n     * ```typescript\n     * // get the data index of the selected dropdown item\n     * let selectedItemIndex = this.dropdown.selectedItem.index\n     * ```\n     */\n    @Input()\n    public get index(): number {\n        if (this._index === null) {\n            warningShown = showMessage(\n                'IgxDropDownItemBaseDirective: Automatic index is deprecated.' +\n                'Bind in the template instead using `<igx-drop-down-item [index]=\"i\"` instead.`',\n                warningShown);\n            return this.itemIndex;\n        }\n        return this._index;\n    }\n\n    public set index(value) {\n        this._index = value;\n    }\n\n    /**\n     * Gets/sets the value of the item if the item is databound\n     *\n     * ```typescript\n     * // usage in IgxDropDownItemComponent\n     * // get\n     * let mySelectedItemValue = this.dropdown.selectedItem.value;\n     *\n     * // set\n     * let mySelectedItem = this.dropdown.selectedItem;\n     * mySelectedItem.value = { id: 123, name: 'Example Name' }\n     *\n     * // usage in IgxComboItemComponent\n     * // get\n     * let myComboItemValue = this.combo.items[0].value;\n     * ```\n     */\n    @Input()\n    public value: any;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-drop-down__item')\n    get itemStyle(): boolean {\n        return !this.isHeader;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-drop-down__item--cosy')\n    public get itemStyleCosy() {\n        return this.dropDown.displayDensity === 'cosy' && !this.isHeader;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-drop-down__item--compact')\n    public get itemStyleCompact() {\n        return this.dropDown.displayDensity === 'compact' && !this.isHeader;\n    }\n\n    /**\n     * Sets/Gets if the item is the currently selected one in the dropdown\n     *\n     * ```typescript\n     *  let mySelectedItem = this.dropdown.selectedItem;\n     *  let isMyItemSelected = mySelectedItem.selected; // true\n     * ```\n     *\n     * Two-way data binding\n     * ```html\n     * <igx-drop-down-item [(selected)]='model.isSelected'></igx-drop-down-item>\n     * ```\n     */\n    @Input()\n    @HostBinding('attr.aria-selected')\n    @HostBinding('class.igx-drop-down__item--selected')\n    get selected(): boolean {\n        return this._selected;\n    }\n\n    set selected(value: boolean) {\n        if (this.isHeader) {\n            return;\n        }\n        this._selected = value;\n        this.selectedChange.emit(this._selected);\n    }\n\n    /**\n     *@hidden\n     */\n    @Output()\n    public selectedChange = new EventEmitter<boolean>();\n\n    /**\n     * @hidden @internal\n     */\n    @Input()\n    @DeprecateProperty(`IgxDropDownItemBaseDirective \\`isSelected\\` property is deprecated.\\n` +\n        `Use \\`selected\\` instead.`)\n    get isSelected(): boolean {\n        return this.selected;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    set isSelected(value: boolean) {\n        this.selected = value;\n    }\n\n    /**\n     * Sets/gets if the given item is focused\n     * ```typescript\n     *  let mySelectedItem = this.dropdown.selectedItem;\n     *  let isMyItemFocused = mySelectedItem.focused;\n     * ```\n     */\n    @HostBinding('class.igx-drop-down__item--focused')\n    get focused(): boolean {\n        return (!this.isHeader && !this.disabled) && this._focused;\n    }\n\n    /**\n     * ```html\n     *  <igx-drop-down-item *ngFor=\"let item of items\" focused={{!item.focused}}>\n     *      <div>\n     *          {{item.field}}\n     *      </div>\n     *  </igx-drop-down-item>\n     * ```\n     */\n    set focused(value: boolean) {\n        this._focused = value;\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @DeprecateProperty(`IgxDropDownItemBaseDirective \\`isFocused\\` property is depracated.\\n` +\n        `Use \\`focused\\` instead.`)\n    get isFocused(): boolean {\n        return this.focused;\n    }\n    /**\n     * @hidden @internal\n     */\n    set isFocused(value: boolean) {\n        this.focused = value;\n    }\n\n    /**\n     * Sets/gets if the given item is header\n     * ```typescript\n     *  // get\n     *  let mySelectedItem = this.dropdown.selectedItem;\n     *  let isMyItemHeader = mySelectedItem.isHeader;\n     * ```\n     *\n     * ```html\n     *  <!--set-->\n     *  <igx-dropdown-item *ngFor=\"let item of items\">\n     *      <div *ngIf=\"items.indexOf(item) === 5; then item.isHeader = true\">\n     *          {{item.field}}\n*           </div>\n     *  </igx-drop-down-item>\n     * ```\n     */\n    @Input()\n    @HostBinding('class.igx-drop-down__header')\n    public isHeader: boolean;\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-drop-down__header--cosy')\n    public get headerClassCosy() {\n        return this.isHeader && this.dropDown.displayDensity === 'cosy';\n    }\n\n    /**\n     * @hidden @internal\n     */\n    @HostBinding('class.igx-drop-down__header--compact')\n    public get headerClassCompact() {\n        return this.isHeader && this.dropDown.displayDensity === 'compact';\n    }\n\n    /**\n     * Sets/gets if the given item is disabled\n     *\n     * ```typescript\n     *  // get\n     *  let mySelectedItem = this.dropdown.selectedItem;\n     *  let myItemIsDisabled = mySelectedItem.disabled;\n     * ```\n     *\n     * ```html\n     *  <igx-drop-down-item *ngFor=\"let item of items\" disabled={{!item.disabled}}>\n     *      <div>\n     *          {{item.field}}\n     *      </div>\n     *  </igx-drop-down-item>\n     * ```\n     * **NOTE:** Drop-down items inside of a disabled `IgxDropDownGroup` will always count as disabled\n     */\n    @Input()\n    @HostBinding('attr.aria-disabled')\n    @HostBinding('class.igx-drop-down__item--disabled')\n    public get disabled(): boolean {\n        return this.group ? this.group.disabled || this._disabled : this._disabled;\n    }\n\n    public set disabled(value: boolean) {\n        this._disabled = value;\n    }\n\n    /**\n     * Gets/sets the `role` attribute of the item. Default is 'option'.\n     *\n     * ```html\n     *  <igx-drop-down-item [role]=\"customRole\"></igx-drop-down-item>\n     * ```\n     */\n    @Input()\n    @HostBinding('attr.role')\n    public role = 'option';\n\n    /**\n     * Gets item index\n     * @hidden @internal\n     */\n    public get itemIndex(): number {\n        return this.dropDown.items.indexOf(this);\n    }\n\n    /**\n     * Gets item element height\n     * @hidden @internal\n     */\n    public get elementHeight(): number {\n        return this.elementRef.nativeElement.clientHeight;\n    }\n\n    /**\n     * Get item html element\n     * @hidden @internal\n     */\n    public get element(): ElementRef {\n        return this.elementRef;\n    }\n\n    constructor(\n        @Inject(IGX_DROPDOWN_BASE) protected dropDown: IDropDownBase,\n        protected elementRef: ElementRef,\n        @Optional() protected group: IgxDropDownGroupComponent,\n        @Optional() @Inject(IgxSelectionAPIService) protected selection?: IgxSelectionAPIService\n    ) { }\n\n    ngDoCheck(): void {\n        if (this._selected) {\n            const dropDownSelectedItem = this.dropDown.selectedItem;\n            if (!dropDownSelectedItem) {\n                this.dropDown.selectItem(this);\n            } else if (this.hasIndex\n                ? this._index !== dropDownSelectedItem.index || this.value !== dropDownSelectedItem.value :\n                this !== dropDownSelectedItem) {\n                this.dropDown.selectItem(this);\n            }\n        }\n    }\n}\n"]}