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:
Родитель
79edde19d6
Коммит
ba82b7299f
|
@ -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++) {
|
||||||
|
|
Загрузка…
Ссылка в новой задаче