/* -*- 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 .
*/
// OGenericAdministrationPage class IDatabaseSettingsDialog; class IItemSetHelper; class OGenericAdministrationPage :public SfxTabPage
,public ::vcl::IWizardPageController
{ private:
Link<OGenericAdministrationPage const *, void> m_aModifiedHandler; /// to be called if something on the page has been modified bool m_abEnableRoadmap; protected:
IDatabaseSettingsDialog* m_pAdminDialog;
IItemSetHelper* m_pItemSetHelper;
css::uno::Reference< css::uno::XComponentContext >
m_xORB; public:
OGenericAdministrationPage(weld::Container* pPage, weld::DialogController* pController, const OUString& rUIXMLDescription, const OUString& rId, const SfxItemSet& rAttrSet); /// set a handler which gets called every time something on the page has been modified void SetModifiedHandler(const Link<OGenericAdministrationPage const *, void>& _rHandler) { m_aModifiedHandler = _rHandler; }
/** Sets the ParentDialog @param _pAdminDialog the ParentDialog @param _pItemSetHelper the itemset helper
*/ void SetAdminDialog(IDatabaseSettingsDialog* _pDialog,IItemSetHelper* _pItemSetHelper)
{
OSL_ENSURE(_pDialog && _pItemSetHelper,"Values are NULL!");
m_pAdminDialog = _pDialog;
m_pItemSetHelper = _pItemSetHelper;
}
/** Sets the ServiceFactory @param _rxORB The service factory.
*/ void SetServiceFactory(const css::uno::Reference< css::uno::XComponentContext >& rxORB)
{
m_xORB = rxORB;
}
/** opens a dialog filled with all data sources available for this type and returns the selected on. @param _eType The type for which the data source dialog should be opened. @param _sReturn <OUT/> contains the selected name. @return <FALSE/> if an error occurred, otherwise <TRUE/>
*/ bool getSelectedDataSource(OUString& _sReturn, OUString const & _sCurr);
/// called from within DeactivatePage. The page is allowed to be deactivated if this method returns sal_True virtualbool prepareLeave() { returntrue; }
/** called from within Reset and ActivatePage, use to initialize the controls with the items from the given set @param _bSaveValue if set to sal_True, the implementation should call SaveValue on all relevant controls
*/ virtualvoid implInitControls(const SfxItemSet& _rSet, bool _bSaveValue);
/// analyze the invalid and the readonly flag which may be present in the set staticvoid getFlags(const SfxItemSet& _rSet, bool& _rValid, bool& _rReadonly);
/** will be called inside <method>implInitControls</method> to save the value if necessary @param _rControlList The list must be filled with the controls. It is not allowed to clear the list before pushing data into it.
*/ virtualvoid fillControls(std::vector< std::unique_ptr<ISaveValueWrapper> >& _rControlList) = 0;
/** will be called inside <method>implInitControls</method> to disable if necessary @param _rControlList The list must be filled with the controls. It is not allowed to clear the list before pushing data into it.
*/ virtualvoid fillWindows(std::vector< std::unique_ptr<ISaveValueWrapper> >& _rControlList) = 0;
public: /** fills the Boolean value into the item set when the value changed. @param _rSet The item set where to put the new value into. @param _pCheckBox The check box which is checked. @param _nID The id in the itemset to set with the new value. @param _bChangedSomething <TRUE/> if something changed otherwise <FALSE/> @param _bRevertValue set to <TRUE/> if the display value should be reverted before putting it into the set
*/ staticvoid fillBool(SfxItemSet& _rSet, const weld::CheckButton* pCheckBox, sal_uInt16 _nID, bool bOptionalBool, bool& _bChangedSomething, bool _bRevertValue = false);
/** fills the int value into the item set when the value changed. @param _rSet The item set where to put the new value into. @param _pEdit The check box which is checked. @param _nID The id in the itemset to set with the new value. @param _bChangedSomething <TRUE/> if something changed otherwise <FALSE/>
*/ staticvoid fillInt32(SfxItemSet& _rSet,const weld::SpinButton* pEdit,TypedWhichId<SfxInt32Item> _nID, bool& _bChangedSomething);
/** fills the String value into the item set when the value changed. @param _rSet The item set where to put the new value into. @param _pEdit The check box which is checked. @param _nID The id in the itemset to set with the new value. @param _bChangedSomething <TRUE/> if something changed otherwise <FALSE/>
*/ staticvoid fillString(SfxItemSet& _rSet,const weld::Entry* pEdit, TypedWhichId<SfxStringItem> _nID, bool& _bChangedSomething); staticvoid fillString(SfxItemSet& _rSet,const dbaui::OConnectionURLEdit* pEdit, TypedWhichId<SfxStringItem> _nID, bool& _bChangedSomething);
protected: /** This link be used for controls where the tabpage does not need to take any special action when the control is modified. The implementation just calls callModifiedHdl.
*/
DECL_LINK(OnControlModified, weld::Widget*, void);
DECL_LINK(OnControlEntryModifyHdl, weld::Entry&, void);
DECL_LINK(OnControlSpinButtonModifyHdl, weld::SpinButton&, void);
DECL_LINK(OnControlModifiedButtonClick, weld::Toggleable&, void);
DECL_LINK(OnTestConnectionButtonClickHdl, weld::Button&, void);
};
} // namespace dbaui
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.