summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2019-03-22 15:59:00 +0000
committerCaolán McNamara <caolanm@redhat.com>2019-03-24 18:19:29 +0100
commitf920e86fbf3968104e1dfc0e9934e80652ed0837 (patch)
tree01f8ed9c445821739b9709c5fee6e51eab0ae24d
parentda881f38c088c439f034e340bbbb4ca53e67389f (diff)
weld SvxSearchDialog
I have to use the other way to specify an a11y role, both are implemented in the vcl parser, but in my gtk3-3.24.7 the role tag crashes the gtk parser, while the other route works fine. The CONTENT_FLOWS_TO accessibility relation is another additional complexity over the norm Change-Id: Ia096bcbe9f00f9944e4e4d5ad9bb1a52d19c7b3f Reviewed-on: https://gerrit.libreoffice.org/69569 Tested-by: Jenkins Reviewed-by: Caolán McNamara <caolanm@redhat.com> Tested-by: Caolán McNamara <caolanm@redhat.com>
-rw-r--r--include/svx/srchdlg.hxx190
-rw-r--r--include/vcl/weld.hxx5
-rw-r--r--include/vcl/window.hxx4
-rw-r--r--sc/source/ui/view/tabvwshe.cxx8
-rw-r--r--sd/source/ui/view/Outliner.cxx2
-rw-r--r--solenv/clang-format/blacklist2
-rw-r--r--svx/Library_svx.mk1
-rw-r--r--svx/inc/AccessibleSvxFindReplaceDialog.hxx55
-rw-r--r--svx/source/accessibility/AccessibleSvxFindReplaceDialog.cxx95
-rw-r--r--svx/source/dialog/srchdlg.cxx1539
-rw-r--r--svx/uiconfig/ui/findreplacedialog.ui46
-rw-r--r--sw/source/core/crsr/viscrs.cxx4
-rw-r--r--sw/source/ui/fldui/fldtdlg.cxx2
-rw-r--r--toolkit/source/awt/vclxaccessiblecomponent.cxx3
-rw-r--r--vcl/inc/window.h3
-rw-r--r--vcl/source/app/salvtables.cxx10
-rw-r--r--vcl/source/window/window2.cxx16
-rw-r--r--vcl/unx/gtk/a11y/atkwrapper.cxx12
-rw-r--r--vcl/unx/gtk/a11y/atkwrapper.hxx2
-rw-r--r--vcl/unx/gtk3/gtk3gtkinst.cxx28
20 files changed, 954 insertions, 1073 deletions
diff --git a/include/svx/srchdlg.hxx b/include/svx/srchdlg.hxx
index 5b202aeebcc9..aa995edbf04f 100644
--- a/include/svx/srchdlg.hxx
+++ b/include/svx/srchdlg.hxx
@@ -89,13 +89,13 @@ enum class SearchLabel
class SvxSearchDialog;
class SVX_DLLPUBLIC SvxSearchDialogWrapper : public SfxChildWindow
{
- VclPtr<SvxSearchDialog> dialog;
+ std::shared_ptr<SvxSearchDialog> dialog;
public:
SvxSearchDialogWrapper( vcl::Window*pParent, sal_uInt16 nId,
SfxBindings* pBindings, SfxChildWinInfo const * pInfo );
virtual ~SvxSearchDialogWrapper () override;
- SvxSearchDialog *getDialog () { return dialog;}
+ SvxSearchDialog *getDialog () { return dialog.get();}
static void SetSearchLabel(const SearchLabel& rSL);
static void SetSearchLabel(const OUString& sStr);
static OUString GetSearchLabel();
@@ -109,18 +109,18 @@ public:
*/
-class SvxSearchDialog : public SfxModelessDialog
+class SVX_DLLPUBLIC SvxSearchDialog : public SfxModelessDialogController
{
friend class SvxSearchController;
friend class SvxSearchDialogWrapper;
friend class SvxJSearchOptionsDialog;
public:
- SvxSearchDialog( vcl::Window* pParent, SfxChildWindow* pChildWin, SfxBindings& rBind );
+ SvxSearchDialog(weld::Window* pParent, SfxChildWindow* pChildWin, SfxBindings& rBind );
virtual ~SvxSearchDialog() override;
- virtual void dispose() override;
- virtual bool Close() override;
+ virtual void EndDialog() override;
+ virtual void Close() override;
// Window
virtual void Activate() override;
@@ -132,74 +132,16 @@ public:
TransliterationFlags GetTransliterationFlags() const;
- void SetDocWin( vcl::Window* pDocWin ) { mpDocWin = pDocWin; }
- vcl::Window* GetDocWin() { return mpDocWin; }
+ void SetDocWin(vcl::Window* pDocWin);
void SetSrchFlag( bool bSuccess ) { mbSuccess = bSuccess; }
bool GetSrchFlag() { return mbSuccess; }
- virtual css::uno::Reference< css::awt::XWindowPeer >
- GetComponentInterface( bool bCreate = true ) override;
-
void SetSaveToModule(bool b);
- void SetSearchLabel(const OUString& rStr) { m_pSearchLabel->SetText(rStr); }
+ void SetSearchLabel(const OUString& rStr) { m_xSearchLabel->set_label(rStr); }
private:
- VclPtr<vcl::Window> mpDocWin;
bool mbSuccess;
-
- VclPtr<VclFrame> m_pSearchFrame;
- VclPtr<ComboBox> m_pSearchLB;
- VclPtr<ListBox> m_pSearchTmplLB;
- VclPtr<FixedText> m_pSearchAttrText;
- VclPtr<FixedText> m_pSearchLabel;
-
- VclPtr<VclFrame> m_pReplaceFrame;
- VclPtr<ComboBox> m_pReplaceLB;
- VclPtr<ListBox> m_pReplaceTmplLB;
- VclPtr<FixedText> m_pReplaceAttrText;
-
- VclPtr<PushButton> m_pSearchBtn;
- VclPtr<PushButton> m_pBackSearchBtn;
- VclPtr<PushButton> m_pSearchAllBtn;
- VclPtr<PushButton> m_pReplaceBtn;
- VclPtr<PushButton> m_pReplaceAllBtn;
-
- VclPtr<VclFrame> m_pComponentFrame;
- VclPtr<PushButton> m_pSearchComponent1PB;
- VclPtr<PushButton> m_pSearchComponent2PB;
-
- VclPtr<CheckBox> m_pMatchCaseCB;
- VclPtr<CheckBox> m_pSearchFormattedCB;
- VclPtr<CheckBox> m_pWordBtn;
-
- VclPtr<PushButton> m_pCloseBtn;
- VclPtr<CheckBox> m_pIncludeDiacritics;
- VclPtr<CheckBox> m_pIncludeKashida;
- VclPtr<VclExpander> m_pOtherOptionsExpander;
- VclPtr<CheckBox> m_pSelectionBtn;
- VclPtr<CheckBox> m_pRegExpBtn;
- VclPtr<CheckBox> m_pWildcardBtn;
- VclPtr<CheckBox> m_pSimilarityBox;
- VclPtr<PushButton> m_pSimilarityBtn;
- VclPtr<CheckBox> m_pLayoutBtn;
- VclPtr<CheckBox> m_pNotesBtn;
- VclPtr<CheckBox> m_pJapMatchFullHalfWidthCB;
- VclPtr<CheckBox> m_pJapOptionsCB;
- VclPtr<CheckBox> m_pReplaceBackwardsCB;
- VclPtr<PushButton> m_pJapOptionsBtn;
-
- VclPtr<PushButton> m_pAttributeBtn;
- VclPtr<PushButton> m_pFormatBtn;
- VclPtr<PushButton> m_pNoFormatBtn;
-
- VclPtr<VclContainer> m_pCalcGrid;
- VclPtr<FixedText> m_pCalcSearchInFT;
- VclPtr<ListBox> m_pCalcSearchInLB;
- VclPtr<FixedText> m_pCalcSearchDirFT;
- VclPtr<RadioButton> m_pRowsBtn;
- VclPtr<RadioButton> m_pColumnsBtn;
- VclPtr<CheckBox> m_pAllSheetsCB;
-
+ bool mbClosing;
SfxBindings& rBindings;
bool bWriter;
@@ -234,41 +176,95 @@ private:
bool m_executingSubDialog = false;
- DECL_LINK( ModifyHdl_Impl, Edit&, void );
- DECL_LINK( FlagHdl_Impl, Button*, void );
- DECL_LINK( CommandHdl_Impl, Button*, void );
- DECL_LINK(TemplateHdl_Impl, Button*, void);
- DECL_LINK( FocusHdl_Impl, Control&, void );
- DECL_LINK( LBSelectHdl_Impl, ListBox&, void );
- DECL_LINK(LoseFocusHdl_Impl, Control&, void);
- DECL_LINK(FormatHdl_Impl, Button*, void);
- DECL_LINK(NoFormatHdl_Impl, Button*, void);
- DECL_LINK(AttributeHdl_Impl, Button*, void);
- DECL_LINK( TimeoutHdl_Impl, Timer*, void );
- void ClickHdl_Impl(void const * pCtrl);
-
- void Construct_Impl();
- void InitControls_Impl();
- void ShowOptionalControls_Impl();
- void Init_Impl( bool bHasItemSet );
- void InitAttrList_Impl( const SfxItemSet* pSSet,
+ std::unique_ptr<weld::Frame> m_xSearchFrame;
+ std::unique_ptr<weld::ComboBox> m_xSearchLB;
+ std::unique_ptr<weld::ComboBox> m_xSearchTmplLB;
+ std::unique_ptr<weld::Label> m_xSearchAttrText;
+ std::unique_ptr<weld::Label> m_xSearchLabel;
+
+ std::unique_ptr<weld::Frame> m_xReplaceFrame;
+ std::unique_ptr<weld::ComboBox> m_xReplaceLB;
+ std::unique_ptr<weld::ComboBox> m_xReplaceTmplLB;
+ std::unique_ptr<weld::Label> m_xReplaceAttrText;
+
+ std::unique_ptr<weld::Button> m_xSearchBtn;
+ std::unique_ptr<weld::Button> m_xBackSearchBtn;
+ std::unique_ptr<weld::Button> m_xSearchAllBtn;
+ std::unique_ptr<weld::Button> m_xReplaceBtn;
+ std::unique_ptr<weld::Button> m_xReplaceAllBtn;
+
+ std::unique_ptr<weld::Frame> m_xComponentFrame;
+ std::unique_ptr<weld::Button> m_xSearchComponent1PB;
+ std::unique_ptr<weld::Button> m_xSearchComponent2PB;
+
+ std::unique_ptr<weld::CheckButton> m_xMatchCaseCB;
+ std::unique_ptr<weld::CheckButton> m_xSearchFormattedCB;
+ std::unique_ptr<weld::CheckButton> m_xWordBtn;
+
+ std::unique_ptr<weld::Button> m_xCloseBtn;
+ std::unique_ptr<weld::CheckButton> m_xIncludeDiacritics;
+ std::unique_ptr<weld::CheckButton> m_xIncludeKashida;
+ std::unique_ptr<weld::Expander> m_xOtherOptionsExpander;
+ std::unique_ptr<weld::CheckButton> m_xSelectionBtn;
+ std::unique_ptr<weld::CheckButton> m_xRegExpBtn;
+ std::unique_ptr<weld::CheckButton> m_xWildcardBtn;
+ std::unique_ptr<weld::CheckButton> m_xSimilarityBox;
+ std::unique_ptr<weld::Button> m_xSimilarityBtn;
+ std::unique_ptr<weld::CheckButton> m_xLayoutBtn;
+ std::unique_ptr<weld::CheckButton> m_xNotesBtn;
+ std::unique_ptr<weld::CheckButton> m_xJapMatchFullHalfWidthCB;
+ std::unique_ptr<weld::CheckButton> m_xJapOptionsCB;
+ std::unique_ptr<weld::CheckButton> m_xReplaceBackwardsCB;
+ std::unique_ptr<weld::Button> m_xJapOptionsBtn;
+
+ std::unique_ptr<weld::Button> m_xAttributeBtn;
+ std::unique_ptr<weld::Button> m_xFormatBtn;
+ std::unique_ptr<weld::Button> m_xNoFormatBtn;
+
+ std::unique_ptr<weld::Widget> m_xCalcGrid;
+ std::unique_ptr<weld::Label> m_xCalcSearchInFT;
+ std::unique_ptr<weld::ComboBox> m_xCalcSearchInLB;
+ std::unique_ptr<weld::Label> m_xCalcSearchDirFT;
+ std::unique_ptr<weld::RadioButton> m_xRowsBtn;
+ std::unique_ptr<weld::RadioButton> m_xColumnsBtn;
+ std::unique_ptr<weld::CheckButton> m_xAllSheetsCB;
+ std::unique_ptr<weld::Label> m_xCalcStrFT;
+
+ DECL_DLLPRIVATE_LINK( ModifyHdl_Impl, weld::ComboBox&, void );
+ DECL_DLLPRIVATE_LINK( FlagHdl_Impl, weld::Button&, void );
+ DECL_DLLPRIVATE_LINK( CommandHdl_Impl, weld::Button&, void );
+ DECL_DLLPRIVATE_LINK(TemplateHdl_Impl, weld::Button&, void);
+ DECL_DLLPRIVATE_LINK( FocusHdl_Impl, weld::Widget&, void );
+ DECL_DLLPRIVATE_LINK( LBSelectHdl_Impl, weld::ComboBox&, void );
+ DECL_DLLPRIVATE_LINK(LoseFocusHdl_Impl, weld::Widget&, void);
+ DECL_DLLPRIVATE_LINK(FormatHdl_Impl, weld::Button&, void);
+ DECL_DLLPRIVATE_LINK(NoFormatHdl_Impl, weld::Button&, void);
+ DECL_DLLPRIVATE_LINK(AttributeHdl_Impl, weld::Button&, void);
+ DECL_DLLPRIVATE_LINK( TimeoutHdl_Impl, Timer*, void );
+ SVX_DLLPRIVATE void ClickHdl_Impl(const weld::Widget* pCtrl);
+
+ SVX_DLLPRIVATE void Construct_Impl();
+ SVX_DLLPRIVATE void InitControls_Impl();
+ SVX_DLLPRIVATE void ShowOptionalControls_Impl();
+ SVX_DLLPRIVATE void Init_Impl( bool bHasItemSet );
+ SVX_DLLPRIVATE void InitAttrList_Impl( const SfxItemSet* pSSet,
const SfxItemSet* pRSet );
- void Remember_Impl( const OUString &rStr, bool bSearch );
- void PaintAttrText_Impl();
- OUString& BuildAttrText_Impl( OUString& rStr, bool bSrchFlag ) const;
+ SVX_DLLPRIVATE void Remember_Impl( const OUString &rStr, bool bSearch );
+ SVX_DLLPRIVATE void PaintAttrText_Impl();
+ SVX_DLLPRIVATE OUString& BuildAttrText_Impl( OUString& rStr, bool bSrchFlag ) const;
- void TemplatesChanged_Impl( SfxStyleSheetBasePool& rPool );
- void EnableControls_Impl( const SearchOptionFlags nFlags );
- void EnableControl_Impl( Control const * pCtrl );
- void SetItem_Impl( const SvxSearchItem* pItem );
+ SVX_DLLPRIVATE void TemplatesChanged_Impl( SfxStyleSheetBasePool& rPool );
+ SVX_DLLPRIVATE void EnableControls_Impl( const SearchOptionFlags nFlags );
+ SVX_DLLPRIVATE void EnableControl_Impl(const weld::Widget& rCtrl);
+ SVX_DLLPRIVATE void SetItem_Impl( const SvxSearchItem* pItem );
- void SetModifyFlag_Impl( const Control* pCtrl );
- void SaveToModule_Impl();
+ SVX_DLLPRIVATE void SetModifyFlag_Impl(const weld::Widget* pCtrl);
+ SVX_DLLPRIVATE void SaveToModule_Impl();
- void ApplyTransliterationFlags_Impl( TransliterationFlags nSettings );
- bool IsOtherOptionsExpanded();
+ SVX_DLLPRIVATE void ApplyTransliterationFlags_Impl( TransliterationFlags nSettings );
+ SVX_DLLPRIVATE bool IsOtherOptionsExpanded();
- short executeSubDialog(VclAbstractDialog * dialog);
+ SVX_DLLPRIVATE short executeSubDialog(VclAbstractDialog * dialog);
};
#endif
diff --git a/include/vcl/weld.hxx b/include/vcl/weld.hxx
index 96f292c4d695..a180243019df 100644
--- a/include/vcl/weld.hxx
+++ b/include/vcl/weld.hxx
@@ -141,6 +141,11 @@ public:
virtual void set_accessible_relation_labeled_by(weld::Widget* pLabel) = 0;
virtual void set_accessible_relation_label_for(weld::Widget* pLabeled) = 0;
+ virtual void
+ add_extra_accessible_relation(const css::accessibility::AccessibleRelation& rRelation)
+ = 0;
+ virtual void clear_extra_accessible_relations() = 0;
+
virtual void set_tooltip_text(const OUString& rTip) = 0;
virtual OUString get_tooltip_text() const = 0;
diff --git a/include/vcl/window.hxx b/include/vcl/window.hxx
index fff03ed1ffb5..c109e80d982d 100644
--- a/include/vcl/window.hxx
+++ b/include/vcl/window.hxx
@@ -67,6 +67,7 @@ enum class PointerStyle;
namespace com { namespace sun { namespace star {
namespace accessibility {
+ struct AccessibleRelation;
class XAccessible;
}
@@ -1252,6 +1253,9 @@ public:
void SetAccessibleRelationMemberOf( vcl::Window* pMemberOf );
vcl::Window* GetAccessibleRelationMemberOf() const;
+ void AddExtraAccessibleRelation(const css::accessibility::AccessibleRelation &rRelation);
+ const std::vector<css::accessibility::AccessibleRelation>& GetExtraAccessibleRelations() const;
+ void ClearExtraAccessibleRelations();
// to avoid sending accessibility events in cases like closing dialogs
// by default checks complete parent path
diff --git a/sc/source/ui/view/tabvwshe.cxx b/sc/source/ui/view/tabvwshe.cxx
index 0059534c22dd..faeb5d05bdfb 100644
--- a/sc/source/ui/view/tabvwshe.cxx
+++ b/sc/source/ui/view/tabvwshe.cxx
@@ -233,11 +233,11 @@ void ScTabViewShell::ExecSearch( SfxRequest& rReq )
ScGlobal::SetSearchItem( *pSearchItem );
bool bSuccess = SearchAndReplace( pSearchItem, true, rReq.IsAPI() );
- const SfxChildWindow* pChildWindow = SfxViewFrame::Current()->GetChildWindow(
+ SfxChildWindow* pChildWindow = SfxViewFrame::Current()->GetChildWindow(
SvxSearchDialogWrapper::GetChildWindowId());
if (pChildWindow)
{
- SvxSearchDialog* pSearchDlg = static_cast<SvxSearchDialog*>(pChildWindow->GetWindow());
+ SvxSearchDialog* pSearchDlg = static_cast<SvxSearchDialog*>(pChildWindow->GetController().get());
if( pSearchDlg )
{
ScTabView* pTabView = GetViewData().GetView();
@@ -303,11 +303,11 @@ void ScTabViewShell::ExecSearch( SfxRequest& rReq )
rReq.IsAPI() ? SfxCallMode::API|SfxCallMode::SYNCHRON :
SfxCallMode::RECORD,
{ &aSearchItem });
- const SfxChildWindow* pChildWindow = SfxViewFrame::Current()->GetChildWindow(
+ SfxChildWindow* pChildWindow = SfxViewFrame::Current()->GetChildWindow(
SvxSearchDialogWrapper::GetChildWindowId());
if (pChildWindow)
{
- SvxSearchDialog* pSearchDlg = static_cast<SvxSearchDialog*>(pChildWindow->GetWindow());
+ SvxSearchDialog* pSearchDlg = static_cast<SvxSearchDialog*>(pChildWindow->GetController().get());
if( pSearchDlg )
{
ScTabView* pTabView = GetViewData().GetView();
diff --git a/sd/source/ui/view/Outliner.cxx b/sd/source/ui/view/Outliner.cxx
index df322f51706b..6c537dce7b81 100644
--- a/sd/source/ui/view/Outliner.cxx
+++ b/sd/source/ui/view/Outliner.cxx
@@ -507,7 +507,7 @@ bool SdOutliner::StartSearchAndReplace (const SvxSearchItem* pSearchItem)
if (pChildWin)
{
SvxSearchDialog* pSearchDlg =
- static_cast<SvxSearchDialog*>(pChildWin->GetWindow());
+ static_cast<SvxSearchDialog*>(pChildWin->GetController().get());
pSearchDlg->SetDocWin( pViewShell->GetActiveWindow() );
pSearchDlg->SetSrchFlag(false);
}
diff --git a/solenv/clang-format/blacklist b/solenv/clang-format/blacklist
index cf9808cb3da4..99522e3d8921 100644
--- a/solenv/clang-format/blacklist
+++ b/solenv/clang-format/blacklist
@@ -13861,7 +13861,6 @@ svtools/source/uno/wizard/wizardpagecontroller.cxx
svtools/source/uno/wizard/wizardpagecontroller.hxx
svtools/source/uno/wizard/wizardshell.cxx
svtools/source/uno/wizard/wizardshell.hxx
-svx/inc/AccessibleSvxFindReplaceDialog.hxx
svx/inc/AccessibleTableShape.hxx
svx/inc/GalleryControl.hxx
svx/inc/dragmt3d.hxx
@@ -13980,7 +13979,6 @@ svx/source/accessibility/AccessibleOLEShape.cxx
svx/source/accessibility/AccessibleShape.cxx
svx/source/accessibility/AccessibleShapeInfo.cxx
svx/source/accessibility/AccessibleShapeTreeInfo.cxx
-svx/source/accessibility/AccessibleSvxFindReplaceDialog.cxx
svx/source/accessibility/AccessibleTextEventQueue.cxx
svx/source/accessibility/AccessibleTextEventQueue.hxx
svx/source/accessibility/AccessibleTextHelper.cxx
diff --git a/svx/Library_svx.mk b/svx/Library_svx.mk
index b9acb5e380e5..b8043c4019fe 100644
--- a/svx/Library_svx.mk
+++ b/svx/Library_svx.mk
@@ -89,7 +89,6 @@ $(eval $(call gb_Library_add_exception_objects,svx,\
svx/source/accessibility/AccessibleShape \
svx/source/accessibility/AccessibleShapeInfo \
svx/source/accessibility/AccessibleShapeTreeInfo \
- svx/source/accessibility/AccessibleSvxFindReplaceDialog \
svx/source/accessibility/AccessibleTextEventQueue \
svx/source/accessibility/AccessibleTextHelper \
svx/source/accessibility/ChildrenManager \
diff --git a/svx/inc/AccessibleSvxFindReplaceDialog.hxx b/svx/inc/AccessibleSvxFindReplaceDialog.hxx
deleted file mode 100644
index a460dcc80b4e..000000000000
--- a/svx/inc/AccessibleSvxFindReplaceDialog.hxx
+++ /dev/null
@@ -1,55 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- *
- * This file incorporates work covered by the following license notice:
- *
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed
- * with this work for additional information regarding copyright
- * ownership. The ASF licenses this file to you under the Apache
- * License, Version 2.0 (the "License"); you may not use this file
- * except in compliance with the License. You may obtain a copy of
- * the License at http://www.apache.org/licenses/LICENSE-2.0 .
- */
-#ifndef INCLUDED_SVX_INC_ACCESSIBLESVXFINDREPLACEDIALOG_HXX
-#define INCLUDED_SVX_INC_ACCESSIBLESVXFINDREPLACEDIALOG_HXX
-
-#include <toolkit/awt/vclxwindow.hxx>
-#include <toolkit/awt/vclxaccessiblecomponent.hxx>
-#include <toolkit/awt/vclxwindows.hxx>
-
-
-class VCLXAccessibleSvxFindReplaceDialog : public VCLXAccessibleComponent
-{
-public:
- VCLXAccessibleSvxFindReplaceDialog(VCLXWindow* pVCLXindow);
- virtual ~VCLXAccessibleSvxFindReplaceDialog() override;
- virtual void FillAccessibleRelationSet( utl::AccessibleRelationSetHelper& rRelationSet ) override;
- // XServiceInfo
- virtual OUString SAL_CALL getImplementationName() override;
- virtual css::uno::Sequence< OUString > SAL_CALL getSupportedServiceNames() override;
-
-};
-
-
-class VCLXSvxFindReplaceDialog : public VCLXDialog
-{
-public:
- VCLXSvxFindReplaceDialog(vcl::Window* pSplDlg)
- {
- SetWindow(pSplDlg);
- }
-private:
- virtual css::uno::Reference< css::accessibility::XAccessibleContext > CreateAccessibleContext() override
- {
- return new VCLXAccessibleSvxFindReplaceDialog(this);
- }
-};
-#endif
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/svx/source/accessibility/AccessibleSvxFindReplaceDialog.cxx b/svx/source/accessibility/AccessibleSvxFindReplaceDialog.cxx
deleted file mode 100644
index 1e0ca231c092..000000000000
--- a/svx/source/accessibility/AccessibleSvxFindReplaceDialog.cxx
+++ /dev/null
@@ -1,95 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*
- * This file is part of the LibreOffice project.
- *
- * This Source Code Form is subject to the terms of the Mozilla Public
- * License, v. 2.0. If a copy of the MPL was not distributed with this
- * file, You can obtain one at http://mozilla.org/MPL/2.0/.
- *
- * This file incorporates work covered by the following license notice:
- *
- * Licensed to the Apache Software Foundation (ASF) under one or more
- * contributor license agreements. See the NOTICE file distributed
- * with this work for additional information regarding copyright
- * ownership. The ASF licenses this file to you under the Apache
- * License, Version 2.0 (the "License"); you may not use this file
- * except in compliance with the License. You may obtain a copy of
- * the License at http://www.apache.org/licenses/LICENSE-2.0 .
- */
-#include <AccessibleSvxFindReplaceDialog.hxx>
-#include <svx/srchdlg.hxx>
-#include <toolkit/awt/vclxwindow.hxx>
-#include <unotools/accessiblerelationsethelper.hxx>
-#include <com/sun/star/accessibility/AccessibleRelationType.hpp>
-#include <com/sun/star/accessibility/XAccessibleGetAccFlowTo.hpp>
-
-using namespace ::com::sun::star;
-using namespace ::com::sun::star::uno;
-
-VCLXAccessibleSvxFindReplaceDialog::VCLXAccessibleSvxFindReplaceDialog(VCLXWindow* pVCLXindow)
- :VCLXAccessibleComponent( pVCLXindow )
-{
-
-}
-
-VCLXAccessibleSvxFindReplaceDialog::~VCLXAccessibleSvxFindReplaceDialog()
-{
-}
-
-void VCLXAccessibleSvxFindReplaceDialog::FillAccessibleRelationSet( utl::AccessibleRelationSetHelper& rRelationSet )
-{
- VCLXAccessibleComponent::FillAccessibleRelationSet( rRelationSet );
- VclPtr<vcl::Window> pDlg = GetWindow();
- if ( !pDlg )
- return;
-
- SvxSearchDialog* pSrchDlg = static_cast<SvxSearchDialog*>( pDlg.get() );
- vcl::Window* pDocWin = pSrchDlg->GetDocWin();
- if ( !pDocWin )
- {
- return;
- }
- Reference < css::accessibility::XAccessible > xDocAcc = pDocWin->GetAccessible();
- if ( !xDocAcc.is() )
- {
- return;
- }
- Reference< css::accessibility::XAccessibleGetAccFlowTo > xGetAccFlowTo( xDocAcc, UNO_QUERY );
- if ( !xGetAccFlowTo.is() )
- {
- return;
- }
-
- const sal_Int32 FORFINDREPLACEFLOWTO = 2;
- uno::Sequence<uno::Any> aAnySeq = xGetAccFlowTo->getAccFlowTo( Any(pSrchDlg->GetSrchFlag()), FORFINDREPLACEFLOWTO );
-
- sal_Int32 nLen = aAnySeq.getLength();
- if ( nLen )
- {
- uno::Sequence< uno::Reference< uno::XInterface > > aSequence( nLen );
- for ( sal_Int32 i = 0; i < nLen; i++ )
- {
- uno::Reference < css::accessibility::XAccessible > xAcc;
- aAnySeq[i] >>= xAcc;
- aSequence[i] = xAcc;
- }
- rRelationSet.AddRelation( css::accessibility::AccessibleRelation( css::accessibility::AccessibleRelationType::CONTENT_FLOWS_TO, aSequence ) );
- }
-}
-
-// XServiceInfo
-
-
-OUString VCLXAccessibleSvxFindReplaceDialog::getImplementationName()
-{
- return OUString( "VCLXAccessibleSvxFindReplaceDialog" );
-}
-
-
-Sequence< OUString > VCLXAccessibleSvxFindReplaceDialog::getSupportedServiceNames()
-{
- Sequence< OUString > aNames { "VCLXAccessibleSvxFindReplaceDialog" };
- return aNames;
-}
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/svx/source/dialog/srchdlg.cxx b/svx/source/dialog/srchdlg.cxx
index d23071acac66..c887d9cf38ee 100644
--- a/svx/source/dialog/srchdlg.cxx
+++ b/svx/source/dialog/srchdlg.cxx
@@ -34,6 +34,9 @@
#include <svl/cjkoptions.hxx>
#include <svl/ctloptions.hxx>
#include <com/sun/star/awt/XWindow.hpp>
+#include <com/sun/star/accessibility/AccessibleRelation.hpp>
+#include <com/sun/star/accessibility/AccessibleRelationType.hpp>
+#include <com/sun/star/accessibility/XAccessibleGetAccFlowTo.hpp>
#include <com/sun/star/container/XNameAccess.hpp>
#include <com/sun/star/frame/XDispatch.hpp>
#include <com/sun/star/frame/XDispatchProvider.hpp>
@@ -58,7 +61,6 @@
#include <svx/svxitems.hrc>
#include <svl/srchitem.hxx>
-#include <AccessibleSvxFindReplaceDialog.hxx>
#include <svx/pageitem.hxx>
#include "srchctrl.hxx"
#include <svx/dialmgr.hxx>
@@ -107,13 +109,14 @@ namespace o3tl {
namespace
{
- bool GetCheckBoxValue(const CheckBox *pBox)
+ bool GetCheckBoxValue(const weld::CheckButton& rBox)
{
- return pBox->IsEnabled() && pBox->IsChecked();
+ return rBox.get_sensitive() && rBox.get_active();
}
- bool GetNegatedCheckBoxValue(const CheckBox *pBox)
+
+ bool GetNegatedCheckBoxValue(const weld::CheckButton& rBox)
{
- return pBox->IsEnabled() && !pBox->IsChecked();
+ return rBox.get_sensitive() && !rBox.get_active();
}
}
@@ -142,7 +145,7 @@ struct SearchDlg_Impl
}
};
-static void ListToStrArr_Impl( sal_uInt16 nId, std::vector<OUString>& rStrLst, ComboBox& rCBox )
+static void ListToStrArr_Impl( sal_uInt16 nId, std::vector<OUString>& rStrLst, weld::ComboBox& rCBox )
{
const SfxStringListItem* pSrchItem =
static_cast<const SfxStringListItem*>(SfxGetpApp()->GetItem( nId ));
@@ -154,7 +157,7 @@ static void ListToStrArr_Impl( sal_uInt16 nId, std::vector<OUString>& rStrLst, C
for (const OUString & s : aLst)
{
rStrLst.push_back(s);
- rCBox.InsertEntry(s);
+ rCBox.append_text(s);
}
}
}
@@ -173,13 +176,11 @@ SearchAttrItemList::SearchAttrItemList( const SearchAttrItemList& rList ) :
(*this)[i].pItem = (*this)[i].pItem->Clone();
}
-
SearchAttrItemList::~SearchAttrItemList()
{
Clear();
}
-
void SearchAttrItemList::Put( const SfxItemSet& rSet )
{
if ( !rSet.Count() )
@@ -251,11 +252,11 @@ void SearchAttrItemList::Remove(size_t nPos)
SrchAttrItemList::erase( begin() + nPos, begin() + nPos + nLen );
}
-SvxSearchDialog::SvxSearchDialog( vcl::Window* pParent, SfxChildWindow* pChildWin, SfxBindings& rBind )
- : SfxModelessDialog(&rBind, pChildWin, pParent, "FindReplaceDialog",
- "svx/ui/findreplacedialog.ui")
- , mpDocWin(nullptr)
+SvxSearchDialog::SvxSearchDialog(weld::Window* pParent, SfxChildWindow* pChildWin, SfxBindings& rBind)
+ : SfxModelessDialogController(&rBind, pChildWin, pParent,
+ "svx/ui/findreplacedialog.ui", "FindReplaceDialog")
, mbSuccess(false)
+ , mbClosing(false)
, rBindings(rBind)
, bWriter(false)
, bSearch(true)
@@ -267,151 +268,84 @@ SvxSearchDialog::SvxSearchDialog( vcl::Window* pParent, SfxChildWindow* pChildWi
, nModifyFlag(ModifyFlags::NONE)
, pReplaceList(new SearchAttrItemList)
, nTransliterationFlags(TransliterationFlags::NONE)
+ , m_xSearchFrame(m_xBuilder->weld_frame("searchframe"))
+ , m_xSearchLB(m_xBuilder->weld_combo_box("searchterm"))
+ , m_xSearchTmplLB(m_xBuilder->weld_combo_box("searchlist"))
+ , m_xSearchAttrText(m_xBuilder->weld_label("searchdesc"))
+ , m_xSearchLabel(m_xBuilder->weld_label("searchlabel"))
+ , m_xReplaceFrame(m_xBuilder->weld_frame("replaceframe"))
+ , m_xReplaceLB(m_xBuilder->weld_combo_box("replaceterm"))
+ , m_xReplaceTmplLB(m_xBuilder->weld_combo_box("replacelist"))
+ , m_xReplaceAttrText(m_xBuilder->weld_label("replacedesc"))
+ , m_xSearchBtn(m_xBuilder->weld_button("search"))
+ , m_xBackSearchBtn(m_xBuilder->weld_button("backsearch"))
+ , m_xSearchAllBtn(m_xBuilder->weld_button("searchall"))
+ , m_xReplaceBtn(m_xBuilder->weld_button("replace"))
+ , m_xReplaceAllBtn(m_xBuilder->weld_button("replaceall"))
+ , m_xComponentFrame(m_xBuilder->weld_frame("componentframe"))
+ , m_xSearchComponent1PB(m_xBuilder->weld_button("component1"))
+ , m_xSearchComponent2PB(m_xBuilder->weld_button("component2"))
+ , m_xMatchCaseCB(m_xBuilder->weld_check_button("matchcase"))
+ , m_xSearchFormattedCB(m_xBuilder->weld_check_button("searchformatted"))
+ , m_xWordBtn(m_xBuilder->weld_check_button("wholewords"))
+ , m_xCloseBtn(m_xBuilder->weld_button("close"))
+ , m_xIncludeDiacritics(m_xBuilder->weld_check_button("includediacritics"))
+ , m_xIncludeKashida(m_xBuilder->weld_check_button("includekashida"))
+ , m_xOtherOptionsExpander(m_xBuilder->weld_expander("OptionsExpander"))
+ , m_xSelectionBtn(m_xBuilder->weld_check_button("selection"))
+ , m_xRegExpBtn(m_xBuilder->weld_check_button("regexp"))
+ , m_xWildcardBtn(m_xBuilder->weld_check_button("wildcard"))
+ , m_xSimilarityBox(m_xBuilder->weld_check_button("similarity"))
+ , m_xSimilarityBtn(m_xBuilder->weld_button("similaritybtn"))
+ , m_xLayoutBtn(m_xBuilder->weld_check_button("layout"))
+ , m_xNotesBtn(m_xBuilder->weld_check_button("notes"))
+ , m_xJapMatchFullHalfWidthCB(m_xBuilder->weld_check_button("matchcharwidth"))
+ , m_xJapOptionsCB(m_xBuilder->weld_check_button("soundslike"))
+ , m_xReplaceBackwardsCB(m_xBuilder->weld_check_button("replace_backwards"))
+ , m_xJapOptionsBtn(m_xBuilder->weld_button("soundslikebtn"))
+ , m_xAttributeBtn(m_xBuilder->weld_button("attributes"))
+ , m_xFormatBtn(m_xBuilder->weld_button("format"))
+ , m_xNoFormatBtn(m_xBuilder->weld_button("noformat"))
+ , m_xCalcGrid(m_xBuilder->weld_widget("calcgrid"))
+ , m_xCalcSearchInFT(m_xBuilder->weld_label("searchinlabel"))
+ , m_xCalcSearchInLB(m_xBuilder->weld_combo_box("calcsearchin"))
+ , m_xCalcSearchDirFT(m_xBuilder->weld_label("searchdir"))
+ , m_xRowsBtn(m_xBuilder->weld_radio_button("rows"))
+ , m_xColumnsBtn(m_xBuilder->weld_radio_button("cols"))
+ , m_xAllSheetsCB(m_xBuilder->weld_check_button("allsheets"))
+ , m_xCalcStrFT(m_xBuilder->weld_label("entirecells"))
{
- get(m_pSearchFrame, "searchframe");
- get(m_pSearchLB, "searchterm");
- get(m_pSearchTmplLB, "searchlist");
- m_pSearchTmplLB->SetStyle(m_pSearchTmplLB->GetStyle() | WB_SORT);
- get(m_pSearchBtn, "search");
- get(m_pBackSearchBtn, "backsearch");
- get(m_pSearchAllBtn, "searchall");
- get(m_pSearchAttrText, "searchdesc");
- m_pSearchAttrText->SetStyle(m_pSearchAttrText->GetStyle() | WB_PATHELLIPSIS);
- m_pSearchAttrText->Hide();
- get(m_pSearchLabel, "searchlabel");
- m_pSearchLabel->SetStyle(m_pSearchLabel->GetStyle() | WB_PATHELLIPSIS);
- m_pSearchLabel->Show();
-
- get(m_pReplaceFrame, "replaceframe");
- get(m_pReplaceLB, "replaceterm");
- get(m_pReplaceTmplLB, "replacelist");
- m_pReplaceTmplLB->SetStyle(m_pReplaceTmplLB->GetStyle() | WB_SORT);
- get(m_pReplaceBtn, "replace");
- get(m_pReplaceAllBtn, "replaceall");
- get(m_pReplaceAttrText, "replacedesc");
- m_pReplaceAttrText->SetStyle(m_pReplaceAttrText->GetStyle() | WB_PATHELLIPSIS);
- m_pReplaceAttrText->Hide();
-
- get(m_pComponentFrame, "componentframe");
- get(m_pSearchComponent1PB, "component1");
- get(m_pSearchComponent2PB, "component2");
-
- get(m_pMatchCaseCB, "matchcase");
- get(m_pSearchFormattedCB, "searchformatted");
- get(m_pWordBtn, "wholewords");
- aCalcStr = get<FixedText>("entirecells")->GetText();
-
- get(m_pCloseBtn, "close");
-
- get(m_pOtherOptionsExpander, "OptionsExpander");
- get(m_pIncludeDiacritics, "includediacritics");
- get(m_pIncludeKashida, "includekashida");
- get(m_pSelectionBtn, "selection");
- get(m_pReplaceBackwardsCB, "replace_backwards");
- get(m_pRegExpBtn, "regexp");
- get(m_pWildcardBtn, "wildcard");
- get(m_pSimilarityBox, "similarity");
- get(m_pSimilarityBtn, "similaritybtn");
- get(m_pLayoutBtn, "layout");
- get(m_pNotesBtn, "notes");
- get(m_pJapMatchFullHalfWidthCB, "matchcharwidth");
- get(m_pJapOptionsCB, "soundslike");
- get(m_pJapOptionsBtn, "soundslikebtn");
-
- get(m_pAttributeBtn, "attributes");
- get(m_pFormatBtn, "format");
- get(m_pNoFormatBtn, "noformat");
-
- get(m_pCalcGrid, "calcgrid");
- get(m_pCalcSearchInFT, "searchinlabel");
- get(m_pCalcSearchInLB, "calcsearchin");
- get(m_pCalcSearchDirFT, "searchdir");
- get(m_pRowsBtn, "rows");
- get(m_pColumnsBtn, "cols");
- get(m_pAllSheetsCB, "allsheets");
-
- // m_pSimilarityBtn->set_height_request(m_pSimilarityBox->get_preferred_size().Height());
- // m_pJapOptionsBtn->set_height_request(m_pJapOptionsCB->get_preferred_size().Height());
+ m_xSearchTmplLB->make_sorted();
+ m_xSearchAttrText->hide();
+ m_xSearchLabel->show();
+
+ m_xReplaceTmplLB->make_sorted();
+ m_xReplaceAttrText->hide();
+
+ aCalcStr = m_xCalcStrFT->get_label();
+
+ // m_xSimilarityBtn->set_height_request(m_xSimilarityBox->get_preferred_size().Height());
+ // m_xJapOptionsBtn->set_height_request(m_xJapOptionsCB->get_preferred_size().Height());
//tdf#122322
nRememberSize = officecfg::Office::Common::Misc::FindReplaceRememberedSearches::get();
- long nTermWidth = approximate_char_width() * 32;
- m_pSearchLB->set_width_request(nTermWidth);
- m_pSearchTmplLB->set_width_request(nTermWidth);
- m_pReplaceLB->set_width_request(nTermWidth);
- m_pReplaceTmplLB->set_width_request(nTermWidth);
+ auto nTermWidth = m_xSearchLB->get_approximate_digit_width() * 28;
+ m_xSearchLB->set_size_request(nTermWidth, -1);
+ m_xSearchTmplLB->set_size_request(nTermWidth, -1);
+ m_xReplaceLB->set_size_request(nTermWidth, -1);
+ m_xReplaceTmplLB->set_size_request(nTermWidth, -1);
Construct_Impl();
}
-
SvxSearchDialog::~SvxSearchDialog()
{
- disposeOnce();
-}
-
-void SvxSearchDialog::dispose()
-{
- Hide();
-
rBindings.EnterRegistrations();
pSearchController.reset();
pOptionsController.reset();
pFamilyController.reset();
rBindings.LeaveRegistrations();
-
- pSearchItem.reset();
- pImpl.reset();
- pSearchList.reset();
- pReplaceList.reset();
- mpDocWin.clear();
- m_pSearchFrame.clear();
- m_pSearchLB.clear();
- m_pSearchTmplLB.clear();
- m_pSearchAttrText.clear();
- m_pSearchLabel.clear();
- m_pReplaceFrame.clear();
- m_pReplaceLB.clear();
- m_pReplaceTmplLB.clear();
- m_pReplaceAttrText.clear();
- m_pSearchBtn.clear();
- m_pBackSearchBtn.clear();
- m_pSearchAllBtn.clear();
- m_pReplaceBtn.clear();
- m_pReplaceAllBtn.clear();
- m_pComponentFrame.clear();
- m_pSearchComponent1PB.clear();
- m_pSearchComponent2PB.clear();
- m_pMatchCaseCB.clear();
- m_pSearchFormattedCB.clear();
- m_pWordBtn.clear();
- m_pCloseBtn.clear();
- m_pIncludeDiacritics.clear();
- m_pIncludeKashida.clear();
- m_pOtherOptionsExpander.clear();
- m_pSelectionBtn.clear();
- m_pReplaceBackwardsCB.clear();
- m_pRegExpBtn.clear();
- m_pWildcardBtn.clear();
- m_pSimilarityBox.clear();
- m_pSimilarityBtn.clear();
- m_pLayoutBtn.clear();
- m_pNotesBtn.clear();
- m_pJapMatchFullHalfWidthCB.clear();
- m_pJapOptionsCB.clear();
- m_pJapOptionsBtn.clear();
- m_pAttributeBtn.clear();
- m_pFormatBtn.clear();
- m_pNoFormatBtn.clear();
- m_pCalcGrid.clear();
- m_pCalcSearchInFT.clear();
- m_pCalcSearchInLB.clear();
- m_pCalcSearchDirFT.clear();
- m_pRowsBtn.clear();
- m_pColumnsBtn.clear();
- m_pAllSheetsCB.clear();
- SfxModelessDialog::dispose();
}
void SvxSearchDialog::Construct_Impl()
@@ -422,20 +356,20 @@ void SvxSearchDialog::Construct_Impl()
LINK( this, SvxSearchDialog, TimeoutHdl_Impl ) );
EnableControls_Impl( SearchOptionFlags::NONE );
- // Store old Text from m_pWordBtn
+ // Store old Text from m_xWordBtn
aCalcStr += "#";
- aCalcStr += m_pWordBtn->GetText();
+ aCalcStr += m_xWordBtn->get_label();
aLayoutStr = SvxResId( RID_SVXSTR_SEARCH_STYLES );
aLayoutWriterStr = SvxResId( RID_SVXSTR_WRITER_STYLES );
aLayoutCalcStr = SvxResId( RID_SVXSTR_CALC_STYLES );
- aStylesStr = m_pLayoutBtn->GetText();
+ aStylesStr = m_xLayoutBtn->get_label();
// Get stored search-strings from the application
ListToStrArr_Impl(SID_SEARCHDLG_SEARCHSTRINGS,
- aSearchStrings, *m_pSearchLB);
+ aSearchStrings, *m_xSearchLB);
ListToStrArr_Impl(SID_SEARCHDLG_REPLACESTRINGS,
- aReplaceStrings, *m_pReplaceLB);
+ aReplaceStrings, *m_xReplaceLB);
InitControls_Impl();
@@ -467,25 +401,25 @@ void SvxSearchDialog::Construct_Impl()
SvtCJKOptions aCJKOptions;
if(!aCJKOptions.IsJapaneseFindEnabled())
{
- m_pJapOptionsCB->Check( false );
- m_pJapOptionsCB->Hide();
- m_pJapOptionsBtn->Hide();
+ m_xJapOptionsCB->set_active( false );
+ m_xJapOptionsCB->hide();
+ m_xJapOptionsBtn->hide();
}
if(!aCJKOptions.IsCJKFontEnabled())
{
- m_pJapMatchFullHalfWidthCB->Hide();
+ m_xJapMatchFullHalfWidthCB->hide();
}
SvtCTLOptions aCTLOptions;
- // Do not disable and hide the m_pIncludeDiacritics button.
+ // Do not disable and hide the m_xIncludeDiacritics button.
// Include Diacritics == Not Ignore Diacritics => A does not match A-Umlaut (Diaeresis).
// Confusingly these have negated names (following the UI) but the actual
// transliteration is to *ignore* diacritics if "included" (sensitive) is
// _not_ checked.
if(!aCTLOptions.IsCTLFontEnabled())
{
- m_pIncludeDiacritics->Check( true );
- m_pIncludeKashida->Check( true );
- m_pIncludeKashida->Hide();
+ m_xIncludeDiacritics->set_active( true );
+ m_xIncludeKashida->set_active( true );
+ m_xIncludeKashida->hide();
}
//component extension - show component search buttons if the commands
// vnd.sun.star::SearchViaComponent1 and 2 are supported
@@ -524,32 +458,38 @@ void SvxSearchDialog::Construct_Impl()
OUString sTemp;
uno::Any aRet = xDirectAccess->getByName("ComponentSearchGroupLabel");
aRet >>= sTemp;
- m_pComponentFrame->get_label_widget()->SetText(sTemp);
+ m_xComponentFrame->set_label(sTemp);
aRet = xDirectAccess->getByName("ComponentSearchCommandLabel1");
aRet >>= sTemp;
- m_pSearchComponent1PB->SetText( sTemp );
+ m_xSearchComponent1PB->set_label( sTemp );
aRet = xDirectAccess->getByName("ComponentSearchCommandLabel2");
aRet >>= sTemp;
- m_pSearchComponent2PB->SetText( sTemp );
+ m_xSearchComponent2PB->set_label( sTemp );
}
}
catch(uno::Exception&){}
- if(!m_pSearchComponent1PB->GetText().isEmpty() && bSearchComponent1 )
+ if(!m_xSearchComponent1PB->get_label().isEmpty() && bSearchComponent1 )
{
- m_pComponentFrame->Show();
- m_pSearchComponent1PB->Show();
+ m_xComponentFrame->show();
+ m_xSearchComponent1PB->show();
}
- if( !m_pSearchComponent2PB->GetText().isEmpty() )
+ if( !m_xSearchComponent2PB->get_label().isEmpty() )
{
- m_pComponentFrame->Show();
- m_pSearchComponent2PB->Show();
+ m_xComponentFrame->show();
+ m_xSearchComponent2PB->show();
}
}
}
+void SvxSearchDialog::EndDialog()
+{
+ mbClosing = true;
+ SfxModelessDialogController::EndDialog();
+ mbClosing = false;
+}
-bool SvxSearchDialog::Close()
+void SvxSearchDialog::Close()
{
// remember strings
if (!aSearchStrings.empty())
@@ -560,34 +500,38 @@ bool SvxSearchDialog::Close()
// save settings to configuration
SvtSearchOptions aOpt;
- aOpt.SetWholeWordsOnly ( m_pWordBtn->IsChecked() );
- aOpt.SetBackwards ( m_pReplaceBackwardsCB->IsChecked() );
- aOpt.SetUseRegularExpression ( m_pRegExpBtn->IsChecked() );
- aOpt.SetUseWildcard ( m_pWildcardBtn->IsChecked() );
- aOpt.SetSearchForStyles ( m_pLayoutBtn->IsChecked() );
- aOpt.SetSimilaritySearch ( m_pSimilarityBox->IsChecked() );
- aOpt.SetUseAsianOptions ( m_pJapOptionsCB->IsChecked() );
- aOpt.SetNotes ( m_pNotesBtn->IsChecked() );
- aOpt.SetIgnoreDiacritics_CTL ( !m_pIncludeDiacritics->IsChecked() );
- aOpt.SetIgnoreKashida_CTL ( !m_pIncludeKashida->IsChecked() );
- aOpt.SetSearchFormatted ( m_pSearchFormattedCB->IsChecked() );
+ aOpt.SetWholeWordsOnly ( m_xWordBtn->get_active() );
+ aOpt.SetBackwards ( m_xReplaceBackwardsCB->get_active() );
+ aOpt.SetUseRegularExpression ( m_xRegExpBtn->get_active() );
+ aOpt.SetUseWildcard ( m_xWildcardBtn->get_active() );
+ aOpt.SetSearchForStyles ( m_xLayoutBtn->get_active() );
+ aOpt.SetSimilaritySearch ( m_xSimilarityBox->get_active() );
+ aOpt.SetUseAsianOptions ( m_xJapOptionsCB->get_active() );
+ aOpt.SetNotes ( m_xNotesBtn->get_active() );
+ aOpt.SetIgnoreDiacritics_CTL ( !m_xIncludeDiacritics->get_active() );
+ aOpt.SetIgnoreKashida_CTL ( !m_xIncludeKashida->get_active() );
+ aOpt.SetSearchFormatted ( m_xSearchFormattedCB->get_active() );
aOpt.Commit();
+ if (mbClosing)
+ return;
+
const SfxPoolItem* ppArgs[] = { pSearchItem.get(), nullptr };
rBindings.GetDispatcher()->Execute( FID_SEARCH_OFF, SfxCallMode::SLOT, ppArgs );
- rBindings.Execute( SID_SEARCH_DLG );
+ rBindings.Invalidate(SID_SEARCH_DLG);
- return true;
+ SfxViewShell* pViewShell = SfxViewShell::Current();
+ if (pViewShell)
+ pViewShell->GetViewFrame()->ToggleChildWindow(SID_SEARCH_DLG);
}
-
TransliterationFlags SvxSearchDialog::GetTransliterationFlags() const
{
- if (!m_pMatchCaseCB->IsChecked())
+ if (!m_xMatchCaseCB->get_active())
nTransliterationFlags |= TransliterationFlags::IGNORE_CASE;
else
nTransliterationFlags &= ~TransliterationFlags::IGNORE_CASE;
- if ( !m_pJapMatchFullHalfWidthCB->IsChecked())
+ if ( !m_xJapMatchFullHalfWidthCB->get_active())
nTransliterationFlags |= TransliterationFlags::IGNORE_WIDTH;
else
nTransliterationFlags &= ~TransliterationFlags::IGNORE_WIDTH;
@@ -604,97 +548,95 @@ void SvxSearchDialog::ApplyTransliterationFlags_Impl( TransliterationFlags nSett
{
nTransliterationFlags = nSettings;
bool bVal(nSettings & TransliterationFlags::IGNORE_CASE);
- m_pMatchCaseCB->Check( !bVal );
+ m_xMatchCaseCB->set_active( !bVal );
bVal = bool(nSettings & TransliterationFlags::IGNORE_WIDTH);
- m_pJapMatchFullHalfWidthCB->Check( !bVal );
+ m_xJapMatchFullHalfWidthCB->set_active( !bVal );
}
bool SvxSearchDialog::IsOtherOptionsExpanded()
{
- return m_pReplaceBackwardsCB->IsChecked() ||
- m_pSelectionBtn->IsChecked() ||
- m_pRegExpBtn->IsChecked() ||
- m_pLayoutBtn->IsChecked() ||
- m_pSimilarityBox->IsChecked() ||
- m_pJapMatchFullHalfWidthCB->IsChecked() ||
- m_pJapOptionsCB->IsChecked() ||
- m_pWildcardBtn->IsChecked() ||
- m_pNotesBtn->IsChecked() ||
- m_pIncludeKashida->IsChecked() ||
- m_pIncludeDiacritics->IsChecked();
+ return m_xReplaceBackwardsCB->get_active() ||
+ m_xSelectionBtn->get_active() ||
+ m_xRegExpBtn->get_active() ||
+ m_xLayoutBtn->get_active() ||
+ m_xSimilarityBox->get_active() ||
+ m_xJapMatchFullHalfWidthCB->get_active() ||
+ m_xJapOptionsCB->get_active() ||
+ m_xWildcardBtn->get_active() ||
+ m_xNotesBtn->get_active() ||
+ m_xIncludeKashida->get_active() ||
+ m_xIncludeDiacritics->get_active();
}
-
void SvxSearchDialog::Activate()
{
// apply possible transliteration changes of the SvxSearchItem member
DBG_ASSERT( pSearchItem, "SearchItem missing" );
if (pSearchItem)
{
- m_pMatchCaseCB->Check( pSearchItem->GetExact() );
- m_pJapMatchFullHalfWidthCB->Check( !pSearchItem->IsMatchFullHalfWidthForms() );
+ m_xMatchCaseCB->set_active( pSearchItem->GetExact() );
+ m_xJapMatchFullHalfWidthCB->set_active( !pSearchItem->IsMatchFullHalfWidthForms() );
}
- SfxModelessDialog::Activate();
+ SfxModelessDialogController::Activate();
}
-
void SvxSearchDialog::InitControls_Impl()
{
// CaseSensitives AutoComplete
- m_pSearchLB->EnableAutocomplete( true, true );
- m_pSearchLB->Show();
- m_pReplaceLB->EnableAutocomplete( true, true );
- m_pReplaceLB->Show();
+ m_xSearchLB->set_entry_completion( true, true );
+ m_xSearchLB->show();
+ m_xReplaceLB->set_entry_completion( true, true );
+ m_xReplaceLB->show();
- m_pFormatBtn->Disable();
- m_pAttributeBtn->Disable();
+ m_xFormatBtn->set_sensitive(false);
+ m_xAttributeBtn->set_sensitive(false);
- m_pSearchLB->SetModifyHdl( LINK( this, SvxSearchDialog, ModifyHdl_Impl ) );
- m_pReplaceLB->SetModifyHdl( LINK( this, SvxSearchDialog, ModifyHdl_Impl ) );
+ m_xSearchLB->connect_changed( LINK( this, SvxSearchDialog, ModifyHdl_Impl ) );
+ m_xReplaceLB->connect_changed( LINK( this, SvxSearchDialog, ModifyHdl_Impl ) );
- Link<Control&,void> aLink = LINK( this, SvxSearchDialog, FocusHdl_Impl );
- m_pSearchLB->SetGetFocusHdl( aLink );
- m_pReplaceLB->SetGetFocusHdl( aLink );
+ Link<weld::Widget&,void> aLink = LINK( this, SvxSearchDialog, FocusHdl_Impl );
+ m_xSearchLB->connect_focus_in( aLink );
+ m_xReplaceLB->connect_focus_in( aLink );
aLink = LINK( this, SvxSearchDialog, LoseFocusHdl_Impl );
- m_pSearchLB->SetLoseFocusHdl( aLink );
- m_pReplaceLB->SetLoseFocusHdl( aLink );
-
- m_pSearchTmplLB->SetLoseFocusHdl( aLink );
- m_pReplaceTmplLB->SetLoseFocusHdl( aLink );
-
- Link<Button*,void> aLink2 = LINK( this, SvxSearchDialog, CommandHdl_Impl );
- m_pSearchBtn->SetClickHdl( aLink2 );
- m_pBackSearchBtn->SetClickHdl( aLink2 );
- m_pSearchAllBtn->SetClickHdl( aLink2 );
- m_pReplaceBtn->SetClickHdl( aLink2 );
- m_pReplaceAllBtn->SetClickHdl( aLink2 );
- m_pCloseBtn->SetClickHdl( aLink2 );
- m_pSimilarityBtn->SetClickHdl( aLink2 );
- m_pJapOptionsBtn->SetClickHdl( aLink2 );
- m_pSearchComponent1PB->SetClickHdl( aLink2 );
- m_pSearchComponent2PB->SetClickHdl( aLink2 );
+ m_xSearchLB->connect_focus_out( aLink );
+ m_xReplaceLB->connect_focus_out( aLink );
+
+ m_xSearchTmplLB->connect_focus_out( aLink );
+ m_xReplaceTmplLB->connect_focus_out( aLink );
+
+ Link<weld::Button&,void> aLink2 = LINK( this, SvxSearchDialog, CommandHdl_Impl );
+ m_xSearchBtn->connect_clicked( aLink2 );
+ m_xBackSearchBtn->connect_clicked( aLink2 );
+ m_xSearchAllBtn->connect_clicked( aLink2 );
+ m_xReplaceBtn->connect_clicked( aLink2 );
+ m_xReplaceAllBtn->connect_clicked( aLink2 );
+ m_xCloseBtn->connect_clicked( aLink2 );
+ m_xSimilarityBtn->connect_clicked( aLink2 );
+ m_xJapOptionsBtn->connect_clicked( aLink2 );
+ m_xSearchComponent1PB->connect_clicked( aLink2 );
+ m_xSearchComponent2PB->connect_clicked( aLink2 );
aLink2 = LINK( this, SvxSearchDialog, FlagHdl_Impl );
- m_pReplaceBackwardsCB->SetClickHdl( aLink2 );
- m_pWordBtn->SetClickHdl( aLink2 );
- m_pSelectionBtn->SetClickHdl( aLink2 );
- m_pMatchCaseCB->SetClickHdl( aLink2 );
- m_pRegExpBtn->SetClickHdl( aLink2 );
- m_pWildcardBtn->SetClickHdl( aLink2 );
- m_pNotesBtn->SetClickHdl( aLink2 );
- m_pSimilarityBox->SetClickHdl( aLink2 );
- m_pJapOptionsCB->SetClickHdl( aLink2 );
- m_pJapMatchFullHalfWidthCB->SetClickHdl( aLink2 );
- m_pIncludeDiacritics->SetClickHdl( aLink2 );
- m_pIncludeKashida->SetClickHdl( aLink2 );
- m_pLayoutBtn->SetClickHdl( LINK( this, SvxSearchDialog, TemplateHdl_Impl ) );
- m_pFormatBtn->SetClickHdl( LINK( this, SvxSearchDialog, FormatHdl_Impl ) );
- m_pNoFormatBtn->SetClickHdl(
+ m_xReplaceBackwardsCB->connect_clicked( aLink2 );
+ m_xWordBtn->connect_clicked( aLink2 );
+ m_xSelectionBtn->connect_clicked( aLink2 );
+ m_xMatchCaseCB->connect_clicked( aLink2 );
+ m_xRegExpBtn->connect_clicked( aLink2 );
+ m_xWildcardBtn->connect_clicked( aLink2 );
+ m_xNotesBtn->connect_clicked( aLink2 );
+ m_xSimilarityBox->connect_clicked( aLink2 );
+ m_xJapOptionsCB->connect_clicked( aLink2 );
+ m_xJapMatchFullHalfWidthCB->connect_clicked( aLink2 );
+ m_xIncludeDiacritics->connect_clicked( aLink2 );
+ m_xIncludeKashida->connect_clicked( aLink2 );
+ m_xLayoutBtn->connect_clicked( LINK( this, SvxSearchDialog, TemplateHdl_Impl ) );
+ m_xFormatBtn->connect_clicked( LINK( this, SvxSearchDialog, FormatHdl_Impl ) );
+ m_xNoFormatBtn->connect_clicked(
LINK( this, SvxSearchDialog, NoFormatHdl_Impl ) );
- m_pAttributeBtn->SetClickHdl(
+ m_xAttributeBtn->connect_clicked(
LINK( this, SvxSearchDialog, AttributeHdl_Impl ) );
}
@@ -734,36 +676,36 @@ void SvxSearchDialog::ShowOptionalControls_Impl()
eFactory == SvtModuleOptions::EFactory::WRITERGLOBAL;
bool bCalcApp = eFactory == SvtModuleOptions::EFactory::CALC;
- m_pLayoutBtn->Show(!bDrawApp);
- m_pNotesBtn->Show(bWriterApp);
- m_pRegExpBtn->Show(!bDrawApp);
- m_pWildcardBtn->Show(bCalcApp); /* TODO:WILDCARD enable for other apps if hey handle it */
- m_pReplaceBackwardsCB->Show();
- m_pSimilarityBox->Show();
- m_pSimilarityBtn->Show();
- m_pSelectionBtn->Show();
- m_pIncludeDiacritics->Show();
- m_pIncludeKashida->Show(aCTLOptions.IsCTLFontEnabled());
- m_pJapMatchFullHalfWidthCB->Show(aCJKOptions.IsCJKFontEnabled());
- m_pJapOptionsCB->Show(aCJKOptions.IsJapaneseFindEnabled());
- m_pJapOptionsBtn->Show(aCJKOptions.IsJapaneseFindEnabled());
+ m_xLayoutBtn->set_visible(!bDrawApp);
+ m_xNotesBtn->set_visible(bWriterApp);
+ m_xRegExpBtn->set_visible(!bDrawApp);
+ m_xWildcardBtn->set_visible(bCalcApp); /* TODO:WILDCARD enable for other apps if hey handle it */
+ m_xReplaceBackwardsCB->show();
+ m_xSimilarityBox->show();
+ m_xSimilarityBtn->show();
+ m_xSelectionBtn->show();
+ m_xIncludeDiacritics->show();
+ m_xIncludeKashida->set_visible(aCTLOptions.IsCTLFontEnabled());
+ m_xJapMatchFullHalfWidthCB->set_visible(aCJKOptions.IsCJKFontEnabled());
+ m_xJapOptionsCB->set_visible(aCJKOptions.IsJapaneseFindEnabled());
+ m_xJapOptionsBtn->set_visible(aCJKOptions.IsJapaneseFindEnabled());
if (bWriter)
{
- m_pAttributeBtn->Show();
- m_pFormatBtn->Show();
- m_pNoFormatBtn->Show();
+ m_xAttributeBtn->show();
+ m_xFormatBtn->show();
+ m_xNoFormatBtn->show();
}
if (bCalcApp)
{
- m_pCalcSearchInFT->Show();
- m_pCalcSearchInLB->Show();
- m_pCalcSearchDirFT->Show();
- m_pRowsBtn->Show();
- m_pColumnsBtn->Show();
- m_pAllSheetsCB->Show();
- m_pSearchFormattedCB->Show();
+ m_xCalcSearchInFT->show();
+ m_xCalcSearchInLB->show();
+ m_xCalcSearchDirFT->show();
+ m_xRowsBtn->show();
+ m_xColumnsBtn->show();
+ m_xAllSheetsCB->show();
+ m_xSearchFormattedCB->show();
}
}
@@ -802,45 +744,45 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
bWriter = ( pSearchItem->GetAppFlag() == SvxSearchApp::WRITER );
if ( !( nModifyFlag & ModifyFlags::Word ) )
- m_pWordBtn->Check( pSearchItem->GetWordOnly() );
+ m_xWordBtn->set_active( pSearchItem->GetWordOnly() );
if ( !( nModifyFlag & ModifyFlags::Exact ) )
- m_pMatchCaseCB->Check( pSearchItem->GetExact() );
+ m_xMatchCaseCB->set_active( pSearchItem->GetExact() );
if ( !( nModifyFlag & ModifyFlags::Backwards ) )
- m_pReplaceBackwardsCB->Check( bReplaceBackwards ); //adjustment to replace backwards
+ m_xReplaceBackwardsCB->set_active( bReplaceBackwards ); //adjustment to replace backwards
if ( !( nModifyFlag & ModifyFlags::Notes ) )
- m_pNotesBtn->Check( pSearchItem->GetNotes() );
+ m_xNotesBtn->set_active( pSearchItem->GetNotes() );
if ( !( nModifyFlag & ModifyFlags::Selection ) )
- m_pSelectionBtn->Check( pSearchItem->GetSelection() );
+ m_xSelectionBtn->set_active( pSearchItem->GetSelection() );
if ( !( nModifyFlag & ModifyFlags::Regexp ) )
- m_pRegExpBtn->Check( pSearchItem->GetRegExp() );
+ m_xRegExpBtn->set_active( pSearchItem->GetRegExp() );
if ( !( nModifyFlag & ModifyFlags::Wildcard ) )
- m_pWildcardBtn->Check( pSearchItem->GetWildcard() );
+ m_xWildcardBtn->set_active( pSearchItem->GetWildcard() );
if ( !( nModifyFlag & ModifyFlags::Layout ) )
- m_pLayoutBtn->Check( pSearchItem->GetPattern() );
- if (m_pNotesBtn->IsChecked())
- m_pLayoutBtn->Disable();
- m_pSimilarityBox->Check( pSearchItem->IsLevenshtein() );
- if ( m_pJapOptionsCB->IsVisible() )
- m_pJapOptionsCB->Check( pSearchItem->IsUseAsianOptions() );
- m_pIncludeDiacritics->Check( !aOpt.IsIgnoreDiacritics_CTL() );
- if ( m_pIncludeKashida->IsVisible() )
- m_pIncludeKashida->Check( !aOpt.IsIgnoreKashida_CTL() );
+ m_xLayoutBtn->set_active( pSearchItem->GetPattern() );
+ if (m_xNotesBtn->get_active())
+ m_xLayoutBtn->set_sensitive(false);
+ m_xSimilarityBox->set_active( pSearchItem->IsLevenshtein() );
+ if ( m_xJapOptionsCB->get_visible() )
+ m_xJapOptionsCB->set_active( pSearchItem->IsUseAsianOptions() );
+ m_xIncludeDiacritics->set_active( !aOpt.IsIgnoreDiacritics_CTL() );
+ if ( m_xIncludeKashida->get_visible() )
+ m_xIncludeKashida->set_active( !aOpt.IsIgnoreKashida_CTL() );
if ( SvxSearchDialog::IsOtherOptionsExpanded() )
- m_pOtherOptionsExpander->set_expanded( true );
+ m_xOtherOptionsExpander->set_expanded( true );
ApplyTransliterationFlags_Impl( pSearchItem->GetTransliterationFlags() );
ShowOptionalControls_Impl();
if ( pSearchItem->GetAppFlag() == SvxSearchApp::CALC )
{
- m_pCalcGrid->Show();
- m_pSearchFormattedCB->Check( aOpt.IsSearchFormatted() );
- Link<Button*,void> aLink = LINK( this, SvxSearchDialog, FlagHdl_Impl );
- m_pCalcSearchInLB->SetSelectHdl( LINK( this, SvxSearchDialog, LBSelectHdl_Impl ) );
- m_pRowsBtn->SetClickHdl( aLink );
- m_pColumnsBtn->SetClickHdl( aLink );
- m_pAllSheetsCB->SetClickHdl( aLink );
- m_pSearchFormattedCB->SetClickHdl( aLink );
+ m_xCalcGrid->show();
+ m_xSearchFormattedCB->set_active( aOpt.IsSearchFormatted() );
+ Link<weld::Button&,void> aLink = LINK( this, SvxSearchDialog, FlagHdl_Impl );
+ m_xCalcSearchInLB->connect_changed( LINK( this, SvxSearchDialog, LBSelectHdl_Impl ) );
+ m_xRowsBtn->connect_clicked( aLink );
+ m_xColumnsBtn->connect_clicked( aLink );
+ m_xAllSheetsCB->connect_clicked( aLink );
+ m_xSearchFormattedCB->connect_clicked( aLink );
ModifyFlags nModifyFlagCheck;
switch ( pSearchItem->GetCellType() )
@@ -861,46 +803,46 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
std::abort(); // cannot happen
}
if ( !(nModifyFlag & nModifyFlagCheck) )
- m_pCalcSearchInLB->SelectEntryPos( static_cast<sal_Int32>(pSearchItem->GetCellType()) );
+ m_xCalcSearchInLB->set_active( static_cast<sal_Int32>(pSearchItem->GetCellType()) );
- m_pWordBtn->SetText( aCalcStr.getToken( 0, '#' ) );
+ m_xWordBtn->set_label( aCalcStr.getToken( 0, '#' ) );
if ( pSearchItem->GetRowDirection() &&
!( nModifyFlag & ModifyFlags::Rows ) )
- m_pRowsBtn->Check();
+ m_xRowsBtn->set_active(true);
else if ( !pSearchItem->GetRowDirection() &&
!( nModifyFlag & ModifyFlags::Columns ) )
- m_pColumnsBtn->Check();
+ m_xColumnsBtn->set_active(true);
if ( !( nModifyFlag & ModifyFlags::AllTables ) )
- m_pAllSheetsCB->Check( pSearchItem->IsAllTables() );
+ m_xAllSheetsCB->set_active( pSearchItem->IsAllTables() );
// only look for formatting in Writer
- m_pFormatBtn->Hide();
- m_pNoFormatBtn->Hide();
- m_pAttributeBtn->Hide();
+ m_xFormatBtn->hide();
+ m_xNoFormatBtn->hide();
+ m_xAttributeBtn->hide();
}
else
{
- m_pSearchFormattedCB->Hide();
- m_pWordBtn->SetText( aCalcStr.getToken( 1, '#' ) );
+ m_xSearchFormattedCB->hide();
+ m_xWordBtn->set_label( aCalcStr.getToken( 1, '#' ) );
if ( pSearchItem->GetAppFlag() == SvxSearchApp::DRAW )
{
- m_pSearchAllBtn->Hide();
+ m_xSearchAllBtn->hide();
- m_pRegExpBtn->Hide();
- m_pWildcardBtn->Hide();
- m_pLayoutBtn->Hide();
+ m_xRegExpBtn->hide();
+ m_xWildcardBtn->hide();
+ m_xLayoutBtn->hide();
// only look for formatting in Writer
- m_pFormatBtn->Hide();
- m_pNoFormatBtn->Hide();
- m_pAttributeBtn->Hide();
+ m_xFormatBtn->hide();
+ m_xNoFormatBtn->hide();
+ m_xAttributeBtn->hide();
}
else
{
- m_pWildcardBtn->Hide(); /* TODO:WILDCARD do not hide for other apps if they handle it */
+ m_xWildcardBtn->hide(); /* TODO:WILDCARD do not hide for other apps if they handle it */
if ( !pSearchList )
{
@@ -923,11 +865,11 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
// similarity search?
if ( !( nModifyFlag & ModifyFlags::Similarity ) )
- m_pSimilarityBox->Check( pSearchItem->IsLevenshtein() );
+ m_xSimilarityBox->set_active( pSearchItem->IsLevenshtein() );
bSet = true;
- FlagHdl_Impl(m_pSimilarityBox);
- FlagHdl_Impl(m_pJapOptionsCB);
+ FlagHdl_Impl(*m_xSimilarityBox);
+ FlagHdl_Impl(*m_xJapOptionsCB);
bool bDisableSearch = false;
SfxViewShell* pViewShell = SfxViewShell::Current();
@@ -937,11 +879,11 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
bool bText = !bSearchPattern;
if ( pViewShell->HasSelection( bText ) )
- EnableControl_Impl(m_pSelectionBtn);
+ EnableControl_Impl(*m_xSelectionBtn);
else
{
- m_pSelectionBtn->Check( false );
- m_pSelectionBtn->Disable();
+ m_xSelectionBtn->set_active( false );
+ m_xSelectionBtn->set_sensitive(false);
}
}
@@ -953,8 +895,8 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
if ( pShell && pShell->GetStyleSheetPool() )
{
// Templates designed
- m_pSearchTmplLB->Clear();
- m_pReplaceTmplLB->Clear();
+ m_xSearchTmplLB->clear();
+ m_xReplaceTmplLB->clear();
SfxStyleSheetBasePool* pStylePool = pShell->GetStyleSheetPool();
pStylePool->SetSearchMask( pSearchItem->GetFamily() );
SfxStyleSheetBase* pBase = pStylePool->First();
@@ -962,29 +904,29 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
while ( pBase )
{
if ( pBase->IsUsed() )
- m_pSearchTmplLB->InsertEntry( pBase->GetName() );
- m_pReplaceTmplLB->InsertEntry( pBase->GetName() );
+ m_xSearchTmplLB->append_text( pBase->GetName() );
+ m_xReplaceTmplLB->append_text( pBase->GetName() );
pBase = pStylePool->Next();
}
- m_pSearchTmplLB->SelectEntry( pSearchItem->GetSearchString() );
- m_pReplaceTmplLB->SelectEntry( pSearchItem->GetReplaceString() );
+ m_xSearchTmplLB->set_active_text( pSearchItem->GetSearchString() );
+ m_xReplaceTmplLB->set_active_text( pSearchItem->GetReplaceString() );
}
- m_pSearchTmplLB->Show();
+ m_xSearchTmplLB->show();
if ( bConstruct )
// Grab focus only after creating
- m_pSearchTmplLB->GrabFocus();
- m_pReplaceTmplLB->Show();
- m_pSearchLB->Hide();
- m_pReplaceLB->Hide();
+ m_xSearchTmplLB->grab_focus();
+ m_xReplaceTmplLB->show();
+ m_xSearchLB->hide();
+ m_xReplaceLB->hide();
- m_pWordBtn->Disable();
- m_pRegExpBtn->Disable();
- m_pWildcardBtn->Disable();
- m_pMatchCaseCB->Disable();
+ m_xWordBtn->set_sensitive(false);
+ m_xRegExpBtn->set_sensitive(false);
+ m_xWildcardBtn->set_sensitive(false);
+ m_xMatchCaseCB->set_sensitive(false);
- bDisableSearch = !m_pSearchTmplLB->GetEntryCount();
+ bDisableSearch = !m_xSearchTmplLB->get_count();
}
else
{
@@ -992,7 +934,7 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
bool bSetReplace = !( nModifyFlag & ModifyFlags::Replace );
if ( !(pSearchItem->GetSearchString().isEmpty()) && bSetSearch )
- m_pSearchLB->SetText( pSearchItem->GetSearchString() );
+ m_xSearchLB->set_entry_text( pSearchItem->GetSearchString() );
else if (!aSearchStrings.empty())
{
bool bAttributes =
@@ -1000,7 +942,7 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
( pReplaceList && pReplaceList->Count() ) );
if ( bSetSearch && !bAttributes )
- m_pSearchLB->SetText(aSearchStrings[0]);
+ m_xSearchLB->set_entry_text(aSearchStrings[0]);
OUString aReplaceTxt = pSearchItem->GetReplaceString();
@@ -1008,72 +950,72 @@ void SvxSearchDialog::Init_Impl( bool bSearchPattern )
aReplaceTxt = aReplaceStrings[0];
if ( bSetReplace && !bAttributes )
- m_pReplaceLB->SetText( aReplaceTxt );
+ m_xReplaceLB->set_entry_text( aReplaceTxt );
}
- m_pSearchLB->Show();
+ m_xSearchLB->show();
if ( bConstruct )
// Grab focus only after creating
- m_pSearchLB->GrabFocus();
- m_pReplaceLB->Show();
- m_pSearchTmplLB->Hide();
- m_pReplaceTmplLB->Hide();
+ m_xSearchLB->grab_focus();
+ m_xReplaceLB->show();
+ m_xSearchTmplLB->hide();
+ m_xReplaceTmplLB->hide();
- EnableControl_Impl(m_pRegExpBtn);
- EnableControl_Impl(m_pWildcardBtn);
- EnableControl_Impl(m_pMatchCaseCB);
+ EnableControl_Impl(*m_xRegExpBtn);
+ EnableControl_Impl(*m_xWildcardBtn);
+ EnableControl_Impl(*m_xMatchCaseCB);
- if ( m_pRegExpBtn->IsChecked() )
- m_pWordBtn->Disable();
+ if ( m_xRegExpBtn->get_active() )
+ m_xWordBtn->set_sensitive(false);
else
- EnableControl_Impl(m_pWordBtn);
+ EnableControl_Impl(*m_xWordBtn);
- bDisableSearch = m_pSearchLB->GetText().isEmpty() &&
- m_pSearchAttrText->GetText().isEmpty();
+ bDisableSearch = m_xSearchLB->get_active_text().isEmpty() &&
+ m_xSearchAttrText->get_label().isEmpty();
}
- FocusHdl_Impl(*m_pSearchLB);
+ FocusHdl_Impl(*m_xSearchLB);
if ( bDisableSearch )
{
- m_pSearchBtn->Disable();
- m_pBackSearchBtn->Disable();
- m_pSearchAllBtn->Disable();
- m_pReplaceBtn->Disable();
- m_pReplaceAllBtn->Disable();
- m_pComponentFrame->Enable(false);
+ m_xSearchBtn->set_sensitive(false);
+ m_xBackSearchBtn->set_sensitive(false);
+ m_xSearchAllBtn->set_sensitive(false);
+ m_xReplaceBtn->set_sensitive(false);
+ m_xReplaceAllBtn->set_sensitive(false);
+ m_xComponentFrame->set_sensitive(false);
}
else
{
- EnableControl_Impl(m_pSearchBtn);
- EnableControl_Impl(m_pBackSearchBtn);
- EnableControl_Impl(m_pReplaceBtn);
- if (!bWriter || !m_pNotesBtn->IsChecked())
+ EnableControl_Impl(*m_xSearchBtn);
+ EnableControl_Impl(*m_xBackSearchBtn);
+ EnableControl_Impl(*m_xReplaceBtn);
+ if (!bWriter || !m_xNotesBtn->get_active())
{
- EnableControl_Impl(m_pSearchAllBtn);
- EnableControl_Impl(m_pReplaceAllBtn);
+ EnableControl_Impl(*m_xSearchAllBtn);
+ EnableControl_Impl(*m_xReplaceAllBtn);
}
if (bWriter && pSearchItem->GetNotes())
{
- m_pSearchAllBtn->Disable();
- m_pReplaceAllBtn->Disable();
+ m_xSearchAllBtn->set_sensitive(false);
+ m_xReplaceAllBtn->set_sensitive(false);
}
}
- if (!m_pSearchAttrText->GetText().isEmpty())
- EnableControl_Impl(m_pNoFormatBtn);
+ if (!m_xSearchAttrText->get_label().isEmpty())
+ EnableControl_Impl(*m_xNoFormatBtn);
else
- m_pNoFormatBtn->Disable();
+ m_xNoFormatBtn->set_sensitive(false);
if ( !pSearchList )
{
- m_pAttributeBtn->Disable();
- m_pFormatBtn->Disable();
+ m_xAttributeBtn->set_sensitive(false);
+ m_xFormatBtn->set_sensitive(false);
}
- if ( m_pLayoutBtn->IsChecked() )
+ if ( m_xLayoutBtn->get_active() )
{
pImpl->bSaveToModule = false;
- TemplateHdl_Impl(m_pLayoutBtn);
+ TemplateHdl_Impl(*m_xLayoutBtn);
pImpl->bSaveToModule = true;
}
}
@@ -1112,13 +1054,13 @@ void SvxSearchDialog::InitAttrList_Impl( const SfxItemSet* pSSet,
{
pSearchList->Put( *pSSet );
- m_pSearchAttrText->SetText( BuildAttrText_Impl( aDesc, true ) );
+ m_xSearchAttrText->set_label( BuildAttrText_Impl( aDesc, true ) );
if ( !aDesc.isEmpty() )
{
- if (!m_pSearchAttrText->IsVisible())
+ if (!m_xSearchAttrText->get_visible())
{
- m_pSearchAttrText->Show();
+ m_xSearchAttrText->show();
bSetOptimalLayoutSize = true;
}
bFormat |= true;
@@ -1134,13 +1076,13 @@ void SvxSearchDialog::InitAttrList_Impl( const SfxItemSet* pSSet,
{
pReplaceList->Put( *pRSet );
- m_pReplaceAttrText->SetText( BuildAttrText_Impl( aDesc, false ) );
+ m_xReplaceAttrText->set_label( BuildAttrText_Impl( aDesc, false ) );
if ( !aDesc.isEmpty() )
{
- if (!m_pReplaceAttrText->IsVisible())
+ if (!m_xReplaceAttrText->get_visible())
{
- m_pReplaceAttrText->Show();
+ m_xReplaceAttrText->show();
bSetOptimalLayoutSize = true;
}
bFormat |= true;
@@ -1149,244 +1091,242 @@ void SvxSearchDialog::InitAttrList_Impl( const SfxItemSet* pSSet,
}
if (bSetOptimalLayoutSize)
- setOptimalLayoutSize();
+ m_xDialog->resize_to_request();
}
-
-IMPL_LINK( SvxSearchDialog, LBSelectHdl_Impl, ListBox&, rCtrl, void )
+IMPL_LINK( SvxSearchDialog, LBSelectHdl_Impl, weld::ComboBox&, rCtrl, void )
{
ClickHdl_Impl(&rCtrl);
}
-IMPL_LINK( SvxSearchDialog, FlagHdl_Impl, Button *, pCtrl, void )
+IMPL_LINK( SvxSearchDialog, FlagHdl_Impl, weld::Button&, rCtrl, void )
{
- ClickHdl_Impl(pCtrl);
+ ClickHdl_Impl(&rCtrl);
}
-void SvxSearchDialog::ClickHdl_Impl(void const * pCtrl)
+void SvxSearchDialog::ClickHdl_Impl(const weld::Widget* pCtrl)
{
if ( pCtrl && !bSet )
- SetModifyFlag_Impl( static_cast<Control const *>(pCtrl) );
+ SetModifyFlag_Impl(pCtrl);
else
bSet = false;
- if (pCtrl == m_pSimilarityBox)
+ if (pCtrl == m_xSimilarityBox.get())
{
- bool bIsChecked = m_pSimilarityBox->IsChecked();
+ bool bIsChecked = m_xSimilarityBox->get_active();
if ( bIsChecked )
{
- m_pSimilarityBtn->Enable();
- m_pRegExpBtn->Check( false );
- m_pRegExpBtn->Disable();
- m_pWildcardBtn->Check( false );
- m_pWildcardBtn->Disable();
- EnableControl_Impl(m_pWordBtn);
-
- if ( m_pLayoutBtn->IsChecked() )
+ m_xSimilarityBtn->set_sensitive(true);
+ m_xRegExpBtn->set_active( false );
+ m_xRegExpBtn->set_sensitive(false);
+ m_xWildcardBtn->set_active( false );
+ m_xWildcardBtn->set_sensitive(false);
+ EnableControl_Impl(*m_xWordBtn);
+
+ if ( m_xLayoutBtn->get_active() )
{
- EnableControl_Impl(m_pMatchCaseCB);
- m_pLayoutBtn->Check( false );
+ EnableControl_Impl(*m_xMatchCaseCB);
+ m_xLayoutBtn->set_active( false );
}
- m_pRegExpBtn->Disable();
- m_pWildcardBtn->Disable();
- m_pLayoutBtn->Disable();
- m_pFormatBtn->Disable();
- m_pNoFormatBtn->Disable();
- m_pAttributeBtn->Disable();
+ m_xRegExpBtn->set_sensitive(false);
+ m_xWildcardBtn->set_sensitive(false);
+ m_xLayoutBtn->set_sensitive(false);
+ m_xFormatBtn->set_sensitive(false);
+ m_xNoFormatBtn->set_sensitive(false);
+ m_xAttributeBtn->set_sensitive(false);
}
else
{
- EnableControl_Impl(m_pRegExpBtn);
- EnableControl_Impl(m_pWildcardBtn);
- if (!m_pNotesBtn->IsChecked())
- EnableControl_Impl(m_pLayoutBtn);
- EnableControl_Impl(m_pFormatBtn);
- EnableControl_Impl(m_pAttributeBtn);
- m_pSimilarityBtn->Disable();
+ EnableControl_Impl(*m_xRegExpBtn);
+ EnableControl_Impl(*m_xWildcardBtn);
+ if (!m_xNotesBtn->get_active())
+ EnableControl_Impl(*m_xLayoutBtn);
+ EnableControl_Impl(*m_xFormatBtn);
+ EnableControl_Impl(*m_xAttributeBtn);
+ m_xSimilarityBtn->set_sensitive(false);
}
pSearchItem->SetLevenshtein( bIsChecked );
}
- else if (pCtrl == m_pNotesBtn)
+ else if (pCtrl == m_xNotesBtn.get())
{
- if (m_pNotesBtn->IsChecked())
+ if (m_xNotesBtn->get_active())
{
- m_pLayoutBtn->Disable();
- m_pSearchAllBtn->Disable();
- m_pReplaceAllBtn->Disable();
+ m_xLayoutBtn->set_sensitive(false);
+ m_xSearchAllBtn->set_sensitive(false);
+ m_xReplaceAllBtn->set_sensitive(false);
}
else
{
- EnableControl_Impl(m_pLayoutBtn);
- ModifyHdl_Impl(*m_pSearchLB);
+ EnableControl_Impl(*m_xLayoutBtn);
+ ModifyHdl_Impl(*m_xSearchLB);
}
}
else
{
- if ( m_pLayoutBtn->IsChecked() && !bFormat )
+ if ( m_xLayoutBtn->get_active() && !bFormat )
{
- m_pWordBtn->Check( false );
- m_pWordBtn->Disable();
- m_pRegExpBtn->Check( false );
- m_pRegExpBtn->Disable();
- m_pWildcardBtn->Check( false );
- m_pWildcardBtn->Disable();
- m_pMatchCaseCB->Check( false );
- m_pMatchCaseCB->Disable();
- m_pNotesBtn->Disable();
-
- if ( m_pSearchTmplLB->GetEntryCount() )
+ m_xWordBtn->set_active( false );
+ m_xWordBtn->set_sensitive(false);
+ m_xRegExpBtn->set_active( false );
+ m_xRegExpBtn->set_sensitive(false);
+ m_xWildcardBtn->set_active( false );
+ m_xWildcardBtn->set_sensitive(false);
+ m_xMatchCaseCB->set_active( false );
+ m_xMatchCaseCB->set_sensitive(false);
+ m_xNotesBtn->set_sensitive(false);
+
+ if ( m_xSearchTmplLB->get_count() )
{
- EnableControl_Impl(m_pSearchBtn);
- EnableControl_Impl(m_pBackSearchBtn);
- EnableControl_Impl(m_pSearchAllBtn);
- EnableControl_Impl(m_pReplaceBtn);
- EnableControl_Impl(m_pReplaceAllBtn);
+ EnableControl_Impl(*m_xSearchBtn);
+ EnableControl_Impl(*m_xBackSearchBtn);
+ EnableControl_Impl(*m_xSearchAllBtn);
+ EnableControl_Impl(*m_xReplaceBtn);
+ EnableControl_Impl(*m_xReplaceAllBtn);
}
}
else
{
- EnableControl_Impl(m_pRegExpBtn);
- EnableControl_Impl(m_pWildcardBtn);
- EnableControl_Impl(m_pMatchCaseCB);
- EnableControl_Impl(m_pNotesBtn);
+ EnableControl_Impl(*m_xRegExpBtn);
+ EnableControl_Impl(*m_xWildcardBtn);
+ EnableControl_Impl(*m_xMatchCaseCB);
+ EnableControl_Impl(*m_xNotesBtn);
- if ( m_pRegExpBtn->IsChecked() )
+ if ( m_xRegExpBtn->get_active() )
{
- m_pWordBtn->Check( false );
- m_pWordBtn->Disable();
- m_pWildcardBtn->Check( false );
- m_pWildcardBtn->Disable();
- m_pSimilarityBox->Check( false );
- m_pSimilarityBox->Disable();
- m_pSimilarityBtn->Disable();
+ m_xWordBtn->set_active( false );
+ m_xWordBtn->set_sensitive(false);
+ m_xWildcardBtn->set_active( false );
+ m_xWildcardBtn->set_sensitive(false);
+ m_xSimilarityBox->set_active( false );
+ m_xSimilarityBox->set_sensitive(false);
+ m_xSimilarityBtn->set_sensitive(false);
}
- else if ( m_pWildcardBtn->IsChecked() )
+ else if ( m_xWildcardBtn->get_active() )
{
- m_pRegExpBtn->Check( false );
- m_pRegExpBtn->Disable();
- m_pSimilarityBox->Check( false );
- m_pSimilarityBox->Disable();
- m_pSimilarityBtn->Disable();
+ m_xRegExpBtn->set_active( false );
+ m_xRegExpBtn->set_sensitive(false);
+ m_xSimilarityBox->set_active( false );
+ m_xSimilarityBox->set_sensitive(false);
+ m_xSimilarityBtn->set_sensitive(false);
}
else
{
- EnableControl_Impl(m_pWordBtn);
- EnableControl_Impl(m_pSimilarityBox);
+ EnableControl_Impl(*m_xWordBtn);
+ EnableControl_Impl(*m_xSimilarityBox);
}
// Search-string in place? then enable Buttons
bSet = true;
- ModifyHdl_Impl(*m_pSearchLB);
+ ModifyHdl_Impl(*m_xSearchLB);
}
}
- if (pCtrl == m_pAllSheetsCB)
+ if (pCtrl == m_xAllSheetsCB.get())
{
bSet = true;
- ModifyHdl_Impl(*m_pSearchLB);
+ ModifyHdl_Impl(*m_xSearchLB);
}
- if (pCtrl == m_pJapOptionsCB)
+ if (pCtrl == m_xJapOptionsCB.get())
{
- bool bEnableJapOpt = m_pJapOptionsCB->IsChecked();
- m_pMatchCaseCB->Enable(!bEnableJapOpt );
- m_pJapMatchFullHalfWidthCB->Enable(!bEnableJapOpt );
- m_pJapOptionsBtn->Enable( bEnableJapOpt );
+ bool bEnableJapOpt = m_xJapOptionsCB->get_active();
+ m_xMatchCaseCB->set_sensitive(!bEnableJapOpt );
+ m_xJapMatchFullHalfWidthCB->set_sensitive(!bEnableJapOpt );
+ m_xJapOptionsBtn->set_sensitive( bEnableJapOpt );
}
if ( pImpl->bSaveToModule )
SaveToModule_Impl();
}
-
-IMPL_LINK( SvxSearchDialog, CommandHdl_Impl, Button *, pBtn, void )
+IMPL_LINK(SvxSearchDialog, CommandHdl_Impl, weld::Button&, rBtn, void)
{
- bool bInclusive = ( m_pLayoutBtn->GetText() == aLayoutStr );
+ bool bInclusive = ( m_xLayoutBtn->get_label() == aLayoutStr );
- if ( ( pBtn == m_pSearchBtn ) ||
- (pBtn == m_pBackSearchBtn) ||
- ( pBtn == m_pSearchAllBtn )||
- ( pBtn == m_pReplaceBtn ) ||
- ( pBtn == m_pReplaceAllBtn ) )
+ if ( ( &rBtn == m_xSearchBtn.get() ) ||
+ (&rBtn == m_xBackSearchBtn.get()) ||
+ ( &rBtn == m_xSearchAllBtn.get() )||
+ ( &rBtn == m_xReplaceBtn.get() ) ||
+ ( &rBtn == m_xReplaceAllBtn.get() ) )
{
- if ( m_pLayoutBtn->IsChecked() && !bInclusive )
+ if ( m_xLayoutBtn->get_active() && !bInclusive )
{
- pSearchItem->SetSearchString ( m_pSearchTmplLB->GetSelectedEntry() );
- pSearchItem->SetReplaceString( m_pReplaceTmplLB->GetSelectedEntry() );
+ pSearchItem->SetSearchString ( m_xSearchTmplLB->get_active_text() );
+ pSearchItem->SetReplaceString( m_xReplaceTmplLB->get_active_text() );
}
else
{
- pSearchItem->SetSearchString ( m_pSearchLB->GetText() );
- pSearchItem->SetReplaceString( m_pReplaceLB->GetText() );
+ pSearchItem->SetSearchString ( m_xSearchLB->get_active_text() );
+ pSearchItem->SetReplaceString( m_xReplaceLB->get_active_text() );
- if ( pBtn == m_pReplaceBtn )
- Remember_Impl( m_pReplaceLB->GetText(), false );
+ if ( &rBtn == m_xReplaceBtn.get() )
+ Remember_Impl( m_xReplaceLB->get_active_text(), false );
else
{
- Remember_Impl( m_pSearchLB->GetText(), true );
+ Remember_Impl( m_xSearchLB->get_active_text(), true );
- if ( pBtn == m_pReplaceAllBtn )
- Remember_Impl( m_pReplaceLB->GetText(), false );
+ if ( &rBtn == m_xReplaceAllBtn.get() )
+ Remember_Impl( m_xReplaceLB->get_active_text(), false );
}
}
pSearchItem->SetRegExp( false );
pSearchItem->SetWildcard( false );
pSearchItem->SetLevenshtein( false );
- if (GetCheckBoxValue(m_pRegExpBtn))
+ if (GetCheckBoxValue(*m_xRegExpBtn))
pSearchItem->SetRegExp( true );
- else if (GetCheckBoxValue(m_pWildcardBtn))
+ else if (GetCheckBoxValue(*m_xWildcardBtn))
pSearchItem->SetWildcard( true );
- else if (GetCheckBoxValue(m_pSimilarityBox))
+ else if (GetCheckBoxValue(*m_xSimilarityBox))
pSearchItem->SetLevenshtein( true );
- pSearchItem->SetWordOnly(GetCheckBoxValue(m_pWordBtn));
+ pSearchItem->SetWordOnly(GetCheckBoxValue(*m_xWordBtn));
bool bSetBackwards = false;
- if( pBtn == m_pBackSearchBtn)
+ if( &rBtn == m_xBackSearchBtn.get())
{
bSetBackwards = true;
}
- else if( pBtn == m_pReplaceBtn)
+ else if( &rBtn == m_xReplaceBtn.get())
{
- bSetBackwards = GetCheckBoxValue(m_pReplaceBackwardsCB);
- bReplaceBackwards = GetCheckBoxValue(m_pReplaceBackwardsCB);
+ bSetBackwards = GetCheckBoxValue(*m_xReplaceBackwardsCB);
+ bReplaceBackwards = GetCheckBoxValue(*m_xReplaceBackwardsCB);
}
pSearchItem->SetBackward(bSetBackwards);
- pSearchItem->SetNotes(GetCheckBoxValue(m_pNotesBtn));
- pSearchItem->SetPattern(GetCheckBoxValue(m_pLayoutBtn));
- pSearchItem->SetSelection(GetCheckBoxValue(m_pSelectionBtn));
- pSearchItem->SetUseAsianOptions(GetCheckBoxValue(m_pJapOptionsCB));
+ pSearchItem->SetNotes(GetCheckBoxValue(*m_xNotesBtn));
+ pSearchItem->SetPattern(GetCheckBoxValue(*m_xLayoutBtn));
+ pSearchItem->SetSelection(GetCheckBoxValue(*m_xSelectionBtn));
+ pSearchItem->SetUseAsianOptions(GetCheckBoxValue(*m_xJapOptionsCB));
TransliterationFlags nFlags = GetTransliterationFlags();
if( !pSearchItem->IsUseAsianOptions())
nFlags &= TransliterationFlags::IGNORE_CASE |
TransliterationFlags::IGNORE_WIDTH;
- if (GetNegatedCheckBoxValue(m_pIncludeDiacritics))
+ if (GetNegatedCheckBoxValue(*m_xIncludeDiacritics))
nFlags |= TransliterationFlags::IGNORE_DIACRITICS_CTL;
- if (GetNegatedCheckBoxValue(m_pIncludeKashida))
+ if (GetNegatedCheckBoxValue(*m_xIncludeKashida))
nFlags |= TransliterationFlags::IGNORE_KASHIDA_CTL;
pSearchItem->SetTransliterationFlags( nFlags );
if ( !bWriter )
{
- if ( m_pCalcSearchInLB->GetSelectedEntryPos() != LISTBOX_ENTRY_NOTFOUND )
- pSearchItem->SetCellType( static_cast<SvxSearchCellType>(m_pCalcSearchInLB->GetSelectedEntryPos()) );
+ if ( m_xCalcSearchInLB->get_active() != -1)
+ pSearchItem->SetCellType( static_cast<SvxSearchCellType>(m_xCalcSearchInLB->get_active()) );
- pSearchItem->SetRowDirection( m_pRowsBtn->IsChecked() );
- pSearchItem->SetAllTables( m_pAllSheetsCB->IsChecked() );
- pSearchItem->SetSearchFormatted( m_pSearchFormattedCB->IsChecked() );
+ pSearchItem->SetRowDirection( m_xRowsBtn->get_active() );
+ pSearchItem->SetAllTables( m_xAllSheetsCB->get_active() );
+ pSearchItem->SetSearchFormatted( m_xSearchFormattedCB->get_active() );
}
- if ((pBtn == m_pSearchBtn) || (pBtn == m_pBackSearchBtn))
+ if ((&rBtn == m_xSearchBtn.get()) || (&rBtn == m_xBackSearchBtn.get()))
pSearchItem->SetCommand( SvxSearchCmd::FIND );
- else if ( pBtn == m_pSearchAllBtn )
+ else if ( &rBtn == m_xSearchAllBtn.get() )
pSearchItem->SetCommand( SvxSearchCmd::FIND_ALL );
- else if ( pBtn == m_pReplaceBtn )
+ else if ( &rBtn == m_xReplaceBtn.get() )
pSearchItem->SetCommand( SvxSearchCmd::REPLACE );
- else if ( pBtn == m_pReplaceAllBtn )
+ else if ( &rBtn == m_xReplaceAllBtn.get() )
pSearchItem->SetCommand( SvxSearchCmd::REPLACE_ALL );
// when looking for templates, delete format lists
@@ -1402,15 +1342,15 @@ IMPL_LINK( SvxSearchDialog, CommandHdl_Impl, Button *, pBtn, void )
const SfxPoolItem* ppArgs[] = { pSearchItem.get(), nullptr };
rBindings.ExecuteSynchron( FID_SEARCH_NOW, ppArgs );
}
- else if ( pBtn == m_pCloseBtn )
+ else if ( &rBtn == m_xCloseBtn.get() )
{
- if ( !m_pLayoutBtn->IsChecked() || bInclusive )
+ if ( !m_xLayoutBtn->get_active() || bInclusive )
{
- OUString aStr( m_pSearchLB->GetText() );
+ OUString aStr( m_xSearchLB->get_active_text() );
if ( !aStr.isEmpty() )
Remember_Impl( aStr, true );
- aStr = m_pReplaceLB->GetText();
+ aStr = m_xReplaceLB->get_active_text();
if ( !aStr.isEmpty() )
Remember_Impl( aStr, false );
@@ -1418,10 +1358,10 @@ IMPL_LINK( SvxSearchDialog, CommandHdl_Impl, Button *, pBtn, void )
SaveToModule_Impl();
Close();
}
- else if (pBtn == m_pSimilarityBtn)
+ else if (&rBtn == m_xSimilarityBtn.get())
{
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
- ScopedVclPtr<AbstractSvxSearchSimilarityDialog> pDlg(pFact->CreateSvxSearchSimilarityDialog(GetFrameWeld(),
+ ScopedVclPtr<AbstractSvxSearchSimilarityDialog> pDlg(pFact->CreateSvxSearchSimilarityDialog(m_xDialog.get(),
pSearchItem->IsLEVRelaxed(),
pSearchItem->GetLEVOther(),
pSearchItem->GetLEVShorter(),
@@ -1435,12 +1375,12 @@ IMPL_LINK( SvxSearchDialog, CommandHdl_Impl, Button *, pBtn, void )
SaveToModule_Impl();
}
}
- else if (pBtn == m_pJapOptionsBtn)
+ else if (&rBtn == m_xJapOptionsBtn.get())
{
SfxItemSet aSet( SfxGetpApp()->GetPool() );
pSearchItem->SetTransliterationFlags( GetTransliterationFlags() );
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
- ScopedVclPtr<AbstractSvxJSearchOptionsDialog> aDlg(pFact->CreateSvxJSearchOptionsDialog(GetFrameWeld(), aSet,
+ ScopedVclPtr<AbstractSvxJSearchOptionsDialog> aDlg(pFact->CreateSvxJSearchOptionsDialog(m_xDialog.get(), aSet,
pSearchItem->GetTransliterationFlags() ));
int nRet = executeSubDialog(aDlg.get());
if (RET_OK == nRet) //! true only if FillItemSet of SvxJSearchOptionsPage returns true
@@ -1450,15 +1390,15 @@ IMPL_LINK( SvxSearchDialog, CommandHdl_Impl, Button *, pBtn, void )
ApplyTransliterationFlags_Impl( nFlags );
}
}
- else if (pBtn == m_pSearchComponent1PB || pBtn == m_pSearchComponent2PB)
+ else if (&rBtn == m_xSearchComponent1PB.get() || &rBtn == m_xSearchComponent2PB.get())
{
uno::Sequence < beans::PropertyValue > aArgs(2);
beans::PropertyValue* pArgs = aArgs.getArray();
pArgs[0].Name = "SearchString";
- pArgs[0].Value <<= m_pSearchLB->GetText();
+ pArgs[0].Value <<= m_xSearchLB->get_active_text();
pArgs[1].Name = "ParentWindow";
- pArgs[1].Value <<= VCLUnoHelper::GetInterface( this );
- if(pBtn == m_pSearchComponent1PB)
+ pArgs[1].Value <<= m_xDialog->GetXWindow();
+ if (&rBtn == m_xSearchComponent1PB.get())
{
if ( pImpl->xCommand1Dispatch.is() )
pImpl->xCommand1Dispatch->dispatch(pImpl->aCommand1URL, aArgs);
@@ -1472,7 +1412,7 @@ IMPL_LINK( SvxSearchDialog, CommandHdl_Impl, Button *, pBtn, void )
}
-IMPL_LINK( SvxSearchDialog, ModifyHdl_Impl, Edit&, rEd, void )
+IMPL_LINK( SvxSearchDialog, ModifyHdl_Impl, weld::ComboBox&, rEd, void )
{
if ( !bSet )
SetModifyFlag_Impl( &rEd );
@@ -1482,39 +1422,38 @@ IMPL_LINK( SvxSearchDialog, ModifyHdl_Impl, Edit&, rEd, void )
// Calc allows searching for empty cells.
bool bAllowEmptySearch = (pSearchItem->GetAppFlag() == SvxSearchApp::CALC);
- if ( &rEd == m_pSearchLB || &rEd == m_pReplaceLB )
+ if (&rEd == m_xSearchLB.get() || &rEd == m_xReplaceLB.get())
{
- sal_Int32 nSrchTxtLen = m_pSearchLB->GetText().getLength();
+ sal_Int32 nSrchTxtLen = m_xSearchLB->get_active_text().getLength();
sal_Int32 nReplTxtLen = 0;
if (bAllowEmptySearch)
- nReplTxtLen = m_pReplaceLB->GetText().getLength();
- sal_Int32 nAttrTxtLen = m_pSearchAttrText->GetText().getLength();
+ nReplTxtLen = m_xReplaceLB->get_active_text().getLength();
+ sal_Int32 nAttrTxtLen = m_xSearchAttrText->get_label().getLength();
if (nSrchTxtLen || nReplTxtLen || nAttrTxtLen)
{
- EnableControl_Impl(m_pSearchBtn);
- EnableControl_Impl(m_pBackSearchBtn);
- EnableControl_Impl(m_pReplaceBtn);
- if (!bWriter || !m_pNotesBtn->IsChecked())
+ EnableControl_Impl(*m_xSearchBtn);
+ EnableControl_Impl(*m_xBackSearchBtn);
+ EnableControl_Impl(*m_xReplaceBtn);
+ if (!bWriter || !m_xNotesBtn->get_active())
{
- EnableControl_Impl(m_pSearchAllBtn);
- EnableControl_Impl(m_pReplaceAllBtn);
+ EnableControl_Impl(*m_xSearchAllBtn);
+ EnableControl_Impl(*m_xReplaceAllBtn);
}
}
else
{
- m_pComponentFrame->Enable(false);
- m_pSearchBtn->Disable();
- m_pBackSearchBtn->Disable();
- m_pSearchAllBtn->Disable();
- m_pReplaceBtn->Disable();
- m_pReplaceAllBtn->Disable();
+ m_xComponentFrame->set_sensitive(false);
+ m_xSearchBtn->set_sensitive(false);
+ m_xBackSearchBtn->set_sensitive(false);
+ m_xSearchAllBtn->set_sensitive(false);
+ m_xReplaceBtn->set_sensitive(false);
+ m_xReplaceAllBtn->set_sensitive(false);
}
}
}
-
-IMPL_LINK_NOARG(SvxSearchDialog, TemplateHdl_Impl, Button*, void)
+IMPL_LINK_NOARG(SvxSearchDialog, TemplateHdl_Impl, weld::Button&, void)
{
if ( pImpl->bSaveToModule )
SaveToModule_Impl();
@@ -1523,7 +1462,7 @@ IMPL_LINK_NOARG(SvxSearchDialog, TemplateHdl_Impl, Button*, void)
return;
OUString sDesc;
- if ( m_pLayoutBtn->IsChecked() )
+ if ( m_xLayoutBtn->get_active() )
{
if ( !pFamilyController )
{
@@ -1555,32 +1494,32 @@ IMPL_LINK_NOARG(SvxSearchDialog, TemplateHdl_Impl, Button*, void)
pFamilyController.reset(
new SvxSearchController( nId, rBindings, *this ) );
rBindings.LeaveRegistrations();
- m_pSearchTmplLB->Clear();
- m_pReplaceTmplLB->Clear();
+ m_xSearchTmplLB->clear();
+ m_xReplaceTmplLB->clear();
- m_pSearchTmplLB->Show();
- m_pReplaceTmplLB->Show();
- m_pSearchLB->Hide();
- m_pReplaceLB->Hide();
+ m_xSearchTmplLB->show();
+ m_xReplaceTmplLB->show();
+ m_xSearchLB->hide();
+ m_xReplaceLB->hide();
- m_pSearchAttrText->SetText( sDesc );
- m_pReplaceAttrText->SetText( sDesc );
+ m_xSearchAttrText->set_label( sDesc );
+ m_xReplaceAttrText->set_label( sDesc );
if(!sDesc.isEmpty())
{
- if (!m_pReplaceAttrText->IsVisible() || !m_pReplaceAttrText->IsVisible())
+ if (!m_xReplaceAttrText->get_visible() || !m_xReplaceAttrText->get_visible())
{
- m_pSearchAttrText->Show();
- m_pReplaceAttrText->Show();
- setOptimalLayoutSize();
+ m_xSearchAttrText->show();
+ m_xReplaceAttrText->show();
+ m_xDialog->resize_to_request();
}
}
}
- m_pFormatBtn->Disable();
- m_pNoFormatBtn->Disable();
- m_pAttributeBtn->Disable();
- m_pSimilarityBox->Disable();
- m_pSimilarityBtn->Disable();
+ m_xFormatBtn->set_sensitive(false);
+ m_xNoFormatBtn->set_sensitive(false);
+ m_xAttributeBtn->set_sensitive(false);
+ m_xSimilarityBox->set_sensitive(false);
+ m_xSimilarityBtn->set_sensitive(false);
}
else
{
@@ -1589,44 +1528,43 @@ IMPL_LINK_NOARG(SvxSearchDialog, TemplateHdl_Impl, Button*, void)
pFamilyController.reset();
rBindings.LeaveRegistrations();
- m_pSearchLB->Show();
- m_pReplaceLB->Show();
- m_pSearchTmplLB->Hide();
- m_pReplaceTmplLB->Hide();
+ m_xSearchLB->show();
+ m_xReplaceLB->show();
+ m_xSearchTmplLB->hide();
+ m_xReplaceTmplLB->hide();
- m_pSearchAttrText->SetText( BuildAttrText_Impl( sDesc, true ) );
- m_pReplaceAttrText->SetText( BuildAttrText_Impl( sDesc, false ) );
+ m_xSearchAttrText->set_label( BuildAttrText_Impl( sDesc, true ) );
+ m_xReplaceAttrText->set_label( BuildAttrText_Impl( sDesc, false ) );
if(!sDesc.isEmpty())
{
- if (!m_pReplaceAttrText->IsVisible() || !m_pReplaceAttrText->IsVisible())
+ if (!m_xReplaceAttrText->get_visible() || !m_xReplaceAttrText->get_visible())
{
- m_pSearchAttrText->Show();
- m_pReplaceAttrText->Show();
- setOptimalLayoutSize();
+ m_xSearchAttrText->show();
+ m_xReplaceAttrText->show();
+ m_xDialog->resize_to_request();
}
}
- EnableControl_Impl(m_pFormatBtn);
- EnableControl_Impl(m_pAttributeBtn);
- EnableControl_Impl(m_pSimilarityBox);
+ EnableControl_Impl(*m_xFormatBtn);
+ EnableControl_Impl(*m_xAttributeBtn);
+ EnableControl_Impl(*m_xSimilarityBox);
- FocusHdl_Impl( bSearch ? *m_pSearchLB : *m_pReplaceLB );
+ FocusHdl_Impl( bSearch ? *m_xSearchLB : *m_xReplaceLB );
}
bSet = true;
pImpl->bSaveToModule = false;
- FlagHdl_Impl(m_pLayoutBtn);
+ FlagHdl_Impl(*m_xLayoutBtn);
pImpl->bSaveToModule = true;
}
-
void SvxSearchDialog::Remember_Impl( const OUString &rStr, bool _bSearch )
{
if ( rStr.isEmpty() )
return;
std::vector<OUString>* pArr = _bSearch ? &aSearchStrings : &aReplaceStrings;
- ComboBox* pListBox = _bSearch ? m_pSearchLB.get() : m_pReplaceLB.get();
+ weld::ComboBox* pListBox = _bSearch ? m_xSearchLB.get() : m_xReplaceLB.get();
// ignore identical strings
if (std::find(pArr->begin(), pArr->end(), rStr) != pArr->end())
@@ -1635,52 +1573,51 @@ void SvxSearchDialog::Remember_Impl( const OUString &rStr, bool _bSearch )
// delete oldest entry at maximum occupancy (ListBox and Array)
if(nRememberSize < pArr->size())
{
- pListBox->RemoveEntryAt(static_cast<sal_uInt16>(nRememberSize - 1));
+ pListBox->remove(static_cast<sal_uInt16>(nRememberSize - 1));
(*pArr)[nRememberSize - 1] = rStr;
pArr->erase(pArr->begin() + nRememberSize - 1);
}
pArr->insert(pArr->begin(), rStr);
- pListBox->InsertEntry(rStr, 0);
+ pListBox->insert_text(0, rStr);
}
-
void SvxSearchDialog::TemplatesChanged_Impl( SfxStyleSheetBasePool& rPool )
{
- OUString aOldSrch( m_pSearchTmplLB->GetSelectedEntry() );
- OUString aOldRepl( m_pReplaceTmplLB->GetSelectedEntry() );
- m_pSearchTmplLB->Clear();
- m_pReplaceTmplLB->Clear();
+ OUString aOldSrch( m_xSearchTmplLB->get_active_text() );
+ OUString aOldRepl( m_xReplaceTmplLB->get_active_text() );
+ m_xSearchTmplLB->clear();
+ m_xReplaceTmplLB->clear();
rPool.SetSearchMask( pSearchItem->GetFamily() );
- m_pSearchTmplLB->SetUpdateMode( false );
- m_pReplaceTmplLB->SetUpdateMode( false );
+ m_xSearchTmplLB->freeze();
+ m_xReplaceTmplLB->freeze();
SfxStyleSheetBase* pBase = rPool.First();
while ( pBase )
{
if ( pBase->IsUsed() )
- m_pSearchTmplLB->InsertEntry( pBase->GetName() );
- m_pReplaceTmplLB->InsertEntry( pBase->GetName() );
+ m_xSearchTmplLB->append_text( pBase->GetName() );
+ m_xReplaceTmplLB->append_text( pBase->GetName() );
pBase = rPool.Next();
}
- m_pSearchTmplLB->SetUpdateMode( true );
- m_pReplaceTmplLB->SetUpdateMode( true );
- m_pSearchTmplLB->SelectEntryPos(0);
+ m_xSearchTmplLB->thaw();
+ m_xReplaceTmplLB->thaw();
+ m_xSearchTmplLB->set_active(0);
if ( !aOldSrch.isEmpty() )
- m_pSearchTmplLB->SelectEntry( aOldSrch );
- m_pReplaceTmplLB->SelectEntryPos(0);
+ m_xSearchTmplLB->set_active_text( aOldSrch );
+ m_xReplaceTmplLB->set_active(0);
if ( !aOldRepl.isEmpty() )
- m_pReplaceTmplLB->SelectEntry( aOldRepl );
+ m_xReplaceTmplLB->set_active_text( aOldRepl );
- if ( m_pSearchTmplLB->GetEntryCount() )
+ if ( m_xSearchTmplLB->get_count() )
{
- EnableControl_Impl(m_pSearchBtn);
- EnableControl_Impl(m_pBackSearchBtn);
- EnableControl_Impl(m_pSearchAllBtn);
- EnableControl_Impl(m_pReplaceBtn);
- EnableControl_Impl(m_pReplaceAllBtn);
+ EnableControl_Impl(*m_xSearchBtn);
+ EnableControl_Impl(*m_xBackSearchBtn);
+ EnableControl_Impl(*m_xSearchAllBtn);
+ EnableControl_Impl(*m_xReplaceBtn);
+ EnableControl_Impl(*m_xReplaceAllBtn);
}
}
@@ -1692,21 +1629,11 @@ void SvxSearchDialog::EnableControls_Impl( const SearchOptionFlags nFlags )
else
nOptions = nFlags;
- if ( nOptions == SearchOptionFlags::NONE )
- {
- if ( IsVisible() )
- {
- Hide();
- return;
- }
- }
- else if ( !IsVisible() )
- Show();
bool bNoSearch = true;
bool bEnableSearch = bool( SearchOptionFlags::SEARCH & nOptions );
- m_pSearchBtn->Enable(bEnableSearch);
- m_pBackSearchBtn->Enable(bEnableSearch);
+ m_xSearchBtn->set_sensitive(bEnableSearch);
+ m_xBackSearchBtn->set_sensitive(bEnableSearch);
if( bEnableSearch )
bNoSearch = false;
@@ -1714,96 +1641,96 @@ void SvxSearchDialog::EnableControls_Impl( const SearchOptionFlags nFlags )
if ( SearchOptionFlags::SEARCHALL & nOptions )
{
- m_pSearchAllBtn->Enable();
+ m_xSearchAllBtn->set_sensitive(true);
bNoSearch = false;
}
else
- m_pSearchAllBtn->Disable();
+ m_xSearchAllBtn->set_sensitive(false);
if ( SearchOptionFlags::REPLACE & nOptions )
{
- m_pReplaceBtn->Enable();
- m_pReplaceFrame->get_label_widget()->Enable();
- m_pReplaceLB->Enable();
- m_pReplaceTmplLB->Enable();
+ m_xReplaceBtn->set_sensitive(true);
+ m_xReplaceFrame->set_sensitive(true);
+ m_xReplaceLB->set_sensitive(true);
+ m_xReplaceTmplLB->set_sensitive(true);
bNoSearch = false;
}
else
{
- m_pReplaceBtn->Disable();
- m_pReplaceFrame->get_label_widget()->Disable();
- m_pReplaceLB->Disable();
- m_pReplaceTmplLB->Disable();
+ m_xReplaceBtn->set_sensitive(false);
+ m_xReplaceFrame->set_sensitive(false);
+ m_xReplaceLB->set_sensitive(false);
+ m_xReplaceTmplLB->set_sensitive(false);
}
if ( SearchOptionFlags::REPLACE_ALL & nOptions )
{
- m_pReplaceAllBtn->Enable();
+ m_xReplaceAllBtn->set_sensitive(true);
bNoSearch = false;
}
else
- m_pReplaceAllBtn->Disable();
- m_pComponentFrame->Enable(!bNoSearch);
- m_pSearchBtn->Enable( !bNoSearch );
- m_pBackSearchBtn->Enable( !bNoSearch );
- m_pSearchFrame->get_label_widget()->Enable( !bNoSearch );
- m_pSearchLB->Enable( !bNoSearch );
- m_pNotesBtn->Enable();
+ m_xReplaceAllBtn->set_sensitive(false);
+ m_xComponentFrame->set_sensitive(!bNoSearch);
+ m_xSearchBtn->set_sensitive( !bNoSearch );
+ m_xBackSearchBtn->set_sensitive( !bNoSearch );
+ m_xSearchFrame->set_sensitive( !bNoSearch );
+ m_xSearchLB->set_sensitive( !bNoSearch );
+ m_xNotesBtn->set_sensitive(true);
if ( SearchOptionFlags::WHOLE_WORDS & nOptions )
- m_pWordBtn->Enable();
+ m_xWordBtn->set_sensitive(true);
else
- m_pWordBtn->Disable();
+ m_xWordBtn->set_sensitive(false);
if ( SearchOptionFlags::BACKWARDS & nOptions )
{
- m_pBackSearchBtn->Enable();
- m_pReplaceBackwardsCB->Enable();
+ m_xBackSearchBtn->set_sensitive(true);
+ m_xReplaceBackwardsCB->set_sensitive(true);
}
else
{
- m_pBackSearchBtn->Disable();
- m_pReplaceBackwardsCB->Disable();
+ m_xBackSearchBtn->set_sensitive(false);
+ m_xReplaceBackwardsCB->set_sensitive(false);
}
if ( SearchOptionFlags::REG_EXP & nOptions )
- m_pRegExpBtn->Enable();
+ m_xRegExpBtn->set_sensitive(true);
else
- m_pRegExpBtn->Disable();
+ m_xRegExpBtn->set_sensitive(false);
if ( SearchOptionFlags::WILDCARD & nOptions )
- m_pWildcardBtn->Enable();
+ m_xWildcardBtn->set_sensitive(true);
else
- m_pWildcardBtn->Disable();
+ m_xWildcardBtn->set_sensitive(false);
if ( SearchOptionFlags::EXACT & nOptions )
- m_pMatchCaseCB->Enable();
+ m_xMatchCaseCB->set_sensitive(true);
else
- m_pMatchCaseCB->Disable();
+ m_xMatchCaseCB->set_sensitive(false);
if ( SearchOptionFlags::SELECTION & nOptions )
- m_pSelectionBtn->Enable();
+ m_xSelectionBtn->set_sensitive(true);
else
- m_pSelectionBtn->Disable();
+ m_xSelectionBtn->set_sensitive(false);
if ( SearchOptionFlags::FAMILIES & nOptions )
- m_pLayoutBtn->Enable();
+ m_xLayoutBtn->set_sensitive(true);
else
- m_pLayoutBtn->Disable();
+ m_xLayoutBtn->set_sensitive(false);
if ( SearchOptionFlags::FORMAT & nOptions )
{
- m_pAttributeBtn->Enable();
- m_pFormatBtn->Enable();
- m_pNoFormatBtn->Enable();
+ m_xAttributeBtn->set_sensitive(true);
+ m_xFormatBtn->set_sensitive(true);
+ m_xNoFormatBtn->set_sensitive(true);
}
else
{
- m_pAttributeBtn->Disable();
- m_pFormatBtn->Disable();
- m_pNoFormatBtn->Disable();
+ m_xAttributeBtn->set_sensitive(false);
+ m_xFormatBtn->set_sensitive(false);
+ m_xNoFormatBtn->set_sensitive(false);
}
if ( SearchOptionFlags::SIMILARITY & nOptions )
{
- m_pSimilarityBox->Enable();
- m_pSimilarityBtn->Enable();
+ m_xSimilarityBox->set_sensitive(true);
+ m_xSimilarityBtn->set_sensitive(true);
}
else
{
- m_pSimilarityBox->Disable();
- m_pSimilarityBtn->Disable();
+ m_xSimilarityBox->set_sensitive(false);
+ m_xSimilarityBtn->set_sensitive(false);
}
if ( pSearchItem )
@@ -1811,110 +1738,108 @@ void SvxSearchDialog::EnableControls_Impl( const SearchOptionFlags nFlags )
( !pSearchList || !pSearchList->Count() ) );
}
-
-void SvxSearchDialog::EnableControl_Impl( Control const * pCtrl )
+void SvxSearchDialog::EnableControl_Impl(const weld::Widget& rCtrl)
{
- if (m_pSearchBtn == pCtrl && ( SearchOptionFlags::SEARCH & nOptions ) )
+ if (m_xSearchBtn.get() == &rCtrl && ( SearchOptionFlags::SEARCH & nOptions ) )
{
- m_pComponentFrame->Enable();
- m_pSearchBtn->Enable();
+ m_xComponentFrame->set_sensitive(true);
+ m_xSearchBtn->set_sensitive(true);
return;
}
- if ( m_pSearchAllBtn == pCtrl &&
+ if ( m_xSearchAllBtn.get() == &rCtrl &&
( SearchOptionFlags::SEARCHALL & nOptions ) )
{
- m_pSearchAllBtn->Enable();
+ m_xSearchAllBtn->set_sensitive(true);
return;
}
- if ( m_pReplaceBtn == pCtrl && ( SearchOptionFlags::REPLACE & nOptions ) )
+ if ( m_xReplaceBtn.get() == &rCtrl && ( SearchOptionFlags::REPLACE & nOptions ) )
{
- m_pReplaceBtn->Enable();
+ m_xReplaceBtn->set_sensitive(true);
return;
}
- if ( m_pReplaceAllBtn == pCtrl &&
+ if ( m_xReplaceAllBtn.get() == &rCtrl &&
( SearchOptionFlags::REPLACE_ALL & nOptions ) )
{
- m_pReplaceAllBtn->Enable();
+ m_xReplaceAllBtn->set_sensitive(true);
return;
}
- if ( m_pWordBtn == pCtrl && ( SearchOptionFlags::WHOLE_WORDS & nOptions ) )
+ if ( m_xWordBtn.get() == &rCtrl && ( SearchOptionFlags::WHOLE_WORDS & nOptions ) )
{
- m_pWordBtn->Enable();
+ m_xWordBtn->set_sensitive(true);
return;
}
if ( SearchOptionFlags::BACKWARDS & nOptions )
{
- if( m_pBackSearchBtn == pCtrl )
+ if( m_xBackSearchBtn.get() == &rCtrl )
{
- m_pBackSearchBtn->Enable();
+ m_xBackSearchBtn->set_sensitive(true);
return;
}
- else if ( m_pReplaceBackwardsCB == pCtrl )
+ else if ( m_xReplaceBackwardsCB.get() == &rCtrl )
{
- m_pReplaceBackwardsCB->Enable();
+ m_xReplaceBackwardsCB->set_sensitive(true);
return;
}
}
- if (m_pNotesBtn == pCtrl)
+ if (m_xNotesBtn.get() == &rCtrl)
{
- m_pNotesBtn->Enable();
+ m_xNotesBtn->set_sensitive(true);
return;
}
- if ( m_pRegExpBtn == pCtrl && ( SearchOptionFlags::REG_EXP & nOptions )
- && !m_pSimilarityBox->IsChecked() && !m_pWildcardBtn->IsChecked())
+ if ( m_xRegExpBtn.get() == &rCtrl && ( SearchOptionFlags::REG_EXP & nOptions )
+ && !m_xSimilarityBox->get_active() && !m_xWildcardBtn->get_active())
{
- m_pRegExpBtn->Enable();
+ m_xRegExpBtn->set_sensitive(true);
return;
}
- if ( m_pWildcardBtn == pCtrl && ( SearchOptionFlags::WILDCARD & nOptions )
- && !m_pSimilarityBox->IsChecked() && !m_pRegExpBtn->IsChecked())
+ if ( m_xWildcardBtn.get() == &rCtrl && ( SearchOptionFlags::WILDCARD & nOptions )
+ && !m_xSimilarityBox->get_active() && !m_xRegExpBtn->get_active())
{
- m_pWildcardBtn->Enable();
+ m_xWildcardBtn->set_sensitive(true);
return;
}
- if ( m_pMatchCaseCB == pCtrl && ( SearchOptionFlags::EXACT & nOptions ) )
+ if ( m_xMatchCaseCB.get() == &rCtrl && ( SearchOptionFlags::EXACT & nOptions ) )
{
- if (!m_pJapOptionsCB->IsChecked())
- m_pMatchCaseCB->Enable();
+ if (!m_xJapOptionsCB->get_active())
+ m_xMatchCaseCB->set_sensitive(true);
return;
}
- if ( m_pSelectionBtn == pCtrl && ( SearchOptionFlags::SELECTION & nOptions ) )
+ if ( m_xSelectionBtn.get() == &rCtrl && ( SearchOptionFlags::SELECTION & nOptions ) )
{
- m_pSelectionBtn->Enable();
+ m_xSelectionBtn->set_sensitive(true);
return;
}
- if ( m_pLayoutBtn == pCtrl && ( SearchOptionFlags::FAMILIES & nOptions ) )
+ if ( m_xLayoutBtn.get() == &rCtrl && ( SearchOptionFlags::FAMILIES & nOptions ) )
{
- m_pLayoutBtn->Enable();
+ m_xLayoutBtn->set_sensitive(true);
return;
}
- if ( m_pAttributeBtn == pCtrl
+ if ( m_xAttributeBtn.get() == &rCtrl
&& ( SearchOptionFlags::FORMAT & nOptions )
&& pSearchList )
{
- m_pAttributeBtn->Enable( pImpl->bFocusOnSearch );
+ m_xAttributeBtn->set_sensitive( pImpl->bFocusOnSearch );
}
- if ( m_pFormatBtn == pCtrl && ( SearchOptionFlags::FORMAT & nOptions ) )
+ if ( m_xFormatBtn.get() == &rCtrl && ( SearchOptionFlags::FORMAT & nOptions ) )
{
- m_pFormatBtn->Enable();
+ m_xFormatBtn->set_sensitive(true);
return;
}
- if ( m_pNoFormatBtn == pCtrl && ( SearchOptionFlags::FORMAT & nOptions ) )
+ if ( m_xNoFormatBtn.get() == &rCtrl && ( SearchOptionFlags::FORMAT & nOptions ) )
{
- m_pNoFormatBtn->Enable();
+ m_xNoFormatBtn->set_sensitive(true);
return;
}
- if ( m_pSimilarityBox == pCtrl && ( SearchOptionFlags::SIMILARITY & nOptions )
- && !m_pRegExpBtn->IsChecked() && !m_pWildcardBtn->IsChecked())
+ if ( m_xSimilarityBox.get() == &rCtrl && ( SearchOptionFlags::SIMILARITY & nOptions )
+ && !m_xRegExpBtn->get_active() && !m_xWildcardBtn->get_active())
{
- m_pSimilarityBox->Enable();
+ m_xSimilarityBox->set_sensitive(true);
- if ( m_pSimilarityBox->IsChecked() )
- m_pSimilarityBtn->Enable();
+ if ( m_xSimilarityBox->get_active() )
+ m_xSimilarityBtn->set_sensitive(true);
}
}
-
void SvxSearchDialog::SetItem_Impl( const SvxSearchItem* pItem )
{
//TODO: save pItem and process later if m_executingSubDialog?
@@ -1926,44 +1851,43 @@ void SvxSearchDialog::SetItem_Impl( const SvxSearchItem* pItem )
}
}
-
-IMPL_LINK( SvxSearchDialog, FocusHdl_Impl, Control&, rControl, void )
+IMPL_LINK(SvxSearchDialog, FocusHdl_Impl, weld::Widget&, rControl, void)
{
- sal_Int32 nTxtLen = m_pSearchAttrText->GetText().getLength();
- Control* pCtrl = &rControl;
- if ( pCtrl == m_pSearchLB )
+ sal_Int32 nTxtLen = m_xSearchAttrText->get_label().getLength();
+ weld::Widget* pCtrl = &rControl;
+ if (pCtrl == m_xSearchLB.get())
{
- if ( pCtrl->HasChildPathFocus() )
+ if (pCtrl->has_focus())
pImpl->bFocusOnSearch = true;
- pCtrl = m_pSearchLB;
+ pCtrl = m_xSearchLB.get();
bSearch = true;
if( nTxtLen )
- EnableControl_Impl(m_pNoFormatBtn);
+ EnableControl_Impl(*m_xNoFormatBtn);
else
- m_pNoFormatBtn->Disable();
- EnableControl_Impl(m_pAttributeBtn);
+ m_xNoFormatBtn->set_sensitive(false);
+ EnableControl_Impl(*m_xAttributeBtn);
}
else
{
pImpl->bFocusOnSearch = false;
- pCtrl = m_pReplaceLB;
+ pCtrl = m_xReplaceLB.get();
bSearch = false;
- if (!m_pReplaceAttrText->GetText().isEmpty())
- EnableControl_Impl(m_pNoFormatBtn);
+ if (!m_xReplaceAttrText->get_label().isEmpty())
+ EnableControl_Impl(*m_xNoFormatBtn);
else
- m_pNoFormatBtn->Disable();
- m_pAttributeBtn->Disable();
+ m_xNoFormatBtn->set_sensitive(false);
+ m_xAttributeBtn->set_sensitive(false);
}
bSet = true;
- static_cast<ComboBox*>(pCtrl)->SetSelection( Selection( SELECTION_MIN, SELECTION_MAX ) );
-
- ModifyHdl_Impl( static_cast<Edit&>(*pCtrl) );
+ weld::ComboBox &rComboBox = dynamic_cast<weld::ComboBox&>(*pCtrl);
+ rComboBox.select_entry_region(0, -1);
+ ModifyHdl_Impl(rComboBox);
if (bFormat && nTxtLen)
- m_pLayoutBtn->SetText(aLayoutStr);
+ m_xLayoutBtn->set_label(aLayoutStr);
else
{
SvtModuleOptions::EFactory eFactory = getModule(rBindings);
@@ -1974,25 +1898,23 @@ IMPL_LINK( SvxSearchDialog, FocusHdl_Impl, Control&, rControl, void )
bool bCalcApp = eFactory == SvtModuleOptions::EFactory::CALC;
if (bWriterApp)
- m_pLayoutBtn->SetText(aLayoutWriterStr);
+ m_xLayoutBtn->set_label(aLayoutWriterStr);
else
{
if (bCalcApp)
- m_pLayoutBtn->SetText(aLayoutCalcStr);
+ m_xLayoutBtn->set_label(aLayoutCalcStr);
else
- m_pLayoutBtn->SetText(aStylesStr);
+ m_xLayoutBtn->set_label(aStylesStr);
}
}
}
-
-IMPL_LINK_NOARG(SvxSearchDialog, LoseFocusHdl_Impl, Control&, void)
+IMPL_LINK_NOARG(SvxSearchDialog, LoseFocusHdl_Impl, weld::Widget&, void)
{
SaveToModule_Impl();
}
-
-IMPL_LINK_NOARG(SvxSearchDialog, FormatHdl_Impl, Button*, void)
+IMPL_LINK_NOARG(SvxSearchDialog, FormatHdl_Impl, weld::Button&, void)
{
SfxObjectShell* pSh = SfxObjectShell::Current();
@@ -2032,7 +1954,7 @@ IMPL_LINK_NOARG(SvxSearchDialog, FormatHdl_Impl, Button*, void)
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
- ScopedVclPtr<SfxAbstractTabDialog> pDlg(pFact->CreateTabItemDialog(GetFrameWeld(), aSet));
+ ScopedVclPtr<SfxAbstractTabDialog> pDlg(pFact->CreateTabItemDialog(m_xDialog.get(), aSet));
pDlg->SetText( aTxt );
if ( executeSubDialog(pDlg.get()) == RET_OK )
@@ -2063,8 +1985,7 @@ IMPL_LINK_NOARG(SvxSearchDialog, FormatHdl_Impl, Button*, void)
}
}
-
-IMPL_LINK_NOARG(SvxSearchDialog, NoFormatHdl_Impl, Button*, void)
+IMPL_LINK_NOARG(SvxSearchDialog, NoFormatHdl_Impl, weld::Button&, void)
{
SvtModuleOptions::EFactory eFactory = getModule(rBindings);
bool bWriterApp =
@@ -2074,75 +1995,73 @@ IMPL_LINK_NOARG(SvxSearchDialog, NoFormatHdl_Impl, Button*, void)
bool bCalcApp = eFactory == SvtModuleOptions::EFactory::CALC;
if (bCalcApp)
- m_pLayoutBtn->SetText( aLayoutCalcStr );
+ m_xLayoutBtn->set_label( aLayoutCalcStr );
else
{
if (bWriterApp)
- m_pLayoutBtn->SetText( aLayoutWriterStr);
+ m_xLayoutBtn->set_label( aLayoutWriterStr);
else
- m_pLayoutBtn->SetText( aStylesStr );
+ m_xLayoutBtn->set_label( aStylesStr );
}
bFormat = false;
- m_pLayoutBtn->Check( false );
+ m_xLayoutBtn->set_active( false );
bool bSetOptimalLayoutSize = false;
if ( bSearch )
{
pSearchList->Clear();
- m_pSearchAttrText->SetText( "" );
- if (m_pSearchAttrText->IsVisible())
+ m_xSearchAttrText->set_label( "" );
+ if (m_xSearchAttrText->get_visible())
{
- m_pSearchAttrText->Hide();
+ m_xSearchAttrText->hide();
bSetOptimalLayoutSize = true;
}
}
else
{
pReplaceList->Clear();
- m_pReplaceAttrText->SetText( "" );
- if (m_pReplaceAttrText->IsVisible())
+ m_xReplaceAttrText->set_label( "" );
+ if (m_xReplaceAttrText->get_visible())
{
- m_pReplaceAttrText->Hide();
+ m_xReplaceAttrText->hide();
bSetOptimalLayoutSize = true;
}
}
if (bSetOptimalLayoutSize)
- setOptimalLayoutSize();
+ m_xDialog->resize_to_request();
pImpl->bSaveToModule = false;
- TemplateHdl_Impl(m_pLayoutBtn);
+ TemplateHdl_Impl(*m_xLayoutBtn);
pImpl->bSaveToModule = true;
- m_pNoFormatBtn->Disable();
+ m_xNoFormatBtn->set_sensitive(false);
}
-
-IMPL_LINK_NOARG(SvxSearchDialog, AttributeHdl_Impl, Button*, void)
+IMPL_LINK_NOARG(SvxSearchDialog, AttributeHdl_Impl, weld::Button&, void)
{
if ( !pSearchList || !pImpl->pRanges )
return;
SvxAbstractDialogFactory* pFact = SvxAbstractDialogFactory::Create();
- ScopedVclPtr<VclAbstractDialog> pDlg(pFact->CreateSvxSearchAttributeDialog(GetFrameWeld(), *pSearchList, pImpl->pRanges.get()));
+ ScopedVclPtr<VclAbstractDialog> pDlg(pFact->CreateSvxSearchAttributeDialog(m_xDialog.get(), *pSearchList, pImpl->pRanges.get()));
executeSubDialog(pDlg.get());
PaintAttrText_Impl();
}
-
IMPL_LINK( SvxSearchDialog, TimeoutHdl_Impl, Timer *, pTimer, void )
{
SfxViewShell* pViewShell = SfxViewShell::Current();
if ( pViewShell )
{
- if ( pViewShell->HasSelection( m_pSearchLB->IsVisible() ) )
- EnableControl_Impl(m_pSelectionBtn);
+ if ( pViewShell->HasSelection( m_xSearchLB->get_visible() ) )
+ EnableControl_Impl(*m_xSelectionBtn);
else
{
- m_pSelectionBtn->Check( false );
- m_pSelectionBtn->Disable();
+ m_xSelectionBtn->set_active( false );
+ m_xSelectionBtn->set_sensitive(false);
}
}
@@ -2227,127 +2146,126 @@ void SvxSearchDialog::PaintAttrText_Impl()
if ( bSearch )
{
- m_pSearchAttrText->SetText( aDesc );
- if (!aDesc.isEmpty() && !m_pSearchAttrText->IsVisible())
+ m_xSearchAttrText->set_label( aDesc );
+ if (!aDesc.isEmpty() && !m_xSearchAttrText->get_visible())
{
- m_pSearchAttrText->Show();
+ m_xSearchAttrText->show();
bSetOptimalLayoutSize = true;
}
- FocusHdl_Impl(*m_pSearchLB);
+ FocusHdl_Impl(*m_xSearchLB);
}
else
{
- m_pReplaceAttrText->SetText( aDesc );
- if (!aDesc.isEmpty() && !m_pReplaceAttrText->IsVisible())
+ m_xReplaceAttrText->set_label( aDesc );
+ if (!aDesc.isEmpty() && !m_xReplaceAttrText->get_visible())
{
- m_pReplaceAttrText->Show();
+ m_xReplaceAttrText->show();
bSetOptimalLayoutSize = true;
}
- FocusHdl_Impl(*m_pReplaceLB);
+ FocusHdl_Impl(*m_xReplaceLB);
}
if (bSetOptimalLayoutSize)
- setOptimalLayoutSize();
+ m_xDialog->resize_to_request();
}
-void SvxSearchDialog::SetModifyFlag_Impl( const Control* pCtrl )
+void SvxSearchDialog::SetModifyFlag_Impl( const weld::Widget* pCtrl )
{
- if ( m_pSearchLB == pCtrl )
+ if (m_xSearchLB.get() == pCtrl)
nModifyFlag |= ModifyFlags::Search;
- else if ( m_pReplaceLB == pCtrl )
+ else if ( m_xReplaceLB.get() == pCtrl )
nModifyFlag |= ModifyFlags::Replace;
- else if ( m_pWordBtn == pCtrl )
+ else if ( m_xWordBtn.get() == pCtrl )
nModifyFlag |= ModifyFlags::Word;
- else if ( m_pMatchCaseCB == pCtrl )
+ else if ( m_xMatchCaseCB.get() == pCtrl )
nModifyFlag |= ModifyFlags::Exact;
- else if ( m_pReplaceBackwardsCB == pCtrl )
+ else if ( m_xReplaceBackwardsCB.get() == pCtrl )
nModifyFlag |= ModifyFlags::Backwards;
- else if ( m_pNotesBtn == pCtrl )
+ else if ( m_xNotesBtn.get() == pCtrl )
nModifyFlag |= ModifyFlags::Notes;
- else if ( m_pSelectionBtn == pCtrl )
+ else if ( m_xSelectionBtn.get() == pCtrl )
nModifyFlag |= ModifyFlags::Selection;
- else if ( m_pRegExpBtn == pCtrl )
+ else if ( m_xRegExpBtn.get() == pCtrl )
nModifyFlag |= ModifyFlags::Regexp;
- else if ( m_pWildcardBtn == pCtrl )
+ else if ( m_xWildcardBtn.get() == pCtrl )
nModifyFlag |= ModifyFlags::Wildcard;
- else if ( m_pLayoutBtn == pCtrl )
+ else if ( m_xLayoutBtn.get() == pCtrl )
nModifyFlag |= ModifyFlags::Layout;
- else if ( m_pSimilarityBox == pCtrl )
+ else if ( m_xSimilarityBox.get() == pCtrl )
nModifyFlag |= ModifyFlags::Similarity;
- else if ( m_pCalcSearchInLB == pCtrl )
+ else if ( m_xCalcSearchInLB.get() == pCtrl )
{
nModifyFlag |= ModifyFlags::Formulas;
nModifyFlag |= ModifyFlags::Values;
nModifyFlag |= ModifyFlags::CalcNotes;
}
- else if ( m_pRowsBtn == pCtrl )
+ else if ( m_xRowsBtn.get() == pCtrl )
nModifyFlag |= ModifyFlags::Rows;
- else if ( m_pColumnsBtn == pCtrl )
+ else if ( m_xColumnsBtn.get() == pCtrl )
nModifyFlag |= ModifyFlags::Columns;
- else if ( m_pAllSheetsCB == pCtrl )
+ else if ( m_xAllSheetsCB.get() == pCtrl )
nModifyFlag |= ModifyFlags::AllTables;
}
-
void SvxSearchDialog::SaveToModule_Impl()
{
if ( !pSearchItem )
return;
- if ( m_pLayoutBtn->IsChecked() )
+ if ( m_xLayoutBtn->get_active() )
{
- pSearchItem->SetSearchString ( m_pSearchTmplLB->GetSelectedEntry() );
- pSearchItem->SetReplaceString( m_pReplaceTmplLB->GetSelectedEntry() );
+ pSearchItem->SetSearchString ( m_xSearchTmplLB->get_active_text() );
+ pSearchItem->SetReplaceString( m_xReplaceTmplLB->get_active_text() );
}
else
{
- pSearchItem->SetSearchString ( m_pSearchLB->GetText() );
- pSearchItem->SetReplaceString( m_pReplaceLB->GetText() );
- Remember_Impl( m_pSearchLB->GetText(), true );
+ pSearchItem->SetSearchString ( m_xSearchLB->get_active_text() );
+ pSearchItem->SetReplaceString( m_xReplaceLB->get_active_text() );
+ Remember_Impl( m_xSearchLB->get_active_text(), true );
}
pSearchItem->SetRegExp( false );
pSearchItem->SetWildcard( false );
pSearchItem->SetLevenshtein( false );
- if (GetCheckBoxValue(m_pRegExpBtn))
+ if (GetCheckBoxValue(*m_xRegExpBtn))
pSearchItem->SetRegExp( true );
- else if (GetCheckBoxValue(m_pWildcardBtn))
+ else if (GetCheckBoxValue(*m_xWildcardBtn))
pSearchItem->SetWildcard( true );
- else if (GetCheckBoxValue(m_pSimilarityBox))
+ else if (GetCheckBoxValue(*m_xSimilarityBox))
pSearchItem->SetLevenshtein( true );
- pSearchItem->SetWordOnly(GetCheckBoxValue(m_pWordBtn));
- pSearchItem->SetBackward(GetCheckBoxValue(m_pReplaceBackwardsCB));
- pSearchItem->SetNotes(GetCheckBoxValue(m_pNotesBtn));
- pSearchItem->SetPattern(GetCheckBoxValue(m_pLayoutBtn));
- pSearchItem->SetSelection(GetCheckBoxValue(m_pSelectionBtn));
- pSearchItem->SetUseAsianOptions(GetCheckBoxValue(m_pJapOptionsCB));
+ pSearchItem->SetWordOnly(GetCheckBoxValue(*m_xWordBtn));
+ pSearchItem->SetBackward(GetCheckBoxValue(*m_xReplaceBackwardsCB));
+ pSearchItem->SetNotes(GetCheckBoxValue(*m_xNotesBtn));
+ pSearchItem->SetPattern(GetCheckBoxValue(*m_xLayoutBtn));
+ pSearchItem->SetSelection(GetCheckBoxValue(*m_xSelectionBtn));
+ pSearchItem->SetUseAsianOptions(GetCheckBoxValue(*m_xJapOptionsCB));
SvtSearchOptions aOpt;
- aOpt.SetIgnoreDiacritics_CTL(GetNegatedCheckBoxValue(m_pIncludeDiacritics));
- aOpt.SetIgnoreKashida_CTL(GetNegatedCheckBoxValue(m_pIncludeKashida));
+ aOpt.SetIgnoreDiacritics_CTL(GetNegatedCheckBoxValue(*m_xIncludeDiacritics));
+ aOpt.SetIgnoreKashida_CTL(GetNegatedCheckBoxValue(*m_xIncludeKashida));
aOpt.Commit();
TransliterationFlags nFlags = GetTransliterationFlags();
if( !pSearchItem->IsUseAsianOptions())
nFlags &= TransliterationFlags::IGNORE_CASE |
TransliterationFlags::IGNORE_WIDTH;
- if (GetNegatedCheckBoxValue(m_pIncludeDiacritics))
+ if (GetNegatedCheckBoxValue(*m_xIncludeDiacritics))
nFlags |= TransliterationFlags::IGNORE_DIACRITICS_CTL;
- if (GetNegatedCheckBoxValue(m_pIncludeKashida))
+ if (GetNegatedCheckBoxValue(*m_xIncludeKashida))
nFlags |= TransliterationFlags::IGNORE_KASHIDA_CTL;
pSearchItem->SetTransliterationFlags( nFlags );
if ( !bWriter )
{
- if ( m_pCalcSearchInLB->GetSelectedEntryPos() != LISTBOX_ENTRY_NOTFOUND )
- pSearchItem->SetCellType( static_cast<SvxSearchCellType>(m_pCalcSearchInLB->GetSelectedEntryPos()) );
+ if (m_xCalcSearchInLB->get_active() != -1)
+ pSearchItem->SetCellType( static_cast<SvxSearchCellType>(m_xCalcSearchInLB->get_active()) );
- pSearchItem->SetRowDirection( m_pRowsBtn->IsChecked() );
- pSearchItem->SetAllTables( m_pAllSheetsCB->IsChecked() );
- pSearchItem->SetSearchFormatted( m_pSearchFormattedCB->IsChecked() );
+ pSearchItem->SetRowDirection( m_xRowsBtn->get_active() );
+ pSearchItem->SetAllTables( m_xAllSheetsCB->get_active() );
+ pSearchItem->SetSearchFormatted( m_xSearchFormattedCB->get_active() );
}
pSearchItem->SetCommand( SvxSearchCmd::FIND );
@@ -2356,18 +2274,39 @@ void SvxSearchDialog::SaveToModule_Impl()
rBindings.GetDispatcher()->Execute( SID_SEARCH_ITEM, SfxCallMode::SLOT, ppArgs );
}
-css::uno::Reference< css::awt::XWindowPeer >
- SvxSearchDialog::GetComponentInterface( bool bCreate )
+void SvxSearchDialog::SetDocWin(vcl::Window* pDocWin)
{
- css::uno::Reference< css::awt::XWindowPeer > xPeer( Window::GetComponentInterface(false) );
- if ( !xPeer.is() && bCreate )
+ m_xDialog->clear_extra_accessible_relations();
+
+ if (!pDocWin)
+ return;
+
+ Reference<css::accessibility::XAccessible> xDocAcc = pDocWin->GetAccessible();
+ if (!xDocAcc.is())
{
- css::awt::XWindowPeer* pPeer = new VCLXSvxFindReplaceDialog(this);
- SetComponentInterface(pPeer);
- return pPeer;
+ return;
+ }
+ Reference<css::accessibility::XAccessibleGetAccFlowTo> xGetAccFlowTo(xDocAcc, UNO_QUERY);
+ if (!xGetAccFlowTo.is())
+ {
+ return;
+ }
+
+ const sal_Int32 FORFINDREPLACEFLOWTO = 2;
+ uno::Sequence<uno::Any> aAnySeq = xGetAccFlowTo->getAccFlowTo(Any(GetSrchFlag()), FORFINDREPLACEFLOWTO);
+
+ sal_Int32 nLen = aAnySeq.getLength();
+ if (nLen)
+ {
+ uno::Sequence<uno::Reference<uno::XInterface>> aSequence(nLen);
+ for (sal_Int32 i = 0; i < nLen; ++i)
+ {
+ uno::Reference < css::accessibility::XAccessible > xAcc;
+ aAnySeq[i] >>= xAcc;
+ aSequence[i] = xAcc;
+ }
+ m_xDialog->add_extra_accessible_relation(css::accessibility::AccessibleRelation(css::accessibility::AccessibleRelationType::CONTENT_FLOWS_TO, aSequence));
}
- else
- return xPeer;
}
short SvxSearchDialog::executeSubDialog(VclAbstractDialog * dialog) {
@@ -2384,9 +2323,9 @@ SvxSearchDialogWrapper::SvxSearchDialogWrapper( vcl::Window* _pParent, sal_uInt1
SfxBindings* pBindings,
SfxChildWinInfo const * pInfo )
: SfxChildWindow( _pParent, nId )
- , dialog (VclPtr<SvxSearchDialog>::Create(_pParent, this, *pBindings))
+ , dialog(new SvxSearchDialog(_pParent->GetFrameWeld(), this, *pBindings))
{
- SetWindow(dialog);
+ SetController(dialog);
dialog->Initialize( pInfo );
pBindings->Update( SID_SEARCH_ITEM );
diff --git a/svx/uiconfig/ui/findreplacedialog.ui b/svx/uiconfig/ui/findreplacedialog.ui
index 1fbade190035..2d3a68113ae5 100644
--- a/svx/uiconfig/ui/findreplacedialog.ui
+++ b/svx/uiconfig/ui/findreplacedialog.ui
@@ -1,5 +1,5 @@
<?xml version="1.0" encoding="UTF-8"?>
-<!-- Generated with glade 3.20.0 -->
+<!-- Generated with glade 3.22.1 -->
<interface domain="svx">
<requires lib="gtk+" version="3.18"/>
<object class="GtkDialog" id="FindReplaceDialog">
@@ -7,7 +7,12 @@
<property name="border_width">6</property>
<property name="title" translatable="yes" context="findreplacedialog|FindReplaceDialog">Find &amp; Replace</property>
<property name="resizable">False</property>
+ <property name="default_width">0</property>
+ <property name="default_height">0</property>
<property name="type_hint">dialog</property>
+ <child>
+ <placeholder/>
+ </child>
<child internal-child="vbox">
<object class="GtkBox" id="dialog-vbox3">
<property name="can_focus">False</property>
@@ -91,7 +96,7 @@
<property name="margin_right">6</property>
<property name="hexpand">True</property>
<child>
- <object class="GtkComboBox" id="searchterm">
+ <object class="GtkComboBoxText" id="searchterm">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="valign">center</property>
@@ -100,6 +105,7 @@
<child internal-child="entry">
<object class="GtkEntry" id="combobox-entry">
<property name="can_focus">True</property>
+ <property name="activates_default">True</property>
</object>
</child>
</object>
@@ -109,7 +115,7 @@
</packing>
</child>
<child>
- <object class="GtkComboBox" id="searchlist">
+ <object class="GtkComboBoxText" id="searchlist">
<property name="can_focus">False</property>
<property name="no_show_all">True</property>
<property name="hexpand">True</property>
@@ -151,6 +157,7 @@
<property name="no_show_all">True</property>
<property name="hexpand">True</property>
<property name="wrap">True</property>
+ <property name="ellipsize">end</property>
<property name="xalign">0</property>
<property name="yalign">0.55000001192092896</property>
</object>
@@ -167,9 +174,11 @@
<property name="wrap">True</property>
<property name="ellipsize">end</property>
<property name="xalign">0</property>
- <accessibility>
- <role type="static"/>
- </accessibility>
+ <child internal-child="accessible">
+ <object class="AtkObject" id="searchlabel-atkobject">
+ <property name="AtkObject::accessible-role" translatable="no">static</property>
+ </object>
+ </child>
</object>
<packing>
<property name="left_attach">1</property>
@@ -275,6 +284,18 @@
<property name="top_attach">3</property>
</packing>
</child>
+ <child>
+ <placeholder/>
+ </child>
+ <child>
+ <placeholder/>
+ </child>
+ <child>
+ <placeholder/>
+ </child>
+ <child>
+ <placeholder/>
+ </child>
</object>
</child>
</object>
@@ -325,7 +346,7 @@
<property name="margin_right">6</property>
<property name="hexpand">True</property>
<child>
- <object class="GtkComboBox" id="replaceterm">
+ <object class="GtkComboBoxText" id="replaceterm">
<property name="visible">True</property>
<property name="can_focus">False</property>
<property name="valign">center</property>
@@ -334,6 +355,7 @@
<child internal-child="entry">
<object class="GtkEntry" id="combobox-entry2">
<property name="can_focus">True</property>
+ <property name="activates_default">True</property>
</object>
</child>
</object>
@@ -343,7 +365,7 @@
</packing>
</child>
<child>
- <object class="GtkComboBox" id="replacelist">
+ <object class="GtkComboBoxText" id="replacelist">
<property name="can_focus">False</property>
<property name="no_show_all">True</property>
<property name="hexpand">True</property>
@@ -385,6 +407,7 @@
<property name="no_show_all">True</property>
<property name="hexpand">True</property>
<property name="wrap">True</property>
+ <property name="ellipsize">end</property>
<property name="xalign">0</property>
</object>
<packing>
@@ -392,6 +415,12 @@
<property name="top_attach">2</property>
</packing>
</child>
+ <child>
+ <placeholder/>
+ </child>
+ <child>
+ <placeholder/>
+ </child>
</object>
</child>
</object>
@@ -1030,6 +1059,7 @@
<property name="use_underline">True</property>
<property name="xalign">0</property>
<property name="draw_indicator">True</property>
+ <property name="group">rows</property>
<accessibility>
<relation type="member-of" target="searchdir"/>
</accessibility>
diff --git a/sw/source/core/crsr/viscrs.cxx b/sw/source/core/crsr/viscrs.cxx
index 672184d863a6..72ccc90b7acd 100644
--- a/sw/source/core/crsr/viscrs.cxx
+++ b/sw/source/core/crsr/viscrs.cxx
@@ -655,7 +655,7 @@ SwCursor* SwShellCursor::Create( SwPaM* pRing ) const
short SwShellCursor::MaxReplaceArived()
{
short nRet = RET_YES;
- vcl::Window* pDlg = SwView::GetSearchDialog();
+ SvxSearchDialog* pDlg = SwView::GetSearchDialog();
if( pDlg )
{
// Terminate old actions. The table-frames get constructed and
@@ -671,7 +671,7 @@ short SwShellCursor::MaxReplaceArived()
}
vActionCounts.push_back(nActCnt);
}
- std::unique_ptr<weld::Builder> xBuilder(Application::CreateBuilder(pDlg->GetFrameWeld(), "modules/swriter/ui/asksearchdialog.ui"));
+ std::unique_ptr<weld::Builder> xBuilder(Application::CreateBuilder(pDlg->getDialog(), "modules/swriter/ui/asksearchdialog.ui"));
std::unique_ptr<weld::MessageDialog> xDialog(xBuilder->weld_message_dialog("AskSearchDialog"));
nRet = xDialog->run();
auto pActionCount = vActionCounts.begin();
diff --git a/sw/source/ui/fldui/fldtdlg.cxx b/sw/source/ui/fldui/fldtdlg.cxx
index cade4bbc0bd1..d7acc4f5aa0b 100644
--- a/sw/source/ui/fldui/fldtdlg.cxx
+++ b/sw/source/ui/fldui/fldtdlg.cxx
@@ -204,8 +204,6 @@ void SwFieldDlg::ReInitTabPage(const OString& rPageId, bool bOnlyActivate)
// newly initialise after activation of a few TabPages
void SwFieldDlg::Activate()
{
- fprintf(stderr, "SwFieldDlg::Activate()\n");
-
SwView* pView = ::GetActiveView();
if( pView )
{
diff --git a/toolkit/source/awt/vclxaccessiblecomponent.cxx b/toolkit/source/awt/vclxaccessiblecomponent.cxx
index d2adad11d884..6f768ac2cbd9 100644
--- a/toolkit/source/awt/vclxaccessiblecomponent.cxx
+++ b/toolkit/source/awt/vclxaccessiblecomponent.cxx
@@ -375,6 +375,9 @@ void VCLXAccessibleComponent::FillAccessibleRelationSet( utl::AccessibleRelation
uno::Sequence< uno::Reference< uno::XInterface > > aSequence { pMemberOf->GetAccessible() };
rRelationSet.AddRelation( accessibility::AccessibleRelation( accessibility::AccessibleRelationType::MEMBER_OF, aSequence ) );
}
+
+ for (const auto& rExtraRelation : pWindow->GetExtraAccessibleRelations())
+ rRelationSet.AddRelation(rExtraRelation);
}
}
diff --git a/vcl/inc/window.h b/vcl/inc/window.h
index ecc28c7dcc98..bee0f55f1425 100644
--- a/vcl/inc/window.h
+++ b/vcl/inc/window.h
@@ -275,7 +275,8 @@ public:
css::uno::Reference< css::awt::XWindowPeer > mxWindowPeer;
css::uno::Reference< css::accessibility::XAccessible > mxAccessible;
std::shared_ptr< VclSizeGroup > m_xSizeGroup;
- std::vector< VclPtr<FixedText> > m_aMnemonicLabels;
+ std::vector<VclPtr<FixedText>> m_aMnemonicLabels;
+ std::vector<css::accessibility::AccessibleRelation> m_aExtraAccessibleRelations;
std::unique_ptr<ImplAccessibleInfos> mpAccessibleInfos;
VCLXWindow* mpVCLXWindow;
vcl::Region maWinRegion; //< region to 'shape' the VCL window (frame coordinates)
diff --git a/vcl/source/app/salvtables.cxx b/vcl/source/app/salvtables.cxx
index 6a27b64f2974..01069b134a81 100644
--- a/vcl/source/app/salvtables.cxx
+++ b/vcl/source/app/salvtables.cxx
@@ -480,6 +480,16 @@ public:
m_xWidget->SetAccessibleRelationLabelFor(pAtkLabeled);
}
+ virtual void add_extra_accessible_relation(const css::accessibility::AccessibleRelation &rRelation) override
+ {
+ m_xWidget->AddExtraAccessibleRelation(rRelation);
+ }
+
+ virtual void clear_extra_accessible_relations() override
+ {
+ m_xWidget->ClearExtraAccessibleRelations();
+ }
+
virtual void set_tooltip_text(const OUString& rTip) override
{
m_xWidget->SetQuickHelpText(rTip);
diff --git a/vcl/source/window/window2.cxx b/vcl/source/window/window2.cxx
index 66df5fa5781f..dfcec76e9b48 100644
--- a/vcl/source/window/window2.cxx
+++ b/vcl/source/window/window2.cxx
@@ -45,6 +45,7 @@
#include <salframe.hxx>
#include <scrwnd.hxx>
+#include <com/sun/star/accessibility/AccessibleRelation.hpp>
#include <com/sun/star/accessibility/AccessibleRole.hpp>
using namespace com::sun::star;
@@ -1946,6 +1947,21 @@ const std::vector<VclPtr<FixedText> >& Window::list_mnemonic_labels() const
return mpWindowImpl->m_aMnemonicLabels;
}
+void Window::AddExtraAccessibleRelation(const css::accessibility::AccessibleRelation &rRelation)
+{
+ mpWindowImpl->m_aExtraAccessibleRelations.push_back(rRelation);
+}
+
+const std::vector<css::accessibility::AccessibleRelation>& Window::GetExtraAccessibleRelations() const
+{
+ return mpWindowImpl->m_aExtraAccessibleRelations;
+}
+
+void Window::ClearExtraAccessibleRelations()
+{
+ mpWindowImpl->m_aExtraAccessibleRelations.clear();
+}
+
} /* namespace vcl */
void DrawFocusRect(vcl::RenderContext& rRenderContext, const tools::Rectangle& rRect)
diff --git a/vcl/unx/gtk/a11y/atkwrapper.cxx b/vcl/unx/gtk/a11y/atkwrapper.cxx
index 2aa1e50bc6c7..a6382c8b2ef6 100644
--- a/vcl/unx/gtk/a11y/atkwrapper.cxx
+++ b/vcl/unx/gtk/a11y/atkwrapper.cxx
@@ -496,8 +496,8 @@ wrapper_get_index_in_parent( AtkObject *atk_obj )
/*****************************************************************************/
-static void
-relation_set_add(AtkRelationSet *pSet, const accessibility::AccessibleRelation& rRelation)
+AtkRelation*
+atk_object_wrapper_relation_new(const accessibility::AccessibleRelation& rRelation)
{
sal_uInt32 nTargetCount = rRelation.TargetSet.getLength();
@@ -515,8 +515,8 @@ relation_set_add(AtkRelationSet *pSet, const accessibility::AccessibleRelation&
aTargets.data(), nTargetCount,
mapRelationType( rRelation.RelationType )
);
- atk_relation_set_add( pSet, pRel );
- g_object_unref( G_OBJECT( pRel ) );
+
+ return pRel;
}
static AtkRelationSet *
@@ -540,7 +540,9 @@ wrapper_ref_relation_set( AtkObject *atk_obj )
sal_Int32 nRelations = xRelationSet.is() ? xRelationSet->getRelationCount() : 0;
for( sal_Int32 n = 0; n < nRelations; n++ )
{
- relation_set_add(pSet, xRelationSet->getRelation(n));
+ AtkRelation *pRel = atk_object_wrapper_relation_new(xRelationSet->getRelation(n));
+ atk_relation_set_add(pSet, pRel);
+ g_object_unref(pRel);
}
}
catch(const uno::Exception &) {
diff --git a/vcl/unx/gtk/a11y/atkwrapper.hxx b/vcl/unx/gtk/a11y/atkwrapper.hxx
index ef33397fa48c..8725e54ccf5b 100644
--- a/vcl/unx/gtk/a11y/atkwrapper.hxx
+++ b/vcl/unx/gtk/a11y/atkwrapper.hxx
@@ -98,6 +98,8 @@ void atk_object_wrapper_dispose(AtkObjectWrapper* wrapper);
AtkStateType mapAtkState( sal_Int16 nState );
+AtkRelation* atk_object_wrapper_relation_new(const css::accessibility::AccessibleRelation& rRelation);
+
void actionIfaceInit(AtkActionIface *iface);
void componentIfaceInit(AtkComponentIface *iface);
void editableTextIfaceInit(AtkEditableTextIface *iface);
diff --git a/vcl/unx/gtk3/gtk3gtkinst.cxx b/vcl/unx/gtk3/gtk3gtkinst.cxx
index 18aaf556223d..d7286685dbcb 100644
--- a/vcl/unx/gtk3/gtk3gtkinst.cxx
+++ b/vcl/unx/gtk3/gtk3gtkinst.cxx
@@ -1299,6 +1299,7 @@ private:
gulong m_nDragLeaveSignalId;
rtl::Reference<GtkDropTarget> m_xDropTarget;
+ std::vector<AtkRelation*> m_aExtraAtkRelations;
static void signalSizeAllocate(GtkWidget*, GdkRectangle* allocation, gpointer widget)
{
@@ -1758,6 +1759,33 @@ public:
g_object_unref(pRelationSet);
}
+ virtual void add_extra_accessible_relation(const css::accessibility::AccessibleRelation &rRelation) override
+ {
+ AtkObject* pAtkObject = gtk_widget_get_accessible(m_pWidget);
+ if (!pAtkObject)
+ return;
+
+ AtkRelationSet *pRelationSet = atk_object_ref_relation_set(pAtkObject);
+ AtkRelation *pRel = atk_object_wrapper_relation_new(rRelation);
+ m_aExtraAtkRelations.push_back(pRel);
+ atk_relation_set_add(pRelationSet, pRel);
+ g_object_unref(pRel);
+ g_object_unref(pRelationSet);
+ }
+
+ virtual void clear_extra_accessible_relations() override
+ {
+ AtkObject* pAtkObject = gtk_widget_get_accessible(m_pWidget);
+ if (!pAtkObject)
+ return;
+
+ AtkRelationSet *pRelationSet = atk_object_ref_relation_set(pAtkObject);
+ for (AtkRelation* pRel : m_aExtraAtkRelations)
+ atk_relation_set_remove(pRelationSet, pRel);
+ m_aExtraAtkRelations.clear();
+ g_object_unref(pRelationSet);
+ }
+
virtual bool get_extents_relative_to(weld::Widget& rRelative, int& x, int &y, int& width, int &height) override
{
//for toplevel windows this is sadly futile under wayland, so we can't tell where a dialog is in order to allow