summaryrefslogtreecommitdiff
path: root/sw/source
diff options
context:
space:
mode:
Diffstat (limited to 'sw/source')
-rw-r--r--sw/source/uibase/inc/redlndlg.hxx3
-rw-r--r--sw/source/uibase/misc/redlndlg.cxx128
2 files changed, 81 insertions, 50 deletions
diff --git a/sw/source/uibase/inc/redlndlg.hxx b/sw/source/uibase/inc/redlndlg.hxx
index 36be9513a932..7337f1fadce4 100644
--- a/sw/source/uibase/inc/redlndlg.hxx
+++ b/sw/source/uibase/inc/redlndlg.hxx
@@ -97,7 +97,8 @@ class SW_DLLPUBLIC SwRedlineAcceptDlg final
SAL_DLLPRIVATE void RemoveParents(SwRedlineTable::size_type nStart, SwRedlineTable::size_type nEnd);
SAL_DLLPRIVATE void InitAuthors();
- SAL_DLLPRIVATE static OUString GetActionImage(const SwRangeRedline& rRedln, sal_uInt16 nStack = 0, bool bRowChanges = false);
+ SAL_DLLPRIVATE static OUString GetActionImage(const SwRangeRedline& rRedln, sal_uInt16 nStack = 0,
+ bool bTableChanges = false, bool bRowChanges = false);
SAL_DLLPRIVATE OUString GetActionText(const SwRangeRedline& rRedln, sal_uInt16 nStack = 0);
SAL_DLLPRIVATE SwRedlineTable::size_type GetRedlinePos(const weld::TreeIter& rEntry);
diff --git a/sw/source/uibase/misc/redlndlg.cxx b/sw/source/uibase/misc/redlndlg.cxx
index 19374e5187a2..e583dc3af1a9 100644
--- a/sw/source/uibase/misc/redlndlg.cxx
+++ b/sw/source/uibase/misc/redlndlg.cxx
@@ -312,19 +312,24 @@ void SwRedlineAcceptDlg::InitAuthors()
m_bOnlyFormatedRedlines );
}
-OUString SwRedlineAcceptDlg::GetActionImage(const SwRangeRedline& rRedln, sal_uInt16 nStack, bool bRowChanges)
+OUString SwRedlineAcceptDlg::GetActionImage(const SwRangeRedline& rRedln, sal_uInt16 nStack,
+ bool bTableChanges, bool bRowChanges)
{
switch (rRedln.GetType(nStack))
{
- case RedlineType::Insert: return bRowChanges
- ? OUString(BMP_REDLINE_ROW_INSERTION)
+ case RedlineType::Insert: return bTableChanges
+ ? bRowChanges
+ ? OUString(BMP_REDLINE_ROW_INSERTION)
+ : OUString(BMP_REDLINE_COL_INSERTION)
: rRedln.IsMoved()
? OUString(BMP_REDLINE_MOVED_INSERTION)
: rRedln.IsAnnotation()
? OUString(BMP_REDLINE_COMMENT_INSERTION)
: OUString(BMP_REDLINE_INSERTED);
- case RedlineType::Delete: return bRowChanges
- ? OUString(BMP_REDLINE_ROW_DELETION)
+ case RedlineType::Delete: return bTableChanges
+ ? bRowChanges
+ ? OUString(BMP_REDLINE_ROW_DELETION)
+ : OUString(BMP_REDLINE_COL_DELETION)
: rRedln.IsMoved()
? OUString(BMP_REDLINE_MOVED_DELETION)
: rRedln.IsAnnotation()
@@ -790,25 +795,23 @@ void SwRedlineAcceptDlg::InsertParents(SwRedlineTable::size_type nStart, SwRedli
bool bIsShowChangesInMargin = SW_MOD()->GetUsrPref(false)->IsShowChangesInMargin();
- // collect redlines of tracked table or table row insertion/deletions under a single tree list
- // item to accept/reject table (row) insertion/deletion with a single click on Accept/Reject
+ // collect redlines of tracked table/row/column insertion/deletions under a single tree list
+ // item to accept/reject the table change with a single click on Accept/Reject
// Note: because update of the tree list depends on parent count, we don't modify
// m_RedlineParents, only store the 2nd and more redlines as children of the tree list
// item of the first redline
// count of items stored as children (to adjust parent position)
- sal_Int32 nSkipRedlines = 0;
- // count of items of the actual table row (or joined table rows) stored as children =
- // redlines of the row(s) - 1 (first redline is associated to the parent tree list item)
- sal_Int32 nSkipRedline = 0;
- // nSkipRedline of the previous table row (to join multiple table rows, if it's possible)
- sal_Int32 nPrevSkipRedline = 0;
-
- // last SwRangeRedline in the table row
+ SwRedlineTable::size_type nSkipRedlines = 0;
+ // count of items of the actual table change stored as children =
+ // redlines of the change - 1 (first redline is associated to the parent tree list item)
+ SwRedlineTable::size_type nSkipRedline = 0;
+
+ // last SwRangeRedline in the table row/column
SwRedlineTable::size_type nLastChangeInRow = SwRedlineTable::npos;
- // descriptor redline of the tracked table row
- SwRedlineTable::size_type nRowChange = SwRedlineTable::npos;
- // descriptor redline of the previous table row to join the table rows
+ // descriptor redline of the tracked table row/column
+ SwRedlineTable::size_type nRowChange = 0;
+ // descriptor redline of the previous table change to join with the next one
SwRedlineTable::size_type nPrevRowChange = SwRedlineTable::npos;
// show all redlines as tree list items,
@@ -825,42 +828,69 @@ void SwRedlineAcceptDlg::InsertParents(SwRedlineTable::size_type nStart, SwRedli
// handle tracked table row changes
const SwTableBox* pTableBox;
const SwTableLine* pTableLine;
- // first SwRangeRedline of the tracked table row(s), base of the parent tree list
- // of the other SwRangeRedlines of the tracked table row(s)
+ bool bChange = false;
+ bool bRowChange = false;
+ // first SwRangeRedline of the tracked table rows/columns, base of the parent tree list
+ // of the other SwRangeRedlines of the tracked table rows or columns
SwRedlineTable::size_type nNewTableParent = SwRedlineTable::npos;
if ( // not recognized yet as tracked table row change
- nLastChangeInRow == SwRedlineTable::npos &&
nullptr != ( pTableBox = pSh->GetRedline(i).Start()->GetNode().GetTableBox() ) &&
nullptr != ( pTableLine = pTableBox->GetUpper() ) &&
- // it's a tracked row change based on the cached row data
- RedlineType::None != pTableLine->GetRedlineType() )
+ // it's a tracked row (or column change) based on the cached row data
+ ( RedlineType::None != pTableLine->GetRedlineType() ||
+ RedlineType::None != pTableBox->GetRedlineType() ) )
{
- SwRedlineTable::size_type nRedline = i;
- nRowChange = pTableLine->UpdateTextChangesOnly(nRedline);
+ // start redline search from the start from the tracked row/column change
+ SwRedlineTable::size_type nStartPos =
+ nRowChange > nSkipRedline ? nRowChange - nSkipRedline : 0;
+ bChange = true;
+ bRowChange = RedlineType::None != pTableLine->GetRedlineType();
+ nRowChange = bRowChange
+ ? pTableLine->UpdateTextChangesOnly(nStartPos)
+ : pTableBox->GetRedline();
if ( SwRedlineTable::npos != nRowChange )
{
- nSkipRedline = nRedline - i - 1;
- nLastChangeInRow = nRedline - 1;
- // join the consecutive deleted/inserted rows under a single treebox item,
+ // redline is there in a tracked table change
+
+ // join the consecutive deleted/inserted rows/columns under a single treebox item,
// if they have the same redline data (equal type, author and time stamp)
- if ( nPrevRowChange != SwRedlineTable::npos &&
- pSh->GetRedline(nRowChange).GetRedlineData() == pSh->GetRedline(nPrevRowChange).GetRedlineData() )
+ if ( nPrevRowChange != SwRedlineTable::npos )
{
- nSkipRedline += nPrevSkipRedline + 1;
- nPrevSkipRedline = 0;
- nPrevRowChange = SwRedlineTable::npos;
+ // note: CanCombine() allows a time frame to join the changes within a short
+ // time period: this avoid of falling apart of the tracked columns inserted
+ // by several clicks
+ if ( pSh->GetRedline(nRowChange).GetRedlineData()
+ .CanCombine(pSh->GetRedline(nPrevRowChange).GetRedlineData()) &&
+ // in the same table?
+ pSh->GetRedline(nRowChange).Start()->GetNode().FindTableNode() ==
+ pSh->GetRedline(nPrevRowChange).Start()->GetNode().FindTableNode() )
+ {
+ nSkipRedline++;
+ }
+ else
+ {
+ nNewTableParent = i;
+ nLastChangeInRow = i;
+ nPrevRowChange = nRowChange;
+ }
}
else
+ {
+ nLastChangeInRow = i;
nNewTableParent = i;
+ }
}
else
+ {
+ // redline is not in a tracked table change
+ bChange = bRowChange = false;
nPrevRowChange = SwRedlineTable::npos;
+ }
}
else
+ // redline is not in a tracked table change
nPrevRowChange = SwRedlineTable::npos;
- bool bRowChange(SwRedlineTable::npos != nLastChangeInRow);
-
bool bShowDeletedTextAsComment = bIsShowChangesInMargin &&
RedlineType::Delete == rRedln.GetType() && rRedln.GetComment().isEmpty();
const OUString& sComment = bShowDeletedTextAsComment
@@ -876,9 +906,9 @@ void SwRedlineAcceptDlg::InsertParents(SwRedlineTable::size_type nStart, SwRedli
// use descriptor SwRangeRedline of the changed row, if needed to show
// the correct redline type, author and time stamp of the tracked row change
- const SwRangeRedline& rChangeRedln = pSh->GetRedline(bRowChange ? nRowChange : i);
+ const SwRangeRedline& rChangeRedln = pSh->GetRedline(bChange ? nRowChange : i);
- OUString sImage = GetActionImage(rChangeRedln, 0, bRowChange && nNewTableParent != SwRedlineTable::npos );
+ OUString sImage = GetActionImage(rChangeRedln, 0, bChange && nNewTableParent != SwRedlineTable::npos, bRowChange );
OUString sAuthor = rChangeRedln.GetAuthorString(0);
pData->aDateTime = rChangeRedln.GetTimeStamp(0);
pData->eType = rChangeRedln.GetType(0);
@@ -887,12 +917,20 @@ void SwRedlineAcceptDlg::InsertParents(SwRedlineTable::size_type nStart, SwRedli
OUString sId = weld::toId(pData.get());
std::unique_ptr<weld::TreeIter> xParent(rTreeView.make_iterator());
- if ( !bRowChange || nNewTableParent != SwRedlineTable::npos )
+ if ( !bChange || nNewTableParent != SwRedlineTable::npos )
+ {
rTreeView.insert(nullptr, i - nSkipRedlines, nullptr, &sId, nullptr, nullptr, false, xParent.get());
+ // before this was a tracked table change with more than a single redline
+ if ( nSkipRedline > 0 )
+ {
+ nSkipRedlines += nSkipRedline;
+ nSkipRedline = 0;
+ }
+ }
else
{
// put 2nd or more redlines of deleted/inserted rows as children of their first redline
- SwRedlineDataParent *const pParent = m_RedlineParents[nLastChangeInRow - nSkipRedline].get();
+ SwRedlineDataParent *const pParent = m_RedlineParents[nLastChangeInRow].get();
rTreeView.insert(pParent->xTLBParent.get(), -1, nullptr, &sId, nullptr, nullptr, false, xParent.get());
}
@@ -916,16 +954,8 @@ void SwRedlineAcceptDlg::InsertParents(SwRedlineTable::size_type nStart, SwRedli
InsertChildren(pRedlineParent, rRedln, bHasRedlineAutoFormat);
- // end of a tracked deletion/insertion of a table row
- if ( nLastChangeInRow != SwRedlineTable::npos && i == nLastChangeInRow )
- {
- nSkipRedlines += nSkipRedline;
- nPrevSkipRedline = nSkipRedline;
- nSkipRedline = 0;
- nPrevRowChange = nRowChange;
- nNewTableParent = SwRedlineTable::npos;
- nLastChangeInRow = SwRedlineTable::npos;
- }
+ nPrevRowChange = nRowChange;
+ nNewTableParent = SwRedlineTable::npos;
}
rTreeView.thaw();
if (m_pTable->IsSorted())