/* * (c) Copyright Ascensio System SIA 2010-2024 * * This program is a free software product. You can redistribute it and/or * modify it under the terms of the GNU Affero General Public License (AGPL) * version 3 as published by the Free Software Foundation. In accordance with * Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect * that Ascensio System SIA expressly excludes the warranty of non-infringement * of any third-party rights. * * This program is distributed WITHOUT ANY WARRANTY; without even the implied * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For * details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html * * You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish * street, Riga, Latvia, EU, LV-1050. * * The interactive user interfaces in modified source and object code versions * of the Program must display Appropriate Legal Notices, as required under * Section 5 of the GNU AGPL version 3. * * Pursuant to Section 7(b) of the License you must retain the original Product * logo when distributing the program. Pursuant to Section 7(e) we decline to * grant you any rights under trademark law for use of our trademarks. * * All the Product's GUI elements, including illustrations and icon sets, as * well as technical writing content are licensed under the terms of the * Creative Commons Attribution-ShareAlike 4.0 International. See the License * terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode * */ "use strict"; ( /** * @param {Window} window * @param {undefined} undefined */ function (window, undefined) { //----------------------------------------------------------------------------------- // Drawing area manager //----------------------------------------------------------------------------------- var sFrozenImageUrl = ''; var sFrozenImageRotUrl = ''; var SHADOW_LENGTH = 8; // Type var FrozenAreaType = { Top : "Top", Bottom : "Bottom", Left : "Left", Right : "Right", Center : "Center", // Default without frozen places LeftTop : "LeftTop", RightTop : "RightTop", LeftBottom : "LeftBottom", RightBottom : "RightBottom" }; // Frozen place function FrozenPlace(ws, type) { var log = false; var _this = this; var asc = window["Asc"]; var asc_Range = asc.Range; _this.worksheet = ws; _this.type = type; _this.range = null; _this.frozenCell = { col: _this.worksheet.topLeftFrozenCell ? _this.worksheet.topLeftFrozenCell.getCol0() : 0, row: _this.worksheet.topLeftFrozenCell ? _this.worksheet.topLeftFrozenCell.getRow0() : 0 }; _this.isValid = true; // Methods _this.initRange = function() { switch (_this.type) { case FrozenAreaType.Top: { if (!_this.frozenCell.col && _this.frozenCell.row) _this.range = new asc_Range(_this.worksheet.getFirstVisibleCol(), 0, _this.worksheet.getLastVisibleCol(), _this.frozenCell.row - 1); else _this.isValid = false; } break; case FrozenAreaType.Bottom: { if (!_this.frozenCell.col && _this.frozenCell.row) _this.range = new asc_Range(0, _this.worksheet.getFirstVisibleRow(), _this.worksheet.getLastVisibleCol(), _this.worksheet.getLastVisibleRow()); else _this.isValid = false; } break; case FrozenAreaType.Left: { if (_this.frozenCell.col && !_this.frozenCell.row) _this.range = new asc_Range(0, 0, _this.frozenCell.col - 1, _this.worksheet.getLastVisibleRow()); else _this.isValid = false; } break; case FrozenAreaType.Right: { if (_this.frozenCell.col && !_this.frozenCell.row) _this.range = new asc_Range(_this.worksheet.getFirstVisibleCol(), 0, _this.worksheet.getLastVisibleCol(), _this.worksheet.getLastVisibleRow()); else _this.isValid = false; } break; case FrozenAreaType.Center: { if (!_this.frozenCell.col && !_this.frozenCell.row) _this.range = new asc_Range(_this.worksheet.getFirstVisibleCol(true), _this.worksheet.getFirstVisibleRow(true), _this.worksheet.getLastVisibleCol(), _this.worksheet.getLastVisibleRow()); else _this.isValid = false; } break; // Other case FrozenAreaType.LeftTop: { if (_this.frozenCell.col && _this.frozenCell.row) _this.range = new asc_Range(0, 0, _this.frozenCell.col - 1, _this.frozenCell.row - 1); else _this.isValid = false; } break; case FrozenAreaType.RightTop: { if (_this.frozenCell.col && _this.frozenCell.row) _this.range = new asc_Range(_this.worksheet.getFirstVisibleCol(), 0, _this.worksheet.getLastVisibleCol(), _this.frozenCell.row - 1); else _this.isValid = false; } break; case FrozenAreaType.LeftBottom: { if (_this.frozenCell.col && _this.frozenCell.row) _this.range = new asc_Range(0, _this.worksheet.getFirstVisibleRow(), _this.frozenCell.col - 1, _this.worksheet.getLastVisibleRow()); else _this.isValid = false; } break; case FrozenAreaType.RightBottom: { if (_this.frozenCell.col && _this.frozenCell.row) _this.range = new asc_Range(_this.worksheet.getFirstVisibleCol(), _this.worksheet.getFirstVisibleRow(), _this.worksheet.getLastVisibleCol(), _this.worksheet.getLastVisibleRow()); else _this.isValid = false; } break; } }; _this.getVisibleRange = function() { var vr = _this.range.clone(); var fv = _this.getFirstVisible(); switch (_this.type) { // Two places case FrozenAreaType.Top: { // without changes } break; case FrozenAreaType.Bottom: { vr.r1 = fv.row; vr.r2 = _this.worksheet.getLastVisibleRow(); } break; case FrozenAreaType.Left: { vr.r1 = fv.row; vr.r2 = _this.worksheet.getLastVisibleRow(); } break; case FrozenAreaType.Right: { vr.c1 = fv.col; vr.c2 = _this.worksheet.getLastVisibleCol(); } break; // Four places case FrozenAreaType.LeftTop: { // without changes } break; case FrozenAreaType.RightTop: { vr.c1 = fv.col; vr.c2 = _this.worksheet.getLastVisibleCol(); } break; case FrozenAreaType.LeftBottom: { vr.r1 = fv.row; vr.r2 = _this.worksheet.getLastVisibleRow(); } break; case FrozenAreaType.RightBottom: { vr.c1 = fv.col; vr.c2 = _this.worksheet.getLastVisibleCol(); vr.r1 = fv.row; vr.r2 = _this.worksheet.getLastVisibleRow(); } break; // No frozen areas case FrozenAreaType.Center: { vr.c1 = fv.col; vr.c2 = _this.worksheet.getLastVisibleCol(); vr.r1 = fv.row; vr.r2 = _this.worksheet.getLastVisibleRow(); } break; } return vr; }; _this.getRect = function(bEvent) { var rect = _this.worksheet.rangeToRectRel(_this.range, 0); switch (_this.type) { case FrozenAreaType.Top: { rect.w = +Infinity; rect.r = +Infinity; if(bEvent) { rect.x = -Infinity; rect.y = -Infinity; } break; } case FrozenAreaType.Bottom: { rect.w = +Infinity; rect.h = +Infinity; rect.r = +Infinity; rect.b = +Infinity; if(bEvent) { rect.x = -Infinity; } break; } case FrozenAreaType.Left: { rect.h = +Infinity; rect.b = +Infinity; if(bEvent) { rect.x = -Infinity; rect.y = -Infinity; } break; } case FrozenAreaType.Right: { rect.w = +Infinity; rect.h = +Infinity; rect.r = +Infinity; rect.b = +Infinity; if(bEvent) { rect.y = -Infinity; } break; } case FrozenAreaType.Center: { rect.w = +Infinity; rect.h = +Infinity; rect.r = +Infinity; rect.b = +Infinity; if(bEvent) { rect.x = -Infinity; rect.y = -Infinity; } break; } // Other case FrozenAreaType.LeftTop: { if(bEvent) { rect.x = -Infinity; rect.y = -Infinity; } break; } case FrozenAreaType.RightTop: { rect.w = +Infinity; rect.r = +Infinity; if(bEvent) { rect.y = -Infinity; } break; } case FrozenAreaType.LeftBottom: { rect.h = +Infinity; rect.b = +Infinity; if(bEvent) { rect.x = -Infinity; } break; } case FrozenAreaType.RightBottom: { rect.w = +Infinity; rect.h = +Infinity; rect.r = +Infinity; rect.b = +Infinity; break; } } return rect; }; _this.getFirstVisible = function() { var fv = { col: 0, row: 0 }; switch (_this.type) { // Two places case FrozenAreaType.Top: { fv.col = _this.worksheet.getFirstVisibleCol(); } break; case FrozenAreaType.Bottom: { fv.col = _this.worksheet.getFirstVisibleCol(); fv.row = _this.worksheet.getFirstVisibleRow(); } break; case FrozenAreaType.Left: { fv.row = _this.worksheet.getFirstVisibleRow(); } break; case FrozenAreaType.Right: { fv.col = _this.worksheet.getFirstVisibleCol(); fv.row = _this.worksheet.getFirstVisibleRow(); } break; // Four places case FrozenAreaType.LeftTop: { } break; case FrozenAreaType.RightTop: { fv.col = _this.worksheet.getFirstVisibleCol(); } break; case FrozenAreaType.LeftBottom: { fv.row = _this.worksheet.getFirstVisibleRow(); } break; case FrozenAreaType.RightBottom: { fv.col = _this.worksheet.getFirstVisibleCol(); fv.row = _this.worksheet.getFirstVisibleRow(); } break; // No frozen areas case FrozenAreaType.Center: { fv.col = _this.worksheet.getFirstVisibleCol(); fv.row = _this.worksheet.getFirstVisibleRow(); } break; } return fv; }; _this.isPointInside = function(x, y, bEvent) { var rect = _this.getRect(bEvent); var result = (x >= rect.x ) && (y >= rect.y) && (x <= rect.r) && (y <= rect.b); if ( log && result ) console.log( x + "," + y + " in " + _this.type); return result; }; _this.isCellInside = function(cell) { var result = false; if (cell && _this.range) { var cellRange = new asc_Range(cell.col, cell.row, cell.col, cell.row); result = _this.range.isIntersect(cellRange); } return result; }; _this.isObjectInside = function(object) { // TODO Нужно учитывать collOff, rowOff var boundsFromTo = object.boundsFromTo; var objectRange = new asc_Range(boundsFromTo.from.col, boundsFromTo.from.row, boundsFromTo.to.col, boundsFromTo.to.row); return _this.range.isIntersect(objectRange); }; _this.getVerticalScroll = function() { // No scroll for Top, LeftTop, RightTop var scroll = 0; var fv = _this.getFirstVisible(); var headerPx = _this.worksheet._getRowTop(0); switch (_this.type) { // Two places case FrozenAreaType.Top: { scroll = headerPx; } break; case FrozenAreaType.Bottom: { scroll = -(_this.worksheet._getRowTop(fv.row) - _this.worksheet._getRowTop(_this.frozenCell.row) + _this.worksheet.getScrollCorrect()) + headerPx; } break; case FrozenAreaType.Left: case FrozenAreaType.Right: { scroll = -(_this.worksheet._getRowTop(fv.row) - _this.worksheet.cellsTop + _this.worksheet.getScrollCorrect()) + headerPx; } break; // Four places case FrozenAreaType.LeftTop: case FrozenAreaType.RightTop: { scroll = headerPx; } break; case FrozenAreaType.LeftBottom: case FrozenAreaType.RightBottom: { scroll = -(_this.worksheet._getRowTop(fv.row) - _this.worksheet._getRowTop(_this.frozenCell.row) + _this.worksheet.getScrollCorrect()) + headerPx; } break; // No frozen areas case FrozenAreaType.Center: { scroll = -(_this.worksheet._getRowTop(fv.row) - _this.worksheet.cellsTop + _this.worksheet.getScrollCorrect()) + headerPx; } break; } return scroll; }; _this.getHorizontalScroll = function() { // No scroll for Left, LeftTop, LeftBottom var scroll = 0; var fv = _this.getFirstVisible(); var headerPx = _this.worksheet._getColLeft(0); switch (_this.type) { // Two places case FrozenAreaType.Top: case FrozenAreaType.Bottom: { scroll = -(_this.worksheet._getColLeft(fv.col) - _this.worksheet.cellsLeft + _this.worksheet.getHorizontalScrollCorrect()) + headerPx; } break; case FrozenAreaType.Left: { scroll = headerPx; } break; case FrozenAreaType.Right: { scroll = -(_this.worksheet._getColLeft(fv.col) - _this.worksheet._getColLeft(_this.frozenCell.col) + _this.worksheet.getHorizontalScrollCorrect()) + headerPx; } break; // Four places case FrozenAreaType.LeftTop: case FrozenAreaType.LeftBottom: { scroll = headerPx; } break; case FrozenAreaType.RightTop: case FrozenAreaType.RightBottom: { scroll = -(_this.worksheet._getColLeft(fv.col) - _this.worksheet._getColLeft(_this.frozenCell.col) + _this.worksheet.getHorizontalScrollCorrect()) + headerPx; } break; // No frozen areas case FrozenAreaType.Center: { scroll = -(_this.worksheet._getColLeft(fv.col) - _this.worksheet.cellsLeft + _this.worksheet.getHorizontalScrollCorrect()) + headerPx; } break; } return _this.worksheet.getRightToLeft() ? -scroll : scroll; }; _this.clip = function(canvas, rect) { canvas.m_oContext.save(); canvas.m_oContext.beginPath(); canvas.m_oContext.rect(rect.x, rect.y, rect.w, rect.h); canvas.m_oContext.clip(); // этот сэйв нужен для восстановления сложных вложенных клипов canvas.m_oContext.save(); }; _this.restore = function(canvas) { canvas.m_oContext.restore(); // этот рестор нужен для восстановления сложных вложенных клипов canvas.m_oContext.restore(); }; _this.getUpdateRect = function (oRect) { let oUpdateRect = _this.worksheet.rangeToRectAbs(_this.range, 3); if(oRect) { oUpdateRect = oUpdateRect.intersection(oRect); } return oUpdateRect; } _this._updateGraphicCanvas = function (fCallback, oRect) { var oUpdateRect = _this.getUpdateRect(oRect); if (!oUpdateRect) { return; } var canvas = _this.worksheet.objectRender.getDrawingCanvas(); _this.setTransform(canvas.shapeCtx, canvas.shapeOverlayCtx, canvas.autoShapeTrack); var oClipRect; if(!oRect) { oClipRect = _this.worksheet.rangeToRectRel(_this.range, 0, true); } else { var oT = canvas.shapeCtx.m_oCoordTransform; var l = (oT.TransformPointX(oUpdateRect.l, oUpdateRect.t) >> 0) - 1; var t = (oT.TransformPointY(oUpdateRect.l, oUpdateRect.t) >> 0) - 1; var r = (oT.TransformPointX(oUpdateRect.r, oUpdateRect.b) >> 0) + 1; var b = (oT.TransformPointY(oUpdateRect.r, oUpdateRect.b) >> 0) + 1; oClipRect = new AscFormat.CGraphicBounds(l, t, r, b); } _this.clip(canvas.shapeCtx, oClipRect); canvas.shapeCtx.updatedRect = oUpdateRect; fCallback(canvas.shapeCtx); canvas.shapeCtx.updatedRect = null; _this.restore(canvas.shapeCtx); } _this.drawObject = function(object, oRect) { this._updateGraphicCanvas(function (graphics) { object.draw(graphics); if ( (object.graphicObject.lockType !== undefined) && (object.graphicObject.lockType !== AscCommon.c_oAscLockTypes.kLockTypeNone) ) { var oApi = Asc['editor']; if(oApi){ if (!oApi.collaborativeEditing.getFast() || object.graphicObject.lockType !== AscCommon.c_oAscLockTypes.kLockTypeMine){ graphics.SetIntegerGrid(false); graphics.transform3(object.graphicObject.transform, false); graphics.DrawLockObjectRect(object.graphicObject.lockType, 0, 0, object.graphicObject.extX, object.graphicObject.extY ); graphics.reset(); graphics.SetIntegerGrid(true); } } } }, oRect); }; _this.drawDropDown = function(object, oRect) { this._updateGraphicCanvas(function (graphics) { object.drawDropDown(graphics); }); }; _this.updateRange = function(object, oRange) { var oClipRange = _this.range.intersectionSimple(oRange); if(!oClipRange) { return; } var canvas = _this.worksheet.objectRender.getDrawingCanvas(); _this.setTransform(canvas.shapeCtx, canvas.shapeOverlayCtx, canvas.autoShapeTrack); _this.clip(canvas.shapeCtx, _this.worksheet.rangeToRectRel(oClipRange, 0, true)); canvas.shapeCtx.updatedRect = _this.worksheet.rangeToRectAbs(oClipRange, 3); //For debug // canvas.shapeCtx.p_color(0, 0, 0, 255); // canvas.shapeCtx.p_width(5); // canvas.shapeCtx.rect(oRect.x, oRect.y, oRect.w, oRect.h); // canvas.shapeCtx.ds(); object.draw(canvas.shapeCtx); canvas.shapeCtx.updatedRect = null; // Lock if ( (object.graphicObject.lockType !== undefined) && (object.graphicObject.lockType !== AscCommon.c_oAscLockTypes.kLockTypeNone) ) { var oApi = Asc['editor']; if(oApi){ if (!oApi.collaborativeEditing.getFast() || object.graphicObject.lockType !== AscCommon.c_oAscLockTypes.kLockTypeMine){ canvas.shapeCtx.SetIntegerGrid(false); canvas.shapeCtx.transform3(object.graphicObject.transform, false); canvas.shapeCtx.DrawLockObjectRect(object.graphicObject.lockType, 0, 0, object.graphicObject.extX, object.graphicObject.extY ); canvas.shapeCtx.reset(); canvas.shapeCtx.SetIntegerGrid(true); } } } _this.restore(canvas.shapeCtx); }; _this.drawFrozenPaneBorderHor = function(autoShapeTrack, y, left, right) { if(Asc.editor.asc_getFrozenPaneBorderType() === Asc.c_oAscFrozenPaneBorderType.shadow) { var nH = SHADOW_LENGTH; if(AscCommon.AscBrowser.isRetina) { nH = AscCommon.AscBrowser.convertToRetinaValue(nH, true); } autoShapeTrack.m_oOverlay.CheckPoint1(left, y - nH); autoShapeTrack.m_oOverlay.CheckPoint2(right, y + nH); autoShapeTrack.drawImage(sFrozenImageUrl, left, y, right, nH); } else { autoShapeTrack.m_oOverlay.DrawFrozenPlaceHorLine(y, left, right); } }; _this.drawFrozenPaneBorderVer = function(autoShapeTrack, x, top, bottom) { if(Asc.editor.asc_getFrozenPaneBorderType() === Asc.c_oAscFrozenPaneBorderType.shadow) { var nW = SHADOW_LENGTH; if(AscCommon.AscBrowser.isRetina) { nW = AscCommon.AscBrowser.convertToRetinaValue(nW, true); } autoShapeTrack.m_oOverlay.CheckPoint1(x - nW, top); autoShapeTrack.m_oOverlay.CheckPoint2(x + nW, bottom); autoShapeTrack.drawImage(sFrozenImageRotUrl, _this.worksheet.checkRtl(x), top, nW, bottom); } else { autoShapeTrack.m_oOverlay.DrawFrozenPlaceVerLine(_this.worksheet.checkRtl(x), top, bottom); } }; _this.drawSelection = function(drawingDocument, shapeCtx, shapeOverlayCtx, autoShapeTrack, trackOverlay) { var ctx = trackOverlay.m_oContext; _this.setTransform(shapeCtx, shapeOverlayCtx, autoShapeTrack, trackOverlay); // Clip _this.clip(shapeOverlayCtx, _this.worksheet.rangeToRectRel(_this.range, 0, true)); if (drawingDocument.m_bIsSelection) { if (!window["IS_NATIVE_EDITOR"]) { drawingDocument.SelectionMatrix = null; trackOverlay.m_oControl.HtmlElement.style.display = "block"; if (null == trackOverlay.m_oContext) { trackOverlay.m_oContext = trackOverlay.m_oControl.HtmlElement.getContext('2d'); } } drawingDocument.private_StartDrawSelection(trackOverlay); this.worksheet.objectRender.controller.drawTextSelection(); drawingDocument.private_EndDrawSelection(); this.worksheet.handlers.trigger("drawMobileSelection", trackOverlay, undefined); } if (drawingDocument.MathTrack.IsActive()) { drawingDocument.DrawMathTrack(trackOverlay); } ctx.globalAlpha = 1.0; this.worksheet.objectRender.controller.drawSelection(drawingDocument); if ( this.worksheet.objectRender.controller.needUpdateOverlay() ) { trackOverlay.Show(); autoShapeTrack.Graphics.put_GlobalAlpha(true, 0.5); this.worksheet.objectRender.controller.drawTracks(autoShapeTrack); autoShapeTrack.Graphics.put_GlobalAlpha(true, 1); _this.restore(autoShapeTrack); } // Restore _this.restore(autoShapeTrack); }; _this.setTransform = function(shapeCtx, shapeOverlayCtx, autoShapeTrack, trackOverlay) { if ( shapeCtx && shapeOverlayCtx && autoShapeTrack ) { var x = _this.getHorizontalScroll(); var y = _this.getVerticalScroll(); shapeCtx.m_oCoordTransform.tx = x; shapeCtx.m_oCoordTransform.ty = y; shapeCtx.CalculateFullTransform(); shapeOverlayCtx.m_oCoordTransform.tx = x; shapeOverlayCtx.m_oCoordTransform.ty = y; shapeOverlayCtx.CalculateFullTransform(); autoShapeTrack.Graphics.m_oCoordTransform.tx = x; autoShapeTrack.Graphics.m_oCoordTransform.ty = y; autoShapeTrack.Graphics.CalculateFullTransform(); _this.worksheet.objectRender.controller.recalculateCurPos(); } if(trackOverlay && trackOverlay.m_oHtmlPage) { var width = trackOverlay.m_oHtmlPage.drawingPage.right - trackOverlay.m_oHtmlPage.drawingPage.left; var height = trackOverlay.m_oHtmlPage.drawingPage.bottom - trackOverlay.m_oHtmlPage.drawingPage.top; trackOverlay.m_oHtmlPage.drawingPage.left = x; trackOverlay.m_oHtmlPage.drawingPage.top = y; trackOverlay.m_oHtmlPage.drawingPage.right = x + width; trackOverlay.m_oHtmlPage.drawingPage.bottom = y + height; } }; _this.drawPaneBorder = function(autoShapeTrack) { var fLeft, fTop, fRight, fBottom; if(_this.type === FrozenAreaType.Bottom){ fTop = this.worksheet._getRowTop(_this.frozenCell.row); fLeft = 0; this.drawFrozenPaneBorderHor(autoShapeTrack, fTop, fLeft, autoShapeTrack.Graphics.m_lWidthPix); } else if(_this.type === FrozenAreaType.Right){ fTop = 0; fLeft = this.worksheet._getColLeft(_this.frozenCell.col); this.drawFrozenPaneBorderVer(autoShapeTrack, fLeft, fTop, autoShapeTrack.Graphics.m_lHeightPix); } else if(_this.type === FrozenAreaType.RightBottom){ //autoShapeTrack.Graphics.put_GlobalAlpha(true, 1); fTop = this.worksheet._getRowTop(_this.frozenCell.row); fLeft = this.worksheet._getColLeft(_this.frozenCell.col); this.drawFrozenPaneBorderHor(autoShapeTrack, fTop, fLeft, autoShapeTrack.Graphics.m_lWidthPix); this.drawFrozenPaneBorderVer(autoShapeTrack, fLeft, fTop, autoShapeTrack.Graphics.m_lHeightPix); } else if(_this.type === FrozenAreaType.LeftBottom){ fTop = this.worksheet._getRowTop(_this.frozenCell.row); fLeft = 0; fRight = this.worksheet._getColLeft(_this.frozenCell.col); this.drawFrozenPaneBorderHor(autoShapeTrack, fTop, fLeft, fRight); } else if(_this.type === FrozenAreaType.RightTop){ fTop = 0; fLeft = this.worksheet._getColLeft(_this.frozenCell.col); fBottom = this.worksheet._getRowTop(_this.frozenCell.row); this.drawFrozenPaneBorderVer(autoShapeTrack, fLeft, fTop, fBottom); } }; // Range constructor _this.initRange(); } // Container function DrawingArea(ws) { var asc = window["Asc"]; this.api = asc["editor"]; this.worksheet = ws; this.frozenPlaces = []; } DrawingArea.prototype.init = function() { this.frozenPlaces = []; if ( this.worksheet ) { var place; if ( this.worksheet.topLeftFrozenCell ) { place = new FrozenPlace(this.worksheet, FrozenAreaType.Top); if ( place.isValid ) this.frozenPlaces.push(place); place = new FrozenPlace(this.worksheet, FrozenAreaType.Bottom); if ( place.isValid ) this.frozenPlaces.push(place); place = new FrozenPlace(this.worksheet, FrozenAreaType.Left); if ( place.isValid ) this.frozenPlaces.push(place); place = new FrozenPlace(this.worksheet, FrozenAreaType.Right); if ( place.isValid ) this.frozenPlaces.push(place); place = new FrozenPlace(this.worksheet, FrozenAreaType.LeftTop); if ( place.isValid ) this.frozenPlaces.push(place); place = new FrozenPlace(this.worksheet, FrozenAreaType.RightTop); if ( place.isValid ) this.frozenPlaces.push(place); place = new FrozenPlace(this.worksheet, FrozenAreaType.LeftBottom); if ( place.isValid ) this.frozenPlaces.push(place); place = new FrozenPlace(this.worksheet, FrozenAreaType.RightBottom); if ( place.isValid ) this.frozenPlaces.push(place); } else this.frozenPlaces.push(new FrozenPlace(this.worksheet, FrozenAreaType.Center)); } }; DrawingArea.prototype.clear = function() { this.worksheet.drawingGraphicCtx.clear(); }; DrawingArea.prototype.clearRect = function(oRect) { var canvas = this.worksheet.objectRender.getDrawingCanvas(); var oT = canvas.shapeCtx.m_oCoordTransform; var l = (oT.TransformPointX(oRect.l, oRect.t) >> 0) - 1; var t = (oT.TransformPointY(oRect.l, oRect.t) >> 0) - 1; var r = (oT.TransformPointX(oRect.r, oRect.b) >> 0) + 1; var b = (oT.TransformPointY(oRect.r, oRect.b) >> 0) + 1; canvas.shapeCtx.m_oContext.clearRect(l, t, r - l, b - t); }; DrawingArea.prototype.drawObject = function(object, oRect) { for ( var i = 0; i < this.frozenPlaces.length; i++ ) { if ( this.frozenPlaces[i].isObjectInside(object) ) { this.frozenPlaces[i].drawObject(object, oRect); } } }; DrawingArea.prototype.drawDropDown = function(object, oRect) { for ( var i = 0; i < this.frozenPlaces.length; i++ ) { this.frozenPlaces[i].drawDropDown(object, oRect); } }; DrawingArea.prototype.updateRange = function(object, oRange) { for ( var i = 0; i < this.frozenPlaces.length; i++ ) { if ( this.frozenPlaces[i].isObjectInside(object) ) { this.frozenPlaces[i].updateRange(object, oRange); } } }; DrawingArea.prototype.reinitRanges = function() { for ( var i = 0; i < this.frozenPlaces.length; i++ ) { this.frozenPlaces[i].initRange(); } }; DrawingArea.prototype.convertCoordsToCursorWR = function(x, y) { let oFrozenPlace = this.frozenPlaces[0]; let oWS = this.worksheet; let canvas = oWS.objectRender.getDrawingCanvas(); let shapeCtx = canvas.shapeCtx; let nXT = AscCommon.AscBrowser.convertToRetinaValue(shapeCtx.m_oCoordTransform.sx * x + oFrozenPlace.getHorizontalScroll(), false); let nYT = AscCommon.AscBrowser.convertToRetinaValue(shapeCtx.m_oCoordTransform.sy * y + oFrozenPlace.getVerticalScroll(), false); return {X: nXT, Y: nYT, Error: false}; }; DrawingArea.prototype.drawSelection = function(drawingDocument) { var oWS = this.worksheet; var canvas = oWS.objectRender.getDrawingCanvas(); var shapeCtx = canvas.shapeCtx; var shapeOverlayCtx = canvas.shapeOverlayCtx; var autoShapeTrack = canvas.autoShapeTrack; var trackOverlay = canvas.trackOverlay; var ctx = trackOverlay.m_oContext; trackOverlay.Clear(); drawingDocument.Overlay = trackOverlay; oWS.overlayGraphicCtx.clear(); oWS._drawCollaborativeElements(autoShapeTrack); var controller = oWS.objectRender.controller; if ( controller.selectedObjects.length || this.api.isStartAddShape || this.api.isInkDrawerOn()) { oWS.cleanSelection(); oWS._drawSelection(); } var chart = controller.getChartForRangesDrawing(); if(chart) { oWS.objectRender.selectDrawingObjectRange(chart); } for ( var i = 0; i < this.frozenPlaces.length; i++ ) { this.frozenPlaces[i].drawSelection(drawingDocument, shapeCtx, shapeOverlayCtx, autoShapeTrack, trackOverlay); } this.drawFrozenPaneBorders(autoShapeTrack); var oWatermark = this.api.watermarkDraw; if(oWatermark) { oWatermark.zoom = 1.0; oWatermark.Generate(); if(oWatermark.width > 0 && oWatermark.height > 0) { let nOffsetY = oWS.cellsTop; while (nOffsetY < ctx.canvas.height) { let nOffsetX = oWS.cellsLeft; while (nOffsetX < ctx.canvas.width) { oWatermark.Draw(ctx, nOffsetX, nOffsetY, oWatermark.width, oWatermark.height); nOffsetX += oWatermark.width; } nOffsetY += oWatermark.height; } } } if (this.api) { const oDrawingDocument = this.api.getDrawingDocument(); if (oDrawingDocument && oDrawingDocument.placeholders.objects.length) { const oRect = {}; const nOffsetX = 2 * oWS.cellsLeft - oWS._getColLeft(oWS.visibleRange.c1); const nOffsetY = 2 * oWS.cellsTop - oWS._getRowTop(oWS.visibleRange.r1); oRect.left = nOffsetX; oRect.right = nOffsetX + ctx.canvas.width; oRect.top = nOffsetY; oRect.bottom = nOffsetY + ctx.canvas.height; var pxToMm = Asc.getCvtRatio(0/*mm*/, 3/*px*/, oWS._getPPIX()); ctx.save(); ctx.beginPath(); ctx.rect(oWS.cellsLeft, oWS.cellsTop, ctx.canvas.width, ctx.canvas.height); ctx.clip(); oDrawingDocument.placeholders.draw(trackOverlay, oWS.workbook.model.nActive, oRect, ctx.canvas.width * pxToMm, ctx.canvas.height * pxToMm); ctx.restore(); } } }; DrawingArea.prototype.drawFrozenPaneBorders = function(autoShapeTrack) { for ( var i = 0; i < this.frozenPlaces.length; i++ ) { this.frozenPlaces[i].drawPaneBorder(autoShapeTrack); } }; DrawingArea.prototype.getOffsets = function(x, y, bEvents) { for ( var i = 0; i < this.frozenPlaces.length; i++ ) { if ( this.frozenPlaces[i].isPointInside(x, y, bEvents) ) { return { x: this.frozenPlaces[i].getHorizontalScroll(), y: this.frozenPlaces[i].getVerticalScroll() } } } return null; }; //--------------------------------------------------------export---------------------------------------------------- window['AscFormat'] = window['AscFormat'] || {}; window['AscCommonExcel'] = window['AscCommonExcel'] || {}; window['AscFormat'].DrawingArea = DrawingArea; window["AscCommonExcel"].sFrozenImageUrl = sFrozenImageUrl; window["AscCommonExcel"].sFrozenImageRotUrl = sFrozenImageRotUrl; })(window);