sw/qa/extras/ooxmlexport/ooxmlfieldexport.cxx | 4 ++-- writerfilter/source/dmapper/DomainMapper.cxx | 22 ++++++---------------- 2 files changed, 8 insertions(+), 18 deletions(-)
New commits: commit a50d82eca96d04b4cea1ea2c7b3610bf9ed951f0 Author: Tamás Zolnai <tamas.zol...@collabora.com> AuthorDate: Wed Jul 3 19:57:19 2019 +0200 Commit: Tamás Zolnai <tamas.zol...@collabora.com> CommitDate: Fri Jul 12 07:04:49 2019 +0200 MSForms: DOCX filter: The new text-based date field is allowed in the header. Change-Id: I71d61c702ccd0470c4c3df09531704783c1b3e01 Reviewed-on: https://gerrit.libreoffice.org/75457 Reviewed-by: Tamás Zolnai <tamas.zol...@collabora.com> Tested-by: Tamás Zolnai <tamas.zol...@collabora.com> diff --git a/sw/qa/extras/ooxmlexport/ooxmlfieldexport.cxx b/sw/qa/extras/ooxmlexport/ooxmlfieldexport.cxx index 3d3c528ef41a..b5b6b6040216 100644 --- a/sw/qa/extras/ooxmlexport/ooxmlfieldexport.cxx +++ b/sw/qa/extras/ooxmlexport/ooxmlfieldexport.cxx @@ -589,13 +589,13 @@ DECLARE_OOXMLEXPORT_TEST(testfdo82492, "fdo82492.docx") assertXPath(pXmlDoc, "/w:document/w:body/w:p/w:sdt[1]/w:sdtContent/w:r",1); } -/*DECLARE_OOXMLEXPORT_TEST(testSdtHeader, "sdt-header.docx") +DECLARE_OOXMLEXPORT_TEST(testSdtHeader, "sdt-header.docx") { // Problem was that w:sdt elements in headers were lost on import. if (xmlDocPtr pXmlDoc = parseExport("word/header1.xml")) // This was 0, w:sdt (and then w:date) was missing. assertXPath(pXmlDoc, "//w:sdt/w:sdtPr/w:date", 1); -}*/ +} DECLARE_OOXMLEXPORT_TEST(testSdtCompanyMultipara, "sdt-company-multipara.docx") { diff --git a/writerfilter/source/dmapper/DomainMapper.cxx b/writerfilter/source/dmapper/DomainMapper.cxx index e1493a31fcb3..f7822eebff09 100644 --- a/writerfilter/source/dmapper/DomainMapper.cxx +++ b/writerfilter/source/dmapper/DomainMapper.cxx @@ -1019,7 +1019,7 @@ void DomainMapper::lcl_attribute(Id nName, Value & val) if (!m_pImpl->m_pSdtHelper->getDropDownItems().empty()) m_pImpl->m_pSdtHelper->createDropDownControl(); - else if (m_pImpl->m_pSdtHelper->validateDateFormat() && !IsInHeaderFooter()) + else if (m_pImpl->m_pSdtHelper->validateDateFormat()) m_pImpl->m_pSdtHelper->createDateContentControl(); break; case NS_ooxml::LN_CT_SdtListItem_displayText: @@ -2435,30 +2435,20 @@ void DomainMapper::sprmWithProps( Sprm& rSprm, const PropertyMapPtr& rContext ) break; case NS_ooxml::LN_CT_SdtDate_dateFormat: { - if (!IsInHeaderFooter()) - m_pImpl->m_pSdtHelper->getDateFormat().append(sStringValue); - else - m_pImpl->appendGrabBag(m_pImpl->m_aInteropGrabBag, "ooxml:CT_SdtDate_dateFormat", sStringValue); + m_pImpl->m_pSdtHelper->getDateFormat().append(sStringValue); } break; case NS_ooxml::LN_CT_SdtDate_storeMappedDataAs: { - if (IsInHeaderFooter()) - m_pImpl->appendGrabBag(m_pImpl->m_aInteropGrabBag, "ooxml:CT_SdtDate_storeMappedDataAs", sStringValue); } break; case NS_ooxml::LN_CT_SdtDate_calendar: { - if (IsInHeaderFooter()) - m_pImpl->appendGrabBag(m_pImpl->m_aInteropGrabBag, "ooxml:CT_SdtDate_calendar", sStringValue); } break; case NS_ooxml::LN_CT_SdtDate_lid: { - if (!IsInHeaderFooter()) - m_pImpl->m_pSdtHelper->getLocale().append(sStringValue); - else - m_pImpl->appendGrabBag(m_pImpl->m_aInteropGrabBag, "ooxml:CT_SdtDate_lid", sStringValue); + m_pImpl->m_pSdtHelper->getLocale().append(sStringValue); } break; case NS_ooxml::LN_CT_SdtPr_dataBinding: @@ -3227,13 +3217,13 @@ void DomainMapper::lcl_utext(const sal_uInt8 * data_, size_t len) return; } } - // Form controls are not allowed in headers / footers; see sw::DocumentContentOperationsManager::InsertDrawObj() - else if (m_pImpl->m_pSdtHelper->validateDateFormat() && !IsInHeaderFooter()) + else if (m_pImpl->m_pSdtHelper->validateDateFormat()) { // Date field will be imported, so we don't need the corresponding date text in most of the cases // however when fullDate is not specified, but we have a date string we need to import it as // simple text (this is the case when user sets date field manually in MSO). - if(!m_pImpl->m_pSdtHelper->getDate().toString().isEmpty() || sText.isEmpty()) + if((!m_pImpl->m_pSdtHelper->getDate().toString().isEmpty() || sText.isEmpty()) && + (!IsInHeaderFooter() || !m_pImpl->IsDiscardHeaderFooter())) // discard date control with header / footer { return; } _______________________________________________ Libreoffice-commits mailing list libreoffice-comm...@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/libreoffice-commits