UNPKG

@catull/igniteui-angular

Version:

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

578 lines 47.1 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 */ 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":"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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(\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"]}