igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
228 lines • 16.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Directive, Optional, Self, Input, HostListener, Inject } from '@angular/core';
import { IGX_DROPDOWN_BASE } from './drop-down.common';
import { IgxDropDownBase } from './drop-down.base';
import { DropDownActionKey } from './drop-down.common';
/**
* Navigation Directive that handles keyboard events on its host and controls a targeted IgxDropDownBase component
*/
var IgxDropDownItemNavigationDirective = /** @class */ (function () {
function IgxDropDownItemNavigationDirective(dropdown) {
this.dropdown = dropdown;
this._target = null;
}
Object.defineProperty(IgxDropDownItemNavigationDirective.prototype, "target", {
/**
* Gets the target of the navigation directive;
*
* ```typescript
* // Get
* export class MyComponent {
* ...
* @ContentChild(IgxDropDownNavigationDirective)
* navDirective: IgxDropDownNavigationDirective = null
* ...
* const navTarget: IgxDropDownBase = navDirective.navTarget
* }
* ```
*/
get: /**
* Gets the target of the navigation directive;
*
* ```typescript
* // Get
* export class MyComponent {
* ...
* \@ContentChild(IgxDropDownNavigationDirective)
* navDirective: IgxDropDownNavigationDirective = null
* ...
* const navTarget: IgxDropDownBase = navDirective.navTarget
* }
* ```
* @return {?}
*/
function () {
return this._target;
},
/**
* Sets the target of the navigation directive;
* If no valid target is passed, it falls back to the drop down context
*
* ```html
* <!-- Set -->
* <input [igxDropDownItemNavigation]="dropdown" />
* ...
* <igx-drop-down #dropdown>
* ...
* </igx-drop-down>
* ```
*/
set: /**
* Sets the target of the navigation directive;
* If no valid target is passed, it falls back to the drop down context
*
* ```html
* <!-- Set -->
* <input [igxDropDownItemNavigation]="dropdown" />
* ...
* <igx-drop-down #dropdown>
* ...
* </igx-drop-down>
* ```
* @param {?} target
* @return {?}
*/
function (target) {
this._target = target ? target : this.dropdown;
},
enumerable: true,
configurable: true
});
/**
* Captures keydown events and calls the appropriate handlers on the target component
*/
/**
* Captures keydown events and calls the appropriate handlers on the target component
* @param {?} event
* @return {?}
*/
IgxDropDownItemNavigationDirective.prototype.handleKeyDown = /**
* Captures keydown events and calls the appropriate handlers on the target component
* @param {?} event
* @return {?}
*/
function (event) {
if (event) {
/** @type {?} */
var key = event.key.toLowerCase();
if (!this.target.collapsed) { // If dropdown is opened
// If dropdown is opened
/** @type {?} */
var navKeys = ['esc', 'escape', 'enter', 'space', 'spacebar', ' ',
'arrowup', 'up', 'arrowdown', 'down', 'home', 'end'];
if (navKeys.indexOf(key) === -1) { // If key has appropriate function in DD
return;
}
event.preventDefault();
event.stopPropagation();
}
else { // If dropdown is closed, do nothing
return;
}
switch (key) {
case 'esc':
case 'escape':
this.target.onItemActionKey(DropDownActionKey.ESCAPE, event);
break;
case 'enter':
this.target.onItemActionKey(DropDownActionKey.ENTER, event);
break;
case 'space':
case 'spacebar':
case ' ':
this.target.onItemActionKey(DropDownActionKey.SPACE, event);
break;
case 'arrowup':
case 'up':
this.onArrowUpKeyDown();
break;
case 'arrowdown':
case 'down':
this.onArrowDownKeyDown();
break;
case 'home':
this.onHomeKeyDown();
break;
case 'end':
this.onEndKeyDown();
break;
default:
return;
}
}
};
/**
* Navigates to previous item
*/
/**
* Navigates to previous item
* @return {?}
*/
IgxDropDownItemNavigationDirective.prototype.onArrowDownKeyDown = /**
* Navigates to previous item
* @return {?}
*/
function () {
this.target.navigateNext();
};
/**
* Navigates to previous item
*/
/**
* Navigates to previous item
* @return {?}
*/
IgxDropDownItemNavigationDirective.prototype.onArrowUpKeyDown = /**
* Navigates to previous item
* @return {?}
*/
function () {
this.target.navigatePrev();
};
/**
* Navigates to target's last item
*/
/**
* Navigates to target's last item
* @return {?}
*/
IgxDropDownItemNavigationDirective.prototype.onEndKeyDown = /**
* Navigates to target's last item
* @return {?}
*/
function () {
this.target.navigateLast();
};
/**
* Navigates to target's first item
*/
/**
* Navigates to target's first item
* @return {?}
*/
IgxDropDownItemNavigationDirective.prototype.onHomeKeyDown = /**
* Navigates to target's first item
* @return {?}
*/
function () {
this.target.navigateFirst();
};
IgxDropDownItemNavigationDirective.decorators = [
{ type: Directive, args: [{
selector: '[igxDropDownItemNavigation]'
},] }
];
/** @nocollapse */
IgxDropDownItemNavigationDirective.ctorParameters = function () { return [
{ type: IgxDropDownBase, decorators: [{ type: Self }, { type: Optional }, { type: Inject, args: [IGX_DROPDOWN_BASE,] }] }
]; };
IgxDropDownItemNavigationDirective.propDecorators = {
target: [{ type: Input, args: ['igxDropDownItemNavigation',] }],
handleKeyDown: [{ type: HostListener, args: ['keydown', ['$event'],] }]
};
return IgxDropDownItemNavigationDirective;
}());
export { IgxDropDownItemNavigationDirective };
if (false) {
/**
* @type {?}
* @protected
*/
IgxDropDownItemNavigationDirective.prototype._target;
/** @type {?} */
IgxDropDownItemNavigationDirective.prototype.dropdown;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-down-navigation.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/drop-down/drop-down-navigation.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvF,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAEvD,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACnD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;;;;AAKvD;IAOI,4CAAkE,QAAyB;QAAzB,aAAQ,GAAR,QAAQ,CAAiB;QAFjF,YAAO,GAAoB,IAAI,CAAC;IAEqD,CAAC;IAgBhG,sBAAI,sDAAM;QAdV;;;;;;;;;;;;;WAaG;;;;;;;;;;;;;;;;QACH;YACI,OAAO,IAAI,CAAC,OAAO,CAAC;QACxB,CAAC;QAED;;;;;;;;;;;;WAYG;;;;;;;;;;;;;;;;QACH,UACW,MAAuB;YAC9B,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;QACnD,CAAC;;;OAlBA;IAoBD;;OAEG;;;;;;IAEH,0DAAa;;;;;IADb,UACc,KAAoB;QAC9B,IAAI,KAAK,EAAE;;gBACD,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,WAAW,EAAE;YACnC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,EAAE,wBAAwB;;;oBAC5C,OAAO,GAAG,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG;oBACvE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC;gBAChD,IAAI,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,wCAAwC;oBACvE,OAAO;iBACV;gBACD,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;aAC3B;iBAAM,EAAE,oCAAoC;gBACzC,OAAO;aACV;YACD,QAAQ,GAAG,EAAE;gBACT,KAAK,KAAK,CAAC;gBACX,KAAK,QAAQ;oBACT,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,iBAAiB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;oBAC7D,MAAM;gBACV,KAAK,OAAO;oBACR,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;oBAC5D,MAAM;gBACV,KAAK,OAAO,CAAC;gBACb,KAAK,UAAU,CAAC;gBAChB,KAAK,GAAG;oBACJ,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,iBAAiB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;oBAC5D,MAAM;gBACV,KAAK,SAAS,CAAC;gBACf,KAAK,IAAI;oBACL,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBACxB,MAAM;gBACV,KAAK,WAAW,CAAC;gBACjB,KAAK,MAAM;oBACP,IAAI,CAAC,kBAAkB,EAAE,CAAC;oBAC1B,MAAM;gBACV,KAAK,MAAM;oBACP,IAAI,CAAC,aAAa,EAAE,CAAC;oBACrB,MAAM;gBACV,KAAK,KAAK;oBACN,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,MAAM;gBACV;oBACI,OAAO;aACd;SACJ;IACL,CAAC;IAED;;OAEG;;;;;IACH,+DAAkB;;;;IAAlB;QACI,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IAC/B,CAAC;IAED;;OAEG;;;;;IACH,6DAAgB;;;;IAAhB;QACI,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IAC/B,CAAC;IAED;;OAEG;;;;;IACH,yDAAY;;;;IAAZ;QACI,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IAC/B,CAAC;IAED;;OAEG;;;;;IACH,0DAAa;;;;IAAb;QACI,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC;IAChC,CAAC;;gBA1HJ,SAAS,SAAC;oBACP,QAAQ,EAAE,6BAA6B;iBAC1C;;;;gBARQ,eAAe,uBAaP,IAAI,YAAI,QAAQ,YAAI,MAAM,SAAC,iBAAiB;;;yBAiCxD,KAAK,SAAC,2BAA2B;gCAQjC,YAAY,SAAC,SAAS,EAAE,CAAC,QAAQ,CAAC;;IA2EvC,yCAAC;CAAA,AA3HD,IA2HC;SAxHY,kCAAkC;;;;;;IAE3C,qDAA0C;;IAE9B,sDAA+E","sourcesContent":["import { Directive, Optional, Self, Input, HostListener, Inject } from '@angular/core';\nimport { IGX_DROPDOWN_BASE } from './drop-down.common';\nimport { IDropDownNavigationDirective } from './drop-down.common';\nimport { IgxDropDownBase } from './drop-down.base';\nimport { DropDownActionKey } from './drop-down.common';\n\n/**\n * Navigation Directive that handles keyboard events on its host and controls a targeted IgxDropDownBase component\n */\n@Directive({\n    selector: '[igxDropDownItemNavigation]'\n})\nexport class IgxDropDownItemNavigationDirective implements IDropDownNavigationDirective {\n\n    protected _target: IgxDropDownBase = null;\n\n    constructor(@Self() @Optional() @Inject(IGX_DROPDOWN_BASE) public dropdown: IgxDropDownBase) { }\n\n    /**\n     * Gets the target of the navigation directive;\n     *\n     * ```typescript\n     * // Get\n     * export class MyComponent {\n     *  ...\n     *  @ContentChild(IgxDropDownNavigationDirective)\n     *  navDirective: IgxDropDownNavigationDirective = null\n     *  ...\n     *  const navTarget: IgxDropDownBase = navDirective.navTarget\n     * }\n     * ```\n     */\n    get target(): IgxDropDownBase {\n        return this._target;\n    }\n\n    /**\n     * Sets the target of the navigation directive;\n     * If no valid target is passed, it falls back to the drop down context\n     *\n     * ```html\n     * <!-- Set -->\n     * <input [igxDropDownItemNavigation]=\"dropdown\" />\n     * ...\n     * <igx-drop-down #dropdown>\n     * ...\n     * </igx-drop-down>\n     * ```\n     */\n    @Input('igxDropDownItemNavigation')\n    set target(target: IgxDropDownBase) {\n        this._target = target ? target : this.dropdown;\n    }\n\n    /**\n     * Captures keydown events and calls the appropriate handlers on the target component\n     */\n    @HostListener('keydown', ['$event'])\n    handleKeyDown(event: KeyboardEvent) {\n        if (event) {\n            const key = event.key.toLowerCase();\n            if (!this.target.collapsed) { // If dropdown is opened\n                const navKeys = ['esc', 'escape', 'enter', 'space', 'spacebar', ' ',\n            'arrowup', 'up', 'arrowdown', 'down', 'home', 'end'];\n                if (navKeys.indexOf(key) === -1) { // If key has appropriate function in DD\n                    return;\n                }\n                event.preventDefault();\n                event.stopPropagation();\n            } else { // If dropdown is closed, do nothing\n                return;\n            }\n            switch (key) {\n                case 'esc':\n                case 'escape':\n                    this.target.onItemActionKey(DropDownActionKey.ESCAPE, event);\n                    break;\n                case 'enter':\n                    this.target.onItemActionKey(DropDownActionKey.ENTER, event);\n                    break;\n                case 'space':\n                case 'spacebar':\n                case ' ':\n                    this.target.onItemActionKey(DropDownActionKey.SPACE, event);\n                    break;\n                case 'arrowup':\n                case 'up':\n                    this.onArrowUpKeyDown();\n                    break;\n                case 'arrowdown':\n                case 'down':\n                    this.onArrowDownKeyDown();\n                    break;\n                case 'home':\n                    this.onHomeKeyDown();\n                    break;\n                case 'end':\n                    this.onEndKeyDown();\n                    break;\n                default:\n                    return;\n            }\n        }\n    }\n\n    /**\n     * Navigates to previous item\n     */\n    onArrowDownKeyDown() {\n        this.target.navigateNext();\n    }\n\n    /**\n     * Navigates to previous item\n     */\n    onArrowUpKeyDown() {\n        this.target.navigatePrev();\n    }\n\n    /**\n     * Navigates to target's last item\n     */\n    onEndKeyDown() {\n        this.target.navigateLast();\n    }\n\n    /**\n     * Navigates to target's first item\n     */\n    onHomeKeyDown() {\n        this.target.navigateFirst();\n    }\n}\n"]}