Merge pull request #952 from ONLYOFFICE/feature/Bug_47149

Feature/bug 47149
This commit is contained in:
maxkadushkin 2021-06-29 23:23:27 +03:00 committed by GitHub
commit e836dc0209
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 44 additions and 3 deletions

View file

@ -272,6 +272,11 @@
"textInvalidRange": "ERROR! Invalid cells range", "textInvalidRange": "ERROR! Invalid cells range",
"textSortAndFilter": "Sort and Filter", "textSortAndFilter": "Sort and Filter",
"textFilter": "Filter", "textFilter": "Filter",
"txtSorting": "Sorting",
"txtExpandSort": "The data next to the selection will not be sorted. Do you want to expand the selection to include the adjacent data or continue with sorting the currently selected cells only?",
"txtExpand": "Expand and sort",
"txtSortSelected": "Sort selected",
"textCancel": "Cancel",
"textComment": "Comment" "textComment": "Comment"
}, },
"Edit" : { "Edit" : {

View file

@ -1,4 +1,6 @@
import React, {Component} from 'react'; import React, {Component} from 'react';
import { f7 } from 'framework7-react';
import { withTranslation } from 'react-i18next';
import AddSortAndFilter from '../../view/add/AddFilter'; import AddSortAndFilter from '../../view/add/AddFilter';
@ -7,6 +9,7 @@ class AddFilterController extends Component {
super(props); super(props);
this.onInsertFilter = this.onInsertFilter.bind(this); this.onInsertFilter = this.onInsertFilter.bind(this);
this.uncheckedFilter = this.uncheckedFilter.bind(this); this.uncheckedFilter = this.uncheckedFilter.bind(this);
this.onInsertSort = this.onInsertSort.bind(this);
const api = Common.EditorApi.get(); const api = Common.EditorApi.get();
@ -38,7 +41,40 @@ class AddFilterController extends Component {
onInsertSort (type) { onInsertSort (type) {
const api = Common.EditorApi.get(); const api = Common.EditorApi.get();
api.asc_sortColFilter(type == 'down' ? Asc.c_oAscSortOptions.Ascending : Asc.c_oAscSortOptions.Descending, '', undefined, undefined, true); const { t } = this.props;
const _t = t('View.Add', {returnObjects: true});
f7.popup.close('.add-popup');
f7.popover.close('#add-popover');
let typeCheck = type == 'down' ? Asc.c_oAscSortOptions.Ascending : Asc.c_oAscSortOptions.Descending;
if( api.asc_sortCellsRangeExpand()) {
f7.dialog.create({
title: _t.txtSorting,
text: _t.txtExpandSort,
buttons: [
{
text: _t.txtExpand,
bold: true,
onClick: () => {
api.asc_sortColFilter(typeCheck, '', undefined, undefined, true);
}
},
{
text: _t.txtSortSelected,
bold: true,
onClick: () => {
api.asc_sortColFilter(typeCheck, '', undefined, undefined);
}
},
{
text: _t.textCancel
}
],
verticalButtons: true,
}).open();
} else
api.asc_sortColFilter(typeCheck, '', undefined, undefined, api.asc_sortCellsRangeExpand() !== null);
} }
onInsertFilter (checked) { onInsertFilter (checked) {
@ -64,4 +100,4 @@ class AddFilterController extends Component {
} }
} }
export default AddFilterController; export default withTranslation()(AddFilterController);

View file

@ -83,4 +83,4 @@
width: 25px; width: 25px;
} }
} }
} }