fixing bug 142065 - when I right click delete a message, the wrong message gets deleted. r=varga, sr=sspitzer

This commit is contained in:
ssu%netscape.com 2003-03-18 19:33:31 +00:00
parent 8d4055c77a
commit a5ce3641fb
4 changed files with 62 additions and 13 deletions

View File

@ -308,6 +308,7 @@ interface nsIMsgDBView : nsISupports
readonly attribute boolean supportsThreading;
attribute nsIMsgSearchSession searchSession;
readonly attribute boolean removeRowOnMoveOrDelete;
nsMsgViewIndex findIndexFromKey(in nsMsgKey aMsgKey, in boolean aExpand);
};

View File

@ -31,6 +31,16 @@
// (onpopuphiding).
function RestoreSelectionWithoutContentLoad(tree)
{
// If a delete or move command had been issued, then we should
// reset gRightMouseButtonDown and gThreadPaneDeleteOrMoveOccurred
// and return (see bug 142065).
if(gThreadPaneDeleteOrMoveOccurred)
{
gRightMouseButtonDown = false;
gThreadPaneDeleteOrMoveOccurred = false;
return;
}
var treeBoxObj = tree.treeBoxObject;
var treeSelection = treeBoxObj.selection;
@ -49,7 +59,7 @@ function RestoreSelectionWithoutContentLoad(tree)
if(tree.id == "threadTree")
gThreadPaneCurrentSelectedIndex = treeSelection.currentIndex;
}
else if(!gThreadPaneDeleteOrMoveOccurred && (treeSelection.currentIndex < 0))
else if(treeSelection.currentIndex < 0)
// Clear the selection in the case of when a folder has just been
// loaded where the message pane does not have a message loaded yet.
// When right-clicking a message in this case and dismissing the

View File

@ -1328,22 +1328,42 @@ function GetCompositeDataSource(command)
return null;
}
// Figures out how many messages are selected (hilighted - does not necessarily
// have the dotted outline) above a given index row value in the thread pane.
function NumberOfSelectedMessagesAboveCurrentIndex(index)
{
var numberOfMessages = 0;
var indicies = GetSelectedIndices(gDBView);
if (indicies && indicies.length)
{
for (var i = 0; i < indicies.length; i++)
{
if (indicies[i] < index)
++numberOfMessages;
else
break;
}
}
return numberOfMessages;
}
function SetNextMessageAfterDelete()
{
var treeSelection = GetThreadTree().treeBoxObject.selection;
gThreadPaneDeleteOrMoveOccurred = true;
if (treeSelection.isSelected(treeSelection.currentIndex))
gNextMessageViewIndexAfterDelete = gDBView.msgToSelectAfterDelete;
else if (treeSelection.currentIndex > gThreadPaneCurrentSelectedIndex)
// Since the currentIndex (the row with the outline/dotted line) is greater
// than the currently selected row (the row that is highlighted), we need to
// make sure that upon a Delete or Move of the selected row, the highlight
// returns to the currentIndex'ed row. It is necessary to subtract 1
// because the row being deleted is above the row with the currentIndex.
// If the subtraction is not done, then the highlight will end up on the
// row listed after the currentIndex'ed row.
gNextMessageViewIndexAfterDelete = treeSelection.currentIndex - 1;
// Only set gThreadPaneDeleteOrMoveOccurred to true if the message was
// truly moved to the trash or deleted, as opposed to an IMAP delete
// (where it is only "marked as deleted". This will prevent bug 142065.
//
// If it's an IMAP delete, then just set gNextMessageViewIndexAfterDelete
// to treeSelection.currentIndex (where the outline is at) because nothing
// was moved or deleted from the folder.
if(gDBView.removeRowOnMoveOrDelete)
{
gThreadPaneDeleteOrMoveOccurred = true;
gNextMessageViewIndexAfterDelete = treeSelection.currentIndex - NumberOfSelectedMessagesAboveCurrentIndex(treeSelection.currentIndex);
}
else
gNextMessageViewIndexAfterDelete = treeSelection.currentIndex;
}

View File

@ -5242,6 +5242,24 @@ nsMsgDBView::GetMsgToSelectAfterDelete(nsMsgViewIndex *msgToSelectAfterDelete)
return NS_OK;
}
NS_IMETHODIMP
nsMsgDBView::GetRemoveRowOnMoveOrDelete(PRBool *aRemoveRowOnMoveOrDelete)
{
NS_ENSURE_ARG_POINTER(aRemoveRowOnMoveOrDelete);
nsCOMPtr <nsIMsgImapMailFolder> imapFolder = do_QueryInterface(m_folder);
if (!imapFolder) {
*aRemoveRowOnMoveOrDelete = PR_TRUE;
return NS_OK;
}
// need to update the imap-delete model, can change more than once in a session.
GetImapDeleteModel(nsnull);
// unlike the other imap delete models, "mark as deleted" does not remove rows on delete (or move)
*aRemoveRowOnMoveOrDelete = (mDeleteModel != nsMsgImapDeleteModels::IMAPDelete);
return NS_OK;
}
NS_IMETHODIMP
nsMsgDBView::GetCurrentlyDisplayedMessage(nsMsgViewIndex *currentlyDisplayedMessage)