diff options
-rw-r--r-- | extras/source/glade/libreoffice-catalog.xml.in | 4 | ||||
-rw-r--r-- | sc/UIConfig_scalc.mk | 1 | ||||
-rw-r--r-- | sc/inc/helpids.h | 1 | ||||
-rw-r--r-- | sc/inc/sc.hrc | 1 | ||||
-rw-r--r-- | sc/inc/scabstdlg.hxx | 2 | ||||
-rw-r--r-- | sc/source/ui/attrdlg/scdlgfact.cxx | 16 | ||||
-rw-r--r-- | sc/source/ui/attrdlg/scdlgfact.hxx | 2 | ||||
-rw-r--r-- | sc/source/ui/dbgui/pvfundlg.cxx | 153 | ||||
-rw-r--r-- | sc/source/ui/dbgui/pvfundlg.src | 137 | ||||
-rw-r--r-- | sc/source/ui/dbgui/pvlaydlg.cxx | 2 | ||||
-rw-r--r-- | sc/source/ui/inc/pvfundlg.hxx | 35 | ||||
-rw-r--r-- | sc/uiconfig/scalc/ui/datafielddialog.ui | 352 |
12 files changed, 455 insertions, 251 deletions
diff --git a/extras/source/glade/libreoffice-catalog.xml.in b/extras/source/glade/libreoffice-catalog.xml.in index 6d7a6dcbe731..56572f206c28 100644 --- a/extras/source/glade/libreoffice-catalog.xml.in +++ b/extras/source/glade/libreoffice-catalog.xml.in @@ -578,6 +578,10 @@ generic-name="CondFormatList" parent="GtkDrawingArea" icon-name="widget-gtk-drawingarea"/> + <glade-widget-class title="ScDPFunctionListBox" name="scuilo-ScDPFunctionListBox" + generic-name="DPFunctionListBox" parent="GtkTreeView" + icon-name="widget-gtk-treeview"/> + <glade-widget-class title="Recent Documents View" name="sfxlo-RecentDocsView" generic-name="Icon View" parent="GtkIconView" icon-name="widget-gtk-iconview"/> diff --git a/sc/UIConfig_scalc.mk b/sc/UIConfig_scalc.mk index 9fb69cfce895..729ae6966609 100644 --- a/sc/UIConfig_scalc.mk +++ b/sc/UIConfig_scalc.mk @@ -73,6 +73,7 @@ $(eval $(call gb_UIConfig_add_uifiles,modules/scalc,\ sc/uiconfig/scalc/ui/covariancedialog \ sc/uiconfig/scalc/ui/createnamesdialog \ sc/uiconfig/scalc/ui/databaroptions \ + sc/uiconfig/scalc/ui/datafielddialog \ sc/uiconfig/scalc/ui/dataform \ sc/uiconfig/scalc/ui/datastreams \ sc/uiconfig/scalc/ui/definedatabaserangedialog \ diff --git a/sc/inc/helpids.h b/sc/inc/helpids.h index 67c6156ebd44..2e0cf5ed5542 100644 --- a/sc/inc/helpids.h +++ b/sc/inc/helpids.h @@ -152,7 +152,6 @@ #define HID_SC_DRAW_RENAME "SC_HID_SC_DRAW_RENAME" -#define HID_SC_DPDATAFIELD "SC_HID_SC_DPDATAFIELD" #define HID_SC_DPSUBT_OPT "SC_HID_SC_DPSUBT_OPT" #define HID_SC_DPSUBT_HIDE "SC_HID_SC_DPSUBT_HIDE" #define HID_SC_DPNUMGROUP "SC_HID_SC_DPNUMGROUP" diff --git a/sc/inc/sc.hrc b/sc/inc/sc.hrc index e6a61f444ec7..97630f8d8419 100644 --- a/sc/inc/sc.hrc +++ b/sc/inc/sc.hrc @@ -1080,7 +1080,6 @@ #define RID_SCDLG_DAPIDATA (SC_DIALOGS_START + 131) -#define RID_SCDLG_DPDATAFIELD (SC_DIALOGS_START + 133) #define RID_SCDLG_DPSUBTOTAL_OPT (SC_DIALOGS_START + 134) #define RID_SCDLG_DPNUMGROUP (SC_DIALOGS_START + 135) #define RID_SCDLG_DPDATEGROUP (SC_DIALOGS_START + 136) diff --git a/sc/inc/scabstdlg.hxx b/sc/inc/scabstdlg.hxx index 52d52bca884f..9b63ee015264 100644 --- a/sc/inc/scabstdlg.hxx +++ b/sc/inc/scabstdlg.hxx @@ -416,7 +416,7 @@ public: virtual AbstractScPivotFilterDlg * CreateScPivotFilterDlg ( Window* pParent, const SfxItemSet& rArgSet, sal_uInt16 nSourceTab , int nId ) = 0; - virtual AbstractScDPFunctionDlg * CreateScDPFunctionDlg( Window* pParent, int nId, + virtual AbstractScDPFunctionDlg * CreateScDPFunctionDlg( Window* pParent, const ScDPLabelDataVector& rLabelVec, const ScDPLabelData& rLabelData, const ScPivotFuncData& rFuncData ) = 0; diff --git a/sc/source/ui/attrdlg/scdlgfact.cxx b/sc/source/ui/attrdlg/scdlgfact.cxx index cf1208efbef8..01a2c54325f2 100644 --- a/sc/source/ui/attrdlg/scdlgfact.cxx +++ b/sc/source/ui/attrdlg/scdlgfact.cxx @@ -881,24 +881,12 @@ AbstractScPivotFilterDlg * ScAbstractDialogFactory_Impl::CreateScPivotFilterDlg } AbstractScDPFunctionDlg * ScAbstractDialogFactory_Impl::CreateScDPFunctionDlg ( Window* pParent, - int nId, const ScDPLabelDataVector& rLabelVec, const ScDPLabelData& rLabelData, const ScPivotFuncData& rFuncData ) { - ScDPFunctionDlg * pDlg=NULL; - switch ( nId ) - { - case RID_SCDLG_DPDATAFIELD : - pDlg = new ScDPFunctionDlg( pParent, rLabelVec, rLabelData, rFuncData ); - break; - default: - break; - } - - if ( pDlg ) - return new AbstractScDPFunctionDlg_Impl( pDlg ); - return 0; + ScDPFunctionDlg * pDlg = new ScDPFunctionDlg( pParent, rLabelVec, rLabelData, rFuncData ); + return new AbstractScDPFunctionDlg_Impl( pDlg ); } AbstractScDPSubtotalDlg * ScAbstractDialogFactory_Impl::CreateScDPSubtotalDlg ( Window* pParent, diff --git a/sc/source/ui/attrdlg/scdlgfact.hxx b/sc/source/ui/attrdlg/scdlgfact.hxx index 604357423560..69443d04c99d 100644 --- a/sc/source/ui/attrdlg/scdlgfact.hxx +++ b/sc/source/ui/attrdlg/scdlgfact.hxx @@ -485,7 +485,7 @@ public: virtual AbstractScPivotFilterDlg * CreateScPivotFilterDlg ( Window* pParent, const SfxItemSet& rArgSet, sal_uInt16 nSourceTab , int nId ); - virtual AbstractScDPFunctionDlg * CreateScDPFunctionDlg( Window* pParent, int nId, + virtual AbstractScDPFunctionDlg * CreateScDPFunctionDlg( Window* pParent, const ScDPLabelDataVector& rLabelVec, const ScDPLabelData& rLabelData, const ScPivotFuncData& rFuncData ); diff --git a/sc/source/ui/dbgui/pvfundlg.cxx b/sc/source/ui/dbgui/pvfundlg.cxx index 40e431eb7f7b..6ca97fec319b 100644 --- a/sc/source/ui/dbgui/pvfundlg.cxx +++ b/sc/source/ui/dbgui/pvfundlg.cxx @@ -28,6 +28,7 @@ #include <com/sun/star/sheet/DataPilotFieldShowItemsMode.hpp> #include <tools/resary.hxx> +#include <vcl/builder.hxx> #include <vcl/msgbox.hxx> #include "scresid.hxx" @@ -155,12 +156,27 @@ static const ScDPListBoxWrapper::MapEntryType spShowFromMap[] = // ============================================================================ -ScDPFunctionListBox::ScDPFunctionListBox( Window* pParent, const ResId& rResId ) : - MultiListBox( pParent, rResId ) +ScDPFunctionListBox::ScDPFunctionListBox(Window* pParent, WinBits nStyle) + : MultiListBox(pParent, nStyle) { FillFunctionNames(); } +ScDPFunctionListBox::ScDPFunctionListBox(Window* pParent, const ResId& rResId) + : MultiListBox(pParent, rResId) +{ + FillFunctionNames(); +} + +extern "C" SAL_DLLPUBLIC_EXPORT Window* SAL_CALL makeScDPFunctionListBox(Window *pParent, VclBuilder::stringmap &rMap) +{ + WinBits nWinStyle = WB_CLIPCHILDREN|WB_LEFT|WB_VCENTER|WB_3DLOOK|WB_SIMPLEMODE; + OString sBorder = VclBuilder::extractCustomProperty(rMap); + if (!sBorder.isEmpty()) + nWinStyle |= WB_BORDER; + return new ScDPFunctionListBox(pParent, nWinStyle); +} + void ScDPFunctionListBox::SetSelection( sal_uInt16 nFuncMask ) { if( (nFuncMask == PIVOT_FUNC_NONE) || (nFuncMask == PIVOT_FUNC_AUTO) ) @@ -191,45 +207,41 @@ void ScDPFunctionListBox::FillFunctionNames() ScDPFunctionDlg::ScDPFunctionDlg( Window* pParent, const ScDPLabelDataVector& rLabelVec, - const ScDPLabelData& rLabelData, const ScPivotFuncData& rFuncData ) : - ModalDialog ( pParent, ScResId( RID_SCDLG_DPDATAFIELD ) ), - maFlFunc ( this, ScResId( FL_FUNC ) ), - maLbFunc ( this, ScResId( LB_FUNC ) ), - maFtNameLabel ( this, ScResId( FT_NAMELABEL ) ), - maFtName ( this, ScResId( FT_NAME ) ), - maFlDisplay ( this, ScResId( FL_DISPLAY ) ), - maFtType ( this, ScResId( FT_TYPE ) ), - maLbType ( this, ScResId( LB_TYPE ) ), - maFtBaseField ( this, ScResId( FT_BASEFIELD ) ), - maLbBaseField ( this, ScResId( LB_BASEFIELD ) ), - maFtBaseItem ( this, ScResId( FT_BASEITEM ) ), - maLbBaseItem ( this, ScResId( LB_BASEITEM ) ), - maBtnOk ( this, ScResId( BTN_OK ) ), - maBtnCancel ( this, ScResId( BTN_CANCEL ) ), - maBtnHelp ( this, ScResId( BTN_HELP ) ), - maBtnMore ( this, ScResId( BTN_MORE ) ), - maLbTypeWrp ( maLbType, spRefTypeMap ), - mrLabelVec ( rLabelVec ), - mbEmptyItem ( false ) -{ - FreeResource(); + const ScDPLabelData& rLabelData, const ScPivotFuncData& rFuncData) + : ModalDialog(pParent, "DataFieldDialog", + "modules/scalc/ui/datafielddialog.ui") + , mrLabelVec(rLabelVec) + , mbEmptyItem(false) +{ + get(mpFtName, "name"); + get(mpLbType, "type"); + mxLbTypeWrp.reset(new ScDPListBoxWrapper(*mpLbType, spRefTypeMap)); + get(mpLbFunc, "functions"); + mpLbFunc->set_height_request(mpLbFunc->GetTextHeight() * 8); + get(mpFtBaseField, "basefieldft"); + get(mpLbBaseField, "basefield"); + get(mpFtBaseItem, "baseitemft"); + get(mpLbBaseItem, "baseitem"); + get(mpBtnOk, "ok"); + Init( rLabelData, rFuncData ); - maLbFunc.EnableMultiSelection(false); + + mpLbFunc->EnableMultiSelection(false); } sal_uInt16 ScDPFunctionDlg::GetFuncMask() const { - return maLbFunc.GetSelection(); + return mpLbFunc->GetSelection(); } DataPilotFieldReference ScDPFunctionDlg::GetFieldRef() const { DataPilotFieldReference aRef; - aRef.ReferenceType = maLbTypeWrp.GetControlValue(); - aRef.ReferenceField = GetBaseFieldName(maLbBaseField.GetSelectEntry()); + aRef.ReferenceType = mxLbTypeWrp->GetControlValue(); + aRef.ReferenceField = GetBaseFieldName(mpLbBaseField->GetSelectEntry()); - sal_uInt16 nBaseItemPos = maLbBaseItem.GetSelectEntryPos(); + sal_uInt16 nBaseItemPos = mpLbBaseItem->GetSelectEntryPos(); switch( nBaseItemPos ) { case SC_BASEITEM_PREV_POS: @@ -242,7 +254,7 @@ DataPilotFieldReference ScDPFunctionDlg::GetFieldRef() const { aRef.ReferenceItemType = DataPilotFieldReferenceItemType::NAMED; if( !mbEmptyItem || (nBaseItemPos > SC_BASEITEM_USER_POS) ) - aRef.ReferenceItemName = GetBaseItemName(maLbBaseItem.GetSelectEntry()); + aRef.ReferenceItemName = GetBaseItemName(mpLbBaseItem->GetSelectEntry()); } } @@ -253,30 +265,21 @@ void ScDPFunctionDlg::Init( const ScDPLabelData& rLabelData, const ScPivotFuncDa { // list box sal_uInt16 nFuncMask = (rFuncData.mnFuncMask == PIVOT_FUNC_NONE) ? PIVOT_FUNC_SUM : rFuncData.mnFuncMask; - maLbFunc.SetSelection( nFuncMask ); + mpLbFunc->SetSelection( nFuncMask ); // field name - maFtName.SetText(rLabelData.getDisplayName()); - - // "More button" controls - maBtnMore.AddWindow( &maFlDisplay ); - maBtnMore.AddWindow( &maFtType ); - maBtnMore.AddWindow( &maLbType ); - maBtnMore.AddWindow( &maFtBaseField ); - maBtnMore.AddWindow( &maLbBaseField ); - maBtnMore.AddWindow( &maFtBaseItem ); - maBtnMore.AddWindow( &maLbBaseItem ); + mpFtName->SetText(rLabelData.getDisplayName()); // handlers - maLbFunc.SetDoubleClickHdl( LINK( this, ScDPFunctionDlg, DblClickHdl ) ); - maLbType.SetSelectHdl( LINK( this, ScDPFunctionDlg, SelectHdl ) ); - maLbBaseField.SetSelectHdl( LINK( this, ScDPFunctionDlg, SelectHdl ) ); + mpLbFunc->SetDoubleClickHdl( LINK( this, ScDPFunctionDlg, DblClickHdl ) ); + mpLbType->SetSelectHdl( LINK( this, ScDPFunctionDlg, SelectHdl ) ); + mpLbBaseField->SetSelectHdl( LINK( this, ScDPFunctionDlg, SelectHdl ) ); // base field list box OUString aSelectedEntry; for( ScDPLabelDataVector::const_iterator aIt = mrLabelVec.begin(), aEnd = mrLabelVec.end(); aIt != aEnd; ++aIt ) { - maLbBaseField.InsertEntry(aIt->getDisplayName()); + mpLbBaseField->InsertEntry(aIt->getDisplayName()); maBaseFieldNameMap.insert( NameMapType::value_type(aIt->getDisplayName(), aIt->maName)); if (aIt->maName == rFuncData.maFieldRef.ReferenceField) @@ -284,41 +287,41 @@ void ScDPFunctionDlg::Init( const ScDPLabelData& rLabelData, const ScPivotFuncDa } // base item list box - maLbBaseItem.SetSeparatorPos( SC_BASEITEM_USER_POS - 1 ); + mpLbBaseItem->SetSeparatorPos( SC_BASEITEM_USER_POS - 1 ); // select field reference type - maLbTypeWrp.SetControlValue( rFuncData.maFieldRef.ReferenceType ); - SelectHdl( &maLbType ); // enables base field/item list boxes + mxLbTypeWrp->SetControlValue( rFuncData.maFieldRef.ReferenceType ); + SelectHdl( mpLbType ); // enables base field/item list boxes // select base field - maLbBaseField.SelectEntry(aSelectedEntry); - if( maLbBaseField.GetSelectEntryPos() >= maLbBaseField.GetEntryCount() ) - maLbBaseField.SelectEntryPos( 0 ); - SelectHdl( &maLbBaseField ); // fills base item list, selects base item + mpLbBaseField->SelectEntry(aSelectedEntry); + if( mpLbBaseField->GetSelectEntryPos() >= mpLbBaseField->GetEntryCount() ) + mpLbBaseField->SelectEntryPos( 0 ); + SelectHdl( mpLbBaseField ); // fills base item list, selects base item // select base item switch( rFuncData.maFieldRef.ReferenceItemType ) { case DataPilotFieldReferenceItemType::PREVIOUS: - maLbBaseItem.SelectEntryPos( SC_BASEITEM_PREV_POS ); + mpLbBaseItem->SelectEntryPos( SC_BASEITEM_PREV_POS ); break; case DataPilotFieldReferenceItemType::NEXT: - maLbBaseItem.SelectEntryPos( SC_BASEITEM_NEXT_POS ); + mpLbBaseItem->SelectEntryPos( SC_BASEITEM_NEXT_POS ); break; default: { if( mbEmptyItem && rFuncData.maFieldRef.ReferenceItemName.isEmpty() ) { // select special "(empty)" entry added before other items - maLbBaseItem.SelectEntryPos( SC_BASEITEM_USER_POS ); + mpLbBaseItem->SelectEntryPos( SC_BASEITEM_USER_POS ); } else { sal_uInt16 nStartPos = mbEmptyItem ? (SC_BASEITEM_USER_POS + 1) : SC_BASEITEM_USER_POS; sal_uInt16 nPos = FindBaseItemPos( rFuncData.maFieldRef.ReferenceItemName, nStartPos ); - if( nPos >= maLbBaseItem.GetEntryCount() ) - nPos = (maLbBaseItem.GetEntryCount() > SC_BASEITEM_USER_POS) ? SC_BASEITEM_USER_POS : SC_BASEITEM_PREV_POS; - maLbBaseItem.SelectEntryPos( nPos ); + if( nPos >= mpLbBaseItem->GetEntryCount() ) + nPos = (mpLbBaseItem->GetEntryCount() > SC_BASEITEM_USER_POS) ? SC_BASEITEM_USER_POS : SC_BASEITEM_PREV_POS; + mpLbBaseItem->SelectEntryPos( nPos ); } } } @@ -340,10 +343,10 @@ sal_uInt16 ScDPFunctionDlg::FindBaseItemPos( const OUString& rEntry, sal_uInt16 { sal_uInt16 nPos = nStartPos; bool bFound = false; - while (nPos < maLbBaseItem.GetEntryCount()) + while (nPos < mpLbBaseItem->GetEntryCount()) { // translate the displayed field name back to its original field name. - const OUString& rName = GetBaseItemName(maLbBaseItem.GetEntry(nPos)); + const OUString& rName = GetBaseItemName(mpLbBaseItem->GetEntry(nPos)); if (rName.equals(rEntry)) { bFound = true; @@ -356,10 +359,10 @@ sal_uInt16 ScDPFunctionDlg::FindBaseItemPos( const OUString& rEntry, sal_uInt16 IMPL_LINK( ScDPFunctionDlg, SelectHdl, ListBox*, pLBox ) { - if( pLBox == &maLbType ) + if( pLBox == mpLbType ) { bool bEnableField, bEnableItem; - switch( maLbTypeWrp.GetControlValue() ) + switch( mxLbTypeWrp->GetControlValue() ) { case DataPilotFieldReferenceType::ITEM_DIFFERENCE: case DataPilotFieldReferenceType::ITEM_PERCENTAGE: @@ -376,27 +379,27 @@ IMPL_LINK( ScDPFunctionDlg, SelectHdl, ListBox*, pLBox ) bEnableField = bEnableItem = false; } - bEnableField &= maLbBaseField.GetEntryCount() > 0; - maFtBaseField.Enable( bEnableField ); - maLbBaseField.Enable( bEnableField ); + bEnableField &= mpLbBaseField->GetEntryCount() > 0; + mpFtBaseField->Enable( bEnableField ); + mpLbBaseField->Enable( bEnableField ); bEnableItem &= bEnableField; - maFtBaseItem.Enable( bEnableItem ); - maLbBaseItem.Enable( bEnableItem ); + mpFtBaseItem->Enable( bEnableItem ); + mpLbBaseItem->Enable( bEnableItem ); } - else if( pLBox == &maLbBaseField ) + else if( pLBox == mpLbBaseField ) { // keep "previous" and "next" entries - while( maLbBaseItem.GetEntryCount() > SC_BASEITEM_USER_POS ) - maLbBaseItem.RemoveEntry( SC_BASEITEM_USER_POS ); + while( mpLbBaseItem->GetEntryCount() > SC_BASEITEM_USER_POS ) + mpLbBaseItem->RemoveEntry( SC_BASEITEM_USER_POS ); // update item list for current base field mbEmptyItem = false; - size_t nBasePos = maLbBaseField.GetSelectEntryPos(); + size_t nBasePos = mpLbBaseField->GetSelectEntryPos(); if( nBasePos < mrLabelVec.size() ) { const vector<ScDPLabelData::Member>& rMembers = mrLabelVec[nBasePos].maMembers; - mbEmptyItem = lclFillListBox( maLbBaseItem, rMembers, SC_BASEITEM_USER_POS ); + mbEmptyItem = lclFillListBox(*mpLbBaseItem, rMembers, SC_BASEITEM_USER_POS); // build cache for base names. NameMapType aMap; vector<ScDPLabelData::Member>::const_iterator itr = rMembers.begin(), itrEnd = rMembers.end(); @@ -406,15 +409,15 @@ IMPL_LINK( ScDPFunctionDlg, SelectHdl, ListBox*, pLBox ) } // select base item - sal_uInt16 nItemPos = (maLbBaseItem.GetEntryCount() > SC_BASEITEM_USER_POS) ? SC_BASEITEM_USER_POS : SC_BASEITEM_PREV_POS; - maLbBaseItem.SelectEntryPos( nItemPos ); + sal_uInt16 nItemPos = (mpLbBaseItem->GetEntryCount() > SC_BASEITEM_USER_POS) ? SC_BASEITEM_USER_POS : SC_BASEITEM_PREV_POS; + mpLbBaseItem->SelectEntryPos( nItemPos ); } return 0; } IMPL_LINK_NOARG(ScDPFunctionDlg, DblClickHdl) { - maBtnOk.Click(); + mpBtnOk->Click(); return 0; } diff --git a/sc/source/ui/dbgui/pvfundlg.src b/sc/source/ui/dbgui/pvfundlg.src index 7af9bc810d04..a826665524dd 100644 --- a/sc/source/ui/dbgui/pvfundlg.src +++ b/sc/source/ui/dbgui/pvfundlg.src @@ -39,143 +39,6 @@ StringArray SCSTR_DPFUNCLISTBOX // ---------------------------------------------------------------------------- -ModalDialog RID_SCDLG_DPDATAFIELD -{ - OutputSize = TRUE ; - HelpId = HID_SC_DPDATAFIELD ; - SVLook = TRUE ; - Size = MAP_APPFONT ( 220 , 99 ) ; - Moveable = TRUE ; - Closeable = FALSE ; - Hide = TRUE ; - FixedLine FL_FUNC - { - Pos = MAP_APPFONT ( 6 , 3 ) ; - Size = MAP_APPFONT ( 152 , 8 ) ; - Text [ en-US ] = "~Function" ; - }; - MultiListBox LB_FUNC - { - HelpID = "sc:MultiListBox:RID_SCDLG_DPDATAFIELD:LB_FUNC"; - Border = TRUE ; - Pos = MAP_APPFONT ( 12 , 14 ) ; - Size = MAP_APPFONT ( 140 , 65 ) ; - TabStop = TRUE ; - AutoHScroll = TRUE ; - SimpleMode = TRUE ; - }; - FixedText FT_NAMELABEL - { - Pos = MAP_APPFONT ( 6 , 85 ) ; - Size = MAP_APPFONT ( 25 , 8 ) ; - Text [ en-US ] = "Name:" ; - }; - FixedText FT_NAME - { - Pos = MAP_APPFONT ( 32 , 85 ) ; - Size = MAP_APPFONT ( 126 , 8 ) ; - }; - FixedLine FL_DISPLAY - { - Pos = MAP_APPFONT( 6, 99 ); - Size = MAP_APPFONT( 152, 8 ); - Text [ en-US ] = "Displayed value"; - }; - FixedText FT_TYPE - { - Pos = MAP_APPFONT( 12, 112 ); - Size = MAP_APPFONT( 60, 8 ); - Text [ en-US ] = "~Type"; - }; - ListBox LB_TYPE - { - HelpID = "sc:ListBox:RID_SCDLG_DPDATAFIELD:LB_TYPE"; - Pos = MAP_APPFONT( 75, 110 ); - Size = MAP_APPFONT( 77, 120 ); - TabStop = TRUE; - Border = TRUE; - DropDown = TRUE; - StringList [ en-US ] = - { - < "Normal"; Default; >; - < "Difference from"; Default; >; - < "% of"; Default; >; - < "% difference from"; Default; >; - < "Running total in"; Default; >; - < "% of row"; Default; >; - < "% of column"; Default; >; - < "% of total"; Default; >; - < "Index"; Default; >; - }; - }; - FixedText FT_BASEFIELD - { - Pos = MAP_APPFONT( 12, 128 ); - Size = MAP_APPFONT( 60, 8 ); - Text [ en-US ] = "~Base field"; - }; - ListBox LB_BASEFIELD - { - HelpID = "sc:ListBox:RID_SCDLG_DPDATAFIELD:LB_BASEFIELD"; - Pos = MAP_APPFONT( 75, 126 ); - Size = MAP_APPFONT( 77, 120 ); - TabStop = TRUE; - Border = TRUE; - DropDown = TRUE; - }; - FixedText FT_BASEITEM - { - Pos = MAP_APPFONT( 12, 144 ); - Size = MAP_APPFONT( 60, 8 ); - Text [ en-US ] = "Ba~se item"; - }; - ListBox LB_BASEITEM - { - HelpID = "sc:ListBox:RID_SCDLG_DPDATAFIELD:LB_BASEITEM"; - Pos = MAP_APPFONT( 75, 142 ); - Size = MAP_APPFONT( 77, 120 ); - TabStop = TRUE; - Border = TRUE; - DropDown = TRUE; - StringList [ en-US ] = - { - < "- previous item -"; Default; >; - < "- next item -"; Default; >; - }; - }; - OKButton BTN_OK - { - Pos = MAP_APPFONT ( 164 , 6 ) ; - Size = MAP_APPFONT ( 50 , 14 ) ; - TabStop = TRUE ; - DefButton = TRUE ; - }; - CancelButton BTN_CANCEL - { - Pos = MAP_APPFONT ( 164 , 23 ) ; - Size = MAP_APPFONT ( 50 , 14 ) ; - TabStop = TRUE ; - }; - HelpButton BTN_HELP - { - Pos = MAP_APPFONT ( 164 , 43 ) ; - Size = MAP_APPFONT ( 50 , 14 ) ; - TabStop = TRUE ; - }; - MoreButton BTN_MORE - { - HelpID = "sc:MoreButton:RID_SCDLG_DPDATAFIELD:BTN_MORE"; - Pos = MAP_APPFONT ( 164 , 79 ) ; - Size = MAP_APPFONT ( 50 , 14 ) ; - TabStop = TRUE ; - MapUnit = MAP_APPFONT ; - Delta = 61 ; - }; - Text [ en-US ] = "Data Field" ; -}; - -// ---------------------------------------------------------------------------- - ModalDialog RID_SCDLG_PIVOTSUBT { OutputSize = TRUE ; diff --git a/sc/source/ui/dbgui/pvlaydlg.cxx b/sc/source/ui/dbgui/pvlaydlg.cxx index e4a9beb2ad3b..ec09af1f5f05 100644 --- a/sc/source/ui/dbgui/pvlaydlg.cxx +++ b/sc/source/ui/dbgui/pvlaydlg.cxx @@ -806,7 +806,7 @@ void ScPivotLayoutDlg::NotifyDoubleClick( ScPivotFieldType eType, size_t nFieldI ScPivotFuncData& rFuncData = maWndData.GetFuncData(nFieldIndex); boost::scoped_ptr<AbstractScDPFunctionDlg> pDlg( pFact->CreateScDPFunctionDlg( - this, RID_SCDLG_DPDATAFIELD, maLabelData, *pData, rFuncData)); + this, maLabelData, *pData, rFuncData)); if ( pDlg->Execute() == RET_OK ) { diff --git a/sc/source/ui/inc/pvfundlg.hxx b/sc/source/ui/inc/pvfundlg.hxx index a89ab3882ad7..e30798f9bd74 100644 --- a/sc/source/ui/inc/pvfundlg.hxx +++ b/sc/source/ui/inc/pvfundlg.hxx @@ -34,6 +34,7 @@ #include <sfx2/itemconnect.hxx> #include "pivot.hxx" +#include <boost/scoped_ptr.hpp> #include <boost/unordered_map.hpp> // ============================================================================ @@ -47,7 +48,8 @@ class ScDPObject; class ScDPFunctionListBox : public MultiListBox { public: - explicit ScDPFunctionListBox( Window* pParent, const ResId& rResId ); + ScDPFunctionListBox(Window* pParent, WinBits nStyle); + ScDPFunctionListBox(Window* pParent, const ResId& rResId); void SetSelection( sal_uInt16 nFuncMask ); sal_uInt16 GetSelection() const; @@ -81,29 +83,22 @@ private: DECL_LINK( DblClickHdl, void* ); private: - FixedLine maFlFunc; - ScDPFunctionListBox maLbFunc; - FixedText maFtNameLabel; - FixedInfo maFtName; - FixedLine maFlDisplay; - FixedText maFtType; - ListBox maLbType; - FixedText maFtBaseField; - ListBox maLbBaseField; - FixedText maFtBaseItem; - ListBox maLbBaseItem; - OKButton maBtnOk; - CancelButton maBtnCancel; - HelpButton maBtnHelp; - MoreButton maBtnMore; + ScDPFunctionListBox* mpLbFunc; + FixedText* mpFtName; + ListBox* mpLbType; + FixedText* mpFtBaseField; + ListBox* mpLbBaseField; + FixedText* mpFtBaseItem; + ListBox* mpLbBaseItem; + OKButton* mpBtnOk; - NameMapType maBaseFieldNameMap; // cache for base field display -> original name. - NameMapType maBaseItemNameMap; // cache for base item display -> original name. + NameMapType maBaseFieldNameMap; // cache for base field display -> original name. + NameMapType maBaseItemNameMap; // cache for base item display -> original name. - ScDPListBoxWrapper maLbTypeWrp; /// Wrapper for direct usage of API constants. + boost::scoped_ptr<ScDPListBoxWrapper> mxLbTypeWrp; /// Wrapper for direct usage of API constants. const ScDPLabelDataVector& mrLabelVec; /// Data of all labels. - bool mbEmptyItem; /// true = Empty base item in listbox. + bool mbEmptyItem; /// true = Empty base item in listbox. }; // ============================================================================ diff --git a/sc/uiconfig/scalc/ui/datafielddialog.ui b/sc/uiconfig/scalc/ui/datafielddialog.ui new file mode 100644 index 000000000000..da0decc8b6d6 --- /dev/null +++ b/sc/uiconfig/scalc/ui/datafielddialog.ui @@ -0,0 +1,352 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!-- Generated with glade 3.16.0 on Fri Jan 17 09:55:40 2014 --> +<interface> + <!-- interface-requires gtk+ 3.0 --> + <!-- interface-requires LibreOffice 1.0 --> + <object class="GtkDialog" id="DataFieldDialog"> + <property name="can_focus">False</property> + <property name="border_width">6</property> + <property name="title" translatable="yes">Data Field</property> + <property name="type_hint">dialog</property> + <child internal-child="vbox"> + <object class="GtkBox" id="dialog-vbox1"> + <property name="can_focus">False</property> + <property name="hexpand">True</property> + <property name="vexpand">True</property> + <property name="orientation">vertical</property> + <property name="spacing">12</property> + <child internal-child="action_area"> + <object class="GtkButtonBox" id="dialog-action_area1"> + <property name="can_focus">False</property> + <property name="layout_style">end</property> + <child> + <object class="GtkButton" id="ok"> + <property name="label">gtk-ok</property> + <property name="visible">True</property> + <property name="can_focus">True</property> + <property name="can_default">True</property> + <property name="has_default">True</property> + <property name="receives_default">True</property> + <property name="use_stock">True</property> + </object> + <packing> + <property name="expand">False</property> + <property name="fill">True</property> + <property name="position">0</property> + </packing> + </child> + <child> + <object class="GtkButton" id="cancel"> + <property name="label">gtk-cancel</property> + <property name="visible">True</property> + <property name="can_focus">True</property> + <property name="can_default">True</property> + <property name="receives_default">True</property> + <property name="use_stock">True</property> + </object> + <packing> + <property name="expand">False</property> + <property name="fill">True</property> + <property name="position">1</property> + </packing> + </child> + <child> + <object class="GtkButton" id="help"> + <property name="label">gtk-help</property> + <property name="visible">True</property> + <property name="can_focus">True</property> + <property name="receives_default">True</property> + <property name="use_stock">True</property> + </object> + <packing> + <property name="expand">False</property> + <property name="fill">True</property> + <property name="position">2</property> + </packing> + </child> + </object> + <packing> + <property name="expand">False</property> + <property name="fill">True</property> + <property name="pack_type">end</property> + <property name="position">0</property> + </packing> + </child> + <child> + <object class="GtkGrid" id="grid1"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="hexpand">True</property> + <property name="vexpand">True</property> + <property name="row_spacing">12</property> + <child> + <object class="GtkFrame" id="frame1"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="hexpand">True</property> + <property name="label_xalign">0</property> + <property name="shadow_type">none</property> + <child> + <object class="GtkAlignment" id="alignment1"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="margin_top">6</property> + <property name="hexpand">True</property> + <property name="top_padding">6</property> + <property name="left_padding">12</property> + <child> + <object class="GtkGrid" id="grid2"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="row_spacing">6</property> + <child> + <object class="scuilo-ScDPFunctionListBox" id="functions:border"> + <property name="visible">True</property> + <property name="can_focus">True</property> + <property name="hexpand">True</property> + <property name="vexpand">True</property> + <child internal-child="selection"> + <object class="GtkTreeSelection" id="treeview-selection1"/> + </child> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">0</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + </object> + </child> + </object> + </child> + <child type="label"> + <object class="GtkLabel" id="label1"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="label" translatable="yes">Function</property> + <attributes> + <attribute name="weight" value="bold"/> + </attributes> + </object> + </child> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">0</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkCheckButton" id="checkbutton1"> + <property name="label" translatable="yes">Show it_ems without data</property> + <property name="visible">True</property> + <property name="can_focus">True</property> + <property name="receives_default">False</property> + <property name="use_underline">True</property> + <property name="xalign">0</property> + <property name="draw_indicator">True</property> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">1</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkGrid" id="grid3"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="column_spacing">12</property> + <child> + <object class="GtkLabel" id="label2"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="xalign">0</property> + <property name="label" translatable="yes">Name:</property> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">0</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkLabel" id="name"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="xalign">0</property> + </object> + <packing> + <property name="left_attach">1</property> + <property name="top_attach">0</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">2</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkExpander" id="expander"> + <property name="visible">True</property> + <property name="can_focus">True</property> + <property name="resize_toplevel">True</property> + <child> + <object class="GtkAlignment" id="alignment2"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="margin_top">6</property> + <property name="hexpand">True</property> + <property name="top_padding">6</property> + <property name="left_padding">12</property> + <child> + <object class="GtkGrid" id="grid4"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="row_spacing">6</property> + <property name="column_spacing">12</property> + <child> + <object class="GtkLabel" id="label4"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="xalign">0</property> + <property name="label" translatable="yes">_Type</property> + <property name="use_underline">True</property> + <property name="mnemonic_widget">type</property> + <property name="ellipsize">end</property> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">0</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkLabel" id="basefieldft"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="xalign">0</property> + <property name="label" translatable="yes">_Base field</property> + <property name="use_underline">True</property> + <property name="mnemonic_widget">basefield</property> + <property name="ellipsize">end</property> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">1</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkLabel" id="baseitemft"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="xalign">0</property> + <property name="label" translatable="yes">Ba_se item</property> + <property name="use_underline">True</property> + <property name="mnemonic_widget">baseitem</property> + <property name="ellipsize">end</property> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">2</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkComboBoxText" id="type"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <items> + <item translatable="yes">Normal</item> + <item translatable="yes">Difference from</item> + <item translatable="yes">% of</item> + <item translatable="yes">% difference from</item> + <item translatable="yes">Running total in</item> + <item translatable="yes">% of row</item> + <item translatable="yes">% of column</item> + <item translatable="yes">% of total</item> + <item translatable="yes">Index</item> + </items> + </object> + <packing> + <property name="left_attach">1</property> + <property name="top_attach">0</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkComboBoxText" id="basefield"> + <property name="visible">True</property> + <property name="can_focus">False</property> + </object> + <packing> + <property name="left_attach">1</property> + <property name="top_attach">1</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + <child> + <object class="GtkComboBoxText" id="baseitem"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <items> + <item translatable="yes">- previous item -</item> + <item translatable="yes">- next item -</item> + </items> + </object> + <packing> + <property name="left_attach">1</property> + <property name="top_attach">2</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + </object> + </child> + </object> + </child> + <child type="label"> + <object class="GtkLabel" id="label3"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="label" translatable="yes">Displayed value</property> + </object> + </child> + </object> + <packing> + <property name="left_attach">0</property> + <property name="top_attach">3</property> + <property name="width">1</property> + <property name="height">1</property> + </packing> + </child> + </object> + <packing> + <property name="expand">False</property> + <property name="fill">True</property> + <property name="position">1</property> + </packing> + </child> + </object> + </child> + <action-widgets> + <action-widget response="0">ok</action-widget> + <action-widget response="0">cancel</action-widget> + </action-widgets> + </object> +</interface> |