Merge branch 'master' of https://github.com/ajayyy/SponsorBlock into improvements

# Conflicts:
#	manifest/manifest.json
#	src/components/SponsorTimeEditComponent.tsx
#	src/config.ts
#	src/content.ts
#	src/types.ts
This commit is contained in:
Ajay Ramachandran 2021-05-22 01:28:24 -04:00
commit 5fbb8c0d4a
57 changed files with 1383 additions and 828 deletions

3
.gitignore vendored
View file

@ -5,4 +5,5 @@ node_modules
web-ext-artifacts web-ext-artifacts
.vscode/ .vscode/
dist/ dist/
tmp/ tmp/
.DS_Store

View file

@ -1,7 +1,7 @@
{ {
"name": "__MSG_fullName__", "name": "__MSG_fullName__",
"short_name": "SponsorBlock", "short_name": "SponsorBlock",
"version": "2.0.14", "version": "2.0.16.1",
"default_locale": "en", "default_locale": "en",
"description": "__MSG_Description__", "description": "__MSG_Description__",
"homepage_url": "https://sponsor.ajay.app", "homepage_url": "https://sponsor.ajay.app",
@ -25,10 +25,11 @@
"web_accessible_resources": [ "web_accessible_resources": [
"icons/LogoSponsorBlocker256px.png", "icons/LogoSponsorBlocker256px.png",
"icons/IconSponsorBlocker256px.png", "icons/IconSponsorBlocker256px.png",
"icons/PlayerStartIconSponsorBlocker256px.png", "icons/PlayerStartIconSponsorBlocker.svg",
"icons/PlayerStopIconSponsorBlocker256px.png", "icons/PlayerStopIconSponsorBlocker.svg",
"icons/PlayerUploadIconSponsorBlocker256px.png", "icons/PlayerUploadIconSponsorBlocker.svg",
"icons/PlayerUploadFailedIconSponsorBlocker256px.png", "icons/PlayerUploadFailedIconSponsorBlocker.svg",
"icons/PlayerCancelSegmentIconSponsorBlocker.svg",
"icons/settings.svg", "icons/settings.svg",
"icons/pencil.svg", "icons/pencil.svg",
"icons/check.svg", "icons/check.svg",
@ -42,8 +43,8 @@
"icons/beep.ogg", "icons/beep.ogg",
"icons/pause.svg", "icons/pause.svg",
"icons/stop.svg", "icons/stop.svg",
"icons/PlayerInfoIconSponsorBlocker256px.png", "icons/PlayerInfoIconSponsorBlocker.svg",
"icons/PlayerDeleteIconSponsorBlocker256px.png", "icons/PlayerDeleteIconSponsorBlocker.svg",
"popup.html", "popup.html",
"content.css" "content.css"
], ],

View file

@ -1 +1,14 @@
{} {
"Loading": {
"message": "በመጫን ላይ..."
},
"paused": {
"message": "ለአፍታ አቁም"
},
"success": {
"message": "ተሳክቷል!"
},
"Username": {
"message": "መለያ ስም"
}
}

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Segment nyní končí" "message": "Segment nyní končí"
}, },
"sponsorCancel": {
"message": "Zrušit vytváření segmentu"
},
"noVideoID": { "noVideoID": {
"message": "Nebylo nalezeno žádné YouTube video.\nPokud je to špatně, obnovte záložku." "message": "Nebylo nalezeno žádné YouTube video.\nPokud je to špatně, obnovte záložku."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Jste si jisti, že toto chcete obnovit?" "message": "Jste si jisti, že toto chcete obnovit?"
}, },
"confirmPrivacy": {
"message": "Toto video bylo zjištěno jako neuvedené. Klikněte na Zrušit, pokud nechcete kontrolovat pro přeskočitelné segmenty."
},
"unlistedCheck": {
"message": "Ignorovat neuvedená / soukromá videa"
},
"whatUnlistedCheck": {
"message": "Toto nastavení mírně zpomalí SponsorBlock. Přeskakování vyhledávání segmentů vyžaduje posílání ID videa serveru. Pokud vám vadí odesílání neuvedených videí přes internet, povolte tuto možnost."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com je nyní podporováno" "message": "m.youtube.com je nyní podporováno"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID kanálu ještě nebylo načteno." "message": "ID kanálu ještě nebylo načteno."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Zdá se, že něco blokuje schopnost rozšíření SponsorBlock získat data o videu. Bude to nejspíš váš adblocker. Podívejte se prosím na https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Vypadá to, že něco blokuje schopnost SponsorBlocku získat údaje o videu. Pro více informací prosím navštivte https://github.com/ajayyy/SponsorBlock/issues/741."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Pokud vám tento problém nepůjde vyřešit, vypněte nastavení 'Ignore unlisted/private videos', protože SponsorBlock nemůže zjistit, jestli je vaše video veřejné či nikoliv" "message": "Vypadá to, že se SponsorBlock nemůže připojit k YouTube API. Pro opravení tohoto problému přijměte žádost o oprávnění, která se dále objeví, a poté znovu načtěte stránku."
},
"acceptPermission": {
"message": "Přijmout oprávnění"
},
"permissionRequestSuccess": {
"message": "Žádost o oprávnění byla úspěšná!"
},
"permissionRequestFailed": {
"message": "Žádost o oprávnění se nezdařila, neklikli jste na Odmítnout?"
},
"adblockerIssueWhitelist": {
"message": "Pokud vám tento problém nepůjde vyřešit, vypněte nastavení 'Vynutit kontrolu kanálu před přeskočením', protože SponsorBlock nemůže zjistit informace o kanálu"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Pokud k tomu stále dochází, může to být způsobeno vaším adblockerem. Podívejte se prosím https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Pokud k tomu stále dochází, může to být způsobeno vaším adblockerem. Podívejte se prosím https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Bist du dir sicher, dass du das zurücksetzen möchtest?" "message": "Bist du dir sicher, dass du das zurücksetzen möchtest?"
}, },
"confirmPrivacy": {
"message": "Das Video wurde als \"nicht gelistet\" erkannt. Klicke auf \"Abbrechen\", wenn du nicht nach Segmenten suchen möchtest."
},
"unlistedCheck": {
"message": "Nicht gelistete und private Videos ignorieren"
},
"whatUnlistedCheck": {
"message": "Diese Einstellung wird SponsorBlock leicht verlangsamen. Das Abfragen von überspringbaren Videosegmenten erfordert das Senden der Video-ID an den Server. Wenn du dir Sorgen darüber machst, dass IDs von nicht gelisteten Videos über das Internet gesendet werden, aktiviere diese Option."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "https://m.youtube.com wird jetzt unterstützt" "message": "https://m.youtube.com wird jetzt unterstützt"
}, },
@ -591,23 +582,32 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "Kanal-ID wurde noch nicht geladen." "message": "Kanal-ID wurde noch nicht geladen."
}, },
"adblockerIssue": { "youtubePermissionRequest": {
"message": "Irgendwas hält SponsorBlock davon ab, die Videodaten abzurufen. Eine mögliche Ursache sind Werbeblocker. Mehr Infos: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Es scheint, dass SponsorBlock nicht in der Lage ist, die YouTube-API zu erreichen. Um dies zu beheben, akzeptieren Sie die Berechtigungsanfrage, die gleich erscheint; Warten Sie ein paar Sekunden, und laden Sie die Seite neu."
}, },
"adblockerIssueUnlistedVideosInfo": { "acceptPermission": {
"message": "Wenn Sie dies nicht lösen können, deaktivieren Sie die Einstellung 'Nicht gelistete und private Videos ignorieren', da SponsorBlock nicht in der Lage ist, die Sichtbarkeit für dieses Video abzurufen" "message": "Berechtigung akzeptieren"
},
"permissionRequestSuccess": {
"message": "Die Berechtigungsanfrage war erfolgreich!"
},
"permissionRequestFailed": {
"message": "Berechtigungsanfrage fehlgeschlagen, haben Sie \"Ablehnen\" angeklickt?"
},
"adblockerIssueWhitelist": {
"message": "Wenn Sie dies nicht lösen können, deaktivieren Sie die Einstellung 'Kanalprüfung vor dem Überspringen von Segmenten erzwingen', da SponsorBlock nicht in der Lage ist, die Sichtbarkeit für dieses Video abzurufen."
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Falls dies weiterhin geschieht, könnte dies durch einen Werbeblocker verursacht werden. Mehr Infos: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Falls dies weiterhin geschieht, könnte dies durch einen Werbeblocker verursacht werden. Mehr Infos: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },
"forceChannelCheck": { "forceChannelCheck": {
"message": "Erzwingen, dass vor dem Überspringen von Segmenten überprüft wird, ob der Kanal zur Whitelist hinzugefügt wurde" "message": "Kanalprüfung vor dem Überspringen von Segmenten erzwingen"
}, },
"whatForceChannelCheck": { "whatForceChannelCheck": {
"message": "Standardmäßig werden Segmente schon übersprungen, bevor SponsorBlock die Kanal-ID einliest. Das kann dazu führen, dass Segmente am Anfang von Videos eines Kanals übersprungen werden, der zur Whitelist hinzugefügt wurde. Diese Option zwingt SponsorBlock dazu, auf die Kanal-ID zu warten - dies resultiert in einer kleinen Verzögerung, die aber mit einer schnellen Internetverbindung nicht spürbar sein sollte." "message": "Standardmäßig werden Segmente schon übersprungen, bevor SponsorBlock die Kanal-ID einliest. Das kann dazu führen, dass Segmente am Anfang von Videos eines Kanals übersprungen werden, der zur Whitelist hinzugefügt wurde. Diese Option zwingt SponsorBlock dazu, auf die Kanal-ID zu warten - dies resultiert in einer kleinen Verzögerung, die aber mit einer schnellen Internetverbindung nicht spürbar sein sollte."
}, },
"forceChannelCheckPopup": { "forceChannelCheckPopup": {
"message": "Eventuell solltest du die Option \"Erzwingen, dass vor dem Überspringen von Segmenten überprüft wird, ob der Kanal zur Whitelist hinzugefügt wurde\" aktivieren." "message": "Eventuell solltest du die Option \"Kanalprüfung vor dem Überspringen von Segmenten erzwingen\" aktivieren."
}, },
"downvoteDescription": { "downvoteDescription": {
"message": "Nicht korrekt oder falsches Timing" "message": "Nicht korrekt oder falsches Timing"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Segment Ends Now" "message": "Segment Ends Now"
}, },
"sponsorCancel": {
"message": "Cancel Creating Segment"
},
"noVideoID": { "noVideoID": {
"message": "No YouTube video found.\nIf this is incorrect, refresh the tab." "message": "No YouTube video found.\nIf this is incorrect, refresh the tab."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Are you sure you would like to reset this?" "message": "Are you sure you would like to reset this?"
}, },
"confirmPrivacy": {
"message": "The video has been detected as unlisted. Click cancel if you do not want to check for skip segments."
},
"unlistedCheck": {
"message": "Ignore Unlisted/Private Videos"
},
"whatUnlistedCheck": {
"message": "This setting will slightly slow down SponsorBlock. Skip segment lookups require sending the video ID to the server. If you are concerned about unlisted video IDs being sent over the internet, enable this option."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com is now supported" "message": "m.youtube.com is now supported"
}, },
@ -619,10 +613,11 @@
"message": "hidden: too short" "message": "hidden: too short"
}, },
"channelDataNotFound": { "channelDataNotFound": {
"message": "Channel ID not loaded yet." "description": "This error appears in an alert when they try to whitelist a channel and the extension is unable to determine what channel they are looking at.",
"message": "Channel ID is not loaded yet. If you are using an embedded video, try using the YouTube homepage instead. This could also be caused by changes in the YouTube layout, if you think so, make a comment here:"
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "It seems that something is blocking SponsorBlock's ability to get video data. This is probably your ad blocker. Please check https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "It seems that something is blocking SponsorBlock's ability to get video data. Please see https://github.com/ajayyy/SponsorBlock/issues/741 for more info."
}, },
"youtubePermissionRequest": { "youtubePermissionRequest": {
"message": "It seems that SponsorBlock is unable to reach the YouTube API. To fix this, accept the permission prompt that will appear next, wait a few seconds, and then reload the page." "message": "It seems that SponsorBlock is unable to reach the YouTube API. To fix this, accept the permission prompt that will appear next, wait a few seconds, and then reload the page."
@ -636,14 +631,8 @@
"permissionRequestFailed": { "permissionRequestFailed": {
"message": "Permission request failed, did you click deny?" "message": "Permission request failed, did you click deny?"
}, },
"adblockerIssueUnlistedVideosInfo": {
"message": "If you are unable to resolve this, then disable the setting 'Ignore unlisted/private videos', as SponsorBlock is unable to retrieve the visibility information for this video"
},
"adblockerIssueWhitelist": { "adblockerIssueWhitelist": {
"message": "If you are unable to resolve this, then disable the setting 'Force Channel Check Before Skipping', as SponsorBlock is unable to retrieve the visibility information for this video" "message": "If you are unable to resolve this, then disable the setting 'Force Channel Check Before Skipping', as SponsorBlock is unable to retrieve the channel information for this video"
},
"itCouldBeAdblockerIssue": {
"message": "If this keeps occuring, it could be caused by your ad blocker. Please check https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },
"forceChannelCheck": { "forceChannelCheck": {
"message": "Force Channel Check Before Skipping" "message": "Force Channel Check Before Skipping"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "El segmento termina ahora" "message": "El segmento termina ahora"
}, },
"sponsorCancel": {
"message": "Cancelar Creación de Segmento"
},
"noVideoID": { "noVideoID": {
"message": "No se encontró vídeo de YouTube.\nSi esto es incorrecto, actualice la pestaña." "message": "No se encontró vídeo de YouTube.\nSi esto es incorrecto, actualice la pestaña."
}, },
@ -233,7 +236,7 @@
"description": "The second line of the message displayed after the notice was upgraded." "description": "The second line of the message displayed after the notice was upgraded."
}, },
"setSkipShortcut": { "setSkipShortcut": {
"message": "Establecer clave para omitir un segmento" "message": "Establecer tecla para omitir un segmento"
}, },
"setStartSponsorShortcut": { "setStartSponsorShortcut": {
"message": "Establecer tecla para iniciar segmento" "message": "Establecer tecla para iniciar segmento"
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "¿Estás seguro de que te gustaría reiniciar esto?" "message": "¿Estás seguro de que te gustaría reiniciar esto?"
}, },
"confirmPrivacy": {
"message": "El vídeo ha sido detectado como no listado. Haz clic en cancelar si no quieres comprobar si hay segmentos salteados."
},
"unlistedCheck": {
"message": "Ignorar los vídeos no listados/privados"
},
"whatUnlistedCheck": {
"message": "Esta configuración ralentizará ligeramente a SponsorBlock. Las búsquedas de segmentos de salto requieren el envío de la identificación del vídeo al servidor. Si le preocupa que se envíen por Internet identificadores de vídeo no listados, habilite esta opción."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com ahora es compatible" "message": "m.youtube.com ahora es compatible"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID de canal no cargado todavía." "message": "ID de canal no cargado todavía."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Parece que algo está bloqueando la capacidad de SponsorBlock para obtener datos de vídeo. Este es probablemente su bloqueador de anuncios. Por favor, compruebe https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Parece que algo está bloqueando la capacidad de SponsorBlock para obtener datos de video, Por favor, vea https://github.com/ajayyy/SponsorBlock/issues/741 para más información."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Si no puedes resolver esto, desactiva la configuración 'Ignorar vídeos no listados/privados', porque SponsorBlock no puede recuperar la información de visibilidad de este vídeo" "message": "Parece que SponsorBlock no puede acceder a la API de YouTube. Para solucionarlo, acepte el aviso de permiso que aparecerá a continuación, espera unos segundos y vuelve a cargar la página."
},
"acceptPermission": {
"message": "Aceptar permiso"
},
"permissionRequestSuccess": {
"message": "¡Petición de permiso realizada con éxito!"
},
"permissionRequestFailed": {
"message": "La petición de permiso ha fallado, ¿ha hecho clic en denegar?"
},
"adblockerIssueWhitelist": {
"message": "Si no puede resolverlo, desactive la opción \"Forzar Comprobación de Canal antes de Saltar\", ya que SponsorBlock no puede recuperar la información del canal de este video"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Si esto sigue ocurriendo, podría ser causado por tu bloqueador de anuncios. Por favor, compruebe https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Solicitudes" "message": "Si esto sigue ocurriendo, podría ser causado por tu bloqueador de anuncios. Por favor, compruebe https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Solicitudes"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Segment lõpeb nüüd" "message": "Segment lõpeb nüüd"
}, },
"sponsorCancel": {
"message": "Tühista segmendi loomine"
},
"noVideoID": { "noVideoID": {
"message": "YouTube'i videot ei leitud.\nKui see ei vasta tõele, laadi kaart uuesti." "message": "YouTube'i videot ei leitud.\nKui see ei vasta tõele, laadi kaart uuesti."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Kas soovid kindlasti selle lähtestada?" "message": "Kas soovid kindlasti selle lähtestada?"
}, },
"confirmPrivacy": {
"message": "See video on registrivälisena tuvastatud. Klõpsa \"tühista\", kui ei soovi otsida vahelejätmise segmente."
},
"unlistedCheck": {
"message": "Ignoreeri registriväliseid/privaatsed videoid"
},
"whatUnlistedCheck": {
"message": "See valik aeglustab veidi SponsorBlocki. Vahelejätmise segmentide hankimiseks saadetakse video ID serverisse. Kui oled mures registriväliste videote IDde internetti saatmise üle, luba see valik."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com on nüüd toetatud" "message": "m.youtube.com on nüüd toetatud"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "Kanali ID pole veel laaditud." "message": "Kanali ID pole veel laaditud."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Tundub, et miski segab SponsorBlocki video andmete hankimise võimalust. See on ilmselt sinu reklaamiblokeerija. Palun vaata https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Tundub, et miski segab SponsorBlocki video andmete hankimise võimalust. Rohkema abi saamiseks palun vaata: https://github.com/ajayyy/SponsorBlock/issues/741"
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Kui sa ei suuda seda lahendada, keela valik \"ignoreeri registriväliseid/privaatsed videoid\", kuna SponsorBlock ei leia selle video nähtavusteavet" "message": "Tundub, et SponsorBlock ei pääse YouTube'i rakendusliidesele ligi. Selle parandamiseks nõustu järgnevalt kuvatava loataotlusega, oota paar sekundit ning seejärel laadi leht uuesti."
},
"acceptPermission": {
"message": "Nõustu loaga"
},
"permissionRequestSuccess": {
"message": "Loataotlus õnnestus!"
},
"permissionRequestFailed": {
"message": "Loataotlus ebaõnnestus, kas sa keeldusid?"
},
"adblockerIssueWhitelist": {
"message": "Kui sa ei suuda seda lahendada, keela valik \"sunnitud kanalikontroll enne vahelejätmist\", kuna SponsorBlock ei leia selle video kanaliteavet"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Kui see jätkub, võib see olla põhjustatud sinu reklaamiblokeerijast. Palun vaata https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Kui see jätkub, võib see olla põhjustatud sinu reklaamiblokeerijast. Palun vaata https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Segmentti Päättyy Nyt" "message": "Segmentti Päättyy Nyt"
}, },
"sponsorCancel": {
"message": "Peruuta Segmentin Luominen"
},
"noVideoID": { "noVideoID": {
"message": "YouTube-videota ei löytynyt.\nJos tämä on väärässä, päivitä välilehti." "message": "YouTube-videota ei löytynyt.\nJos tämä on väärässä, päivitä välilehti."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Oletko varma, että haluat nollata tämän?" "message": "Oletko varma, että haluat nollata tämän?"
}, },
"confirmPrivacy": {
"message": "Video on havaittu piilotetuksi. Paina peruuta, jos et halua tarkistaa ohitettavia segmenttejä."
},
"unlistedCheck": {
"message": "Ohita Piilotetut/Yksityiset Videot"
},
"whatUnlistedCheck": {
"message": "Tämä asetus hidastaa SponsorBlockia hieman. Ohitus-segmenttien haku edellyttää video ID:n lähettämistä palvelimelle. Jos olet huolissasi, että piilotettujen videoiden ID:itä lähetetään internetin kautta, ota tämä asetus käyttöön."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com-osoitetta tuetaan nyt" "message": "m.youtube.com-osoitetta tuetaan nyt"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "Kanavatunnusta ei ole vielä ladattu." "message": "Kanavatunnusta ei ole vielä ladattu."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Näyttää siltä, että jokin estää SponsorBlockin kykyä saada videotietoja. Tämä on luultavasti mainosten esto-ohjelmasi. Tarkista https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Näyttää siltä, että jokin estää SponsorBlockin kykyä saada videotietoja. Katso https://github.com/ajayyy/SponsorBlock/issues/741 lisätietoja varten."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Jos et pysty ratkaisemaan tätä, poista käytöstä asetus 'Ohita piilotetut/yksityiset videot', koska SponsorBlock ei pysty noutamaan tämän videon näkyvyystietoja" "message": "Näyttää siltä, että SponsorBlock ei pysty saavuttamaan YouTube-APIa. Korjataksesi tämän, hyväksy seuraavaksi ilmestyvä käyttöoikeusilmoitus, odota muutama sekunti ja lataa sitten sivu uudelleen."
},
"acceptPermission": {
"message": "Hyväksy käyttöoikeus"
},
"permissionRequestSuccess": {
"message": "Käyttöoikeuspyyntö onnistui!"
},
"permissionRequestFailed": {
"message": "Käyttöoikeuspyyntö epäonnistui, klikkasitko kiellä?"
},
"adblockerIssueWhitelist": {
"message": "Jos et pysty ratkaisemaan tätä, poista käytöstä asetus 'Pakota Kanavan Tarkistus Ennen Ohittamista', koska SponsorBlock ei pysty noutamaan tämän videon kanavatietoja"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Jos tämä toistuu, mainosten esto-ohjelmasi voi olla syynä. Katso https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Jos tämä toistuu, mainosten esto-ohjelmasi voi olla syynä. Katso https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Voulez-vous vraiment remettre à zéro ?" "message": "Voulez-vous vraiment remettre à zéro ?"
}, },
"confirmPrivacy": {
"message": "La vidéo a été détectée comme étant non répertoriée. Cliquez sur annuler si vous ne voulez pas vérifier les segments sautés."
},
"unlistedCheck": {
"message": "Ignorer les vidéos non listées"
},
"whatUnlistedCheck": {
"message": "Ce réglage ralentira légèrement SponsorBlock. Pour sauter des segments, il faut envoyer l'ID de la vidéo au serveur. Si vous craignez que des identifiants de vidéo non répertoriés soient envoyés sur Internet, activez cette option."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com est maintenant pris en charge" "message": "m.youtube.com est maintenant pris en charge"
}, },
@ -591,12 +582,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "L'ID de la chaîne n'a pas encore été chargé." "message": "L'ID de la chaîne n'a pas encore été chargé."
}, },
"adblockerIssue": {
"message": "Il semble que quelque chose empêche SponsorBlock de récupérer les données de la vidéo. C'est probablement votre bloqueur de publicités. Veuillez consulter https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
},
"adblockerIssueUnlistedVideosInfo": {
"message": "Si vous ne pouvez pas résoudre ça, désactivé le paramètre 'Ignorer vidéos privées ou pas listées\", car SponsorBlock ne peux pas trouver cette vidéo"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Si ça se reproduit, c'est peut-être causé par votre bloqueur de publicités. Veuillez consulter https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Si ça se reproduit, c'est peut-être causé par votre bloqueur de publicités. Veuillez consulter https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },

View file

@ -47,10 +47,10 @@
"message": "Klikni unskip kako bi se vratio otkuda si došao." "message": "Klikni unskip kako bi se vratio otkuda si došao."
}, },
"unskip": { "unskip": {
"message": "Unskip" "message": "Ne preskači"
}, },
"reskip": { "reskip": {
"message": "Reskip" "message": "Preskoči opet"
}, },
"paused": { "paused": {
"message": "Pauzirano" "message": "Pauzirano"
@ -109,12 +109,23 @@
"voteOnTime": { "voteOnTime": {
"message": "Glasaj za isječak" "message": "Glasaj za isječak"
}, },
"recordTimesDescription": {
"message": "Pošalji"
},
"submissionEditHint": {
"message": "Uređivanje dijela prikazat će se nakon što pritisneš gumb za slanje",
"description": "Appears in the popup to inform them that editing has been moved to the video player."
},
"clearTimesButton": { "clearTimesButton": {
"message": "Očisti vremena" "message": "Očisti vremena"
}, },
"submitTimesButton": { "submitTimesButton": {
"message": "Unesi vremena" "message": "Unesi vremena"
}, },
"yourWork": {
"message": "Tvoja slanja",
"description": "Used to describe the section that will show you the statistics from your submissions."
},
"whatChangeUserID": { "whatChangeUserID": {
"message": "Ovo bi trebalo ostati privatno. slično je lozinki i ne bi se smjelo dijeliti ni s kime. Ako netko ovo ima, mogu se lažno predstavljati kao ti." "message": "Ovo bi trebalo ostati privatno. slično je lozinki i ne bi se smjelo dijeliti ni s kime. Ako netko ovo ima, mogu se lažno predstavljati kao ti."
}, },
@ -171,5 +182,75 @@
}, },
"minDurationDescription": { "minDurationDescription": {
"message": "Isječci kraći od postavljene vrijednosti neće biti preskočeni ili prikazani u playeru." "message": "Isječci kraći od postavljene vrijednosti neće biti preskočeni ili prikazani u playeru."
},
"confirmNoticeTitle": {
"message": "Pošalji segment"
},
"submit": {
"message": "Pošalji"
},
"category_sponsor": {
"message": "Sponzor"
},
"category_intro": {
"message": "Stanka/Uvodna animacija"
},
"category_intro_description": {
"message": "Interval bez stvarnog sadržaja. Može biti stanka, statični kadar, ponavljajuća animacija. Ovo se ne bi trebalo koristiti za prijelaze koji sadrže informacije."
},
"category_intro_short": {
"message": "Stanka"
},
"category_outro": {
"message": "Završni kadrovi/Zasluge"
},
"category_interaction": {
"message": "Podsjetnik interakcije (Pretplati se)"
},
"category_interaction_short": {
"message": "Podsjetnik interakcije"
},
"category_selfpromo": {
"message": "Neplaćena promocija ili samopromocija"
},
"category_selfpromo_description": {
"message": "Slično kao „sponzor”, osim za neplaćenu promociju i samopromociju. To uključuje odlomke marketinga, donacija ili informacija o tome, s kim su surađivali."
},
"category_music_offtopic": {
"message": "Glazba: Ne-glazbeni dio"
},
"category_music_offtopic_description": {
"message": "Samo za videospotove. Ovo bi se trebalo koristiti samo za dijelove videospotova koji još nisu obuhvaćeni drugom kategorijom."
},
"category_music_offtopic_short": {
"message": "Ne-glazbeni"
},
"manualSkip": {
"message": "Ručno preskakanje"
},
"youMustSelectACategory": {
"message": "Moraš odabrati kategoriju za sve segmente koje šalješ!"
},
"nonMusicCategoryOnMusic": {
"message": "Ovaj je video kategoriziran kao glazba. Je li stvarno ima sponzora? Ako je ovo zapravo „Ne-glazbeni segment”, otvori opcije proširenja i aktiviraj ovu kategoriju. Zatim ovaj segment možeš posalti kao „Ne-glazbeni” umjesto sponzora. Pročitaj smjernice ako nešto nije jasno."
},
"multipleSegments": {
"message": "Više segmenata"
},
"guidelines": {
"message": "Smjernice"
},
"readTheGuidelines": {
"message": "Pročitaj Smjernice!",
"description": "Show the first time they submit or if they are \"high risk\""
},
"categoryUpdate1": {
"message": "Stigle su kategorije!"
},
"categoryUpdate2": {
"message": "Otvori opcije za preskakanje uvoda, kraja, proizvoda itd."
},
"help": {
"message": "Pomoć"
} }
} }

View file

@ -388,15 +388,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Biztosan vissza szeretné állítani?" "message": "Biztosan vissza szeretné állítani?"
}, },
"confirmPrivacy": {
"message": "Videó észlelve nem listázottként. Kattintson a Mégse gombra, ha nem akar ellenőrizni átugorható szegmensek után."
},
"unlistedCheck": {
"message": "Nem listázott/Privát videók ignorálása"
},
"whatUnlistedCheck": {
"message": "Ez a beállítás kissé lelassíthatja a SponsorBlockot. A szegmensek átugrásához szükséges, hogy a videoID el legyen küldve a szerverre. Ha aggódik az interneten küldött nem listázott videóazonosítók küldése miatt, kapcsolja be ezt a funkciót."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "az m.youtube.com már támogatott" "message": "az m.youtube.com már támogatott"
}, },
@ -561,9 +552,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "A csatorna azonosító még nem töltődött be." "message": "A csatorna azonosító még nem töltődött be."
}, },
"adblockerIssue": {
"message": "Valami meggátolja a SponsorBlockot a videó adatainak megszerzésében. Valószínűleg az ad-blockere. Kérem ellenőrizze: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Ha ez folyamatosan előfordul, lehet hogy az ad-blockere okozza. Kérem nézzen utána: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Ha ez folyamatosan előfordul, lehet hogy az ad-blockere okozza. Kérem nézzen utána: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },

View file

@ -79,8 +79,11 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Segmen Berakhir Sekarang" "message": "Segmen Berakhir Sekarang"
}, },
"sponsorCancel": {
"message": "Batalkan Membuat Segmen"
},
"noVideoID": { "noVideoID": {
"message": "Video YouTube tidak ditemukan.\nJika terjadi kesalahan, silahkan ulangin halaman." "message": "Video YouTube tidak ditemukan.\nJika terjadi kesalahan, segarkan halaman."
}, },
"success": { "success": {
"message": "Sukses!" "message": "Sukses!"
@ -113,10 +116,10 @@
"message": "Apakah anda yakin ingin mengirim ini?" "message": "Apakah anda yakin ingin mengirim ini?"
}, },
"whitelistChannel": { "whitelistChannel": {
"message": "Daftar kanal putih" "message": "Daftar putih channel"
}, },
"removeFromWhitelist": { "removeFromWhitelist": {
"message": "Hapus kanal dari daftar putih" "message": "Hapus channel dari daftar putih"
}, },
"voteOnTime": { "voteOnTime": {
"message": "Beri Segmen Vote" "message": "Beri Segmen Vote"
@ -207,7 +210,7 @@
"message": "Fetch Ulang Segmen Di Video Baru" "message": "Fetch Ulang Segmen Di Video Baru"
}, },
"whatRefetchWhenNotFound": { "whatRefetchWhenNotFound": {
"message": "Jika ini merupakan video baru, dan tidak ada segmen yang ditemukan, itu akan terus merefetch setiap beberapa menit saat anda menonton." "message": "Jika ini merupakan video baru, dan tidak ada segmen yang ditemukan, SponsorBlock akan terus merefetch setiap beberapa menit saat anda menonton."
}, },
"showNotice": { "showNotice": {
"message": "Tampilkan Pemberitahuan Lagi" "message": "Tampilkan Pemberitahuan Lagi"
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Apakah anda yakin ingin mengatur ulang ini?" "message": "Apakah anda yakin ingin mengatur ulang ini?"
}, },
"confirmPrivacy": {
"message": "Video ini dideteksi sebagai tidak terdaftar. Klik batal jika kamu tidak ingin mengecek untuk melewati segmen."
},
"unlistedCheck": {
"message": "Abaikan Video Tidak Terdaftar/Privat"
},
"whatUnlistedCheck": {
"message": "Pengaturan ini akan sedikit melambatkan SponsorBlock. Pencarian lewati segmen membutuhkan pengiriman ID video ke server. Jika anda khawatir tentang ID unlisted video terkirim ke internet, hidupkan opsi ini."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com sekarang didukung" "message": "m.youtube.com sekarang didukung"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID Channel belum dimuat." "message": "ID Channel belum dimuat."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Sepertinya ada sesuatu yang memblokir kemampuan SponsorBlock untuk mendapatkan data video. Kemungkinan karena ad blocker anda. Mohon cek https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Sepertinya sesuatu memnghalangi abilitas SponsorBlock untuk mendapatkan data video. Silahkan lihat https://github.com/ajayyy/SponsorBlock/issues/741 untuk info lebih lanjut."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Jika anda tidak bisa menyelesaikan ini, maka nonaktifkan pengaturan 'Abaikan video tidak terdaftar/privat', karena SponsorBlock tidak bisa mendapatkan informasi visibilitas untuk video ini" "message": "Sepertinya SponsorBlock tidak dapat menjangkau API YouTube. Untuk menyelesaikan masalah ini, terima permintaan izin yang akan muncul selanjutnya, tunggu beberapa detik, dan muat ulang halaman ini."
},
"acceptPermission": {
"message": "Terima permintaan izin"
},
"permissionRequestSuccess": {
"message": "Permintaan izin berhasil!"
},
"permissionRequestFailed": {
"message": "Permintaan izin gagal, apakah anda mengklik tolak?"
},
"adblockerIssueWhitelist": {
"message": "Apabila anda tidak dapat menyelesaikan masalah ini, maka nonaktifkan pengaturan 'Paksa Cek Channel Sebelum Melewati', dikarenakan SponsorBlock tidak dapat menerima informasi channel untuk video ini"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Jika ini terus terjadi, kemungkinan terjadi karena ad blocker anda. Mohon cek https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Jika ini terus terjadi, kemungkinan terjadi karena ad blocker anda. Mohon cek https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Il Segmento Termina Ora" "message": "Il Segmento Termina Ora"
}, },
"sponsorCancel": {
"message": "Annulla Creazione del Segmento"
},
"noVideoID": { "noVideoID": {
"message": "Nessun video YouTube trovato.\nSe è un errore, ricarica la scheda." "message": "Nessun video YouTube trovato.\nSe è un errore, ricarica la scheda."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Sei sicuro di voler eseguire il reset?" "message": "Sei sicuro di voler eseguire il reset?"
}, },
"confirmPrivacy": {
"message": "Il video è stato rilevato come non in elenco. Clicca su Annulla se non desideri verificare la presenza di segmenti da saltare."
},
"unlistedCheck": {
"message": "Ignora Video Non Pubblicati/Privati"
},
"whatUnlistedCheck": {
"message": "Questa impostazione rallenterà leggermente SponsorBlock. Le ricerche di segmenti da saltare richiedono l'invio dell'ID video al server. Se sei preoccupato per gli ID video non in elenco inviati su Internet, attiva questa opzione."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com è ora supportato" "message": "m.youtube.com è ora supportato"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID canale non ancora caricato." "message": "ID canale non ancora caricato."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Sembra che qualcosa stia bloccando la capacità di SponsorBlock di ottenere dati video. Questo probabilmente è il tuo ad blocker. Controlla https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Sembra che qualcosa stia bloccando l'abilità di SponsorBlock di ottenere i dati del video. Sei pregato di vedere https://github.com/ajayyy/SponsorBlock/issues/741 per ulteriori informazioni."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Se non riesci a risolvere questo problema, disabilita l'impostazione 'Ignora video non elencati/privati', poiché SponsorBlock non è in grado di recuperare le informazioni di visibilità di questo video" "message": "Sembra che SponsorBlock non sia in grado di raggiungere l'API di YouTube. Per risolverlo, accetta la richiesta di autorizzazione che comparirà in seguito, attendi qualche secondo, quindi ricarica la pagina."
},
"acceptPermission": {
"message": "Accetta autorizzazione"
},
"permissionRequestSuccess": {
"message": "Richiesta di autorizzazione riuscita!"
},
"permissionRequestFailed": {
"message": "Richiesta di assicurazione fallita, hai cliccato nega?"
},
"adblockerIssueWhitelist": {
"message": "Se non riesci a risolverlo, disabilita allora l'impostazione 'Forza Controllo Canale Prima di Saltare', poiché SponsorBlock non è in grado di recuperare le informazioni del canale per questo video"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Se questo continua a verificarsi, potrebbe essere causato dal tuo ad-blocker. Controlla https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Se questo continua a verificarsi, potrebbe essere causato dal tuo ad-blocker. Controlla https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -20,10 +20,10 @@
"message": "チャンネルをホワイトリストに登録しました!" "message": "チャンネルをホワイトリストに登録しました!"
}, },
"Segment": { "Segment": {
"message": "セグメント" "message": "区域"
}, },
"Segments": { "Segments": {
"message": "セグメント" "message": "区域"
}, },
"upvoteButtonInfo": { "upvoteButtonInfo": {
"message": "この提案を支持する" "message": "この提案を支持する"
@ -68,16 +68,16 @@
"message": "スポンサー表示の投稿中にエラーが発生しました。しばらく経ってからもう一度お試しください。" "message": "スポンサー表示の投稿中にエラーが発生しました。しばらく経ってからもう一度お試しください。"
}, },
"sponsorFound": { "sponsorFound": {
"message": "この動画用のセグメントはデータベースに登録されています!" "message": "この動画用の区域は情報集合体に登録されています!"
}, },
"sponsor404": { "sponsor404": {
"message": "セグメントが見つかりませんでした" "message": "区域が見つかりませんでした"
}, },
"sponsorStart": { "sponsorStart": {
"message": "セグメントが始まりました" "message": "区域が始まりました"
}, },
"sponsorEnd": { "sponsorEnd": {
"message": "セグメントが終わりました" "message": "区域が終わりました"
}, },
"noVideoID": { "noVideoID": {
"message": "YouTube動画が見つかりませんでした。\nこれが正しくない場合は、タブを再読み込みしてください。" "message": "YouTube動画が見つかりませんでした。\nこれが正しくない場合は、タブを再読み込みしてください。"
@ -98,7 +98,7 @@
"message": "次の動画IDで提出します:" "message": "次の動画IDで提出します:"
}, },
"clearTimes": { "clearTimes": {
"message": "セグメントをクリア" "message": "区域を消去"
}, },
"openPopup": { "openPopup": {
"message": "SponsorBlock のポップアップを開く" "message": "SponsorBlock のポップアップを開く"
@ -107,7 +107,7 @@
"message": "ポップアップを閉じる" "message": "ポップアップを閉じる"
}, },
"SubmitTimes": { "SubmitTimes": {
"message": "セグメントを提出" "message": "区域を提出"
}, },
"submitCheck": { "submitCheck": {
"message": "本当に提出してよろしいですか?" "message": "本当に提出してよろしいですか?"
@ -119,7 +119,7 @@
"message": "ホワイトリストからチャンネルを削除" "message": "ホワイトリストからチャンネルを削除"
}, },
"voteOnTime": { "voteOnTime": {
"message": "セグメントに投票" "message": "区域に投票"
}, },
"Submissions": { "Submissions": {
"message": "提出数" "message": "提出数"
@ -171,7 +171,7 @@
"message": "YouTube プレイヤーにボタンを表示しない" "message": "YouTube プレイヤーにボタンを表示しない"
}, },
"hideButtonsDescription": { "hideButtonsDescription": {
"message": "これを有効にするとYouTubeプレーヤーのセグメント提出ボタンが非表示になります。" "message": "これを有効にするとYouTube再生画面の区域提出UIが非表示になります。"
}, },
"showInfoButton": { "showInfoButton": {
"message": "YouTubeプレーヤーの情報ボタンを表示する" "message": "YouTubeプレーヤーの情報ボタンを表示する"
@ -189,25 +189,25 @@
"message": "YouTube プレイヤーから削除ボタンを表示する" "message": "YouTube プレイヤーから削除ボタンを表示する"
}, },
"whatDeleteButton": { "whatDeleteButton": {
"message": "これはYouTubeプレーヤー上のボタンで、現在の動画から未提出のセグメントを全て消去します。" "message": "これはYouTube再生画面上のUIで現在の動画から未提出の区域を全て消去します。"
}, },
"enableViewTracking": { "enableViewTracking": {
"message": "スキップ回数の統計を有効にする" "message": "スキップ回数の統計を有効にする"
}, },
"whatViewTracking": { "whatViewTracking": {
"message": "この機能は、あなたがスキップしたセグメントを追跡して、そのセグメントがどれだけ役に立ったかを他のユーザーに知らせることで、スパムがデータベースに紛れないようにするための評価基準として使用されます。あなたがセグメントをスキップするたびに、拡張機能はサーバーにメッセージを送信します。使用回数の統計が正確になるよう、できる限り多くの人がこの設定を変更しないことを望みます。:)" "message": "この機能は、あなたが飛び越した区域を追跡して、当該区域がどれだけ役に立ったかを他の利用者に知らせることで、不正な情報が情報集合体に紛れないようにするための評価基準として使用されます。あなたが区域を飛び越すたびに、拡張機能はサーバーに通報を送信します。使用回数の統計が正確になるよう、できる限り多くの人がこの設定を変更しないことを望みます。:)"
}, },
"enableQueryByHashPrefix": { "enableQueryByHashPrefix": {
"message": "ハッシュプレフィックスを使って要求" "message": "ハッシュプレフィックスを使って要求"
}, },
"whatQueryByHashPrefix": { "whatQueryByHashPrefix": {
"message": "動画IDを使用してサーバーからセグメントを要求する代わりに、動画IDのハッシュから最初の4文字が送信されます。それに対して、サーバーは類似したハッシュを持つすべての動画のデータを返却します。" "message": "サーバーに区域を要求する際に動画IDの代わりに動画IDのハッシュから最初の4文字を送信します。それに対してサーバーは類似したハッシュを持つすべての動画の情報を応答します。"
}, },
"enableRefetchWhenNotFound": { "enableRefetchWhenNotFound": {
"message": "新しい動画ではセグメントを再取得する" "message": "新しい動画では区域を再取得する"
}, },
"whatRefetchWhenNotFound": { "whatRefetchWhenNotFound": {
"message": "動画がまだ新しくセグメントが見つからない場合は、動画を視聴している間、数分おきにセグメントを検索し続けます。" "message": "動画がまだ新しく区域が見つからない場合は、動画を視聴している間、数分おきに区域を検索し続けます。"
}, },
"showNotice": { "showNotice": {
"message": "再度通知を表示する" "message": "再度通知を表示する"
@ -296,6 +296,9 @@
"youHaveSkipped": { "youHaveSkipped": {
"message": "スキップしたセグメント数: " "message": "スキップしたセグメント数: "
}, },
"youHaveSaved": {
"message": "ご自身の時間をこれだけ節約しました: "
},
"minLower": { "minLower": {
"message": "分" "message": "分"
}, },
@ -308,15 +311,75 @@
"hoursLower": { "hoursLower": {
"message": "時間" "message": "時間"
}, },
"youHaveSavedTime": {
"message": "他の人々の時間をこれだけ節約しました:"
},
"youHaveSavedTimeEnd": {
"message": "(彼らの人生のうち)"
},
"statusReminder": {
"message": "サーバーの状態についてはstatus.sponsor.ajay.appを確認してください。"
},
"changeUserID": {
"message": "利用者IDの読み込み・書き出し"
},
"whatChangeUserID": {
"message": "これを公開してはいけません。これは暗証語のようなものであり,誰とも共有するべきではありません。これを持っている人はあなたになりすませてしまいます。"
},
"setUserID": {
"message": "利用者IDを設定"
},
"userIDChangeWarning": {
"message": "警告: 利用者IDの変更は恒久的です。本当に実行しますか 念のため旧IDを控えておいてください。"
},
"createdBy": { "createdBy": {
"message": "作成者" "message": "作成者"
}, },
"autoSkip": { "autoSkip": {
"message": "自動スキップ" "message": "自動スキップ"
}, },
"showSkipNotice": {
"message": "区域を飛び越した後に通知を表示する"
},
"keybindCurrentlySet": {
"message": "。現在の設定は:"
},
"supportInvidious": {
"message": "Invidiousに対応"
},
"supportInvidiousDescription": {
"message": "Invidious (invidio.us) は第三者製のYouTubeクライアントです。Invidious対応を有効にするには追加の権限を受け入れなければいけません。 これはChromeやその他のChromium系列の匿名閲覧状態では動作しません。"
},
"optionsInfo": {
"message": "Invidious対応を有効にし自動飛越を無効にしGUIを非表示にします。"
},
"addInvidiousInstance": {
"message": "Invidiousインスタンスを追加"
},
"addInvidiousInstanceDescription": {
"message": "任意のInvidiousインスタンスを追加します。ドメイン名だけを記入してください。例: invidious.ajay.app"
},
"add": { "add": {
"message": "追加" "message": "追加"
}, },
"addInvidiousInstanceError": {
"message": "無効なドメイン名です。ドメイン部分だけを含めてください。例: invidious.ajay.app"
},
"resetInvidiousInstance": {
"message": "Invidiousインスタンス一覧を初期化"
},
"resetInvidiousInstanceAlert": {
"message": "Invidiousインスタン一覧を初期化しようとしています"
},
"currentInstances": {
"message": "現在のインスタンス:"
},
"minDuration": {
"message": "飛越す最短の時間(秒):"
},
"minDurationDescription": {
"message": "設定値より短い区域は飛び越されず,再生画面にも表示されません。"
},
"customServerAddress": { "customServerAddress": {
"message": "SponsorBlock サーバーアドレス" "message": "SponsorBlock サーバーアドレス"
}, },
@ -329,6 +392,9 @@
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com は現在サポートされています" "message": "m.youtube.com は現在サポートされています"
}, },
"confirmNoticeTitle": {
"message": "区域を提出"
},
"submit": { "submit": {
"message": "送信" "message": "送信"
}, },
@ -344,6 +410,10 @@
"edit": { "edit": {
"message": "編集" "message": "編集"
}, },
"to": {
"message": "",
"description": "Used between segments. Example: 1:20 to 1:30"
},
"category_sponsor": { "category_sponsor": {
"message": "スポンサー" "message": "スポンサー"
}, },
@ -359,6 +429,9 @@
"category_selfpromo": { "category_selfpromo": {
"message": "無報酬 / セルフプロモーション" "message": "無報酬 / セルフプロモーション"
}, },
"category_music_offtopic": {
"message": "音楽: 音楽ではない区間"
},
"disable": { "disable": {
"message": "無効" "message": "無効"
}, },
@ -379,7 +452,7 @@
"message": "カテゴリ" "message": "カテゴリ"
}, },
"skipOption": { "skipOption": {
"message": "スキップ オプション", "message": "飛越設定",
"description": "Used on the options page to describe the ways to skip the segment (auto skip, manual, etc.)" "description": "Used on the options page to describe the ways to skip the segment (auto skip, manual, etc.)"
}, },
"enableTestingServer": { "enableTestingServer": {
@ -391,9 +464,24 @@
"chooseACategory": { "chooseACategory": {
"message": "カテゴリーを選択" "message": "カテゴリーを選択"
}, },
"youMustSelectACategory": {
"message": "提出する全ての区域について,その範疇を選択する必要があります!"
},
"channelDataNotFound": { "channelDataNotFound": {
"message": "まだチャンネル ID が読み込まれてません。" "message": "まだチャンネル ID が読み込まれてません。"
}, },
"youtubePermissionRequest": {
"message": "SponsorBlockがYouTube APIを参照できないようです。修正するには次に表示される画面で許可を承認してから数秒後に再読み込みしてください。"
},
"acceptPermission": {
"message": "許可を承認する"
},
"permissionRequestSuccess": {
"message": "許可要求が成功しました。"
},
"permissionRequestFailed": {
"message": "権限要求に失敗しました。承認を拒否しましたか?"
},
"incorrectCategory": { "incorrectCategory": {
"message": "カテゴリが違います" "message": "カテゴリが違います"
}, },

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "광고 구간 끝" "message": "광고 구간 끝"
}, },
"sponsorCancel": {
"message": "구간 생성 취소"
},
"noVideoID": { "noVideoID": {
"message": "유튜브 동영상을 찾을 수 없습니다.\n오류라면, 탭을 새로고침해보세요." "message": "유튜브 동영상을 찾을 수 없습니다.\n오류라면, 탭을 새로고침해보세요."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "정말로 초기화하시겠습니까?" "message": "정말로 초기화하시겠습니까?"
}, },
"confirmPrivacy": {
"message": "이 영상은 일부 공개 영상으로 감지되었습니다. 구간 스킵을 확인하지 않으려면 취소를 누르세요."
},
"unlistedCheck": {
"message": "일부 공개/비공개 영상 무시"
},
"whatUnlistedCheck": {
"message": "이 설정은 SponsorBlock을 약간 느리게 만듭니다. 건너뛰기 부분 질의는 서버에 영상 ID를 전송해야 합니다. 목록에 없는 영상 ID가 인터넷으로 전송되는 것이 우려된다면 이 옵션을 활성화 해주세요."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "이제 m.youtube.com 링크를 지원합니다" "message": "이제 m.youtube.com 링크를 지원합니다"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "채널 ID가 로드되지 않았습니다." "message": "채널 ID가 로드되지 않았습니다."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "무언가가 SponsorBlock의 영상 데이터 수집을 막고 있는 것으로 보입니다. 이것은 광고 차단기로 인해 그럴 가능성이 있습니다. https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests 사이트를 참조하세요" "message": "무언가가 SponsorBlock의 동영상 데이터 수집을 막고 있는 것 같습니다. https://github.com/ajayyy/SponsorBlock/issues/741 사이트를 참조하세요."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "이 문제를 해결할 수 없는 경우, SponsorBlock이 이 동영상에 대한 보이는 정보를 찾을 수 없으므로 '일부 공개/비공개 동영상 무시' 설정을 꺼주십시오." "message": "SponsorBlock이 YouTube API에 접근할 수 없는 것으로 보입니다. 이 문제를 해결하려면, 다음에 뜨는 권한 창에서 권한을 허용해주시고 잠시 기다린 뒤, 페이지를 새로고침하십시오."
},
"acceptPermission": {
"message": "권한 허용"
},
"permissionRequestSuccess": {
"message": "권한 요청에 성공했습니다!"
},
"permissionRequestFailed": {
"message": "권한 요청에 실패했습니다. 거부를 누르셨나요?"
},
"adblockerIssueWhitelist": {
"message": "이 문제를 해결할 수 없는 경우, SponsorBlock이 이 동영상에 대한 채널 정보를 찾을 수 없으므로 '건너뛰기 전 채널 강제 체크' 설정을 꺼주십시오."
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "오류가 지속된다면, 광고 차단기로 인해 발생할 수 있습니다. https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests 사이트를 참조하세요" "message": "오류가 지속된다면, 광고 차단기로 인해 발생할 수 있습니다. https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests 사이트를 참조하세요"

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "ഇത് പുന reset സജ്ജമാക്കാൻ നിങ്ങൾ ആഗ്രഹിക്കുന്നുണ്ടോ?" "message": "ഇത് പുന reset സജ്ജമാക്കാൻ നിങ്ങൾ ആഗ്രഹിക്കുന്നുണ്ടോ?"
}, },
"confirmPrivacy": {
"message": "വീഡിയോ ലിസ്റ്റുചെയ്യാത്തതായി കണ്ടെത്തി. ഒഴിവാക്കൽ സെഗ്‌മെന്റുകൾ പരിശോധിക്കാൻ നിങ്ങൾ ആഗ്രഹിക്കുന്നില്ലെങ്കിൽ റദ്ദാക്കുക ക്ലിക്കുചെയ്യുക."
},
"unlistedCheck": {
"message": "ലിസ്റ്റുചെയ്യാത്ത / സ്വകാര്യ വീഡിയോകൾ അവഗണിക്കുക"
},
"whatUnlistedCheck": {
"message": "ഈ ക്രമീകരണം സ്പോൺസർബ്ലോക്കിനെ ചെറുതായി മന്ദഗതിയിലാക്കും. സെഗ്‌മെന്റ് തിരയലുകൾ ഒഴിവാക്കുക സെർവറിലേക്ക് വീഡിയോ ഐഡി അയയ്‌ക്കേണ്ടതുണ്ട്. ലിസ്റ്റുചെയ്യാത്ത വീഡിയോ ഐഡികൾ ഇൻറർനെറ്റിലൂടെ അയയ്ക്കുന്നതിനെക്കുറിച്ച് നിങ്ങൾക്ക് ആശങ്കയുണ്ടെങ്കിൽ, ഈ ഓപ്ഷൻ പ്രാപ്തമാക്കുക."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com ഇപ്പോൾ പിന്തുണയ്ക്കുന്നു" "message": "m.youtube.com ഇപ്പോൾ പിന്തുണയ്ക്കുന്നു"
}, },
@ -591,12 +582,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ചാനൽ ഐഡി ഇതുവരെ ലോഡുചെയ്തിട്ടില്ല." "message": "ചാനൽ ഐഡി ഇതുവരെ ലോഡുചെയ്തിട്ടില്ല."
}, },
"adblockerIssue": {
"message": "വീഡിയോ ഡാറ്റ നേടാനുള്ള സ്പോൺസർബ്ലോക്കിന്റെ കഴിവ് എന്തോ തടയുന്നുവെന്ന് തോന്നുന്നു. ഇത് മിക്കവാറും നിങ്ങളുടെ പരസ്യ ബ്ലോക്കറാണ്. Https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests പരിശോധിക്കുക"
},
"adblockerIssueUnlistedVideosInfo": {
"message": "നിങ്ങൾക്ക് ഇത് പരിഹരിക്കാൻ കഴിയുന്നില്ലെങ്കിൽ, ഈ ലിസ്റ്റിനായുള്ള ദൃശ്യപരത വിവരങ്ങൾ വീണ്ടെടുക്കാൻ സ്പോൺസർബ്ലോക്കിന് കഴിയാത്തതിനാൽ 'ലിസ്റ്റുചെയ്യാത്ത / സ്വകാര്യ വീഡിയോകൾ അവഗണിക്കുക' എന്ന ക്രമീകരണം അപ്രാപ്തമാക്കുക"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "ഇത് സംഭവിച്ചുകൊണ്ടിരിക്കുകയാണെങ്കിൽ, ഇത് നിങ്ങളുടെ പരസ്യ ബ്ലോക്കർ കാരണമാകാം. Https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests പരിശോധിക്കുക" "message": "ഇത് സംഭവിച്ചുകൊണ്ടിരിക്കുകയാണെങ്കിൽ, ഇത് നിങ്ങളുടെ പരസ്യ ബ്ലോക്കർ കാരണമാകാം. Https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests പരിശോധിക്കുക"
}, },

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Adakah anda pasti mahu menetapkan semula ini?" "message": "Adakah anda pasti mahu menetapkan semula ini?"
}, },
"confirmPrivacy": {
"message": "Video tersebut dikesan sebagai tidak tersenarai. Klik batal jika anda tidak mahu memeriksa segmen langkau."
},
"unlistedCheck": {
"message": "Abaikan Video Tidak Tersenarai / Peribadi"
},
"whatUnlistedCheck": {
"message": "Tetapan ini sedikit melambatkan SponsorBlock. Skip segmen carian memerlukan penghantaran ID video ke pelayan. Sekiranya anda bimbang tentang ID video yang tidak tersenarai dihantar melalui internet, aktifkan pilihan ini."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com kini disokong" "message": "m.youtube.com kini disokong"
}, },
@ -591,12 +582,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID Saluran belum dimuat." "message": "ID Saluran belum dimuat."
}, },
"adblockerIssue": {
"message": "Nampaknya ada sesuatu yang menyekat kemampuan SponsorBlock untuk mendapatkan data video. Ini mungkin penyekat iklan anda. Sila periksa https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
},
"adblockerIssueUnlistedVideosInfo": {
"message": "Sekiranya anda tidak dapat menyelesaikannya, maka matikan tetapan 'Abaikan video tidak tersenarai / peribadi', kerana SponsorBlock tidak dapat mengambil maklumat keterlihatan untuk video ini"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Sekiranya ini terus berlaku, ini mungkin disebabkan oleh penyekat iklan anda. Sila periksa https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Sekiranya ini terus berlaku, ini mungkin disebabkan oleh penyekat iklan anda. Sila periksa https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Segment eindigt nu" "message": "Segment eindigt nu"
}, },
"sponsorCancel": {
"message": "Segment aanmaken annuleren"
},
"noVideoID": { "noVideoID": {
"message": "Geen YouTube-video gevonden.\nVernieuw het tabblad als dit onjuist is." "message": "Geen YouTube-video gevonden.\nVernieuw het tabblad als dit onjuist is."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Weet u zeker dat u dit wilt herstellen?" "message": "Weet u zeker dat u dit wilt herstellen?"
}, },
"confirmPrivacy": {
"message": "De video is als onvermeld gedetecteerd. Klik op annuleren als u niet wilt controleren op segmenten om over te slaan."
},
"unlistedCheck": {
"message": "Onvermelde/privé-video's negeren"
},
"whatUnlistedCheck": {
"message": "Deze instelling zal SponsorBlock iets vertragen. Opzoeken van segmenten om over te slaan vereist het versturen van de video-ID naar de server. Schakel deze optie in als u bezorgd bent over het versturen van ID's van onvermelde video's via internet."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com wordt nu ondersteund" "message": "m.youtube.com wordt nu ondersteund"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "Kanaal-ID is nog niet geladen." "message": "Kanaal-ID is nog niet geladen."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Het lijkt erop dat iets de mogelijkheid van SponsorBlock om videogegevens te krijgen blokkeert. Dit is waarschijnlijk uw reclamefilter. Zie https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocks-Requests" "message": "Het lijkt erop dat iets de mogelijkheid van SponsorBlock om videogegevens op te halen, blokkeert. Zie https://github.com/ajayyy/SponsorBlock/issues/741 voor meer informatie."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Als u dit niet kunt oplossen, schakel dan de instelling 'onvermelde/privé-video's negeren' uit omdat SponsorBlock niet in staat is de zichtbaarheidsinformatie voor deze video op te halen" "message": "Het lijkt erop dat SponsorBlock de YouTube API niet kan bereiken. Om dit op te lossen, accepteer het machtigingsverzoek dat hierna wordt weergegeven, wacht een aantal seconden en laad de pagina vervolgens opnieuw."
},
"acceptPermission": {
"message": "Machtiging accepteren"
},
"permissionRequestSuccess": {
"message": "Verzoek om machtiging gelukt!"
},
"permissionRequestFailed": {
"message": "Verzoek om machtiging mislukt. Heeft u op geweigerd geklikt?"
},
"adblockerIssueWhitelist": {
"message": "Als u dit niet kunt oplossen, schakel dan de instelling 'kanaalcontrole forceren vóór overslaan' uit omdat SponsorBlock niet in staat is de kanaalinformatie voor deze video op te halen"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Als dit blijft optreden, kan dit worden veroorzaakt door uw reclamefilter. Zie https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Als dit blijft optreden, kan dit worden veroorzaakt door uw reclamefilter. Zie https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Er du sikker på at du vil tilbakestille dette?" "message": "Er du sikker på at du vil tilbakestille dette?"
}, },
"confirmPrivacy": {
"message": "Denne videoen har blitt oppdaget å være uoppført. Klikk Avbryt hvis du ikke vil se etter hoppesegmenter."
},
"unlistedCheck": {
"message": "Ignorer uoppførte/private videoer"
},
"whatUnlistedCheck": {
"message": "Denne innstillingen vil gjøre SponsorBlock marginalt tregere. Å se etter segmenter å hoppe over, krever å sende inn video-ID-en til tjeneren. Hvis du er bekymret for at uoppførte video-ID-er blir sendt over internettet, skru på denne innstillingen."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com er nå støttet" "message": "m.youtube.com er nå støttet"
}, },
@ -591,11 +582,17 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "Kanal-ID-en er ikke lastet inn enda." "message": "Kanal-ID-en er ikke lastet inn enda."
}, },
"adblockerIssue": { "youtubePermissionRequest": {
"message": "Det ser ut som noe blokkerer SponsorBlock sin evne til å innhente videodata. Det er sannsynligvis reklameblokkereren din. Vennligst sjekk https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Det ser ut til at SponsorBlock ikke klarer å nå YouTube-API-en. For å fikse dette, godta tillatelsesspørringen som dukker opp etter dette, vent noen sekunder, og så last inn siden på nytt."
}, },
"adblockerIssueUnlistedVideosInfo": { "acceptPermission": {
"message": "Hvis du ikke klarer å løse dette, skru av innstillingen «Ignorer uoppførte/private videoer», siden SponsorBlock er ute av stand til å innhente synlighetsinformasjonen til denne videoen." "message": "Godta tillatelse"
},
"permissionRequestSuccess": {
"message": "Tillatelsesforespørselen lyktes!"
},
"permissionRequestFailed": {
"message": "Tillatelsesforespørselen mislyktes, klikket du på Avvis?"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Hvis dette skjer til stadighet, kan det være forårsaket av reklameblokkereren din. Vennligst sjekk https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Hvis dette skjer til stadighet, kan det være forårsaket av reklameblokkereren din. Vennligst sjekk https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -125,7 +125,7 @@
"message": "Zgłoszenia" "message": "Zgłoszenia"
}, },
"savedPeopleFrom": { "savedPeopleFrom": {
"message": "Oszczędzono innym " "message": "Oszczędziłeś innym "
}, },
"viewLeaderboard": { "viewLeaderboard": {
"message": "Ranking" "message": "Ranking"
@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Czy na pewno chcesz to zresetować?" "message": "Czy na pewno chcesz to zresetować?"
}, },
"confirmPrivacy": {
"message": "Ten film został wykryty jako niepubliczny. Kliknij Anuluj, jeśli nie chcesz sprawdzać, czy są dla niego segmenty."
},
"unlistedCheck": {
"message": "Ignoruj niepubliczne/prywatne filmy"
},
"whatUnlistedCheck": {
"message": "Ta opcja spowolni nieco SponsorBlock. Wyszukiwanie istniejących segmentów wymaga wysłania ID filmu do serwera. Jeśli niepokoi Cię fakt wysyłania przez internet ID niepublicznych filmów, włącz tę opcję."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com jest teraz wspierany" "message": "m.youtube.com jest teraz wspierany"
}, },
@ -591,11 +582,17 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID kanału nie zostało póki co załadowane." "message": "ID kanału nie zostało póki co załadowane."
}, },
"adblockerIssue": { "youtubePermissionRequest": {
"message": "Wygląda na to, że coś blokuje możliwość pobierania danych o filmach przez SponsorBlock. To prawdopodobnie Twój ad blocker. Sprawdź proszę https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Wygląda na to, że SponsorBlock nie jest w stanie połączyć się z API YouTube. Aby to naprawić, zaakceptuj monit o pozwolenie, który pojawi się za chwilę, odczekaj kilka sekund, a następnie odśwież stronę."
}, },
"adblockerIssueUnlistedVideosInfo": { "acceptPermission": {
"message": "Jeżeli nie możesz naprawić tego to wyłącz w ustawieniach opcję \"Ignoruj prywatne filmy\", ponieważ SponsorBlock nie może uzyskać informacji o widoczności tego filmu" "message": "Zaakceptuj uprawnienie"
},
"permissionRequestSuccess": {
"message": "Uzyskano uprawnienia!"
},
"permissionRequestFailed": {
"message": "Prośba odrzucona. Może kliknięto „Odmów”?"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Jeśli ten problem się powtarza, możliwą przyczyną jest Twój ad blocker. Sprawdź proszę https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Jeśli ten problem się powtarza, możliwą przyczyną jest Twój ad blocker. Sprawdź proszę https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "O segmento termina agora" "message": "O segmento termina agora"
}, },
"sponsorCancel": {
"message": "Cancelar Criação de Segmento"
},
"noVideoID": { "noVideoID": {
"message": "Nenhum vídeo do YouTube encontrado.\nSe isto estiver incorreto, atualize a aba." "message": "Nenhum vídeo do YouTube encontrado.\nSe isto estiver incorreto, atualize a aba."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Tem certeza que deseja redefinir?" "message": "Tem certeza que deseja redefinir?"
}, },
"confirmPrivacy": {
"message": "O vídeo foi detectado como não listado. Clique em cancelar se você não deseja verificar se há segmentos pulados."
},
"unlistedCheck": {
"message": "Ignorar vídeos não listados/privados"
},
"whatUnlistedCheck": {
"message": "Esta configuração diminuirá um pouco o desempenho do SponsorBlock. As pesquisas do segmento exigem que se envie o ID do vídeo para o servidor. Se você estiver preocupado com o envio de IDs de vídeo não listados pela internet, habilite essa opção."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com agora é suportado" "message": "m.youtube.com agora é suportado"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID do canal ainda não carregado." "message": "ID do canal ainda não carregado."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Parece que algo está bloqueando o SponsorBlock de obter dados de vídeo. Isso é provavelmente o seu bloqueador de anúncios. Por favor, verifique https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock-Requests" "message": "Parece que algo está bloqueando a habilidade do SponsorBlock de obter dados de vídeo. Por favor, veja https://github.com/ajayyy/SponsorBlock/issues/741 para mais informações."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Se você não consegue resolver isso, desative a configuração 'Ignorar vídeos não listados/privados', pois o SponsorBlock não pode recuperar as informações de visibilidade deste vídeo" "message": "Parece que o SponsorBlock é incapaz de acessar a API do YouTube. Para corrigir isso, aceite a permissão do prompt que aparecerá a seguir, espere alguns segundos e recarregue a página."
},
"acceptPermission": {
"message": "Aceitar permissão"
},
"permissionRequestSuccess": {
"message": "Solicitação de permissão bem-sucedida!"
},
"permissionRequestFailed": {
"message": "Falha na solicitação de permissão. Você clicou em negar?"
},
"adblockerIssueWhitelist": {
"message": "Se você não consegue resolver isso, desative a configuração 'Forçar Verificação do Canal Antes de Pular', pois o SponsorBlock não pode recuperar as informações deste vídeo"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Se isso continuar acontecendo, pode ser causado pelo seu bloqueador de anúncios. Por favor, verifique https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock-Requests" "message": "Se isso continuar acontecendo, pode ser causado pelo seu bloqueador de anúncios. Por favor, verifique https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock-Requests"

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Sunteți sigur că doriți să resetați asta?" "message": "Sunteți sigur că doriți să resetați asta?"
}, },
"confirmPrivacy": {
"message": "Acest videoclip a fost detectat ca nelistat. Faceți clic pe anulați dacă nu doriți să verificați segmentele de sărire."
},
"unlistedCheck": {
"message": "Ignoră Videoclipurile Nelistate/Private"
},
"whatUnlistedCheck": {
"message": "Această setare va încetini puțin SponsorBlock. Căutările segmentelor de sărire necesită trimiterea ID-ului videoclipului către server. Dacă sunteți îngrijorat de trimiterea ID-ul videoclipurilor nelistate, activați această opțiune."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com este acum suportat" "message": "m.youtube.com este acum suportat"
}, },
@ -588,9 +579,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID-ul Canalului nu a fost încărcat încă." "message": "ID-ul Canalului nu a fost încărcat încă."
}, },
"adblockerIssue": {
"message": "Se pare că ceva blocheaza abilitatea extensiei SponsorBlock pentru a obține datele videoclipului. Cel mai probabil este adblocker-ul dumneavoastră. Vă rugăm să verificați https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Dacă acest lucru continuă să se întample, ar putea fi cauzat de adblocker-ul dumneavoastră. Vă rugăm să verificați \nhttps://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Dacă acest lucru continuă să se întample, ar putea fi cauzat de adblocker-ul dumneavoastră. Vă rugăm să verificați \nhttps://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Сегмент заканчивается здесь" "message": "Сегмент заканчивается здесь"
}, },
"sponsorCancel": {
"message": "Отменить создание сегмента"
},
"noVideoID": { "noVideoID": {
"message": "Видео YouTube не найдено.\nЕсли это не так, обновите вкладку." "message": "Видео YouTube не найдено.\nЕсли это не так, обновите вкладку."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Вы действительно хотите это сбросить?" "message": "Вы действительно хотите это сбросить?"
}, },
"confirmPrivacy": {
"message": "Было обнаружено, что это видео - с доступом по ссылке. Нажмите \"отмена\", если не хотите проверять для него сегменты."
},
"unlistedCheck": {
"message": "Игнорировать непубличные видео"
},
"whatUnlistedCheck": {
"message": "Эта настройка незначительно замедлит SponsorBlock. Поиск сегментов требует отправки идентификатора видео на сервер. Если Вас беспокоит отправка идентификаторов скрытых видео по интернету, включите эту настройку."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com теперь поддерживается" "message": "m.youtube.com теперь поддерживается"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID канала еще не загружен." "message": "ID канала еще не загружен."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Кажется, что-то блокирует возможность SponsorBlock'а получать данные о видео. Возможно, это ваш блокировщик рекламы. Пожалуйста, перейдите на https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocker-Blocking-SponsorBlock's-Requests" "message": "Похоже, что-то блокирует возможность SponsorBlock'а получать данные о видео. Подробнее: https://github.com/ajayyy/SponsorBlock/issues/741."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Если вы не можете решить эту проблему, попробуйте отключить \"Игнорировать непубличные видео\" в настройках, т. к. SponsorBlock не может получить настройки доступа этого видео" "message": "Кажется, SponsorBlock не может получить доступ к API YouTube. Чтобы исправить эту ошибку, дайте разрешение в окне, которое сейчас появится, подождите несколько секунд и затем перезагрузите страницу."
},
"acceptPermission": {
"message": "Дать разрешение"
},
"permissionRequestSuccess": {
"message": "Разрешение получено!"
},
"permissionRequestFailed": {
"message": "Не удалось получить разрешение, вы нажали на \"Блокировать\"?"
},
"adblockerIssueWhitelist": {
"message": "Если вы не можете решить эту проблему, попробуйте отключить \"Принудительная проверка каналов перед пропуском\" в настройках, т. к. SponsorBlock не может определить название канала для этого видео"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Если это сообщения появляется слишком часто, это может быть вызвано вашим блокировщиком рекламы. Пожалуйста, перейдите на https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Если это сообщения появляется слишком часто, это может быть вызвано вашим блокировщиком рекламы. Пожалуйста, перейдите на https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Koniec segmentu" "message": "Koniec segmentu"
}, },
"sponsorCancel": {
"message": "Zrušiť vytváranie segmentu"
},
"noVideoID": { "noVideoID": {
"message": "Nenašlo sa žiadne YouTube video.\nAk je to chyba, obnovte záložku." "message": "Nenašlo sa žiadne YouTube video.\nAk je to chyba, obnovte záložku."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Naozaj to chcete obnoviť?" "message": "Naozaj to chcete obnoviť?"
}, },
"confirmPrivacy": {
"message": "Toto video je nezaradené. Ak nechcete skontrolovať preskočiteľné segmenty, stlačte Zrušiť."
},
"unlistedCheck": {
"message": "Ignorovať nezaradené a súkromné videá"
},
"whatUnlistedCheck": {
"message": "Toto nastavenie mierne spomalí SponsorBlock. Vyhľadávanie segmentov na preskočenie si vyžaduje odoslanie ID videa na server. Ak si nie ste istí odosielaním ID nezaradených videí cez internet, tak toto nastavenie zapnite."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "už je podporované aj m.youtube.com" "message": "už je podporované aj m.youtube.com"
}, },
@ -591,23 +585,35 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID kanála nie je zatiaľ načítané." "message": "ID kanála nie je zatiaľ načítané."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Zdá sa, že niečo blokuje SponsorBlocku možnosť získať dáta o videu. Pravdepodobne to bude Váš adblocker. Prosím navštívte https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Zdá sa, že niečo blokuje SponsorBlocku možnosť získať dáta o videu. Prosím navštívte https://github.com/ajayyy/SponsorBlock/issues/741 pre viac informácií."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Ak to neviete vyriešiť, vypnite nastavenie \"Ignorovať nezaradené a súkromné videá\", lebo SponsorBlock nevie zistiť viditeľnosť tohto videa" "message": "SponsorBlock nemá prístup k YouTube API. Povoľte oprávnenie v nasledovnej výzve, počkajte pár sekúnd a znovu nahrajte stránku."
},
"acceptPermission": {
"message": "Povoľte oprávnenie"
},
"permissionRequestSuccess": {
"message": "Oprávnenie bolo úspešne povolené!"
},
"permissionRequestFailed": {
"message": "Povolenie oprávnenia zlyhalo, stlačili ste odmietnuť?"
},
"adblockerIssueWhitelist": {
"message": "Ak to neviete vyriešiť, vypnite nastavenie \"Vynútiť kontrolu kanála pred preskočením\", lebo SponsorBlock nevie zistiť informácie o kanále tohto videa"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Ak sa to bude diať aj naďalej, môže to byť spôsobené Vašim adblockerom. Prosím navštívte https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Ak sa to bude diať aj naďalej, môže to byť spôsobené Vašim adblockerom. Prosím navštívte https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },
"forceChannelCheck": { "forceChannelCheck": {
"message": "Vynútiť Kontrolu Kanála Pred Preskočením" "message": "Vynútiť kontrolu kanála pred preskočením"
}, },
"whatForceChannelCheck": { "whatForceChannelCheck": {
"message": "V predvolenom nastavení sa preskočia segmenty hneď bez kontroly kanálu. V predvolenom nastavení môžu byť niektoré segmenty na začiatku videa na kanáloch pridaných na whitelist preskočené. Povolením tejto možnosti tomu zabránite, ale všetky preskakovania budú mať mierne oneskorenie, pretože získanie ID kanála môže chvíľu trvať. Toto oneskorenie nemusí byť viditeľné, ak máte rýchly internet." "message": "V predvolenom nastavení sa preskočia segmenty hneď bez kontroly kanálu. V predvolenom nastavení môžu byť niektoré segmenty na začiatku videa na kanáloch pridaných na whitelist preskočené. Povolením tejto možnosti tomu zabránite, ale všetky preskakovania budú mať mierne oneskorenie, pretože získanie ID kanála môže chvíľu trvať. Toto oneskorenie nemusí byť viditeľné, ak máte rýchly internet."
}, },
"forceChannelCheckPopup": { "forceChannelCheckPopup": {
"message": "Zvážte Povolenie \"Vynútiť Kontrolu Kanála Pred Preskočením\"" "message": "Zvážte povolenie \"Vynútiť kontrolu kanála pred preskočením\""
}, },
"downvoteDescription": { "downvoteDescription": {
"message": "Nesprávne/Zlé načasovanie" "message": "Nesprávne/Zlé načasovanie"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "Segmentet slutar nu" "message": "Segmentet slutar nu"
}, },
"sponsorCancel": {
"message": "Avbryt skapandet av segmentet"
},
"noVideoID": { "noVideoID": {
"message": "Hittade ingen YouTube-video.\nUppdatera fliken om detta är felaktigt." "message": "Hittade ingen YouTube-video.\nUppdatera fliken om detta är felaktigt."
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Är du säker på att du vill rensa?" "message": "Är du säker på att du vill rensa?"
}, },
"confirmPrivacy": {
"message": "Den här videon verkar vara olistad. Klicka på avbryt om du inte vill söka efter överhoppade segment."
},
"unlistedCheck": {
"message": "Ignorera olistade/privata videor"
},
"whatUnlistedCheck": {
"message": "Den här inställningen kommer att slöa ner SponsorBlock. Segmentöverhoppssökningar kräver att video-ID skickas till servern. Om du är orolig över att olistade video-ID:s skickas över internet, aktivera då detta alternativ."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com stöds nu" "message": "m.youtube.com stöds nu"
}, },
@ -591,11 +585,23 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "Kanal-ID är inte inladdat än." "message": "Kanal-ID är inte inladdat än."
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "Det verkar som om något blockerar SponsorBlocks från att hämta videodata. Det beror förmodligen på din annonsblockerare. Vänligen kontrollera https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Det verkar som om något blockerar SponsorBlock från att hämta videodata. Gå till https://github.com/ajayyy/SponsorBlock/issues/741 för mer info."
}, },
"adblockerIssueUnlistedVideosInfo": { "youtubePermissionRequest": {
"message": "Om du inte kan lösa detta kan du inaktivera 'Ignorera olistade/privata videor' i inställningar, eftersom SponsorBlock inte kan hämta synlighetsinformationen för den här videon" "message": "Det verkar som att SponsorBlock inte kan nå YouTube-API:t. För att åtgärda problemet ska du acceptera behörighetsfrågan som visas härnäst och vänta några sekunder och sedan ladda om sidan."
},
"acceptPermission": {
"message": "Godkänn behörighet"
},
"permissionRequestSuccess": {
"message": "Behörighet godkänd!"
},
"permissionRequestFailed": {
"message": "Behörighetsbegäran misslyckades, tryckte du på förneka?"
},
"adblockerIssueWhitelist": {
"message": "Om du inte kan lösa detta kan du inaktivera 'Tvinga kontroll av kanalen innan hoppa över' i inställningarna, eftersom SponsorBlock inte kan hämta kanalinformationen för den här videon"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Om detta fortsätter att inträffa, kan orsaken vara din annonsblockerare. Vänligen kontrollera https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Om detta fortsätter att inträffa, kan orsaken vara din annonsblockerare. Vänligen kontrollera https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "இதை மீட்டமைக்க விரும்புகிறீர்களா?" "message": "இதை மீட்டமைக்க விரும்புகிறீர்களா?"
}, },
"confirmPrivacy": {
"message": "வீடியோ பட்டியலிடப்படாதது என கண்டறியப்பட்டுள்ளது. பகுதிகளைத் தவிர்க்க நீங்கள் விரும்பவில்லை எனில் ரத்துசெய் என்பதைக் கிளிக் செய்க."
},
"unlistedCheck": {
"message": "பட்டியலிடப்படாத / தனிப்பட்ட வீடியோக்களை புறக்கணிக்கவும்"
},
"whatUnlistedCheck": {
"message": "இந்த அமைப்பு ஸ்பான்சர் பிளாக் சற்று மெதுவாக்கும். பிரிவு தேடல்களைத் தவிர் சேவையகத்திற்கு வீடியோ ஐடியை அனுப்ப வேண்டும். பட்டியலிடப்படாத வீடியோ ஐடிகள் இணையத்தில் அனுப்பப்படுவது குறித்து நீங்கள் கவலைப்பட்டால், இந்த விருப்பத்தை இயக்கவும்."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com இப்போது துணைபுரிகிறது" "message": "m.youtube.com இப்போது துணைபுரிகிறது"
}, },
@ -591,12 +582,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "சேனல் ஐடி இன்னும் ஏற்றப்படவில்லை." "message": "சேனல் ஐடி இன்னும் ஏற்றப்படவில்லை."
}, },
"adblockerIssue": {
"message": "வீடியோ தரவைப் பெறுவதற்கான ஸ்பான்சர் பிளாக் திறனை ஏதோ தடுக்கிறது என்று தெரிகிறது. இது உங்கள் விளம்பர தடுப்பாளராக இருக்கலாம். Https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests ஐ சரிபார்க்கவும்"
},
"adblockerIssueUnlistedVideosInfo": {
"message": "இதை நீங்கள் தீர்க்க முடியாவிட்டால், 'பட்டியலிடப்படாத / தனிப்பட்ட வீடியோக்களைப் புறக்கணிக்கவும்' என்ற அமைப்பை முடக்கு, ஏனெனில் இந்த வீடியோவுக்கான தெரிவுநிலை தகவலை ஸ்பான்சர் பிளாக் பெற முடியவில்லை"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "இது தொடர்ந்து நடந்தால், அது உங்கள் விளம்பர தடுப்பாளரால் ஏற்படலாம். Https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests ஐ சரிபார்க்கவும்" "message": "இது தொடர்ந்து நடந்தால், அது உங்கள் விளம்பர தடுப்பாளரால் ஏற்படலாம். Https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests ஐ சரிபார்க்கவும்"
}, },

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "మీరు దీన్ని రీసెట్ చేయాలనుకుంటున్నారా?" "message": "మీరు దీన్ని రీసెట్ చేయాలనుకుంటున్నారా?"
}, },
"confirmPrivacy": {
"message": "వీడియో జాబితా చేయనిదిగా కనుగొనబడింది. మీరు విభాగాలను దాటవేయాలనుకుంటే రద్దు చేయి క్లిక్ చేయండి."
},
"unlistedCheck": {
"message": "జాబితా చేయని / ప్రైవేట్ వీడియోలను విస్మరించండి"
},
"whatUnlistedCheck": {
"message": "ఈ సెట్టింగ్ స్పాన్సర్బ్లాక్‌ను కొద్దిగా నెమ్మదిస్తుంది. సెగ్మెంట్ శోధనను దాటవేయి వీడియో ID ని సర్వర్‌కు పంపడం అవసరం. జాబితా చేయని వీడియో ఐడిలను ఇంటర్నెట్ ద్వారా పంపడం గురించి మీకు ఆందోళన ఉంటే, ఈ ఎంపికను ప్రారంభించండి."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com కి ఇప్పుడు మద్దతు ఉంది" "message": "m.youtube.com కి ఇప్పుడు మద్దతు ఉంది"
}, },
@ -591,12 +582,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ఛానెల్ ID ఇంకా లోడ్ కాలేదు." "message": "ఛానెల్ ID ఇంకా లోడ్ కాలేదు."
}, },
"adblockerIssue": {
"message": "వీడియో డేటాను పొందే స్పాన్సర్బ్లాక్ సామర్థ్యాన్ని ఏదో అడ్డుకుంటున్నట్లు కనిపిస్తోంది. ఇది బహుశా మీ యాడ్ బ్లాకర్. దయచేసి https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests తనిఖీ చేయండి"
},
"adblockerIssueUnlistedVideosInfo": {
"message": "మీరు దీన్ని పరిష్కరించలేకపోతే, స్పాన్సర్బ్లాక్ ఈ వీడియో కోసం దృశ్యమాన సమాచారాన్ని తిరిగి పొందలేకపోతున్నందున, 'జాబితా చేయని / ప్రైవేట్ వీడియోలను విస్మరించండి' సెట్టింగ్‌ను నిలిపివేయండి"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "ఇది జరుగుతూ ఉంటే, అది మీ ప్రకటన బ్లాకర్ వల్ల సంభవించవచ్చు. దయచేసి https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests తనిఖీ చేయండి" "message": "ఇది జరుగుతూ ఉంటే, అది మీ ప్రకటన బ్లాకర్ వల్ల సంభవించవచ్చు. దయచేసి https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests తనిఖీ చేయండి"
}, },

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Bunu sıfırlamak istediğinize emin misiniz?" "message": "Bunu sıfırlamak istediğinize emin misiniz?"
}, },
"confirmPrivacy": {
"message": "Videonun liste dışı olduğu tespit edildi. Atlanan kısımları kontrol etmek istemiyorsanız iptal'i tıklayın."
},
"unlistedCheck": {
"message": "Listedışı/Özel Videoları Görmezden Gel"
},
"whatUnlistedCheck": {
"message": "Bu ayar, SponsorBlock'u biraz yavaşlatacaktır. atlama kısımlarının bulunması için, video kimliğinin sunucuya gönderilmesini gerektirir. Listelenmemiş video kimliklerinin İnternet üzerinden gönderilmesi konusunda endişeleriniz varsa, bu seçeneği etkinleştirin."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com şu an desteklenmektedir" "message": "m.youtube.com şu an desteklenmektedir"
}, },
@ -591,12 +582,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "Kanal kimliği henüz yüklenmedi." "message": "Kanal kimliği henüz yüklenmedi."
}, },
"adblockerIssue": {
"message": "Bir şeyin SponsorBlock'un video bilgisi almasını engelliyor gibi görünüyor. Bu reklam engelleyiciniz olabilir. Lütfen şu adresi kontrol edin https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
},
"adblockerIssueUnlistedVideosInfo": {
"message": "Bunu çözümleyemiyorsanız \"Liste dışı/gizli videoları göz ardı et\" seçeneğini kapatın, SponsorBlock bu videonun gizlilik bilgisini alamıyor"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Bunu sürekli yaşıyorsanız, reklam engelleyiciniz tarafından gerçekleşiyor olabilir. https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests adresini kontrol edin." "message": "Bunu sürekli yaşıyorsanız, reklam engelleyiciniz tarafından gerçekleşiyor olabilir. https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests adresini kontrol edin."
}, },

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Ви дійсно хочете це скинути?" "message": "Ви дійсно хочете це скинути?"
}, },
"confirmPrivacy": {
"message": "Було виявлено, що це відео - з доступом по посиланню. Натисніть \"скасування\", якщо не хочете перевіряти для нього сегменти."
},
"unlistedCheck": {
"message": "Ігнорувати непублічні відео"
},
"whatUnlistedCheck": {
"message": "Це налаштування дещо сповільнить SponsorBlock. Пошук сегментів вимагає надсилання ідентифікатора відео на сервер. Якщо Вас турбує надсилання ідентифікаторів прихованих відео по інтернету, включіть це налаштування."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com тепер підтримується" "message": "m.youtube.com тепер підтримується"
}, },
@ -591,12 +582,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "ID каналу ще не завантажений." "message": "ID каналу ще не завантажений."
}, },
"adblockerIssue": {
"message": "Здається, щось блокує можливість SponsorBlock'а отримувати дані про відео. Можливо, це ваш блокувальник реклами. Будь ласка, перейдіть на https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocker-Blocking-SponsorBlock's-Requests"
},
"adblockerIssueUnlistedVideosInfo": {
"message": "Якщо вам не вдалося вирішити це, вимкніть параметр \"Ігнорувати непублічні відео\", оскільки SponsorBlock не в змозі отримати інформацію про видимість цього відео"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Якщо це повідомлення з'являється занадто часто, це може бути викликано вашим блокувальником реклами. Будь ласка, перейдіть на https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Якщо це повідомлення з'являється занадто часто, це може бути викликано вашим блокувальником реклами. Будь ласка, перейдіть на https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },

View file

@ -404,15 +404,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "Bạn có chắc mình muốn thiết lập lại không?" "message": "Bạn có chắc mình muốn thiết lập lại không?"
}, },
"confirmPrivacy": {
"message": "Video này là video không công khai. Ấn hủy nếu bạn không muốn tìm xem có đoạn quảng cáo không."
},
"unlistedCheck": {
"message": "Bỏ qua video không công khai/riêng tư"
},
"whatUnlistedCheck": {
"message": "Cài đặt này sẽ làm chậm SponsorBlock một chút. Mã video cần phải được gửi đến máy chủ để truy vấn đoạn quảng cáo. Nếu bạn quan ngại về việc mã video không công khai bị gửi qua mạng, hãy bật tùy chọn này."
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "m.youtube.com đã được hỗ trợ" "message": "m.youtube.com đã được hỗ trợ"
}, },
@ -585,12 +576,6 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "Chưa đọc được ID của kênh." "message": "Chưa đọc được ID của kênh."
}, },
"adblockerIssue": {
"message": "Hình như có gì đó đã ngăn chặn SponsorBlock truy vấn dữ liệu của video. Có thể do trình chặn quảng cáo của bạn. Hãy kiểm tra ở đây: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
},
"adblockerIssueUnlistedVideosInfo": {
"message": "Nếu bạn không thể giải quyết được vấn đề này, hãy vô hiệu hoá cài đặt 'Bỏ qua video không công khai/riêng tư', vì SponsorBlock không thể lấy được thông tin hiển thị của video này"
},
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "Nếu lỗi này tiếp tục xuất hiện, nó có thể là do trình chặn quảng cáo của bạn. Hãy kiểm tra ở đây: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "Nếu lỗi này tiếp tục xuất hiện, nó có thể là do trình chặn quảng cáo của bạn. Hãy kiểm tra ở đây: https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"
}, },

View file

@ -407,15 +407,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "您确定要重置它吗?" "message": "您确定要重置它吗?"
}, },
"confirmPrivacy": {
"message": "检测到此视频为未公开列出视频。如果您不想进行跳过片段开始,请点击取消。"
},
"unlistedCheck": {
"message": "忽略未找到记录的视频"
},
"whatUnlistedCheck": {
"message": "此设置将略微减慢 SponsorBlock 的速度。查询可跳过片段时需要向服务器发送视频 ID。如果您对通过互联网发送不公开列出视频的 ID 有疑虑,请启用此选项。"
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "现已支持 m.youtube.com" "message": "现已支持 m.youtube.com"
}, },
@ -591,11 +582,11 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "频道 ID 尚未加载。" "message": "频道 ID 尚未加载。"
}, },
"adblockerIssue": { "acceptPermission": {
"message": "似乎某些东西正在阻止 SponsorBlock 获取视频数据的功能。它很可能是您的广告拦截器。请查看 https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "接受权限"
}, },
"adblockerIssueUnlistedVideosInfo": { "permissionRequestSuccess": {
"message": "如果您无法解决这个问题,请禁用“忽略未公开列出/私有视频”设置,因为 SpongorBlock 无法检索此视频是否可见" "message": "权限请求成功!"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "如果这种情况不断发生,它可能是由您的广告拦截器引起的。请查看 https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "如果这种情况不断发生,它可能是由您的广告拦截器引起的。请查看 https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -79,6 +79,9 @@
"sponsorEnd": { "sponsorEnd": {
"message": "片段現在結束" "message": "片段現在結束"
}, },
"sponsorCancel": {
"message": "取消創建片段"
},
"noVideoID": { "noVideoID": {
"message": "找不到 YouTube 影片。\n如果這是不正確的重新整理此分頁" "message": "找不到 YouTube 影片。\n如果這是不正確的重新整理此分頁"
}, },
@ -407,15 +410,6 @@
"areYouSureReset": { "areYouSureReset": {
"message": "您確定要重製這個嗎?" "message": "您確定要重製這個嗎?"
}, },
"confirmPrivacy": {
"message": "此影片已被偵測為未列出。點擊取消以不檢查跳過片段"
},
"unlistedCheck": {
"message": "忽略私人/未列出的影片"
},
"whatUnlistedCheck": {
"message": "此設定會微微降低 SponsorBlock 的速度。跳過片段檢查會需要將影片 ID 送到伺服器。如果您對將未列出的影片被流出的話,啟用這個選項"
},
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "現已支援 m.youtube.com" "message": "現已支援 m.youtube.com"
}, },
@ -588,11 +582,20 @@
"channelDataNotFound": { "channelDataNotFound": {
"message": "頻道 ID 尚未載入" "message": "頻道 ID 尚未載入"
}, },
"adblockerIssue": { "videoInfoFetchFailed": {
"message": "似乎某些東西正在阻止 SponsorBlock 獲取影片資料的功能。它很可能是您的廣告攔截器。請查看 https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "似乎有東西在阻止 SponsorBlock 獲取影片資料。請查看 https://github.com/ajayyy/SponsorBlock/issues/741 以了解更多資訊。"
}, },
"adblockerIssueUnlistedVideosInfo": { "acceptPermission": {
"message": "如果您沒辦法解決這個問題,請停用\"忽略私人或不公開影片\",因為 SponsorBlock 無法獲取這部影片的可見性資料。" "message": "允許權限"
},
"permissionRequestSuccess": {
"message": "成功允許權限!"
},
"permissionRequestFailed": {
"message": "允許權限失敗,您是不是按到拒絕了?"
},
"adblockerIssueWhitelist": {
"message": "如果您沒辦法解決這個問題,請停用\"強制在跳過前檢查頻道\",因為 SponsorBlock 無法獲取這部影片的頻道資料。"
}, },
"itCouldBeAdblockerIssue": { "itCouldBeAdblockerIssue": {
"message": "如果這種情況不斷發生,它可能是由您的廣告攔截器引起的。請查看 https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests" "message": "如果這種情況不斷發生,它可能是由您的廣告攔截器引起的。請查看 https://github.com/ajayyy/SponsorBlock/wiki/Fix-Ad-Blocker-Blocking-SponsorBlock's-Requests"

View file

@ -42,12 +42,12 @@
<img src="https://i.imgur.com/caf5Bju.png"> <img src="https://i.imgur.com/caf5Bju.png">
</span> </span>
Videos will automatically be skipped if they are found in the database. You can open the popup by clicking the extension icon to get a preview of what they are. Video segments will automatically be skipped if they are found in the database. You can open the popup by clicking the extension icon to get a preview of what they are.
<br/> <br/>
<br/> <br/>
Whenever you skip a video, you will get a notice report that submission. If the timing seems wrong, report it! You can also vote in the popup. The extension auto upvotes it if you don't report it, so make sure to report when necessary (this can be disabled in the options). Whenever you skip a segment, you will get notice. If the timing seems wrong vote down by clicking downvote! You can also vote in the popup.
</p> </p>
<div class="center"><img height="120px" src="https://user-images.githubusercontent.com/12688112/63067735-5a638700-bede-11e9-8147-f321b57527ec.gif"></div> <div class="center"><img height="120px" src="https://user-images.githubusercontent.com/12688112/63067735-5a638700-bede-11e9-8147-f321b57527ec.gif"></div>
@ -81,8 +81,8 @@
<h1>This is too slow</h1> <h1>This is too slow</h1>
<p> <p>
There are hotkeys if you want to use them. You must be focused on the YouTube player to use them. Press the semicolon key to indicate the start/end of a sponsor segment and click the appostrophe to submit. There are hotkeys if you want to use them. You must be focused on the YouTube player to use them. Press the semicolon key to indicate the start/end of a sponsor segment and click the apostrophe to submit.
These can be changed in the options. If you don't use QWERTY, you should probably change the keybinds. These can be changed in the options. If you don't use QWERTY, you should probably change the keybinding.
</p> </p>
<h1>I hate these buttons, they are so ugly</h1> <h1>I hate these buttons, they are so ugly</h1>

View file

@ -0,0 +1,67 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
viewBox="0 0 565.15 568"
version="1.1"
id="svg16"
sodipodi:docname="PlayerCancelSegmentIconSponsorBlocker.svg"
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"
inkscape:export-filename="D:\Dell Data\_Projects\_____SponsorSkip\ignored\svg\SponsorBlocker4.png"
inkscape:export-xdpi="43.436523"
inkscape:export-ydpi="43.436523">
<metadata
id="metadata20">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title>LogoSponsorBlocker2</dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="1001"
id="namedview18"
showgrid="false"
inkscape:zoom="0.83098592"
inkscape:cx="-238.41697"
inkscape:cy="258.22009"
inkscape:window-x="477"
inkscape:window-y="961"
inkscape:window-maximized="1"
inkscape:current-layer="svg16" />
<defs
id="defs4">
<style
id="style2">.cls-1{fill:red;}.cls-2{fill:#fff;}</style>
</defs>
<title
id="title6">LogoSponsorBlocker2</title>
<path
class="cls-1"
d="m 282.58,568 a 65,65 0 0 1 -34.14,-9.66 C 95.41,463.94 2.54,300.46 0,121 a 64.91,64.91 0 0 1 34,-58.09 522.56,522.56 0 0 1 497.16,0 64.91,64.91 0 0 1 34,58.12 c -2.53,179.43 -95.4,342.91 -248.42,437.3 A 65,65 0 0 1 282.58,568 Z m 0,-548.31 A 502.24,502.24 0 0 0 43.4,80.22 45.27,45.27 0 0 0 19.7,120.75 c 2.44,172.67 91.81,330 239.07,420.83 a 46.19,46.19 0 0 0 47.61,0 C 453.64,450.73 543,293.42 545.45,120.75 A 45.26,45.26 0 0 0 521.75,80.21 502.26,502.26 0 0 0 282.58,19.69 Z"
id="path8"
inkscape:connector-curvature="0"
style="fill:#ffffff" />
<path
style="fill:#ffffff"
d="M 284.70508 42.693359 A 479.9 479.9 0 0 0 54.369141 100.41992 A 22.53 22.53 0 0 0 42.669922 120.41992 C 45.069922 290.25992 135.67008 438.63977 270.83008 522.00977 A 22.48 22.48 0 0 0 294.32031 522.00977 C 429.48031 438.63977 520.08047 290.25992 522.48047 120.41992 A 22.53 22.53 0 0 0 510.7793 100.41992 A 479.9 479.9 0 0 0 284.70508 42.693359 z M 224.94922 162.35352 L 282.57422 219.98047 L 340.20117 162.35352 L 384.33984 206.49219 L 326.71484 264.11719 L 384.33984 321.74414 L 340.20117 365.88281 L 282.57422 308.25781 L 224.94922 365.88281 L 180.81055 321.74414 L 238.4375 264.11719 L 180.81055 206.49219 L 224.94922 162.35352 z "
id="path10" />
</svg>

After

Width:  |  Height:  |  Size: 3 KiB

View file

@ -0,0 +1,88 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
viewBox="0 0 565.15 568"
version="1.1"
id="svg16"
sodipodi:docname="PlayerDeleteIconSponsorBlocker.svg"
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"
inkscape:export-filename="D:\Dell Data\_Projects\_____SponsorSkip\ignored\svg\SponsorBlocker4.png"
inkscape:export-xdpi="43.436523"
inkscape:export-ydpi="43.436523">
<metadata
id="metadata20">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title>LogoSponsorBlocker2</dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="1001"
id="namedview18"
showgrid="false"
inkscape:zoom="0.83098592"
inkscape:cx="209.2657"
inkscape:cy="235.85704"
inkscape:window-x="477"
inkscape:window-y="961"
inkscape:window-maximized="1"
inkscape:current-layer="svg16" />
<defs
id="defs4">
<style
id="style2">.cls-1{fill:red;}.cls-2{fill:#fff;}</style>
</defs>
<title
id="title6">LogoSponsorBlocker2</title>
<path
class="cls-1"
d="m 282.58,568 a 65,65 0 0 1 -34.14,-9.66 C 95.41,463.94 2.54,300.46 0,121 a 64.91,64.91 0 0 1 34,-58.09 522.56,522.56 0 0 1 497.16,0 64.91,64.91 0 0 1 34,58.12 c -2.53,179.43 -95.4,342.91 -248.42,437.3 A 65,65 0 0 1 282.58,568 Z m 0,-548.31 A 502.24,502.24 0 0 0 43.4,80.22 45.27,45.27 0 0 0 19.7,120.75 c 2.44,172.67 91.81,330 239.07,420.83 a 46.19,46.19 0 0 0 47.61,0 C 453.64,450.73 543,293.42 545.45,120.75 A 45.26,45.26 0 0 0 521.75,80.21 502.26,502.26 0 0 0 282.58,19.69 Z"
id="path8"
inkscape:connector-curvature="0"
style="fill:#ffffff" />
<path
style="fill:#ffffff"
d="M 284.70508 42.693359 A 479.9 479.9 0 0 0 54.369141 100.41992 A 22.53 22.53 0 0 0 42.669922 120.41992 C 45.069922 290.25992 135.67008 438.63977 270.83008 522.00977 A 22.48 22.48 0 0 0 294.32031 522.00977 C 429.48031 438.63977 520.08047 290.25992 522.48047 120.41992 A 22.53 22.53 0 0 0 510.7793 100.41992 A 479.9 479.9 0 0 0 284.70508 42.693359 z M 184.84375 113.77344 L 380.30664 113.77344 L 380.30664 161.31836 L 184.84375 161.31836 L 184.84375 113.77344 z M 184.84375 174.45703 L 380.30469 174.45703 L 380.30469 430.16992 L 184.84375 430.16992 L 184.84375 174.45703 z "
id="path10" />
<g
id="g849"
transform="matrix(1.1485222,0,0,1.1485222,-41.968703,-56.737897)"
style="fill:#ffffff">
<g
id="g869"
style="fill:#ffffff">
<path
style="fill:#ffffff;fill-opacity:1;stroke:none;stroke-width:0.84762007;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
d="M 223.01024,230.22964 H 245.1343 V 395.01181 H 223.01024 Z"
id="rect857" />
<path
style="fill:#ffffff;fill-opacity:1;stroke:none;stroke-width:0.84762007;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
d="m 271.51297,230.22964 h 22.12406 v 164.78217 h -22.12406 z"
id="rect859" />
<path
style="fill:#ffffff;fill-opacity:1;stroke:none;stroke-width:0.84762007;stroke-miterlimit:4;stroke-dasharray:none;stroke-opacity:1"
d="m 317.46292,230.22964 h 22.12406 v 164.78217 h -22.12406 z"
id="rect861" />
</g>
</g>
</svg>

After

Width:  |  Height:  |  Size: 3.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 KiB

View file

@ -0,0 +1,120 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
viewBox="0 0 565.15 568"
version="1.1"
id="svg16"
sodipodi:docname="PlayerInfoIconSponsorBlocker.svg"
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"
inkscape:export-filename="D:\Dell Data\_Projects\_____SponsorSkip\ignored\svg\SponsorBlocker4.png"
inkscape:export-xdpi="43.436523"
inkscape:export-ydpi="43.436523">
<metadata
id="metadata20">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title>LogoSponsorBlocker2</dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="1001"
id="namedview18"
showgrid="false"
inkscape:zoom="0.83098592"
inkscape:cx="203.60203"
inkscape:cy="226.95062"
inkscape:window-x="477"
inkscape:window-y="961"
inkscape:window-maximized="1"
inkscape:current-layer="svg16" />
<defs
id="defs4">
<style
id="style2">.cls-1{fill:red;}.cls-2{fill:#fff;}</style>
</defs>
<title
id="title6">LogoSponsorBlocker2</title>
<path
class="cls-1"
d="m 282.58,568 a 65,65 0 0 1 -34.14,-9.66 C 95.41,463.94 2.54,300.46 0,121 a 64.91,64.91 0 0 1 34,-58.09 522.56,522.56 0 0 1 497.16,0 64.91,64.91 0 0 1 34,58.12 c -2.53,179.43 -95.4,342.91 -248.42,437.3 A 65,65 0 0 1 282.58,568 Z m 0,-548.31 A 502.24,502.24 0 0 0 43.4,80.22 45.27,45.27 0 0 0 19.7,120.75 c 2.44,172.67 91.81,330 239.07,420.83 a 46.19,46.19 0 0 0 47.61,0 C 453.64,450.73 543,293.42 545.45,120.75 A 45.26,45.26 0 0 0 521.75,80.21 502.26,502.26 0 0 0 282.58,19.69 Z"
id="path8"
inkscape:connector-curvature="0"
style="fill:#ffffff" />
<path
style="fill:#ffffff"
d="M 284.70508 42.693359 A 479.9 479.9 0 0 0 54.369141 100.41992 A 22.53 22.53 0 0 0 42.669922 120.41992 C 45.069922 290.25992 135.67008 438.63977 270.83008 522.00977 A 22.48 22.48 0 0 0 294.32031 522.00977 C 429.48031 438.63977 520.08047 290.25992 522.48047 120.41992 A 22.53 22.53 0 0 0 510.7793 100.41992 A 479.9 479.9 0 0 0 284.70508 42.693359 z M 282.57422 102.03711 C 371.92182 102.03711 444.65625 174.74933 444.65625 264.11719 C 444.65625 353.48504 371.92182 426.19922 282.57422 426.19922 C 193.20636 426.19922 120.49414 353.48504 120.49414 264.11719 C 120.49414 174.74933 193.20636 102.03711 282.57422 102.03711 z M 282.57422 132.42578 C 209.96157 132.42578 150.88281 191.50454 150.88281 264.11719 C 150.88281 336.72984 209.96157 395.80859 282.57422 395.80859 C 355.18687 395.80859 414.26562 336.72984 414.26562 264.11719 C 414.26562 191.50454 355.18687 132.42578 282.57422 132.42578 z M 280.01172 149.12109 C 294.1331 149.12109 304.375 159.72726 304.375 173.16992 C 304.375 186.6531 294.10302 196.60156 279.67773 196.60156 C 264.94855 196.60156 255.32422 186.6531 255.32422 173.16992 C 255.32422 159.72726 264.94824 149.12109 280.01172 149.12109 z M 245.07422 217.8125 L 302.4707 217.8125 L 302.45117 352.50391 L 320.74609 353.47656 L 320.74609 379.11523 L 244.42578 379.11523 L 244.42578 354.74219 L 255.01172 353.78906 C 260.76562 353.15087 264.29102 351.21646 264.29102 343.51758 L 264.29102 254.36328 C 264.29102 247.28233 262.3858 245.04297 256.27734 245.04297 L 245.07422 244.41406 L 245.07422 217.8125 z "
id="path10" />
<g
id="g883"
transform="matrix(10.130113,0,0,10.130113,45.728213,14.587871)"
style="fill:#ffffff">
<g
id="g827"
style="fill:#ffffff" />
<g
id="g829"
style="fill:#ffffff" />
<g
id="g831"
style="fill:#ffffff" />
<g
id="g833"
style="fill:#ffffff" />
<g
id="g835"
style="fill:#ffffff" />
<g
id="g837"
style="fill:#ffffff" />
<g
id="g839"
style="fill:#ffffff" />
<g
id="g841"
style="fill:#ffffff" />
<g
id="g843"
style="fill:#ffffff" />
<g
id="g845"
style="fill:#ffffff" />
<g
id="g847"
style="fill:#ffffff" />
<g
id="g849"
style="fill:#ffffff" />
<g
id="g851"
style="fill:#ffffff" />
<g
id="g853"
style="fill:#ffffff" />
<g
id="g855"
style="fill:#ffffff" />
<g
id="g857"
style="fill:#ffffff" />
</g>
</svg>

After

Width:  |  Height:  |  Size: 4.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 15 KiB

View file

@ -0,0 +1,71 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
viewBox="0 0 565.15 568"
version="1.1"
id="svg16"
sodipodi:docname="PlayerStartIconSponsorBlocker.svg"
inkscape:version="0.92.4 (5da689c313, 2019-01-14)">
<metadata
id="metadata20">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
</cc:Work>
</rdf:RDF>
</metadata>
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="1001"
id="namedview18"
showgrid="false"
inkscape:zoom="0.83098592"
inkscape:cx="-0.3618106"
inkscape:cy="322.44266"
inkscape:window-x="477"
inkscape:window-y="961"
inkscape:window-maximized="1"
inkscape:current-layer="Layer_1-2" />
<defs
id="defs4">
<style
id="style2">.cls-1{fill:red;}.cls-2{fill:#fff;}</style>
</defs>
<title
id="title6">LogoSponsorBlocker2</title>
<g
id="Layer_2"
data-name="Layer 2">
<g
id="Layer_1-2"
data-name="Layer 1"
style="fill:#ffffff">
<path
class="cls-1"
d="M282.58,568a65,65,0,0,1-34.14-9.66C95.41,463.94,2.54,300.46,0,121A64.91,64.91,0,0,1,34,62.91a522.56,522.56,0,0,1,497.16,0,64.91,64.91,0,0,1,34,58.12c-2.53,179.43-95.4,342.91-248.42,437.3A65,65,0,0,1,282.58,568Zm0-548.31A502.24,502.24,0,0,0,43.4,80.22a45.27,45.27,0,0,0-23.7,40.53c2.44,172.67,91.81,330,239.07,420.83a46.19,46.19,0,0,0,47.61,0C453.64,450.73,543,293.42,545.45,120.75a45.26,45.26,0,0,0-23.7-40.54A502.26,502.26,0,0,0,282.58,19.69Z"
id="path8"
style="fill:#ffffff" />
<path
style="fill:#ffffff"
d="M 284.70508 42.693359 A 479.9 479.9 0 0 0 54.369141 100.41992 A 22.53 22.53 0 0 0 42.669922 120.41992 C 45.069922 290.25992 135.67008 438.63977 270.83008 522.00977 A 22.48 22.48 0 0 0 294.32031 522.00977 C 429.48031 438.63977 520.08047 290.25992 522.48047 120.41992 A 22.53 22.53 0 0 0 510.7793 100.41992 A 479.9 479.9 0 0 0 284.70508 42.693359 z M 220.41016 145.74023 L 411.2793 255.93945 L 220.41016 366.14062 L 220.41016 145.74023 z "
id="path10" />
</g>
</g>
</svg>

After

Width:  |  Height:  |  Size: 2.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.1 KiB

View file

@ -0,0 +1,67 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
viewBox="0 0 565.15 568"
version="1.1"
id="svg16"
sodipodi:docname="PlayerStopIconSponsorBlocker.svg"
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"
inkscape:export-filename="D:\Dell Data\_Projects\_____SponsorSkip\ignored\svg\SponsorBlocker4.png"
inkscape:export-xdpi="43.436523"
inkscape:export-ydpi="43.436523">
<metadata
id="metadata20">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title>LogoSponsorBlocker2</dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="1001"
id="namedview18"
showgrid="false"
inkscape:zoom="0.83098595"
inkscape:cx="194.89884"
inkscape:cy="305.06785"
inkscape:window-x="477"
inkscape:window-y="961"
inkscape:window-maximized="1"
inkscape:current-layer="svg16" />
<defs
id="defs4">
<style
id="style2">.cls-1{fill:red;}.cls-2{fill:#fff;}</style>
</defs>
<title
id="title6">LogoSponsorBlocker2</title>
<path
class="cls-1"
d="m 282.58,568 a 65,65 0 0 1 -34.14,-9.66 C 95.41,463.94 2.54,300.46 0,121 a 64.91,64.91 0 0 1 34,-58.09 522.56,522.56 0 0 1 497.16,0 64.91,64.91 0 0 1 34,58.12 c -2.53,179.43 -95.4,342.91 -248.42,437.3 A 65,65 0 0 1 282.58,568 Z m 0,-548.31 A 502.24,502.24 0 0 0 43.4,80.22 45.27,45.27 0 0 0 19.7,120.75 c 2.44,172.67 91.81,330 239.07,420.83 a 46.19,46.19 0 0 0 47.61,0 C 453.64,450.73 543,293.42 545.45,120.75 A 45.26,45.26 0 0 0 521.75,80.21 502.26,502.26 0 0 0 282.58,19.69 Z"
id="path8"
inkscape:connector-curvature="0"
style="fill:#ffffff" />
<path
style="fill:#ffffff"
d="M 284.70508 42.693359 A 479.9 479.9 0 0 0 54.369141 100.41992 A 22.53 22.53 0 0 0 42.669922 120.41992 C 45.069922 290.25992 135.67008 438.63977 270.83008 522.00977 A 22.48 22.48 0 0 0 294.32031 522.00977 C 429.48031 438.63977 520.08047 290.25992 522.48047 120.41992 A 22.53 22.53 0 0 0 510.7793 100.41992 A 479.9 479.9 0 0 0 284.70508 42.693359 z M 187.11914 147.00977 L 378.03125 147.00977 L 378.03125 351.04102 L 187.11914 351.04102 L 187.11914 147.00977 z "
id="path10" />
</svg>

After

Width:  |  Height:  |  Size: 2.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 7.1 KiB

View file

@ -0,0 +1,71 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
viewBox="0 0 565.15 568"
version="1.1"
id="svg16"
sodipodi:docname="PlayerUploadFailedIconSponsorBlocker.svg"
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"
inkscape:export-filename="D:\Dell Data\_Projects\_____SponsorSkip\ignored\svg\SponsorBlocker4.png"
inkscape:export-xdpi="43.436523"
inkscape:export-ydpi="43.436523">
<metadata
id="metadata20">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title>LogoSponsorBlocker2</dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="1001"
id="namedview18"
showgrid="false"
inkscape:zoom="0.83098592"
inkscape:cx="-277.20441"
inkscape:cy="286.71724"
inkscape:window-x="477"
inkscape:window-y="961"
inkscape:window-maximized="1"
inkscape:current-layer="svg16" />
<defs
id="defs4">
<style
id="style2">.cls-1{fill:red;}.cls-2{fill:#fff;}</style>
</defs>
<title
id="title6">LogoSponsorBlocker2</title>
<path
class="cls-1"
d="m 282.58,568 a 65,65 0 0 1 -34.14,-9.66 C 95.41,463.94 2.54,300.46 0,121 a 64.91,64.91 0 0 1 34,-58.09 522.56,522.56 0 0 1 497.16,0 64.91,64.91 0 0 1 34,58.12 c -2.53,179.43 -95.4,342.91 -248.42,437.3 A 65,65 0 0 1 282.58,568 Z m 0,-548.31 A 502.24,502.24 0 0 0 43.4,80.22 45.27,45.27 0 0 0 19.7,120.75 c 2.44,172.67 91.81,330 239.07,420.83 a 46.19,46.19 0 0 0 47.61,0 C 453.64,450.73 543,293.42 545.45,120.75 A 45.26,45.26 0 0 0 521.75,80.21 502.26,502.26 0 0 0 282.58,19.69 Z"
id="path8"
inkscape:connector-curvature="0"
style="fill:#ffffff" />
<path
style="fill:#ffffff"
d="M 284.70508 42.693359 A 479.9 479.9 0 0 0 54.369141 100.41992 A 22.53 22.53 0 0 0 42.669922 120.41992 C 45.069922 290.25992 135.67008 438.63977 270.83008 522.00977 A 22.48 22.48 0 0 0 294.32031 522.00977 C 429.48031 438.63977 520.08047 290.25992 522.48047 120.41992 A 22.53 22.53 0 0 0 510.7793 100.41992 A 479.9 479.9 0 0 0 284.70508 42.693359 z M 282.57422 123.27344 C 302.2486 123.27344 318.08789 139.67142 318.08789 160.03906 L 318.08789 310.16211 C 318.08789 330.52975 302.2486 346.92773 282.57422 346.92773 C 262.89984 346.92773 247.0625 330.52975 247.0625 310.16211 L 247.0625 160.03906 C 247.0625 139.67142 262.89984 123.27344 282.57422 123.27344 z M 282.57422 373.71094 C 302.2487 373.71094 318.08789 389.55014 318.08789 409.22461 C 318.08789 428.89909 302.2487 444.73633 282.57422 444.73633 C 262.89975 444.73633 247.06055 428.89909 247.06055 409.22461 C 247.06055 389.55014 262.89975 373.71094 282.57422 373.71094 z "
id="path10" />
<g
id="g821"
transform="translate(0,32.491428)"
style="fill:#ffffff" />
</svg>

After

Width:  |  Height:  |  Size: 3.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 KiB

View file

@ -0,0 +1,67 @@
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:cc="http://creativecommons.org/ns#"
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:svg="http://www.w3.org/2000/svg"
xmlns="http://www.w3.org/2000/svg"
xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
viewBox="0 0 565.15 568"
version="1.1"
id="svg16"
sodipodi:docname="PlayerUploadIconSponsorBlocker.svg"
inkscape:version="0.92.4 (5da689c313, 2019-01-14)"
inkscape:export-filename="D:\Dell Data\_Projects\_____SponsorSkip\ignored\svg\SponsorBlocker4.png"
inkscape:export-xdpi="43.436523"
inkscape:export-ydpi="43.436523">
<metadata
id="metadata20">
<rdf:RDF>
<cc:Work
rdf:about="">
<dc:format>image/svg+xml</dc:format>
<dc:type
rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
<dc:title>LogoSponsorBlocker2</dc:title>
</cc:Work>
</rdf:RDF>
</metadata>
<sodipodi:namedview
pagecolor="#ffffff"
bordercolor="#666666"
borderopacity="1"
objecttolerance="10"
gridtolerance="10"
guidetolerance="10"
inkscape:pageopacity="0"
inkscape:pageshadow="2"
inkscape:window-width="1920"
inkscape:window-height="1001"
id="namedview18"
showgrid="false"
inkscape:zoom="0.83098595"
inkscape:cx="-374.9496"
inkscape:cy="291.99093"
inkscape:window-x="477"
inkscape:window-y="961"
inkscape:window-maximized="1"
inkscape:current-layer="svg16" />
<defs
id="defs4">
<style
id="style2">.cls-1{fill:red;}.cls-2{fill:#fff;}</style>
</defs>
<title
id="title6">LogoSponsorBlocker2</title>
<path
class="cls-1"
d="m 282.58,568 a 65,65 0 0 1 -34.14,-9.66 C 95.41,463.94 2.54,300.46 0,121 a 64.91,64.91 0 0 1 34,-58.09 522.56,522.56 0 0 1 497.16,0 64.91,64.91 0 0 1 34,58.12 c -2.53,179.43 -95.4,342.91 -248.42,437.3 A 65,65 0 0 1 282.58,568 Z m 0,-548.31 A 502.24,502.24 0 0 0 43.4,80.22 45.27,45.27 0 0 0 19.7,120.75 c 2.44,172.67 91.81,330 239.07,420.83 a 46.19,46.19 0 0 0 47.61,0 C 453.64,450.73 543,293.42 545.45,120.75 A 45.26,45.26 0 0 0 521.75,80.21 502.26,502.26 0 0 0 282.58,19.69 Z"
id="path8"
inkscape:connector-curvature="0"
style="fill:#ffffff" />
<path
style="fill:#ffffff"
d="M 284.70508 42.693359 A 479.9 479.9 0 0 0 54.369141 100.41992 A 22.53 22.53 0 0 0 42.669922 120.41992 C 45.069922 290.25992 135.67008 438.63977 270.83008 522.00977 A 22.48 22.48 0 0 0 294.32031 522.00977 C 429.48031 438.63977 520.08047 290.25992 522.48047 120.41992 A 22.53 22.53 0 0 0 510.7793 100.41992 A 479.9 479.9 0 0 0 284.70508 42.693359 z M 282.57422 112.11133 L 282.87109 112.11133 L 423.75977 365.75391 L 330.30273 365.75391 L 330.30273 409.21094 L 234.84766 409.21094 L 234.84766 365.75391 L 141.39062 365.75391 L 282.57422 112.11133 z "
id="path10" />
</svg>

After

Width:  |  Height:  |  Size: 3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 12 KiB

View file

@ -310,23 +310,6 @@
<br/> <br/>
<br/> <br/>
<div option-type="toggle" sync-option="hashPrefix">
<label class="switch-container" label-name="__MSG_enableQueryByHashPrefix__">
<label class="switch">
<input type="checkbox" checked>
<span class="slider round"></span>
</label>
</label>
<br/>
<br/>
<div class="small-description">__MSG_whatQueryByHashPrefix__</div>
</div>
<br/>
<br/>
<div option-type="toggle" sync-option="refetchWhenNotFound"> <div option-type="toggle" sync-option="refetchWhenNotFound">
<label class="switch-container" label-name="__MSG_enableRefetchWhenNotFound__"> <label class="switch-container" label-name="__MSG_enableRefetchWhenNotFound__">
<label class="switch"> <label class="switch">
@ -344,23 +327,6 @@
<br/> <br/>
<br/> <br/>
<div option-type="toggle" sync-option="checkForUnlistedVideos">
<label class="switch-container" label-name="__MSG_unlistedCheck__">
<label class="switch">
<input type="checkbox">
<span class="slider round"></span>
</label>
</label>
<br/>
<br/>
<div class="small-description">__MSG_whatUnlistedCheck__</div>
</div>
<br/>
<br/>
<div option-type="private-text-change" sync-option="userID" confirm-message="userIDChangeWarning"> <div option-type="private-text-change" sync-option="userID" confirm-message="userIDChangeWarning">
<div class="option-button trigger-button"> <div class="option-button trigger-button">
__MSG_changeUserID__ __MSG_changeUserID__

View file

@ -71,7 +71,7 @@
</div> </div>
<div id="submissionSection" style="display: none"> <div id="submissionSection" style="display: none">
<b style="display: block; margin-top: 12px;">__MSG_submissionEditHint__</b> <b style="display: block; margin-top: 12px;">__MSG_submissionEditHint__</b>
<div id="submitTimesContainer" style="display: none; margin-top: 12px;"> <div id="submitTimesContainer" style="margin-top: 12px;">
<button id="submitTimes" class="mediumButton">__MSG_submitTimesButton__</button> <button id="submitTimes" class="mediumButton">__MSG_submitTimesButton__</button>
</div> </div>
</div> </div>

View file

@ -261,7 +261,7 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
if (utils.getCategoryActionType(event.target.value as Category) === CategoryActionType.POI) { if (utils.getCategoryActionType(event.target.value as Category) === CategoryActionType.POI) {
this.setTimeTo(1, null); this.setTimeTo(1, null);
this.props.contentContainer().changeStartSponsorButton(true, true); this.props.contentContainer().updateEditButtonsOnPlayer();
} }
this.saveEditTimes(); this.saveEditTimes();
@ -356,13 +356,8 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
deleteTime(): void { deleteTime(): void {
const sponsorTimes = this.props.contentContainer().sponsorTimesSubmitting; const sponsorTimes = this.props.contentContainer().sponsorTimesSubmitting;
const index = this.props.index; const index = this.props.index;
const removingIncomplete = sponsorTimes[index].segment.length < 2;
//if it is not a complete sponsor time
if (sponsorTimes[index].segment.length < 2) {
//update video player
this.props.contentContainer().changeStartSponsorButton(true, true);
}
sponsorTimes.splice(index, 1); sponsorTimes.splice(index, 1);
//save this //save this
@ -373,13 +368,16 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
//if they are all removed //if they are all removed
if (sponsorTimes.length == 0) { if (sponsorTimes.length == 0) {
this.props.submissionNotice.cancel(); this.props.submissionNotice.cancel();
//update video player
this.props.contentContainer().changeStartSponsorButton(true, false);
} else { } else {
//update display //update display
this.props.submissionNotice.forceUpdate(); this.props.submissionNotice.forceUpdate();
} }
//if it is not a complete segment, or all are removed
if (sponsorTimes.length === 0 || removingIncomplete) {
//update video player
this.props.contentContainer().updateEditButtonsOnPlayer();
}
} }
configUpdate(): void { configUpdate(): void {

View file

@ -3,6 +3,7 @@ import { Category, CategorySelection, CategorySkipOption, PreviewBarOption, Spon
interface SBConfig { interface SBConfig {
userID: string, userID: string,
/** Contains unsubmitted segments that the user has created. */
segmentTimes: SBMap<string, SponsorTime[]>, segmentTimes: SBMap<string, SponsorTime[]>,
defaultCategory: Category, defaultCategory: Category,
whitelistedChannels: string[], whitelistedChannels: string[],
@ -31,8 +32,8 @@ interface SBConfig {
audioNotificationOnSkip, audioNotificationOnSkip,
checkForUnlistedVideos: boolean, checkForUnlistedVideos: boolean,
testingServer: boolean, testingServer: boolean,
hashPrefix: boolean,
refetchWhenNotFound: boolean, refetchWhenNotFound: boolean,
ytInfoPermissionGranted: boolean,
// What categories should be skipped // What categories should be skipped
categorySelections: CategorySelection[], categorySelections: CategorySelection[],
@ -168,8 +169,8 @@ const Config: SBObject = {
audioNotificationOnSkip: false, audioNotificationOnSkip: false,
checkForUnlistedVideos: false, checkForUnlistedVideos: false,
testingServer: false, testingServer: false,
hashPrefix: true,
refetchWhenNotFound: true, refetchWhenNotFound: true,
ytInfoPermissionGranted: false,
categorySelections: [{ categorySelections: [{
name: "sponsor" as Category, name: "sponsor" as Category,

View file

@ -1,7 +1,5 @@
import Config from "./config"; import Config from "./config";
import { SponsorTime, CategorySkipOption, VideoID, SponsorHideType, FetchResponse, VideoInfo, StorageChangesObject, CategoryActionType, ChannelIDInfo, ChannelIDStatus, SegmentUUID, Category } from "./types";
import { SponsorTime, CategorySkipOption, VideoID, SponsorHideType, FetchResponse, VideoInfo, StorageChangesObject, CategoryActionType, SegmentUUID, Category } from "./types";
import { ContentContainer } from "./types"; import { ContentContainer } from "./types";
import Utils from "./utils"; import Utils from "./utils";
const utils = new Utils(); const utils = new Utils();
@ -29,7 +27,7 @@ const skipNotices: SkipNotice[] = [];
// JSON video info // JSON video info
let videoInfo: VideoInfo = null; let videoInfo: VideoInfo = null;
//the channel this video is about //the channel this video is about
let channelID: string; let channelIDInfo: ChannelIDInfo;
// Skips are scheduled to ensure precision. // Skips are scheduled to ensure precision.
// Skips are rescheduled every seeking event. // Skips are rescheduled every seeking event.
@ -71,8 +69,11 @@ let channelWhitelisted = false;
// create preview bar // create preview bar
let previewBar: PreviewBar = null; let previewBar: PreviewBar = null;
//the player controls on the YouTube player /** Element containing the player controls on the YouTube player. */
let controls = null; let controls: HTMLElement | null = null;
/** Contains buttons created by `createButton()`. */
const playerButtons: Record<string, {button: HTMLButtonElement, image: HTMLImageElement}> = {};
// Direct Links after the config is loaded // Direct Links after the config is loaded
utils.wait(() => Config.config !== null, 1000, 1).then(() => videoIDChange(getYouTubeVideoID(document.URL))); utils.wait(() => Config.config !== null, 1000, 1).then(() => videoIDChange(getYouTubeVideoID(document.URL)));
@ -81,10 +82,7 @@ utils.wait(() => Config.config !== null, 1000, 1).then(() => videoIDChange(getYo
//this only happens if there is an error //this only happens if there is an error
let sponsorLookupRetries = 0; let sponsorLookupRetries = 0;
//if showing the start sponsor button or the end sponsor button on the player /** Segments created by the user which have not yet been submitted. */
let showingStartSponsor = true;
//the sponsor times being prepared to be submitted
let sponsorTimesSubmitting: SponsorTime[] = []; let sponsorTimesSubmitting: SponsorTime[] = [];
//becomes true when isInfoFound is called //becomes true when isInfoFound is called
@ -111,12 +109,15 @@ const skipNoticeContentContainer: ContentContainer = () => ({
onMobileYouTube, onMobileYouTube,
sponsorSubmissionNotice: submissionNotice, sponsorSubmissionNotice: submissionNotice,
resetSponsorSubmissionNotice, resetSponsorSubmissionNotice,
changeStartSponsorButton, updateEditButtonsOnPlayer,
previewTime, previewTime,
videoInfo, videoInfo,
getRealCurrentTime: getRealCurrentTime getRealCurrentTime: getRealCurrentTime
}); });
// value determining when to count segment as skipped and send telemetry to server (percent based)
const manualSkipPercentCount = 0.5;
//get messages from the background script and the popup //get messages from the background script and the popup
chrome.runtime.onMessage.addListener(messageListener); chrome.runtime.onMessage.addListener(messageListener);
@ -127,11 +128,11 @@ function messageListener(request: Message, sender: unknown, sendResponse: (respo
videoIDChange(getYouTubeVideoID(document.URL)); videoIDChange(getYouTubeVideoID(document.URL));
break; break;
case "sponsorStart": case "sponsorStart":
sponsorMessageStarted(sendResponse); startOrEndTimingNewSegment()
break; sendResponse({
case "sponsorDataChanged": creatingSegment: isSegmentCreationInProgress(),
updateSponsorTimesSubmitting(); });
break; break;
case "isInfoFound": case "isInfoFound":
@ -150,13 +151,14 @@ function messageListener(request: Message, sender: unknown, sendResponse: (respo
break; break;
case "getVideoID": case "getVideoID":
sendResponse({ sendResponse({
videoID: sponsorVideoID videoID: sponsorVideoID,
creatingSegment: isSegmentCreationInProgress(),
}); });
break; break;
case "getChannelID": case "getChannelID":
sendResponse({ sendResponse({
channelID: channelID channelID: channelIDInfo.id
}); });
break; break;
@ -170,10 +172,6 @@ function messageListener(request: Message, sender: unknown, sendResponse: (respo
channelWhitelisted = request.value; channelWhitelisted = request.value;
sponsorsLookup(sponsorVideoID); sponsorsLookup(sponsorVideoID);
break;
case "changeStartSponsorButton":
changeStartSponsorButton(request.showStartSponsor, request.uploadButtonVisible);
break; break;
case "submitTimes": case "submitTimes":
submitSponsorTimes(); submitSponsorTimes();
@ -212,7 +210,10 @@ function resetValues() {
videoInfo = null; videoInfo = null;
channelWhitelisted = false; channelWhitelisted = false;
channelID = null; channelIDInfo = {
status: ChannelIDStatus.Fetching,
id: null
};
//empty the preview bar //empty the preview bar
if (previewBar !== null) { if (previewBar !== null) {
@ -250,29 +251,25 @@ async function videoIDChange(id) {
// Wait for options to be ready // Wait for options to be ready
await utils.wait(() => Config.config !== null, 5000, 1); await utils.wait(() => Config.config !== null, 5000, 1);
// Get new video info
getVideoInfo();
// If enabled, it will check if this video is private or unlisted and double check with the user if the sponsors should be looked up // If enabled, it will check if this video is private or unlisted and double check with the user if the sponsors should be looked up
if (Config.config.checkForUnlistedVideos) { if (Config.config.checkForUnlistedVideos) {
try { const shouldContinue = confirm("SponsorBlock: You have the setting 'Ignore Unlisted/Private Videos' enabled."
await utils.wait(() => !!videoInfo, 5000, 1); + " Due to a change in how segment fetching works, this setting is not needed anymore as it cannot leak your video ID to the server."
} catch (err) { + " It instead sends just the first 4 characters of a longer hash of the videoID to the server, and filters through a subset of the database."
await videoInfoFetchFailed("adblockerIssueUnlistedVideosInfo"); + " More info about this implementation can be found here: https://github.com/ajayyy/SponsorBlockServer/issues/25"
} + "\n\nPlease click okay to confirm that you acknowledge this and continue using SponsorBlock.");
if (shouldContinue) {
if (isUnlisted()) { Config.config.checkForUnlistedVideos = false;
const shouldContinue = confirm(chrome.i18n.getMessage("confirmPrivacy")); } else {
if(!shouldContinue) return; return;
} }
} }
// Get new video info
getVideoInfo();
// Update whitelist data when the video data is loaded // Update whitelist data when the video data is loaded
utils.wait(() => !!videoInfo, 5000, 10).then(whitelistCheck).catch(() => { whitelistCheck();
if (Config.config.forceChannelCheck) {
videoInfoFetchFailed("adblockerIssueWhitelist");
}
});
//setup the preview bar //setup the preview bar
if (previewBar === null) { if (previewBar === null) {
@ -298,33 +295,20 @@ async function videoIDChange(id) {
//close popup //close popup
closeInfoMenu(); closeInfoMenu();
sponsorsLookup(id); sponsorsLookup(id);
//make sure everything is properly added // Make sure all player buttons are properly added
updateVisibilityOfPlayerControlsButton().then(() => { updateVisibilityOfPlayerControlsButton();
//see if the onvideo control image needs to be changed
const segments = Config.config.segmentTimes.get(sponsorVideoID);
if (segments != null && segments.length > 0 && segments[segments.length - 1].segment.length >= 2) {
changeStartSponsorButton(true, true);
} else if (segments != null && segments.length > 0 && segments[segments.length - 1].segment.length < 2) {
changeStartSponsorButton(false, true);
} else {
changeStartSponsorButton(true, false);
}
});
//reset sponsor times submitting // Clear unsubmitted segments from the previous video
sponsorTimesSubmitting = []; sponsorTimesSubmitting = [];
updateSponsorTimesSubmitting(); updateSponsorTimesSubmitting();
//see if video controls buttons should be added
if (!onInvidious) {
updateVisibilityOfPlayerControlsButton();
}
} }
function handleMobileControlsMutations(): void { function handleMobileControlsMutations(): void {
updateVisibilityOfPlayerControlsButton();
if (previewBar !== null) { if (previewBar !== null) {
if (document.body.contains(previewBar.container)) { if (document.body.contains(previewBar.container)) {
const progressBarBackground = document.querySelector<HTMLElement>(".progress-bar-background"); const progressBarBackground = document.querySelector<HTMLElement>(".progress-bar-background");
@ -409,7 +393,7 @@ function startSponsorSchedule(includeIntersectingSegments = false, currentTime?:
if (video.paused) return; if (video.paused) return;
if (Config.config.disableSkipping || channelWhitelisted || (channelID === null && Config.config.forceChannelCheck)){ if (Config.config.disableSkipping || channelWhitelisted || (channelIDInfo.status === ChannelIDStatus.Fetching && Config.config.forceChannelCheck)){
return; return;
} }
@ -577,33 +561,22 @@ async function sponsorsLookup(id: string) {
} }
// Check for hashPrefix setting // Check for hashPrefix setting
let getRequest; const hashPrefix = (await utils.getHash(id, 1)).substr(0, 4);
if (Config.config.hashPrefix) { utils.asyncRequestToServer('GET', "/api/skipSegments/" + hashPrefix, {
const hashPrefix = (await utils.getHash(id, 1)).substr(0, 4); categories
getRequest = utils.asyncRequestToServer('GET', "/api/skipSegments/" + hashPrefix, { }).then(async (response: FetchResponse) => {
categories
});
} else {
getRequest = utils.asyncRequestToServer('GET', "/api/skipSegments", {
videoID: id,
categories
});
}
getRequest.then(async (response: FetchResponse) => {
if (response?.ok) { if (response?.ok) {
let result = JSON.parse(response.responseText); let result = JSON.parse(response.responseText);
if (Config.config.hashPrefix) { result = result.filter((video) => video.videoID === id);
result = result.filter((video) => video.videoID === id); if (result.length > 0) {
if (result.length > 0) { result = result[0].segments;
result = result[0].segments; if (result.length === 0) { // return if no segments found
if (result.length === 0) { // return if no segments found
retryFetch(id);
return;
}
} else { // return if no video found
retryFetch(id); retryFetch(id);
return; return;
} }
} else { // return if no video found
retryFetch(id);
return;
} }
const recievedSegments: SponsorTime[] = result; const recievedSegments: SponsorTime[] = result;
@ -733,20 +706,6 @@ async function getVideoInfo(): Promise<void> {
} }
} }
async function videoInfoFetchFailed(errorMessage: string): Promise<void> {
if (utils.isFirefox()) {
// Attempt to ask permission for youtube.com domain
alert(chrome.i18n.getMessage("youtubePermissionRequest"));
chrome.runtime.sendMessage({
message: "openPage",
url: "permissions/index.html#youtube.com"
});
} else {
alert(chrome.i18n.getMessage("adblockerIssue") + "\n\n" + chrome.i18n.getMessage(errorMessage));
}
}
function getYouTubeVideoID(url: string) { function getYouTubeVideoID(url: string) {
// For YouTube TV support // For YouTube TV support
if(url.startsWith("https://www.youtube.com/tv#/")) url = url.replace("#", ""); if(url.startsWith("https://www.youtube.com/tv#/")) url = url.replace("#", "");
@ -843,23 +802,34 @@ function updatePreviewBar(): void {
} }
//checks if this channel is whitelisted, should be done only after the channelID has been loaded //checks if this channel is whitelisted, should be done only after the channelID has been loaded
function whitelistCheck() { async function whitelistCheck() {
channelID = videoInfo?.videoDetails?.channelId; const whitelistedChannels = Config.config.whitelistedChannels;
if (!channelID) {
channelID = null; const channelID = document.querySelector(".ytd-channel-name a")?.getAttribute("href")?.replace(/\/.+\//, "") // YouTube
?? document.querySelector(".ytp-title-channel-logo")?.getAttribute("href")?.replace(/https:\/.+\//, "") // YouTube Embed
?? document.querySelector("a > .channel-profile")?.parentElement?.getAttribute("href")?.replace(/\/.+\//, ""); // Invidious
if (channelID) {
channelIDInfo = {
status: ChannelIDStatus.Found,
id: channelID
}
} else {
channelIDInfo = {
status: ChannelIDStatus.Failed,
id: null
}
return; return;
} }
//see if this is a whitelisted channel //see if this is a whitelisted channel
const whitelistedChannels = Config.config.whitelistedChannels;
if (whitelistedChannels != undefined && whitelistedChannels.includes(channelID)) { if (whitelistedChannels != undefined && whitelistedChannels.includes(channelID)) {
channelWhitelisted = true; channelWhitelisted = true;
} }
// check if the start of segments were missed // check if the start of segments were missed
if (Config.config.forceChannelCheck && sponsorTimes && sponsorTimes.length > 0) startSkipScheduleCheckingForStartSponsors(); if (Config.config.forceChannelCheck && sponsorTimes?.length > 0) startSkipScheduleCheckingForStartSponsors();
} }
/** /**
@ -984,6 +954,26 @@ function previewTime(time: number, unpause = true) {
} }
} }
//send telemetry and count skip
function sendTelemetryAndCount(skippingSegments: SponsorTime[], secondsSkipped: number, fullSkip: boolean) {
if (!Config.config.trackViewCount) return;
let counted = false;
for (const segment of skippingSegments) {
const index = sponsorTimes.indexOf(segment);
if (index !== -1 && !sponsorSkipped[index]) {
sponsorSkipped[index] = true;
if (!counted) {
Config.config.minutesSaved = Config.config.minutesSaved + secondsSkipped / 60;
Config.config.skipCount = Config.config.skipCount + 1;
counted = true;
}
if (fullSkip) utils.asyncRequestToServer("POST", "/api/viewedVideoSponsorTime?UUID=" + segment.UUID);
}
}
}
//skip from the start time to the end time for a certain index sponsor time //skip from the start time to the end time for a certain index sponsor time
function skipToTime(v: HTMLVideoElement, skipTime: number[], skippingSegments: SponsorTime[], openNotice: boolean) { function skipToTime(v: HTMLVideoElement, skipTime: number[], skippingSegments: SponsorTime[], openNotice: boolean) {
// There will only be one submission if it is manual skip // There will only be one submission if it is manual skip
@ -1008,29 +998,7 @@ function skipToTime(v: HTMLVideoElement, skipTime: number[], skippingSegments: S
} }
//send telemetry that a this sponsor was skipped //send telemetry that a this sponsor was skipped
if (Config.config.trackViewCount && autoSkip) { if (autoSkip) sendTelemetryAndCount(skippingSegments, skipTime[1] - skipTime[0], true);
let alreadySkipped = false;
let isUnsubmittedSegment = false;
for (const segment of skippingSegments) {
const index = sponsorTimes.indexOf(segment);
if (index !== -1 && !sponsorSkipped[index]) {
utils.asyncRequestToServer("POST", "/api/viewedVideoSponsorTime?UUID=" + segment.UUID);
sponsorSkipped[index] = true;
} else if (sponsorSkipped[index]) {
alreadySkipped = true;
}
if (index === -1) isUnsubmittedSegment = true;
}
// Count this as a skip
if (!alreadySkipped && !isUnsubmittedSegment) {
Config.config.minutesSaved = Config.config.minutesSaved + (skipTime[1] - skipTime[0]) / 60;
Config.config.skipCount = Config.config.skipCount + 1;
}
}
} }
function unskipSponsorTime(segment: SponsorTime) { function unskipSponsorTime(segment: SponsorTime) {
@ -1039,13 +1007,18 @@ function unskipSponsorTime(segment: SponsorTime) {
} }
function reskipSponsorTime(segment: SponsorTime) { function reskipSponsorTime(segment: SponsorTime) {
const skippedTime = Math.max(segment.segment[1] - video.currentTime, 0);
const segmentDuration = segment.segment[1] - segment.segment[0];
const fullSkip = skippedTime / segmentDuration > manualSkipPercentCount;
video.currentTime = segment.segment[1]; video.currentTime = segment.segment[1];
sendTelemetryAndCount([segment], skippedTime, fullSkip);
startSponsorSchedule(true, segment.segment[1], false); startSponsorSchedule(true, segment.segment[1], false);
} }
function createButton(baseID, title, callback, imageName, isDraggable=false): boolean { function createButton(baseID: string, title: string, callback: () => void, imageName: string, isDraggable = false): HTMLElement {
if (document.getElementById(baseID + "Button") != null) return false; const existingElement = document.getElementById(baseID + "Button");
if (existingElement !== null) return existingElement;
// Button HTML // Button HTML
const newButton = document.createElement("button"); const newButton = document.createElement("button");
@ -1069,9 +1042,15 @@ function createButton(baseID, title, callback, imageName, isDraggable=false): bo
newButton.appendChild(newButtonImage); newButton.appendChild(newButtonImage);
// Add the button to player // Add the button to player
controls.prepend(newButton); if (controls) controls.prepend(newButton);
return true; // Store the elements to prevent unnecessary querying
playerButtons[baseID] = {
button: newButton,
image: newButtonImage,
};
return newButton;
} }
function getControls(): HTMLElement | false { function getControls(): HTMLElement | false {
@ -1081,8 +1060,8 @@ function getControls(): HTMLElement | false {
// Mobile YouTube // Mobile YouTube
".player-controls-top", ".player-controls-top",
// Invidious/videojs video element's controls element // Invidious/videojs video element's controls element
".vjs-control-bar" ".vjs-control-bar",
] ];
for (const controlsSelector of controlsSelectors) { for (const controlsSelector of controlsSelectors) {
const controls = document.querySelectorAll(controlsSelector); const controls = document.querySelectorAll(controlsSelector);
@ -1095,53 +1074,75 @@ function getControls(): HTMLElement | false {
return false; return false;
} }
//adds all the player controls buttons /** Creates any missing buttons on the YouTube player if possible. */
async function createButtons(): Promise<boolean> { async function createButtons(): Promise<void> {
if (onMobileYouTube) return; if (onMobileYouTube) return;
const result = await utils.wait(getControls).catch(); controls = await utils.wait(getControls).catch();
//set global controls variable
controls = result;
let createdButton = false;
// Add button if does not already exist in html // Add button if does not already exist in html
createdButton = createButton("startSponsor", "sponsorStart", startSponsorClicked, "PlayerStartIconSponsorBlocker256px.png") || createdButton; createButton("startSponsor", "sponsorStart", () => closeInfoMenuAnd(() => startOrEndTimingNewSegment()), "PlayerStartIconSponsorBlocker.svg");
createdButton = createButton("info", "openPopup", openInfoMenu, "PlayerInfoIconSponsorBlocker256px.png") || createdButton; createButton("cancelSponsor", "sponsorCancel", () => closeInfoMenuAnd(() => cancelCreatingSegment()), "PlayerCancelSegmentIconSponsorBlocker.svg");
createdButton = createButton("delete", "clearTimes", clearSponsorTimes, "PlayerDeleteIconSponsorBlocker256px.png") || createdButton; createButton("info", "openPopup", openInfoMenu, "PlayerInfoIconSponsorBlocker.svg");
createdButton = createButton("submit", "SubmitTimes", submitSponsorTimes, "PlayerUploadIconSponsorBlocker256px.png") || createdButton; createButton("delete", "clearTimes", () => closeInfoMenuAnd(() => clearSponsorTimes()), "PlayerDeleteIconSponsorBlocker.svg");
createButton("submit", "SubmitTimes", submitSponsorTimes, "PlayerUploadIconSponsorBlocker.svg");
return createdButton;
} }
//adds or removes the player controls button to what it should be /** Creates any missing buttons on the player and updates their visiblity. */
async function updateVisibilityOfPlayerControlsButton(): Promise<boolean> { async function updateVisibilityOfPlayerControlsButton(): Promise<void> {
//not on a proper video yet // Not on a proper video yet
if (!sponsorVideoID) return false; if (!sponsorVideoID) return;
const createdButtons = await createButtons(); await createButtons();
if (!createdButtons) return;
if (Config.config.hideVideoPlayerControls || onInvidious) { updateEditButtonsOnPlayer();
document.getElementById("startSponsorButton").style.display = "none";
document.getElementById("submitButton").style.display = "none";
} else {
document.getElementById("startSponsorButton").style.removeProperty("display");
}
//don't show the info button on embeds // Don't show the info button on embeds
if (Config.config.hideInfoButtonPlayerControls || document.URL.includes("/embed/") || onInvidious) { if (Config.config.hideInfoButtonPlayerControls || document.URL.includes("/embed/") || onInvidious) {
document.getElementById("infoButton").style.display = "none"; playerButtons.info.button.style.display = "none";
} else { } else {
document.getElementById("infoButton").style.removeProperty("display"); playerButtons.info.button.style.removeProperty("display");
} }
}
if (Config.config.hideDeleteButtonPlayerControls || onInvidious) {
document.getElementById("deleteButton").style.display = "none"; /** Updates the visibility of buttons on the player related to creating segments. */
function updateEditButtonsOnPlayer(): void {
// Don't try to update the buttons if we aren't on a YouTube video page
if (!sponsorVideoID) return;
const buttonsEnabled = !Config.config.hideVideoPlayerControls && !onInvidious;
let creatingSegment = false;
let submitButtonVisible = false;
let deleteButtonVisible = false;
// Only check if buttons should be visible if they're enabled
if (buttonsEnabled) {
creatingSegment = isSegmentCreationInProgress();
// Show only if there are any segments to submit
submitButtonVisible = sponsorTimesSubmitting.length > 0;
// Show only if there are any segments to delete
deleteButtonVisible = sponsorTimesSubmitting.length > 1 || (sponsorTimesSubmitting.length > 0 && !creatingSegment);
} }
return createdButtons; // Update the elements
playerButtons.startSponsor.button.style.display = buttonsEnabled ? "unset" : "none";
playerButtons.cancelSponsor.button.style.display = buttonsEnabled && creatingSegment ? "unset" : "none";
if (buttonsEnabled) {
if (creatingSegment) {
playerButtons.startSponsor.image.src = chrome.extension.getURL("icons/PlayerStopIconSponsorBlocker.svg");
playerButtons.startSponsor.button.setAttribute("title", chrome.i18n.getMessage("sponsorEnd"));
} else {
playerButtons.startSponsor.image.src = chrome.extension.getURL("icons/PlayerStartIconSponsorBlocker.svg");
playerButtons.startSponsor.button.setAttribute("title", chrome.i18n.getMessage("sponsorStart"));
}
}
playerButtons.submit.button.style.display = submitButtonVisible && !Config.config.hideUploadButtonPlayerControls ? "unset" : "none";
playerButtons.delete.button.style.display = deleteButtonVisible && !Config.config.hideDeleteButtonPlayerControls ? "unset" : "none";
} }
/** /**
@ -1162,30 +1163,48 @@ function getRealCurrentTime(): number {
} }
} }
function startSponsorClicked() { function startOrEndTimingNewSegment() {
//it can't update to this info yet if (!isSegmentCreationInProgress()) {
closeInfoMenu();
toggleStartSponsorButton();
//add to sponsorTimes
if (sponsorTimesSubmitting.length > 0 && sponsorTimesSubmitting[sponsorTimesSubmitting.length - 1].segment.length < 2) {
//it is an end time
sponsorTimesSubmitting[sponsorTimesSubmitting.length - 1].segment[1] = getRealCurrentTime();
sponsorTimesSubmitting[sponsorTimesSubmitting.length - 1].segment.sort((a, b) => a > b ? 1 : (a < b ? -1 : 0));
} else {
//it is a start time
sponsorTimesSubmitting.push({ sponsorTimesSubmitting.push({
segment: [getRealCurrentTime()], segment: [getRealCurrentTime()],
UUID: null, UUID: null,
category: Config.config.defaultCategory category: Config.config.defaultCategory,
}); });
} else {
// Finish creating the new segment
const existingSegment = getIncompleteSegment();
const existingTime = existingSegment.segment[0];
const currentTime = getRealCurrentTime();
// Swap timestamps if the user put the segment end before the start
existingSegment.segment = [Math.min(existingTime, currentTime), Math.max(existingTime, currentTime)];
} }
//save this info // Save the newly created segment
Config.config.segmentTimes.set(sponsorVideoID, sponsorTimesSubmitting); Config.config.segmentTimes.set(sponsorVideoID, sponsorTimesSubmitting);
updateSponsorTimesSubmitting(false) updateEditButtonsOnPlayer();
updateSponsorTimesSubmitting(false);
}
function getIncompleteSegment(): SponsorTime {
return sponsorTimesSubmitting[sponsorTimesSubmitting.length - 1];
}
/** Is the latest submitting segment incomplete */
function isSegmentCreationInProgress(): boolean {
const segment = getIncompleteSegment();
return segment && segment?.segment?.length !== 2;
}
function cancelCreatingSegment() {
if (isSegmentCreationInProgress()) {
sponsorTimesSubmitting.splice(sponsorTimesSubmitting.length - 1, 1);
Config.config.segmentTimes.set(sponsorVideoID, sponsorTimesSubmitting);
}
updateEditButtonsOnPlayer();
updateSponsorTimesSubmitting(false);
} }
function updateSponsorTimesSubmitting(getFromConfig = true) { function updateSponsorTimesSubmitting(getFromConfig = true) {
@ -1214,31 +1233,6 @@ function updateSponsorTimesSubmitting(getFromConfig = true) {
} }
} }
async function changeStartSponsorButton(showStartSponsor: boolean, uploadButtonVisible: boolean): Promise<boolean> {
if(!sponsorVideoID || onMobileYouTube) return false;
//if it isn't visible, there is no data
const shouldHide = (uploadButtonVisible && !(Config.config.hideDeleteButtonPlayerControls || onInvidious)) ? "unset" : "none"
document.getElementById("deleteButton").style.display = shouldHide;
if (!Config.config.hideUploadButtonPlayerControls && !onInvidious) {
document.getElementById("submitButton").style.display = shouldHide;
}
if (showStartSponsor) {
showingStartSponsor = true;
(<HTMLImageElement> document.getElementById("startSponsorImage")).src = chrome.extension.getURL("icons/PlayerStartIconSponsorBlocker256px.png");
document.getElementById("startSponsorButton").setAttribute("title", chrome.i18n.getMessage("sponsorStart"));
} else {
showingStartSponsor = false;
(<HTMLImageElement> document.getElementById("startSponsorImage")).src = chrome.extension.getURL("icons/PlayerStopIconSponsorBlocker256px.png");
document.getElementById("startSponsorButton").setAttribute("title", chrome.i18n.getMessage("sponsorEND"));
}
}
function toggleStartSponsorButton() {
changeStartSponsorButton(!showingStartSponsor, true);
}
function openInfoMenu() { function openInfoMenu() {
if (document.getElementById("sponsorBlockPopupContainer") != null) { if (document.getElementById("sponsorBlockPopupContainer") != null) {
//it's already added //it's already added
@ -1248,7 +1242,7 @@ function openInfoMenu() {
popupInitialised = false; popupInitialised = false;
//hide info button //hide info button
document.getElementById("infoButton").style.display = "none"; if (playerButtons.info) playerButtons.info.button.style.display = "none";
sendRequestToCustomServer('GET', chrome.extension.getURL("popup.html"), function(xmlhttp) { sendRequestToCustomServer('GET', chrome.extension.getURL("popup.html"), function(xmlhttp) {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) { if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
@ -1310,20 +1304,28 @@ function openInfoMenu() {
function closeInfoMenu() { function closeInfoMenu() {
const popup = document.getElementById("sponsorBlockPopupContainer"); const popup = document.getElementById("sponsorBlockPopupContainer");
if (popup != null) { if (popup === null) return;
popup.remove();
//show info button if it's not an embed popup.remove();
if (!document.URL.includes("/embed/")) {
document.getElementById("infoButton").style.display = "unset"; // Show info button if it's not an embed
} if (!document.URL.includes("/embed/") && playerButtons.info) {
playerButtons.info.button.style.display = "unset";
} }
} }
function clearSponsorTimes() { /**
//it can't update to this info yet * The content script currently has no way to notify the info menu of changes. As a workaround we close it, thus making it query the new information when reopened.
*
* This function and all its uses should be removed when this issue is fixed.
* */
function closeInfoMenuAnd<T>(func: () => T): T {
closeInfoMenu(); closeInfoMenu();
return func();
}
function clearSponsorTimes() {
const currentVideoID = sponsorVideoID; const currentVideoID = sponsorVideoID;
const sponsorTimes = Config.config.segmentTimes.get(currentVideoID); const sponsorTimes = Config.config.segmentTimes.get(currentVideoID);
@ -1341,8 +1343,7 @@ function clearSponsorTimes() {
updatePreviewBar(); updatePreviewBar();
//set buttons to be correct updateEditButtonsOnPlayer();
changeStartSponsorButton(true, false);
} }
} }
@ -1408,18 +1409,6 @@ function dontShowNoticeAgain() {
closeAllSkipNotices(); closeAllSkipNotices();
} }
function sponsorMessageStarted(callback: (response: MessageResponse) => void) {
video = document.querySelector('video');
//send back current time
callback({
time: video.currentTime
})
//update button
toggleStartSponsorButton();
}
/** /**
* Helper method for the submission notice to clear itself when it closes * Helper method for the submission notice to clear itself when it closes
*/ */
@ -1430,9 +1419,6 @@ function resetSponsorSubmissionNotice() {
function submitSponsorTimes() { function submitSponsorTimes() {
if (submissionNotice !== null) return; if (submissionNotice !== null) return;
//it can't update to this info yet
closeInfoMenu();
if (sponsorTimesSubmitting !== undefined && sponsorTimesSubmitting.length > 0) { if (sponsorTimesSubmitting !== undefined && sponsorTimesSubmitting.length > 0) {
submissionNotice = new SubmissionNotice(skipNoticeContentContainer, sendSubmitMessage); submissionNotice = new SubmissionNotice(skipNoticeContentContainer, sendSubmitMessage);
} }
@ -1441,10 +1427,10 @@ function submitSponsorTimes() {
//send the message to the background js //send the message to the background js
//called after all the checks have been made that it's okay to do so //called after all the checks have been made that it's okay to do so
async function sendSubmitMessage(): Promise<void> { async function sendSubmitMessage() {
//add loading animation // Add loading animation
(<HTMLImageElement> document.getElementById("submitImage")).src = chrome.extension.getURL("icons/PlayerUploadIconSponsorBlocker256px.png"); playerButtons.submit.image.src = chrome.extension.getURL("icons/PlayerUploadIconSponsorBlocker.svg");
document.getElementById("submitButton").style.animation = "rotate 1s 0s infinite"; playerButtons.submit.button.style.animation = "rotate 1s 0s infinite";
//check if a sponsor exceeds the duration of the video //check if a sponsor exceeds the duration of the video
for (let i = 0; i < sponsorTimesSubmitting.length; i++) { for (let i = 0; i < sponsorTimesSubmitting.length; i++) {
@ -1476,13 +1462,15 @@ async function sendSubmitMessage(): Promise<void> {
}); });
if (response.status === 200) { if (response.status === 200) {
//hide loading message // Handle submission success
const submitButton = document.getElementById("submitButton"); const submitButton = playerButtons.submit.button;
// Make the animation finite
submitButton.style.animation = "rotate 1s"; submitButton.style.animation = "rotate 1s";
//finish this animation
//when the animation is over, hide the button // When the animation is over, hide the button
const animationEndListener = function() { const animationEndListener = () => {
changeStartSponsorButton(true, false); updateEditButtonsOnPlayer();
submitButton.style.animation = "none"; submitButton.style.animation = "none";
@ -1491,13 +1479,11 @@ async function sendSubmitMessage(): Promise<void> {
submitButton.addEventListener("animationend", animationEndListener); submitButton.addEventListener("animationend", animationEndListener);
//clear the sponsor times // Remove segments from storage since they've already been submitted
Config.config.segmentTimes.delete(sponsorVideoID); Config.config.segmentTimes.delete(sponsorVideoID);
//add submissions to current sponsors list // Add submissions to current sponsors list
if (sponsorTimes === null) sponsorTimes = []; sponsorTimes = (sponsorTimes || []).concat(sponsorTimesSubmitting);
sponsorTimes = sponsorTimes.concat(sponsorTimesSubmitting);
// Increase contribution count // Increase contribution count
Config.config.sponsorTimesContributed = Config.config.sponsorTimesContributed + sponsorTimesSubmitting.length; Config.config.sponsorTimesContributed = Config.config.sponsorTimesContributed + sponsorTimesSubmitting.length;
@ -1511,9 +1497,9 @@ async function sendSubmitMessage(): Promise<void> {
updatePreviewBar(); updatePreviewBar();
} else { } else {
//show that the upload failed // Show that the upload failed
document.getElementById("submitButton").style.animation = "unset"; playerButtons.submit.button.style.animation = "unset";
(<HTMLImageElement> document.getElementById("submitImage")).src = chrome.extension.getURL("icons/PlayerUploadFailedIconSponsorBlocker256px.png"); playerButtons.submit.image.src = chrome.extension.getURL("icons/PlayerUploadFailedIconSponsorBlocker.svg");
alert(utils.getErrorMessage(response.status, response.responseText)); alert(utils.getErrorMessage(response.status, response.responseText));
} }
@ -1570,7 +1556,7 @@ function hotkeyListener(e: KeyboardEvent): void {
} }
break; break;
case startSponsorKey: case startSponsorKey:
startSponsorClicked(); startOrEndTimingNewSegment();
break; break;
case submitKey: case submitKey:
submitSponsorTimes(); submitSponsorTimes();
@ -1578,14 +1564,6 @@ function hotkeyListener(e: KeyboardEvent): void {
} }
} }
/**
* Is this an unlisted YouTube video.
* Assumes that the the privacy info is available.
*/
function isUnlisted(): boolean {
return videoInfo?.microformat?.playerMicroformatRenderer?.isUnlisted || videoInfo?.videoDetails?.isPrivate;
}
/** /**
* Adds the CSS to the page if needed. Required on optional sites with Chrome. * Adds the CSS to the page if needed. Required on optional sites with Chrome.
*/ */

View file

@ -12,7 +12,6 @@ interface DefaultMessage {
message: message:
"update" "update"
| "sponsorStart" | "sponsorStart"
| "sponsorDataChanged"
| "isInfoFound" | "isInfoFound"
| "getVideoID" | "getVideoID"
| "getChannelID" | "getChannelID"
@ -25,13 +24,7 @@ interface BoolValueMessage {
value: boolean; value: boolean;
} }
interface ChangeStartSponsorButtonMessage { export type Message = BaseMessage & (DefaultMessage | BoolValueMessage);
message: "changeStartSponsorButton";
showStartSponsor: boolean;
uploadButtonVisible: boolean;
}
export type Message = BaseMessage & (DefaultMessage | BoolValueMessage | ChangeStartSponsorButtonMessage);
interface IsInfoFoundMessageResponse { interface IsInfoFoundMessageResponse {
found: boolean; found: boolean;
@ -47,7 +40,7 @@ interface GetChannelIDResponse {
} }
interface SponsorStartResponse { interface SponsorStartResponse {
time: number; creatingSegment: boolean;
} }
interface IsChannelWhitelistedResponse { interface IsChannelWhitelistedResponse {

View file

@ -22,6 +22,8 @@ async function init() {
if (granted) { if (granted) {
alert(chrome.i18n.getMessage("permissionRequestSuccess")); alert(chrome.i18n.getMessage("permissionRequestSuccess"));
Config.config.ytInfoPermissionGranted = true;
chrome.tabs.getCurrent((tab) => { chrome.tabs.getCurrent((tab) => {
chrome.tabs.remove(tab.id); chrome.tabs.remove(tab.id);
}); });

View file

@ -126,8 +126,8 @@ async function runThePopup(messageListener?: MessageListener): Promise<void> {
PageElements.optionsButton.addEventListener("click", openOptions); PageElements.optionsButton.addEventListener("click", openOptions);
PageElements.helpButton.addEventListener("click", openHelp); PageElements.helpButton.addEventListener("click", openHelp);
//if true, the button now selects the end time /** If true, the content script is in the process of creating a new segment. */
let startTimeChosen = false; let creatingSegment = false;
//the start and end time pairs (2d) //the start and end time pairs (2d)
let sponsorTimes: SponsorTime[] = []; let sponsorTimes: SponsorTime[] = [];
@ -233,11 +233,13 @@ async function runThePopup(messageListener?: MessageListener): Promise<void> {
function onTabs(tabs) { function onTabs(tabs) {
messageHandler.sendMessage(tabs[0].id, {message: 'getVideoID'}, function(result) { messageHandler.sendMessage(tabs[0].id, {message: 'getVideoID'}, function(result) {
if (result != undefined && result.videoID) { if (result !== undefined && result.videoID) {
currentVideoID = result.videoID; currentVideoID = result.videoID;
creatingSegment = result.creatingSegment;
loadTabData(tabs); loadTabData(tabs);
} else if (result == undefined && chrome.runtime.lastError) { } else if (result === undefined && chrome.runtime.lastError) {
// this isn't a YouTube video then, or at least the content script is not loaded //this isn't a YouTube video then, or at least the content script is not loaded
displayNoVideo(); displayNoVideo();
} }
}); });
@ -253,19 +255,11 @@ async function runThePopup(messageListener?: MessageListener): Promise<void> {
//load video times for this video //load video times for this video
const sponsorTimesStorage = Config.config.segmentTimes.get(currentVideoID); const sponsorTimesStorage = Config.config.segmentTimes.get(currentVideoID);
if (sponsorTimesStorage != undefined && sponsorTimesStorage.length > 0) { if (sponsorTimesStorage != undefined && sponsorTimesStorage.length > 0) {
if (sponsorTimesStorage[sponsorTimesStorage.length - 1] != undefined && sponsorTimesStorage[sponsorTimesStorage.length - 1].segment.length < 2) {
startTimeChosen = true;
PageElements.sponsorStart.innerHTML = chrome.i18n.getMessage("sponsorEnd");
}
sponsorTimes = sponsorTimesStorage; sponsorTimes = sponsorTimesStorage;
//show submission section
PageElements.submissionSection.style.display = "unset";
showSubmitTimesIfNecessary();
} }
updateSegmentEditingUI();
//check if this video's sponsors are known //check if this video's sponsors are known
messageHandler.sendMessage( messageHandler.sendMessage(
tabs[0].id, tabs[0].id,
@ -321,51 +315,44 @@ async function runThePopup(messageListener?: MessageListener): Promise<void> {
//the content script will get the message if a YouTube page is open //the content script will get the message if a YouTube page is open
messageHandler.query({ messageHandler.query({
active: true, active: true,
currentWindow: true currentWindow: true,
}, tabs => { }, (tabs) => {
messageHandler.sendMessage( messageHandler.sendMessage(
tabs[0].id, tabs[0].id,
{from: 'popup', message: 'sponsorStart'}, {from: 'popup', message: 'sponsorStart'},
startSponsorCallback async (response) => {
startSponsorCallback(response);
// Perform a second update after the config changes take effect as a workaround for a race condition
const removeListener = (listener: typeof lateUpdate) => {
const index = Config.configListeners.indexOf(listener);
if (index !== -1) Config.configListeners.splice(index, 1);
};
const lateUpdate = () => {
startSponsorCallback(response);
removeListener(lateUpdate);
};
Config.configListeners.push(lateUpdate);
// Remove the listener after 200ms in case the changes were propagated by the time we got the response
setTimeout(() => removeListener(lateUpdate), 200);
},
); );
}); });
} }
function startSponsorCallback(response) { function startSponsorCallback(response: {creatingSegment: boolean}) {
const sponsorTimesIndex = sponsorTimes.length - (startTimeChosen ? 1 : 0); creatingSegment = response.creatingSegment;
if (sponsorTimes[sponsorTimesIndex] == undefined) { // Only update the segments after a segment was created
sponsorTimes[sponsorTimesIndex] = { if (!creatingSegment) {
segment: [], sponsorTimes = Config.config.segmentTimes.get(currentVideoID) || [];
category: Config.config.defaultCategory,
UUID: null
};
} }
sponsorTimes[sponsorTimesIndex].segment[startTimeChosen ? 1 : 0] = response.time; // Update the UI
updateSegmentEditingUI();
const localStartTimeChosen = startTimeChosen;
Config.config.segmentTimes.set(currentVideoID, sponsorTimes);
//send a message to the client script
if (localStartTimeChosen) {
messageHandler.query({
active: true,
currentWindow: true
}, tabs => {
messageHandler.sendMessage(
tabs[0].id,
{message: "sponsorDataChanged"}
);
});
}
updateStartTimeChosen();
//show submission section
PageElements.submissionSection.style.display = "unset";
showSubmitTimesIfNecessary();
} }
//display the video times from the array at the top, in a different section //display the video times from the array at the top, in a different section
@ -484,34 +471,13 @@ async function runThePopup(messageListener?: MessageListener): Promise<void> {
PageElements.showNoticeAgain.style.display = "none"; PageElements.showNoticeAgain.style.display = "none";
} }
function updateStartTimeChosen() { /** Updates any UI related to segment editing and submission according to the current state. */
//update startTimeChosen letiable function updateSegmentEditingUI() {
if (!startTimeChosen) { PageElements.sponsorStart.innerText = chrome.i18n.getMessage(creatingSegment ? "sponsorEnd" : "sponsorStart");
startTimeChosen = true;
PageElements.sponsorStart.innerHTML = chrome.i18n.getMessage("sponsorEnd"); PageElements.submissionSection.style.display = sponsorTimes && sponsorTimes.length > 0 ? "unset" : "none";
} else {
resetStartTimeChosen();
}
} }
//set it to false
function resetStartTimeChosen() {
startTimeChosen = false;
PageElements.sponsorStart.innerHTML = chrome.i18n.getMessage("sponsorStart");
}
//hides and shows the submit times button when needed
function showSubmitTimesIfNecessary() {
//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 = "flex";
} else {
//hide submit times button
document.getElementById("submitTimesContainer").style.display = "none";
}
}
//make the options div visible //make the options div visible
function openOptions() { function openOptions() {
chrome.runtime.sendMessage({"message": "openConfig"}); chrome.runtime.sendMessage({"message": "openConfig"});
@ -615,8 +581,7 @@ async function runThePopup(messageListener?: MessageListener): Promise<void> {
{message: 'getChannelID'}, {message: 'getChannelID'},
function(response) { function(response) {
if (!response.channelID) { if (!response.channelID) {
alert(chrome.i18n.getMessage("channelDataNotFound") + "\n\n" + alert(chrome.i18n.getMessage("channelDataNotFound") + " https://github.com/ajayyy/SponsorBlock/issues/753");
chrome.i18n.getMessage("itCouldBeAdblockerIssue"));
return; return;
} }
@ -726,10 +691,11 @@ async function runThePopup(messageListener?: MessageListener): Promise<void> {
* @param {float} seconds * @param {float} seconds
* @returns {string} * @returns {string}
*/ */
function getFormattedHours(minues) { function getFormattedHours(minutes) {
const hours = Math.floor(minues / 60); minutes = Math.round(minutes * 10) / 10
return (hours > 0 ? hours + "h " : "") + (minues % 60).toFixed(1); const hours = Math.floor(minutes / 60);
} return (hours > 0 ? hours + "h " : "") + (minutes % 60).toFixed(1);
}
//end of function //end of function
} }

View file

@ -17,7 +17,7 @@ export interface ContentContainer {
onMobileYouTube: boolean, onMobileYouTube: boolean,
sponsorSubmissionNotice: SubmissionNotice, sponsorSubmissionNotice: SubmissionNotice,
resetSponsorSubmissionNotice: () => void, resetSponsorSubmissionNotice: () => void,
changeStartSponsorButton: (showStartSponsor: boolean, uploadButtonVisible: boolean) => Promise<boolean>, updateEditButtonsOnPlayer: () => void,
previewTime: (time: number, unpause?: boolean) => void, previewTime: (time: number, unpause?: boolean) => void,
videoInfo: VideoInfo, videoInfo: VideoInfo,
getRealCurrentTime: () => number getRealCurrentTime: () => number
@ -60,7 +60,7 @@ export type SegmentUUID = string & { __segmentUUIDBrand: unknown };
export type Category = string & { __categoryBrand: unknown }; export type Category = string & { __categoryBrand: unknown };
export interface SponsorTime { export interface SponsorTime {
segment: number[]; segment: [number] | [number, number];
UUID: SegmentUUID; UUID: SegmentUUID;
category: Category; category: Category;
@ -168,4 +168,15 @@ export type VideoID = string;
export type StorageChangesObject = { [key: string]: chrome.storage.StorageChange }; export type StorageChangesObject = { [key: string]: chrome.storage.StorageChange };
export type UnEncodedSegmentTimes = [string, SponsorTime[]][]; export type UnEncodedSegmentTimes = [string, SponsorTime[]][];
export enum ChannelIDStatus {
Fetching,
Found,
Failed
}
export interface ChannelIDInfo {
id: string,
status: ChannelIDStatus
}

View file

@ -23,8 +23,8 @@ export default class Utils {
this.backgroundScriptContainer = backgroundScriptContainer; this.backgroundScriptContainer = backgroundScriptContainer;
} }
// Function that can be used to wait for a condition before returning /** Function that can be used to wait for a condition before returning. */
async wait(condition: () => HTMLElement | boolean, timeout = 5000, check = 100): Promise<HTMLElement | boolean> { async wait<T>(condition: () => T | false, timeout = 5000, check = 100): Promise<T> {
return await new Promise((resolve, reject) => { return await new Promise((resolve, reject) => {
setTimeout(() => reject("TIMEOUT"), timeout); setTimeout(() => reject("TIMEOUT"), timeout);