1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski #include "vbaformatcondition.hxx"
24*b1cdbd2cSJim Jagielski #include "vbaformatconditions.hxx"
25*b1cdbd2cSJim Jagielski #include <ooo/vba/excel/XlFormatConditionType.hpp>
26*b1cdbd2cSJim Jagielski 
27*b1cdbd2cSJim Jagielski using namespace ::ooo::vba;
28*b1cdbd2cSJim Jagielski using namespace ::com::sun::star;
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski ScVbaFormatConditions*
lcl_getScVbaFormatConditionsPtr(const uno::Reference<excel::XFormatConditions> & xFormatConditions)31*b1cdbd2cSJim Jagielski lcl_getScVbaFormatConditionsPtr( const uno::Reference< excel::XFormatConditions >& xFormatConditions ) throw ( script::BasicErrorException )
32*b1cdbd2cSJim Jagielski {
33*b1cdbd2cSJim Jagielski 	ScVbaFormatConditions* pFormatConditions = static_cast< ScVbaFormatConditions* >( xFormatConditions.get() );
34*b1cdbd2cSJim Jagielski 	if ( !pFormatConditions )
35*b1cdbd2cSJim Jagielski 		DebugHelper::exception(SbERR_METHOD_FAILED, rtl::OUString() );
36*b1cdbd2cSJim Jagielski 	return pFormatConditions;
37*b1cdbd2cSJim Jagielski }
ScVbaFormatCondition(const uno::Reference<XHelperInterface> & xParent,const uno::Reference<uno::XComponentContext> & xContext,const uno::Reference<sheet::XSheetConditionalEntry> & _xSheetConditionalEntry,const uno::Reference<excel::XStyle> & _xStyle,const uno::Reference<excel::XFormatConditions> & _xFormatConditions,const uno::Reference<css::beans::XPropertySet> & _xPropertySet)38*b1cdbd2cSJim Jagielski ScVbaFormatCondition::ScVbaFormatCondition(  const uno::Reference< XHelperInterface >& xParent, const uno::Reference< uno::XComponentContext > & xContext, const uno::Reference< sheet::XSheetConditionalEntry >& _xSheetConditionalEntry, const uno::Reference< excel::XStyle >& _xStyle, const uno::Reference< excel::XFormatConditions >& _xFormatConditions, const uno::Reference< css::beans::XPropertySet >& _xPropertySet ) throw ( css::uno::RuntimeException ) : ScVbaFormatCondition_BASE( xParent, xContext, uno::Reference< sheet::XSheetCondition >( _xSheetConditionalEntry, css::uno::UNO_QUERY_THROW ) ), moFormatConditions( _xFormatConditions ), mxStyle( _xStyle ), mxParentRangePropertySet( _xPropertySet )
39*b1cdbd2cSJim Jagielski {
40*b1cdbd2cSJim Jagielski         mxSheetConditionalEntries = lcl_getScVbaFormatConditionsPtr( moFormatConditions )->getSheetConditionalEntries();
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski         mxSheetConditionalEntry = _xSheetConditionalEntry;
43*b1cdbd2cSJim Jagielski         msStyleName = mxStyle->getName();
44*b1cdbd2cSJim Jagielski }
45*b1cdbd2cSJim Jagielski 
46*b1cdbd2cSJim Jagielski 
47*b1cdbd2cSJim Jagielski void SAL_CALL
Delete()48*b1cdbd2cSJim Jagielski ScVbaFormatCondition::Delete(  ) throw (script::BasicErrorException, uno::RuntimeException)
49*b1cdbd2cSJim Jagielski {
50*b1cdbd2cSJim Jagielski 	ScVbaFormatConditions* pFormatConditions = lcl_getScVbaFormatConditionsPtr( moFormatConditions );
51*b1cdbd2cSJim Jagielski 	pFormatConditions->removeFormatCondition(msStyleName, sal_True);
52*b1cdbd2cSJim Jagielski         notifyRange();
53*b1cdbd2cSJim Jagielski }
54*b1cdbd2cSJim Jagielski 
55*b1cdbd2cSJim Jagielski void SAL_CALL
Modify(::sal_Int32 _nType,const uno::Any & _aOperator,const uno::Any & _aFormula1,const uno::Any & _aFormula2)56*b1cdbd2cSJim Jagielski ScVbaFormatCondition::Modify( ::sal_Int32 _nType, const uno::Any& _aOperator, const uno::Any& _aFormula1, const uno::Any& _aFormula2 ) throw (script::BasicErrorException, uno::RuntimeException)
57*b1cdbd2cSJim Jagielski {
58*b1cdbd2cSJim Jagielski 	try
59*b1cdbd2cSJim Jagielski 	{
60*b1cdbd2cSJim Jagielski 		ScVbaFormatConditions* pFormatConditions = lcl_getScVbaFormatConditionsPtr( moFormatConditions );
61*b1cdbd2cSJim Jagielski 		pFormatConditions->removeFormatCondition(msStyleName, sal_False);
62*b1cdbd2cSJim Jagielski 		pFormatConditions->Add(_nType, _aOperator, _aFormula1, _aFormula2, mxStyle);
63*b1cdbd2cSJim Jagielski 	}
64*b1cdbd2cSJim Jagielski 	catch (uno::Exception& )
65*b1cdbd2cSJim Jagielski 	{
66*b1cdbd2cSJim Jagielski 		DebugHelper::exception(SbERR_METHOD_FAILED, rtl::OUString() );
67*b1cdbd2cSJim Jagielski 	}
68*b1cdbd2cSJim Jagielski }
69*b1cdbd2cSJim Jagielski 
70*b1cdbd2cSJim Jagielski uno::Reference< excel::XInterior > SAL_CALL
Interior()71*b1cdbd2cSJim Jagielski ScVbaFormatCondition::Interior(  ) throw (script::BasicErrorException, uno::RuntimeException)
72*b1cdbd2cSJim Jagielski {
73*b1cdbd2cSJim Jagielski 	return mxStyle->Interior();
74*b1cdbd2cSJim Jagielski }
75*b1cdbd2cSJim Jagielski 
76*b1cdbd2cSJim Jagielski uno::Reference< excel::XFont > SAL_CALL
Font()77*b1cdbd2cSJim Jagielski ScVbaFormatCondition::Font(  ) throw (script::BasicErrorException, uno::RuntimeException)
78*b1cdbd2cSJim Jagielski {
79*b1cdbd2cSJim Jagielski 	return mxStyle->Font();
80*b1cdbd2cSJim Jagielski }
81*b1cdbd2cSJim Jagielski uno::Any SAL_CALL
Borders(const uno::Any & Index)82*b1cdbd2cSJim Jagielski ScVbaFormatCondition::Borders( const uno::Any& Index ) throw (script::BasicErrorException, uno::RuntimeException)
83*b1cdbd2cSJim Jagielski { return mxStyle->Borders( Index );
84*b1cdbd2cSJim Jagielski }
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski sheet::ConditionOperator
retrieveAPIType(sal_Int32 _nVBAType,const uno::Reference<sheet::XSheetCondition> & _xSheetCondition)87*b1cdbd2cSJim Jagielski ScVbaFormatCondition::retrieveAPIType(sal_Int32 _nVBAType, const uno::Reference< sheet::XSheetCondition >& _xSheetCondition ) throw ( script::BasicErrorException )
88*b1cdbd2cSJim Jagielski {
89*b1cdbd2cSJim Jagielski 	sheet::ConditionOperator aAPIType = sheet::ConditionOperator_NONE;
90*b1cdbd2cSJim Jagielski 	switch (_nVBAType)
91*b1cdbd2cSJim Jagielski 	{
92*b1cdbd2cSJim Jagielski 		case excel::XlFormatConditionType::xlExpression:
93*b1cdbd2cSJim Jagielski 			aAPIType = sheet::ConditionOperator_FORMULA;
94*b1cdbd2cSJim Jagielski 			break;
95*b1cdbd2cSJim Jagielski 		case excel::XlFormatConditionType::xlCellValue:
96*b1cdbd2cSJim Jagielski 			if ( _xSheetCondition.is() && (_xSheetCondition->getOperator() == sheet::ConditionOperator_FORMULA ) )
97*b1cdbd2cSJim Jagielski 				aAPIType = sheet::ConditionOperator_NONE;
98*b1cdbd2cSJim Jagielski 			break;
99*b1cdbd2cSJim Jagielski 		default:
100*b1cdbd2cSJim Jagielski 			DebugHelper::exception(SbERR_METHOD_FAILED, rtl::OUString() );
101*b1cdbd2cSJim Jagielski 	}
102*b1cdbd2cSJim Jagielski 	return aAPIType;
103*b1cdbd2cSJim Jagielski }
104*b1cdbd2cSJim Jagielski 
105*b1cdbd2cSJim Jagielski void
setFormula1(const uno::Any & _aFormula1)106*b1cdbd2cSJim Jagielski ScVbaFormatCondition::setFormula1( const uno::Any& _aFormula1) throw ( script::BasicErrorException )
107*b1cdbd2cSJim Jagielski {
108*b1cdbd2cSJim Jagielski 	// getA1Formula *SHOULD* detect whether the formula is r1c1 or A1 syntax
109*b1cdbd2cSJim Jagielski 	// and if R1C1 convert to A1
110*b1cdbd2cSJim Jagielski 	ScVbaFormatCondition_BASE::setFormula1( uno::makeAny( lcl_getScVbaFormatConditionsPtr( moFormatConditions )->getA1Formula(_aFormula1) ) );
111*b1cdbd2cSJim Jagielski }
112*b1cdbd2cSJim Jagielski 
113*b1cdbd2cSJim Jagielski void
setFormula2(const uno::Any & _aFormula2)114*b1cdbd2cSJim Jagielski ScVbaFormatCondition::setFormula2( const uno::Any& _aFormula2) throw ( script::BasicErrorException )
115*b1cdbd2cSJim Jagielski {
116*b1cdbd2cSJim Jagielski 	ScVbaFormatCondition_BASE::setFormula1( uno::makeAny( lcl_getScVbaFormatConditionsPtr( moFormatConditions )->getA1Formula(_aFormula2)) );
117*b1cdbd2cSJim Jagielski }
118*b1cdbd2cSJim Jagielski 
119*b1cdbd2cSJim Jagielski ::sal_Int32 SAL_CALL
Type()120*b1cdbd2cSJim Jagielski ScVbaFormatCondition::Type(  ) throw ( script::BasicErrorException, uno::RuntimeException )
121*b1cdbd2cSJim Jagielski {
122*b1cdbd2cSJim Jagielski 	sal_Int32 nReturnType = 0;
123*b1cdbd2cSJim Jagielski 	if ( mxSheetCondition->getOperator() == sheet::ConditionOperator_FORMULA)
124*b1cdbd2cSJim Jagielski 		nReturnType = excel::XlFormatConditionType::xlExpression;
125*b1cdbd2cSJim Jagielski 	else
126*b1cdbd2cSJim Jagielski 		nReturnType = excel::XlFormatConditionType::xlCellValue;
127*b1cdbd2cSJim Jagielski 	return nReturnType;
128*b1cdbd2cSJim Jagielski }
129*b1cdbd2cSJim Jagielski 
130*b1cdbd2cSJim Jagielski 
131*b1cdbd2cSJim Jagielski ::sal_Int32
Operator(sal_Bool bVal)132*b1cdbd2cSJim Jagielski ScVbaFormatCondition::Operator( sal_Bool bVal ) throw (script::BasicErrorException )
133*b1cdbd2cSJim Jagielski {
134*b1cdbd2cSJim Jagielski 	return ScVbaFormatCondition_BASE::Operator( bVal );
135*b1cdbd2cSJim Jagielski }
136*b1cdbd2cSJim Jagielski ::sal_Int32 SAL_CALL
Operator()137*b1cdbd2cSJim Jagielski ScVbaFormatCondition::Operator(  ) throw (script::BasicErrorException, uno::RuntimeException)
138*b1cdbd2cSJim Jagielski {
139*b1cdbd2cSJim Jagielski 	return ScVbaFormatCondition_BASE::Operator( sal_True );
140*b1cdbd2cSJim Jagielski }
141*b1cdbd2cSJim Jagielski 
142*b1cdbd2cSJim Jagielski void
notifyRange()143*b1cdbd2cSJim Jagielski ScVbaFormatCondition::notifyRange() throw ( script::BasicErrorException )
144*b1cdbd2cSJim Jagielski {
145*b1cdbd2cSJim Jagielski 	try
146*b1cdbd2cSJim Jagielski 	{
147*b1cdbd2cSJim Jagielski 		mxParentRangePropertySet->setPropertyValue( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ConditionalFormat") ), uno::makeAny( mxSheetConditionalEntries) );
148*b1cdbd2cSJim Jagielski     }
149*b1cdbd2cSJim Jagielski 	catch (uno::Exception& )
150*b1cdbd2cSJim Jagielski 	{
151*b1cdbd2cSJim Jagielski         DebugHelper::exception(SbERR_METHOD_FAILED, rtl::OUString() );
152*b1cdbd2cSJim Jagielski     }
153*b1cdbd2cSJim Jagielski }
154*b1cdbd2cSJim Jagielski 
155*b1cdbd2cSJim Jagielski rtl::OUString&
getServiceImplName()156*b1cdbd2cSJim Jagielski ScVbaFormatCondition::getServiceImplName()
157*b1cdbd2cSJim Jagielski {
158*b1cdbd2cSJim Jagielski 	static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("ScVbaFormatCondition") );
159*b1cdbd2cSJim Jagielski 	return sImplName;
160*b1cdbd2cSJim Jagielski }
161*b1cdbd2cSJim Jagielski 
162*b1cdbd2cSJim Jagielski uno::Sequence< rtl::OUString >
getServiceNames()163*b1cdbd2cSJim Jagielski ScVbaFormatCondition::getServiceNames()
164*b1cdbd2cSJim Jagielski {
165*b1cdbd2cSJim Jagielski 	static uno::Sequence< rtl::OUString > aServiceNames;
166*b1cdbd2cSJim Jagielski 	if ( aServiceNames.getLength() == 0 )
167*b1cdbd2cSJim Jagielski 	{
168*b1cdbd2cSJim Jagielski 		aServiceNames.realloc( 1 );
169*b1cdbd2cSJim Jagielski 		aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.excel.FormatCondition" ) );
170*b1cdbd2cSJim Jagielski 	}
171*b1cdbd2cSJim Jagielski 	return aServiceNames;
172*b1cdbd2cSJim Jagielski }
173