igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
652 lines • 39.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* This file contains all the directives used by the @link IgxTimePickerComponent.
* You should generally not use them directly.
* @preferred
*/
import { Directive, ElementRef, HostBinding, HostListener, Inject, Input, TemplateRef } from '@angular/core';
import { IGX_TIME_PICKER_COMPONENT } from './time-picker.common';
import { InteractionMode } from '../core/enums';
/**
* @hidden
*/
var IgxItemListDirective = /** @class */ (function () {
function IgxItemListDirective(timePicker, elementRef) {
this.timePicker = timePicker;
this.elementRef = elementRef;
this.tabindex = 0;
}
Object.defineProperty(IgxItemListDirective.prototype, "defaultCSS", {
get: /**
* @return {?}
*/
function () {
return true;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxItemListDirective.prototype, "hourCSS", {
get: /**
* @return {?}
*/
function () {
return this.type === 'hourList';
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxItemListDirective.prototype, "minuteCSS", {
get: /**
* @return {?}
*/
function () {
return this.type === 'minuteList';
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxItemListDirective.prototype, "ampmCSS", {
get: /**
* @return {?}
*/
function () {
return this.type === 'ampmList';
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
IgxItemListDirective.prototype.onFocus = /**
* @return {?}
*/
function () {
this.isActive = true;
};
/**
* @return {?}
*/
IgxItemListDirective.prototype.onBlur = /**
* @return {?}
*/
function () {
this.isActive = false;
};
/**
* @private
* @return {?}
*/
IgxItemListDirective.prototype.nextItem = /**
* @private
* @return {?}
*/
function () {
switch (this.type) {
case 'hourList': {
this.timePicker.nextHour();
break;
}
case 'minuteList': {
this.timePicker.nextMinute();
break;
}
case 'ampmList': {
this.timePicker.nextAmPm();
break;
}
}
};
/**
* @private
* @return {?}
*/
IgxItemListDirective.prototype.prevItem = /**
* @private
* @return {?}
*/
function () {
switch (this.type) {
case 'hourList': {
this.timePicker.prevHour();
break;
}
case 'minuteList': {
this.timePicker.prevMinute();
break;
}
case 'ampmList': {
this.timePicker.prevAmPm();
break;
}
}
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxItemListDirective.prototype.onKeydownArrowDown = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
this.nextItem();
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxItemListDirective.prototype.onKeydownArrowUp = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
this.prevItem();
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxItemListDirective.prototype.onKeydownArrowRight = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
/** @type {?} */
var listName = ((/** @type {?} */ (event.target))).className;
if (listName.indexOf('hourList') !== -1) {
this.timePicker.minuteList.nativeElement.focus();
}
else if (listName.indexOf('minuteList') !== -1 && this.timePicker._ampmItems.length !== 0) {
this.timePicker.ampmList.nativeElement.focus();
}
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxItemListDirective.prototype.onKeydownArrowLeft = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
/** @type {?} */
var listName = ((/** @type {?} */ (event.target))).className;
if (listName.indexOf('minuteList') !== -1) {
this.timePicker.hourList.nativeElement.focus();
}
else if (listName.indexOf('ampmList') !== -1) {
this.timePicker.minuteList.nativeElement.focus();
}
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxItemListDirective.prototype.onKeydownEnter = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
if (this.timePicker.mode === InteractionMode.DropDown) {
this.timePicker.hideOverlay();
return;
}
this.timePicker.okButtonClick();
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxItemListDirective.prototype.onKeydownEscape = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
this.timePicker.cancelButtonClick();
};
/**
* @hidden
*/
/**
* @hidden
* @return {?}
*/
IgxItemListDirective.prototype.onHover = /**
* @hidden
* @return {?}
*/
function () {
this.elementRef.nativeElement.focus();
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxItemListDirective.prototype.onScroll = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
event.stopPropagation();
if (event.deltaY > 0) {
this.nextItem();
}
else if (event.deltaY < 0) {
this.prevItem();
}
};
/**
* @hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxItemListDirective.prototype.onPanMove = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
if (event.deltaY < 0) {
this.nextItem();
}
else if (event.deltaY > 0) {
this.prevItem();
}
};
IgxItemListDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxItemList]'
},] }
];
/** @nocollapse */
IgxItemListDirective.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] },
{ type: ElementRef }
]; };
IgxItemListDirective.propDecorators = {
type: [{ type: Input, args: ['igxItemList',] }],
tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }],
defaultCSS: [{ type: HostBinding, args: ['class.igx-time-picker__column',] }],
hourCSS: [{ type: HostBinding, args: ['class.igx-time-picker__hourList',] }],
minuteCSS: [{ type: HostBinding, args: ['class.igx-time-picker__minuteList',] }],
ampmCSS: [{ type: HostBinding, args: ['class.igx-time-picker__ampmList',] }],
onFocus: [{ type: HostListener, args: ['focus',] }],
onBlur: [{ type: HostListener, args: ['blur',] }],
onKeydownArrowDown: [{ type: HostListener, args: ['keydown.arrowdown', ['$event'],] }],
onKeydownArrowUp: [{ type: HostListener, args: ['keydown.arrowup', ['$event'],] }],
onKeydownArrowRight: [{ type: HostListener, args: ['keydown.arrowright', ['$event'],] }],
onKeydownArrowLeft: [{ type: HostListener, args: ['keydown.arrowleft', ['$event'],] }],
onKeydownEnter: [{ type: HostListener, args: ['keydown.enter', ['$event'],] }],
onKeydownEscape: [{ type: HostListener, args: ['keydown.escape', ['$event'],] }],
onHover: [{ type: HostListener, args: ['mouseover',] }],
onScroll: [{ type: HostListener, args: ['wheel', ['$event'],] }],
onPanMove: [{ type: HostListener, args: ['panmove', ['$event'],] }]
};
return IgxItemListDirective;
}());
export { IgxItemListDirective };
if (false) {
/** @type {?} */
IgxItemListDirective.prototype.type;
/** @type {?} */
IgxItemListDirective.prototype.isActive;
/** @type {?} */
IgxItemListDirective.prototype.tabindex;
/** @type {?} */
IgxItemListDirective.prototype.timePicker;
/**
* @type {?}
* @private
*/
IgxItemListDirective.prototype.elementRef;
}
/**
* @hidden
*/
var IgxHourItemDirective = /** @class */ (function () {
function IgxHourItemDirective(timePicker, itemList) {
this.timePicker = timePicker;
this.itemList = itemList;
}
Object.defineProperty(IgxHourItemDirective.prototype, "defaultCSS", {
get: /**
* @return {?}
*/
function () {
return true;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxHourItemDirective.prototype, "selectedCSS", {
get: /**
* @return {?}
*/
function () {
return this.isSelectedHour;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxHourItemDirective.prototype, "activeCSS", {
get: /**
* @return {?}
*/
function () {
return this.isSelectedHour && this.itemList.isActive;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxHourItemDirective.prototype, "isSelectedHour", {
get: /**
* @return {?}
*/
function () {
return this.timePicker.selectedHour === this.value;
},
enumerable: true,
configurable: true
});
/**
* @param {?} item
* @return {?}
*/
IgxHourItemDirective.prototype.onClick = /**
* @param {?} item
* @return {?}
*/
function (item) {
if (item !== '') {
this.timePicker.scrollHourIntoView(item);
}
};
IgxHourItemDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxHourItem]'
},] }
];
/** @nocollapse */
IgxHourItemDirective.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] },
{ type: IgxItemListDirective }
]; };
IgxHourItemDirective.propDecorators = {
value: [{ type: Input, args: ['igxHourItem',] }],
defaultCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item',] }],
selectedCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item--selected',] }],
activeCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item--active',] }],
onClick: [{ type: HostListener, args: ['click', ['value'],] }]
};
return IgxHourItemDirective;
}());
export { IgxHourItemDirective };
if (false) {
/** @type {?} */
IgxHourItemDirective.prototype.value;
/** @type {?} */
IgxHourItemDirective.prototype.timePicker;
/**
* @type {?}
* @private
*/
IgxHourItemDirective.prototype.itemList;
}
/**
* @hidden
*/
var IgxMinuteItemDirective = /** @class */ (function () {
function IgxMinuteItemDirective(timePicker, itemList) {
this.timePicker = timePicker;
this.itemList = itemList;
}
Object.defineProperty(IgxMinuteItemDirective.prototype, "defaultCSS", {
get: /**
* @return {?}
*/
function () {
return true;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMinuteItemDirective.prototype, "selectedCSS", {
get: /**
* @return {?}
*/
function () {
return this.isSelectedMinute;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMinuteItemDirective.prototype, "activeCSS", {
get: /**
* @return {?}
*/
function () {
return this.isSelectedMinute && this.itemList.isActive;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxMinuteItemDirective.prototype, "isSelectedMinute", {
get: /**
* @return {?}
*/
function () {
return this.timePicker.selectedMinute === this.value;
},
enumerable: true,
configurable: true
});
/**
* @param {?} item
* @return {?}
*/
IgxMinuteItemDirective.prototype.onClick = /**
* @param {?} item
* @return {?}
*/
function (item) {
if (item !== '') {
this.timePicker.scrollMinuteIntoView(item);
}
};
IgxMinuteItemDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxMinuteItem]'
},] }
];
/** @nocollapse */
IgxMinuteItemDirective.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] },
{ type: IgxItemListDirective }
]; };
IgxMinuteItemDirective.propDecorators = {
value: [{ type: Input, args: ['igxMinuteItem',] }],
defaultCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item',] }],
selectedCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item--selected',] }],
activeCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item--active',] }],
onClick: [{ type: HostListener, args: ['click', ['value'],] }]
};
return IgxMinuteItemDirective;
}());
export { IgxMinuteItemDirective };
if (false) {
/** @type {?} */
IgxMinuteItemDirective.prototype.value;
/** @type {?} */
IgxMinuteItemDirective.prototype.timePicker;
/**
* @type {?}
* @private
*/
IgxMinuteItemDirective.prototype.itemList;
}
/**
* @hidden
*/
var IgxAmPmItemDirective = /** @class */ (function () {
function IgxAmPmItemDirective(timePicker, itemList) {
this.timePicker = timePicker;
this.itemList = itemList;
}
Object.defineProperty(IgxAmPmItemDirective.prototype, "defaultCSS", {
get: /**
* @return {?}
*/
function () {
return true;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAmPmItemDirective.prototype, "selectedCSS", {
get: /**
* @return {?}
*/
function () {
return this.isSelectedAmPm;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAmPmItemDirective.prototype, "activeCSS", {
get: /**
* @return {?}
*/
function () {
return this.isSelectedAmPm && this.itemList.isActive;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxAmPmItemDirective.prototype, "isSelectedAmPm", {
get: /**
* @return {?}
*/
function () {
return this.timePicker.selectedAmPm === this.value;
},
enumerable: true,
configurable: true
});
/**
* @param {?} item
* @return {?}
*/
IgxAmPmItemDirective.prototype.onClick = /**
* @param {?} item
* @return {?}
*/
function (item) {
if (item !== '') {
this.timePicker.scrollAmPmIntoView(item);
}
};
IgxAmPmItemDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxAmPmItem]'
},] }
];
/** @nocollapse */
IgxAmPmItemDirective.ctorParameters = function () { return [
{ type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] },
{ type: IgxItemListDirective }
]; };
IgxAmPmItemDirective.propDecorators = {
value: [{ type: Input, args: ['igxAmPmItem',] }],
defaultCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item',] }],
selectedCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item--selected',] }],
activeCSS: [{ type: HostBinding, args: ['class.igx-time-picker__item--active',] }],
onClick: [{ type: HostListener, args: ['click', ['value'],] }]
};
return IgxAmPmItemDirective;
}());
export { IgxAmPmItemDirective };
if (false) {
/** @type {?} */
IgxAmPmItemDirective.prototype.value;
/** @type {?} */
IgxAmPmItemDirective.prototype.timePicker;
/**
* @type {?}
* @private
*/
IgxAmPmItemDirective.prototype.itemList;
}
/**
* This directive should be used to mark which ng-template will be used from IgxTimePicker when re-templating its input group.
*/
var IgxTimePickerTemplateDirective = /** @class */ (function () {
function IgxTimePickerTemplateDirective(template) {
this.template = template;
}
IgxTimePickerTemplateDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxTimePickerTemplate]'
},] }
];
/** @nocollapse */
IgxTimePickerTemplateDirective.ctorParameters = function () { return [
{ type: TemplateRef }
]; };
return IgxTimePickerTemplateDirective;
}());
export { IgxTimePickerTemplateDirective };
if (false) {
/** @type {?} */
IgxTimePickerTemplateDirective.prototype.template;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.directives.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/time-picker/time-picker.directives.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * This file contains all the directives used by the @link IgxTimePickerComponent.\n * You should generally not use them directly.\n * @preferred\n */\nimport {\n    Directive,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    TemplateRef\n} from '@angular/core';\nimport { IGX_TIME_PICKER_COMPONENT, IgxTimePickerBase } from './time-picker.common';\nimport { InteractionMode } from '../core/enums';\n\n/** @hidden */\n@Directive({\n    selector: '[igxItemList]'\n})\nexport class IgxItemListDirective {\n\n    @Input('igxItemList')\n    public type: string;\n\n    public isActive: boolean;\n\n    constructor(@Inject(IGX_TIME_PICKER_COMPONENT)\n    public timePicker: IgxTimePickerBase,\n        private elementRef: ElementRef) { }\n\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\n\n    @HostBinding('class.igx-time-picker__column')\n    get defaultCSS(): boolean {\n        return true;\n    }\n\n    @HostBinding('class.igx-time-picker__hourList')\n    get hourCSS(): boolean {\n        return this.type === 'hourList';\n    }\n\n    @HostBinding('class.igx-time-picker__minuteList')\n    get minuteCSS(): boolean {\n        return this.type === 'minuteList';\n    }\n\n    @HostBinding('class.igx-time-picker__ampmList')\n    get ampmCSS(): boolean {\n        return this.type === 'ampmList';\n    }\n\n    @HostListener('focus')\n    public onFocus() {\n        this.isActive = true;\n    }\n\n    @HostListener('blur')\n    public onBlur() {\n        this.isActive = false;\n    }\n\n    private nextItem(): void {\n        switch (this.type) {\n            case 'hourList': {\n                this.timePicker.nextHour();\n                break;\n            }\n            case 'minuteList': {\n                this.timePicker.nextMinute();\n                break;\n            }\n            case 'ampmList': {\n                this.timePicker.nextAmPm();\n                break;\n            }\n        }\n    }\n\n    private prevItem(): void {\n        switch (this.type) {\n            case 'hourList': {\n                this.timePicker.prevHour();\n                break;\n            }\n            case 'minuteList': {\n                this.timePicker.prevMinute();\n                break;\n            }\n            case 'ampmList': {\n                this.timePicker.prevAmPm();\n                break;\n            }\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowdown', ['$event'])\n    public onKeydownArrowDown(event: KeyboardEvent) {\n        event.preventDefault();\n\n        this.nextItem();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowup', ['$event'])\n    public onKeydownArrowUp(event: KeyboardEvent) {\n        event.preventDefault();\n\n        this.prevItem();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowright', ['$event'])\n    public onKeydownArrowRight(event: KeyboardEvent) {\n        event.preventDefault();\n\n        const listName = (event.target as HTMLElement).className;\n\n        if (listName.indexOf('hourList') !== -1) {\n            this.timePicker.minuteList.nativeElement.focus();\n        } else if (listName.indexOf('minuteList') !== -1 && this.timePicker._ampmItems.length !== 0) {\n            this.timePicker.ampmList.nativeElement.focus();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.arrowleft', ['$event'])\n    public onKeydownArrowLeft(event: KeyboardEvent) {\n        event.preventDefault();\n\n        const listName = (event.target as HTMLElement).className;\n\n        if (listName.indexOf('minuteList') !== -1) {\n            this.timePicker.hourList.nativeElement.focus();\n        } else if (listName.indexOf('ampmList') !== -1) {\n            this.timePicker.minuteList.nativeElement.focus();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.enter', ['$event'])\n    public onKeydownEnter(event: KeyboardEvent) {\n        event.preventDefault();\n\n        if (this.timePicker.mode === InteractionMode.DropDown) {\n            this.timePicker.hideOverlay();\n            return;\n        }\n        this.timePicker.okButtonClick();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('keydown.escape', ['$event'])\n    public onKeydownEscape(event: KeyboardEvent) {\n        event.preventDefault();\n\n        this.timePicker.cancelButtonClick();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('mouseover')\n    public onHover() {\n        this.elementRef.nativeElement.focus();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('wheel', ['$event'])\n    public onScroll(event) {\n        event.preventDefault();\n        event.stopPropagation();\n\n        if (event.deltaY > 0) {\n            this.nextItem();\n        } else if (event.deltaY < 0) {\n            this.prevItem();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('panmove', ['$event'])\n    public onPanMove(event) {\n        if (event.deltaY < 0) {\n            this.nextItem();\n        } else if (event.deltaY > 0) {\n            this.prevItem();\n        }\n    }\n}\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxHourItem]'\n})\nexport class IgxHourItemDirective {\n\n    @Input('igxHourItem')\n    public value: string;\n\n    @HostBinding('class.igx-time-picker__item')\n    get defaultCSS(): boolean {\n        return true;\n    }\n\n    @HostBinding('class.igx-time-picker__item--selected')\n    get selectedCSS(): boolean {\n        return this.isSelectedHour;\n    }\n\n    @HostBinding('class.igx-time-picker__item--active')\n    get activeCSS(): boolean {\n        return this.isSelectedHour && this.itemList.isActive;\n    }\n\n    get isSelectedHour(): boolean {\n        return this.timePicker.selectedHour === this.value;\n    }\n\n    constructor(@Inject(IGX_TIME_PICKER_COMPONENT)\n    public timePicker: IgxTimePickerBase,\n        private itemList: IgxItemListDirective) { }\n\n    @HostListener('click', ['value'])\n    public onClick(item) {\n        if (item !== '') {\n            this.timePicker.scrollHourIntoView(item);\n        }\n    }\n}\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxMinuteItem]'\n})\nexport class IgxMinuteItemDirective {\n\n    @Input('igxMinuteItem')\n    public value: string;\n\n    @HostBinding('class.igx-time-picker__item')\n    get defaultCSS(): boolean {\n        return true;\n    }\n\n    @HostBinding('class.igx-time-picker__item--selected')\n    get selectedCSS(): boolean {\n        return this.isSelectedMinute;\n    }\n\n    @HostBinding('class.igx-time-picker__item--active')\n    get activeCSS(): boolean {\n        return this.isSelectedMinute && this.itemList.isActive;\n    }\n\n    get isSelectedMinute(): boolean {\n        return this.timePicker.selectedMinute === this.value;\n    }\n\n    constructor(@Inject(IGX_TIME_PICKER_COMPONENT)\n    public timePicker: IgxTimePickerBase,\n        private itemList: IgxItemListDirective) { }\n\n    @HostListener('click', ['value'])\n    public onClick(item) {\n        if (item !== '') {\n            this.timePicker.scrollMinuteIntoView(item);\n        }\n    }\n}\n\n/**\n * @hidden\n */\n@Directive({\n    selector: '[igxAmPmItem]'\n})\nexport class IgxAmPmItemDirective {\n\n    @Input('igxAmPmItem')\n    public value: string;\n\n    @HostBinding('class.igx-time-picker__item')\n    get defaultCSS(): boolean {\n        return true;\n    }\n\n    @HostBinding('class.igx-time-picker__item--selected')\n    get selectedCSS(): boolean {\n        return this.isSelectedAmPm;\n    }\n\n    @HostBinding('class.igx-time-picker__item--active')\n    get activeCSS(): boolean {\n        return this.isSelectedAmPm && this.itemList.isActive;\n    }\n\n    get isSelectedAmPm(): boolean {\n        return this.timePicker.selectedAmPm === this.value;\n    }\n\n    constructor(@Inject(IGX_TIME_PICKER_COMPONENT)\n    public timePicker: IgxTimePickerBase,\n        private itemList: IgxItemListDirective) { }\n\n    @HostListener('click', ['value'])\n    public onClick(item) {\n        if (item !== '') {\n            this.timePicker.scrollAmPmIntoView(item);\n        }\n    }\n}\n\n/**\n * This directive should be used to mark which ng-template will be used from IgxTimePicker when re-templating its input group.\n */\n@Directive({\n    selector: '[igxTimePickerTemplate]'\n})\nexport class IgxTimePickerTemplateDirective {\n    constructor(public template: TemplateRef<any>) { }\n}\n\n"]}