improve redirect tab

This commit is contained in:
2018-05-23 10:46:04 +08:00
parent c81b2d1989
commit fb452ef3de
2 changed files with 67 additions and 30 deletions

View File

@ -5,13 +5,16 @@
// console.log(request); // console.log(request);
let data = extractData(request.itemsSelector, request.fieldSelectors); let data = extractData(request.itemsSelector, request.fieldSelectors);
// console.log(data); // console.log(data);
sendResponse(data); if (sendResponse) sendResponse(data);
} else if (request.from == "doExtractGotoUrl") { } else if (request.from == "doExtractGotoUrl") {
// console.log(request); // console.log(request);
window.location.replace(request.url); window.location.replace(request.url);
} else if (request.from == "doExtractReportIn") { } else if (request.from == "doExtractReportIn") {
// console.log("doExtractReportIn"); // console.log("doExtractReportIn");
sendResponse(request.from); if (sendResponse) sendResponse(request.from);
} else if (request.from == "doExtractQueryUrl") {
// console.log("doExtractReportIn");
if (sendResponse) sendResponse(window.location.href);
} }
} }
); );

View File

@ -69,42 +69,76 @@ function extractTabData(tab, itemsSelector, fieldSelectors) {
} }
function redirectTab(tab, url) { function redirectTab(tab, url) {
let done = false;
let timeOut;
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
let req = { let req = {
from: "doExtractGotoUrl", from: "doExtractGotoUrl",
url: url url: url
} }
chrome.tabs.sendMessage(tab.id, req, r => { let curUrl = "";
// if (r != req.from) return; queryUrl(tab)
// detectLoop(); .then(u => {
setTimeout(() => { if (url !== u) {
detectLoop(); curUrl = u;
}, 500); chrome.tabs.sendMessage(tab.id, req);
}); }
setTimeout(() => { })
if (!done) { .then(() => queryUrl(tab, curUrl))
reject(`redirectTab failed after 10 second.`); .then(() => reportIn(tab))
clearTimeout(timeOut); .then(tab => resolve(tab))
} .catch(err => reject(err));
}, 10000); });
}
function detectLoop() { function reportIn(tab) {
let req = { let req = {
from: "doExtractReportIn" from: "doExtractReportIn"
} }
return new Promise((resolve, reject) => {
let timeOut;
let rejectTimeout = setTimeout(() => {
reject(`reportIn failed after 10 second.`);
clearTimeout(timeOut);
}, 10000);
loop();
function loop() {
chrome.tabs.sendMessage(tab.id, req, r => { chrome.tabs.sendMessage(tab.id, req, r => {
if (r != req.from) return; if (r == req.from) {
resolve(tab) resolve(tab);
done = true; clearTimeout(rejectTimeout);
} else {
timeOut = setTimeout(() => {
loop();
}, 500);
}
});
}
});
}
function queryUrl(tab, urlExcluded) {
let req = {
from: "doExtractQueryUrl"
}
return new Promise((resolve, reject) => {
let timeOut;
let rejectTimeout = setTimeout(() => {
reject(`queryUrl failed after 10 second.`);
clearTimeout(timeOut);
}, 10000);
loop();
function loop() {
chrome.tabs.sendMessage(tab.id, req, url => {
if (url && (!urlExcluded || (urlExcluded && urlExcluded != url))) {
resolve(url);
clearTimeout(rejectTimeout);
} else {
timeOut = setTimeout(() => {
loop();
}, 500);
}
}); });
if (!done) {
clearTimeout(timeOut);
timeOut = setTimeout(() => {
detectLoop();
}, 100);
}
} }
}); });
} }