Commit 4e7848c7 authored by Alexander.Trofimov's avatar Alexander.Trofimov

fix bugs #22959, #23026

при scroll-е пересчитываем область ячейки

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@67019 954022d7-b5bf-4e40-9824-e11837661b57
parent f43b1cb2
...@@ -82,6 +82,7 @@ ...@@ -82,6 +82,7 @@
this.input = input; this.input = input;
this.handlers = new asc_HL(handlers); this.handlers = new asc_HL(handlers);
this.options = {}; this.options = {};
this.sides = undefined;
//---declaration--- //---declaration---
this.canvasOuter = undefined; this.canvasOuter = undefined;
...@@ -223,11 +224,6 @@ ...@@ -223,11 +224,6 @@
/** /**
* @param {Object} options * @param {Object} options
* cellX - cell x coord (pt)
* cellY - cell y coord (pt)
* leftSide - array
* rightSide - array
* bottomSide - array
* fragments - text fragments * fragments - text fragments
* flags - text flags (wrapText, textAlign) * flags - text flags (wrapText, textAlign)
* font * font
...@@ -440,23 +436,44 @@ ...@@ -440,23 +436,44 @@
t._moveCursor(kEndOfText); t._moveCursor(kEndOfText);
}; };
CellEditor.prototype.move = function (dx, dy, l, t, r, b) { CellEditor.prototype.move = function (l, t, r, b) {
var opt = this.options; this.sides = this.options.getSides();
this.left = this.sides.cellX;
this.top = this.sides.cellY;
this.right = this.sides.r[0];
this.bottom = this.sides.b[0];
// Обновляем флаги, т.к. мы уже могли выставить wrap
this.textFlags.wrapText = this.options.flags.wrapText;
if (this.textFlags.wrapText) {
this.textFlags.wrapOnlyNL = true;
this.textFlags.wrapText = false;
}
// ToDo вынести в отдельную функцию
var canExpW = true, canExpH = true, tm, expW, expH, fragments = this._getRenderFragments();
if (0 < fragments.length) {
tm = this.textRender.measureString(fragments, this.textFlags, this._getContentWidth());
expW = tm.width > this._getContentWidth();
expH = tm.height > this._getContentHeight();
this.left += dx; while (expW && canExpW || expH && canExpH) {
this.right += dx; if (expW) { canExpW = this._expandWidth(); }
this.top += dy; if (expH) { canExpH = this._expandHeight(); }
this.bottom += dy;
opt.leftSide.forEach(function (e,i,a) {a[i] = e + dx;}); if (!canExpW) {
opt.rightSide.forEach(function (e,i,a) {a[i] = e + dx;}); this.textFlags.wrapText = true;
opt.bottomSide.forEach(function (e,i,a) {a[i] = e + dy;}); tm = this.textRender.measureString(fragments, this.textFlags, this._getContentWidth());
} else {
tm = this.textRender.measure(this._getContentWidth());
}
expW = tm.width > this._getContentWidth();
expH = tm.height > this._getContentHeight();
}
}
if (this.left < l || this.top < t || this.left > r || this.top > b) { if (this.left < l || this.top < t || this.left > r || this.top > b) {
// hide // hide
this._hideCanvas(); this._hideCanvas();
} else { } else {
// ToDo выставлять опции (т.к. при scroll редактор должен пересчитываться и уменьшаться размеры)
this._adjustCanvas(); this._adjustCanvas();
this._showCanvas(); this._showCanvas();
this._renderText(); this._renderText();
...@@ -640,7 +657,7 @@ ...@@ -640,7 +657,7 @@
var ctx = this.drawingCtx; var ctx = this.drawingCtx;
var u = ctx.getUnits(); var u = ctx.getUnits();
this.textFlags = opt.flags; this.textFlags = opt.flags.clone();
if (this.textFlags.textAlign.toLowerCase() === "justify" || this.isFormula()) { if (this.textFlags.textAlign.toLowerCase() === "justify" || this.isFormula()) {
this.textFlags.textAlign = "left"; this.textFlags.textAlign = "left";
} }
...@@ -661,14 +678,12 @@ ...@@ -661,14 +678,12 @@
this.kx = asc_getcvt(u, 0/*px*/, ctx.getPPIX()); this.kx = asc_getcvt(u, 0/*px*/, ctx.getPPIX());
this.ky = asc_getcvt(u, 0/*px*/, ctx.getPPIY()); this.ky = asc_getcvt(u, 0/*px*/, ctx.getPPIY());
opt.leftSide.sort(fSortDescending); this.sides = opt.getSides();
opt.rightSide.sort(fSortAscending);
opt.bottomSide.sort(fSortAscending);
this.left = opt.cellX; this.left = this.sides.cellX;
this.top = opt.cellY; this.top = this.sides.cellY;
this.right = opt.rightSide[0]; this.right = this.sides.r[0];
this.bottom = opt.bottomSide[0]; this.bottom = this.sides.b[0];
this.cursorPos = opt.cursorPos !== undefined ? opt.cursorPos : 0; this.cursorPos = opt.cursorPos !== undefined ? opt.cursorPos : 0;
this.topLineIndex = 0; this.topLineIndex = 0;
...@@ -1026,15 +1041,15 @@ ...@@ -1026,15 +1041,15 @@
}; };
CellEditor.prototype._expandWidth = function () { CellEditor.prototype._expandWidth = function () {
var t = this, opt = t.options, l = false, r = false; var t = this, l = false, r = false, leftSide = this.sides.l, rightSide = this.sides.r;
function expandLeftSide() { function expandLeftSide() {
var i = asc_search(opt.leftSide, function (v) {return v < t.left;}); var i = asc_search(leftSide, function (v) {return v < t.left;});
if (i >= 0) { if (i >= 0) {
t.left = opt.leftSide[i]; t.left = leftSide[i];
return true; return true;
} }
var val = opt.leftSide[opt.leftSide.length - 1]; var val = leftSide[leftSide.length - 1];
if (Math.abs(t.left - val) > 0.000001) { // left !== leftSide[len-1] if (Math.abs(t.left - val) > 0.000001) { // left !== leftSide[len-1]
t.left = val; t.left = val;
} }
...@@ -1042,12 +1057,12 @@ ...@@ -1042,12 +1057,12 @@
} }
function expandRightSide() { function expandRightSide() {
var i = asc_search(opt.rightSide, function (v) {return v > t.right;}); var i = asc_search(rightSide, function (v) {return v > t.right;});
if (i >= 0) { if (i >= 0) {
t.right = opt.rightSide[i]; t.right = rightSide[i];
return true; return true;
} }
var val = opt.rightSide[opt.rightSide.length - 1]; var val = rightSide[rightSide.length - 1];
if (Math.abs(t.right - val) > 0.000001) { // right !== rightSide[len-1] if (Math.abs(t.right - val) > 0.000001) { // right !== rightSide[len-1]
t.right = val; t.right = val;
} }
...@@ -1064,12 +1079,12 @@ ...@@ -1064,12 +1079,12 @@
}; };
CellEditor.prototype._expandHeight = function () { CellEditor.prototype._expandHeight = function () {
var t = this, opt = t.options, i = asc_search(opt.bottomSide, function (v) {return v > t.bottom;}); var t = this, bottomSide = this.sides.b, i = asc_search(bottomSide, function (v) {return v > t.bottom;});
if (i >= 0) { if (i >= 0) {
t.bottom = opt.bottomSide[i]; t.bottom = bottomSide[i];
return true; return true;
} }
var val = opt.bottomSide[opt.bottomSide.length - 1]; var val = bottomSide[bottomSide.length - 1];
if (Math.abs(t.bottom - val) > 0.000001) { // bottom !== bottomSide[len-1] if (Math.abs(t.bottom - val) > 0.000001) { // bottom !== bottomSide[len-1]
t.bottom = val; t.bottom = val;
} }
......
...@@ -5266,8 +5266,7 @@ ...@@ -5266,8 +5266,7 @@
ctxH - (this.rows[oldEnd].top - this.rows[oldStart].top + this.cellsTop + diffHeight) : 0; ctxH - (this.rows[oldEnd].top - this.rows[oldStart].top + this.cellsTop + diffHeight) : 0;
if (this.isCellEditMode && editor && this.activeRange.r1 >= rFrozen) { if (this.isCellEditMode && editor && this.activeRange.r1 >= rFrozen) {
editor.move(0, -dy, this.cellsLeft + (this.activeRange.c1 >= cFrozen ? diffWidth : 0), editor.move(this.cellsLeft + (this.activeRange.c1 >= cFrozen ? diffWidth : 0), this.cellsTop + diffHeight, ctxW, ctxH);
this.cellsTop + diffHeight, ctxW, ctxH);
} }
var widthChanged = Math.max(calcDecades(vr.r2 + 1), 3) !== oldDec; var widthChanged = Math.max(calcDecades(vr.r2 + 1), 3) !== oldDec;
...@@ -5456,8 +5455,7 @@ ...@@ -5456,8 +5455,7 @@
ctxW - (this.cols[oldEnd].left - this.cols[oldStart].left + this.cellsLeft + diffWidth) : 0; ctxW - (this.cols[oldEnd].left - this.cols[oldStart].left + this.cellsLeft + diffWidth) : 0;
if (this.isCellEditMode && editor && this.activeRange.c1 >= cFrozen) { if (this.isCellEditMode && editor && this.activeRange.c1 >= cFrozen) {
editor.move(-dx, 0, this.cellsLeft + diffWidth, editor.move(this.cellsLeft + diffWidth, this.cellsTop + (this.activeRange.r1 >= rFrozen ? diffHeight : 0), ctxW, ctxH);
this.cellsTop + (this.activeRange.r1 >= rFrozen ? diffHeight : 0), ctxW, ctxH);
} }
// Перемещаем область // Перемещаем область
...@@ -10365,70 +10363,50 @@ ...@@ -10365,70 +10363,50 @@
return true; return true;
}; };
WorksheetView.prototype.openCellEditor = function (editor, x, y, isCoord, fragments, cursorPos, WorksheetView.prototype.openCellEditor = function(editor, x, y, isCoord, fragments, cursorPos, isFocus, isClearCell, isHideCursor, isQuickInput, activeRange) {
isFocus, isClearCell, isHideCursor, isQuickInput, activeRange) { var t = this, tc = this.cols, tr = this.rows, col, row, c, fl, mc, bg, isMerged;
var t = this, vr, tc = this.cols, tr = this.rows, col, row, c, fl, mc, bg, isMerged;
var offsetX = 0, offsetY = 0;
var ar = this.activeRange; var ar = this.activeRange;
if (activeRange) if (activeRange) {
this.activeRange = activeRange.clone(); this.activeRange = activeRange.clone();
}
if (this.objectRender.checkCursorDrawingObject(x, y)) if (this.objectRender.checkCursorDrawingObject(x, y)) {
return false; return false;
function getLeftSide(col) {
var i, res = [], offs = t.cols[vr.c1].left - t.cols[0].left - offsetX;
for (i = col; i >= vr.c1; --i) {
if (t.width_1px < t.cols[i].width)
res.push(t.cols[i].left - offs);
}
return res;
} }
function getRightSide(col) { function getVisibleRangeObject() {
var i, w, res = [], offs = t.cols[vr.c1].left - t.cols[0].left - offsetX; var vr = t.visibleRange.clone(), offsetX = 0, offsetY = 0;
if (t.topLeftFrozenCell) {
// Для замерженных ячеек, можем уйти за границу var cFrozen = t.topLeftFrozenCell.getCol0();
if (isMerged && col > vr.c2) var rFrozen = t.topLeftFrozenCell.getRow0();
col = vr.c2; if (0 < cFrozen) {
if (col >= cFrozen) {
for (i = col; i <= vr.c2; ++i) { offsetX = tc[cFrozen].left - tc[0].left;
w = t.cols[i].width; } else {
if (t.width_1px < w) vr.c1 = 0;
res.push(t.cols[i].left + w - offs); vr.c2 = cFrozen - 1;
} }
w = t.drawingCtx.getWidth();
if (res[res.length - 1] > w) {
res[res.length - 1] = w;
} }
return res; if (0 < rFrozen) {
if (row >= rFrozen) {
offsetY = tr[rFrozen].top - tr[0].top;
} else {
vr.r1 = 0;
vr.r2 = rFrozen - 1;
} }
function getBottomSide(row) {
var i, h, res = [], offs = t.rows[vr.r1].top - t.rows[0].top - offsetY;
// Для замерженных ячеек, можем уйти за границу
if (isMerged && row > vr.r2)
row = vr.r2;
for (i = row; i <= vr.r2; ++i) {
h = t.rows[i].height;
if (t.height_1px < h)
res.push(t.rows[i].top + h - offs);
} }
h = t.drawingCtx.getHeight();
if (res[res.length - 1] > h) {
res[res.length - 1] = h;
} }
return res; return {vr: vr, offsetX: offsetX, offsetY: offsetY};
} }
if (isCoord) { if (isCoord) {
x *= asc_getcvt( 0/*px*/, 1/*pt*/, this._getPPIX() ); x *= asc_getcvt(0/*px*/, 1/*pt*/, this._getPPIX());
y *= asc_getcvt( 0/*px*/, 1/*pt*/, this._getPPIY() ); y *= asc_getcvt(0/*px*/, 1/*pt*/, this._getPPIY());
col = this._findColUnderCursor(x, true); col = this._findColUnderCursor(x, true);
row = this._findRowUnderCursor(y, true); row = this._findRowUnderCursor(y, true);
if (!col || !row) {return false;} if (!col || !row) {
return false;
}
col = col.col; col = col.col;
row = row.row; row = row.row;
} else { } else {
...@@ -10438,14 +10416,18 @@ ...@@ -10438,14 +10416,18 @@
// Возможно стоит заменить на ячейку из кеша // Возможно стоит заменить на ячейку из кеша
c = this._getVisibleCell(col, row); c = this._getVisibleCell(col, row);
if (!c) {throw "Can not get cell data (col=" + col + ", row=" + row + ")";} if (!c) {
throw "Can not get cell data (col=" + col + ", row=" + row + ")";
}
fl = this._getCellFlags(c); fl = this._getCellFlags(c);
isMerged = fl.isMerged(); isMerged = fl.isMerged();
if (isMerged) { if (isMerged) {
mc = fl.merged; mc = fl.merged;
c = this._getVisibleCell(mc.c1, mc.r1); c = this._getVisibleCell(mc.c1, mc.r1);
if (!c) {throw "Can not get merged cell data (col=" + mc.c1 + ", row=" + mc.r1 + ")";} if (!c) {
throw "Can not get merged cell data (col=" + mc.c1 + ", row=" + mc.r1 + ")";
}
fl = this._getCellFlags(c); fl = this._getCellFlags(c);
} }
...@@ -10454,28 +10436,6 @@ ...@@ -10454,28 +10436,6 @@
this.handlers.trigger("onScroll", this._calcActiveCellOffset()); this.handlers.trigger("onScroll", this._calcActiveCellOffset());
this.isCellEditMode = true; this.isCellEditMode = true;
vr = this.visibleRange.clone();
if (this.topLeftFrozenCell) {
var cFrozen = this.topLeftFrozenCell.getCol0();
var rFrozen = this.topLeftFrozenCell.getRow0();
if (0 < cFrozen) {
if (col >= cFrozen)
offsetX = tc[cFrozen].left - tc[0].left;
else {
vr.c1 = 0;
vr.c2 = cFrozen - 1;
}
}
if (0 < rFrozen) {
if (row >= rFrozen)
offsetY = tr[rFrozen].top - tr[0].top;
else {
vr.r1 = 0;
vr.r2 = rFrozen - 1;
}
}
}
bg = c.getFill(); bg = c.getFill();
this.isFormulaEditMode = false; this.isFormulaEditMode = false;
// Очищаем массив ячеек для текущей формулы // Очищаем массив ячеек для текущей формулы
...@@ -10496,11 +10456,6 @@ ...@@ -10496,11 +10456,6 @@
var arrAutoCompleteLC = asc.arrayToLowerCase(arrAutoComplete); var arrAutoCompleteLC = asc.arrayToLowerCase(arrAutoComplete);
editor.open({ editor.open({
cellX: this.cellsLeft + tc[!isMerged ? col : mc.c1].left - tc[vr.c1].left + offsetX,
cellY: this.cellsTop + tr[!isMerged ? row : mc.r1].top - tr[vr.r1].top + offsetY,
leftSide: getLeftSide(!isMerged ? col : mc.c1),
rightSide: getRightSide(!isMerged ? col : mc.c2),
bottomSide: getBottomSide(!isMerged ? row : mc.r2),
fragments: fragments, fragments: fragments,
flags: fl, flags: fl,
font: new asc.FontProperties(c.getFontname(), c.getFontsize()), font: new asc.FontProperties(c.getFontname(), c.getFontsize()),
...@@ -10515,10 +10470,57 @@ ...@@ -10515,10 +10470,57 @@
isAddPersentFormat: isQuickInput && c_oAscNumFormatType.Percent === c.getNumFormat().getType(), isAddPersentFormat: isQuickInput && c_oAscNumFormatType.Percent === c.getNumFormat().getType(),
autoComplete: arrAutoComplete, autoComplete: arrAutoComplete,
autoCompleteLC: arrAutoCompleteLC, autoCompleteLC: arrAutoCompleteLC,
saveValueCallback: function (val, flags, skipNLCheck) { saveValueCallback: function(val, flags, skipNLCheck) {
var oCellEdit = isMerged ? new asc_Range(mc.c1, mc.r1, mc.c1, mc.r1) : new asc_Range(col, row, col, row); var oCellEdit = isMerged ? new asc_Range(mc.c1, mc.r1, mc.c1, mc.r1) : new asc_Range(col, row, col, row);
return t._saveCellValueAfterEdit(oCellEdit, c, val, flags, return t._saveCellValueAfterEdit(oCellEdit, c, val, flags, skipNLCheck, /*isNotHistory*/false, /*lockDraw*/false);
skipNLCheck, /*isNotHistory*/false, /*lockDraw*/false); },
getSides: function() {
var _col = !isMerged ? col : mc.c1;
var _row = !isMerged ? row : mc.r2;
var vro = getVisibleRangeObject();
var i, w, h, arrLeftS = [], arrRightS = [], arrBottomS = [];
var offsX = tc[vro.vr.c1].left - tc[0].left - vro.offsetX;
var offsY = tr[vro.vr.r1].top - tr[0].top - vro.offsetY;
var cellX = tc[_col].left - offsX, cellY = tr[!isMerged ? row : mc.r1].top - offsY;
for (i = _col; i >= vro.vr.c1; --i) {
if (t.width_1px < tc[i].width) {
arrLeftS.push(tc[i].left - offsX);
}
}
arrLeftS.sort(fSortDescending);
// Для замерженных ячеек, можем уйти за границу
if (isMerged && _col > vro.vr.c2) {
_col = vro.vr.c2;
}
for (i = _col; i <= vro.vr.c2; ++i) {
w = tc[i].width;
if (t.width_1px < w) {
arrRightS.push(tc[i].left + w - offsX);
}
}
w = t.drawingCtx.getWidth();
if (arrRightS[arrRightS.length - 1] > w) {
arrRightS[arrRightS.length - 1] = w;
}
arrRightS.sort(fSortAscending);
// Для замерженных ячеек, можем уйти за границу
if (isMerged && _row > vro.vr.r2) {
_row = vro.vr.r2;
}
for (i = _row; i <= vro.vr.r2; ++i) {
h = tr[i].height;
if (t.height_1px < h) {
arrBottomS.push(tr[i].top + h - offsY);
}
}
h = t.drawingCtx.getHeight();
if (arrBottomS[arrBottomS.length - 1] > h) {
arrBottomS[arrBottomS.length - 1] = h;
}
arrBottomS.sort(fSortAscending);
return {l: arrLeftS, r: arrRightS, b: arrBottomS, cellX: cellX, cellY: cellY};
} }
}); });
return true; return true;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment