From 584cfd4ff8964a0747e3fb047c10decd6fef3e00 Mon Sep 17 00:00:00 2001 From: Ajay Ramachandran Date: Tue, 6 Jul 2021 01:33:06 -0400 Subject: [PATCH 1/3] Add lock button shown for VIPs --- manifest/manifest.json | 1 + public/icons/lock.svg | 1 + public/popup.html | 3 ++ src/content.ts | 2 ++ src/popup.ts | 79 ++++++++++++++++++++---------------------- 5 files changed, 44 insertions(+), 42 deletions(-) create mode 100644 public/icons/lock.svg diff --git a/manifest/manifest.json b/manifest/manifest.json index 771562e400..a822954171 100644 --- a/manifest/manifest.json +++ b/manifest/manifest.json @@ -41,6 +41,7 @@ "icons/report.png", "icons/close.png", "icons/refresh.svg", + "icons/lock.svg", "icons/beep.ogg", "icons/PlayerInfoIconSponsorBlocker.svg", "icons/PlayerDeleteIconSponsorBlocker.svg", diff --git a/public/icons/lock.svg b/public/icons/lock.svg new file mode 100644 index 0000000000..95a257b2e2 --- /dev/null +++ b/public/icons/lock.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/public/popup.html b/public/popup.html index 466de0bdef..9cc9761225 100644 --- a/public/popup.html +++ b/public/popup.html @@ -21,6 +21,9 @@ +
diff --git a/src/content.ts b/src/content.ts index 8f98edaa16..12a2a9f247 100644 --- a/src/content.ts +++ b/src/content.ts @@ -1412,11 +1412,13 @@ function openInfoMenu() { const edit = popup.querySelector("#sbPopupIconEdit"); const check = popup.querySelector("#sbPopupIconCheck"); const refreshSegments = popup.querySelector("#refreshSegments"); + const lockSegments = popup.querySelector("#lockSegments"); logo.src = chrome.extension.getURL("icons/IconSponsorBlocker256px.png"); settings.src = chrome.extension.getURL("icons/settings.svg"); edit.src = chrome.extension.getURL("icons/pencil.svg"); check.src = chrome.extension.getURL("icons/check.svg"); refreshSegments.src = chrome.extension.getURL("icons/refresh.svg"); + lockSegments.src = chrome.extension.getURL("icons/lock.svg"); parentNode.insertBefore(popup, parentNode.firstChild); diff --git a/src/popup.ts b/src/popup.ts index 9efa790f4e..e1dac07b53 100644 --- a/src/popup.ts +++ b/src/popup.ts @@ -103,6 +103,7 @@ async function runThePopup(messageListener?: MessageListener): Promise { "sponsorMessageTimes", //"downloadedSponsorMessageTimes", "refreshSegmentsButton", + "lockSegmentsButton", "whitelistButton", "sbDonate" ].forEach(id => PageElements[id] = document.getElementById(id)); @@ -133,6 +134,7 @@ async function runThePopup(messageListener?: MessageListener): Promise { PageElements.optionsButton.addEventListener("click", openOptions); PageElements.helpButton.addEventListener("click", openHelp); PageElements.refreshSegmentsButton.addEventListener("click", refreshSegments); + PageElements.lockSegmentsButton.addEventListener("click", lockSegments); /** If true, the content script is in the process of creating a new segment. */ let creatingSegment = false; @@ -158,53 +160,42 @@ async function runThePopup(messageListener?: MessageListener): Promise { PageElements.showNoticeAgain.style.display = "unset"; } - utils.sendRequestToServer("GET", "/api/getUsername?userID=" + Config.config.userID, (res) => { - if (res.status === 200) { - PageElements.usernameValue.innerText = JSON.parse(res.responseText).userName - } - }) - - //get the amount of times this user has contributed and display it to thank them - if (Config.config.sponsorTimesContributed != undefined) { - PageElements.sponsorTimesContributionsDisplay.innerText = Config.config.sponsorTimesContributed.toLocaleString(); - PageElements.sponsorTimesContributionsContainer.classList.remove("hidden"); - - //get the userID - const userID = Config.config.userID; - if (userID != undefined) { - //there are probably some views on these submissions then - //get the amount of views from the sponsors submitted - utils.sendRequestToServer("GET", "/api/getViewsForUser?userID=" + userID, function(response) { - if (response.status == 200) { - const viewCount = JSON.parse(response.responseText).viewCount; - if (viewCount != 0) { - if (viewCount > 1) { - PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segments"); - } else { - PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segment"); - } + const userInfoRes = await utils.asyncRequestToServer("GET", "/api/userInfo?userID=" + Config.config.userID); + if (userInfoRes.ok) { + const userInfo = JSON.parse(userInfoRes.responseText); - PageElements.sponsorTimesViewsDisplay.innerText = viewCount.toLocaleString(); - PageElements.sponsorTimesViewsContainer.style.display = "unset"; - } + if (userInfo.vip) PageElements.lockSegmentsButton.classList.remove("hidden"); + + PageElements.usernameValue.innerText = userInfo.userName; + + //get the amount of times this user has contributed and display it to thank them + if (Config.config.sponsorTimesContributed != undefined) { + PageElements.sponsorTimesContributionsDisplay.innerText = Config.config.sponsorTimesContributed.toLocaleString(); + PageElements.sponsorTimesContributionsContainer.classList.remove("hidden"); + + //get the userID + const viewCount = userInfo.viewCount; + if (viewCount != 0) { + if (viewCount > 1) { + PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segments"); + } else { + PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segment"); } - }); - //get this time in minutes - utils.sendRequestToServer("GET", "/api/getSavedTimeForUser?userID=" + userID, function(response) { - if (response.status == 200) { - const minutesSaved = JSON.parse(response.responseText).timeSaved; - if (minutesSaved != 0) { - if (minutesSaved != 1) { - PageElements.sponsorTimesOthersTimeSavedEndWord.innerText = chrome.i18n.getMessage("minsLower"); - } else { - PageElements.sponsorTimesOthersTimeSavedEndWord.innerText = chrome.i18n.getMessage("minLower"); - } + PageElements.sponsorTimesViewsDisplay.innerText = viewCount.toLocaleString(); + PageElements.sponsorTimesViewsContainer.style.display = "unset"; + } - PageElements.sponsorTimesOthersTimeSavedDisplay.innerText = getFormattedHours(minutesSaved); - } + const minutesSaved = userInfo.minutesSaved; + if (minutesSaved != 0) { + if (minutesSaved != 1) { + PageElements.sponsorTimesOthersTimeSavedEndWord.innerText = chrome.i18n.getMessage("minsLower"); + } else { + PageElements.sponsorTimesOthersTimeSavedEndWord.innerText = chrome.i18n.getMessage("minLower"); } - }); + + PageElements.sponsorTimesOthersTimeSavedDisplay.innerText = getFormattedHours(minutesSaved); + } } } @@ -690,6 +681,10 @@ async function runThePopup(messageListener?: MessageListener): Promise { ); } + function lockSegments() { + alert("lock"); + } + /** * Should skipping be disabled (visuals stay) */ From b06694533136e8609e251280ddca6c66299fd4dd Mon Sep 17 00:00:00 2001 From: Ajay Ramachandran Date: Tue, 6 Jul 2021 01:35:39 -0400 Subject: [PATCH 2/3] Use segment count from the API --- src/popup.ts | 42 +++++++++++++++++++----------------------- 1 file changed, 19 insertions(+), 23 deletions(-) diff --git a/src/popup.ts b/src/popup.ts index e1dac07b53..7cae5c9296 100644 --- a/src/popup.ts +++ b/src/popup.ts @@ -168,34 +168,30 @@ async function runThePopup(messageListener?: MessageListener): Promise { PageElements.usernameValue.innerText = userInfo.userName; - //get the amount of times this user has contributed and display it to thank them - if (Config.config.sponsorTimesContributed != undefined) { - PageElements.sponsorTimesContributionsDisplay.innerText = Config.config.sponsorTimesContributed.toLocaleString(); - PageElements.sponsorTimesContributionsContainer.classList.remove("hidden"); - - //get the userID - const viewCount = userInfo.viewCount; - if (viewCount != 0) { - if (viewCount > 1) { - PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segments"); - } else { - PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segment"); - } + PageElements.sponsorTimesContributionsDisplay.innerText = userInfo.segmentCount.toLocaleString(); + PageElements.sponsorTimesContributionsContainer.classList.remove("hidden"); - PageElements.sponsorTimesViewsDisplay.innerText = viewCount.toLocaleString(); - PageElements.sponsorTimesViewsContainer.style.display = "unset"; + const viewCount = userInfo.viewCount; + if (viewCount != 0) { + if (viewCount > 1) { + PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segments"); + } else { + PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segment"); } - const minutesSaved = userInfo.minutesSaved; - if (minutesSaved != 0) { - if (minutesSaved != 1) { - PageElements.sponsorTimesOthersTimeSavedEndWord.innerText = chrome.i18n.getMessage("minsLower"); - } else { - PageElements.sponsorTimesOthersTimeSavedEndWord.innerText = chrome.i18n.getMessage("minLower"); - } + PageElements.sponsorTimesViewsDisplay.innerText = viewCount.toLocaleString(); + PageElements.sponsorTimesViewsContainer.style.display = "unset"; + } - PageElements.sponsorTimesOthersTimeSavedDisplay.innerText = getFormattedHours(minutesSaved); + const minutesSaved = userInfo.minutesSaved; + if (minutesSaved != 0) { + if (minutesSaved != 1) { + PageElements.sponsorTimesOthersTimeSavedEndWord.innerText = chrome.i18n.getMessage("minsLower"); + } else { + PageElements.sponsorTimesOthersTimeSavedEndWord.innerText = chrome.i18n.getMessage("minLower"); } + + PageElements.sponsorTimesOthersTimeSavedDisplay.innerText = getFormattedHours(minutesSaved); } } From d97d45ae1467ba11319a372102c83c8e3865e36a Mon Sep 17 00:00:00 2001 From: Ajay Ramachandran Date: Tue, 6 Jul 2021 01:39:05 -0400 Subject: [PATCH 3/3] Remove some redundant checks --- src/popup.ts | 38 ++++++++++++++------------------------ 1 file changed, 14 insertions(+), 24 deletions(-) diff --git a/src/popup.ts b/src/popup.ts index 7cae5c9296..5220701e50 100644 --- a/src/popup.ts +++ b/src/popup.ts @@ -146,17 +146,13 @@ async function runThePopup(messageListener?: MessageListener): Promise { let currentVideoID = null; //show proper disable skipping button - const disableSkipping = Config.config.disableSkipping; - if (disableSkipping != undefined && disableSkipping) { + if (Config.config.disableSkipping) { PageElements.disableSkipping.style.display = "none"; PageElements.enableSkipping.style.display = "unset"; PageElements.toggleSwitch.checked = false; } - //if the don't show notice again variable is true, an option to - // disable should be available - const dontShowNotice = Config.config.dontShowNotice; - if (dontShowNotice != undefined && dontShowNotice) { + if (Config.config.dontShowNotice) { PageElements.showNoticeAgain.style.display = "unset"; } @@ -195,29 +191,23 @@ async function runThePopup(messageListener?: MessageListener): Promise { } } - //get the amount of times this user has skipped a sponsor - if (Config.config.skipCount != undefined) { - if (Config.config.skipCount != 1) { - PageElements.sponsorTimesSkipsDoneEndWord.innerText = chrome.i18n.getMessage("Segments"); - } else { - PageElements.sponsorTimesSkipsDoneEndWord.innerText = chrome.i18n.getMessage("Segment"); - } - - PageElements.sponsorTimesSkipsDoneDisplay.innerText = Config.config.skipCount.toLocaleString(); - PageElements.sponsorTimesSkipsDoneContainer.style.display = "unset"; + if (Config.config.skipCount != 1) { + PageElements.sponsorTimesSkipsDoneEndWord.innerText = chrome.i18n.getMessage("Segments"); + } else { + PageElements.sponsorTimesSkipsDoneEndWord.innerText = chrome.i18n.getMessage("Segment"); } - //get the amount of time this user has saved. - if (Config.config.minutesSaved != undefined) { - if (Config.config.minutesSaved != 1) { - PageElements.sponsorTimeSavedEndWord.innerText = chrome.i18n.getMessage("minsLower"); - } else { - PageElements.sponsorTimeSavedEndWord.innerText = chrome.i18n.getMessage("minLower"); - } + PageElements.sponsorTimesSkipsDoneDisplay.innerText = Config.config.skipCount.toLocaleString(); + PageElements.sponsorTimesSkipsDoneContainer.style.display = "unset"; - PageElements.sponsorTimeSavedDisplay.innerText = getFormattedHours(Config.config.minutesSaved); + if (Config.config.minutesSaved != 1) { + PageElements.sponsorTimeSavedEndWord.innerText = chrome.i18n.getMessage("minsLower"); + } else { + PageElements.sponsorTimeSavedEndWord.innerText = chrome.i18n.getMessage("minLower"); } + PageElements.sponsorTimeSavedDisplay.innerText = getFormattedHours(Config.config.minutesSaved); + // Must be delayed so it only happens once loaded setTimeout(() => PageElements.sponsorblockPopup.classList.remove("preload"), 250);