UNPKG

@catull/igniteui-angular

Version:

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

669 lines 53 kB
import { __decorate, __metadata, __param } from "tslib"; /** * 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: function () { return true; }, enumerable: true, configurable: true }); Object.defineProperty(IgxItemListDirective.prototype, "hourCSS", { get: function () { return this.type === 'hourList'; }, enumerable: true, configurable: true }); Object.defineProperty(IgxItemListDirective.prototype, "minuteCSS", { get: function () { return this.type === 'minuteList'; }, enumerable: true, configurable: true }); Object.defineProperty(IgxItemListDirective.prototype, "secondsCSS", { get: function () { return this.type === 'secondsList'; }, enumerable: true, configurable: true }); Object.defineProperty(IgxItemListDirective.prototype, "ampmCSS", { get: function () { return this.type === 'ampmList'; }, enumerable: true, configurable: true }); IgxItemListDirective.prototype.onFocus = function () { this.isActive = true; }; IgxItemListDirective.prototype.onBlur = function () { this.isActive = false; }; IgxItemListDirective.prototype.nextItem = function () { switch (this.type) { case 'hourList': { this.timePicker.nextHour(); break; } case 'minuteList': { this.timePicker.nextMinute(); break; } case 'secondsList': { this.timePicker.nextSeconds(); break; } case 'ampmList': { this.timePicker.nextAmPm(); break; } } }; IgxItemListDirective.prototype.prevItem = function () { switch (this.type) { case 'hourList': { this.timePicker.prevHour(); break; } case 'minuteList': { this.timePicker.prevMinute(); break; } case 'secondsList': { this.timePicker.prevSeconds(); break; } case 'ampmList': { this.timePicker.prevAmPm(); break; } } }; /** * @hidden */ IgxItemListDirective.prototype.onKeydownArrowDown = function (event) { event.preventDefault(); this.nextItem(); }; /** * @hidden */ IgxItemListDirective.prototype.onKeydownArrowUp = function (event) { event.preventDefault(); this.prevItem(); }; /** * @hidden */ IgxItemListDirective.prototype.onKeydownArrowRight = function (event) { event.preventDefault(); var listName = event.target.className; if (listName.indexOf('hourList') !== -1 && this.timePicker.minuteList) { this.timePicker.minuteList.nativeElement.focus(); } else if ((listName.indexOf('hourList') !== -1 || listName.indexOf('minuteList') !== -1) && this.timePicker.secondsList) { this.timePicker.secondsList.nativeElement.focus(); } else if ((listName.indexOf('hourList') !== -1 || listName.indexOf('minuteList') !== -1 || listName.indexOf('secondsList') !== -1) && this.timePicker.ampmList) { this.timePicker.ampmList.nativeElement.focus(); } }; /** * @hidden */ IgxItemListDirective.prototype.onKeydownArrowLeft = function (event) { event.preventDefault(); var listName = event.target.className; if (listName.indexOf('ampmList') !== -1 && this.timePicker.secondsList) { this.timePicker.secondsList.nativeElement.focus(); } else if (listName.indexOf('secondsList') !== -1 && this.timePicker.secondsList && listName.indexOf('minutesList') && this.timePicker.minuteList) { this.timePicker.minuteList.nativeElement.focus(); } else if (listName.indexOf('ampmList') !== -1 && this.timePicker.minuteList) { this.timePicker.minuteList.nativeElement.focus(); } else if ((listName.indexOf('ampmList') !== -1 || listName.indexOf('secondsList') !== -1 || listName.indexOf('minuteList') !== -1) && this.timePicker.hourList) { this.timePicker.hourList.nativeElement.focus(); } }; /** * @hidden */ IgxItemListDirective.prototype.onKeydownEnter = function (event) { event.preventDefault(); if (this.timePicker.mode === InteractionMode.DropDown) { this.timePicker.close(); return; } this.timePicker.okButtonClick(); }; /** * @hidden */ IgxItemListDirective.prototype.onKeydownEscape = function (event) { event.preventDefault(); this.timePicker.cancelButtonClick(); }; /** * @hidden */ IgxItemListDirective.prototype.onHover = function () { this.elementRef.nativeElement.focus(); }; /** * @hidden */ IgxItemListDirective.prototype.onScroll = function (event) { event.preventDefault(); event.stopPropagation(); if (event.deltaY > 0) { this.nextItem(); } else if (event.deltaY < 0) { this.prevItem(); } }; /** * @hidden */ IgxItemListDirective.prototype.onPanMove = function (event) { if (event.deltaY < 0) { this.nextItem(); } else if (event.deltaY > 0) { this.prevItem(); } }; IgxItemListDirective.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }, { type: ElementRef } ]; }; __decorate([ Input('igxItemList'), __metadata("design:type", String) ], IgxItemListDirective.prototype, "type", void 0); __decorate([ HostBinding('attr.tabindex'), __metadata("design:type", Object) ], IgxItemListDirective.prototype, "tabindex", void 0); __decorate([ HostBinding('class.igx-time-picker__column'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxItemListDirective.prototype, "defaultCSS", null); __decorate([ HostBinding('class.igx-time-picker__hourList'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxItemListDirective.prototype, "hourCSS", null); __decorate([ HostBinding('class.igx-time-picker__minuteList'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxItemListDirective.prototype, "minuteCSS", null); __decorate([ HostBinding('class.igx-time-picker__secondsList'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxItemListDirective.prototype, "secondsCSS", null); __decorate([ HostBinding('class.igx-time-picker__ampmList'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxItemListDirective.prototype, "ampmCSS", null); __decorate([ HostListener('focus'), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onFocus", null); __decorate([ HostListener('blur'), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onBlur", null); __decorate([ HostListener('keydown.arrowdown', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onKeydownArrowDown", null); __decorate([ HostListener('keydown.arrowup', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onKeydownArrowUp", null); __decorate([ HostListener('keydown.arrowright', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onKeydownArrowRight", null); __decorate([ HostListener('keydown.arrowleft', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onKeydownArrowLeft", null); __decorate([ HostListener('keydown.enter', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onKeydownEnter", null); __decorate([ HostListener('keydown.escape', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onKeydownEscape", null); __decorate([ HostListener('mouseover'), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onHover", null); __decorate([ HostListener('wheel', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onScroll", null); __decorate([ HostListener('panmove', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxItemListDirective.prototype, "onPanMove", null); IgxItemListDirective = __decorate([ Directive({ selector: '[igxItemList]' }), __param(0, Inject(IGX_TIME_PICKER_COMPONENT)), __metadata("design:paramtypes", [Object, ElementRef]) ], IgxItemListDirective); return IgxItemListDirective; }()); export { IgxItemListDirective }; /** * @hidden */ var IgxHourItemDirective = /** @class */ (function () { function IgxHourItemDirective(timePicker, itemList) { this.timePicker = timePicker; this.itemList = itemList; } Object.defineProperty(IgxHourItemDirective.prototype, "defaultCSS", { get: function () { return true; }, enumerable: true, configurable: true }); Object.defineProperty(IgxHourItemDirective.prototype, "selectedCSS", { get: function () { return this.isSelectedHour; }, enumerable: true, configurable: true }); Object.defineProperty(IgxHourItemDirective.prototype, "activeCSS", { get: function () { return this.isSelectedHour && this.itemList.isActive; }, enumerable: true, configurable: true }); Object.defineProperty(IgxHourItemDirective.prototype, "isSelectedHour", { get: function () { return this.timePicker.selectedHour === this.value; }, enumerable: true, configurable: true }); IgxHourItemDirective.prototype.onClick = function (item) { if (item !== '') { this.timePicker.scrollHourIntoView(item); } }; IgxHourItemDirective.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }, { type: IgxItemListDirective } ]; }; __decorate([ Input('igxHourItem'), __metadata("design:type", String) ], IgxHourItemDirective.prototype, "value", void 0); __decorate([ HostBinding('class.igx-time-picker__item'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxHourItemDirective.prototype, "defaultCSS", null); __decorate([ HostBinding('class.igx-time-picker__item--selected'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxHourItemDirective.prototype, "selectedCSS", null); __decorate([ HostBinding('class.igx-time-picker__item--active'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxHourItemDirective.prototype, "activeCSS", null); __decorate([ HostListener('click', ['value']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxHourItemDirective.prototype, "onClick", null); IgxHourItemDirective = __decorate([ Directive({ selector: '[igxHourItem]' }), __param(0, Inject(IGX_TIME_PICKER_COMPONENT)), __metadata("design:paramtypes", [Object, IgxItemListDirective]) ], IgxHourItemDirective); return IgxHourItemDirective; }()); export { IgxHourItemDirective }; /** * @hidden */ var IgxMinuteItemDirective = /** @class */ (function () { function IgxMinuteItemDirective(timePicker, itemList) { this.timePicker = timePicker; this.itemList = itemList; } Object.defineProperty(IgxMinuteItemDirective.prototype, "defaultCSS", { get: function () { return true; }, enumerable: true, configurable: true }); Object.defineProperty(IgxMinuteItemDirective.prototype, "selectedCSS", { get: function () { return this.isSelectedMinute; }, enumerable: true, configurable: true }); Object.defineProperty(IgxMinuteItemDirective.prototype, "activeCSS", { get: function () { return this.isSelectedMinute && this.itemList.isActive; }, enumerable: true, configurable: true }); Object.defineProperty(IgxMinuteItemDirective.prototype, "isSelectedMinute", { get: function () { return this.timePicker.selectedMinute === this.value; }, enumerable: true, configurable: true }); IgxMinuteItemDirective.prototype.onClick = function (item) { if (item !== '') { this.timePicker.scrollMinuteIntoView(item); } }; IgxMinuteItemDirective.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }, { type: IgxItemListDirective } ]; }; __decorate([ Input('igxMinuteItem'), __metadata("design:type", String) ], IgxMinuteItemDirective.prototype, "value", void 0); __decorate([ HostBinding('class.igx-time-picker__item'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxMinuteItemDirective.prototype, "defaultCSS", null); __decorate([ HostBinding('class.igx-time-picker__item--selected'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxMinuteItemDirective.prototype, "selectedCSS", null); __decorate([ HostBinding('class.igx-time-picker__item--active'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxMinuteItemDirective.prototype, "activeCSS", null); __decorate([ HostListener('click', ['value']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxMinuteItemDirective.prototype, "onClick", null); IgxMinuteItemDirective = __decorate([ Directive({ selector: '[igxMinuteItem]' }), __param(0, Inject(IGX_TIME_PICKER_COMPONENT)), __metadata("design:paramtypes", [Object, IgxItemListDirective]) ], IgxMinuteItemDirective); return IgxMinuteItemDirective; }()); export { IgxMinuteItemDirective }; /** * @hidden */ var IgxSecondsItemDirective = /** @class */ (function () { function IgxSecondsItemDirective(timePicker, itemList) { this.timePicker = timePicker; this.itemList = itemList; } Object.defineProperty(IgxSecondsItemDirective.prototype, "defaultCSS", { get: function () { return true; }, enumerable: true, configurable: true }); Object.defineProperty(IgxSecondsItemDirective.prototype, "selectedCSS", { get: function () { return this.isSelectedSeconds; }, enumerable: true, configurable: true }); Object.defineProperty(IgxSecondsItemDirective.prototype, "activeCSS", { get: function () { return this.isSelectedSeconds && this.itemList.isActive; }, enumerable: true, configurable: true }); Object.defineProperty(IgxSecondsItemDirective.prototype, "isSelectedSeconds", { get: function () { return this.timePicker.selectedSeconds === this.value; }, enumerable: true, configurable: true }); IgxSecondsItemDirective.prototype.onClick = function (item) { if (item !== '') { this.timePicker.scrollSecondsIntoView(item); } }; IgxSecondsItemDirective.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }, { type: IgxItemListDirective } ]; }; __decorate([ Input('igxSecondsItem'), __metadata("design:type", String) ], IgxSecondsItemDirective.prototype, "value", void 0); __decorate([ HostBinding('class.igx-time-picker__item'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxSecondsItemDirective.prototype, "defaultCSS", null); __decorate([ HostBinding('class.igx-time-picker__item--selected'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxSecondsItemDirective.prototype, "selectedCSS", null); __decorate([ HostBinding('class.igx-time-picker__item--active'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxSecondsItemDirective.prototype, "activeCSS", null); __decorate([ HostListener('click', ['value']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxSecondsItemDirective.prototype, "onClick", null); IgxSecondsItemDirective = __decorate([ Directive({ selector: '[igxSecondsItem]' }), __param(0, Inject(IGX_TIME_PICKER_COMPONENT)), __metadata("design:paramtypes", [Object, IgxItemListDirective]) ], IgxSecondsItemDirective); return IgxSecondsItemDirective; }()); export { IgxSecondsItemDirective }; /** * @hidden */ var IgxAmPmItemDirective = /** @class */ (function () { function IgxAmPmItemDirective(timePicker, itemList) { this.timePicker = timePicker; this.itemList = itemList; } Object.defineProperty(IgxAmPmItemDirective.prototype, "defaultCSS", { get: function () { return true; }, enumerable: true, configurable: true }); Object.defineProperty(IgxAmPmItemDirective.prototype, "selectedCSS", { get: function () { return this.isSelectedAmPm; }, enumerable: true, configurable: true }); Object.defineProperty(IgxAmPmItemDirective.prototype, "activeCSS", { get: function () { return this.isSelectedAmPm && this.itemList.isActive; }, enumerable: true, configurable: true }); Object.defineProperty(IgxAmPmItemDirective.prototype, "isSelectedAmPm", { get: function () { return this.timePicker.selectedAmPm === this.value; }, enumerable: true, configurable: true }); IgxAmPmItemDirective.prototype.onClick = function (item) { if (item !== '') { this.timePicker.scrollAmPmIntoView(item); } }; IgxAmPmItemDirective.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [IGX_TIME_PICKER_COMPONENT,] }] }, { type: IgxItemListDirective } ]; }; __decorate([ Input('igxAmPmItem'), __metadata("design:type", String) ], IgxAmPmItemDirective.prototype, "value", void 0); __decorate([ HostBinding('class.igx-time-picker__item'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxAmPmItemDirective.prototype, "defaultCSS", null); __decorate([ HostBinding('class.igx-time-picker__item--selected'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxAmPmItemDirective.prototype, "selectedCSS", null); __decorate([ HostBinding('class.igx-time-picker__item--active'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxAmPmItemDirective.prototype, "activeCSS", null); __decorate([ HostListener('click', ['value']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxAmPmItemDirective.prototype, "onClick", null); IgxAmPmItemDirective = __decorate([ Directive({ selector: '[igxAmPmItem]' }), __param(0, Inject(IGX_TIME_PICKER_COMPONENT)), __metadata("design:paramtypes", [Object, IgxItemListDirective]) ], IgxAmPmItemDirective); return IgxAmPmItemDirective; }()); export { IgxAmPmItemDirective }; /** * 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.ctorParameters = function () { return [ { type: TemplateRef } ]; }; IgxTimePickerTemplateDirective = __decorate([ Directive({ selector: '[igxTimePickerTemplate]' }), __metadata("design:paramtypes", [TemplateRef]) ], IgxTimePickerTemplateDirective); return IgxTimePickerTemplateDirective; }()); export { IgxTimePickerTemplateDirective }; /** * This directive can be used to add custom action buttons to the dropdownb/dialog. */ var IgxTimePickerActionsDirective = /** @class */ (function () { function IgxTimePickerActionsDirective(template) { this.template = template; } IgxTimePickerActionsDirective.ctorParameters = function () { return [ { type: TemplateRef } ]; }; IgxTimePickerActionsDirective = __decorate([ Directive({ selector: '[igxTimePickerActions]' }), __metadata("design:paramtypes", [TemplateRef]) ], IgxTimePickerActionsDirective); return IgxTimePickerActionsDirective; }()); export { IgxTimePickerActionsDirective }; //# 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":";AAAA;;;;GAIG;AACH,OAAO,EACH,SAAS,EACT,UAAU,EACV,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EACL,WAAW,EACd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,yBAAyB,EAAqB,MAAM,sBAAsB,CAAC;AACpF,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAEhD,cAAc;AAId;IAOI,8BAC8C,UAA6B,EAC/D,UAAsB;QADY,eAAU,GAAV,UAAU,CAAmB;QAC/D,eAAU,GAAV,UAAU,CAAY;QAI3B,aAAQ,GAAG,CAAC,CAAC;IAHhB,CAAC;IAML,sBAAI,4CAAU;aAAd;YACI,OAAO,IAAI,CAAC;QAChB,CAAC;;;OAAA;IAGD,sBAAI,yCAAO;aAAX;YACI,OAAO,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC;QACpC,CAAC;;;OAAA;IAGD,sBAAI,2CAAS;aAAb;YACI,OAAO,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC;QACtC,CAAC;;;OAAA;IAGD,sBAAI,4CAAU;aAAd;YACI,OAAO,IAAI,CAAC,IAAI,KAAK,aAAa,CAAC;QACvC,CAAC;;;OAAA;IAGD,sBAAI,yCAAO;aAAX;YACI,OAAO,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC;QACpC,CAAC;;;OAAA;IAGM,sCAAO,GAAd;QACI,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACzB,CAAC;IAGM,qCAAM,GAAb;QACI,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IAC1B,CAAC;IAEO,uCAAQ,GAAhB;QACI,QAAQ,IAAI,CAAC,IAAI,EAAE;YACf,KAAK,UAAU,CAAC,CAAC;gBACb,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;gBAC3B,MAAM;aACT;YACD,KAAK,YAAY,CAAC,CAAC;gBACf,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC;gBAC7B,MAAM;aACT;YACD,KAAK,aAAa,CAAC,CAAC;gBAChB,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;gBAC9B,MAAM;aACT;YACD,KAAK,UAAU,CAAC,CAAC;gBACb,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;gBAC3B,MAAM;aACT;SACJ;IACL,CAAC;IAEO,uCAAQ,GAAhB;QACI,QAAQ,IAAI,CAAC,IAAI,EAAE;YACf,KAAK,UAAU,CAAC,CAAC;gBACb,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;gBAC3B,MAAM;aACT;YACD,KAAK,YAAY,CAAC,CAAC;gBACf,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,CAAC;gBAC7B,MAAM;aACT;YACD,KAAK,aAAa,CAAC,CAAC;gBAChB,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;gBAC9B,MAAM;aACT;YACD,KAAK,UAAU,CAAC,CAAC;gBACb,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;gBAC3B,MAAM;aACT;SACJ;IACL,CAAC;IAED;;OAEG;IAEI,iDAAkB,GAAzB,UAA0B,KAAoB;QAC1C,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAED;;OAEG;IAEI,+CAAgB,GAAvB,UAAwB,KAAoB;QACxC,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAED;;OAEG;IAEI,kDAAmB,GAA1B,UAA2B,KAAoB;QAC3C,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAM,QAAQ,GAAI,KAAK,CAAC,MAAsB,CAAC,SAAS,CAAC;QAEzD,IAAI,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YACnE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACpD;aAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE;YACtH,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACrD;aAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACpF,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YACrE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAClD;IACL,CAAC;IAED;;OAEG;IAEI,iDAAkB,GAAzB,UAA0B,KAAoB;QAC1C,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAM,QAAQ,GAAI,KAAK,CAAC,MAAsB,CAAC,SAAS,CAAC;QAEzD,IAAI,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,WAAW,EAAE;YACpE,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACrD;aAAM,IAAI,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,WAAW;eACzE,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YAClE,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACpD;aAAM,IAAI,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YAC1E,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACpD;aAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,QAAQ,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACrF,QAAQ,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YACpE,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAClD;IACL,CAAC;IAED;;OAEG;IAEI,6CAAc,GAArB,UAAsB,KAAoB;QACtC,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,KAAK,eAAe,CAAC,QAAQ,EAAE;YACnD,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YACxB,OAAO;SACV;QACD,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;IACpC,CAAC;IAED;;OAEG;IAEI,8CAAe,GAAtB,UAAuB,KAAoB;QACvC,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;IACxC,CAAC;IAED;;OAEG;IAEI,sCAAO,GAAd;QACI,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC1C,CAAC;IAED;;OAEG;IAEI,uCAAQ,GAAf,UAAgB,KAAK;QACjB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACnB;aAAM,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACnB;IACL,CAAC;IAED;;OAEG;IAEI,wCAAS,GAAhB,UAAiB,KAAK;QAClB,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACnB;aAAM,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACnB;IACL,CAAC;;gDAzMI,MAAM,SAAC,yBAAyB;gBACb,UAAU;;IANlC;QADC,KAAK,CAAC,aAAa,CAAC;;sDACD;IAUpB;QADC,WAAW,CAAC,eAAe,CAAC;;0DACT;IAGpB;QADC,WAAW,CAAC,+BAA+B,CAAC;;;0DAG5C;IAGD;QADC,WAAW,CAAC,iCAAiC,CAAC;;;uDAG9C;IAGD;QADC,WAAW,CAAC,mCAAmC,CAAC;;;yDAGhD;IAGD;QADC,WAAW,CAAC,oCAAoC,CAAC;;;0DAGjD;IAGD;QADC,WAAW,CAAC,iCAAiC,CAAC;;;uDAG9C;IAGD;QADC,YAAY,CAAC,OAAO,CAAC;;;;uDAGrB;IAGD;QADC,YAAY,CAAC,MAAM,CAAC;;;;sDAGpB;IAgDD;QADC,YAAY,CAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC,CAAC;;yCACb,aAAa;;kEAI7C;IAMD;QADC,YAAY,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,CAAC;;yCACb,aAAa;;gEAI3C;IAMD;QADC,YAAY,CAAC,oBAAoB,EAAE,CAAC,QAAQ,CAAC,CAAC;;yCACb,aAAa;;mEAa9C;IAMD;QADC,YAAY,CAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC,CAAC;;yCACb,aAAa;;kEAe7C;IAMD;QADC,YAAY,CAAC,eAAe,EAAE,CAAC,QAAQ,CAAC,CAAC;;yCACb,aAAa;;8DAQzC;IAMD;QADC,YAAY,CAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC,CAAC;;yCACb,aAAa;;+DAI1C;IAMD;QADC,YAAY,CAAC,WAAW,CAAC;;;;uDAGzB;IAMD;QADC,YAAY,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;wDAUjC;IAMD;QADC,YAAY,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;yDAOnC;IAjNQ,oBAAoB;QAHhC,SAAS,CAAC;YACP,QAAQ,EAAE,eAAe;SAC5B,CAAC;QASO,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;iDACd,UAAU;OATzB,oBAAoB,CAkNhC;IAAD,2BAAC;CAAA,AAlND,IAkNC;SAlNY,oBAAoB;AAoNjC;;GAEG;AAIH;IAwBI,8BACO,UAA6B,EACxB,QAA8B;QADnC,eAAU,GAAV,UAAU,CAAmB;QACxB,aAAQ,GAAR,QAAQ,CAAsB;IAAI,CAAC;IApB/C,sBAAI,4CAAU;aAAd;YACI,OAAO,IAAI,CAAC;QAChB,CAAC;;;OAAA;IAGD,sBAAI,6CAAW;aAAf;YACI,OAAO,IAAI,CAAC,cAAc,CAAC;QAC/B,CAAC;;;OAAA;IAGD,sBAAI,2CAAS;aAAb;YACI,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACzD,CAAC;;;OAAA;IAED,sBAAI,gDAAc;aAAlB;YACI,OAAO,IAAI,CAAC,UAAU,CAAC,YAAY,KAAK,IAAI,CAAC,KAAK,CAAC;QACvD,CAAC;;;OAAA;IAOM,sCAAO,GAAd,UAAe,IAAI;QACf,IAAI,IAAI,KAAK,EAAE,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;SAC5C;IACL,CAAC;;gDATY,MAAM,SAAC,yBAAyB;gBAEvB,oBAAoB;;IAvB1C;QADC,KAAK,CAAC,aAAa,CAAC;;uDACA;IAGrB;QADC,WAAW,CAAC,6BAA6B,CAAC;;;0DAG1C;IAGD;QADC,WAAW,CAAC,uCAAuC,CAAC;;;2DAGpD;IAGD;QADC,WAAW,CAAC,qCAAqC,CAAC;;;yDAGlD;IAWD;QADC,YAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;;;;uDAKhC;IAjCQ,oBAAoB;QAHhC,SAAS,CAAC;YACP,QAAQ,EAAE,eAAe;SAC5B,CAAC;QAyBe,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;iDAExB,oBAAoB;OA1BjC,oBAAoB,CAkChC;IAAD,2BAAC;CAAA,AAlCD,IAkCC;SAlCY,oBAAoB;AAoCjC;;GAEG;AAIH;IAwBI,gCACO,UAA6B,EACxB,QAA8B;QADnC,eAAU,GAAV,UAAU,CAAmB;QACxB,aAAQ,GAAR,QAAQ,CAAsB;IAAI,CAAC;IApB/C,sBAAI,8CAAU;aAAd;YACI,OAAO,IAAI,CAAC;QAChB,CAAC;;;OAAA;IAGD,sBAAI,+CAAW;aAAf;YACI,OAAO,IAAI,CAAC,gBAAgB,CAAC;QACjC,CAAC;;;OAAA;IAGD,sBAAI,6CAAS;aAAb;YACI,OAAO,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAC3D,CAAC;;;OAAA;IAED,sBAAI,oDAAgB;aAApB;YACI,OAAO,IAAI,CAAC,UAAU,CAAC,cAAc,KAAK,IAAI,CAAC,KAAK,CAAC;QACzD,CAAC;;;OAAA;IAOM,wCAAO,GAAd,UAAe,IAAI;QACf,IAAI,IAAI,KAAK,EAAE,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;SAC9C;IACL,CAAC;;gDATY,MAAM,SAAC,yBAAyB;gBAEvB,oBAAoB;;IAvB1C;QADC,KAAK,CAAC,eAAe,CAAC;;yDACF;IAGrB;QADC,WAAW,CAAC,6BAA6B,CAAC;;;4DAG1C;IAGD;QADC,WAAW,CAAC,uCAAuC,CAAC;;;6DAGpD;IAGD;QADC,WAAW,CAAC,qCAAqC,CAAC;;;2DAGlD;IAWD;QADC,YAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;;;;yDAKhC;IAjCQ,sBAAsB;QAHlC,SAAS,CAAC;YACP,QAAQ,EAAE,iBAAiB;SAC9B,CAAC;QAyBe,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;iDAExB,oBAAoB;OA1BjC,sBAAsB,CAkClC;IAAD,6BAAC;CAAA,AAlCD,IAkCC;SAlCY,sBAAsB;AAoCnC;;GAEG;AAIH;IAwBI,iCACO,UAA6B,EACxB,QAA8B;QADnC,eAAU,GAAV,UAAU,CAAmB;QACxB,aAAQ,GAAR,QAAQ,CAAsB;IAAI,CAAC;IApB/C,sBAAI,+CAAU;aAAd;YACI,OAAO,IAAI,CAAC;QAChB,CAAC;;;OAAA;IAGD,sBAAI,gDAAW;aAAf;YACI,OAAO,IAAI,CAAC,iBAAiB,CAAC;QAClC,CAAC;;;OAAA;IAGD,sBAAI,8CAAS;aAAb;YACI,OAAO,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAC5D,CAAC;;;OAAA;IAED,sBAAI,sDAAiB;aAArB;YACI,OAAO,IAAI,CAAC,UAAU,CAAC,eAAe,KAAK,IAAI,CAAC,KAAK,CAAC;QAC1D,CAAC;;;OAAA;IAOM,yCAAO,GAAd,UAAe,IAAI;QACf,IAAI,IAAI,KAAK,EAAE,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;SAC/C;IACL,CAAC;;gDATY,MAAM,SAAC,yBAAyB;gBAEvB,oBAAoB;;IAvB1C;QADC,KAAK,CAAC,gBAAgB,CAAC;;0DACH;IAGrB;QADC,WAAW,CAAC,6BAA6B,CAAC;;;6DAG1C;IAGD;QADC,WAAW,CAAC,uCAAuC,CAAC;;;8DAGpD;IAGD;QADC,WAAW,CAAC,qCAAqC,CAAC;;;4DAGlD;IAWD;QADC,YAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;;;;0DAKhC;IAjCQ,uBAAuB;QAHnC,SAAS,CAAC;YACP,QAAQ,EAAE,kBAAkB;SAC/B,CAAC;QAyBe,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;iDAExB,oBAAoB;OA1BjC,uBAAuB,CAkCnC;IAAD,8BAAC;CAAA,AAlCD,IAkCC;SAlCY,uBAAuB;AAoCpC;;GAEG;AAIH;IAwBI,8BACO,UAA6B,EACxB,QAA8B;QADnC,eAAU,GAAV,UAAU,CAAmB;QACxB,aAAQ,GAAR,QAAQ,CAAsB;IAAI,CAAC;IApB/C,sBAAI,4CAAU;aAAd;YACI,OAAO,IAAI,CAAC;QAChB,CAAC;;;OAAA;IAGD,sBAAI,6CAAW;aAAf;YACI,OAAO,IAAI,CAAC,cAAc,CAAC;QAC/B,CAAC;;;OAAA;IAGD,sBAAI,2CAAS;aAAb;YACI,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;QACzD,CAAC;;;OAAA;IAED,sBAAI,gDAAc;aAAlB;YACI,OAAO,IAAI,CAAC,UAAU,CAAC,YAAY,KAAK,IAAI,CAAC,KAAK,CAAC;QACvD,CAAC;;;OAAA;IAOM,sCAAO,GAAd,UAAe,IAAI;QACf,IAAI,IAAI,KAAK,EAAE,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;SAC5C;IACL,CAAC;;gDATY,MAAM,SAAC,yBAAyB;gBAEvB,oBAAoB;;IAvB1C;QADC,KAAK,CAAC,aAAa,CAAC;;uDACA;IAGrB;QADC,WAAW,CAAC,6BAA6B,CAAC;;;0DAG1C;IAGD;QADC,WAAW,CAAC,uCAAuC,CAAC;;;2DAGpD;IAGD;QADC,WAAW,CAAC,qCAAqC,CAAC;;;yDAGlD;IAWD;QADC,YAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;;;;uDAKhC;IAjCQ,oBAAoB;QAHhC,SAAS,CAAC;YACP,QAAQ,EAAE,eAAe;SAC5B,CAAC;QAyBe,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;iDAExB,oBAAoB;OA1BjC,oBAAoB,CAkChC;IAAD,2BAAC;CAAA,AAlCD,IAkCC;SAlCY,oBAAoB;AAoCjC;;GAEG;AAIH;IACI,wCAAmB,QAA0B;QAA1B,aAAQ,GAAR,QAAQ,CAAkB;IAAI,CAAC;;gBAArB,WAAW;;IAD/B,8BAA8B;QAH1C,SAAS,CAAC;YACP,QAAQ,EAAE,yBAAyB;SACtC,CAAC;yCAE+B,WAAW;OAD/B,8BAA8B,CAE1C;IAAD,qCAAC;CAAA,AAFD,IAEC;SAFY,8BAA8B;AAI3C;;GAEG;AAIH;IACI,uCAAmB,QAA0B;QAA1B,aAAQ,GAAR,QAAQ,CAAkB;IAAI,CAAC;;gBAArB,WAAW;;IAD/B,6BAA6B;QAHzC,SAAS,CAAC;YACP,QAAQ,EAAE,wBAAwB;SACrC,CAAC;yCAE+B,WAAW;OAD/B,6BAA6B,CAEzC;IAAD,oCAAC;CAAA,AAFD,IAEC;SAFY,6BAA6B","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(\n        @Inject(IGX_TIME_PICKER_COMPONENT) public timePicker: IgxTimePickerBase,\n        private elementRef: ElementRef\n    ) { }\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__secondsList')\n    get secondsCSS(): boolean {\n        return this.type === 'secondsList';\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 'secondsList': {\n                this.timePicker.nextSeconds();\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 'secondsList': {\n                this.timePicker.prevSeconds();\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 && this.timePicker.minuteList) {\n            this.timePicker.minuteList.nativeElement.focus();\n        } else if ((listName.indexOf('hourList') !== -1 || listName.indexOf('minuteList') !== -1) && this.timePicker.secondsList) {\n            this.timePicker.secondsList.nativeElement.focus();\n        } else if ((listName.indexOf('hourList') !== -1 || listName.indexOf('minuteList') !== -1 ||\n            listName.indexOf('secondsList') !== -1) && this.timePicker.ampmList) {\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        const listName = (event.target as HTMLElement).className;\n\n        if (listName.indexOf('ampmList') !== -1 && this.timePicker.secondsList) {\n            this.timePicker.secondsList.nativeElement.focus();\n        } else if (listName.indexOf('secondsList') !== -1 && this.timePicker.secondsList\n            && listName.indexOf('minutesList') && this.timePicker.minuteList) {\n            this.timePicker.minuteList.nativeElement.focus();\n        } else if (listName.indexOf('ampmList') !== -1 && this.timePicker.minuteList) {\n            this.timePicker.minuteList.nativeElement.focus();\n        } else if ((listName.indexOf('ampmList') !== -1 || listName.indexOf('secondsList') !== -1 ||\n            listName.indexOf('minuteList') !== -1) && this.timePicker.hourList) {\n            this.timePicker.hourList.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.close();\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: '[igxSecondsItem]'\n})\nexport class IgxSecondsItemDirective {\n\n    @Input('igxSecondsItem')\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(): 