igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
500 lines • 33.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* This file contains all the directives used by the @link IgxTimePickerComponent.
* You should generally not use them directly.
* @preferred
*/
import { Directive, ElementRef, HostBinding, HostListener, Inject, Input, TemplateRef } from '@angular/core';
import { IGX_TIME_PICKER_COMPONENT } from './time-picker.common';
import { InteractionMode } from '../core/enums';
/**
* @hidden
*/
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"]}