Commit d6a63849 authored by Alexander.Trofimov's avatar Alexander.Trofimov

fix formula mode (in cell editor)

parent be4d574e
...@@ -211,6 +211,7 @@ ...@@ -211,6 +211,7 @@
this.r2 = r2; this.r2 = r2;
this.refType1 = referenceType.R; this.refType1 = referenceType.R;
this.refType2 = referenceType.R; this.refType2 = referenceType.R;
this.type = c_oAscSelectionType.RangeCells;
return normalize ? this.normalize() : this; return normalize ? this.normalize() : this;
} }
...@@ -233,6 +234,7 @@ ...@@ -233,6 +234,7 @@
var oRes = new Range(this.c1, this.r1, this.c2, this.r2, normalize); var oRes = new Range(this.c1, this.r1, this.c2, this.r2, normalize);
oRes.refType1 = this.refType1; oRes.refType1 = this.refType1;
oRes.refType2 = this.refType2; oRes.refType2 = this.refType2;
oRes.type = this.type;
return oRes; return oRes;
}; };
......
...@@ -789,16 +789,17 @@ ...@@ -789,16 +789,17 @@
}; };
CellEditor.prototype._parseRangeStr = function (s) { CellEditor.prototype._parseRangeStr = function (s) {
var range = AscCommonExcel.g_oRangeCache.getActiveRange(s); //var range = AscCommonExcel.g_oRangeCache.getActiveRange(s);
var range = AscCommonExcel.g_oRangeCache.getAscRange(s);
return range ? range.clone() : null; return range ? range.clone() : null;
}; };
CellEditor.prototype._parseFormulaRanges = function () { CellEditor.prototype._parseFormulaRanges = function () {
var s = this._getFragmentsText( this.options.fragments ), t = this, ret = false, range, var s = this._getFragmentsText(
wsOPEN = this.handlers.trigger( "getCellFormulaEnterWSOpen" ), this.options.fragments), t = this, ret = false, range, wsOPEN = this.handlers.trigger(
ws = wsOPEN ? wsOPEN.model : this.handlers.trigger( "getActiveWS" ); "getCellFormulaEnterWSOpen"), ws = wsOPEN ? wsOPEN.model : this.handlers.trigger("getActiveWS");
if ( s.length < 1 || s.charAt( 0 ) !== "=" || this.options.cellNumFormat == Asc.c_oAscNumFormatType.Text ) { if (s.length < 1 || s.charAt(0) !== "=" || this.options.cellNumFormat == Asc.c_oAscNumFormatType.Text) {
return ret; return ret;
} }
...@@ -822,14 +823,13 @@ ...@@ -822,14 +823,13 @@
// var __e__ = new Date().getTime(); // var __e__ = new Date().getTime();
// console.log("e-s "+ (__e__ - __s__)); // console.log("e-s "+ (__e__ - __s__));
this._formula = new AscCommonExcel.parserFormula( s.substr( 1 ), this.options.cellName, ws ); this._formula = new AscCommonExcel.parserFormula(s.substr(1), this.options.cellName, ws);
this._formula.parse(); this._formula.parse();
var r, offset, _e, _s, wsName = null, refStr, isName = false, var r, offset, _e, _s, wsName = null, refStr, isName = false, _sColorPos;
_sColorPos;
if ( this._formula.RefPos && this._formula.RefPos.length > 0 ) { if (this._formula.RefPos && this._formula.RefPos.length > 0) {
for ( var index = 0; index < this._formula.RefPos.length; index++ ) { for (var index = 0; index < this._formula.RefPos.length; index++) {
wsName = null; wsName = null;
isName = false; isName = false;
r = this._formula.RefPos[index]; r = this._formula.RefPos[index];
...@@ -839,18 +839,16 @@ ...@@ -839,18 +839,16 @@
_sColorPos = _s = r.start; _sColorPos = _s = r.start;
switch ( r.oper.type ) { switch (r.oper.type) {
case cElementType.cell : case cElementType.cell : {
{ if (wsOPEN) {
if ( wsOPEN ) {
wsName = wsOPEN.model.getName(); wsName = wsOPEN.model.getName();
} }
ret = true; ret = true;
refStr = r.oper.value; refStr = r.oper.value;
break; break;
} }
case cElementType.cell3D : case cElementType.cell3D : {
{
ret = true; ret = true;
wsName = r.oper.ws.getName(); wsName = r.oper.ws.getName();
_s = _e - r.oper.value.length; _s = _e - r.oper.value.length;
...@@ -858,18 +856,16 @@ ...@@ -858,18 +856,16 @@
refStr = r.oper.value; refStr = r.oper.value;
break; break;
} }
case cElementType.cellsRange : case cElementType.cellsRange : {
{ if (wsOPEN) {
if ( wsOPEN ) {
wsName = wsOPEN.model.getName(); wsName = wsOPEN.model.getName();
} }
ret = true; ret = true;
refStr = r.oper.value; refStr = r.oper.value;
break; break;
} }
case cElementType.cellsRange3D : case cElementType.cellsRange3D : {
{ if (!r.oper.isSingleSheet()) {
if ( !r.oper.isSingleSheet() ) {
continue; continue;
} }
ret = true; ret = true;
...@@ -880,20 +876,20 @@ ...@@ -880,20 +876,20 @@
break; break;
} }
case cElementType.table : case cElementType.table :
case cElementType.name : case cElementType.name : {
{
var nameRef = r.oper.toRef(); var nameRef = r.oper.toRef();
if( nameRef instanceof AscCommonExcel.cError ) continue; if (nameRef instanceof AscCommonExcel.cError) {
switch ( nameRef.type ) { continue;
}
switch (nameRef.type) {
case cElementType.cellsRange3D :{ case cElementType.cellsRange3D : {
if ( !nameRef.isSingleSheet() ) { if (!nameRef.isSingleSheet()) {
continue; continue;
} }
} }
case cElementType.cellsRange : case cElementType.cellsRange :
case cElementType.cell3D : case cElementType.cell3D : {
{
ret = true; ret = true;
refStr = nameRef.value; refStr = nameRef.value;
wsName = nameRef.getWS().getName(); wsName = nameRef.getWS().getName();
...@@ -908,15 +904,19 @@ ...@@ -908,15 +904,19 @@
continue; continue;
} }
if ( ret ) { if (ret) {
range = t._parseRangeStr( refStr ); range = t._parseRangeStr(refStr);
if(!range) return false; if (!range) {
return false;
}
range.cursorePos = offset - (_e - _s) + 1; range.cursorePos = offset - (_e - _s) + 1;
range.formulaRangeLength = _e - _s; range.formulaRangeLength = _e - _s;
range.colorRangePos = offset - (_e - _sColorPos) + 1; range.colorRangePos = offset - (_e - _sColorPos) + 1;
range.colorRangeLength = _e - _sColorPos; range.colorRangeLength = _e - _sColorPos;
if ( isName )range.isName = isName; if (isName) {
t.handlers.trigger( "newRange", range, wsName ); range.isName = isName;
}
t.handlers.trigger("newRange", range, wsName);
} }
} }
} }
...@@ -924,7 +924,7 @@ ...@@ -924,7 +924,7 @@
}; };
CellEditor.prototype._findRangeUnderCursor = function () { CellEditor.prototype._findRangeUnderCursor = function () {
var t = this, s = t.textRender.getChars(0, t.textRender.getCharsCount()), range, arrFR = this.handlers.trigger( var ranges, t = this, s = t.textRender.getChars(0, t.textRender.getCharsCount()), range, arrFR = this.handlers.trigger(
"getFormulaRanges"), a; "getFormulaRanges"), a;
for (var id = 0; id < arrFR.length; id++) { for (var id = 0; id < arrFR.length; id++) {
...@@ -932,13 +932,16 @@ ...@@ -932,13 +932,16 @@
* находится ли курсор в позиции над этим диапазоном, дабы не парсить всю формулу заново * находится ли курсор в позиции над этим диапазоном, дабы не парсить всю формулу заново
* необходимо чтобы парсить случаи когда используется что-то такое sumnas2:K2 - sumnas2 невалидная ссылка. * необходимо чтобы парсить случаи когда используется что-то такое sumnas2:K2 - sumnas2 невалидная ссылка.
* */ * */
a = arrFR[id]; ranges = arrFR[id].ranges;
for (var i = 0, l = ranges.length; i < l; ++i) {
a = ranges[i];
if (t.cursorPos >= a.cursorePos && t.cursorPos <= a.cursorePos + a.formulaRangeLength) { if (t.cursorPos >= a.cursorePos && t.cursorPos <= a.cursorePos + a.formulaRangeLength) {
range = a.clone(true); range = a.clone(true);
range.isName = a.isName; range.isName = a.isName;
return {index: a.cursorePos, length: a.formulaRangeLength, range: range}; return {index: a.cursorePos, length: a.formulaRangeLength, range: range};
} }
} }
}
/*не нашли диапазонов под курсором, парсим формулу*/ /*не нашли диапазонов под курсором, парсим формулу*/
var r, offset, _e, _s, wsName = null, ret = false, refStr, isName = false, _sColorPos, wsOPEN = this.handlers.trigger( var r, offset, _e, _s, wsName = null, ret = false, refStr, isName = false, _sColorPos, wsOPEN = this.handlers.trigger(
...@@ -1026,7 +1029,7 @@ ...@@ -1026,7 +1029,7 @@
if (this.handlers.trigger("getActiveWS") && this.handlers.trigger("getActiveWS").getName() != wsName) { if (this.handlers.trigger("getActiveWS") && this.handlers.trigger("getActiveWS").getName() != wsName) {
return {index: -1, length: 0, range: null}; return {index: -1, length: 0, range: null};
} }
range.isName = isName range.isName = isName;
return {index: _s, length: r.oper.value.length, range: range, wsName: wsName}; return {index: _s, length: r.oper.value.length, range: range, wsName: wsName};
} }
} }
...@@ -1070,33 +1073,36 @@ ...@@ -1070,33 +1073,36 @@
}; };
CellEditor.prototype._getRenderFragments = function () { CellEditor.prototype._getRenderFragments = function () {
var opt = this.options, fragments = opt.fragments, i, j, first, last, val, lengthColors, tmpColors, colorIndex, uniqueColorIndex; var opt = this.options, fragments = opt.fragments, ranges, i, j, k, l, first, last, val, lengthColors, tmpColors, colorIndex, uniqueColorIndex;
if ( this.isFormula() ) { if (this.isFormula()) {
var arrRanges = this.handlers.trigger( "getFormulaRanges" ); var arrRanges = this.handlers.trigger("getFormulaRanges");
if ( 0 < arrRanges.length ) { if (0 < arrRanges.length) {
fragments = []; fragments = [];
for ( i = 0; i < opt.fragments.length; ++i ) for (i = 0; i < opt.fragments.length; ++i) {
fragments.push( opt.fragments[i].clone() ); fragments.push(opt.fragments[i].clone());
}
lengthColors = AscCommonExcel.c_oAscFormulaRangeBorderColor.length; lengthColors = AscCommonExcel.c_oAscFormulaRangeBorderColor.length;
tmpColors = []; tmpColors = [];
uniqueColorIndex = 0; uniqueColorIndex = 0;
for ( i = 0; i < arrRanges.length; ++i ) { for (i = 0; i < arrRanges.length; ++i) {
val = arrRanges[i]; ranges = arrRanges[i].ranges;
for (j = 0, l = ranges.length; j < l; ++j) {
colorIndex = asc.getUniqueRangeColor( arrRanges, i, tmpColors ); val = ranges[j];
if ( null == colorIndex ) { colorIndex = asc.getUniqueRangeColor(ranges, j, tmpColors);
if (null == colorIndex) {
colorIndex = uniqueColorIndex++; colorIndex = uniqueColorIndex++;
} }
tmpColors.push( colorIndex ); tmpColors.push(colorIndex);
this._extractFragments( val.colorRangePos, val.colorRangeLength, fragments );
first = this._findFragment( val.cursorePos, fragments ); this._extractFragments(val.colorRangePos, val.colorRangeLength, fragments);
last = this._findFragment( val.cursorePos + val.formulaRangeLength - 1, fragments ); first = this._findFragment(val.cursorePos, fragments);
if ( first && last ) { last = this._findFragment(val.cursorePos + val.formulaRangeLength - 1, fragments);
for ( j = first.index; j <= last.index; ++j ) if (first && last) {
fragments[j].format.c = AscCommonExcel.c_oAscFormulaRangeBorderColor[colorIndex % lengthColors]; for (k = first.index; k <= last.index; ++k) {
fragments[k].format.c = AscCommonExcel.c_oAscFormulaRangeBorderColor[colorIndex % lengthColors];
}
}
} }
} }
} }
...@@ -1835,18 +1841,18 @@ ...@@ -1835,18 +1841,18 @@
} }
}; };
CellEditor.prototype._findFragment = function ( pos, fragments ) { CellEditor.prototype._findFragment = function (pos, fragments) {
var i, begin, end; var i, begin, end;
if ( !fragments ) { if (!fragments) {
fragments = this.options.fragments; fragments = this.options.fragments;
} }
for ( i = 0, begin = 0; i < fragments.length; ++i ) { for (i = 0, begin = 0; i < fragments.length; ++i) {
end = begin + fragments[i].text.length; end = begin + fragments[i].text.length;
if ( pos >= begin && pos < end ) { if (pos >= begin && pos < end) {
return {index: i, begin: begin, end: end}; return {index: i, begin: begin, end: end};
} }
if ( i < fragments.length - 1 ) { if (i < fragments.length - 1) {
begin = end; begin = end;
} }
} }
...@@ -1917,20 +1923,20 @@ ...@@ -1917,20 +1923,20 @@
return res; return res;
}; };
CellEditor.prototype._extractFragments = function ( startPos, length, fragments ) { CellEditor.prototype._extractFragments = function (startPos, length, fragments) {
var fr; var fr;
fr = this._findFragment( startPos, fragments ); fr = this._findFragment(startPos, fragments);
if ( !fr ) { if (!fr) {
throw "Can not extract fragment of text"; throw "Can not extract fragment of text";
} }
this._splitFragment( fr, startPos, fragments ); this._splitFragment(fr, startPos, fragments);
fr = this._findFragment( startPos + length, fragments ); fr = this._findFragment(startPos + length, fragments);
if ( !fr ) { if (!fr) {
throw "Can not extract fragment of text"; throw "Can not extract fragment of text";
} }
this._splitFragment( fr, startPos + length, fragments ); this._splitFragment(fr, startPos + length, fragments);
}; };
CellEditor.prototype._addFragments = function ( f, pos ) { CellEditor.prototype._addFragments = function ( f, pos ) {
......
...@@ -1263,6 +1263,11 @@ ...@@ -1263,6 +1263,11 @@
} }
}; };
WorksheetView.prototype._getSelection = function () {
return (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] :
this.model.selectionRange;
};
WorksheetView.prototype._fixVisibleRange = function ( range ) { WorksheetView.prototype._fixVisibleRange = function ( range ) {
var tmp; var tmp;
if ( null !== this.topLeftFrozenCell ) { if ( null !== this.topLeftFrozenCell ) {
...@@ -3833,21 +3838,23 @@ ...@@ -3833,21 +3838,23 @@
}; };
WorksheetView.prototype._drawFormulaRanges = function (arrRanges) { WorksheetView.prototype._drawFormulaRanges = function (arrRanges) {
var i, length = AscCommonExcel.c_oAscFormulaRangeBorderColor.length; var i, ranges, length = AscCommonExcel.c_oAscFormulaRangeBorderColor.length;
var strokeColor, colorIndex, uniqueColorIndex = 0, tmpColors = []; var strokeColor, colorIndex, uniqueColorIndex = 0, tmpColors = [];
for (i = 0; i < arrRanges.length; ++i) { for (i = 0; i < arrRanges.length; ++i) {
var oFormulaRange = arrRanges[i].clone(true); ranges = arrRanges[i].ranges;
colorIndex = asc.getUniqueRangeColor(arrRanges, i, tmpColors); for (var j = 0, l = ranges.length; j < l; ++j) {
colorIndex = asc.getUniqueRangeColor(ranges, j, tmpColors);
if (null == colorIndex) { if (null == colorIndex) {
colorIndex = uniqueColorIndex++; colorIndex = uniqueColorIndex++;
} }
tmpColors.push(colorIndex); tmpColors.push(colorIndex);
strokeColor = AscCommonExcel.c_oAscFormulaRangeBorderColor[colorIndex % length]; strokeColor = AscCommonExcel.c_oAscFormulaRangeBorderColor[colorIndex % length];
this._drawElements(this._drawSelectionElement, oFormulaRange,
AscCommonExcel.selectionLineType.Selection | (arrRanges[i].isName ? AscCommonExcel.selectionLineType.None : this._drawElements(this._drawSelectionElement, ranges[j],
AscCommonExcel.selectionLineType.Selection | (ranges[j].isName ? AscCommonExcel.selectionLineType.None :
AscCommonExcel.selectionLineType.Resize), strokeColor); AscCommonExcel.selectionLineType.Resize), strokeColor);
} }
}
}; };
WorksheetView.prototype._drawSelectRange = function () { WorksheetView.prototype._drawSelectRange = function () {
...@@ -4042,28 +4049,24 @@ ...@@ -4042,28 +4049,24 @@
if (0 < this.arrActiveFormulaRanges.length) { if (0 < this.arrActiveFormulaRanges.length) {
for (i = 0; i < this.arrActiveFormulaRanges.length; ++i) { for (i = 0; i < this.arrActiveFormulaRanges.length; ++i) {
var activeFormula = this.arrActiveFormulaRanges[i].clone(true); this.arrActiveFormulaRanges[i].ranges.forEach(function (item) {
var arnIntersection = item.intersectionSimple(range);
activeFormula = activeFormula.intersection(range); if (arnIntersection) {
if (null === activeFormula) { _x1 = t.cols[arnIntersection.c1].left - offsetX - t.width_3px;
// это ссылка из формулы на еще не добавленный рэндж _x2 = arnIntersection.c2 > t.cols.length ? width :
continue; t.cols[arnIntersection.c2].left + t.cols[arnIntersection.c2].width - offsetX + t.width_1px +
} t.width_2px;
_y1 = t.rows[arnIntersection.r1].top - offsetY - t.height_3px;
// Координаты для range формулы _y2 = arnIntersection.r2 > t.rows.length ? height : t.rows[arnIntersection.r2].top + t.rows[arnIntersection.r2].height - offsetY +
_x1 = this.cols[activeFormula.c1].left - offsetX - this.width_3px; t.height_1px + t.height_2px;
_x2 = activeFormula.c2 > this.cols.length ? width :
this.cols[activeFormula.c2].left + this.cols[activeFormula.c2].width - offsetX + this.width_3px;
_y1 = this.rows[activeFormula.r1].top - offsetY - this.height_3px;
_y2 = activeFormula.r2 > this.rows.length ? height :
this.rows[activeFormula.r2].top + this.rows[activeFormula.r2].height - offsetY + this.height_3px;
// Выбираем наибольший range для очистки
x1 = Math.min(x1, _x1); x1 = Math.min(x1, _x1);
x2 = Math.max(x2, _x2); x2 = Math.max(x2, _x2);
y1 = Math.min(y1, _y1); y1 = Math.min(y1, _y1);
y2 = Math.max(y2, _y2); y2 = Math.max(y2, _y2);
} }
});
}
// Вышли из редактора, очистим массив // Вышли из редактора, очистим массив
//TODO: Нужно ли очищать массив ячеек из формулы в отрисовке??? //TODO: Нужно ли очищать массив ячеек из формулы в отрисовке???
...@@ -6044,8 +6047,7 @@ ...@@ -6044,8 +6047,7 @@
var targetArr = this.isFormulaEditMode ? 0 : -1; var targetArr = this.isFormulaEditMode ? 0 : -1;
for (i = 0, l = arrRanges.length; i < l; ++i) { for (i = 0, l = arrRanges.length; i < l; ++i) {
oFormulaRange = arrRanges[i].clone(true); oFormulaRange = arrRanges[i].getLast();
oFormulaRange.isName = arrRanges[i].isName;
res = !oFormulaRange.isName && res = !oFormulaRange.isName &&
this._hitInRange(oFormulaRange, AscCommonExcel.selectionLineType.Resize, vr, x, y, offsetX, offsetY); this._hitInRange(oFormulaRange, AscCommonExcel.selectionLineType.Resize, vr, x, y, offsetX, offsetY);
if (res) { if (res) {
...@@ -6396,10 +6398,8 @@ ...@@ -6396,10 +6398,8 @@
}; };
WorksheetView.prototype._fixSelectionOfMergedCells = function (fixedRange) { WorksheetView.prototype._fixSelectionOfMergedCells = function (fixedRange) {
var ar = fixedRange ? fixedRange : var tmpSelection = this._getSelection();
((this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] : var ar = fixedRange ? fixedRange : tmpSelection.getLast();
this.model.selectionRange.getLast());
if (!ar) { if (!ar) {
return; return;
} }
...@@ -6420,7 +6420,9 @@ ...@@ -6420,7 +6420,9 @@
} }
ar.r2 = ar.r1 === res.r1 ? res.r2 : res.r1; ar.r2 = ar.r1 === res.r1 ? res.r2 : res.r1;
ar.normalize(); ar.normalize();
this.model.selectionRange.update(); if (!fixedRange) {
tmpSelection.update();
}
}; };
WorksheetView.prototype._findVisibleCol = function (from, dc, flag) { WorksheetView.prototype._findVisibleCol = function (from, dc, flag) {
...@@ -6502,8 +6504,7 @@ ...@@ -6502,8 +6504,7 @@
WorksheetView.prototype._moveActiveCellToXY = function (x, y) { WorksheetView.prototype._moveActiveCellToXY = function (x, y) {
var c, r; var c, r;
var ar = (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] : var ar = this._getSelection().getLast();
this.model.selectionRange.getLast();
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());
...@@ -6544,9 +6545,9 @@ ...@@ -6544,9 +6545,9 @@
}; };
WorksheetView.prototype._moveActiveCellToOffset = function (dc, dr) { WorksheetView.prototype._moveActiveCellToOffset = function (dc, dr) {
var ar = (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] : var tmpSelection = this._getSelection();
this.model.selectionRange.getLast(); var ar = tmpSelection.getLast();
var activeCell = this.model.selectionRange.activeCell; var activeCell = tmpSelection.activeCell;
var mc = this.model.getMergedByCell(activeCell.row, activeCell.col); var mc = this.model.getMergedByCell(activeCell.row, activeCell.col);
var c = mc ? (dc < 0 ? mc.c1 : dc > 0 ? Math.min(mc.c2, this.nColsCount - 1 - dc) : activeCell.col) : var c = mc ? (dc < 0 ? mc.c1 : dc > 0 ? Math.min(mc.c2, this.nColsCount - 1 - dc) : activeCell.col) :
activeCell.col; activeCell.col;
...@@ -6574,12 +6575,12 @@ ...@@ -6574,12 +6575,12 @@
}; };
WorksheetView.prototype._calcSelectionEndPointByXY = function (x, y) { WorksheetView.prototype._calcSelectionEndPointByXY = function (x, y) {
var ar = (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] : var tmpSelection = this._getSelection();
this.model.selectionRange.getLast(); var ar = tmpSelection.getLast();
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());
var res = new asc_Range(this.model.selectionRange.activeCell.col, this.model.selectionRange.activeCell.row, this._findColUnderCursor( var res = new asc_Range(tmpSelection.activeCell.col, tmpSelection.activeCell.row, this._findColUnderCursor(
x).col, this._findRowUnderCursor(y).row, true); x).col, this._findRowUnderCursor(y).row, true);
if (ar.type === c_oAscSelectionType.RangeCells) { if (ar.type === c_oAscSelectionType.RangeCells) {
this._fixSelectionOfMergedCells(res); this._fixSelectionOfMergedCells(res);
...@@ -6588,14 +6589,13 @@ ...@@ -6588,14 +6589,13 @@
}; };
WorksheetView.prototype._calcSelectionEndPointByOffset = function (dc, dr) { WorksheetView.prototype._calcSelectionEndPointByOffset = function (dc, dr) {
var ar = (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] : var tmpSelection = this._getSelection();
this.model.selectionRange.getLast(); var ar = tmpSelection.getLast();
var startCol = this.model.selectionRange.activeCell.col, startRow = this.model.selectionRange.activeCell.row;
var c1, r1, c2, r2, tmp; var c1, r1, c2, r2, tmp;
tmp = asc.getEndValueRange(dc, startCol, ar.c1, ar.c2); tmp = asc.getEndValueRange(dc, tmpSelection.activeCell.col, ar.c1, ar.c2);
c1 = tmp.x1; c1 = tmp.x1;
c2 = tmp.x2; c2 = tmp.x2;
tmp = asc.getEndValueRange(dr, startRow, ar.r1, ar.r2); tmp = asc.getEndValueRange(dr, tmpSelection.activeCell.row, ar.r1, ar.r2);
r1 = tmp.x1; r1 = tmp.x1;
r2 = tmp.x2; r2 = tmp.x2;
...@@ -6631,8 +6631,7 @@ ...@@ -6631,8 +6631,7 @@
}; };
WorksheetView.prototype._calcActiveRangeOffsetIsCoord = function (x, y) { WorksheetView.prototype._calcActiveRangeOffsetIsCoord = function (x, y) {
var ar = (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] : var ar = this._getSelection().getLast();
this.model.selectionRange.getLast();
if (this.isFormulaEditMode) { if (this.isFormulaEditMode) {
// Для формул нужно сделать ограничение по range (у нас хранится полный диапазон) // Для формул нужно сделать ограничение по range (у нас хранится полный диапазон)
if (ar.c2 >= this.nColsCount || ar.r2 >= this.nRowsCount) { if (ar.c2 >= this.nColsCount || ar.r2 >= this.nRowsCount) {
...@@ -6673,8 +6672,7 @@ ...@@ -6673,8 +6672,7 @@
WorksheetView.prototype._calcActiveRangeOffset = function () { WorksheetView.prototype._calcActiveRangeOffset = function () {
var vr = this.visibleRange; var vr = this.visibleRange;
var ar = (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] : var ar = this._getSelection().getLast();
this.model.selectionRange.getLast();
if (this.isFormulaEditMode) { if (this.isFormulaEditMode) {
// Для формул нужно сделать ограничение по range (у нас хранится полный диапазон) // Для формул нужно сделать ограничение по range (у нас хранится полный диапазон)
if (ar.c2 >= this.nColsCount || ar.r2 >= this.nRowsCount) { if (ar.c2 >= this.nColsCount || ar.r2 >= this.nRowsCount) {
...@@ -7346,8 +7344,7 @@ ...@@ -7346,8 +7344,7 @@
this.model.selectionRange.clean(); this.model.selectionRange.clean();
} }
} }
var ar = ((this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] : var ar = this._getSelection().getLast().clone();
this.model.selectionRange.getLast()).clone();
var ret = {}; var ret = {};
var isChangeSelectionShape = false; var isChangeSelectionShape = false;
...@@ -7486,9 +7483,7 @@ ...@@ -7486,9 +7483,7 @@
if (isCoord) { if (isCoord) {
isChangeSelectionShape = this._checkSelectionShape(); isChangeSelectionShape = this._checkSelectionShape();
} }
var lastActiveRange = this.model.selectionRange.getLast(); var ar = this._getSelection().getLast();
var ar = (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition] :
lastActiveRange;
var newRange = isCoord ? this._calcSelectionEndPointByXY(x, y) : this._calcSelectionEndPointByOffset(x, y); var newRange = isCoord ? this._calcSelectionEndPointByXY(x, y) : this._calcSelectionEndPointByOffset(x, y);
var isEqual = newRange.isEqual(ar); var isEqual = newRange.isEqual(ar);
...@@ -7519,8 +7514,8 @@ ...@@ -7519,8 +7514,8 @@
this.model.workbook.handlers.trigger("asc_onHideComment"); this.model.workbook.handlers.trigger("asc_onHideComment");
return isCoord ? this._calcActiveRangeOffsetIsCoord(x, y) : this._calcActiveRangeOffset( return isCoord ? this._calcActiveRangeOffsetIsCoord(x, y) : this._calcActiveRangeOffset(
this.getCellLeftRelative(x < 0 ? lastActiveRange.c1 : lastActiveRange.c2, /*pt*/0), this.getCellLeftRelative(x < 0 ? ar.c1 : ar.c2, /*pt*/0),
this.getCellTopRelative(y < 0 ? lastActiveRange.r1 : lastActiveRange.r2, /*pt*/0)); this.getCellTopRelative(y < 0 ? ar.r1 : ar.r2, /*pt*/0));
}; };
// Окончание выделения // Окончание выделения
...@@ -11335,41 +11330,53 @@ ...@@ -11335,41 +11330,53 @@
this.draw( lockDraw ); this.draw( lockDraw );
}; };
WorksheetView.prototype.enterCellRange = function ( editor ) { WorksheetView.prototype.enterCellRange = function (editor) {
if ( !this.isFormulaEditMode ) { if (!this.isFormulaEditMode) {
return; return;
} }
var currentRange = this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition].clone(); var currentFormula = this.arrActiveFormulaRanges[this.arrActiveFormulaRangesPosition];
var startCol = currentRange.startCol, startRow = currentRange.startRow; var currentRange = currentFormula.getLast().clone();
var activeCellId = currentFormula.activeCellId;
var activeCell = currentFormula.activeCell.clone();
// Замерженную ячейку должны отдать только левую верхнюю. // Замерженную ячейку должны отдать только левую верхнюю.
var mergedRange = this.model.getMergedByCell( currentRange.r1, currentRange.c1 ); var mergedRange = this.model.getMergedByCell(currentRange.r1, currentRange.c1);
if ( mergedRange && currentRange.isEqual( mergedRange ) ) { if (mergedRange && currentRange.isEqual(mergedRange)) {
currentRange.r2 = currentRange.r1; currentRange.r2 = currentRange.r1;
currentRange.c2 = currentRange.c1; currentRange.c2 = currentRange.c1;
} }
/* var defName = this.model.workbook.findDefinesNames(this.model.getName()+"!"+currentRange.getAbsName(),this.model.getId()); /* var defName = this.model.workbook.findDefinesNames(this.model.getName()+"!"+currentRange.getAbsName(),this.model.getId());
console.log("defName #2 " + defName);*/ console.log("defName #2 " + defName);*/
var sheetName = "", cFEWSO = editor.handlers.trigger( "getCellFormulaEnterWSOpen" ); var sheetName = "", cFEWSO = editor.handlers.trigger("getCellFormulaEnterWSOpen");
if( editor.formulaIsOperator() && cFEWSO && cFEWSO.model.getId() != this.model.getId() ){ if (editor.formulaIsOperator() && cFEWSO && cFEWSO.model.getId() != this.model.getId()) {
sheetName = parserHelp.getEscapeSheetName(this.model.getName())+"!"; sheetName = parserHelp.getEscapeSheetName(this.model.getName()) + "!";
} }
editor.enterCellRange( /*defName || */sheetName + currentRange.getAllRange().getName() ); editor.enterCellRange(/*defName || */sheetName + currentRange.getAllRange().getName());
for ( var tmpRange, i = 0; i < this.arrActiveFormulaRanges.length; ++i ) { for (var tmpRange, i = 0; i < this.arrActiveFormulaRanges.length; ++i) {
tmpRange = this.arrActiveFormulaRanges[i]; tmpRange = this.arrActiveFormulaRanges[i];
if ( tmpRange.isEqual( currentRange ) ) { if (tmpRange.getLast().isEqual(currentRange)) {
tmpRange.startCol = startCol; tmpRange.activeCellId = activeCellId;
tmpRange.startRow = startRow; tmpRange.activeCell.col = activeCell.col;
tmpRange.activeCell.row = activeCell.row;
break; break;
} }
} }
}; };
WorksheetView.prototype.addFormulaRange = function ( range ) { WorksheetView.prototype.addFormulaRange = function (range) {
var r = range !== undefined ? range : new asc_ActiveRange( this.activeRange.c1, this.activeRange.r1, this.activeRange.c2, this.activeRange.r2 ); var r = this.model.selectionRange.clone();
this.arrActiveFormulaRanges.push( r ); if (range) {
r.assign2(range);
var lastSelection = r.getLast();
lastSelection.cursorePos = range.cursorePos;
lastSelection.formulaRangeLength = range.formulaRangeLength;
lastSelection.colorRangePos = range.colorRangePos;
lastSelection.colorRangeLength = range.colorRangeLength;
lastSelection.isName = range.isName;
}
this.arrActiveFormulaRanges.push(r);
this.arrActiveFormulaRangesPosition = this.arrActiveFormulaRanges.length - 1; this.arrActiveFormulaRangesPosition = this.arrActiveFormulaRanges.length - 1;
this._fixSelectionOfMergedCells(); this._fixSelectionOfMergedCells();
}; };
...@@ -11377,7 +11384,7 @@ ...@@ -11377,7 +11384,7 @@
WorksheetView.prototype.activeFormulaRange = function (range) { WorksheetView.prototype.activeFormulaRange = function (range) {
this.arrActiveFormulaRangesPosition = -1; this.arrActiveFormulaRangesPosition = -1;
for (var i = 0; i < this.arrActiveFormulaRanges.length; ++i) { for (var i = 0; i < this.arrActiveFormulaRanges.length; ++i) {
if (this.arrActiveFormulaRanges[i].isEqual(range)) { if (this.arrActiveFormulaRanges[i].getLast().isEqual(range)) {
this.arrActiveFormulaRangesPosition = i; this.arrActiveFormulaRangesPosition = i;
return; return;
} }
...@@ -11386,7 +11393,7 @@ ...@@ -11386,7 +11393,7 @@
WorksheetView.prototype.removeFormulaRange = function (range) { WorksheetView.prototype.removeFormulaRange = function (range) {
this.arrActiveFormulaRangesPosition = -1; this.arrActiveFormulaRangesPosition = -1;
for (var i = 0; i < this.arrActiveFormulaRanges.length; ++i) { for (var i = 0; i < this.arrActiveFormulaRanges.length; ++i) {
if (this.arrActiveFormulaRanges[i].isEqual(range)) { if (this.arrActiveFormulaRanges[i].getLast().isEqual(range)) {
this.arrActiveFormulaRanges.splice(i, 1); this.arrActiveFormulaRanges.splice(i, 1);
return; return;
} }
......
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