@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
198 lines • 28.6 kB
JavaScript
import { __decorate, __metadata, __read, __spread } from "tslib";
import { Injectable, NgZone } from '@angular/core';
/**
* @hidden
* @internal
*/
var IgxColumnResizingService = /** @class */ (function () {
function IgxColumnResizingService(zone) {
this.zone = zone;
/**
*@hidden
*/
this.resizeCursor = null;
/**
*@hidden
*/
this.showResizer = false;
}
Object.defineProperty(IgxColumnResizingService.prototype, "resizerHeight", {
/**
*@hidden
*/
get: function () {
var height = this.column.grid.getVisibleContentHeight();
// Column height multiplier in case there are Column Layouts. The resizer height need to take into account rowStart.
var columnHeightMultiplier = 1;
if (this.column.columnLayoutChild) {
columnHeightMultiplier = this.column.grid.multiRowLayoutRowSize - this.column.rowStart + 1;
}
if (this.column.level !== 0) {
height -= this.column.topLevelParent.headerGroup.height - this.column.headerGroup.height * columnHeightMultiplier;
}
return height;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnResizingService.prototype, "restrictResizeMin", {
/**
* Returns the minimal possible width to which the column can be resized.
*/
get: function () {
var actualMinWidth = parseFloat(this.column.minWidth);
var minWidth = actualMinWidth < parseFloat(this.column.width) ? actualMinWidth : parseFloat(this.column.width);
return this.column.headerCell.elementRef.nativeElement.getBoundingClientRect().width - minWidth;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxColumnResizingService.prototype, "restrictResizeMax", {
/**
* Returns the maximal possible width to which the column can be resized.
*/
get: function () {
var actualWidth = this.column.headerCell.elementRef.nativeElement.getBoundingClientRect().width;
if (this.column.maxWidth) {
return parseFloat(this.column.maxWidth) - actualWidth;
}
else {
return Number.MAX_SAFE_INTEGER;
}
},
enumerable: true,
configurable: true
});
/**
* Autosizes the column to the longest currently visible cell value, including the header cell.
* If the column has a predifined maxWidth and the autosized column width will become bigger than it,
* then the column is sized to its maxWidth.
* If the column is pinned and the autosized column width will cause the pinned area to become bigger
* than the maximum allowed pinned area width (80% of the total grid width), autosizing will be deismissed.
*/
IgxColumnResizingService.prototype.autosizeColumnOnDblClick = function () {
var currentColWidth = this.column.headerCell.elementRef.nativeElement.getBoundingClientRect().width;
var size = this.column.getLargestCellWidth();
if (this.column.maxWidth && (parseFloat(size) > parseFloat(this.column.maxWidth))) {
this.column.width = parseFloat(this.column.maxWidth) + 'px';
}
else if (parseFloat(size) < parseFloat(this.column.minWidth)) {
this.column.width = this.column.minWidth + 'px';
}
else {
this.column.width = size;
}
this.zone.run(function () { });
this.column.grid.onColumnResized.emit({
column: this.column,
prevWidth: currentColWidth.toString(),
newWidth: this.column.width
});
};
/**
* Resizes the column regaridng to the column minWidth and maxWidth.
*/
IgxColumnResizingService.prototype.resizeColumn = function (event) {
this.showResizer = false;
var diff = event.clientX - this.startResizePos;
var currentColWidth = parseFloat(this.column.width);
var actualWidth = this.column.headerCell.elementRef.nativeElement.getBoundingClientRect().width;
currentColWidth = Number.isNaN(currentColWidth) || (currentColWidth < actualWidth) ? actualWidth : currentColWidth;
var colMinWidth = this.getColMinWidth(this.column);
var colMaxWidth = this.getColMaxWidth(this.column);
if (this.column.grid.hasColumnLayouts) {
this.resizeColumnLayoutFor(this.column, diff);
}
else {
if (currentColWidth + diff < colMinWidth) {
this.column.width = colMinWidth + 'px';
}
else if (colMaxWidth && (currentColWidth + diff > colMaxWidth)) {
this.column.width = colMaxWidth + 'px';
}
else {
this.column.width = (currentColWidth + diff) + 'px';
}
}
this.zone.run(function () { });
if (currentColWidth !== parseFloat(this.column.width)) {
this.column.grid.onColumnResized.emit({
column: this.column,
prevWidth: currentColWidth.toString(),
newWidth: this.column.width
});
}
this.isColumnResizing = false;
};
IgxColumnResizingService.prototype.getColMinWidth = function (column) {
var currentColWidth = parseFloat(column.width);
var actualWidth = column.headerCell.elementRef.nativeElement.getBoundingClientRect().width;
currentColWidth = Number.isNaN(currentColWidth) || (currentColWidth < actualWidth) ? actualWidth : currentColWidth;
var actualMinWidth = parseFloat(column.minWidth);
return actualMinWidth < currentColWidth ? actualMinWidth : currentColWidth;
};
IgxColumnResizingService.prototype.getColMaxWidth = function (column) {
return column.pinned ? parseFloat(this.pinnedMaxWidth) : parseFloat(column.maxWidth);
};
IgxColumnResizingService.prototype.resizeColumnLayoutFor = function (column, diff) {
var _this = this;
var relativeColumns = column.getResizableColUnderEnd();
var combinedSpan = relativeColumns.reduce(function (acc, col) { return acc + col.spanUsed; }, 0);
// Resize first those who might reach min/max width
var columnsToResize = __spread(relativeColumns);
var updatedDiff = diff;
var updatedCombinedSpan = combinedSpan;
var setMinMaxCols = false;
var _loop_1 = function () {
// Cycle them until there are not ones that reach min/max size, because the diff accumulates after each cycle.
// This is because we can have at first 2 cols reaching min width and then after
// recalculating the diff there might be 1 more that reaches min width.
setMinMaxCols = false;
var newCombinedSpan = updatedCombinedSpan;
var newColsToResize = [];
columnsToResize.forEach(function (col) {
var currentResizeWidth = parseFloat(col.target.calcWidth);
var resizeScaled = (diff / updatedCombinedSpan) * col.target.gridColumnSpan;
var minWidth = _this.getColMinWidth(col.target);
var maxWidth = _this.getColMaxWidth(col.target);
if (currentResizeWidth + resizeScaled < minWidth) {
col.target.width = minWidth + 'px';
updatedDiff += (currentResizeWidth - minWidth);
newCombinedSpan -= col.spanUsed;
setMinMaxCols = true;
}
else if (maxWidth && (currentResizeWidth + resizeScaled > maxWidth)) {
col.target.width = maxWidth + 'px';
updatedDiff -= (maxWidth - currentResizeWidth);
newCombinedSpan -= col.spanUsed;
setMinMaxCols = true;
}
else {
// Save new ones that can be resized
newColsToResize.push(col);
}
});
updatedCombinedSpan = newCombinedSpan;
columnsToResize = newColsToResize;
};
do {
_loop_1();
} while (setMinMaxCols);
// Those left that don't reach min/max size resize them normally.
columnsToResize.forEach(function (col) {
var currentResizeWidth = parseFloat(col.target.calcWidth);
var resizeScaled = (updatedDiff / updatedCombinedSpan) * col.target.gridColumnSpan;
col.target.width = (currentResizeWidth + resizeScaled) + 'px';
});
};
IgxColumnResizingService.ctorParameters = function () { return [
{ type: NgZone }
]; };
IgxColumnResizingService = __decorate([
Injectable(),
__metadata("design:paramtypes", [NgZone])
], IgxColumnResizingService);
return IgxColumnResizingService;
}());
export { IgxColumnResizingService };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizing.service.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/resizing/resizing.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { IgxColumnComponent } from '../columns/column.component';\n\n/**\n * @hidden\n * @internal\n */\n@Injectable()\nexport class IgxColumnResizingService {\n\n    private pinnedMaxWidth: string;\n\n    /**\n     *@hidden\n     */\n    public startResizePos: number;\n    /**\n     * Indicates that a column is currently being resized.\n     */\n    public isColumnResizing: boolean;\n    /**\n     *@hidden\n     */\n    public resizeCursor: string = null;\n    /**\n     *@hidden\n     */\n    public showResizer = false;\n    /**\n     * The column being resized.\n     */\n    public column: IgxColumnComponent;\n\n    constructor(private zone: NgZone) { }\n\n    /**\n     *@hidden\n     */\n    get resizerHeight(): number {\n        let height = this.column.grid.getVisibleContentHeight();\n\n        // Column height multiplier in case there are Column Layouts. The resizer height need to take into account rowStart.\n        let columnHeightMultiplier = 1;\n        if (this.column.columnLayoutChild) {\n            columnHeightMultiplier = this.column.grid.multiRowLayoutRowSize - this.column.rowStart + 1;\n        }\n\n        if (this.column.level !== 0) {\n            height -= this.column.topLevelParent.headerGroup.height - this.column.headerGroup.height * columnHeightMultiplier;\n        }\n\n        return height;\n    }\n\n    /**\n     * Returns the minimal possible width to which the column can be resized.\n     */\n    get restrictResizeMin(): number {\n        const actualMinWidth = parseFloat(this.column.minWidth);\n        const minWidth = actualMinWidth < parseFloat(this.column.width) ? actualMinWidth : parseFloat(this.column.width);\n\n        return this.column.headerCell.elementRef.nativeElement.getBoundingClientRect().width - minWidth;\n    }\n\n    /**\n     * Returns the maximal possible width to which the column can be resized.\n     */\n    get restrictResizeMax(): number {\n        const actualWidth = this.column.headerCell.elementRef.nativeElement.getBoundingClientRect().width;\n        if (this.column.maxWidth) {\n            return parseFloat(this.column.maxWidth) - actualWidth;\n        } else {\n            return Number.MAX_SAFE_INTEGER;\n        }\n    }\n\n    /**\n     * Autosizes the column to the longest currently visible cell value, including the header cell.\n     * If the column has a predifined maxWidth and the autosized column width will become bigger than it,\n     * then the column is sized to its maxWidth.\n     * If the column is pinned and the autosized column width will cause the pinned area to become bigger\n     * than the maximum allowed pinned area width (80% of the total grid width), autosizing will be deismissed.\n     */\n    public autosizeColumnOnDblClick() {\n        const currentColWidth = this.column.headerCell.elementRef.nativeElement.getBoundingClientRect().width;\n\n        const size = this.column.getLargestCellWidth();\n        if (this.column.maxWidth && (parseFloat(size) > parseFloat(this.column.maxWidth))) {\n            this.column.width = parseFloat(this.column.maxWidth) + 'px';\n        } else if (parseFloat(size) < parseFloat(this.column.minWidth)) {\n            this.column.width = this.column.minWidth + 'px';\n        } else {\n            this.column.width = size;\n        }\n\n        this.zone.run(() => {});\n\n        this.column.grid.onColumnResized.emit({\n            column: this.column,\n            prevWidth: currentColWidth.toString(),\n            newWidth: this.column.width\n        });\n    }\n\n    /**\n     * Resizes the column regaridng to the column minWidth and maxWidth.\n     */\n    public resizeColumn(event: MouseEvent) {\n        this.showResizer = false;\n        const diff = event.clientX - this.startResizePos;\n\n        let currentColWidth = parseFloat(this.column.width);\n        const actualWidth = this.column.headerCell.elementRef.nativeElement.getBoundingClientRect().width;\n        currentColWidth = Number.isNaN(currentColWidth) || (currentColWidth < actualWidth) ? actualWidth : currentColWidth;\n\n        const colMinWidth = this.getColMinWidth(this.column);\n        const colMaxWidth = this.getColMaxWidth(this.column);\n        if (this.column.grid.hasColumnLayouts) {\n            this.resizeColumnLayoutFor(this.column, diff);\n        } else {\n            if (currentColWidth + diff < colMinWidth) {\n                this.column.width = colMinWidth + 'px';\n            } else if (colMaxWidth && (currentColWidth + diff > colMaxWidth)) {\n                this.column.width = colMaxWidth + 'px';\n            } else {\n                this.column.width = (currentColWidth + diff) + 'px';\n            }\n        }\n\n        this.zone.run(() => {});\n\n        if (currentColWidth !== parseFloat(this.column.width)) {\n            this.column.grid.onColumnResized.emit({\n                column: this.column,\n                prevWidth: currentColWidth.toString(),\n                newWidth: this.column.width\n            });\n        }\n\n        this.isColumnResizing = false;\n    }\n\n    protected getColMinWidth(column: IgxColumnComponent) {\n        let currentColWidth = parseFloat(column.width);\n        const actualWidth = column.headerCell.elementRef.nativeElement.getBoundingClientRect().width;\n        currentColWidth = Number.isNaN(currentColWidth) || (currentColWidth < actualWidth) ? actualWidth : currentColWidth;\n\n        const actualMinWidth = parseFloat(column.minWidth);\n        return actualMinWidth < currentColWidth ? actualMinWidth : currentColWidth;\n    }\n\n    protected getColMaxWidth(column: IgxColumnComponent) {\n        return column.pinned ? parseFloat(this.pinnedMaxWidth) : parseFloat(column.maxWidth);\n    }\n\n    protected resizeColumnLayoutFor(column: IgxColumnComponent, diff: number) {\n        const relativeColumns = column.getResizableColUnderEnd();\n        const combinedSpan = relativeColumns.reduce((acc, col) =>  acc + col.spanUsed, 0);\n\n        // Resize first those who might reach min/max width\n        let columnsToResize = [...relativeColumns];\n        let updatedDiff = diff;\n        let updatedCombinedSpan = combinedSpan;\n        let setMinMaxCols = false;\n        do {\n            // Cycle them until there are not ones that reach min/max size, because the diff accumulates after each cycle.\n            // This is because we can have at first 2 cols reaching min width and then after\n            // recalculating the diff there might be 1 more that reaches min width.\n            setMinMaxCols = false;\n            let newCombinedSpan = updatedCombinedSpan;\n            const newColsToResize = [];\n            columnsToResize.forEach((col) => {\n                const currentResizeWidth = parseFloat(col.target.calcWidth);\n                const resizeScaled = (diff / updatedCombinedSpan) * col.target.gridColumnSpan;\n\n                const minWidth = this.getColMinWidth(col.target);\n                const maxWidth = this.getColMaxWidth(col.target);\n                if (currentResizeWidth + resizeScaled < minWidth) {\n                    col.target.width = minWidth + 'px';\n                    updatedDiff += (currentResizeWidth - minWidth);\n                    newCombinedSpan -= col.spanUsed;\n                    setMinMaxCols = true;\n                } else if (maxWidth && (currentResizeWidth + resizeScaled > maxWidth)) {\n                    col.target.width = maxWidth + 'px';\n                    updatedDiff -= (maxWidth - currentResizeWidth);\n                    newCombinedSpan -= col.spanUsed;\n                    setMinMaxCols = true;\n                } else {\n                    // Save new ones that can be resized\n                    newColsToResize.push(col);\n                }\n            });\n\n            updatedCombinedSpan = newCombinedSpan;\n            columnsToResize = newColsToResize;\n        } while (setMinMaxCols);\n\n        // Those left that don't reach min/max size resize them normally.\n        columnsToResize.forEach((col) => {\n            const currentResizeWidth = parseFloat(col.target.calcWidth);\n            const resizeScaled = (updatedDiff / updatedCombinedSpan) * col.target.gridColumnSpan;\n            col.target.width = (currentResizeWidth + resizeScaled) + 'px';\n        });\n    }\n}\n"]}