Commit 826f44e4 authored by GoshaZotov's avatar GoshaZotov

fix bug 32645 - MS Excel считает книгу поврежденной после применения...

fix bug 32645  -   MS Excel считает книгу поврежденной после применения сортировки по столбцу со спарклайнами в некоторых книгах и экспорта в XLSX
parent 6c2e7683
......@@ -5005,7 +5005,7 @@ TablePart.prototype.generateTotalsRowLabel = function()
}
this.TableColumns[0].generateTotalsRowLabel();
this.TableColumns[this.TableColumns.length - 1].generateTotalsRowFunction();
this.TableColumns[this.TableColumns.length - 1].generateTotalsRowFunction(this);
};
TablePart.prototype.changeDisplayName = function(newName)
......@@ -5021,6 +5021,17 @@ TablePart.prototype.getRangeWithoutHeaderFooter = function()
return Asc.Range(this.Ref.c1, startRow, this.Ref.c2, endRow);
};
TablePart.prototype.checkTotalRowFormula = function()
{
if(this.TotalsRowCount)
{
for(var i = 0; i < this.TableColumns.length; i++)
{
this.TableColumns[i].checkTotalRowFormula(this);
}
}
};
/** @constructor */
function AutoFilter() {
this.Ref = null;
......@@ -5270,11 +5281,12 @@ TableColumn.prototype.generateTotalsRowLabel = function(){
this.TotalsRowLabel = "Summary";
}
};
TableColumn.prototype.generateTotalsRowFunction = function(){
TableColumn.prototype.generateTotalsRowFunction = function(tablePart){
//TODO добавить в перевод
if(this.TotalsRowFunction === null)
{
this.TotalsRowFunction = Asc.ETotalsRowFunction.totalrowfunctionSum;
this.TotalsRowFunction = Asc.ETotalsRowFunction.totalrowfunctionCustom;
this.TotalsRowFormula = "SUBTOTAL(109," + tablePart.DisplayName + "[" + this.Name + "])";
}
};
......@@ -5287,10 +5299,12 @@ TableColumn.prototype.getTotalRowFormula = function(tablePart){
{
case Asc.ETotalsRowFunction.totalrowfunctionAverage:
{
res = "SUBTOTAL(101," + tablePart.DisplayName + "[" + this.Name + "])";
break;
}
case Asc.ETotalsRowFunction.totalrowfunctionCount:
{
res = "SUBTOTAL(103," + tablePart.DisplayName + "[" + this.Name + "])";
break;
}
case Asc.ETotalsRowFunction.totalrowfunctionCountNums:
......@@ -5299,14 +5313,17 @@ TableColumn.prototype.getTotalRowFormula = function(tablePart){
}
case Asc.ETotalsRowFunction.totalrowfunctionCustom:
{
res = this.TotalsRowFormula;
break;
}
case Asc.ETotalsRowFunction.totalrowfunctionMax:
{
res = "SUBTOTAL(104," + tablePart.DisplayName + "[" + this.Name + "])";
break;
}
case Asc.ETotalsRowFunction.totalrowfunctionMin:
{
res = "SUBTOTAL(105," + tablePart.DisplayName + "[" + this.Name + "])";
break;
}
case Asc.ETotalsRowFunction.totalrowfunctionNone:
......@@ -5315,23 +5332,21 @@ TableColumn.prototype.getTotalRowFormula = function(tablePart){
}
case Asc.ETotalsRowFunction.totalrowfunctionStdDev:
{
res = "SUBTOTAL(107," + tablePart.DisplayName + "[" + this.Name + "])";
break;
}
case Asc.ETotalsRowFunction.totalrowfunctionSum:
{
res = "=SUBTOTAL(109;" + tablePart.DisplayName + "[" + this.Name + "]";
res = "SUBTOTAL(109," + tablePart.DisplayName + "[" + this.Name + "])";
break;
}
case Asc.ETotalsRowFunction.totalrowfunctionVar:
{
res = "SUBTOTAL(110," + tablePart.DisplayName + "[" + this.Name + "])";
break;
}
}
}
else if(null !== this.TotalsRowFormula)
{
res = this.TotalsRowFormula;
}
return res;
};
......@@ -5360,6 +5375,19 @@ TableColumn.prototype.setTotalsRowLabel = function(val){
this.TotalsRowLabel = val;
};
TableColumn.prototype.checkTotalRowFormula = function(tablePart){
if(null !== this.TotalsRowFunction && Asc.ETotalsRowFunction.totalrowfunctionCustom !== this.TotalsRowFunction)
{
var totalRowFormula = this.getTotalRowFormula(tablePart);
if(null !== totalRowFormula)
{
this.TotalsRowFormula = totalRowFormula;
this.TotalsRowFunction = Asc.ETotalsRowFunction.totalrowfunctionCustom;
}
}
};
/** @constructor */
function TableStyleInfo() {
this.Name = null;
......
......@@ -4265,7 +4265,7 @@
var formula = tableColumn.getTotalRowFormula(options);
if(null !== formula)
{
range.setValue(formula);
range.setValue("=" + formula, null, true);
if(isSetTotalRowType)
{
var numFormatType = this._getFormatTableColumnRange(options, tableColumn.Name);
......
......@@ -12428,7 +12428,9 @@
{
for(var i = 0; i < tableParts.length; i++)
{
this.model.autoFilters._setColorStyleTable(worksheet.TableParts[i].Ref, worksheet.TableParts[i]);
this.model.autoFilters._setColorStyleTable(tableParts[i].Ref, tableParts[i]);
//TODO пока заменяем при открытии на TotalsRowFormula
tableParts[i].checkTotalRowFormula();
}
}
......
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