Commit e90f3b3e authored by Alexander.Trofimov's avatar Alexander.Trofimov Committed by Alexander.Trofimov

Добавил в handlers WorksheetView onScroll для возможности проскроллить на...

Добавил в handlers WorksheetView onScroll для возможности проскроллить на нужную ячейку с синхронизацией scroll. Теперь при открытии не видимой ячейки на редактирование, мы ее покажем.
Баг http://bugzserver/show_bug.cgi?id=24272

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@57632 954022d7-b5bf-4e40-9824-e11837661b57
parent 9aaec35f
...@@ -254,7 +254,7 @@ ...@@ -254,7 +254,7 @@
}; };
/** /**
* @param delta {Object} * @param delta {{deltaX: number, deltaY: number}}
*/ */
asc_CEventsController.prototype.scroll = function (delta) { asc_CEventsController.prototype.scroll = function (delta) {
if (delta) { if (delta) {
......
...@@ -363,7 +363,8 @@ ...@@ -363,7 +363,8 @@
"onRenameCellTextEnd" : function (countFind, countReplace) {self.handlers.trigger("asc_onRenameCellTextEnd", countFind, countReplace);}, "onRenameCellTextEnd" : function (countFind, countReplace) {self.handlers.trigger("asc_onRenameCellTextEnd", countFind, countReplace);},
"onStopFormatPainter" : function () {self.handlers.trigger("asc_onStopFormatPainter");}, "onStopFormatPainter" : function () {self.handlers.trigger("asc_onStopFormatPainter");},
"onDocumentPlaceChanged" : function () {self._onDocumentPlaceChanged();}, "onDocumentPlaceChanged" : function () {self._onDocumentPlaceChanged();},
"updateSheetViewSettings" : function () {self.handlers.trigger("asc_onUpdateSheetViewSettings");} "updateSheetViewSettings" : function () {self.handlers.trigger("asc_onUpdateSheetViewSettings");},
"onScroll" : function (d) {self.controller.scroll(d);}
}); });
this.model.handlers.add("cleanCellCache", function (wsId, range, canChangeColWidth, bLockDraw) { this.model.handlers.add("cleanCellCache", function (wsId, range, canChangeColWidth, bLockDraw) {
......
...@@ -10417,13 +10417,13 @@ ...@@ -10417,13 +10417,13 @@
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, vr = t.visibleRange.clone(), tc = t.cols, tr = t.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 offsetX = 0, offsetY = 0;
var ar = t.activeRange; var ar = this.activeRange;
if (activeRange) if (activeRange)
t.activeRange = activeRange.clone(); this.activeRange = activeRange.clone();
if (t.objectRender.checkCursorDrawingObject(x, y)) if (this.objectRender.checkCursorDrawingObject(x, y))
return false; return false;
function getLeftSide(col) { function getLeftSide(col) {
...@@ -10474,10 +10474,10 @@ ...@@ -10474,10 +10474,10 @@
} }
if (isCoord) { if (isCoord) {
x *= asc_getcvt( 0/*px*/, 1/*pt*/, t._getPPIX() ); x *= asc_getcvt( 0/*px*/, 1/*pt*/, this._getPPIX() );
y *= asc_getcvt( 0/*px*/, 1/*pt*/, t._getPPIY() ); y *= asc_getcvt( 0/*px*/, 1/*pt*/, this._getPPIY() );
col = t._findColUnderCursor(x, true); col = this._findColUnderCursor(x, true);
row = t._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;
...@@ -10487,9 +10487,24 @@ ...@@ -10487,9 +10487,24 @@
} }
// Возможно стоит заменить на ячейку из кеша // Возможно стоит заменить на ячейку из кеша
c = t._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);
isMerged = fl.isMerged();
if (isMerged) {
mc = fl.merged;
c = this._getVisibleCell(mc.c1, mc.r1);
if (!c) {throw "Can not get merged cell data (col=" + mc.c1 + ", row=" + mc.r1 + ")";}
fl = this._getCellFlags(c);
}
// Выставляем режим 'не редактируем' (иначе мы попытаемся переместить редактор, который еще не открыт)
this.isCellEditMode = false;
this.handlers.trigger("onScroll", this._calcActiveCellOffset());
this.isCellEditMode = true;
vr = this.visibleRange.clone();
if (this.topLeftFrozenCell) { if (this.topLeftFrozenCell) {
var cFrozen = this.topLeftFrozenCell.getCol0(); var cFrozen = this.topLeftFrozenCell.getCol0();
var rFrozen = this.topLeftFrozenCell.getRow0(); var rFrozen = this.topLeftFrozenCell.getRow0();
...@@ -10511,44 +10526,10 @@ ...@@ -10511,44 +10526,10 @@
} }
} }
fl = t._getCellFlags(c);
isMerged = fl.isMerged();
if (isMerged) {
mc = fl.merged;
c = t._getVisibleCell(mc.c1, mc.r1);
if (!c) {throw "Can not get merged cell data (col=" + mc.c1 + ", row=" + mc.r1 + ")";}
fl = t._getCellFlags(c);
// Первую ячейку нужно сделать видимой
var bIsUpdateX = false;
var bIsUpdateY = false;
if (mc.c1 < vr.c1) {
t.visibleRange.c1 = vr.c1 = mc.c1;
bIsUpdateX = true;
t._calcVisibleColumns();
}
if (mc.r1 < vr.r1) {
t.visibleRange.r1 = vr.r1 = mc.r1;
bIsUpdateY = true;
t._calcVisibleRows();
}
if (bIsUpdateX && bIsUpdateY) {
this.handlers.trigger("reinitializeScroll");
} else if (bIsUpdateX) {
this.handlers.trigger("reinitializeScrollX");
} else if (bIsUpdateY) {
this.handlers.trigger("reinitializeScrollY");
}
if (bIsUpdateX || bIsUpdateY) {
t.draw();
}
}
bg = c.getFill(); bg = c.getFill();
t.isFormulaEditMode = false; this.isFormulaEditMode = false;
// Очищаем массив ячеек для текущей формулы // Очищаем массив ячеек для текущей формулы
t.arrActiveFormulaRanges = []; this.arrActiveFormulaRanges = [];
var oFontColor = c.getFontcolor(); var oFontColor = c.getFontcolor();
// Скрываем окно редактирования комментария // Скрываем окно редактирования комментария
...@@ -10565,18 +10546,18 @@ ...@@ -10565,18 +10546,18 @@
var arrAutoCompleteLC = asc.arrayToLowerCase(arrAutoComplete); var arrAutoCompleteLC = asc.arrayToLowerCase(arrAutoComplete);
editor.open({ editor.open({
cellX: t.cellsLeft + tc[!isMerged ? col : mc.c1].left - tc[vr.c1].left + offsetX, cellX: this.cellsLeft + tc[!isMerged ? col : mc.c1].left - tc[vr.c1].left + offsetX,
cellY: t.cellsTop + tr[!isMerged ? row : mc.r1].top - tr[vr.r1].top + offsetY, cellY: this.cellsTop + tr[!isMerged ? row : mc.r1].top - tr[vr.r1].top + offsetY,
leftSide: getLeftSide(!isMerged ? col : mc.c1), leftSide: getLeftSide(!isMerged ? col : mc.c1),
rightSide: getRightSide(!isMerged ? col : mc.c2), rightSide: getRightSide(!isMerged ? col : mc.c2),
bottomSide: getBottomSide(!isMerged ? row : mc.r2), bottomSide: getBottomSide(!isMerged ? row : mc.r2),
fragments: fragments, fragments: fragments,
flags: fl, flags: fl,
font: new asc_FP(c.getFontname(), c.getFontsize()), font: new asc_FP(c.getFontname(), c.getFontsize()),
background: bg || t.settings.cells.defaultState.background, background: bg || this.settings.cells.defaultState.background,
textColor: oFontColor || t.settings.cells.defaultState.color, textColor: oFontColor || this.settings.cells.defaultState.color,
cursorPos: cursorPos, cursorPos: cursorPos,
zoom: t.getZoom(), zoom: this.getZoom(),
focus: isFocus, focus: isFocus,
isClearCell: isClearCell, isClearCell: isClearCell,
isHideCursor: isHideCursor, isHideCursor: isHideCursor,
......
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