office-gobmx/xmloff/source/chart/SchXMLParagraphContext.cxx
Balazs Varga d7214aba95 tdf#160517 - chart odf: import/export formatted chart titles
(main, sub, axis titles) texts properly to/from odf format.

Fix odf export of formatted chart titles. The exported data structure
will look like:

<chart:title svg:x="3.304cm" svg:y="0.285cm" chart:style-name="ch2">
    <text:p>
        <text:span text:style-name="T1">This</text:span>
        <text:span text:style-name="T2"> is</text:span>
        .
        .
        .
        <text:span text:style-name="T3">3</text:span>
        <text:span text:style-name="T2"> a </text:span>
    </text:p>
</chart:title>

Fix import of formatted chart titles. Put the properties and related texts
into the chart2::XFormattedString2 uno objects.

Follow-up commit of:
55e9a27afd
Related: tdf#39052 - chart ooxml: export formatted chart titles

4f994cec38
tdf#39052 - Chart: make characters formatable in editable chart textshapes

--
TODO: chart data point / dataseries labels are handled differently
since those are not editable objects, but that is a completily different
issue.
--

Change-Id: I1842f2c69c132bdf578bb2d354f451cc9d49c63c
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/166122
Reviewed-by: Michael Stahl <michael.stahl@allotropia.de>
Tested-by: Jenkins
Reviewed-by: Balazs Varga <balazs.varga.extern@allotropia.de>
2024-04-18 18:07:57 +02:00

235 lines
7 KiB
C++

/* -*- 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 .
*/
#include "SchXMLParagraphContext.hxx"
#include <sal/log.hxx>
#include <xmloff/xmlimp.hxx>
#include <xmloff/xmlnamespace.hxx>
#include <xmloff/xmltoken.hxx>
using namespace com::sun::star;
using namespace ::xmloff::token;
SchXMLParagraphContext::SchXMLParagraphContext( SvXMLImport& rImport,
OUString& rText,
OUString * pOutId /* = 0 */ ) :
SvXMLImportContext( rImport ),
mrText( rText ),
mpId( pOutId )
{
}
SchXMLParagraphContext::~SchXMLParagraphContext()
{}
void SchXMLParagraphContext::startFastElement(
sal_Int32 /*nElement*/,
const uno::Reference< xml::sax::XFastAttributeList >& xAttrList )
{
// remember the id. It is used for storing the original cell range string in
// a local table (cached data)
if( !mpId )
return;
bool bHaveXmlId( false );
for( auto& aIter : sax_fastparser::castToFastAttributeList(xAttrList) )
{
switch(aIter.getToken())
{
case XML_ELEMENT(XML, XML_ID):
(*mpId) = aIter.toString();
bHaveXmlId = true;
break;
case XML_ELEMENT(TEXT, XML_ID):
{ // text:id shall be ignored if xml:id exists
if (!bHaveXmlId)
{
(*mpId) = aIter.toString();
}
break;
}
default:
XMLOFF_WARN_UNKNOWN("xmloff", aIter);
}
}
}
void SchXMLParagraphContext::endFastElement(sal_Int32 )
{
mrText = maBuffer.makeStringAndClear();
}
css::uno::Reference< css::xml::sax::XFastContextHandler > SchXMLParagraphContext::createFastChildContext(
sal_Int32 nElement,
const css::uno::Reference< css::xml::sax::XFastAttributeList >& )
{
if( nElement == XML_ELEMENT(TEXT, XML_TAB_STOP) )
{
maBuffer.append( u'\x0009'); // tabulator
}
else if( nElement == XML_ELEMENT(TEXT, XML_LINE_BREAK) )
{
maBuffer.append( u'\x000A'); // linefeed
}
else
XMLOFF_WARN_UNKNOWN_ELEMENT("xmloff", nElement);
return nullptr;
}
void SchXMLParagraphContext::characters( const OUString& rChars )
{
maBuffer.append( rChars );
}
SchXMLTitleParaContext::SchXMLTitleParaContext( SvXMLImport& rImport,
std::vector<std::pair<OUString, OUString>>& rParaText,
OUString * pOutId /* = 0 */ ) :
SvXMLImportContext( rImport ),
mrParaText( rParaText ),
mpId( pOutId )
{
}
SchXMLTitleParaContext::~SchXMLTitleParaContext()
{}
void SchXMLTitleParaContext::startFastElement(
sal_Int32 /*nElement*/,
const uno::Reference< xml::sax::XFastAttributeList >& xAttrList )
{
// remember the id. It is used for storing the original cell range string in
// a local table (cached data)
if( !mpId )
return;
bool bHaveXmlId( false );
for( auto& aIter : sax_fastparser::castToFastAttributeList(xAttrList) )
{
switch(aIter.getToken())
{
case XML_ELEMENT(TEXT, XML_STYLE_NAME):
maStyleName = aIter.toString();
break;
case XML_ELEMENT(XML, XML_ID):
(*mpId) = aIter.toString();
bHaveXmlId = true;
break;
case XML_ELEMENT(TEXT, XML_ID):
{ // text:id shall be ignored if xml:id exists
if (!bHaveXmlId)
{
(*mpId) = aIter.toString();
}
break;
}
default:
XMLOFF_WARN_UNKNOWN("xmloff", aIter);
}
}
}
void SchXMLTitleParaContext::endFastElement(sal_Int32 )
{
if (!maBuffer.isEmpty())
mrParaText.push_back(std::make_pair(maStyleName, maBuffer.makeStringAndClear()));
}
void SchXMLTitleParaContext::characters(const OUString& rChars)
{
maBuffer.append(rChars);
}
css::uno::Reference< css::xml::sax::XFastContextHandler > SchXMLTitleParaContext::createFastChildContext(
sal_Int32 nElement,
const css::uno::Reference< css::xml::sax::XFastAttributeList >& xAttrList)
{
if( nElement == XML_ELEMENT(TEXT, XML_SPAN) )
{
if (!maBuffer.isEmpty())
mrParaText.push_back(std::make_pair(maStyleName, maBuffer.makeStringAndClear()));
return new SchXMLTitleSpanContext(GetImport(), mrParaText, xAttrList);
}
else if( nElement == XML_ELEMENT(TEXT, XML_TAB_STOP) )
{
maBuffer.append( u'\x0009'); // tabulator
}
else if( nElement == XML_ELEMENT(TEXT, XML_LINE_BREAK) )
{
maBuffer.append( u'\x000A'); // linefeed
}
else
XMLOFF_WARN_UNKNOWN_ELEMENT("xmloff", nElement);
return nullptr;
}
SchXMLTitleSpanContext::SchXMLTitleSpanContext(SvXMLImport& rImport, std::vector<std::pair<OUString, OUString>>& rSpanTexts,
const css::uno::Reference< css::xml::sax::XFastAttributeList >& xAttrList) :
SvXMLImportContext(rImport),
mrSpanTexts(rSpanTexts)
{
for( auto& aIter : sax_fastparser::castToFastAttributeList(xAttrList) )
{
if( aIter.getToken() == XML_ELEMENT(TEXT, XML_STYLE_NAME) )
{
maStyleName = aIter.toString();
break;
}
}
}
SchXMLTitleSpanContext::~SchXMLTitleSpanContext()
{}
void SchXMLTitleSpanContext::characters(const OUString& rChars)
{
maCharBuffer.append(rChars);
}
css::uno::Reference< css::xml::sax::XFastContextHandler > SchXMLTitleSpanContext::createFastChildContext(
sal_Int32 nElement,
const css::uno::Reference< css::xml::sax::XFastAttributeList >& /*xAttrList*/)
{
if( nElement == XML_ELEMENT(TEXT, XML_TAB_STOP) )
{
maCharBuffer.append( u'\x0009'); // tabulator
}
else if( nElement == XML_ELEMENT(TEXT, XML_LINE_BREAK) )
{
maCharBuffer.append( u'\x000A'); // linefeed
}
else
XMLOFF_WARN_UNKNOWN_ELEMENT("xmloff", nElement);
return nullptr;
}
void SchXMLTitleSpanContext::endFastElement(sal_Int32)
{
if (!maCharBuffer.isEmpty())
mrSpanTexts.push_back(std::make_pair(maStyleName, maCharBuffer.makeStringAndClear()));
}
/* vim:set shiftwidth=4 softtabstop=4 expandtab: */