1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 #ifndef SC_VBA_FORMATCONDITIONS_HXX
24 #define SC_VBA_FORMATCONDITIONS_HXX
25 #include <ooo/vba/excel/XFormatConditions.hpp>
26 #include <ooo/vba/excel/XStyles.hpp>
27 #include <ooo/vba/excel/XRange.hpp>
28 #include <com/sun/star/beans/XPropertySet.hpp>
29 #include <com/sun/star/table/CellAddress.hpp>
30 #include <com/sun/star/sheet/XSheetConditionalEntries.hpp>
31 #include <vbahelper/vbacollectionimpl.hxx>
32 
33 typedef CollTestImplHelper< ov::excel::XFormatConditions > ScVbaFormatConditions_BASE;
34 class ScVbaFormatConditions: public ScVbaFormatConditions_BASE
35 {
36 	css::table::CellAddress maCellAddress;
37 	css::uno::Reference< css::sheet::XSheetConditionalEntries > mxSheetConditionalEntries;
38 	css::uno::Reference< ov::excel::XStyles > mxStyles;
39 	css::uno::Reference< ov::excel::XRange > mxRangeParent;
40 	css::uno::Reference< css::beans::XPropertySet > mxParentRangePropertySet;
41 public:
42 	ScVbaFormatConditions( const css::uno::Reference< ov::XHelperInterface >& xParent, const css::uno::Reference< css::uno::XComponentContext > & xContext, const css::uno::Reference< css::sheet::XSheetConditionalEntries >&, const css::uno::Reference< css::frame::XModel >&  );
43 	void notifyRange() throw ( css::script::BasicErrorException );
44 	virtual css::uno::Reference< ov::excel::XFormatCondition > Add( ::sal_Int32 Type, const css::uno::Any& Operator, const css::uno::Any& Formula1, const css::uno::Any& Formula2, const css::uno::Reference< ov::excel::XStyle >& _xCalcStyle ) throw (css::script::BasicErrorException, css::uno::RuntimeException);
45 	rtl::OUString getA1Formula(const css::uno::Any& _aFormula) throw ( css::script::BasicErrorException );
46 	rtl::OUString getStyleName();
47 	void removeFormatCondition( const rtl::OUString& _sStyleName, sal_Bool _bRemoveStyle) throw ( css::script::BasicErrorException );
getSheetConditionalEntries()48 	css::uno::Reference< css::sheet::XSheetConditionalEntries > getSheetConditionalEntries() { return mxSheetConditionalEntries; }
49 	// XFormatConditions
50 	virtual void SAL_CALL Delete(  ) throw (css::script::BasicErrorException, css::uno::RuntimeException);
51 	virtual css::uno::Reference< ov::excel::XFormatCondition > SAL_CALL Add( ::sal_Int32 Type, const css::uno::Any& Operator, const css::uno::Any& Formula1, const css::uno::Any& Formula2 ) throw (css::script::BasicErrorException, css::uno::RuntimeException);
52 	// XEnumerationAccess
53 	virtual css::uno::Type SAL_CALL getElementType() throw (css::uno::RuntimeException);
54 	virtual css::uno::Reference< css::container::XEnumeration > SAL_CALL createEnumeration() throw (css::uno::RuntimeException);
55 	virtual css::uno::Any createCollectionObject(const css::uno::Any&);
56 	// XHelperInterface
57 	virtual rtl::OUString& getServiceImplName();
58 	virtual css::uno::Sequence<rtl::OUString> getServiceNames();
59 };
60 
61 #endif //SC_VBA_AXES_HXX
62