UNPKG

igniteui-angular

Version:

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

172 lines • 13.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Directive, ElementRef, forwardRef, HostListener, Inject } from '@angular/core'; import { IgxGridBaseComponent } from './grid-base.component'; import { first, tap } from 'rxjs/operators'; import { IgxGridNavigationService } from './grid-navigation.service'; /** * @hidden */ var IgxRowEditTemplateDirective = /** @class */ (function () { function IgxRowEditTemplateDirective() { } IgxRowEditTemplateDirective.decorators = [ { type: Directive, args: [{ selector: '[igxRowEdit]' },] } ]; return IgxRowEditTemplateDirective; }()); export { IgxRowEditTemplateDirective }; /** * @hidden */ var IgxRowEditTextDirective = /** @class */ (function () { function IgxRowEditTextDirective() { } IgxRowEditTextDirective.decorators = [ { type: Directive, args: [{ selector: '[igxRowEditText]' },] } ]; return IgxRowEditTextDirective; }()); export { IgxRowEditTextDirective }; /** * @hidden */ var IgxRowEditActionsDirective = /** @class */ (function () { function IgxRowEditActionsDirective() { } IgxRowEditActionsDirective.decorators = [ { type: Directive, args: [{ selector: '[igxRowEditActions]' },] } ]; return IgxRowEditActionsDirective; }()); export { IgxRowEditActionsDirective }; // TODO: Refactor circular ref, deps and logic /** * @hidden */ var IgxRowEditTabStopDirective = /** @class */ (function () { function IgxRowEditTabStopDirective(grid, element, navigationService) { this.element = element; this.grid = grid; this.navigationService = navigationService; this.navigationService.grid = grid; } Object.defineProperty(IgxRowEditTabStopDirective.prototype, "allTabs", { get: /** * @private * @return {?} */ function () { return this.grid.rowEditTabs; }, enumerable: true, configurable: true }); /** * @param {?} event * @return {?} */ IgxRowEditTabStopDirective.prototype.handleTab = /** * @param {?} event * @return {?} */ function (event) { event.stopPropagation(); if (this.allTabs.length > 1) { if ((this.allTabs.last === this && !event.shiftKey) || (this.allTabs.first === this && event.shiftKey)) { this.move(event); } } else { this.move(event); } }; /** * @private * @param {?} rowIndex * @param {?} cellIndex * @return {?} */ IgxRowEditTabStopDirective.prototype.focusNextCell = /** * @private * @param {?} rowIndex * @param {?} cellIndex * @return {?} */ function (rowIndex, cellIndex) { /** @type {?} */ var grid = (/** @type {?} */ (this.grid)); grid.parentVirtDir.onChunkLoad.pipe(first(), tap(function () { return grid.markForCheck(); })).subscribe(function () { grid.rowInEditMode.cells.find(function (c) { return c.visibleColumnIndex === cellIndex; }).element.nativeElement.focus(); }); }; /** * @private * @param {?} event * @return {?} */ IgxRowEditTabStopDirective.prototype.move = /** * @private * @param {?} event * @return {?} */ function (event) { event.preventDefault(); /** @type {?} */ var horizontalScroll = this.grid.parentVirtDir.getHorizontalScroll(); /** @type {?} */ var targetIndex = event.shiftKey ? this.grid.lastEditableColumnIndex : this.grid.firstEditableColumnIndex; /** @type {?} */ var targetCell = this.grid.rowInEditMode.cells.find(function (e) { return e.visibleColumnIndex === targetIndex; }); if (!targetCell || !this.navigationService.isColumnFullyVisible(targetIndex) || !this.navigationService.isColumnLeftFullyVisible(targetIndex)) { this.focusNextCell(this.grid.rowInEditMode.index, targetIndex); horizontalScroll.scrollLeft = this.grid.rowInEditMode.virtDirRow.getColumnScrollLeft(this.navigationService.getColumnUnpinnedIndex(targetIndex)); } else { targetCell.nativeElement.focus(); } }; IgxRowEditTabStopDirective.decorators = [ { type: Directive, args: [{ selector: "[igxRowEditTabStop]" },] } ]; /** @nocollapse */ IgxRowEditTabStopDirective.ctorParameters = function () { return [ { type: undefined, decorators: [{ type: Inject, args: [forwardRef(function () { return IgxGridBaseComponent; }),] }] }, { type: ElementRef }, { type: undefined, decorators: [{ type: Inject, args: [forwardRef(function () { return IgxGridNavigationService; }),] }] } ]; }; IgxRowEditTabStopDirective.propDecorators = { handleTab: [{ type: HostListener, args: ['keydown.Tab', ["$event"],] }, { type: HostListener, args: ['keydown.Shift.Tab', ["$event"],] }] }; return IgxRowEditTabStopDirective; }()); export { IgxRowEditTabStopDirective }; if (false) { /** * @type {?} * @private */ IgxRowEditTabStopDirective.prototype.grid; /** * @type {?} * @private */ IgxRowEditTabStopDirective.prototype.navigationService; /** @type {?} */ IgxRowEditTabStopDirective.prototype.element; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.rowEdit.directive.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/grid.rowEdit.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, forwardRef, HostListener, Inject, QueryList } from '@angular/core';\nimport { IgxGridBaseComponent } from './grid-base.component';\nimport { first, tap } from 'rxjs/operators';\nimport { IgxGridNavigationService } from './grid-navigation.service';\n\n/** @hidden */\n@Directive({\n    selector: '[igxRowEdit]'\n})\nexport class IgxRowEditTemplateDirective { }\n\n/** @hidden */\n@Directive({\n    selector: '[igxRowEditText]'\n})\nexport class IgxRowEditTextDirective { }\n\n/** @hidden */\n@Directive({\n    selector: '[igxRowEditActions]'\n})\nexport class IgxRowEditActionsDirective { }\n\n\n// TODO: Refactor circular ref, deps and logic\n/** @hidden */\n@Directive({\n    selector: `[igxRowEditTabStop]`\n})\nexport class IgxRowEditTabStopDirective {\n    private get allTabs(): QueryList<IgxRowEditTabStopDirective> {\n        return this.grid.rowEditTabs;\n    }\n\n    private grid: IgxGridBaseComponent;\n    private navigationService: IgxGridNavigationService;\n\n    constructor(\n        @Inject(forwardRef(() => IgxGridBaseComponent)) grid,\n        public element: ElementRef,\n        @Inject(forwardRef(() => IgxGridNavigationService)) navigationService) {\n            this.grid = grid;\n            this.navigationService = navigationService;\n            this.navigationService.grid = grid;\n        }\n    @HostListener('keydown.Tab', [`$event`])\n    @HostListener('keydown.Shift.Tab', [`$event`])\n    public handleTab(event: KeyboardEvent): void {\n        event.stopPropagation();\n        if (this.allTabs.length > 1) {\n            if ((this.allTabs.last ===  this && !event.shiftKey) ||\n                (this.allTabs.first ===  this && event.shiftKey)\n            ) {\n                this.move(event);\n            }\n        } else {\n            this.move(event);\n        }\n    }\n    private focusNextCell(rowIndex, cellIndex) {\n        const grid = this.grid as any;\n        grid.parentVirtDir.onChunkLoad.pipe(first(), tap(() => grid.markForCheck())).subscribe(() => {\n            grid.rowInEditMode.cells.find(c => c.visibleColumnIndex === cellIndex).element.nativeElement.focus();\n        });\n    }\n    private move(event: KeyboardEvent) {\n        event.preventDefault();\n        const horizontalScroll = this.grid.parentVirtDir.getHorizontalScroll();\n        const targetIndex = event.shiftKey ? this.grid.lastEditableColumnIndex : this.grid.firstEditableColumnIndex;\n        const targetCell = this.grid.rowInEditMode.cells.find(e => e.visibleColumnIndex === targetIndex);\n        if (!targetCell ||\n            !this.navigationService.isColumnFullyVisible(targetIndex)\n            || !this.navigationService.isColumnLeftFullyVisible(targetIndex)) {\n            this.focusNextCell(this.grid.rowInEditMode.index, targetIndex);\n            horizontalScroll.scrollLeft =\n            this.grid.rowInEditMode.virtDirRow.getColumnScrollLeft(this.navigationService.getColumnUnpinnedIndex(targetIndex));\n        } else {\n            targetCell.nativeElement.focus();\n        }\n    }\n}\n"]}