För att prova de tusentals tillägg tillgängliga här, ladda ner Mozilla Firefox, ett snabbt och gratis sätt att surfa på webben!
StängVälkommen till Firefox tillägg.
Välj bland tusentals extrafunktioner och stilar för att göra Firefox till ditt.
StängRecensioner av Message Archive Options
21 recensioner av detta tillägg
Betygsatt 5 utav 5 stjärnor
It's handy, we need update to 128.
Betygsatt 4 utav 5 stjärnor
This is a very handy add-on. Can you please update it so it works on Thunderbird 60+?
Denna recension är för en tidigare version av tillägget (5.0.0).Update for TB60 has landed !
Please report problems or new feature requests.
Betygsatt 1 utav 5 stjärnor
"Message Archive Options 5.0.0 could not be installed because it is not compatible with Thunderbird 3.1.13."
Where to find the right version of this?
It cannot be found at all from inside Thunderbird.
That's because 5.0.0 isn't compatible with TB3.1.13. Install an old version for your old version of Thunderbird!
Betygsatt 3 utav 5 stjärnor
howdy y'all,
this is built into tb5, which supports per-account settings.
take care,lee
Betygsatt 5 utav 5 stjärnor
Can I create difference configurations for different accounts?
For example:
acc.1 - Year - Month
acc.2 - Month - Day
and run it by special key or by RMB-submenu?
Betygsatt 2 utav 5 stjärnor
Might be just the addon I need to disable the anoying 'a' shortcut with which I keep loosing my emails.
The only problem is that it is not compatible with my TB.
Any plans to make this compatible with TB 3.1?
Thanks!
Betygsatt 5 utav 5 stjärnor
This is an excellent add-on and is very useful. Is Evil-Jeff continuing its development? I would gladly donate to see piviul's patch added in and the whole works made work with V3.1...
Denna recension är för en tidigare version av tillägget (0.3.1).Betygsatt 4 utav 5 stjärnor
There is still a bug ... when I am in the root folder of my first create account and I try to press A then there is an error message saying that "The operation failed because an other operation is unsing the folder. Please wait ..." but if I am in a subfolder, it worked fine!
There are also some errors when the addon creates the subdirs that it will uses the ISO Date format as dir name, instead of the original foldername.
Betygsatt 4 utav 5 stjärnor
Your new code of the overlay.js works fine BUT you have to restart TB if you want that the option in dialog "2 Additonal Leves" with %F will work!
Denna recension är för en tidigare version av tillägget (0.3.1).Betygsatt 4 utav 5 stjärnor
Thanks, it works. But not the way it should be.
When you have subfolders on INBOX your code uses the word INBOX as a subfolder name in the archive. So it only works when the folder is directly below the account name, like Trash, Sent, Inbox...
I know that you can't or won't iterate thru the subdirs but lets just use the folder name where the mail is in it which you want to archive.
The option %F doesn't work, only %f.
With %F I am getting the whole date string as directory name...
Betygsatt 5 utav 5 stjärnor
Hi, the last 15th february I've send the patched overlay.js to eviljeff hoping in a fast update of the add-on. Because there are other interested in the patch I write the new overlay.js here:
--- begin overlay.js
var messagearchiveoptions = {
preferenceService: Components.classes["@mozilla.org/preferences-service;1"].getService(Components.interfaces.nsIPrefService).getBranch("extensions.messagearchiveoptions@eviljeff.com."),
get monthValue() {return this.preferenceService.getComplexValue("monthstring",Components.interfaces.nsISupportsString).toString();},
get yearValue() {return this.preferenceService.getComplexValue("yearstring", Components.interfaces.nsISupportsString).toString();},
get keyModifiers() {
var modifiers=new Array();
if (this.preferenceService.getBoolPref("key.shift")) modifiers.push("shift");
if (this.preferenceService.getBoolPref("key.alt")) modifiers.push("alt");
if (this.preferenceService.getBoolPref("key.control")) modifiers.push("accel");
return modifiers;
},
onLoad: function() {
BatchMessageMover.prototype.archiveSelectedMessages = function() {
gFolderDisplay.hintMassMoveStarting();
var selectedMessages = gFolderDisplay.selectedMessages;
if (!selectedMessages.length) {
return;
}
var messages = Components.classes['@mozilla.org/array;1'].createInstance(Components.interfaces.nsIMutableArray);
for (let i = 0; i < selectedMessages.length; ++i) {
let msgHdr = selectedMessages[i];
let server = msgHdr.folder.server;
let rootFolder = server.rootFolder;
let msgDate = new Date(msgHdr.date / 1000);
let fullPath = String(msgHdr.folder.URI).replace(server.serverURI, "").substring(1);
let rootPath = fullPath.substring(0, fullPath.indexOf('/', 1));
if (rootPath.length == 0) rootPath=fullPath;
let yearValue = messagearchiveoptions.yearValue.replace('%F', fullPath);
yearValue = yearValue.replace('%f', rootPath);
let msgYear = msgDate.toLocaleFormat(yearValue);
let monthValue = messagearchiveoptions.monthValue.replace('%F', fullPath);
monthValue = monthValue.replace('%f', rootPath);
let monthFolderName = msgDate.toLocaleFormat(monthValue);
let archiveFolderUri;
if (server.type == "rss") {
archiveFolderUri = server.serverURI + "/Archives";
} else {
let identity = getIdentityForServer(server);
if (!identity) {
identity = getIdentityForHeader(msgHdr);
}
archiveFolderUri = identity.archiveFolder;
}
let archiveFolder = GetMsgFolderFromUri(archiveFolderUri, false);
let granularity = archiveFolder.server.archiveGranularity;
let copyBatchKey = msgHdr.folder.URI + "\0";
if (granularity >= Components.interfaces.nsIMsgIncomingServer.perYearArchiveFolders) {
copyBatchKey += msgYear;
}
if (granularity >= Components.interfaces.nsIMsgIncomingServer.perMonthArchiveFolders) {
copyBatchKey += monthFolderName;
}
if (!(copyBatchKey in this._batches)) {
this._batches[copyBatchKey] = [msgHdr.folder, archiveFolderUri, granularity, msgYear, monthFolderName];
}
this._batches[copyBatchKey].push(msgHdr);
}
this.processNextBatch();
}
document.getElementById("key_archive").setAttribute("modifiers",this.keyModifiers.join(", "));
},
observe:function(subject ,topic , data) {
if (topic!="nsPref:changed") return;
document.getElementById("key_archive").setAttribute("modifiers",this.keyModifiers.join(", "));
}
};
window.addEventListener("load", function(e) { messagearchiveoptions.onLoad(e); }, false);
messagearchiveoptions.preferenceService.QueryInterface(Components.interfaces.nsIPrefBranch2).addObserver("key", messagearchiveoptions, false);
--- end
I've removed the license block so please don't delete it from the original overlay.js!
Have a grat day
Piviul
Betygsatt 4 utav 5 stjärnor
Your diff file won't work ... or I haven't found the correct syntax for "diffing" it:
patch < overlay.js.diff
Hmm... Looks like a normal diff to me...
File to patch: overlay.js
Patching file overlay.js using Plan A...
Hunk #1 failed at 38.
Hunk #2 failed at 50.
2 out of 2 hunks failed--saving rejects to overlay.js.rej
done
So please do just an update on the addon instead of posting the diffs here.
Betygsatt 4 utav 5 stjärnor
hello,
I tried to update the file overlay.js but does not work.
Could you send me the updated file?
Thanks
Betygsatt 4 utav 5 stjärnor
hello,
I tried to update the file overlay.js but does not work.
Could you send me the updated file?
Thanks
Betygsatt 4 utav 5 stjärnor
We have done some little changes to overlay.js to have folder structure (root only or full structure) support permitting new %f (root structure) or %F (full structure) in the year and month options as asked from andras.tim, BlackForst and Illtud Daniel. This is de diff:
38,48c38,48
< preferenceService: Components.classes["@mozilla.org/preferences-service;1"].getService(Components.interfaces.nsIPrefService).getBranch("extensions.messagearchiveoptions@eviljeff.com."),
<
< get monthValue() {return this.preferenceService.getComplexValue("monthstring",Components.interfaces.nsISupportsString).toString();},
< get yearValue() {return this.preferenceService.getComplexValue("yearstring", Components.interfaces.nsISupportsString).toString();},
< get keyModifiers() {
< var modifiers=new Array();
< if (this.preferenceService.getBoolPref("key.shift")) modifiers.push("shift");
< if (this.preferenceService.getBoolPref("key.alt")) modifiers.push("alt");
< if (this.preferenceService.getBoolPref("key.control")) modifiers.push("accel");
< return modifiers;
< },
---
> preferenceService: Components.classes["@mozilla.org/preferences-service;1"].getService(Components.interfaces.nsIPrefService).getBranch("extensions.messagearchiveoptions@eviljeff.com."),
>
> get monthValue() {return this.preferenceService.getComplexValue("monthstring",Components.interfaces.nsISupportsString).toString();},
> get yearValue() {return this.preferenceService.getComplexValue("yearstring", Components.interfaces.nsISupportsString).toString();},
> get keyModifiers() {
> var modifiers=new Array();
> if (this.preferenceService.getBoolPref("key.shift")) modifiers.push("shift");
> if (this.preferenceService.getBoolPref("key.alt")) modifiers.push("alt");
> if (this.preferenceService.getBoolPref("key.control")) modifiers.push("accel");
> return modifiers;
> },
50,55c50,98
< var origfunc=BatchMessageMover.prototype.archiveSelectedMessages.toSource();
< origfunc=origfunc.replace('msgDate.toLocaleFormat("%Y-%m")','msgDate.toLocaleFormat(messagearchiveoptions.monthValue)');
< origfunc=origfunc.replace('msgDate.getFullYear().toString()','msgDate.toLocaleFormat(messagearchiveoptions.yearValue)');
< eval("BatchMessageMover.prototype.archiveSelectedMessages = "+origfunc);
< //BatchMessageMover.prototype.archiveSelectedMessages = this.archiveSelectedMessages;
<
---
> BatchMessageMover.prototype.archiveSelectedMessages = function() {
> gFolderDisplay.hintMassMoveStarting();
> var selectedMessages = gFolderDisplay.selectedMessages;
> if (!selectedMessages.length) {
> return;
> }
> var messages = Components.classes['@mozilla.org/array;1'].createInstance(Components.interfaces.nsIMutableArray);
> for (let i = 0; i < selectedMessages.length; ++i) {
> let msgHdr = selectedMessages[i];
> let server = msgHdr.folder.server;
> let rootFolder = server.rootFolder;
> let msgDate = new Date(msgHdr.date / 1000);
> //let msgYear = msgDate.toLocaleFormat(messagearchiveoptions.yearValue);
> //let monthFolderName = msgDate.toLocaleFormat(messagearchiveoptions.monthValue);
> let fullPath = String(msgHdr.folder.URI).replace(server.serverURI, "").substring(1);
> let rootPath = fullPath.substring(0, fullPath.indexOf('/', 1));
> if (rootPath.length == 0) rootPath=fullPath;
> let yearValue = messagearchiveoptions.yearValue.replace('%F', fullPath);
> yearValue = yearValue.replace('%f', rootPath);
> let msgYear = msgDate.toLocaleFormat(yearValue);
> let monthValue = messagearchiveoptions.monthValue.replace('%F', fullPath);
> monthValue = monthValue.replace('%f', rootPath);
> let monthFolderName = msgDate.toLocaleFormat(monthValue);
> let archiveFolderUri;
> if (server.type == "rss") {
> archiveFolderUri = server.serverURI + "/Archives";
> } else {
> let identity = getIdentityForServer(server);
> if (!identity) {
> identity = getIdentityForHeader(msgHdr);
> }
> archiveFolderUri = identity.archiveFolder;
> }
> let archiveFolder = GetMsgFolderFromUri(archiveFolderUri, false);
> let granularity = archiveFolder.server.archiveGranularity;
> let copyBatchKey = msgHdr.folder.URI + "\0";
> if (granularity >= Components.interfaces.nsIMsgIncomingServer.perYearArchiveFolders) {
> copyBatchKey += msgYear;
> }
> if (granularity >= Components.interfaces.nsIMsgIncomingServer.perMonthArchiveFolders) {
> copyBatchKey += monthFolderName;
> }
> if (!(copyBatchKey in this._batches)) {
> this._batches[copyBatchKey] = [msgHdr.folder, archiveFolderUri, granularity, msgYear, monthFolderName];
> }
> this._batches[copyBatchKey].push(msgHdr);
> }
> this.processNextBatch();
> }
Piviul
Betygsatt 1 utav 5 stjärnor
Good, good, but unfortunately does not keep the folder structure. : (
Denna recension är för en tidigare version av tillägget (0.3.1).Betygsatt 5 utav 5 stjärnor
Works perfectly... I had discovered I was accidentally archiving important messages; this solves the problem. Thanks!
Denna recension är för en tidigare version av tillägget (0.3.1).Betygsatt 3 utav 5 stjärnor
+ 1 for enhancement given by BlackForst and Illtud Daniel
this will be really useful
Betygsatt 3 utav 5 stjärnor
"Handy UI for the prefs, but I find the archive function useless without the possibility of keeping the existing folder structure in the archive - ie archiving a mail in 'Projects/New North Building' should move the mail to 'archive/2009/Projects/New North Building'. Any chance that your extension could be enhanced to deliver that?"
Yeah this would make sense! other wise the Archives function isn't so useful...
Betygsatt 4 utav 5 stjärnor
Handy UI for the prefs, but I find the archive function useless without the possibility of keeping the existing folder structure in the archive - ie archiving a mail in 'Projects/New North Building' should move the mail to 'archive/2009/Projects/New North Building'. Any chance that your extension could be enhanced to deliver that?
Denna recension är för en tidigare version av tillägget (0.3.1).För att skapa egna samlingar, måste du ha ett konto för Mozilla tillägg.