igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
172 lines • 13.8 kB
JavaScript
/**
* @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"]}