Commit 2ea5df30 authored by GoshaZotov's avatar GoshaZotov

add function for change format table ref(af_changeTableRange)

parent f792173c
......@@ -128,6 +128,7 @@ var historyitem_AutoFilter_ChangeTableStyle = 9;
var historyitem_AutoFilter_Change = 10;
var historyitem_AutoFilter_CleanFormat = 11;
var historyitem_AutoFilter_ChangeTableInfo = 12;
var historyitem_AutoFilter_ChangeTableRef = 13;
function CHistory(workbook)
......
......@@ -4502,6 +4502,47 @@ TablePart.prototype.changeRef = function(col, row, bIsFirst) {
if(this.AutoFilter)
this.AutoFilter.changeRef(col, row, bIsFirst);
};
TablePart.prototype.changeRefOnRange = function(range, autoFilters, generateNewTableColumns) {
if(!range)
return;
//add table columns
if(generateNewTableColumns)
{
var newTableColumns = [];
var intersectionRanges = this.Ref.intersection(range);
for(var i = range.c1; i <= range.c2; i++)
{
var tableColumn;
if(i >= intersectionRanges.c1 && i <= intersectionRanges.c2)
{
var tableIndex = i - this.Ref.c1;
tableColumn = this.TableColumns[tableIndex];
}
else
{
tableColumn = new TableColumn();
}
newTableColumns.push(tableColumn);
}
for(var j = 0; j < newTableColumns.length; j++)
{
if(newTableColumns[j].Name === null)
newTableColumns[j].Name = autoFilters._generateColumnName2(newTableColumns);
}
this.TableColumns = newTableColumns;
}
this.Ref = Asc.Range(range.c1, range.r1, range.c2, range.r2);
//event
this.handlers.trigger("changeRefTablePart", this.DisplayName, this.Ref);
if(this.AutoFilter)
this.AutoFilter.changeRefOnRange(range);
};
TablePart.prototype.isApplyAutoFilter = function() {
var res = false;
......@@ -4573,7 +4614,7 @@ TablePart.prototype.addTableColumns = function(activeRange, autoFilters)
for(var j = 0; j < newTableColumns.length; j++)
{
if(newTableColumns[j].Name === null)
newTableColumns[j].Name = autoFilters._generateColumnName2(newTableColumns, newTableColumns[j - 1].Name);
newTableColumns[j].Name = autoFilters._generateColumnName2(newTableColumns);
}
this.TableColumns = newTableColumns;
......@@ -4583,7 +4624,7 @@ TablePart.prototype.addTableLastColumn = function(activeRange, autoFilters, isAd
{
var newTableColumns = this.TableColumns;
newTableColumns.push(new TableColumn());
newTableColumns[newTableColumns.length - 1].Name = autoFilters._generateColumnName2(newTableColumns, newTableColumns[newTableColumns.length - 2].Name);
newTableColumns[newTableColumns.length - 1].Name = autoFilters._generateColumnName2(newTableColumns);
this.TableColumns = newTableColumns;
};
......@@ -4785,6 +4826,15 @@ AutoFilter.prototype.changeRef = function(col, row, bIsFirst) {
this.Ref = ref;
};
AutoFilter.prototype.changeRefOnRange = function(range) {
if(!range)
return;
this.Ref = Asc.Range(range.c1, range.r1, range.c2, range.r2);
if(this.AutoFilter)
this.AutoFilter.changeRefOnRange(range);
};
AutoFilter.prototype.isApplyAutoFilter = function() {
var res = false;
......
......@@ -744,6 +744,9 @@ var maxIndividualValues = 10000;
case historyitem_AutoFilter_ChangeTableInfo:
this.changeFormatTableInfo(data.displayName, data.type, data.val);
break;
case historyitem_AutoFilter_ChangeTableRef:
this.changeTableRange(data.displayName, data.moveTo);
break;
}
History.TurnOn();
},
......@@ -785,7 +788,7 @@ var maxIndividualValues = 10000;
else
worksheet.AutoFilter = cloneData;
}
else if(type === historyitem_AutoFilter_Change || type === historyitem_AutoFilter_ChangeTableInfo)//добавление/удаление строк/столбцов
else if(type === historyitem_AutoFilter_Change || type === historyitem_AutoFilter_ChangeTableInfo || type === historyitem_AutoFilter_ChangeTableRef)
{
if(worksheet.AutoFilter && cloneData.newFilterRef.isEqual(worksheet.AutoFilter.Ref))
worksheet.AutoFilter = cloneData.oldFilter.clone(null);
......@@ -2235,7 +2238,22 @@ var maxIndividualValues = 10000;
changeTableRange: function(tableName, range)
{
var tablePart = this._getFilterByDisplayName(tableName);
if(!tablePart)
{
return false;
}
var oldFilter = tablePart.clone(null);
tablePart.changeRefOnRange(range, this, true);
this._addHistoryObj({oldFilter: oldFilter, newFilterRef: tablePart.Ref.clone()}, historyitem_AutoFilter_ChangeTableRef,
{activeCells: tablePart.Ref.clone(), arnTo: range, displayName: tableName});
this._cleanStyleTable(oldFilter.Ref);
this._setColorStyleTable(tablePart.Ref, tablePart, null, true);
},
_clearRange: function(range, isClearText)
......@@ -4398,10 +4416,9 @@ var maxIndividualValues = 10000;
}
},
_generateColumnName2: function(tableColumns, prevColumnName)
_generateColumnName2: function(tableColumns)
{
var columnName = "Column";
var name = prevColumnName.split(columnName);
var indexColumn = name[1];
var nextIndex;
......
......@@ -13162,9 +13162,11 @@
{
History.Create_NewPoint();
History.StartTransaction();
range = Asc.g_oRangeCache.getAscRange(range);
this.model.autoFilters.changeTableRange(tableName, range);
//this._onUpdateFormatTable(isChangeRange, false, true);
this._onUpdateFormatTable(range, false, true);
//TODO добавить перерисовку таблицы и перерисовку шаблонов
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