diff options
author | Caolán McNamara <caolanm@redhat.com> | 2018-04-08 20:47:09 +0100 |
---|---|---|
committer | Caolán McNamara <caolanm@redhat.com> | 2018-04-09 11:44:03 +0200 |
commit | 27702e0c7aa04665433426567d4cc7857a126f37 (patch) | |
tree | 9549c5ec713e5e251b9def130a574bcc0fdf1ca1 /sw/source/uibase/misc | |
parent | 1a4e0b3003b88f8541a8e0e3264346ced10f4796 (diff) |
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 <ci@libreoffice.org>
Reviewed-by: Caolán McNamara <caolanm@redhat.com>
Tested-by: Caolán McNamara <caolanm@redhat.com>
Diffstat (limited to 'sw/source/uibase/misc')
-rw-r--r-- | sw/source/uibase/misc/numberingtypelistbox.cxx | 118 |
1 files changed, 118 insertions, 0 deletions
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: */ |