xref: /trunk/main/sc/source/ui/vba/vbatitle.hxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1 /*************************************************************************
2  *
3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4  *
5  * Copyright 2000, 2010 Oracle and/or its affiliates.
6  *
7  * OpenOffice.org - a multi-platform office productivity suite
8  *
9  * This file is part of OpenOffice.org.
10  *
11  * OpenOffice.org is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * OpenOffice.org is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU Lesser General Public License version 3 for more details
19  * (a copy is included in the LICENSE file that accompanied this code).
20  *
21  * You should have received a copy of the GNU Lesser General Public License
22  * version 3 along with OpenOffice.org.  If not, see
23  * <http://www.openoffice.org/license.html>
24  * for a copy of the LGPLv3 License.
25  *
26  ************************************************************************/
27 #ifndef SC_VBA_TITLE_HXX
28 #define SC_VBA_TITLE_HXX
29 
30 #include <vbahelper/vbahelperinterface.hxx>
31 #include "excelvbahelper.hxx"
32 #include "vbainterior.hxx"
33 #include "vbafont.hxx"
34 #include "vbapalette.hxx"
35 #include <com/sun/star/drawing/XShape.hpp>
36 #include <com/sun/star/beans/XPropertySet.hpp>
37 #include <ooo/vba/excel/XTitle.hpp>
38 #include <ooo/vba/excel/XCharacters.hpp>
39 #include <basic/sberrors.hxx>
40 #include <memory>
41 
42 template< typename Ifc1 >
43 class TitleImpl : public InheritedHelperInterfaceImpl< Ifc1 >
44 {
45 typedef InheritedHelperInterfaceImpl< Ifc1 > BaseClass;
46 
47 protected:
48     css::uno::Reference< css::drawing::XShape > xTitleShape;
49     css::uno::Reference< css::beans::XPropertySet > xShapePropertySet;
50     std::auto_ptr<ov::ShapeHelper> oShapeHelper;
51     ScVbaPalette m_Palette;
52 public:
53     TitleImpl(  const css::uno::Reference< ov::XHelperInterface >& xParent,   const css::uno::Reference< css::uno::XComponentContext >& xContext, const css::uno::Reference< css::drawing::XShape >& _xTitleShape ) : BaseClass( xParent, xContext ), xTitleShape( _xTitleShape )
54     {
55         xShapePropertySet.set( xTitleShape, css::uno::UNO_QUERY_THROW );
56         oShapeHelper.reset( new ov::ShapeHelper(xTitleShape) );
57     }
58     css::uno::Reference< ov::excel::XInterior > SAL_CALL Interior(  ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
59     {
60         // #TODO find out what the proper parent should be
61         // leaving as set by the helperapi for the moment
62         // #TODO we really need the ScDocument to pass to ScVbaInterior
63         // otherwise attemps to access the palette will fail
64         return new ScVbaInterior( BaseClass::mxParent, BaseClass::mxContext, xShapePropertySet );
65     }
66     css::uno::Reference< ov::excel::XFont > SAL_CALL Font(  ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
67     {
68         // #TODO find out what the proper parent should be
69         // leaving as set by the helperapi for the moment
70         return new ScVbaFont( BaseClass::mxParent, BaseClass::mxContext, m_Palette, xShapePropertySet );
71 
72     }
73     void SAL_CALL setText( const ::rtl::OUString& Text ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
74     {
75         try
76         {
77             xShapePropertySet->setPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("String") ), css::uno::makeAny( Text ));
78         }
79         catch ( css::uno::Exception& )
80         {
81             throw css::script::BasicErrorException( rtl::OUString(), css::uno::Reference< css::uno::XInterface >(), SbERR_METHOD_FAILED, rtl::OUString() );
82         }
83     }
84     ::rtl::OUString SAL_CALL getText(  ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
85     {
86         ::rtl::OUString sText;
87         try
88         {
89             xShapePropertySet->getPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("String") ) ) >>= sText;
90         }
91         catch ( css::uno::Exception& )
92         {
93             throw css::script::BasicErrorException( rtl::OUString(), css::uno::Reference< css::uno::XInterface >(), SbERR_METHOD_FAILED, rtl::OUString() );
94         }
95         return sText;
96     }
97 
98     css::uno::Reference< ov::excel::XCharacters > SAL_CALL Characters(  ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
99     {
100         // #FIXME #TODO the helperapi Characters implementation doesn't
101         // seem to do very much, need to know how the existing Characters
102         // impl ( that we use for Range ) can be reused
103         return  css::uno::Reference< ov::excel::XCharacters > ();
104     }
105 
106     void SAL_CALL setTop( double Top ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
107     {
108         oShapeHelper->setTop( Top );
109     }
110     double SAL_CALL getTop(  ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
111     {
112         return oShapeHelper->getTop();
113     }
114     void SAL_CALL setLeft( double Left ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
115     {
116         oShapeHelper->setLeft( Left );
117     }
118     double SAL_CALL getLeft(  ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
119     {
120         return oShapeHelper->getLeft();
121     }
122     void SAL_CALL setOrientation( ::sal_Int32 _nOrientation ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
123     {
124         try
125         {
126             xShapePropertySet->setPropertyValue(rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("TextRotation")), css::uno::makeAny(_nOrientation*100));
127         }
128         catch (css::uno::Exception& )
129         {
130             throw css::script::BasicErrorException( rtl::OUString(), css::uno::Reference< css::uno::XInterface >(), SbERR_METHOD_FAILED, rtl::OUString() );
131         }
132     }
133     ::sal_Int32 SAL_CALL getOrientation(  ) throw (css::script::BasicErrorException, css::uno::RuntimeException)
134     {
135         sal_Int32 nSOOrientation = 0;
136         try
137         {
138             xShapePropertySet->getPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("TextRotation"))) >>= nSOOrientation;
139         }
140         catch (css::uno::Exception& )
141         {
142             throw css::script::BasicErrorException( rtl::OUString(), css::uno::Reference< css::uno::XInterface >(), SbERR_METHOD_FAILED, rtl::OUString() );
143         }
144         return static_cast< sal_Int32 >(nSOOrientation / 100) ;
145     }
146 // XHelperInterface
147     rtl::OUString& getServiceImplName()
148     {
149         static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("TitleImpl") );
150         return sImplName;
151     }
152     css::uno::Sequence< rtl::OUString > getServiceNames()
153     {
154         static css::uno::Sequence< rtl::OUString > aServiceNames;
155         if ( aServiceNames.getLength() == 0 )
156         {
157             aServiceNames.realloc( 1 );
158             aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.XTitle" ) );
159         }
160         return aServiceNames;
161     }
162 };
163 #endif
164