1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: vbaworksheet.hxx,v $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
30 #ifndef SC_VBA_WORKSHEET_HXX
31 #define SC_VBA_WORKSHEET_HXX
33 #include <cppuhelper/implbase2.hxx>
34 #include <comphelper/unwrapargs.hxx>
36 #include <com/sun/star/sheet/XSpreadsheet.hpp>
37 #include <com/sun/star/script/XInvocation.hpp>
38 #include <ooo/vba/excel/XWorksheet.hpp>
39 #include <ooo/vba/excel/XComments.hpp>
40 #include <ooo/vba/excel/XRange.hpp>
41 #include <com/sun/star/lang/XEventListener.hpp>
42 #include <com/sun/star/uno/XComponentContext.hpp>
43 #include <com/sun/star/frame/XModel.hpp>
44 #include <ooo/vba/excel/XOutline.hpp>
45 #include <ooo/vba/excel/XPageSetup.hpp>
46 #include <ooo/vba/excel/XHPageBreaks.hpp>
47 #include <ooo/vba/excel/XVPageBreaks.hpp>
48 #include <ooo/vba/excel/XChartObjects.hpp>
49 #include <com/sun/star/container/XNamed.hpp>
51 #include <vbahelper/vbahelperinterface.hxx>
52 #include "address.hxx"
54 typedef InheritedHelperInterfaceImpl1
< ov::excel::XWorksheet
> WorksheetImpl_BASE
;
56 class ScVbaWorksheet
: public WorksheetImpl_BASE
58 css::uno::Reference
< css::sheet::XSpreadsheet
> mxSheet
;
59 css::uno::Reference
< css::frame::XModel
> mxModel
;
60 css::uno::Reference
< ov::excel::XChartObjects
> mxCharts
;
62 css::uno::Reference
< ov::excel::XWorksheet
> getSheetAtOffset(SCTAB offset
) throw (css::uno::RuntimeException
);
63 css::uno::Reference
< ov::excel::XRange
> getSheetRange() throw (css::uno::RuntimeException
);
65 css::uno::Reference
< css::container::XNameAccess
> getFormControls();
66 css::uno::Any
getControlShape( const rtl::OUString
& sName
);
69 ScVbaWorksheet( const css::uno::Reference
< ov::XHelperInterface
>& xParent
, const css::uno::Reference
< css::uno::XComponentContext
>& xContext
);
71 ScVbaWorksheet( const css::uno::Reference
< ov::XHelperInterface
>& xParent
,
72 const css::uno::Reference
< css::uno::XComponentContext
>& xContext
,
73 const css::uno::Reference
< css::sheet::XSpreadsheet
>& xSheet
,
74 const css::uno::Reference
< css::frame::XModel
>& xModel
)throw (css::uno::RuntimeException
) ;
75 ScVbaWorksheet( css::uno::Sequence
< css::uno::Any
> const& aArgs
, css::uno::Reference
< css::uno::XComponentContext
>const& xContext
) throw ( css::lang::IllegalArgumentException
);
77 virtual ~ScVbaWorksheet() {}
79 virtual css::uno::Reference
< css::frame::XModel
> getModel()
81 virtual css::uno::Reference
< css::sheet::XSpreadsheet
> getSheet()
85 virtual ::rtl::OUString SAL_CALL
getName() throw (css::uno::RuntimeException
);
86 virtual void SAL_CALL
setName( const ::rtl::OUString
&rName
) throw (css::uno::RuntimeException
);
87 virtual sal_Bool SAL_CALL
getVisible() throw (css::uno::RuntimeException
);
88 virtual void SAL_CALL
setVisible( sal_Bool bVisible
) throw (css::uno::RuntimeException
);
89 virtual ::sal_Int32 SAL_CALL
getStandardWidth() throw (css::uno::RuntimeException
);
90 virtual ::sal_Int32 SAL_CALL
getStandardHeight() throw (css::uno::RuntimeException
);
91 virtual ::sal_Bool SAL_CALL
getProtectionMode() throw (css::uno::RuntimeException
);
92 virtual ::sal_Bool SAL_CALL
getProtectContents() throw (css::uno::RuntimeException
);
93 virtual ::sal_Bool SAL_CALL
getProtectDrawingObjects() throw (css::uno::RuntimeException
);
94 virtual css::uno::Reference
< ov::excel::XRange
> SAL_CALL
getUsedRange() throw (css::uno::RuntimeException
) ;
95 virtual css::uno::Any SAL_CALL
ChartObjects( const css::uno::Any
& Index
) throw (css::uno::RuntimeException
);
96 virtual css::uno::Reference
< ov::excel::XOutline
> SAL_CALL
Outline( ) throw (css::uno::RuntimeException
);
97 virtual css::uno::Reference
< ov::excel::XPageSetup
> SAL_CALL
PageSetup( ) throw (css::uno::RuntimeException
);
98 virtual css::uno::Any SAL_CALL
HPageBreaks( const css::uno::Any
& aIndex
) throw (css::uno::RuntimeException
);
99 virtual css::uno::Any SAL_CALL
VPageBreaks( const css::uno::Any
& aIndex
) throw (css::uno::RuntimeException
);
100 virtual css::uno::Reference
< ov::excel::XWorksheet
> SAL_CALL
getNext() throw (css::uno::RuntimeException
);
101 virtual css::uno::Reference
< ov::excel::XWorksheet
> SAL_CALL
getPrevious() throw (css::uno::RuntimeException
);
102 virtual sal_Int16 SAL_CALL
getIndex() throw (css::uno::RuntimeException
);
103 virtual sal_Int32 SAL_CALL
getEnableSelection() throw (css::uno::RuntimeException
);
104 virtual void SAL_CALL
setEnableSelection( sal_Int32 nSelection
) throw (css::uno::RuntimeException
);
107 virtual void SAL_CALL
Activate() throw (css::uno::RuntimeException
);
108 virtual void SAL_CALL
Select() throw (css::uno::RuntimeException
);
109 virtual css::uno::Reference
< ov::excel::XRange
> SAL_CALL
Range( const css::uno::Any
& Cell1
, const css::uno::Any
& Cell2
) throw (css::uno::RuntimeException
);
110 virtual void SAL_CALL
Move( const css::uno::Any
& Before
, const css::uno::Any
& After
) throw (css::uno::RuntimeException
) ;
111 virtual void SAL_CALL
Copy( const css::uno::Any
& Before
, const css::uno::Any
& After
) throw (css::uno::RuntimeException
);
112 virtual void SAL_CALL
Paste( const css::uno::Any
& Destination
, const css::uno::Any
& Link
) throw (css::uno::RuntimeException
);
113 virtual void SAL_CALL
Delete( ) throw (css::uno::RuntimeException
);
114 virtual void SAL_CALL
Protect( const css::uno::Any
& Password
, const css::uno::Any
& DrawingObjects
, const css::uno::Any
& Contents
, const css::uno::Any
& Scenarios
, const css::uno::Any
& UserInterfaceOnly
) throw (css::uno::RuntimeException
);
115 virtual void SAL_CALL
Unprotect( const css::uno::Any
& Password
) throw (css::uno::RuntimeException
);
117 virtual void SAL_CALL
Calculate( ) throw (css::uno::RuntimeException
);
118 virtual void SAL_CALL
CheckSpelling( const css::uno::Any
& CustomDictionary
,const css::uno::Any
& IgnoreUppercase
,const css::uno::Any
& AlwaysSuggest
, const css::uno::Any
& SpellingLang
) throw (css::uno::RuntimeException
);
120 virtual css::uno::Reference
< ov::excel::XRange
> SAL_CALL
Cells( const css::uno::Any
&nRow
, const css::uno::Any
&nCol
) throw (css::uno::RuntimeException
);
121 virtual css::uno::Reference
< ov::excel::XRange
> SAL_CALL
Rows(const css::uno::Any
& aIndex
) throw (css::uno::RuntimeException
);
122 virtual css::uno::Reference
< ov::excel::XRange
> SAL_CALL
Columns(const css::uno::Any
& aIndex
) throw (css::uno::RuntimeException
);
124 virtual css::uno::Any SAL_CALL
Evaluate( const ::rtl::OUString
& Name
) throw (css::uno::RuntimeException
);
125 virtual css::uno::Any SAL_CALL
PivotTables( const css::uno::Any
& Index
) throw (css::uno::RuntimeException
);
126 virtual css::uno::Any SAL_CALL
Comments( const css::uno::Any
& Index
) throw (css::uno::RuntimeException
);
128 virtual css::uno::Any SAL_CALL
OLEObjects( const css::uno::Any
& Index
) throw (css::uno::RuntimeException
);
129 virtual css::uno::Any SAL_CALL
Shapes( const css::uno::Any
& aIndex
) throw (css::uno::RuntimeException
);
130 virtual void SAL_CALL
setEnableCalculation( ::sal_Bool EnableCalculation
) throw ( css::script::BasicErrorException
, css::uno::RuntimeException
);
131 virtual ::sal_Bool SAL_CALL
getEnableCalculation( ) throw (css::script::BasicErrorException
, css::uno::RuntimeException
);
132 virtual void SAL_CALL
ShowDataForm( ) throw (css::uno::RuntimeException
);
134 virtual css::uno::Reference
< css::beans::XIntrospectionAccess
> SAL_CALL
getIntrospection( ) throw (css::uno::RuntimeException
);
135 virtual css::uno::Any SAL_CALL
invoke( const ::rtl::OUString
& aFunctionName
, const css::uno::Sequence
< css::uno::Any
>& aParams
, css::uno::Sequence
< ::sal_Int16
>& aOutParamIndex
, css::uno::Sequence
< css::uno::Any
>& aOutParam
) throw (css::lang::IllegalArgumentException
, css::script::CannotConvertException
, css::reflection::InvocationTargetException
, css::uno::RuntimeException
);
136 virtual void SAL_CALL
setValue( const ::rtl::OUString
& aPropertyName
, const css::uno::Any
& aValue
) throw (css::beans::UnknownPropertyException
, css::script::CannotConvertException
, css::reflection::InvocationTargetException
, css::uno::RuntimeException
);
137 virtual css::uno::Any SAL_CALL
getValue( const ::rtl::OUString
& aPropertyName
) throw (css::beans::UnknownPropertyException
, css::uno::RuntimeException
);
138 virtual ::sal_Bool SAL_CALL
hasMethod( const ::rtl::OUString
& aName
) throw (css::uno::RuntimeException
);
139 virtual ::sal_Bool SAL_CALL
hasProperty( const ::rtl::OUString
& aName
) throw (css::uno::RuntimeException
);
141 virtual rtl::OUString SAL_CALL
getCodeName() throw (css::uno::RuntimeException
);
142 virtual void SAL_CALL
setCodeName( const rtl::OUString
& sCodeName
) throw (css::uno::RuntimeException
);
143 sal_Int16
getSheetID() throw (css::uno::RuntimeException
);
145 virtual void SAL_CALL
PrintOut( const css::uno::Any
& From
, const css::uno::Any
& To
, const css::uno::Any
& Copies
, const css::uno::Any
& Preview
, const css::uno::Any
& ActivePrinter
, const css::uno::Any
& PrintToFile
, const css::uno::Any
& Collate
, const css::uno::Any
& PrToFileName
, const css::uno::Any
& IgnorePrintAreas
) throw (css::uno::RuntimeException
);
147 virtual rtl::OUString
& getServiceImplName();
148 virtual css::uno::Sequence
<rtl::OUString
> getServiceNames();
151 #endif /* SC_VBA_WORKSHEET_HXX */