summaryrefslogtreecommitdiff
path: root/sc/source
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2019-04-16 15:44:33 +0100
committerCaolán McNamara <caolanm@redhat.com>2019-04-17 08:58:11 +0200
commit73482f5e8742cc9fce32de1fc660059aae2a9583 (patch)
tree083cdca51c23a9dabede61905ad26cce2eface2f /sc/source
parent6f43902b12dd36fa2b69401065df198ef9ffdb09 (diff)
weld ScSpecialFilterDlg
Change-Id: Iecf88c5720f2407654d85a1a70a04faed43fd690 Reviewed-on: https://gerrit.libreoffice.org/70832 Tested-by: Jenkins Reviewed-by: Caolán McNamara <caolanm@redhat.com> Tested-by: Caolán McNamara <caolanm@redhat.com>
Diffstat (limited to 'sc/source')
-rw-r--r--sc/source/ui/dbgui/sfiltdlg.cxx262
-rw-r--r--sc/source/ui/inc/filtdlg.hxx65
-rw-r--r--sc/source/ui/inc/reffact.hxx2
-rw-r--r--sc/source/ui/view/reffact.cxx4
-rw-r--r--sc/source/ui/view/tabvwshc.cxx57
5 files changed, 180 insertions, 210 deletions
diff --git a/sc/source/ui/dbgui/sfiltdlg.cxx b/sc/source/ui/dbgui/sfiltdlg.cxx
index 919632c577fd..8438dcf2f563 100644
--- a/sc/source/ui/dbgui/sfiltdlg.cxx
+++ b/sc/source/ui/dbgui/sfiltdlg.cxx
@@ -51,44 +51,45 @@ namespace
// class ScSpecialFilterDialog
-ScSpecialFilterDlg::ScSpecialFilterDlg( SfxBindings* pB, SfxChildWindow* pCW, vcl::Window* pParent,
+ScSpecialFilterDlg::ScSpecialFilterDlg( SfxBindings* pB, SfxChildWindow* pCW, weld::Window* pParent,
const SfxItemSet& rArgSet )
- : ScAnyRefDlg ( pB, pCW, pParent, "AdvancedFilterDialog", "modules/scalc/ui/advancedfilterdialog.ui" ),
-
- aStrUndefined ( ScResId(SCSTR_UNDEFINED) ),
- nWhichQuery ( rArgSet.GetPool()->GetWhich( SID_QUERY ) ),
- theQueryData ( static_cast<const ScQueryItem&>(
- rArgSet.Get( nWhichQuery )).GetQueryData() ),
- pViewData ( nullptr ),
- pDoc ( nullptr ),
- pRefInputEdit ( nullptr ),
- bRefInputMode ( false )
+ : ScAnyRefDlgController(pB, pCW, pParent, "modules/scalc/ui/advancedfilterdialog.ui", "AdvancedFilterDialog")
+ , aStrUndefined ( ScResId(SCSTR_UNDEFINED) )
+ , nWhichQuery ( rArgSet.GetPool()->GetWhich( SID_QUERY ) )
+ , theQueryData ( static_cast<const ScQueryItem&>(
+ rArgSet.Get( nWhichQuery )).GetQueryData() )
+ , pViewData(nullptr)
+ , pDoc(nullptr)
+ , bRefInputMode(false)
+ , m_pRefInputEdit(nullptr)
+ , m_xLbFilterArea(m_xBuilder->weld_combo_box("lbfilterarea"))
+ , m_xEdFilterArea(new formula::WeldRefEdit(m_xBuilder->weld_entry("edfilterarea")))
+ , m_xRbFilterArea(new formula::WeldRefButton(m_xBuilder->weld_button("rbfilterarea")))
+ , m_xExpander(m_xBuilder->weld_expander("more"))
+ , m_xBtnCase(m_xBuilder->weld_check_button("case"))
+ , m_xBtnRegExp(m_xBuilder->weld_check_button("regexp"))
+ , m_xBtnHeader(m_xBuilder->weld_check_button("header"))
+ , m_xBtnUnique(m_xBuilder->weld_check_button("unique"))
+ , m_xBtnCopyResult(m_xBuilder->weld_check_button("copyresult"))
+ , m_xLbCopyArea(m_xBuilder->weld_combo_box("lbcopyarea"))
+ , m_xEdCopyArea(new formula::WeldRefEdit(m_xBuilder->weld_entry("edcopyarea")))
+ , m_xRbCopyArea(new formula::WeldRefButton(m_xBuilder->weld_button("rbcopyarea")))
+ , m_xBtnDestPers(m_xBuilder->weld_check_button("destpers"))
+ , m_xFtDbAreaLabel(m_xBuilder->weld_label("dbarealabel"))
+ , m_xFtDbArea(m_xBuilder->weld_label("dbarea"))
+ , m_xBtnOk(m_xBuilder->weld_button("ok"))
+ , m_xBtnCancel(m_xBuilder->weld_button("cancel"))
+ , m_xFilterFrame(m_xBuilder->weld_frame("filterframe"))
+ , m_xFilterLabel(m_xFilterFrame->weld_label_widget())
{
- get(pLbFilterArea,"lbfilterarea");
- get(pEdFilterArea,"edfilterarea");
- pEdFilterArea->SetReferences(this, get<VclFrame>("filterframe")->get_label_widget());
- get(pRbFilterArea,"rbfilterarea");
- pRbFilterArea->SetReferences(this, pEdFilterArea);
- get(pBtnCase,"case");
- get(pBtnRegExp,"regexp");
- get(pBtnHeader,"header");
- get(pBtnUnique,"unique");
- get(pBtnCopyResult,"copyresult");
- get(pLbCopyArea,"lbcopyarea");
- get(pEdCopyArea,"edcopyarea");
- pEdCopyArea->SetReferences(this, pBtnCopyResult);
- get(pRbCopyArea,"rbcopyarea");
- pRbCopyArea->SetReferences(this, pEdCopyArea);
- get(pBtnDestPers,"destpers");
- get(pFtDbAreaLabel,"dbarealabel");
- get(pFtDbArea,"dbarea");
- get(pBtnOk,"ok");
- get(pBtnCancel,"cancel");
- get(pExpander,"more");
+ m_xEdFilterArea->SetReferences(this, m_xFilterLabel.get());
+ m_xRbFilterArea->SetReferences(this, m_xEdFilterArea.get());
+ m_xEdCopyArea->SetReferences(this, m_xFtDbAreaLabel.get());
+ m_xRbCopyArea->SetReferences(this, m_xEdCopyArea.get());
Init( rArgSet );
- pEdFilterArea->GrabFocus();
+ m_xEdFilterArea->GrabFocus();
// hack: control of RefInput
pIdle.reset( new Idle("Special Filter Dialog") );
@@ -100,16 +101,6 @@ ScSpecialFilterDlg::ScSpecialFilterDlg( SfxBindings* pB, SfxChildWindow* pCW, vc
ScSpecialFilterDlg::~ScSpecialFilterDlg()
{
- disposeOnce();
-}
-
-void ScSpecialFilterDlg::dispose()
-{
- const sal_Int32 nEntries = pLbFilterArea->GetEntryCount();
-
- for ( sal_Int32 i=1; i<nEntries; ++i )
- delete static_cast<OUString*>(pLbFilterArea->GetEntryData( i ));
-
pOptionsMgr.reset();
pOutItem.reset();
@@ -117,26 +108,6 @@ void ScSpecialFilterDlg::dispose()
// hack: control of RefInput
pIdle->Stop();
pIdle.reset();
-
- pLbFilterArea.clear();
- pEdFilterArea.clear();
- pRbFilterArea.clear();
- pExpander.clear();
- pBtnCase.clear();
- pBtnRegExp.clear();
- pBtnHeader.clear();
- pBtnUnique.clear();
- pBtnCopyResult.clear();
- pLbCopyArea.clear();
- pEdCopyArea.clear();
- pRbCopyArea.clear();
- pBtnDestPers.clear();
- pFtDbAreaLabel.clear();
- pFtDbArea.clear();
- pBtnOk.clear();
- pBtnCancel.clear();
- pRefInputEdit.clear();
- ScAnyRefDlg::dispose();
}
void ScSpecialFilterDlg::Init( const SfxItemSet& rArgSet )
@@ -144,33 +115,32 @@ void ScSpecialFilterDlg::Init( const SfxItemSet& rArgSet )
const ScQueryItem& rQueryItem = static_cast<const ScQueryItem&>(
rArgSet.Get( nWhichQuery ));
- pBtnOk->SetClickHdl ( LINK( this, ScSpecialFilterDlg, EndDlgHdl ) );
- pBtnCancel->SetClickHdl ( LINK( this, ScSpecialFilterDlg, EndDlgHdl ) );
- pLbFilterArea->SetSelectHdl ( LINK( this, ScSpecialFilterDlg, FilterAreaSelHdl ) );
- pEdFilterArea->SetModifyHdl ( LINK( this, ScSpecialFilterDlg, FilterAreaModHdl ) );
+ m_xBtnOk->connect_clicked( LINK( this, ScSpecialFilterDlg, EndDlgHdl ) );
+ m_xBtnCancel->connect_clicked( LINK( this, ScSpecialFilterDlg, EndDlgHdl ) );
+ m_xLbFilterArea->connect_changed( LINK( this, ScSpecialFilterDlg, FilterAreaSelHdl ) );
+ m_xEdFilterArea->SetModifyHdl ( LINK( this, ScSpecialFilterDlg, FilterAreaModHdl ) );
pViewData = rQueryItem.GetViewData();
pDoc = pViewData ? pViewData->GetDocument() : nullptr;
- pEdFilterArea->SetText( EMPTY_OUSTRING ); // may be overwritten below
+ m_xEdFilterArea->SetText( EMPTY_OUSTRING ); // may be overwritten below
if ( pViewData && pDoc )
{
- if(pDoc->GetChangeTrack()!=nullptr) pBtnCopyResult->Disable();
+ if(pDoc->GetChangeTrack()!=nullptr) m_xBtnCopyResult->set_sensitive(false);
ScRangeName* pRangeNames = pDoc->GetRangeName();
- pLbFilterArea->Clear();
- pLbFilterArea->InsertEntry( aStrUndefined, 0 );
+ m_xLbFilterArea->clear();
+ m_xLbFilterArea->append_text(aStrUndefined);
for (const auto& rEntry : *pRangeNames)
{
if (!rEntry.second->HasType(ScRangeData::Type::Criteria))
continue;
- const sal_Int32 nInsert = pLbFilterArea->InsertEntry(rEntry.second->GetName());
OUString aSymbol;
rEntry.second->GetSymbol(aSymbol);
- pLbFilterArea->SetEntryData(nInsert, new OUString(aSymbol));
+ m_xLbFilterArea->append(aSymbol, rEntry.second->GetName());
}
// is there a stored source range?
@@ -179,33 +149,33 @@ void ScSpecialFilterDlg::Init( const SfxItemSet& rArgSet )
if (rQueryItem.GetAdvancedQuerySource(aAdvSource))
{
OUString aRefStr(aAdvSource.Format(ScRefFlags::RANGE_ABS_3D, pDoc, pDoc->GetAddressConvention()));
- pEdFilterArea->SetRefString( aRefStr );
+ m_xEdFilterArea->SetRefString( aRefStr );
}
}
- pLbFilterArea->SelectEntryPos( 0 );
+ m_xLbFilterArea->set_active( 0 );
// let options be initialized:
- pOptionsMgr.reset( new ScFilterOptionsMgr(
+ pOptionsMgr.reset( new FilterOptionsMgr(
pViewData,
theQueryData,
- pBtnCase,
- pBtnRegExp,
- pBtnHeader,
- pBtnUnique,
- pBtnCopyResult,
- pBtnDestPers,
- pLbCopyArea,
- pEdCopyArea,
- pRbCopyArea,
- pFtDbAreaLabel,
- pFtDbArea,
+ m_xBtnCase.get(),
+ m_xBtnRegExp.get(),
+ m_xBtnHeader.get(),
+ m_xBtnUnique.get(),
+ m_xBtnCopyResult.get(),
+ m_xBtnDestPers.get(),
+ m_xLbCopyArea.get(),
+ m_xEdCopyArea.get(),
+ m_xRbCopyArea.get(),
+ m_xFtDbAreaLabel.get(),
+ m_xFtDbArea.get(),
aStrUndefined ) );
// special filter always needs column headers
- pBtnHeader->Check();
- pBtnHeader->Disable();
+ m_xBtnHeader->set_active(true);
+ m_xBtnHeader->set_sensitive(false);
// turn on modal mode
// SetDispatcherLock( true );
@@ -213,12 +183,12 @@ void ScSpecialFilterDlg::Init( const SfxItemSet& rArgSet )
//SFX_APPWINDOW->Disable(false); //! general method in ScAnyRefDlg
}
-bool ScSpecialFilterDlg::Close()
+void ScSpecialFilterDlg::Close()
{
if (pViewData)
pViewData->GetDocShell()->CancelAutoDBRange();
- return DoClose( ScSpecialFilterDlgWrapper::GetChildWindowId() );
+ DoClose( ScSpecialFilterDlgWrapper::GetChildWindowId() );
}
// Transfer of a table area selected with the mouse, which is then displayed
@@ -226,20 +196,20 @@ bool ScSpecialFilterDlg::Close()
void ScSpecialFilterDlg::SetReference( const ScRange& rRef, ScDocument* pDocP )
{
- if ( bRefInputMode && pRefInputEdit ) // only possible if in the reference edit mode
+ if ( bRefInputMode && m_pRefInputEdit ) // only possible if in the reference edit mode
{
if ( rRef.aStart != rRef.aEnd )
- RefInputStart( pRefInputEdit );
+ RefInputStart( m_pRefInputEdit );
OUString aRefStr;
const formula::FormulaGrammar::AddressConvention eConv = pDocP->GetAddressConvention();
- if ( pRefInputEdit == pEdCopyArea)
+ if (m_pRefInputEdit == m_xEdCopyArea.get())
aRefStr = rRef.aStart.Format(ScRefFlags::ADDR_ABS_3D, pDocP, eConv);
- else if ( pRefInputEdit == pEdFilterArea)
+ else if (m_pRefInputEdit == m_xEdFilterArea.get())
aRefStr = rRef.Format(ScRefFlags::RANGE_ABS_3D, pDocP, eConv);
- pRefInputEdit->SetRefString( aRefStr );
+ m_pRefInputEdit->SetRefString( aRefStr );
}
}
@@ -247,19 +217,19 @@ void ScSpecialFilterDlg::SetActive()
{
if ( bRefInputMode )
{
- if ( pRefInputEdit == pEdCopyArea )
+ if (m_pRefInputEdit == m_xEdCopyArea.get())
{
- pEdCopyArea->GrabFocus();
- pEdCopyArea->GetModifyHdl().Call( *pEdCopyArea );
+ m_xEdCopyArea->GrabFocus();
+ m_xEdCopyArea->GetModifyHdl().Call( *m_xEdCopyArea );
}
- else if ( pRefInputEdit == pEdFilterArea )
+ else if (m_pRefInputEdit == m_xEdFilterArea.get())
{
- pEdFilterArea->GrabFocus();
- FilterAreaModHdl( *pEdFilterArea );
+ m_xEdFilterArea->GrabFocus();
+ FilterAreaModHdl( *m_xEdFilterArea );
}
}
else
- GrabFocus();
+ m_xDialog->grab_focus();
RefInputDone();
}
@@ -279,14 +249,14 @@ bool ScSpecialFilterDlg::IsRefInputMode() const
// Handler:
-IMPL_LINK( ScSpecialFilterDlg, EndDlgHdl, Button*, pBtn, void )
+IMPL_LINK(ScSpecialFilterDlg, EndDlgHdl, weld::Button&, rBtn, void)
{
OSL_ENSURE( pDoc && pViewData, "Document or ViewData not found. :-/" );
- if ( (pBtn == pBtnOk) && pDoc && pViewData )
+ if (&rBtn == m_xBtnOk.get() && pDoc && pViewData)
{
- OUString theCopyStr( pEdCopyArea->GetText() );
- OUString theAreaStr( pEdFilterArea->GetText() );
+ OUString theCopyStr( m_xEdCopyArea->GetText() );
+ OUString theAreaStr( m_xEdFilterArea->GetText() );
ScQueryParam theOutParam( theQueryData );
ScAddress theAdrCopy;
bool bEditInputOk = true;
@@ -294,7 +264,7 @@ IMPL_LINK( ScSpecialFilterDlg, EndDlgHdl, Button*, pBtn, void )
ScRange theFilterArea;
const formula::FormulaGrammar::AddressConvention eConv = pDoc->GetAddressConvention();
- if ( pBtnCopyResult->IsChecked() )
+ if ( m_xBtnCopyResult->get_active() )
{
sal_Int32 nColonPos = theCopyStr.indexOf( ':' );
@@ -305,11 +275,11 @@ IMPL_LINK( ScSpecialFilterDlg, EndDlgHdl, Button*, pBtn, void )
if ( (nResult & ScRefFlags::VALID) == ScRefFlags::ZERO )
{
- if (!pExpander->get_expanded())
- pExpander->set_expanded(true);
+ if (!m_xExpander->get_expanded())
+ m_xExpander->set_expanded(true);
- ERRORBOX(GetFrameWeld(), STR_INVALID_TABREF);
- pEdCopyArea->GrabFocus();
+ ERRORBOX(m_xDialog.get(), STR_INVALID_TABREF);
+ m_xEdCopyArea->GrabFocus();
bEditInputOk = false;
}
}
@@ -320,8 +290,8 @@ IMPL_LINK( ScSpecialFilterDlg, EndDlgHdl, Button*, pBtn, void )
if ( (nResult & ScRefFlags::VALID) == ScRefFlags::ZERO )
{
- ERRORBOX(GetFrameWeld(), STR_INVALID_TABREF);
- pEdFilterArea->GrabFocus();
+ ERRORBOX(m_xDialog.get(), STR_INVALID_TABREF);
+ m_xEdFilterArea->GrabFocus();
bEditInputOk = false;
}
}
@@ -340,7 +310,7 @@ IMPL_LINK( ScSpecialFilterDlg, EndDlgHdl, Button*, pBtn, void )
ScAddress& rStart = theFilterArea.aStart;
ScAddress& rEnd = theFilterArea.aEnd;
- if ( pBtnCopyResult->IsChecked() )
+ if ( m_xBtnCopyResult->get_active() )
{
theOutParam.bInplace = false;
theOutParam.nDestTab = theAdrCopy.Tab();
@@ -355,13 +325,13 @@ IMPL_LINK( ScSpecialFilterDlg, EndDlgHdl, Button*, pBtn, void )
theOutParam.nDestRow = 0;
}
- theOutParam.bHasHeader = pBtnHeader->IsChecked();
+ theOutParam.bHasHeader = m_xBtnHeader->get_active();
theOutParam.bByRow = true;
- theOutParam.bCaseSens = pBtnCase->IsChecked();
- theOutParam.eSearchType = pBtnRegExp->IsChecked() ? utl::SearchParam::SearchType::Regexp :
+ theOutParam.bCaseSens = m_xBtnCase->get_active();
+ theOutParam.eSearchType = m_xBtnRegExp->get_active() ? utl::SearchParam::SearchType::Regexp :
utl::SearchParam::SearchType::Normal;
- theOutParam.bDuplicate = !pBtnUnique->IsChecked();
- theOutParam.bDestPers = pBtnDestPers->IsChecked();
+ theOutParam.bDuplicate = !m_xBtnUnique->get_active();
+ theOutParam.bDestPers = m_xBtnDestPers->get_active();
bQueryOk = pDoc->CreateQueryParam(ScRange(rStart,rEnd), theOutParam);
}
@@ -374,39 +344,38 @@ IMPL_LINK( ScSpecialFilterDlg, EndDlgHdl, Button*, pBtn, void )
GetBindings().GetDispatcher()->ExecuteList(FID_FILTER_OK,
SfxCallMode::SLOT | SfxCallMode::RECORD,
{ GetOutputItem(theOutParam, theFilterArea) });
- Close();
+ response(RET_OK);
}
else
{
- ERRORBOX(GetFrameWeld(), STR_INVALID_QUERYAREA);
- pEdFilterArea->GrabFocus();
+ ERRORBOX(m_xDialog.get(), STR_INVALID_QUERYAREA);
+ m_xEdFilterArea->GrabFocus();
}
}
- else if ( pBtn == pBtnCancel )
+ else if (&rBtn == m_xBtnCancel.get())
{
- Close();
+ response(RET_CANCEL);
}
}
IMPL_LINK( ScSpecialFilterDlg, TimeOutHdl, Timer*, _pIdle, void )
{
// every 50ms check whether RefInputMode is still true
-
- if( (_pIdle == pIdle.get()) && IsActive() )
+ if (_pIdle == pIdle.get() && m_xDialog->has_toplevel_focus())
{
- if( pEdCopyArea->HasFocus() || pRbCopyArea->HasFocus() )
+ if( m_xEdCopyArea->GetWidget()->has_focus() || m_xRbCopyArea->GetWidget()->has_focus() )
{
- pRefInputEdit = pEdCopyArea;
+ m_pRefInputEdit = m_xEdCopyArea.get();
bRefInputMode = true;
}
- else if( pEdFilterArea->HasFocus() || pRbFilterArea->HasFocus() )
+ else if( m_xEdFilterArea->GetWidget()->has_focus() || m_xRbFilterArea->GetWidget()->has_focus() )
{
- pRefInputEdit = pEdFilterArea;
+ m_pRefInputEdit = m_xEdFilterArea.get();
bRefInputMode = true;
}
else if( bRefInputMode )
{
- pRefInputEdit = nullptr;
+ m_pRefInputEdit = nullptr;
bRefInputMode = false;
}
}
@@ -414,23 +383,23 @@ IMPL_LINK( ScSpecialFilterDlg, TimeOutHdl, Timer*, _pIdle, void )
pIdle->Start();
}
-IMPL_LINK( ScSpecialFilterDlg, FilterAreaSelHdl, ListBox&, rLb, void )
+IMPL_LINK(ScSpecialFilterDlg, FilterAreaSelHdl, weld::ComboBox&, rLb, void)
{
- if ( &rLb == pLbFilterArea )
+ if (&rLb == m_xLbFilterArea.get())
{
OUString aString;
- const sal_Int32 nSelPos = pLbFilterArea->GetSelectedEntryPos();
+ const sal_Int32 nSelPos = m_xLbFilterArea->get_active();
if ( nSelPos > 0 )
- aString = *static_cast<OUString*>(pLbFilterArea->GetEntryData( nSelPos ));
+ aString = m_xLbFilterArea->get_id(nSelPos);
- pEdFilterArea->SetText( aString );
+ m_xEdFilterArea->SetText( aString );
}
}
-IMPL_LINK( ScSpecialFilterDlg, FilterAreaModHdl, Edit&, rEd, void )
+IMPL_LINK( ScSpecialFilterDlg, FilterAreaModHdl, formula::WeldRefEdit&, rEd, void )
{
- if ( &rEd == pEdFilterArea )
+ if (&rEd == m_xEdFilterArea.get())
{
if ( pDoc && pViewData )
{
@@ -439,22 +408,21 @@ IMPL_LINK( ScSpecialFilterDlg, FilterAreaModHdl, Edit&, rEd, void )
if ( (nResult & ScRefFlags::VALID) == ScRefFlags::VALID )
{
- const sal_Int32 nCount = pLbFilterArea->GetEntryCount();
-
- for ( sal_Int32 i=1; i<nCount; ++i )
+ const sal_Int32 nCount = m_xLbFilterArea->get_count();
+ for (sal_Int32 i = 1; i < nCount; ++i)
{
- OUString* pStr = static_cast<OUString*>(pLbFilterArea->GetEntryData( i ));
- if (theCurAreaStr == *pStr)
+ OUString aStr = m_xLbFilterArea->get_id(i);
+ if (theCurAreaStr == aStr)
{
- pLbFilterArea->SelectEntryPos( i );
+ m_xLbFilterArea->set_active( i );
return;
}
}
- pLbFilterArea->SelectEntryPos( 0 );
+ m_xLbFilterArea->set_active( 0 );
}
}
else
- pLbFilterArea->SelectEntryPos( 0 );
+ m_xLbFilterArea->set_active( 0 );
}
}
diff --git a/sc/source/ui/inc/filtdlg.hxx b/sc/source/ui/inc/filtdlg.hxx
index 74e87b1cf12b..6e14a2444167 100644
--- a/sc/source/ui/inc/filtdlg.hxx
+++ b/sc/source/ui/inc/filtdlg.hxx
@@ -33,7 +33,6 @@
#include <vector>
#include <map>
-class ScFilterOptionsMgr;
class FilterOptionsMgr;
class ScViewData;
class ScDocument;
@@ -158,44 +157,24 @@ private:
DECL_LINK( TimeOutHdl, Timer*, void );
};
-class ScSpecialFilterDlg : public ScAnyRefDlg
+class ScSpecialFilterDlg : public ScAnyRefDlgController
{
public:
- ScSpecialFilterDlg( SfxBindings* pB, SfxChildWindow* pCW, vcl::Window* pParent,
- const SfxItemSet& rArgSet );
- virtual ~ScSpecialFilterDlg() override;
- virtual void dispose() override;
+ ScSpecialFilterDlg(SfxBindings* pB, SfxChildWindow* pCW, weld::Window* pParent,
+ const SfxItemSet& rArgSet);
+ virtual ~ScSpecialFilterDlg() override;
virtual void SetReference( const ScRange& rRef, ScDocument* pDoc ) override;
virtual bool IsRefInputMode() const override;
virtual void SetActive() override;
- virtual bool Close() override;
+ virtual void Close() override;
private:
- VclPtr<ListBox> pLbFilterArea;
- VclPtr<formula::RefEdit> pEdFilterArea;
- VclPtr<formula::RefButton> pRbFilterArea;
-
- VclPtr<VclExpander> pExpander;
- VclPtr<CheckBox> pBtnCase;
- VclPtr<CheckBox> pBtnRegExp;
- VclPtr<CheckBox> pBtnHeader;
- VclPtr<CheckBox> pBtnUnique;
- VclPtr<CheckBox> pBtnCopyResult;
- VclPtr<ListBox> pLbCopyArea;
- VclPtr<formula::RefEdit> pEdCopyArea;
- VclPtr<formula::RefButton> pRbCopyArea;
- VclPtr<CheckBox> pBtnDestPers;
- VclPtr<FixedText> pFtDbAreaLabel;
- VclPtr<FixedText> pFtDbArea;
const OUString aStrUndefined;
- VclPtr<OKButton> pBtnOk;
- VclPtr<CancelButton> pBtnCancel;
-
- std::unique_ptr<ScFilterOptionsMgr> pOptionsMgr;
+ std::unique_ptr<FilterOptionsMgr> pOptionsMgr;
const sal_uInt16 nWhichQuery;
const ScQueryParam theQueryData;
@@ -203,21 +182,45 @@ private:
ScViewData* pViewData;
ScDocument* pDoc;
- VclPtr<formula::RefEdit> pRefInputEdit;
bool bRefInputMode;
// Hack: RefInput control
std::unique_ptr<Idle> pIdle;
+ formula::WeldRefEdit* m_pRefInputEdit;
+
+ std::unique_ptr<weld::ComboBox> m_xLbFilterArea;
+ std::unique_ptr<formula::WeldRefEdit> m_xEdFilterArea;
+ std::unique_ptr<formula::WeldRefButton> m_xRbFilterArea;
+
+ std::unique_ptr<weld::Expander> m_xExpander;
+ std::unique_ptr<weld::CheckButton> m_xBtnCase;
+ std::unique_ptr<weld::CheckButton> m_xBtnRegExp;
+ std::unique_ptr<weld::CheckButton> m_xBtnHeader;
+ std::unique_ptr<weld::CheckButton> m_xBtnUnique;
+ std::unique_ptr<weld::CheckButton> m_xBtnCopyResult;
+ std::unique_ptr<weld::ComboBox> m_xLbCopyArea;
+ std::unique_ptr<formula::WeldRefEdit> m_xEdCopyArea;
+ std::unique_ptr<formula::WeldRefButton> m_xRbCopyArea;
+ std::unique_ptr<weld::CheckButton> m_xBtnDestPers;
+ std::unique_ptr<weld::Label> m_xFtDbAreaLabel;
+ std::unique_ptr<weld::Label> m_xFtDbArea;
+
+ std::unique_ptr<weld::Button> m_xBtnOk;
+ std::unique_ptr<weld::Button> m_xBtnCancel;
+
+ std::unique_ptr<weld::Frame> m_xFilterFrame;
+ std::unique_ptr<weld::Label> m_xFilterLabel;
+
private:
void Init( const SfxItemSet& rArgSet );
ScQueryItem* GetOutputItem( const ScQueryParam& rParam,
const ScRange& rSource );
// Handler
- DECL_LINK( FilterAreaSelHdl, ListBox&, void );
- DECL_LINK( FilterAreaModHdl, Edit&, void );
- DECL_LINK( EndDlgHdl, Button*, void );
+ DECL_LINK( FilterAreaSelHdl, weld::ComboBox&, void );
+ DECL_LINK( FilterAreaModHdl, formula::WeldRefEdit&, void );
+ DECL_LINK( EndDlgHdl, weld::Button&, void );
// Hack: RefInput control
DECL_LINK( TimeOutHdl, Timer*, void );
diff --git a/sc/source/ui/inc/reffact.hxx b/sc/source/ui/inc/reffact.hxx
index 3d44627c9e6d..09c83aaf5632 100644
--- a/sc/source/ui/inc/reffact.hxx
+++ b/sc/source/ui/inc/reffact.hxx
@@ -52,7 +52,7 @@ DECL_WRAPPER_WITHID(ScXMLSourceDlgWrapper)
DECL_WRAPPER_WITHID(ScPivotLayoutWrapper)
DECL_WRAPPER_WITHID_CONTROLLER(ScTabOpDlgWrapper)
DECL_WRAPPER_WITHID_CONTROLLER(ScFilterDlgWrapper)
-DECL_WRAPPER_WITHID(ScSpecialFilterDlgWrapper)
+DECL_WRAPPER_WITHID_CONTROLLER(ScSpecialFilterDlgWrapper)
DECL_WRAPPER_WITHID_CONTROLLER(ScDbNameDlgWrapper)
DECL_WRAPPER_WITHID_CONTROLLER(ScConsolidateDlgWrapper)
DECL_WRAPPER_WITHID_CONTROLLER(ScPrintAreasDlgWrapper)
diff --git a/sc/source/ui/view/reffact.cxx b/sc/source/ui/view/reffact.cxx
index 445de338882d..02c89d153321 100644
--- a/sc/source/ui/view/reffact.cxx
+++ b/sc/source/ui/view/reffact.cxx
@@ -40,7 +40,7 @@ SFX_IMPL_MODELESSDIALOG_WITHID(ScXMLSourceDlgWrapper, SID_MANAGE_XML_SOURCE)
SFX_IMPL_MODELESSDIALOG_WITHID(ScPivotLayoutWrapper, SID_OPENDLG_PIVOTTABLE )
SFX_IMPL_CHILDWINDOW_WITHID(ScTabOpDlgWrapper, SID_OPENDLG_TABOP )
SFX_IMPL_CHILDWINDOW_WITHID(ScFilterDlgWrapper, SID_FILTER )
-SFX_IMPL_MODELESSDIALOG_WITHID(ScSpecialFilterDlgWrapper, SID_SPECIAL_FILTER )
+SFX_IMPL_CHILDWINDOW_WITHID(ScSpecialFilterDlgWrapper, SID_SPECIAL_FILTER )
SFX_IMPL_CHILDWINDOW_WITHID(ScDbNameDlgWrapper, SID_DEFINE_DBNAME )
SFX_IMPL_CHILDWINDOW_WITHID(ScConsolidateDlgWrapper, SID_OPENDLG_CONSOLIDATE)
SFX_IMPL_CHILDWINDOW_WITHID(ScPrintAreasDlgWrapper, SID_OPENDLG_EDIT_PRINTAREA )
@@ -137,7 +137,7 @@ IMPL_CONTROLLER_CHILD_CTOR( ScTabOpDlgWrapper, SID_OPENDLG_TABOP )
IMPL_CONTROLLER_CHILD_CTOR( ScFilterDlgWrapper, SID_FILTER )
-IMPL_CHILD_CTOR( ScSpecialFilterDlgWrapper, SID_SPECIAL_FILTER )
+IMPL_CONTROLLER_CHILD_CTOR( ScSpecialFilterDlgWrapper, SID_SPECIAL_FILTER )
IMPL_CONTROLLER_CHILD_CTOR( ScDbNameDlgWrapper, SID_DEFINE_DBNAME )
diff --git a/sc/source/ui/view/tabvwshc.cxx b/sc/source/ui/view/tabvwshc.cxx
index 40d6a9744ea6..a13c875d776d 100644
--- a/sc/source/ui/view/tabvwshc.cxx
+++ b/sc/source/ui/view/tabvwshc.cxx
@@ -144,35 +144,6 @@ VclPtr<SfxModelessDialog> ScTabViewShell::CreateRefDialog(
switch( nSlotId )
{
- case SID_SPECIAL_FILTER:
- {
- ScQueryParam aQueryParam;
- SfxItemSet aArgSet( GetPool(),
- svl::Items<SCITEM_QUERYDATA,
- SCITEM_QUERYDATA>{} );
-
- ScDBData* pDBData = GetDBData(false, SC_DB_MAKE, ScGetDBSelection::RowDown);
- pDBData->ExtendDataArea(pDoc);
- pDBData->GetQueryParam( aQueryParam );
-
- ScRange aArea;
- pDBData->GetArea(aArea);
- MarkRange(aArea, false);
-
- ScQueryItem aItem( SCITEM_QUERYDATA, &GetViewData(), &aQueryParam );
- ScRange aAdvSource;
- if (pDBData->GetAdvancedQuerySource(aAdvSource))
- aItem.SetAdvancedQuerySource( &aAdvSource );
-
- aArgSet.Put( aItem );
-
- // mark current sheet (due to RefInput in dialog)
- GetViewData().SetRefTabNo( GetViewData().GetTabNo() );
-
- pResult = VclPtr<ScSpecialFilterDlg>::Create( pB, pCW, pParent, aArgSet );
- }
- break;
-
case SID_OPENDLG_OPTSOLVER:
{
ScViewData& rViewData = GetViewData();
@@ -485,6 +456,34 @@ std::unique_ptr<SfxModelessDialogController> ScTabViewShell::CreateRefDialogCont
xResult.reset(new ScFilterDlg(pB, pCW, pParent, aArgSet));
break;
}
+ case SID_SPECIAL_FILTER:
+ {
+ ScQueryParam aQueryParam;
+ SfxItemSet aArgSet( GetPool(),
+ svl::Items<SCITEM_QUERYDATA,
+ SCITEM_QUERYDATA>{} );
+
+ ScDBData* pDBData = GetDBData(false, SC_DB_MAKE, ScGetDBSelection::RowDown);
+ pDBData->ExtendDataArea(pDoc);
+ pDBData->GetQueryParam( aQueryParam );
+
+ ScRange aArea;
+ pDBData->GetArea(aArea);
+ MarkRange(aArea, false);
+
+ ScQueryItem aItem( SCITEM_QUERYDATA, &GetViewData(), &aQueryParam );
+ ScRange aAdvSource;
+ if (pDBData->GetAdvancedQuerySource(aAdvSource))
+ aItem.SetAdvancedQuerySource( &aAdvSource );
+
+ aArgSet.Put( aItem );
+
+ // mark current sheet (due to RefInput in dialog)
+ GetViewData().SetRefTabNo( GetViewData().GetTabNo() );
+
+ xResult.reset(new ScSpecialFilterDlg(pB, pCW, pParent, aArgSet));
+ break;
+ }
}
if (xResult)