UNPKG

igniteui-angular

Version:

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

140 lines • 14.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { IgxDropDownItemNavigationDirective } from '../drop-down/drop-down-navigation.directive'; import { Directive, Input, HostListener } from '@angular/core'; import { Subscription, timer } from 'rxjs'; /** * @hidden \@internal */ export class IgxSelectItemNavigationDirective extends IgxDropDownItemNavigationDirective { constructor() { super(null); // tslint:disable:member-ordering this.inputStream = ''; this.clearStream$ = Subscription.EMPTY; } /** * Captures keydown events and calls the appropriate handlers on the target component * @param {?} event * @return {?} */ handleKeyDown(event) { if (!event || event.shiftKey) { return; } /** @type {?} */ const key = event.key.toLowerCase(); if (event.altKey && (key === 'arrowdown' || key === 'arrowup' || key === 'down' || key === 'up')) { this.target.toggle(); return; } if (this.target.collapsed) { switch (key) { case 'space': case 'spacebar': case ' ': case 'enter': event.preventDefault(); this.target.open(); return; case 'arrowdown': case 'down': this.target.navigateNext(); this.target.selectItem(this.target.focusedItem); event.preventDefault(); return; case 'arrowup': case 'up': this.target.navigatePrev(); this.target.selectItem(this.target.focusedItem); event.preventDefault(); return; default: break; } } super.handleKeyDown(event); } /** * Handle continuous letter typing navigation * @param {?} event * @return {?} */ captureKey(event) { // relying only on key, available on all major browsers: // https://caniuse.com/#feat=keyboardevent-key (IE/Edge quirk doesn't affect letter typing) if (!event || !event.key || event.key.length > 1) { // ignore longer keys ('Alt', 'ArrowDown', etc) return; } this.clearStream$.unsubscribe(); this.clearStream$ = timer(500).subscribe(() => { this.inputStream = ''; }); this.inputStream += event.key; /** @type {?} */ const focusedItem = (/** @type {?} */ (this.target.focusedItem)); // select the item if (focusedItem && this.inputStream.length > 1 && focusedItem.itemText.toLowerCase().startsWith(this.inputStream.toLowerCase())) { return; } this.activateItemByText(this.inputStream); } /** * @param {?} text * @return {?} */ activateItemByText(text) { /** @type {?} */ const items = (/** @type {?} */ (this.target.items)); /** @type {?} */ const activeItemIndex = items.indexOf((/** @type {?} */ (this.target.focusedItem))) || 0; // ^ this is focused OR selected if the dd is closed /** @type {?} */ let nextItem = items.slice(activeItemIndex + 1).find(x => !x.disabled && (x.itemText.toLowerCase().startsWith(text.toLowerCase()))); if (!nextItem) { nextItem = items.slice(0, activeItemIndex).find(x => !x.disabled && (x.itemText.toLowerCase().startsWith(text.toLowerCase()))); } if (!nextItem) { return; } if (this.target.collapsed) { this.target.selectItem(nextItem); } this.target.navigateItem(items.indexOf(nextItem)); } /** * @return {?} */ ngOnDestroy() { this.clearStream$.unsubscribe(); } } IgxSelectItemNavigationDirective.decorators = [ { type: Directive, args: [{ selector: '[igxSelectItemNavigation]' },] } ]; /** @nocollapse */ IgxSelectItemNavigationDirective.ctorParameters = () => []; IgxSelectItemNavigationDirective.propDecorators = { target: [{ type: Input, args: ['igxSelectItemNavigation',] }], captureKey: [{ type: HostListener, args: ['keyup', ['$event'],] }] }; if (false) { /** @type {?} */ IgxSelectItemNavigationDirective.prototype.target; /** * @type {?} * @private */ IgxSelectItemNavigationDirective.prototype.inputStream; /** * @type {?} * @private */ IgxSelectItemNavigationDirective.prototype.clearStream$; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-navigation.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/select/select-navigation.directive.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,kCAAkC,EAAE,MAAM,6CAA6C,CAAC;AACjG,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,YAAY,EAAa,MAAM,eAAe,CAAC;AAC1E,OAAO,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;;;;AAQ3C,MAAM,OAAO,gCAAiC,SAAQ,kCAAkC;IAKpF;QAAgB,KAAK,CAAC,IAAI,CAAC,CAAC;;QA4CpB,gBAAW,GAAG,EAAE,CAAC;QACjB,iBAAY,GAAG,YAAY,CAAC,KAAK,CAAC;IA7Cb,CAAC;;;;;;IAG9B,aAAa,CAAC,KAAoB;QAC9B,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,QAAQ,EAAE;YAC1B,OAAO;SACV;;cAEK,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,WAAW,EAAE;QACnC,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC,GAAG,KAAK,WAAW,IAAI,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,MAAM,IAAI,GAAG,KAAK,IAAI,CAAC,EAAE;YAC9F,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC;YACrB,OAAO;SACV;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;YACvB,QAAQ,GAAG,EAAE;gBACT,KAAK,OAAO,CAAC;gBACb,KAAK,UAAU,CAAC;gBAChB,KAAK,GAAG,CAAC;gBACT,KAAK,OAAO;oBACR,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;oBACnB,OAAO;gBACX,KAAK,WAAW,CAAC;gBACjB,KAAK,MAAM;oBACP,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;oBAC3B,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;oBAChD,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,OAAO;gBACX,KAAK,SAAS,CAAC;gBACf,KAAK,IAAI;oBACL,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;oBAC3B,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;oBAChD,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,OAAO;gBACX;oBACI,MAAM;aACb;SACJ;QAED,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;;;;;;IAQM,UAAU,CAAC,KAAoB;QAClC,wDAAwD;QACxD,2FAA2F;QAC3F,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,GAAG,IAAI,KAAK,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9C,+CAA+C;YAC/C,OAAO;SACV;QAED,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC1C,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,IAAI,KAAK,CAAC,GAAG,CAAC;;cACxB,WAAW,GAAG,mBAAA,IAAI,CAAC,MAAM,CAAC,WAAW,EAA0B;QAErE,kBAAkB;QAClB,IAAI,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,GAAG,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,EAAE;YAC7H,OAAO;SACV;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IAC9C,CAAC;;;;;IAEM,kBAAkB,CAAC,IAAY;;cAC5B,KAAK,GAAG,mBAAA,IAAI,CAAC,MAAM,CAAC,KAAK,EAA4B;;cACrD,eAAe,GAAG,KAAK,CAAC,OAAO,CAAC,mBAAA,IAAI,CAAC,MAAM,CAAC,WAAW,EAA0B,CAAC,IAAI,CAAC;;;YAEzF,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,eAAe,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;QAEnI,IAAI,CAAC,QAAQ,EAAE;YACX,QAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,eAAe,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC;SAClI;QAED,IAAI,CAAC,QAAQ,EAAE;YACX,OAAO;SACV;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;YACvB,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;SACpC;QACD,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;IACtD,CAAC;;;;IAED,WAAW;QACP,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;IACpC,CAAC;;;YArGJ,SAAS,SAAC;gBACP,QAAQ,EAAE,2BAA2B;aACxC;;;;;qBAGI,KAAK,SAAC,yBAAyB;yBAmD/B,YAAY,SAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;;;;IAnDjC,kDAC6B;;;;;IA8C7B,uDAAyB;;;;;IACzB,wDAA0C","sourcesContent":["import { IgxDropDownItemNavigationDirective } from '../drop-down/drop-down-navigation.directive';\nimport { Directive, Input, HostListener, OnDestroy } from '@angular/core';\nimport { Subscription, timer } from 'rxjs';\nimport { IgxSelectItemComponent } from './select-item.component';\nimport { IgxSelectBase } from './select.common';\n\n/** @hidden @internal */\n@Directive({\n    selector: '[igxSelectItemNavigation]'\n})\nexport class IgxSelectItemNavigationDirective extends IgxDropDownItemNavigationDirective implements OnDestroy {\n\n    @Input('igxSelectItemNavigation')\n    public target: IgxSelectBase;\n\n    constructor() { super(null); }\n\n    /** Captures keydown events and calls the appropriate handlers on the target component */\n    handleKeyDown(event: KeyboardEvent) {\n        if (!event || event.shiftKey) {\n            return;\n        }\n\n        const key = event.key.toLowerCase();\n        if (event.altKey && (key === 'arrowdown' || key === 'arrowup' || key === 'down' || key === 'up')) {\n            this.target.toggle();\n            return;\n        }\n\n        if (this.target.collapsed) {\n            switch (key) {\n                case 'space':\n                case 'spacebar':\n                case ' ':\n                case 'enter':\n                    event.preventDefault();\n                    this.target.open();\n                    return;\n                case 'arrowdown':\n                case 'down':\n                    this.target.navigateNext();\n                    this.target.selectItem(this.target.focusedItem);\n                    event.preventDefault();\n                    return;\n                case 'arrowup':\n                case 'up':\n                    this.target.navigatePrev();\n                    this.target.selectItem(this.target.focusedItem);\n                    event.preventDefault();\n                    return;\n                default:\n                    break;\n            }\n        }\n\n        super.handleKeyDown(event);\n    }\n\n    // tslint:disable:member-ordering\n    private inputStream = '';\n    private clearStream$ = Subscription.EMPTY;\n\n    /** Handle continuous letter typing navigation */\n    @HostListener('keyup', ['$event'])\n    public captureKey(event: KeyboardEvent) {\n        // relying only on key, available on all major browsers:\n        // https://caniuse.com/#feat=keyboardevent-key (IE/Edge quirk doesn't affect letter typing)\n        if (!event || !event.key || event.key.length > 1) {\n            // ignore longer keys ('Alt', 'ArrowDown', etc)\n            return;\n        }\n\n        this.clearStream$.unsubscribe();\n        this.clearStream$ = timer(500).subscribe(() => {\n            this.inputStream = '';\n        });\n        this.inputStream += event.key;\n        const focusedItem = this.target.focusedItem as IgxSelectItemComponent;\n\n        // select the item\n        if (focusedItem && this.inputStream.length > 1 && focusedItem.itemText.toLowerCase().startsWith(this.inputStream.toLowerCase())) {\n            return;\n        }\n        this.activateItemByText(this.inputStream);\n    }\n\n    public activateItemByText(text: string) {\n        const items = this.target.items as IgxSelectItemComponent[];\n        const activeItemIndex = items.indexOf(this.target.focusedItem as IgxSelectItemComponent) || 0;\n        // ^ this is focused OR selected if the dd is closed\n        let nextItem = items.slice(activeItemIndex + 1).find(x => !x.disabled && (x.itemText.toLowerCase().startsWith(text.toLowerCase())));\n\n        if (!nextItem) {\n            nextItem = items.slice(0, activeItemIndex).find(x => !x.disabled && (x.itemText.toLowerCase().startsWith(text.toLowerCase())));\n        }\n\n        if (!nextItem) {\n            return;\n        }\n\n        if (this.target.collapsed) {\n            this.target.selectItem(nextItem);\n        }\n        this.target.navigateItem(items.indexOf(nextItem));\n    }\n\n    ngOnDestroy(): void {\n        this.clearStream$.unsubscribe();\n    }\n}\n"]}