Files
SysTray-X/webext/js/defaults.js

499 lines
12 KiB
JavaScript
Raw Normal View History

2021-09-04 22:16:18 +02:00
//
// Get the prefered storage
//
2023-09-06 22:04:41 +02:00
function storage() {
2021-09-04 22:16:18 +02:00
console.log("Using local storage");
return browser.storage.local;
}
//
// Get window startup state
//
async function getStartupState() {
function resolve(result) {
const startMinimized = result.startMinimized || "false";
return startMinimized === "true" ? "minimized" : "normal";
}
function reject() {
return "normal";
}
return await storage().get("startMinimized").then(resolve, reject);
}
//
// Get window restore position state
//
async function getRestorePositionsState() {
function resolve(result) {
const restorePositions = result.restorePositions || "false";
return restorePositions;
}
function reject() {
return "false";
}
return await storage().get("restorePositions").then(resolve, reject);
}
//
// Get window startup window positions
//
async function getStartupWindowPositions() {
function resolve(result) {
const windowPositions = result.windowPositions || [];
return windowPositions;
}
function reject() {
return [];
}
return await storage().get("windowPositions").then(resolve, reject);
}
//
// Get close type
//
async function getCloseType() {
function resolve(result) {
return result.closeType || "1";
}
function reject() {
return undefined;
}
return await storage().get("closeType").then(resolve, reject);
}
//
// Get KDE integration, default icon hide
//
async function getHideDefaultIcon() {
function resolve(result) {
const hideDefaultIcon = result.hideDefaultIcon || "false";
return hideDefaultIcon === "true";
}
function reject() {
return false;
}
return await storage().get("hideDefaultIcon").then(resolve, reject);
}
2020-01-24 22:20:30 +01:00
//
2020-05-22 22:54:10 +02:00
// Set default default icon
2020-01-24 22:20:30 +01:00
// Use <div> as storage
//
async function getDefaultIcon() {
2021-09-04 22:16:18 +02:00
function resolve(result) {
const defaultIconMime = result.defaultIconMime || "";
const defaultIcon = result.defaultIcon || "";
return { defaultIconMime, defaultIcon };
2020-05-22 22:54:10 +02:00
}
2021-09-04 22:16:18 +02:00
function reject() {
return "";
2020-05-22 22:54:10 +02:00
}
const { defaultIconMime, defaultIcon } = await storage()
2021-09-04 22:16:18 +02:00
.get(["defaultIconMime", "defaultIcon"])
.then(resolve, reject);
2020-05-22 22:54:10 +02:00
if (defaultIconMime === "" || defaultIcon === "") {
2020-05-22 22:54:10 +02:00
const toDataURL = (url) =>
fetch(url)
.then((response) => response.blob())
.then(
(blob) =>
new Promise((resolve, reject) => {
const reader = new FileReader();
reader.onloadend = () => resolve(reader.result);
reader.onerror = reject;
reader.readAsDataURL(blob);
})
);
// Convert image to storage param
var defaultIconPath;
if (SysTrayX.Info.browserInfo.majorVersion < 115) {
defaultIconPath = "icons/Thunderbird.png";
} else {
defaultIconPath = "icons/Thunderbird115.png";
}
const { defaultIconMimeUrl, defaultIconBase64Url } = await toDataURL(
defaultIconPath
2020-05-22 22:54:10 +02:00
).then((dataUrl) => {
const data = dataUrl.split(":").pop().split(",");
return {
defaultIconMimeUrl: data[0].split(";")[0],
defaultIconBase64Url: data[1],
2020-05-22 22:54:10 +02:00
};
});
// Store default icon (base64)
2021-09-04 22:16:18 +02:00
await storage().set({
defaultIconMime: defaultIconMimeUrl,
defaultIcon: defaultIconBase64Url,
2020-05-22 22:54:10 +02:00
});
// Store in HTML
const defaultIconDiv = document.getElementById("defaultIcon");
defaultIconDiv.setAttribute("data-default-icon-mime", defaultIconMimeUrl);
defaultIconDiv.setAttribute("data-default-icon", defaultIconBase64Url);
2020-05-22 22:54:10 +02:00
}
}
//
// Set default unread icon
// Use <div> as storage
//
async function getIcon() {
2021-09-04 22:16:18 +02:00
function resolve(result) {
const iconMime = result.iconMime || "";
const icon = result.icon || "";
return { iconMime, icon };
2020-01-24 22:20:30 +01:00
}
2021-09-04 22:16:18 +02:00
function reject() {
return "";
2020-01-24 22:20:30 +01:00
}
const { iconMime, icon } = await storage()
2021-09-04 22:16:18 +02:00
.get(["iconMime", "icon"])
.then(resolve, reject);
2020-01-24 22:20:30 +01:00
if (iconMime === "" || icon === "") {
const toDataURL = (url) =>
2020-01-24 22:20:30 +01:00
fetch(url)
.then((response) => response.blob())
2020-01-24 22:20:30 +01:00
.then(
(blob) =>
2020-01-24 22:20:30 +01:00
new Promise((resolve, reject) => {
const reader = new FileReader();
reader.onloadend = () => resolve(reader.result);
reader.onerror = reject;
reader.readAsDataURL(blob);
})
);
// Convert image to storage param
const { iconMimeUrl, iconBase64Url } = await toDataURL(
"icons/blank-icon.png"
).then((dataUrl) => {
const data = dataUrl.split(":").pop().split(",");
return { iconMimeUrl: data[0].split(";")[0], iconBase64Url: data[1] };
});
2020-01-24 22:20:30 +01:00
// Store default icon (base64)
2021-09-04 22:16:18 +02:00
await storage().set({
iconMime: iconMimeUrl,
icon: iconBase64Url,
2020-01-24 22:20:30 +01:00
});
// Store in HTML
const iconDiv = document.getElementById("icon");
iconDiv.setAttribute("data-icon-mime", iconMimeUrl);
iconDiv.setAttribute("data-icon", iconBase64Url);
2020-01-24 22:20:30 +01:00
}
}
2020-02-29 20:36:08 +01:00
//
2020-05-12 21:38:03 +02:00
// Get filters
//
2020-05-12 21:38:03 +02:00
async function getFilters() {
2021-09-04 22:16:18 +02:00
function resolve(result) {
2021-09-12 16:51:55 +02:00
let filters = result.filters || undefined;
2020-05-13 21:24:29 +02:00
2021-09-12 16:51:55 +02:00
if (filters === undefined || filters.length === 0) {
//
// No filters defined, create base filters
//
console.debug("Stored filters: undefined or empty");
2020-05-21 12:12:10 +02:00
2021-09-12 16:51:55 +02:00
filters = [];
for (const account of SysTrayX.Messaging.accounts) {
const inbox = account.folders.filter(
(folder) => folder.type == "inbox"
);
2020-05-13 21:24:29 +02:00
2021-09-12 16:51:55 +02:00
if (inbox.length > 0) {
let folder = {};
2023-09-06 22:04:41 +02:00
// console.debug("Folder 91+: " + JSON.stringify(inbox[0]));
filters.push({
accountId: inbox[0].accountId,
version: SysTrayX.Info.version,
folders: [inbox[0].path],
});
2021-09-12 16:51:55 +02:00
}
}
2021-09-04 22:16:18 +02:00
2021-09-12 16:51:55 +02:00
console.debug("Force new filters: " + JSON.stringify(filters));
2021-08-12 22:33:29 +02:00
} else {
2021-09-12 16:51:55 +02:00
console.debug("Stored filters: " + JSON.stringify(filters));
2021-08-12 22:33:29 +02:00
}
2021-09-12 16:51:55 +02:00
return filters;
2021-08-10 19:58:16 +02:00
}
2021-09-04 22:16:18 +02:00
function reject() {
return undefined;
}
2021-09-04 22:16:18 +02:00
return await storage().get("filters").then(resolve, reject);
}
//
// Get count type
//
async function getCountType() {
2021-09-04 22:16:18 +02:00
function resolve(result) {
return result.countType || "0";
}
2021-09-04 22:16:18 +02:00
function reject() {
2020-08-02 21:32:09 +02:00
return undefined;
}
2021-09-04 22:16:18 +02:00
return await storage().get("countType").then(resolve, reject);
2020-08-02 21:32:09 +02:00
}
2021-08-10 19:58:16 +02:00
//
2023-08-25 20:44:32 +02:00
// Get start app parameters
//
2023-08-25 18:18:20 +02:00
async function getStartAppParam() {
function resolve(result) {
2023-08-25 18:18:20 +02:00
const startApp = result.startApp || "";
const startAppArgs = result.startAppArgs || "";
return { startApp, startAppArgs };
}
function reject() {
2023-08-25 18:18:20 +02:00
return { startApp: "", startAppArgs: "" };
}
return await storage()
2023-08-25 18:18:20 +02:00
.get(["startApp", "startAppArgs"])
.then(resolve, reject);
}
2021-08-10 19:58:16 +02:00
// Helper funcs for TB91 and later folder handling
2021-08-10 21:39:35 +02:00
async function getMailFolderInfo(folder) {
return await browser.folders.getFolderInfo(folder);
}
2021-08-10 19:58:16 +02:00
// Check if a folder is in the filter list
2021-08-10 20:13:33 +02:00
function isFolderInFilters(folder) {
2021-09-12 16:51:55 +02:00
const accountIndex = SysTrayX.Messaging.filters.findIndex(
(account) => account.accountId === folder.accountId
2021-08-10 19:58:16 +02:00
);
2021-09-12 16:51:55 +02:00
if (accountIndex !== -1) {
return (
SysTrayX.Messaging.filters[accountIndex].folders.filter(
(path) => path === folder.path
).length > 0
);
} else {
return false;
}
2021-08-10 19:58:16 +02:00
}
// Check if the parent folder of a folder is in the filter list
2021-08-10 20:13:33 +02:00
function isParentFolderInFilters(folder) {
2021-08-10 19:58:16 +02:00
const parentPath = folder.path.substring(0, folder.path.lastIndexOf("/"));
2021-09-12 16:51:55 +02:00
const accountIndex = SysTrayX.Messaging.filters.findIndex(
(account) => account.accountId === folder.accountId
2021-08-10 19:58:16 +02:00
);
2021-09-12 16:51:55 +02:00
if (accountIndex !== -1) {
return (
SysTrayX.Messaging.filters[accountIndex].folders.filter(
(path) => path === parentPath
).length > 0
);
} else {
return false;
}
2021-08-10 19:58:16 +02:00
}
// Delete a folder from the filter list
2021-09-04 22:16:18 +02:00
async function deleteFolderFromFilters(folder) {
2021-09-12 16:51:55 +02:00
const accountIndex = SysTrayX.Messaging.filters.findIndex(
(account) => account.accountId === folder.accountId
2021-08-10 19:58:16 +02:00
);
2021-09-12 16:51:55 +02:00
if (accountIndex !== -1) {
const account = SysTrayX.Messaging.filters[accountIndex];
account.folders = account.folders.filter((path) => path !== folder.path);
// Store the new filters
await storage().set({
filters: SysTrayX.Messaging.filters,
});
}
2021-08-10 19:58:16 +02:00
}
// Get the account name from an id
function getAccountName(id) {
2021-09-12 16:51:55 +02:00
const account = SysTrayX.Messaging.accounts.find(
2021-08-10 19:58:16 +02:00
(account) => account.id === id
2021-09-12 16:51:55 +02:00
);
2021-08-10 19:58:16 +02:00
return account.name;
}
// Add a folder to the filter list
2021-09-04 22:16:18 +02:00
async function addFolderToFilters(newFolder) {
2021-09-12 16:51:55 +02:00
const accountIndex = SysTrayX.Messaging.filters.findIndex(
(account) => account.accountId === newFolder.accountId
);
2021-09-12 16:51:55 +02:00
if (accountIndex !== -1) {
const account = SysTrayX.Messaging.filters[accountIndex];
account.folders.push(newFolder.path);
// Store the new filter
await storage().set({
filters: SysTrayX.Messaging.filters,
});
}
}
2023-09-10 21:08:31 +02:00
// Collect unread mail
const collectUnreadMail = async () => {
for (const filter of SysTrayX.Messaging.filters) {
for (const path of filter.folders) {
const folder = {
accountId: filter.accountId,
path: path,
};
let mailFolderInfo = {};
try {
mailFolderInfo = await browser.folders.getFolderInfo(folder);
} catch (err) {
console.debug("Filter error: " + err);
console.debug("Filter error: " + JSON.stringify(folder));
}
if (mailFolderInfo.unreadMessageCount !== undefined) {
if (SysTrayX.Messaging.unread[folder.accountId] === undefined) {
SysTrayX.Messaging.unread[folder.accountId] = {};
}
if (SysTrayX.Messaging.new[folder.accountId] === undefined) {
SysTrayX.Messaging.new[folder.accountId] = {};
}
if (
SysTrayX.Messaging.new[folder.accountId][folder.path] === undefined
) {
SysTrayX.Messaging.new[folder.accountId][folder.path] = [];
}
SysTrayX.Messaging.unread[folder.accountId][folder.path] =
mailFolderInfo.unreadMessageCount;
}
}
}
};
// Count and send the unread and new mails
2023-09-11 21:31:07 +02:00
const sendMailCountPre115 = () => {
if (SysTrayX.Info.browserInfo.majorVersion < 115) {
// Collect the unread mail
collectUnreadMail();
// Count the collected mail
let unreadCount = 0;
let newCount = 0;
SysTrayX.Messaging.filters.forEach((filter) => {
const accountId = filter.accountId;
filter.folders.forEach((path) => {
if (SysTrayX.Messaging.unread[accountId] !== undefined) {
if (SysTrayX.Messaging.unread[accountId][path] !== undefined) {
unreadCount = unreadCount + SysTrayX.Messaging.unread[accountId][path];
}
}
2023-09-11 21:31:07 +02:00
if (SysTrayX.Messaging.new[accountId] !== undefined) {
if (SysTrayX.Messaging.new[accountId][path] !== undefined) {
newCount = newCount + SysTrayX.Messaging.new[accountId][path].length;
}
}
2023-09-11 21:31:07 +02:00
});
});
2023-09-11 21:31:07 +02:00
//console.debug("Filters: " + JSON.stringify(SysTrayX.Messaging.filters));
//console.debug("New: " + JSON.stringify(SysTrayX.Messaging.new));
2023-10-03 21:46:28 +02:00
//console.debug("sendMailCountPre115 Unread: " + unreadCount);
//console.debug("sendMailCountPre115 New: " + newCount);
2023-09-09 19:58:00 +02:00
2023-09-11 21:31:07 +02:00
SysTrayX.Link.postSysTrayXMessage( { mailCount: { unread: unreadCount, new: newCount } } );
}
2022-07-03 14:16:05 +02:00
};
2023-09-06 21:21:06 +02:00
2023-09-10 21:08:31 +02:00
// Count and send the unread and new mails (>TB115)
2023-09-11 21:31:07 +02:00
const sendMailCount = async () => {
if (SysTrayX.Info.browserInfo.majorVersion >= 115) {
2023-09-06 21:21:06 +02:00
2023-09-11 21:31:07 +02:00
// New only works for >=TB106
2023-09-06 21:21:06 +02:00
2023-09-11 21:31:07 +02:00
let unreadCount = 0;
let newCount = 0;
2023-09-06 21:21:06 +02:00
2023-09-11 21:31:07 +02:00
for (const filter of SysTrayX.Messaging.filters) {
for (const path of filter.folders) {
const folder = {
accountId: filter.accountId,
path: path,
};
async function* listMessages(folder) {
let page = await messenger.messages.list(folder);
2023-09-06 21:21:06 +02:00
for (let message of page.messages) {
yield message;
}
2023-09-11 21:31:07 +02:00
while (page.id) {
page = await messenger.messages.continueList(page.id);
for (let message of page.messages) {
yield message;
}
}
2023-09-06 21:21:06 +02:00
}
2023-09-11 21:31:07 +02:00
let messages = listMessages(folder);
for await (let message of messages) {
if( message.new )
{
newCount = newCount + 1;
}
2023-09-06 21:21:06 +02:00
2023-09-11 21:31:07 +02:00
if( !message.read )
{
unreadCount = unreadCount + 1;
}
2023-09-06 21:21:06 +02:00
}
}
}
2023-10-03 21:46:28 +02:00
//console.debug("sendMailCount Unread: " + unreadCount);
//console.debug("sendMailCount New: " + newCount);
2023-09-11 21:31:07 +02:00
SysTrayX.Link.postSysTrayXMessage( { mailCount: { unread: unreadCount, new: newCount } } );
}
2023-09-06 21:21:06 +02:00
};