@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
578 lines • 47.1 kB
JavaScript
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 */
let IgxItemListDirective = class IgxItemListDirective {
constructor(timePicker, elementRef) {
this.timePicker = timePicker;
this.elementRef = elementRef;
this.tabindex = 0;
}
get defaultCSS() {
return true;
}
get hourCSS() {
return this.type === 'hourList';
}
get minuteCSS() {
return this.type === 'minuteList';
}
get secondsCSS() {
return this.type === 'secondsList';
}
get ampmCSS() {
return this.type === 'ampmList';
}
onFocus() {
this.isActive = true;
}
onBlur() {
this.isActive = false;
}
nextItem() {
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;
}
}
}
prevItem() {
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
*/
onKeydownArrowDown(event) {
event.preventDefault();
this.nextItem();
}
/**
* @hidden
*/
onKeydownArrowUp(event) {
event.preventDefault();
this.prevItem();
}
/**
* @hidden
*/
onKeydownArrowRight(event) {
event.preventDefault();
const 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
*/
onKeydownArrowLeft(event) {
event.preventDefault();
const 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
*/
onKeydownEnter(event) {
event.preventDefault();
if (this.timePicker.mode === InteractionMode.DropDown) {
this.timePicker.close();
return;
}
this.timePicker.okButtonClick();
}
/**
* @hidden
*/
onKeydownEscape(event) {
event.preventDefault();
this.timePicker.cancelButtonClick();
}
/**
* @hidden
*/
onHover() {
this.elementRef.nativeElement.focus();
}
/**
* @hidden
*/
onScroll(event) {
event.preventDefault();
event.stopPropagation();
if (event.deltaY > 0) {
this.nextItem();
}
else if (event.deltaY < 0) {
this.prevItem();
}
}
/**
* @hidden
*/
onPanMove(event) {
if (event.deltaY < 0) {
this.nextItem();
}
else if (event.deltaY > 0) {
this.prevItem();
}
}
};
IgxItemListDirective.ctorParameters = () => [
{ 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);
export { IgxItemListDirective };
/**
* @hidden
*/
let IgxHourItemDirective = class IgxHourItemDirective {
constructor(timePicker, itemList) {
this.timePicker = timePicker;
this.itemList = itemList;
}
get defaultCSS() {
return true;
}
get selectedCSS() {
return this.isSelectedHour;
}
get activeCSS() {
return this.isSelectedHour && this.itemList.isActive;
}
get isSelectedHour() {
return this.timePicker.selectedHour === this.value;
}
onClick(item) {
if (item !== '') {
this.timePicker.scrollHourIntoView(item);
}
}
};
IgxHourItemDirective.ctorParameters = () => [
{ 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);
export { IgxHourItemDirective };
/**
* @hidden
*/
let IgxMinuteItemDirective = class IgxMinuteItemDirective {
constructor(timePicker, itemList) {
this.timePicker = timePicker;
this.itemList = itemList;
}
get defaultCSS() {
return true;
}
get selectedCSS() {
return this.isSelectedMinute;
}
get activeCSS() {
return this.isSelectedMinute && this.itemList.isActive;
}
get isSelectedMinute() {
return this.timePicker.selectedMinute === this.value;
}
onClick(item) {
if (item !== '') {
this.timePicker.scrollMinuteIntoView(item);
}
}
};
IgxMinuteItemDirective.ctorParameters = () => [
{ 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);
export { IgxMinuteItemDirective };
/**
* @hidden
*/
let IgxSecondsItemDirective = class IgxSecondsItemDirective {
constructor(timePicker, itemList) {
this.timePicker = timePicker;
this.itemList = itemList;
}
get defaultCSS() {
return true;
}
get selectedCSS() {
return this.isSelectedSeconds;
}
get activeCSS() {
return this.isSelectedSeconds && this.itemList.isActive;
}
get isSelectedSeconds() {
return this.timePicker.selectedSeconds === this.value;
}
onClick(item) {
if (item !== '') {
this.timePicker.scrollSecondsIntoView(item);
}
}
};
IgxSecondsItemDirective.ctorParameters = () => [
{ 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);
export { IgxSecondsItemDirective };
/**
* @hidden
*/
let IgxAmPmItemDirective = class IgxAmPmItemDirective {
constructor(timePicker, itemList) {
this.timePicker = timePicker;
this.itemList = itemList;
}
get defaultCSS() {
return true;
}
get selectedCSS() {
return this.isSelectedAmPm;
}
get activeCSS() {
return this.isSelectedAmPm && this.itemList.isActive;
}
get isSelectedAmPm() {
return this.timePicker.selectedAmPm === this.value;
}
onClick(item) {
if (item !== '') {
this.timePicker.scrollAmPmIntoView(item);
}
}
};
IgxAmPmItemDirective.ctorParameters = () => [
{ 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);
export { IgxAmPmItemDirective };
/**
* This directive should be used to mark which ng-template will be used from IgxTimePicker when re-templating its input group.
*/
let IgxTimePickerTemplateDirective = class IgxTimePickerTemplateDirective {
constructor(template) {
this.template = template;
}
};
IgxTimePickerTemplateDirective.ctorParameters = () => [
{ type: TemplateRef }
];
IgxTimePickerTemplateDirective = __decorate([
Directive({
selector: '[igxTimePickerTemplate]'
}),
__metadata("design:paramtypes", [TemplateRef])
], IgxTimePickerTemplateDirective);
export { IgxTimePickerTemplateDirective };
/**
* This directive can be used to add custom action buttons to the dropdownb/dialog.
*/
let IgxTimePickerActionsDirective = class IgxTimePickerActionsDirective {
constructor(template) {
this.template = template;
}
};
IgxTimePickerActionsDirective.ctorParameters = () => [
{ type: TemplateRef }
];
IgxTimePickerActionsDirective = __decorate([
Directive({
selector: '[igxTimePickerActions]'
}),
__metadata("design:paramtypes", [TemplateRef])
], 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,IAAa,oBAAoB,GAAjC,MAAa,oBAAoB;IAO7B,YAC8C,UAA6B,EAC/D,UAAsB;QADY,eAAU,GAAV,UAAU,CAAmB;QAC/D,eAAU,GAAV,UAAU,CAAY;QAI3B,aAAQ,GAAG,CAAC,CAAC;IAHhB,CAAC;IAML,IAAI,UAAU;QACV,OAAO,IAAI,CAAC;IAChB,CAAC;IAGD,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC;IACpC,CAAC;IAGD,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,IAAI,KAAK,YAAY,CAAC;IACtC,CAAC;IAGD,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,IAAI,KAAK,aAAa,CAAC;IACvC,CAAC;IAGD,IAAI,OAAO;QACP,OAAO,IAAI,CAAC,IAAI,KAAK,UAAU,CAAC;IACpC,CAAC;IAGM,OAAO;QACV,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACzB,CAAC;IAGM,MAAM;QACT,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IAC1B,CAAC;IAEO,QAAQ;QACZ,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,QAAQ;QACZ,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,kBAAkB,CAAC,KAAoB;QAC1C,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAED;;OAEG;IAEI,gBAAgB,CAAC,KAAoB;QACxC,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAED;;OAEG;IAEI,mBAAmB,CAAC,KAAoB;QAC3C,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,MAAM,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,kBAAkB,CAAC,KAAoB;QAC1C,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,MAAM,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,cAAc,CAAC,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,eAAe,CAAC,KAAoB;QACvC,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;IACxC,CAAC;IAED;;OAEG;IAEI,OAAO;QACV,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC1C,CAAC;IAED;;OAEG;IAEI,QAAQ,CAAC,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,SAAS,CAAC,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;CACJ,CAAA;;4CA1MQ,MAAM,SAAC,yBAAyB;YACb,UAAU;;AANlC;IADC,KAAK,CAAC,aAAa,CAAC;;kDACD;AAUpB;IADC,WAAW,CAAC,eAAe,CAAC;;sDACT;AAGpB;IADC,WAAW,CAAC,+BAA+B,CAAC;;;sDAG5C;AAGD;IADC,WAAW,CAAC,iCAAiC,CAAC;;;mDAG9C;AAGD;IADC,WAAW,CAAC,mCAAmC,CAAC;;;qDAGhD;AAGD;IADC,WAAW,CAAC,oCAAoC,CAAC;;;sDAGjD;AAGD;IADC,WAAW,CAAC,iCAAiC,CAAC;;;mDAG9C;AAGD;IADC,YAAY,CAAC,OAAO,CAAC;;;;mDAGrB;AAGD;IADC,YAAY,CAAC,MAAM,CAAC;;;;kDAGpB;AAgDD;IADC,YAAY,CAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC,CAAC;;qCACb,aAAa;;8DAI7C;AAMD;IADC,YAAY,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,CAAC;;qCACb,aAAa;;4DAI3C;AAMD;IADC,YAAY,CAAC,oBAAoB,EAAE,CAAC,QAAQ,CAAC,CAAC;;qCACb,aAAa;;+DAa9C;AAMD;IADC,YAAY,CAAC,mBAAmB,EAAE,CAAC,QAAQ,CAAC,CAAC;;qCACb,aAAa;;8DAe7C;AAMD;IADC,YAAY,CAAC,eAAe,EAAE,CAAC,QAAQ,CAAC,CAAC;;qCACb,aAAa;;0DAQzC;AAMD;IADC,YAAY,CAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC,CAAC;;qCACb,aAAa;;2DAI1C;AAMD;IADC,YAAY,CAAC,WAAW,CAAC;;;;mDAGzB;AAMD;IADC,YAAY,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;oDAUjC;AAMD;IADC,YAAY,CAAC,SAAS,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;qDAOnC;AAjNQ,oBAAoB;IAHhC,SAAS,CAAC;QACP,QAAQ,EAAE,eAAe;KAC5B,CAAC;IASO,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;6CACd,UAAU;GATzB,oBAAoB,CAkNhC;SAlNY,oBAAoB;AAoNjC;;GAEG;AAIH,IAAa,oBAAoB,GAAjC,MAAa,oBAAoB;IAwB7B,YACO,UAA6B,EACxB,QAA8B;QADnC,eAAU,GAAV,UAAU,CAAmB;QACxB,aAAQ,GAAR,QAAQ,CAAsB;IAAI,CAAC;IApB/C,IAAI,UAAU;QACV,OAAO,IAAI,CAAC;IAChB,CAAC;IAGD,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAGD,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;IACzD,CAAC;IAED,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,YAAY,KAAK,IAAI,CAAC,KAAK,CAAC;IACvD,CAAC;IAOM,OAAO,CAAC,IAAI;QACf,IAAI,IAAI,KAAK,EAAE,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;SAC5C;IACL,CAAC;CACJ,CAAA;;4CAVgB,MAAM,SAAC,yBAAyB;YAEvB,oBAAoB;;AAvB1C;IADC,KAAK,CAAC,aAAa,CAAC;;mDACA;AAGrB;IADC,WAAW,CAAC,6BAA6B,CAAC;;;sDAG1C;AAGD;IADC,WAAW,CAAC,uCAAuC,CAAC;;;uDAGpD;AAGD;IADC,WAAW,CAAC,qCAAqC,CAAC;;;qDAGlD;AAWD;IADC,YAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;;;;mDAKhC;AAjCQ,oBAAoB;IAHhC,SAAS,CAAC;QACP,QAAQ,EAAE,eAAe;KAC5B,CAAC;IAyBe,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;6CAExB,oBAAoB;GA1BjC,oBAAoB,CAkChC;SAlCY,oBAAoB;AAoCjC;;GAEG;AAIH,IAAa,sBAAsB,GAAnC,MAAa,sBAAsB;IAwB/B,YACO,UAA6B,EACxB,QAA8B;QADnC,eAAU,GAAV,UAAU,CAAmB;QACxB,aAAQ,GAAR,QAAQ,CAAsB;IAAI,CAAC;IApB/C,IAAI,UAAU;QACV,OAAO,IAAI,CAAC;IAChB,CAAC;IAGD,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,gBAAgB,CAAC;IACjC,CAAC;IAGD,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAC3D,CAAC;IAED,IAAI,gBAAgB;QAChB,OAAO,IAAI,CAAC,UAAU,CAAC,cAAc,KAAK,IAAI,CAAC,KAAK,CAAC;IACzD,CAAC;IAOM,OAAO,CAAC,IAAI;QACf,IAAI,IAAI,KAAK,EAAE,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAC;SAC9C;IACL,CAAC;CACJ,CAAA;;4CAVgB,MAAM,SAAC,yBAAyB;YAEvB,oBAAoB;;AAvB1C;IADC,KAAK,CAAC,eAAe,CAAC;;qDACF;AAGrB;IADC,WAAW,CAAC,6BAA6B,CAAC;;;wDAG1C;AAGD;IADC,WAAW,CAAC,uCAAuC,CAAC;;;yDAGpD;AAGD;IADC,WAAW,CAAC,qCAAqC,CAAC;;;uDAGlD;AAWD;IADC,YAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;;;;qDAKhC;AAjCQ,sBAAsB;IAHlC,SAAS,CAAC;QACP,QAAQ,EAAE,iBAAiB;KAC9B,CAAC;IAyBe,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;6CAExB,oBAAoB;GA1BjC,sBAAsB,CAkClC;SAlCY,sBAAsB;AAoCnC;;GAEG;AAIH,IAAa,uBAAuB,GAApC,MAAa,uBAAuB;IAwBhC,YACO,UAA6B,EACxB,QAA8B;QADnC,eAAU,GAAV,UAAU,CAAmB;QACxB,aAAQ,GAAR,QAAQ,CAAsB;IAAI,CAAC;IApB/C,IAAI,UAAU;QACV,OAAO,IAAI,CAAC;IAChB,CAAC;IAGD,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAClC,CAAC;IAGD,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,iBAAiB,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;IAC5D,CAAC;IAED,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,UAAU,CAAC,eAAe,KAAK,IAAI,CAAC,KAAK,CAAC;IAC1D,CAAC;IAOM,OAAO,CAAC,IAAI;QACf,IAAI,IAAI,KAAK,EAAE,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;SAC/C;IACL,CAAC;CACJ,CAAA;;4CAVgB,MAAM,SAAC,yBAAyB;YAEvB,oBAAoB;;AAvB1C;IADC,KAAK,CAAC,gBAAgB,CAAC;;sDACH;AAGrB;IADC,WAAW,CAAC,6BAA6B,CAAC;;;yDAG1C;AAGD;IADC,WAAW,CAAC,uCAAuC,CAAC;;;0DAGpD;AAGD;IADC,WAAW,CAAC,qCAAqC,CAAC;;;wDAGlD;AAWD;IADC,YAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;;;;sDAKhC;AAjCQ,uBAAuB;IAHnC,SAAS,CAAC;QACP,QAAQ,EAAE,kBAAkB;KAC/B,CAAC;IAyBe,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;6CAExB,oBAAoB;GA1BjC,uBAAuB,CAkCnC;SAlCY,uBAAuB;AAoCpC;;GAEG;AAIH,IAAa,oBAAoB,GAAjC,MAAa,oBAAoB;IAwB7B,YACO,UAA6B,EACxB,QAA8B;QADnC,eAAU,GAAV,UAAU,CAAmB;QACxB,aAAQ,GAAR,QAAQ,CAAsB;IAAI,CAAC;IApB/C,IAAI,UAAU;QACV,OAAO,IAAI,CAAC;IAChB,CAAC;IAGD,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAGD,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC;IACzD,CAAC;IAED,IAAI,cAAc;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,YAAY,KAAK,IAAI,CAAC,KAAK,CAAC;IACvD,CAAC;IAOM,OAAO,CAAC,IAAI;QACf,IAAI,IAAI,KAAK,EAAE,EAAE;YACb,IAAI,CAAC,UAAU,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;SAC5C;IACL,CAAC;CACJ,CAAA;;4CAVgB,MAAM,SAAC,yBAAyB;YAEvB,oBAAoB;;AAvB1C;IADC,KAAK,CAAC,aAAa,CAAC;;mDACA;AAGrB;IADC,WAAW,CAAC,6BAA6B,CAAC;;;sDAG1C;AAGD;IADC,WAAW,CAAC,uCAAuC,CAAC;;;uDAGpD;AAGD;IADC,WAAW,CAAC,qCAAqC,CAAC;;;qDAGlD;AAWD;IADC,YAAY,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;;;;mDAKhC;AAjCQ,oBAAoB;IAHhC,SAAS,CAAC;QACP,QAAQ,EAAE,eAAe;KAC5B,CAAC;IAyBe,WAAA,MAAM,CAAC,yBAAyB,CAAC,CAAA;6CAExB,oBAAoB;GA1BjC,oBAAoB,CAkChC;SAlCY,oBAAoB;AAoCjC;;GAEG;AAIH,IAAa,8BAA8B,GAA3C,MAAa,8BAA8B;IACvC,YAAmB,QAA0B;QAA1B,aAAQ,GAAR,QAAQ,CAAkB;IAAI,CAAC;CACrD,CAAA;;YADgC,WAAW;;AAD/B,8BAA8B;IAH1C,SAAS,CAAC;QACP,QAAQ,EAAE,yBAAyB;KACtC,CAAC;qCAE+B,WAAW;GAD/B,8BAA8B,CAE1C;SAFY,8BAA8B;AAI3C;;GAEG;AAIH,IAAa,6BAA6B,GAA1C,MAAa,6BAA6B;IACtC,YAAmB,QAA0B;QAA1B,aAAQ,GAAR,QAAQ,CAAkB;IAAI,CAAC;CACrD,CAAA;;YADgC,WAAW;;AAD/B,6BAA6B;IAHzC,SAAS,CAAC;QACP,QAAQ,EAAE,wBAAwB;KACrC,CAAC;qCAE+B,WAAW;GAD/B,6BAA6B,CAEzC;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(): boolean {\n        return this.isSelectedSeconds;\n    }\n\n    @HostBinding('class.igx-time-picker__item--active')\n    get activeCSS(): boolean {\n        return this.isSelectedSeconds && this.itemList.isActive;\n    }\n\n    get isSelectedSeconds(): boolean {\n        return this.timePicker.selectedSeconds === 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.scrollSecondsIntoView(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/**\n * This directive can be used to add custom action buttons to the dropdownb/dialog.\n */\n@Directive({\n    selector: '[igxTimePickerActions]'\n})\nexport class IgxTimePickerActionsDirective {\n    constructor(public template: TemplateRef<any>) { }\n}\n"]}