chromeextension/background.js

116 lines
3.1 KiB
JavaScript
Raw Permalink Normal View History

2024-05-13 22:51:32 +02:00
// Define a variable to store last call URL info
2024-05-27 19:37:06 +02:00
let state = { date: '', result: '' };
2024-05-13 22:51:32 +02:00
2024-05-27 19:37:06 +02:00
// Function to update last call URL info and send this to the popup
function updateState({date, result}) {
state.date = date;
state.result = result;
sendState()
2024-05-13 22:51:32 +02:00
}
2024-05-27 19:37:06 +02:00
async function sendState() {
try {
await chrome.runtime.sendMessage({
...state
});
}
catch(err) {
console.log(`cant send data to popup ${err.message}`);
}
2024-05-13 22:51:32 +02:00
}
// Message listener for communication with popup
chrome.runtime.onMessage.addListener(function (message, sender, sendResponse) {
2024-05-27 19:37:06 +02:00
if (message.type === 'sendState') {
sendState()
2024-05-13 22:51:32 +02:00
} else if (message.type === 'callURLManually') {
callURL();
}
2024-05-27 19:37:06 +02:00
return false;
2024-05-13 22:51:32 +02:00
});
// Function to call the URL
async function callURL() {
try {
2024-05-27 19:37:06 +02:00
updateState(new Date().toLocaleString(), '');
2024-05-13 22:51:32 +02:00
const bookmarks = await exportBookmarks();
2024-05-27 19:37:06 +02:00
const response = await fetch('https://bookmark.raphaelpiccolo.com/fr/push', {
2024-05-13 22:51:32 +02:00
method: 'POST',
headers: {
'Content-Type': 'application/json'
},
body: JSON.stringify(bookmarks)
});
const text = await response.text();
2024-05-27 19:37:06 +02:00
updateState(new Date().toLocaleString(), text);
2024-05-13 22:51:32 +02:00
} catch (err) {
console.error('Une erreur est survenue lors de l\'appel à l\'URL :', err);
2024-05-27 19:37:06 +02:00
updateState(new Date().toLocaleString(), 'Error: ' + err.message);
2024-05-13 22:51:32 +02:00
}
}
// Get bookmarks recursively
function getBookmarks(node) {
if (node.children) {
const bookmarks = [];
for (const child of node.children) {
if (child.url) {
bookmarks.push({ title: child.title, url: child.url });
} else {
bookmarks.push({ folder: child.title, children: getBookmarks(child) });
}
}
return bookmarks;
}
}
// Function to export bookmarks
async function exportBookmarks() {
return new Promise((resolve, reject) => {
chrome.bookmarks.getTree((nodes) => {
const bookmarks = getBookmarks(nodes[0]);
resolve(bookmarks);
});
});
}
// Event listeners for bookmarks changes
chrome.bookmarks.onCreated.addListener(callURL);
chrome.bookmarks.onChanged.addListener(callURL);
chrome.bookmarks.onImportEnded.addListener(callURL);
chrome.bookmarks.onMoved.addListener(callURL);
chrome.bookmarks.onChildrenReordered.addListener(callURL);
// Call URL function on chrome boot
setTimeout(callURL, 10000);
2024-05-27 19:37:06 +02:00
// async function pushActivity(tab) {
// var url = (await chrome.tabs.get(tab)).url;
// console.log(url);
// }
2024-05-13 22:51:32 +02:00
2024-05-27 19:37:06 +02:00
// chrome.tabs.onUpdated.addListener(function (tabId, changeInfo, tab) {
// // Vérifier si l'URL a changé
// if (changeInfo.url) {
// pushActivity(tabId);
// }
// });
2024-05-13 22:51:32 +02:00
2024-05-27 19:37:06 +02:00
// chrome.tabs.onActivated.addListener((tab) => { pushActivity(tab.tabId) });
2024-05-13 22:51:32 +02:00
// window.setInterval(checkBrowserFocus, 1000);
// function checkBrowserFocus() {
// chrome.windows.getCurrent(function (browser) {
// console.log(browser.focused)
// })
// }