Commit af6f7da3 authored by Igor.Zotov's avatar Igor.Zotov

http://bugzserver/show_bug.cgi?id=28357 - открытие / применение а/ф

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@61739 954022d7-b5bf-4e40-9824-e11837661b57
parent 0977de02
...@@ -2631,6 +2631,21 @@ var gUndoInsDelCellsFlag = true; ...@@ -2631,6 +2631,21 @@ var gUndoInsDelCellsFlag = true;
currentFilter = aWs.TableParts[filtersOp[0]]; currentFilter = aWs.TableParts[filtersOp[0]];
ref = aWs.TableParts[filtersOp[0]].AutoFilter.Ref; ref = aWs.TableParts[filtersOp[0]].AutoFilter.Ref;
} }
var oldFilter = currentFilter.clone(aWs);
var filterRange = ref;
if(ref)
{
//в случае а/ф находим последнюю точку со значением
if(currentFilter.TableStyleInfo === undefined)
{
var endRow = this._getEndValueRow(ref);
filterRange = filterRange.clone();
filterRange.r2 = endRow;
}
}
//проходим от начала до конца диапазона данного фильтра //проходим от начала до конца диапазона данного фильтра
var startIdCell = currentFilter.result[filtersOp[1]].id; var startIdCell = currentFilter.result[filtersOp[1]].id;
...@@ -2641,7 +2656,7 @@ var gUndoInsDelCellsFlag = true; ...@@ -2641,7 +2656,7 @@ var gUndoInsDelCellsFlag = true;
var isMerged = startRange.hasMerged(); var isMerged = startRange.hasMerged();
var startCell = this._idToRange(startIdCell); var startCell = this._idToRange(startIdCell);
if(isMerged && startCell.c1 != isMerged.c1 && ref && ref.containsRange(isMerged)) if(isMerged && startCell.c1 != isMerged.c1 && filterRange && filterRange.containsRange(isMerged))
{ {
var endCell = this._idToRange(endIdCell); var endCell = this._idToRange(endIdCell);
var diff = startCell.c1 - isMerged.c1; var diff = startCell.c1 - isMerged.c1;
...@@ -2664,19 +2679,20 @@ var gUndoInsDelCellsFlag = true; ...@@ -2664,19 +2679,20 @@ var gUndoInsDelCellsFlag = true;
var n = 0; var n = 0;
//проверка на спец. символы //проверка на спец. символы
//this._isSpecValueCustomFilter(conFilter); //this._isSpecValueCustomFilter(conFilter);
for(var i = startRange.first.row; i < endRange.first.row; i++) for(var i = filterRange.r1 + 1; i <= filterRange.r2; i++)
{ {
var cell = ws.model.getCell3(i,startRange.first.col - 1); var cell = ws.model.getCell3(i, filterRange.c1);
var val = cell.getValue(); var val = cell.getValue();
var type = cell.getType(); var type = cell.getType();
var valWithFormat = cell.getValueWithFormat(); var valWithFormat = cell.getValueWithFormat();
arrayFil[n] = this._getLogical(conFilter,{type: type, val: val, valWithFormat: valWithFormat}); arrayFil[n] = this._getLogical(conFilter,{type: type, val: val, valWithFormat: valWithFormat});
var isHidden = this._isHiddenAnotherFilter(conFilter.cellId,i,currentFilter.Ref); var isHidden = this._isHiddenAnotherFilter(conFilter.cellId, i, filterRange);
if(isHidden != undefined) if(isHidden != undefined)
arrayFil[n] = isHidden; arrayFil[n] = isHidden;
n++; n++;
} }
var oldFilter = currentFilter.clone(aWs);
currentFilter.Ref = filterRange;
//**добавляем данные в aWs.AutoFilter или aWs.TableParts** //**добавляем данные в aWs.AutoFilter или aWs.TableParts**
this._addCustomFilters(filtersOp,aWs,conFilter,isMerged); this._addCustomFilters(filtersOp,aWs,conFilter,isMerged);
...@@ -2727,7 +2743,7 @@ var gUndoInsDelCellsFlag = true; ...@@ -2727,7 +2743,7 @@ var gUndoInsDelCellsFlag = true;
c1: activeCells.c1, c1: activeCells.c1,
r2: activeCells.r1, r2: activeCells.r1,
c2: activeCells.c1 c2: activeCells.c1
}; }
//**получаем нужный фильтр** //**получаем нужный фильтр**
var indexFilter = this._findArrayFromAllFilter3(newAcCells,cellId); var indexFilter = this._findArrayFromAllFilter3(newAcCells,cellId);
...@@ -2759,7 +2775,19 @@ var gUndoInsDelCellsFlag = true; ...@@ -2759,7 +2775,19 @@ var gUndoInsDelCellsFlag = true;
var oldFilter = filterObj.clone(aWs); var oldFilter = filterObj.clone(aWs);
var cell = ws.model.getCell3(activeCells.r1, activeCells.c1); var cell = ws.model.getCell3(activeCells.r1, activeCells.c1);
var filterRange = ref; var filterRange = ref;
if(ref && true !== customFilter)
{
//в случае а/ф находим последнюю точку со значением
if(currentFilter.TableStyleInfo === undefined)
{
var endRow = this._getEndValueRow(ref);
filterRange = filterRange.clone();
filterRange.r2 = endRow;
filterObj.Ref = filterRange;
}
}
var rangeStart = filterRange; var rangeStart = filterRange;
if(newAcCells.c1 == (rangeStart.c1 + parseInt(filtersOp[1]))) if(newAcCells.c1 == (rangeStart.c1 + parseInt(filtersOp[1])))
...@@ -4427,8 +4455,20 @@ var gUndoInsDelCellsFlag = true; ...@@ -4427,8 +4455,20 @@ var gUndoInsDelCellsFlag = true;
_getOpenAndClosedValues: function(numFilter, currentFilter, opFil, buttonId) _getOpenAndClosedValues: function(numFilter, currentFilter, opFil, buttonId)
{ {
var isFilterCol = false, idDigitalFilter = false, result = [], ws = this.worksheet; var isFilterCol = false, idDigitalFilter = false, result = [], ws = this.worksheet;
//находим стартовую и конечную строку а/ф
if(currentFilter && currentFilter.Ref)
{
var startRow = currentFilter.Ref.r1;
var endRow = currentFilter.Ref.r2;
//в случае а/ф находим последнюю точку со значением
if(currentFilter.TableStyleInfo === undefined)
{
endRow = this._getEndValueRow(currentFilter.Ref);
}
}
for(var fN = 0; fN < opFil.length; fN++) for(var fN = 0; fN < opFil.length; fN++)
{ {
var curFilter = opFil[fN]; var curFilter = opFil[fN];
...@@ -4458,8 +4498,6 @@ var gUndoInsDelCellsFlag = true; ...@@ -4458,8 +4498,6 @@ var gUndoInsDelCellsFlag = true;
if(sb && sb == numFilter) if(sb && sb == numFilter)
numFilter = curFilter.ColId; numFilter = curFilter.ColId;
var startRow = ws.model.getCell(new CellAddress(acCell.id)).first.row - 1;
var endRow = ws.model.getCell(new CellAddress(acCell.idNext)).first.row - 1;
var col = ws.model.getCell(new CellAddress(acCell.id)).first.col - 1; var col = ws.model.getCell(new CellAddress(acCell.id)).first.col - 1;
var visible; var visible;
for(var nRow = startRow + 1; nRow <= endRow; nRow++) for(var nRow = startRow + 1; nRow <= endRow; nRow++)
...@@ -4611,8 +4649,7 @@ var gUndoInsDelCellsFlag = true; ...@@ -4611,8 +4649,7 @@ var gUndoInsDelCellsFlag = true;
} }
if(sb && sb == numFilter) if(sb && sb == numFilter)
numFilter = curFilter.ColId; numFilter = curFilter.ColId;
var startRow = ws.model.getCell(new CellAddress(acCell.id)).first.row - 1;
var endRow = ws.model.getCell(new CellAddress(acCell.idNext)).first.row - 1;
var col = ws.model.getCell(new CellAddress(acCell.id)).first.col - 1; var col = ws.model.getCell(new CellAddress(acCell.id)).first.col - 1;
for(nRow = startRow + 1; nRow <= endRow; nRow++) for(nRow = startRow + 1; nRow <= endRow; nRow++)
{ {
...@@ -4667,8 +4704,7 @@ var gUndoInsDelCellsFlag = true; ...@@ -4667,8 +4704,7 @@ var gUndoInsDelCellsFlag = true;
//пересматриваем все значения //пересматриваем все значения
var nC = 0; var nC = 0;
var acCell = currentFilter.result[curFilter.ColId]; var acCell = currentFilter.result[curFilter.ColId];
var startRow = ws.model.getCell(new CellAddress(acCell.id)).first.row - 1;
var endRow = ws.model.getCell(new CellAddress(acCell.idNext)).first.row - 1;
var col = ws.model.getCell(new CellAddress(acCell.id)).first.col - 1; var col = ws.model.getCell(new CellAddress(acCell.id)).first.col - 1;
var top10Arr = []; var top10Arr = [];
for(nRow = startRow + 1; nRow <= endRow; nRow++) for(nRow = startRow + 1; nRow <= endRow; nRow++)
...@@ -4770,11 +4806,8 @@ var gUndoInsDelCellsFlag = true; ...@@ -4770,11 +4806,8 @@ var gUndoInsDelCellsFlag = true;
var col = ws.model.getCell(new CellAddress(buttonId)).first.col - 1; var col = ws.model.getCell(new CellAddress(buttonId)).first.col - 1;
var startRow = rangeFilter.r1 + 1;
var endRow = rangeFilter.r2;
var nC = 0; var nC = 0;
for(var s = startRow; s <= endRow; s++) for(var s = startRow + 1; s <= endRow; s++)
{ {
var cell = ws.model.getCell3(s,col); var cell = ws.model.getCell3(s,col);
if(!result[nC]) if(!result[nC])
...@@ -4810,6 +4843,47 @@ var gUndoInsDelCellsFlag = true; ...@@ -4810,6 +4843,47 @@ var gUndoInsDelCellsFlag = true;
return result; return result;
}, },
//находим непустые ячейки под данным фильтром
_getEndValueRow: function(ref)
{
var ws = this.worksheet;
var aWs = this._getCurrentWS();
var r2 = ref.r2;
var aGCells = aWs.aGCells;
var result = r2;
var isEnd = false;
if(aWs.nRowsCount - 1 > r2)
{
for(var i = r2 + 1; i <= aWs.nRowsCount; i++)
{
if(aGCells[i])
{
for(var j = ref.c1; j <= ref.c2; j++)
{
if(aGCells[i].c[j] && aGCells[i].c[j].oValue && false === aGCells[i].c[j].oValue.isEmpty())
{
result++;
break;
}
else if(j === ref.c2)
{
isEnd = true;
break;
}
}
}
else
break;
if(isEnd)
break;
}
}
return result;
},
_addNewFilter: function(val, tableColumns, aWs, isAll, style, bWithoutFilter) _addNewFilter: function(val, tableColumns, aWs, isAll, style, bWithoutFilter)
{ {
var newFilter, ref; var newFilter, ref;
......
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