summaryrefslogtreecommitdiff
path: root/sw/source
diff options
context:
space:
mode:
authorCaolán McNamara <caolanm@redhat.com>2018-06-11 21:18:57 +0100
committerCaolán McNamara <caolanm@redhat.com>2018-06-12 11:46:59 +0200
commitd86549db56b25c2b201285cb67521cccc11b8bae (patch)
tree6e98aafc395af17dd7f2403601ce4e601302ef4e /sw/source
parenta69de8695755f4ae4d12358acb40c7cffcf1b84e (diff)
weld SwTableColumnPage
Change-Id: I2e92de5899bdee7c5a8a7c29c3a0f407cbb5a1d3 Reviewed-on: https://gerrit.libreoffice.org/55645 Tested-by: Jenkins <ci@libreoffice.org> Reviewed-by: Caolán McNamara <caolanm@redhat.com> Tested-by: Caolán McNamara <caolanm@redhat.com>
Diffstat (limited to 'sw/source')
-rw-r--r--sw/source/ui/table/tabledlg.cxx228
-rw-r--r--sw/source/uibase/inc/prcntfld.hxx1
-rw-r--r--sw/source/uibase/table/tablepg.hxx39
3 files changed, 113 insertions, 155 deletions
diff --git a/sw/source/ui/table/tabledlg.cxx b/sw/source/ui/table/tabledlg.cxx
index 9f9c703d7e60..ee4fb784772f 100644
--- a/sw/source/ui/table/tabledlg.cxx
+++ b/sw/source/ui/table/tabledlg.cxx
@@ -131,7 +131,7 @@ void SwFormatTablePage::Init()
m_xRightBtn->connect_toggled( aLk2 );
m_xCenterBtn->connect_toggled( aLk2 );
- Link<weld::MetricSpinButton&,void> aLk = LINK( this, SwFormatTablePage, UpDownHdl );
+ Link<weld::MetricSpinButton&,void> aLk = LINK(this, SwFormatTablePage, ValueChangedHdl);
m_xTopMF->connect_value_changed(aLk);
m_xBottomMF->connect_value_changed(aLk);
m_xRightMF->connect_value_changed(aLk);
@@ -256,9 +256,9 @@ void SwFormatTablePage::RightModify()
}
}
-IMPL_LINK( SwFormatTablePage, UpDownHdl, weld::MetricSpinButton&, rEdit, void )
+IMPL_LINK( SwFormatTablePage, ValueChangedHdl, weld::MetricSpinButton&, rEdit, void )
{
- if( m_xRightMF->get() == &rEdit)
+ if (m_xRightMF->get() == &rEdit)
RightModify();
ModifyHdl(rEdit);
}
@@ -697,9 +697,8 @@ DeactivateRC SwFormatTablePage::DeactivatePage( SfxItemSet* _pSet )
}
//Description: Page column configuration
-SwTableColumnPage::SwTableColumnPage(vcl::Window* pParent, const SfxItemSet& rSet)
- : SfxTabPage(pParent, "TableColumnPage",
- "modules/swriter/ui/tablecolumnpage.ui", &rSet)
+SwTableColumnPage::SwTableColumnPage(TabPageParent pParent, const SfxItemSet& rSet)
+ : SfxTabPage(pParent, "modules/swriter/ui/tablecolumnpage.ui", "TableColumnPage", &rSet)
, pTableData(nullptr)
, nTableWidth(0)
, nMinWidth(MINLAY)
@@ -708,28 +707,25 @@ SwTableColumnPage::SwTableColumnPage(vcl::Window* pParent, const SfxItemSet& rSe
, bModified(false)
, bModifyTable(false)
, bPercentMode(false)
+ , m_aFieldArr { m_xBuilder->weld_metric_spin_button("width1", FUNIT_CM),
+ m_xBuilder->weld_metric_spin_button("width2", FUNIT_CM),
+ m_xBuilder->weld_metric_spin_button("width3", FUNIT_CM),
+ m_xBuilder->weld_metric_spin_button("width4", FUNIT_CM),
+ m_xBuilder->weld_metric_spin_button("width5", FUNIT_CM),
+ m_xBuilder->weld_metric_spin_button("width6", FUNIT_CM) }
+ , m_aTextArr { std::unique_ptr<weld::Label>(m_xBuilder->weld_label("1")),
+ std::unique_ptr<weld::Label>(m_xBuilder->weld_label("2")),
+ std::unique_ptr<weld::Label>(m_xBuilder->weld_label("3")),
+ std::unique_ptr<weld::Label>(m_xBuilder->weld_label("4")),
+ std::unique_ptr<weld::Label>(m_xBuilder->weld_label("5")),
+ std::unique_ptr<weld::Label>(m_xBuilder->weld_label("6")) }
+ , m_xModifyTableCB(m_xBuilder->weld_check_button("adaptwidth"))
+ , m_xProportionalCB(m_xBuilder->weld_check_button("adaptcolumns"))
+ , m_xSpaceFT(m_xBuilder->weld_label("spaceft"))
+ , m_xSpaceED(m_xBuilder->weld_metric_spin_button("space", FUNIT_CM))
+ , m_xUpBtn(m_xBuilder->weld_button("next"))
+ , m_xDownBtn(m_xBuilder->weld_button("back"))
{
- get(m_pModifyTableCB, "adaptwidth");
- get(m_pProportionalCB, "adaptcolumns");
- get(m_pSpaceFT, "spaceft");
- get(m_pSpaceED, "space-nospin");
- get(m_pUpBtn, "next");
- get(m_pDownBtn, "back");
-
- m_aFieldArr[0].set(get<MetricField>("width1"));
- m_aFieldArr[1].set(get<MetricField>("width2"));
- m_aFieldArr[2].set(get<MetricField>("width3"));
- m_aFieldArr[3].set(get<MetricField>("width4"));
- m_aFieldArr[4].set(get<MetricField>("width5"));
- m_aFieldArr[5].set(get<MetricField>("width6"));
-
- m_pTextArr[0] = get<FixedText>("1");
- m_pTextArr[1] = get<FixedText>("2");
- m_pTextArr[2] = get<FixedText>("3");
- m_pTextArr[3] = get<FixedText>("4");
- m_pTextArr[4] = get<FixedText>("5");
- m_pTextArr[5] = get<FixedText>("6");
-
SetExchangeSupport();
const SfxPoolItem* pItem;
@@ -739,26 +735,11 @@ SwTableColumnPage::SwTableColumnPage(vcl::Window* pParent, const SfxItemSet& rSe
SwTableColumnPage::~SwTableColumnPage()
{
- disposeOnce();
-}
-
-void SwTableColumnPage::dispose()
-{
- m_pModifyTableCB.clear();
- m_pProportionalCB.clear();
- m_pSpaceFT.clear();
- m_pSpaceED.clear();
- m_pUpBtn.clear();
- m_pDownBtn.clear();
- for (auto& p : m_pTextArr)
- p.clear();
- SfxTabPage::dispose();
}
-VclPtr<SfxTabPage> SwTableColumnPage::Create( TabPageParent pParent,
- const SfxItemSet* rAttrSet)
+VclPtr<SfxTabPage> SwTableColumnPage::Create(TabPageParent pParent, const SfxItemSet* rAttrSet)
{
- return VclPtr<SwTableColumnPage>::Create( pParent.pParent, *rAttrSet );
+ return VclPtr<SwTableColumnPage>::Create(pParent, *rAttrSet);
}
void SwTableColumnPage::Reset( const SfxItemSet* )
@@ -786,19 +767,19 @@ void SwTableColumnPage::Reset( const SfxItemSet* )
{
m_aFieldArr[i].SetPrcntValue( m_aFieldArr[i].NormalizePercent(
GetVisibleWidth(i) ), FUNIT_TWIP );
- m_aFieldArr[i].SetMin( nMinTwips , FUNIT_TWIP );
- m_aFieldArr[i].SetMax( nMaxTwips , FUNIT_TWIP );
- m_aFieldArr[i].Enable();
- m_pTextArr[i]->Enable();
+ m_aFieldArr[i].set_min(nMinTwips, FUNIT_TWIP);
+ m_aFieldArr[i].set_max(nMaxTwips, FUNIT_TWIP);
+ m_aFieldArr[i].set_sensitive(true);
+ m_aTextArr[i]->set_sensitive(true);
}
if( nNoOfVisibleCols > MET_FIELDS )
- m_pUpBtn->Enable();
+ m_xUpBtn->set_sensitive(true);
for( sal_uInt16 i = nNoOfVisibleCols; i < MET_FIELDS; ++i )
{
- m_aFieldArr[i].SetText( OUString() );
- m_pTextArr[i]->Disable();
+ m_aFieldArr[i].set_text(OUString());
+ m_aTextArr[i]->set_sensitive(false);
}
}
ActivatePage(rSet);
@@ -808,32 +789,28 @@ void SwTableColumnPage::Reset( const SfxItemSet* )
void SwTableColumnPage::Init(bool bWeb)
{
FieldUnit aMetric = ::GetDfltMetric(bWeb);
- Link<SpinField&,void> aLkUp = LINK( this, SwTableColumnPage, UpHdl );
- Link<SpinField&,void> aLkDown = LINK( this, SwTableColumnPage, DownHdl );
- Link<Control&,void> aLkLF = LINK( this, SwTableColumnPage, LoseFocusHdl );
- for( sal_uInt16 i = 0; i < MET_FIELDS; i++ )
+ Link<weld::MetricSpinButton&,void> aLk = LINK(this, SwTableColumnPage, ValueChangedHdl);
+ for (sal_uInt16 i = 0; i < MET_FIELDS; ++i)
{
aValueTable[i] = i;
m_aFieldArr[i].SetMetric(aMetric);
- m_aFieldArr[i].SetUpHdl( aLkUp );
- m_aFieldArr[i].SetDownHdl( aLkDown );
- m_aFieldArr[i].SetLoseFocusHdl( aLkLF );
+ m_aFieldArr[i].connect_value_changed(aLk);
}
- SetMetric(*m_pSpaceED, aMetric);
+ SetFieldUnit(*m_xSpaceED, aMetric);
- Link<Button*,void> aLk = LINK( this, SwTableColumnPage, AutoClickHdl );
- m_pUpBtn->SetClickHdl( aLk );
- m_pDownBtn->SetClickHdl( aLk );
+ Link<weld::Button&,void> aClickLk = LINK(this, SwTableColumnPage, AutoClickHdl);
+ m_xUpBtn->connect_clicked(aClickLk);
+ m_xDownBtn->connect_clicked(aClickLk);
- aLk = LINK( this, SwTableColumnPage, ModeHdl );
- m_pModifyTableCB->SetClickHdl( aLk );
- m_pProportionalCB->SetClickHdl( aLk );
+ Link<weld::ToggleButton&,void> aToggleLk = LINK(this, SwTableColumnPage, ModeHdl);
+ m_xModifyTableCB->connect_toggled(aToggleLk);
+ m_xProportionalCB->connect_toggled(aToggleLk);
}
-IMPL_LINK( SwTableColumnPage, AutoClickHdl, Button*, pControl, void )
+IMPL_LINK(SwTableColumnPage, AutoClickHdl, weld::Button&, rControl, void)
{
//move display window
- if(pControl == m_pDownBtn.get())
+ if (&rControl == m_xDownBtn.get())
{
if(aValueTable[0] > 0)
{
@@ -841,7 +818,7 @@ IMPL_LINK( SwTableColumnPage, AutoClickHdl, Button*, pControl, void )
rn -= 1;
}
}
- if (pControl == m_pUpBtn.get())
+ if (&rControl == m_xUpBtn.get())
{
if( aValueTable[ MET_FIELDS -1 ] < nNoOfVisibleCols -1 )
{
@@ -854,88 +831,72 @@ IMPL_LINK( SwTableColumnPage, AutoClickHdl, Button*, pControl, void )
OUString sEntry('~');
OUString sIndex = OUString::number( aValueTable[i] + 1 );
sEntry += sIndex;
- m_pTextArr[i]->SetText( sEntry );
+ m_aTextArr[i]->set_label(sEntry);
}
- m_pDownBtn->Enable(aValueTable[0] > 0);
- m_pUpBtn->Enable(aValueTable[ MET_FIELDS -1 ] < nNoOfVisibleCols -1 );
+ m_xDownBtn->set_sensitive(aValueTable[0] > 0);
+ m_xUpBtn->set_sensitive(aValueTable[ MET_FIELDS -1 ] < nNoOfVisibleCols -1 );
UpdateCols(0);
}
-IMPL_LINK( SwTableColumnPage, UpHdl, SpinField&, rEdit, void )
+IMPL_LINK(SwTableColumnPage, ValueChangedHdl, weld::MetricSpinButton&, rEdit, void)
{
bModified = true;
- ModifyHdl( static_cast<MetricField*>(&rEdit) );
+ ModifyHdl(&rEdit);
}
-IMPL_LINK( SwTableColumnPage, DownHdl, SpinField&, rEdit, void )
+IMPL_LINK(SwTableColumnPage, ModeHdl, weld::ToggleButton&, rBox, void)
{
- bModified = true;
- ModifyHdl( static_cast<MetricField*>(&rEdit) );
-}
-
-IMPL_LINK( SwTableColumnPage, LoseFocusHdl, Control&, rControl, void )
-{
- MetricField* pEdit = static_cast<MetricField*>(&rControl);
- if (pEdit->IsModified())
+ const bool bCheck = rBox.get_active();
+ if (&rBox == m_xProportionalCB.get())
{
- bModified = true;
- ModifyHdl( pEdit );
+ if (bCheck)
+ m_xModifyTableCB->set_active(true);
+ m_xModifyTableCB->set_sensitive(!bCheck && bModifyTable);
}
}
-IMPL_LINK( SwTableColumnPage, ModeHdl, Button*, pBox, void )
+bool SwTableColumnPage::FillItemSet( SfxItemSet* )
{
- bool bCheck = static_cast<CheckBox*>(pBox)->IsChecked();
- if (pBox == m_pProportionalCB)
+ for (SwPercentField & i : m_aFieldArr)
{
- if(bCheck)
- m_pModifyTableCB->Check();
- m_pModifyTableCB->Enable(!bCheck && bModifyTable);
- }
-}
-
-bool SwTableColumnPage::FillItemSet( SfxItemSet* )
-{
- for(PercentField & i : m_aFieldArr)
- {
- if (i.HasFocus())
+ if (i.has_focus())
{
- LoseFocusHdl(*i.get());
+ ModifyHdl(i.get());
break;
}
}
- if(bModified)
+ if (bModified)
{
pTableData->SetColsChanged();
}
return bModified;
}
-void SwTableColumnPage::ModifyHdl( MetricField const * pField )
+void SwTableColumnPage::ModifyHdl(const weld::MetricSpinButton* pField)
{
- PercentField *pEdit = nullptr;
- sal_uInt16 i;
+ SwPercentField *pEdit = nullptr;
+ sal_uInt16 i;
- for( i = 0; i < MET_FIELDS; i++)
+ for( i = 0; i < MET_FIELDS; i++)
+ {
+ if (pField == m_aFieldArr[i].get())
{
- if (pField == m_aFieldArr[i].get())
- {
- pEdit = &m_aFieldArr[i];
- break;
- }
+ pEdit = &m_aFieldArr[i];
+ break;
}
+ }
- if (MET_FIELDS <= i || !pEdit)
- {
- OSL_ENSURE(false, "cannot happen.");
- return;
- }
+ if (MET_FIELDS <= i || !pEdit)
+ {
+ OSL_ENSURE(false, "cannot happen.");
+ return;
+ }
- SetVisibleWidth(aValueTable[i], static_cast< SwTwips >(pEdit->DenormalizePercent(pEdit->GetValue( FUNIT_TWIP ))) );
+ SetVisibleWidth(aValueTable[i], pEdit->DenormalizePercent(pEdit->get_value(FUNIT_TWIP)));
- UpdateCols( aValueTable[i] );
+ UpdateCols( aValueTable[i] );
}
void SwTableColumnPage::UpdateCols( sal_uInt16 nCurrentPos )
@@ -948,8 +909,8 @@ void SwTableColumnPage::UpdateCols( sal_uInt16 nCurrentPos )
}
SwTwips nDiff = nSum - nTableWidth;
- bool bModifyTableChecked = m_pModifyTableCB->IsChecked();
- bool bProp = m_pProportionalCB->IsChecked();
+ bool bModifyTableChecked = m_xModifyTableCB->get_active();
+ bool bProp = m_xProportionalCB->get_active();
if (!bModifyTableChecked && !bProp)
{
@@ -1041,17 +1002,16 @@ void SwTableColumnPage::UpdateCols( sal_uInt16 nCurrentPos )
}
if(!bPercentMode)
- m_pSpaceED->SetValue(m_pSpaceED->Normalize( pTableData->GetSpace() - nTableWidth) , FUNIT_TWIP);
+ m_xSpaceED->set_value(m_xSpaceED->normalize(pTableData->GetSpace() - nTableWidth), FUNIT_TWIP);
for( sal_uInt16 i = 0; ( i < nNoOfVisibleCols ) && ( i < MET_FIELDS ); i++)
{
m_aFieldArr[i].SetPrcntValue(m_aFieldArr[i].NormalizePercent(
GetVisibleWidth(aValueTable[i]) ), FUNIT_TWIP);
- m_aFieldArr[i].ClearModifyFlag();
}
}
-void SwTableColumnPage::ActivatePage( const SfxItemSet& )
+void SwTableColumnPage::ActivatePage( const SfxItemSet& )
{
bPercentMode = pTableData->GetWidthPercent() != 0;
for( sal_uInt16 i = 0; (i < MET_FIELDS) && (i < nNoOfVisibleCols); i++ )
@@ -1070,27 +1030,27 @@ void SwTableColumnPage::ActivatePage( const SfxItemSet& )
UpdateCols(0);
}
bModifyTable = true;
- if(pTableData->GetWidthPercent() ||
+ if (pTableData->GetWidthPercent() ||
text::HoriOrientation::FULL == nTableAlign ||
pTableData->IsLineSelected() )
bModifyTable = false;
- if(bPercentMode)
+ if (bPercentMode)
{
- m_pModifyTableCB->Check(false);
- m_pProportionalCB->Check(false);
+ m_xModifyTableCB->set_active(false);
+ m_xProportionalCB->set_active(false);
}
- else if( !bModifyTable )
+ else if (!bModifyTable)
{
- m_pProportionalCB->Check(false);
- m_pModifyTableCB->Check(false);
+ m_xProportionalCB->set_active(false);
+ m_xModifyTableCB->set_active(false);
}
- m_pSpaceFT->Enable(!bPercentMode);
- m_pSpaceED->Enable(!bPercentMode);
- m_pModifyTableCB->Enable( !bPercentMode && bModifyTable );
- m_pProportionalCB->Enable(!bPercentMode && bModifyTable );
+ m_xSpaceFT->set_sensitive(!bPercentMode);
+ m_xSpaceED->set_sensitive(!bPercentMode);
+ m_xModifyTableCB->set_sensitive( !bPercentMode && bModifyTable );
+ m_xProportionalCB->set_sensitive(!bPercentMode && bModifyTable );
- m_pSpaceED->SetValue(m_pSpaceED->Normalize(
- pTableData->GetSpace() - nTableWidth) , FUNIT_TWIP);
+ m_xSpaceED->set_value(m_xSpaceED->normalize(
+ pTableData->GetSpace() - nTableWidth), FUNIT_TWIP);
}
diff --git a/sw/source/uibase/inc/prcntfld.hxx b/sw/source/uibase/inc/prcntfld.hxx
index 4e3e0c3f8a2e..21f9978338e8 100644
--- a/sw/source/uibase/inc/prcntfld.hxx
+++ b/sw/source/uibase/inc/prcntfld.hxx
@@ -124,6 +124,7 @@ public:
bool has_focus() const { return m_pField->has_focus(); }
void save_value() { m_pField->save_value(); }
bool get_value_changed_from_saved() const { return m_pField->get_value_changed_from_saved(); }
+ void set_text(const OUString& rStr) { m_pField->set_text(rStr); }
void SetMetricFieldMin(int nNewMin) { m_pField->set_min(nNewMin, FUNIT_NONE); }
void SetMetricFieldMax(int nNewMax) { m_pField->set_max(nNewMax, FUNIT_NONE); }
diff --git a/sw/source/uibase/table/tablepg.hxx b/sw/source/uibase/table/tablepg.hxx
index 3883de6cd2b6..dc4e4abda802 100644
--- a/sw/source/uibase/table/tablepg.hxx
+++ b/sw/source/uibase/table/tablepg.hxx
@@ -75,7 +75,7 @@ class SwFormatTablePage : public SfxTabPage
DECL_LINK(AutoClickHdl, weld::ToggleButton&, void);
DECL_LINK(RelWidthClickHdl, weld::ToggleButton&, void);
void RightModify();
- DECL_LINK(UpDownHdl, weld::MetricSpinButton&, void);
+ DECL_LINK(ValueChangedHdl, weld::MetricSpinButton&, void);
using TabPage::ActivatePage;
using TabPage::DeactivatePage;
@@ -96,33 +96,31 @@ public:
class SwTableColumnPage : public SfxTabPage
{
- VclPtr<CheckBox> m_pModifyTableCB;
- VclPtr<CheckBox> m_pProportionalCB;
- VclPtr<FixedText> m_pSpaceFT;
- VclPtr<MetricField> m_pSpaceED;
- VclPtr<PushButton> m_pUpBtn;
- VclPtr<PushButton> m_pDownBtn;
-
SwTableRep* pTableData;
- PercentField m_aFieldArr[MET_FIELDS];
- VclPtr<FixedText> m_pTextArr[MET_FIELDS];
SwTwips nTableWidth;
SwTwips nMinWidth;
- sal_uInt16 nNoOfCols;
- sal_uInt16 nNoOfVisibleCols;
+ sal_uInt16 nNoOfCols;
+ sal_uInt16 nNoOfVisibleCols;
// Remember the width, when switching to autoalign
- sal_uInt16 aValueTable[MET_FIELDS];// primary assignment of the MetricFields
+ sal_uInt16 aValueTable[MET_FIELDS];// primary assignment of the MetricFields
bool bModified:1;
bool bModifyTable:1;
bool bPercentMode:1;
+ SwPercentField m_aFieldArr[MET_FIELDS];
+ std::unique_ptr<weld::Label> m_aTextArr[MET_FIELDS];
+ std::unique_ptr<weld::CheckButton> m_xModifyTableCB;
+ std::unique_ptr<weld::CheckButton> m_xProportionalCB;
+ std::unique_ptr<weld::Label> m_xSpaceFT;
+ std::unique_ptr<weld::MetricSpinButton> m_xSpaceED;
+ std::unique_ptr<weld::Button> m_xUpBtn;
+ std::unique_ptr<weld::Button> m_xDownBtn;
+
void Init(bool bWeb);
- DECL_LINK( AutoClickHdl, Button *, void );
- void ModifyHdl( MetricField const * pEdit );
- DECL_LINK( UpHdl, SpinField&, void );
- DECL_LINK( DownHdl, SpinField&, void );
- DECL_LINK( LoseFocusHdl, Control&, void );
- DECL_LINK( ModeHdl, Button *, void );
+ DECL_LINK(AutoClickHdl, weld::Button&, void);
+ void ModifyHdl(const weld::MetricSpinButton* pEdit);
+ DECL_LINK(ValueChangedHdl, weld::MetricSpinButton&, void);
+ DECL_LINK(ModeHdl, weld::ToggleButton&, void);
void UpdateCols( sal_uInt16 nCurrentPos );
SwTwips GetVisibleWidth(sal_uInt16 nPos);
void SetVisibleWidth(sal_uInt16 nPos, SwTwips nNewWidth);
@@ -131,9 +129,8 @@ class SwTableColumnPage : public SfxTabPage
using TabPage::DeactivatePage;
public:
- SwTableColumnPage( vcl::Window* pParent, const SfxItemSet& rSet );
+ SwTableColumnPage(TabPageParent pParent, const SfxItemSet& rSet);
virtual ~SwTableColumnPage() override;
- virtual void dispose() override;
static VclPtr<SfxTabPage> Create( TabPageParent pParent, const SfxItemSet* rAttrSet);
virtual bool FillItemSet( SfxItemSet* rSet ) override;