/************************************************************************* * * $RCSfile: Time.cxx,v $ * * $Revision: 1.15 $ * * last change: $Author: hr $ $Date: 2004-05-10 12:47:21 $ * * 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 #endif #ifndef _TOOLS_TIME_HXX #include #endif #ifndef _COMPHELPER_DATETIME_HXX_ #include #endif #ifndef _DBHELPER_DBCONVERSION_HXX_ #include #endif #ifndef _COM_SUN_STAR_SDBC_DATATYPE_HPP_ #include #endif using namespace dbtools; //......................................................................... namespace frm { //......................................................................... 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; using namespace ::com::sun::star::awt; using namespace ::com::sun::star::io; using namespace ::com::sun::star::lang; //================================================================== //= //================================================================== //================================================================== //= OTimeControl //================================================================== //------------------------------------------------------------------ OTimeControl::OTimeControl(const Reference& _rxFactory) :OBoundControl(_rxFactory, VCL_CONTROL_TIMEFIELD) { } //------------------------------------------------------------------ InterfaceRef SAL_CALL OTimeControl_CreateInstance(const Reference& _rxFactory) { return *(new OTimeControl(_rxFactory)); } //------------------------------------------------------------------------------ Sequence OTimeControl::_getTypes() { 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 //================================================================== //------------------------------------------------------------------ InterfaceRef SAL_CALL OTimeModel_CreateInstance(const Reference& _rxFactory) { return *(new OTimeModel(_rxFactory)); } // XServiceInfo //------------------------------------------------------------------------------ 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; return aSupported; } //------------------------------------------------------------------------------ Sequence OTimeModel::_getTypes() { return OBoundControlModel::_getTypes(); } //------------------------------------------------------------------ DBG_NAME( OTimeModel ) //------------------------------------------------------------------ OTimeModel::OTimeModel(const Reference& _rxFactory) :OEditBaseModel( _rxFactory, VCL_CONTROLMODEL_TIMEFIELD, FRM_SUN_CONTROL_TIMEFIELD, sal_False, sal_True ) // use the old control name for compytibility reasons ,OLimitedFormats(_rxFactory, FormComponentType::TIMEFIELD) { DBG_CTOR( OTimeModel, NULL ); m_nClassId = FormComponentType::TIMEFIELD; initValueProperty( PROPERTY_TIME, PROPERTY_ID_TIME ); setAggregateSet(m_xAggregateFastSet, getOriginalHandle(PROPERTY_ID_TIMEFORMAT)); } //------------------------------------------------------------------------------ OTimeModel::OTimeModel( const OTimeModel* _pOriginal, const Reference& _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 ); } // XCloneable //------------------------------------------------------------------------------ IMPLEMENT_DEFAULT_CLONING( OTimeModel ) //------------------------------------------------------------------------------ ::rtl::OUString SAL_CALL OTimeModel::getServiceName() throw ( ::com::sun::star::uno::RuntimeException) { return FRM_COMPONENT_TIMEFIELD; // old (non-sun) name for compatibility ! } // XPropertySet //------------------------------------------------------------------------------ Reference SAL_CALL OTimeModel::getPropertySetInfo() throw( RuntimeException ) { Reference xInfo( createPropertySetInfo( getInfoHelper() ) ); return xInfo; } //------------------------------------------------------------------------------ void OTimeModel::fillProperties( Sequence< Property >& _rProps, Sequence< Property >& _rAggregateProps ) const { BEGIN_DESCRIBE_PROPERTIES( 4, OEditBaseModel ) DECL_PROP3(DEFAULT_TIME, sal_Int32, BOUND, MAYBEDEFAULT, MAYBEVOID); DECL_PROP1(TABINDEX, sal_Int16, BOUND); DECL_PROP1(FORMATKEY, sal_Int32, TRANSIENT); DECL_IFACE_PROP2(FORMATSSUPPLIER, XNumberFormatsSupplier, READONLY, TRANSIENT); END_DESCRIBE_PROPERTIES(); } //------------------------------------------------------------------------------ ::cppu::IPropertyArrayHelper& OTimeModel::getInfoHelper() { return *const_cast(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 ); } //------------------------------------------------------------------------------ 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); } // XLoadListener //------------------------------------------------------------------------------ void OTimeModel::onConnectedDbColumn( const Reference< XInterface >& _rxForm ) { OBoundControlModel::onConnectedDbColumn( _rxForm ); Reference xField = getField(); if (xField.is()) { m_bDateTimeField = sal_False; try { sal_Int32 nFieldType; xField->getPropertyValue(PROPERTY_FIELDTYPE) >>= nFieldType; m_bDateTimeField = (nFieldType == DataType::TIMESTAMP); } catch(Exception&) { } } } //------------------------------------------------------------------------------ sal_Bool OTimeModel::commitControlValueToDbColumn( bool _bPostReset ) { Any aControlValue( m_xAggregateFastSet->getFastPropertyValue( getValuePropertyAggHandle() ) ); if ( !compare( aControlValue, m_aSaveValue ) ) { if ( !aControlValue.hasValue() ) m_xColumnUpdate->updateNull(); else { try { starutil::Time aTime; if ( !( aControlValue >>= aTime ) ) { sal_Int32 nAsInt(0); aControlValue >>= nAsInt; aTime = DBTypeConversion::toTime(nAsInt); } 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); } } catch(Exception&) { return sal_False; } } m_aSaveValue = aControlValue; } 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; } //------------------------------------------------------------------------------ Any OTimeModel::translateDbColumnToControlValue() { starutil::Time aTime = m_xColumn->getTime(); if ( m_xColumn->wasNull() ) m_aSaveValue.clear(); else // the aggregated set expects an Int32 as value ... m_aSaveValue <<= DBTypeConversion::toINT32( aTime ); return m_aSaveValue; } //------------------------------------------------------------------------------ Any OTimeModel::getDefaultForReset() const { Any aValue; if (m_aDefault.getValueType().getTypeClass() == TypeClass_LONG) aValue = m_aDefault; else { // aktuelles Datum einstellen ::Time aCurrentTime; aValue <<= (sal_Int32)aCurrentTime.GetTime(); } return aValue; } //......................................................................... } // namespace frm //.........................................................................