Commit e018f763 authored by GoshaZotov's avatar GoshaZotov

add function af_checkInsDelCells(check range before ins/del cells)

parent c662c9e3
...@@ -1922,6 +1922,31 @@ var maxIndividualValues = 10000; ...@@ -1922,6 +1922,31 @@ var maxIndividualValues = 10000;
return result; return result;
}, },
getTableIntersectionRange: function(range)
{
var worksheet = this.worksheet;
var res = null;
var tableParts = worksheet.TableParts;
if(tableParts)
{
for(var i = 0; i < tableParts.length; i++)
{
if(tableParts[i].Ref.intersection(range))
{
if(res === null)
{
res = [];
}
res.push(worksheet.TableParts[i]);
}
}
}
return res;
},
changeFormatTableInfo: function(tablePart, optionType) changeFormatTableInfo: function(tablePart, optionType)
{ {
switch(optionType) switch(optionType)
...@@ -3825,21 +3850,6 @@ var maxIndividualValues = 10000; ...@@ -3825,21 +3850,6 @@ var maxIndividualValues = 10000;
return res; return res;
}, },
_isIntersectionTableParts: function(range)
{
var worksheet = this.worksheet;
var tableParts = worksheet.TableParts;
var tablePart;
for(var i = 0; i < tableParts.length; i++)
{
tablePart = tableParts[i];
if(tablePart.Ref.intersection(range))
return true;
}
return false;
},
_cleanFilterColumnsAndSortState: function(autoFilterElement, activeCells) _cleanFilterColumnsAndSortState: function(autoFilterElement, activeCells)
{ {
var worksheet = this.worksheet; var worksheet = this.worksheet;
...@@ -4001,17 +4011,17 @@ var maxIndividualValues = 10000; ...@@ -4001,17 +4011,17 @@ var maxIndividualValues = 10000;
var tableRef = worksheet.TableParts[i].Ref; var tableRef = worksheet.TableParts[i].Ref;
if(tableRef.r1 >= range.r2) if(tableRef.r1 >= range.r2)
{ {
if(range.c1 < tableRef.c1 && range.c2 < tableRef.c2 && range.c2 >= tableRef.c1) if(tableRef.c1 < range.c1 && tableRef.c2 > range.c1 && tableRef.c2 <= range.c2)
{ {
result = true; result = true;
break; break;
} }
else if(range.c1 > tableRef.c1 && range.c2 > tableRef.c2 && range.c1 >= tableRef.c1) else if(tableRef.c1 >= range.c1 && tableRef.c1 < range.c2 && tableRef.c2 > range.c2)
{ {
result = true; result = true;
break; break;
} }
else if((range.c1 > tableRef.c1 && range.c2 <= tableRef.c2) || (range.c1 >= tableRef.c1 && range.c2 < tableRef.c2)) else if((tableRef.c1 <= range.c1 && tableRef.c2 > range.c2) || (tableRef.c1 < range.c1 && tableRef.c2 >= range.c2))
{ {
result = true; result = true;
break; break;
...@@ -4023,6 +4033,41 @@ var maxIndividualValues = 10000; ...@@ -4023,6 +4033,41 @@ var maxIndividualValues = 10000;
return result; return result;
}, },
isPartTablePartsRightRange: function(range)
{
var worksheet = this.worksheet;
var res = false;
if(worksheet.TableParts && worksheet.TableParts.length)
{
for(var i = 0; i < worksheet.TableParts.length; i++)
{
var tableRef = worksheet.TableParts[i].Ref;
if(tableRef.c1 >= range.c2)
{
if(tableRef.r1 < range.r1 && tableRef.r2 > range.r1 && tableRef.r2 <= range.r2)
{
result = true;
break;
}
else if(tableRef.r1 >= range.r1 && tableRef.r1 < range.r2 && tableRef.r2 > range.r2)
{
result = true;
break;
}
else if((tableRef.r1 <= range.r1 && tableRef.r2 > range.r2) || (tableRef.r1 < range.r1 && tableRef.r2 >= range.r2))
{
result = true;
break;
}
}
}
}
return res;
},
_isPartAutoFilterUnderRange: function(range) _isPartAutoFilterUnderRange: function(range)
{ {
var worksheet = this.worksheet; var worksheet = this.worksheet;
......
...@@ -10313,7 +10313,7 @@ ...@@ -10313,7 +10313,7 @@
range = t.model.getRange3( arn.r1, arn.c1, arn.r2, arn.c2 ); range = t.model.getRange3( arn.r1, arn.c1, arn.r2, arn.c2 );
switch ( val ) { switch ( val ) {
case c_oAscInsertOptions.InsertCellsAndShiftRight: case c_oAscInsertOptions.InsertCellsAndShiftRight:
isCheckChangeAutoFilter = t.model.autoFilters.isActiveCellsCrossHalfFTable( arn, c_oAscInsertOptions.InsertCellsAndShiftRight, prop ); isCheckChangeAutoFilter = t.af_checkInsDelCells( arn, c_oAscInsertOptions.InsertCellsAndShiftRight, prop );
if ( isCheckChangeAutoFilter === false ) { if ( isCheckChangeAutoFilter === false ) {
return; return;
} }
...@@ -10334,7 +10334,7 @@ ...@@ -10334,7 +10334,7 @@
this._isLockedCells( oChangeData.changedRange, null, onChangeWorksheetCallback ); this._isLockedCells( oChangeData.changedRange, null, onChangeWorksheetCallback );
break; break;
case c_oAscInsertOptions.InsertCellsAndShiftDown: case c_oAscInsertOptions.InsertCellsAndShiftDown:
isCheckChangeAutoFilter = t.model.autoFilters.isActiveCellsCrossHalfFTable( arn, c_oAscInsertOptions.InsertCellsAndShiftDown, prop ); isCheckChangeAutoFilter = t.af_checkInsDelCells( arn, c_oAscInsertOptions.InsertCellsAndShiftDown, prop );
if ( isCheckChangeAutoFilter === false ) { if ( isCheckChangeAutoFilter === false ) {
return; return;
} }
...@@ -10393,7 +10393,7 @@ ...@@ -10393,7 +10393,7 @@
range = t.model.getRange3( checkRange.r1, checkRange.c1, checkRange.r2, checkRange.c2 ); range = t.model.getRange3( checkRange.r1, checkRange.c1, checkRange.r2, checkRange.c2 );
switch ( val ) { switch ( val ) {
case c_oAscDeleteOptions.DeleteCellsAndShiftLeft: case c_oAscDeleteOptions.DeleteCellsAndShiftLeft:
isCheckChangeAutoFilter = t.model.autoFilters.isActiveCellsCrossHalfFTable( arn, c_oAscDeleteOptions.DeleteCellsAndShiftLeft, prop ); isCheckChangeAutoFilter = t.af_checkInsDelCells( arn, c_oAscDeleteOptions.DeleteCellsAndShiftLeft, prop );
if ( isCheckChangeAutoFilter === false ) { if ( isCheckChangeAutoFilter === false ) {
return; return;
} }
...@@ -10418,7 +10418,7 @@ ...@@ -10418,7 +10418,7 @@
this._isLockedCells( oChangeData.changedRange, null, onChangeWorksheetCallback ); this._isLockedCells( oChangeData.changedRange, null, onChangeWorksheetCallback );
break; break;
case c_oAscDeleteOptions.DeleteCellsAndShiftTop: case c_oAscDeleteOptions.DeleteCellsAndShiftTop:
isCheckChangeAutoFilter = t.model.autoFilters.isActiveCellsCrossHalfFTable( arn, c_oAscDeleteOptions.DeleteCellsAndShiftTop, prop ); isCheckChangeAutoFilter = t.af_checkInsDelCells( arn, c_oAscDeleteOptions.DeleteCellsAndShiftTop, prop );
if ( isCheckChangeAutoFilter === false ) { if ( isCheckChangeAutoFilter === false ) {
return; return;
} }
...@@ -12810,7 +12810,7 @@ ...@@ -12810,7 +12810,7 @@
{ {
var t = this; var t = this;
var ws = this.model; var ws = this.model;
var acitveRange = this.activeRange.clone(); var acitveRange = this.activeRange;
var tablePart = ws.autoFilters._getFilterByDisplayName(tableName); var tablePart = ws.autoFilters._getFilterByDisplayName(tableName);
...@@ -12824,37 +12824,51 @@ ...@@ -12824,37 +12824,51 @@
var startRow = this.activeRange.r1; var startRow = this.activeRange.r1;
var endRow = this.activeRange.r2; var endRow = this.activeRange.r2;
var newActiveRange = null; var newActiveRange = this.activeRange.clone();
var val; var val = null;
switch(optionType) switch(optionType)
{ {
case c_oAscInsertOptions.InsertTableRowAbove: case c_oAscInsertOptions.InsertTableRowAbove:
{ {
newActiveRange = new Asc.Range(tablePart.Ref.c1, startRow, tablePart.Ref.c2, endRow); newActiveRange.c1 = tablePart.Ref.c1;
newActiveRange.c2 = tablePart.Ref.c2;
val = c_oAscInsertOptions.InsertCellsAndShiftDown; val = c_oAscInsertOptions.InsertCellsAndShiftDown;
break; break;
} }
case c_oAscInsertOptions.InsertTableRowBelow: case c_oAscInsertOptions.InsertTableRowBelow:
{ {
newActiveRange = new Asc.Range(tablePart.Ref.c1, startRow - 1, tablePart.Ref.c2, endRow - 1); newActiveRange.c1 = tablePart.Ref.c1;
newActiveRange.c2 = tablePart.Ref.c2;
newActiveRange.r1 = startRow + (endRow - startRow) + 1;
newActiveRange.r2 = endRow + (endRow - startRow) + 1;
val = c_oAscInsertOptions.InsertCellsAndShiftDown; val = c_oAscInsertOptions.InsertCellsAndShiftDown;
break; break;
} }
case c_oAscInsertOptions.InsertTableColLeft: case c_oAscInsertOptions.InsertTableColLeft:
{ {
newActiveRange = new Asc.Range(startCol - 1, tablePart.Ref.r1, endCol - 1, tablePart.Ref.r2); newActiveRange.c1 = startCol - 1;
newActiveRange.c2 = endCol - 1;
newActiveRange.r1 = tablePart.Ref.r1;
newActiveRange.r2 = tablePart.Ref.r2;
val = c_oAscInsertOptions.InsertCellsAndShiftRight; val = c_oAscInsertOptions.InsertCellsAndShiftRight;
break; break;
} }
case c_oAscInsertOptions.InsertTableColRight: case c_oAscInsertOptions.InsertTableColRight:
{ {
newActiveRange = new Asc.Range(startCol, tablePart.Ref.r1, endCol, tablePart.Ref.r2); newActiveRange = new Asc.Range(startCol, tablePart.Ref.r1, endCol, tablePart.Ref.r2);
newActiveRange.r1 = tablePart.Ref.r1;
newActiveRange.r2 = tablePart.Ref.r2;
val = c_oAscInsertOptions.InsertCellsAndShiftRight; val = c_oAscInsertOptions.InsertCellsAndShiftRight;
break; break;
} }
} }
if(newActiveRange !== null) if(val !== null)
{ {
t.activeRange = newActiveRange; t.activeRange = newActiveRange;
t.changeWorksheet("insCell", val); t.changeWorksheet("insCell", val);
...@@ -12884,16 +12898,16 @@ ...@@ -12884,16 +12898,16 @@
var val; var val;
switch(optionType) switch(optionType)
{ {
case c_oAscInsertOptions.DeleteColumns: case c_oAscDeleteOptions.DeleteColumns:
{ {
newActiveRange = new Asc.Range(startCol, tablePart.Ref.r1, endCol, tablePart.Ref.r2); newActiveRange = new Asc.Range(startCol, tablePart.Ref.r1, endCol, tablePart.Ref.r2);
val = c_oAscInsertOptions.DeleteCellsAndShiftLeft; val = c_oAscDeleteOptions.DeleteCellsAndShiftLeft;
break; break;
} }
case c_oAscInsertOptions.DeleteRows: case c_oAscDeleteOptions.DeleteRows:
{ {
newActiveRange = new Asc.Range(tablePart.Ref.c1, startRow, tablePart.Ref.c2, endRow); newActiveRange = new Asc.Range(tablePart.Ref.c1, startRow, tablePart.Ref.c2, endRow);
val = c_oAscInsertOptions.DeleteCellsAndShiftTop; val = c_oAscDeleteOptions.DeleteCellsAndShiftTop;
break; break;
} }
case c_oAscInsertOptions.DeleteTable: case c_oAscInsertOptions.DeleteTable:
...@@ -12927,6 +12941,103 @@ ...@@ -12927,6 +12941,103 @@
//TODO тестовый вариант. нужно сделать методы и добавлять в историю //TODO тестовый вариант. нужно сделать методы и добавлять в историю
tablePart.DisplayName = newName; tablePart.DisplayName = newName;
}; };
WorksheetView.prototype.af_checkInsDelCells = function(activeRange, val, prop)
{
var t = this;
var ws = this.model;
var res = true;
var intersectionTableParts = ws.autoFilters.getTableIntersectionRange(activeRange);
var isPartTablePartsUnderRange = ws.autoFilters._isPartTablePartsUnderRange(activeRange);
var isPartTablePartsRightRange = ws.autoFilters.isPartTablePartsRightRange(activeRange);
var isOneTableIntersection = intersectionTableParts && intersectionTableParts.length === 1 ? intersectionTableParts[0] : null;
var checkInsCells = function()
{
switch(val)
{
case c_oAscInsertOptions.InsertCellsAndShiftDown:
{
//если внизу находится часть форматированной таблицы или это часть форматированной таблицы
if(isPartTablePartsUnderRange)
{
res = false;
}
else if(isOneTableIntersection !== null && !(isOneTableIntersection.Ref.c1 === activeRange.c1 && isOneTableIntersection.Ref.c2 === activeRange.c2))
{
res = false;
}
break;
}
case c_oAscInsertOptions.InsertCellsAndShiftRight:
{
//если справа находится часть форматированной таблицы или это часть форматированной таблицы
if(isPartTablePartsRightRange)
{
res = false;
}
break;
}
case c_oAscInsertOptions.InsertColumns:
{
break;
}
case c_oAscInsertOptions.InsertRows:
{
break;
}
}
};
var checkDelCells = function()
{
switch(val)
{
case c_oAscDeleteOptions.DeleteCellsAndShiftTop:
{
if(isPartTablePartsUnderRange)
{
res = false;
}
break;
}
case c_oAscDeleteOptions.DeleteCellsAndShiftLeft:
{
if(isPartTablePartsUnderRange)
{
res = false;
}
break;
}
case c_oAscDeleteOptions.DeleteColumns:
{
break;
}
case c_oAscDeleteOptions.DeleteRows:
{
break;
}
}
};
prop === "insCell" ? checkInsCells() : checkDelCells();
if(res === false)
{
ws.workbook.handlers.trigger("asc_onError", c_oAscError.ID.AutoFilterChangeFormatTableError, c_oAscError.Level.NoCritical);
}
return res;
};
/* /*
* Export * Export
* ----------------------------------------------------------------------------- * -----------------------------------------------------------------------------
......
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