1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 29*cdf0e10cSrcweir #include "precompiled_xmloff.hxx" 30*cdf0e10cSrcweir #include "officeforms.hxx" 31*cdf0e10cSrcweir #include <xmloff/xmluconv.hxx> 32*cdf0e10cSrcweir #include <xmloff/xmltoken.hxx> 33*cdf0e10cSrcweir #include "xmloff/xmlnmspe.hxx" 34*cdf0e10cSrcweir #include <xmloff/xmlexp.hxx> 35*cdf0e10cSrcweir #include <xmloff/xmlimp.hxx> 36*cdf0e10cSrcweir #include <xmloff/nmspmap.hxx> 37*cdf0e10cSrcweir #include <comphelper/extract.hxx> 38*cdf0e10cSrcweir #include "strings.hxx" 39*cdf0e10cSrcweir #include <rtl/logfile.hxx> 40*cdf0e10cSrcweir 41*cdf0e10cSrcweir //......................................................................... 42*cdf0e10cSrcweir namespace xmloff 43*cdf0e10cSrcweir { 44*cdf0e10cSrcweir //......................................................................... 45*cdf0e10cSrcweir 46*cdf0e10cSrcweir using namespace ::com::sun::star::uno; 47*cdf0e10cSrcweir using namespace ::com::sun::star::beans; 48*cdf0e10cSrcweir using namespace ::com::sun::star::frame; 49*cdf0e10cSrcweir using namespace ::com::sun::star::xml; 50*cdf0e10cSrcweir using ::xmloff::token::XML_FORMS; 51*cdf0e10cSrcweir 52*cdf0e10cSrcweir //========================================================================= 53*cdf0e10cSrcweir //= OFormsRootImport 54*cdf0e10cSrcweir //========================================================================= 55*cdf0e10cSrcweir TYPEINIT1(OFormsRootImport, SvXMLImportContext); 56*cdf0e10cSrcweir //------------------------------------------------------------------------- 57*cdf0e10cSrcweir OFormsRootImport::OFormsRootImport( SvXMLImport& rImport, sal_uInt16 nPrfx, const rtl::OUString& rLocalName ) 58*cdf0e10cSrcweir :SvXMLImportContext(rImport, nPrfx, rLocalName) 59*cdf0e10cSrcweir { 60*cdf0e10cSrcweir } 61*cdf0e10cSrcweir 62*cdf0e10cSrcweir //------------------------------------------------------------------------- 63*cdf0e10cSrcweir OFormsRootImport::~OFormsRootImport() 64*cdf0e10cSrcweir { 65*cdf0e10cSrcweir } 66*cdf0e10cSrcweir 67*cdf0e10cSrcweir //------------------------------------------------------------------------- 68*cdf0e10cSrcweir SvXMLImportContext* OFormsRootImport::CreateChildContext( sal_uInt16 _nPrefix, const ::rtl::OUString& _rLocalName, 69*cdf0e10cSrcweir const Reference< sax::XAttributeList>& xAttrList ) 70*cdf0e10cSrcweir { 71*cdf0e10cSrcweir return GetImport().GetFormImport()->createContext( _nPrefix, _rLocalName, xAttrList ); 72*cdf0e10cSrcweir } 73*cdf0e10cSrcweir 74*cdf0e10cSrcweir //------------------------------------------------------------------------- 75*cdf0e10cSrcweir void OFormsRootImport::implImportBool(const Reference< sax::XAttributeList >& _rxAttributes, OfficeFormsAttributes _eAttribute, 76*cdf0e10cSrcweir const Reference< XPropertySet >& _rxProps, const Reference< XPropertySetInfo >& _rxPropInfo, 77*cdf0e10cSrcweir const ::rtl::OUString& _rPropName, sal_Bool _bDefault) 78*cdf0e10cSrcweir { 79*cdf0e10cSrcweir // the complete attribute name to look for 80*cdf0e10cSrcweir ::rtl::OUString sCompleteAttributeName = GetImport().GetNamespaceMap().GetQNameByIndex( 81*cdf0e10cSrcweir OAttributeMetaData::getOfficeFormsAttributeNamespace(_eAttribute), 82*cdf0e10cSrcweir ::rtl::OUString::createFromAscii(OAttributeMetaData::getOfficeFormsAttributeName(_eAttribute))); 83*cdf0e10cSrcweir 84*cdf0e10cSrcweir // get and convert the value 85*cdf0e10cSrcweir ::rtl::OUString sAttributeValue = _rxAttributes->getValueByName(sCompleteAttributeName); 86*cdf0e10cSrcweir sal_Bool bValue = _bDefault; 87*cdf0e10cSrcweir GetImport().GetMM100UnitConverter().convertBool(bValue, sAttributeValue); 88*cdf0e10cSrcweir 89*cdf0e10cSrcweir // set the property 90*cdf0e10cSrcweir if (_rxPropInfo->hasPropertyByName(_rPropName)) 91*cdf0e10cSrcweir _rxProps->setPropertyValue(_rPropName, ::cppu::bool2any(bValue)); 92*cdf0e10cSrcweir } 93*cdf0e10cSrcweir 94*cdf0e10cSrcweir //------------------------------------------------------------------------- 95*cdf0e10cSrcweir void OFormsRootImport::StartElement( const Reference< sax::XAttributeList >& _rxAttrList ) 96*cdf0e10cSrcweir { 97*cdf0e10cSrcweir ENTER_LOG_CONTEXT( "xmloff::OFormsRootImport - importing the complete tree" ); 98*cdf0e10cSrcweir SvXMLImportContext::StartElement( _rxAttrList ); 99*cdf0e10cSrcweir 100*cdf0e10cSrcweir try 101*cdf0e10cSrcweir { 102*cdf0e10cSrcweir Reference< XPropertySet > xDocProperties(GetImport().GetModel(), UNO_QUERY); 103*cdf0e10cSrcweir if ( xDocProperties.is() ) 104*cdf0e10cSrcweir { // an empty model is allowed: when doing a copy'n'paste from e.g. Writer to Calc, 105*cdf0e10cSrcweir // this is done via streaming the controls as XML. 106*cdf0e10cSrcweir Reference< XPropertySetInfo > xDocPropInfo; 107*cdf0e10cSrcweir if (xDocProperties.is()) 108*cdf0e10cSrcweir xDocPropInfo = xDocProperties->getPropertySetInfo(); 109*cdf0e10cSrcweir 110*cdf0e10cSrcweir implImportBool(_rxAttrList, ofaAutomaticFocus, xDocProperties, xDocPropInfo, PROPERTY_AUTOCONTROLFOCUS, sal_False); 111*cdf0e10cSrcweir implImportBool(_rxAttrList, ofaApplyDesignMode, xDocProperties, xDocPropInfo, PROPERTY_APPLYDESIGNMODE, sal_True); 112*cdf0e10cSrcweir } 113*cdf0e10cSrcweir } 114*cdf0e10cSrcweir catch(Exception&) 115*cdf0e10cSrcweir { 116*cdf0e10cSrcweir OSL_ENSURE(sal_False, "OFormsRootImport::StartElement: caught an exception while setting the document properties!"); 117*cdf0e10cSrcweir } 118*cdf0e10cSrcweir } 119*cdf0e10cSrcweir 120*cdf0e10cSrcweir //------------------------------------------------------------------------- 121*cdf0e10cSrcweir void OFormsRootImport::EndElement() 122*cdf0e10cSrcweir { 123*cdf0e10cSrcweir SvXMLImportContext::EndElement(); 124*cdf0e10cSrcweir LEAVE_LOG_CONTEXT( ); 125*cdf0e10cSrcweir } 126*cdf0e10cSrcweir 127*cdf0e10cSrcweir //===================================================================== 128*cdf0e10cSrcweir //= OFormsRootExport 129*cdf0e10cSrcweir //===================================================================== 130*cdf0e10cSrcweir //--------------------------------------------------------------------- 131*cdf0e10cSrcweir OFormsRootExport::OFormsRootExport( SvXMLExport& _rExp ) 132*cdf0e10cSrcweir :m_pImplElement(NULL) 133*cdf0e10cSrcweir { 134*cdf0e10cSrcweir addModelAttributes(_rExp); 135*cdf0e10cSrcweir 136*cdf0e10cSrcweir m_pImplElement = new SvXMLElementExport(_rExp, XML_NAMESPACE_OFFICE, XML_FORMS, sal_True, sal_True); 137*cdf0e10cSrcweir } 138*cdf0e10cSrcweir 139*cdf0e10cSrcweir //--------------------------------------------------------------------- 140*cdf0e10cSrcweir OFormsRootExport::~OFormsRootExport( ) 141*cdf0e10cSrcweir { 142*cdf0e10cSrcweir delete m_pImplElement; 143*cdf0e10cSrcweir } 144*cdf0e10cSrcweir 145*cdf0e10cSrcweir //------------------------------------------------------------------------- 146*cdf0e10cSrcweir void OFormsRootExport::implExportBool(SvXMLExport& _rExp, OfficeFormsAttributes _eAttribute, 147*cdf0e10cSrcweir const Reference< XPropertySet >& _rxProps, const Reference< XPropertySetInfo >& _rxPropInfo, 148*cdf0e10cSrcweir const ::rtl::OUString& _rPropName, sal_Bool _bDefault) 149*cdf0e10cSrcweir { 150*cdf0e10cSrcweir // retrieve the property value 151*cdf0e10cSrcweir sal_Bool bValue = _bDefault; 152*cdf0e10cSrcweir if (_rxPropInfo->hasPropertyByName(_rPropName)) 153*cdf0e10cSrcweir bValue = ::cppu::any2bool(_rxProps->getPropertyValue(_rPropName)); 154*cdf0e10cSrcweir 155*cdf0e10cSrcweir // convert into a string 156*cdf0e10cSrcweir ::rtl::OUStringBuffer aValue; 157*cdf0e10cSrcweir _rExp.GetMM100UnitConverter().convertBool(aValue, bValue); 158*cdf0e10cSrcweir 159*cdf0e10cSrcweir // add the attribute 160*cdf0e10cSrcweir _rExp.AddAttribute( 161*cdf0e10cSrcweir OAttributeMetaData::getOfficeFormsAttributeNamespace(_eAttribute), 162*cdf0e10cSrcweir OAttributeMetaData::getOfficeFormsAttributeName(_eAttribute), 163*cdf0e10cSrcweir aValue.makeStringAndClear()); 164*cdf0e10cSrcweir } 165*cdf0e10cSrcweir 166*cdf0e10cSrcweir //------------------------------------------------------------------------- 167*cdf0e10cSrcweir void OFormsRootExport::addModelAttributes(SvXMLExport& _rExp) SAL_THROW(()) 168*cdf0e10cSrcweir { 169*cdf0e10cSrcweir try 170*cdf0e10cSrcweir { 171*cdf0e10cSrcweir Reference< XPropertySet > xDocProperties(_rExp.GetModel(), UNO_QUERY); 172*cdf0e10cSrcweir if ( xDocProperties.is() ) 173*cdf0e10cSrcweir { // an empty model is allowed: when doing a copy'n'paste from e.g. Writer to Calc, 174*cdf0e10cSrcweir // this is done via streaming the controls as XML. 175*cdf0e10cSrcweir Reference< XPropertySetInfo > xDocPropInfo; 176*cdf0e10cSrcweir if (xDocProperties.is()) 177*cdf0e10cSrcweir xDocPropInfo = xDocProperties->getPropertySetInfo(); 178*cdf0e10cSrcweir 179*cdf0e10cSrcweir implExportBool(_rExp, ofaAutomaticFocus, xDocProperties, xDocPropInfo, PROPERTY_AUTOCONTROLFOCUS, sal_False); 180*cdf0e10cSrcweir implExportBool(_rExp, ofaApplyDesignMode, xDocProperties, xDocPropInfo, PROPERTY_APPLYDESIGNMODE, sal_True); 181*cdf0e10cSrcweir } 182*cdf0e10cSrcweir } 183*cdf0e10cSrcweir catch(Exception&) 184*cdf0e10cSrcweir { 185*cdf0e10cSrcweir OSL_ENSURE(sal_False, "OFormsRootExport::addModelAttributes: caught an exception while retrieving the document properties!"); 186*cdf0e10cSrcweir } 187*cdf0e10cSrcweir } 188*cdf0e10cSrcweir 189*cdf0e10cSrcweir //......................................................................... 190*cdf0e10cSrcweir } // namespace xmloff 191*cdf0e10cSrcweir //......................................................................... 192*cdf0e10cSrcweir 193*cdf0e10cSrcweir 194