1
0
mirror of https://github.com/nileshtrivedi/better synced 2025-01-14 21:45:52 +01:00

Merge pull request #15 from nileshtrivedi/feature-dismiss-popup

feat: permanently dismiss popup
This commit is contained in:
Nilesh 2020-08-06 17:25:43 +05:30 committed by GitHub
commit 042a075c49
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 28 additions and 4 deletions

View File

@ -35,7 +35,7 @@ function onStartup(){
function getMatch(url){ function getMatch(url){
var match = BETTER_ALTERNATIVES.find(pattern => url.match(new RegExp(pattern.urlPattern))); var match = BETTER_ALTERNATIVES.find(pattern => url.match(new RegExp(pattern.urlPattern)));
if(match && match.alternatives) if(match && match.alternatives)
return match.alternatives; return match;
else return null; else return null;
} }

View File

@ -53,8 +53,9 @@ function createRecommendedAlt(recommendedAlternative) {
return recommendedAlt; return recommendedAlt;
} }
function showBetter(alternatives) { function showBetter(match) {
if(!alternatives) return; if(!match || !match.alternatives) return;
let alternatives = match.alternatives;
let betterdiv = document.createElement("div"); let betterdiv = document.createElement("div");
betterdiv.setAttribute("style", betterdiv.setAttribute("style",
@ -71,12 +72,35 @@ function showBetter(alternatives) {
let dismissButton = document.createElement("button"); let dismissButton = document.createElement("button");
dismissButton.innerHTML = "✗ Dismiss suggestion for this URL"; dismissButton.innerHTML = "✗ Dismiss suggestion for this URL";
dismissButton.setAttribute("style", "display: block; font-size: 14px; margin: 16px auto;"); dismissButton.setAttribute("style", "display: block; font-size: 14px; margin: 16px auto;");
dismissButton.addEventListener("click", () => {
document.body.removeChild(betterdiv);
dismissPermanently(match);
})
betterdiv.appendChild(dismissButton); betterdiv.appendChild(dismissButton);
document.body.appendChild(betterdiv); document.body.appendChild(betterdiv);
} }
function dismissPermanently(match) {
let key = `dismiss@${match.urlPattern}`
chrome.storage.local.set({
[key]: true,
});
}
function ifNotDissmissed(match, callback) {
let key = `dismiss@${match.urlPattern}`
chrome.storage.local.get(key, (item) => {
if (item && item[key]) {
return;
} else {
callback(match);
}
})
}
chrome.runtime.sendMessage({type: 'getMatch', url: document.location.href}, (response) => { chrome.runtime.sendMessage({type: 'getMatch', url: document.location.href}, (response) => {
if (response) { if (response) {
showBetter(response); ifNotDissmissed(response, showBetter);
} }
}); });