igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
517 lines • 31.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { IGX_DROPDOWN_BASE } from './drop-down.common';
import { Input, HostBinding, HostListener, ElementRef, Optional, Inject } from '@angular/core';
import { IgxSelectionAPIService } from '../core/selection';
import { DeprecateProperty, showMessage } from '../core/deprecateDecorators';
import { IgxDropDownGroupComponent } from './drop-down-group.component';
/** @type {?} */
var NEXT_ID = 0;
/** @type {?} */
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()
* @abstract
*/
var IgxDropDownItemBase = /** @class */ (function () {
function IgxDropDownItemBase(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++;
/**
* 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(IgxDropDownItemBase.prototype, "itemID", {
/**
* @hidden @internal
*/
get: /**
* @hidden \@internal
* @template THIS
* @this {THIS}
* @return {THIS}
*/
function () {
return (/** @type {?} */ (this));
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.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: /**
* The data index of the dropdown item.
*
* ```typescript
* // get the data index of the selected dropdown item
* let selectedItemIndex = this.dropdown.selectedItem.index
* ```
* @return {?}
*/
function () {
if (this._index === null) {
warningShown = showMessage('IgxDropDownItemBase: 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: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._index = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.prototype, "itemStyle", {
/**
* @hidden @internal
*/
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return !this.isHeader;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.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
* ```
*/
get: /**
* Sets/Gets if the item is the currently selected one in the dropdown
*
* ```typescript
* let mySelectedItem = this.dropdown.selectedItem;
* let isMyItemSelected = mySelectedItem.selected; // true
* ```
* @return {?}
*/
function () {
return this._selected;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
if (this.isHeader) {
return;
}
this._selected = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.prototype, "isSelected", {
/**
* @hidden @internal
*/
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return this.selected;
},
/**
* @hidden @internal
*/
set: /**
* @hidden \@internal
* @param {?} value
* @return {?}
*/
function (value) {
this.selected = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.prototype, "focused", {
/**
* Sets/gets if the given item is focused
* ```typescript
* let mySelectedItem = this.dropdown.selectedItem;
* let isMyItemFocused = mySelectedItem.isFocused;
* ```
*/
get: /**
* Sets/gets if the given item is focused
* ```typescript
* let mySelectedItem = this.dropdown.selectedItem;
* let isMyItemFocused = mySelectedItem.isFocused;
* ```
* @return {?}
*/
function () {
return (!this.isHeader && !this.disabled) && this._focused;
},
/**
* ```html
* <igx-drop-down-item *ngFor="let item of items" isFocused={{!item.isFocused}}>
* <div>
* {{item.field}}
* </div>
* </igx-drop-down-item>
* ```
*/
set: /**
* ```html
* <igx-drop-down-item *ngFor="let item of items" isFocused={{!item.isFocused}}>
* <div>
* {{item.field}}
* </div>
* </igx-drop-down-item>
* ```
* @param {?} value
* @return {?}
*/
function (value) {
this._focused = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.prototype, "isFocused", {
/**
* @hidden @internal
*/
get: /**
* @hidden \@internal
* @return {?}
*/
function () {
return this.focused;
},
/**
* @hidden @internal
*/
set: /**
* @hidden \@internal
* @param {?} value
* @return {?}
*/
function (value) {
this.focused = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.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: /**
* 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
* @return {?}
*/
function () {
return this.group ? this.group.disabled || this._disabled : this._disabled;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._disabled = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.prototype, "itemIndex", {
/**
* Gets item index
* @hidden @internal
*/
get: /**
* Gets item index
* @hidden \@internal
* @return {?}
*/
function () {
return this.dropDown.items.indexOf(this);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.prototype, "elementHeight", {
/**
* Gets item element height
* @hidden @internal
*/
get: /**
* Gets item element height
* @hidden \@internal
* @return {?}
*/
function () {
return this.elementRef.nativeElement.clientHeight;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxDropDownItemBase.prototype, "element", {
/**
* Get item html element
* @hidden @internal
*/
get: /**
* Get item html element
* @hidden \@internal
* @return {?}
*/
function () {
return this.elementRef;
},
enumerable: true,
configurable: true
});
/**
* @hidden @internal
*/
/**
* @hidden \@internal
* @param {?} event
* @return {?}
*/
IgxDropDownItemBase.prototype.clicked = /**
* @hidden \@internal
* @param {?} event
* @return {?}
*/
function (event) {
};
/**
* @return {?}
*/
IgxDropDownItemBase.prototype.ngDoCheck = /**
* @return {?}
*/
function () {
if (this.selected) {
/** @type {?} */
var dropDownSelectedItem = this.selection.first_item(this.dropDown.id);
if (!dropDownSelectedItem || this !== dropDownSelectedItem) {
this.dropDown.selectItem(this);
}
}
};
/** @nocollapse */
IgxDropDownItemBase.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,] }] }
]; };
IgxDropDownItemBase.propDecorators = {
id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }],
index: [{ type: Input }],
value: [{ type: Input }],
itemStyle: [{ type: HostBinding, args: ['class.igx-drop-down__item',] }],
selected: [{ type: Input }, { type: HostBinding, args: ['attr.aria-selected',] }, { type: HostBinding, args: ['class.igx-drop-down__item--selected',] }],
isSelected: [{ type: Input }],
focused: [{ type: HostBinding, args: ['class.igx-drop-down__item--focused',] }],
isHeader: [{ type: Input }, { type: HostBinding, args: ['class.igx-drop-down__header',] }],
disabled: [{ type: Input }, { type: HostBinding, args: ['attr.aria-disabled',] }, { type: HostBinding, args: ['class.igx-drop-down__item--disabled',] }],
role: [{ type: Input }, { type: HostBinding, args: ['attr.role',] }],
clicked: [{ type: HostListener, args: ['click', ['$event'],] }]
};
tslib_1.__decorate([
DeprecateProperty("IgxDropDownItemBase `isSelected` property is deprecated.\n" +
"Use `selected` instead."),
tslib_1.__metadata("design:type", Boolean),
tslib_1.__metadata("design:paramtypes", [Boolean])
], IgxDropDownItemBase.prototype, "isSelected", null);
tslib_1.__decorate([
DeprecateProperty("IgxDropDownItemBase `isFocused` property is depracated.\n" +
"Use `focused` instead."),
tslib_1.__metadata("design:type", Boolean),
tslib_1.__metadata("design:paramtypes", [Boolean])
], IgxDropDownItemBase.prototype, "isFocused", null);
return IgxDropDownItemBase;
}());
export { IgxDropDownItemBase };
if (false) {
/**
* @hidden
* @type {?}
* @protected
*/
IgxDropDownItemBase.prototype._focused;
/**
* @type {?}
* @protected
*/
IgxDropDownItemBase.prototype._selected;
/**
* @type {?}
* @protected
*/
IgxDropDownItemBase.prototype._index;
/**
* @type {?}
* @protected
*/
IgxDropDownItemBase.prototype._disabled;
/**
* 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
* @type {?}
*/
IgxDropDownItemBase.prototype.id;
/**
* Gets/sets the value of the item if the item is databound
*
* ```typescript
* // usage in IgxDropDownItemComponent
* // get
* let mySelectedItemValue = this.dropdown.selectedItem.value;
*
* // set
* let mySelectedItem = this.dropdown.selectedItem;
* mySelectedItem.value = { id: 123, name: 'Example Name' }
*
* // usage in IgxComboItemComponent
* // get
* let myComboItemValue = this.combo.items[0].value;
* ```
* @type {?}
*/
IgxDropDownItemBase.prototype.value;
/**
* Sets/gets if the given item is header
* ```typescript
* // get
* let mySelectedItem = this.dropdown.selectedItem;
* let isMyItemHeader = mySelectedItem.isHeader;
* ```
*
* ```html
* <!--set-->
* <igx-dropdown-item *ngFor="let item of items">
* <div *ngIf="items.indexOf(item) === 5; then item.isHeader = true">
* {{item.field}}
* </div>
* </igx-drop-down-item>
* ```
* @type {?}
*/
IgxDropDownItemBase.prototype.isHeader;
/**
* Gets/sets the `role` attribute of the item. Default is 'option'.
*
* ```html
* <igx-drop-down-item [role]="customRole"></igx-drop-down-item>
* ```
* @type {?}
*/
IgxDropDownItemBase.prototype.role;
/**
* @type {?}
* @protected
*/
IgxDropDownItemBase.prototype.dropDown;
/**
* @type {?}
* @protected
*/
IgxDropDownItemBase.prototype.elementRef;
/**
* @type {?}
* @protected
*/
IgxDropDownItemBase.prototype.group;
/**
* @type {?}
* @protected
*/
IgxDropDownItemBase.prototype.selection;
}
//# 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 { Input, HostBinding, HostListener, ElementRef, Optional, Inject, DoCheck } 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 */\nexport abstract class IgxDropDownItemBase implements DoCheck {\n    /**\n     * @hidden\n     */\n    protected _focused = false;\n    protected _selected = false;\n    protected _index = null;\n    protected _disabled = false;\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                'IgxDropDownItemBase: 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     * 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    @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    }\n\n    /**\n     * @hidden @internal\n     */\n    @Input()\n    @DeprecateProperty(`IgxDropDownItemBase \\`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.isFocused;\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\" isFocused={{!item.isFocused}}>\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(`IgxDropDownItemBase \\`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     * 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    /**\n     * @hidden @internal\n     */\n    @HostListener('click', ['$event'])\n    clicked(event) {\n    }\n\n    ngDoCheck(): void {\n        if (this.selected) {\n            const dropDownSelectedItem = this.selection.first_item(this.dropDown.id);\n            if (!dropDownSelectedItem || this !== dropDownSelectedItem) {\n                this.dropDown.selectItem(this);\n            }\n        }\n    }\n}\n"]}