2000-09-18 16:07:07 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-11 00:35:25 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2008-04-11 00:35:25 +00:00
|
|
|
* Copyright 2008 by Sun Microsystems, Inc.
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2008-04-11 00:35:25 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2008-04-11 00:35:25 +00:00
|
|
|
* $RCSfile: fmpgeimp.hxx,v $
|
2008-08-19 08:49:39 +00:00
|
|
|
* $Revision: 1.19 $
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2008-04-11 00:35:25 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2008-04-11 00:35:25 +00:00
|
|
|
* OpenOffice.org is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License version 3
|
|
|
|
* only, as published by the Free Software Foundation.
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2008-04-11 00:35:25 +00:00
|
|
|
* OpenOffice.org is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU Lesser General Public License version 3 for more details
|
|
|
|
* (a copy is included in the LICENSE file that accompanied this code).
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
2008-04-11 00:35:25 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2000-09-18 16:07:07 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
#ifndef _SVX_FMUNOPGE_HXX
|
|
|
|
#define _SVX_FMUNOPGE_HXX
|
|
|
|
|
2000-11-15 13:55:12 +00:00
|
|
|
#include <com/sun/star/sdbc/XDataSource.hpp>
|
2000-09-18 16:07:07 +00:00
|
|
|
#include <com/sun/star/container/XNameAccess.hpp>
|
|
|
|
#include <com/sun/star/form/XFormComponent.hpp>
|
|
|
|
#include <com/sun/star/form/XForm.hpp>
|
|
|
|
#include <com/sun/star/container/XNameContainer.hpp>
|
|
|
|
#include <com/sun/star/frame/XModel.hpp>
|
2002-05-28 14:52:37 +00:00
|
|
|
#include <com/sun/star/lang/XServiceInfo.hpp>
|
2000-09-18 16:07:07 +00:00
|
|
|
|
|
|
|
#include <tools/list.hxx>
|
2008-05-05 14:46:00 +00:00
|
|
|
#include <tools/link.hxx>
|
2000-10-20 13:13:45 +00:00
|
|
|
#include <comphelper/uno3.hxx>
|
2000-09-18 16:07:07 +00:00
|
|
|
|
2008-05-05 14:46:00 +00:00
|
|
|
#include "svx/svxdllapi.h"
|
2005-03-18 09:01:44 +00:00
|
|
|
|
2000-09-18 16:07:07 +00:00
|
|
|
class SvStream;
|
|
|
|
class FmFormObj;
|
2005-06-14 15:33:47 +00:00
|
|
|
class FmFormPage;
|
2000-09-18 16:07:07 +00:00
|
|
|
class SdrObject;
|
|
|
|
|
|
|
|
//FORWARD_DECLARE_INTERFACE(uno,Reference)
|
|
|
|
FORWARD_DECLARE_INTERFACE(io,XObjectOutputStream)
|
|
|
|
FORWARD_DECLARE_INTERFACE(io,XObjectInputStream)
|
|
|
|
FORWARD_DECLARE_INTERFACE(container,XIndexContainer)
|
|
|
|
|
|
|
|
class SdrObjList;
|
|
|
|
|
2006-06-19 15:05:55 +00:00
|
|
|
DECLARE_LIST(FmObjectList, FmFormObj*)
|
2000-09-18 16:07:07 +00:00
|
|
|
|
|
|
|
//==================================================================
|
|
|
|
// FmFormPageImpl
|
|
|
|
// lauscht an allen Containern, um festzustellen, wann Objecte
|
|
|
|
// eingefuegt worden sind und wann diese entfernt wurden
|
|
|
|
//==================================================================
|
|
|
|
|
2005-03-18 09:01:44 +00:00
|
|
|
class SVX_DLLPRIVATE FmFormPageImpl
|
2000-09-18 16:07:07 +00:00
|
|
|
{
|
2005-03-18 17:43:38 +00:00
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::form::XForm> xCurrentForm;
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::container::XNameContainer> m_xForms;
|
2008-05-05 14:46:00 +00:00
|
|
|
FmFormPage* pPage;
|
|
|
|
Link m_aFormsCreationHdl;
|
2000-09-18 16:07:07 +00:00
|
|
|
|
2008-08-19 08:49:39 +00:00
|
|
|
sal_Bool m_bFirstActivation;
|
|
|
|
bool m_bAttemptedFormCreation;
|
2002-09-09 13:27:00 +00:00
|
|
|
|
2000-09-18 16:07:07 +00:00
|
|
|
protected:
|
2008-12-01 12:31:27 +00:00
|
|
|
void Init();
|
|
|
|
|
|
|
|
public:
|
2000-09-18 16:07:07 +00:00
|
|
|
FmFormPageImpl(FmFormPage* _pPage);
|
|
|
|
FmFormPageImpl(FmFormPage* _pPage, const FmFormPageImpl& rImpl);
|
|
|
|
~FmFormPageImpl();
|
|
|
|
|
|
|
|
// nur wichtig fuer den DesignMode
|
|
|
|
void setCurForm(::com::sun::star::uno::Reference< ::com::sun::star::form::XForm> xForm);
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::form::XForm> getDefaultForm();
|
|
|
|
|
2008-12-01 12:31:27 +00:00
|
|
|
/** finds a place in the form component hierarchy where to insert the given component
|
2005-03-18 09:01:44 +00:00
|
|
|
|
2008-12-01 12:31:27 +00:00
|
|
|
Note that no actual insertion happens, this is the responsibility of the caller (as
|
|
|
|
the caller might decide on a suitable place where in the returned container the insertion
|
|
|
|
should happen).
|
2005-03-18 09:01:44 +00:00
|
|
|
*/
|
2008-12-01 12:31:27 +00:00
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::form::XForm> findPlaceInFormComponentHierarchy(
|
2005-03-18 09:01:44 +00:00
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::form::XFormComponent>& rContent,
|
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDataSource>& rDatabase = ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDataSource>(),
|
|
|
|
const ::rtl::OUString& rDBTitle = ::rtl::OUString(),
|
|
|
|
const ::rtl::OUString& rCursorSource = ::rtl::OUString(),
|
|
|
|
sal_Int32 nCommandType = 0
|
|
|
|
);
|
2000-09-18 16:07:07 +00:00
|
|
|
|
2002-09-09 13:27:00 +00:00
|
|
|
// activation handling
|
|
|
|
inline sal_Bool hasEverBeenActivated( ) const { return !m_bFirstActivation; }
|
|
|
|
inline void setHasBeenActivated( ) { m_bFirstActivation = sal_False; }
|
|
|
|
|
2008-12-01 12:31:27 +00:00
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::container::XNameContainer>& getForms( bool _bForceCreate = true );
|
|
|
|
|
2008-05-05 14:46:00 +00:00
|
|
|
void SetFormsCreationHdl( const Link& _rFormsCreationHdl ) { m_aFormsCreationHdl = _rFormsCreationHdl; }
|
|
|
|
const Link& GetFormsCreationHdl() const { return m_aFormsCreationHdl; }
|
|
|
|
|
2000-09-18 16:07:07 +00:00
|
|
|
protected:
|
2005-03-18 09:01:44 +00:00
|
|
|
/** finds a form with a given data source signature
|
|
|
|
@param rForm
|
|
|
|
the form to start the search with. This form, including all possible sub forms,
|
|
|
|
will be examined
|
|
|
|
@param rDatabase
|
|
|
|
the data source which to which the found form must be bound
|
|
|
|
@param rCommand
|
|
|
|
the desired Command property value of the sought-after form
|
|
|
|
@param nCommandType
|
|
|
|
the desired CommandType property value of the sought-after form
|
|
|
|
*/
|
|
|
|
::com::sun::star::uno::Reference< ::com::sun::star::form::XForm> findFormForDataSource(
|
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::form::XForm>& rForm,
|
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::sdbc::XDataSource>& rDatabase,
|
|
|
|
const ::rtl::OUString& rCommand,
|
|
|
|
sal_Int32 nCommandType
|
|
|
|
);
|
2000-09-18 16:07:07 +00:00
|
|
|
|
2002-05-28 14:52:37 +00:00
|
|
|
::rtl::OUString getDefaultName(
|
|
|
|
sal_Int16 _nClassId,
|
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::form::XForm>& _rxControls,
|
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XServiceInfo >& _rxObject
|
|
|
|
) const;
|
2000-09-18 16:07:07 +00:00
|
|
|
|
2005-02-17 09:58:06 +00:00
|
|
|
private:
|
|
|
|
/** validates whether <member>xCurrentForm</member> is still valid and to be used
|
|
|
|
|
|
|
|
There are situations where our current form becomes invalid, without us noticing this. Thus,
|
|
|
|
every method which accesses <member>xCurrentForm</member> should beforehand validate the current
|
|
|
|
form by calling this method.
|
|
|
|
|
|
|
|
If <member>xCurrentForm</member> is not valid anymore, it is reset to <NULL/>.
|
|
|
|
|
2008-12-01 12:31:27 +00:00
|
|
|
@return
|
|
|
|
<TRUE/> if and only if xCurrentForm is valid.
|
|
|
|
|
2005-02-17 09:58:06 +00:00
|
|
|
@since #i40086#
|
|
|
|
*/
|
2008-12-01 12:31:27 +00:00
|
|
|
bool validateCurForm();
|
2005-02-17 09:58:06 +00:00
|
|
|
|
2000-09-18 16:07:07 +00:00
|
|
|
public:
|
|
|
|
|
2002-05-28 14:52:37 +00:00
|
|
|
static UniString getDefaultName(
|
|
|
|
sal_Int16 nClassId,
|
|
|
|
const ::com::sun::star::uno::Reference< ::com::sun::star::lang::XServiceInfo >& _rxObject
|
|
|
|
);
|
2000-09-18 16:07:07 +00:00
|
|
|
|
|
|
|
::rtl::OUString setUniqueName(const ::com::sun::star::uno::Reference< ::com::sun::star::form::XFormComponent>& xFormComponent, const ::com::sun::star::uno::Reference< ::com::sun::star::form::XForm>& xControls);
|
|
|
|
::rtl::OUString getUniqueName(const ::rtl::OUString& rName, const ::com::sun::star::uno::Reference< ::com::sun::star::container::XNameAccess>& xNamedSet) const;
|
2008-08-19 08:49:39 +00:00
|
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
FmFormPageImpl(); // never implemented
|
|
|
|
FmFormPageImpl( const FmFormPageImpl& ); // never implemented
|
|
|
|
FmFormPageImpl& operator=( const FmFormPageImpl& ); // never implemented
|
2000-09-18 16:07:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#endif // _SVX_FMUNOPGE_HXX
|
|
|
|
|