diff --git a/README.md b/README.md
index 1ca64824..3c13765c 100644
--- a/README.md
+++ b/README.md
@@ -97,6 +97,7 @@ The awesome [Invidious API](https://github.com/omarroth/invidious/wiki/API) was
Originally forked from [YTSponsorSkip](https://github.com/NDevTK/YTSponsorSkip), but zero code remains.
-Some icons made by Gregor Cresnar from www.flaticon.com and are licensed by CC 3.0 BY
-
-Some icons made by Freepik from www.flaticon.com are licensed by CC 3.0 BY
+Icons made by:
+* Gregor Cresnar from www.flaticon.com and are licensed by CC 3.0 BY
+* Freepik from www.flaticon.com and are licensed by CC 3.0 BY
+* Alexander Kahlkopf from iconmonstr.com and are licensed by iconmonstr License
diff --git a/manifest/manifest.json b/manifest/manifest.json
index db127294..2cfd9bce 100644
--- a/manifest/manifest.json
+++ b/manifest/manifest.json
@@ -28,6 +28,9 @@
"icons/PlayerStopIconSponsorBlocker256px.png",
"icons/PlayerUploadIconSponsorBlocker256px.png",
"icons/PlayerUploadFailedIconSponsorBlocker256px.png",
+ "icons/settings.svg",
+ "icons/pencil.svg",
+ "icons/check.svg",
"icons/upvote.png",
"icons/downvote.png",
"icons/thumbs_down.svg",
diff --git a/public/_locales/en/messages.json b/public/_locales/en/messages.json
index 62ec128c..a13a3165 100644
--- a/public/_locales/en/messages.json
+++ b/public/_locales/en/messages.json
@@ -86,7 +86,7 @@
"message": "Segment Ends Now"
},
"noVideoID": {
- "message": "No YouTube video found at this tab. If you know this is a YouTube tab, close this popup and open it again. If that does not work, try reloading the tab."
+ "message": "No YouTube video found.\nIf this is incorrect, refresh the tab."
},
"success": {
"message": "Success!"
@@ -122,31 +122,35 @@
"message": "Are you sure you want to submit this?"
},
"whitelistChannel": {
- "message": "Whitelist Channel"
+ "message": "Add to whitelist"
},
"removeFromWhitelist": {
- "message": "Remove Channel From Whitelist"
+ "message": "Remove from whitelist"
},
"voteOnTime": {
"message": "Vote On A Segment"
},
- "soFarUHSubmited": {
- "message": "So far, you've submitted"
+ "Submissions": {
+ "message": "Submissions"
},
"savedPeopleFrom": {
- "message": "You have saved people from "
+ "message": "You've saved people from "
},
"viewLeaderboard": {
- "message": "View the leaderboard"
+ "message": "Leaderboard"
},
"here": {
"message": "here"
},
"recordTimesDescription": {
- "message": "Click the button below when the segment starts and ends to record and submit it to the database."
+ "message": "Submit"
+ },
+ "submissionEditHint": {
+ "message": "Section editing will appear after you click submit",
+ "description": "Appears in the popup to inform them that editing has been moved to the video player."
},
"popupHint": {
- "message": "Hint: Press the semicolon key while focused on a video to report the start/end of a segment and quote to submit. (This can be changed in the options)"
+ "message": "Hint: You can setup keybinds for submitting in the options"
},
"clearTimesButton": {
"message": "Clear Times"
@@ -157,6 +161,9 @@
"publicStats": {
"message": "This is used on the public stats page to show off how much you've contributed. See it"
},
+ "Username": {
+ "message": "Username"
+ },
"setUsername": {
"message": "Set Username"
},
@@ -253,10 +260,10 @@
"message": "Connection Timeout. Check your internet connection. If your internet is working, the server is probably overloaded or down."
},
"disableSkipping": {
- "message": "Disable SponsorBlock"
+ "message": "Skipping is enabled"
},
"enableSkipping": {
- "message": "Enable SponsorBlock"
+ "message": "Skipping is disabled"
},
"yourWork": {
"message": "Your Work",
@@ -296,7 +303,7 @@
"message": "This time appears in brackets next to the current time on below the seekbar. This shows the total video duration minus any segments. This includes segments marked as only \"Show In Seekbar\"."
},
"youHaveSkipped": {
- "message": "You have skipped "
+ "message": "You've skipped "
},
"youHaveSaved": {
"message": "You have saved yourself "
@@ -314,10 +321,10 @@
"message": "hours"
},
"youHaveSavedTime": {
- "message": "You have saved people"
+ "message": "You've saved people"
},
"youHaveSavedTimeEnd": {
- "message": " of their lives."
+ "message": " of their lives"
},
"statusReminder": {
"message": "Check status.sponsor.ajay.app for server status."
@@ -634,5 +641,8 @@
},
"unsubmittedWarningDescription": {
"message": "Send a notification when you leave a video with segments that are not uploaded"
+ },
+ "help": {
+ "message": "Help"
}
}
diff --git a/public/icons/check.svg b/public/icons/check.svg
new file mode 100644
index 00000000..7ceda54b
--- /dev/null
+++ b/public/icons/check.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/public/icons/pencil.svg b/public/icons/pencil.svg
new file mode 100644
index 00000000..a14954fb
--- /dev/null
+++ b/public/icons/pencil.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/public/icons/settings.svg b/public/icons/settings.svg
new file mode 100644
index 00000000..d2fdae8f
--- /dev/null
+++ b/public/icons/settings.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/public/icons/thumb.svg b/public/icons/thumb.svg
new file mode 100644
index 00000000..c66bcdbd
--- /dev/null
+++ b/public/icons/thumb.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/public/libs/Source+Sans+Pro.css b/public/libs/Source+Sans+Pro.css
index 3a00466c..55a505fc 100644
--- a/public/libs/Source+Sans+Pro.css
+++ b/public/libs/Source+Sans+Pro.css
@@ -3,7 +3,7 @@
font-family: 'Source Sans Pro';
font-style: normal;
font-weight: 400;
- src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v12/6xK3dSBYKcSV-LCoeQqfX1RYOo3qNa7lqDY.woff2) format('woff2');
+ src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qNa7lqDY.woff2) format('woff2');
unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@@ -11,7 +11,7 @@
font-family: 'Source Sans Pro';
font-style: normal;
font-weight: 400;
- src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v12/6xK3dSBYKcSV-LCoeQqfX1RYOo3qPK7lqDY.woff2) format('woff2');
+ src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qPK7lqDY.woff2) format('woff2');
unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek-ext */
@@ -19,7 +19,7 @@
font-family: 'Source Sans Pro';
font-style: normal;
font-weight: 400;
- src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v12/6xK3dSBYKcSV-LCoeQqfX1RYOo3qNK7lqDY.woff2) format('woff2');
+ src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qNK7lqDY.woff2) format('woff2');
unicode-range: U+1F00-1FFF;
}
/* greek */
@@ -27,7 +27,7 @@
font-family: 'Source Sans Pro';
font-style: normal;
font-weight: 400;
- src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v12/6xK3dSBYKcSV-LCoeQqfX1RYOo3qO67lqDY.woff2) format('woff2');
+ src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qO67lqDY.woff2) format('woff2');
unicode-range: U+0370-03FF;
}
/* vietnamese */
@@ -35,15 +35,15 @@
font-family: 'Source Sans Pro';
font-style: normal;
font-weight: 400;
- src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v12/6xK3dSBYKcSV-LCoeQqfX1RYOo3qN67lqDY.woff2) format('woff2');
- unicode-range: U+0102-0103, U+0110-0111, U+1EA0-1EF9, U+20AB;
+ src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qN67lqDY.woff2) format('woff2');
+ unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
font-family: 'Source Sans Pro';
font-style: normal;
font-weight: 400;
- src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v12/6xK3dSBYKcSV-LCoeQqfX1RYOo3qNq7lqDY.woff2) format('woff2');
+ src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qNq7lqDY.woff2) format('woff2');
unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@@ -51,6 +51,62 @@
font-family: 'Source Sans Pro';
font-style: normal;
font-weight: 400;
- src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v12/6xK3dSBYKcSV-LCoeQqfX1RYOo3qOK7l.woff2) format('woff2');
+ src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xK3dSBYKcSV-LCoeQqfX1RYOo3qOK7l.woff2) format('woff2');
unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
+/* cyrillic-ext */
+@font-face {
+ font-family: 'Source Sans Pro';
+ font-style: normal;
+ font-weight: 700;
+ src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3ig4vwmhduz8A.woff2) format('woff2');
+ unicode-range: U+0460-052F, U+1C80-1C88, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
+}
+/* cyrillic */
+@font-face {
+ font-family: 'Source Sans Pro';
+ font-style: normal;
+ font-weight: 700;
+ src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3ig4vwkxduz8A.woff2) format('woff2');
+ unicode-range: U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
+}
+/* greek-ext */
+@font-face {
+ font-family: 'Source Sans Pro';
+ font-style: normal;
+ font-weight: 700;
+ src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3ig4vwmxduz8A.woff2) format('woff2');
+ unicode-range: U+1F00-1FFF;
+}
+/* greek */
+@font-face {
+ font-family: 'Source Sans Pro';
+ font-style: normal;
+ font-weight: 700;
+ src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3ig4vwlBduz8A.woff2) format('woff2');
+ unicode-range: U+0370-03FF;
+}
+/* vietnamese */
+@font-face {
+ font-family: 'Source Sans Pro';
+ font-style: normal;
+ font-weight: 700;
+ src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3ig4vwmBduz8A.woff2) format('woff2');
+ unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+1EA0-1EF9, U+20AB;
+}
+/* latin-ext */
+@font-face {
+ font-family: 'Source Sans Pro';
+ font-style: normal;
+ font-weight: 700;
+ src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3ig4vwmRduz8A.woff2) format('woff2');
+ unicode-range: U+0100-024F, U+0259, U+1E00-1EFF, U+2020, U+20A0-20AB, U+20AD-20CF, U+2113, U+2C60-2C7F, U+A720-A7FF;
+}
+/* latin */
+@font-face {
+ font-family: 'Source Sans Pro';
+ font-style: normal;
+ font-weight: 700;
+ src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'), url(https://fonts.gstatic.com/s/sourcesanspro/v13/6xKydSBYKcSV-LCoeQqfX1RYOo3ig4vwlxdu.woff2) format('woff2');
+ unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
+}
\ No newline at end of file
diff --git a/public/popup.css b/public/popup.css
index fab03e3d..5a9f7b01 100644
--- a/public/popup.css
+++ b/public/popup.css
@@ -1,242 +1,361 @@
-/* reset some properties to default (youtube messes with them */
-p.popupElement {
- margin-block-start: 1em;
- margin-block-end: 1em;
- margin-inline-start: 0px;
- margin-inline-end: 0px;
+:root {
+ --sb-main-bg-color: #222626;
+ --sb-main-fg-color: white;
+ --sb-gray-fg-color: #444848;
+ --sb-on-white-bg: black;
+ --sb-green-bg: #077B27;
}
-h1.popupElement {
- margin-block-start: 0.67em;
- margin-block-end: 0.67em;
- margin-inline-start: 0px;
- margin-inline-end: 0px;
- font-weight: bold;
+.hidden {
+ display: none !important;
}
-h2.popupElement {
- margin-block-start: 0.83em;
- margin-block-end: 0.83em;
- margin-inline-start: 0px;
- margin-inline-end: 0px;
- font-weight: bold;
+#sponsorblockPopup {
+ color: var(--sb-main-fg-color);
+ font-family: 'Source Sans Pro', sans-serif;
+ font-size: 14px;
+ display: flex;
+ flex-flow: column nowrap;
+ align-items: center;
+ width: 330px;
+ margin: 22px;
+ text-align: center;
}
-h3.popupElement {
- margin-block-start: 1em;
- margin-block-end: 1em;
- margin-inline-start: 0px;
- margin-inline-end: 0px;
- font-weight: bold;
+#issueReporterTimeButtons > .votingButtons > .segmentTimeButton {
+ font-weight: bold;
+ color: var(--sb-main-fg-color);
+ background: none;
+ border: none;
+ padding: 10px 8px;
+ outline: none;
+
+ cursor: pointer;
}
-sub.popupElement {
- font-size: smaller;
+.dot {
+ height: 10px;
+ width: 10px;
+ border-radius: 50%;
+ display: inline-block;
}
-/* end reset */
-#sponsorBlockPopupLogo {
- vertical-align: text-bottom;
+.sponsorTimesThanksForVotingText {
+ font-size: large;
+}
+
+.voteButton {
+ height: 20px;
+ padding: 0 5px;
+
+ cursor: pointer;
+}
+
+#videoInfo>p, #videoInfo>div>p {
+ margin: 0;
+}
+
+div.logoText {
+ display: flex;
+ flex-flow: row nowrap;
+ align-items: center;
+ color: var(--sb-main-fg-color);
+}
+
+div.logoText>p, .sbHeader {
+ font-size: 32px;
+ margin: -4px 0 -2px;
+ font-weight: bold;
+}
+
+.sbHeader.sbSubHeader {
+ font-size: 20px;
+}
+
+.largeButton{
+ background: white;
+ /*font-weight: bold;*/
+ padding: 6px 24px;
+ font-size: 20px;
+ border-radius: 25px;
+ border: none;
+ text-decoration: none;
+ color: black;
+ min-height: 26px;
+ min-width: 152px;
+ display: block;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ font-family: 'Source Sans Pro', sans-serif;
+}
+
+.sponsorBlockPageBody .mediumButton {
+ background-color:#cc1717;
+ -moz-border-radius:28px;
+ -webkit-border-radius:28px;
+ border-radius:28px;
+ border: none;
+ display:inline-block;
+ cursor:pointer;
+ color:#ffffff;
+ font-size:16px;
+ padding:8px 37px;
+ text-decoration:none;
+ text-shadow:0px 0px 0px #662727;
+ font-family: 'Source Sans Pro', sans-serif;
+
+ transition: 0.01s background-color;
+}
+.sponsorBlockPageBody .mediumButton:hover {
+ background-color:#ec1c1c;
+}
+.sponsorBlockPageBody .mediumButton:focus {
+outline: none;
+background-color:#ec1c1c;
+}
+.sponsorBlockPageBody .mediumButton:active {
+ position:relative;
+ top:1px;
+}
+
+/* disable extension */
+
+#disableExtension {
+ display: flex;
+ flex-flow: column nowrap;
+ align-items: center;
+}
+
+/* switch button */
+
+.toggleSwitchContainer {
+ display: flex;
+ cursor: pointer;
+}
+
+.switchBg {
+ display: block;
+ height: 37px;
+ width: 78px;
+ border-radius: 18.5px;
+}
+
+.switchBg.shadow {
+ background: none;
+ box-shadow: 0.75px 0.75px 10px 0px rgba(50, 50, 50, 0.5);
+ opacity: 1;
+}
+
+.switchBg.white {
+ position: absolute;
+ background: white;
+ opacity: 1;
+}
+
+.switchBg.green {
+ position: absolute;
+ background: #00a205;
+ opacity: 0;
+ transition: opacity .2s ease-out;
+}
+
+.switchDot {
+ width: 25px;
+ height: 25px;
+ margin: 6px;
+ background: white;
+ position: absolute;
+ border-radius: 12.5px;
+ box-shadow: .75px .75px 3.8px 0px rgba(50, 50, 50, 0.45);
+ transition: transform .2s ease-out;
+}
+
+.preload * {
+ transition: none !important;
+}
+
+#toggleSwitch:checked~.switchDot {
+ transform: translateX(40px);
+}
+
+#toggleSwitch:checked~.switchBg.green {
+ opacity: 1 !important;
+}
+
+#toggleSwitch:checked~.switchBg.white {
+ opacity: 0 !important;
+ transition: opacity .2s step-end;
+}
+
+.sidebyside {
+ display: flex;
+ flex-flow: row nowrap;
+ width: 88%;
+ margin: 0 6% 0 6%;
+}
+
+.sidebyside>div {
+ width: 50%;
+ justify-content: center;
+}
+
+#whitelistButton, #sponsorTimesSkipsDoneContainer, .toggleSwitchContainer {
+ margin-bottom: 2px !important;
+}
+
+#whitelistForceCheck {
+ font-weight: bold;
+ text-decoration: underline;
+ font-size: large;
+ cursor: pointer;
+ padding: 10px 0;
+}
+
+.sbHeader {
+ margin-bottom: 5px !important;
}
.logoText {
- color: white;
+ margin-bottom: 6px !important;
}
-h1.popupElement {
- margin-top: 0px;
- margin-bottom: 10px;
+#videoInfo, #mainControls, .sidebyside, #sponsorTimesSkipsDoneContainer, .largeButton {
+ margin-bottom: 12px !important;
+}
+#mainControls{
+ flex-flow: column;
+ align-items: center;
+}
+#submitTimesContainer{
+ flex-flow: column;
+ align-items: center;
+}
+/* additional buttons */
+
+#additionalButtons {
+ display: flex;
+ flex-flow: column nowrap;
+ align-items: center;
}
-.popupBody {
- font-size: 14px;
- background-color: #333;
- padding: 0px 5px;
+#additionalButtons>button, button#setUsernameButton, #submitUsername {
+ background: none;
+ border: none;
+ color: white;
+ width: fit-content;
+ padding-left: 0;
- font-family: 'Source Sans Pro', sans-serif;
-
- color: #dddddd;
+ cursor: pointer;
}
-.outerPopupBody {
- background-color: #222626;
- overflow-y: scroll;
+#submitUsername {
+ padding-left: 5pt;
}
-.discreteLink.popupElement {
- color: #dddddd;
+#additionalButtons, #additionalButtons>button {
+ font-size: 15px;
}
-.recordingSubtitle.popupElement {
- margin-bottom: 10px;
+#usernameValue, #usernameInput, #sponsorTimesContributionsDisplay{
+ font-size: 16px;
}
-.voteButton.popupElement {
- height: 32px;
- margin-right: 15px;
- cursor: pointer;
-}
-.voteButton:hover.popupElement {
- filter: brightness(80%);
+.SBWhitelistIcon {
+ min-width: 16px;
+ min-height: 16px;
+ margin-top: auto;
+ margin-bottom: auto;
+
+ height: 100%;
}
-#discordButtonContainer.popupElement {
- font-size: 12px;
+.SBWhitelistIcon>path {
+ fill: var(--sb-main-fg-color);
}
-.sponsorTime.popupElement {
- font-size: 20px;
+label>p, #disableExtension>p, #usernameValue, #usernameElement > div > p,#sponsorTimesContributionsContainer > div > p, #usernameElement > div > #setUsername > #setUsernameStatusContainer > p {
+ margin: 0;
}
-.smallLink.popupElement {
- font-size: 10px;
- text-decoration: underline;
- cursor: pointer;
+#usernameElement > div > p, #sponsorTimesContributionsContainer {
+ text-align: start;
}
-.mediumLink.popupElement {
- font-size: 15px;
- margin-left: 25px;
- margin-right: 25px;
- text-decoration: underline;
- cursor: pointer;
+.grayedOut>.SBWhitelistIcon>path {
+ fill: var(--sb-gray-fg-color);
}
-.tinyLink.popupElement {
- font-size: 10px;
- text-decoration: underline;
- cursor: pointer;
+.grayedOut>label {
+ color: var(--sb-gray-fg-color);
}
-.whitelistButton.popupElement {
- background-color:#27a52d;
- -moz-border-radius:28px;
- -webkit-border-radius:28px;
- border-radius:28px;
- border: none;
- display:inline-block;
- cursor:pointer;
- color:#ffffff;
- font-size:16px;
- padding:8px 37px;
- text-decoration:none;
- text-shadow:0px 0px 0px #27663c;
-
- transition: 0.01s background-color;
-}
-.whitelistButton:hover.popupElement {
- background-color:#3acc3a;
-}
-.whitelistButton:focus.popupElement {
- outline: none;
- background-color:#3acc3a;
-}
-.whitelistButton:active.popupElement {
- position:relative;
- top:1px;
+.SBWhitelistIcon.rotated {
+ transform: rotate(45deg);
}
-.greenButton.popupElement {
- background-color:#cc1717;
- -moz-border-radius:28px;
- -webkit-border-radius:28px;
- border-radius:28px;
- border: none;
- display:inline-block;
- cursor:pointer;
- color:#ffffff;
- font-size:16px;
- padding:8px 37px;
- text-decoration:none;
- text-shadow:0px 0px 0px #662727;
-
- transition: 0.01s background-color;
-}
-.greenButton:hover.popupElement {
- background-color:#ec1c1c;
-}
-.greenButton:focus.popupElement {
- outline: none;
- background-color:#ec1c1c;
-}
-.greenButton:active.popupElement {
- position:relative;
- top:1px;
+.SBWhitelistIconContainer, button#optionsButton>img, .logoText>img, #usernameValue {
+ margin-right: 8px;
}
-.dangerButton.popupElement {
- background-color:#bc3315;
- -moz-border-radius:3px;
- -webkit-border-radius:3px;
- border-radius:3px;
- border: none;
- display:inline-block;
- cursor:pointer;
- color:#ffffff;
- font-size:13px;
- padding:6px 24px;
- text-decoration:none;
- text-shadow:0px 1px 0px #854629;
-}
-.dangerButton:hover.popupElement {
- background-color:#d0451b;
-}
-.dangerButton:focus.popupElement {
- outline: none;
- background-color:#d0451b;
-}
-.dangerButton:active.popupElement {
- position:relative;
- top:1px;
+#whitelistButton>label, #additionalButtons>button, div#setUsernameContainer {
+ display: flex;
+ flex-flow: row nowrap;
}
-.warningButton.popupElement {
- background-color:#bc8215;
- -moz-border-radius:3px;
- -webkit-border-radius:3px;
- border-radius:3px;
- border: none;
- display:inline-block;
- cursor:pointer;
- color:#ffffff;
- font-size:13px;
- padding:6px 24px;
- text-decoration:none;
- text-shadow:0px 1px 0px #856829;
-}
-.warningButton:hover.popupElement {
- background-color:#d0821b;
-}
-.warningButton:focus.popupElement {
- outline: none;
- background-color:#d0821b;
-}
-.warningButton:active.popupElement {
- position:relative;
- top:1px;
+#whitelistButton>label, #additionalButtons>button, div#setUsernameContainer>button {
+ cursor: pointer;
}
-.smallButton.popupElement {
- background-color:#f9902d;
- -moz-border-radius:3px;
- -webkit-border-radius:3px;
- border-radius:3px;
- border:1px solid #f9a72d;
- display:inline-block;
- cursor:pointer;
- color:#ffffff;
- font-size:14px;
- padding:6px 10px;
- text-decoration:none;
+#usernameElement > div, #sponsorTimesContributionsContainer > div {
+ display: flex;
+ flex-flow: column nowrap;
+ align-items: flex-start;
}
-.smallButton:hover.popupElement {
- background-color:#fa9806;
+
+.sidebyside > #usernameElement, .sidebyside > #sponsorTimesContributionsContainer {
+ display: flex;
+ align-items: center;
}
-.smallButton:focus.popupElement {
- outline: none;
- background-color:#fa9806;
+
+#usernameValue{
+ overflow: hidden;
+ text-overflow: ellipsis;
+ max-width: 130px;
+}
+
+#setUsername {
+ display:flex;
+}
+
+#usernameInput {
+ background: none;
+ padding: 0;
+ border: white 1px solid;
+ color: var(--sb-main-fg-color);
+ width: calc(100% - 24px);
+
+ text-overflow: ellipsis;
+}
+
+#setUsername.SBExpanded {
+ width: 200%;
+}
+
+/* footer */
+
+#sbFooter > a {
+ color: var(--sb-main-fg-color);
+ text-decoration: none;
+}
+
+#showNoticeAgain {
+ margin-top: 30px;
+
+ color: var(--sb-main-fg-color);
+ background: none;
+ border: 1px solid white;
+ cursor: pointer;
+ padding: 5px;
+
+ border-radius: 5px;
}
-.smallButton:active.popupElement {
- position:relative;
- top:1px;
-}
\ No newline at end of file
diff --git a/public/popup.html b/public/popup.html
index d977724e..80755e8b 100644
--- a/public/popup.html
+++ b/public/popup.html
@@ -1,203 +1,146 @@
-
-
-
-
-
+
+ __MSG_openPopup__
+
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
+ __MSG_forceChannelCheckPopup__
+
+
+
+
+
__MSG_popupHint__
+
+
+
+
+
__MSG_submissionEditHint__
+
+
+
+
+
+
+
+
+
+
__MSG_Username__:
+
+
+
+
+
+
+
+
+
+
+
+
+
-
-
-
+
+
+
\ No newline at end of file
diff --git a/src/background.ts b/src/background.ts
index ec398d59..03afea42 100644
--- a/src/background.ts
+++ b/src/background.ts
@@ -31,6 +31,9 @@ chrome.runtime.onMessage.addListener(function (request, sender, callback) {
case "openConfig":
chrome.runtime.openOptionsPage();
return;
+ case "openHelp":
+ window.open(chrome.runtime.getURL('help/index_en.html'));
+ return;
case "sendRequest":
sendRequestToCustomServer(request.type, request.url, request.data).then(async (response) => {
callback({
diff --git a/src/content.ts b/src/content.ts
index daea9e5e..03a596ef 100644
--- a/src/content.ts
+++ b/src/content.ts
@@ -1125,7 +1125,7 @@ async function createButtons(): Promise
{
let createdButton = false;
// Add button if does not already exist in html
- createdButton = createButton("startSponsor", "sponsorStart", startSponsorClicked, "PlayerStartIconSponsorBlocker256px.png") || createdButton;
+ createdButton = createButton("startSponsor", "sponsorStart", startSponsorClicked, "PlayerStartIconSponsorBlocker256px.png") || createdButton;
createdButton = createButton("info", "openPopup", openInfoMenu, "PlayerInfoIconSponsorBlocker256px.png") || createdButton;
createdButton = createButton("delete", "clearTimes", clearSponsorTimes, "PlayerDeleteIconSponsorBlocker256px.png") || createdButton;
createdButton = createButton("submit", "SubmitTimes", submitSponsorTimes, "PlayerUploadIconSponsorBlocker256px.png") || createdButton;
@@ -1275,9 +1275,17 @@ function openInfoMenu() {
sendRequestToCustomServer('GET', chrome.extension.getURL("popup.html"), function(xmlhttp) {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
- var popup = document.createElement("div");
+ let popup = document.createElement("div");
popup.id = "sponsorBlockPopupContainer";
- popup.innerHTML = xmlhttp.responseText
+
+ let htmlData = xmlhttp.responseText;
+ // Hack to replace head data (title, favicon)
+ htmlData = htmlData.replace(/[\S\s]*<\/head>/gi, "");
+ // Hack to replace body tag with div
+ htmlData = htmlData.replace(/ popup.querySelector("#sponsorBlockPopupLogo");
+ let settings = popup.querySelector("#sbPopupIconSettings");
+ let edit = popup.querySelector("#sbPopupIconEdit");
+ let check = popup.querySelector("#sbPopupIconCheck");
logo.src = chrome.extension.getURL("icons/LogoSponsorBlocker256px.png");
-
- //remove the style sheet and font that are not necessary
- popup.querySelector("#sponsorBlockPopupFont").remove();
- popup.querySelector("#sponsorBlockStyleSheet").remove();
+ settings.src = chrome.extension.getURL("icons/settings.svg");
+ edit.src = chrome.extension.getURL("icons/pencil.svg");
+ check.src = chrome.extension.getURL("icons/check.svg");
+ check.src = chrome.extension.getURL("icons/thumb.svg");
parentNode.insertBefore(popup, parentNode.firstChild);
diff --git a/src/popup.ts b/src/popup.ts
index 1bb5d195..74b8e4f9 100644
--- a/src/popup.ts
+++ b/src/popup.ts
@@ -33,7 +33,7 @@ class MessageHandler {
} else {
chrome.tabs.query(config, callback);
}
-
+
}
}
@@ -47,121 +47,109 @@ async function runThePopup(messageListener?: MessageListener) {
var PageElements: any = {};
- ["sponsorStart",
- // Top toggles
- "whitelistChannel",
- "unwhitelistChannel",
- "whitelistForceCheck",
- "disableSkipping",
- "enableSkipping",
- // Options
- "showNoticeAgain",
- "optionsButton",
- // More controls
- "submitTimes",
- "reportAnIssue",
- // sponsorTimesContributions
- "sponsorTimesContributionsContainer",
- "sponsorTimesContributionsDisplay",
- "sponsorTimesContributionsDisplayEndWord",
- // sponsorTimesViewsDisplay
- "sponsorTimesViewsContainer",
- "sponsorTimesViewsDisplay",
- "sponsorTimesViewsDisplayEndWord",
- // sponsorTimesOthersTimeSaved
- "sponsorTimesOthersTimeSavedContainer",
- "sponsorTimesOthersTimeSavedDisplay",
- "sponsorTimesOthersTimeSavedEndWord",
- // sponsorTimesSkipsDone
- "sponsorTimesSkipsDoneContainer",
- "sponsorTimesSkipsDoneDisplay",
- "sponsorTimesSkipsDoneEndWord",
- // sponsorTimeSaved
- "sponsorTimeSavedContainer",
- "sponsorTimeSavedDisplay",
- "sponsorTimeSavedEndWord",
- // discordButtons
- "discordButtonContainer",
- "hideDiscordButton",
- // Username
- "setUsernameContainer",
- "setUsernameButton",
- "setUsernameStatusContainer",
- "setUsernameStatus",
- "setUsername",
- "usernameInput",
- "submitUsername",
- // More
- "submissionSection",
- "mainControls",
- "loadingIndicator",
- "videoFound",
- "sponsorMessageTimes",
- "downloadedSponsorMessageTimes",
+ [
+ "sponsorblockPopup",
+ "sponsorStart",
+ // Top toggles
+ "whitelistChannel",
+ "unwhitelistChannel",
+ "whitelistToggle",
+ "whitelistForceCheck",
+ "disableSkipping",
+ "enableSkipping",
+ "toggleSwitch",
+ // Options
+ "showNoticeAgain",
+ "optionsButton",
+ "helpButton",
+ // More controls
+ "submitTimes",
+ "sponsorTimesContributionsContainer",
+ "sponsorTimesContributionsDisplay",
+ "sponsorTimesViewsContainer",
+ "sponsorTimesViewsDisplay",
+ "sponsorTimesViewsDisplayEndWord",
+ "sponsorTimesOthersTimeSavedDisplay",
+ "sponsorTimesOthersTimeSavedEndWord",
+ "sponsorTimesSkipsDoneContainer",
+ "sponsorTimesSkipsDoneDisplay",
+ "sponsorTimesSkipsDoneEndWord",
+ "sponsorTimeSavedDisplay",
+ "sponsorTimeSavedEndWord",
+ // Username
+ "setUsernameContainer",
+ "setUsernameButton",
+ "setUsernameStatusContainer",
+ "setUsernameStatus",
+ "setUsername",
+ "usernameInput",
+ "usernameValue",
+ "submitUsername",
+ // More
+ "submissionSection",
+ "mainControls",
+ "loadingIndicator",
+ "videoFound",
+ "sponsorMessageTimes",
+ //"downloadedSponsorMessageTimes",
+ "whitelistButton",
].forEach(id => PageElements[id] = document.getElementById(id));
//setup click listeners
PageElements.sponsorStart.addEventListener("click", sendSponsorStartMessage);
- PageElements.whitelistChannel.addEventListener("click", whitelistChannel);
+ PageElements.whitelistToggle.addEventListener("change", function() {
+ if (this.checked) {
+ whitelistChannel();
+ } else {
+ unwhitelistChannel();
+ }
+ });
PageElements.whitelistForceCheck.addEventListener("click", openOptions);
- PageElements.unwhitelistChannel.addEventListener("click", unwhitelistChannel);
- PageElements.disableSkipping.addEventListener("click", () => toggleSkipping(true));
- PageElements.enableSkipping.addEventListener("click", () => toggleSkipping(false));
+ PageElements.toggleSwitch.addEventListener("change", function() {
+ toggleSkipping(!this.checked);
+ });
PageElements.submitTimes.addEventListener("click", submitTimes);
PageElements.showNoticeAgain.addEventListener("click", showNoticeAgain);
PageElements.setUsernameButton.addEventListener("click", setUsernameButton);
+ PageElements.usernameValue.addEventListener("click", setUsernameButton);
PageElements.submitUsername.addEventListener("click", submitUsername);
PageElements.optionsButton.addEventListener("click", openOptions);
- PageElements.reportAnIssue.addEventListener("click", reportAnIssue);
- PageElements.hideDiscordButton.addEventListener("click", hideDiscordButton);
-
+ PageElements.helpButton.addEventListener("click", openHelp);
+
//if true, the button now selects the end time
let startTimeChosen = false;
-
+
//the start and end time pairs (2d)
let sponsorTimes: SponsorTime[] = [];
-
+
//current video ID of this tab
let currentVideoID = null;
-
- //see if discord link can be shown
- let hideDiscordLink = Config.config.hideDiscordLink;
- if (hideDiscordLink == undefined || !hideDiscordLink) {
- let hideDiscordLaunches = Config.config.hideDiscordLaunches;
- //only if less than 10 launches
- if (hideDiscordLaunches == undefined || hideDiscordLaunches < 10) {
- PageElements.discordButtonContainer.style.display = null;
-
- if (hideDiscordLaunches == undefined) {
- hideDiscordLaunches = 1;
- }
- Config.config.hideDiscordLaunches = hideDiscordLaunches + 1;
- }
- }
//show proper disable skipping button
let disableSkipping = Config.config.disableSkipping;
if (disableSkipping != undefined && 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
+ //if the don't show notice again variable is true, an option to
// disable should be available
let dontShowNotice = Config.config.dontShowNotice;
if (dontShowNotice != undefined && dontShowNotice) {
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) {
- if (Config.config.sponsorTimesContributed !== 1) {
- PageElements.sponsorTimesContributionsDisplayEndWord.innerText = chrome.i18n.getMessage("Segments");
- } else {
- PageElements.sponsorTimesContributionsDisplayEndWord.innerText = chrome.i18n.getMessage("Segment");
- }
- PageElements.sponsorTimesContributionsDisplay.innerText = Config.config.sponsorTimesContributed;
- PageElements.sponsorTimesContributionsContainer.style.display = "unset";
+ PageElements.sponsorTimesContributionsDisplay.innerText = Config.config.sponsorTimesContributed.toLocaleString();
+ PageElements.sponsorTimesContributionsContainer.classList.remove("hidden");
//get the userID
let userID = Config.config.userID;
@@ -178,7 +166,7 @@ async function runThePopup(messageListener?: MessageListener) {
PageElements.sponsorTimesViewsDisplayEndWord.innerText = chrome.i18n.getMessage("Segment");
}
- PageElements.sponsorTimesViewsDisplay.innerText = viewCount;
+ PageElements.sponsorTimesViewsDisplay.innerText = viewCount.toLocaleString();
PageElements.sponsorTimesViewsContainer.style.display = "unset";
}
}
@@ -196,7 +184,6 @@ async function runThePopup(messageListener?: MessageListener) {
}
PageElements.sponsorTimesOthersTimeSavedDisplay.innerText = getFormattedHours(minutesSaved);
- PageElements.sponsorTimesOthersTimeSavedContainer.style.display = "unset";
}
}
});
@@ -211,7 +198,7 @@ async function runThePopup(messageListener?: MessageListener) {
PageElements.sponsorTimesSkipsDoneEndWord.innerText = chrome.i18n.getMessage("Segment");
}
- PageElements.sponsorTimesSkipsDoneDisplay.innerText = Config.config.skipCount;
+ PageElements.sponsorTimesSkipsDoneDisplay.innerText = Config.config.skipCount.toLocaleString();
PageElements.sponsorTimesSkipsDoneContainer.style.display = "unset";
}
@@ -224,14 +211,16 @@ async function runThePopup(messageListener?: MessageListener) {
}
PageElements.sponsorTimeSavedDisplay.innerText = getFormattedHours(Config.config.minutesSaved);
- PageElements.sponsorTimeSavedContainer.style.display = "unset";
}
-
+
+ // Must be delayed so it only happens once loaded
+ setTimeout(() => PageElements.sponsorblockPopup.classList.remove("preload"), 250);
+
messageHandler.query({
active: true,
currentWindow: true
}, onTabs);
-
+
function onTabs(tabs) {
messageHandler.sendMessage(tabs[0].id, {message: 'getVideoID'}, function(result) {
if (result != undefined && result.videoID) {
@@ -243,15 +232,15 @@ async function runThePopup(messageListener?: MessageListener) {
}
});
}
-
+
function loadTabData(tabs) {
if (!currentVideoID) {
//this isn't a YouTube video then
displayNoVideo();
return;
}
-
- //load video times for this video
+
+ //load video times for this video
let sponsorTimesStorage = Config.config.segmentTimes.get(currentVideoID);
if (sponsorTimesStorage != undefined && sponsorTimesStorage.length > 0) {
if (sponsorTimesStorage[sponsorTimesStorage.length - 1] != undefined && sponsorTimesStorage[sponsorTimesStorage.length - 1].segment.length < 2) {
@@ -266,7 +255,7 @@ async function runThePopup(messageListener?: MessageListener) {
showSubmitTimesIfNecessary();
}
-
+
//check if this video's sponsors are known
messageHandler.sendMessage(
tabs[0].id,
@@ -274,18 +263,19 @@ async function runThePopup(messageListener?: MessageListener) {
infoFound
);
}
-
+
function infoFound(request: {found: boolean, sponsorTimes: SponsorTime[]}) {
if(chrome.runtime.lastError) {
//This page doesn't have the injected content script, or at least not yet
displayNoVideo();
return;
}
-
+
//if request is undefined, then the page currently being browsed is not YouTube
if (request != undefined) {
//remove loading text
- PageElements.mainControls.style.display = "unset"
+ PageElements.mainControls.style.display = "flex";
+ PageElements.whitelistButton.classList.remove("hidden");
PageElements.loadingIndicator.style.display = "none";
if (request.found) {
@@ -309,15 +299,14 @@ async function runThePopup(messageListener?: MessageListener) {
if (response.value) {
PageElements.whitelistChannel.style.display = "none";
PageElements.unwhitelistChannel.style.display = "unset";
-
- PageElements.downloadedSponsorMessageTimes.innerText = chrome.i18n.getMessage("channelWhitelisted");
- PageElements.downloadedSponsorMessageTimes.style.fontWeight = "bold";
+ PageElements.whitelistToggle.checked = true;
+ document.querySelectorAll('.SBWhitelistIcon')[0].classList.add("rotated");
}
});
}
);
}
-
+
function sendSponsorStartMessage() {
//the content script will get the message if a YouTube page is open
messageHandler.query({
@@ -331,10 +320,10 @@ async function runThePopup(messageListener?: MessageListener) {
);
});
}
-
+
function startSponsorCallback(response) {
let sponsorTimesIndex = sponsorTimes.length - (startTimeChosen ? 1 : 0);
-
+
if (sponsorTimes[sponsorTimesIndex] == undefined) {
sponsorTimes[sponsorTimesIndex] = {
segment: [],
@@ -342,12 +331,12 @@ async function runThePopup(messageListener?: MessageListener) {
UUID: null
};
}
-
+
sponsorTimes[sponsorTimesIndex].segment[startTimeChosen ? 1 : 0] = response.time;
let localStartTimeChosen = startTimeChosen;
Config.config.segmentTimes.set(currentVideoID, sponsorTimes);
-
+
//send a message to the client script
if (localStartTimeChosen) {
messageHandler.query({
@@ -360,391 +349,102 @@ async function runThePopup(messageListener?: MessageListener) {
);
});
}
-
+
updateStartTimeChosen();
-
+
//show submission section
PageElements.submissionSection.style.display = "unset";
-
+
showSubmitTimesIfNecessary();
}
-
+
//display the video times from the array at the top, in a different section
function displayDownloadedSponsorTimes(request: {found: boolean, sponsorTimes: SponsorTime[]}) {
if (request.sponsorTimes != undefined) {
- //set it to the message
- if (PageElements.downloadedSponsorMessageTimes.innerText != chrome.i18n.getMessage("channelWhitelisted")) {
- PageElements.downloadedSponsorMessageTimes.innerText = getSponsorTimesMessage(request.sponsorTimes);
- }
+
+ // Sort list by start time
+ let segmentTimes = request.sponsorTimes
+ .sort((a, b) => a.segment[1] - b.segment[1])
+ .sort((a, b) => a.segment[0] - b.segment[0]);
//add them as buttons to the issue reporting container
let container = document.getElementById("issueReporterTimeButtons");
- for (let i = 0; i < request.sponsorTimes.length; i++) {
+ for (let i = 0; i < segmentTimes.length; i++) {
+ let UUID = segmentTimes[i].UUID;
+
let sponsorTimeButton = document.createElement("button");
- sponsorTimeButton.className = "warningButton popupElement";
+ sponsorTimeButton.className = "segmentTimeButton popupElement";
+
+ let prefix = chrome.i18n.getMessage("category_" + segmentTimes[i].category) + ": ";
let extraInfo = "";
- if (request.sponsorTimes[i].hidden === SponsorHideType.Downvoted) {
+ if (segmentTimes[i].hidden === SponsorHideType.Downvoted) {
//this one is downvoted
extraInfo = " (" + chrome.i18n.getMessage("hiddenDueToDownvote") + ")";
- } else if (request.sponsorTimes[i].hidden === SponsorHideType.MinimumDuration) {
+ } else if (segmentTimes[i].hidden === SponsorHideType.MinimumDuration) {
//this one is too short
extraInfo = " (" + chrome.i18n.getMessage("hiddenDueToDuration") + ")";
}
- sponsorTimeButton.innerText = getFormattedTime(request.sponsorTimes[i].segment[0]) + " " + chrome.i18n.getMessage("to") + " " + getFormattedTime(request.sponsorTimes[i].segment[1]) + extraInfo;
-
+ sponsorTimeButton.innerText = prefix + getFormattedTime(segmentTimes[i].segment[0]) + " " + chrome.i18n.getMessage("to") + " " + getFormattedTime(segmentTimes[i].segment[1]) + extraInfo;
+
+ let categoryColorCircle = document.createElement("span");
+ categoryColorCircle.id = "sponsorTimesCategoryColorCircle" + UUID;
+ categoryColorCircle.style.backgroundColor = Config.config.barTypes[segmentTimes[i].category].color;
+ categoryColorCircle.classList.add("dot");
+ categoryColorCircle.classList.add("sponsorTimesCategoryColorCircle");
+
let votingButtons = document.createElement("div");
-
- let UUID = request.sponsorTimes[i].UUID;
-
+ votingButtons.classList.add("votingButtons");
+
//thumbs up and down buttons
let voteButtonsContainer = document.createElement("div");
voteButtonsContainer.id = "sponsorTimesVoteButtonsContainer" + UUID;
voteButtonsContainer.setAttribute("align", "center");
voteButtonsContainer.style.display = "none"
-
+
let upvoteButton = document.createElement("img");
upvoteButton.id = "sponsorTimesUpvoteButtonsContainer" + UUID;
- upvoteButton.className = "voteButton popupElement";
- upvoteButton.src = chrome.extension.getURL("icons/upvote.png");
+ upvoteButton.className = "voteButton";
+ upvoteButton.src = chrome.extension.getURL("icons/thumbs_up.svg");
upvoteButton.addEventListener("click", () => vote(1, UUID));
-
+
let downvoteButton = document.createElement("img");
downvoteButton.id = "sponsorTimesDownvoteButtonsContainer" + UUID;
- downvoteButton.className = "voteButton popupElement";
- downvoteButton.src = chrome.extension.getURL("icons/downvote.png");
+ downvoteButton.className = "voteButton";
+ downvoteButton.src = chrome.extension.getURL("icons/thumbs_down.svg");
downvoteButton.addEventListener("click", () => vote(0, UUID));
-
+
//add thumbs up and down buttons to the container
- voteButtonsContainer.appendChild(document.createElement("br"));
- voteButtonsContainer.appendChild(document.createElement("br"));
voteButtonsContainer.appendChild(upvoteButton);
voteButtonsContainer.appendChild(downvoteButton);
-
+
//add click listener to open up vote panel
sponsorTimeButton.addEventListener("click", function() {
- voteButtonsContainer.style.display = "unset";
+ voteButtonsContainer.style.removeProperty("display");
});
-
- container.appendChild(sponsorTimeButton);
- container.appendChild(voteButtonsContainer);
-
- //if it is not the last iteration
- if (i != request.sponsorTimes.length - 1) {
- container.appendChild(document.createElement("br"));
- container.appendChild(document.createElement("br"));
- }
+
+ // Will contain request status
+ let voteStatusContainer = document.createElement("div");
+ voteStatusContainer.id = "sponsorTimesVoteStatusContainer" + UUID;
+ voteStatusContainer.classList.add("sponsorTimesVoteStatusContainer");
+ voteStatusContainer.style.display = "none";
+
+ let thanksForVotingText = document.createElement("div");
+ thanksForVotingText.id = "sponsorTimesThanksForVotingText" + UUID;
+ thanksForVotingText.classList.add("sponsorTimesThanksForVotingText");
+ voteStatusContainer.appendChild(thanksForVotingText);
+
+ votingButtons.append(categoryColorCircle);
+ votingButtons.append(sponsorTimeButton);
+ votingButtons.append(voteButtonsContainer);
+ votingButtons.append(voteStatusContainer);
+
+ container.appendChild(votingButtons);
}
}
}
-
- //get the message that visually displays the video times
- function getSponsorTimesMessage(sponsorTimes: SponsorTime[]) {
- let sponsorTimesMessage = "";
-
- for (let i = 0; i < sponsorTimes.length; i++) {
- for (let s = 0; s < sponsorTimes[i].segment.length; s++) {
- let timeMessage = getFormattedTime(sponsorTimes[i].segment[s]);
- //if this is an end time
- if (s == 1) {
- timeMessage = " " + chrome.i18n.getMessage("to") + " " + timeMessage;
- } else if (i > 0) {
- //add commas if necessary
- timeMessage = ", " + timeMessage;
- }
- if (sponsorTimes[i].hidden === SponsorHideType.Downvoted) {
- //this one is downvoted
- timeMessage += " (" + chrome.i18n.getMessage("hiddenDueToDownvote") + ")";
- } else if (sponsorTimes[i].hidden === SponsorHideType.MinimumDuration) {
- //this one is too short
- timeMessage += " (" + chrome.i18n.getMessage("hiddenDueToDuration") + ")";
- }
-
- sponsorTimesMessage += timeMessage;
- }
- }
-
- return sponsorTimesMessage;
- }
-
- //get the message that visually displays the video times
- //this version is a div that contains each with delete buttons
- function getSponsorTimesMessageDiv(sponsorTimes) {
- // let sponsorTimesMessage = "";
- let sponsorTimesContainer = document.createElement("div");
- sponsorTimesContainer.id = "sponsorTimesContainer";
-
- for (let i = 0; i < sponsorTimes.length; i++) {
- let currentSponsorTimeContainer = document.createElement("div");
- currentSponsorTimeContainer.id = "sponsorTimeContainer" + i;
- currentSponsorTimeContainer.className = "sponsorTime popupElement";
- let currentSponsorTimeMessage = "";
-
- let deleteButton = document.createElement("span");
- deleteButton.id = "sponsorTimeDeleteButton" + i;
- deleteButton.innerText = "Delete";
- deleteButton.className = "mediumLink popupElement";
- let index = i;
- deleteButton.addEventListener("click", () => deleteSponsorTime(index));
-
- let previewButton = document.createElement("span");
- previewButton.id = "sponsorTimePreviewButton" + i;
- previewButton.innerText = "Preview";
- previewButton.className = "mediumLink popupElement";
- previewButton.addEventListener("click", () => previewSponsorTime(index));
-
- let editButton = document.createElement("span");
- editButton.id = "sponsorTimeEditButton" + i;
- editButton.innerText = "Edit";
- editButton.className = "mediumLink popupElement";
- editButton.addEventListener("click", () => editSponsorTime(index));
-
- for (let s = 0; s < sponsorTimes[i].length; s++) {
- let timeMessage = getFormattedTime(sponsorTimes[i][s]);
- //if this is an end time
- if (s == 1) {
- timeMessage = " " + chrome.i18n.getMessage("to") + " " + timeMessage;
- } else if (i > 0) {
- //add commas if necessary
- timeMessage = timeMessage;
- }
-
- currentSponsorTimeMessage += timeMessage;
- }
-
- currentSponsorTimeContainer.innerText = currentSponsorTimeMessage;
-
- sponsorTimesContainer.appendChild(currentSponsorTimeContainer);
- sponsorTimesContainer.appendChild(deleteButton);
-
- //only if it is a complete sponsor time
- if (sponsorTimes[i].length > 1) {
- sponsorTimesContainer.appendChild(previewButton);
- sponsorTimesContainer.appendChild(editButton);
-
- currentSponsorTimeContainer.addEventListener("click", () => editSponsorTime(index));
- }
- }
-
- return sponsorTimesContainer;
- }
-
- function previewSponsorTime(index) {
- let skipTime = sponsorTimes[index].segment[0];
-
- if (document.getElementById("startTimeMinutes" + index) != null) {
- //edit is currently open, use that time
-
- skipTime = getSponsorTimeEditTimes("startTime", index);
-
- //save the edit
- saveSponsorTimeEdit(index, false);
- }
-
- messageHandler.query({
- active: true,
- currentWindow: true
- }, tabs => {
- messageHandler.sendMessage(
- tabs[0].id, {
- message: "skipToTime",
- time: skipTime - 2
- }
- );
- });
- }
-
- function editSponsorTime(index) {
- if (document.getElementById("startTimeMinutes" + index) != null) {
- //already open
- return;
- }
-
- //hide submit button
- document.getElementById("submitTimesContainer").style.display = "none";
-
- let sponsorTimeContainer = document.getElementById("sponsorTimeContainer" + index);
-
- //the button to set the current time
- let startTimeNowButton = document.createElement("span");
- startTimeNowButton.id = "startTimeNowButton" + index;
- startTimeNowButton.innerText = "(Now)";
- startTimeNowButton.className = "tinyLink popupElement";
- startTimeNowButton.addEventListener("click", () => setEditTimeToCurrentTime("startTime", index));
-
- //get sponsor time minutes and seconds boxes
- let startTimeMinutes = document.createElement("input");
- startTimeMinutes.id = "startTimeMinutes" + index;
- startTimeMinutes.className = "sponsorTime popupElement";
- startTimeMinutes.type = "text";
- startTimeMinutes.value = String(getTimeInMinutes(sponsorTimes[index].segment[0]));
- startTimeMinutes.style.width = "45px";
-
- let startTimeSeconds = document.createElement("input");
- startTimeSeconds.id = "startTimeSeconds" + index;
- startTimeSeconds.className = "sponsorTime popupElement";
- startTimeSeconds.type = "text";
- startTimeSeconds.value = getTimeInFormattedSeconds(sponsorTimes[index].segment[0]);
- startTimeSeconds.style.width = "60px";
-
- let endTimeMinutes = document.createElement("input");
- endTimeMinutes.id = "endTimeMinutes" + index;
- endTimeMinutes.className = "sponsorTime popupElement";
- endTimeMinutes.type = "text";
- endTimeMinutes.value = String(getTimeInMinutes(sponsorTimes[index].segment[1]));
- endTimeMinutes.style.width = "45px";
-
- let endTimeSeconds = document.createElement("input");
- endTimeSeconds.id = "endTimeSeconds" + index;
- endTimeSeconds.className = "sponsorTime popupElement";
- endTimeSeconds.type = "text";
- endTimeSeconds.value = getTimeInFormattedSeconds(sponsorTimes[index].segment[1]);
- endTimeSeconds.style.width = "60px";
-
- //the button to set the current time
- let endTimeNowButton = document.createElement("span");
- endTimeNowButton.id = "endTimeNowButton" + index;
- endTimeNowButton.innerText = "(Now)";
- endTimeNowButton.className = "tinyLink popupElement";
- endTimeNowButton.addEventListener("click", () => setEditTimeToCurrentTime("endTime", index));
-
- let colonText = document.createElement("span");
- colonText.innerText = ":";
-
- let toText = document.createElement("span");
- toText.innerText = " " + chrome.i18n.getMessage("to") + " ";
-
- //remove all children to replace
- while (sponsorTimeContainer.firstChild) {
- sponsorTimeContainer.removeChild(sponsorTimeContainer.firstChild);
- }
-
- sponsorTimeContainer.appendChild(startTimeNowButton);
- sponsorTimeContainer.appendChild(startTimeMinutes);
- sponsorTimeContainer.appendChild(colonText);
- sponsorTimeContainer.appendChild(startTimeSeconds);
- sponsorTimeContainer.appendChild(toText);
- sponsorTimeContainer.appendChild(endTimeMinutes);
- sponsorTimeContainer.appendChild(colonText);
- sponsorTimeContainer.appendChild(endTimeSeconds);
- sponsorTimeContainer.appendChild(endTimeNowButton);
-
- //add save button and remove edit button
- let saveButton = document.createElement("span");
- saveButton.id = "sponsorTimeSaveButton" + index;
- saveButton.innerText = "Save";
- saveButton.className = "mediumLink popupElement";
- saveButton.addEventListener("click", () => saveSponsorTimeEdit(index));
-
- let editButton = document.getElementById("sponsorTimeEditButton" + index);
- let sponsorTimesContainer = document.getElementById("sponsorTimesContainer");
-
- sponsorTimesContainer.replaceChild(saveButton, editButton);
- }
-
- function setEditTimeToCurrentTime(idStartName, index) {
- messageHandler.query({
- active: true,
- currentWindow: true
- }, tabs => {
- messageHandler.sendMessage(
- tabs[0].id,
- {message: "getCurrentTime"},
- function (response) {
- let minutes = document.getElementById(idStartName + "Minutes" + index);
- let seconds = document.getElementById(idStartName + "Seconds" + index);
-
- minutes.value = String(getTimeInMinutes(response.currentTime));
- seconds.value = getTimeInFormattedSeconds(response.currentTime);
- });
- });
- }
-
- //id start name is whether it is the startTime or endTime
- //gives back the time in seconds
- function getSponsorTimeEditTimes(idStartName, index): number {
- let minutes = document.getElementById(idStartName + "Minutes" + index);
- let seconds = document.getElementById(idStartName + "Seconds" + index);
-
- return parseInt(minutes.value) * 60 + parseFloat(seconds.value);
- }
-
- function saveSponsorTimeEdit(index, closeEditMode = true) {
- sponsorTimes[index].segment[0] = getSponsorTimeEditTimes("startTime", index);
- sponsorTimes[index].segment[1] = getSponsorTimeEditTimes("endTime", index);
-
- //save this
- Config.config.segmentTimes.set(currentVideoID, sponsorTimes);
-
- messageHandler.query({
- active: true,
- currentWindow: true
- }, tabs => {
- messageHandler.sendMessage(
- tabs[0].id,
- {message: "sponsorDataChanged"}
- );
- });
-
- if (closeEditMode) {
- showSubmitTimesIfNecessary();
- }
- }
-
- //deletes the sponsor time submitted at an index
- function deleteSponsorTime(index) {
- //if it is not a complete sponsor time
- if (sponsorTimes[index].segment.length < 2) {
- messageHandler.query({
- active: true,
- currentWindow: true
- }, function(tabs) {
- messageHandler.sendMessage(tabs[0].id, {
- message: "changeStartSponsorButton",
- showStartSponsor: true,
- uploadButtonVisible: false
- });
- });
-
- resetStartTimeChosen();
- }
-
- sponsorTimes.splice(index, 1);
-
- //save this
- Config.config.segmentTimes.set(currentVideoID, sponsorTimes);
-
- //if they are all removed
- if (sponsorTimes.length == 0) {
- //update chrome tab
- messageHandler.query({
- active: true,
- currentWindow: true
- }, function(tabs) {
- messageHandler.sendMessage(tabs[0].id, {
- message: "changeStartSponsorButton",
- showStartSponsor: true,
- uploadButtonVisible: false
- });
- });
-
- //hide submission section
- document.getElementById("submissionSection").style.display = "none";
- }
-
- messageHandler.query({
- active: true,
- currentWindow: true
- }, tabs => {
- messageHandler.sendMessage(
- tabs[0].id,
- {message: "sponsorDataChanged"}
- );
- });
- }
-
function submitTimes() {
if (sponsorTimes.length > 0) {
messageHandler.query({
@@ -786,7 +486,7 @@ async function runThePopup(messageListener?: MessageListener) {
//check if an end time has been specified for the latest sponsor time
if (sponsorTimes.length > 0 && sponsorTimes[sponsorTimes.length - 1].segment.length > 1) {
//show submit times button
- document.getElementById("submitTimesContainer").style.display = "unset";
+ document.getElementById("submitTimesContainer").style.display = "flex";
} else {
//hide submit times button
document.getElementById("submitTimesContainer").style.display = "none";
@@ -798,29 +498,24 @@ async function runThePopup(messageListener?: MessageListener) {
chrome.runtime.sendMessage({"message": "openConfig"});
}
+ function openHelp() {
+ chrome.runtime.sendMessage({"message": "openHelp"});
+ }
+
//make the options username setting option visible
function setUsernameButton() {
- //get username from the server
- utils.sendRequestToServer("GET", "/api/getUsername?userID=" + Config.config.userID, function (response) {
- if (response.status == 200) {
- PageElements.usernameInput.value = JSON.parse(response.responseText).userName;
+ PageElements.usernameInput.value = PageElements.usernameValue.innerText;
- PageElements.submitUsername.style.display = "unset";
- PageElements.usernameInput.style.display = "unset";
+ PageElements.submitUsername.style.display = "unset";
+ PageElements.usernameInput.style.display = "unset";
- PageElements.setUsernameContainer.style.display = "none";
- PageElements.setUsername.style.display = "unset";
- PageElements
- PageElements.setUsernameStatusContainer.style.display = "none";
- } else {
- PageElements.setUsername.style.display = "unset";
- PageElements.submitUsername.style.display = "none";
- PageElements.usernameInput.style.display = "none";
+ PageElements.setUsernameContainer.style.display = "none";
+ PageElements.setUsername.style.display = "flex";
+ PageElements.setUsername.classList.add("SBExpanded");
+
+ PageElements.setUsernameStatusContainer.style.display = "none";
- PageElements.setUsernameStatusContainer.style.display = "unset";
- PageElements.setUsernameStatus.innerText = utils.getErrorMessage(response.status);
- }
- });
+ PageElements.sponsorTimesContributionsContainer.classList.add("hidden");
}
//submit the new username
@@ -829,15 +524,20 @@ async function runThePopup(messageListener?: MessageListener) {
PageElements.setUsernameStatusContainer.style.display = "unset";
PageElements.setUsernameStatus.innerText = chrome.i18n.getMessage("Loading");
- //get the userID
utils.sendRequestToServer("POST", "/api/setUsername?userID=" + Config.config.userID + "&username=" + PageElements.usernameInput.value, function (response) {
if (response.status == 200) {
//submitted
PageElements.submitUsername.style.display = "none";
PageElements.usernameInput.style.display = "none";
- PageElements.setUsernameStatus.innerText = chrome.i18n.getMessage("success");
- } else {
+ PageElements.setUsernameContainer.style.removeProperty("display");
+ PageElements.setUsername.classList.remove("SBExpanded");
+ PageElements.usernameValue.innerText = PageElements.usernameInput.value;
+
+ PageElements.setUsernameStatusContainer.style.display = "none";
+
+ PageElements.sponsorTimesContributionsContainer.classList.remove("hidden");
+ } else {
PageElements.setUsernameStatus.innerText = utils.getErrorMessage(response.status);
}
});
@@ -852,24 +552,15 @@ async function runThePopup(messageListener?: MessageListener) {
document.getElementById("loadingIndicator").innerText = chrome.i18n.getMessage("noVideoID");
}
- function reportAnIssue() {
- document.getElementById("issueReporterContainer").style.display = "unset";
- PageElements.reportAnIssue.style.display = "none";
- }
-
function addVoteMessage(message, UUID) {
- let container = document.getElementById("sponsorTimesVoteButtonsContainer" + UUID);
- //remove all children
- while (container.firstChild) {
- container.removeChild(container.firstChild);
- }
-
- let thanksForVotingText = document.createElement("h2");
+ let voteButtonsContainer = document.getElementById("sponsorTimesVoteButtonsContainer" + UUID);
+ voteButtonsContainer.style.display = "none";
+
+ let voteStatusContainer = document.getElementById("sponsorTimesVoteStatusContainer" + UUID);
+ voteStatusContainer.style.removeProperty("display");
+
+ let thanksForVotingText = document.getElementById("sponsorTimesThanksForVotingText" + UUID);
thanksForVotingText.innerText = message;
- //there are already breaks there
- thanksForVotingText.style.marginBottom = "0px";
-
- container.appendChild(thanksForVotingText);
}
function vote(type, UUID) {
@@ -894,11 +585,6 @@ async function runThePopup(messageListener?: MessageListener) {
});
}
- function hideDiscordButton() {
- Config.config.hideDiscordLink = true;
- PageElements.discordButtonContainer.style.display = "none";
- }
-
//converts time in seconds to minutes:seconds
function getFormattedTime(seconds) {
let minutes = Math.floor(seconds / 60);
@@ -942,10 +628,9 @@ async function runThePopup(messageListener?: MessageListener) {
//change button
PageElements.whitelistChannel.style.display = "none";
PageElements.unwhitelistChannel.style.display = "unset";
- if (!Config.config.forceChannelCheck) PageElements.whitelistForceCheck.style.display = "unset";
+ document.querySelectorAll('.SBWhitelistIcon')[0].classList.add("rotated");
- PageElements.downloadedSponsorMessageTimes.innerText = chrome.i18n.getMessage("channelWhitelisted");
- PageElements.downloadedSponsorMessageTimes.style.fontWeight = "bold";
+ if (!Config.config.forceChannelCheck) PageElements.whitelistForceCheck.classList.remove("hidden");
//save this
Config.config.whitelistedChannels = whitelistedChannels;
@@ -990,9 +675,7 @@ async function runThePopup(messageListener?: MessageListener) {
//change button
PageElements.whitelistChannel.style.display = "unset";
PageElements.unwhitelistChannel.style.display = "none";
-
- PageElements.downloadedSponsorMessageTimes.innerText = "";
- PageElements.downloadedSponsorMessageTimes.style.fontWeight = "unset";
+ document.querySelectorAll('.SBWhitelistIcon')[0].classList.remove("rotated");
//save this
Config.config.whitelistedChannels = whitelistedChannels;
@@ -1067,10 +750,6 @@ async function runThePopup(messageListener?: MessageListener) {
}
if (chrome.tabs != undefined) {
- //add the width restriction (because Firefox)
- let link = document.getElementById("sponsorBlockStyleSheet");
- ( link.sheet).insertRule('.popupBody { width: 325 }', 0);
-
//this means it is actually opened in the popup
runThePopup();
}