diff options
Diffstat (limited to 'sw/source')
-rw-r--r-- | sw/source/uibase/inc/conttree.hxx | 28 | ||||
-rw-r--r-- | sw/source/uibase/inc/navicfg.hxx | 148 | ||||
-rw-r--r-- | sw/source/uibase/utlui/content.cxx | 240 | ||||
-rw-r--r-- | sw/source/uibase/utlui/navicfg.cxx | 72 | ||||
-rw-r--r-- | sw/source/uibase/utlui/navipi.cxx | 21 |
5 files changed, 120 insertions, 389 deletions
diff --git a/sw/source/uibase/inc/conttree.hxx b/sw/source/uibase/inc/conttree.hxx index 0c7eb59dea43..cf1246425ac0 100644 --- a/sw/source/uibase/inc/conttree.hxx +++ b/sw/source/uibase/inc/conttree.hxx @@ -112,19 +112,7 @@ class SwContentTree final : public SfxListener sal_uInt8 m_nOutlineLevel; sal_uInt8 m_nOutlineTracking = 1; // 1 default, 2 focus, 3 off - bool m_bTableTracking = true; - bool m_bSectionTracking = true; - bool m_bFrameTracking = true; - bool m_bImageTracking = true; - bool m_bOLEobjectTracking = true; - bool m_bBookmarkTracking = true; - bool m_bHyperlinkTracking = true; - bool m_bReferenceTracking = true; - bool m_bIndexTracking = true; - bool m_bCommentTracking = true; - bool m_bDrawingObjectTracking = true; - bool m_bFieldTracking = true; - bool m_bFootnoteTracking = true; + o3tl::enumarray<ContentTypeId, bool> mTrackContentType; SwOutlineNodes::size_type m_nLastGotoContentWasOutlinePos = SwOutlineNodes::npos; @@ -230,19 +218,7 @@ public: void SetOutlineLevel(sal_uInt8 nSet); void SetOutlineTracking(sal_uInt8 nSet); - void SetTableTracking(bool bSet); - void SetSectionTracking(bool bSet); - void SetFrameTracking(bool bSet); - void SetImageTracking(bool bSet); - void SetOLEobjectTracking(bool bSet); - void SetBookmarkTracking(bool bSet); - void SetHyperlinkTracking(bool bSet); - void SetReferenceTracking(bool bSet); - void SetIndexTracking(bool bSet); - void SetCommentTracking(bool bSet); - void SetDrawingObjectTracking(bool bSet); - void SetFieldTracking(bool bSet); - void SetFootnoteTracking(bool bSet); + void SetContentTypeTracking(ContentTypeId eCntTypeId, bool bSet); /** Execute commands of the Navigator */ void ExecCommand(std::string_view rCmd, bool bModifier); diff --git a/sw/source/uibase/inc/navicfg.hxx b/sw/source/uibase/inc/navicfg.hxx index e36d45e10302..ad4bb10afb70 100644 --- a/sw/source/uibase/inc/navicfg.hxx +++ b/sw/source/uibase/inc/navicfg.hxx @@ -20,9 +20,8 @@ #define INCLUDED_SW_SOURCE_UIBASE_INC_NAVICFG_HXX #include <unotools/configitem.hxx> - -enum class RegionMode; -enum class ContentTypeId; +#include <o3tl/enumarray.hxx> +#include "swcont.hxx" class SwNavigationConfig final : public utl::ConfigItem { @@ -34,21 +33,10 @@ class SwNavigationConfig final : public utl::ConfigItem bool m_bIsSmall; //ShowListBox bool m_bIsGlobalActive; //GlobalDocMode// global view for GlobalDoc valid? sal_Int32 m_nOutlineTracking; - bool m_bIsTableTracking; - bool m_bIsSectionTracking; - bool m_bIsFrameTracking; - bool m_bIsImageTracking; - bool m_bIsOLEobjectTracking; - bool m_bIsBookmarkTracking; - bool m_bIsHyperlinkTracking; - bool m_bIsReferenceTracking; - bool m_bIsIndexTracking; - bool m_bIsCommentTracking; - bool m_bIsDrawingObjectTracking; - bool m_bIsFieldTracking; - bool m_bIsFootnoteTracking; bool m_bIsNavigateOnSelect; + o3tl::enumarray<ContentTypeId, bool> mContentTypeTrack; + static css::uno::Sequence<OUString> GetPropertyNames(); virtual void ImplCommit() override; @@ -123,122 +111,18 @@ public: } } - bool IsTableTracking() const {return m_bIsTableTracking;} - void SetTableTracking(bool bSet){ - if(m_bIsTableTracking != bSet) - { - SetModified(); - m_bIsTableTracking = bSet; - } - } - - bool IsSectionTracking() const {return m_bIsSectionTracking;} - void SetSectionTracking(bool bSet){ - if(m_bIsSectionTracking != bSet) - { - SetModified(); - m_bIsSectionTracking = bSet; - } - } - - bool IsFrameTracking() const {return m_bIsFrameTracking;} - void SetFrameTracking(bool bSet){ - if(m_bIsFrameTracking != bSet) - { - SetModified(); - m_bIsFrameTracking = bSet; - } - } - - bool IsImageTracking() const {return m_bIsImageTracking;} - void SetImageTracking(bool bSet){ - if(m_bIsImageTracking != bSet) - { - SetModified(); - m_bIsImageTracking = bSet; - } - } - - bool IsOLEobjectTracking() const {return m_bIsOLEobjectTracking;} - void SetOLEobjectTracking(bool bSet){ - if(m_bIsOLEobjectTracking != bSet) - { - SetModified(); - m_bIsOLEobjectTracking = bSet; - } - } - - bool IsBookmarkTracking() const {return m_bIsBookmarkTracking;} - void SetBookmarkTracking(bool bSet){ - if(m_bIsBookmarkTracking != bSet) - { - SetModified(); - m_bIsBookmarkTracking = bSet; - } - } - - bool IsHyperlinkTracking() const {return m_bIsHyperlinkTracking;} - void SetHyperlinkTracking(bool bSet){ - if(m_bIsHyperlinkTracking != bSet) - { - SetModified(); - m_bIsHyperlinkTracking = bSet; - } - } - - bool IsReferenceTracking() const {return m_bIsReferenceTracking;} - void SetReferenceTracking(bool bSet){ - if(m_bIsReferenceTracking != bSet) - { - SetModified(); - m_bIsReferenceTracking = bSet; - } - } - - bool IsIndexTracking() const {return m_bIsIndexTracking;} - void SetIndexTracking(bool bSet){ - if(m_bIsIndexTracking != bSet) - { - SetModified(); - m_bIsIndexTracking = bSet; - } - } - - bool IsCommentTracking() const {return m_bIsCommentTracking;} - void SetCommentTracking(bool bSet){ - if(m_bIsCommentTracking != bSet) - { - SetModified(); - m_bIsCommentTracking = bSet; - } - } - - bool IsDrawingObjectTracking() const {return m_bIsDrawingObjectTracking;} - void SetDrawingObjectTracking(bool bSet){ - if(m_bIsDrawingObjectTracking != bSet) - { - SetModified(); - m_bIsDrawingObjectTracking = bSet; - } - } - - bool IsFieldTracking() const {return m_bIsFieldTracking;} - void SetFieldTracking(bool bSet){ - if(m_bIsFieldTracking != bSet) - { - SetModified(); - m_bIsFieldTracking = bSet; - } - } - - bool IsFootnoteTracking() const {return m_bIsFootnoteTracking;} - void SetFootnoteTracking(bool bSet){ - if(m_bIsFootnoteTracking != bSet) - { - SetModified(); - m_bIsFootnoteTracking = bSet; - } - } + bool IsContentTypeTrack(ContentTypeId eCntTypeId) + { + return mContentTypeTrack[eCntTypeId]; + } + void SetContentTypeTrack(ContentTypeId eCntTypeId, const bool bSet) + { + if (mContentTypeTrack[eCntTypeId] != bSet) + { + SetModified(); + mContentTypeTrack[eCntTypeId] = bSet; + } + } bool IsNavigateOnSelect() const {return m_bIsNavigateOnSelect;} }; diff --git a/sw/source/uibase/utlui/content.cxx b/sw/source/uibase/utlui/content.cxx index 3a52f9d14e84..0f2e290fa510 100644 --- a/sw/source/uibase/utlui/content.cxx +++ b/sw/source/uibase/utlui/content.cxx @@ -954,6 +954,8 @@ SwContentTree::SwContentTree(std::unique_ptr<weld::TreeView> xTreeView, SwNaviga for (ContentTypeId i : o3tl::enumrange<ContentTypeId>()) { + if (i != ContentTypeId::OUTLINE) + mTrackContentType[i] = true; m_aActiveContentArr[i] = nullptr; m_aHiddenContentArr[i] = nullptr; } @@ -1446,62 +1448,66 @@ IMPL_LINK(SwContentTree, CommandHdl, const CommandEvent&, rCEvt, bool) pType = weld::fromId<SwContent*>( m_xTreeView->get_id(*xEntry))->GetParent(); const ContentTypeId nContentType = pType->GetType(); + OString aIdent; switch (nContentType) { case ContentTypeId::TABLE: - xPop->set_active("tabletracking", m_bTableTracking); + aIdent = "tabletracking"; bRemoveTableTracking = false; break; case ContentTypeId::REGION: - xPop->set_active("sectiontracking", m_bSectionTracking); + aIdent = "sectiontracking"; bRemoveSectionTracking = false; break; case ContentTypeId::FRAME: - xPop->set_active("frametracking", m_bFrameTracking); + aIdent = "frametracking"; bRemoveFrameTracking = false; break; case ContentTypeId::GRAPHIC: - xPop->set_active("imagetracking", m_bImageTracking); + aIdent = "imagetracking"; bRemoveImageTracking = false; break; case ContentTypeId::OLE: - xPop->set_active("oleobjecttracking", m_bOLEobjectTracking); + aIdent = "oleobjecttracking"; bRemoveOLEobjectTracking = false; break; case ContentTypeId::BOOKMARK: - xPop->set_active("bookmarktracking", m_bBookmarkTracking); + aIdent = "bookmarktracking"; bRemoveBookmarkTracking = false; break; case ContentTypeId::URLFIELD: - xPop->set_active("hyperlinktracking", m_bHyperlinkTracking); + aIdent = "hyperlinktracking"; bRemoveHyperlinkTracking = false; break; case ContentTypeId::REFERENCE: - xPop->set_active("referencetracking", m_bReferenceTracking); + aIdent = "referencetracking"; bRemoveReferenceTracking = false; break; case ContentTypeId::INDEX: - xPop->set_active("indextracking", m_bIndexTracking); + aIdent = "indextracking"; bRemoveIndexTracking = false; break; case ContentTypeId::POSTIT: - xPop->set_active("commenttracking", m_bCommentTracking); + aIdent = "commenttracking"; bRemoveCommentTracking = false; break; case ContentTypeId::DRAWOBJECT: - xPop->set_active("drawingobjecttracking", m_bDrawingObjectTracking); + aIdent = "drawingobjecttracking"; bRemoveDrawingObjectTracking = false; break; case ContentTypeId::TEXTFIELD: - xPop->set_active("fieldtracking", m_bFieldTracking); + aIdent = "fieldtracking"; bRemoveFieldTracking = false; break; case ContentTypeId::FOOTNOTE: - xPop->set_active("footnotetracking", m_bFootnoteTracking); + aIdent = "footnotetracking"; bRemoveFootnoteTracking = false; break; default: break; } + if (!aIdent.isEmpty()) + xPop->set_active(aIdent, mTrackContentType[nContentType]); + // Edit only if the shown content is coming from the current view. if (State::HIDDEN != m_eState && (State::ACTIVE == m_eState || m_pActiveShell == GetActiveView()->GetWrtShellPtr()) @@ -3460,19 +3466,19 @@ void SwContentTree::UpdateTracking() if (m_pActiveShell->GetSelectionType() == SelectionType::Graphic && !(m_bIsRoot && m_nRootType != ContentTypeId::GRAPHIC)) { - if (!m_bImageTracking) return; + if (!mTrackContentType[ContentTypeId::GRAPHIC]) return; aContentTypeName = SwResId(STR_CONTENT_TYPE_GRAPHIC); } else if (m_pActiveShell->GetSelectionType() == SelectionType::Frame && !(m_bIsRoot && m_nRootType != ContentTypeId::FRAME)) { - if (!m_bFrameTracking) return; + if (!mTrackContentType[ContentTypeId::FRAME]) return; aContentTypeName = SwResId(STR_CONTENT_TYPE_FRAME); } else if (m_pActiveShell->GetSelectionType() == SelectionType::Ole && !(m_bIsRoot && m_nRootType != ContentTypeId::OLE)) { - if (!m_bOLEobjectTracking) return; + if (!mTrackContentType[ContentTypeId::OLE]) return; aContentTypeName = SwResId(STR_CONTENT_TYPE_OLE); } if (!aContentTypeName.isEmpty()) @@ -3488,7 +3494,7 @@ void SwContentTree::UpdateTracking() SelectionType::DbForm)) && !(m_bIsRoot && m_nRootType != ContentTypeId::DRAWOBJECT)) { - if (m_bDrawingObjectTracking) + if (mTrackContentType[ContentTypeId::DRAWOBJECT]) { // Multiple selection is possible when in root content navigation view so unselect all // selected entries before reselecting. This causes a bit of an annoyance when the treeview @@ -3521,13 +3527,14 @@ void SwContentTree::UpdateTracking() m_pActiveShell->GetContentAtPos(m_pActiveShell->GetCursorDocPos(), aContentAtPos) && !(m_bIsRoot && m_nRootType != ContentTypeId::FOOTNOTE)) { - if (m_bFootnoteTracking) + if (mTrackContentType[ContentTypeId::FOOTNOTE]) lcl_SelectByContentTypeAndAddress(this, *m_xTreeView, ContentTypeId::FOOTNOTE, aContentAtPos.pFndTextAttr); return; } // bookmarks - track first bookmark at cursor - if (m_bBookmarkTracking && (m_pActiveShell->GetSelectionType() & SelectionType::Text)) + if (mTrackContentType[ContentTypeId::BOOKMARK] && + (m_pActiveShell->GetSelectionType() & SelectionType::Text)) { SwPaM* pCursor = m_pActiveShell->GetCursor(); IDocumentMarkAccess* const pMarkAccess = m_pActiveShell->getIDocumentMarkAccess(); @@ -3557,7 +3564,7 @@ void SwContentTree::UpdateTracking() aContentAtPos.pFndTextAttr && !(m_bIsRoot && m_nRootType != ContentTypeId::REFERENCE)) { - if (m_bReferenceTracking) + if (mTrackContentType[ContentTypeId::REFERENCE]) { const SwFormatRefMark& rRefMark = aContentAtPos.pFndTextAttr->GetRefMark(); lcl_SelectByContentTypeAndName(this, *m_xTreeView, SwResId(STR_CONTENT_TYPE_REFERENCE), @@ -3574,7 +3581,7 @@ void SwContentTree::UpdateTracking() // in the tree by name may result in incorrect selection. Find the item in the tree by // comparing the SwTextINetFormat pointer at the document cursor position to that stored // in the item SwURLFieldContent. - if (m_bHyperlinkTracking) + if (mTrackContentType[ContentTypeId::URLFIELD]) lcl_SelectByContentTypeAndAddress(this, *m_xTreeView, ContentTypeId::URLFIELD, aContentAtPos.pFndTextAttr); return; @@ -3585,19 +3592,18 @@ void SwContentTree::UpdateTracking() m_nRootType != ContentTypeId::TEXTFIELD && m_nRootType != ContentTypeId::POSTIT)) { - ContentTypeId nContentTypeId = + ContentTypeId eCntTypeId = pField->GetTypeId() == SwFieldTypesEnum::Postit ? ContentTypeId::POSTIT : ContentTypeId::TEXTFIELD; - if ((m_bFieldTracking && nContentTypeId == ContentTypeId::TEXTFIELD) || - (m_bCommentTracking && nContentTypeId == ContentTypeId::POSTIT)) - lcl_SelectByContentTypeAndAddress(this, *m_xTreeView, nContentTypeId, pField); + if (mTrackContentType[eCntTypeId]) + lcl_SelectByContentTypeAndAddress(this, *m_xTreeView, eCntTypeId, pField); return; } // table if (m_pActiveShell->IsCursorInTable() && !(m_bIsRoot && m_nRootType != ContentTypeId::TABLE)) { - if(m_bTableTracking && m_pActiveShell->GetTableFormat()) + if (mTrackContentType[ContentTypeId::TABLE] && m_pActiveShell->GetTableFormat()) { OUString aName = m_pActiveShell->GetTableFormat()->GetName(); lcl_SelectByContentTypeAndName(this, *m_xTreeView, SwResId(STR_CONTENT_TYPE_TABLE), @@ -3609,7 +3615,7 @@ void SwContentTree::UpdateTracking() if (const SwTOXBase* pTOX = m_pActiveShell->GetCurTOX(); pTOX && !(m_bIsRoot && m_nRootType != ContentTypeId::INDEX)) { - if (m_bIndexTracking) + if (mTrackContentType[ContentTypeId::INDEX]) lcl_SelectByContentTypeAndName(this, *m_xTreeView, SwResId(STR_CONTENT_TYPE_INDEX), pTOX->GetTOXName()); return; @@ -3618,7 +3624,7 @@ void SwContentTree::UpdateTracking() if (const SwSection* pSection = m_pActiveShell->GetCurrSection(); pSection && !(m_bIsRoot && m_nRootType != ContentTypeId::REGION)) { - if (m_bSectionTracking) + if (mTrackContentType[ContentTypeId::REGION]) { lcl_SelectByContentTypeAndName(this, *m_xTreeView, SwResId(STR_CONTENT_TYPE_REGION), pSection->GetSectionName()); @@ -4151,83 +4157,31 @@ void SwContentTree::ExecuteContextMenuAction(const OString& rSelectedPopupEntry) } return; } - if (rSelectedPopupEntry == "tabletracking") - { - m_bTableTracking = !m_bTableTracking; - SetTableTracking(m_bTableTracking); - return; - } - if (rSelectedPopupEntry == "sectiontracking") - { - m_bSectionTracking = !m_bSectionTracking; - SetSectionTracking(m_bSectionTracking); - return; - } - if (rSelectedPopupEntry == "frametracking") - { - m_bFrameTracking = !m_bFrameTracking; - SetFrameTracking(m_bFrameTracking); - return; - } - if (rSelectedPopupEntry == "imagetracking") - { - m_bImageTracking = !m_bImageTracking; - SetImageTracking(m_bImageTracking); - return; - } - if (rSelectedPopupEntry == "oleobjecttracking") - { - m_bOLEobjectTracking = !m_bOLEobjectTracking; - SetOLEobjectTracking(m_bOLEobjectTracking); - return; - } - if (rSelectedPopupEntry == "bookmarktracking") - { - m_bBookmarkTracking = !m_bBookmarkTracking; - SetBookmarkTracking(m_bBookmarkTracking); - return; - } - if (rSelectedPopupEntry == "hyperlinktracking") - { - m_bHyperlinkTracking = !m_bHyperlinkTracking; - SetHyperlinkTracking(m_bHyperlinkTracking); - return; - } - if (rSelectedPopupEntry == "referencetracking") - { - m_bReferenceTracking = !m_bReferenceTracking; - SetReferenceTracking(m_bReferenceTracking); - return; - } - if (rSelectedPopupEntry == "indextracking") - { - m_bIndexTracking = !m_bIndexTracking; - SetIndexTracking(m_bIndexTracking); - return; - } - if (rSelectedPopupEntry == "commenttracking") - { - m_bCommentTracking = !m_bCommentTracking; - SetCommentTracking(m_bCommentTracking); - return; - } - if (rSelectedPopupEntry == "drawingobjecttracking") - { - m_bDrawingObjectTracking = !m_bDrawingObjectTracking; - SetDrawingObjectTracking(m_bDrawingObjectTracking); - return; - } - if (rSelectedPopupEntry == "fieldtracking") - { - m_bFieldTracking = !m_bFieldTracking; - SetFieldTracking(m_bFieldTracking); - return; - } - if (rSelectedPopupEntry == "footnotetracking") + { - m_bFootnoteTracking = !m_bFootnoteTracking; - SetFootnoteTracking(m_bFootnoteTracking); - return; + std::map<OString, ContentTypeId> mPopupEntryToContentTypeId + { + {"tabletracking", ContentTypeId::TABLE}, + {"frametracking", ContentTypeId::FRAME}, + {"imagetracking", ContentTypeId::GRAPHIC}, + {"oleobjecttracking", ContentTypeId::OLE}, + {"bookmarktracking", ContentTypeId::BOOKMARK}, + {"sectiontracking", ContentTypeId::REGION}, + {"hyperlinktracking", ContentTypeId::URLFIELD}, + {"referencetracking", ContentTypeId::REFERENCE}, + {"indextracking", ContentTypeId::INDEX}, + {"commenttracking", ContentTypeId::POSTIT}, + {"drawingobjecttracking", ContentTypeId::DRAWOBJECT}, + {"fieldtracking", ContentTypeId::TEXTFIELD}, + {"footnotetracking", ContentTypeId::FOOTNOTE} + }; + + if (mPopupEntryToContentTypeId.count(rSelectedPopupEntry)) + { + ContentTypeId eCntTypeId = mPopupEntryToContentTypeId[rSelectedPopupEntry]; + SetContentTypeTracking(eCntTypeId, !mTrackContentType[eCntTypeId]); + return; + } } std::unique_ptr<weld::TreeIter> xFirst(m_xTreeView->make_iterator()); @@ -4501,82 +4455,10 @@ void SwContentTree::SetOutlineTracking(sal_uInt8 nSet) m_pConfig->SetOutlineTracking(m_nOutlineTracking); } -void SwContentTree::SetTableTracking(bool bSet) -{ - m_bTableTracking = bSet; - m_pConfig->SetTableTracking(m_bTableTracking); -} - -void SwContentTree::SetSectionTracking(bool bSet) -{ - m_bSectionTracking = bSet; - m_pConfig->SetSectionTracking(m_bSectionTracking); -} - -void SwContentTree::SetFrameTracking(bool bSet) -{ - m_bFrameTracking = bSet; - m_pConfig->SetFrameTracking(m_bFrameTracking); -} - -void SwContentTree::SetImageTracking(bool bSet) -{ - m_bImageTracking = bSet; - m_pConfig->SetImageTracking(m_bImageTracking); -} - -void SwContentTree::SetOLEobjectTracking(bool bSet) -{ - m_bOLEobjectTracking = bSet; - m_pConfig->SetOLEobjectTracking(m_bOLEobjectTracking); -} - -void SwContentTree::SetBookmarkTracking(bool bSet) -{ - m_bBookmarkTracking = bSet; - m_pConfig->SetBookmarkTracking(m_bBookmarkTracking); -} - -void SwContentTree::SetHyperlinkTracking(bool bSet) -{ - m_bHyperlinkTracking = bSet; - m_pConfig->SetHyperlinkTracking(m_bHyperlinkTracking); -} - -void SwContentTree::SetReferenceTracking(bool bSet) -{ - m_bReferenceTracking = bSet; - m_pConfig->SetReferenceTracking(m_bReferenceTracking); -} - -void SwContentTree::SetIndexTracking(bool bSet) -{ - m_bIndexTracking = bSet; - m_pConfig->SetIndexTracking(m_bIndexTracking); -} - -void SwContentTree::SetCommentTracking(bool bSet) -{ - m_bCommentTracking = bSet; - m_pConfig->SetCommentTracking(m_bCommentTracking); -} - -void SwContentTree::SetDrawingObjectTracking(bool bSet) -{ - m_bDrawingObjectTracking = bSet; - m_pConfig->SetDrawingObjectTracking(m_bDrawingObjectTracking); -} - -void SwContentTree::SetFieldTracking(bool bSet) -{ - m_bFieldTracking = bSet; - m_pConfig->SetFieldTracking(m_bFieldTracking); -} - -void SwContentTree::SetFootnoteTracking(bool bSet) +void SwContentTree::SetContentTypeTracking(ContentTypeId eCntTypeId, bool bSet) { - m_bFootnoteTracking = bSet; - m_pConfig->SetFootnoteTracking(m_bFootnoteTracking); + mTrackContentType[eCntTypeId] = bSet; + m_pConfig->SetContentTypeTrack(eCntTypeId, bSet); } // Mode Change: Show dropped Doc diff --git a/sw/source/uibase/utlui/navicfg.cxx b/sw/source/uibase/utlui/navicfg.cxx index f06478cf9bbd..2639c1ed52c6 100644 --- a/sw/source/uibase/utlui/navicfg.cxx +++ b/sw/source/uibase/utlui/navicfg.cxx @@ -24,10 +24,30 @@ #include <osl/diagnose.h> #include <sal/log.hxx> #include <com/sun/star/uno/Sequence.hxx> +#include <map> using namespace ::utl; using namespace ::com::sun::star::uno; +namespace { + std::map<OUString, ContentTypeId> mPropNameToContentTypeId + { + {"TableTracking", ContentTypeId::TABLE}, + {"FrameTracking", ContentTypeId::FRAME}, + {"ImageTracking", ContentTypeId::GRAPHIC}, + {"OLEobjectTracking", ContentTypeId::OLE}, + {"BookmarkTracking", ContentTypeId::BOOKMARK}, + {"SectionTracking", ContentTypeId::REGION}, + {"HyperlinkTracking", ContentTypeId::URLFIELD}, + {"ReferenceTracking", ContentTypeId::REFERENCE}, + {"IndexTracking", ContentTypeId::INDEX}, + {"CommentTracking", ContentTypeId::POSTIT}, + {"DrawingObjectTracking", ContentTypeId::DRAWOBJECT}, + {"FieldTracking", ContentTypeId::TEXTFIELD}, + {"FootnoteTracking", ContentTypeId::FOOTNOTE} + }; +} + Sequence<OUString> SwNavigationConfig::GetPropertyNames() { return css::uno::Sequence<OUString>{ @@ -65,19 +85,6 @@ SwNavigationConfig::SwNavigationConfig() : m_bIsSmall(false), m_bIsGlobalActive(true), m_nOutlineTracking(1), - m_bIsTableTracking(true), - m_bIsSectionTracking(true), - m_bIsFrameTracking(true), - m_bIsImageTracking(true), - m_bIsOLEobjectTracking(true), - m_bIsBookmarkTracking(true), - m_bIsHyperlinkTracking(true), - m_bIsReferenceTracking(true), - m_bIsIndexTracking(true), - m_bIsCommentTracking(true), - m_bIsDrawingObjectTracking(true), - m_bIsFieldTracking(true), - m_bIsFootnoteTracking(true), m_bIsNavigateOnSelect(false) { Load(); @@ -129,19 +136,13 @@ void SwNavigationConfig::Load() case 5: m_bIsSmall = *o3tl::doAccess<bool>(pValues[nProp]); break; case 6: m_bIsGlobalActive = *o3tl::doAccess<bool>(pValues[nProp]); break; case 7: pValues[nProp] >>= m_nOutlineTracking; break; - case 8: m_bIsTableTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 9: m_bIsSectionTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 10: m_bIsFrameTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 11: m_bIsImageTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 12: m_bIsOLEobjectTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 13: m_bIsBookmarkTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 14: m_bIsHyperlinkTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 15: m_bIsReferenceTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 16: m_bIsIndexTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 17: m_bIsCommentTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 18: m_bIsDrawingObjectTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 19: m_bIsFieldTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; - case 20: m_bIsFootnoteTracking = *o3tl::doAccess<bool>(pValues[nProp]); break; + case 8: case 9: case 10: case 11: case 12: case 13: case 14: case 15: case 16: + case 17: case 18: case 19: case 20: + { + mContentTypeTrack[mPropNameToContentTypeId[aNames[nProp]]] = + *o3tl::doAccess<bool>(pValues[nProp]); + break; + } case 21: m_bIsNavigateOnSelect = *o3tl::doAccess<bool>(pValues[nProp]); break; } } @@ -170,19 +171,12 @@ void SwNavigationConfig::ImplCommit() case 5: pValues[nProp] <<= m_bIsSmall; break; case 6: pValues[nProp] <<= m_bIsGlobalActive; break; case 7: pValues[nProp] <<= m_nOutlineTracking; break; - case 8: pValues[nProp] <<= m_bIsTableTracking; break; - case 9: pValues[nProp] <<= m_bIsSectionTracking; break; - case 10: pValues[nProp] <<= m_bIsFrameTracking; break; - case 11: pValues[nProp] <<= m_bIsImageTracking; break; - case 12: pValues[nProp] <<= m_bIsOLEobjectTracking; break; - case 13: pValues[nProp] <<= m_bIsBookmarkTracking; break; - case 14: pValues[nProp] <<= m_bIsHyperlinkTracking; break; - case 15: pValues[nProp] <<= m_bIsReferenceTracking; break; - case 16: pValues[nProp] <<= m_bIsIndexTracking; break; - case 17: pValues[nProp] <<= m_bIsCommentTracking; break; - case 18: pValues[nProp] <<= m_bIsDrawingObjectTracking; break; - case 19: pValues[nProp] <<= m_bIsFieldTracking; break; - case 20: pValues[nProp] <<= m_bIsFootnoteTracking; break; + case 8: case 9: case 10: case 11: case 12: case 13: case 14: case 15: case 16: + case 17: case 18: case 19: case 20: + { + pValues[nProp] <<= mContentTypeTrack[mPropNameToContentTypeId[aNames[nProp]]]; + break; + } case 21: pValues[nProp] <<= m_bIsNavigateOnSelect; break; } } diff --git a/sw/source/uibase/utlui/navipi.cxx b/sw/source/uibase/utlui/navipi.cxx index f964a86957c8..6423dbafac99 100644 --- a/sw/source/uibase/utlui/navipi.cxx +++ b/sw/source/uibase/utlui/navipi.cxx @@ -47,6 +47,8 @@ #include <uiobject.hxx> +#include <o3tl/enumrange.hxx> + using namespace ::com::sun::star::uno; using namespace ::com::sun::star::frame; @@ -524,19 +526,12 @@ SwNavigationPI::SwNavigationPI(weld::Widget* pParent, // unexpected content tracking could occur if these content tree settings are not done before. m_xContentTree->SetOutlineLevel(static_cast<sal_uInt8>(m_pConfig->GetOutlineLevel())); m_xContentTree->SetOutlineTracking(static_cast<sal_uInt8>(m_pConfig->GetOutlineTracking())); - m_xContentTree->SetTableTracking(m_pConfig->IsTableTracking()); - m_xContentTree->SetSectionTracking(m_pConfig->IsSectionTracking()); - m_xContentTree->SetFrameTracking(m_pConfig->IsFrameTracking()); - m_xContentTree->SetImageTracking(m_pConfig->IsImageTracking()); - m_xContentTree->SetOLEobjectTracking(m_pConfig->IsOLEobjectTracking()); - m_xContentTree->SetBookmarkTracking(m_pConfig->IsBookmarkTracking()); - m_xContentTree->SetHyperlinkTracking(m_pConfig->IsHyperlinkTracking()); - m_xContentTree->SetReferenceTracking(m_pConfig->IsReferenceTracking()); - m_xContentTree->SetIndexTracking(m_pConfig->IsIndexTracking()); - m_xContentTree->SetCommentTracking(m_pConfig->IsCommentTracking()); - m_xContentTree->SetDrawingObjectTracking(m_pConfig->IsDrawingObjectTracking()); - m_xContentTree->SetFieldTracking(m_pConfig->IsFieldTracking()); - m_xContentTree->SetFootnoteTracking(m_pConfig->IsFootnoteTracking()); + for (ContentTypeId eCntTypeId : o3tl::enumrange<ContentTypeId>()) + { + if (eCntTypeId != ContentTypeId::OUTLINE) + m_xContentTree->SetContentTypeTracking( + eCntTypeId, m_pConfig->IsContentTypeTrack(eCntTypeId)); + } if (const ContentTypeId nRootType = m_pConfig->GetRootType(); nRootType != ContentTypeId::UNKNOWN) |