From 7c2bcac3e6aac31811adede6f466d2125184da4c Mon Sep 17 00:00:00 2001 From: Heiko Tietze Date: Wed, 2 Mar 2022 12:20:44 +0100 Subject: Resolves tdf#131155 - Keep frequently used options on sort criteria tab * Row/Column header moved * Sort by row/column moved * Extra variables removed * UI tests adjusted to read/set sort direction and header from first tab Change-Id: I9fc0406806256f289d52e45b096e392067768eaa Reviewed-on: https://gerrit.libreoffice.org/c/core/+/130843 Tested-by: Heiko Tietze Reviewed-by: Heiko Tietze --- sc/qa/uitest/conditional_format/tdf81696.py | 2 +- sc/qa/uitest/sort/naturalSort.py | 5 +- sc/qa/uitest/sort/sorting.py | 4 +- sc/qa/uitest/sort/tdf49531.py | 6 +- sc/qa/uitest/sort/tdf53482.py | 7 +- sc/qa/uitest/sort/tdf57465.py | 8 +- sc/qa/uitest/sort/tdf91305.py | 9 +- sc/qa/uitest/sort/tdf99208.py | 11 +- sc/source/ui/dbgui/sortdlg.cxx | 2 - sc/source/ui/dbgui/sortkeydlg.cxx | 6 + sc/source/ui/dbgui/tpsort.cxx | 198 ++++++++++------------------ sc/source/ui/inc/sortdlg.hxx | 9 -- sc/source/ui/inc/tpsort.hxx | 17 ++- sc/uiconfig/scalc/ui/sortcriteriapage.ui | 154 ++++++++++++++++++++-- sc/uiconfig/scalc/ui/sortkey.ui | 3 +- sc/uiconfig/scalc/ui/sortoptionspage.ui | 123 +++-------------- 16 files changed, 270 insertions(+), 294 deletions(-) (limited to 'sc') diff --git a/sc/qa/uitest/conditional_format/tdf81696.py b/sc/qa/uitest/conditional_format/tdf81696.py index 6b9bb7903154..0fca31e2bd98 100644 --- a/sc/qa/uitest/conditional_format/tdf81696.py +++ b/sc/qa/uitest/conditional_format/tdf81696.py @@ -28,7 +28,7 @@ class tdf81696(UITestCase): #Open sort dialog by DATA - SORT,Just sort it by Column A, ascending. (it's default) with self.ui_test.execute_dialog_through_command(".uno:DataSort") as xDialog: xTabs = xDialog.getChild("tabcontrol") - xleftright = xDialog.getChild("leftright") + xleftright = xDialog.getChild("rbLeftRight") select_pos(xTabs, "0") #verify diff --git a/sc/qa/uitest/sort/naturalSort.py b/sc/qa/uitest/sort/naturalSort.py index ca8384d5f2bf..6d9dd3edd7ca 100644 --- a/sc/qa/uitest/sort/naturalSort.py +++ b/sc/qa/uitest/sort/naturalSort.py @@ -85,12 +85,13 @@ class CalcNaturalSorting(UITestCase): #Open sort dialog by DATA - SORT with self.ui_test.execute_dialog_through_command(".uno:DataSort") as xDialog: xTabs = xDialog.getChild("tabcontrol") - xleftright = xDialog.getChild("leftright") select_pos(xTabs, "1") xNatural = xDialog.getChild("naturalsort") - xleftright.executeAction("CLICK", tuple()) if (get_state_as_dict(xNatural)["Selected"]) == "false": xNatural.executeAction("CLICK", tuple()) + select_pos(xTabs, "0") + xleftright = xDialog.getChild("rbLeftRight") + xleftright.executeAction("CLICK", tuple()) #Verify self.assertEqual(get_cell_by_position(document, 0, 0, 0).getString(), "MW-1") diff --git a/sc/qa/uitest/sort/sorting.py b/sc/qa/uitest/sort/sorting.py index 10645827435c..a3c901574109 100644 --- a/sc/qa/uitest/sort/sorting.py +++ b/sc/qa/uitest/sort/sorting.py @@ -58,7 +58,7 @@ class CalcSorting(UITestCase): xTabs = xDialog.getChild("tabcontrol") select_pos(xTabs, "1") #Verify that option "Range contains column labels" is set - xHeader = xDialog.getChild("header") + xHeader = xDialog.getChild("cbHeader") self.assertEqual(get_state_as_dict(xHeader)["Selected"], "true") #Cancel dialog #Select Range A1:B5 @@ -100,7 +100,7 @@ class CalcSorting(UITestCase): xTabs = xDialog.getChild("tabcontrol") select_pos(xTabs, "1") #Verify that option "Range contains column labels" is not set - xHeader = xDialog.getChild("header") + xHeader = xDialog.getChild("cbHeader") self.assertEqual(get_state_as_dict(xHeader)["Selected"], "false") #Cancel dialog diff --git a/sc/qa/uitest/sort/tdf49531.py b/sc/qa/uitest/sort/tdf49531.py index 08f94cd1a275..98d705bf8dd3 100644 --- a/sc/qa/uitest/sort/tdf49531.py +++ b/sc/qa/uitest/sort/tdf49531.py @@ -31,14 +31,14 @@ class tdf49531(UITestCase): xTabs = xDialog.getChild("tabcontrol") select_pos(xTabs, "1") xNatural = xDialog.getChild("naturalsort") - xtopdown = xDialog.getChild("topdown") - xHeader = xDialog.getChild("header") if (get_state_as_dict(xNatural)["Selected"]) == "true": xNatural.executeAction("CLICK", tuple()) + select_pos(xTabs, "0") + xtopdown = xDialog.getChild("rbTopDown") + xHeader = xDialog.getChild("cbHeader") if (get_state_as_dict(xHeader)["Selected"]) == "true": xHeader.executeAction("CLICK", tuple()) xtopdown.executeAction("CLICK", tuple()) - select_pos(xTabs, "0") xSortKey1 = xDialog.getChild("sortlb") xAsc = xDialog.getChild("up") select_by_text(xSortKey1, "B") diff --git a/sc/qa/uitest/sort/tdf53482.py b/sc/qa/uitest/sort/tdf53482.py index f96c780f92d9..fbcbac0a8549 100644 --- a/sc/qa/uitest/sort/tdf53482.py +++ b/sc/qa/uitest/sort/tdf53482.py @@ -29,7 +29,7 @@ class tdf53482(UITestCase): xTabs = xDialog.getChild("tabcontrol") select_pos(xTabs, "1") #3. On Options tab, tick 'Range contains column labels' - xHeader = xDialog.getChild("header") + xHeader = xDialog.getChild("cbHeader") xHeader.executeAction("CLICK", tuple()) if (get_state_as_dict(xHeader)["Selected"]) == "false": xHeader.executeAction("CLICK", tuple()) @@ -60,14 +60,13 @@ class tdf53482(UITestCase): #2. Click Data menu, Sort with self.ui_test.execute_dialog_through_command(".uno:DataSort") as xDialog: xTabs = xDialog.getChild("tabcontrol") - select_pos(xTabs, "1") + select_pos(xTabs, "0") #3. On Options tab, tick 'Range contains column labels' - xHeader = xDialog.getChild("header") + xHeader = xDialog.getChild("cbHeader") xHeader.executeAction("CLICK", tuple()) if (get_state_as_dict(xHeader)["Selected"]) == "false": xHeader.executeAction("CLICK", tuple()) #4. On Sort Criteria tab, set appropriate criteria - select_pos(xTabs, "0") xDown = xDialog.getChild("down") xDown.executeAction("CLICK", tuple()) #5. Click Ok diff --git a/sc/qa/uitest/sort/tdf57465.py b/sc/qa/uitest/sort/tdf57465.py index eefb3fdd4be8..bd7efaabc50a 100644 --- a/sc/qa/uitest/sort/tdf57465.py +++ b/sc/qa/uitest/sort/tdf57465.py @@ -23,17 +23,15 @@ class tdf57465(UITestCase): with self.ui_test.execute_dialog_through_command(".uno:DataSort") as xDialog: xTabs = xDialog.getChild("tabcontrol") - select_pos(xTabs, "1") + select_pos(xTabs, "0") - xHeader = xDialog.getChild("header") + xHeader = xDialog.getChild("cbHeader") if (get_state_as_dict(xHeader)["Selected"]) == 'true': xHeader.executeAction("CLICK", tuple()) - xLeftRight = xDialog.getChild("leftright") + xLeftRight = xDialog.getChild("rbLeftRight") xLeftRight.executeAction("CLICK", tuple()) - select_pos(xTabs, "0") - self.assertEqual("1", get_state_as_dict(xDialog.getChild("sortlb"))['DisplayText']) diff --git a/sc/qa/uitest/sort/tdf91305.py b/sc/qa/uitest/sort/tdf91305.py index 6292cd9fafde..ebc452daf56f 100644 --- a/sc/qa/uitest/sort/tdf91305.py +++ b/sc/qa/uitest/sort/tdf91305.py @@ -31,8 +31,8 @@ class tdf91305(UITestCase): #Open sort dialog by DATA - SORT with self.ui_test.execute_dialog_through_command(".uno:DataSort") as xDialog: xTabs = xDialog.getChild("tabcontrol") - xleftright = xDialog.getChild("leftright") - select_pos(xTabs, "1") + xleftright = xDialog.getChild("rbLeftRight") + select_pos(xTabs, "0") xleftright.executeAction("CLICK", tuple()) #verify self.assertEqual(get_cell_by_position(document, 0, 0, 0).getString(), "aa") @@ -41,11 +41,10 @@ class tdf91305(UITestCase): #Open sort dialog by DATA - SORT with self.ui_test.execute_dialog_through_command(".uno:DataSort") as xDialog: xTabs = xDialog.getChild("tabcontrol") - xleftright = xDialog.getChild("leftright") + xleftright = xDialog.getChild("rbLeftRight") xdown = xDialog.getChild("down") - select_pos(xTabs, "1") - xleftright.executeAction("CLICK", tuple()) select_pos(xTabs, "0") + xleftright.executeAction("CLICK", tuple()) xdown.executeAction("CLICK", tuple()) self.assertEqual(get_cell_by_position(document, 0, 0, 0).getString(), "ff") self.assertEqual(get_cell_by_position(document, 0, 1, 0).getString(), "cc") diff --git a/sc/qa/uitest/sort/tdf99208.py b/sc/qa/uitest/sort/tdf99208.py index e272484cbc32..9e3115d51b71 100644 --- a/sc/qa/uitest/sort/tdf99208.py +++ b/sc/qa/uitest/sort/tdf99208.py @@ -30,17 +30,18 @@ class tdf99208(UITestCase): xTabs = xDialog.getChild("tabcontrol") select_pos(xTabs, "1") xNatural = xDialog.getChild("naturalsort") - xtopdown = xDialog.getChild("topdown") - xHeader = xDialog.getChild("header") xFormats = xDialog.getChild("formats") if (get_state_as_dict(xNatural)["Selected"]) == "false": xNatural.executeAction("CLICK", tuple()) - if (get_state_as_dict(xHeader)["Selected"]) == "false": - xHeader.executeAction("CLICK", tuple()) if (get_state_as_dict(xFormats)["Selected"]) == "false": xFormats.executeAction("CLICK", tuple()) - xtopdown.executeAction("CLICK", tuple()) select_pos(xTabs, "0") + xtopdown = xDialog.getChild("rbTopDown") + xHeader = xDialog.getChild("cbHeader") + if (get_state_as_dict(xHeader)["Selected"]) == "false": + xHeader.executeAction("CLICK", tuple()) + xtopdown.executeAction("CLICK", tuple()) + xSortKey1 = xDialog.getChild("sortlb") xAsc = xDialog.getChild("up") select_by_text(xSortKey1, "FODMAP") diff --git a/sc/source/ui/dbgui/sortdlg.cxx b/sc/source/ui/dbgui/sortdlg.cxx index 4c5f5c18e00c..22af2230b081 100644 --- a/sc/source/ui/dbgui/sortdlg.cxx +++ b/sc/source/ui/dbgui/sortdlg.cxx @@ -25,8 +25,6 @@ ScSortDlg::ScSortDlg(weld::Window* pParent, const SfxItemSet* pArgSet) : SfxTabDialogController(pParent, "modules/scalc/ui/sortdialog.ui", "SortDialog", pArgSet) - , bIsHeaders(false) - , bIsByRows(false) { AddTabPage("criteria", ScTabPageSortFields::Create, nullptr); AddTabPage("options", ScTabPageSortOptions::Create, nullptr); diff --git a/sc/source/ui/dbgui/sortkeydlg.cxx b/sc/source/ui/dbgui/sortkeydlg.cxx index d927439e258f..599280735be9 100644 --- a/sc/source/ui/dbgui/sortkeydlg.cxx +++ b/sc/source/ui/dbgui/sortkeydlg.cxx @@ -11,6 +11,9 @@ #include #include +#include +#include + ScSortKeyItem::ScSortKeyItem(weld::Container* pParent) : m_xBuilder(Application::CreateBuilder(pParent, "modules/scalc/ui/sortkey.ui")) , m_xFrame(m_xBuilder->weld_frame("SortKeyFrame")) @@ -23,6 +26,9 @@ ScSortKeyItem::ScSortKeyItem(weld::Container* pParent) // tdf#136155 let the other elements in the dialog determine the width of the // combobox m_xLbSort->set_size_request(m_xLbSort->get_approximate_digit_width() * 12, -1); + // keep the UI static when switching the labels + const sal_Int32 nChars = std::max( ScResId(SCSTR_COLUMN).getLength(), ScResId(SCSTR_ROW).getLength() ) + 2; // +2 to avoid cut-off labels on kf5/gen + m_xLabel->set_size_request( m_xLabel->get_approximate_digit_width() * nChars, -1); } ScSortKeyItem::~ScSortKeyItem() diff --git a/sc/source/ui/dbgui/tpsort.cxx b/sc/source/ui/dbgui/tpsort.cxx index 0cbd1c350752..9fa00704d148 100644 --- a/sc/source/ui/dbgui/tpsort.cxx +++ b/sc/source/ui/dbgui/tpsort.cxx @@ -76,16 +76,20 @@ ScTabPageSortFields::ScTabPageSortFields(weld::Container* pPage, weld::DialogCon aStrUndefined ( ScResId( SCSTR_UNDEFINED ) ), aStrColumn ( ScResId( SCSTR_COLUMN ) ), aStrRow ( ScResId( SCSTR_ROW ) ), + aStrRowLabel ( ScResId( SCSTR_ROW_LABEL ) ), + aStrColLabel ( ScResId( SCSTR_COL_LABEL ) ), nWhichSort ( rArgSet.GetPool()->GetWhich( SID_SORT ) ), pViewData ( nullptr ), aSortData ( rArgSet.Get( nWhichSort ).GetSortData() ), nFieldCount ( 0 ), // show actual size of the sorting keys without limiting them to the default size - nSortKeyCount(std::max(aSortData.GetSortKeyCount(), static_cast(DEFSORT))), - bHasHeader ( false ), - bSortByRows ( false ) + nSortKeyCount(std::max(aSortData.GetSortKeyCount(), static_cast(DEFSORT))) + , m_xTop(m_xBuilder->weld_container("TopWindow")) + , m_xBtnHeader(m_xBuilder->weld_check_button("cbHeader")) + , m_xBtnTopDown(m_xBuilder->weld_radio_button("rbTopDown")) + , m_xBtnLeftRight(m_xBuilder->weld_radio_button("rbLeftRight")) , m_xScrolledWindow(m_xBuilder->weld_scrolled_window("SortCriteriaPage")) , m_xBox(m_xBuilder->weld_container("SortKeyWindow")) , m_aSortWin(m_xBox.get()) @@ -111,6 +115,31 @@ ScTabPageSortFields::~ScTabPageSortFields() void ScTabPageSortFields::Init() { + // Check whether the field that is passed on is a database field: + ScDocument* pDoc = pViewData ? &pViewData->GetDocument() : nullptr; + if ( pDoc ) + { + ScDBCollection* pDBColl = pDoc->GetDBCollection(); + const SCTAB nCurTab = pViewData->GetTabNo(); + if ( pDBColl ) + { + ScDBData* pDBData + = pDBColl->GetDBAtArea( nCurTab, + aSortData.nCol1, aSortData.nRow1, + aSortData.nCol2, aSortData.nRow2 ); + if ( pDBData ) + { + m_xBtnHeader->set_active(pDBData->HasHeader()); + } + } + } + m_xBtnHeader->set_label(aStrColLabel); + + Link aLink = LINK(this, ScTabPageSortFields, SortDirHdl ); + m_xBtnTopDown->connect_toggled( aLink ); + m_xBtnLeftRight->connect_toggled( aLink ); + m_xBtnHeader->connect_toggled( aLink ); + const ScSortItem& rSortItem = GetItemSet().Get( nWhichSort ); pViewData = rSortItem.GetViewData(); @@ -133,8 +162,9 @@ std::unique_ptr ScTabPageSortFields::Create(weld::Container* pPage, void ScTabPageSortFields::Reset( const SfxItemSet* /* rArgSet */ ) { - bSortByRows = aSortData.bByRow; - bHasHeader = aSortData.bHasHeader; + m_xBtnHeader->set_active( aSortData.bHasHeader ); + m_xBtnTopDown->set_active( aSortData.bByRow ); + m_xBtnLeftRight->set_active( !aSortData.bByRow ); if (m_aSortWin.m_aSortKeyItems[0]->m_xLbSort->get_count() == 0) FillFieldLists(0); @@ -201,12 +231,6 @@ void ScTabPageSortFields::Reset( const SfxItemSet* /* rArgSet */ ) m_aSortWin.m_aSortKeyItems[i]->DisableField(); } - if (ScSortDlg* pDlg = static_cast(GetDialogController())) - { - pDlg->SetByRows ( bSortByRows ); - pDlg->SetHeaders( bHasHeader ); - } - // Make sure that there is always a last undefined sort key if (m_aSortWin.m_aSortKeyItems[nSortKeyCount - 1]->m_xLbSort->get_active() > 0) SetLastSortKey( nSortKeyCount ); @@ -226,6 +250,9 @@ bool ScTabPageSortFields::FillItemSet( SfxItemSet* rArgSet ) aNewSortData = aTempData; } } + aNewSortData.bByRow = m_xBtnTopDown->get_active(); + aNewSortData.bHasHeader = m_xBtnHeader->get_active(); + std::vector nSortPos; for ( sal_uInt16 i=0; i 0 ) { for ( sal_uInt16 i=0; i 0); - - // If the "OK" was selected on the Options page while the sort - // direction was changed, then the first field (i.e. nFieldArr[0]) - // of the respective direction is chosen as the sorting criterion: - ScSortDlg* pDlg = static_cast(GetDialogController()); - if ( pDlg && bSortByRows != pDlg->GetByRows() ) - { - for ( sal_uInt16 i=0; i 0); + aNewSortData.maKeyState[i].nField = nFieldArr[nSortPos[i]]; aNewSortData.maKeyState[i].bAscending = m_aSortWin.m_aSortKeyItems[i]->m_xBtnUp->get_active(); - - // bHasHeader is in ScTabPageSortOptions::FillItemSet, where it belongs + } } else { @@ -278,36 +289,14 @@ void ScTabPageSortFields::ActivatePage( const SfxItemSet& rSet ) { // Refresh local copy with shared data aSortData = rSet.Get( SCITEM_SORTDATA ).GetSortData(); - ScSortDlg* pDlg = static_cast(GetDialogController()); - if (!pDlg) - return; - - if ( bHasHeader == pDlg->GetHeaders() && bSortByRows == pDlg->GetByRows() ) - return; - std::vector nCurSel; - for ( sal_uInt16 i=0; im_xLbSort->get_active() ); - - bHasHeader = pDlg->GetHeaders(); - bSortByRows = pDlg->GetByRows(); - FillFieldLists(0); - - for ( sal_uInt16 i=0; im_xLbSort->set_active(nCurSel[i]); + m_xBtnHeader->set_active( aSortData.bHasHeader ); + m_xBtnTopDown->set_active( aSortData.bByRow ); + m_xBtnLeftRight->set_active( !aSortData.bByRow ); } DeactivateRC ScTabPageSortFields::DeactivatePage( SfxItemSet* pSetP ) { - if (ScSortDlg* pDlg = static_cast(GetDialogController())) - { - if ( bHasHeader != pDlg->GetHeaders() ) - pDlg->SetHeaders( bHasHeader ); - - if ( bSortByRows != pDlg->GetByRows() ) - pDlg->SetByRows( bSortByRows ); - } - if ( pSetP ) FillItemSet( pSetP ); @@ -336,7 +325,7 @@ void ScTabPageSortFields::FillFieldLists( sal_uInt16 nStartField ) nFieldArr.clear(); nFieldArr.push_back(0); - if ( bSortByRows ) + if ( aSortData.bByRow ) { OUString aFieldName; SCCOL nMaxCol = rDoc.ClampToAllocatedColumns(nTab, aSortData.nCol2); @@ -345,7 +334,7 @@ void ScTabPageSortFields::FillFieldLists( sal_uInt16 nStartField ) for ( col=nFirstSortCol; col<=nMaxCol && iget_active() != aSortData.bByRow) || (m_xBtnHeader->get_active() != aSortData.bHasHeader)) + { + if (m_xBtnTopDown->get_active()) + m_xBtnHeader->set_label(aStrColLabel); + else + m_xBtnHeader->set_label(aStrRowLabel); + + aSortData.bByRow = m_xBtnTopDown->get_active(); + aSortData.bHasHeader = m_xBtnHeader->get_active(); + + // remember selection + std::vector nCurSel; + for ( sal_uInt16 i=0; im_xLbSort->get_active() ); + + FillFieldLists(0); + + for ( sal_uInt16 i=0; im_xLbSort->set_active(nCurSel[i]); + } +} + IMPL_LINK( ScTabPageSortFields, SelectHdl, weld::ComboBox&, rLb, void ) { OUString aSelEntry = rLb.get_active_text(); @@ -478,15 +491,12 @@ void ScTabPageSortFields::AddSortKey( sal_uInt16 nItem ) ScTabPageSortOptions::ScTabPageSortOptions(weld::Container* pPage, weld::DialogController* pController, const SfxItemSet& rArgSet) : SfxTabPage(pPage, pController, "modules/scalc/ui/sortoptionspage.ui", "SortOptionsPage", &rArgSet) - , aStrRowLabel(ScResId(SCSTR_ROW_LABEL)) - , aStrColLabel(ScResId(SCSTR_COL_LABEL)) , aStrUndefined(ScResId(SCSTR_UNDEFINED)) , nWhichSort(rArgSet.GetPool()->GetWhich(SID_SORT)) , aSortData(rArgSet.Get(nWhichSort).GetSortData()) , pViewData(nullptr) , pDoc(nullptr) , m_xBtnCase(m_xBuilder->weld_check_button("case")) - , m_xBtnHeader(m_xBuilder->weld_check_button("header")) , m_xBtnFormats(m_xBuilder->weld_check_button("formats")) , m_xBtnNaturalSort(m_xBuilder->weld_check_button("naturalsort")) , m_xBtnCopyResult(m_xBuilder->weld_check_button("copyresult")) @@ -497,8 +507,6 @@ ScTabPageSortOptions::ScTabPageSortOptions(weld::Container* pPage, weld::DialogC , m_xLbLanguage(new SvxLanguageBox(m_xBuilder->weld_combo_box("language"))) , m_xFtAlgorithm(m_xBuilder->weld_label("algorithmft")) , m_xLbAlgorithm(m_xBuilder->weld_combo_box("algorithmlb")) - , m_xBtnTopDown(m_xBuilder->weld_radio_button("topdown")) - , m_xBtnLeftRight(m_xBuilder->weld_radio_button("leftright")) , m_xBtnIncComments(m_xBuilder->weld_check_button("includenotes")) , m_xBtnIncImages(m_xBuilder->weld_check_button("includeimages")) { @@ -520,8 +528,6 @@ void ScTabPageSortOptions::Init() m_xLbOutPos->connect_changed( LINK( this, ScTabPageSortOptions, SelOutPosHdl ) ); m_xBtnCopyResult->connect_toggled( LINK( this, ScTabPageSortOptions, EnableHdl ) ); m_xBtnSortUser->connect_toggled( LINK( this, ScTabPageSortOptions, EnableHdl ) ); - m_xBtnTopDown->connect_toggled( LINK( this, ScTabPageSortOptions, SortDirHdl ) ); - m_xBtnLeftRight->connect_toggled( LINK( this, ScTabPageSortOptions, SortDirHdl ) ); m_xLbLanguage->connect_changed( LINK( this, ScTabPageSortOptions, FillAlgorHdl ) ); pViewData = rSortItem.GetViewData(); @@ -531,8 +537,6 @@ void ScTabPageSortOptions::Init() if ( pViewData && pDoc ) { - ScDBCollection* pDBColl = pDoc->GetDBCollection(); - const SCTAB nCurTab = pViewData->GetTabNo(); const formula::FormulaGrammar::AddressConvention eConv = pDoc->GetAddressConvention(); m_xLbOutPos->clear(); @@ -550,22 +554,6 @@ void ScTabPageSortOptions::Init() m_xLbOutPos->set_active(0); m_xEdOutPos->set_text(OUString()); - - // Check whether the field that is passed on is a database field: - - if ( pDBColl ) - { - ScDBData* pDBData - = pDBColl->GetDBAtArea( nCurTab, - aSortData.nCol1, aSortData.nRow1, - aSortData.nCol2, aSortData.nRow2 ); - if ( pDBData ) - { - m_xBtnHeader->set_active(pDBData->HasHeader()); - } - } - - m_xBtnHeader->set_label(aStrColLabel); } FillUserSortListBox(); @@ -598,22 +586,10 @@ void ScTabPageSortOptions::Reset( const SfxItemSet* /* rArgSet */ ) m_xBtnCase->set_active( aSortData.bCaseSens ); m_xBtnFormats->set_active( aSortData.aDataAreaExtras.mbCellFormats ); - m_xBtnHeader->set_active( aSortData.bHasHeader ); m_xBtnNaturalSort->set_active( aSortData.bNaturalSort ); m_xBtnIncComments->set_active( aSortData.aDataAreaExtras.mbCellNotes ); m_xBtnIncImages->set_active( aSortData.aDataAreaExtras.mbCellDrawObjects ); - if ( aSortData.bByRow ) - { - m_xBtnTopDown->set_active(true); - m_xBtnHeader->set_label( aStrColLabel ); - } - else - { - m_xBtnLeftRight->set_active(true); - m_xBtnHeader->set_label( aStrRowLabel ); - } - LanguageType eLang = LanguageTag::convertToLanguageType( aSortData.aCollatorLocale, false); if ( eLang == LANGUAGE_DONTKNOW ) eLang = LANGUAGE_SYSTEM; @@ -661,8 +637,6 @@ bool ScTabPageSortOptions::FillItemSet( SfxItemSet* rArgSet ) if (const ScSortItem* pSortItem = pExample->GetItemIfSet(nWhichSort)) aNewSortData = pSortItem->GetSortData(); } - aNewSortData.bByRow = m_xBtnTopDown->get_active(); - aNewSortData.bHasHeader = m_xBtnHeader->get_active(); aNewSortData.bCaseSens = m_xBtnCase->get_active(); aNewSortData.bNaturalSort = m_xBtnNaturalSort->get_active(); aNewSortData.aDataAreaExtras.mbCellNotes = m_xBtnIncComments->get_active(); @@ -706,21 +680,6 @@ void ScTabPageSortOptions::ActivatePage( const SfxItemSet& rSet ) ScSortDlg* pDlg = static_cast(GetDialogController()); if (!pDlg) return; - - if ( m_xBtnHeader->get_active() != pDlg->GetHeaders() ) - { - m_xBtnHeader->set_active( pDlg->GetHeaders() ); - } - - if ( m_xBtnTopDown->get_active() != pDlg->GetByRows() ) - { - m_xBtnTopDown->set_active( pDlg->GetByRows() ); - m_xBtnLeftRight->set_active( !pDlg->GetByRows() ); - } - - m_xBtnHeader->set_label( (pDlg->GetByRows()) - ? aStrColLabel - : aStrRowLabel ); } DeactivateRC ScTabPageSortOptions::DeactivatePage( SfxItemSet* pSetP ) @@ -764,13 +723,6 @@ DeactivateRC ScTabPageSortOptions::DeactivatePage( SfxItemSet* pSetP ) } } - ScSortDlg* pDlg = static_cast(GetDialogController()); - if (pDlg && bPosInputOk) - { - pDlg->SetHeaders( m_xBtnHeader->get_active() ); - pDlg->SetByRows ( m_xBtnTopDown->get_active() ); - } - if ( pSetP && bPosInputOk ) FillItemSet( pSetP ); @@ -834,14 +786,6 @@ IMPL_LINK(ScTabPageSortOptions, SelOutPosHdl, weld::ComboBox&, rLb, void) } } -IMPL_LINK_NOARG(ScTabPageSortOptions, SortDirHdl, weld::Toggleable&, void) -{ - if (m_xBtnTopDown->get_active()) - m_xBtnHeader->set_label(aStrColLabel); - else - m_xBtnHeader->set_label(aStrRowLabel); -} - void ScTabPageSortOptions::EdOutPosModHdl() { OUString theCurPosStr = m_xEdOutPos->get_text(); diff --git a/sc/source/ui/inc/sortdlg.hxx b/sc/source/ui/inc/sortdlg.hxx index ae58ef310df2..10d4268d7c51 100644 --- a/sc/source/ui/inc/sortdlg.hxx +++ b/sc/source/ui/inc/sortdlg.hxx @@ -26,15 +26,6 @@ class ScSortDlg : public SfxTabDialogController { public: ScSortDlg(weld::Window* pParent, const SfxItemSet* pArgSet); - - void SetHeaders( bool bHeaders ) { bIsHeaders = bHeaders; } - void SetByRows ( bool bByRows ) { bIsByRows = bByRows; } - bool GetHeaders() const { return bIsHeaders; } - bool GetByRows () const { return bIsByRows; } - -private: - bool bIsHeaders; - bool bIsByRows; }; class ScSortWarningDlg : public weld::GenericDialogController diff --git a/sc/source/ui/inc/tpsort.hxx b/sc/source/ui/inc/tpsort.hxx index 39043e0cc0a2..655f3a7732ed 100644 --- a/sc/source/ui/inc/tpsort.hxx +++ b/sc/source/ui/inc/tpsort.hxx @@ -61,6 +61,8 @@ private: OUString aStrUndefined; OUString aStrColumn; OUString aStrRow; + OUString aStrRowLabel; + OUString aStrColLabel; TypedWhichId nWhichSort; ScViewData* pViewData; @@ -69,9 +71,10 @@ private: sal_uInt16 nFieldCount; sal_uInt16 nSortKeyCount; - bool bHasHeader; - bool bSortByRows; - + std::unique_ptr m_xTop; + std::unique_ptr m_xBtnHeader; + std::unique_ptr m_xBtnTopDown; + std::unique_ptr m_xBtnLeftRight; std::unique_ptr m_xScrolledWindow; std::unique_ptr m_xBox; ScSortKeyWindow m_aSortWin; @@ -87,6 +90,8 @@ private: // Handler ------------------------ DECL_LINK(SelectHdl, weld::ComboBox&, void); DECL_LINK(ScrollToEndHdl, Timer*, void); + DECL_LINK(SortDirHdl, weld::Toggleable&, void); + }; // Sort Options @@ -107,8 +112,6 @@ protected: virtual DeactivateRC DeactivatePage ( SfxItemSet* pSet ) override; private: - OUString aStrRowLabel; - OUString aStrColLabel; OUString aStrUndefined; TypedWhichId nWhichSort; @@ -121,7 +124,6 @@ private: std::unique_ptr m_xColWrap; std::unique_ptr m_xBtnCase; - std::unique_ptr m_xBtnHeader; std::unique_ptr m_xBtnFormats; std::unique_ptr m_xBtnNaturalSort; std::unique_ptr m_xBtnCopyResult; @@ -132,8 +134,6 @@ private: std::unique_ptr m_xLbLanguage; std::unique_ptr m_xFtAlgorithm; std::unique_ptr m_xLbAlgorithm; - std::unique_ptr m_xBtnTopDown; - std::unique_ptr m_xBtnLeftRight; std::unique_ptr m_xBtnIncComments; std::unique_ptr m_xBtnIncImages; @@ -145,7 +145,6 @@ private: DECL_LINK( EnableHdl, weld::Toggleable&, void ); DECL_LINK( SelOutPosHdl, weld::ComboBox&, void ); void EdOutPosModHdl(); - DECL_LINK( SortDirHdl, weld::Toggleable&, void ); void FillAlgor(); DECL_LINK( FillAlgorHdl, weld::ComboBox&, void ); }; diff --git a/sc/uiconfig/scalc/ui/sortcriteriapage.ui b/sc/uiconfig/scalc/ui/sortcriteriapage.ui index 7662f423161d..df7e23219161 100644 --- a/sc/uiconfig/scalc/ui/sortcriteriapage.ui +++ b/sc/uiconfig/scalc/ui/sortcriteriapage.ui @@ -2,36 +2,168 @@ - + True - True + False True True - never + vertical - + True - False + True True True + never - + True False True True - vertical - + + True + False + True + True + vertical + + + + + + + Specify the sorting options for the selected range. + + + + + False + True + 0 + + + + + True + False + + False + True + 1 + - - - Specify the sorting options for the selected range. + + + True + False + 6 + 0 + none + + + + True + False + 6 + 3 + 3 + 3 + + + Top to bottom (sort rows) + True + True + False + True + True + True + + + 1 + 1 + + + + + Left to right (sort columns) + True + True + False + True + True + True + rbTopDown + + + 1 + 2 + + + + + True + False + Direction: + 1 + + + 0 + 1 + + + + + Range contains... + True + True + False + True + True + + + 1 + 0 + + + + + True + False + Headers: + 1 + + + 0 + 0 + + + + + + + + + + True + False + Sort Options + + + + + + + False + True + 2 + diff --git a/sc/uiconfig/scalc/ui/sortkey.ui b/sc/uiconfig/scalc/ui/sortkey.ui index 87695eb45593..62b7813bc2db 100644 --- a/sc/uiconfig/scalc/ui/sortkey.ui +++ b/sc/uiconfig/scalc/ui/sortkey.ui @@ -80,7 +80,8 @@ True False - Column/Row: + Column/Row: + 1 0 diff --git a/sc/uiconfig/scalc/ui/sortoptionspage.ui b/sc/uiconfig/scalc/ui/sortoptionspage.ui index d7918df57a25..13a23bfeb388 100644 --- a/sc/uiconfig/scalc/ui/sortoptionspage.ui +++ b/sc/uiconfig/scalc/ui/sortoptionspage.ui @@ -15,12 +15,13 @@ 0 none - + True False 12 6 + 12 6 12 @@ -42,25 +43,6 @@ 0 - - - Range contains... - True - True - False - True - True - - - Omits the first row or the first column in the selection from the sort. - - - - - 0 - 1 - - Include formats @@ -77,7 +59,7 @@ 0 - 2 + 1 @@ -96,7 +78,7 @@ 0 - 3 + 2 @@ -110,7 +92,7 @@ 0 - 4 + 3 @@ -124,7 +106,7 @@ 0 - 5 + 4 @@ -146,7 +128,7 @@ 0 - 6 + 5 @@ -167,7 +149,7 @@ 0 - 7 + 6 @@ -189,7 +171,7 @@ 1 - 7 + 6 @@ -211,7 +193,7 @@ 0 - 8 + 7 @@ -231,7 +213,7 @@ 0 - 9 + 8 2 @@ -246,7 +228,7 @@ 0 - 10 + 9 @@ -260,7 +242,7 @@ 1 - 10 + 9 @@ -275,7 +257,7 @@ 1 - 11 + 10 @@ -297,7 +279,7 @@ 0 - 11 + 10 @@ -321,9 +303,6 @@ - - - @@ -343,78 +322,6 @@ 0 - - - True - False - 0 - none - - - - True - False - 12 - 6 - - - _Top to bottom (sort rows) - True - True - False - True - True - True - - - Sorts rows by the values in the active columns of the selected range. - - - - - 0 - 0 - - - - - L_eft to right (sort columns) - True - True - False - True - True - topdown - - - Sorts columns by the values in the active rows of the selected range. - - - - - 0 - 1 - - - - - - - True - False - Direction - - - - - - - - False - True - 10 - - Sets additional sorting options. -- cgit