Commit 3de94942 authored by Julia Radzhabova's avatar Julia Radzhabova

[SSE] Применение сортировки и фильтрации по цвету.

parent 514f3d37
...@@ -206,10 +206,10 @@ define([ ...@@ -206,10 +206,10 @@ define([
toolbar.btnInsertText.on('click', _.bind(this.onBtnInsertTextClick, this)); toolbar.btnInsertText.on('click', _.bind(this.onBtnInsertTextClick, this));
toolbar.btnInsertText.menu.on('item:click', _.bind(this.onInsertTextClick, this)); toolbar.btnInsertText.menu.on('item:click', _.bind(this.onInsertTextClick, this));
toolbar.btnInsertShape.menu.on('hide:after', _.bind(this.onInsertShapeHide, this)); toolbar.btnInsertShape.menu.on('hide:after', _.bind(this.onInsertShapeHide, this));
toolbar.btnSortDown.on('click', _.bind(this.onSortType, this, 'ascending')); toolbar.btnSortDown.on('click', _.bind(this.onSortType, this, Asc.c_oAscSortOptions.Ascending));
toolbar.btnSortUp.on('click', _.bind(this.onSortType, this, 'descending')); toolbar.btnSortUp.on('click', _.bind(this.onSortType, this, Asc.c_oAscSortOptions.Descending));
toolbar.mnuitemSortAZ.on('click', _.bind(this.onSortType, this, 'ascending')); toolbar.mnuitemSortAZ.on('click', _.bind(this.onSortType, this, Asc.c_oAscSortOptions.Ascending));
toolbar.mnuitemSortZA.on('click', _.bind(this.onSortType, this, 'descending')); toolbar.mnuitemSortZA.on('click', _.bind(this.onSortType, this, Asc.c_oAscSortOptions.Descending));
toolbar.btnSetAutofilter.on('click', _.bind(this.onAutoFilter, this)); toolbar.btnSetAutofilter.on('click', _.bind(this.onAutoFilter, this));
toolbar.mnuitemAutoFilter.on('click', _.bind(this.onAutoFilter, this)); toolbar.mnuitemAutoFilter.on('click', _.bind(this.onAutoFilter, this));
toolbar.btnClearAutofilter.on('click', _.bind(this.onClearFilter, this)); toolbar.btnClearAutofilter.on('click', _.bind(this.onClearFilter, this));
......
...@@ -365,7 +365,7 @@ define([ ...@@ -365,7 +365,7 @@ define([
checkable : true, checkable : true,
checked : false checked : false
}); });
this.miSortLow2High.on('click', _.bind(this.onSortType, this, 'ascending')); this.miSortLow2High.on('click', _.bind(this.onSortType, this, Asc.c_oAscSortOptions.Ascending));
this.miSortHigh2Low = new Common.UI.MenuItem({ this.miSortHigh2Low = new Common.UI.MenuItem({
caption : this.txtSortHigh2Low, caption : this.txtSortHigh2Low,
...@@ -373,7 +373,7 @@ define([ ...@@ -373,7 +373,7 @@ define([
checkable : true, checkable : true,
checked : false checked : false
}); });
this.miSortHigh2Low.on('click', _.bind(this.onSortType, this, 'descending')); this.miSortHigh2Low.on('click', _.bind(this.onSortType, this, Asc.c_oAscSortOptions.Descending));
this.miSortCellColor = new Common.UI.MenuItem({ this.miSortCellColor = new Common.UI.MenuItem({
caption : this.txtSortCellColor, caption : this.txtSortCellColor,
...@@ -483,10 +483,13 @@ define([ ...@@ -483,10 +483,13 @@ define([
caption : this.txtClear, caption : this.txtClear,
checkable : false checkable : false
}); });
this.miClear.on('click', _.bind(this.onClear, this));
this.miReapply = new Common.UI.MenuItem({ this.miReapply = new Common.UI.MenuItem({
caption : this.txtReapply, caption : this.txtReapply,
checkable : false checkable : false
}); });
this.miReapply.on('click', _.bind(this.onReapply, this));
this.filtersMenu = new Common.UI.Menu({ this.filtersMenu = new Common.UI.Menu({
items: [ items: [
...@@ -519,7 +522,7 @@ define([ ...@@ -519,7 +522,7 @@ define([
'006400', '800080', '8B0000', '808000', 'FFFFFF', 'D3D3D3' '006400', '800080', '8B0000', '808000', 'FFFFFF', 'D3D3D3'
] ]
}); });
this.mnuSortColorCellsPicker.on('select', _.bind(this.onSortColorCellsSelect, this)); this.mnuSortColorCellsPicker.on('select', _.bind(this.onSortColorSelect, this, Asc.c_oAscSortOptions.ByColorFill));
this.mnuSortColorFontPicker = new Common.UI.ColorPaletteExt({ this.mnuSortColorFontPicker = new Common.UI.ColorPaletteExt({
el: $('#filter-dlg-sort-font-color'), el: $('#filter-dlg-sort-font-color'),
...@@ -530,7 +533,7 @@ define([ ...@@ -530,7 +533,7 @@ define([
'006400', '800080', '8B0000', '808000', 'FFFFFF', 'D3D3D3' '006400', '800080', '8B0000', '808000', 'FFFFFF', 'D3D3D3'
] ]
}); });
this.mnuSortColorFontPicker.on('select', _.bind(this.onSortColorFontSelect, this)); this.mnuSortColorFontPicker.on('select', _.bind(this.onSortColorSelect, this, Asc.c_oAscSortOptions.ByColorFont));
this.mnuFilterColorCellsPicker = new Common.UI.ColorPaletteExt({ this.mnuFilterColorCellsPicker = new Common.UI.ColorPaletteExt({
el: $('#filter-dlg-filter-cells-color'), el: $('#filter-dlg-filter-cells-color'),
...@@ -665,7 +668,7 @@ define([ ...@@ -665,7 +668,7 @@ define([
} }
if (item.value==0) { if (item.value==0) {
//clear filters this.onClear();
return; return;
} else if (item.value!==-1) { } else if (item.value!==-1) {
var newCustomFilter = new Asc.CustomFilters(); var newCustomFilter = new Asc.CustomFilters();
...@@ -718,7 +721,7 @@ define([ ...@@ -718,7 +721,7 @@ define([
} }
if (item.value==0) { if (item.value==0) {
//clear filters this.onClear();
return; return;
} else if (item.value!==-1) { } else if (item.value!==-1) {
var newCustomFilter = new Asc.CustomFilters(); var newCustomFilter = new Asc.CustomFilters();
...@@ -762,12 +765,11 @@ define([ ...@@ -762,12 +765,11 @@ define([
this.close(); this.close();
}, },
onSortColorCellsSelect: function(picker, color) { onSortColorSelect: function(type, picker, color) {
if (this.api && this.configTo) {
}, this.api.asc_sortColFilter(type, this.configTo.asc_getCellId(), this.configTo.asc_getDisplayName(), color == 'transparent' ? null : Common.Utils.ThemeColor.getRgbColor(color));
}
onSortColorFontSelect: function(picker, color) { this.close();
}, },
onCellCheck: function (listView, itemView, record) { onCellCheck: function (listView, itemView, record) {
...@@ -843,6 +845,18 @@ define([ ...@@ -843,6 +845,18 @@ define([
} }
}, },
onClear: function() {
if (this.api && this.configTo)
this.api.asc_clearFilterColumn(this.configTo.asc_getCellId(), this.configTo.asc_getDisplayName());
this.close();
},
onReapply: function() {
if (this.api && this.configTo)
this.api.asc_applyAutoFilter(this.config);
this.close();
},
setSettings: function (config) { setSettings: function (config) {
this.config = config; this.config = config;
this.configTo = config; this.configTo = config;
...@@ -855,39 +869,52 @@ define([ ...@@ -855,39 +869,52 @@ define([
isCustomFilter = (this.initialFilterType === Asc.c_oAscAutoFilterTypes.CustomFilters), isCustomFilter = (this.initialFilterType === Asc.c_oAscAutoFilterTypes.CustomFilters),
isTextFilter = this.configTo.asc_getIsTextFilter(), isTextFilter = this.configTo.asc_getIsTextFilter(),
colorsFill = this.configTo.asc_getColorsFill(), colorsFill = this.configTo.asc_getColorsFill(),
colorsFont = this.configTo.asc_getColorsFont(); colorsFont = this.configTo.asc_getColorsFont(),
sort = this.configTo.asc_getSortState(),
sortColor = this.configTo.asc_getSortColor();
if (sortColor) sortColor = Common.Utils.ThemeColor.getHexColor(sortColor.get_r(), sortColor.get_g(), sortColor.get_b()).toLocaleUpperCase();
this.miTextFilter.setVisible(isTextFilter); this.miTextFilter.setVisible(isTextFilter);
this.miNumFilter.setVisible(!isTextFilter); this.miNumFilter.setVisible(!isTextFilter);
this.miTextFilter.setChecked(isCustomFilter && isTextFilter, true); this.miTextFilter.setChecked(isCustomFilter && isTextFilter, true);
this.miNumFilter.setChecked(isCustomFilter && !isTextFilter, true); this.miNumFilter.setChecked(isCustomFilter && !isTextFilter, true);
if (colorsFont && colorsFont.length>0) { this.miSortLow2High.setChecked(sort == Asc.c_oAscSortOptions.Ascending, true);
this.miSortHigh2Low.setChecked(sort == Asc.c_oAscSortOptions.Descending, true);
var hasColors = (colorsFont && colorsFont.length>0);
this.miSortFontColor.setVisible(hasColors);
this.miFilterFontColor.setVisible(hasColors);
if (hasColors) {
var colors = ['transparent']; var colors = ['transparent'];
colorsFont.forEach(function(item, index) { colorsFont.forEach(function(item, index) {
colors.push(Common.Utils.ThemeColor.getHexColor(item.get_r(), item.get_g(), item.get_b()).toLocaleUpperCase()); colors.push(Common.Utils.ThemeColor.getHexColor(item.get_r(), item.get_g(), item.get_b()).toLocaleUpperCase());
}); });
this.mnuSortColorFontPicker.updateColors(colors); this.mnuSortColorFontPicker.updateColors(colors);
this.mnuFilterColorFontPicker.updateColors(colors); this.mnuFilterColorFontPicker.updateColors(colors);
this.miSortFontColor.setVisible(true);
this.miFilterFontColor.setVisible(true); this.miFilterFontColor.setChecked(false, true);
} else { this.miSortFontColor.setChecked(sort == Asc.c_oAscSortOptions.ByColorFont, true);
this.miSortFontColor.setVisible(false); if (sort == Asc.c_oAscSortOptions.ByColorFont)
this.miFilterFontColor.setVisible(false); this.mnuSortColorFontPicker.select(sortColor, true);
} }
if (colorsFill && colorsFill.length>0) { hasColors = (colorsFill && colorsFill.length>0);
this.miSortCellColor.setVisible(hasColors);
this.miFilterCellColor.setVisible(hasColors);
if (hasColors) {
var colors = ['transparent']; var colors = ['transparent'];
colorsFill.forEach(function(item, index) { colorsFill.forEach(function(item, index) {
colors.push(Common.Utils.ThemeColor.getHexColor(item.get_r(), item.get_g(), item.get_b()).toLocaleUpperCase()); colors.push(Common.Utils.ThemeColor.getHexColor(item.get_r(), item.get_g(), item.get_b()).toLocaleUpperCase());
}); });
this.mnuSortColorCellsPicker.updateColors(colors); this.mnuSortColorCellsPicker.updateColors(colors);
this.mnuFilterColorCellsPicker.updateColors(colors); this.mnuFilterColorCellsPicker.updateColors(colors);
this.miSortCellColor.setVisible(true);
this.miFilterCellColor.setVisible(true); this.miFilterCellColor.setChecked(false, true);
} else { this.miSortCellColor.setChecked(sort == Asc.c_oAscSortOptions.ByColorFill, true);
this.miSortCellColor.setVisible(false); if (sort == Asc.c_oAscSortOptions.ByColorFill)
this.miFilterCellColor.setVisible(false); this.mnuSortColorFontPicker.select(sortColor, true);
} }
if (isCustomFilter) { if (isCustomFilter) {
...@@ -916,24 +943,15 @@ define([ ...@@ -916,24 +943,15 @@ define([
filterColor = colorFilter.asc_getCColor(); filterColor = colorFilter.asc_getCColor();
if (filterColor) if (filterColor)
filterColor = Common.Utils.ThemeColor.getHexColor(filterColor.get_r(), filterColor.get_g(), filterColor.get_b()).toLocaleUpperCase(); filterColor = Common.Utils.ThemeColor.getHexColor(filterColor.get_r(), filterColor.get_g(), filterColor.get_b()).toLocaleUpperCase();
if ( colorFilter.asc_getCellColor()===null ) // cell color if ( colorFilter.asc_getCellColor()===null ) { // cell color
this.miFilterCellColor.setChecked(true, true);
this.mnuFilterColorCellsPicker.select(filterColor, true); this.mnuFilterColorCellsPicker.select(filterColor, true);
else if (colorFilter.asc_getCellColor()===false) // font color } else if (colorFilter.asc_getCellColor()===false) { // font color
this.miFilterFontColor.setChecked(true, true);
this.mnuFilterColorFontPicker.select(filterColor, true); this.mnuFilterColorFontPicker.select(filterColor, true);
} }
this.miSortLow2High.setChecked(false, true);
this.miSortHigh2Low.setChecked(false, true);
var sort = this.configTo.asc_getSortState();
if (sort) {
if ('ascending' === sort) {
this.miSortLow2High.setChecked(true, true);
} else {
this.miSortHigh2Low.setChecked(true, true);
}
} }
this.btnOk.setDisabled(isCustomFilter); this.btnOk.setDisabled(isCustomFilter);
}, },
......
...@@ -230,10 +230,10 @@ define([ ...@@ -230,10 +230,10 @@ define([
items: [ items: [
{ {
caption : me.txtAscending, caption : me.txtAscending,
value : 'ascending' value : Asc.c_oAscSortOptions.Ascending
},{ },{
caption : me.txtDescending, caption : me.txtDescending,
value : 'descending' value : Asc.c_oAscSortOptions.Descending
} }
] ]
}) })
......
...@@ -1454,13 +1454,13 @@ define([ ...@@ -1454,13 +1454,13 @@ define([
caption : me.txtSortAZ, caption : me.txtSortAZ,
iconCls : 'mnu-sort-asc', iconCls : 'mnu-sort-asc',
lock : [_set.selChart, _set.selChartText, _set.selShape, _set.selShapeText, _set.selImage, _set.coAuth, _set.ruleFilter], lock : [_set.selChart, _set.selChartText, _set.selShape, _set.selShapeText, _set.selImage, _set.coAuth, _set.ruleFilter],
value : 'ascending' value : Asc.c_oAscSortOptions.Ascending
}), }),
me.mnuitemSortZA = new Common.UI.MenuItem({ me.mnuitemSortZA = new Common.UI.MenuItem({
caption : me.txtSortZA, caption : me.txtSortZA,
iconCls : 'mnu-sort-desc', iconCls : 'mnu-sort-desc',
lock : [_set.selChart, _set.selChartText, _set.selShape, _set.selShapeText, _set.selImage, _set.coAuth, _set.ruleFilter], lock : [_set.selChart, _set.selChartText, _set.selShape, _set.selShapeText, _set.selImage, _set.coAuth, _set.ruleFilter],
value : 'descending' value : Asc.c_oAscSortOptions.Descending
}), }),
me.mnuitemAutoFilter = new Common.UI.MenuItem({ me.mnuitemAutoFilter = new Common.UI.MenuItem({
caption : me.txtFilter, caption : me.txtFilter,
......
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