summaryrefslogtreecommitdiff
path: root/sw/source
diff options
context:
space:
mode:
Diffstat (limited to 'sw/source')
-rw-r--r--sw/source/uibase/inc/conttree.hxx28
-rw-r--r--sw/source/uibase/inc/navicfg.hxx148
-rw-r--r--sw/source/uibase/utlui/content.cxx240
-rw-r--r--sw/source/uibase/utlui/navicfg.cxx72
-rw-r--r--sw/source/uibase/utlui/navipi.cxx21
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)