Compare commits

...

43 Commits
3.0.4 ... 3.2

Author SHA1 Message Date
Ajay Ramachandran
f219122f00 bump version 2021-09-19 22:41:21 -04:00
Ajay Ramachandran
008671d97f New Crowdin updates (#938) 2021-09-19 22:40:43 -04:00
FlorianZahn
6fb3802fd4 Preview skip-lenth dependant on playbackspeed (#949)
* Preview button playback speed dependant

Pressing "Preview" will now jump 2 seconds in front of the segment start time, depending on the playback speed.
2021-09-19 10:24:37 -04:00
Ajay Ramachandran
73241a0bd1 Fix in the middle of mute 2021-09-16 23:21:59 -04:00
Ajay Ramachandran
cc995b9848 Merge pull request #942 from LofhJann/master
Fix username wrapping
2021-09-15 21:33:23 -04:00
Janne Löfhjelm
778379d294 Fix username wrapping 2021-09-11 03:33:41 +03:00
Ajay Ramachandran
1083520666 Add warning for submitting multiple highlights 2021-09-10 19:07:16 -04:00
Ajay Ramachandran
cad5cd97fc New Crowdin updates (#933) 2021-09-07 23:29:35 -04:00
Ajay Ramachandran
7f5728d4db bump version 2021-09-07 23:28:48 -04:00
Ajay Ramachandran
06fa2748fe Fix package-lock, fix #937 2021-09-07 18:54:37 -04:00
Ajay Ramachandran
8b50373eab Merge branch 'master' of https://github.com/ajayyy/SponsorBlock 2021-09-06 23:51:28 -04:00
Ajay Ramachandran
bdedf86d63 Fix selenium test to change category 2021-09-06 23:51:26 -04:00
Ajay Ramachandran
0fb84dc03d Merge pull request #934 from KarelVerschraegen/patch-2
Fix typo in SubmissionNoticeComponent
2021-09-06 16:11:03 -04:00
Ajay Ramachandran
041ccdaf11 Merge branch 'master' of https://github.com/ajayyy/SponsorBlock 2021-09-06 16:10:34 -04:00
Ajay Ramachandran
1f967b3f69 Fix skips not being counted and crash on old browser 2021-09-06 16:10:32 -04:00
KarelVerschraegen
07f0b87379 Fix typo in SubmissionNoticeComponent 2021-09-06 15:50:13 +02:00
Ajay Ramachandran
840dbbde4a New Crowdin updates (#928) 2021-09-05 13:30:51 -04:00
Ajay Ramachandran
2b9000ff84 bump version 2021-09-05 13:29:45 -04:00
Ajay Ramachandran
0d0171530c Remove unused string 2021-09-04 02:17:57 -04:00
Ajay Ramachandran
6040d177fa Say muted instead of skipped for mute segments 2021-09-04 02:09:10 -04:00
Ajay Ramachandran
2c1f5f16c2 Only show mute option for supported categories 2021-09-04 01:44:09 -04:00
Ajay Ramachandran
0e7a298967 bump version 2021-09-03 17:01:03 -04:00
Ajay Ramachandran
9a9f151979 New Crowdin updates (#926) 2021-09-03 16:58:07 -04:00
Ajay Ramachandran
ca814c9dcc Merge pull request #917 from mchangrh/update-matrix
update matrix links
2021-09-03 16:36:58 -04:00
Ajay Ramachandran
976dbb9159 Merge branch 'master' into update-matrix 2021-09-03 16:36:51 -04:00
Ajay Ramachandran
90ce9808f1 New Crowdin updates (#924)
* New translations messages.json (Italian)

* New translations messages.json (Vietnamese)

* New translations messages.json (Swedish)

* New translations messages.json (Turkish)

* New translations messages.json (Chinese Simplified)

* New translations messages.json (Indonesian)

* New translations messages.json (Tamil)

* New translations messages.json (Polish)

* New translations messages.json (Croatian)

* New translations messages.json (Estonian)

* New translations messages.json (Malay)

* New translations messages.json (Telugu)

* New translations messages.json (Malayalam)

* New translations messages.json (Norwegian)

* New translations messages.json (Russian)

* New translations messages.json (French)

* New translations messages.json (Portuguese, Brazilian)

* New translations messages.json (Spanish)

* New translations messages.json (Czech)

* New translations messages.json (German)

* New translations messages.json (Japanese)

* New translations messages.json (Dutch)

* New translations messages.json (Slovak)

* New translations messages.json (Ukrainian)

* New translations messages.json (Chinese Traditional)

* New translations messages.json (Romanian)

* New translations messages.json (Bulgarian)

* New translations messages.json (Finnish)

* New translations messages.json (Hungarian)

* New translations messages.json (Italian)

* New translations messages.json (Korean)

* New translations messages.json (German)

* New translations messages.json (Dutch)

* New translations messages.json (Ukrainian)

* New translations messages.json (French)

* New translations messages.json (Korean)

* New translations messages.json (Turkish)
2021-09-03 16:35:11 -04:00
Ajay Ramachandran
ef942fca8e Merge pull request #923 from ajayyy/silent-skip
Mute segments
2021-09-02 13:22:44 -04:00
Ajay Ramachandran
3671c4bb69 Hide mute option for highlight 2021-09-02 13:20:50 -04:00
Ajay Ramachandran
ef15526dcd Explain how to get public userID 2021-09-02 12:00:18 -04:00
Ajay Ramachandran
096737dcbb bump version 2021-09-02 11:44:38 -04:00
Ajay Ramachandran
02360c1f3c Fix centering on submission notice 2021-09-02 11:44:25 -04:00
Ajay Ramachandran
ccd8342ddb Update top contibutors 2021-09-02 00:37:53 -04:00
Ajay Ramachandran
4ae2a42c8c New Crowdin updates (#902) 2021-09-02 00:19:36 -04:00
Ajay Ramachandran
5ad809cfb4 Add e2e test for mute skip 2021-09-01 22:00:48 -04:00
Ajay Ramachandran
d1e46825af Fix mute skip failing on videos without segments 2021-09-01 22:00:48 -04:00
Ajay Ramachandran
2763b6b6aa Clarify muting option 2021-09-01 22:00:48 -04:00
Ajay Ramachandran
427b90a5e9 Add option to disable mute segments 2021-09-01 22:00:48 -04:00
Ajay Ramachandran
60e54ee129 Hide unmute buttons after segment is finished 2021-09-01 22:00:48 -04:00
Ajay Ramachandran
4092bf9b05 Make skip notice buttons work with mute segments 2021-09-01 22:00:48 -04:00
Ajay Ramachandran
f31c2985e2 Add silent skipping to scheduler 2021-09-01 22:00:48 -04:00
Ajay Ramachandran
34cfd14e74 Add UI for submitting mute segments and request mute segments 2021-09-01 21:59:44 -04:00
Michael C
0367f7900f udpate discord link for consistency 2021-08-29 15:01:11 -04:00
Michael C
47261a360c update matrix links 2021-08-29 14:56:08 -04:00
54 changed files with 1942 additions and 26303 deletions

View File

@@ -2,5 +2,15 @@
"serverAddress": "https://sponsor.ajay.app", "serverAddress": "https://sponsor.ajay.app",
"testingServerAddress": "https://sponsor.ajay.app/test", "testingServerAddress": "https://sponsor.ajay.app/test",
"serverAddressComment": "This specifies the default SponsorBlock server to connect to", "serverAddressComment": "This specifies the default SponsorBlock server to connect to",
"categoryList": ["sponsor", "selfpromo", "interaction", "poi_highlight", "intro", "outro", "preview", "music_offtopic"] "categoryList": ["sponsor", "selfpromo", "interaction", "poi_highlight", "intro", "outro", "preview", "music_offtopic"],
"categorySupport": {
"sponsor": ["skip", "mute"],
"selfpromo": ["skip", "mute"],
"interaction": ["skip", "mute"],
"intro": ["skip"],
"outro": ["skip"],
"preview": ["skip"],
"music_offtopic": ["skip"],
"poi_highlight": ["skip"]
}
} }

View File

@@ -1,7 +1,7 @@
{ {
"name": "__MSG_fullName__", "name": "__MSG_fullName__",
"short_name": "SponsorBlock", "short_name": "SponsorBlock",
"version": "3.0.4", "version": "3.2",
"default_locale": "en", "default_locale": "en",
"description": "__MSG_Description__", "description": "__MSG_Description__",
"homepage_url": "https://sponsor.ajay.app", "homepage_url": "https://sponsor.ajay.app",

26181
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -57,5 +57,35 @@
}, },
"manualPaused": { "manualPaused": {
"message": "تم إيقاف الموقت" "message": "تم إيقاف الموقت"
},
"confirmMSG": {
"message": "لتحرير أو حذف قيّم فردياً، انقر فوق زر المعلومات أو فتح الإضافة عن طريق النقر على أيقونة الإضافة في الزاوية اليمنى العليا."
},
"clearThis": {
"message": "هل أنت متأكد أنك تريد حذف هذا؟\n\n"
},
"Unknown": {
"message": "حدث خطأ في إرسال توقيت الرعاة الخاص بك، الرجاء المحاولة مرة أخرى لاحقاً."
},
"sponsorFound": {
"message": "يحتوي هذا الفيديو على أجزاء في قاعدة البيانات!"
},
"sponsor404": {
"message": "لم يتم العثور على أجزاء"
},
"sponsorStart": {
"message": "يبدأ الجزء الآن"
},
"sponsorEnd": {
"message": "ينتهي الجزء الآن"
},
"sponsorCancel": {
"message": "إلغاء إنشاء جزء"
},
"noVideoID": {
"message": "لم يتم العثور على فيديو يوتيوب.\nإذا كان هذا غير صحيح، قم بتحديث الصفحة."
},
"refreshSegments": {
"message": "تحديث الأجزاء"
} }
} }

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Пропускане отново" "message": "Пропускане отново"
}, },
"unmute": {
"message": "Вкл. на звука"
},
"paused": { "paused": {
"message": "На пауза" "message": "На пауза"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Възникна грешка с връзката. Код на грешката: " "message": "Възникна грешка с връзката. Код на грешката: "
}, },
"wantToSubmit": {
"message": "Искате ли да изпратите сегментите за видеоклип с id"
},
"clearTimes": { "clearTimes": {
"message": "Изчистване на сегментите" "message": "Изчистване на сегментите"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Задайте потребителско име" "message": "Задайте потребителско име"
}, },
"copyPublicID": {
"message": "Копиране на публичния UserID"
},
"discordAdvert": { "discordAdvert": {
"message": "Елате в официалния Discord сървър, за да давате предложения!" "message": "Елате в официалния Discord сървър, за да давате предложения!"
}, },
@@ -299,9 +302,15 @@
"skip": { "skip": {
"message": "Пропускане" "message": "Пропускане"
}, },
"mute": {
"message": "Заглушаване"
},
"skip_category": { "skip_category": {
"message": "Пропускане на {0}?" "message": "Пропускане на {0}?"
}, },
"mute_category": {
"message": "Заглушаване на {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Прескачане до {0}?", "message": "Прескачане до {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -310,6 +319,10 @@
"message": "{0} пропуснат", "message": "{0} пропуснат",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} заглушено",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Прескочено до {0}", "message": "Прескочено до {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -363,7 +376,7 @@
"message": "Импортиране/експортиране на вашия UserID" "message": "Импортиране/експортиране на вашия UserID"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Това трябва да се пази тайно. То е като парола и не трябва да се споделя с никого. Ако някой го притежава, той може да се представи за вас." "message": "Това трябва да се пази в тайна. То е като парола и не трябва да се споделя с никого. Ако някой го има, може да се представи за вас. Ако търсите своя публичен потребителски идентификатор, щракнете върху иконата на клипборда в изскачащия прозорец."
}, },
"setUserID": { "setUserID": {
"message": "Задаване на UserID" "message": "Задаване на UserID"
@@ -601,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Автоматично пропускане на всички сегменти, когато има сегмент без музика" "message": "Автоматично пропускане на всички сегменти, когато има сегмент без музика"
}, },
"muteSegments": {
"message": "Разрешаване на сегменти, които заглушават звука, вместо да се пропускат"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Вашият цвят не е форматиран правилно. Трябва да бъде 3- или 6-цифрен шестнадесетичен код с „#“ в началото." "message": "Вашият цвят не е форматиран правилно. Трябва да бъде 3- или 6-цифрен шестнадесетичен код с „#“ в началото."
}, },
@@ -640,6 +656,9 @@
"message": "За да изпратите сегменти с категория „{0}“, трябва да я активирате от опциите. Ще бъдете пренасочени към опциите сега.", "message": "За да изпратите сегменти с категория „{0}“, трябва да я активирате от опциите. Ще бъдете пренасочени към опциите сега.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Внимание: Само един сегмент от този тип може да е активен. Изпращането на няколко ще доведе до показване на случаен."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Трябва да изберете категория за всички сегменти, които изпращате!" "message": "Трябва да изберете категория за всички сегменти, които изпращате!"
}, },
@@ -723,7 +742,7 @@
"message": "Скриване завинаги" "message": "Скриване завинаги"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Получихте предупреждение и временно не можете да изпращате сегменти. Това означава, че забелязахме, че допускате някои често срещани грешки, които не са злонамерени, и просто искаме да изясним правилата. Можете също да се присъедините към този чат с помощта на discord.gg/SponsorBlock или matrix.to/#/+sponsor:ajay.app" "message": "Получихте предупреждение и временно не можете да изпращате сегменти. Това означава, че забелязахме, че допускате някои често срещани грешки, които не са злонамерени, и просто искаме да изясним правилата. Можете също да се присъедините към този чат с помощта на discord.gg/SponsorBlock или matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Гласуването е отхвърлено поради предупреждение. Щракнете, за да отворите чат и да го разрешите, или се върнете по-късно, когато имате време.", "message": "Гласуването е отхвърлено поради предупреждение. Щракнете, за да отворите чат и да го разрешите, или се върнете по-късно, когато имате време.",

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Znovu přeskočit" "message": "Znovu přeskočit"
}, },
"unmute": {
"message": "Zrušit ztlumení"
},
"paused": { "paused": {
"message": "Pozastaveno" "message": "Pozastaveno"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Došlo k chybě připojení. Kód chyby: " "message": "Došlo k chybě připojení. Kód chyby: "
}, },
"wantToSubmit": {
"message": "Chcete odeslat segmenty pro video s id"
},
"clearTimes": { "clearTimes": {
"message": "Vymazat segmenty" "message": "Vymazat segmenty"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Nastavit uživatelské jméno" "message": "Nastavit uživatelské jméno"
}, },
"copyPublicID": {
"message": "Kopírovat veřejné uživatelské ID"
},
"discordAdvert": { "discordAdvert": {
"message": "Připojte se k oficiálnímu Discord serveru k podání návrhů a zpětné vazby!" "message": "Připojte se k oficiálnímu Discord serveru k podání návrhů a zpětné vazby!"
}, },
@@ -299,9 +302,15 @@
"skip": { "skip": {
"message": "Přeskočit" "message": "Přeskočit"
}, },
"mute": {
"message": "Ztlumit"
},
"skip_category": { "skip_category": {
"message": "Přeskočit {0}?" "message": "Přeskočit {0}?"
}, },
"mute_category": {
"message": "Ztlumit {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Přeskočit na {0}?", "message": "Přeskočit na {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -310,6 +319,10 @@
"message": "Segment {0} přeskočen", "message": "Segment {0} přeskočen",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "Segment {0} ztlumen",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Přeskočeno na {0}", "message": "Přeskočeno na {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -363,7 +376,7 @@
"message": "Importovat / exportovat vaše UserID" "message": "Importovat / exportovat vaše UserID"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Toto byste měli udržet v soukromí. Je to jako heslo a neměli byste jej s nikým sdílet. Pokud jej někdo má, může se za vás vydávat." "message": "Toto by mělo být ponecháno v soukromí. Je to jako heslo a nemělo by být s nikým sdíleno. Pokud to někdo má, může se za vás vydávat. Pokud hledáte vaše veřejné uživatelské ID, klikněte na ikonu schránky ve vyskakovacím okně."
}, },
"setUserID": { "setUserID": {
"message": "Nastavit UserID" "message": "Nastavit UserID"
@@ -601,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Automaticky přeskočit všechny segmenty, když je ve videu nehudební segment" "message": "Automaticky přeskočit všechny segmenty, když je ve videu nehudební segment"
}, },
"muteSegments": {
"message": "Povolit segmenty, které místo přeskočení ztlumují zvuk"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Vaše barva má nesprávný formát. Měl by to být 3 nebo 6 znaků dlouhý HEX kód s křížkem na začátku." "message": "Vaše barva má nesprávný formát. Měl by to být 3 nebo 6 znaků dlouhý HEX kód s křížkem na začátku."
}, },
@@ -640,6 +656,9 @@
"message": "Pro odeslání segmentů v kategorii \"{0}\" to nejprve musíte povolit v nastavení. Nyní budete přesměrováni do nastavení.", "message": "Pro odeslání segmentů v kategorii \"{0}\" to nejprve musíte povolit v nastavení. Nyní budete přesměrováni do nastavení.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Varování: tento typ segmentu může být aktivní najednou pouze jeden. Odeslání více segmentů způsobí zobrazení náhodného segmentu."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Musíte vybrat kategorii pro všechny odeslané segmenty!" "message": "Musíte vybrat kategorii pro všechny odeslané segmenty!"
}, },
@@ -723,7 +742,7 @@
"message": "Skrýt napořád" "message": "Skrýt napořád"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Dostali jste varování a nemůžete dočasně přidávat segmenty. To znamená, že jsme si všimli, že děláte běžné chyby, které nejsou škodlivé, jen chceme vyjasnit pravidla. Také se můžete připojit do tohoto chatu pomocí discord.gg/SponsorBlock nebo matrix.to/#/+sponsor:ajay.app" "message": "Dostali jste varování a nemůžete dočasně přidávat segmenty. To znamená, že jsme si všimli, že děláte běžné chyby, které nejsou škodlivé, jen chceme vyjasnit pravidla. Také se můžete připojit do tohoto chatu pomocí discord.gg/SponsorBlock nebo matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Hlas zamítnut kvůli varování. Klikněte pro otevření chatu pro vyřešení, nebo se vraťte později, až budete mít čas.", "message": "Hlas zamítnut kvůli varování. Klikněte pro otevření chatu pro vyřešení, nebo se vraťte později, až budete mít čas.",

View File

@@ -4,7 +4,7 @@
"description": "Name of the extension." "description": "Name of the extension."
}, },
"Description": { "Description": {
"message": "Überspringe Sponsoren, Betteln um Abonnenten und mehr in YouTube-Videos. Melde Sponsoren in Videos, die du guckst, um Anderen Zeit zu sparen.", "message": "Überspringe Sponsoren, Betteln um Abonnenten und mehr in YouTube-Videos. Melde Sponsoren in Videos, die du schaust, um Anderen Zeit zu ersparen.",
"description": "Description of the extension." "description": "Description of the extension."
}, },
"400": { "400": {
@@ -32,7 +32,7 @@
"message": "Melden" "message": "Melden"
}, },
"reportButtonInfo": { "reportButtonInfo": {
"message": "Diesen Beitrag als falsch melden." "message": "Beitrag als unzulässig melden."
}, },
"Dismiss": { "Dismiss": {
"message": "Abbrechen" "message": "Abbrechen"
@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Nochmal überspringen" "message": "Nochmal überspringen"
}, },
"unmute": {
"message": "Ton an"
},
"paused": { "paused": {
"message": "Pausiert" "message": "Pausiert"
}, },
@@ -86,10 +89,10 @@
"message": "Kein YouTube-Video gefunden.\nWenn dies falsch ist, aktualisiere den Tab." "message": "Kein YouTube-Video gefunden.\nWenn dies falsch ist, aktualisiere den Tab."
}, },
"refreshSegments": { "refreshSegments": {
"message": "Segment aktualisieren" "message": "Segmente aktualisieren"
}, },
"success": { "success": {
"message": "Geschafft!" "message": "Erfolg!"
}, },
"voted": { "voted": {
"message": "Abgestimmt!" "message": "Abgestimmt!"
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Ein Verbindungsfehler ist aufgetreten. Fehlermeldung: " "message": "Ein Verbindungsfehler ist aufgetreten. Fehlermeldung: "
}, },
"wantToSubmit": {
"message": "Möchtest du für Video-ID einreichen"
},
"clearTimes": { "clearTimes": {
"message": "Alle Segmente löschen" "message": "Alle Segmente löschen"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Benutzernamen festlegen" "message": "Benutzernamen festlegen"
}, },
"copyPublicID": {
"message": "Öffentliche Benutzer-ID kopieren"
},
"discordAdvert": { "discordAdvert": {
"message": "Tritt dem offiziellen Discord-Server bei und teile Anregungen und Feedback!" "message": "Tritt dem offiziellen Discord-Server bei und teile Anregungen und Feedback!"
}, },
@@ -227,6 +230,21 @@
"showSkipNotice": { "showSkipNotice": {
"message": "Zeige Pop-up nach dem Überspringen eines Segments" "message": "Zeige Pop-up nach dem Überspringen eines Segments"
}, },
"noticeVisibilityMode0": {
"message": "Skip-Meldung in voller größe"
},
"noticeVisibilityMode1": {
"message": "Kleine Skip-Meldung für Auto-Skips"
},
"noticeVisibilityMode2": {
"message": "Alles kleine Skip-Meldungen"
},
"noticeVisibilityMode3": {
"message": "Verblasste Skip-Meldung für Auto-Skip"
},
"noticeVisibilityMode4": {
"message": "Alles verblasste Skip-Meldungen"
},
"longDescription": { "longDescription": {
"message": "SponsorBlock lässt dich gesponserte Videosegmente, Intros, Outros, Interaktions-Erinnerungen, Musikvideoteile ohne Musik und andere nervige Teile von YouTube-Videos überspringen. SponsorBlock ist eine crowdsourced Browser-Erweiterung, in der jeder die Start- und Endzeit gesponserter Videosegmente und anderer Segmente von YouTube-Videos einreicht. Sobald eine Person diese Informationen einreicht, überspringen alle anderen mit dieser Erweiterung das gesponserte Segment.", "message": "SponsorBlock lässt dich gesponserte Videosegmente, Intros, Outros, Interaktions-Erinnerungen, Musikvideoteile ohne Musik und andere nervige Teile von YouTube-Videos überspringen. SponsorBlock ist eine crowdsourced Browser-Erweiterung, in der jeder die Start- und Endzeit gesponserter Videosegmente und anderer Segmente von YouTube-Videos einreicht. Sobald eine Person diese Informationen einreicht, überspringen alle anderen mit dieser Erweiterung das gesponserte Segment.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
@@ -284,9 +302,15 @@
"skip": { "skip": {
"message": "Überspringen" "message": "Überspringen"
}, },
"mute": {
"message": "Ton aus"
},
"skip_category": { "skip_category": {
"message": "{0} überspringen?" "message": "{0} überspringen?"
}, },
"mute_category": {
"message": "{0} stummschalten?"
},
"skip_to_category": { "skip_to_category": {
"message": "Zu {0} springen?", "message": "Zu {0} springen?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -295,6 +319,10 @@
"message": "{0} übersprungen", "message": "{0} übersprungen",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} stummgeschalten",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Zu {0} gesprungen", "message": "Zu {0} gesprungen",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -348,7 +376,7 @@
"message": "Benutzer-ID importieren/exportieren" "message": "Benutzer-ID importieren/exportieren"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Halte diese ID geheim. Sie ist dazu in der Lage dich eindeutig zu identifizieren und sollte mit niemanden geteilt werden." "message": "Dies sollte geheim gehalten werden. Dies ist wie ein Passwort und sollte mit niemandem geteilt werden. Sollte es jemand haben, könnte er sich als dich ausgeben. Wenn du nach deiner öffentlichen Benutzer-ID suchst, klicke das \"Kopieren\"-Symbol bei deinem Benutzernamen im Popup."
}, },
"setUserID": { "setUserID": {
"message": "Interne Benutzer-ID festlegen" "message": "Interne Benutzer-ID festlegen"
@@ -442,7 +470,7 @@
"message": "Import/Export aller Einstellungen" "message": "Import/Export aller Einstellungen"
}, },
"whatExportOptions": { "whatExportOptions": {
"message": "Dies ist deine gesamte Konfiguration im JSON-Format. Sie beinhält unter anderem auch deine interne Benutzer-ID und sollte daher ebenfalls mit niemanden geteilt werden." "message": "Dies ist deine gesamte Konfiguration im JSON-Format. Da diese auch deine Benutzer-ID enthält, solltest du dir genau überlegen, mit wem du diese teilen möchtest."
}, },
"setOptions": { "setOptions": {
"message": "Konfiguration aus dem Eingabefeld übernehmen" "message": "Konfiguration aus dem Eingabefeld übernehmen"
@@ -469,7 +497,7 @@
"message": "Vorschau" "message": "Vorschau"
}, },
"unsubmitted": { "unsubmitted": {
"message": "Nicht eingereicht" "message": "Nicht übermittelt"
}, },
"inspect": { "inspect": {
"message": "Überprüfen" "message": "Überprüfen"
@@ -577,12 +605,18 @@
"autoSkip_POI": { "autoSkip_POI": {
"message": "Automatisch zum Start springen" "message": "Automatisch zum Start springen"
}, },
"manualSkip_POI": {
"message": "Beim Laden des Videos fragen"
},
"showOverlay_POI": { "showOverlay_POI": {
"message": "In der Video-Zeitleiste anzeigen" "message": "In Suchleiste anzeigen"
}, },
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Alle Segmente automatisch überspringen, wenn ein nicht-Musiksegment vorhanden ist" "message": "Alle Segmente automatisch überspringen, wenn ein nicht-Musiksegment vorhanden ist"
}, },
"muteSegments": {
"message": "Segmente zulassen, die den Ton ausschalten anstatt zu überspringen"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Die Farbe ist falsch formatiert. Sie sollte ein 3-6-stelliger Hex-Code mit einer Raute am Anfang sein." "message": "Die Farbe ist falsch formatiert. Sie sollte ein 3-6-stelliger Hex-Code mit einer Raute am Anfang sein."
}, },
@@ -622,6 +656,9 @@
"message": "Um Segmente aus der Kategorie \"{0}\" zu senden, musst du diese in den Optionen aktivieren. Du wirst jetzt zu den Optionen weitergeleitet.", "message": "Um Segmente aus der Kategorie \"{0}\" zu senden, musst du diese in den Optionen aktivieren. Du wirst jetzt zu den Optionen weitergeleitet.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Achtung: Diese Art von Segment kann nur einmal pro Video aktiv sein. Sollten mehrere eingereicht werden, wird ein zufälliges angezeigt werden."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Du musst eine Kategorie für jedes zu übermittelnde Segment auswählen!" "message": "Du musst eine Kategorie für jedes zu übermittelnde Segment auswählen!"
}, },
@@ -693,18 +730,91 @@
"help": { "help": {
"message": "Hilfe" "message": "Hilfe"
}, },
"GotIt": {
"message": "Verstanden",
"description": "Used as the button to dismiss a tooltip"
},
"experiementOptOut": { "experiementOptOut": {
"message": "Abmeldung aller zukünftigen Experimente", "message": "Aus allen zukünftigen Experimenten abmelden",
"description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private." "description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private."
}, },
"hideForever": { "hideForever": {
"message": "Dauerhaft verbergen" "message": "Dauerhaft verbergen"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Du wurdest ermahnt und kannst zur Zeit keine Segmente einreichen. Uns ist nämlich aufgefallen, dass du ein paar gängige Fehler machst, die nicht bösartig sind. Um die Regeln klarzustellen laden wir dich zu einem kurzem Gespräch auf discord.gg/SponsorBlock oder matrix.to/#/+sponsor:ajay.app ein" "message": "Du wurdest verwarnt und kannst vorrübergehend keine Segmente einreichen. Es ist uns aufgefallen, dass du gängige Fehler machst, welche nicht schädlich sind, und wir wollen dir nur die Regeln klar machen. Du kannst auch dem Chat durch discord.gg/SponsorBlock oder matrix.to/#/#sponsor:ajay.app beitreten"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Abstimmung wegen einer Warnung abgelehnt. Um über sie zu reden, klicke hier, oder schreibe uns später.", "message": "Abstimmung wegen einer Warnung abgelehnt. Klicke hier um einen Chat zu öffnen, oder versuch es später erneut, wenn du Zeit hast.",
"description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser." "description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser."
},
"Donate": {
"message": "Spenden"
},
"hideDonationLink": {
"message": "Verstecke Spendenlink"
},
"helpPageThanksForInstalling": {
"message": "Danke fürs installieren von SponsorBlock."
},
"helpPageReviewOptions": {
"message": "Bitte überprüfe die unten stehenden Optionen"
},
"helpPageFeatureDisclaimer": {
"message": "Viele Funktionen sind standardmäßig deaktiviert. Wenn du Intros und Outtros überspringen willst, Invidious verwenden willst, usw. aktiviere sie unten. Du kannst auch UI-Elemente verstecken/anzeigen."
},
"helpPageHowSkippingWorks": {
"message": "Wie überspringen funktioniert"
},
"helpPageHowSkippingWorks1": {
"message": "Videosegmente werden automatisch übersprungen, wenn sie in der Datenbank gefunden werden. Du kannst das Popup öffnen, indem du auf das Erweiterungssymbol klickst, um eine Vorschau darüber zu erhalten, was diese sind."
},
"helpPageHowSkippingWorks2": {
"message": "Wannimmer du ein Segment überspringst, wirst du benachrichtigt. Wenn das Timing falsch erscheint, kannst du as durch klicken auf den Downvote button downvoten! Du kannst auch im Popup voten."
},
"Submitting": {
"message": "Übermitteln"
},
"helpPageSubmitting1": {
"message": "Das übermitteln kann entweder im Popup durch das drücken vom \"Segment Started Jetzt\" Knopf oder im Videoplayer mit den Knöpfen im Player gemacht werden."
},
"helpPageSubmitting2": {
"message": "Mit einem Klick auf den Play-Knopf wird der Beginn eines Segments und mit dem klick auf den Stop-Knopf das ende eines Segments markiert. Du kannst mehrere Sponsoren vorbereiten, bevor du auf Absenden klickst. Das klicken des Upload-Knopfes wird die Segmente übermitteln. Das klicken des Mülleimers löscht es."
},
"Editing": {
"message": "Bearbeitung"
},
"helpPageEditing1": {
"message": "Wenn du etwas falsch gemacht hast, kannst du ein Segment bearbeiten oder löschen nachdem du auf den Auf-Pfeil Knopf gedrückt hast."
},
"helpPageTooSlow": {
"message": "Das ist zu langsam"
},
"helpPageTooSlow1": {
"message": "Es gibt Hotkeys, wenn du diese verwenden möchtest. Drücke die Semikolon-Taste um den Anfang/das Ende eines Sponsor-Segments zu markieren und die Abostrophe-Taste um es zu übermitteln. Diese können in den Optionen geändert werden. Wenn du keine QWERTY-Tastatur verwendest, solltest du eventuell die Keybinds ändern."
},
"helpPageCopyOfDatabase": {
"message": "Kann ich eine kopie der Datenbank erhalten? Was passiert wenn du verschwindest?"
},
"helpPageCopyOfDatabase1": {
"message": "Die Datenbank ist öffentlich und verfügbar unter"
},
"helpPageCopyOfDatabase2": {
"message": "Der Quellcode ist frei verfügbar. Selbst wenn mir etwas passieren würde wären deine Übermittlungen nicht verloren."
},
"helpPageNews": {
"message": "Nachrichten und wie es gemacht wird"
},
"helpPageSourceCode": {
"message": "Wo kann ich den Quellcode kriegen?"
},
"Credits": {
"message": "Mitwirkende"
},
"highlightNewFeature": {
"message": "Neu! Gehe mit einem Klick zum Punkt des Videos mit der neuen \"Hervorheben\" Kategorie"
},
"LearnMore": {
"message": "Erfahre mehr"
} }
} }

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Reskip" "message": "Reskip"
}, },
"unmute": {
"message": "Unmute"
},
"paused": { "paused": {
"message": "Paused" "message": "Paused"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "A connection error has occured. Error code: " "message": "A connection error has occured. Error code: "
}, },
"wantToSubmit": {
"message": "Do you want to submit for video id"
},
"clearTimes": { "clearTimes": {
"message": "Clear Segments" "message": "Clear Segments"
}, },
@@ -302,9 +302,15 @@
"skip": { "skip": {
"message": "Skip" "message": "Skip"
}, },
"mute": {
"message": "Mute"
},
"skip_category": { "skip_category": {
"message": "Skip {0}?" "message": "Skip {0}?"
}, },
"mute_category": {
"message": "Mute {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Skip to {0}?", "message": "Skip to {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -313,6 +319,10 @@
"message": "{0} Skipped", "message": "{0} Skipped",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} Muted",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Skipped to {0}", "message": "Skipped to {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -366,7 +376,7 @@
"message": "Import/Export Your UserID" "message": "Import/Export Your UserID"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "This should be kept private. This is like a password and should not be shared with anyone. If someone has this, they can impersonate you." "message": "This should be kept private. This is like a password and should not be shared with anyone. If someone has this, they can impersonate you. If you are looking for your public userID, click the clipboard icon in the popup."
}, },
"setUserID": { "setUserID": {
"message": "Set UserID" "message": "Set UserID"
@@ -604,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Auto skip all segments when there is a non-music segment" "message": "Auto skip all segments when there is a non-music segment"
}, },
"muteSegments": {
"message": "Allow segments that mute audio instead of skip"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Your color is formatted incorrectly. It should be a 3 or 6 digit hex code with a number sign at the beginning." "message": "Your color is formatted incorrectly. It should be a 3 or 6 digit hex code with a number sign at the beginning."
}, },
@@ -643,6 +656,9 @@
"message": "To submit segments with the category of \"{0}\", you must enable it in the options. You will be redirected to the options now.", "message": "To submit segments with the category of \"{0}\", you must enable it in the options. You will be redirected to the options now.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Warning: This type of segment can have a maximum of one active at a time. Submitting multiple will cause a random one to be shown."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "You must select a category for all segments you are submitting!" "message": "You must select a category for all segments you are submitting!"
}, },
@@ -726,7 +742,7 @@
"message": "Hide forever" "message": "Hide forever"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "You got a warning and cannot submit segments temporarily. This means that we noticed you were making some common mistakes that are not malicious, and we just want to clarify the rules. You can also join this chat using discord.gg/SponsorBlock or matrix.to/#/+sponsor:ajay.app" "message": "You got a warning and cannot submit segments temporarily. This means that we noticed you were making some common mistakes that are not malicious, and we just want to clarify the rules. You can also join this chat using discord.gg/SponsorBlock or matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Vote rejected due to a warning. Click to open a chat to resolve it, or come back later when you have time.", "message": "Vote rejected due to a warning. Click to open a chat to resolve it, or come back later when you have time.",

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Volver a saltar" "message": "Volver a saltar"
}, },
"unmute": {
"message": "Restaurar sonido"
},
"paused": { "paused": {
"message": "Pausado" "message": "Pausado"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Ha ocurrido un error de conexión. Código de error: " "message": "Ha ocurrido un error de conexión. Código de error: "
}, },
"wantToSubmit": {
"message": "¿Quiere enviar el segmento para el video con ID"
},
"clearTimes": { "clearTimes": {
"message": "Borrar Segmentos" "message": "Borrar Segmentos"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Escoger Nombre De Usuario" "message": "Escoger Nombre De Usuario"
}, },
"copyPublicID": {
"message": "Copiar el ID de usuario público"
},
"discordAdvert": { "discordAdvert": {
"message": "¡Únete al servidor oficial de discord para darnos sugerencias y comentarios!" "message": "¡Únete al servidor oficial de discord para darnos sugerencias y comentarios!"
}, },
@@ -299,9 +302,15 @@
"skip": { "skip": {
"message": "Omitir" "message": "Omitir"
}, },
"mute": {
"message": "Silenciar"
},
"skip_category": { "skip_category": {
"message": "¿Saltar {0}?" "message": "¿Saltar {0}?"
}, },
"mute_category": {
"message": "¿Silenciar {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "¿Saltar a {0}?", "message": "¿Saltar a {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -310,6 +319,10 @@
"message": "{0} Omitido/as", "message": "{0} Omitido/as",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} Silenciado",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Se ha saltado a {0}", "message": "Se ha saltado a {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -360,16 +373,16 @@
"message": "Comprueba status.sponsor.ajay.app para ver el estado del servidor." "message": "Comprueba status.sponsor.ajay.app para ver el estado del servidor."
}, },
"changeUserID": { "changeUserID": {
"message": "Importar/Exportar tu UserID" "message": "Importar/Exportar tu ID de usuario"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Esto debería mantenerse privado. Es como una contraseña y no debe ser compartido con nadie. Si alguien tiene esto, pueden imitarte." "message": "Esto se debería mantener privado. Esto es como una contraseña y no debe ser compartido con nadie. Si alguien tiene esto, puede suplantarte. Si estás buscando tu ID de usuario público, haz clic en el icono de portapapeles en la ventana emergente."
}, },
"setUserID": { "setUserID": {
"message": "Establecer la ID de usuario" "message": "Establecer el ID de usuario"
}, },
"userIDChangeWarning": { "userIDChangeWarning": {
"message": "Advertencia: El cambio de la ID de usuario es irreversible. ¿Está seguro de que le desea hacerlo? Asegúrese de hacer una copia de respaldo de la anterior por si acaso." "message": "Advertencia: El cambio del ID de usuario es irreversible. ¿Está seguro de que le desea hacerlo? Asegúrese de hacer una copia de respaldo de la anterior por si acaso."
}, },
"createdBy": { "createdBy": {
"message": "Creado Por" "message": "Creado Por"
@@ -601,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Omitir automáticamente todos los segmentos cuando hay un segmento sin música" "message": "Omitir automáticamente todos los segmentos cuando hay un segmento sin música"
}, },
"muteSegments": {
"message": "Permitir segmentos que silencian el audio en lugar de omitir"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Su color está formateado incorrectamente. Debería ser un código hexadecimal de 3 o 6 dígitos con un signo numérico al principio." "message": "Su color está formateado incorrectamente. Debería ser un código hexadecimal de 3 o 6 dígitos con un signo numérico al principio."
}, },
@@ -640,6 +656,9 @@
"message": "Para enviar segmentos con la categoría de \"{0}\", debes activarlo en las opciones. Serás redirigido a las opciones ahora.", "message": "Para enviar segmentos con la categoría de \"{0}\", debes activarlo en las opciones. Serás redirigido a las opciones ahora.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Advertencia: Solo puede haber uno de este tipo de segmento activo a la vez. Enviar múltiples causará que se muestre uno al azar."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "¡Debes seleccionar una categoría para todos los segmentos que estés presentando!" "message": "¡Debes seleccionar una categoría para todos los segmentos que estés presentando!"
}, },
@@ -723,7 +742,7 @@
"message": "Ocultar para siempre" "message": "Ocultar para siempre"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Ha recibido una advertencia y no puede enviar segmentos temporalmente. Esto significa que hemos notado de que estaba cometiendo algunos errores comunes que no son maliciosos, y solo queremos aclarar las reglas. Puedes unirte a este chat usando discord.gg/SponsorBlock o matrix.to/#/+sponsor:ajay.app" "message": "Ha recibido una advertencia y no puede enviar segmentos temporalmente. Esto significa que hemos notado de que estaba cometiendo algunos errores comunes que no son maliciosos, y solo queremos aclarar las reglas. Puedes unirte a este chat usando discord.gg/SponsorBlock o matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Voto rechazado debido a una advertencia. Haga clic aquí para abrir un chat para resolverlo, o vuelva más tarde cuando tenga tiempo.", "message": "Voto rechazado debido a una advertencia. Haga clic aquí para abrir un chat para resolverlo, o vuelva más tarde cuando tenga tiempo.",

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Jäta uuesti vahele" "message": "Jäta uuesti vahele"
}, },
"unmute": {
"message": "Tühista vaigistus"
},
"paused": { "paused": {
"message": "Pausil" "message": "Pausil"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Ühendusega esines tõrge. Veakood: " "message": "Ühendusega esines tõrge. Veakood: "
}, },
"wantToSubmit": {
"message": "Kas soovid segmendid saata video IDle"
},
"clearTimes": { "clearTimes": {
"message": "Tühjenda segmendid" "message": "Tühjenda segmendid"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Määra kasutajanimi" "message": "Määra kasutajanimi"
}, },
"copyPublicID": {
"message": "Kopeeri avalik UserID"
},
"discordAdvert": { "discordAdvert": {
"message": "Tule liitu ametliku Discordi serveriga, et anda soovitusi ja tagasisidet!" "message": "Tule liitu ametliku Discordi serveriga, et anda soovitusi ja tagasisidet!"
}, },
@@ -227,6 +230,21 @@
"showSkipNotice": { "showSkipNotice": {
"message": "Kuva segmendi vahelejätmisel teatis" "message": "Kuva segmendi vahelejätmisel teatis"
}, },
"noticeVisibilityMode0": {
"message": "Täissuuruses vahelejätmise teavitused"
},
"noticeVisibilityMode1": {
"message": "Väikesed vahelejätmise teavitused autom. vahelejätmistele"
},
"noticeVisibilityMode2": {
"message": "Kõik vahelejätmise teavitused on väikesed"
},
"noticeVisibilityMode3": {
"message": "Hääbuvad vahelejätmise teavitused autom. vahelejätmistele"
},
"noticeVisibilityMode4": {
"message": "Kõik vahelejätmise teavitused hääbuvad"
},
"longDescription": { "longDescription": {
"message": "SponsorBlock lubab sul vahele jätta sponsorid, vaheajad, kanali tellimise meeldetuletused ja muud YouTube'i videote tüütud kohad. SponsorBlock on rahva ühistööna toimiv brauserilaiendus, mis lubab igaühel saata sponsoreeritud segmendi algus- ja lõpuaegu ning teiste video segmentide aegu. Kui üks inimene saadab sponsoreeritud segmendi, jätavad teised laienduse kasutajad kohe selle vahele. Laiendus võimaldab ka muusikavideotel mitte-muusika jaotised vahele jätta.", "message": "SponsorBlock lubab sul vahele jätta sponsorid, vaheajad, kanali tellimise meeldetuletused ja muud YouTube'i videote tüütud kohad. SponsorBlock on rahva ühistööna toimiv brauserilaiendus, mis lubab igaühel saata sponsoreeritud segmendi algus- ja lõpuaegu ning teiste video segmentide aegu. Kui üks inimene saadab sponsoreeritud segmendi, jätavad teised laienduse kasutajad kohe selle vahele. Laiendus võimaldab ka muusikavideotel mitte-muusika jaotised vahele jätta.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
@@ -284,9 +302,15 @@
"skip": { "skip": {
"message": "Jäta vahele" "message": "Jäta vahele"
}, },
"mute": {
"message": "Vaigista"
},
"skip_category": { "skip_category": {
"message": "Jätad {0} vahele?" "message": "Jätad {0} vahele?"
}, },
"mute_category": {
"message": "Vaigistad {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Jäta {0}-ni vahele?", "message": "Jäta {0}-ni vahele?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -295,6 +319,10 @@
"message": "{0} vahelejäetud", "message": "{0} vahelejäetud",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} vaigistatud",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "{0}-ni vahelejäetud", "message": "{0}-ni vahelejäetud",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -348,7 +376,7 @@
"message": "Impordi/ekspordi oma UserID" "message": "Impordi/ekspordi oma UserID"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Seda tuleks privaatsena hoida. See on nagu parool ning seda ei tohiks kellegagi jagada. Kui kellelgi see on, saavad nad sinuna esineda." "message": "Seda tuleks privaatsena hoida. See on nagu parool ning seda ei tohiks kellegagi jagada. Kui kellelgi see on, saavad nad sinuna esineda.\nKui otsid avalikku UserID'd, klõpsa hüpikus olevat lõikelaua ikooni."
}, },
"setUserID": { "setUserID": {
"message": "Seadista UserID" "message": "Seadista UserID"
@@ -586,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Jäta automaatselt kõik segmendid vahele, kui eksisteerib mitte-muusika segment" "message": "Jäta automaatselt kõik segmendid vahele, kui eksisteerib mitte-muusika segment"
}, },
"muteSegments": {
"message": "Luba segmente, mis vahelejätmise asemel vaigistavad heli"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Sinu värv on sobimatult vormistatud. See peaks olema 3- või 6-numbriline 16-kümmendsüsteemis kood, arvu ees trellid." "message": "Sinu värv on sobimatult vormistatud. See peaks olema 3- või 6-numbriline 16-kümmendsüsteemis kood, arvu ees trellid."
}, },
@@ -708,7 +739,7 @@
"message": "Peida igaveseks" "message": "Peida igaveseks"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Sa said hoiatuse ning ei saa ajutiselt segmente saata. See tähendab, et me leidsime sind tegemast teatud sagedasi, mitte-pahatahtlikke vigu, ning soovime sulle meie reegleid täpsustada (inglise keeles). Sa võid selle vestlusega liituda ka discord.gg/SponsorBlock või matrix.to/#/+sponsor:ajay.app kaudu." "message": "Sa said hoiatuse ning ei saa ajutiselt segmente saata. See tähendab, et me leidsime sind tegemast teatud sagedasi, mitte-pahatahtlikke vigu, ning soovime sulle meie reegleid täpsustada (inglise keeles). Sa võid selle vestlusega liituda ka discord.gg/SponsorBlock või matrix.to/#/#sponsor:ajay.app kaudu."
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Hääletus hoiatuse tõttu tagasilükatud. Klõpsa, et avada selle lahendamiseks vestlus või tule hiljem tagasi, kui aega saad.", "message": "Hääletus hoiatuse tõttu tagasilükatud. Klõpsa, et avada selle lahendamiseks vestlus või tule hiljem tagasi, kui aega saad.",
@@ -723,9 +754,15 @@
"helpPageThanksForInstalling": { "helpPageThanksForInstalling": {
"message": "Täname SponsorBlocki paigaldamise eest." "message": "Täname SponsorBlocki paigaldamise eest."
}, },
"helpPageNews": {
"message": "Uudised ja kuidas see on valmistatud"
},
"Credits": { "Credits": {
"message": "Tiitrid" "message": "Tiitrid"
}, },
"highlightNewFeature": {
"message": "Uus! Mine ühe klõpsuga video eesmärgi juurde uue \"esiletõstu\" kategooriaga"
},
"LearnMore": { "LearnMore": {
"message": "Lisateave" "message": "Lisateave"
} }

View File

@@ -6,6 +6,9 @@
"400": { "400": {
"message": "سرور گفت که این درخواست نامعتبر است" "message": "سرور گفت که این درخواست نامعتبر است"
}, },
"429": {
"message": "شما برای این یک ویدیو تعداد بیش از حدی زمان اسپانسر ثبت کرده‌اید، آیا مطمئن هستید که به این تعداد وجود دارد؟"
},
"409": { "409": {
"message": "این قبلاً ثبت شده است" "message": "این قبلاً ثبت شده است"
}, },
@@ -24,6 +27,9 @@
"reportButtonTitle": { "reportButtonTitle": {
"message": "گزارش" "message": "گزارش"
}, },
"reportButtonInfo": {
"message": "گزارش این ارسال به‌عنوان غیر صحیح."
},
"Dismiss": { "Dismiss": {
"message": "رد کردن" "message": "رد کردن"
}, },
@@ -42,6 +48,9 @@
"reskip": { "reskip": {
"message": "دوباره رد کردن" "message": "دوباره رد کردن"
}, },
"unmute": {
"message": "صدادار"
},
"paused": { "paused": {
"message": "وقفه شده" "message": "وقفه شده"
}, },
@@ -54,6 +63,9 @@
"Unknown": { "Unknown": {
"message": "اشکالی در ثبت کردن زمان های ارسالی شما پیش آمد. لطفا بعداً دوباره تلاش کنید." "message": "اشکالی در ثبت کردن زمان های ارسالی شما پیش آمد. لطفا بعداً دوباره تلاش کنید."
}, },
"sponsorFound": {
"message": "این ویدیو دارای بخش‌هایی در پایگاه‌داده است!"
},
"sponsor404": { "sponsor404": {
"message": "هیچ بخشی پیدا نشد" "message": "هیچ بخشی پیدا نشد"
}, },
@@ -63,6 +75,15 @@
"sponsorEnd": { "sponsorEnd": {
"message": "بخش اینجا پایان می‌یابد" "message": "بخش اینجا پایان می‌یابد"
}, },
"sponsorCancel": {
"message": "لغو ساختن بخش"
},
"noVideoID": {
"message": "هیچ ویدیوی یوتیوب‌ای یافت نشد.\nاگر این صحیح نیست، زبانه را تازه کنید."
},
"refreshSegments": {
"message": "تازه‌کردن بخش‌ها"
},
"success": { "success": {
"message": "موفقیت!" "message": "موفقیت!"
}, },
@@ -75,9 +96,6 @@
"connectionError": { "connectionError": {
"message": "خطای شبکه رخ داده است. کد خطا: " "message": "خطای شبکه رخ داده است. کد خطا: "
}, },
"wantToSubmit": {
"message": "آی می‌خواهید که گزارش را ثبت کنید برای ویدیوی"
},
"clearTimes": { "clearTimes": {
"message": "پاک‌نمودن بخش‌ها" "message": "پاک‌نمودن بخش‌ها"
}, },
@@ -93,15 +111,36 @@
"submitCheck": { "submitCheck": {
"message": "مطمئن هستید که میخواهید این را ثبت کنید؟" "message": "مطمئن هستید که میخواهید این را ثبت کنید؟"
}, },
"whitelistChannel": {
"message": "قرار دادن کانال در لیست سفید"
},
"removeFromWhitelist": {
"message": "حذف کانال از لیست سفید"
},
"voteOnTime": { "voteOnTime": {
"message": "رأی دهی به یک بخش" "message": "رأی دهی به یک بخش"
}, },
"Submissions": {
"message": "ارسالی‌ها"
},
"savedPeopleFrom": {
"message": "شما دیگران را نجات دادید از "
},
"viewLeaderboard": {
"message": "لیست سرنشینان"
},
"recordTimesDescription": {
"message": "ثبت"
},
"clearTimesButton": { "clearTimesButton": {
"message": "حذف دفعات" "message": "حذف دفعات"
}, },
"submitTimesButton": { "submitTimesButton": {
"message": "ثبت دفعات" "message": "ثبت دفعات"
}, },
"Username": {
"message": "نام‌کاربری"
},
"setUsername": { "setUsername": {
"message": "تنظیم نام کاربری" "message": "تنظیم نام کاربری"
}, },
@@ -132,5 +171,101 @@
"noticeUpdate2": { "noticeUpdate2": {
"message": "اگر همچنان این را نمی‌پسندید، گزینه هرگز نمایش نده را انتخاب کنید.", "message": "اگر همچنان این را نمی‌پسندید، گزینه هرگز نمایش نده را انتخاب کنید.",
"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."
},
"disableSkipping": {
"message": "ردکردن فعال است"
},
"enableSkipping": {
"message": "ردکردن غیرفعال است"
},
"yourWork": {
"message": "کار شما",
"description": "Used to describe the section that will show you the statistics from your submissions."
},
"errorCode": {
"message": "کد خطا: "
},
"skip": {
"message": "رد کردن"
},
"mute": {
"message": "بی‌صدا"
},
"createdBy": {
"message": "ایجاد شده توسط"
},
"add": {
"message": "افزودن"
},
"save": {
"message": "ذخیره"
},
"reset": {
"message": "بازنشانی"
},
"areYouSureReset": {
"message": "آيا مطمئن هستيد که مي خواهيد این را بازنشانی کنید؟"
},
"mobileUpdateInfo": {
"message": "m.youtube.com اکنون پشتیبانی می‌شود"
},
"setOptions": {
"message": "تنظیم گزینه‌ها"
},
"submit": {
"message": "ثبت"
},
"cancel": {
"message": "لغو"
},
"delete": {
"message": "حذف"
},
"preview": {
"message": "پیش‌نمایش"
},
"unsubmitted": {
"message": "ثبت‌نشده"
},
"inspect": {
"message": "مشاهده"
},
"edit": {
"message": "ویرایش"
},
"to": {
"message": "به",
"description": "Used between segments. Example: 1:20 to 1:30"
},
"category_sponsor": {
"message": "اسپانسر"
},
"category_music_offtopic_short": {
"message": "غیر موسیقی"
},
"category_poi_highlight": {
"message": "برجسته"
},
"autoSkip": {
"message": "ردکردن خودکار"
},
"manualSkip": {
"message": "ردکردن دستی"
},
"bracketNow": {
"message": "(اکنون)"
},
"bracketEnd": {
"message": "(پایان)"
},
"help": {
"message": "راهنما"
},
"GotIt": {
"message": "فهمیدم",
"description": "Used as the button to dismiss a tooltip"
},
"Donate": {
"message": "کمک مالی"
} }
} }

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Ohita uudelleen" "message": "Ohita uudelleen"
}, },
"unmute": {
"message": "Poista mykistys"
},
"paused": { "paused": {
"message": "Pysäytetty" "message": "Pysäytetty"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Yhteysvirhe on tapahtunut. Virhekoodi: " "message": "Yhteysvirhe on tapahtunut. Virhekoodi: "
}, },
"wantToSubmit": {
"message": "Haluatko lähettää segmentit videotunnukselle"
},
"clearTimes": { "clearTimes": {
"message": "Tyhjennä segmentit" "message": "Tyhjennä segmentit"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Aseta käyttäjänimi" "message": "Aseta käyttäjänimi"
}, },
"copyPublicID": {
"message": "Kopio julkinen UserID"
},
"discordAdvert": { "discordAdvert": {
"message": "Liity mukaan viralliselle Discord-palvelimelle, jotta voit antaa ehdotuksia ja palautetta!" "message": "Liity mukaan viralliselle Discord-palvelimelle, jotta voit antaa ehdotuksia ja palautetta!"
}, },
@@ -299,11 +302,14 @@
"skip": { "skip": {
"message": "Ohita" "message": "Ohita"
}, },
"mute": {
"message": "Mykistä"
},
"skip_category": { "skip_category": {
"message": "Ohita {0}?" "message": "Ohita {0}?"
}, },
"skip_to_category": { "skip_to_category": {
"message": "Ohita {0}an?", "message": "Ohita kohtaan: {0}",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
}, },
"skipped": { "skipped": {
@@ -311,7 +317,7 @@
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"skipped_to_category": { "skipped_to_category": {
"message": "Ohitettiin {0}an", "message": "Ohitettiin kohtaan: {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
}, },
"disableAutoSkip": { "disableAutoSkip": {
@@ -363,7 +369,7 @@
"message": "Tuo/vie UserID:si" "message": "Tuo/vie UserID:si"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Tämä tulisi pitää yksityisenä. Tämä on kuin salasana eikä sitä pitäisi jakaa kenellekään. Jos joku saa tämän, hän voi esiintyä sinuna." "message": "Tämä pitäisi pitää yksityisenä. Tämä on kuin salasana, eikä sitä pitäisi jakaa kenenkään kanssa. Jos jollakulla on tämä, he voivat esiintyä sinuna. Jos etsit julkista userID:täsi, napsauta leikepöydän kuvaketta ponnahdusikkunassa."
}, },
"setUserID": { "setUserID": {
"message": "Aseta UserID" "message": "Aseta UserID"
@@ -601,6 +607,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Ohita kaikki segmentit automaattisesti, kun videossa on \"Musiikiton\" segmentti" "message": "Ohita kaikki segmentit automaattisesti, kun videossa on \"Musiikiton\" segmentti"
}, },
"muteSegments": {
"message": "Salli segmentit, jotka mykistävät äänen ohittamisen sijaan"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Väriformaattisi on muotoiltu väärin. Sen pitäisi olla 3 tai 6 numeroinen hex-koodi, jossa on # alussa." "message": "Väriformaattisi on muotoiltu väärin. Sen pitäisi olla 3 tai 6 numeroinen hex-koodi, jossa on # alussa."
}, },
@@ -640,6 +649,9 @@
"message": "Lähettääksesi segmenttejä \"{0}\" kategorialla, sinun täytyy aktivoida se asetuksista. Sinut uudelleenohjataan asetuksiin nyt.", "message": "Lähettääksesi segmenttejä \"{0}\" kategorialla, sinun täytyy aktivoida se asetuksista. Sinut uudelleenohjataan asetuksiin nyt.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Varoitus: Tämäntyyppisiä segmenttejä voi olla aktiivisena enintään yksi. Usean lähettäminen aiheuttaa sen, että satunnainen segmentti näytetään."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Sinun täytyy valita kategoria kaikille segmenteille, joita olet lähettämässä!" "message": "Sinun täytyy valita kategoria kaikille segmenteille, joita olet lähettämässä!"
}, },
@@ -723,7 +735,7 @@
"message": "Piilota ikuisesti" "message": "Piilota ikuisesti"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Sait varoituksen ja et voi lähettää segmenttejä väliaikaisesti. Tämä tarkoittaa, että huomasimme, että teit joitakin yleisiä virheitä, jotka eivät ole tahallisia, ja haluamme vain selventää säännöt. Voit myös liittyä tähän keskusteluun käyttäen discord.gg/SponsorBlock tai matrix.to/#/+sponsor:ajay.app" "message": "Sait varoituksen ja et voi lähettää segmenttejä väliaikaisesti. Tämä tarkoittaa, että huomasimme, että teit joitakin yleisiä virheitä, jotka eivät ole tahallisia, ja haluamme vain selventää säännöt. Voit myös liittyä tähän keskusteluun käyttäen discord.gg/SponsorBlock tai matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Ääni hylättiin varoituksen takia. Klikkaa avataksesi chatin sen ratkaisemiseksi, tai tule takaisin myöhemmin kun sinulla on siihen aikaa.", "message": "Ääni hylättiin varoituksen takia. Klikkaa avataksesi chatin sen ratkaisemiseksi, tai tule takaisin myöhemmin kun sinulla on siihen aikaa.",

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Sauter" "message": "Sauter"
}, },
"unmute": {
"message": "Réactiver le son"
},
"paused": { "paused": {
"message": "En pause" "message": "En pause"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Erreur de connexion. Code d'erreur : " "message": "Erreur de connexion. Code d'erreur : "
}, },
"wantToSubmit": {
"message": "Voulez-vous soumettre vos segments pour la vidéo"
},
"clearTimes": { "clearTimes": {
"message": "Effacer les segments" "message": "Effacer les segments"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Choisir un pseudonyme" "message": "Choisir un pseudonyme"
}, },
"copyPublicID": {
"message": "Copier l'ID utilisateur"
},
"discordAdvert": { "discordAdvert": {
"message": "Rejoignez le serveur Discord officiel pour toutes suggestions ou remarques!" "message": "Rejoignez le serveur Discord officiel pour toutes suggestions ou remarques!"
}, },
@@ -227,6 +230,21 @@
"showSkipNotice": { "showSkipNotice": {
"message": "Notifier après qu'un segment ait été sauté" "message": "Notifier après qu'un segment ait été sauté"
}, },
"noticeVisibilityMode0": {
"message": "Notifications de passage"
},
"noticeVisibilityMode1": {
"message": "Petite notifications de passage pour l'auto skip"
},
"noticeVisibilityMode2": {
"message": "Toute les petites notifications de passage"
},
"noticeVisibilityMode3": {
"message": "Notifications de passage qui disparaissent pour l'auto skip"
},
"noticeVisibilityMode4": {
"message": "Toute les notifications de passage qui disparaissent"
},
"longDescription": { "longDescription": {
"message": "SponsorBlock vous permet de passer les sponsors, les intros, les outros, les rappels d'abonnement et autres parties ennuyeuses des vidéos YouTube. SponsorBlock est une extension de navigateur qui permet à n'importe qui de soumettre les temps de début et de fin des segments sponsorisés et d'autres segments de vidéos YouTube. Une fois qu'une personne a soumis ces informations, toutes les autres personnes possédant cette extension passeront directement les segments sponsorisés. Vous pouvez également sauter les sections non musicales des vidéos musicales.", "message": "SponsorBlock vous permet de passer les sponsors, les intros, les outros, les rappels d'abonnement et autres parties ennuyeuses des vidéos YouTube. SponsorBlock est une extension de navigateur qui permet à n'importe qui de soumettre les temps de début et de fin des segments sponsorisés et d'autres segments de vidéos YouTube. Une fois qu'une personne a soumis ces informations, toutes les autres personnes possédant cette extension passeront directement les segments sponsorisés. Vous pouvez également sauter les sections non musicales des vidéos musicales.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
@@ -284,9 +302,31 @@
"skip": { "skip": {
"message": "Passer" "message": "Passer"
}, },
"mute": {
"message": "Couper le son"
},
"skip_category": { "skip_category": {
"message": "Passer {0} ?" "message": "Passer {0} ?"
}, },
"mute_category": {
"message": "Mute {0}?"
},
"skip_to_category": {
"message": "Passer à {0}?",
"description": "Used for skipping to things (Skip to Highlight)"
},
"skipped": {
"message": "{0} ignoré",
"description": "Example: Sponsor Skipped"
},
"muted": {
"message": "{0} mis en sourdine",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": {
"message": "Sauté à {0}",
"description": "Used for skipping to things (Skipped to Highlight)"
},
"disableAutoSkip": { "disableAutoSkip": {
"message": "Désactiver le passage automatique" "message": "Désactiver le passage automatique"
}, },
@@ -336,7 +376,7 @@
"message": "Importer/Exporter Votre ID d'Utilisateur" "message": "Importer/Exporter Votre ID d'Utilisateur"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Cette information doit rester confidentielle. C'est comme un mot de passe et ne devrait pas être partagé avec quiconque. Si quelqu'un l'obtient, il pourra se faire passer pour vous." "message": "Cela devrait rester privé. C'est comme un mot de passe et ne devrait être partagé avec personne. Si quelqu'un a cela, il peut vous usurper. Si vous recherchez votre identifiant d'utilisateur public, cliquez sur l'icône du presse-papiers dans le popup."
}, },
"setUserID": { "setUserID": {
"message": "Définir \"UserID\"" "message": "Définir \"UserID\""
@@ -538,6 +578,12 @@
"category_music_offtopic_short": { "category_music_offtopic_short": {
"message": "Hors musique" "message": "Hors musique"
}, },
"category_poi_highlight": {
"message": "Surligner"
},
"category_poi_highlight_description": {
"message": "La partie de la vidéo que la plupart des gens veulent voir. Similaire à \"la vidéo commence à x mins\"."
},
"category_livestream_messages": { "category_livestream_messages": {
"message": "Stream : lecture de dons et messages" "message": "Stream : lecture de dons et messages"
}, },
@@ -556,6 +602,21 @@
"disable": { "disable": {
"message": "Désactiver" "message": "Désactiver"
}, },
"autoSkip_POI": {
"message": "Passer automatiquement au début"
},
"manualSkip_POI": {
"message": "Demander lors du chargement de la vidéo"
},
"showOverlay_POI": {
"message": "Afficher dans la barre de recherche"
},
"autoSkipOnMusicVideos": {
"message": "Ignorer automatiquement tous les segments lorsqu'il y a un segment non-musical"
},
"muteSegments": {
"message": "Autoriser les segments qui bloquent l'audio au lieu de le passer"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Votre couleur est mal formatée. Il devrait s'agir d'un code hexadécimal à 3 ou 6 chiffres avec un signe numérique au début." "message": "Votre couleur est mal formatée. Il devrait s'agir d'un code hexadécimal à 3 ou 6 chiffres avec un signe numérique au début."
}, },
@@ -666,11 +727,91 @@
"help": { "help": {
"message": "Aide" "message": "Aide"
}, },
"GotIt": {
"message": "Compris",
"description": "Used as the button to dismiss a tooltip"
},
"experiementOptOut": { "experiementOptOut": {
"message": "Se désinscrire de toutes les futures expériences", "message": "Se désinscrire de toutes les futures expériences",
"description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private." "description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private."
}, },
"hideForever": { "hideForever": {
"message": "Cacher pour toujours" "message": "Cacher pour toujours"
},
"warningChatInfo": {
"message": "Vous avez reçu un avertissement et ne pouvez pas soumettre des segments temporairement. Cela signifie que nous avons remarqué que vous commettez des erreurs courantes qui ne sont pas malveillantes, et que nous voulons simplement clarifier les règles. Vous pouvez également rejoindre ce chat en utilisant discord.gg/SponsorBlock ou matrix.to/#/+sponsor:ajay.app"
},
"voteRejectedWarning": {
"message": "Le vote a été rejeté en raison d'un avertissement. Cliquez pour ouvrir un chat et y mettre fin , ou revenez plus tard lorsque vous avez le temps.",
"description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser."
},
"Donate": {
"message": "Faire un don"
},
"hideDonationLink": {
"message": "Cacher le lien de don"
},
"helpPageThanksForInstalling": {
"message": "Merci d'avoir installé SponsorBlock."
},
"helpPageReviewOptions": {
"message": "Veuillez vérifier les options ci-dessous"
},
"helpPageFeatureDisclaimer": {
"message": "De nombreuses fonctionnalités sont désactivées par défaut. Si vous voulez ignorer les intros, outros, utiliser Invidious, etc., activez-les ci-dessous. Vous pouvez également masquer/afficher les éléments de l'interface."
},
"helpPageHowSkippingWorks": {
"message": "Comment fonctionne le saut d'un segment"
},
"helpPageHowSkippingWorks1": {
"message": "Les segments vidéo seront automatiquement ignorés s'ils sont trouvés dans la base de données. Vous pouvez ouvrir le popup en cliquant sur l'icône de l'extension pour obtenir un aperçu de ces segments."
},
"helpPageHowSkippingWorks2": {
"message": "À chaque fois que vous sautez un segment, vous en serez averti. Si le timing semble incorrect, vous pouvez disliker le segment, vous pouvez également voter dans le popup."
},
"Submitting": {
"message": "Soumission en cours"
},
"helpPageSubmitting1": {
"message": "La soumission peut être effectuée dans le popup en appuyant sur le bouton \"le segment commence maintenant\" ou dans le lecteur vidéo avec les boutons du lecteur."
},
"helpPageSubmitting2": {
"message": "Cliquer sur le bouton de lecture indique le début d'un segment et cliquer sur l'icône d'arrêt indique la fin. Vous pouvez préparer plusieurs sponsors avant d'appuyer sur Soumettre. Cliquer sur le bouton de soumission enverra le segment. Cliquer sur le poubelle supprimera vos segments."
},
"Editing": {
"message": "Édition en cours"
},
"helpPageEditing1": {
"message": "Si vous avez fait une erreur, vous pouvez modifier ou supprimer vos segments après avoir cliqué sur le bouton avec la flèche vers le haut."
},
"helpPageTooSlow": {
"message": "Ceci est trop lent"
},
"helpPageTooSlow1": {
"message": "Il y a des raccourcis clavier si vous voulez les utiliser. Appuyez sur la touche point-virgule pour indiquer le début / la fin d'un segment sponsorisé et cliquez sur l'apostrophe pour soumettre. Cela peut être modifié dans les options. Si vous n'utilisez pas un clavier QWERTY, vous devriez probablement changer la touche assignée de base."
},
"helpPageCopyOfDatabase": {
"message": "Puis-je obtenir une copie de la base de données ? Que se passe-t-il si vous disparaissez ?"
},
"helpPageCopyOfDatabase1": {
"message": "La base de données est publique et disponible à"
},
"helpPageCopyOfDatabase2": {
"message": "Le code source est librement disponible. Donc, même si il m'arrive quelque chose, vos soumissions ne seront pas perdues."
},
"helpPageNews": {
"message": "Nouvelles et comment elles sont faites"
},
"helpPageSourceCode": {
"message": "Où puis-je obtenir le code source ?"
},
"Credits": {
"message": "Crédits"
},
"highlightNewFeature": {
"message": "Nouveau! Aller à l'essentiel de la vidéo en un clic avec la nouvelle catégorie points essentiels"
},
"LearnMore": {
"message": "En savoir plus"
} }
} }

View File

@@ -94,9 +94,6 @@
"connectionError": { "connectionError": {
"message": "התקבלה שגיאת חיבור. קוד השגיאה: " "message": "התקבלה שגיאת חיבור. קוד השגיאה: "
}, },
"wantToSubmit": {
"message": "האם אתה רוצה לדווח עבור סרטון שמספר הזיהוי שלו הוא"
},
"clearTimes": { "clearTimes": {
"message": "נקה מקטעים" "message": "נקה מקטעים"
}, },

View File

@@ -91,9 +91,6 @@
"connectionError": { "connectionError": {
"message": "Dogodija se greška u povezivanju. Kod pogreške: " "message": "Dogodija se greška u povezivanju. Kod pogreške: "
}, },
"wantToSubmit": {
"message": "Želiš li unijeti za video id"
},
"clearTimes": { "clearTimes": {
"message": "Očisti isječke" "message": "Očisti isječke"
}, },
@@ -179,9 +176,6 @@
"hoursLower": { "hoursLower": {
"message": "h" "message": "h"
}, },
"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."
},
"setUserID": { "setUserID": {
"message": "Postavi UserID" "message": "Postavi UserID"
}, },

View File

@@ -100,9 +100,6 @@
"connectionError": { "connectionError": {
"message": "Kapcsolódási probléma merült fel. Error kód: " "message": "Kapcsolódási probléma merült fel. Error kód: "
}, },
"wantToSubmit": {
"message": "Szeretné beküldeni a szegmenst ehhez a videóhoz:"
},
"clearTimes": { "clearTimes": {
"message": "Szegmensek törlése" "message": "Szegmensek törlése"
}, },
@@ -329,9 +326,6 @@
"changeUserID": { "changeUserID": {
"message": "UserID importálása / exportálása" "message": "UserID importálása / exportálása"
}, },
"whatChangeUserID": {
"message": "Ezt titokban kell tartani. Olyan, mint egy jelszó, nem szabad senkivel megosztania. Ha valakinek megvan, megszemélyesítheti Önt."
},
"setUserID": { "setUserID": {
"message": "UserID beállítása" "message": "UserID beállítása"
}, },
@@ -431,6 +425,9 @@
"preview": { "preview": {
"message": "Előnézet" "message": "Előnézet"
}, },
"unsubmitted": {
"message": "Nincs beküldve"
},
"inspect": { "inspect": {
"message": "Megvizsgál" "message": "Megvizsgál"
}, },
@@ -495,6 +492,9 @@
"category_outro_description": { "category_outro_description": {
"message": "Stáblista, vagy amikor megjelennek a YouTube zárókártyák. Nem használandó információt tartalmazó következtetésekkor." "message": "Stáblista, vagy amikor megjelennek a YouTube zárókártyák. Nem használandó információt tartalmazó következtetésekkor."
}, },
"category_preview": {
"message": "Előzetes/Ismétlés"
},
"category_music_offtopic": { "category_music_offtopic": {
"message": "Zene: nem-zene szegmens" "message": "Zene: nem-zene szegmens"
}, },
@@ -597,5 +597,33 @@
}, },
"help": { "help": {
"message": "Segítség" "message": "Segítség"
},
"GotIt": {
"message": "Értettem",
"description": "Used as the button to dismiss a tooltip"
},
"hideForever": {
"message": "Eltüntetés örökre"
},
"Donate": {
"message": "Támogatás"
},
"Submitting": {
"message": "Küldés"
},
"Editing": {
"message": "Szerkesztés"
},
"helpPageTooSlow": {
"message": "Ez túl lassú"
},
"helpPageNews": {
"message": "Hírek és hogyan készül"
},
"Credits": {
"message": "Készítők"
},
"LearnMore": {
"message": "Tudj meg többet"
} }
} }

View File

@@ -97,9 +97,6 @@
"connectionError": { "connectionError": {
"message": "Kesalahan koneksi terjadi. Kode kesalahan: " "message": "Kesalahan koneksi terjadi. Kode kesalahan: "
}, },
"wantToSubmit": {
"message": "Apakah anda ingin mengirim untuk id video"
},
"clearTimes": { "clearTimes": {
"message": "Hapus Segmen" "message": "Hapus Segmen"
}, },
@@ -281,6 +278,18 @@
"skip_category": { "skip_category": {
"message": "Lewati {0}?" "message": "Lewati {0}?"
}, },
"skip_to_category": {
"message": "Lompat ke {0}?",
"description": "Used for skipping to things (Skip to Highlight)"
},
"skipped": {
"message": "{0} dilewati",
"description": "Example: Sponsor Skipped"
},
"skipped_to_category": {
"message": "Melewati ke {0}",
"description": "Used for skipping to things (Skipped to Highlight)"
},
"disableAutoSkip": { "disableAutoSkip": {
"message": "Nonaktifkan Lewati Otomatis" "message": "Nonaktifkan Lewati Otomatis"
}, },
@@ -329,9 +338,6 @@
"changeUserID": { "changeUserID": {
"message": "Impor/Ekspor UserID" "message": "Impor/Ekspor UserID"
}, },
"whatChangeUserID": {
"message": "Ini sebaiknya dirahasiakan. Ini terlihat seperti password dan sebaiknya tidak dibagikan ke orang lain. Jika seseorang mempunyai ini, dia dapat berpura-pura menjadi anda."
},
"setUserID": { "setUserID": {
"message": "Atur UserID" "message": "Atur UserID"
}, },
@@ -344,6 +350,9 @@
"keybindCurrentlySet": { "keybindCurrentlySet": {
"message": ". Saat ini diatur pada:" "message": ". Saat ini diatur pada:"
}, },
"supportOtherSites": {
"message": "Dukung Situs Youtube Pihak Ketiga"
},
"optionsInfo": { "optionsInfo": {
"message": "Aktifkan dukungan Invidious, nonaktifkan lewati otomatis, tombol sembunyi dan lainnya." "message": "Aktifkan dukungan Invidious, nonaktifkan lewati otomatis, tombol sembunyi dan lainnya."
}, },
@@ -428,6 +437,9 @@
"preview": { "preview": {
"message": "Pratinjau" "message": "Pratinjau"
}, },
"unsubmitted": {
"message": "Belum dikirim"
},
"inspect": { "inspect": {
"message": "Inspeksi" "message": "Inspeksi"
}, },
@@ -492,6 +504,12 @@
"category_outro_description": { "category_outro_description": {
"message": "Kredit atau saat kartu akhir YouTube muncul. Tidak untuk kesimpulan dengan informasi." "message": "Kredit atau saat kartu akhir YouTube muncul. Tidak untuk kesimpulan dengan informasi."
}, },
"category_preview": {
"message": "Pratinjau/Rekap"
},
"category_preview_description": {
"message": "Rekapan singkat dari episode sebelumnya, atau pratinjau tentang apa yang akan terjadi nanti di video. Dimaksudkan untuk klip bersama yang di edit, bukan ringkasan yang diucapkan."
},
"category_music_offtopic": { "category_music_offtopic": {
"message": "Musik: Bagian Non-Musik" "message": "Musik: Bagian Non-Musik"
}, },
@@ -519,9 +537,22 @@
"disable": { "disable": {
"message": "Nonaktif" "message": "Nonaktif"
}, },
"manualSkip_POI": {
"message": "Tanya saat video dimuat"
},
"showOverlay_POI": {
"message": "Tampilkan di Bilah Waktu"
},
"autoSkipOnMusicVideos": {
"message": "Lewati semua segmen secara otomatis ketika ada segmen non-music"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Warna anda tidak diformat dengan benar. Harusnya terdiri dari 3 atau 6 digit kode heksa dengan tagar di awal." "message": "Warna anda tidak diformat dengan benar. Harusnya terdiri dari 3 atau 6 digit kode heksa dengan tagar di awal."
}, },
"previewColor": {
"message": "Warna yang Belum Dikirim",
"description": "Referring to submissions that have not been sent to the server yet."
},
"seekBarColor": { "seekBarColor": {
"message": "Warna Bilah Waktu" "message": "Warna Bilah Waktu"
}, },
@@ -622,7 +653,29 @@
"categoryUpdate2": { "categoryUpdate2": {
"message": "Buka opsi untuk melewati intro, outro, merch, dll." "message": "Buka opsi untuk melewati intro, outro, merch, dll."
}, },
"help": {
"message": "Bantuan"
},
"GotIt": {
"message": "Mengerti",
"description": "Used as the button to dismiss a tooltip"
},
"hideForever": { "hideForever": {
"message": "Sembunyikan selamanya" "message": "Sembunyikan selamanya"
},
"Donate": {
"message": "Donasi"
},
"hideDonationLink": {
"message": "Sembunyikan tautan donasi"
},
"helpPageThanksForInstalling": {
"message": "Terima kasih telah menginstall SponsorBlock."
},
"helpPageReviewOptions": {
"message": "Haram ditinjau opsi di bawah ini"
},
"helpPageHowSkippingWorks": {
"message": "Cara kerja melewati segmen"
} }
} }

View File

@@ -4,20 +4,20 @@
"description": "Name of the extension." "description": "Name of the extension."
}, },
"Description": { "Description": {
"message": "Salta sponsorizzazioni, implorazioni di iscrizione ai canali e molto altro sui video di YouTube. Segnala gli sponsor sui video che guardi per salvare il tempo ad altri.", "message": "Salta sponsorizzazioni, richieste d'iscrizione ai canali e molto altro sui video di YouTube. Segnala gli sponsor sui video che guardi per salvare il tempo agli altri.",
"description": "Description of the extension." "description": "Description of the extension."
}, },
"400": { "400": {
"message": "Richiesta non valida" "message": "Richiesta non valida"
}, },
"429": { "429": {
"message": "Stai inviando troppi spezzoni per questo video, sei sicuro che ce ne siano così tanti?" "message": "Stai inviando troppi segmenti per questo video, sei sicuro che ce ne siano così tanti?"
}, },
"409": { "409": {
"message": "Questo spezzone è già stato inviato" "message": "Questo è già stato inviato"
}, },
"channelWhitelisted": { "channelWhitelisted": {
"message": "Canale aggiunto alla whitelist!" "message": "Canale aggiunto alla lista delle esclusioni!"
}, },
"Segment": { "Segment": {
"message": "segmento" "message": "segmento"
@@ -52,11 +52,14 @@
"reskip": { "reskip": {
"message": "Salta ancora" "message": "Salta ancora"
}, },
"unmute": {
"message": "Riattiva il microfono"
},
"paused": { "paused": {
"message": "In pausa" "message": "In pausa"
}, },
"manualPaused": { "manualPaused": {
"message": "Timer Fermato" "message": "Timer fermato"
}, },
"confirmMSG": { "confirmMSG": {
"message": "\n\nPer modificare o eliminare valori specifici, premi il pulsante delle informazioni o apri il popup cliccando l'icona dell'estensione nell'angolo in alto a destra." "message": "\n\nPer modificare o eliminare valori specifici, premi il pulsante delle informazioni o apri il popup cliccando l'icona dell'estensione nell'angolo in alto a destra."
@@ -65,7 +68,7 @@
"message": "Sei sicuro di volerlo cancellare?\n\n" "message": "Sei sicuro di volerlo cancellare?\n\n"
}, },
"Unknown": { "Unknown": {
"message": "Si è verificato un errore durante l'invio dello spezzone sponsorizzato, per favore riprova più tardi." "message": "Si è verificato un errore durante l'invio del segmento, per favore riprova più tardi."
}, },
"sponsorFound": { "sponsorFound": {
"message": "Questo video ha dei segmenti nel database!" "message": "Questo video ha dei segmenti nel database!"
@@ -74,10 +77,10 @@
"message": "Nessun segmento trovato" "message": "Nessun segmento trovato"
}, },
"sponsorStart": { "sponsorStart": {
"message": "Il Segmento Inizia Ora" "message": "Il segmento inizia qui"
}, },
"sponsorEnd": { "sponsorEnd": {
"message": "Il Segmento Termina Ora" "message": "Il segmento finisce ora"
}, },
"sponsorCancel": { "sponsorCancel": {
"message": "Annulla Creazione del Segmento" "message": "Annulla Creazione del Segmento"
@@ -89,7 +92,7 @@
"message": "Ricarica i segmenti" "message": "Ricarica i segmenti"
}, },
"success": { "success": {
"message": "Successo!" "message": "Ha funzionato!"
}, },
"voted": { "voted": {
"message": "Votato!" "message": "Votato!"
@@ -100,20 +103,17 @@
"connectionError": { "connectionError": {
"message": "Si è verificato un errore durante la connessione. Codice errore: " "message": "Si è verificato un errore durante la connessione. Codice errore: "
}, },
"wantToSubmit": {
"message": "Desideri inviare per l'id video"
},
"clearTimes": { "clearTimes": {
"message": "Pulisci Segmenti" "message": "Rimuovi i segmenti"
}, },
"openPopup": { "openPopup": {
"message": "Apri il Popup di SponsorBlock" "message": "Apri il popup di SponsorBlock"
}, },
"closePopup": { "closePopup": {
"message": "Chiudi il popup" "message": "Chiudi il popup"
}, },
"SubmitTimes": { "SubmitTimes": {
"message": "Invia Segmenti" "message": "Invia i segmenti"
}, },
"submitCheck": { "submitCheck": {
"message": "Sei sicuro di volerlo inviare?" "message": "Sei sicuro di volerlo inviare?"
@@ -125,7 +125,7 @@
"message": "Rimuovi il canale dalle eccezioni" "message": "Rimuovi il canale dalle eccezioni"
}, },
"voteOnTime": { "voteOnTime": {
"message": "Vota un Segmento" "message": "Vota un segmento"
}, },
"Submissions": { "Submissions": {
"message": "Contributi" "message": "Contributi"
@@ -147,19 +147,22 @@
"message": "Suggerimento: puoi configurare dei comandi rapidi nelle opzioni" "message": "Suggerimento: puoi configurare dei comandi rapidi nelle opzioni"
}, },
"clearTimesButton": { "clearTimesButton": {
"message": "Cancella Minutaggi" "message": "Cancella minutaggio"
}, },
"submitTimesButton": { "submitTimesButton": {
"message": "Invia Minutaggi" "message": "Invia minutaggio"
}, },
"publicStats": { "publicStats": {
"message": "Viene utilizzato nelle pagine delle statistiche pubbliche che mostrano quanto hai contribuito. Vedi" "message": "Questo è usato nelle pagine pubbliche delle statistiche per mostrare quanto hai contribuito. Vedilo"
}, },
"Username": { "Username": {
"message": "Nome utente" "message": "Nome utente"
}, },
"setUsername": { "setUsername": {
"message": "Imposta Username" "message": "Imposta nome utente"
},
"copyPublicID": {
"message": "Copia UserID Pubblico"
}, },
"discordAdvert": { "discordAdvert": {
"message": "Entra nel server Discord ufficiale per darci suggerimenti e feedback!" "message": "Entra nel server Discord ufficiale per darci suggerimenti e feedback!"
@@ -171,19 +174,19 @@
"message": "Opzioni" "message": "Opzioni"
}, },
"showButtons": { "showButtons": {
"message": "Mostra i Pulsanti nel Lettore di YouTube" "message": "Mostra i pulsanti sul video"
}, },
"hideButtons": { "hideButtons": {
"message": "Nascondi i Pulsanti nel Lettore di YouTube" "message": "Nascondi i pulsanti sul video"
}, },
"hideButtonsDescription": { "hideButtonsDescription": {
"message": "Nasconde i pulsanti che appaiono nel lettore di YouTube per inviare spezzoni sponsorizzati. Capisco che può essere fastidioso per alcune\n persone. Invece di utilizzare quei pulsanti, è possibile utilizzare questo popup per inviare gli spezzoni sponsorizzati. Per nascondere l'avviso che appare, \nusa il bottone \"Non mostrare più\" nell'avviso. Potrai sempre abilitare nuovamente queste impostazioni in futuro." "message": "Nasconde i pulsanti che appaiono sul video per inviare i segmenti da nascondere."
}, },
"showInfoButton": { "showInfoButton": {
"message": "Mostra il Pulsante Informazioni nel Lettore di YouTube" "message": "Mostra il pulsante delle informazioni sopra al video"
}, },
"hideInfoButton": { "hideInfoButton": {
"message": "Nascondi il Pulsante Informazioni nel Lettore di YouTube" "message": "Nascondi il pulsante d'informazioni sopra al video"
}, },
"whatInfoButton": { "whatInfoButton": {
"message": "Questo è il pulsante che apre un popup nella pagina YouTube." "message": "Questo è il pulsante che apre un popup nella pagina YouTube."
@@ -192,19 +195,19 @@
"message": "Nascondi in automatico il Pulsante di Informazioni" "message": "Nascondi in automatico il Pulsante di Informazioni"
}, },
"hideDeleteButton": { "hideDeleteButton": {
"message": "Nascondi il Pulsante Elimina nel Lettore di YouTube" "message": "Nascondi il pulsante elimina"
}, },
"showDeleteButton": { "showDeleteButton": {
"message": "Mostra il Pulsante Elimina nel Lettore di YouTube" "message": "Mostra il pulsante elimina"
}, },
"whatDeleteButton": { "whatDeleteButton": {
"message": "Questo è il pulsante che ti permette di cancellare tutti gli spezzoni sponsorizzati nel lettore di YouTube." "message": "Questo è il pulsante che ti permette di cancellare tutti i segmenti non inviati del video attuale."
}, },
"enableViewTracking": { "enableViewTracking": {
"message": "Attiva Monitoraggio Salti" "message": "Attiva il conteggio dei salti"
}, },
"whatViewTracking": { "whatViewTracking": {
"message": "Questa funzionalità tiene traccia dei segmenti che hai saltato, per far sapere agli utenti quanto il loro contributo abbia aiutato gli altri e sia stato utilizzato come metrica insieme ai voti positivi, per garantire che lo spam non entri nel database. L'estensione invierà un messaggio al server ogni volta che salterai un segmento. Si spera che la maggior parte delle persone non modifichino questa impostazione, in modo da non intaccare l'accuratezza dei numeri di visualizzazione. :)" "message": "Questa funzionalità tiene traccia dei segmenti che hai saltato per far sapere agli utenti quanto il loro contributo abbia aiutato gli altri e anche come statistica, insieme ai voti positivi, per garantire che lo spam non entri nel database. L'estensione invierà un messaggio al server ogni volta che salterai un segmento. Si spera che la maggior parte delle persone non modifichino questa impostazione, in modo da non intaccare l'accuratezza dei numeri di visualizzazione. :)"
}, },
"enableViewTrackingInPrivate": { "enableViewTrackingInPrivate": {
"message": "Abilita il conteggio dei salti nelle schede private/anonime" "message": "Abilita il conteggio dei salti nelle schede private/anonime"
@@ -216,13 +219,13 @@
"message": "Invece di richiedere i segmenti dal server utilizzando l'ID del video, viene inviato un hash dei primi 4 caratteri dell'ID. Questo server invierà i dati per tutti i video con hash simili." "message": "Invece di richiedere i segmenti dal server utilizzando l'ID del video, viene inviato un hash dei primi 4 caratteri dell'ID. Questo server invierà i dati per tutti i video con hash simili."
}, },
"enableRefetchWhenNotFound": { "enableRefetchWhenNotFound": {
"message": "Ricarica I Segmenti Su Nuovi Video" "message": "Ricarica i segmenti su nuovi video"
}, },
"whatRefetchWhenNotFound": { "whatRefetchWhenNotFound": {
"message": "Se il video è nuovo, e non risultano esserci segmenti, continueremo a cercarne di nuovi ogni pochi minuti." "message": "Se il video è nuovo, e non risultano esserci segmenti, continueremo a cercarne di nuovi ogni pochi minuti."
}, },
"showNotice": { "showNotice": {
"message": "Mostra di Nuovo l'Avviso" "message": "Mostra di nuovo l'avviso"
}, },
"showSkipNotice": { "showSkipNotice": {
"message": "Mostra Avviso Dopo Aver Saltato un Segmento" "message": "Mostra Avviso Dopo Aver Saltato un Segmento"
@@ -243,15 +246,15 @@
"message": "Tutti i Salta Avvisi Offuscati" "message": "Tutti i Salta Avvisi Offuscati"
}, },
"longDescription": { "longDescription": {
"message": "SponsorBlock ti consente di saltare sponsorizzazioni, introduzioni, conclusioni, promemoria di iscrizione e altre componenti fastidiose dei video su YouTube. SponsorBlock è un'estensione per browser in crowdsourcing, che consente a chiunque di inviare l'ora di inizio e di fine dei segmenti sponsorizzati e altri segmenti video su YouTube. Quando una persona invia queste informazioni, chiunque altro in possesso di questa estensione sarà in grado di saltare direttamente il segmento sponsorizzato. È possibile saltare anche le sezioni non musicali dei video musicali.", "message": "SponsorBlock ti consente di saltare sponsorizzazioni, introduzioni, conclusioni, promemoria di iscrizione e altri elementi fastidiosi dai video YouTube. SponsorBlock è un'estensione per browser di crowdsourcing, cioè che consente a chiunque di inviare l'ora di inizio e di fine dei segmenti sponsorizzati e di altro tipo. Quando una persona invia queste informazioni, chiunque altro in possesso di questa estensione sarà in grado di saltare automaticamente il segmento sponsorizzato. È possibile saltare anche le sezioni non musicali dei video musicali.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
}, },
"website": { "website": {
"message": "Sito Web", "message": "Sito web",
"description": "Used on Firefox Store Page" "description": "Used on Firefox Store Page"
}, },
"sourceCode": { "sourceCode": {
"message": "Codice Sorgente", "message": "Codice sorgente",
"description": "Used on Firefox Store Page" "description": "Used on Firefox Store Page"
}, },
"noticeUpdate": { "noticeUpdate": {
@@ -275,7 +278,7 @@
"message": "Seleziona un tasto premendolo sulla tastiera" "message": "Seleziona un tasto premendolo sulla tastiera"
}, },
"keybindDescriptionComplete": { "keybindDescriptionComplete": {
"message": "L'associazione di tasti è stata impostata a: " "message": "Il comando rapido è stato impostato come: "
}, },
"0": { "0": {
"message": "Timeout della connessione. Controlla la tua connessione a Internet. Se internet sta funzionando, il server è probabilmente sovraccarico oppure giù." "message": "Timeout della connessione. Controlla la tua connessione a Internet. Se internet sta funzionando, il server è probabilmente sovraccarico oppure giù."
@@ -299,9 +302,15 @@
"skip": { "skip": {
"message": "Salta" "message": "Salta"
}, },
"mute": {
"message": "Silenzia"
},
"skip_category": { "skip_category": {
"message": "Vuoi saltare {0}?" "message": "Vuoi saltare {0}?"
}, },
"mute_category": {
"message": "Silenziare {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Saltare a {0}?", "message": "Saltare a {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -310,6 +319,10 @@
"message": "{0} Saltato", "message": "{0} Saltato",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} silenziato",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Saltato a {0}", "message": "Saltato a {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -363,7 +376,7 @@
"message": "Importa/Esporta Il Tuo ID Utente" "message": "Importa/Esporta Il Tuo ID Utente"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Questo dovrebbe essere tenuto privato. Questo è come una password e non dovrebbe essere condiviso con nessuno. Se qualcuno ha questo, ti può impersonare." "message": "Questo dovrebbe esser mantenuto privato. È come una password e non dovrebbe esser condiviso con nessuno. Se qualcuno lo possiede, può impersonarti. Se stai cercando il tuo userID pubblico, clicca l'icona degli appunti nel popup."
}, },
"setUserID": { "setUserID": {
"message": "Imposta ID utente" "message": "Imposta ID utente"
@@ -601,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Salta automaticamente tutti i segmenti quando c'è un segmento non musicale" "message": "Salta automaticamente tutti i segmenti quando c'è un segmento non musicale"
}, },
"muteSegments": {
"message": "Silenzia i segmenti invece di saltarli, quando possibile"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Il tuo colore è formattato in modo errato. Dovrebbe essere un codice esadecimale a 3 o 6 cifre con un segno numerico iniziale." "message": "Il tuo colore è formattato in modo errato. Dovrebbe essere un codice esadecimale a 3 o 6 cifre con un segno numerico iniziale."
}, },
@@ -640,6 +656,9 @@
"message": "Per inviare segmenti della categoria \"{0}\", è necessario abilitarlo nelle opzioni. Sarai reindirizzato alle opzioni.", "message": "Per inviare segmenti della categoria \"{0}\", è necessario abilitarlo nelle opzioni. Sarai reindirizzato alle opzioni.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Attenzione: questo tipo di segmento può essere presente una sola volta. Inviarne più di uno causerà la visualizzazione casuale di uno solo."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Devi selezionare una categoria per tutti i segmenti che stai inviando!" "message": "Devi selezionare una categoria per tutti i segmenti che stai inviando!"
}, },
@@ -723,7 +742,7 @@
"message": "Nascondi per sempre" "message": "Nascondi per sempre"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Hai ricevuto un ammonimento and non puoi inviare segmenti temporaneamente. Ciò significa che abbiamo notato che stavi commettendo alcuni errori comuni senza scopo malevolo, e vogliamo che tu ricontrollassi le regole. Puoi anche partecipare a questa chat su discord.gg/SponsorBlock o matrix.to/#/+sponsor:ajay.app" "message": "Hai ricevuto un avvertimento e non puoi temporaneamente inviare i segmenti. Questo significa che abbiamo notato che stavi commettendo alcuni errori comuni non malevoli, e vogliamo solo chiarire le regole. Puoi anche unirti a questa chat usando discord.gg/SponsorBlock o matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Voto rifiutato a causa di un ammonimento. Clicca per aprire una chat per risolverlo, oppure torna dopo quando hai tempo.", "message": "Voto rifiutato a causa di un ammonimento. Clicca per aprire una chat per risolverlo, oppure torna dopo quando hai tempo.",

View File

@@ -100,9 +100,6 @@
"connectionError": { "connectionError": {
"message": "接続エラーが発生しました。 エラーコード: " "message": "接続エラーが発生しました。 エラーコード: "
}, },
"wantToSubmit": {
"message": "次の動画IDで提出します:"
},
"clearTimes": { "clearTimes": {
"message": "セグメントを消去" "message": "セグメントを消去"
}, },
@@ -362,9 +359,6 @@
"changeUserID": { "changeUserID": {
"message": "ユーザーIDのインポート/エクスポート" "message": "ユーザーIDのインポート/エクスポート"
}, },
"whatChangeUserID": {
"message": "ユーザーIDは公開しないでください。これはパスワードのようなもので誰とも共有するべきではありません。 他の誰かが知った場合、あなたになりすます可能性があります。"
},
"setUserID": { "setUserID": {
"message": "ユーザーIDを設定" "message": "ユーザーIDを設定"
}, },
@@ -723,7 +717,7 @@
"message": "二度と表示しない" "message": "二度と表示しない"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "警告のため,区域の送信が一時的に禁止されています。これは利用者さまが間違いを犯されているというこちらどもの判断ではありますが,この間違いが悪意あるものとは思っておりません。単に,利用者さまに区域送信における規則を知っていただきたいだけです。連絡先: discord.gg/SponsorBlockmatrix.to/#/+sponsor:ajay.app" "message": "警告のため,区域の送信が一時的に禁止されています。これは利用者さまが間違いを犯されているというこちらどもの判断ではありますが,この間違いが悪意あるものとは思っておりません。単に,利用者さまに区域送信における規則を知っていただきたいだけです。連絡先: discord.gg/SponsorBlockmatrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "警告により投票が拒否されました。クリックして運営に連絡するか,少し時間を置いてからやりなおしてください。", "message": "警告により投票が拒否されました。クリックして運営に連絡するか,少し時間を置いてからやりなおしてください。",

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "다시 건너뛰기" "message": "다시 건너뛰기"
}, },
"unmute": {
"message": "음소거 해제"
},
"paused": { "paused": {
"message": "정지됨" "message": "정지됨"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "서버 오류가 발생하였습니다. 오류 코드: " "message": "서버 오류가 발생하였습니다. 오류 코드: "
}, },
"wantToSubmit": {
"message": "영상 id를 제출하시겠습니까"
},
"clearTimes": { "clearTimes": {
"message": "구간 제거" "message": "구간 제거"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "사용자 이름 설정" "message": "사용자 이름 설정"
}, },
"copyPublicID": {
"message": "공개 사용자 ID 복사"
},
"discordAdvert": { "discordAdvert": {
"message": "공식 디스코드 서버에 들어와서 기능 제안을 해주시거나 피드백을 남겨주세요!" "message": "공식 디스코드 서버에 들어와서 기능 제안을 해주시거나 피드백을 남겨주세요!"
}, },
@@ -227,6 +230,21 @@
"showSkipNotice": { "showSkipNotice": {
"message": "구간을 건너뛴 후 알림 표시" "message": "구간을 건너뛴 후 알림 표시"
}, },
"noticeVisibilityMode0": {
"message": "건너뛰기 알림 크게"
},
"noticeVisibilityMode1": {
"message": "자동 건너뛰기에 대해서는 건너뛰기 알림 작게"
},
"noticeVisibilityMode2": {
"message": "모든 건너뛰기 알림 작게"
},
"noticeVisibilityMode3": {
"message": "자동 건너뛰기에 대해서는 건너뛰기 알림 숨김"
},
"noticeVisibilityMode4": {
"message": "모든 건너뛰기 알림 숨김"
},
"longDescription": { "longDescription": {
"message": "SponsorBlock을 사용하면 영상에서 스폰서 광고, 인트로 영상, 아웃트로 영상, 구독 광고와 그 외 쓸데없는 부분을 즉시 건너뛸 수 있습니다. SponsorBlock은 모든 사람들이 참여하는 브라우저 확장 기능으로 확장 기능 사용자는 스폰서 광고 또는 다른 광고의 시작 시간과 끝 시간을 확인하여 서버로 전송할 수 있습니다. 이러한 정보가 전송되면 그 영상을 보는 다른 사용자들은 광고 구간이 나오기 전에 자동으로 건너뛸 수 있습니다. SponsorBlock을 사용하면 뮤직 비디오에서 음악이나 노래가 아닌 구간도 건너뛸 수 있습니다.", "message": "SponsorBlock을 사용하면 영상에서 스폰서 광고, 인트로 영상, 아웃트로 영상, 구독 광고와 그 외 쓸데없는 부분을 즉시 건너뛸 수 있습니다. SponsorBlock은 모든 사람들이 참여하는 브라우저 확장 기능으로 확장 기능 사용자는 스폰서 광고 또는 다른 광고의 시작 시간과 끝 시간을 확인하여 서버로 전송할 수 있습니다. 이러한 정보가 전송되면 그 영상을 보는 다른 사용자들은 광고 구간이 나오기 전에 자동으로 건너뛸 수 있습니다. SponsorBlock을 사용하면 뮤직 비디오에서 음악이나 노래가 아닌 구간도 건너뛸 수 있습니다.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
@@ -284,9 +302,15 @@
"skip": { "skip": {
"message": "스킵" "message": "스킵"
}, },
"mute": {
"message": "음소거"
},
"skip_category": { "skip_category": {
"message": "{0} 을(를) 건너뛰겠어요?" "message": "{0} 을(를) 건너뛰겠어요?"
}, },
"mute_category": {
"message": "{0} 카테고리를 음소거하시겠습니까?"
},
"skip_to_category": { "skip_to_category": {
"message": "{0}(으)로 건너뛰겠어요?", "message": "{0}(으)로 건너뛰겠어요?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -295,6 +319,10 @@
"message": "{0} 건너뜀", "message": "{0} 건너뜀",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} 음소거됨",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "{0}(으)로 건너뛰었습니다", "message": "{0}(으)로 건너뛰었습니다",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -348,7 +376,7 @@
"message": "사용자 ID 가져오기/내보내기" "message": "사용자 ID 가져오기/내보내기"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "이 정보는 다른 사람에게 공개하지 마세요. 이것은 비밀번호처럼 절대로 알려주면 안되는 정보입니다. 다른 사람이 이 정보를 습득했을 경우 사용자를 사칭할 수도 있습니다." "message": "이 정보는 다른 사람에게 공개하지 마세요. 이것은 비밀번호처럼 절대로 알려주면 안되는 정보입니다. 다른 사람이 이 정보를 습득했을 경우 사용자를 사칭할 수도 있습니다. 혹시 공개 사용자 ID를 찾고 있다면, 팝업 내 클립보드 아이콘을 누르시기 바랍니다."
}, },
"setUserID": { "setUserID": {
"message": "사용자ID 설정" "message": "사용자ID 설정"
@@ -586,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "음악이 아닌 구간이 있을 때는 모든 구간 자동 건너뛰기" "message": "음악이 아닌 구간이 있을 때는 모든 구간 자동 건너뛰기"
}, },
"muteSegments": {
"message": "구간을 건너뛰지 않고 음소거 처리"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "올바르지 않은 색상 코드입니다. 색상 코드는 샵 (#) 기호로 시작하여 3자리 또는 6자리의 16진수로 구성되어야 합니다." "message": "올바르지 않은 색상 코드입니다. 색상 코드는 샵 (#) 기호로 시작하여 3자리 또는 6자리의 16진수로 구성되어야 합니다."
}, },
@@ -625,6 +656,9 @@
"message": "\"{0}\" 카테고리의 세그먼트를 제출하려면 설정에서 활성화 해주셔야 합니다. 지금 설정으로 이동합니다.", "message": "\"{0}\" 카테고리의 세그먼트를 제출하려면 설정에서 활성화 해주셔야 합니다. 지금 설정으로 이동합니다.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "경고: 이 유형의 세그먼트는 한 번에 최대 하나씩 활성화될 수 있습니다. 여러 개를 제출하면 무작위로 표시됩니다."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "제출 해야하는 모든 구간의 카테고리를 설정해야합니다!" "message": "제출 해야하는 모든 구간의 카테고리를 설정해야합니다!"
}, },
@@ -708,7 +742,7 @@
"message": "다시 보지 않음" "message": "다시 보지 않음"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "현재 귀하가 악의적이지 않은 일반적인 실수를 저지르고 있음을 발견했습니다. 이에 따라 경고 조치가 내려져 일시적으로 구간을 제출할 수 없게 되었습니다. 저희는 단지 규칙을 명확히 전달하고자 합니다. discord.gg/SponsorBlock 또는 matrix.to/#/+sponsor:ajay.app 링크를 통해 대화에 참여할 수도 있습니다." "message": "현재 귀하가 악의적이지 않은 일반적인 실수를 저지르고 있음을 발견했습니다. 이에 따라 경고 조치가 내려져 일시적으로 구간을 제출할 수 없게 되었습니다. 저희는 단지 규칙을 명확히 전달하고자 합니다. discord.gg/SponsorBlock 또는 matrix.to/#/#sponsor:ajay.app 링크를 통해 대화에 참여할 수도 있습니다."
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "경고로 인해 투표가 거부되었습니다. 클릭하여 대화로 해결하거나, 나중에 시간이 나면 다시 오세요.", "message": "경고로 인해 투표가 거부되었습니다. 클릭하여 대화로 해결하거나, 나중에 시간이 나면 다시 오세요.",
@@ -744,6 +778,9 @@
"helpPageSubmitting1": { "helpPageSubmitting1": {
"message": "\"광고 구간 시작\" 버튼을 누른 다음 팝업에서 제출할 수도 있으며 동영상 플레이어 내 버튼으로 제출할 수도 있습니다." "message": "\"광고 구간 시작\" 버튼을 누른 다음 팝업에서 제출할 수도 있으며 동영상 플레이어 내 버튼으로 제출할 수도 있습니다."
}, },
"helpPageSubmitting2": {
"message": "재생 아이콘을 누르면 구간의 시점을 정할 수 있고 중지 아이콘을 누르면 구간의 종점을 정할 수 있습니다. 제출하기 전 여러 구간을 설정할 수 있습니다. 업로드 아이콘을 눌러 제출할 수 있습니다. 휴지통 아이콘을 눌러 구간을 제거할 수 있습니다."
},
"Editing": { "Editing": {
"message": "수정" "message": "수정"
}, },
@@ -753,6 +790,18 @@
"helpPageTooSlow": { "helpPageTooSlow": {
"message": "너무 느립니다" "message": "너무 느립니다"
}, },
"helpPageTooSlow1": {
"message": "원하는 경우 단축키를 이용할 수 있습니다. 쌍반점 키를 눌러 스폰서 구간의 시점/종점을 설정할 수 있으며 작은따옴표 키를 눌러 구간을 제출할 수 있습니다. 설정에서 이를 변경할 수 있습니다. QWERTY 자판을 사용하지 않는 경우, 단축키 설정을 변경해야 할 수 있습니다."
},
"helpPageCopyOfDatabase": {
"message": "데이터베이스의 사본을 구할 수 있을까요? 개발자에게 무슨 일이 생기면 어떻게 되는 거죠?"
},
"helpPageCopyOfDatabase1": {
"message": "데이터베이스는 공개되어 있으며 다음 주소를 통해 접근할 수 있습니다"
},
"helpPageCopyOfDatabase2": {
"message": "소스 코드는 자유롭게 이용할 수 있습니다. 따라서 제게 무슨 일이 생기더라도, 기여 사항이 사라지는 일은 없습니다."
},
"helpPageNews": { "helpPageNews": {
"message": "소식 및 제작 방법" "message": "소식 및 제작 방법"
}, },

View File

@@ -94,9 +94,6 @@
"connectionError": { "connectionError": {
"message": "ഒരു കണക്ഷൻ പിശക് സംഭവിച്ചു. പിശക് കോഡ്: " "message": "ഒരു കണക്ഷൻ പിശക് സംഭവിച്ചു. പിശക് കോഡ്: "
}, },
"wantToSubmit": {
"message": "വീഡിയോ ഐഡിക്ക് സമർപ്പിക്കാൻ നിങ്ങൾ ആഗ്രഹിക്കുന്നുണ്ടോ"
},
"clearTimes": { "clearTimes": {
"message": "സെഗ്‌മെന്റുകൾ മായ്‌ക്കുക" "message": "സെഗ്‌മെന്റുകൾ മായ്‌ക്കുക"
}, },
@@ -320,9 +317,6 @@
"changeUserID": { "changeUserID": {
"message": "നിങ്ങളുടെ യൂസർ ഐഡി ഇറക്കുമതി ചെയ്യുക / കയറ്റുമതി ചെയ്യുക" "message": "നിങ്ങളുടെ യൂസർ ഐഡി ഇറക്കുമതി ചെയ്യുക / കയറ്റുമതി ചെയ്യുക"
}, },
"whatChangeUserID": {
"message": "ഇത് സ്വകാര്യമായി സൂക്ഷിക്കണം. ഇത് ഒരു പാസ്‌വേഡ് പോലെയാണ്, ഇത് ആരുമായും പങ്കിടാൻ പാടില്ല. ആർക്കെങ്കിലും ഇത് ഉണ്ടെങ്കിൽ, അവർക്ക് നിങ്ങളെ ആൾമാറാട്ടം നടത്താം."
},
"setUserID": { "setUserID": {
"message": "യൂസർ ഐഡി സജ്ജമാക്കുക" "message": "യൂസർ ഐഡി സജ്ജമാക്കുക"
}, },

View File

@@ -94,9 +94,6 @@
"connectionError": { "connectionError": {
"message": "Ralat sambungan telah berlaku. Kod salah: " "message": "Ralat sambungan telah berlaku. Kod salah: "
}, },
"wantToSubmit": {
"message": "Adakah anda ingin menghantar untuk id video"
},
"clearTimes": { "clearTimes": {
"message": "Kosongkan Segmen" "message": "Kosongkan Segmen"
}, },
@@ -320,9 +317,6 @@
"changeUserID": { "changeUserID": {
"message": "Import / Eksport Id Pengguna Anda" "message": "Import / Eksport Id Pengguna Anda"
}, },
"whatChangeUserID": {
"message": "Perkara ini harus dirahsiakan. Ini seperti kata laluan dan tidak boleh dikongsi dengan sesiapa pun. Sekiranya seseorang mempunyai ini, mereka boleh menyamar sebagai anda."
},
"setUserID": { "setUserID": {
"message": "Tetapkan Id Pengguna" "message": "Tetapkan Id Pengguna"
}, },

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Opnieuw overslaan" "message": "Opnieuw overslaan"
}, },
"unmute": {
"message": "Niet meer dempen"
},
"paused": { "paused": {
"message": "Gepauzeerd" "message": "Gepauzeerd"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Er is een verbindingsfout opgetreden. Foutcode: " "message": "Er is een verbindingsfout opgetreden. Foutcode: "
}, },
"wantToSubmit": {
"message": "Wilt u indienen voor video-id"
},
"clearTimes": { "clearTimes": {
"message": "Segmenten verwijderen" "message": "Segmenten verwijderen"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Gebruikersnaam instellen" "message": "Gebruikersnaam instellen"
}, },
"copyPublicID": {
"message": "Publieke gebruikers-ID kopiëren"
},
"discordAdvert": { "discordAdvert": {
"message": "Word lid van de officiële Discord-server om suggesties en feedback te geven!" "message": "Word lid van de officiële Discord-server om suggesties en feedback te geven!"
}, },
@@ -299,9 +302,15 @@
"skip": { "skip": {
"message": "Overslaan" "message": "Overslaan"
}, },
"mute": {
"message": "Dempen"
},
"skip_category": { "skip_category": {
"message": "{0} overslaan?" "message": "{0} overslaan?"
}, },
"mute_category": {
"message": "{0} dempen?"
},
"skip_to_category": { "skip_to_category": {
"message": "Overslaan naar {0}?", "message": "Overslaan naar {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -310,6 +319,10 @@
"message": "{0} overgeslagen", "message": "{0} overgeslagen",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} gedempt",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Overgeslagen naar {0}", "message": "Overgeslagen naar {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -363,7 +376,7 @@
"message": "Uw gebruikers-ID importeren/exporteren" "message": "Uw gebruikers-ID importeren/exporteren"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Dit moet privé gehouden worden. Dit is als een wachtwoord en mag met niemand gedeeld worden. Als iemand dit heeft, kan hij zich voordoen als u." "message": "Dit moet privé gehouden worden. Dit is als een wachtwoord en mag met niemand gedeeld worden. Als iemand dit heeft, kan hij zich voordoen als u. Klik op het klembordpictogram in de popup als u op zoek bent naar uw publieke gebrukers-ID."
}, },
"setUserID": { "setUserID": {
"message": "Gebruikers-ID instellen" "message": "Gebruikers-ID instellen"
@@ -601,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Automatisch alle segmenten overslaan wanneer er een niet-muziek-segment is" "message": "Automatisch alle segmenten overslaan wanneer er een niet-muziek-segment is"
}, },
"muteSegments": {
"message": "Segmenten toestaan die audio dempen in plaats van overslaan"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Uw kleur is verkeerd geformatteerd. Het moet een hexadecimale code van 3 of 6 cijfers zijn met een hekje aan het begin." "message": "Uw kleur is verkeerd geformatteerd. Het moet een hexadecimale code van 3 of 6 cijfers zijn met een hekje aan het begin."
}, },
@@ -640,6 +656,9 @@
"message": "Om segmenten met de categorie \"{0}\" in te dienen, moet u deze in de opties inschakelen. U wordt nu doorgestuurd naar de opties.", "message": "Om segmenten met de categorie \"{0}\" in te dienen, moet u deze in de opties inschakelen. U wordt nu doorgestuurd naar de opties.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Waarschuwing: dit type segment kan maximaal één keer tegelijk actief zijn. Meerdere segmenten indienen zal weergave van een willekeurig segment veroorzaken."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "U moet een categorie selecteren voor alle segmenten die u indient!" "message": "U moet een categorie selecteren voor alle segmenten die u indient!"
}, },
@@ -723,7 +742,7 @@
"message": "Voor altijd verbergen" "message": "Voor altijd verbergen"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "U heeft een waarschuwing gekregen en kunt tijdelijk geen segmenten indienen. Dit betekent dat we gemerkt hebben dat u een aantal veelvoorkomende fouten maakt die niet kwaadaardig zijn, en we willen gewoon de regels verduidelijken. U kunt ook deelnemen aan deze chat via discord.gg/SponsorBlock of matrix.to/#/+sponsor:ajay.app" "message": "U heeft een waarschuwing gekregen en kunt tijdelijk geen segmenten indienen. Dit betekent dat we gemerkt hebben dat u een aantal veelvoorkomende fouten maakt die niet kwaadaardig zijn, en we willen gewoon de regels verduidelijken. U kunt ook deelnemen aan deze chat via discord.gg/SponsorBlock of matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Stem geweigerd vanwege een waarschuwing. Klik om een chat te openen om het op te lossen, of kom later terug als u tijd hebt.", "message": "Stem geweigerd vanwege een waarschuwing. Klik om een chat te openen om het op te lossen, of kom later terug als u tijd hebt.",

View File

@@ -94,9 +94,6 @@
"connectionError": { "connectionError": {
"message": "En tilkoblingsfeil har oppstått. Feilkode: " "message": "En tilkoblingsfeil har oppstått. Feilkode: "
}, },
"wantToSubmit": {
"message": "Vil du sende inn for video-ID-en"
},
"clearTimes": { "clearTimes": {
"message": "Tøm segmenter" "message": "Tøm segmenter"
}, },
@@ -320,9 +317,6 @@
"changeUserID": { "changeUserID": {
"message": "Importer/Eksporter din bruker-ID" "message": "Importer/Eksporter din bruker-ID"
}, },
"whatChangeUserID": {
"message": "Dette burde holdes privat. Dette er som et passord og burde ikke deles med noen. Hvis noen har dette, kan de etterligne deg."
},
"setUserID": { "setUserID": {
"message": "Angi bruker-ID" "message": "Angi bruker-ID"
}, },

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Pomiń" "message": "Pomiń"
}, },
"unmute": {
"message": "Odcisz"
},
"paused": { "paused": {
"message": "Zatrzymany" "message": "Zatrzymany"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Wystąpił błąd połączenia. Kod błędu: " "message": "Wystąpił błąd połączenia. Kod błędu: "
}, },
"wantToSubmit": {
"message": "Czy chcesz wysłać dla filmu o id"
},
"clearTimes": { "clearTimes": {
"message": "Wyczyść segmenty" "message": "Wyczyść segmenty"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Ustaw nazwę użytkownika" "message": "Ustaw nazwę użytkownika"
}, },
"copyPublicID": {
"message": "Kopiuj Publiczne ID Użytkownika"
},
"discordAdvert": { "discordAdvert": {
"message": "Dołącz do oficjalnego serwera na discordzie i podziel się wrażeniami i sugestiami!" "message": "Dołącz do oficjalnego serwera na discordzie i podziel się wrażeniami i sugestiami!"
}, },
@@ -227,6 +230,21 @@
"showSkipNotice": { "showSkipNotice": {
"message": "Pokaż informację po pominięciu segmentu" "message": "Pokaż informację po pominięciu segmentu"
}, },
"noticeVisibilityMode0": {
"message": "Duże powiadomienia o przewinięciu"
},
"noticeVisibilityMode1": {
"message": "Małe powiadomienia o automatycznym przewijaniu"
},
"noticeVisibilityMode2": {
"message": "Małe powiadomienia o przewinięciu"
},
"noticeVisibilityMode3": {
"message": "Znikające powiadomienia o automatycznym przewijaniu"
},
"noticeVisibilityMode4": {
"message": "Znikające powiadomienia o przewijaniu"
},
"longDescription": { "longDescription": {
"message": "SponsorBlock pozwala pomijać sponsorów, intra, outra, przypomnienia o subskrypcjach i inne irytujące fragmenty filmów na YouTube. SponsorBlock jest opartym na crowdsourcingu rozszerzeniem do przeglądarki, które pozwala każdemu zgłosić początek i koniec segmentów sponsorowanych oraz innych segmentów w filmach na YouTube. Kiedy ktoś już zamieści te informacje, wszyscy pozostali z tym rozszerzeniem będą pomijać segment sponsorowany. Możesz również pomijać fragmenty teledysków bez muzyki.", "message": "SponsorBlock pozwala pomijać sponsorów, intra, outra, przypomnienia o subskrypcjach i inne irytujące fragmenty filmów na YouTube. SponsorBlock jest opartym na crowdsourcingu rozszerzeniem do przeglądarki, które pozwala każdemu zgłosić początek i koniec segmentów sponsorowanych oraz innych segmentów w filmach na YouTube. Kiedy ktoś już zamieści te informacje, wszyscy pozostali z tym rozszerzeniem będą pomijać segment sponsorowany. Możesz również pomijać fragmenty teledysków bez muzyki.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
@@ -284,9 +302,31 @@
"skip": { "skip": {
"message": "Pomiń" "message": "Pomiń"
}, },
"mute": {
"message": "Wycisz"
},
"skip_category": { "skip_category": {
"message": "Pominąć {0}?" "message": "Pominąć {0}?"
}, },
"mute_category": {
"message": "Wyciszyć {0}?"
},
"skip_to_category": {
"message": "Przejść do {0}?",
"description": "Used for skipping to things (Skip to Highlight)"
},
"skipped": {
"message": "Pominięto {0}",
"description": "Example: Sponsor Skipped"
},
"muted": {
"message": "Wyciszono {0}",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": {
"message": "Przewinięto do {0}",
"description": "Used for skipping to things (Skipped to Highlight)"
},
"disableAutoSkip": { "disableAutoSkip": {
"message": "Wyłącz autopomijanie" "message": "Wyłącz autopomijanie"
}, },
@@ -336,7 +376,7 @@
"message": "Importuj/Eksportuj swój identyfikator użytkownika" "message": "Importuj/Eksportuj swój identyfikator użytkownika"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Ta informacja jest poufna i działa jak hasło. Użytkownik, który ma do niej dostęp, może zgłaszać treści jako ty." "message": "Powinno pozostać prywatne. Jest to niczym hasło i nie powinno być nikomu udostępniane. Przy jego użyciu może się pod ciebie podszywać. Jeśli szukasz publicznego ID użytkownika, kliknij ikonę schowka w wyskakującym oknie."
}, },
"setUserID": { "setUserID": {
"message": "Ustaw identyfikator użytkownika" "message": "Ustaw identyfikator użytkownika"
@@ -538,6 +578,12 @@
"category_music_offtopic_short": { "category_music_offtopic_short": {
"message": "Bez muzyki" "message": "Bez muzyki"
}, },
"category_poi_highlight": {
"message": "Wyróżnione"
},
"category_poi_highlight_description": {
"message": "Część filmu, która interesuje większość osób. Podobne do komentarzy typu „Filmik zaczyna się od x”."
},
"category_livestream_messages": { "category_livestream_messages": {
"message": "Transmisja live: Dotacja/Czytanie wiadomości" "message": "Transmisja live: Dotacja/Czytanie wiadomości"
}, },
@@ -556,9 +602,21 @@
"disable": { "disable": {
"message": "Wyłączone" "message": "Wyłączone"
}, },
"autoSkip_POI": {
"message": "Automatycznie przewiń do początku"
},
"manualSkip_POI": {
"message": "Zapytaj, gdy wideo się załaduje"
},
"showOverlay_POI": {
"message": "Pokaż na pasku"
},
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Automatycznie pomiń wszystkie segmenty, gdy istnieje segment niemuzyczny" "message": "Automatycznie pomiń wszystkie segmenty, gdy istnieje segment niemuzyczny"
}, },
"muteSegments": {
"message": "Zezwalaj na segmenty, które wyciszą dźwięk zamiast pomijać"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Nieprawidłowy format koloru. Powinien to być zapis szesnastkowy (heksadecymalny) składający się z 3 lub 6 znaków poprzedzonych kratką (#)." "message": "Nieprawidłowy format koloru. Powinien to być zapis szesnastkowy (heksadecymalny) składający się z 3 lub 6 znaków poprzedzonych kratką (#)."
}, },
@@ -598,6 +656,9 @@
"message": "Aby przesyłać segmenty o kategorii „{0}”, musisz ją włączyć w opcjach. Za chwilę nastąpi przekierowanie do ustawień.", "message": "Aby przesyłać segmenty o kategorii „{0}”, musisz ją włączyć w opcjach. Za chwilę nastąpi przekierowanie do ustawień.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Ostrzeżenie: Ten typ segmentu, może być maksymalnie jeden. Przesyłanie kilku na raz spowoduje, że pojawi się losowy."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Musisz wybrać kategorię dla każdego segmentu, który zamieszczasz!" "message": "Musisz wybrać kategorię dla każdego segmentu, który zamieszczasz!"
}, },
@@ -669,6 +730,10 @@
"help": { "help": {
"message": "Pomoc" "message": "Pomoc"
}, },
"GotIt": {
"message": "Rozumiem",
"description": "Used as the button to dismiss a tooltip"
},
"experiementOptOut": { "experiementOptOut": {
"message": "Wyłączenie wszystkich przyszłych eksperymentów", "message": "Wyłączenie wszystkich przyszłych eksperymentów",
"description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private." "description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private."
@@ -677,10 +742,79 @@
"message": "Schowaj na zawsze" "message": "Schowaj na zawsze"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Otrzymałeś ostrzeżenie i nie możesz tymczasowo przesłać segmentów. Oznacza to, że zauważyliśmy, że popełniałeś pewne pospolite błędy, które nie są złośliwe i po prostu chcemy wyjaśnić zasady. Możesz również dołączyć do tego czatu używając discord.gg/SponsorBlock lub matrix.to/#/+sponsor:ajay.app" "message": "Otrzymałeś ostrzeżenie i nie możesz tymczasowo przesłać segmentów. Oznacza to, że zauważyliśmy, że popełniałeś pewne pospolite błędy, które nie są złośliwe i po prostu chcemy wyjaśnić zasady. Możesz również dołączyć do tego czatu używając discord.gg/SponsorBlock lub matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Głosowanie odrzucone z powodu ostrzeżenia. Kliknij, aby otworzyć czat w celu rozwiązania problemu lub wróć później, gdy będziesz miał czas.", "message": "Głosowanie odrzucone z powodu ostrzeżenia. Kliknij, aby otworzyć czat w celu rozwiązania problemu lub wróć później, gdy będziesz miał czas.",
"description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser." "description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser."
},
"Donate": {
"message": "Dotacje"
},
"hideDonationLink": {
"message": "Ukryj opcję dotacji"
},
"helpPageThanksForInstalling": {
"message": "Dziękujemy za zainstalowanie SponsorBlock."
},
"helpPageReviewOptions": {
"message": "Przejrzyj poniższe opcje"
},
"helpPageFeatureDisclaimer": {
"message": "Wiele funkcji jest domyślnie wyłączonych. Jeśli chcesz pomijać intra, outra, używać Invidious, itp., włącz je poniżej. Możesz również ukryć/pokazać elementy interfejsu użytkownika."
},
"helpPageHowSkippingWorks": {
"message": "Jak działa pomijanie"
},
"helpPageHowSkippingWorks1": {
"message": "Segmenty filmu zostaną automatycznie pominięte, jeśli znajdują się w bazie danych. Możesz kliknąć na ikonę rozszerzenia, aby podejrzeć, czym one są."
},
"helpPageHowSkippingWorks2": {
"message": "Za każdym razem, gdy pominiesz segment, otrzymasz powiadomienie. Jeśli moment nie wydaje się być poprawny, kliknij łapkę w dół! Możesz również głosować w okienku pop-up."
},
"Submitting": {
"message": "Wysyłanie"
},
"helpPageSubmitting1": {
"message": "Wysyłanie może być wykonane w wyskakującym okienku, poprzez kliknięcie przycisku \"Początek segmentu\" lub za pomocą przycisków na odtwarzaczu wideo."
},
"helpPageSubmitting2": {
"message": "Kliknięcie przycisku odtwarzania wskazuje początek segmentu a kliknięcie ikony stop wskazuje koniec segmentu. Możesz przygotować wielu segmentów przed wysłaniem. Aby wysłać kliknij przycisk potwierdzający, a aby usunąć - na śmietnik."
},
"Editing": {
"message": "Edytowanie"
},
"helpPageEditing1": {
"message": "Jeśli się pomyliłeś, możesz edytować i usuwać swoje segmenty poprzez kliknięcie przycisku ze strzałką w górę."
},
"helpPageTooSlow": {
"message": "Zbyt wolno"
},
"helpPageTooSlow1": {
"message": "Istnieją skróty klawiszowe, jeśli chcesz ich używać. Naciśnij klawisz średnika, aby wskazać początek/koniec segmentu sponsora i kliknij w apostrof, aby przesłać. Można je zmienić w opcjach. Jeśli nie używasz QWERTY, prawdopodobnie powinieneś zmienić skrót klawiszowy."
},
"helpPageCopyOfDatabase": {
"message": "Czy mogę otrzymać kopię bazy danych? Co się stanie, jeśli przestaniecie istnieć?"
},
"helpPageCopyOfDatabase1": {
"message": "Baza danych jest publiczna i dostępna na stronie"
},
"helpPageCopyOfDatabase2": {
"message": "Kod źródłowy jest dostępny. Tak więc, nawet jeśli coś się ze mną stanie, wasze zgłoszenia nie zostaną utracone."
},
"helpPageNews": {
"message": "Wiadomości i jak to jest zrobione"
},
"helpPageSourceCode": {
"message": "Gdzie mogę otrzymać kod źródłowy?"
},
"Credits": {
"message": "Autorzy"
},
"highlightNewFeature": {
"message": "Nowość! Przejdź do interesującej części filmu jednym kliknięciem z nową kategorią wyróżnione"
},
"LearnMore": {
"message": "Dowiedz się więcej"
} }
} }

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Pular novamente" "message": "Pular novamente"
}, },
"unmute": {
"message": "Ativar som"
},
"paused": { "paused": {
"message": "Pausado" "message": "Pausado"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Ocorreu um erro de conexão. Código de erro: " "message": "Ocorreu um erro de conexão. Código de erro: "
}, },
"wantToSubmit": {
"message": "Deseja enviar para o vídeo com id"
},
"clearTimes": { "clearTimes": {
"message": "Limpar Segmentos" "message": "Limpar Segmentos"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Definir nome de usuário" "message": "Definir nome de usuário"
}, },
"copyPublicID": {
"message": "Copiar ID Pública de Usuário"
},
"discordAdvert": { "discordAdvert": {
"message": "Junte-se ao servidor do discord oficial para dar dicas e sugestões!" "message": "Junte-se ao servidor do discord oficial para dar dicas e sugestões!"
}, },
@@ -299,9 +302,15 @@
"skip": { "skip": {
"message": "Pular" "message": "Pular"
}, },
"mute": {
"message": "Silenciar"
},
"skip_category": { "skip_category": {
"message": "Pular {0}?" "message": "Pular {0}?"
}, },
"mute_category": {
"message": "Silenciar {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Pular para {0}?", "message": "Pular para {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -310,6 +319,10 @@
"message": "{0} Ignorado", "message": "{0} Ignorado",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} Silenciado",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Pulado para {0}", "message": "Pulado para {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -363,7 +376,7 @@
"message": "Importar/Exportar seu ID de usuário" "message": "Importar/Exportar seu ID de usuário"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Isso deve ser mantido em segredo. É como se fosse uma senha e não deve ser compartilhado com ninguém. Se alguém tiver isso, poderá se passar por você." "message": "Esta informação deve se mantida privada. Ela é como uma senha e não deve ser compartilhada. Outras pessoas poderão se passar por você caso obtenham acesso. Se estiver procurando por sua ID Pública de Usuário, clique no ícone de prancheta no popup."
}, },
"setUserID": { "setUserID": {
"message": "Definir ID de usuário" "message": "Definir ID de usuário"
@@ -601,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Pular automaticamente todos os segmentos quando há um segmento que não é música" "message": "Pular automaticamente todos os segmentos quando há um segmento que não é música"
}, },
"muteSegments": {
"message": "Permitir segmentos que silenciem o áudio ao invés de pular"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Sua cor está formatada incorretamente. Deve ser um código hexadecimal de 3 ou 6 dígitos com uma cerquilha (hashtag) no início." "message": "Sua cor está formatada incorretamente. Deve ser um código hexadecimal de 3 ou 6 dígitos com uma cerquilha (hashtag) no início."
}, },
@@ -723,7 +739,7 @@
"message": "Ocultar para sempre" "message": "Ocultar para sempre"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Você recebeu um aviso e temporariamente não poderá enviar segmentos. Isso significa que notamos que você cometeu alguns erros comuns que não são maliciosos, e queremos apenas clarificar as regras. Você também pode participar desse chat usando discord.gg/SponsorBlock ou matrix.to/#/+sponsor:ajay.app" "message": "Você recebeu um aviso e temporariamente não poderá enviar segmentos. Isso significa que notamos que você cometeu alguns erros comuns que não são maliciosos, e queremos apenas clarificar as regras. Você também pode participar desse chat usando discord.gg/SponsorBlock ou matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Voto rejeitado devido a um aviso. Clique para abrir um chat para resolvê-lo, ou volte mais tarde quando tiver tempo.", "message": "Voto rejeitado devido a um aviso. Clique para abrir um chat para resolvê-lo, ou volte mais tarde quando tiver tempo.",

View File

@@ -94,9 +94,6 @@
"connectionError": { "connectionError": {
"message": "A apărut o eroare de conexiune. Cod de eroare: " "message": "A apărut o eroare de conexiune. Cod de eroare: "
}, },
"wantToSubmit": {
"message": "Doriți să trimiteți pentru id video"
},
"clearTimes": { "clearTimes": {
"message": "Curăță segmentele" "message": "Curăță segmentele"
}, },
@@ -320,9 +317,6 @@
"changeUserID": { "changeUserID": {
"message": "Importă/Exportă Id-ul Tău De Utilizator" "message": "Importă/Exportă Id-ul Tău De Utilizator"
}, },
"whatChangeUserID": {
"message": "Acest lucru trebuie să fie păstrat. Este ca și o parolă și nu ar trebui împartășită cu nimeni. Daca cineva are acest lucru, se poate da drept tu."
},
"setUserID": { "setUserID": {
"message": "Setează Id-ul Utilizatorului" "message": "Setează Id-ul Utilizatorului"
}, },

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Пропустить" "message": "Пропустить"
}, },
"unmute": {
"message": "Включить звук"
},
"paused": { "paused": {
"message": "Пауза" "message": "Пауза"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Ошибка соединения. Код ошибки: " "message": "Ошибка соединения. Код ошибки: "
}, },
"wantToSubmit": {
"message": "Вы хотите отправить сегменты для видео с id"
},
"clearTimes": { "clearTimes": {
"message": "Очистить сегменты" "message": "Очистить сегменты"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Установить имя пользователя" "message": "Установить имя пользователя"
}, },
"copyPublicID": {
"message": "Копировать публичный UserID"
},
"discordAdvert": { "discordAdvert": {
"message": "Присоединяйтесь к официальному серверу Discord, чтобы оставить предложения и обратную связь!" "message": "Присоединяйтесь к официальному серверу Discord, чтобы оставить предложения и обратную связь!"
}, },
@@ -299,9 +302,15 @@
"skip": { "skip": {
"message": "Пропустить" "message": "Пропустить"
}, },
"mute": {
"message": "Заглушить"
},
"skip_category": { "skip_category": {
"message": "Пропустить {0}?" "message": "Пропустить {0}?"
}, },
"mute_category": {
"message": "Заглушить {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Пропустить до {0}?", "message": "Пропустить до {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -310,6 +319,10 @@
"message": "Пропущено: {0}", "message": "Пропущено: {0}",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} заглушен",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Пропущено до {0}", "message": "Пропущено до {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -363,7 +376,7 @@
"message": "Импорт/Экспорт Вашего идентификатора пользователя" "message": "Импорт/Экспорт Вашего идентификатора пользователя"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Его нужно держать в секрете. Это как пароль, не стоит им ни с кем делиться. Если он у кого-то есть, он сможет выдать себя за Вас." "message": "Держите его в тайне. Относитесь к нему как к паролю и не передавайте никому. Если кто-то им завладеет, то сможет выдать себя за вас. Если вы ищете публичный ID пользователя, нажмите значок буфера обмена во всплывающем окне."
}, },
"setUserID": { "setUserID": {
"message": "Установить идентификатор пользователя" "message": "Установить идентификатор пользователя"
@@ -601,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Пропускать все сегменты автоматически при наличии сегмента без музыки" "message": "Пропускать все сегменты автоматически при наличии сегмента без музыки"
}, },
"muteSegments": {
"message": "Разрешить сегменты, которые отключают звук вместо пропуска"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Вы ввели цвет в неправильном формате. Это должно быть 3-х или 6-ти значное шестнадцатеричное число с символом # в начале." "message": "Вы ввели цвет в неправильном формате. Это должно быть 3-х или 6-ти значное шестнадцатеричное число с символом # в начале."
}, },
@@ -640,6 +656,9 @@
"message": "Чтобы отправить сегменты категории \"{0}\", вы должны включить её в настройках. Сейчас вы будете туда перенаправлены.", "message": "Чтобы отправить сегменты категории \"{0}\", вы должны включить её в настройках. Сейчас вы будете туда перенаправлены.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Предупреждение: Только один сегмент данного типа может быть активным. Отправка нескольких приведёт к отображению только одного случайно выбранного."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Вы должны выбрать категорию для всех сегментов, которые вы отправляете!" "message": "Вы должны выбрать категорию для всех сегментов, которые вы отправляете!"
}, },
@@ -723,7 +742,7 @@
"message": "Скрыть навсегда" "message": "Скрыть навсегда"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Вы получили предупреждение и временно не можете отправлять сегменты. Мы заметили, что вы совершали распространенные ошибки, которые не являются злонамеренными, и просто хотим уточнить для вас правила. Вы также можете присоединиться к нашему чату, используя discord.gg/SponsorBlock или matrix.to/#/+sponsor:ajay.app" "message": "Вы получили предупреждение и временно не можете отправлять сегменты. Мы заметили, что вы совершали распространенные ошибки, которые не являются злонамеренными, и просто хотим уточнить для вас правила. Вы также можете присоединиться к нашему чату, используя discord.gg/SponsorBlock или matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Голосование отклонено из-за предупреждения. Нажмите, чтобы открыть чат, где вы можете решить проблему, или вернитесь, когда у вас будет время.", "message": "Голосование отклонено из-за предупреждения. Нажмите, чтобы открыть чат, где вы можете решить проблему, или вернитесь, когда у вас будет время.",

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Znovu preskočiť" "message": "Znovu preskočiť"
}, },
"unmute": {
"message": "Zrušiť stíšenie"
},
"paused": { "paused": {
"message": "Pozastavené" "message": "Pozastavené"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Nastala chyba pripojenia. Kód chyby: " "message": "Nastala chyba pripojenia. Kód chyby: "
}, },
"wantToSubmit": {
"message": "Chcete odoslať segmenty pre video id"
},
"clearTimes": { "clearTimes": {
"message": "Zmazať segmenty" "message": "Zmazať segmenty"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Nastaviť Používateľské meno" "message": "Nastaviť Používateľské meno"
}, },
"copyPublicID": {
"message": "Skopírovať verejné ID používateľa"
},
"discordAdvert": { "discordAdvert": {
"message": "Pripojte sa k oficiálnemu Discord serveru a zanechajte nám pripomienky!" "message": "Pripojte sa k oficiálnemu Discord serveru a zanechajte nám pripomienky!"
}, },
@@ -284,9 +287,15 @@
"skip": { "skip": {
"message": "Preskočiť" "message": "Preskočiť"
}, },
"mute": {
"message": "Stíšiť"
},
"skip_category": { "skip_category": {
"message": "Preskočiť {0}?" "message": "Preskočiť {0}?"
}, },
"mute_category": {
"message": "Stíšiť {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Preskočiť na {0}?", "message": "Preskočiť na {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -295,6 +304,10 @@
"message": "{0} preskočené", "message": "{0} preskočené",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} stíšený",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Preskočené na {0}", "message": "Preskočené na {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -348,7 +361,7 @@
"message": "Import/export vášho ID používateľa" "message": "Import/export vášho ID používateľa"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Toto si držte v bezpečí. Je to ako heslo a nemali by ste ho s nikým zdieľať. Ten kto ho má by sa mohol zas vydávať." "message": "Toto si starostlivo uchovajte. Podobne ako heslo by ste to nemali s nikým zdieľať. Ak by to získal niekto ďalší, mohol bym uškodiť. Ak hľadáte vaše verejné ID používateľa, stlačte ikonu schránky v podokne."
}, },
"setUserID": { "setUserID": {
"message": "Nastaviť Používateľove ID" "message": "Nastaviť Používateľove ID"
@@ -586,6 +599,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Automaticky preskočiť všetky segmenty ak neexistuje segment bez hudby" "message": "Automaticky preskočiť všetky segmenty ak neexistuje segment bez hudby"
}, },
"muteSegments": {
"message": "Povoliť segmenty, ktoré namiesto preskočenia stíšía zvuk"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Vaša farba je nesprávne naformátovaná. Mal by to byť 3 alebo 6-miestny hexadecimálny kód so znakom čísla na začiatku." "message": "Vaša farba je nesprávne naformátovaná. Mal by to byť 3 alebo 6-miestny hexadecimálny kód so znakom čísla na začiatku."
}, },
@@ -625,6 +641,9 @@
"message": "Pre odoslanie segmentov z kategórie \"{0}\" ju musíte zapnúť v nastaveniach. Teraz tam budete presmerovaní.", "message": "Pre odoslanie segmentov z kategórie \"{0}\" ju musíte zapnúť v nastaveniach. Teraz tam budete presmerovaní.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Varovanie: Tento typ segmentu môže byť aktívny len jeden. Odoslanie viacerých spôsobí zobrazenie náhodného z nich."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Musíte zvoliť kategóriu pre každý segment!" "message": "Musíte zvoliť kategóriu pre každý segment!"
}, },
@@ -708,7 +727,7 @@
"message": "Navždy skryť" "message": "Navždy skryť"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Dostali ste varovanie a nemôžete tak dočasne odosielať segmenty. To znamená, že sme si všimli, že ste spravili nejaké chyby, ktoré nie sú myslené zle, a chceme Vám len objasniť pravidlá. Môžete sa pripojiť do konverzácie pomocou discord.gg/SponsorBlock alebo matrix.to/#/+sponsor:ajay.app" "message": "Dostali ste varovanie a nemôžete tak dočasne odosielať segmenty. To znamená, že sme si všimli, že ste spravili nejaké chyby, ktoré nie sú myslené zle, a chceme Vám len objasniť pravidlá. Môžete sa pripojiť do konverzácie pomocou discord.gg/SponsorBlock alebo matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Hlasovanie bolo zamietnuté kvôli varovaniu. Kliknite pre otvorenie chatu, aby ste ho vyriešili, alebo sa vráťte až budete mať čas.", "message": "Hlasovanie bolo zamietnuté kvôli varovaniu. Kliknite pre otvorenie chatu, aby ste ho vyriešili, alebo sa vráťte až budete mať čas.",

View File

@@ -1 +1,30 @@
{} {
"Options": {
"message": "Подешавања"
},
"sourceCode": {
"message": "Изворни код",
"description": "Used on Firefox Store Page"
},
"errorCode": {
"message": "Код грешке: "
},
"skip": {
"message": "Прескочи"
},
"add": {
"message": "Додај"
},
"save": {
"message": "Сачувај"
},
"cancel": {
"message": "Откажи"
},
"edit": {
"message": "Измени"
},
"help": {
"message": "Помоћ"
}
}

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Hoppa över igen" "message": "Hoppa över igen"
}, },
"unmute": {
"message": "Ljud"
},
"paused": { "paused": {
"message": "Pausad" "message": "Pausad"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Anslutningsfel. Felkod: " "message": "Anslutningsfel. Felkod: "
}, },
"wantToSubmit": {
"message": "Vill du skicka in för video-ID"
},
"clearTimes": { "clearTimes": {
"message": "Rensa segmenten" "message": "Rensa segmenten"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Ange användarnamn" "message": "Ange användarnamn"
}, },
"copyPublicID": {
"message": "Kopiera publikt Användar-ID"
},
"discordAdvert": { "discordAdvert": {
"message": "Gå med i den officiella discordservern för att ge förslag och feedback!" "message": "Gå med i den officiella discordservern för att ge förslag och feedback!"
}, },
@@ -299,9 +302,15 @@
"skip": { "skip": {
"message": "Hoppa över" "message": "Hoppa över"
}, },
"mute": {
"message": "Ljudlös"
},
"skip_category": { "skip_category": {
"message": "Hoppa över {0}?" "message": "Hoppa över {0}?"
}, },
"mute_category": {
"message": "Gör {0} ljudlös?"
},
"skip_to_category": { "skip_to_category": {
"message": "Hoppa till {0}?", "message": "Hoppa till {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -310,6 +319,10 @@
"message": "{0} överhoppad", "message": "{0} överhoppad",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} ljudlös",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Hoppat till {0}", "message": "Hoppat till {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -363,7 +376,7 @@
"message": "Importera/Exportera Ditt AnvändarID" "message": "Importera/Exportera Ditt AnvändarID"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Denna ska hållas privat. Den fungerar som ett lösenord och ska inte delas med någon. Om någon får tag i den kan de utge sig för att vara dig." "message": "Detta ska hållas privat. Detta är som ett lösenord och ska inte delas med någon. Om andra får tag i det kan de utge sig för att vara dig. Om du letar efter ditt offentliga Användar-ID kan du klicka på urklippsikonen i popupen."
}, },
"setUserID": { "setUserID": {
"message": "Ange AnvändarID" "message": "Ange AnvändarID"
@@ -601,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Hoppa över alla segment automatiskt när det finns ett icke-musiksegment" "message": "Hoppa över alla segment automatiskt när det finns ett icke-musiksegment"
}, },
"muteSegments": {
"message": "Tillåt segment som tystar ljudet i stället för att hoppa över"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Din färg är felaktigt formaterad. Det ska vara en 3- eller 6-siffrig hex-kod med en siffra i början." "message": "Din färg är felaktigt formaterad. Det ska vara en 3- eller 6-siffrig hex-kod med en siffra i början."
}, },
@@ -640,6 +656,9 @@
"message": "För att skicka segment med kategorin \"{0}\" måste du först aktivera det i alternativen. Du kommer nu att bli omdirigerad till alternativen.", "message": "För att skicka segment med kategorin \"{0}\" måste du först aktivera det i alternativen. Du kommer nu att bli omdirigerad till alternativen.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Varning: Denna typ av segment kan endast ha ett segment aktivt åt gången. Skickas flera segment kommer en av dem att visas slumpmässigt."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Du måste välja en kategori för alla segment du skickar in!" "message": "Du måste välja en kategori för alla segment du skickar in!"
}, },
@@ -723,7 +742,7 @@
"message": "Dölj för alltid" "message": "Dölj för alltid"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Du har fått en tillfällig varning och kan inte skicka in segment. Detta innebär att vi har upptäckt att några vanliga misstag är gjorda som inte är uppsåtliga och vi vill bara klargöra reglerna. Du kan också gå med i den här chatten genom att använda discord.gg/SponsorBlock eller matrix.to/#/+sponsor:ajay.app" "message": "Du har fått en tillfällig varning och kan inte skicka in segment. Detta innebär att vi har upptäckt att några vanliga misstag är gjorda som inte är uppsåtliga och vi vill bara klargöra reglerna. Du kan också gå med i den här chatten genom att använda discord.gg/SponsorBlock eller matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Rösten avvisades på grund av en varning. Klicka för att öppna ett chattfönster för att lösa problemet eller kom tillbaka senare när du har tid.", "message": "Rösten avvisades på grund av en varning. Klicka för att öppna ett chattfönster för att lösa problemet eller kom tillbaka senare när du har tid.",

View File

@@ -94,9 +94,6 @@
"connectionError": { "connectionError": {
"message": "இணைப்பு பிழை ஏற்பட்டது. பிழை குறியீடு: " "message": "இணைப்பு பிழை ஏற்பட்டது. பிழை குறியீடு: "
}, },
"wantToSubmit": {
"message": "வீடியோ ஐடிக்கு நீங்கள் சமர்ப்பிக்க விரும்புகிறீர்களா"
},
"clearTimes": { "clearTimes": {
"message": "பிரிவுகளை அழிக்கவும்" "message": "பிரிவுகளை அழிக்கவும்"
}, },
@@ -320,9 +317,6 @@
"changeUserID": { "changeUserID": {
"message": "உங்கள் பயனர் ஐடியை இறக்குமதி / ஏற்றுமதி செய்யுங்கள்" "message": "உங்கள் பயனர் ஐடியை இறக்குமதி / ஏற்றுமதி செய்யுங்கள்"
}, },
"whatChangeUserID": {
"message": "இதை தனிப்பட்ட முறையில் வைத்திருக்க வேண்டும். இது கடவுச்சொல் போன்றது மற்றும் யாருடனும் பகிரக்கூடாது. யாராவது இதை வைத்திருந்தால், அவர்கள் உங்களைப் போல ஆள்மாறாட்டம் செய்யலாம்."
},
"setUserID": { "setUserID": {
"message": "UserID ஐ அமைக்கவும்" "message": "UserID ஐ அமைக்கவும்"
}, },

View File

@@ -94,9 +94,6 @@
"connectionError": { "connectionError": {
"message": "కనెక్షన్ లోపం సంభవించింది. లోపం కోడ్: " "message": "కనెక్షన్ లోపం సంభవించింది. లోపం కోడ్: "
}, },
"wantToSubmit": {
"message": "మీరు వీడియో ఐడి కోసం సమర్పించాలనుకుంటున్నారా"
},
"clearTimes": { "clearTimes": {
"message": "విభాగాలను క్లియర్ చేయండి" "message": "విభాగాలను క్లియర్ చేయండి"
}, },
@@ -320,9 +317,6 @@
"changeUserID": { "changeUserID": {
"message": "మీ యూజర్‌ఐడిని దిగుమతి / ఎగుమతి చేయండి" "message": "మీ యూజర్‌ఐడిని దిగుమతి / ఎగుమతి చేయండి"
}, },
"whatChangeUserID": {
"message": "దీన్ని ప్రైవేట్‌గా ఉంచాలి. ఇది పాస్‌వర్డ్ లాంటిది మరియు ఎవరితోనూ భాగస్వామ్యం చేయకూడదు. ఎవరైనా దీన్ని కలిగి ఉంటే, వారు మిమ్మల్ని వంచించగలరు."
},
"setUserID": { "setUserID": {
"message": "UserID ని సెట్ చేయండి" "message": "UserID ని సెట్ చేయండి"
}, },

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Tekrar atla" "message": "Tekrar atla"
}, },
"unmute": {
"message": "Sesi Aç"
},
"paused": { "paused": {
"message": "Duraklatıldı" "message": "Duraklatıldı"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Bağlantı hatası oluştu. Hata kodu: " "message": "Bağlantı hatası oluştu. Hata kodu: "
}, },
"wantToSubmit": {
"message": "Bu video kimliği için göndermek istiyor musun"
},
"clearTimes": { "clearTimes": {
"message": "Kısımları temizle" "message": "Kısımları temizle"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Kullanıcı Adı Belirle" "message": "Kullanıcı Adı Belirle"
}, },
"copyPublicID": {
"message": "Herkese Açık Kullanıcı Kimliğini Kopyala"
},
"discordAdvert": { "discordAdvert": {
"message": "Öneri ve geri bildirimleriniz için resmi Discord serverımıza katılın!" "message": "Öneri ve geri bildirimleriniz için resmi Discord serverımıza katılın!"
}, },
@@ -227,6 +230,15 @@
"showSkipNotice": { "showSkipNotice": {
"message": "Bir Kısmı Atladıktan Sonra Uyarı Göster" "message": "Bir Kısmı Atladıktan Sonra Uyarı Göster"
}, },
"noticeVisibilityMode0": {
"message": "Tam Boyutlu Atlama Bildirimleri"
},
"noticeVisibilityMode1": {
"message": "Otomatik Atlama için Küçük Atlama Bildirimleri"
},
"noticeVisibilityMode2": {
"message": "Tüm Küçük Atlama Bildirimleri"
},
"longDescription": { "longDescription": {
"message": "SponsorBlock, sponsorları, giriş ve bitiş kısımlarını, abonelik hatırlatıcılarını ve YouTube videolarının diğer can sıkıcı kısımlarını atlamanıza olanak tanır. SponsorBlock, herkesin sponsorlu kısımları ve YouTube videolarının diğer kısımlarının başlangıç ve bitiş zamanlarını göndermesine izin veren kitle kaynaklı bir tarayıcı uzantısıdır. Bir kişi bu bilgiyi gönderdikten sonra, bu uzantıya sahip diğer herkes sponsorlu kısımları hemen atlayacaktır. Müzik videolarının müzik dışı bölümlerini de atlayabilirsiniz.", "message": "SponsorBlock, sponsorları, giriş ve bitiş kısımlarını, abonelik hatırlatıcılarını ve YouTube videolarının diğer can sıkıcı kısımlarını atlamanıza olanak tanır. SponsorBlock, herkesin sponsorlu kısımları ve YouTube videolarının diğer kısımlarının başlangıç ve bitiş zamanlarını göndermesine izin veren kitle kaynaklı bir tarayıcı uzantısıdır. Bir kişi bu bilgiyi gönderdikten sonra, bu uzantıya sahip diğer herkes sponsorlu kısımları hemen atlayacaktır. Müzik videolarının müzik dışı bölümlerini de atlayabilirsiniz.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
@@ -284,6 +296,9 @@
"skip": { "skip": {
"message": "Atla" "message": "Atla"
}, },
"mute": {
"message": "Sustur"
},
"skip_category": { "skip_category": {
"message": "{0} atla?" "message": "{0} atla?"
}, },
@@ -348,7 +363,7 @@
"message": "Kullanıcı kimliğini Dışarı/İçeri Aktar" "message": "Kullanıcı kimliğini Dışarı/İçeri Aktar"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Bu gizli tutulmalıdır. Bu bir şifreye benzer ve diğerleriyle paylaşılmaması gerekir. Birinin eline geçerse, sizi taklit edebilir." "message": "Bu gizli tutulmalıdır. Bu bir şifre gibidir ve kimseyle paylaşılmamalıdır. Eğer birisi buna sahipse, seni taklit edebilir. Herkese açık kullanıcı kimliğinizi arıyorsanız, açılır pencerede pano simgesine tıklayın."
}, },
"setUserID": { "setUserID": {
"message": "Kullanıcı kimliği Belirle" "message": "Kullanıcı kimliği Belirle"
@@ -550,6 +565,12 @@
"category_music_offtopic_short": { "category_music_offtopic_short": {
"message": "Müzik Olmayan Bölüm" "message": "Müzik Olmayan Bölüm"
}, },
"category_poi_highlight": {
"message": "Vurgu"
},
"category_poi_highlight_description": {
"message": "Videoda, çoğu insanın aradığı kısım. \"Video x sürede başlıyor\" yorumlarına benzer."
},
"category_livestream_messages": { "category_livestream_messages": {
"message": "Canlı Yayın: Bağış/Mesaj Okuma" "message": "Canlı Yayın: Bağış/Mesaj Okuma"
}, },
@@ -580,6 +601,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Müzik olmayan kısım varsa tüm kısımları otomatik atla" "message": "Müzik olmayan kısım varsa tüm kısımları otomatik atla"
}, },
"muteSegments": {
"message": "Atlamak yerine sesi kapatan bölümlere izin ver"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Renginiz yanlış biçimlendirilmiştir. Başında bir kare işareti bulunan 3 veya 6 basamaklı bir onaltılık kod olmalıdır." "message": "Renginiz yanlış biçimlendirilmiştir. Başında bir kare işareti bulunan 3 veya 6 basamaklı bir onaltılık kod olmalıdır."
}, },
@@ -690,6 +714,10 @@
"help": { "help": {
"message": "Yardım" "message": "Yardım"
}, },
"GotIt": {
"message": "Anladım",
"description": "Used as the button to dismiss a tooltip"
},
"experiementOptOut": { "experiementOptOut": {
"message": "Gelecekteki deneylerin hiçbirine katılma", "message": "Gelecekteki deneylerin hiçbirine katılma",
"description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private." "description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private."
@@ -698,10 +726,28 @@
"message": "Asla gösterme" "message": "Asla gösterme"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Bir uyarı aldınız ve geçici bir süreliğine kısım gönderemeyeceksiniz. Sizin kısım göndermede zararlı olmayan bazı hatalar yaptığınızı belirledik ve size kurallarııklamak istiyoruz. Bu sohbete discord.gg/SponsorBlock veya matrix.to/#/+sponsor:ajay.app üzerinden de katılabilirsiniz" "message": "Bir uyarı aldınız ve geçici bir süreliğine kısım gönderemeyeceksiniz. Sizin kısım göndermede zararlı olmayan bazı hatalar yaptığınızı belirledik ve size kurallarııklamak istiyoruz. Bu sohbete discord.gg/SponsorBlock veya matrix.to/#/#sponsor:ajay.app üzerinden de katılabilirsiniz"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Bir uyarı nedeniyle oy reddedildi. Çözüm bulmak için buraya tıklayarak bir sohbet açın veya daha sonra vaktiniz olduğunda uğrayın.", "message": "Bir uyarı nedeniyle oy reddedildi. Çözüm bulmak için buraya tıklayarak bir sohbet açın veya daha sonra vaktiniz olduğunda uğrayın.",
"description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser." "description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser."
},
"Donate": {
"message": "Bağış Yap"
},
"hideDonationLink": {
"message": "Bağış Bağlantısını Gizle"
},
"helpPageThanksForInstalling": {
"message": "SponsorBlock'u yüklediğiniz için teşekkürler."
},
"helpPageReviewOptions": {
"message": "Lütfen aşağıdaki seçenekleri inceleyin"
},
"helpPageFeatureDisclaimer": {
"message": "Birçok özellik varsayılan olarak devre dışıdır. İntroları, outroları atlamak vb. kullanmak istiyorsanız, bunları aşağıdan etkinleştirin. Ayrıca arayüz öğelerini gizleyebilir/gösterebilirsiniz."
},
"helpPageHowSkippingWorks": {
"message": "Atlama nasıl çalışıyor"
} }
} }

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Пропустити" "message": "Пропустити"
}, },
"unmute": {
"message": "Увімкнути звук"
},
"paused": { "paused": {
"message": "Пауза" "message": "Пауза"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Помилка з'єднання. Код помилки: " "message": "Помилка з'єднання. Код помилки: "
}, },
"wantToSubmit": {
"message": "Ви хочете надіслати сегменти для відео з id"
},
"clearTimes": { "clearTimes": {
"message": "Очистити сегменти" "message": "Очистити сегменти"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Встановити ім'я користувача" "message": "Встановити ім'я користувача"
}, },
"copyPublicID": {
"message": "Копіювати публічний UserID"
},
"discordAdvert": { "discordAdvert": {
"message": "Приєднуйтесь до офіційного сервера Discord, щоб залишити пропозиції і зворотний зв'язок!" "message": "Приєднуйтесь до офіційного сервера Discord, щоб залишити пропозиції і зворотний зв'язок!"
}, },
@@ -227,6 +230,21 @@
"showSkipNotice": { "showSkipNotice": {
"message": "Показувати сповіщення після пропуску сегмента" "message": "Показувати сповіщення після пропуску сегмента"
}, },
"noticeVisibilityMode0": {
"message": "Повнорозмірні сповіщення про пропуски"
},
"noticeVisibilityMode1": {
"message": "Зменшені сповіщення для автоматичних пропусків"
},
"noticeVisibilityMode2": {
"message": "Всі сповіщення зменшеного розміру"
},
"noticeVisibilityMode3": {
"message": "Напівпрозорі сповіщення для автоматичних пропусків"
},
"noticeVisibilityMode4": {
"message": "Напівпрозорі сповіщення для всіх пропусків"
},
"longDescription": { "longDescription": {
"message": "SponsorBlock дозволяє пропускати спонсорські вставки, початкові і кінцеві заставки, прохання підписатися і інше в відео на YouTube. SponsorBlock - колективне розширення, яке дозволяє кожному надіслати час початку і кінця подібних сегментів в відео. Після того, як хто-небудь надсилає цю інформацію, всі інші користувачі розширення будуть автоматично пропускати ці сегменти. Так само можна пропускати частини кліпів без музики.", "message": "SponsorBlock дозволяє пропускати спонсорські вставки, початкові і кінцеві заставки, прохання підписатися і інше в відео на YouTube. SponsorBlock - колективне розширення, яке дозволяє кожному надіслати час початку і кінця подібних сегментів в відео. Після того, як хто-небудь надсилає цю інформацію, всі інші користувачі розширення будуть автоматично пропускати ці сегменти. Так само можна пропускати частини кліпів без музики.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
@@ -284,9 +302,15 @@
"skip": { "skip": {
"message": "Пропустити" "message": "Пропустити"
}, },
"mute": {
"message": "Вимкнути звук"
},
"skip_category": { "skip_category": {
"message": "Пропустити {0}?" "message": "Пропустити {0}?"
}, },
"mute_category": {
"message": "Вимкнути звук {0}?"
},
"skip_to_category": { "skip_to_category": {
"message": "Пропустить до {0}?", "message": "Пропустить до {0}?",
"description": "Used for skipping to things (Skip to Highlight)" "description": "Used for skipping to things (Skip to Highlight)"
@@ -295,6 +319,10 @@
"message": "{0} Пропущено", "message": "{0} Пропущено",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
}, },
"muted": {
"message": "{0} Вимкнений звук",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": { "skipped_to_category": {
"message": "Пропущено до {0}", "message": "Пропущено до {0}",
"description": "Used for skipping to things (Skipped to Highlight)" "description": "Used for skipping to things (Skipped to Highlight)"
@@ -348,7 +376,7 @@
"message": "Імпортувати/Експортувати Ваш ідентифікатор користувача" "message": "Імпортувати/Експортувати Ваш ідентифікатор користувача"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Це потрібно тримати в секреті. Це як пароль, не варто ним ні з ким ділитися. Якщо він у кого-то є, він зможе видати себе за Вас." "message": "Тримайте його в таємниці. Ставтеся до нього як до паролю і не передавайте нікому. Якщо хтось їм заволодіє, то зможе видати себе за вас. Якщо ви шукаєте публічний ID користувача, натисніть значок буфера обміну у спливаючому вікні."
}, },
"setUserID": { "setUserID": {
"message": "Встановити ідентифікатор користувача" "message": "Встановити ідентифікатор користувача"
@@ -551,7 +579,7 @@
"message": "Без музики" "message": "Без музики"
}, },
"category_poi_highlight": { "category_poi_highlight": {
"message": "Основные" "message": "Основне"
}, },
"category_poi_highlight_description": { "category_poi_highlight_description": {
"message": "Часть видео, которую ищут большинство людей. Аналогично комментарию «Видео начинается с X:XX»." "message": "Часть видео, которую ищут большинство людей. Аналогично комментарию «Видео начинается с X:XX»."
@@ -586,6 +614,9 @@
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Автоматично пропустити усі сегменти, якщо присутній сегмент без музики" "message": "Автоматично пропустити усі сегменти, якщо присутній сегмент без музики"
}, },
"muteSegments": {
"message": "Дозволити сегменти, які відключають звук замість пропуску"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Ви ввели колір в неправильному форматі. Це повинно бути 3-х або 6-ти значне шістнадцяткове число з символом # на початку." "message": "Ви ввели колір в неправильному форматі. Це повинно бути 3-х або 6-ти значне шістнадцяткове число з символом # на початку."
}, },
@@ -625,6 +656,9 @@
"message": "Щоб надіслати сегменти категорії \"{0}\", ви повинні включити її в налаштуваннях. Зараз ви будете туди перенаправлені.", "message": "Щоб надіслати сегменти категорії \"{0}\", ви повинні включити її в налаштуваннях. Зараз ви будете туди перенаправлені.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Увага: Сегменти даного типу можуть бути активними лише по одному. Надсилання декількох призведе до відображення випадкового сегмента."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Ви повинні обрати категорію для всіх сегментів, які ви відправляєте!" "message": "Ви повинні обрати категорію для всіх сегментів, які ви відправляєте!"
}, },
@@ -696,6 +730,10 @@
"help": { "help": {
"message": "Довідка" "message": "Довідка"
}, },
"GotIt": {
"message": "Зрозуміло",
"description": "Used as the button to dismiss a tooltip"
},
"experiementOptOut": { "experiementOptOut": {
"message": "Відмова від усіх майбутніх експериментів", "message": "Відмова від усіх майбутніх експериментів",
"description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private." "description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private."
@@ -704,10 +742,79 @@
"message": "Сховати назавжди" "message": "Сховати назавжди"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Ви отримали попередження, тому тимчасово не можете обирати сегменти. Це означає, що ми помітили, що ви робили кілька поширених помилок, які не є злісними. Тому ми хочемо нагадати вам правила. Ви можете приєднатися до чату з правилами використовуючи discord.gg/SponsorBlock або matrix.to/#/+sponsor:ajay.app" "message": "Ви отримали попередження, тому тимчасово не можете обирати сегменти. Це означає, що ми помітили, що ви робили кілька поширених помилок, які не є злісними. Тому ми хочемо нагадати вам правила. Ви можете приєднатися до чату з правилами використовуючи discord.gg/SponsorBlock або matrix.to/#/#sponsor:ajay.app"
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Голосування відхилено через попередження. Натисніть, щоб відкрити чат для вирішення цієї проблеми, або поверніться пізніше.", "message": "Голосування відхилено через попередження. Натисніть, щоб відкрити чат для вирішення цієї проблеми, або поверніться пізніше.",
"description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser." "description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser."
},
"Donate": {
"message": "Пожертвувати"
},
"hideDonationLink": {
"message": "Приховати посилання на пожертвування"
},
"helpPageThanksForInstalling": {
"message": "Дякую за встановлення SponsorBlock."
},
"helpPageReviewOptions": {
"message": "Будь ласка, ознайомтеся з налаштуваннями нижче"
},
"helpPageFeatureDisclaimer": {
"message": "Багато функцій за замовчуванням відключені. Якщо ви хочете пропускати початкові і кінцеві заставки, використовувати Invidious, тощо, увімкніть їх нижче. Ви також можете приховати / показати елементи інтерфейсу."
},
"helpPageHowSkippingWorks": {
"message": "Як працює пропуск"
},
"helpPageHowSkippingWorks1": {
"message": "Сегменти відео будуть автоматично пропущені, якщо вони знаходяться в базі даних. Ви можете відкрити спливаюче вікно, натиснувши на значок розширення, щоб подивитися, які сегменти додані."
},
"helpPageHowSkippingWorks2": {
"message": "Коли ви будете пропускати сегмент, ви отримаєте сповіщення. Якщо час здасться вам неправильним, проголосуйте проти, натиснувши на палець вниз! Ви також можете проголосувати у спливаючому вікні."
},
"Submitting": {
"message": "Відправлення"
},
"helpPageSubmitting1": {
"message": "Відправлення може бути виконана у спливаючому вікні натисканням на кнопку \"Сегмент починається звідси\" або кнопками в відеоплеєрі."
},
"helpPageSubmitting2": {
"message": "Натискання на кнопку відтворення означає початок сегмента і натискання на кнопку стоп позначає його кінець. Ви можете позначити кілька сегментів перед тим, як натиснути на кнопку відправлення. Натискання на кошик видалить все."
},
"Editing": {
"message": "Редагування"
},
"helpPageEditing1": {
"message": "Якщо ви зробили щось не так, ви можете відредагувати або видалити сегменти, натиснувши на кнопку зі стрілкою вгору."
},
"helpPageTooSlow": {
"message": "Це занадто повільно"
},
"helpPageTooSlow1": {
"message": "Все це також можна робити за допомогою гарячих клавіш. Натисніть \"ж\" для вказівки початку/кінця сегмента, \"є\" для відправки. Клавіші можуть бути змінені в налаштуваннях. Якщо ви не використовуєте QWERTY, то варто відразу поміняти гарячі клавіші."
},
"helpPageCopyOfDatabase": {
"message": "Чи можу я отримати копію бази даних? Що якщо ви пропадете?"
},
"helpPageCopyOfDatabase1": {
"message": "База даних доступна для всіх тут:"
},
"helpPageCopyOfDatabase2": {
"message": "Вихідний код у відкритому доступі, так що навіть якщо щось трапиться зі мною, ваш вклад не пропаде."
},
"helpPageNews": {
"message": "Новини та як це зроблено"
},
"helpPageSourceCode": {
"message": "Де можна отримати вихідний код?"
},
"Credits": {
"message": "Автори"
},
"highlightNewFeature": {
"message": "Новинка! Переходьте відразу до головного моменту відео за допомогою нової категорії \"Важливе\""
},
"LearnMore": {
"message": "Дізнатися більше"
} }
} }

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "Bỏ qua lại" "message": "Bỏ qua lại"
}, },
"unmute": {
"message": "Bật tiếng"
},
"paused": { "paused": {
"message": "Tạm dừng" "message": "Tạm dừng"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "Đã xảy ra lỗi kết nối. Mã của lỗi: " "message": "Đã xảy ra lỗi kết nối. Mã của lỗi: "
}, },
"wantToSubmit": {
"message": "Bạn có muốn đăng đoạn quảng cáo cho video có mã id"
},
"clearTimes": { "clearTimes": {
"message": "Xóa đoạn quảng cáo" "message": "Xóa đoạn quảng cáo"
}, },
@@ -161,6 +161,9 @@
"setUsername": { "setUsername": {
"message": "Đặt tên người dùng" "message": "Đặt tên người dùng"
}, },
"copyPublicID": {
"message": "Sao chép Public UserID"
},
"discordAdvert": { "discordAdvert": {
"message": "Hãy tham gia server Discord chính thức để đăng gợi ý và phản hồi!" "message": "Hãy tham gia server Discord chính thức để đăng gợi ý và phản hồi!"
}, },
@@ -227,6 +230,21 @@
"showSkipNotice": { "showSkipNotice": {
"message": "Hiển thị thông báo sau khi bỏ qua quảng cáo" "message": "Hiển thị thông báo sau khi bỏ qua quảng cáo"
}, },
"noticeVisibilityMode0": {
"message": "Thông báo bỏ qua với kích thước đầy đủ"
},
"noticeVisibilityMode1": {
"message": "Thông báo bỏ qua kích thước nhỏ nếu phân đoạn được tự động bỏ qua"
},
"noticeVisibilityMode2": {
"message": "Thông báo bỏ qua kích thước nhỏ cho toàn bộ phân đoạn"
},
"noticeVisibilityMode3": {
"message": "Thông báo bỏ qua mờ nếu phân đoạn được tự động bỏ qua"
},
"noticeVisibilityMode4": {
"message": "Thông báo bỏ qua mờ cho tất cả các phân đoạn"
},
"longDescription": { "longDescription": {
"message": "SponsorBlock giúp bạn bỏ qua quảng cáo từ nhà tài trợ, đoạn giới thiệu, đoạn kết, lời nhắc đăng ký kênh, và những phần khó chịu khác trong các video Youtube. SponsorBlock là một tiện ích mở rộng cho trình duyệt, cho phép tất cả người dùng đăng thời điểm bắt đầu và kết thúc của những đoạn quảng cáo từ nhà tài trợ và các đoạn khác trong video Youtube. Sau khi một người đăng thông tin này lên, tất cả mọi người dùng tiện ích mở rộng này sẽ bỏ qua đoạn quảng cáo đó. Bạn cũng có thể bỏ qua phần không có nhạc trong những video âm nhạc.", "message": "SponsorBlock giúp bạn bỏ qua quảng cáo từ nhà tài trợ, đoạn giới thiệu, đoạn kết, lời nhắc đăng ký kênh, và những phần khó chịu khác trong các video Youtube. SponsorBlock là một tiện ích mở rộng cho trình duyệt, cho phép tất cả người dùng đăng thời điểm bắt đầu và kết thúc của những đoạn quảng cáo từ nhà tài trợ và các đoạn khác trong video Youtube. Sau khi một người đăng thông tin này lên, tất cả mọi người dùng tiện ích mở rộng này sẽ bỏ qua đoạn quảng cáo đó. Bạn cũng có thể bỏ qua phần không có nhạc trong những video âm nhạc.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
@@ -284,6 +302,9 @@
"skip": { "skip": {
"message": "Bỏ qua" "message": "Bỏ qua"
}, },
"mute": {
"message": "Ngắt tiếng"
},
"skip_category": { "skip_category": {
"message": "Bỏ qua {0}?" "message": "Bỏ qua {0}?"
}, },
@@ -336,7 +357,7 @@
"message": "Nhập/Xuất mã người dùng của bạn" "message": "Nhập/Xuất mã người dùng của bạn"
}, },
"whatChangeUserID": { "whatChangeUserID": {
"message": "Bạn nên giữ bí mật mã này. Nó như mật khẩu vậy, do đó không nên chia sẻ với người khác. Nếu ai đó có mã này, họ có thể giả mạo bạn." "message": "Đây là mã cần được giữ bí mật. Nó giống như mật khẩu và không nên được chia sẻ cho bất kì ai khác. Nếu ai đó lấy được mã này, họ có thể mạo danh bạn. Còn nếu như bạn đang tìm khoá ID công khai, hãy nhấn vào nút \"Sao chép Public ID\" trong popup của SponsorBlock."
}, },
"setUserID": { "setUserID": {
"message": "Đặt mã người dùng" "message": "Đặt mã người dùng"
@@ -538,6 +559,12 @@
"category_music_offtopic_short": { "category_music_offtopic_short": {
"message": "Không có nhạc" "message": "Không có nhạc"
}, },
"category_poi_highlight": {
"message": "Điểm/Khoảnh khắc quan trọng"
},
"category_poi_highlight_description": {
"message": "Phần của video mà hầu hết mọi người đang tìm kiếm. Tương tự với câu nói \"Video bắt đầu từ x\"."
},
"category_livestream_messages": { "category_livestream_messages": {
"message": "Luồng phát trực tiếp: Đọc Quyên góp/Tin nhắn" "message": "Luồng phát trực tiếp: Đọc Quyên góp/Tin nhắn"
}, },
@@ -556,9 +583,21 @@
"disable": { "disable": {
"message": "Tắt" "message": "Tắt"
}, },
"autoSkip_POI": {
"message": "Tự động bỏ qua"
},
"manualSkip_POI": {
"message": "Hỏi khi video bắt đầu"
},
"showOverlay_POI": {
"message": "Hiện ở thanh xem trước"
},
"autoSkipOnMusicVideos": { "autoSkipOnMusicVideos": {
"message": "Tự động bỏ qua tất cả các phân đoạn nếu trong video có phân đoạn không phải nhạc" "message": "Tự động bỏ qua tất cả các phân đoạn nếu trong video có phân đoạn không phải nhạc"
}, },
"muteSegments": {
"message": "Cho phép các phân đoạn bị tắt tiếng hay vì bỏ qua"
},
"colorFormatIncorrect": { "colorFormatIncorrect": {
"message": "Mã màu sai định dạng. Mã màu phải có 3 hoặc 6 ký tự hệ hex và có dấu thăng ở đầu." "message": "Mã màu sai định dạng. Mã màu phải có 3 hoặc 6 ký tự hệ hex và có dấu thăng ở đầu."
}, },
@@ -598,6 +637,9 @@
"message": "Để gửi một phân đoạn với chủ đề \"{0}\", bạn cần phải kích hoạt nó trong phần tuỳ chọn. Bạn sẽ được đưa đến phần tuỳ chỉnh bây giờ.", "message": "Để gửi một phân đoạn với chủ đề \"{0}\", bạn cần phải kích hoạt nó trong phần tuỳ chọn. Bạn sẽ được đưa đến phần tuỳ chỉnh bây giờ.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options." "description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
}, },
"poiOnlyOneSegment": {
"message": "Cảnh báo: Loại phân đoạn này nếu hiển thị CHỈ CÓ 1 PHÂN ĐOẠN được xuất hiện trong video. Nếu bạn gửi lên, khi đó, phân đoạn xuất hiện duy nhất sẽ được lựa chọn ngẫu nhiên."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Bạn phải lựa chọn một danh mục cho tất cả phân đoạn bạn đang muốn đăng tải!" "message": "Bạn phải lựa chọn một danh mục cho tất cả phân đoạn bạn đang muốn đăng tải!"
}, },
@@ -669,6 +711,10 @@
"help": { "help": {
"message": "Trợ giúp" "message": "Trợ giúp"
}, },
"GotIt": {
"message": "Đã hiểu",
"description": "Used as the button to dismiss a tooltip"
},
"experiementOptOut": { "experiementOptOut": {
"message": "Từ chối tham gia thử nghiệm trong tương lai", "message": "Từ chối tham gia thử nghiệm trong tương lai",
"description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private." "description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private."
@@ -677,10 +723,37 @@
"message": "Ẩn vĩnh viễn" "message": "Ẩn vĩnh viễn"
}, },
"warningChatInfo": { "warningChatInfo": {
"message": "Bạn đã nhận được một cảnh báo (Warring) và tạm thời không thể gửi các phân đoạn. Bạn đã mắc lỗi trong việc tạo quá nhiều lần (có thể là chọn sai kiểu phân đoạn hoặc sai thời gian phân đoạn). Chúng tôi muốn bạn nhận ra điều đó để có thể giúp bạn khắc phục điều này trong tương lai, không mắc lỗi nữa. Bạn có thể gặp các VIP User tại đây: discord.gg/SponsorBlock hoặc matrix.to/#/+sponsor:ajay.app. Bọn họ sẽ giúp bạn gỡ cảnh báo sau khi bạn đã hiểu ra lỗi sai của bạn." "message": "Bạn đã nhận được một cảnh báo (Warring) và tạm thời không thể gửi các phân đoạn. Bạn đã mắc lỗi trong việc tạo quá nhiều lần (có thể là chọn sai kiểu phân đoạn hoặc sai thời gian phân đoạn). Chúng tôi muốn bạn nhận ra điều đó để có thể giúp bạn khắc phục điều này trong tương lai, không mắc lỗi nữa. Bạn có thể gặp các VIP User tại đây: discord.gg/SponsorBlock hoặc matrix.to/#/#sponsor:ajay.app. Bọn họ sẽ giúp bạn gỡ cảnh báo sau khi bạn đã hiểu ra lỗi sai của bạn."
}, },
"voteRejectedWarning": { "voteRejectedWarning": {
"message": "Bỏ phiếu bị từ chối do có cảnh báo. Nhấp để mở cuộc trò chuyện để giải quyết hoặc quay lại sau.", "message": "Bỏ phiếu bị từ chối do có cảnh báo. Nhấp để mở cuộc trò chuyện để giải quyết hoặc quay lại sau.",
"description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser." "description": "This is an integrated chat panel that will appearing allowing them to talk to the Discord/Matrix chat without leaving their browser."
},
"Donate": {
"message": "Donate"
},
"hideDonationLink": {
"message": "Ẩn link donate"
},
"helpPageThanksForInstalling": {
"message": "Cảm ơn bạn đã cài đặt SponsorBlock."
},
"helpPageReviewOptions": {
"message": "Xin hãy xem xét các tuỳ chọn bên dưới"
},
"helpPageFeatureDisclaimer": {
"message": "Nhiều tính năng sẽ bị tắt theo mặc định. Nếu bạn muốn bỏ qua phần intro, sử dụng trên các trang web bên thứ 3 như Invidious, v. v...., bạn có thể bật nó ở bên dưới. Bạn cũng có thể cho hiện/ẩn UI người dùng."
},
"helpPageHowSkippingWorks": {
"message": "Việc bỏ qua 1 đoạn trong video được thực hiện thế nào?"
},
"helpPageHowSkippingWorks1": {
"message": "Các phân đoạn trong video sẽ tự động bị bỏ qua nếu chúng được tìm thấy trong cơ sở dữ liệu của chúng tôi. Bạn có thể mở cửa sổ xem trước các phân đoạn ấy bằng cách nhấp vào biểu tượng tiện ích mở rộng."
},
"helpPageHowSkippingWorks2": {
"message": "Bất cứ khi nào bỏ qua một phân đoạn, bạn sẽ nhận được 1 cửa sổ thông báo bât. Nếu phân đoạn có vẻ sai, hãy bỏ phiếu bằng cách nhấp vào nút downvote! Bạn cũng có thể bỏ phiếu trong cửa sổ bật lên khi nhấn vào biểu tượng tiện ích mở rộng. Và bạn có thể tắt việc hiển thị bảng thông báo này trong phần cài đặt tiện ích."
},
"helpPageTooSlow": {
"message": "Quá chậm"
} }
} }

View File

@@ -97,9 +97,6 @@
"connectionError": { "connectionError": {
"message": "连接错误。错误代码: " "message": "连接错误。错误代码: "
}, },
"wantToSubmit": {
"message": "您是否想为以下视频 ID 提交:"
},
"clearTimes": { "clearTimes": {
"message": "清除片段" "message": "清除片段"
}, },
@@ -323,9 +320,6 @@
"changeUserID": { "changeUserID": {
"message": "导入/导出您的用户 ID" "message": "导入/导出您的用户 ID"
}, },
"whatChangeUserID": {
"message": "这应该被保密。这就像一个密码,且不应该告诉任何人。如果有人拥有它,他就可以冒充您。"
},
"setUserID": { "setUserID": {
"message": "设定用户 ID" "message": "设定用户 ID"
}, },

View File

@@ -52,6 +52,9 @@
"reskip": { "reskip": {
"message": "繼續跳過" "message": "繼續跳過"
}, },
"unmute": {
"message": "解除靜音"
},
"paused": { "paused": {
"message": "已暫停" "message": "已暫停"
}, },
@@ -100,9 +103,6 @@
"connectionError": { "connectionError": {
"message": "已發生連線錯誤。錯誤碼: " "message": "已發生連線錯誤。錯誤碼: "
}, },
"wantToSubmit": {
"message": "您想為這個影片ID提交嗎"
},
"clearTimes": { "clearTimes": {
"message": "清除片段" "message": "清除片段"
}, },
@@ -335,9 +335,6 @@
"changeUserID": { "changeUserID": {
"message": "匯入/匯出您的使用者 ID" "message": "匯入/匯出您的使用者 ID"
}, },
"whatChangeUserID": {
"message": "這應該被保密。這就像一個密碼,不應該與他人分享。如果有人擁有它,他們就可以冒充您。"
},
"setUserID": { "setUserID": {
"message": "設定使用者 ID" "message": "設定使用者 ID"
}, },
@@ -535,6 +532,9 @@
"category_music_offtopic_short": { "category_music_offtopic_short": {
"message": "非音樂" "message": "非音樂"
}, },
"category_poi_highlight": {
"message": "重點"
},
"category_livestream_messages": { "category_livestream_messages": {
"message": "直播:捐贈/訊息閱讀" "message": "直播:捐贈/訊息閱讀"
}, },
@@ -666,11 +666,18 @@
"help": { "help": {
"message": "說明" "message": "說明"
}, },
"GotIt": {
"message": "知道了",
"description": "Used as the button to dismiss a tooltip"
},
"experiementOptOut": { "experiementOptOut": {
"message": "關閉所有未來的實驗性功能", "message": "關閉所有未來的實驗性功能",
"description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private." "description": "This is used in a popup about a new experiment to get a list of unlisted videos to back up since all unlisted videos uploaded before 2017 will be set to private."
}, },
"hideForever": { "hideForever": {
"message": "永久隱藏" "message": "永久隱藏"
},
"Credits": {
"message": "致謝"
} }
} }

View File

@@ -154,11 +154,13 @@
} }
.sponsorSkipNotice { .sponsorSkipNotice {
min-width: calc(100% - 50px);
transition: all 0.1s ease-out; transition: all 0.1s ease-out;
} }
.sponsorSkipNoticeLimitWidth {
min-width: calc(100% - 50px);
}
.sponsorSkipNotice .hidden { .sponsorSkipNotice .hidden {
display: none; display: none;
} }
@@ -470,7 +472,7 @@ input::-webkit-inner-spin-button {
text-decoration: underline; text-decoration: underline;
} }
.sponsorTimeCategories { .sponsorTimeEditSelector {
margin-top: 5px; margin-top: 5px;
margin-bottom: 5px; margin-bottom: 5px;

View File

@@ -30,7 +30,7 @@
</p> </p>
<p> <p>
Come contribute, make some suggestions and help out on <a href="https://discord.gg/QnmVMpU">Discord</a> or on <a href="https://matrix.to/#/#sponsor:ajay.app?via=ajay.app&via=matrix.org&via=mozilla.org">Matrix</a>. Come contribute, make some suggestions and help out on <a href="https://discord.gg/SponsorBlock">Discord</a> or on <a href="https://matrix.to/#/#sponsor:ajay.app?via=ajay.app&via=matrix.org&via=mozilla.org">Matrix</a>.
</p> </p>
<p style="margin-bottom: 0; margin-top: 0" class="bigText center">__MSG_helpPageReviewOptions__</p> <p style="margin-bottom: 0; margin-top: 0" class="bigText center">__MSG_helpPageReviewOptions__</p>
@@ -119,7 +119,7 @@
<a href="https://github.com/ajayyy/SponsorBlockServer/graphs/contributors">SponsorBlockServer contributors</a> and <a href="https://github.com/ajayyy/SponsorBlockServer/graphs/contributors">SponsorBlockServer contributors</a> and
<a href="https://github.com/ajayyy/SponsorBlockSite/graphs/contributors">SponsorBlockSite contributors</a> such <a href="https://github.com/ajayyy/SponsorBlockSite/graphs/contributors">SponsorBlockSite contributors</a> such
as <a href="https://github.com/NDevTK">NDev</a>, <a href="https://github.com/Joe-Dowd">Joe Dowd</a>, as <a href="https://github.com/NDevTK">NDev</a>, <a href="https://github.com/Joe-Dowd">Joe Dowd</a>,
<a href="https://github.com/bershanskiy">Anton Bershanskiy</a> and more. <a href="https://mchang.name/">Michael Chang</a> and more.
</p> </p>
<p>The awesome <a href="https://github.com/omarroth/invidious/wiki/API">Invidious API</a> is used to grab the time the video was published.</p> <p>The awesome <a href="https://github.com/omarroth/invidious/wiki/API">Invidious API</a> is used to grab the time the video was published.</p>

View File

@@ -50,6 +50,22 @@
<br/> <br/>
</div> </div>
<div option-type="toggle" sync-option="muteSegments">
<label class="switch-container">
<label class="switch">
<input type="checkbox" checked>
<span class="slider round"></span>
</label>
<div class="switch-label">
__MSG_muteSegments__
</div>
</label>
<br/>
<br/>
<br/>
</div>
<br/> <br/>
<br/> <br/>

View File

@@ -275,6 +275,10 @@ background-color:#ec1c1c;
cursor: pointer; cursor: pointer;
} }
button#setUsernameButton {
flex: 0 1;
}
#submitUsername { #submitUsername {
padding-left: 5pt; padding-left: 5pt;
} }
@@ -285,6 +289,7 @@ background-color:#ec1c1c;
#usernameValue, #usernameInput, #sponsorTimesContributionsDisplay{ #usernameValue, #usernameInput, #sponsorTimesContributionsDisplay{
font-size: 16px; font-size: 16px;
flex: 1 0;
} }
.SBWhitelistIcon { .SBWhitelistIcon {
@@ -343,6 +348,7 @@ label>p, #disableExtension>p, #usernameValue, #usernameElement > div > p,#sponso
#copyUserID { #copyUserID {
width: 100%; width: 100%;
flex: 0 1;
} }
#setUsernameContainer { #setUsernameContainer {

View File

@@ -142,7 +142,7 @@
<a href="https://sponsor.ajay.app/stats" target="_blank" rel="noopener">__MSG_viewLeaderboard__</a> | <a href="https://sponsor.ajay.app/stats" target="_blank" rel="noopener">__MSG_viewLeaderboard__</a> |
<a href="https://github.com/ajayyy/SponsorBlock" target="_blank" rel="noopener">GitHub</a> <a href="https://github.com/ajayyy/SponsorBlock" target="_blank" rel="noopener">GitHub</a>
<br/> <br/>
<a href="https://discord.gg/QnmVMpU" target="_blank" rel="noopener">Discord</a> | <a href="https://discord.gg/SponsorBlock" target="_blank" rel="noopener">Discord</a> |
<a href="https://matrix.to/#/#sponsor:ajay.app?via=ajay.app&via=matrix.org&via=mozilla.org" target="_blank" rel="noopener">Matrix</a> | <a href="https://matrix.to/#/#sponsor:ajay.app?via=ajay.app&via=matrix.org&via=mozilla.org" target="_blank" rel="noopener">Matrix</a> |
<a id="helpButton" style="cursor: pointer;">__MSG_help__</a> | <a id="helpButton" style="cursor: pointer;">__MSG_help__</a> |
<a href="https://sponsor.ajay.app/donate" target="_blank" rel="noopener" id="sbDonate">$</a> <a href="https://sponsor.ajay.app/donate" target="_blank" rel="noopener" id="sbDonate">$</a>

View File

@@ -25,6 +25,7 @@ export interface NoticeProps {
bottomRow?: React.ReactElement[], bottomRow?: React.ReactElement[],
smaller?: boolean, smaller?: boolean,
limitWidth?: boolean,
// Callback for when this is closed // Callback for when this is closed
closeListener: () => void, closeListener: () => void,
@@ -105,11 +106,13 @@ class NoticeComponent extends React.Component<NoticeProps, NoticeState> {
<div className={"sponsorSkipNoticeTableContainer" <div className={"sponsorSkipNoticeTableContainer"
+ (this.props.fadeIn ? " sponsorSkipNoticeFadeIn" : "") + (this.props.fadeIn ? " sponsorSkipNoticeFadeIn" : "")
+ (this.state.startFaded ? " sponsorSkipNoticeFaded" : "") }> + (this.state.startFaded ? " sponsorSkipNoticeFaded" : "") }>
<table className="sponsorSkipObject sponsorSkipNotice"> <table className={"sponsorSkipObject sponsorSkipNotice"
+ (this.props.limitWidth ? " sponsorSkipNoticeLimitWidth" : "")}>
<tbody> <tbody>
{/* First row */} {/* First row */}
<tr id={"sponsorSkipNoticeFirstRow" + this.idSuffix}> <tr id={"sponsorSkipNoticeFirstRow" + this.idSuffix}
className="sponsorSkipNoticeFirstRow">
{/* Left column */} {/* Left column */}
<td className="noticeLeftIcon"> <td className="noticeLeftIcon">
{/* Logo */} {/* Logo */}

View File

@@ -1,7 +1,7 @@
import * as React from "react"; import * as React from "react";
import * as CompileConfig from "../../config.json"; import * as CompileConfig from "../../config.json";
import Config from "../config" import Config from "../config"
import { Category, ContentContainer, CategoryActionType, SponsorHideType, SponsorTime, NoticeVisbilityMode } from "../types"; import { Category, ContentContainer, CategoryActionType, SponsorHideType, SponsorTime, NoticeVisbilityMode, ActionType } from "../types";
import NoticeComponent from "./NoticeComponent"; import NoticeComponent from "./NoticeComponent";
import NoticeTextSelectionComponent from "./NoticeTextSectionComponent"; import NoticeTextSelectionComponent from "./NoticeTextSectionComponent";
@@ -39,8 +39,9 @@ export interface SkipNoticeState {
maxCountdownTime?: () => number; maxCountdownTime?: () => number;
countdownText?: string; countdownText?: string;
unskipText?: string; skipButtonText?: string;
unskipCallback?: (index: number) => void; skipButtonCallback?: (index: number) => void;
showSkipButton?: boolean;
downvoting?: boolean; downvoting?: boolean;
choosingCategory?: boolean; choosingCategory?: boolean;
@@ -110,8 +111,9 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
countdownTime: Config.config.skipNoticeDuration, countdownTime: Config.config.skipNoticeDuration,
countdownText: null, countdownText: null,
unskipText: chrome.i18n.getMessage("unskip"), skipButtonText: this.getUnskipText(),
unskipCallback: (index) => this.unskip(index), skipButtonCallback: (index) => this.unskip(index),
showSkipButton: true,
downvoting: false, downvoting: false,
choosingCategory: false, choosingCategory: false,
@@ -126,7 +128,7 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
if (!this.autoSkip) { if (!this.autoSkip) {
// Assume manual skip is only skipping 1 submission // Assume manual skip is only skipping 1 submission
Object.assign(this.state, this.getUnskippedModeInfo(0, chrome.i18n.getMessage("skip"))); Object.assign(this.state, this.getUnskippedModeInfo(0, this.getSkipText()));
} }
} }
@@ -165,6 +167,7 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
ref={this.noticeRef} ref={this.noticeRef}
closeListener={() => this.closeListener()} closeListener={() => this.closeListener()}
smaller={this.state.smaller} smaller={this.state.smaller}
limitWidth={true}
firstColumn={firstColumn} firstColumn={firstColumn}
bottomRow={[...this.getMessageBoxes(), ...this.getBottomRow() ]} bottomRow={[...this.getMessageBoxes(), ...this.getBottomRow() ]}
onMouseEnter={() => this.onMouseEnter() } > onMouseEnter={() => this.onMouseEnter() } >
@@ -296,9 +299,9 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
} }
getSkipButton(): JSX.Element { getSkipButton(): JSX.Element {
if (this.segments.length > 1 if (this.state.showSkipButton && (this.segments.length > 1
|| getCategoryActionType(this.segments[0].category) !== CategoryActionType.POI || getCategoryActionType(this.segments[0].category) !== CategoryActionType.POI
|| this.props.unskipTime) { || this.props.unskipTime)) {
return ( return (
<span className="sponsorSkipNoticeUnskipSection"> <span className="sponsorSkipNoticeUnskipSection">
<button id={"sponsorSkipUnskipButton" + this.idSuffix} <button id={"sponsorSkipUnskipButton" + this.idSuffix}
@@ -306,7 +309,7 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
style={{marginLeft: "4px"}} style={{marginLeft: "4px"}}
onClick={() => this.prepAction(SkipNoticeAction.Unskip)}> onClick={() => this.prepAction(SkipNoticeAction.Unskip)}>
{this.state.unskipText + (this.state.showKeybindHint ? " (" + Config.config.skipKeybind + ")" : "")} {this.state.skipButtonText + (this.state.showKeybindHint ? " (" + Config.config.skipKeybind + ")" : "")}
</button> </button>
</span> </span>
); );
@@ -396,7 +399,7 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
this.contentContainer().vote(undefined, this.segments[index].UUID, this.categoryOptionRef.current.value as Category, this) this.contentContainer().vote(undefined, this.segments[index].UUID, this.categoryOptionRef.current.value as Category, this)
break; break;
case SkipNoticeAction.Unskip: case SkipNoticeAction.Unskip:
this.state.unskipCallback(index); this.state.skipButtonCallback(index);
break; break;
} }
@@ -456,7 +459,29 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
unskip(index: number): void { unskip(index: number): void {
this.contentContainer().unskipSponsorTime(this.segments[index], this.props.unskipTime); this.contentContainer().unskipSponsorTime(this.segments[index], this.props.unskipTime);
this.unskippedMode(index, chrome.i18n.getMessage("reskip")); this.unskippedMode(index, this.getReskipText());
}
reskip(index: number): void {
this.contentContainer().reskipSponsorTime(this.segments[index]);
const newState: SkipNoticeState = {
skipButtonText: this.getUnskipText(),
skipButtonCallback: this.unskip.bind(this),
maxCountdownTime: () => Config.config.skipNoticeDuration,
countdownTime: Config.config.skipNoticeDuration
};
// See if the title should be changed
if (!this.autoSkip) {
newState.noticeTitle = chrome.i18n.getMessage("noticeTitle");
}
//reset countdown
this.setState(newState, () => {
this.noticeRef.current.resetCountdown();
});
} }
/** Sets up notice to be not skipped yet */ /** Sets up notice to be not skipped yet */
@@ -478,36 +503,14 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
} : this.state.maxCountdownTime; } : this.state.maxCountdownTime;
return { return {
unskipText: buttonText, skipButtonText: buttonText,
unskipCallback: (index) => this.reskip(index), skipButtonCallback: (index) => this.reskip(index),
// change max duration to however much of the sponsor is left // change max duration to however much of the sponsor is left
maxCountdownTime: maxCountdownTime, maxCountdownTime: maxCountdownTime,
countdownTime: maxCountdownTime() countdownTime: maxCountdownTime()
} as SkipNoticeState; } as SkipNoticeState;
} }
reskip(index: number): void {
this.contentContainer().reskipSponsorTime(this.segments[index]);
const newState: SkipNoticeState = {
unskipText: chrome.i18n.getMessage("unskip"),
unskipCallback: this.unskip.bind(this),
maxCountdownTime: () => Config.config.skipNoticeDuration,
countdownTime: Config.config.skipNoticeDuration
};
// See if the title should be changed
if (!this.autoSkip) {
newState.noticeTitle = chrome.i18n.getMessage("noticeTitle");
}
//reset countdown
this.setState(newState, () => {
this.noticeRef.current.resetCountdown();
});
}
afterVote(segment: SponsorTime, type: number, category: Category): void { afterVote(segment: SponsorTime, type: number, category: Category): void {
this.addVoteButtonInfo(chrome.i18n.getMessage("voted")); this.addVoteButtonInfo(chrome.i18n.getMessage("voted"));
@@ -558,6 +561,52 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
this.props.closeListener(); this.props.closeListener();
} }
unmutedListener(): void {
if (this.props.segments.length === 1
&& this.props.segments[0].actionType === ActionType.Mute
&& this.contentContainer().v.currentTime >= this.props.segments[0].segment[1]) {
this.setState({
showSkipButton: false
});
}
}
private getUnskipText(): string {
switch (this.props.segments[0].actionType) {
case ActionType.Mute: {
return chrome.i18n.getMessage("unmute");
}
case ActionType.Skip:
default: {
return chrome.i18n.getMessage("unskip");
}
}
}
private getReskipText(): string {
switch (this.props.segments[0].actionType) {
case ActionType.Mute: {
return chrome.i18n.getMessage("mute");
}
case ActionType.Skip:
default: {
return chrome.i18n.getMessage("reskip");
}
}
}
private getSkipText(): string {
switch (this.props.segments[0].actionType) {
case ActionType.Mute: {
return chrome.i18n.getMessage("mute");
}
case ActionType.Skip:
default: {
return chrome.i18n.getMessage("skip");
}
}
}
} }
export default SkipNoticeComponent; export default SkipNoticeComponent;

View File

@@ -1,12 +1,12 @@
import * as React from "react"; import * as React from "react";
import Config from "../config";
import * as CompileConfig from "../../config.json"; import * as CompileConfig from "../../config.json";
import Config from "../config";
import { ActionType, ActionTypes, Category, CategoryActionType, ContentContainer, SponsorTime } from "../types";
import Utils from "../utils"; import Utils from "../utils";
import { Category, CategoryActionType, ContentContainer, SponsorTime } from "../types";
import SubmissionNoticeComponent from "./SubmissionNoticeComponent";
import { getCategoryActionType } from "../utils/categoryUtils"; import { getCategoryActionType } from "../utils/categoryUtils";
import SubmissionNoticeComponent from "./SubmissionNoticeComponent";
const utils = new Utils(); const utils = new Utils();
export interface SponsorTimeEditProps { export interface SponsorTimeEditProps {
@@ -32,6 +32,7 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
idSuffix: string; idSuffix: string;
categoryOptionRef: React.RefObject<HTMLSelectElement>; categoryOptionRef: React.RefObject<HTMLSelectElement>;
actionTypeOptionRef: React.RefObject<HTMLSelectElement>;
configUpdateListener: () => void; configUpdateListener: () => void;
@@ -39,6 +40,7 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
super(props); super(props);
this.categoryOptionRef = React.createRef(); this.categoryOptionRef = React.createRef();
this.actionTypeOptionRef = React.createRef();
this.idSuffix = this.props.idSuffix; this.idSuffix = this.props.idSuffix;
@@ -171,7 +173,7 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
{/* Category */} {/* Category */}
<div style={{position: "relative"}}> <div style={{position: "relative"}}>
<select id={"sponsorTimeCategories" + this.idSuffix} <select id={"sponsorTimeCategories" + this.idSuffix}
className="sponsorTimeCategories" className="sponsorTimeEditSelector sponsorTimeCategories"
defaultValue={sponsorTime.category} defaultValue={sponsorTime.category}
ref={this.categoryOptionRef} ref={this.categoryOptionRef}
onChange={this.categorySelectionChange.bind(this)}> onChange={this.categorySelectionChange.bind(this)}>
@@ -188,6 +190,19 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
</a> </a>
</div> </div>
{/* Action Type */}
{CompileConfig.categorySupport[sponsorTime.category]?.length > 1 ? (
<div style={{position: "relative"}}>
<select id={"sponsorTimeActionTypes" + this.idSuffix}
className="sponsorTimeEditSelector sponsorTimeActionTypes"
defaultValue={sponsorTime.actionType}
ref={this.actionTypeOptionRef}
onChange={() => this.saveEditTimes()}>
{this.getActionTypeOptions(sponsorTime)}
</select>
</div>
): ""}
<br/> <br/>
{/* Editing Tools */} {/* Editing Tools */}
@@ -264,11 +279,31 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
if (getCategoryActionType(event.target.value as Category) === CategoryActionType.POI) { if (getCategoryActionType(event.target.value as Category) === CategoryActionType.POI) {
this.setTimeTo(1, null); this.setTimeTo(1, null);
this.props.contentContainer().updateEditButtonsOnPlayer(); this.props.contentContainer().updateEditButtonsOnPlayer();
if (this.props.contentContainer().sponsorTimesSubmitting
.some((segment, i) => segment.category === event.target.value && i !== this.props.index)) {
alert(chrome.i18n.getMessage("poiOnlyOneSegment"));
}
} }
this.saveEditTimes(); this.saveEditTimes();
} }
getActionTypeOptions(sponsorTime: SponsorTime): React.ReactElement[] {
const elements = [];
for (const actionType of CompileConfig.categorySupport[sponsorTime.category]) {
elements.push(
<option value={actionType}
key={actionType}>
{chrome.i18n.getMessage(actionType)}
</option>
);
}
return elements;
}
setTimeToNow(index: number): void { setTimeToNow(index: number): void {
this.setTimeTo(index, this.props.contentContainer().getRealCurrentTime()); this.setTimeTo(index, this.props.contentContainer().getRealCurrentTime());
} }
@@ -331,6 +366,8 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
} }
sponsorTimesSubmitting[this.props.index].category = this.categoryOptionRef.current.value as Category; sponsorTimesSubmitting[this.props.index].category = this.categoryOptionRef.current.value as Category;
sponsorTimesSubmitting[this.props.index].actionType =
this.actionTypeOptionRef?.current ? this.actionTypeOptionRef.current.value as ActionType : ActionType.Skip;
Config.config.segmentTimes.set(this.props.contentContainer().sponsorVideoID, sponsorTimesSubmitting); Config.config.segmentTimes.set(this.props.contentContainer().sponsorVideoID, sponsorTimesSubmitting);
@@ -343,7 +380,7 @@ class SponsorTimeEditComponent extends React.Component<SponsorTimeEditProps, Spo
const skipTime = sponsorTimes[index].segment[0]; const skipTime = sponsorTimes[index].segment[0];
this.props.contentContainer().previewTime(skipTime - 2); this.props.contentContainer().previewTime(skipTime - (2 * this.props.contentContainer().v.playbackRate));
} }
inspectTime(): void { inspectTime(): void {

View File

@@ -15,13 +15,13 @@ export interface SubmissionNoticeProps {
closeListener: () => void; closeListener: () => void;
} }
export interface SubmissionNoticeeState { export interface SubmissionNoticeState {
noticeTitle: string, noticeTitle: string,
messages: string[], messages: string[],
idSuffix: string; idSuffix: string;
} }
class SubmissionNoticeComponent extends React.Component<SubmissionNoticeProps, SubmissionNoticeeState> { class SubmissionNoticeComponent extends React.Component<SubmissionNoticeProps, SubmissionNoticeState> {
// Contains functions and variables from the content script needed by the skip notice // Contains functions and variables from the content script needed by the skip notice
contentContainer: ContentContainer; contentContainer: ContentContainer;

View File

@@ -17,6 +17,7 @@ interface SBConfig {
submissionCountSinceCategories: number, // New count used to show the "Read The Guidelines!!" message submissionCountSinceCategories: number, // New count used to show the "Read The Guidelines!!" message
showTimeWithSkips: boolean, showTimeWithSkips: boolean,
disableSkipping: boolean, disableSkipping: boolean,
muteSegments: boolean,
trackViewCount: boolean, trackViewCount: boolean,
trackViewCountInPrivate: boolean, trackViewCountInPrivate: boolean,
dontShowNotice: boolean, dontShowNotice: boolean,
@@ -162,6 +163,7 @@ const Config: SBObject = {
submissionCountSinceCategories: 0, submissionCountSinceCategories: 0,
showTimeWithSkips: true, showTimeWithSkips: true,
disableSkipping: false, disableSkipping: false,
muteSegments: true,
trackViewCount: true, trackViewCount: true,
trackViewCountInPrivate: true, trackViewCountInPrivate: true,
dontShowNotice: false, dontShowNotice: false,

View File

@@ -1,5 +1,5 @@
import Config from "./config"; import Config from "./config";
import { SponsorTime, CategorySkipOption, VideoID, SponsorHideType, VideoInfo, StorageChangesObject, CategoryActionType, ChannelIDInfo, ChannelIDStatus, SponsorSourceType, SegmentUUID, Category, SkipToTimeParams, ToggleSkippable } from "./types"; import { SponsorTime, CategorySkipOption, VideoID, SponsorHideType, VideoInfo, StorageChangesObject, CategoryActionType, ChannelIDInfo, ChannelIDStatus, SponsorSourceType, SegmentUUID, Category, SkipToTimeParams, ToggleSkippable, ActionType, ScheduledTime } from "./types";
import { ContentContainer } from "./types"; import { ContentContainer } from "./types";
import Utils from "./utils"; import Utils from "./utils";
@@ -45,6 +45,7 @@ let sponsorSkipped: boolean[] = [];
//the video //the video
let video: HTMLVideoElement; let video: HTMLVideoElement;
let videoMuted = false; // Has it been attempted to be muted
let videoMutationObserver: MutationObserver = null; let videoMutationObserver: MutationObserver = null;
// List of videos that have had event listeners added to them // List of videos that have had event listeners added to them
const videosWithEventListeners: HTMLVideoElement[] = []; const videosWithEventListeners: HTMLVideoElement[] = [];
@@ -396,7 +397,6 @@ function cancelSponsorSchedule(): void {
} }
/** /**
*
* @param currentTime Optional if you don't want to use the actual current time * @param currentTime Optional if you don't want to use the actual current time
*/ */
function startSponsorSchedule(includeIntersectingSegments = false, currentTime?: number, includeNonIntersectingSegments = true): void { function startSponsorSchedule(includeIntersectingSegments = false, currentTime?: number, includeNonIntersectingSegments = true): void {
@@ -412,6 +412,17 @@ function startSponsorSchedule(includeIntersectingSegments = false, currentTime?:
} }
if (!video || video.paused) return; if (!video || video.paused) return;
if (currentTime === undefined || currentTime === null) currentTime = video.currentTime;
if (videoMuted && !inMuteSegment(currentTime)) {
video.muted = false;
videoMuted = false;
for (const notice of skipNotices) {
// So that the notice can hide buttons
notice.unmutedListener();
}
}
if (Config.config.disableSkipping || channelWhitelisted || (channelIDInfo.status === ChannelIDStatus.Fetching && Config.config.forceChannelCheck)){ if (Config.config.disableSkipping || channelWhitelisted || (channelIDInfo.status === ChannelIDStatus.Fetching && Config.config.forceChannelCheck)){
return; return;
@@ -419,14 +430,12 @@ function startSponsorSchedule(includeIntersectingSegments = false, currentTime?:
if (incorrectVideoCheck()) return; if (incorrectVideoCheck()) return;
if (currentTime === undefined || currentTime === null) currentTime = video.currentTime;
const skipInfo = getNextSkipIndex(currentTime, includeIntersectingSegments, includeNonIntersectingSegments); const skipInfo = getNextSkipIndex(currentTime, includeIntersectingSegments, includeNonIntersectingSegments);
if (skipInfo.index === -1) return; if (skipInfo.index === -1) return;
const currentSkip = skipInfo.array[skipInfo.index]; const currentSkip = skipInfo.array[skipInfo.index];
const skipTime: number[] = [currentSkip.segment[0], skipInfo.array[skipInfo.endIndex].segment[1]]; const skipTime: number[] = [currentSkip.scheduledTime, skipInfo.array[skipInfo.endIndex].segment[1]];
const timeUntilSponsor = skipTime[0] - currentTime; const timeUntilSponsor = skipTime[0] - currentTime;
const videoID = sponsorVideoID; const videoID = sponsorVideoID;
@@ -461,7 +470,8 @@ function startSponsorSchedule(includeIntersectingSegments = false, currentTime?:
openNotice: skipInfo.openNotice openNotice: skipInfo.openNotice
}); });
if (utils.getCategorySelection(currentSkip.category)?.option === CategorySkipOption.ManualSkip) { if (utils.getCategorySelection(currentSkip.category)?.option === CategorySkipOption.ManualSkip
|| currentSkip.actionType === ActionType.Mute) {
forcedSkipTime = skipTime[0] + 0.001; forcedSkipTime = skipTime[0] + 0.001;
} else { } else {
forcedSkipTime = skipTime[1]; forcedSkipTime = skipTime[1];
@@ -480,12 +490,19 @@ function startSponsorSchedule(includeIntersectingSegments = false, currentTime?:
} }
} }
function inMuteSegment(currentTime: number): boolean {
const checkFunction = (segment) => segment.actionType === ActionType.Mute && segment.segment[0] <= currentTime && segment.segment[1] > currentTime;
return sponsorTimes?.some(checkFunction) || sponsorTimesSubmitting.some(checkFunction);
}
/** /**
* This makes sure the videoID is still correct and if the sponsorTime is included * This makes sure the videoID is still correct and if the sponsorTime is included
*/ */
function incorrectVideoCheck(videoID?: string, sponsorTime?: SponsorTime): boolean { function incorrectVideoCheck(videoID?: string, sponsorTime?: SponsorTime): boolean {
const currentVideoID = getYouTubeVideoID(document.URL); const currentVideoID = getYouTubeVideoID(document.URL);
if (currentVideoID !== (videoID || sponsorVideoID) || (sponsorTime && (!sponsorTimes || !sponsorTimes.includes(sponsorTime)) && !sponsorTimesSubmitting.includes(sponsorTime))) { if (currentVideoID !== (videoID || sponsorVideoID) || (sponsorTime
&& (!sponsorTimes || !sponsorTimes?.some((time) => time.segment === sponsorTime.segment))
&& !sponsorTimesSubmitting.some((time) => time.segment === sponsorTime.segment))) {
// Something has really gone wrong // Something has really gone wrong
console.error("[SponsorBlock] The videoID recorded when trying to skip is different than what it should be."); console.error("[SponsorBlock] The videoID recorded when trying to skip is different than what it should be.");
console.error("[SponsorBlock] VideoID recorded: " + sponsorVideoID + ". Actual VideoID: " + currentVideoID); console.error("[SponsorBlock] VideoID recorded: " + sponsorVideoID + ". Actual VideoID: " + currentVideoID);
@@ -575,7 +592,7 @@ function setupVideoListeners() {
} }
if (!Config.config.dontShowNotice) { if (!Config.config.dontShowNotice) {
const currentPoiSegment = sponsorTimes.find((segment) => const currentPoiSegment = sponsorTimes?.find((segment) =>
getCategoryActionType(segment.category) === CategoryActionType.POI && getCategoryActionType(segment.category) === CategoryActionType.POI &&
video.currentTime - segment.segment[0] > 0 && video.currentTime - segment.segment[0] > 0 &&
video.currentTime - segment.segment[0] < previewBar.getMinimumSize(true)); video.currentTime - segment.segment[0] < previewBar.getMinimumSize(true));
@@ -644,6 +661,7 @@ async function sponsorsLookup(id: string, keepOldSubmissions = true) {
const hashPrefix = (await utils.getHash(id, 1)).substr(0, 4); const hashPrefix = (await utils.getHash(id, 1)).substr(0, 4);
const response = await utils.asyncRequestToServer('GET', "/api/skipSegments/" + hashPrefix, { const response = await utils.asyncRequestToServer('GET', "/api/skipSegments/" + hashPrefix, {
categories, categories,
actionTypes: Config.config.muteSegments ? [ActionType.Skip, ActionType.Mute] : [ActionType.Skip],
userAgent: `${chrome.runtime.id}` userAgent: `${chrome.runtime.id}`
}); });
@@ -945,31 +963,33 @@ async function whitelistCheck() {
* Returns info about the next upcoming sponsor skip * Returns info about the next upcoming sponsor skip
*/ */
function getNextSkipIndex(currentTime: number, includeIntersectingSegments: boolean, includeNonIntersectingSegments: boolean): function getNextSkipIndex(currentTime: number, includeIntersectingSegments: boolean, includeNonIntersectingSegments: boolean):
{array: SponsorTime[], index: number, endIndex: number, openNotice: boolean} { {array: ScheduledTime[], index: number, endIndex: number, openNotice: boolean} {
const sponsorStartTimes = getStartTimes(sponsorTimes, includeIntersectingSegments, includeNonIntersectingSegments); const { includedTimes: submittedArray, scheduledTimes: sponsorStartTimes } =
const sponsorStartTimesAfterCurrentTime = getStartTimes(sponsorTimes, includeIntersectingSegments, includeNonIntersectingSegments, currentTime, true, true); getStartTimes(sponsorTimes, includeIntersectingSegments, includeNonIntersectingSegments);
const { scheduledTimes: sponsorStartTimesAfterCurrentTime } = getStartTimes(sponsorTimes, includeIntersectingSegments, includeNonIntersectingSegments, currentTime, true, true);
const minSponsorTimeIndex = sponsorStartTimes.indexOf(Math.min(...sponsorStartTimesAfterCurrentTime)); const minSponsorTimeIndex = sponsorStartTimes.indexOf(Math.min(...sponsorStartTimesAfterCurrentTime));
const endTimeIndex = getLatestEndTimeIndex(sponsorTimes, minSponsorTimeIndex); const endTimeIndex = getLatestEndTimeIndex(submittedArray, minSponsorTimeIndex);
const unsubmittedSponsorStartTimes = getStartTimes(sponsorTimesSubmitting, includeIntersectingSegments, includeNonIntersectingSegments); const { includedTimes: unsubmittedArray, scheduledTimes: unsubmittedSponsorStartTimes } =
const unsubmittedSponsorStartTimesAfterCurrentTime = getStartTimes(sponsorTimesSubmitting, includeIntersectingSegments, includeNonIntersectingSegments, currentTime, false, false); getStartTimes(sponsorTimesSubmitting, includeIntersectingSegments, includeNonIntersectingSegments);
const { scheduledTimes: unsubmittedSponsorStartTimesAfterCurrentTime } = getStartTimes(sponsorTimesSubmitting, includeIntersectingSegments, includeNonIntersectingSegments, currentTime, false, false);
const minUnsubmittedSponsorTimeIndex = unsubmittedSponsorStartTimes.indexOf(Math.min(...unsubmittedSponsorStartTimesAfterCurrentTime)); const minUnsubmittedSponsorTimeIndex = unsubmittedSponsorStartTimes.indexOf(Math.min(...unsubmittedSponsorStartTimesAfterCurrentTime));
const previewEndTimeIndex = getLatestEndTimeIndex(sponsorTimesSubmitting, minUnsubmittedSponsorTimeIndex); const previewEndTimeIndex = getLatestEndTimeIndex(unsubmittedArray, minUnsubmittedSponsorTimeIndex);
if ((minUnsubmittedSponsorTimeIndex === -1 && minSponsorTimeIndex !== -1) || if ((minUnsubmittedSponsorTimeIndex === -1 && minSponsorTimeIndex !== -1) ||
sponsorStartTimes[minSponsorTimeIndex] < unsubmittedSponsorStartTimes[minUnsubmittedSponsorTimeIndex]) { sponsorStartTimes[minSponsorTimeIndex] < unsubmittedSponsorStartTimes[minUnsubmittedSponsorTimeIndex]) {
return { return {
array: sponsorTimes.filter((segment) => getCategoryActionType(segment.category) === CategoryActionType.Skippable), array: submittedArray,
index: minSponsorTimeIndex, index: minSponsorTimeIndex,
endIndex: endTimeIndex, endIndex: endTimeIndex,
openNotice: true openNotice: true
}; };
} else { } else {
return { return {
array: sponsorTimesSubmitting.filter((segment) => getCategoryActionType(segment.category) === CategoryActionType.Skippable), array: unsubmittedArray,
index: minUnsubmittedSponsorTimeIndex, index: minUnsubmittedSponsorTimeIndex,
endIndex: previewEndTimeIndex, endIndex: previewEndTimeIndex,
openNotice: false openNotice: false
@@ -993,7 +1013,10 @@ function getNextSkipIndex(currentTime: number, includeIntersectingSegments: bool
function getLatestEndTimeIndex(sponsorTimes: SponsorTime[], index: number, hideHiddenSponsors = true): number { function getLatestEndTimeIndex(sponsorTimes: SponsorTime[], index: number, hideHiddenSponsors = true): number {
// Only combine segments for AutoSkip // Only combine segments for AutoSkip
if (index == -1 || if (index == -1 ||
!shouldAutoSkip(sponsorTimes[index])) return index; !shouldAutoSkip(sponsorTimes[index])
|| sponsorTimes[index].actionType !== ActionType.Skip) {
return index;
}
// Default to the normal endTime // Default to the normal endTime
let latestEndTimeIndex = index; let latestEndTimeIndex = index;
@@ -1004,7 +1027,8 @@ function getLatestEndTimeIndex(sponsorTimes: SponsorTime[], index: number, hideH
if (currentSegment[0] <= latestEndTime && currentSegment[1] > latestEndTime if (currentSegment[0] <= latestEndTime && currentSegment[1] > latestEndTime
&& (!hideHiddenSponsors || sponsorTimes[i].hidden === SponsorHideType.Visible) && (!hideHiddenSponsors || sponsorTimes[i].hidden === SponsorHideType.Visible)
&& shouldAutoSkip(sponsorTimes[i])) { && shouldAutoSkip(sponsorTimes[i])
&& sponsorTimes[i].actionType === ActionType.Skip) {
// Overlapping segment // Overlapping segment
latestEndTimeIndex = i; latestEndTimeIndex = i;
} }
@@ -1029,24 +1053,42 @@ function getLatestEndTimeIndex(sponsorTimes: SponsorTime[], index: number, hideH
* the current time, but end after * the current time, but end after
*/ */
function getStartTimes(sponsorTimes: SponsorTime[], includeIntersectingSegments: boolean, includeNonIntersectingSegments: boolean, function getStartTimes(sponsorTimes: SponsorTime[], includeIntersectingSegments: boolean, includeNonIntersectingSegments: boolean,
minimum?: number, onlySkippableSponsors = false, hideHiddenSponsors = false): number[] { minimum?: number, onlySkippableSponsors = false, hideHiddenSponsors = false): {includedTimes: ScheduledTime[], scheduledTimes: number[]} {
if (sponsorTimes === null) return []; if (!sponsorTimes) return {includedTimes: [], scheduledTimes: []};
const startTimes: number[] = []; const includedTimes: ScheduledTime[] = [];
const scheduledTimes: number[] = [];
for (let i = 0; i < sponsorTimes?.length; i++) { const possibleTimes = sponsorTimes.map((sponsorTime) => ({
...sponsorTime,
scheduledTime: sponsorTime.segment[0]
}));
// Schedule at the end time to know when to unmute
sponsorTimes.filter(sponsorTime => sponsorTime.actionType === ActionType.Mute)
.forEach(sponsorTime => {
if (!possibleTimes.some((time) => sponsorTime.segment[1] === time.scheduledTime)) {
possibleTimes.push({
...sponsorTime,
scheduledTime: sponsorTime.segment[1]
});
}
});
for (let i = 0; i < possibleTimes.length; i++) {
if ((minimum === undefined if ((minimum === undefined
|| ((includeNonIntersectingSegments && sponsorTimes[i].segment[0] >= minimum) || ((includeNonIntersectingSegments && possibleTimes[i].scheduledTime >= minimum)
|| (includeIntersectingSegments && sponsorTimes[i].segment[0] < minimum && sponsorTimes[i].segment[1] > minimum))) || (includeIntersectingSegments && possibleTimes[i].scheduledTime < minimum && possibleTimes[i].segment[1] > minimum)))
&& (!onlySkippableSponsors || shouldSkip(sponsorTimes[i])) && (!onlySkippableSponsors || shouldSkip(possibleTimes[i]))
&& (!hideHiddenSponsors || sponsorTimes[i].hidden === SponsorHideType.Visible) && (!hideHiddenSponsors || possibleTimes[i].hidden === SponsorHideType.Visible)
&& getCategoryActionType(sponsorTimes[i].category) === CategoryActionType.Skippable) { && getCategoryActionType(possibleTimes[i].category) === CategoryActionType.Skippable) {
startTimes.push(sponsorTimes[i].segment[0]); scheduledTimes.push(possibleTimes[i].scheduledTime);
includedTimes.push(possibleTimes[i]);
} }
} }
return startTimes; return { includedTimes, scheduledTimes };
} }
/** /**
@@ -1069,7 +1111,7 @@ function sendTelemetryAndCount(skippingSegments: SponsorTime[], secondsSkipped:
let counted = false; let counted = false;
for (const segment of skippingSegments) { for (const segment of skippingSegments) {
const index = sponsorTimes.indexOf(segment); const index = sponsorTimes?.findIndex((s) => s.segment === segment.segment);
if (index !== -1 && !sponsorSkipped[index]) { if (index !== -1 && !sponsorSkipped[index]) {
sponsorSkipped[index] = true; sponsorSkipped[index] = true;
if (!counted) { if (!counted) {
@@ -1092,13 +1134,27 @@ function skipToTime({v, skipTime, skippingSegments, openNotice, forceAutoSkip, u
if ((autoSkip || sponsorTimesSubmitting.some((time) => time.segment === skippingSegments[0].segment)) if ((autoSkip || sponsorTimesSubmitting.some((time) => time.segment === skippingSegments[0].segment))
&& v.currentTime !== skipTime[1]) { && v.currentTime !== skipTime[1]) {
// Fix for looped videos not working when skipping to the end #426 switch(skippingSegments[0].actionType) {
// for some reason you also can't skip to 1 second before the end case ActionType.Skip: {
if (v.loop && v.duration > 1 && skipTime[1] >= v.duration - 1) { // Fix for looped videos not working when skipping to the end #426
v.currentTime = 0; // for some reason you also can't skip to 1 second before the end
} else { if (v.loop && v.duration > 1 && skipTime[1] >= v.duration - 1) {
v.currentTime = skipTime[1]; v.currentTime = 0;
} else {
v.currentTime = skipTime[1];
}
break;
}
case ActionType.Mute: {
if (!v.muted) {
v.muted = true;
videoMuted = true;
}
break;
}
} }
} }
if (!autoSkip if (!autoSkip
@@ -1138,19 +1194,29 @@ function skipToTime({v, skipTime, skippingSegments, openNotice, forceAutoSkip, u
} }
function unskipSponsorTime(segment: SponsorTime, unskipTime: number = null) { function unskipSponsorTime(segment: SponsorTime, unskipTime: number = null) {
//add a tiny bit of time to make sure it is not skipped again if (segment.actionType === ActionType.Mute) {
console.log(unskipTime) video.muted = false;
video.currentTime = unskipTime ?? segment.segment[0] + 0.001; videoMuted = false;
} else {
//add a tiny bit of time to make sure it is not skipped again
video.currentTime = unskipTime ?? segment.segment[0] + 0.001;
}
} }
function reskipSponsorTime(segment: SponsorTime) { function reskipSponsorTime(segment: SponsorTime) {
const skippedTime = Math.max(segment.segment[1] - video.currentTime, 0); if (segment.actionType === ActionType.Mute) {
const segmentDuration = segment.segment[1] - segment.segment[0]; video.muted = true;
const fullSkip = skippedTime / segmentDuration > manualSkipPercentCount; videoMuted = true;
} else {
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); sendTelemetryAndCount([segment], skippedTime, fullSkip);
startSponsorSchedule(true, segment.segment[1], false); startSponsorSchedule(true, segment.segment[1], false);
}
} }
function createButton(baseID: string, title: string, callback: () => void, imageName: string, isDraggable = false): HTMLElement { function createButton(baseID: string, title: string, callback: () => void, imageName: string, isDraggable = false): HTMLElement {
@@ -1193,13 +1259,13 @@ function createButton(baseID: string, title: string, callback: () => void, image
function shouldAutoSkip(segment: SponsorTime): boolean { function shouldAutoSkip(segment: SponsorTime): boolean {
return utils.getCategorySelection(segment.category)?.option === CategorySkipOption.AutoSkip || return utils.getCategorySelection(segment.category)?.option === CategorySkipOption.AutoSkip ||
(Config.config.autoSkipOnMusicVideos && sponsorTimes.some((s) => s.category === "music_offtopic") (Config.config.autoSkipOnMusicVideos && sponsorTimes?.some((s) => s.category === "music_offtopic")
&& getCategoryActionType(segment.category) === CategoryActionType.Skippable); && getCategoryActionType(segment.category) === CategoryActionType.Skippable);
} }
function shouldSkip(segment: SponsorTime): boolean { function shouldSkip(segment: SponsorTime): boolean {
return utils.getCategorySelection(segment.category)?.option !== CategorySkipOption.ShowOverlay || return utils.getCategorySelection(segment.category)?.option !== CategorySkipOption.ShowOverlay ||
(Config.config.autoSkipOnMusicVideos && sponsorTimes.some((s) => s.category === "music_offtopic")); (Config.config.autoSkipOnMusicVideos && sponsorTimes?.some((s) => s.category === "music_offtopic"));
} }
function getControls(): HTMLElement | false { function getControls(): HTMLElement | false {
@@ -1333,6 +1399,7 @@ function startOrEndTimingNewSegment() {
segment: [getRealCurrentTime()], segment: [getRealCurrentTime()],
UUID: null, UUID: null,
category: Config.config.defaultCategory, category: Config.config.defaultCategory,
actionType: ActionType.Skip,
source: SponsorSourceType.Local source: SponsorSourceType.Local
}); });
} else { } else {
@@ -1389,6 +1456,7 @@ function updateSponsorTimesSubmitting(getFromConfig = true) {
segment: segmentTime.segment, segment: segmentTime.segment,
UUID: segmentTime.UUID, UUID: segmentTime.UUID,
category: segmentTime.category, category: segmentTime.category,
actionType: segmentTime.actionType,
source: segmentTime.source source: segmentTime.source
}); });
} }

View File

@@ -71,6 +71,10 @@ class SkipNotice {
toggleSkip(): void { toggleSkip(): void {
this.skipNoticeRef?.current?.prepAction(SkipNoticeAction.Unskip); this.skipNoticeRef?.current?.prepAction(SkipNoticeAction.Unskip);
} }
unmutedListener(): void {
this.skipNoticeRef?.current?.unmutedListener();
}
} }
export default SkipNotice; export default SkipNotice;

View File

@@ -56,6 +56,13 @@ export enum CategoryActionType {
POI = "_POI" POI = "_POI"
} }
export enum ActionType {
Skip = "skip",
Mute = "mute"
}
export const ActionTypes = [ActionType.Skip, ActionType.Mute];
export type SegmentUUID = string & { __segmentUUIDBrand: unknown }; export type SegmentUUID = string & { __segmentUUIDBrand: unknown };
export type Category = string & { __categoryBrand: unknown }; export type Category = string & { __categoryBrand: unknown };
@@ -69,11 +76,16 @@ export interface SponsorTime {
UUID: SegmentUUID; UUID: SegmentUUID;
category: Category; category: Category;
actionType: ActionType;
hidden?: SponsorHideType; hidden?: SponsorHideType;
source?: SponsorSourceType; source?: SponsorSourceType;
} }
export interface ScheduledTime extends SponsorTime {
scheduledTime: number;
}
export interface PreviewBarOption { export interface PreviewBarOption {
color: string, color: string,
opacity: string opacity: string

View File

@@ -1,15 +1,39 @@
import { Category, CategoryActionType, SponsorTime } from "../types"; import { ActionType, Category, CategoryActionType, SponsorTime } from "../types";
export function getSkippingText(segments: SponsorTime[], autoSkip: boolean): string { export function getSkippingText(segments: SponsorTime[], autoSkip: boolean): string {
const categoryName = chrome.i18n.getMessage(segments.length > 1 ? "multipleSegments" const categoryName = chrome.i18n.getMessage(segments.length > 1 ? "multipleSegments"
: "category_" + segments[0].category + "_short") || chrome.i18n.getMessage("category_" + segments[0].category); : "category_" + segments[0].category + "_short") || chrome.i18n.getMessage("category_" + segments[0].category);
if (autoSkip) { if (autoSkip) {
const messageId = getCategoryActionType(segments[0].category) === CategoryActionType.Skippable let messageId = "";
? "skipped" : "skipped_to_category"; if (getCategoryActionType(segments[0].category) === CategoryActionType.Skippable) {
switch (segments[0].actionType) {
case ActionType.Skip:
messageId = "skipped";
break;
case ActionType.Mute:
messageId = "muted";
break;
}
} else {
messageId = "skipped_to_category";
}
return chrome.i18n.getMessage(messageId).replace("{0}", categoryName); return chrome.i18n.getMessage(messageId).replace("{0}", categoryName);
} else { } else {
const messageId = getCategoryActionType(segments[0].category) === CategoryActionType.Skippable let messageId = "";
? "skip_category" : "skip_to_category"; if (getCategoryActionType(segments[0].category) === CategoryActionType.Skippable) {
switch (segments[0].actionType) {
case ActionType.Skip:
messageId = "skip_category";
break;
case ActionType.Mute:
messageId = "mute_category";
break;
}
} else {
messageId = "skip_to_category";
}
return chrome.i18n.getMessage(messageId).replace("{0}", categoryName); return chrome.i18n.getMessage(messageId).replace("{0}", categoryName);
} }
} }

View File

@@ -13,8 +13,12 @@ test("Selenium Chrome test", async () => {
await createSegment(driver, "4", "10.33", "0:04.000 to 0:10.330"); await createSegment(driver, "4", "10.33", "0:04.000 to 0:10.330");
await editSegments(driver, 0, "0:04.000", "0:10.330", "5", "13.211", "0:05.000 to 0:13.211", false); await editSegments(driver, 0, "0:04.000", "0:10.330", "5", "13.211", "0:05.000 to 0:13.211", false);
await autoskipSegment(driver, 5, 13.211); await autoskipSegment(driver, 5, 13.211);
await setSegmentCategory(driver, 0, 1, false);
await setSegmentActionType(driver, 0, 1, false);
await editSegments(driver, 0, "0:05.000", "0:13.211", "5", "7.5", "0:05.000 to 0:07.500", false);
await muteSkipSegment(driver, 5, 7.5);
} finally { } finally {
await driver.quit(); await driver.quit();
} }
@@ -24,7 +28,7 @@ async function setup(): Promise<WebDriver> {
const options = new Chrome.Options(); const options = new Chrome.Options();
options.addArguments("--load-extension=" + Path.join(__dirname, "../dist/")); options.addArguments("--load-extension=" + Path.join(__dirname, "../dist/"));
options.addArguments("--mute-audio"); options.addArguments("--mute-audio");
options.addArguments("--disable-features=PreloadMediaEngagementData, MediaEngagementBypassAutoplayPolicies") options.addArguments("--disable-features=PreloadMediaEngagementData, MediaEngagementBypassAutoplayPolicies");
const driver = await new Builder().forBrowser("chrome").setChromeOptions(options).build(); const driver = await new Builder().forBrowser("chrome").setChromeOptions(options).build();
driver.manage().setTimeouts({ driver.manage().setTimeouts({
@@ -106,6 +110,26 @@ async function editSegments(driver: WebDriver, index: number, expectedStartTimeB
await driver.wait(until.elementTextIs(sponsorTimeDisplay, expectedDisplayedTime)); await driver.wait(until.elementTextIs(sponsorTimeDisplay, expectedDisplayedTime));
} }
async function setSegmentCategory(driver: WebDriver, index: number, categoryIndex: number, openSubmitBox: boolean): Promise<void> {
if (openSubmitBox) {
const submitButton = await driver.findElement(By.id("submitButton"));
await submitButton.click();
}
const categorySelection = await driver.findElement(By.css(`#sponsorTimeCategoriesSubmissionNotice${index} > option:nth-child(${categoryIndex + 1})`));
await categorySelection.click();
}
async function setSegmentActionType(driver: WebDriver, index: number, actionTypeIndex: number, openSubmitBox: boolean): Promise<void> {
if (openSubmitBox) {
const submitButton = await driver.findElement(By.id("submitButton"));
await submitButton.click();
}
const actionTypeSelection = await driver.findElement(By.css(`#sponsorTimeActionTypesSubmissionNotice${index} > option:nth-child(${actionTypeIndex + 1})`));
await actionTypeSelection.click();
}
async function autoskipSegment(driver: WebDriver, startTime: number, endTime: number): Promise<void> { async function autoskipSegment(driver: WebDriver, startTime: number, endTime: number): Promise<void> {
const video = await driver.findElement(By.css("video")); const video = await driver.findElement(By.css("video"));
@@ -113,7 +137,21 @@ async function autoskipSegment(driver: WebDriver, startTime: number, endTime: nu
await driver.executeScript("document.querySelector('video').play()"); await driver.executeScript("document.querySelector('video').play()");
await driver.sleep(1300); await driver.sleep(1300);
expect(parseFloat(await video.getAttribute("currentTime"))).toBeGreaterThan(endTime); expect(parseFloat(await video.getAttribute("currentTime"))).toBeGreaterThan(endTime);
await driver.executeScript("document.querySelector('video').pause()"); await driver.executeScript("document.querySelector('video').pause()");
} }
async function muteSkipSegment(driver: WebDriver, startTime: number, endTime: number): Promise<void> {
const duration = endTime - startTime;
const video = await driver.findElement(By.css("video"));
await driver.executeScript("document.querySelector('video').currentTime = " + (startTime - 0.5));
await driver.executeScript("document.querySelector('video').play()");
await driver.sleep(1300);
expect(await video.getAttribute("muted")).toEqual("true");
await driver.sleep(duration * 1000 + 300);
expect(await video.getAttribute("muted")).toBeNull(); // Default is null for some reason
await driver.executeScript("document.querySelector('video').pause()");
}

View File

@@ -8,6 +8,11 @@
"noEmitOnError": false, "noEmitOnError": false,
"typeRoots": [ "node_modules/@types" ], "typeRoots": [ "node_modules/@types" ],
"resolveJsonModule": true, "resolveJsonModule": true,
"jsx": "react" "jsx": "react",
"lib": [
"es2019",
"dom",
"dom.iterable"
]
} }
} }