basctl/source/basicide/basides1.cxx | 1 cui/source/customize/cfg.cxx | 2 cui/source/dialogs/cuifmsearch.cxx | 1 cui/source/inc/optlingu.hxx | 1 cui/source/options/optaboutconfig.cxx | 1 cui/source/options/optaccessibility.hxx | 2 cui/source/options/optjava.cxx | 7 cui/source/options/optjava.hxx | 2 cui/source/options/optopencl.hxx | 1 cui/source/options/optsave.hxx | 1 cui/source/options/optupdt.hxx | 1 cui/source/options/personalization.cxx | 1 cui/source/tabpages/tparea.cxx | 6 include/sfx2/tabdlg.hxx | 120 ---- sc/source/ui/inc/tpcalc.hxx | 1 sc/source/ui/view/tabcont.cxx | 1 sd/source/ui/dlg/diactrl.cxx | 1 sd/source/ui/dlg/paragr.cxx | 1 sfx2/Library_sfx.mk | 1 sfx2/inc/uitest/sfx_uiobject.hxx | 39 - sfx2/source/dialog/dinfdlg.cxx | 2 sfx2/source/dialog/tabdlg.cxx | 952 -------------------------------- sfx2/source/uitest/sfx_uiobject.cxx | 87 -- svx/source/form/fmshimp.cxx | 1 sw/source/uibase/uiview/viewprt.cxx | 1 25 files changed, 24 insertions(+), 1210 deletions(-)
New commits: commit 13da1c7913ca76ca5b33f0666ab7cc4a219815e1 Author: Caolán McNamara <caol...@redhat.com> AuthorDate: Wed May 29 14:16:06 2019 +0100 Commit: Caolán McNamara <caol...@redhat.com> CommitDate: Fri May 31 10:31:28 2019 +0200 drop unneeded includes Change-Id: Ie0f52bb1d6866075d0b664bfc3ddc47c02e4f81b Reviewed-on: https://gerrit.libreoffice.org/73169 Tested-by: Jenkins Reviewed-by: Caolán McNamara <caol...@redhat.com> Tested-by: Caolán McNamara <caol...@redhat.com> diff --git a/basctl/source/basicide/basides1.cxx b/basctl/source/basicide/basides1.cxx index 8ec13c090270..5fac7468fe41 100644 --- a/basctl/source/basicide/basides1.cxx +++ b/basctl/source/basicide/basides1.cxx @@ -52,6 +52,7 @@ #include <svl/visitem.hxx> #include <svl/whiter.hxx> #include <vcl/xtextedt.hxx> +#include <vcl/tabctrl.hxx> #include <vcl/textview.hxx> #include <vcl/svapp.hxx> #include <vcl/weld.hxx> diff --git a/cui/source/customize/cfg.cxx b/cui/source/customize/cfg.cxx index 4ae83691ae40..bf583d4d37a4 100644 --- a/cui/source/customize/cfg.cxx +++ b/cui/source/customize/cfg.cxx @@ -25,11 +25,13 @@ #include <time.h> #include <typeinfo> +#include <vcl/button.hxx> #include <vcl/commandinfoprovider.hxx> #include <vcl/edit.hxx> #include <vcl/event.hxx> #include <vcl/help.hxx> #include <vcl/svapp.hxx> +#include <vcl/toolbox.hxx> #include <vcl/weld.hxx> #include <vcl/decoview.hxx> #include <vcl/virdev.hxx> diff --git a/cui/source/dialogs/cuifmsearch.cxx b/cui/source/dialogs/cuifmsearch.cxx index ea1ad2452d00..d898930ef147 100644 --- a/cui/source/dialogs/cuifmsearch.cxx +++ b/cui/source/dialogs/cuifmsearch.cxx @@ -18,6 +18,7 @@ */ #include <tools/debug.hxx> +#include <vcl/button.hxx> #include <vcl/weld.hxx> #include <vcl/svapp.hxx> #include <dialmgr.hxx> diff --git a/cui/source/inc/optlingu.hxx b/cui/source/inc/optlingu.hxx index 8a6b75a016e0..77e016d0b154 100644 --- a/cui/source/inc/optlingu.hxx +++ b/cui/source/inc/optlingu.hxx @@ -19,6 +19,7 @@ #ifndef INCLUDED_CUI_SOURCE_INC_OPTLINGU_HXX #define INCLUDED_CUI_SOURCE_INC_OPTLINGU_HXX +#include <vcl/button.hxx> #include <vcl/fixed.hxx> #include <vcl/toolbox.hxx> #include <vcl/field.hxx> diff --git a/cui/source/options/optaboutconfig.cxx b/cui/source/options/optaboutconfig.cxx index e62d555a1f1c..b7a02eff8287 100644 --- a/cui/source/options/optaboutconfig.cxx +++ b/cui/source/options/optaboutconfig.cxx @@ -10,6 +10,7 @@ #include "optaboutconfig.hxx" #include "optHeaderTabListbox.hxx" +#include <vcl/button.hxx> #include <vcl/event.hxx> #include <vcl/svlbitm.hxx> #include <vcl/treelistentry.hxx> diff --git a/cui/source/options/optaccessibility.hxx b/cui/source/options/optaccessibility.hxx index d451d1969875..5f4dc18206a5 100644 --- a/cui/source/options/optaccessibility.hxx +++ b/cui/source/options/optaccessibility.hxx @@ -20,8 +20,10 @@ #define INCLUDED_CUI_SOURCE_OPTIONS_OPTACCESSIBILITY_HXX #include <sfx2/tabdlg.hxx> +#include <vcl/button.hxx> #include <vcl/fixed.hxx> #include <vcl/field.hxx> + class SvxAccessibilityOptionsTabPage : public SfxTabPage { VclPtr<CheckBox> m_pAccessibilityTool; diff --git a/cui/source/options/optopencl.hxx b/cui/source/options/optopencl.hxx index de289d23341f..dc3a226bb37c 100644 --- a/cui/source/options/optopencl.hxx +++ b/cui/source/options/optopencl.hxx @@ -23,6 +23,7 @@ #include <opencl/openclconfig.hxx> #include <sfx2/tabdlg.hxx> #include <svtools/simptabl.hxx> +#include <vcl/button.hxx> #include <vcl/fixed.hxx> class SvxOpenCLTabPage : public SfxTabPage diff --git a/cui/source/options/optsave.hxx b/cui/source/options/optsave.hxx index 56d88fd5af4a..a6b7579f16f5 100644 --- a/cui/source/options/optsave.hxx +++ b/cui/source/options/optsave.hxx @@ -20,6 +20,7 @@ #define INCLUDED_CUI_SOURCE_OPTIONS_OPTSAVE_HXX #include <memory> +#include <vcl/button.hxx> #include <vcl/field.hxx> #include <vcl/fixed.hxx> #include <vcl/lstbox.hxx> diff --git a/cui/source/options/optupdt.hxx b/cui/source/options/optupdt.hxx index 5e09143ca61a..b9c844fa82a1 100644 --- a/cui/source/options/optupdt.hxx +++ b/cui/source/options/optupdt.hxx @@ -21,6 +21,7 @@ #define INCLUDED_CUI_SOURCE_OPTIONS_OPTUPDT_HXX #include <sfx2/tabdlg.hxx> +#include <vcl/button.hxx> #include <vcl/fixed.hxx> #include <com/sun/star/container/XNameReplace.hpp> #include <com/sun/star/configuration/XReadWriteAccess.hpp> diff --git a/cui/source/options/personalization.cxx b/cui/source/options/personalization.cxx index e9d9380065d1..e7c68fccb495 100644 --- a/cui/source/options/personalization.cxx +++ b/cui/source/options/personalization.cxx @@ -20,6 +20,7 @@ #include <rtl/strbuf.hxx> #include <tools/urlobj.hxx> #include <tools/stream.hxx> +#include <vcl/button.hxx> #include <vcl/event.hxx> #include <vcl/svapp.hxx> #include <vcl/settings.hxx> diff --git a/include/sfx2/tabdlg.hxx b/include/sfx2/tabdlg.hxx index 862dc10a1bcc..77f9125ef8d2 100644 --- a/include/sfx2/tabdlg.hxx +++ b/include/sfx2/tabdlg.hxx @@ -24,9 +24,6 @@ #include <sfx2/dllapi.h> #include <sfx2/basedlgs.hxx> #include <sal/types.h> -#include <vcl/button.hxx> -#include <vcl/tabctrl.hxx> -#include <vcl/tabdlg.hxx> #include <vcl/tabpage.hxx> #include <svl/itempool.hxx> #include <svl/itemset.hxx> diff --git a/sc/source/ui/inc/tpcalc.hxx b/sc/source/ui/inc/tpcalc.hxx index f2a3e33284ac..31d5d6f3c62e 100644 --- a/sc/source/ui/inc/tpcalc.hxx +++ b/sc/source/ui/inc/tpcalc.hxx @@ -21,6 +21,7 @@ #define INCLUDED_SC_SOURCE_UI_INC_TPCALC_HXX #include <sfx2/tabdlg.hxx> +#include <vcl/button.hxx> #include <vcl/fixed.hxx> #include <vcl/field.hxx> #include "editfield.hxx" diff --git a/sc/source/ui/view/tabcont.cxx b/sc/source/ui/view/tabcont.cxx index e4e42e947dcc..4a2739c28fe0 100644 --- a/sc/source/ui/view/tabcont.cxx +++ b/sc/source/ui/view/tabcont.cxx @@ -23,6 +23,7 @@ #include <tools/urlobj.hxx> #include <vcl/commandevent.hxx> #include <vcl/svapp.hxx> +#include <vcl/tabctrl.hxx> #include <tabcont.hxx> #include <tabvwsh.hxx> #include <docsh.hxx> diff --git a/sd/source/ui/dlg/diactrl.cxx b/sd/source/ui/dlg/diactrl.cxx index cc8dd8761501..d05f4f1f16a0 100644 --- a/sd/source/ui/dlg/diactrl.cxx +++ b/sd/source/ui/dlg/diactrl.cxx @@ -18,6 +18,7 @@ */ #include <svl/intitem.hxx> +#include <vcl/toolbox.hxx> #include <strings.hrc> diff --git a/sd/source/ui/dlg/paragr.cxx b/sd/source/ui/dlg/paragr.cxx index 3f874bbe8aaf..a1e631b49254 100644 --- a/sd/source/ui/dlg/paragr.cxx +++ b/sd/source/ui/dlg/paragr.cxx @@ -22,6 +22,7 @@ #include <svl/cjkoptions.hxx> #include <svl/eitem.hxx> #include <svl/intitem.hxx> +#include <vcl/button.hxx> #include <svx/dialogs.hrc> #include <svx/svxids.hrc> diff --git a/svx/source/form/fmshimp.cxx b/svx/source/form/fmshimp.cxx index 18c38e3c4882..6ee16148076a 100644 --- a/svx/source/form/fmshimp.cxx +++ b/svx/source/form/fmshimp.cxx @@ -96,6 +96,7 @@ #include <toolkit/helper/vclunohelper.hxx> #include <tools/debug.hxx> #include <tools/diagnose_ex.h> +#include <vcl/image.hxx> #include <vcl/weld.hxx> #include <vcl/waitobj.hxx> #include <vcl/settings.hxx> diff --git a/sw/source/uibase/uiview/viewprt.cxx b/sw/source/uibase/uiview/viewprt.cxx index 42301529fe8a..3a3bf94abef3 100644 --- a/sw/source/uibase/uiview/viewprt.cxx +++ b/sw/source/uibase/uiview/viewprt.cxx @@ -25,6 +25,7 @@ #include <sfx2/app.hxx> #include <sfx2/viewfrm.hxx> #include <vcl/weld.hxx> +#include <vcl/button.hxx> #include <vcl/oldprintadaptor.hxx> #include <sfx2/printer.hxx> #include <sfx2/prnmon.hxx> commit d6e4c97c8e8ab96ca099dd4f8a3fe35204dea8c1 Author: Caolán McNamara <caol...@redhat.com> AuthorDate: Wed May 29 12:41:16 2019 +0100 Commit: Caolán McNamara <caol...@redhat.com> CommitDate: Fri May 31 10:31:17 2019 +0200 remove newly unused SfxTabDialog Change-Id: Iebbfe2ab66ff6e058c90c85de747f549cbc36aa5 Reviewed-on: https://gerrit.libreoffice.org/73156 Tested-by: Jenkins Reviewed-by: Caolán McNamara <caol...@redhat.com> Tested-by: Caolán McNamara <caol...@redhat.com> diff --git a/cui/source/options/optjava.cxx b/cui/source/options/optjava.cxx index 34f8de7c3f4b..4c2a9d1f2c8c 100644 --- a/cui/source/options/optjava.cxx +++ b/cui/source/options/optjava.cxx @@ -362,7 +362,6 @@ IMPL_LINK_NOARG(SvxJavaOptionsPage, StartFolderPickerHdl, void*, void) } } - IMPL_LINK( SvxJavaOptionsPage, DialogClosedHdl, DialogClosedEvent*, pEvt, void ) { if ( RET_OK == pEvt->DialogResult ) @@ -373,10 +372,9 @@ IMPL_LINK( SvxJavaOptionsPage, DialogClosedHdl, DialogClosedEvent*, pEvt, void ) } } - -IMPL_LINK_NOARG( SvxJavaOptionsPage, ExpertConfigHdl_Impl, Button*, void ) +IMPL_STATIC_LINK( SvxJavaOptionsPage, ExpertConfigHdl_Impl, Button*, pButton, void ) { - ScopedVclPtrInstance< CuiAboutConfigTabPage > pExpertConfigDlg(GetTabDialog()); + ScopedVclPtrInstance< CuiAboutConfigTabPage > pExpertConfigDlg(pButton->GetParentDialog()); pExpertConfigDlg->Reset();//initialize and reset function if( RET_OK == pExpertConfigDlg->Execute() ) @@ -387,7 +385,6 @@ IMPL_LINK_NOARG( SvxJavaOptionsPage, ExpertConfigHdl_Impl, Button*, void ) pExpertConfigDlg.disposeAndClear(); } - void SvxJavaOptionsPage::ClearJavaInfo() { #if HAVE_FEATURE_JAVA diff --git a/cui/source/options/optjava.hxx b/cui/source/options/optjava.hxx index 12de3f8df507..116008567143 100644 --- a/cui/source/options/optjava.hxx +++ b/cui/source/options/optjava.hxx @@ -98,7 +98,7 @@ private: DECL_LINK( StartFolderPickerHdl, void *, void ); DECL_LINK( DialogClosedHdl, css::ui::dialogs::DialogClosedEvent*, void ); - DECL_LINK( ExpertConfigHdl_Impl, Button*, void); + DECL_STATIC_LINK(SvxJavaOptionsPage, ExpertConfigHdl_Impl, Button*, void); void ClearJavaInfo(); void ClearJavaList(); diff --git a/cui/source/tabpages/tparea.cxx b/cui/source/tabpages/tparea.cxx index f3ff007461cf..0ba9dcdeda72 100644 --- a/cui/source/tabpages/tparea.cxx +++ b/cui/source/tabpages/tparea.cxx @@ -393,15 +393,9 @@ void SvxAreaTabPage::SelectFillType(weld::ToggleButton& rButton, const SfxItemSe maBox.SelectButton(&rButton); FillType eFillType = static_cast<FillType>(maBox.GetCurrentButtonPos()); TabPageParent aFillTab(m_xFillTab.get(), GetDialogController()); - // TEMP - if (!aFillTab.pController) - aFillTab.pParent = GetParentDialog(); m_pFillTabPage.disposeAndReset(lcl_CreateFillStyleTabPage(eFillType, aFillTab, m_rXFSet)); if (m_pFillTabPage) - { - m_pFillTabPage->SetTabDialog(GetTabDialog()); m_pFillTabPage->SetDialogController(GetDialogController()); - } CreatePage( eFillType , m_pFillTabPage); } } diff --git a/include/sfx2/tabdlg.hxx b/include/sfx2/tabdlg.hxx index 80cb3faade16..862dc10a1bcc 100644 --- a/include/sfx2/tabdlg.hxx +++ b/include/sfx2/tabdlg.hxx @@ -51,121 +51,6 @@ public: virtual SfxPoolItem* Clone(SfxItemPool* pToPool = nullptr) const override; }; -class SFX2_DLLPUBLIC SfxTabDialog : public TabDialog -{ -private: -friend class SfxTabPage; -friend class SfxTabDialogUIObject; - - VclPtr<VclBox> m_pBox; - VclPtr<TabControl> m_pTabCtrl; - - VclPtr<PushButton> m_pOKBtn; - VclPtr<PushButton> m_pUserBtn; - VclPtr<CancelButton> m_pCancelBtn; - VclPtr<HelpButton> m_pHelpBtn; - VclPtr<PushButton> m_pResetBtn; - VclPtr<PushButton> m_pBaseFmtBtn; - - bool m_bOwnsOKBtn; - bool m_bOwnsCancelBtn; - bool m_bOwnsHelpBtn; - bool m_bOwnsResetBtn; - bool m_bOwnsBaseFmtBtn; - - std::unique_ptr<SfxItemSet> m_pSet; - std::unique_ptr<SfxItemSet> m_pOutSet; - std::unique_ptr< TabDlg_Impl > m_pImpl; - std::unique_ptr<sal_uInt16[]> m_pRanges; - sal_uInt16 m_nAppPageId; - bool m_bStandardPushed; - - DECL_DLLPRIVATE_LINK(ActivatePageHdl, TabControl*, void ); - DECL_DLLPRIVATE_LINK(DeactivatePageHdl, TabControl*, bool ); - DECL_DLLPRIVATE_LINK(OkHdl, Button*, void); - DECL_DLLPRIVATE_LINK(ResetHdl, Button*, void); - DECL_DLLPRIVATE_LINK(BaseFmtHdl, Button*, void); - DECL_DLLPRIVATE_LINK(UserHdl, Button*, void); - DECL_DLLPRIVATE_LINK(CancelHdl, Button*, void); - SAL_DLLPRIVATE void Init_Impl(); - -protected: - virtual short Ok(); - // Is deleted in Sfx! - static SfxItemSet* CreateInputItemSet( sal_uInt16 nId ); - virtual void PageCreated( sal_uInt16 nId, SfxTabPage &rPage ); - - VclPtr<VclButtonBox> m_pActionArea; - SfxItemSet* m_pExampleSet; - SfxItemSet* GetInputSetImpl(); - SfxTabPage* GetTabPage( sal_uInt16 nPageId ) const; - - /** prepare to leave the current page. Calls the DeactivatePage method of the current page, (if necessary), - handles the item sets to copy. - @return sal_True if it is allowed to leave the current page, sal_False otherwise - */ - bool PrepareLeaveCurrentPage(); - - /** save the position of the TabDialog and which tab page is the currently active one - */ - void SavePosAndId(); - - void SetPageName(sal_uInt16 nPageId, const OString& rName) const; -public: - SfxTabDialog(vcl::Window* pParent, - const OUString& rID, const OUString& rUIXMLDescription, - const SfxItemSet * = nullptr); - virtual ~SfxTabDialog() override; - virtual void dispose() override; - - sal_uInt16 AddTabPage( const OString& rName, // Name of the label for the page in the notebook .ui - CreateTabPage pCreateFunc); // != 0 - - void AddTabPage( sal_uInt16 nId, - const OUString &rRiderText, - CreateTabPage pCreateFunc, // != 0 - sal_uInt16 nPos = TAB_APPEND); - - void SetCurPageId(sal_uInt16 nId) - { - m_nAppPageId = nId; - } - sal_uInt16 GetCurPageId() const - { - return m_pTabCtrl->GetCurPageId(); - } - - SfxTabPage* GetCurTabPage() const - { - return GetTabPage(m_pTabCtrl->GetCurPageId()); - } - - virtual OString GetScreenshotId() const override; - - OUString const & GetPageText( sal_uInt16 nPageId ) const - { - return m_pTabCtrl->GetPageText(nPageId); - } - - void ShowPage( sal_uInt16 nId ); - - // may provide local slots converted by Map - const sal_uInt16* GetInputRanges( const SfxItemPool& ); - const SfxItemSet* GetOutputItemSet() const { return m_pOutSet.get(); } - - short Execute() override; - bool StartExecuteAsync( VclAbstractDialog::AsyncContext &rCtx ) override; - - const SfxItemSet* GetExampleSet() const { return m_pExampleSet; } - - SAL_DLLPRIVATE void Start_Impl(); - - virtual FactoryFunction GetUITestFactory() const override; - // Screenshot interface - virtual std::vector<OString> getAllPageUIXMLDescriptions() const override; - virtual bool selectPageByUIXMLDescription(const OString& rUIXMLDescription) override; -}; - class SFX2_DLLPUBLIC SfxTabDialogController : public SfxOkDialogController { protected: @@ -306,10 +191,8 @@ protected: return static_cast<const T*>(GetOldItem(rSet, sal_uInt16(nSlot), bDeep)); } - SfxTabDialog* GetTabDialog() const; SfxOkDialogController* GetDialogController() const; public: - void SetTabDialog(SfxTabDialog* pDialog); void SetDialogController(SfxOkDialogController* pDialog); public: virtual ~SfxTabPage() override; diff --git a/sfx2/Library_sfx.mk b/sfx2/Library_sfx.mk index d4fb4cf6b972..fe6f24c6dd98 100644 --- a/sfx2/Library_sfx.mk +++ b/sfx2/Library_sfx.mk @@ -291,7 +291,6 @@ $(eval $(call gb_Library_add_exception_objects,sfx,\ sfx2/source/statbar/stbitem \ sfx2/source/styles/StyleManager \ sfx2/source/toolbox/tbxitem \ - sfx2/source/uitest/sfx_uiobject \ sfx2/source/view/classificationcontroller \ sfx2/source/view/classificationhelper \ sfx2/source/view/frame \ diff --git a/sfx2/inc/uitest/sfx_uiobject.hxx b/sfx2/inc/uitest/sfx_uiobject.hxx deleted file mode 100644 index b240a2745aa3..000000000000 --- a/sfx2/inc/uitest/sfx_uiobject.hxx +++ /dev/null @@ -1,39 +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/. - */ - -#include <vcl/uitest/uiobject.hxx> -#include <memory> - -class SfxTabDialog; - -class SfxTabDialogUIObject : public WindowUIObject -{ -private: - - VclPtr<SfxTabDialog> mxTabDialog; - -public: - - SfxTabDialogUIObject(const VclPtr<SfxTabDialog>& xTabDialog); - - virtual ~SfxTabDialogUIObject() override; - - virtual StringMap get_state() override; - - virtual void execute(const OUString& rAction, - const StringMap& rParameters) override; - - static std::unique_ptr<UIObject> create(vcl::Window* pWindow); - -protected: - - virtual OUString get_name() const override; -}; - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sfx2/source/dialog/dinfdlg.cxx b/sfx2/source/dialog/dinfdlg.cxx index 02afc0af8452..71612ce19235 100644 --- a/sfx2/source/dialog/dinfdlg.cxx +++ b/sfx2/source/dialog/dinfdlg.cxx @@ -814,7 +814,7 @@ void SfxDocumentPage::ImplUpdateSignatures() try { xD = security::DocumentDigitalSignatures::createDefault(comphelper::getProcessComponentContext()); - xD->setParentWindow(VCLUnoHelper::GetInterface(GetTabDialog())); + xD->setParentWindow(GetDialogController()->getDialog()->GetXWindow()); } catch ( const css::uno::DeploymentException& ) { diff --git a/sfx2/source/dialog/tabdlg.cxx b/sfx2/source/dialog/tabdlg.cxx index 79e2ad750ada..f75b78a1a9f7 100644 --- a/sfx2/source/dialog/tabdlg.cxx +++ b/sfx2/source/dialog/tabdlg.cxx @@ -33,7 +33,6 @@ #include <sfx2/bindings.hxx> #include <sfx2/sfxdlg.hxx> #include <sfx2/viewsh.hxx> -#include <uitest/sfx_uiobject.hxx> #include <unotools/viewoptions.hxx> #include <vcl/builder.hxx> #include <vcl/IDialogRenderable.hxx> @@ -52,7 +51,6 @@ using namespace ::com::sun::star::uno; struct TabPageImpl { bool mbStandard; - VclPtr<SfxTabDialog> mxDialog; SfxOkDialogController* mpDialogController; css::uno::Reference< css::frame::XFrame > mxFrame; @@ -61,7 +59,6 @@ struct TabPageImpl struct Data_Impl { - sal_uInt16 const nId; // The ID OString const sId; // The ID CreateTabPage fnCreatePage; // Pointer to Factory GetTabPageRanges fnGetRanges; // Pointer to Ranges-Function @@ -69,22 +66,15 @@ struct Data_Impl bool bRefresh; // Flag: Page must be re-initialized // Constructor - Data_Impl( sal_uInt16 Id, const OString& rId, CreateTabPage fnPage, + Data_Impl( const OString& rId, CreateTabPage fnPage, GetTabPageRanges fnRanges ) : - nId ( Id ), sId ( rId ), fnCreatePage( fnPage ), fnGetRanges ( fnRanges ), pTabPage ( nullptr ), bRefresh ( false ) { - if ( !fnCreatePage ) - { - SfxAbstractDialogFactory* pFact = SfxAbstractDialogFactory::Create(); - fnCreatePage = pFact->GetTabPageCreatorFunc( nId ); - fnGetRanges = pFact->GetTabPageRangesFunc( nId ); - } } }; @@ -119,25 +109,6 @@ struct TabDlg_Impl } }; - -static Data_Impl* Find( const SfxTabDlgData_Impl& rArr, sal_uInt16 nId, sal_uInt16* pPos = nullptr) -{ - const sal_uInt16 nCount = rArr.size(); - - for ( sal_uInt16 i = 0; i < nCount; ++i ) - { - Data_Impl* pObj = rArr[i]; - - if ( pObj->nId == nId ) - { - if ( pPos ) - *pPos = i; - return pObj; - } - } - return nullptr; -} - static Data_Impl* Find( const SfxTabDlgData_Impl& rArr, const OString& rId, sal_uInt16* pPos = nullptr) { const sal_uInt16 nCount = rArr.size(); @@ -320,16 +291,6 @@ void SfxTabPage::ChangesApplied() { } -void SfxTabPage::SetTabDialog(SfxTabDialog* pDialog) -{ - pImpl->mxDialog = pDialog; -} - -SfxTabDialog* SfxTabPage::GetTabDialog() const -{ - return pImpl->mxDialog; -} - void SfxTabPage::SetDialogController(SfxOkDialogController* pDialog) { pImpl->mpDialogController = pDialog; @@ -361,918 +322,9 @@ const SfxItemSet* SfxTabPage::GetDialogExampleSet() const { if (pImpl->mpDialogController) return pImpl->mpDialogController->GetExampleSet(); - if (pImpl->mxDialog) - return pImpl->mxDialog->GetExampleSet(); - return nullptr; -} - -SfxTabDialog::SfxTabDialog - -/* [Description] - - Constructor, temporary without Frame -*/ - -( - vcl::Window* pParent, // Parent Window - const OUString& rID, const OUString& rUIXMLDescription, //Dialog Name, Dialog .ui path - const SfxItemSet* pItemSet // Itemset with the data; - // can be NULL, when Pages are onDemand -) - : TabDialog(pParent, rID, rUIXMLDescription) - , m_pSet(pItemSet ? new SfxItemSet(*pItemSet) : nullptr) - , m_nAppPageId(USHRT_MAX) - , m_bStandardPushed(false) - , m_pExampleSet(nullptr) -{ - Init_Impl(); - - sal_uInt16 nPageCount = m_pTabCtrl->GetPageCount(); - for (sal_uInt16 nPage = 0; nPage < nPageCount; ++nPage) - { - sal_uInt16 nPageId = m_pTabCtrl->GetPageId(nPage); - m_pTabCtrl->SetTabPage(nPageId, nullptr); - } -} - -SfxTabDialog::~SfxTabDialog() -{ - disposeOnce(); -} - -void SfxTabDialog::dispose() -{ - SavePosAndId(); - - for (auto & elem : m_pImpl->aData) - { - if ( elem->pTabPage ) - { - // save settings of all pages (user data) - elem->pTabPage->FillUserData(); - OUString aPageData( elem->pTabPage->GetUserData() ); - if ( !aPageData.isEmpty() ) - { - // save settings of all pages (user data) - OUString sConfigId = OStringToOUString(elem->pTabPage->GetConfigId(), - RTL_TEXTENCODING_UTF8); - if (sConfigId.isEmpty()) - { - SAL_WARN("sfx.dialog", "Tabpage needs to be converted to .ui format"); - sConfigId = OUString::number(elem->nId); - } - - SvtViewOptions aPageOpt(EViewType::TabPage, sConfigId); - aPageOpt.SetUserItem( USERITEM_NAME, makeAny( aPageData ) ); - } - - elem->pTabPage.disposeAndClear(); - } - delete elem; - elem = nullptr; - } - - m_pImpl.reset(); - m_pSet.reset(); - m_pOutSet.reset(); - delete m_pExampleSet; - m_pExampleSet = nullptr; - m_pRanges.reset(); - - if (m_bOwnsBaseFmtBtn) - m_pBaseFmtBtn.disposeAndClear(); - if (m_bOwnsResetBtn) - m_pResetBtn.disposeAndClear(); - if (m_bOwnsHelpBtn) - m_pHelpBtn.disposeAndClear(); - if (m_bOwnsCancelBtn) - m_pCancelBtn.disposeAndClear(); - if (m_bOwnsOKBtn) - m_pOKBtn.disposeAndClear(); - m_pBox.clear(); - m_pTabCtrl.clear(); - m_pOKBtn.clear(); - m_pUserBtn.clear(); - m_pCancelBtn.clear(); - m_pHelpBtn.clear(); - m_pResetBtn.clear(); - m_pBaseFmtBtn.clear(); - m_pActionArea.clear(); - - TabDialog::dispose(); -} - -void SfxTabDialog::Init_Impl() -/* [Description] - - internal initialization of the dialogue -*/ -{ - m_pBox = get_content_area(); - assert(m_pBox); - m_pUIBuilder->get(m_pTabCtrl, "tabcontrol"); - - m_pImpl.reset( new TabDlg_Impl(m_pTabCtrl->GetPageCount()) ); - - m_pActionArea = get_action_area(); - assert(m_pActionArea); - - m_pOKBtn = m_pUIBuilder->get<PushButton>("ok"); - m_bOwnsOKBtn = m_pOKBtn == nullptr; - if (m_bOwnsOKBtn) - m_pOKBtn = VclPtr<OKButton>::Create(m_pActionArea); - - m_pCancelBtn = m_pUIBuilder->get<CancelButton>("cancel"); - m_bOwnsCancelBtn = m_pCancelBtn == nullptr; - if (m_bOwnsCancelBtn) - m_pCancelBtn = VclPtr<CancelButton>::Create(m_pActionArea); - - m_pHelpBtn = m_pUIBuilder->get<HelpButton>("help"); - m_bOwnsHelpBtn = m_pHelpBtn == nullptr; - if (m_bOwnsHelpBtn) - m_pHelpBtn = VclPtr<HelpButton>::Create(m_pActionArea); - - m_pResetBtn = m_pUIBuilder->get<PushButton>("reset"); - m_bOwnsResetBtn = m_pResetBtn == nullptr; - if (m_bOwnsResetBtn) - { - m_pResetBtn = VclPtr<PushButton>::Create(m_pActionArea.get()); - m_pResetBtn->set_id("reset"); - } - else - m_pImpl->bHideResetBtn = !m_pResetBtn->IsVisible(); - - m_pBaseFmtBtn = m_pUIBuilder->get<PushButton>("standard"); - m_bOwnsBaseFmtBtn = m_pBaseFmtBtn == nullptr; - if (m_bOwnsBaseFmtBtn) - { - m_pBaseFmtBtn = VclPtr<PushButton>::Create(m_pActionArea.get()); - m_pBaseFmtBtn->set_id("standard"); - } - - m_pOKBtn->SetClickHdl( LINK( this, SfxTabDialog, OkHdl ) ); - m_pCancelBtn->SetClickHdl( LINK( this, SfxTabDialog, CancelHdl ) ); - m_pResetBtn->SetClickHdl( LINK( this, SfxTabDialog, ResetHdl ) ); - m_pResetBtn->SetText( SfxResId( STR_RESET ) ); - m_pTabCtrl->SetActivatePageHdl( - LINK( this, SfxTabDialog, ActivatePageHdl ) ); - m_pTabCtrl->SetDeactivatePageHdl( - LINK( this, SfxTabDialog, DeactivatePageHdl ) ); - m_pActionArea->Show(); - m_pBox->Show(); - m_pTabCtrl->Show(); - m_pOKBtn->Show(); - m_pCancelBtn->Show(); - m_pHelpBtn->Show(); - m_pResetBtn->Show(); - m_pResetBtn->SetHelpId( HID_TABDLG_RESET_BTN ); - - if ( m_pUserBtn ) - { - m_pUserBtn->SetClickHdl( LINK( this, SfxTabDialog, UserHdl ) ); - m_pUserBtn->Show(); - } - - if ( m_pSet ) - { - m_pExampleSet = new SfxItemSet( *m_pSet ); - m_pOutSet.reset(new SfxItemSet( *m_pSet->GetPool(), m_pSet->GetRanges() )); - } -} - -short SfxTabDialog::Execute() -{ - if ( !m_pTabCtrl->GetPageCount() ) - return RET_CANCEL; - Start_Impl(); - - return TabDialog::Execute(); -} - -bool SfxTabDialog::StartExecuteAsync( VclAbstractDialog::AsyncContext &rCtx ) -{ - if ( !m_pTabCtrl->GetPageCount() ) - { - rCtx.mxOwner.disposeAndClear(); - return false; - } - Start_Impl(); - return TabDialog::StartExecuteAsync( rCtx ); -} - -void SfxTabDialog::Start_Impl() -{ - assert(m_pImpl->aData.size() == m_pTabCtrl->GetPageCount() - && "not all pages registered"); - sal_uInt16 nActPage = m_pTabCtrl->GetPageId( 0 ); - - // load old settings, when exists - SvtViewOptions aDlgOpt(EViewType::TabDialog, OStringToOUString(GetHelpId(),RTL_TEXTENCODING_UTF8)); - if ( aDlgOpt.Exists() ) - { - SetWindowState(OUStringToOString(aDlgOpt.GetWindowState(), RTL_TEXTENCODING_ASCII_US)); - - // initial TabPage from Program/Help/config - nActPage = m_pTabCtrl->GetPageId(aDlgOpt.GetPageID()); - - if ( USHRT_MAX != m_nAppPageId ) - nActPage = m_nAppPageId; - - if ( TAB_PAGE_NOTFOUND == m_pTabCtrl->GetPagePos( nActPage ) ) - nActPage = m_pTabCtrl->GetPageId( 0 ); - } - else if ( USHRT_MAX != m_nAppPageId && TAB_PAGE_NOTFOUND != m_pTabCtrl->GetPagePos( m_nAppPageId ) ) - nActPage = m_nAppPageId; - - m_pTabCtrl->SetCurPageId( nActPage ); - ActivatePageHdl( m_pTabCtrl ); -} - -/* - Adds a page to the dialog. The Name must correspond to a entry in the - TabControl in the dialog .ui -*/ -sal_uInt16 SfxTabDialog::AddTabPage -( - const OString &rName, // Page ID - CreateTabPage pCreateFunc // Pointer to the Factory Method -) -{ - sal_uInt16 nId = m_pTabCtrl->GetPageId(rName); - m_pImpl->aData.push_back(new Data_Impl(nId, rName, pCreateFunc, nullptr)); - return nId; -} - -void SfxTabDialog::AddTabPage - -/* [Description] - - Add a page to the dialog. The Rider text is passed on, the page has no - counterpart in the TabControl in the resource of the dialogue. -*/ - -( - sal_uInt16 nId, - const OUString& rRiderText, - CreateTabPage pCreateFunc, - sal_uInt16 nPos -) -{ - DBG_ASSERT( TAB_PAGE_NOTFOUND == m_pTabCtrl->GetPagePos( nId ), - "Double Page-Ids in the Tabpage" ); - m_pTabCtrl->InsertPage( nId, rRiderText, nPos ); - m_pImpl->aData.push_back( new Data_Impl(nId, "", pCreateFunc, nullptr ) ); -} - -void SfxTabDialog::PageCreated - -/* [Description] - - Default implementation of the virtual method. This is called immediately - after creating a page. Here the dialogue can call the TabPage Method - directly. -*/ - -( - sal_uInt16, // Id of the created page - SfxTabPage& // Reference to the created page -) -{ -} - - -SfxItemSet* SfxTabDialog::GetInputSetImpl() - -/* [Description] - - Derived classes may create new storage for the InputSet. This has to be - released in the Destructor. To do this, this method must be called. -*/ - -{ - return m_pSet.get(); -} - - -SfxTabPage* SfxTabDialog::GetTabPage( sal_uInt16 nPageId ) const - -/* [Description] - - Return TabPage with the specified Id. -*/ - -{ - sal_uInt16 nPos = 0; - Data_Impl* pDataObject = Find( m_pImpl->aData, nPageId, &nPos ); - - if ( pDataObject ) - return pDataObject->pTabPage; return nullptr; } -void SfxTabDialog::SavePosAndId() -{ - // save settings (screen position and current page) - SvtViewOptions aDlgOpt(EViewType::TabDialog, OStringToOUString(GetHelpId(),RTL_TEXTENCODING_UTF8)); - aDlgOpt.SetWindowState(OStringToOUString(GetWindowState(WindowStateMask::Pos),RTL_TEXTENCODING_ASCII_US)); - // to-do replace with name of page when all pages are converted to .ui - aDlgOpt.SetPageID(m_pTabCtrl->GetPageName(m_pTabCtrl->GetCurPageId())); -} - - -short SfxTabDialog::Ok() - -/* [Description] - - Ok handler for the Dialogue. - - Dialog's current location and current page are saved for the next time - the dialog is shown. - - The OutputSet is created and for each page this or the special OutputSet - is set by calling the method <SfxTabPage::FillItemSet(SfxItemSet &)>, to - insert the entered data by the user into the set. - - [Return value] - - RET_OK: if at least one page has returned from FillItemSet, - otherwise RET_CANCEL. -*/ -{ - SavePosAndId(); //See fdo#38828 "Apply" resetting window position - - if ( !m_pOutSet ) - { - if ( m_pExampleSet ) - m_pOutSet.reset(new SfxItemSet( *m_pExampleSet )); - else if ( m_pSet ) - m_pOutSet = m_pSet->Clone( false ); // without Items - } - bool bModified = false; - - for (auto const& elem : m_pImpl->aData) - { - SfxTabPage* pTabPage = elem->pTabPage; - - if ( pTabPage ) - { - if ( m_pSet && !pTabPage->HasExchangeSupport() ) - { - SfxItemSet aTmp( *m_pSet->GetPool(), m_pSet->GetRanges() ); - - if ( pTabPage->FillItemSet( &aTmp ) ) - { - bModified = true; - if (m_pExampleSet) - m_pExampleSet->Put( aTmp ); - m_pOutSet->Put( aTmp ); - } - } - } - } - - if ( m_pOutSet && m_pOutSet->Count() > 0 ) - bModified = true; - - if (m_bStandardPushed) - bModified = true; - return bModified ? RET_OK : RET_CANCEL; -} - -IMPL_LINK_NOARG(SfxTabDialog, CancelHdl, Button*, void) -{ - EndDialog( RET_USER_CANCEL ); -} - - -SfxItemSet* SfxTabDialog::CreateInputItemSet( sal_uInt16 ) - -/* [Description] - - Default implementation of the virtual Method. - This is called when pages create their sets onDemand. -*/ - -{ - SAL_WARN( "sfx.dialog", "CreateInputItemSet not implemented" ); - return new SfxAllItemSet( SfxGetpApp()->GetPool() ); -} - - -IMPL_LINK_NOARG(SfxTabDialog, OkHdl, Button*, void) - -/* [Description] - - Handler of the Ok-Buttons - This calls the current page <SfxTabPage::DeactivatePage(SfxItemSet *)>. - Returns <DeactivateRC::LeavePage>, <SfxTabDialog::Ok()> is called - and the Dialog is ended. -*/ - -{ - if (PrepareLeaveCurrentPage()) - { - if ( m_pImpl->bModal ) - EndDialog( Ok() ); - else - { - Ok(); - Close(); - } - } -} - -bool SfxTabDialog::PrepareLeaveCurrentPage() -{ - sal_uInt16 const nId = m_pTabCtrl->GetCurPageId(); - SfxTabPage* pPage = dynamic_cast<SfxTabPage*> (m_pTabCtrl->GetTabPage( nId )); - bool bEnd = !pPage; - - if ( pPage ) - { - DeactivateRC nRet = DeactivateRC::LeavePage; - if ( m_pSet ) - { - SfxItemSet aTmp( *m_pSet->GetPool(), m_pSet->GetRanges() ); - - if ( pPage->HasExchangeSupport() ) - nRet = pPage->DeactivatePage( &aTmp ); - else - nRet = pPage->DeactivatePage( nullptr ); - - if ( ( DeactivateRC::LeavePage & nRet ) == DeactivateRC::LeavePage - && aTmp.Count() ) - { - m_pExampleSet->Put( aTmp ); - m_pOutSet->Put( aTmp ); - } - } - else - nRet = pPage->DeactivatePage( nullptr ); - bEnd = nRet != DeactivateRC::KeepPage; - } - - return bEnd; -} - - -IMPL_LINK_NOARG(SfxTabDialog, UserHdl, Button*, void) - -/* [Description] - - Handler of the User-Buttons - This calls the current page <SfxTabPage::DeactivatePage(SfxItemSet *)>. - returns this <DeactivateRC::LeavePage> and <SfxTabDialog::Ok()> is called. - Then the Dialog is ended with the Return value <SfxTabDialog::Ok()> -*/ - -{ - if ( PrepareLeaveCurrentPage () ) - { - short nRet = Ok(); - - if ( RET_OK == nRet ) - nRet = RET_USER; - else - nRet = RET_USER_CANCEL; - EndDialog( nRet ); - } -} - - -IMPL_LINK_NOARG(SfxTabDialog, ResetHdl, Button*, void) - -/* [Description] - - Handler behind the reset button. - The Current Page is new initialized with their initial data, all the - settings that the user has made on this page are repealed. -*/ - -{ - const sal_uInt16 nId = m_pTabCtrl->GetCurPageId(); - Data_Impl* pDataObject = Find( m_pImpl->aData, nId ); - DBG_ASSERT( pDataObject, "Id not known" ); - - pDataObject->pTabPage->Reset( m_pSet.get() ); - // Also reset relevant items of ExampleSet and OutSet to initial state - if (!pDataObject->fnGetRanges) - return; - - if (!m_pExampleSet) - m_pExampleSet = new SfxItemSet(*m_pSet); - - const SfxItemPool* pPool = m_pSet->GetPool(); - const sal_uInt16* pTmpRanges = (pDataObject->fnGetRanges)(); - - while (*pTmpRanges) - { - const sal_uInt16* pU = pTmpRanges + 1; - - // Correct Range with multiple values - sal_uInt16 nTmp = *pTmpRanges, nTmpEnd = *pU; - DBG_ASSERT(nTmp <= nTmpEnd, "Range is sorted the wrong way"); - - if (nTmp > nTmpEnd) - { - // If really sorted wrongly, then set new - std::swap(nTmp, nTmpEnd); - } - - while (nTmp && nTmp <= nTmpEnd) - { - // Iterate over the Range and set the Items - sal_uInt16 nWh = pPool->GetWhich(nTmp); - const SfxPoolItem* pItem; - if (SfxItemState::SET == m_pSet->GetItemState(nWh, false, &pItem)) - { - m_pExampleSet->Put(*pItem); - m_pOutSet->Put(*pItem); - } - else - { - m_pExampleSet->ClearItem(nWh); - m_pOutSet->ClearItem(nWh); - } - nTmp++; - } - // Go to the next pair - pTmpRanges += 2; - } -} - - -IMPL_LINK_NOARG(SfxTabDialog, BaseFmtHdl, Button*, void) - -/* [Description] - - Handler behind the Standard-Button. - This button is available when editing style sheets. All the set attributes - in the edited stylesheet are deleted. -*/ - -{ - m_bStandardPushed = true; - - const sal_uInt16 nId = m_pTabCtrl->GetCurPageId(); - Data_Impl* pDataObject = Find( m_pImpl->aData, nId ); - DBG_ASSERT( pDataObject, "Id not known" ); - - if ( !pDataObject->fnGetRanges ) - return; - - if ( !m_pExampleSet ) - m_pExampleSet = new SfxItemSet( *m_pSet ); - - const SfxItemPool* pPool = m_pSet->GetPool(); - const sal_uInt16* pTmpRanges = (pDataObject->fnGetRanges)(); - SfxItemSet aTmpSet( *m_pExampleSet ); - - while ( *pTmpRanges ) - { - const sal_uInt16* pU = pTmpRanges + 1; - - // Correct Range with multiple values - sal_uInt16 nTmp = *pTmpRanges, nTmpEnd = *pU; - DBG_ASSERT( nTmp <= nTmpEnd, "Range is sorted the wrong way" ); - - if ( nTmp > nTmpEnd ) - { - // If really sorted wrongly, then set new - std::swap(nTmp, nTmpEnd); - } - - while ( nTmp && nTmp <= nTmpEnd ) // guard against overflow - { - // Iterate over the Range and set the Items - sal_uInt16 nWh = pPool->GetWhich( nTmp ); - m_pExampleSet->ClearItem( nWh ); - aTmpSet.ClearItem( nWh ); - // At the Outset of InvalidateItem, - // so that the change takes effect - m_pOutSet->InvalidateItem( nWh ); - nTmp++; - } - // Go to the next pair - pTmpRanges += 2; - } - // Set all Items as new -> the call the current Page Reset() - DBG_ASSERT( pDataObject->pTabPage, "the Page is gone" ); - pDataObject->pTabPage->Reset( &aTmpSet ); - pDataObject->pTabPage->pImpl->mbStandard = true; -} - - -IMPL_LINK( SfxTabDialog, ActivatePageHdl, TabControl *, pTabCtrl, void ) - -/* [Description] - - Handler that is called by StarView for switching to a different page. - If the page not exist yet then it is created and the virtual Method - <SfxTabDialog::PageCreated( sal_uInt16, SfxTabPage &)> is called. If the page - exist, then the if possible the <SfxTabPage::Reset(const SfxItemSet &)> or - <SfxTabPage::ActivatePage(const SfxItemSet &)> is called. -*/ - -{ - sal_uInt16 nId = pTabCtrl->GetCurPageId(); - - DBG_ASSERT( m_pImpl->aData.size(), "no Pages registered" ); - - // Tab Page already there? - VclPtr<SfxTabPage> pTabPage = dynamic_cast<SfxTabPage*> (pTabCtrl->GetTabPage( nId )); - Data_Impl* pDataObject = Find( m_pImpl->aData, nId ); - - // fallback to 1st page when requested one does not exist - if(!pDataObject && pTabCtrl->GetPageCount()) - { - pTabCtrl->SetCurPageId(pTabCtrl->GetPageId(0)); - nId = pTabCtrl->GetCurPageId(); - pTabPage = dynamic_cast< SfxTabPage* >(pTabCtrl->GetTabPage(nId)); - pDataObject = Find(m_pImpl->aData, nId); - } - - if (!pDataObject) - { - SAL_WARN("sfx.dialog", "Tab Page ID not known, this is pretty serious and needs investigation"); - return; - } - - // Create TabPage if possible: - if ( !pTabPage ) - { - if ( m_pSet ) - pTabPage = (pDataObject->fnCreatePage)(static_cast<vcl::Window*>(pTabCtrl), m_pSet.get()); - else - pTabPage = (pDataObject->fnCreatePage)(pTabCtrl, CreateInputItemSet(nId)); - DBG_ASSERT( nullptr == pDataObject->pTabPage, "create TabPage more than once" ); - pDataObject->pTabPage = pTabPage; - pTabPage->SetTabDialog(this); - - OUString sConfigId = OStringToOUString(pTabPage->GetConfigId(), RTL_TEXTENCODING_UTF8); - if (sConfigId.isEmpty()) - { - SAL_WARN("sfx.dialog", "Tabpage needs to be converted to .ui format"); - sConfigId = OUString::number(pDataObject->nId); - } - SvtViewOptions aPageOpt(EViewType::TabPage, sConfigId); - OUString sUserData; - Any aUserItem = aPageOpt.GetUserItem( USERITEM_NAME ); - OUString aTemp; - if ( aUserItem >>= aTemp ) - sUserData = aTemp; - pTabPage->SetUserData( sUserData ); - Size aSiz = pTabPage->GetSizePixel(); - - Size aCtrlSiz = pTabCtrl->GetTabPageSizePixel(); - // Only set Size on TabControl when < as TabPage - if ( aCtrlSiz.Width() < aSiz.Width() || - aCtrlSiz.Height() < aSiz.Height() ) - { - pTabCtrl->SetTabPageSizePixel( aSiz ); - } - - PageCreated( nId, *pTabPage ); - - pTabPage->Reset( m_pSet.get() ); - - pTabCtrl->SetTabPage( nId, pTabPage ); - } - else if ( pDataObject->bRefresh ) - pTabPage->Reset( m_pSet.get() ); - pDataObject->bRefresh = false; - - if ( m_pExampleSet ) - pTabPage->ActivatePage( *m_pExampleSet ); - - if ( pTabPage->IsReadOnly() || m_pImpl->bHideResetBtn ) - m_pResetBtn->Hide(); - else - m_pResetBtn->Show(); -} - - -IMPL_LINK( SfxTabDialog, DeactivatePageHdl, TabControl *, pTabCtrl, bool ) - -/* [Description] - - Handler that is called by StarView before leaving a page. - - [Cross-reference] - - <SfxTabPage::DeactivatePage(SfxItemSet *)> -*/ - -{ - sal_uInt16 nId = pTabCtrl->GetCurPageId(); - SfxTabPage *pPage = dynamic_cast<SfxTabPage*> (pTabCtrl->GetTabPage( nId )); - DBG_ASSERT( pPage, "no active Page" ); - if (!pPage) - return false; -#ifdef DBG_UTIL - Data_Impl* pDataObject = Find( m_pImpl->aData, pTabCtrl->GetCurPageId() ); - DBG_ASSERT( pDataObject, "no Data structure for current page" ); -#endif - - DeactivateRC nRet = DeactivateRC::LeavePage; - - if ( !m_pExampleSet && pPage->HasExchangeSupport() && m_pSet ) - m_pExampleSet = new SfxItemSet( *m_pSet->GetPool(), m_pSet->GetRanges() ); - - if ( m_pSet ) - { - SfxItemSet aTmp( *m_pSet->GetPool(), m_pSet->GetRanges() ); - - if ( pPage->HasExchangeSupport() ) - nRet = pPage->DeactivatePage( &aTmp ); - else - nRet = pPage->DeactivatePage( nullptr ); - if ( ( DeactivateRC::LeavePage & nRet ) == DeactivateRC::LeavePage && - aTmp.Count() && m_pExampleSet) - { - m_pExampleSet->Put( aTmp ); - m_pOutSet->Put( aTmp ); - } - } - else - { - if ( pPage->HasExchangeSupport() ) //!!! - { - if ( !m_pExampleSet ) - { - SfxItemPool* pPool = pPage->GetItemSet().GetPool(); - m_pExampleSet = - new SfxItemSet( *pPool, GetInputRanges( *pPool ) ); - } - nRet = pPage->DeactivatePage( m_pExampleSet ); - } - else - nRet = pPage->DeactivatePage( nullptr ); - } - - if ( nRet & DeactivateRC::RefreshSet ) - { - // Flag all Pages as to be initialized as new - - for (auto const& elem : m_pImpl->aData) - { - elem->bRefresh = ( elem->pTabPage.get() != pPage ); // Do not refresh own Page anymore - } - } - return static_cast<bool>(nRet & DeactivateRC::LeavePage); -} - - -void SfxTabDialog::ShowPage( sal_uInt16 nId ) - -/* [Description] - - The TabPage is activated with the specified Id. -*/ - -{ - m_pTabCtrl->SetCurPageId( nId ); - ActivatePageHdl( m_pTabCtrl ); -} - -OString SfxTabDialog::GetScreenshotId() const -{ - SfxTabPage *pActiveTabPage = GetCurTabPage(); - OString aScreenshotId = GetHelpId(); - - if ( pActiveTabPage ) - { - vcl::Window* pToplevelBox = pActiveTabPage->GetWindow( GetWindowType::FirstChild ); - - if ( pToplevelBox ) - aScreenshotId = pToplevelBox->GetHelpId(); - } - - return aScreenshotId; -} - -const sal_uInt16* SfxTabDialog::GetInputRanges( const SfxItemPool& rPool ) - -/* [Description] - - Makes the set over the range of all pages of the dialogue. Pages have the - static method for querying their range in AddTabPage, ie deliver their - sets onDemand. - - [Return value] - - Pointer to a null-terminated array of sal_uInt16. This array belongs to the - dialog and is deleted when the dialogue is destroy. - - [Cross-reference] - - <SfxTabDialog::AddTabPage(sal_uInt16, CreateTabPage, GetTabPageRanges, bool)> - <SfxTabDialog::AddTabPage(sal_uInt16, const String &, CreateTabPage, GetTabPageRanges, bool, sal_uInt16)> - <SfxTabDialog::AddTabPage(sal_uInt16, const Bitmap &, CreateTabPage, GetTabPageRanges, bool, sal_uInt16)> -*/ - -{ - if ( m_pSet ) - { - SAL_WARN( "sfx.dialog", "Set already exists!" ); - return m_pSet->GetRanges(); - } - - if ( m_pRanges ) - return m_pRanges.get(); - std::vector<sal_uInt16> aUS; - - for (auto const& elem : m_pImpl->aData) - { - - if ( elem->fnGetRanges ) - { - const sal_uInt16* pTmpRanges = (elem->fnGetRanges)(); - const sal_uInt16* pIter = pTmpRanges; - - sal_uInt16 nLen; - for( nLen = 0; *pIter; ++nLen, ++pIter ) - ; - aUS.insert( aUS.end(), pTmpRanges, pTmpRanges + nLen ); - } - } - - //! Remove duplicated Ids? - { - for (auto & elem : aUS) - elem = rPool.GetWhich(elem); - } - - // sort - if ( aUS.size() > 1 ) - { - std::sort( aUS.begin(), aUS.end() ); - } - - m_pRanges.reset(new sal_uInt16[aUS.size() + 1]); - std::copy( aUS.begin(), aUS.end(), m_pRanges.get() ); - m_pRanges[aUS.size()] = 0; - return m_pRanges.get(); -} - -void SfxTabDialog::SetPageName(sal_uInt16 nPageId, const OString& rName) const -{ - m_pTabCtrl->SetPageName(nPageId, rName); -} - -FactoryFunction SfxTabDialog::GetUITestFactory() const -{ - return SfxTabDialogUIObject::create; -} - -std::vector<OString> SfxTabDialog::getAllPageUIXMLDescriptions() const -{ - std::vector<OString> aRetval; - - for (auto const& elem : m_pImpl->aData) - { - SfxTabPage* pCandidate = GetTabPage(elem->nId); - - if (!pCandidate) - { - // force SfxTabPage creation - const_cast<SfxTabDialog*>(this)->ShowPage(elem->nId); - pCandidate = GetTabPage(elem->nId); - } - - if (pCandidate) - { - // use UIXMLDescription (without '.ui', with '/') - aRetval.push_back(pCandidate->getUIFile()); - } - } - - return aRetval; -} - -bool SfxTabDialog::selectPageByUIXMLDescription(const OString& rUIXMLDescription) -{ - for (auto const& elem : m_pImpl->aData) - { - SfxTabPage* pCandidate = elem->pTabPage; - - if (!pCandidate) - { - // force SfxTabPage creation - ShowPage(elem->nId); - pCandidate = GetTabPage(elem->nId); - } - - if (pCandidate && pCandidate->getUIFile() == rUIXMLDescription) - { - ShowPage(elem->nId); - return true; - } - } - - return false; -} - SfxTabDialogController::SfxTabDialogController ( weld::Window* pParent, // Parent Window @@ -1817,7 +869,7 @@ void SfxTabDialogController::AddTabPage(const OString &rName /* Page ID */, CreateTabPage pCreateFunc /* Pointer to the Factory Method */, GetTabPageRanges pRangesFunc /* Pointer to the Method for querying Ranges onDemand */) { - m_pImpl->aData.push_back(new Data_Impl(m_pImpl->aData.size(), rName, pCreateFunc, pRangesFunc)); + m_pImpl->aData.push_back(new Data_Impl(rName, pCreateFunc, pRangesFunc)); } void SfxTabDialogController::AddTabPage(const OString &rName /* Page ID */, diff --git a/sfx2/source/uitest/sfx_uiobject.cxx b/sfx2/source/uitest/sfx_uiobject.cxx deleted file mode 100644 index 5a56b4168e18..000000000000 --- a/sfx2/source/uitest/sfx_uiobject.cxx +++ /dev/null @@ -1,87 +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/. - */ - -#include <memory> -#include <uitest/sfx_uiobject.hxx> - -#include <sfx2/tabdlg.hxx> - -SfxTabDialogUIObject::SfxTabDialogUIObject(const VclPtr<SfxTabDialog>& xTabDialog): - WindowUIObject(xTabDialog), - mxTabDialog(xTabDialog) -{ -} - -SfxTabDialogUIObject::~SfxTabDialogUIObject() -{ -} - -StringMap SfxTabDialogUIObject::get_state() -{ - StringMap aMap = WindowUIObject::get_state(); - sal_uInt16 nPageId = mxTabDialog->GetCurPageId(); - std::vector<sal_uInt16> aPageIds = mxTabDialog->m_pTabCtrl->GetPageIDs(); - OUString aStrIds; - OUString aStrNames; - for (auto const& pageId : aPageIds) - { - aStrIds = aStrIds + OUString::number(pageId) + ";"; - aStrNames = aStrNames + mxTabDialog->GetPageText(pageId) + ";"; - } - - aMap["PageIds"] = aStrIds; - aMap["PageNames"] = aStrNames; - aMap["CurrentPageID"] = OUString::number(nPageId); - aMap["CurrentPageText"] = mxTabDialog->GetPageText(nPageId); - return aMap; -} - -void SfxTabDialogUIObject::execute(const OUString& rAction, - const StringMap& rParameters) -{ - if (rAction != "SELECT") - return; - - if (rParameters.find("POS") != rParameters.end()) - { - auto itr = rParameters.find("POS"); - sal_uInt32 nPos = itr->second.toUInt32(); - std::vector<sal_uInt16> aIds = mxTabDialog->m_pTabCtrl->GetPageIDs(); - sal_uInt16 nPageId = aIds[nPos]; - mxTabDialog->ShowPage(nPageId); - } - else if (rParameters.find("NAME") != rParameters.end()) - { - auto itr = rParameters.find("NAME"); - OUString aName = itr->second; - std::vector<sal_uInt16> aIds = mxTabDialog->m_pTabCtrl->GetPageIDs(); - for (auto const& elem : aIds) - { - if (mxTabDialog->GetPageText(elem) == aName) - { - mxTabDialog->ShowPage(elem); - break; - } - } - } -} - -std::unique_ptr<UIObject> SfxTabDialogUIObject::create(vcl::Window* pWindow) -{ - SfxTabDialog* pDialog = dynamic_cast<SfxTabDialog*>(pWindow); - assert(pDialog); - return std::unique_ptr<UIObject>(new SfxTabDialogUIObject(pDialog)); -} - -OUString SfxTabDialogUIObject::get_name() const -{ - return OUString("SfxTabDialogUIObject"); -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ _______________________________________________ Libreoffice-commits mailing list libreoffice-comm...@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits