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 #include "precompiled_reportdesign.hxx"
24 #include "conditionupdater.hxx"
25 #include "reportformula.hxx"
26 
27 /** === begin UNO includes === **/
28 #include <com/sun/star/report/XFormatCondition.hpp>
29 /** === end UNO includes === **/
30 
31 #include <tools/diagnose_ex.h>
32 
33 //........................................................................
34 namespace rptui
35 {
36 //........................................................................
37 
38 	/** === begin UNO using === **/
39     using ::com::sun::star::beans::PropertyChangeEvent;
40     using ::com::sun::star::uno::Reference;
41     using ::com::sun::star::report::XReportControlModel;
42     using ::com::sun::star::uno::UNO_QUERY;
43     using ::com::sun::star::report::XFormatCondition;
44     using ::com::sun::star::uno::UNO_QUERY_THROW;
45     using ::com::sun::star::uno::Exception;
46 	/** === end UNO using === **/
47 
48 	//====================================================================
49 	//= ConditionUpdater
50 	//====================================================================
51 	//--------------------------------------------------------------------
ConditionUpdater()52     ConditionUpdater::ConditionUpdater()
53     {
54     }
55 
56 	//--------------------------------------------------------------------
~ConditionUpdater()57     ConditionUpdater::~ConditionUpdater()
58     {
59     }
60 
61 	//--------------------------------------------------------------------
notifyPropertyChange(const PropertyChangeEvent & _rEvent)62     void ConditionUpdater::notifyPropertyChange( const PropertyChangeEvent& _rEvent )
63     {
64         if ( !impl_lateInit_nothrow() )
65             return;
66 
67         Reference< XReportControlModel > xRptControlModel( _rEvent.Source, UNO_QUERY );
68         if ( xRptControlModel.is() && _rEvent.PropertyName.equalsAscii( "DataField" ) )
69         {
70             ::rtl::OUString sOldDataSource, sNewDataSource;
71             OSL_VERIFY( _rEvent.OldValue >>= sOldDataSource );
72             OSL_VERIFY( _rEvent.NewValue >>= sNewDataSource );
73             impl_adjustFormatConditions_nothrow( xRptControlModel, sOldDataSource, sNewDataSource );
74         }
75     }
76 
77     //--------------------------------------------------------------------
impl_lateInit_nothrow()78     bool ConditionUpdater::impl_lateInit_nothrow()
79     {
80         if ( !m_aConditionalExpressions.empty() )
81             return true;
82 
83         ConditionalExpressionFactory::getKnownConditionalExpressions( m_aConditionalExpressions );
84         return true;
85     }
86 
87     //--------------------------------------------------------------------
impl_adjustFormatConditions_nothrow(const Reference<XReportControlModel> & _rxRptControlModel,const::rtl::OUString & _rOldDataSource,const::rtl::OUString & _rNewDataSource)88     void ConditionUpdater::impl_adjustFormatConditions_nothrow( const Reference< XReportControlModel >& _rxRptControlModel,
89         const ::rtl::OUString& _rOldDataSource, const ::rtl::OUString& _rNewDataSource )
90     {
91         try
92         {
93             ReportFormula aOldContentFormula( _rOldDataSource );
94             ::rtl::OUString sOldUnprefixed( aOldContentFormula.getBracketedFieldOrExpression() );
95             ReportFormula aNewContentFormula( _rNewDataSource );
96             ::rtl::OUString sNewUnprefixed( aNewContentFormula.getBracketedFieldOrExpression() );
97 
98             sal_Int32 nCount( _rxRptControlModel->getCount() );
99             Reference< XFormatCondition > xFormatCondition;
100             ::rtl::OUString sFormulaExpression, sLHS, sRHS;
101             for ( sal_Int32 i=0; i<nCount; ++i )
102             {
103                 xFormatCondition.set( _rxRptControlModel->getByIndex( i ), UNO_QUERY_THROW );
104                 ReportFormula aFormula( xFormatCondition->getFormula() );
105                 sFormulaExpression = aFormula.getExpression();
106 
107                 for (   ConditionalExpressions::const_iterator loop = m_aConditionalExpressions.begin();
108                         loop != m_aConditionalExpressions.end();
109                         ++loop
110                     )
111                 {
112                     if ( !loop->second->matchExpression( sFormulaExpression, sOldUnprefixed, sLHS, sRHS ) )
113                         continue;
114 
115                     // the expression matches -> translate it to the new data source of the report control model
116                     sFormulaExpression = loop->second->assembleExpression( sNewUnprefixed, sLHS, sRHS );
117                     aFormula = ReportFormula( ReportFormula::Expression, sFormulaExpression );
118                     xFormatCondition->setFormula( aFormula.getCompleteFormula() );
119                     break;
120                 }
121             }
122         }
123         catch( const Exception& )
124         {
125         	DBG_UNHANDLED_EXCEPTION();
126         }
127     }
128 
129 //........................................................................
130 } // namespace rptui
131 //........................................................................
132