include/vcl/weld.hxx | 1 sw/qa/uitest/writer_tests/lineNumbering.py | 4 sw/source/ui/dialog/swdlgfact.cxx | 7 sw/source/ui/dialog/swdlgfact.hxx | 12 + sw/source/ui/misc/linenum.cxx | 203 +++++++++++-------------- sw/source/uibase/inc/linenum.hxx | 52 +++--- sw/source/uibase/inc/numberingtypelistbox.hxx | 15 + sw/source/uibase/misc/numberingtypelistbox.cxx | 118 ++++++++++++++ sw/uiconfig/swriter/ui/linenumbering.ui | 67 +++----- vcl/source/app/salvtables.cxx | 5 vcl/unx/gtk3/gtk3gtkinst.cxx | 9 - 11 files changed, 315 insertions(+), 178 deletions(-)
New commits: commit 27702e0c7aa04665433426567d4cc7857a126f37 Author: Caolán McNamara <caol...@redhat.com> Date: Sun Apr 8 20:47:09 2018 +0100 weld SwLineNumberingDlg and use the same SetFieldUnit as the reset of writer uses Change-Id: I7fbc4743cdcf057a40b4b84375c62293b8edd074 Reviewed-on: https://gerrit.libreoffice.org/52607 Tested-by: Jenkins <c...@libreoffice.org> Reviewed-by: Caolán McNamara <caol...@redhat.com> Tested-by: Caolán McNamara <caol...@redhat.com> diff --git a/include/vcl/weld.hxx b/include/vcl/weld.hxx index 33efcd3e0e41..1f036c563363 100644 --- a/include/vcl/weld.hxx +++ b/include/vcl/weld.hxx @@ -67,6 +67,7 @@ public: virtual void set_margin_bottom(int nMargin) = 0; virtual void set_accessible_name(const OUString& rName) = 0; + virtual OUString get_accessible_name() const = 0; virtual void connect_focus_in(const Link<Widget&, void>& rLink) = 0; virtual void connect_focus_out(const Link<Widget&, void>& rLink) = 0; diff --git a/sw/qa/uitest/writer_tests/lineNumbering.py b/sw/qa/uitest/writer_tests/lineNumbering.py index b9d46ecb1ad6..8d1b1103657d 100644 --- a/sw/qa/uitest/writer_tests/lineNumbering.py +++ b/sw/qa/uitest/writer_tests/lineNumbering.py @@ -87,7 +87,7 @@ class WriterLineNumbering(UITestCase): self.assertEqual(get_state_as_dict(xstyledropdown)["SelectEntryText"], "Bullets") self.assertEqual(get_state_as_dict(xformatdropdown)["SelectEntryText"], "A, B, C, ...") self.assertEqual(get_state_as_dict(xpositiondropdown)["SelectEntryText"], "Right") - self.assertEqual(get_state_as_dict(xspacingspin)["Text"], "1.00 cm") + self.assertEqual(get_state_as_dict(xspacingspin)["Text"], "0.60 cm") self.assertEqual(get_state_as_dict(xintervalspin)["Text"], "6") self.assertEqual(get_state_as_dict(xtextentry)["Text"], ";") self.assertEqual(get_state_as_dict(xlinesspin)["Text"], "4") @@ -118,4 +118,4 @@ class WriterLineNumbering(UITestCase): xCancelBtn = xDialog.getChild("cancel") self.ui_test.close_dialog_through_button(xCancelBtn) self.ui_test.close_doc() -# vim: set shiftwidth=4 softtabstop=4 expandtab: \ No newline at end of file +# vim: set shiftwidth=4 softtabstop=4 expandtab: diff --git a/sw/source/ui/dialog/swdlgfact.cxx b/sw/source/ui/dialog/swdlgfact.cxx index eae34ddfb912..0bfd7b545bee 100644 --- a/sw/source/ui/dialog/swdlgfact.cxx +++ b/sw/source/ui/dialog/swdlgfact.cxx @@ -115,6 +115,10 @@ short AbstractSwMergeTableDlg_Impl::Execute() { return m_xDlg->execute(); } +short AbstractGenericDialog_Impl::Execute() +{ + return m_xDlg->run(); +} short AbstractSwSortDlg_Impl::Execute() { return m_xDlg->execute(); @@ -950,8 +954,7 @@ VclPtr<VclAbstractDialog> SwAbstractDialogFactory_Impl::CreateTitlePageDlg ( vcl VclPtr<VclAbstractDialog> SwAbstractDialogFactory_Impl::CreateVclSwViewDialog(SwView& rView) { - VclPtr<Dialog> pDlg = VclPtr<SwLineNumberingDlg>::Create( &rView ); - return VclPtr<VclAbstractDialog_Impl>::Create( pDlg ); + return VclPtr<AbstractGenericDialog_Impl>::Create(new SwLineNumberingDlg(rView)); } VclPtr<AbstractInsTableDlg> SwAbstractDialogFactory_Impl::CreateInsTableDlg(SwView& rView) diff --git a/sw/source/ui/dialog/swdlgfact.hxx b/sw/source/ui/dialog/swdlgfact.hxx index d2e1f5e342a8..a10c4845fde0 100644 --- a/sw/source/ui/dialog/swdlgfact.hxx +++ b/sw/source/ui/dialog/swdlgfact.hxx @@ -106,6 +106,18 @@ class VclAbstractDialog_Impl : public VclAbstractDialog DECL_ABSTDLG_BASE(VclAbstractDialog_Impl,Dialog) }; +class AbstractGenericDialog_Impl : public VclAbstractDialog +{ +protected: + std::unique_ptr<weld::GenericDialogController> m_xDlg; +public: + explicit AbstractGenericDialog_Impl(weld::GenericDialogController* p) + : m_xDlg(p) + { + } + virtual short Execute() override; +}; + class AbstractSwSortDlg_Impl : public VclAbstractDialog { protected: diff --git a/sw/source/ui/misc/linenum.cxx b/sw/source/ui/misc/linenum.cxx index 3416730d414d..40604b299f1e 100644 --- a/sw/source/ui/misc/linenum.cxx +++ b/sw/source/ui/misc/linenum.cxx @@ -19,6 +19,7 @@ #include <sfx2/viewfrm.hxx> #include <svl/style.hxx> +#include <svtools/unitconv.hxx> #include <view.hxx> #include <wrtsh.hxx> #include <docsh.hxx> @@ -29,7 +30,10 @@ #include <fldbas.hxx> #include <lineinfo.hxx> #include <linenum.hxx> +#include <swmodule.hxx> #include <uitool.hxx> +#include <usrpref.hxx> +#include <wdocsh.hxx> #include <fmtline.hxx> #include <strings.hrc> @@ -58,150 +62,133 @@ static void lcl_setLineNumbering(const OUString& rName, SwWrtShell* pSh, bool bL xStyleSheet->SetItemSet(rSet); } -SwLineNumberingDlg::SwLineNumberingDlg(SwView const *pVw) - : SfxModalDialog( &pVw->GetViewFrame()->GetWindow(), "LineNumberingDialog", - "modules/swriter/ui/linenumbering.ui" ) - , pSh(pVw->GetWrtShellPtr()) +SwLineNumberingDlg::SwLineNumberingDlg(const SwView& rVw) + : GenericDialogController(rVw.GetViewFrame()->GetWindow().GetFrameWeld(), + "modules/swriter/ui/linenumbering.ui", "LineNumberingDialog") + , m_pSh(rVw.GetWrtShellPtr()) + , m_xBodyContent(m_xBuilder->weld_widget("content")) + , m_xDivIntervalFT(m_xBuilder->weld_widget("every")) + , m_xDivIntervalNF(m_xBuilder->weld_spin_button("linesspin")) + , m_xDivRowsFT(m_xBuilder->weld_widget("lines")) + , m_xNumIntervalNF(m_xBuilder->weld_spin_button("intervalspin")) + , m_xCharStyleLB(m_xBuilder->weld_combo_box_text("styledropdown")) + , m_xFormatLB(new NumberingTypeListBox(m_xBuilder->weld_combo_box_text("formatdropdown"))) + , m_xPosLB(m_xBuilder->weld_combo_box_text("positiondropdown")) + , m_xOffsetMF(m_xBuilder->weld_metric_spin_button("spacingspin")) + , m_xDivisorED(m_xBuilder->weld_entry("textentry")) + , m_xCountEmptyLinesCB(m_xBuilder->weld_check_button("blanklines")) + , m_xCountFrameLinesCB(m_xBuilder->weld_check_button("linesintextframes")) + , m_xRestartEachPageCB(m_xBuilder->weld_check_button("restarteverynewpage")) + , m_xNumberingOnCB(m_xBuilder->weld_check_button("shownumbering")) + , m_xNumberingOnFooterHeader(m_xBuilder->weld_check_button("showfooterheadernumbering")) + , m_xOKButton(m_xBuilder->weld_button("ok")) + , m_xNumIntervalFT(m_xBuilder->weld_widget("interval")) + , m_xNumRowsFT(m_xBuilder->weld_widget("intervallines")) { - get(m_pBodyContent, "content"); - get(m_pDivIntervalFT, "every"); - get(m_pDivIntervalNF, "linesspin"); - get(m_pDivRowsFT, "lines"); - get(m_pNumIntervalNF, "intervalspin"); - get(m_pCharStyleLB, "styledropdown"); - get(m_pFormatLB, "formatdropdown"); - get(m_pPosLB, "positiondropdown"); - get(m_pOffsetMF, "spacingspin"); - get(m_pDivisorED, "textentry"); - get(m_pCountEmptyLinesCB, "blanklines"); - get(m_pCountFrameLinesCB, "linesintextframes"); - get(m_pRestartEachPageCB, "restarteverynewpage"); - get(m_pNumberingOnCB, "shownumbering"); - get(m_pNumberingOnFooterHeader, "showfooterheadernumbering"); - - OUString sIntervalName = m_pDivIntervalFT->GetAccessibleName() + m_xFormatLB->Reload(SwInsertNumTypes::Extended); + + OUString sIntervalName = m_xDivIntervalFT->get_accessible_name() + "(" - + m_pDivRowsFT->GetAccessibleName() + + m_xDivRowsFT->get_accessible_name() + ")"; - m_pDivIntervalNF->SetAccessibleName(sIntervalName); + m_xDivIntervalNF->set_accessible_name(sIntervalName); - vcl::Window *pNumIntervalFT = get<vcl::Window>("interval"); - vcl::Window *pNumRowsFT = get<vcl::Window>("intervallines"); - sIntervalName = pNumIntervalFT->GetAccessibleName() + sIntervalName = m_xNumIntervalFT->get_accessible_name() + "(" - + pNumRowsFT->GetAccessibleName() + + m_xNumRowsFT->get_accessible_name() + ")"; - m_pNumIntervalNF->SetAccessibleName(sIntervalName); + m_xNumIntervalNF->set_accessible_name(sIntervalName); // char styles - ::FillCharStyleListBox(*m_pCharStyleLB, pSh->GetView().GetDocShell()); + ::FillCharStyleListBox(*m_xCharStyleLB, m_pSh->GetView().GetDocShell()); - const SwLineNumberInfo &rInf = pSh->GetLineNumberInfo(); - IDocumentStylePoolAccess& rIDSPA = pSh->getIDocumentStylePoolAccess(); + const SwLineNumberInfo &rInf = m_pSh->GetLineNumberInfo(); + IDocumentStylePoolAccess& rIDSPA = m_pSh->getIDocumentStylePoolAccess(); OUString sStyleName(rInf.GetCharFormat( rIDSPA )->GetName()); - const sal_Int32 nPos = m_pCharStyleLB->GetEntryPos(sStyleName); + const int nPos = m_xCharStyleLB->find_text(sStyleName); - if (nPos != LISTBOX_ENTRY_NOTFOUND) - m_pCharStyleLB->SelectEntryPos(nPos); + if (nPos != -1) + m_xCharStyleLB->set_active(nPos); else { if (!sStyleName.isEmpty()) { - m_pCharStyleLB->InsertEntry(sStyleName); - m_pCharStyleLB->SelectEntry(sStyleName); + m_xCharStyleLB->append_text(sStyleName); + m_xCharStyleLB->set_active(sStyleName); } } // format SvxNumType nSelFormat = rInf.GetNumType().GetNumberingType(); - m_pFormatLB->SelectNumberingType(nSelFormat); + m_xFormatLB->SelectNumberingType(nSelFormat); // position - m_pPosLB->SelectEntryPos(static_cast<sal_Int32>(rInf.GetPos())); + m_xPosLB->set_active(rInf.GetPos()); // offset sal_uInt16 nOffset = rInf.GetPosFromLeft(); if (nOffset == USHRT_MAX) nOffset = 0; - m_pOffsetMF->SetValue(m_pOffsetMF->Normalize(nOffset), FUNIT_TWIP); + FieldUnit eFieldUnit = SW_MOD()->GetUsrPref(dynamic_cast< const SwWebDocShell*>( + rVw.GetDocShell()) != nullptr)->GetMetric(); + ::SetFieldUnit(*m_xOffsetMF, eFieldUnit); + m_xOffsetMF->set_value(m_xOffsetMF->normalize(nOffset), FUNIT_TWIP); // numbering offset - m_pNumIntervalNF->SetValue(rInf.GetCountBy()); + m_xNumIntervalNF->set_value(rInf.GetCountBy()); // divider - m_pDivisorED->SetText(rInf.GetDivider()); + m_xDivisorED->set_text(rInf.GetDivider()); // divider offset - m_pDivIntervalNF->SetValue(rInf.GetDividerCountBy()); + m_xDivIntervalNF->set_value(rInf.GetDividerCountBy()); // count - m_pCountEmptyLinesCB->Check(rInf.IsCountBlankLines()); - m_pCountFrameLinesCB->Check(rInf.IsCountInFlys()); - m_pRestartEachPageCB->Check(rInf.IsRestartEachPage()); + m_xCountEmptyLinesCB->set_active(rInf.IsCountBlankLines()); + m_xCountFrameLinesCB->set_active(rInf.IsCountInFlys()); + m_xRestartEachPageCB->set_active(rInf.IsRestartEachPage()); - m_pNumberingOnCB->Check(rInf.IsPaintLineNumbers()); + m_xNumberingOnCB->set_active(rInf.IsPaintLineNumbers()); // Header/Footer Line Numbering - rtl::Reference< SwDocStyleSheet > xStyleSheet = lcl_getDocStyleSheet(SwResId(STR_POOLCOLL_FOOTER), pSh); + rtl::Reference< SwDocStyleSheet > xStyleSheet = lcl_getDocStyleSheet(SwResId(STR_POOLCOLL_FOOTER), m_pSh); if(xStyleSheet.is()) { SfxItemSet& rSet = xStyleSheet->GetItemSet(); const SwFormatLineNumber &aFormat = rSet.Get(RES_LINENUMBER); - if(aFormat.IsCount()) - m_pNumberingOnFooterHeader->SetState(TRISTATE_TRUE); + if (aFormat.IsCount()) + m_xNumberingOnFooterHeader->set_state(TRISTATE_TRUE); else - m_pNumberingOnFooterHeader->SetState(TRISTATE_FALSE); + m_xNumberingOnFooterHeader->set_state(TRISTATE_FALSE); } // Line Numbering - m_pNumberingOnCB->SetClickHdl(LINK(this, SwLineNumberingDlg, LineOnOffHdl)); - m_pDivisorED->SetModifyHdl(LINK(this, SwLineNumberingDlg, ModifyHdl)); - ModifyHdl(*m_pDivisorED); - LineOnOffHdl(nullptr); + m_xNumberingOnCB->connect_clicked(LINK(this, SwLineNumberingDlg, LineOnOffHdl)); + m_xDivisorED->connect_changed(LINK(this, SwLineNumberingDlg, ModifyHdl)); + ModifyHdl(*m_xDivisorED); + LineOnOffHdl(*m_xNumberingOnCB); - get<PushButton>("ok")->SetClickHdl(LINK(this, SwLineNumberingDlg, OKHdl)); + m_xOKButton->connect_clicked(LINK(this, SwLineNumberingDlg, OKHdl)); } SwLineNumberingDlg::~SwLineNumberingDlg() { - disposeOnce(); } -void SwLineNumberingDlg::dispose() -{ - m_pBodyContent.clear(); - m_pDivIntervalFT.clear(); - m_pDivIntervalNF.clear(); - m_pDivRowsFT.clear(); - m_pNumIntervalNF.clear(); - m_pCharStyleLB.clear(); - m_pFormatLB.clear(); - m_pPosLB.clear(); - m_pOffsetMF.clear(); - m_pDivisorED.clear(); - m_pCountEmptyLinesCB.clear(); - m_pCountFrameLinesCB.clear(); - m_pRestartEachPageCB.clear(); - m_pNumberingOnCB.clear(); - m_pNumberingOnFooterHeader.clear(); - SfxModalDialog::dispose(); -} - - -IMPL_LINK_NOARG(SwLineNumberingDlg, OKHdl, Button*, void) +IMPL_LINK_NOARG(SwLineNumberingDlg, OKHdl, weld::Button&, void) { - SwLineNumberInfo aInf(pSh->GetLineNumberInfo()); + SwLineNumberInfo aInf(m_pSh->GetLineNumberInfo()); // char styles - OUString sCharFormatName(m_pCharStyleLB->GetSelectedEntry()); - SwCharFormat *pCharFormat = pSh->FindCharFormatByName(sCharFormatName); + OUString sCharFormatName(m_xCharStyleLB->get_active_text()); + SwCharFormat *pCharFormat = m_pSh->FindCharFormatByName(sCharFormatName); if (!pCharFormat) { - SfxStyleSheetBasePool* pPool = pSh->GetView().GetDocShell()->GetStyleSheetPool(); + SfxStyleSheetBasePool* pPool = m_pSh->GetView().GetDocShell()->GetStyleSheetPool(); SfxStyleSheetBase* pBase; pBase = pPool->Find(sCharFormatName, SfxStyleFamily::Char); if(!pBase) @@ -214,60 +201,60 @@ IMPL_LINK_NOARG(SwLineNumberingDlg, OKHdl, Button*, void) // format SvxNumberType aType; - aType.SetNumberingType(m_pFormatLB->GetSelectedNumberingType()); + aType.SetNumberingType(m_xFormatLB->GetSelectedNumberingType()); aInf.SetNumType(aType); // position - aInf.SetPos(static_cast<LineNumberPosition>(m_pPosLB->GetSelectedEntryPos())); + aInf.SetPos(static_cast<LineNumberPosition>(m_xPosLB->get_active())); // offset - aInf.SetPosFromLeft(static_cast<sal_uInt16>(m_pOffsetMF->Denormalize(m_pOffsetMF->GetValue(FUNIT_TWIP)))); + aInf.SetPosFromLeft(static_cast<sal_uInt16>(m_xOffsetMF->denormalize(m_xOffsetMF->get_value(FUNIT_TWIP)))); // numbering offset - aInf.SetCountBy(static_cast<sal_uInt16>(m_pNumIntervalNF->GetValue())); + aInf.SetCountBy(static_cast<sal_uInt16>(m_xNumIntervalNF->get_value())); // divider - aInf.SetDivider(m_pDivisorED->GetText()); + aInf.SetDivider(m_xDivisorED->get_text()); // divider offset - aInf.SetDividerCountBy(static_cast<sal_uInt16>(m_pDivIntervalNF->GetValue())); + aInf.SetDividerCountBy(static_cast<sal_uInt16>(m_xDivIntervalNF->get_value())); // count - aInf.SetCountBlankLines(m_pCountEmptyLinesCB->IsChecked()); - aInf.SetCountInFlys(m_pCountFrameLinesCB->IsChecked()); - aInf.SetRestartEachPage(m_pRestartEachPageCB->IsChecked()); + aInf.SetCountBlankLines(m_xCountEmptyLinesCB->get_active()); + aInf.SetCountInFlys(m_xCountFrameLinesCB->get_active()); + aInf.SetRestartEachPage(m_xRestartEachPageCB->get_active()); - aInf.SetPaintLineNumbers(m_pNumberingOnCB->IsChecked()); + aInf.SetPaintLineNumbers(m_xNumberingOnCB->get_active()); - pSh->SetLineNumberInfo(aInf); + m_pSh->SetLineNumberInfo(aInf); // Set LineNumber explicitly for Header and Footer - lcl_setLineNumbering(SwResId(STR_POOLCOLL_FOOTER), pSh, m_pNumberingOnFooterHeader->IsChecked()); - lcl_setLineNumbering(SwResId(STR_POOLCOLL_HEADER), pSh, m_pNumberingOnFooterHeader->IsChecked()); - if( m_pNumberingOnFooterHeader->IsChecked()) - m_pNumberingOnFooterHeader->SetState(TRISTATE_TRUE); + lcl_setLineNumbering(SwResId(STR_POOLCOLL_FOOTER), m_pSh, m_xNumberingOnFooterHeader->get_active()); + lcl_setLineNumbering(SwResId(STR_POOLCOLL_HEADER), m_pSh, m_xNumberingOnFooterHeader->get_active()); + if( m_xNumberingOnFooterHeader->get_active()) + m_xNumberingOnFooterHeader->set_state(TRISTATE_TRUE); else - m_pNumberingOnFooterHeader->SetState(TRISTATE_FALSE); + m_xNumberingOnFooterHeader->set_state(TRISTATE_FALSE); - EndDialog( RET_OK ); + m_xDialog->response(RET_OK); } // modify -IMPL_LINK_NOARG(SwLineNumberingDlg, ModifyHdl, Edit&, void) +IMPL_LINK_NOARG(SwLineNumberingDlg, ModifyHdl, weld::Entry&, void) { - bool bEnable = m_pNumberingOnCB->IsChecked() && !m_pDivisorED->GetText().isEmpty(); + bool bEnable = m_xNumberingOnCB->get_active() && !m_xDivisorED->get_text().isEmpty(); - m_pDivIntervalFT->Enable(bEnable); - m_pDivIntervalNF->Enable(bEnable); - m_pDivRowsFT->Enable(bEnable); + m_xDivIntervalFT->set_sensitive(bEnable); + m_xDivIntervalNF->set_sensitive(bEnable); + m_xDivRowsFT->set_sensitive(bEnable); } // On/Off -IMPL_LINK_NOARG(SwLineNumberingDlg, LineOnOffHdl, Button*, void) +IMPL_LINK_NOARG(SwLineNumberingDlg, LineOnOffHdl, weld::Button&, void) { - bool bEnable = m_pNumberingOnCB->IsChecked(); - m_pBodyContent->Enable(bEnable); - ModifyHdl(*m_pDivisorED); + bool bEnable = m_xNumberingOnCB->get_active(); + m_xBodyContent->set_sensitive(bEnable); + ModifyHdl(*m_xDivisorED); } /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sw/source/uibase/inc/linenum.hxx b/sw/source/uibase/inc/linenum.hxx index 80bee87c15bf..6290c17bd2dc 100644 --- a/sw/source/uibase/inc/linenum.hxx +++ b/sw/source/uibase/inc/linenum.hxx @@ -19,43 +19,41 @@ #ifndef INCLUDED_SW_SOURCE_UIBASE_INC_LINENUM_HXX #define INCLUDED_SW_SOURCE_UIBASE_INC_LINENUM_HXX -#include <sfx2/basedlgs.hxx> -#include <vcl/button.hxx> -#include <vcl/layout.hxx> -#include <vcl/lstbox.hxx> +#include <vcl/weld.hxx> #include "numberingtypelistbox.hxx" -namespace vcl { class Window; } class SwView; class SwWrtShell; -class SwLineNumberingDlg : public SfxModalDialog +class SwLineNumberingDlg : public weld::GenericDialogController { private: - SwWrtShell* pSh; - VclPtr<VclContainer> m_pBodyContent; - VclPtr<vcl::Window> m_pDivIntervalFT; - VclPtr<NumericField> m_pDivIntervalNF; - VclPtr<vcl::Window> m_pDivRowsFT; - VclPtr<NumericField> m_pNumIntervalNF; - VclPtr<ListBox> m_pCharStyleLB; - VclPtr<SwNumberingTypeListBox> m_pFormatLB; - VclPtr<ListBox> m_pPosLB; - VclPtr<MetricField> m_pOffsetMF; - VclPtr<Edit> m_pDivisorED; - VclPtr<CheckBox> m_pCountEmptyLinesCB; - VclPtr<CheckBox> m_pCountFrameLinesCB; - VclPtr<CheckBox> m_pRestartEachPageCB; - VclPtr<CheckBox> m_pNumberingOnCB; - VclPtr<CheckBox> m_pNumberingOnFooterHeader; - DECL_LINK(OKHdl, Button*, void); - DECL_LINK(LineOnOffHdl, Button*, void); - DECL_LINK(ModifyHdl, Edit&, void); + SwWrtShell* m_pSh; + std::unique_ptr<weld::Widget> m_xBodyContent; + std::unique_ptr<weld::Widget> m_xDivIntervalFT; + std::unique_ptr<weld::SpinButton> m_xDivIntervalNF; + std::unique_ptr<weld::Widget> m_xDivRowsFT; + std::unique_ptr<weld::SpinButton> m_xNumIntervalNF; + std::unique_ptr<weld::ComboBoxText> m_xCharStyleLB; + std::unique_ptr<NumberingTypeListBox> m_xFormatLB; + std::unique_ptr<weld::ComboBoxText> m_xPosLB; + std::unique_ptr<weld::MetricSpinButton> m_xOffsetMF; + std::unique_ptr<weld::Entry> m_xDivisorED; + std::unique_ptr<weld::CheckButton> m_xCountEmptyLinesCB; + std::unique_ptr<weld::CheckButton> m_xCountFrameLinesCB; + std::unique_ptr<weld::CheckButton> m_xRestartEachPageCB; + std::unique_ptr<weld::CheckButton> m_xNumberingOnCB; + std::unique_ptr<weld::CheckButton> m_xNumberingOnFooterHeader; + std::unique_ptr<weld::Button> m_xOKButton; + std::unique_ptr<weld::Widget> m_xNumIntervalFT; + std::unique_ptr<weld::Widget> m_xNumRowsFT; + DECL_LINK(OKHdl, weld::Button&, void); + DECL_LINK(LineOnOffHdl, weld::Button&, void); + DECL_LINK(ModifyHdl, weld::Entry&, void); public: - SwLineNumberingDlg(SwView const *pVw); + SwLineNumberingDlg(const SwView& rVw); virtual ~SwLineNumberingDlg() override; - virtual void dispose() override; }; #endif diff --git a/sw/source/uibase/inc/numberingtypelistbox.hxx b/sw/source/uibase/inc/numberingtypelistbox.hxx index 658b4b765ce5..393a60df2ee7 100644 --- a/sw/source/uibase/inc/numberingtypelistbox.hxx +++ b/sw/source/uibase/inc/numberingtypelistbox.hxx @@ -21,6 +21,7 @@ #include <memory> #include <vcl/lstbox.hxx> +#include <vcl/weld.hxx> #include <swdllapi.h> #include <o3tl/typed_flags_set.hxx> #include <editeng/svxenum.hxx> @@ -57,6 +58,20 @@ public: bool SelectNumberingType(SvxNumType nType); }; +class SW_DLLPUBLIC NumberingTypeListBox +{ + std::unique_ptr<weld::ComboBoxText> m_xWidget; + std::unique_ptr<SwNumberingTypeListBox_Impl> m_xImpl; + +public: + NumberingTypeListBox(weld::ComboBoxText* pWidget); + ~NumberingTypeListBox(); + + void Reload(SwInsertNumTypes nTypeFlags); + SvxNumType GetSelectedNumberingType(); + bool SelectNumberingType(SvxNumType nType); +}; + #endif /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sw/source/uibase/misc/numberingtypelistbox.cxx b/sw/source/uibase/misc/numberingtypelistbox.cxx index 31f7c5de9cc4..b55ddb5a983e 100644 --- a/sw/source/uibase/misc/numberingtypelistbox.cxx +++ b/sw/source/uibase/misc/numberingtypelistbox.cxx @@ -184,4 +184,122 @@ bool SwNumberingTypeListBox::SelectNumberingType(SvxNumType nType) return LISTBOX_ENTRY_NOTFOUND != nPos; } +NumberingTypeListBox::NumberingTypeListBox(weld::ComboBoxText* pWidget) + : m_xWidget(pWidget) + , m_xImpl(new SwNumberingTypeListBox_Impl) +{ + uno::Reference<uno::XComponentContext> xContext( ::comphelper::getProcessComponentContext() ); + uno::Reference<text::XDefaultNumberingProvider> xDefNum = text::DefaultNumberingProvider::create(xContext); + m_xImpl->xInfo.set(xDefNum, uno::UNO_QUERY); +} + +NumberingTypeListBox::~NumberingTypeListBox() +{ +} + +void NumberingTypeListBox::Reload(SwInsertNumTypes nTypeFlags) +{ + m_xWidget->clear(); + uno::Sequence<sal_Int16> aTypes; + const sal_Int16* pTypes = nullptr; + if (nTypeFlags & SwInsertNumTypes::Extended) + { + if (m_xImpl->xInfo.is()) + { + aTypes = m_xImpl->xInfo->getSupportedNumberingTypes(); + pTypes = aTypes.getConstArray(); + } + } + + for(size_t i = 0; i < SvxNumberingTypeTable::Count(); i++) + { + sal_IntPtr nValue = SvxNumberingTypeTable::GetValue(i); + bool bInsert = true; + int nPos = -1; + switch(nValue) + { + case style::NumberingType::NUMBER_NONE: + bInsert = bool(nTypeFlags & SwInsertNumTypes::NoNumbering); + nPos = 0; + + break; + case style::NumberingType::CHAR_SPECIAL: + bInsert = bool(nTypeFlags & SwInsertNumTypes::Bullet); + + break; + case style::NumberingType::PAGE_DESCRIPTOR: + bInsert = bool(nTypeFlags & SwInsertNumTypes::PageStyleNumbering); + + break; + case style::NumberingType::BITMAP: + bInsert = bool(nTypeFlags & SwInsertNumTypes::Bitmap ); + + break; + case style::NumberingType::BITMAP | LINK_TOKEN: + bInsert = false; + + break; + default: + if (nValue > style::NumberingType::CHARS_LOWER_LETTER_N) + { + // Insert only if offered by i18n framework per configuration. + bInsert = false; + if (pTypes) + { + for(sal_Int32 nType = 0; nType < aTypes.getLength(); nType++) + { + if (pTypes[nType] == nValue) + { + bInsert = true; + break; // for + } + } + } + } + } + if (bInsert) + { + m_xWidget->insert(nPos, OUString::number(nValue), SvxNumberingTypeTable::GetString(i)); + } + } + if (nTypeFlags & SwInsertNumTypes::Extended) + { + if (pTypes) + { + for (sal_Int32 nType = 0; nType < aTypes.getLength(); nType++) + { + sal_Int16 nCurrent = pTypes[nType]; + if (nCurrent > style::NumberingType::CHARS_LOWER_LETTER_N) + { + if (m_xWidget->find_id(OUString::number(nCurrent)) == -1) + { + m_xWidget->insert(-1, OUString::number(nCurrent), m_xImpl->xInfo->getNumberingIdentifier(nCurrent)); + } + } + } + } + m_xWidget->set_active(0); + } +} + +SvxNumType NumberingTypeListBox::GetSelectedNumberingType() +{ + SvxNumType nRet = SVX_NUM_CHARS_UPPER_LETTER; + int nSelPos = m_xWidget->get_active(); + if (nSelPos != -1) + nRet = static_cast<SvxNumType>(m_xWidget->get_id(nSelPos).toInt32()); +#if OSL_DEBUG_LEVEL > 0 + else + OSL_FAIL("NumberingTypeListBox not selected"); +#endif + return nRet; +} + +bool NumberingTypeListBox::SelectNumberingType(SvxNumType nType) +{ + int nPos = m_xWidget->find_id(OUString::number(nType)); + m_xWidget->set_active(nPos); + return nPos != -1; +} + /* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/sw/uiconfig/swriter/ui/linenumbering.ui b/sw/uiconfig/swriter/ui/linenumbering.ui index 28047802320e..d2bdafc7c27b 100644 --- a/sw/uiconfig/swriter/ui/linenumbering.ui +++ b/sw/uiconfig/swriter/ui/linenumbering.ui @@ -1,8 +1,7 @@ <?xml version="1.0" encoding="UTF-8"?> -<!-- Generated with glade 3.18.3 --> +<!-- Generated with glade 3.20.4 --> <interface domain="sw"> <requires lib="gtk+" version="3.18"/> - <requires lib="LibreOffice" version="1.0"/> <object class="GtkAdjustment" id="intervaladjustment"> <property name="lower">1</property> <property name="upper">1000</property> @@ -16,26 +15,6 @@ <property name="step_increment">1</property> <property name="page_increment">10</property> </object> - <object class="GtkListStore" id="positionstore"> - <columns> - <!-- column-name positions --> - <column type="gchararray"/> - </columns> - <data> - <row> - <col id="0" translatable="yes" context="linenumbering|positionstore">Left</col> - </row> - <row> - <col id="0" translatable="yes" context="linenumbering|positionstore">Right</col> - </row> - <row> - <col id="0" translatable="yes" context="linenumbering|positionstore">Inner</col> - </row> - <row> - <col id="0" translatable="yes" context="linenumbering|positionstore">Outer</col> - </row> - </data> - </object> <object class="GtkAdjustment" id="spacingadjustment"> <property name="upper">9999</property> <property name="value">0.5</property> @@ -46,6 +25,9 @@ <property name="can_focus">False</property> <property name="border_width">6</property> <property name="title" translatable="yes" context="linenumbering|LineNumberingDialog">Line Numbering</property> + <property name="modal">True</property> + <property name="default_width">0</property> + <property name="default_height">0</property> <property name="type_hint">dialog</property> <child internal-child="vbox"> <object class="GtkBox" id="dialog-vbox1"> @@ -61,6 +43,7 @@ <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> @@ -158,10 +141,10 @@ <object class="GtkLabel" id="characterstyle"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|characterstyle">Character style:</property> <property name="use_underline">True</property> <property name="mnemonic_widget">styledropdown</property> + <property name="xalign">0</property> </object> <packing> <property name="left_attach">0</property> @@ -172,8 +155,8 @@ <object class="GtkLabel" id="format"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|format">Format:</property> + <property name="xalign">0</property> </object> <packing> <property name="left_attach">0</property> @@ -184,10 +167,10 @@ <object class="GtkLabel" id="position"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|position">Position:</property> <property name="use_underline">True</property> <property name="mnemonic_widget">positiondropdown</property> + <property name="xalign">0</property> </object> <packing> <property name="left_attach">0</property> @@ -198,10 +181,10 @@ <object class="GtkLabel" id="spacing"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|spacing">Spacing:</property> <property name="use_underline">True</property> - <property name="mnemonic_widget">spacingspin:0.00cm</property> + <property name="mnemonic_widget">spacingspin</property> + <property name="xalign">0</property> </object> <packing> <property name="left_attach">0</property> @@ -212,10 +195,10 @@ <object class="GtkLabel" id="interval"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|interval">Interval:</property> <property name="use_underline">True</property> <property name="mnemonic_widget">intervalspin</property> + <property name="xalign">0</property> </object> <packing> <property name="left_attach">0</property> @@ -223,7 +206,7 @@ </packing> </child> <child> - <object class="GtkComboBox" id="styledropdown"> + <object class="GtkComboBoxText" id="styledropdown"> <property name="visible">True</property> <property name="can_focus">False</property> <property name="hexpand">True</property> @@ -235,11 +218,10 @@ </packing> </child> <child> - <object class="swlo-SwNumberingTypeListBox" id="formatdropdown"> + <object class="GtkComboBoxText" id="formatdropdown"> <property name="visible">True</property> <property name="can_focus">False</property> <property name="hexpand">True</property> - <property name="type">16</property> </object> <packing> <property name="left_attach">1</property> @@ -248,11 +230,16 @@ </packing> </child> <child> - <object class="GtkComboBox" id="positiondropdown"> + <object class="GtkComboBoxText" id="positiondropdown"> <property name="visible">True</property> <property name="can_focus">False</property> <property name="hexpand">True</property> - <property name="model">positionstore</property> + <items> + <item translatable="yes" context="linenumbering|positionstore">Left</item> + <item translatable="yes" context="linenumbering|positionstore">Right</item> + <item translatable="yes" context="linenumbering|positionstore">Inner</item> + <item translatable="yes" context="linenumbering|positionstore">Outer</item> + </items> </object> <packing> <property name="left_attach">1</property> @@ -261,7 +248,7 @@ </packing> </child> <child> - <object class="GtkSpinButton" id="spacingspin:0.00cm"> + <object class="GtkSpinButton" id="spacingspin"> <property name="visible">True</property> <property name="can_focus">True</property> <property name="halign">start</property> @@ -295,8 +282,8 @@ <object class="GtkLabel" id="intervallines"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|intervallines">lines</property> + <property name="xalign">0</property> </object> <packing> <property name="expand">False</property> @@ -359,10 +346,10 @@ <object class="GtkLabel" id="text"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|text">Text:</property> <property name="use_underline">True</property> <property name="mnemonic_widget">textentry</property> + <property name="xalign">0</property> </object> <packing> <property name="left_attach">0</property> @@ -373,10 +360,10 @@ <object class="GtkLabel" id="every"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|every">Every:</property> <property name="use_underline">True</property> <property name="mnemonic_widget">linesspin</property> + <property name="xalign">0</property> </object> <packing> <property name="left_attach">0</property> @@ -387,6 +374,7 @@ <object class="GtkEntry" id="textentry"> <property name="visible">True</property> <property name="can_focus">True</property> + <property name="activates_default">True</property> <property name="width_chars">3</property> </object> <packing> @@ -399,8 +387,8 @@ <object class="GtkLabel" id="lines"> <property name="visible">True</property> <property name="can_focus">False</property> - <property name="xalign">0</property> <property name="label" translatable="yes" context="linenumbering|lines">lines</property> + <property name="xalign">0</property> </object> <packing> <property name="left_attach">2</property> @@ -568,5 +556,8 @@ <action-widget response="-6">cancel</action-widget> <action-widget response="-11">help</action-widget> </action-widgets> + <child> + <placeholder/> + </child> </object> </interface> diff --git a/vcl/source/app/salvtables.cxx b/vcl/source/app/salvtables.cxx index 637f5651d66b..6a31861bce43 100644 --- a/vcl/source/app/salvtables.cxx +++ b/vcl/source/app/salvtables.cxx @@ -310,6 +310,11 @@ public: m_xWidget->SetAccessibleName(rName); } + virtual OUString get_accessible_name() const override + { + return m_xWidget->GetAccessibleName(); + } + virtual void connect_focus_in(const Link<Widget&, void>& rLink) override { assert(!m_aFocusInHdl.IsSet()); diff --git a/vcl/unx/gtk3/gtk3gtkinst.cxx b/vcl/unx/gtk3/gtk3gtkinst.cxx index 081efc63bffb..ebb5dfdde8a3 100644 --- a/vcl/unx/gtk3/gtk3gtkinst.cxx +++ b/vcl/unx/gtk3/gtk3gtkinst.cxx @@ -1332,7 +1332,14 @@ public: AtkObject* pAtkObject = gtk_widget_get_accessible(m_pWidget); if (!pAtkObject) return; - atk_object_set_description(pAtkObject, OUStringToOString(rName, RTL_TEXTENCODING_UTF8).getStr()); + atk_object_set_name(pAtkObject, OUStringToOString(rName, RTL_TEXTENCODING_UTF8).getStr()); + } + + virtual OUString get_accessible_name() const override + { + AtkObject* pAtkObject = gtk_widget_get_accessible(m_pWidget); + const char* pStr = pAtkObject ? atk_object_get_name(pAtkObject) : nullptr; + return OUString(pStr, pStr ? strlen(pStr) : 0, RTL_TEXTENCODING_UTF8); } virtual weld::Container* weld_parent() const override; _______________________________________________ Libreoffice-commits mailing list libreoffice-comm...@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits