UNPKG

@catull/igniteui-angular

Version:

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

198 lines 28.6 kB
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"]}