Commit 878147ee authored by Igor.Zotov's avatar Igor.Zotov Committed by Alexander.Trofimov

http://bugzserver/show_bug.cgi?id=30092 - Не происходит обновление канвы после...

http://bugzserver/show_bug.cgi?id=30092 - Не происходит обновление канвы после применения Delete/Insert Cells к одной из форматированных таблиц

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@64415 954022d7-b5bf-4e40-9824-e11837661b57
parent a62bcacf
...@@ -1307,6 +1307,7 @@ var maxIndividualValues = 10000; ...@@ -1307,6 +1307,7 @@ var maxIndividualValues = 10000;
var DeleteColumns = ((insertType == c_oAscDeleteOptions.DeleteColumns && type == 'delCell') || insertType == c_oAscInsertOptions.InsertColumns) ? true : false; var DeleteColumns = ((insertType == c_oAscDeleteOptions.DeleteColumns && type == 'delCell') || insertType == c_oAscInsertOptions.InsertColumns) ? true : false;
activeRange = activeRange.clone(); activeRange = activeRange.clone();
var diff = activeRange.c2 - activeRange.c1 + 1; var diff = activeRange.c2 - activeRange.c1 + 1;
var redrawTablesArr = [];
if(type === "delCell") if(type === "delCell")
diff = - diff; diff = - diff;
...@@ -1319,6 +1320,22 @@ var maxIndividualValues = 10000; ...@@ -1319,6 +1320,22 @@ var maxIndividualValues = 10000;
History.StartTransaction(); History.StartTransaction();
History.Create_NewPoint(); History.Create_NewPoint();
var cleanStylesTables = function(redrawTablesArr)
{
for(var i = 0; i < redrawTablesArr.length; i++)
{
t._cleanStyleTable(redrawTablesArr[i].oldfilterRef);
}
};
var setStylesTables = function(redrawTablesArr)
{
for(var i = 0; i < redrawTablesArr.length; i++)
{
t._setColorStyleTable(redrawTablesArr[i].newFilter.Ref, redrawTablesArr[i].newFilter, null, true);
}
};
var changeFilter = function(filter, bTablePart) var changeFilter = function(filter, bTablePart)
{ {
var ref = filter.Ref; var ref = filter.Ref;
...@@ -1413,10 +1430,7 @@ var maxIndividualValues = 10000; ...@@ -1413,10 +1430,7 @@ var maxIndividualValues = 10000;
//set style //set style
if(oldFilter && bTablePart) if(oldFilter && bTablePart)
{ redrawTablesArr.push({oldfilterRef: oldFilter.Ref, newFilter: filter});
t._cleanStyleTable(oldFilter.Ref);
t._setColorStyleTable(filter.Ref, filter, null, true);
}
} }
}; };
...@@ -1430,6 +1444,11 @@ var maxIndividualValues = 10000; ...@@ -1430,6 +1444,11 @@ var maxIndividualValues = 10000;
for(var i = 0; i < tableParts.length; i++) for(var i = 0; i < tableParts.length; i++)
changeFilter(tableParts[i], true); changeFilter(tableParts[i], true);
//set styles for tables
cleanStylesTables(redrawTablesArr);
setStylesTables(redrawTablesArr);
History.EndTransaction(); History.EndTransaction();
}, },
...@@ -1442,6 +1461,7 @@ var maxIndividualValues = 10000; ...@@ -1442,6 +1461,7 @@ var maxIndividualValues = 10000;
var DeleteRows = ((insertType == c_oAscDeleteOptions.DeleteRows && type == 'delCell') || insertType == c_oAscInsertOptions.InsertRows) ? true : false; var DeleteRows = ((insertType == c_oAscDeleteOptions.DeleteRows && type == 'delCell') || insertType == c_oAscInsertOptions.InsertRows) ? true : false;
activeRange = activeRange.clone(); activeRange = activeRange.clone();
var diff = activeRange.r2 - activeRange.r1 + 1; var diff = activeRange.r2 - activeRange.r1 + 1;
var redrawTablesArr = [];
if(type === "delCell") if(type === "delCell")
diff = - diff; diff = - diff;
...@@ -1454,7 +1474,23 @@ var maxIndividualValues = 10000; ...@@ -1454,7 +1474,23 @@ var maxIndividualValues = 10000;
History.StartTransaction(); History.StartTransaction();
History.Create_NewPoint(); History.Create_NewPoint();
var cleanStylesTables = function(redrawTablesArr)
{
for(var i = 0; i < redrawTablesArr.length; i++)
{
t._cleanStyleTable(redrawTablesArr[i].oldfilterRef);
}
};
var setStylesTables = function(redrawTablesArr)
{
for(var i = 0; i < redrawTablesArr.length; i++)
{
t._setColorStyleTable(redrawTablesArr[i].newFilter.Ref, redrawTablesArr[i].newFilter, null, true);
}
};
var changeFilter = function(filter, bTablePart) var changeFilter = function(filter, bTablePart)
{ {
var ref = filter.Ref; var ref = filter.Ref;
...@@ -1485,11 +1521,9 @@ var maxIndividualValues = 10000; ...@@ -1485,11 +1521,9 @@ var maxIndividualValues = 10000;
t._addHistoryObj(changeElement, historyitem_AutoFilter_Change, null, true, oldFilter.Ref, null, true); t._addHistoryObj(changeElement, historyitem_AutoFilter_Change, null, true, oldFilter.Ref, null, true);
} }
//set style
if(oldFilter && bTablePart) if(oldFilter && bTablePart)
{ redrawTablesArr.push({oldfilterRef: oldFilter.Ref, newFilter: filter});
t._cleanStyleTable(oldFilter.Ref);
t._setColorStyleTable(filter.Ref, filter, null, true);
}
}; };
//change autoFilter //change autoFilter
...@@ -1501,6 +1535,10 @@ var maxIndividualValues = 10000; ...@@ -1501,6 +1535,10 @@ var maxIndividualValues = 10000;
for(var i = 0; i < tableParts.length; i++) for(var i = 0; i < tableParts.length; i++)
changeFilter(tableParts[i], true); changeFilter(tableParts[i], true);
//set styles for tables
cleanStylesTables(redrawTablesArr);
setStylesTables(redrawTablesArr);
History.EndTransaction(); History.EndTransaction();
}, },
......
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