diff options
author | Palenik Mihály <palenik.mihaly@gmail.com> | 2014-07-03 20:35:20 +0200 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2014-07-08 16:14:45 +0100 |
commit | 554a61317267cc364b0bf53131db1be07e035cfb (patch) | |
tree | da6ba68132f92432fedf2fd278928ee92ef7e775 /reportdesign/source | |
parent | 2fa900c7c3eb52049f10df195eb58c07b17aa54f (diff) |
Convert RID_CONDFORMAT to .ui
Change-Id: I23ac6a7328a43c2fb63f2f804f6718f64e73eb8e
Diffstat (limited to 'reportdesign/source')
-rw-r--r-- | reportdesign/source/ui/dlg/CondFormat.cxx | 113 | ||||
-rw-r--r-- | reportdesign/source/ui/dlg/CondFormat.hrc | 19 | ||||
-rw-r--r-- | reportdesign/source/ui/dlg/CondFormat.src | 215 | ||||
-rw-r--r-- | reportdesign/source/ui/dlg/Condition.cxx | 380 | ||||
-rw-r--r-- | reportdesign/source/ui/dlg/Condition.hxx | 63 | ||||
-rw-r--r-- | reportdesign/source/ui/inc/CondFormat.hxx | 17 |
6 files changed, 209 insertions, 598 deletions
diff --git a/reportdesign/source/ui/dlg/CondFormat.cxx b/reportdesign/source/ui/dlg/CondFormat.cxx index 706f2d65f349..a687b142ab09 100644 --- a/reportdesign/source/ui/dlg/CondFormat.cxx +++ b/reportdesign/source/ui/dlg/CondFormat.cxx @@ -80,40 +80,57 @@ namespace rptui } }; + void ConditionalFormattingDialog::impl_setPrefHeight(bool bFirst) + { + if (!m_bConstructed && !bFirst) + return; - // class ConditionalFormattingDialog + //allow dialog to resize itself + size_t nCount = impl_getConditionCount(); + if (nCount) + { + long nHeight = m_aConditions[0]->get_preferred_size().Height(); + size_t nVisibleConditions = ::std::min(nCount, MAX_CONDITIONS); + nHeight *= nVisibleConditions; + if (nHeight != m_pConditionPlayground->get_height_request()) + { + m_pConditionPlayground->set_height_request(nHeight); + if (!isCalculatingInitialLayoutSize() && !bFirst) + setOptimalLayoutSize(); + } + } + } + // class ConditionalFormattingDialog ConditionalFormattingDialog::ConditionalFormattingDialog( Window* _pParent, const Reference< XReportControlModel >& _rxFormatConditions, ::rptui::OReportController& _rController ) - :ModalDialog( _pParent, ModuleRes(RID_CONDFORMAT) ) - ,m_aConditionPlayground( this, ModuleRes( WND_COND_PLAYGROUND ) ) - ,m_aSeparator(this, ModuleRes(FL_SEPARATOR1)) - ,m_aPB_OK(this, ModuleRes(PB_OK)) - ,m_aPB_CANCEL(this, ModuleRes(PB_CANCEL)) - ,m_aPB_Help(this, ModuleRes(PB_HELP)) - ,m_aCondScroll( this, ModuleRes( SB_ALL_CONDITIONS ) ) + :ModalDialog( _pParent, "CondFormat", "modules/dbreport/ui/condformatdialog.ui" ) ,m_rController( _rController ) ,m_xFormatConditions( _rxFormatConditions ) ,m_bDeletingCondition( false ) + ,m_bConstructed( false ) { + get(m_pConditionPlayground, "condPlaygroundDrawingarea"); + get(m_pCondScroll, "condScrollbar"); + OSL_ENSURE( m_xFormatConditions.is(), "ConditionalFormattingDialog::ConditionalFormattingDialog: ReportControlModel is NULL -> Prepare for GPF!" ); m_xCopy.set( m_xFormatConditions->createClone(), UNO_QUERY_THROW ); - m_aCondScroll.SetScrollHdl( LINK( this, ConditionalFormattingDialog, OnScroll ) ); + m_pCondScroll->SetScrollHdl( LINK( this, ConditionalFormattingDialog, OnScroll ) ); impl_initializeConditions(); - FreeResource(); - } + impl_setPrefHeight(true); + m_bConstructed = true; + } ConditionalFormattingDialog::~ConditionalFormattingDialog() { m_aConditions.clear(); } - void ConditionalFormattingDialog::impl_updateConditionIndicies() { sal_Int32 nIndex = 0; @@ -126,18 +143,18 @@ namespace rptui } } - void ConditionalFormattingDialog::impl_conditionCountChanged() { if ( m_aConditions.empty() ) impl_addCondition_nothrow( 0 ); + impl_setPrefHeight(false); + impl_updateScrollBarRange(); impl_updateConditionIndicies(); impl_layoutAll(); } - void ConditionalFormattingDialog::addCondition( size_t _nAddAfterIndex ) { OSL_PRECOND( _nAddAfterIndex < impl_getConditionCount(), "ConditionalFormattingDialog::addCondition: illegal condition index!" ); @@ -164,11 +181,9 @@ namespace rptui ::comphelper::copyProperties(m_xCopy.get(),xCond.get()); m_xCopy->insertByIndex( _nNewCondIndex, makeAny( xCond ) ); - ConditionPtr pCon( new Condition( &m_aConditionPlayground, *this, m_rController ) ); + ConditionPtr pCon( new Condition( m_pConditionPlayground, *this, m_rController ) ); pCon->setCondition( xCond ); m_aConditions.insert( m_aConditions.begin() + _nNewCondIndex, pCon ); - - pCon->setPosSizePixel( 0, 0, impl_getConditionWidth(), 0, WINDOW_POSSIZE_WIDTH ); } catch( const Exception& ) { @@ -276,29 +291,18 @@ namespace rptui impl_updateConditionIndicies(); // re-layout all conditions - Point aDummy; - impl_layoutConditions( aDummy ); + impl_layoutConditions(); // ensure the moved condition is visible impl_ensureConditionVisible( nNewConditionIndex ); } - - long ConditionalFormattingDialog::impl_getConditionWidth() const - { - const Size aDialogSize( GetOutputSizePixel() ); - const Size aScrollBarWidth( LogicToPixel( Size( SCROLLBAR_WIDTH + UNRELATED_CONTROLS, 0 ), MAP_APPFONT ) ); - return aDialogSize.Width() - aScrollBarWidth.Width(); - } - - IMPL_LINK( ConditionalFormattingDialog, OnScroll, ScrollBar*, /*_pNotInterestedIn*/ ) { size_t nFirstCondIndex( impl_getFirstVisibleConditionIndex() ); size_t nFocusCondIndex = impl_getFocusedConditionIndex( nFirstCondIndex ); - Point aDummy; - impl_layoutConditions( aDummy ); + impl_layoutConditions(); if ( nFocusCondIndex < nFirstCondIndex ) impl_focusCondition( nFirstCondIndex ); @@ -308,15 +312,15 @@ namespace rptui return 0; } - - void ConditionalFormattingDialog::impl_layoutConditions( Point& _out_rBelowLastVisible ) + void ConditionalFormattingDialog::impl_layoutConditions() { +#if 0 // position the condition's playground long nConditionWidth = impl_getConditionWidth(); long nConditionHeight = LogicToPixel( Size( 0, CONDITION_HEIGHT ), MAP_APPFONT ).Height(); size_t nVisibleConditions = ::std::min( impl_getConditionCount(), MAX_CONDITIONS ); Size aPlaygroundSize( nConditionWidth, nVisibleConditions * nConditionHeight ); - m_aConditionPlayground.SetSizePixel( aPlaygroundSize ); + m_pConditionPlayground->SetSizePixel( aPlaygroundSize ); _out_rBelowLastVisible = Point( 0, aPlaygroundSize.Height() ); // position the single conditions @@ -329,34 +333,18 @@ namespace rptui (*cond)->setPosSizePixel( aConditionPos.X(), aConditionPos.Y(), nConditionWidth, nConditionHeight ); aConditionPos.Move( 0, nConditionHeight ); } +#endif } - void ConditionalFormattingDialog::impl_layoutAll() { // condition's positions - Point aPos; - impl_layoutConditions( aPos ); + impl_layoutConditions(); - // scrollbar size and visibility - m_aCondScroll.setPosSizePixel( 0, 0, 0, aPos.Y(), WINDOW_POSSIZE_HEIGHT ); + // scrollbar visibility if ( !impl_needScrollBar() ) // normalize the position, so it can, in all situations, be used as top index - m_aCondScroll.SetThumbPos( 0 ); - - // the separator and the buttons below it - aPos += LogicToPixel( Point( 0 , RELATED_CONTROLS ), MAP_APPFONT ); - m_aSeparator.setPosSizePixel( 0, aPos.Y(), 0, 0, WINDOW_POSSIZE_Y ); - - aPos += LogicToPixel( Point( 0 , UNRELATED_CONTROLS ), MAP_APPFONT ); - Window* pWindows[] = { &m_aPB_OK, &m_aPB_CANCEL, &m_aPB_Help }; - for ( size_t i= 0; i < sizeof(pWindows)/sizeof(pWindows[0]); ++i ) - { - pWindows[i]->setPosSizePixel( 0, aPos.Y(), 0, 0, WINDOW_POSSIZE_Y ); - } - - aPos += LogicToPixel( Point( 0, BUTTON_HEIGHT + RELATED_CONTROLS ), MAP_APPFONT ); - setPosSizePixel( 0, 0, 0, aPos.Y(), WINDOW_POSSIZE_HEIGHT ); + m_pCondScroll->SetThumbPos( 0 ); } void ConditionalFormattingDialog::impl_initializeConditions() @@ -366,7 +354,7 @@ namespace rptui sal_Int32 nCount = m_xCopy->getCount(); for ( sal_Int32 i = 0; i < nCount ; ++i ) { - ConditionPtr pCon( new Condition( &m_aConditionPlayground, *this, m_rController ) ); + ConditionPtr pCon( new Condition( m_pConditionPlayground, *this, m_rController ) ); Reference< XFormatCondition > xCond( m_xCopy->getByIndex(i), UNO_QUERY ); pCon->setCondition( xCond ); pCon->updateToolbar( xCond.get() ); @@ -381,7 +369,6 @@ namespace rptui impl_conditionCountChanged(); } - void ConditionalFormattingDialog::applyCommand( size_t _nCondIndex, sal_uInt16 _nCommandId, const ::Color _aColor ) { OSL_PRECOND( _nCommandId, "ConditionalFormattingDialog::applyCommand: illegal command id!" ); @@ -527,13 +514,13 @@ namespace rptui const Window* pPlaygroundCandidate = pConditionCandidate ? pConditionCandidate->GetParent() : NULL; while ( ( pPlaygroundCandidate ) && ( pPlaygroundCandidate != this ) - && ( pPlaygroundCandidate != &m_aConditionPlayground ) + && ( pPlaygroundCandidate != m_pConditionPlayground ) ) { pConditionCandidate = pConditionCandidate->GetParent(); pPlaygroundCandidate = pConditionCandidate ? pConditionCandidate->GetParent() : NULL; } - if ( pPlaygroundCandidate == &m_aConditionPlayground ) + if ( pPlaygroundCandidate == m_pConditionPlayground ) { impl_ensureConditionVisible( dynamic_cast< const Condition& >( *pConditionCandidate ).getConditionIndex() ); } @@ -547,7 +534,7 @@ namespace rptui size_t ConditionalFormattingDialog::impl_getFirstVisibleConditionIndex() const { - return (size_t)m_aCondScroll.GetThumbPos(); + return (size_t)m_pCondScroll->GetThumbPos(); } @@ -576,9 +563,9 @@ namespace rptui { long nMax = ( impl_getConditionCount() > MAX_CONDITIONS ) ? impl_getConditionCount() - MAX_CONDITIONS + 1 : 0; - m_aCondScroll.SetRangeMin( 0 ); - m_aCondScroll.SetRangeMax( nMax ); - m_aCondScroll.SetVisibleSize( 1 ); + m_pCondScroll->SetRangeMin( 0 ); + m_pCondScroll->SetRangeMax( nMax ); + m_pCondScroll->SetVisibleSize( 1 ); } @@ -586,8 +573,8 @@ namespace rptui { OSL_PRECOND( _nTopCondIndex + MAX_CONDITIONS <= impl_getConditionCount(), "ConditionalFormattingDialog::impl_scrollTo: illegal index!" ); - m_aCondScroll.SetThumbPos( _nTopCondIndex ); - OnScroll( &m_aCondScroll ); + m_pCondScroll->SetThumbPos( _nTopCondIndex ); + OnScroll( m_pCondScroll ); } diff --git a/reportdesign/source/ui/dlg/CondFormat.hrc b/reportdesign/source/ui/dlg/CondFormat.hrc index 515c2d0ee7bd..5d776ff9726b 100644 --- a/reportdesign/source/ui/dlg/CondFormat.hrc +++ b/reportdesign/source/ui/dlg/CondFormat.hrc @@ -35,25 +35,6 @@ #define IMAGE_BUTTON_WIDTH 12 #define IMAGE_BUTTON_HEIGHT 14 -#define FL_CONDITION_HEADER 2 -#define CRTL_FORMAT_PREVIEW 3 -#define TB_FORMAT 4 -#define LB_COND_TYPE 5 -#define LB_OP 6 -#define ED_CONDITION_LHS 7 -#define FT_AND 8 -#define PB_OK 9 -#define PB_CANCEL 10 -#define PB_HELP 11 -#define FL_SEPARATOR1 12 -#define ED_CONDITION_RHS 13 -#define SB_ALL_CONDITIONS 18 -#define WND_COND_PLAYGROUND 19 -#define BTN_MOVE_UP 20 -#define BTN_MOVE_DOWN 21 -#define BTN_ADD_CONDITION 22 -#define BTN_REMOVE_CONDITION 23 - #define ROW_0_POS ( RELATED_CONTROLS ) #define ROW_0_HEIGHT ( FIXEDTEXT_HEIGHT ) #define ROW_1_POS ( ROW_0_POS + ROW_0_HEIGHT + UNRELATED_CONTROLS ) diff --git a/reportdesign/source/ui/dlg/CondFormat.src b/reportdesign/source/ui/dlg/CondFormat.src index 688d27959636..5f933a8cc72a 100644 --- a/reportdesign/source/ui/dlg/CondFormat.src +++ b/reportdesign/source/ui/dlg/CondFormat.src @@ -21,220 +21,7 @@ #include "helpids.hrc" #include <svx/globlmn.hrc> #include "rptui_slotid.hrc" - -Control WIN_CONDITION -{ - Size = MAP_APPFONT ( CONDITION_WIDTH , CONDITION_HEIGHT ) ; - HelpId = HID_RPT_COND_DLG; - DialogControl = TRUE; - Hide = TRUE; - - FixedLine FL_CONDITION_HEADER - { - Pos = MAP_APPFONT ( RELATED_CONTROLS, ROW_0_POS ) ; - Size = MAP_APPFONT ( CONDITION_WIDTH - 2 * RELATED_CONTROLS, ROW_0_HEIGHT ) ; - }; - - ListBox LB_COND_TYPE - { - Pos = MAP_APPFONT ( UNRELATED_CONTROLS, ROW_1_POS ) ; - Size = MAP_APPFONT( COND_TYPE_WIDTH, 60 ); - Border = TRUE; - DropDown = TRUE; - TabStop = TRUE; - Sort = FALSE; - StringList [ en-US ] = - { - < "Field Value Is" ; Default ; > ; - < "Expression Is" ; Default ; > ; - }; - }; - - ListBox LB_OP - { - Pos = MAP_APPFONT ( UNRELATED_CONTROLS + COND_TYPE_WIDTH + UNRELATED_CONTROLS, ROW_1_POS ) ; - Size = MAP_APPFONT( COND_OP_WIDTH, 60 ); - Border = TRUE; - DropDown = TRUE; - TabStop = TRUE; - Sort = FALSE; - StringList [ en-US ] = - { - < "between" ; 0; > ; - < "not between" ; 1; > ; - < "equal to" ; 2; > ; - < "not equal to" ; 3; > ; - < "greater than" ; 4; > ; - < "less than" ; 5; > ; - < "greater than or equal to" ; 6; > ; - < "less than or equal to" ; 7; > ; - }; - }; - - Edit ED_CONDITION_LHS - { - Pos = MAP_APPFONT ( 3*UNRELATED_CONTROLS + COND_TYPE_WIDTH + COND_OP_WIDTH, ROW_1_POS ) ; - Size = MAP_APPFONT( EDIT_WIDTH, EDIT_HEIGHT ); - Border = TRUE; - TabStop = TRUE; - }; - - FixedText FT_AND - { - Pos = MAP_APPFONT ( 4*UNRELATED_CONTROLS + COND_TYPE_WIDTH + COND_OP_WIDTH + EDIT_WIDTH, - ROW_1_POS + ( FIXEDTEXT_HEIGHT - EDIT_HEIGHT ) / 2 ); - Size = MAP_APPFONT( OPERATOR_SEP_WIDTH , FIXEDTEXT_HEIGHT ); - Text [ en-US ] = "and"; - }; - - Edit ED_CONDITION_RHS - { - Pos = MAP_APPFONT ( 5*UNRELATED_CONTROLS + COND_TYPE_WIDTH + COND_OP_WIDTH + EDIT_WIDTH + OPERATOR_SEP_WIDTH, - ROW_1_POS ); - Size = MAP_APPFONT( EDIT_WIDTH, EDIT_HEIGHT ); - Border = TRUE; - TabStop = TRUE; - }; - - ImageButton BTN_MOVE_UP - { - Pos = MAP_APPFONT ( CONDITION_WIDTH - UNRELATED_CONTROLS - IMAGE_BUTTON_WIDTH, ROW_1_POS ) ; - Size = MAP_APPFONT ( IMAGE_BUTTON_WIDTH, IMAGE_BUTTON_HEIGHT ) ; - TabStop = TRUE ; - Symbol = IMAGEBUTTON_ARROW_UP ; - }; - - ImageButton BTN_MOVE_DOWN - { - Pos = MAP_APPFONT ( CONDITION_WIDTH - UNRELATED_CONTROLS - IMAGE_BUTTON_WIDTH, ROW_1_POS + IMAGE_BUTTON_HEIGHT + RELATED_CONTROLS ) ; - Size = MAP_APPFONT ( IMAGE_BUTTON_WIDTH, IMAGE_BUTTON_HEIGHT ) ; - TabStop = TRUE ; - Symbol = IMAGEBUTTON_ARROW_DOWN ; - }; - - ToolBox TB_FORMAT - { - Pos = MAP_APPFONT ( UNRELATED_CONTROLS + RELATED_CONTROLS, ROW_2_POS ) ; - ButtonType = BUTTON_SYMBOL; - Align = BOXALIGN_TOP; - HelpId = HID_RPT_CONDFORMAT_TB; - Customize = FALSE; - ItemList = - { - ToolBoxItem - { - ITEM_FORMAT_ATTR_CHAR_WEIGHT - Checkable = TRUE; - }; - ToolBoxItem - { - ITEM_FORMAT_ATTR_CHAR_POSTURE - Checkable = TRUE; - }; - ToolBoxItem - { - ITEM_FORMAT_ATTR_CHAR_UNDERLINE - Checkable = TRUE; - }; - ToolBoxItem - { - Type = TOOLBOXITEM_SEPARATOR; - }; - ToolBoxItem - { - ITEM_TOOLBAR_BACKGROUND_COLOR - DropDown = TRUE; - }; - ToolBoxItem - { - ITEM_TOOLBAR_ATTR_CHAR_COLOR - Identifier = SID_ATTR_CHAR_COLOR2; - Command = ".uno:FontColor"; - }; - ToolBoxItem - { - ITEM_FORMAT_CHAR_DLG - }; - }; - }; - - Window CRTL_FORMAT_PREVIEW - { - Pos = MAP_APPFONT ( 2*UNRELATED_CONTROLS, ROW_2_POS ) ; - Size = MAP_APPFONT ( CONDITION_WIDTH - UNRELATED_CONTROLS, ROW_2_HEIGHT ) ; - Border = TRUE ; - HelpId = HID_RPT_CRTL_FORMAT_PREVIEW; - Text [ en-US ] = "Example"; - }; - - PushButton BTN_ADD_CONDITION - { - Pos = MAP_APPFONT( CONDITION_WIDTH - 2*UNRELATED_CONTROLS - 2*IMAGE_BUTTON_WIDTH - RELATED_CONTROLS, ROW_3_POS ); - Size = MAP_APPFONT( IMAGE_BUTTON_WIDTH, IMAGE_BUTTON_HEIGHT ); - Text = "+"; - }; - - PushButton BTN_REMOVE_CONDITION - { - Pos = MAP_APPFONT( CONDITION_WIDTH - 2*UNRELATED_CONTROLS - 2*IMAGE_BUTTON_WIDTH - RELATED_CONTROLS, ROW_3_POS ); - Size = MAP_APPFONT( IMAGE_BUTTON_WIDTH, IMAGE_BUTTON_HEIGHT ); - Text = "-"; - }; -}; - -ModalDialog RID_CONDFORMAT -{ - OutputSize = TRUE ; - SVLook = TRUE ; - Size = MAP_APPFONT ( COND_DLG_WIDTH, COND_DLG_HEIGHT ) ; - Text [ en-US ] = "Conditional Formatting" ; - HelpId = HID_RPT_CONDFORMAT_DLG; - Moveable = TRUE ; - Closeable = TRUE ; - - Window WND_COND_PLAYGROUND - { - Pos = MAP_APPFONT ( 0, 0 ) ; - Size = MAP_APPFONT ( CONDITION_WIDTH, CONDITION_HEIGHT ) ; - DialogControl = TRUE; - Hide = FALSE; - }; - - FixedLine FL_SEPARATOR1 - { - Pos = MAP_APPFONT ( RELATED_CONTROLS, CONDITION_HEIGHT + RELATED_CONTROLS ) ; - Size = MAP_APPFONT ( CONDITION_WIDTH - 2*RELATED_CONTROLS , 1 ) ; - }; - - OKButton PB_OK - { - Pos = MAP_APPFONT ( CONDITION_WIDTH - 3*BUTTON_WIDTH - 2*UNRELATED_CONTROLS - RELATED_CONTROLS, CONDITION_HEIGHT + 2*RELATED_CONTROLS + 1) ; - Size = MAP_APPFONT ( BUTTON_WIDTH , BUTTON_HEIGHT ) ; - TabStop = TRUE ; - DefButton = TRUE ; - }; - - CancelButton PB_CANCEL - { - Pos = MAP_APPFONT ( CONDITION_WIDTH - 2*BUTTON_WIDTH - 2*UNRELATED_CONTROLS , CONDITION_HEIGHT + 2*RELATED_CONTROLS + 1) ; - Size = MAP_APPFONT ( BUTTON_WIDTH , BUTTON_HEIGHT ) ; - TabStop = TRUE ; - }; - - HelpButton PB_HELP - { - TabStop = TRUE ; - Pos = MAP_APPFONT ( CONDITION_WIDTH - BUTTON_WIDTH - UNRELATED_CONTROLS, CONDITION_HEIGHT + 2*RELATED_CONTROLS + 1) ; - Size = MAP_APPFONT ( BUTTON_WIDTH , BUTTON_HEIGHT ) ; - Text [ en-US ] = "~Help"; - }; - - ScrollBar SB_ALL_CONDITIONS - { - Pos = MAP_APPFONT ( CONDITION_WIDTH, RELATED_CONTROLS ) ; - Size = MAP_APPFONT ( SCROLLBAR_WIDTH, CONDITION_HEIGHT + RELATED_CONTROLS ) ; - }; -}; +#include "rptui_slotid.hrc" String STR_NUMBERED_CONDITION { diff --git a/reportdesign/source/ui/dlg/Condition.cxx b/reportdesign/source/ui/dlg/Condition.cxx index d41009d02d3a..b14867af2591 100644 --- a/reportdesign/source/ui/dlg/Condition.cxx +++ b/reportdesign/source/ui/dlg/Condition.cxx @@ -56,39 +56,19 @@ using namespace ::com::sun::star; using namespace ::com::sun::star::uno; using namespace ::com::sun::star::beans; -ConditionField::ConditionField( Condition* _pParent, const ResId& _rResId ) : Edit(_pParent,_rResId) -,m_pParent(_pParent) -,m_aFormula(this) +ConditionField::ConditionField(Condition* pParent, Edit* pSubEdit, PushButton *pFormula) + : m_pParent(pParent) + , m_pSubEdit(pSubEdit) + , m_pFormula(pFormula) { - m_pSubEdit = new Edit(this,0); - SetSubEdit(m_pSubEdit); m_pSubEdit->EnableRTL( false ); m_pSubEdit->SetPosPixel( Point() ); - m_aFormula.SetText(OUString("...")); - m_aFormula.SetClickHdl( LINK( this, ConditionField, OnFormula ) ); - m_aFormula.Show(); - m_pSubEdit->Show(); - Resize(); + m_pFormula->SetText(OUString("...")); + m_pFormula->SetClickHdl( LINK( this, ConditionField, OnFormula ) ); } -ConditionField::~ConditionField() -{ - SetSubEdit(NULL); - delete m_pSubEdit; -} - -void ConditionField::Resize() -{ - Edit::Resize(); - const Size aSize = GetOutputSizePixel(); - const Size aButtonSize( LogicToPixel( Size( 12, 0 ), MAP_APPFONT ).Width(),aSize.Height()); - const Point aButtonPos(aSize.Width() - aButtonSize.Width(), 0); - m_aFormula.SetPosSizePixel(aButtonPos,aButtonSize); - m_pSubEdit->SetPosSizePixel(Point(0,0),Size(aButtonPos.X() ,aSize.Height())); -} - -IMPL_LINK( ConditionField, OnFormula, Button*, /*_pClickedButton*/ ) +IMPL_LINK( ConditionField, OnFormula, Button*, _pClickedButton ) { OUString sFormula(m_pSubEdit->GetText()); const sal_Int32 nLen = sFormula.getLength(); @@ -97,7 +77,7 @@ IMPL_LINK( ConditionField, OnFormula, Button*, /*_pClickedButton*/ ) ReportFormula aFormula( sFormula ); sFormula = aFormula.getCompleteFormula(); } - uno::Reference< awt::XWindow> xInspectorWindow = VCLUnoHelper::GetInterface(this); + uno::Reference< awt::XWindow> xInspectorWindow = VCLUnoHelper::GetInterface(_pClickedButton); uno::Reference< beans::XPropertySet> xProp(m_pParent->getController().getRowSet(),uno::UNO_QUERY); if ( rptui::openDialogFormula_nothrow( sFormula, m_pParent->getController().getContext(),xInspectorWindow,xProp ) ) { @@ -108,7 +88,6 @@ IMPL_LINK( ConditionField, OnFormula, Button*, /*_pClickedButton*/ ) } // class SvxColorWindow_Impl -------------------------------------------------- - #ifndef WB_NO_DIRECTSELECT #define WB_NO_DIRECTSELECT ((WinBits)0x04000000) #endif @@ -227,21 +206,9 @@ IMPL_LINK_NOARG(OColorPopup, SelectHdl) Condition::Condition( Window* _pParent, IConditionalFormatAction& _rAction, ::rptui::OReportController& _rController ) - :Control(_pParent, ModuleRes(WIN_CONDITION)) + :VclHBox(_pParent) ,m_rController( _rController ) ,m_rAction( _rAction ) - ,m_aHeader(this, ModuleRes(FL_CONDITION_HEADER)) - ,m_aConditionType(this, ModuleRes(LB_COND_TYPE)) - ,m_aOperationList( this, ModuleRes(LB_OP)) - ,m_aCondLHS(this, ModuleRes(ED_CONDITION_LHS)) - ,m_aOperandGlue(this, ModuleRes(FT_AND)) - ,m_aCondRHS(this, ModuleRes(ED_CONDITION_RHS)) - ,m_aActions(this, ModuleRes(TB_FORMAT)) - ,m_aPreview(this, ModuleRes(CRTL_FORMAT_PREVIEW)) - ,m_aMoveUp( this, ModuleRes( BTN_MOVE_UP ) ) - ,m_aMoveDown( this, ModuleRes( BTN_MOVE_DOWN ) ) - ,m_aAddCondition( this, ModuleRes( BTN_ADD_CONDITION ) ) - ,m_aRemoveCondition( this, ModuleRes( BTN_REMOVE_CONDITION ) ) ,m_pColorFloat(NULL) ,m_pBtnUpdaterFontColor(NULL) ,m_pBtnUpdaterBackgroundColor(NULL) @@ -249,63 +216,86 @@ Condition::Condition( Window* _pParent, IConditionalFormatAction& _rAction, ::rp ,m_nLastKnownWindowWidth( -1 ) ,m_bInDestruction( false ) { - FreeResource(); - m_aActions.SetStyle(m_aActions.GetStyle()|WB_LINESPACING); - m_aCondLHS.GrabFocus(); + m_pUIBuilder = new VclBuilder(this, getUIRootDir(), "modules/dbreport/ui/conditionwin.ui"); - m_aConditionType.SetSelectHdl( LINK( this, Condition, OnTypeSelected ) ); + get(m_pHeader, "headerLabel"); + get(m_pConditionType, "typeCombobox"); + get(m_pOperationList, "opCombobox"); + m_pCondLHS = new ConditionField(this, get<Edit>("lhsEntry"), get<PushButton>("lhsButton")); + get(m_pOperandGlue, "andLabel"); + m_pCondRHS = new ConditionField(this, get<Edit>("rhsEntry"), get<PushButton>("rhsButton")); + get(m_pActions, "formatToolbox"); + get(m_pPreview, "previewDrawingarea"); + get(m_pMoveUp, "upButton"); + get(m_pMoveDown, "downButton"); + get(m_pAddCondition, "addButton"); + get(m_pRemoveCondition, "removeButton"); - m_aOperationList.SetDropDownLineCount( 10 ); - m_aOperationList.SetSelectHdl( LINK( this, Condition, OnOperationSelected ) ); + m_pActions->SetStyle(m_pActions->GetStyle()|WB_LINESPACING); + m_pCondLHS->GrabFocus(); - m_aActions.SetSelectHdl(LINK(this, Condition, OnFormatAction)); - m_aActions.SetDropdownClickHdl( LINK( this, Condition, DropdownClick ) ); - setToolBox(&m_aActions); + m_pConditionType->SetSelectHdl( LINK( this, Condition, OnTypeSelected ) ); - m_aMoveUp.SetClickHdl( LINK( this, Condition, OnConditionAction ) ); - m_aMoveDown.SetClickHdl( LINK( this, Condition, OnConditionAction ) ); - m_aAddCondition.SetClickHdl( LINK( this, Condition, OnConditionAction ) ); - m_aRemoveCondition.SetClickHdl( LINK( this, Condition, OnConditionAction ) ); + m_pOperationList->SetDropDownLineCount( 10 ); + m_pOperationList->SetSelectHdl( LINK( this, Condition, OnOperationSelected ) ); - m_aMoveUp.SetStyle( m_aMoveUp.GetStyle() | WB_NOPOINTERFOCUS ); - m_aMoveDown.SetStyle( m_aMoveDown.GetStyle() | WB_NOPOINTERFOCUS ); - m_aAddCondition.SetStyle( m_aMoveUp.GetStyle() | WB_NOPOINTERFOCUS | WB_CENTER | WB_VCENTER ); - m_aRemoveCondition.SetStyle( m_aMoveDown.GetStyle() | WB_NOPOINTERFOCUS | WB_CENTER | WB_VCENTER ); + m_pActions->SetSelectHdl(LINK(this, Condition, OnFormatAction)); + m_pActions->SetDropdownClickHdl( LINK( this, Condition, DropdownClick ) ); + setToolBox(m_pActions); - Font aFont( m_aAddCondition.GetFont() ); - aFont.SetWeight( WEIGHT_BOLD ); - m_aAddCondition.SetFont( aFont ); - m_aRemoveCondition.SetFont( aFont ); + m_pMoveUp->SetClickHdl( LINK( this, Condition, OnConditionAction ) ); + m_pMoveDown->SetClickHdl( LINK( this, Condition, OnConditionAction ) ); + m_pAddCondition->SetClickHdl( LINK( this, Condition, OnConditionAction ) ); + m_pRemoveCondition->SetClickHdl( LINK( this, Condition, OnConditionAction ) ); - m_aOperandGlue.SetStyle( m_aOperandGlue.GetStyle() | WB_VCENTER ); + m_pMoveUp->SetStyle( m_pMoveUp->GetStyle() | WB_NOPOINTERFOCUS ); + m_pMoveDown->SetStyle( m_pMoveDown->GetStyle() | WB_NOPOINTERFOCUS ); + m_pAddCondition->SetStyle( m_pAddCondition->GetStyle() | WB_NOPOINTERFOCUS ); + m_pRemoveCondition->SetStyle( m_pRemoveCondition->GetStyle() | WB_NOPOINTERFOCUS ); - m_aConditionType.SelectEntryPos( 0 ); - m_aOperationList.SelectEntryPos( 0 ); + Font aFont( m_pAddCondition->GetFont() ); + aFont.SetWeight( WEIGHT_BOLD ); + m_pAddCondition->SetFont( aFont ); + m_pRemoveCondition->SetFont( aFont ); - // the toolbar got its site automatically, ensure that the preview is positioned - // right of it - Size aRelatedControls( LogicToPixel( Size( RELATED_CONTROLS, 0 ), MAP_APPFONT ) ); - Point aToolbarPos( m_aActions.GetPosPixel() ); - Size aToolbarSize( m_aActions.GetSizePixel() ); - m_aPreview.setPosSizePixel( aToolbarPos.X() + aToolbarSize.Width() + 2 * aRelatedControls.Width(), - 0, 0, 0, WINDOW_POSSIZE_X ); + m_pOperandGlue->SetStyle( m_pOperandGlue->GetStyle() | WB_VCENTER ); - // ensure the toolbar is vertically centered, relative to the preview - Size aPreviewSize( m_aPreview.GetSizePixel() ); - m_aActions.setPosSizePixel( 0, aToolbarPos.Y() + ( aPreviewSize.Height() - aToolbarSize.Height() ) / 2, 0, 0, WINDOW_POSSIZE_Y ); + m_pConditionType->SelectEntryPos( 0 ); + m_pOperationList->SelectEntryPos( 0 ); + + m_nBoldId = m_pActions->GetItemId(".uno:Bold"); + m_nItalicId = m_pActions->GetItemId(".uno:Italic"); + m_nUnderLineId = m_pActions->GetItemId(".uno:Underline"); + m_nBackgroundColorId = m_pActions->GetItemId(".uno:BackgroundColor"); + m_nFontColorId = m_pActions->GetItemId(".uno:FontColor"); + m_nFontDialogId = m_pActions->GetItemId(".uno:FontDialog"); m_pBtnUpdaterBackgroundColor = new ::svx::ToolboxButtonColorUpdater( - SID_BACKGROUND_COLOR, SID_BACKGROUND_COLOR, &m_aActions ); + SID_BACKGROUND_COLOR, m_nBackgroundColorId, m_pActions ); m_pBtnUpdaterFontColor = new ::svx::ToolboxButtonColorUpdater( - SID_ATTR_CHAR_COLOR2, SID_ATTR_CHAR_COLOR2, &m_aActions ); + SID_ATTR_CHAR_COLOR2, m_nFontColorId, m_pActions ); Show(); - impl_layoutAll(); - ConditionalExpressionFactory::getKnownConditionalExpressions( m_aConditionalExpressions ); } +sal_uInt16 Condition::mapToolbarItemToSlotId(sal_uInt16 nItemId) const +{ + if (nItemId == m_nBoldId) + return SID_ATTR_CHAR_WEIGHT; + if (nItemId == m_nItalicId) + return SID_ATTR_CHAR_POSTURE; + if (nItemId == m_nUnderLineId) + return SID_ATTR_CHAR_UNDERLINE; + if (nItemId == m_nBackgroundColorId) + return SID_BACKGROUND_COLOR; + if (nItemId == m_nFontColorId) + return SID_ATTR_CHAR_COLOR2; + if (nItemId == m_nFontDialogId) + return SID_CHAR_DLG; + return 0; +} Condition::~Condition() { @@ -313,32 +303,31 @@ Condition::~Condition() delete m_pColorFloat; delete m_pBtnUpdaterFontColor; + delete m_pCondLHS; + delete m_pCondRHS; delete m_pBtnUpdaterBackgroundColor; } IMPL_LINK( Condition, DropdownClick, ToolBox*, /*pToolBar*/ ) { - sal_uInt16 nId( m_aActions.GetCurItemId() ); + sal_uInt16 nId( m_pActions->GetCurItemId() ); if ( !m_pColorFloat ) - m_pColorFloat = new OColorPopup(&m_aActions,this); + m_pColorFloat = new OColorPopup(m_pActions,this); sal_uInt16 nTextId = 0; - switch(nId) + if (nId == m_nFontColorId) { - case SID_ATTR_CHAR_COLOR2: - nTextId = STR_CHARCOLOR; - break; - case SID_BACKGROUND_COLOR: - nTextId = STR_CHARBACKGROUND; - break; - default: - break; + nTextId = STR_CHARCOLOR; + } + else if (nId == m_nBackgroundColorId) + { + nTextId = STR_CHARBACKGROUND; } if ( nTextId ) m_pColorFloat->SetText(OUString(ModuleRes(nTextId))); - m_pColorFloat->SetSlotId(nId); - m_pColorFloat->SetPosPixel(m_aActions.GetItemPopupPosition(nId,m_pColorFloat->GetSizePixel())); - m_pColorFloat->StartPopupMode(&m_aActions); + m_pColorFloat->SetSlotId(mapToolbarItemToSlotId(nId)); + m_pColorFloat->SetPosPixel(m_pActions->GetItemPopupPosition(nId,m_pColorFloat->GetSizePixel())); + m_pColorFloat->StartPopupMode(m_pActions); m_pColorFloat->StartSelection(); return 1; @@ -347,20 +336,19 @@ IMPL_LINK( Condition, DropdownClick, ToolBox*, /*pToolBar*/ ) IMPL_LINK( Condition, OnFormatAction, ToolBox*, /*NOTINTERESTEDIN*/ ) { Color aCol(COL_AUTO); - ApplyCommand(m_aActions.GetCurItemId(),aCol); + ApplyCommand(mapToolbarItemToSlotId(m_pActions->GetCurItemId()),aCol); return 0L; } - IMPL_LINK( Condition, OnConditionAction, Button*, _pClickedButton ) { - if ( _pClickedButton == &m_aMoveUp ) + if ( _pClickedButton == m_pMoveUp ) m_rAction.moveConditionUp( getConditionIndex() ); - else if ( _pClickedButton == &m_aMoveDown ) + else if ( _pClickedButton == m_pMoveDown ) m_rAction.moveConditionDown( getConditionIndex() ); - else if ( _pClickedButton == &m_aAddCondition ) + else if ( _pClickedButton == m_pAddCondition ) m_rAction.addCondition( getConditionIndex() ); - else if ( _pClickedButton == &m_aRemoveCondition ) + else if ( _pClickedButton == m_pRemoveCondition ) m_rAction.deleteCondition( getConditionIndex() ); return 0L; } @@ -375,137 +363,34 @@ void Condition::ApplyCommand( sal_uInt16 _nCommandId, const ::Color& _rColor) m_rAction.applyCommand( m_nCondIndex, _nCommandId, _rColor ); } -void Condition::setImageList(sal_Int16 _eBitmapSet) +void Condition::setImageList(sal_Int16 /*_eBitmapSet*/) { +#if 0 sal_Int16 nN = IMG_CONDFORMAT_DLG_SC; if ( _eBitmapSet == SFX_SYMBOLS_SIZE_LARGE ) nN = IMG_CONDFORMAT_DLG_LC; - m_aActions.SetImageList(ImageList(ModuleRes(nN))); + m_pActions->SetImageList(ImageList(ModuleRes(nN))); +#endif } -void Condition::resizeControls(const Size& _rDiff) +void Condition::resizeControls(const Size& /*_rDiff*/) { +#if 0 // we use large images so we must change them if ( _rDiff.Width() || _rDiff.Height() ) { Invalidate(); } +#endif } -void Condition::Paint( const Rectangle& rRect ) -{ - Control::Paint(rRect); - - // draw border - const StyleSettings& rStyleSettings = GetSettings().GetStyleSettings(); - ColorChanger aColors( this, rStyleSettings.GetShadowColor(), rStyleSettings.GetDialogColor() ); - DrawRect( impl_getToolBarBorderRect() ); -} - -void Condition::StateChanged( StateChangedType nType ) -{ - Control::StateChanged( nType ); - - if ( nType == STATE_CHANGE_CONTROLBACKGROUND ) - { - // Check if we need to get new images for normal/high contrast mode - checkImageList(); - } - else if ( nType == STATE_CHANGE_TEXT ) - { - // The physical toolbar changed its outlook and shows another logical toolbar! - // We have to set the correct high contrast mode on the new tbx manager. - checkImageList(); - } -} - -void Condition::DataChanged( const DataChangedEvent& rDCEvt ) -{ - Control::DataChanged( rDCEvt ); - - if ((( rDCEvt.GetType() == DATACHANGED_SETTINGS ) || - ( rDCEvt.GetType() == DATACHANGED_DISPLAY )) && - ( rDCEvt.GetFlags() & SETTINGS_STYLE )) - { - // Check if we need to get new images for normal/high contrast mode - checkImageList(); - } -} - - void Condition::GetFocus() { - Control::GetFocus(); + VclHBox::GetFocus(); if ( !m_bInDestruction ) - m_aCondLHS.GrabFocus(); -} - - -void Condition::Resize() -{ - Control::Resize(); - impl_layoutAll(); -} - - -Rectangle Condition::impl_getToolBarBorderRect() const -{ - const Point aToolbarPos( m_aActions.GetPosPixel() ); - const Size aToolbarSize( m_aActions.GetSizePixel() ); - const Size aRelatedControls = LogicToPixel( Size( RELATED_CONTROLS, RELATED_CONTROLS ), MAP_APPFONT ); - - Rectangle aBorderRect( aToolbarPos, aToolbarSize ); - aBorderRect.Left() -= aRelatedControls.Width(); - aBorderRect.Top() -= aRelatedControls.Height(); - aBorderRect.Right() += aRelatedControls.Width(); - aBorderRect.Bottom() += aRelatedControls.Height(); - - return aBorderRect; -} - - -void Condition::impl_layoutAll() -{ - // if our width changed, resize/-position some controls - const Size aSize( GetOutputSizePixel() ); - if ( aSize.Width() == m_nLastKnownWindowWidth ) - return; - - m_nLastKnownWindowWidth = aSize.Width(); - - const Size aRelatedControls( LogicToPixel( Size( RELATED_CONTROLS, RELATED_CONTROLS ), MAP_APPFONT ) ); - const Size aUnrelatedControls( LogicToPixel( Size( UNRELATED_CONTROLS, 0 ), MAP_APPFONT ) ); - const Point aRow1( LogicToPixel( Point( 0, ROW_1_POS ), MAP_APPFONT ) ); - const Point aRow3( LogicToPixel( Point( 0, ROW_3_POS ), MAP_APPFONT ) ); - - // resize the header line - m_aHeader.setPosSizePixel( 0, 0, aSize.Width() - 2 * aRelatedControls.Width(), 0, WINDOW_POSSIZE_WIDTH ); - - // position the up/down buttons - const Size aButtonSize( LogicToPixel( Size( IMAGE_BUTTON_WIDTH, IMAGE_BUTTON_HEIGHT ), MAP_APPFONT ) ); - Point aButtonPos( aSize.Width() - aUnrelatedControls.Width() - aButtonSize.Width(), aRow1.Y() ); - m_aMoveUp.setPosSizePixel( aButtonPos.X(), aButtonPos.Y(), aButtonSize.Width(), aButtonSize.Height() ); - aButtonPos.Move( 0, aButtonSize.Height() + aRelatedControls.Height() ); - m_aMoveDown.setPosSizePixel( aButtonPos.X(), aButtonPos.Y(), aButtonSize.Width(), aButtonSize.Height() ); - - // resize the preview - const long nNewPreviewRight = aButtonPos.X() - aRelatedControls.Width(); - - const Point aPreviewPos( m_aPreview.GetPosPixel() ); - OSL_ENSURE( aPreviewPos.X() < nNewPreviewRight, "Condition::impl_layoutAll: being *that* small should not be allowed!" ); - m_aPreview.setPosSizePixel( 0, 0, nNewPreviewRight - aPreviewPos.X(), 0, WINDOW_POSSIZE_WIDTH ); - - // position the add/remove buttons - aButtonPos = Point( nNewPreviewRight - aButtonSize.Width(), aRow3.Y() ); - m_aRemoveCondition.setPosSizePixel( aButtonPos.X(), aButtonPos.Y(), aButtonSize.Width(), aButtonSize.Height() ); - aButtonPos.Move( -( aButtonSize.Width() + aRelatedControls.Width() ), 0 ); - m_aAddCondition.setPosSizePixel( aButtonPos.X(), aButtonPos.Y(), aButtonSize.Width(), aButtonSize.Height() ); - - // layout the operands input controls - impl_layoutOperands(); + m_pCondLHS->GrabFocus(); } - IMPL_LINK( Condition, OnTypeSelected, ListBox*, /*_pNotInterestedIn*/ ) { impl_layoutOperands(); @@ -519,7 +404,6 @@ IMPL_LINK( Condition, OnOperationSelected, ListBox*, /*_pNotInterestedIn*/ ) return 0L; } - void Condition::impl_layoutOperands() { const ConditionType eType( impl_getCurrentConditionType() ); @@ -533,43 +417,12 @@ void Condition::impl_layoutOperands() ) ); - const Size aRelatedControls( LogicToPixel( Size( RELATED_CONTROLS, 0 ), MAP_APPFONT ) ); - const Rectangle aPreviewRect( m_aPreview.GetPosPixel(), m_aPreview.GetSizePixel() ); - // the "condition type" list box - const Rectangle aCondTypeRect( m_aConditionType.GetPosPixel(), m_aConditionType.GetSizePixel() ); - const Point aOpListPos( aCondTypeRect.Right() + aRelatedControls.Width(), aCondTypeRect.Top() ); - const Size aOpListSize( LogicToPixel( Size( COND_OP_WIDTH, 60 ), MAP_APPFONT ) ); - m_aOperationList.setPosSizePixel( aOpListPos.X(), aOpListPos.Y(),aOpListSize.Width(), aOpListSize.Height() ); - m_aOperationList.Show( !bIsExpression ); - - // the LHS input field - Point aLHSPos( aOpListPos.X() + aOpListSize.Width() + aRelatedControls.Width(), aOpListPos.Y() ); - if ( bIsExpression ) - aLHSPos.X() = aOpListPos.X(); - Size aLHSSize( LogicToPixel( Size( EDIT_WIDTH, EDIT_HEIGHT ), MAP_APPFONT ) ); - if ( !bHaveRHS ) - aLHSSize.Width() = aPreviewRect.Right() - aLHSPos.X(); - m_aCondLHS.setPosSizePixel( aLHSPos.X(), aLHSPos.Y(), aLHSSize.Width(), aLHSSize.Height() ); - - if ( bHaveRHS ) - { - // the "and" text being the glue between LHS and RHS - const Point aOpGluePos( aLHSPos.X() + aLHSSize.Width() + aRelatedControls.Width(), aLHSPos.Y() ); - const Size aOpGlueSize( m_aOperandGlue.GetTextWidth( m_aOperandGlue.GetText() ) + aRelatedControls.Width(), aLHSSize.Height() ); - m_aOperandGlue.setPosSizePixel( aOpGluePos.X(), aOpGluePos.Y(), aOpGlueSize.Width(), aOpGlueSize.Height() ); - - // the RHS input field - const Point aRHSPos( aOpGluePos.X() + aOpGlueSize.Width() + aRelatedControls.Width(), aOpGluePos.Y() ); - const Size aRHSSize( aPreviewRect.Right() - aRHSPos.X(), aLHSSize.Height() ); - m_aCondRHS.setPosSizePixel( aRHSPos.X(), aRHSPos.Y(), aRHSSize.Width(), aRHSSize.Height() ); - } - - m_aOperandGlue.Show( bHaveRHS ); - m_aCondRHS.Show( bHaveRHS ); + m_pOperationList->Show( !bIsExpression ); + m_pOperandGlue->Show( bHaveRHS ); + m_pCondRHS->Show( bHaveRHS ); } - void Condition::impl_setCondition( const OUString& _rConditionFormula ) { // determine the condition's type and comparison operation @@ -612,10 +465,10 @@ void Condition::impl_setCondition( const OUString& _rConditionFormula ) } // update UI - m_aConditionType.SelectEntryPos( (sal_uInt16)eType ); - m_aOperationList.SelectEntryPos( (sal_uInt16)eOperation ); - m_aCondLHS.SetText( sLHS ); - m_aCondRHS.SetText( sRHS ); + m_pConditionType->SelectEntryPos( (sal_uInt16)eType ); + m_pOperationList->SelectEntryPos( (sal_uInt16)eOperation ); + m_pCondLHS->SetText( sLHS ); + m_pCondRHS->SetText( sRHS ); // re-layout impl_layoutOperands(); @@ -648,11 +501,12 @@ void Condition::updateToolbar(const uno::Reference< report::XReportControlFormat OSL_ENSURE(_xReportControlFormat.is(),"XReportControlFormat is NULL!"); if ( _xReportControlFormat.is() ) { - sal_uInt16 nItemCount = m_aActions.GetItemCount(); + sal_uInt16 nItemCount = m_pActions->GetItemCount(); for (sal_uInt16 j = 0; j< nItemCount; ++j) { - sal_uInt16 nItemId = m_aActions.GetItemId(j); - m_aActions.CheckItem( nItemId, m_rController.isFormatCommandEnabled( nItemId, _xReportControlFormat ) ); + sal_uInt16 nItemId = m_pActions->GetItemId(j); + m_pActions->CheckItem( nItemId, m_rController.isFormatCommandEnabled(mapToolbarItemToSlotId(nItemId), + _xReportControlFormat ) ); } try @@ -663,9 +517,9 @@ void Condition::updateToolbar(const uno::Reference< report::XReportControlFormat aFont.SetEmphasisMark( static_cast< FontEmphasisMark >( _xReportControlFormat->getControlTextEmphasis() ) ); aFont.SetRelief( static_cast< FontRelief >( _xReportControlFormat->getCharRelief() ) ); aFont.SetColor( _xReportControlFormat->getCharColor() ); - m_aPreview.SetFont( aFont, aFont, aFont ); - m_aPreview.SetBackColor( _xReportControlFormat->getControlBackground() ); - m_aPreview.SetTextLineColor( Color( _xReportControlFormat->getCharUnderlineColor() ) ); + m_pPreview->SetFont( aFont, aFont, aFont ); + m_pPreview->SetBackColor( _xReportControlFormat->getControlBackground() ); + m_pPreview->SetTextLineColor( Color( _xReportControlFormat->getCharUnderlineColor() ) ); } catch( const Exception& ) { @@ -679,8 +533,8 @@ void Condition::fillFormatCondition(const uno::Reference< report::XFormatConditi const ConditionType eType( impl_getCurrentConditionType() ); const ComparisonOperation eOperation( impl_getCurrentComparisonOperation() ); - const OUString sLHS( m_aCondLHS.GetText() ); - const OUString sRHS( m_aCondRHS.GetText() ); + const OUString sLHS( m_pCondLHS->GetText() ); + const OUString sRHS( m_pCondRHS->GetText() ); OUString sUndecoratedFormula( sLHS ); @@ -702,17 +556,17 @@ void Condition::setConditionIndex( size_t _nCondIndex, size_t _nCondCount ) m_nCondIndex = _nCondIndex; OUString sHeader( ModuleRes( STR_NUMBERED_CONDITION ) ); sHeader = sHeader.replaceFirst( "$number$", OUString::number( _nCondIndex + 1) ); - m_aHeader.SetText( sHeader ); + m_pHeader->SetText( sHeader ); - m_aMoveUp.Enable( _nCondIndex > 0 ); + m_pMoveUp->Enable( _nCondIndex > 0 ); OSL_PRECOND( _nCondCount > 0, "Condition::setConditionIndex: having no conditions at all is nonsense!" ); - m_aMoveDown.Enable( _nCondIndex < _nCondCount - 1 ); + m_pMoveDown->Enable( _nCondIndex < _nCondCount - 1 ); } bool Condition::isEmpty() const { - return m_aCondLHS.GetText().isEmpty(); + return m_pCondLHS->GetText().isEmpty(); } diff --git a/reportdesign/source/ui/dlg/Condition.hxx b/reportdesign/source/ui/dlg/Condition.hxx index b28b43ab3537..7635082a22f5 100644 --- a/reportdesign/source/ui/dlg/Condition.hxx +++ b/reportdesign/source/ui/dlg/Condition.hxx @@ -33,6 +33,8 @@ #include <vcl/field.hxx> #include <vcl/button.hxx> #include <vcl/toolbox.hxx> +#include <vcl/builder.hxx> +#include <vcl/layout.hxx> #include <memory> @@ -45,39 +47,48 @@ namespace rptui class IConditionalFormatAction; class Condition; - class ConditionField : public Edit + class ConditionField { Condition* m_pParent; Edit* m_pSubEdit; - PushButton m_aFormula; + PushButton* m_pFormula; DECL_LINK( OnFormula, Button* ); public: - ConditionField( Condition* pParent, const ResId& rResId ); - virtual ~ConditionField(); - virtual void Resize() SAL_OVERRIDE; + ConditionField(Condition* pParent, Edit* pSubEdit, PushButton *pFormula); + void GrabFocus() { m_pSubEdit->GrabFocus(); } + void Show(bool bShow) { m_pSubEdit->Show(bShow); m_pFormula->Show(bShow); } + void SetText(const OUString& rText) { m_pSubEdit->SetText(rText); } + OUString GetText() const { return m_pSubEdit->GetText(); } }; - //= Condition - class Condition :public Control + class Condition :public VclHBox ,public dbaui::OToolBoxHelper + ,public VclBuilderContainer { + sal_uInt16 m_nBoldId; + sal_uInt16 m_nItalicId; + sal_uInt16 m_nUnderLineId; + sal_uInt16 m_nBackgroundColorId; + sal_uInt16 m_nFontColorId; + sal_uInt16 m_nFontDialogId; + ::rptui::OReportController& m_rController; IConditionalFormatAction& m_rAction; - FixedLine m_aHeader; - ListBox m_aConditionType; - ListBox m_aOperationList; - ConditionField m_aCondLHS; - FixedText m_aOperandGlue; - ConditionField m_aCondRHS; - ToolBox m_aActions; - SvxFontPrevWindow m_aPreview; - ImageButton m_aMoveUp; - ImageButton m_aMoveDown; - PushButton m_aAddCondition; - PushButton m_aRemoveCondition; + FixedText* m_pHeader; + ListBox* m_pConditionType; + ListBox* m_pOperationList; + ConditionField* m_pCondLHS; + FixedText* m_pOperandGlue; + ConditionField* m_pCondRHS; + ToolBox* m_pActions; + SvxFontPrevWindow* m_pPreview; + PushButton* m_pMoveUp; + PushButton* m_pMoveDown; + PushButton* m_pAddCondition; + PushButton* m_pRemoveCondition; OColorPopup* m_pColorFloat; ::svx::ToolboxButtonColorUpdater* m_pBtnUpdaterFontColor; // updates the color below the toolbar icon @@ -139,20 +150,14 @@ namespace rptui inline ::rptui::OReportController& getController() const { return m_rController; } + sal_uInt16 mapToolbarItemToSlotId(sal_uInt16 nItemId) const; + protected: - virtual void StateChanged( StateChangedType nStateChange ) SAL_OVERRIDE; - virtual void DataChanged( const DataChangedEvent& rDCEvt ) SAL_OVERRIDE; - virtual void Paint( const Rectangle& rRect ) SAL_OVERRIDE; - virtual void Resize() SAL_OVERRIDE; virtual void GetFocus() SAL_OVERRIDE; private: - void impl_layoutAll(); void impl_layoutOperands(); - /// determines the rectangle to be occupied by the toolbar, including the border drawn around it - Rectangle impl_getToolBarBorderRect() const; - inline ConditionType impl_getCurrentConditionType() const; @@ -169,13 +174,13 @@ namespace rptui inline ConditionType Condition::impl_getCurrentConditionType() const { - return sal::static_int_cast< ConditionType >( m_aConditionType.GetSelectEntryPos() ); + return sal::static_int_cast< ConditionType >( m_pConditionType->GetSelectEntryPos() ); } inline ComparisonOperation Condition::impl_getCurrentComparisonOperation() const { - return sal::static_int_cast< ComparisonOperation >( m_aOperationList.GetSelectEntryPos() ); + return sal::static_int_cast< ComparisonOperation >( m_pOperationList->GetSelectEntryPos() ); } diff --git a/reportdesign/source/ui/inc/CondFormat.hxx b/reportdesign/source/ui/inc/CondFormat.hxx index 86b3d3c6c381..6edee15d1b55 100644 --- a/reportdesign/source/ui/inc/CondFormat.hxx +++ b/reportdesign/source/ui/inc/CondFormat.hxx @@ -73,13 +73,9 @@ namespace rptui typedef ::std::vector< ConditionPtr > Conditions; OModuleClient m_aModuleClient; - Window m_aConditionPlayground; + Window* m_pConditionPlayground; Conditions m_aConditions; - FixedLine m_aSeparator; - OKButton m_aPB_OK; - CancelButton m_aPB_CANCEL; - HelpButton m_aPB_Help; - ScrollBar m_aCondScroll; + ScrollBar* m_pCondScroll; ::rptui::OReportController& m_rController; ::com::sun::star::uno::Reference< ::com::sun::star::report::XReportControlModel > @@ -88,6 +84,7 @@ namespace rptui m_xCopy; bool m_bDeletingCondition; + bool m_bConstructed; public: ConditionalFormattingDialog( @@ -134,7 +131,7 @@ namespace rptui void impl_layoutAll(); /// does the layout for the condition windows - void impl_layoutConditions( Point& _out_rBelowLastVisible ); + void impl_layoutConditions(); /// called when the number of conditions has changed in any way void impl_conditionCountChanged(); @@ -154,9 +151,6 @@ namespace rptui /// returns the index of the last visible condition size_t impl_getLastVisibleConditionIndex() const; - /// determines the width of a Condition - long impl_getConditionWidth() const; - /// focuses the condition with the given index, making it visible if necessary void impl_focusCondition( size_t _nCondIndex ); @@ -171,6 +165,9 @@ namespace rptui /// ensures the condition with the given index is visible void impl_ensureConditionVisible( size_t _nCondIndex ); + + /// set the preferred height of the action_area + void impl_setPrefHeight(bool bFirst); }; |