mirror of
https://github.com/ajayyy/SponsorBlock.git
synced 2025-12-17 21:18:56 +03:00
Added UI to support picking out sponsors and submitting
This commit is contained in:
92
popup.js
Normal file
92
popup.js
Normal file
@@ -0,0 +1,92 @@
|
||||
document.getElementById("sponsorStart").addEventListener("click", sendSponsorStartMessage);
|
||||
document.getElementById("clearTimes").addEventListener("click", clearTimes);
|
||||
|
||||
//if true, the button now selects the end time
|
||||
var startTimeChosen = false;
|
||||
|
||||
//the start and end time pairs (2d)
|
||||
var videoTimes = [];
|
||||
//load video times
|
||||
chrome.storage.local.get(['videoTimes'], function(result) {
|
||||
if (result.videoTimes != undefined) {
|
||||
videoTimes = result.videoTimes;
|
||||
|
||||
if (videoTimes[videoTimes.length - 1].length < 2) {
|
||||
startTimeChosen = true;
|
||||
}
|
||||
|
||||
displayVideoTimes();
|
||||
}
|
||||
});
|
||||
|
||||
function sendSponsorStartMessage() {
|
||||
//the content script will get the message if a YouTube page is open
|
||||
chrome.tabs.query({
|
||||
active: true,
|
||||
currentWindow: true
|
||||
}, tabs => {
|
||||
// ...and send a request for the DOM info...
|
||||
chrome.tabs.sendMessage(
|
||||
tabs[0].id,
|
||||
{from: 'popup', subject: 'DOMInfo', message: 'sponsorStart'}
|
||||
);
|
||||
});
|
||||
}
|
||||
|
||||
chrome.runtime.onMessage.addListener(function (request, sender, callback) {
|
||||
if (request.message == "time") {
|
||||
let timeMessage = request.time.toFixed(2) + "s";
|
||||
|
||||
let videoTimesIndex = videoTimes.length - (startTimeChosen ? 1 : 0);
|
||||
|
||||
if (videoTimes[videoTimesIndex] == undefined) {
|
||||
videoTimes[videoTimesIndex] = [];
|
||||
}
|
||||
|
||||
videoTimes[videoTimesIndex][startTimeChosen ? 1 : 0] = request.time;
|
||||
|
||||
chrome.storage.local.set({"videoTimes": videoTimes});
|
||||
|
||||
//update startTimeChosen variable
|
||||
if (!startTimeChosen) {
|
||||
startTimeChosen = true;
|
||||
document.getElementById("sponsorStart").innerHTML = "Sponsorship Ends";
|
||||
} else {
|
||||
startTimeChosen = false;
|
||||
document.getElementById("sponsorStart").innerHTML = "Sponsorship Start";
|
||||
}
|
||||
|
||||
//display video times on screen
|
||||
displayVideoTimes();
|
||||
}
|
||||
});
|
||||
|
||||
//display the video times from the array
|
||||
function displayVideoTimes() {
|
||||
//make sure the div is empty first
|
||||
document.getElementById("sponsorMessageTimes").innerHTML = "";
|
||||
|
||||
for (let i = 0; i < videoTimes.length; i++) {
|
||||
console.log(videoTimes)
|
||||
for (let s = 0; s < videoTimes[i].length; s++) {
|
||||
let timeMessage = videoTimes[i][s] + "s";
|
||||
//if this is an end time
|
||||
if (s == 1) {
|
||||
timeMessage = " to " + timeMessage;
|
||||
} else if (i > 0) {
|
||||
//add commas if necessary
|
||||
timeMessage = ", " + timeMessage;
|
||||
}
|
||||
|
||||
document.getElementById("sponsorMessageTimes").innerHTML += timeMessage;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
function clearTimes() {
|
||||
videoTimes = [];
|
||||
|
||||
chrome.storage.local.set({"videoTimes": videoTimes});
|
||||
|
||||
displayVideoTimes();
|
||||
}
|
||||
Reference in New Issue
Block a user