Line data Source code
1 : /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 : /*
3 : * This file is part of the LibreOffice project.
4 : *
5 : * This Source Code Form is subject to the terms of the Mozilla Public
6 : * License, v. 2.0. If a copy of the MPL was not distributed with this
7 : * file, You can obtain one at http://mozilla.org/MPL/2.0/.
8 : *
9 : * This file incorporates work covered by the following license notice:
10 : *
11 : * Licensed to the Apache Software Foundation (ASF) under one or more
12 : * contributor license agreements. See the NOTICE file distributed
13 : * with this work for additional information regarding copyright
14 : * ownership. The ASF licenses this file to you under the Apache
15 : * License, Version 2.0 (the "License"); you may not use this file
16 : * except in compliance with the License. You may obtain a copy of
17 : * the License at http://www.apache.org/licenses/LICENSE-2.0 .
18 : */
19 :
20 : #include "comphelper/anytostring.hxx"
21 : #include "cppuhelper/exc_hlp.hxx"
22 :
23 : #include <com/sun/star/beans/XMultiPropertySet.hpp>
24 : #include <com/sun/star/container/XNamed.hpp>
25 :
26 : #include "oox/helper/propertyset.hxx"
27 : #include "oox/core/xmlfilterbase.hxx"
28 : #include "headerfootercontext.hxx"
29 : #include "oox/ppt/backgroundproperties.hxx"
30 : #include "oox/ppt/slidefragmenthandler.hxx"
31 : #include "oox/ppt/slidetimingcontext.hxx"
32 : #include "oox/ppt/slidetransitioncontext.hxx"
33 : #include "oox/ppt/slidemastertextstylescontext.hxx"
34 : #include "oox/ppt/pptshapegroupcontext.hxx"
35 : #include "oox/ppt/pptshape.hxx"
36 : #include "oox/vml/vmldrawing.hxx"
37 : #include "oox/vml/vmldrawingfragment.hxx"
38 : #include "oox/drawingml/clrschemecontext.hxx"
39 : #include "oox/ppt/pptimport.hxx"
40 :
41 :
42 : using namespace ::com::sun::star;
43 : using namespace ::oox::core;
44 : using namespace ::oox::drawingml;
45 : using namespace ::com::sun::star::uno;
46 : using namespace ::com::sun::star::drawing;
47 : using namespace ::com::sun::star::xml::sax;
48 : using namespace ::com::sun::star::container;
49 :
50 : namespace oox { namespace ppt {
51 :
52 0 : SlideFragmentHandler::SlideFragmentHandler( XmlFilterBase& rFilter, const OUString& rFragmentPath, SlidePersistPtr pPersistPtr, const ShapeLocation eShapeLocation ) throw()
53 : : FragmentHandler2( rFilter, rFragmentPath )
54 : , mpSlidePersistPtr( pPersistPtr )
55 0 : , meShapeLocation( eShapeLocation )
56 : {
57 0 : OUString aVMLDrawingFragmentPath = getFragmentPathFromFirstTypeFromOfficeDoc( "vmlDrawing" );
58 0 : if( !aVMLDrawingFragmentPath.isEmpty() )
59 0 : getFilter().importFragment( new oox::vml::DrawingFragment(
60 0 : getFilter(), aVMLDrawingFragmentPath, *pPersistPtr->getDrawing() ) );
61 0 : }
62 :
63 0 : SlideFragmentHandler::~SlideFragmentHandler() throw()
64 : {
65 : // convert and insert all VML shapes (mostly form controls)
66 0 : mpSlidePersistPtr->getDrawing()->convertAndInsert();
67 0 : }
68 :
69 0 : ::oox::core::ContextHandlerRef SlideFragmentHandler::onCreateContext( sal_Int32 aElementToken, const AttributeList& rAttribs )
70 : {
71 0 : switch( aElementToken )
72 : {
73 : case PPT_TOKEN( sldMaster ): // CT_SlideMaster
74 : case PPT_TOKEN( handoutMaster ): // CT_HandoutMaster
75 : case PPT_TOKEN( sld ): // CT_CommonSlideData
76 : {
77 0 : Reference< XDrawPage > xSlide( mpSlidePersistPtr->getPage() );
78 0 : PropertyMap aPropMap;
79 0 : PropertySet aSlideProp( xSlide );
80 :
81 0 : aPropMap.setProperty( PROP_Visible, rAttribs.getBool( XML_show, true ));
82 0 : aSlideProp.setProperties( aPropMap );
83 :
84 0 : return this;
85 : }
86 : case PPT_TOKEN( notes ): // CT_NotesSlide
87 : {
88 : // Import notesMaster
89 0 : PowerPointImport& rFilter = dynamic_cast< PowerPointImport& >( getFilter() );
90 0 : OUString aNotesFragmentPath = getFragmentPathFromFirstTypeFromOfficeDoc( "notesMaster" );
91 :
92 0 : std::vector< SlidePersistPtr >& rMasterPages( rFilter.getMasterPages() );
93 0 : std::vector< SlidePersistPtr >::iterator aIter( rMasterPages.begin() );
94 0 : while( aIter != rMasterPages.end() )
95 : {
96 0 : if( (*aIter)->getPath() == aNotesFragmentPath )
97 : {
98 0 : if( !mpSlidePersistPtr->getMasterPersist() )
99 0 : mpSlidePersistPtr->setMasterPersist( *aIter );
100 0 : break;
101 : }
102 0 : ++aIter;
103 : }
104 0 : if( aIter == rMasterPages.end() && !mpSlidePersistPtr->getMasterPersist() )
105 : {
106 0 : TextListStylePtr pTextListStyle(new TextListStyle);
107 : SlidePersistPtr pMasterPersistPtr = SlidePersistPtr( new SlidePersist( rFilter, true, true, mpSlidePersistPtr->getPage(),
108 0 : ShapePtr( new PPTShape( Master, "com.sun.star.drawing.GroupShape" ) ), mpSlidePersistPtr->getNotesTextStyle() ) );
109 0 : pMasterPersistPtr->setPath( aNotesFragmentPath );
110 0 : rFilter.getMasterPages().push_back( pMasterPersistPtr );
111 0 : FragmentHandlerRef xMasterFragmentHandler( new SlideFragmentHandler( rFilter, aNotesFragmentPath, pMasterPersistPtr, Master ) );
112 0 : rFilter.importFragment( xMasterFragmentHandler );
113 0 : mpSlidePersistPtr->setMasterPersist( pMasterPersistPtr );
114 : }
115 0 : return this;
116 : }
117 : case PPT_TOKEN( notesMaster ): // CT_NotesMaster
118 0 : return this;
119 : case PPT_TOKEN( cSld ): // CT_CommonSlideData
120 0 : maSlideName = rAttribs.getString(XML_name, OUString());
121 0 : return this;
122 :
123 : case PPT_TOKEN( spTree ): // CT_GroupShape
124 : {
125 : // TODO Convert this to FragmentHandler2
126 : return new PPTShapeGroupContext(
127 : *this, mpSlidePersistPtr, meShapeLocation, mpSlidePersistPtr->getShapes(),
128 0 : oox::drawingml::ShapePtr( new PPTShape( meShapeLocation, "com.sun.star.drawing.GroupShape" ) ) );
129 : }
130 : break;
131 :
132 : case PPT_TOKEN( controls ):
133 0 : return this;
134 : case PPT_TOKEN( control ):
135 : {
136 0 : ::oox::vml::ControlInfo aInfo;
137 0 : aInfo.setShapeId( rAttribs.getInteger( XML_spid, 0 ) );
138 0 : aInfo.maFragmentPath = getFragmentPathFromRelId( rAttribs.getString( R_TOKEN( id ), OUString() ) );
139 0 : aInfo.maName = rAttribs.getXString( XML_name, OUString() );
140 0 : mpSlidePersistPtr->getDrawing()->registerControl( aInfo );
141 : }
142 0 : return this;
143 :
144 : case PPT_TOKEN( timing ): // CT_SlideTiming
145 0 : return new SlideTimingContext( *this, mpSlidePersistPtr->getTimeNodeList() );
146 : case PPT_TOKEN( transition ): // CT_SlideTransition
147 0 : return new SlideTransitionContext( *this, rAttribs, maSlideProperties );
148 : case PPT_TOKEN( hf ):
149 0 : return new HeaderFooterContext( *this, rAttribs, mpSlidePersistPtr->getHeaderFooter() );
150 :
151 : // BackgroundGroup
152 : case PPT_TOKEN( bg ):
153 0 : return this;
154 : case PPT_TOKEN( bgPr ): // CT_BackgroundProperties
155 : {
156 0 : FillPropertiesPtr pFillPropertiesPtr( new FillProperties );
157 0 : mpSlidePersistPtr->setBackgroundProperties( pFillPropertiesPtr );
158 0 : return new BackgroundPropertiesContext( *this, *pFillPropertiesPtr );
159 : }
160 0 : break;
161 :
162 : case PPT_TOKEN( bgRef ): // a:CT_StyleMatrixReference
163 : {
164 0 : const FillProperties *pFillProperties = NULL;
165 0 : if( mpSlidePersistPtr->getTheme() )
166 0 : pFillProperties = mpSlidePersistPtr->getTheme()->getFillStyle( rAttribs.getInteger( XML_idx, -1 ) );
167 0 : FillPropertiesPtr pFillPropertiesPtr( pFillProperties ? new FillProperties( *pFillProperties ) : new FillProperties() );
168 0 : ContextHandlerRef ret = new ColorContext( *this, mpSlidePersistPtr->getBackgroundColor() );
169 0 : mpSlidePersistPtr->setBackgroundProperties( pFillPropertiesPtr );
170 0 : return ret;
171 : }
172 : break;
173 :
174 : case A_TOKEN( overrideClrMapping ):
175 : case PPT_TOKEN( clrMap ): // CT_ColorMapping
176 : {
177 0 : oox::drawingml::ClrMapPtr pClrMapPtr( ( aElementToken == PPT_TOKEN( clrMap ) || !mpSlidePersistPtr.get() || !mpSlidePersistPtr->getClrMap().get() ) ? new oox::drawingml::ClrMap() : new oox::drawingml::ClrMap( *mpSlidePersistPtr->getClrMap() ) );
178 0 : ContextHandlerRef ret = new oox::drawingml::clrMapContext( *this, rAttribs, *pClrMapPtr );
179 0 : mpSlidePersistPtr->setClrMap( pClrMapPtr );
180 0 : return ret;
181 : }
182 : break;
183 : case PPT_TOKEN( clrMapOvr ): // CT_ColorMappingOverride
184 : case PPT_TOKEN( sldLayoutIdLst ): // CT_SlideLayoutIdList
185 0 : return this;
186 : case PPT_TOKEN( txStyles ): // CT_SlideMasterTextStyles
187 0 : return new SlideMasterTextStylesContext( *this, mpSlidePersistPtr );
188 : case PPT_TOKEN( custDataLst ): // CT_CustomerDataList
189 : case PPT_TOKEN( tagLst ): // CT_TagList
190 0 : return this;
191 :
192 : //for Comments
193 : case PPT_TOKEN( cmLst ):
194 0 : break;
195 : case PPT_TOKEN( cm ):
196 0 : if(!mpSlidePersistPtr->getCommentsList().cmLst.empty())
197 : {
198 : // set comment text for earlier comment
199 0 : mpSlidePersistPtr->getCommentsList().cmLst.back().setText( getCharVector().back() );
200 : }
201 : // insert a new comment in vector commentsList
202 0 : mpSlidePersistPtr->getCommentsList().cmLst.push_back(Comment());
203 0 : mpSlidePersistPtr->getCommentsList().cmLst.back().setAuthorId(rAttribs.getString(XML_authorId, OUString()));
204 0 : mpSlidePersistPtr->getCommentsList().cmLst.back().setdt(rAttribs.getString(XML_dt, OUString()));
205 0 : mpSlidePersistPtr->getCommentsList().cmLst.back().setidx(rAttribs.getString(XML_idx, OUString()));
206 0 : break;
207 :
208 : case PPT_TOKEN( pos ):
209 0 : mpSlidePersistPtr->getCommentsList().cmLst.back().setPoint(
210 : rAttribs.getString(XML_x, OUString()),
211 0 : rAttribs.getString(XML_y, OUString()));
212 0 : break;
213 :
214 : case PPT_TOKEN( cmAuthor ):
215 0 : CommentAuthor _author;
216 0 : _author.clrIdx = rAttribs.getString(XML_clrIdx, OUString());
217 0 : _author.id = rAttribs.getString(XML_id, OUString());
218 0 : _author.initials = rAttribs.getString(XML_initials, OUString());
219 0 : _author.lastIdx = rAttribs.getString(XML_lastIdx, OUString());
220 0 : _author.name = rAttribs.getString(XML_name, OUString());
221 0 : mpSlidePersistPtr->getCommentAuthors().addAuthor(_author);
222 0 : break;
223 : }
224 :
225 0 : return this;
226 : }
227 0 : void SlideFragmentHandler::onCharacters( const OUString& rChars)
228 : {
229 0 : maCharVector.push_back(rChars);
230 0 : }
231 0 : void SlideFragmentHandler::finalizeImport()
232 : {
233 : try
234 : {
235 0 : Reference< XDrawPage > xSlide( mpSlidePersistPtr->getPage() );
236 0 : PropertySet aSlideProp( xSlide );
237 0 : aSlideProp.setProperties( maSlideProperties );
238 0 : if ( !maSlideName.isEmpty() )
239 : {
240 0 : Reference< XNamed > xNamed( xSlide, UNO_QUERY );
241 0 : if( xNamed.is() )
242 0 : xNamed->setName( maSlideName );
243 0 : }
244 : }
245 0 : catch( uno::Exception& )
246 : {
247 : OSL_FAIL( OString("oox::ppt::SlideFragmentHandler::EndElement(), "
248 : "exception caught: " +
249 : OUStringToOString(
250 : comphelper::anyToString( cppu::getCaughtException() ),
251 : RTL_TEXTENCODING_UTF8 )).getStr());
252 : }
253 0 : }
254 :
255 0 : } }
256 :
257 : /* vim:set shiftwidth=4 softtabstop=4 expandtab: */
|