UNPKG

igniteui-angular

Version:

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

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