Files
libreoffice/forms/source/component/Time.cxx

389 lines
14 KiB
C++
Raw Normal View History

2000-09-18 15:33:13 +00:00
/*************************************************************************
*
* $RCSfile: Time.cxx,v $
*
* $Revision: 1.15 $
2000-09-18 15:33:13 +00:00
*
* last change: $Author: hr $ $Date: 2004-05-10 12:47:21 $
2000-09-18 15:33:13 +00:00
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License version 2.1, as published by the Free Software Foundation.
*
* This library 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 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston,
* MA 02111-1307 USA
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (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.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
#ifndef _FORMS_TIME_HXX_
#include "Time.hxx"
#endif
#ifndef _TOOLS_DEBUG_HXX
#include <tools/debug.hxx>
#endif
#ifndef _TOOLS_TIME_HXX
#include <tools/time.hxx>
#endif
2000-10-19 10:52:20 +00:00
#ifndef _COMPHELPER_DATETIME_HXX_
#include <comphelper/datetime.hxx>
2000-09-18 15:33:13 +00:00
#endif
2000-10-19 10:52:20 +00:00
#ifndef _DBHELPER_DBCONVERSION_HXX_
#include <connectivity/dbconversion.hxx>
2000-09-18 15:33:13 +00:00
#endif
#ifndef _COM_SUN_STAR_SDBC_DATATYPE_HPP_
#include <com/sun/star/sdbc/DataType.hpp>
#endif
2000-10-19 10:52:20 +00:00
using namespace dbtools;
2000-09-18 15:33:13 +00:00
//.........................................................................
namespace frm
{
//.........................................................................
2000-11-23 07:48:15 +00:00
using namespace ::com::sun::star::uno;
using namespace ::com::sun::star::sdb;
using namespace ::com::sun::star::sdbc;
using namespace ::com::sun::star::sdbcx;
using namespace ::com::sun::star::beans;
using namespace ::com::sun::star::container;
using namespace ::com::sun::star::form;
using namespace ::com::sun::star::util;
2000-11-23 07:48:15 +00:00
using namespace ::com::sun::star::awt;
using namespace ::com::sun::star::io;
using namespace ::com::sun::star::lang;
2000-09-18 15:33:13 +00:00
//==================================================================
//=
//==================================================================
2000-09-18 15:33:13 +00:00
//==================================================================
//= OTimeControl
//==================================================================
//------------------------------------------------------------------
2000-11-23 07:48:15 +00:00
OTimeControl::OTimeControl(const Reference<XMultiServiceFactory>& _rxFactory)
2000-09-18 15:33:13 +00:00
:OBoundControl(_rxFactory, VCL_CONTROL_TIMEFIELD)
{
}
//------------------------------------------------------------------
2000-11-23 07:48:15 +00:00
InterfaceRef SAL_CALL OTimeControl_CreateInstance(const Reference<XMultiServiceFactory>& _rxFactory)
2000-09-18 15:33:13 +00:00
{
return *(new OTimeControl(_rxFactory));
}
//------------------------------------------------------------------------------
2000-11-23 07:48:15 +00:00
Sequence<Type> OTimeControl::_getTypes()
2000-09-18 15:33:13 +00:00
{
return OBoundControl::_getTypes();
}
//------------------------------------------------------------------------------
StringSequence SAL_CALL OTimeControl::getSupportedServiceNames() throw()
{
StringSequence aSupported = OBoundControl::getSupportedServiceNames();
aSupported.realloc(aSupported.getLength() + 1);
::rtl::OUString*pArray = aSupported.getArray();
pArray[aSupported.getLength()-1] = FRM_SUN_CONTROL_TIMEFIELD;
return aSupported;
}
//==================================================================
//= OTimeModel
//==================================================================
//------------------------------------------------------------------
2000-11-23 07:48:15 +00:00
InterfaceRef SAL_CALL OTimeModel_CreateInstance(const Reference<XMultiServiceFactory>& _rxFactory)
2000-09-18 15:33:13 +00:00
{
return *(new OTimeModel(_rxFactory));
}
2000-11-23 07:48:15 +00:00
// XServiceInfo
2000-09-18 15:33:13 +00:00
//------------------------------------------------------------------------------
StringSequence SAL_CALL OTimeModel::getSupportedServiceNames() throw()
{
StringSequence aSupported = OBoundControlModel::getSupportedServiceNames();
sal_Int32 nOldLen = aSupported.getLength();
aSupported.realloc( nOldLen + 4 );
::rtl::OUString* pStoreTo = aSupported.getArray() + nOldLen;
*pStoreTo++ = DATA_AWARE_CONTROL_MODEL;
*pStoreTo++ = VALIDATABLE_CONTROL_MODEL;
*pStoreTo++ = FRM_SUN_COMPONENT_TIMEFIELD;
*pStoreTo++ = FRM_SUN_COMPONENT_DATABASE_TIMEFIELD;
2000-09-18 15:33:13 +00:00
return aSupported;
}
//------------------------------------------------------------------------------
2000-11-23 07:48:15 +00:00
Sequence<Type> OTimeModel::_getTypes()
2000-09-18 15:33:13 +00:00
{
return OBoundControlModel::_getTypes();
}
//------------------------------------------------------------------
DBG_NAME( OTimeModel )
2000-09-18 15:33:13 +00:00
//------------------------------------------------------------------
2000-11-23 07:48:15 +00:00
OTimeModel::OTimeModel(const Reference<XMultiServiceFactory>& _rxFactory)
:OEditBaseModel( _rxFactory, VCL_CONTROLMODEL_TIMEFIELD, FRM_SUN_CONTROL_TIMEFIELD, sal_False, sal_True )
2000-09-18 15:33:13 +00:00
// use the old control name for compytibility reasons
,OLimitedFormats(_rxFactory, FormComponentType::TIMEFIELD)
2000-09-18 15:33:13 +00:00
{
DBG_CTOR( OTimeModel, NULL );
2000-11-23 07:48:15 +00:00
m_nClassId = FormComponentType::TIMEFIELD;
initValueProperty( PROPERTY_TIME, PROPERTY_ID_TIME );
setAggregateSet(m_xAggregateFastSet, getOriginalHandle(PROPERTY_ID_TIMEFORMAT));
}
//------------------------------------------------------------------------------
OTimeModel::OTimeModel( const OTimeModel* _pOriginal, const Reference<XMultiServiceFactory>& _rxFactory )
:OEditBaseModel( _pOriginal, _rxFactory )
,OLimitedFormats( _rxFactory, FormComponentType::TIMEFIELD )
{
DBG_CTOR( OTimeModel, NULL );
setAggregateSet( m_xAggregateFastSet, getOriginalHandle( PROPERTY_ID_TIMEFORMAT ) );
}
//------------------------------------------------------------------------------
OTimeModel::~OTimeModel( )
{
setAggregateSet(Reference< XFastPropertySet >(), -1);
DBG_DTOR( OTimeModel, NULL );
2000-09-18 15:33:13 +00:00
}
// XCloneable
//------------------------------------------------------------------------------
IMPLEMENT_DEFAULT_CLONING( OTimeModel )
2000-09-18 15:33:13 +00:00
//------------------------------------------------------------------------------
2001-09-12 16:54:29 +00:00
::rtl::OUString SAL_CALL OTimeModel::getServiceName() throw ( ::com::sun::star::uno::RuntimeException)
2000-09-18 15:33:13 +00:00
{
return FRM_COMPONENT_TIMEFIELD; // old (non-sun) name for compatibility !
}
2000-11-23 07:48:15 +00:00
// XPropertySet
2000-09-18 15:33:13 +00:00
//------------------------------------------------------------------------------
2000-11-23 07:48:15 +00:00
Reference<XPropertySetInfo> SAL_CALL OTimeModel::getPropertySetInfo() throw( RuntimeException )
2000-09-18 15:33:13 +00:00
{
2000-11-23 07:48:15 +00:00
Reference<XPropertySetInfo> xInfo( createPropertySetInfo( getInfoHelper() ) );
2000-09-18 15:33:13 +00:00
return xInfo;
}
//------------------------------------------------------------------------------
void OTimeModel::fillProperties(
2000-11-23 07:48:15 +00:00
Sequence< Property >& _rProps,
Sequence< Property >& _rAggregateProps ) const
2000-09-18 15:33:13 +00:00
{
BEGIN_DESCRIBE_PROPERTIES( 4, OEditBaseModel )
DECL_PROP3(DEFAULT_TIME, sal_Int32, BOUND, MAYBEDEFAULT, MAYBEVOID);
DECL_PROP1(TABINDEX, sal_Int16, BOUND);
2001-05-18 13:46:18 +00:00
DECL_PROP1(FORMATKEY, sal_Int32, TRANSIENT);
DECL_IFACE_PROP2(FORMATSSUPPLIER, XNumberFormatsSupplier, READONLY, TRANSIENT);
END_DESCRIBE_PROPERTIES();
2000-09-18 15:33:13 +00:00
}
//------------------------------------------------------------------------------
::cppu::IPropertyArrayHelper& OTimeModel::getInfoHelper()
{
return *const_cast<OTimeModel*>(this)->getArrayHelper();
}
//------------------------------------------------------------------------------
void SAL_CALL OTimeModel::getFastPropertyValue(Any& _rValue, sal_Int32 _nHandle ) const
{
switch (_nHandle)
{
case PROPERTY_ID_FORMATKEY:
getFormatKeyPropertyValue(_rValue);
break;
case PROPERTY_ID_FORMATSSUPPLIER:
_rValue <<= getFormatsSupplier();
break;
default:
OEditBaseModel::getFastPropertyValue(_rValue, _nHandle);
break;
}
}
//------------------------------------------------------------------------------
sal_Bool SAL_CALL OTimeModel::convertFastPropertyValue(Any& _rConvertedValue, Any& _rOldValue,
sal_Int32 _nHandle, const Any& _rValue ) throw(IllegalArgumentException)
{
if (PROPERTY_ID_FORMATKEY == _nHandle)
return convertFormatKeyPropertyValue(_rConvertedValue, _rOldValue, _rValue);
else
return OEditBaseModel::convertFastPropertyValue(_rConvertedValue, _rOldValue, _nHandle, _rValue );
}
//------------------------------------------------------------------------------
2001-09-12 16:54:29 +00:00
void SAL_CALL OTimeModel::setFastPropertyValue_NoBroadcast(sal_Int32 _nHandle, const Any& _rValue) throw ( ::com::sun::star::uno::Exception)
{
if (PROPERTY_ID_FORMATKEY == _nHandle)
setFormatKeyPropertyValue(_rValue);
else
OEditBaseModel::setFastPropertyValue_NoBroadcast(_nHandle, _rValue);
}
2000-11-23 07:48:15 +00:00
// XLoadListener
2000-09-18 15:33:13 +00:00
//------------------------------------------------------------------------------
void OTimeModel::onConnectedDbColumn( const Reference< XInterface >& _rxForm )
2000-09-18 15:33:13 +00:00
{
OBoundControlModel::onConnectedDbColumn( _rxForm );
Reference<XPropertySet> xField = getField();
if (xField.is())
2000-09-18 15:33:13 +00:00
{
m_bDateTimeField = sal_False;
try
{
sal_Int32 nFieldType;
xField->getPropertyValue(PROPERTY_FIELDTYPE) >>= nFieldType;
2000-11-23 07:48:15 +00:00
m_bDateTimeField = (nFieldType == DataType::TIMESTAMP);
2000-09-18 15:33:13 +00:00
}
2000-11-23 07:48:15 +00:00
catch(Exception&)
2000-09-18 15:33:13 +00:00
{
}
}
}
//------------------------------------------------------------------------------
sal_Bool OTimeModel::commitControlValueToDbColumn( bool _bPostReset )
2000-09-18 15:33:13 +00:00
{
Any aControlValue( m_xAggregateFastSet->getFastPropertyValue( getValuePropertyAggHandle() ) );
if ( !compare( aControlValue, m_aSaveValue ) )
2000-09-18 15:33:13 +00:00
{
if ( !aControlValue.hasValue() )
2000-09-18 15:33:13 +00:00
m_xColumnUpdate->updateNull();
else
{
try
{
starutil::Time aTime;
if ( !( aControlValue >>= aTime ) )
2000-09-18 15:33:13 +00:00
{
sal_Int32 nAsInt(0);
aControlValue >>= nAsInt;
2000-10-19 10:52:20 +00:00
aTime = DBTypeConversion::toTime(nAsInt);
2000-09-18 15:33:13 +00:00
}
if (!m_bDateTimeField)
m_xColumnUpdate->updateTime(aTime);
else
{
starutil::DateTime aDateTime = m_xColumn->getTimestamp();
aDateTime.HundredthSeconds = aTime.HundredthSeconds;
aDateTime.Seconds = aTime.Seconds;
aDateTime.Minutes = aTime.Minutes;
aDateTime.Hours = aTime.Hours;
m_xColumnUpdate->updateTimestamp(aDateTime);
}
}
2000-11-23 07:48:15 +00:00
catch(Exception&)
2000-09-18 15:33:13 +00:00
{
return sal_False;
}
}
m_aSaveValue = aControlValue;
2000-09-18 15:33:13 +00:00
}
return sal_True;
}
//------------------------------------------------------------------------------
Any OTimeModel::translateControlValueToValidatableValue( ) const
{
Any aValidatableValue( getControlValue() );
if ( aValidatableValue.hasValue() )
{
sal_Int32 nTime = 0;
OSL_ENSURE( aValidatableValue >>= nTime, "OTimeModel::translateControlValueToValidatableValue: invalid time!" );
if ( nTime == ::Time( 99, 99, 99 ).GetTime() )
// "invalid time" in VCL is different from "invalid time" in UNO
aValidatableValue <<= ::com::sun::star::util::Time( -1, -1, -1, -1 );
else
aValidatableValue <<= DBTypeConversion::toTime( nTime );
}
return aValidatableValue;
}
2000-09-18 15:33:13 +00:00
//------------------------------------------------------------------------------
Any OTimeModel::translateDbColumnToControlValue()
2000-09-18 15:33:13 +00:00
{
starutil::Time aTime = m_xColumn->getTime();
if ( m_xColumn->wasNull() )
2000-09-18 15:33:13 +00:00
m_aSaveValue.clear();
else
// the aggregated set expects an Int32 as value ...
m_aSaveValue <<= DBTypeConversion::toINT32( aTime );
return m_aSaveValue;
2000-09-18 15:33:13 +00:00
}
//------------------------------------------------------------------------------
Any OTimeModel::getDefaultForReset() const
2000-09-18 15:33:13 +00:00
{
2000-11-23 07:48:15 +00:00
Any aValue;
if (m_aDefault.getValueType().getTypeClass() == TypeClass_LONG)
2000-09-18 15:33:13 +00:00
aValue = m_aDefault;
else
{ // aktuelles Datum einstellen
::Time aCurrentTime;
2000-10-19 10:52:20 +00:00
aValue <<= (sal_Int32)aCurrentTime.GetTime();
2000-09-18 15:33:13 +00:00
}
return aValue;
2000-09-18 15:33:13 +00:00
}
//.........................................................................
} // namespace frm
//.........................................................................