Commit 4b083d78 authored by Igor.Zotov's avatar Igor.Zotov Committed by Alexander.Trofimov

http://bugzserver/show_bug.cgi?id=28357 - Отсутствует поддержка...

http://bugzserver/show_bug.cgi?id=28357 -  Отсутствует поддержка автоматического расширения диапазона автофильтра

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@64311 954022d7-b5bf-4e40-9824-e11837661b57
parent 8113ef50
...@@ -106,7 +106,8 @@ var maxIndividualValues = 10000; ...@@ -106,7 +106,8 @@ var maxIndividualValues = 10000;
var g_oAutoFiltersOptionsProperties = { var g_oAutoFiltersOptionsProperties = {
cellId : 0, cellId : 0,
values : 1, values : 1,
filter : 2 filter : 2,
automaticRowCount : 3
}; };
function AutoFiltersOptions () { function AutoFiltersOptions () {
...@@ -118,6 +119,7 @@ var maxIndividualValues = 10000; ...@@ -118,6 +119,7 @@ var maxIndividualValues = 10000;
this.values = null; this.values = null;
this.filter = null; this.filter = null;
this.sortVal = null; this.sortVal = null;
this.automaticRowCount = null;
return this; return this;
} }
...@@ -135,6 +137,7 @@ var maxIndividualValues = 10000; ...@@ -135,6 +137,7 @@ var maxIndividualValues = 10000;
case this.Properties.cellId: return this.cellId; break; case this.Properties.cellId: return this.cellId; break;
case this.Properties.values: return this.values; break; case this.Properties.values: return this.values; break;
case this.Properties.filter: return this.filter; break; case this.Properties.filter: return this.filter; break;
case this.Properties.automaticRowCount: return this.automaticRowCount; break;
} }
return null; return null;
...@@ -144,6 +147,7 @@ var maxIndividualValues = 10000; ...@@ -144,6 +147,7 @@ var maxIndividualValues = 10000;
case this.Properties.cellId: this.cellId = value;break; case this.Properties.cellId: this.cellId = value;break;
case this.Properties.values: this.values = value;break; case this.Properties.values: this.values = value;break;
case this.Properties.filter: this.filter = value;break; case this.Properties.filter: this.filter = value;break;
case this.Properties.automaticRowCount: this.automaticRowCount = value;break;
} }
}, },
...@@ -152,6 +156,7 @@ var maxIndividualValues = 10000; ...@@ -152,6 +156,7 @@ var maxIndividualValues = 10000;
asc_setFilterObj : function(filter) { this.filter = filter; }, asc_setFilterObj : function(filter) { this.filter = filter; },
asc_setSortState : function(sortVal) { this.sortVal = sortVal; }, asc_setSortState : function(sortVal) { this.sortVal = sortVal; },
asc_setAutomaticRowCount : function(val) { this.automaticRowCount = val; },
asc_getCellId : function() { return this.cellId; }, asc_getCellId : function() { return this.cellId; },
asc_getValues : function() { return this.values; }, asc_getValues : function() { return this.values; },
...@@ -524,6 +529,15 @@ var maxIndividualValues = 10000; ...@@ -524,6 +529,15 @@ var maxIndividualValues = 10000;
if(allFilterOpenElements) if(allFilterOpenElements)
autoFilter.FilterColumns.splice(filterObj.index, 1);//if all rows opened autoFilter.FilterColumns.splice(filterObj.index, 1);//if all rows opened
//автоматическое расширение диапазона а/ф
if(autoFiltersObject.automaticRowCount && filterObj.filter && filterObj.filter.Ref && filterObj.filter.getType() === g_nFiltersType.autoFilter)
{
var currentDiff = filterObj.filter.Ref.r2 - filterObj.filter.Ref.r1;
var newDiff = autoFiltersObject.automaticRowCount - filterObj.filter.Ref.r1;
if(newDiff > currentDiff)
filterObj.filter.changeRef(null, newDiff - currentDiff);
}
//open/close rows //open/close rows
if(!bUndoChanges && !bRedoChanges) if(!bUndoChanges && !bRedoChanges)
...@@ -696,7 +710,7 @@ var maxIndividualValues = 10000; ...@@ -696,7 +710,7 @@ var maxIndividualValues = 10000;
{ {
if(filter.FilterColumns[i].ColId === col - range.c1) if(filter.FilterColumns[i].ColId === col - range.c1)
{ {
if(filter.FilterColumns[i].ShowButton !== false) if(filter.FilterColumns[i].isApplyAutoFilter())
isSetFilter = true; isSetFilter = true;
else else
isShowButton = false; isShowButton = false;
...@@ -2828,7 +2842,7 @@ var maxIndividualValues = 10000; ...@@ -2828,7 +2842,7 @@ var maxIndividualValues = 10000;
}, },
//TODO пока включаю протестированную функцию. позже доработать функцию _getAdjacentCellsAF2, она работает быстрее! //TODO пока включаю протестированную функцию. позже доработать функцию _getAdjacentCellsAF2, она работает быстрее!
_getAdjacentCellsAF: function(ar, aWs) _getAdjacentCellsAF: function(ar, aWs, ignoreAutoFilter)
{ {
var ws = this.worksheet; var ws = this.worksheet;
var cloneActiveRange = ar.clone(true); // ToDo слишком много клонирования var cloneActiveRange = ar.clone(true); // ToDo слишком много клонирования
...@@ -2993,7 +3007,7 @@ var maxIndividualValues = 10000; ...@@ -2993,7 +3007,7 @@ var maxIndividualValues = 10000;
//var oldFilters = this.allAutoFilter; //var oldFilters = this.allAutoFilter;
var oldFilters =[]; var oldFilters =[];
if(aWs.AutoFilter) if(aWs.AutoFilter && !ignoreAutoFilter)
{ {
oldFilters[0] = aWs.AutoFilter oldFilters[0] = aWs.AutoFilter
} }
...@@ -3279,7 +3293,9 @@ var maxIndividualValues = 10000; ...@@ -3279,7 +3293,9 @@ var maxIndividualValues = 10000;
//get values //get values
var colId = filterProp.colId; var colId = filterProp.colId;
var values = this._getOpenAndClosedValues(autoFilter, colId); var openAndClosedValues = this._getOpenAndClosedValues(autoFilter, colId);
var values = openAndClosedValues.values;
var automaticRowCount = openAndClosedValues.automaticRowCount
var filters = this._getFilterColumn(autoFilter, colId); var filters = this._getFilterColumn(autoFilter, colId);
var rangeButton = Asc.Range(autoFilter.Ref.c1 + colId, autoFilter.Ref.r1, autoFilter.Ref.c1 + colId, autoFilter.Ref.r1); var rangeButton = Asc.Range(autoFilter.Ref.c1 + colId, autoFilter.Ref.r1, autoFilter.Ref.c1 + colId, autoFilter.Ref.r1);
...@@ -3330,6 +3346,7 @@ var maxIndividualValues = 10000; ...@@ -3330,6 +3346,7 @@ var maxIndividualValues = 10000;
autoFilterObject.asc_setCellId(cellId); autoFilterObject.asc_setCellId(cellId);
autoFilterObject.asc_setValues(values); autoFilterObject.asc_setValues(values);
autoFilterObject.asc_setFilterObj(filterObj); autoFilterObject.asc_setFilterObj(filterObj);
autoFilterObject.asc_setAutomaticRowCount(automaticRowCount);
ws.handlers.trigger("setAutoFiltersDialog", autoFilterObject); ws.handlers.trigger("setAutoFiltersDialog", autoFilterObject);
}, },
...@@ -3574,6 +3591,16 @@ var maxIndividualValues = 10000; ...@@ -3574,6 +3591,16 @@ var maxIndividualValues = 10000;
values[count] = tempResult; values[count] = tempResult;
}; };
var maxFilterRow = ref.r2;
var automaticRowCount = null;
if(filter.getType() === g_nFiltersType.autoFilter && filter.isApplyAutoFilter() === false)//нужно подхватить нижние ячейки в случае, если это не применен а/ф
{
var automaticRange = this._getAdjacentCellsAF(filter.Ref, aWs, true);
automaticRowCount = automaticRange.r2;
if(automaticRowCount > maxFilterRow)
maxFilterRow = automaticRowCount;
}
var individualCount, count, tempResult; var individualCount, count, tempResult;
var isCustomFilters = currentElemArray !== null && filterColumns[currentElemArray] && filterColumns[currentElemArray].CustomFiltersObj; var isCustomFilters = currentElemArray !== null && filterColumns[currentElemArray] && filterColumns[currentElemArray].CustomFiltersObj;
...@@ -3581,7 +3608,7 @@ var maxIndividualValues = 10000; ...@@ -3581,7 +3608,7 @@ var maxIndividualValues = 10000;
{ {
individualCount = 0; individualCount = 0;
count = 0; count = 0;
for(var i = ref.r1 + 1; i <= ref.r2; i++) for(var i = ref.r1 + 1; i <= maxFilterRow; i++)
{ {
//max strings //max strings
if(individualCount > maxIndividualValues) if(individualCount > maxIndividualValues)
...@@ -3659,7 +3686,7 @@ var maxIndividualValues = 10000; ...@@ -3659,7 +3686,7 @@ var maxIndividualValues = 10000;
} }
} }
return this._sortArrayMinMax(values); return {values: this._sortArrayMinMax(values), automaticRowCount: automaticRowCount};
}, },
_sortArrayMinMax: function(elements) _sortArrayMinMax: function(elements)
......
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