Bug 465015 - drag+drop of message not blocked to it's originating folder

p=me r=mkmelin+mozilla sr=neil
This commit is contained in:
Ian Neal 2009-02-01 23:18:08 +00:00
Родитель 79edde19d6
Коммит ba82b7299f
1 изменённых файлов: 49 добавлений и 7 удалений

Просмотреть файл

@ -339,16 +339,57 @@ let gFolderTreeView = {
* drag drop interfaces * drag drop interfaces
*/ */
canDrop: function ftv_canDrop(aRow, aOrientation) { canDrop: function ftv_canDrop(aRow, aOrientation) {
const Cc = Components.classes;
const Ci = Components.interfaces;
if (aOrientation != Ci.nsITreeView.DROP_ON)
return false;
let targetFolder = gFolderTreeView._rowMap[aRow]._folder; let targetFolder = gFolderTreeView._rowMap[aRow]._folder;
if (!targetFolder) if (!targetFolder)
return false; return false;
let dt = this._currentTransfer; let dt = this._currentTransfer;
let types = dt.mozTypesAt(0); let types = dt.mozTypesAt(0);
if (Array.indexOf(types, "text/x-moz-message") != -1 && if (Array.indexOf(types, "text/x-moz-message") != -1) {
!targetFolder.canFileMessages) // Don't allow drop onto server itself.
return false; if (targetFolder.isServer)
if (aOrientation != Components.interfaces.nsITreeView.DROP_ON) return false;
return false; // Don't allow drop into a folder that cannot take messages.
if (!targetFolder.canFileMessages)
return false;
let messenger = Cc["@mozilla.org/messenger;1"].createInstance(Ci.nsIMessenger);
for (let i = 0; i < dt.mozItemCount; i++) {
let msgHdr = messenger.msgHdrFromURI(dt.mozGetDataAt("text/x-moz-message", i));
// Don't allow drop onto original folder.
if (msgHdr.folder == targetFolder)
return false;
}
}
else if (Array.indexOf(types, "text/x-moz-folder") != -1) {
// If cannot create subfolders then don't allow drop here.
if (!targetFolder.canCreateSubfolders)
return false;
for (let i = 0; i < dt.mozItemCount; i++) {
let folder = dt.mozGetDataAt("text/x-moz-folder", i)
.QueryInterface(Ci.nsIMsgFolder);
// Don't allow to drop on itself.
if (targetFolder == folder)
return false;
// Don't allow immediate child to be dropped onto its parent.
if (targetFolder == folder.parent)
return false;
// Don't allow dragging of virtual folders across accounts.
if ((folder.flags & Ci.nsMsgFolderFlags.Virtual) &&
folder.server != targetFolder.server)
return false;
// Don't allow parent to be dropped on its ancestors.
if (folder.isAncestorOf(targetFolder))
return false;
// If there is a folder that can't be renamed, don't allow it to be
// dropped if it is not to "Local Folders" or is to the same account.
if (!folder.canRename && (targetFolder.server.type != "none" ||
folder.server == targetFolder.server))
return false;
}
}
return true; return true;
}, },
drop: function ftv_drop(aRow, aOrientation) { drop: function ftv_drop(aRow, aOrientation) {
@ -366,7 +407,8 @@ let gFolderTreeView = {
if (Array.indexOf(types, "text/x-moz-folder") != -1) { if (Array.indexOf(types, "text/x-moz-folder") != -1) {
for (let i = 0; i < count; i++) { for (let i = 0; i < count; i++) {
let folders = new Array; let folders = new Array;
folders.push(dt.mozGetDataAt("text/x-moz-folder", i)); folders.push(dt.mozGetDataAt("text/x-moz-folder", i)
.QueryInterface(Ci.nsIMsgFolder));
let array = toXPCOMArray(folders, Ci.nsIMutableArray); let array = toXPCOMArray(folders, Ci.nsIMutableArray);
cs.CopyFolders(array, targetFolder, cs.CopyFolders(array, targetFolder,
(folders[0].server == targetFolder.server), null, (folders[0].server == targetFolder.server), null,
@ -375,7 +417,7 @@ let gFolderTreeView = {
} }
else if (Array.indexOf(types, "text/x-moz-message") != -1) { else if (Array.indexOf(types, "text/x-moz-message") != -1) {
let array = Cc["@mozilla.org/array;1"] let array = Cc["@mozilla.org/array;1"]
.createInstance(Components.interfaces.nsIMutableArray); .createInstance(Ci.nsIMutableArray);
let sourceFolder; let sourceFolder;
let messenger = Cc["@mozilla.org/messenger;1"].createInstance(Ci.nsIMessenger); let messenger = Cc["@mozilla.org/messenger;1"].createInstance(Ci.nsIMessenger);
for (let i = 0; i < count; i++) { for (let i = 0; i < count; i++) {