/* -*- 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 . */ /** @#file * * This file implements XMLTextParagraphExport methods to export * - footnotes * - endnotes * - footnote configuration elements * - endnote configuration elements */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "XMLTextCharStyleNamesElementExport.hxx" #include #include using namespace ::com::sun::star; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::lang; using namespace ::com::sun::star::beans; using namespace ::com::sun::star::text; using namespace ::com::sun::star::container; using namespace ::xmloff::token; void XMLTextParagraphExport::exportTextFootnote( const Reference & rPropSet, const OUString& rText, bool bAutoStyles, bool bIsProgress ) { // get footnote and associated text Any aAny; aAny = rPropSet->getPropertyValue(sFootnote); Reference xFootnote; aAny >>= xFootnote; Reference xText(xFootnote, UNO_QUERY); // are we an endnote? Reference xServiceInfo( xFootnote, UNO_QUERY ); bool bIsEndnote = xServiceInfo->supportsService(sTextEndnoteService); if (bAutoStyles) { // handle formatting of citation mark Add( XML_STYLE_FAMILY_TEXT_TEXT, rPropSet ); // handle formatting within footnote exportTextFootnoteHelper(xFootnote, xText, rText, bAutoStyles, bIsEndnote, bIsProgress ); } else { // create span (for citation mark) if necessary; footnote content // wil be handled via exportTextFootnoteHelper, exportText bool bHasHyperlink; bool bIsUICharStyle = false; bool bHasAutoStyle = false; OUString sStyle = FindTextStyleAndHyperlink( rPropSet, bHasHyperlink, bIsUICharStyle, bHasAutoStyle ); // export hyperlink (if we have one) Reference < XPropertySetInfo > xPropSetInfo; if( bHasHyperlink ) { Reference xPropState( rPropSet, UNO_QUERY ); xPropSetInfo = rPropSet->getPropertySetInfo(); bHasHyperlink = addHyperlinkAttributes( rPropSet, xPropState, xPropSetInfo ); } SvXMLElementExport aHyperlink( GetExport(), bHasHyperlink, XML_NAMESPACE_TEXT, XML_A, false, false ); if( bHasHyperlink ) { // export events (if supported) OUString sHyperLinkEvents("HyperLinkEvents"); if (xPropSetInfo->hasPropertyByName(sHyperLinkEvents)) { Any a = rPropSet->getPropertyValue(sHyperLinkEvents); Reference xName; a >>= xName; GetExport().GetEventExport().Export(xName, false); } } { XMLTextCharStyleNamesElementExport aCharStylesExport( GetExport(), bIsUICharStyle && aCharStyleNamesPropInfoCache.hasProperty( rPropSet ), bHasAutoStyle, rPropSet, sCharStyleNames ); if( !sStyle.isEmpty() ) { GetExport().AddAttribute( XML_NAMESPACE_TEXT, XML_STYLE_NAME, GetExport().EncodeStyleName( sStyle ) ); SvXMLElementExport aElem( GetExport(), XML_NAMESPACE_TEXT, XML_SPAN, false, false ); exportTextFootnoteHelper(xFootnote, xText, rText, bAutoStyles, bIsEndnote, bIsProgress ); } else { exportTextFootnoteHelper(xFootnote, xText, rText, bAutoStyles, bIsEndnote, bIsProgress ); } } } } void XMLTextParagraphExport::exportTextFootnoteHelper( const Reference & rFootnote, const Reference & rText, const OUString& rTextString, bool bAutoStyles, bool bIsEndnote, bool bIsProgress ) { if (bAutoStyles) { exportText(rText, bAutoStyles, bIsProgress, true ); } else { // export reference Id (for reference fields) Reference xPropSet(rFootnote, UNO_QUERY); Any aAny = xPropSet->getPropertyValue(sReferenceId); sal_Int32 nNumber = 0; aAny >>= nNumber; OUStringBuffer aBuf; aBuf.appendAscii("ftn"); aBuf.append(nNumber); GetExport().AddAttribute(XML_NAMESPACE_TEXT, XML_ID, aBuf.makeStringAndClear()); GetExport().AddAttribute(XML_NAMESPACE_TEXT, XML_NOTE_CLASS, GetXMLToken( bIsEndnote ? XML_ENDNOTE : XML_FOOTNOTE ) ); SvXMLElementExport aNote(GetExport(), XML_NAMESPACE_TEXT, XML_NOTE, false, false); { // handle label vs. automatic numbering OUString sLabel = rFootnote->getLabel(); if (!sLabel.isEmpty()) { GetExport().AddAttribute(XML_NAMESPACE_TEXT, XML_LABEL, sLabel); } // else: automatic numbering -> no attribute SvXMLElementExport aCite(GetExport(), XML_NAMESPACE_TEXT, XML_NOTE_CITATION, false, false); GetExport().Characters(rTextString); } { SvXMLElementExport aBody(GetExport(), XML_NAMESPACE_TEXT, XML_NOTE_BODY, false, false); exportText(rText, bAutoStyles, bIsProgress, true ); } } } void XMLTextParagraphExport::exportTextFootnoteConfiguration() { // footnote settings Reference aFootnotesSupplier(GetExport().GetModel(), UNO_QUERY); Reference aFootnoteConfiguration( aFootnotesSupplier->getFootnoteSettings()); exportTextFootnoteConfigurationHelper(aFootnoteConfiguration, false); // endnote settings Reference aEndnotesSupplier(GetExport().GetModel(), UNO_QUERY); Reference aEndnoteConfiguration( aEndnotesSupplier->getEndnoteSettings()); exportTextFootnoteConfigurationHelper(aEndnoteConfiguration, true); } static void lcl_exportString( SvXMLExport& rExport, const Reference & rPropSet, const OUString& sProperty, sal_uInt16 nPrefix, enum XMLTokenEnum eElement, bool bEncodeName, bool bOmitIfEmpty) { DBG_ASSERT( eElement != XML_TOKEN_INVALID, "need element token"); Any aAny = rPropSet->getPropertyValue(sProperty); OUString sTmp; aAny >>= sTmp; if (!bOmitIfEmpty || !sTmp.isEmpty()) { if( bEncodeName ) sTmp = rExport.EncodeStyleName( sTmp ); rExport.AddAttribute(nPrefix, eElement, sTmp); } } void XMLTextParagraphExport::exportTextFootnoteConfigurationHelper( const Reference & rFootnoteConfig, bool bIsEndnote) { GetExport().AddAttribute(XML_NAMESPACE_TEXT, XML_NOTE_CLASS, GetXMLToken( bIsEndnote ? XML_ENDNOTE : XML_FOOTNOTE ) ); // default/paragraph style lcl_exportString( GetExport(), rFootnoteConfig, sParaStyleName, XML_NAMESPACE_TEXT, XML_DEFAULT_STYLE_NAME, true, true); // citation style lcl_exportString( GetExport(), rFootnoteConfig, sCharStyleName, XML_NAMESPACE_TEXT, XML_CITATION_STYLE_NAME, true, true); // citation body style lcl_exportString( GetExport(), rFootnoteConfig, sAnchorCharStyleName, XML_NAMESPACE_TEXT, XML_CITATION_BODY_STYLE_NAME, true, true); // page style lcl_exportString( GetExport(), rFootnoteConfig, sPageStyleName, XML_NAMESPACE_TEXT, XML_MASTER_PAGE_NAME, true, true ); // prefix lcl_exportString( GetExport(), rFootnoteConfig, sPrefix, XML_NAMESPACE_STYLE, XML_NUM_PREFIX, false, true); // suffix lcl_exportString( GetExport(), rFootnoteConfig, sSuffix, XML_NAMESPACE_STYLE, XML_NUM_SUFFIX, false, true); Any aAny; // numbering style OUStringBuffer sBuffer; aAny = rFootnoteConfig->getPropertyValue(sNumberingType); sal_Int16 nNumbering = 0; aAny >>= nNumbering; GetExport().GetMM100UnitConverter().convertNumFormat( sBuffer, nNumbering); GetExport().AddAttribute(XML_NAMESPACE_STYLE, XML_NUM_FORMAT, sBuffer.makeStringAndClear() ); GetExport().GetMM100UnitConverter().convertNumLetterSync( sBuffer, nNumbering); if (!sBuffer.isEmpty() ) { GetExport().AddAttribute(XML_NAMESPACE_STYLE, XML_NUM_LETTER_SYNC, sBuffer.makeStringAndClear()); } // StartAt / start-value aAny = rFootnoteConfig->getPropertyValue(sStartAt); sal_Int16 nOffset = 0; aAny >>= nOffset; ::sax::Converter::convertNumber(sBuffer, (sal_Int32)nOffset); GetExport().AddAttribute(XML_NAMESPACE_TEXT, XML_START_VALUE, sBuffer.makeStringAndClear()); // some properties are for footnotes only if (!bIsEndnote) { // footnotes position aAny = rFootnoteConfig->getPropertyValue( sPositionEndOfDoc); GetExport().AddAttribute(XML_NAMESPACE_TEXT, XML_FOOTNOTES_POSITION, ( (*(sal_Bool *)aAny.getValue()) ? XML_DOCUMENT : XML_PAGE ) ); aAny = rFootnoteConfig->getPropertyValue(sFootnoteCounting); sal_Int16 nTmp = 0; aAny >>= nTmp; enum XMLTokenEnum eElement; switch (nTmp) { case FootnoteNumbering::PER_PAGE: eElement = XML_PAGE; break; case FootnoteNumbering::PER_CHAPTER: eElement = XML_CHAPTER; break; case FootnoteNumbering::PER_DOCUMENT: default: eElement = XML_DOCUMENT; break; } GetExport().AddAttribute(XML_NAMESPACE_TEXT, XML_START_NUMBERING_AT, eElement); } // element SvXMLElementExport aFootnoteConfigElement( GetExport(), XML_NAMESPACE_TEXT, XML_NOTES_CONFIGURATION, true, true); // two element for footnote content if (!bIsEndnote) { OUString sTmp; // end notice / quo vadis aAny = rFootnoteConfig->getPropertyValue(sEndNotice); aAny >>= sTmp; if (!sTmp.isEmpty()) { SvXMLElementExport aElem(GetExport(), XML_NAMESPACE_TEXT, XML_FOOTNOTE_CONTINUATION_NOTICE_FORWARD, true, false); GetExport().Characters(sTmp); } // begin notice / ergo sum aAny = rFootnoteConfig->getPropertyValue(sBeginNotice); aAny >>= sTmp; if (!sTmp.isEmpty()) { SvXMLElementExport aElem(GetExport(), XML_NAMESPACE_TEXT, XML_FOOTNOTE_CONTINUATION_NOTICE_BACKWARD, true, false); GetExport().Characters(sTmp); } } } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */