Compare commits

...

36 Commits
3.6.2 ... 3.7.1

Author SHA1 Message Date
Ajay Ramachandran
b758cbb25f bump version 2021-12-30 17:20:11 -05:00
Ajay Ramachandran
f2be7a9c5b Merge pull request #1113 from CyberPhoenix90/fix_interval_leak
fix leak that was killing performance over long periods
2021-12-30 10:56:42 -05:00
CyberPhoenix90
8763d173bd fix missing semi colon 2021-12-30 15:22:02 +01:00
CyberPhoenix90
07e3117e22 fix leak that was killing performance over long periods 2021-12-30 15:05:09 +01:00
Ajay
12bc10ea1f Make youtube settings in front of skip notice 2021-12-29 00:35:33 -05:00
Ajay
2db1971190 Don't change countdown speed with playback speed
Fix #1067
2021-12-29 00:30:24 -05:00
Ajay Ramachandran
c3107ffcff bump version 2021-12-28 15:25:20 -05:00
Ajay Ramachandran
4bca8ad2f7 Merge pull request #1071 from mchangrh/invidiousCI
Auto-populate invidious list
2021-12-28 15:09:19 -05:00
Ajay Ramachandran
e729e036cf New Crowdin updates (#1054) 2021-12-28 14:51:14 -05:00
Ajay
7b74307013 formatting 2021-12-28 14:50:18 -05:00
Ajay
6aa1665d7c Create pull request for invidious list instead of commit 2021-12-28 14:50:12 -05:00
Ajay Ramachandran
a1bae95cdc Merge pull request #1091 from AronHK/audio-notification
Decouple audio notification from Skip Notice
2021-12-28 11:36:04 -05:00
Ajay
c5b72a01a2 Remove filler update notice 2021-12-26 20:16:26 -05:00
Ajay
8ade66d7b3 Fix skip notice deleting segments causing issues
Fixes #1105
2021-12-22 12:13:31 -05:00
Ajay Ramachandran
d42862541b Merge branch 'master' of https://github.com/ajayyy/SponsorBlock 2021-12-15 22:01:31 -05:00
Ajay Ramachandran
54001763a7 Don't hide userID option if not set
Fix #1025
2021-12-15 22:01:28 -05:00
Ajay Ramachandran
7186829bc3 Merge pull request #1079 from Choromanski/feature/format-time-to-days
Format minutes now Days, Hours and Minutes
2021-12-11 19:39:28 -05:00
Aron HK
3d3b261f8f skipNoticeContentContainer().v -> video
Co-authored-by: Ajay Ramachandran <dev@ajay.app>
2021-12-12 01:38:31 +01:00
Ajay Ramachandran
33094f2541 Add example for abbreviations 2021-12-11 19:33:11 -05:00
Hegymegi Kiss Áron
9f9df9479b move audio notification to content.ts
fixes  #756
2021-12-11 16:02:07 +01:00
Ajay Ramachandran
1c911581db Fix loop fix on Safari 2021-12-10 23:53:56 -05:00
Ajay Ramachandran
071f8b1729 Don't skip exactly to the end on Safari
Fix #1027
2021-12-10 23:52:50 -05:00
Ajay Ramachandran
8d1b35403d Fix auto hiding info not hiding
Fix #811
2021-12-10 19:09:25 -05:00
Brian Choromanski
a8fee918e4 Merge branch 'master' into feature/format-time-to-days 2021-12-06 06:09:21 -05:00
Brian Choromanski
7bca8e508e Localized d and h 2021-12-06 05:57:37 -05:00
Michael C
e16aae393f also check against length 2021-12-04 23:16:26 -05:00
Ajay Ramachandran
44de741e84 Merge pull request #1072 from Choromanski/feature/updated-comments
Changed comments from seconds and hours to minutes
2021-12-04 22:18:53 -05:00
Brian Choromanski
bc990cd683 Format minutes from hours, and minutes to days, hours, and minutes 2021-12-04 11:56:55 -05:00
Michael C
33098ac659 migrate and populat on reset 2021-12-01 17:48:07 -05:00
Ajay Ramachandran
2f8ec7a5e5 Merge pull request #1073 from mchangrh/patch-1
Update licence in package.json
2021-12-01 17:00:17 -05:00
Ajay Ramachandran
48f7c1e0a1 fix license in package.json 2021-12-01 17:00:04 -05:00
Michael M. Chang
29c3b80d0b Update licence in package.json
#721
2021-12-01 16:44:08 -05:00
Michael C
dc47b9ffd2 appease CI/ webpack
move to ci/
change triggers
2021-11-30 18:17:28 -05:00
Brian Choromanski
eaa47c8d40 Changed comments from seconds and hours to minutes 2021-11-30 17:36:21 -05:00
Michael C
e4e453a11c add code to parse and filter 2021-11-30 15:55:26 -05:00
Ajay Ramachandran
2209c230e7 Fix autohide info button affecting skip to highlight
Fix #1063
2021-11-27 00:06:52 -05:00
39 changed files with 1090 additions and 172 deletions

26
.github/workflows/updateInvidous.yml vendored Normal file
View File

@@ -0,0 +1,26 @@
name: update invidious
on:
workflow_dispatch:
schedule:
- cron: '0 0 1 * *' # check every month
jobs:
check-list:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Download instance list
run: |
wget https://api.invidious.io/instances.json -O data.json
- name: "Run CI"
run: npm run ci:invidious
- name: Create pull request to update list
uses: peter-evans/create-pull-request@v3
with:
commit-message: Update Invidious List
author: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
branch: ci/update_invidious_list
title: Update Invidious List
body: Automated Invidious list update

1
.gitignore vendored
View File

@@ -7,3 +7,4 @@ web-ext-artifacts
dist/ dist/
tmp/ tmp/
.DS_Store .DS_Store
ci/data.json

55
ci/invidiousCI.ts Normal file
View File

@@ -0,0 +1,55 @@
/*
This file is only ran by GitHub Actions in order to populate the Invidious instances list
This file should not be shipped with the extension
*/
import { writeFile, existsSync } from 'fs';
import { join } from 'path';
// import file from https://api.invidious.io/instances.json
if (!existsSync('./data.json')) {
process.exit(1);
}
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
// @ts-ignore
import * as data from "./data.json";
type instanceMap = {
name: string,
url: string,
dailyRatios: {ratio: string, label: string }[],
thirtyDayUptime: string
}[]
// only https servers
const mapped: instanceMap = data
// eslint-disable-next-line @typescript-eslint/no-explicit-any
.filter((i: any) => i[1]?.type === 'https')
// eslint-disable-next-line @typescript-eslint/no-explicit-any
.map((instance: any) => {
return {
name: instance[0],
url: instance[1].uri,
dailyRatios: instance[1].monitor.dailyRatios,
thirtyDayUptime: instance[1]?.monitor['30dRatio'].ratio,
}
})
// reliability and sanity checks
const reliableCheck = mapped
.filter((instance) => {
// 30d uptime >= 90%
const thirtyDayUptime = Number(instance.thirtyDayUptime) >= 90
// available for at least 80/90 days
const dailyRatioCheck = instance.dailyRatios.filter(status => status.label !== "black")
return (thirtyDayUptime && dailyRatioCheck.length >= 80)
})
// url includes name
.filter(instance => instance.url.includes(instance.name))
// finally map to array
const result: string[] = reliableCheck.map(instance => instance.name)
writeFile(join(__dirname, "./invidiouslist.json"), JSON.stringify(result), (err) => {
if (err) return console.log(err);
})

1
ci/invidiouslist.json Normal file
View File

@@ -0,0 +1 @@
["yewtu.be","invidious.snopyta.org","vid.puffyan.us","invidious.kavin.rocks","invidio.xamh.de","invidious-us.kavin.rocks","inv.riverside.rocks","vid.mint.lgbt","youtube.076.ne.jp","invidious.namazso.eu"]

View File

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

View File

@@ -52,6 +52,7 @@
"build:watch": "npm run build:watch:chrome", "build:watch": "npm run build:watch:chrome",
"build:watch:chrome": "webpack --env.browser=chrome --config webpack/webpack.dev.js --watch", "build:watch:chrome": "webpack --env.browser=chrome --config webpack/webpack.dev.js --watch",
"build:watch:firefox": "webpack --env.browser=firefox --config webpack/webpack.dev.js --watch", "build:watch:firefox": "webpack --env.browser=firefox --config webpack/webpack.dev.js --watch",
"ci:invidious": "ts-node ci/invidiousCI.ts",
"dev": "npm run build:dev && concurrently \"npm run web-run\" \"npm run build:watch\"", "dev": "npm run build:dev && concurrently \"npm run web-run\" \"npm run build:watch\"",
"dev:firefox": "npm run build:dev:firefox && concurrently \"npm run web-run:firefox\" \"npm run build:watch:firefox\"", "dev:firefox": "npm run build:dev:firefox && concurrently \"npm run web-run:firefox\" \"npm run build:watch:firefox\"",
"dev:firefox-android": "npm run build:dev:firefox && concurrently \"npm run web-run:firefox-android\" \"npm run build:watch:firefox\"", "dev:firefox-android": "npm run build:dev:firefox && concurrently \"npm run web-run:firefox-android\" \"npm run build:watch:firefox\"",
@@ -66,6 +67,6 @@
"url": "git+https://github.com/ajayyy/SponsorBlock.git" "url": "git+https://github.com/ajayyy/SponsorBlock.git"
}, },
"author": "Ajay Ramachandran", "author": "Ajay Ramachandran",
"license": "GPL-3.0-only", "license": "LGPL-3.0-or-later",
"private": true "private": true
} }

View File

@@ -263,7 +263,7 @@
"description": "The second line of the message displayed after the notice was upgraded." "description": "The second line of the message displayed after the notice was upgraded."
}, },
"setSkipShortcut": { "setSkipShortcut": {
"message": "Nastavit klíč pro přeskočení segmentu" "message": "Nastavit klávesu pro přeskočení segmentu"
}, },
"setStartSponsorShortcut": { "setStartSponsorShortcut": {
"message": "Nastavte klávesu pro spuštění/zastavení segmentu" "message": "Nastavte klávesu pro spuštění/zastavení segmentu"
@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Novinka! Překakujte výplňové části a vtipy s kategorií výplň. Povolte ji v nastavení" "message": "Novinka! Překakujte výplňové části a vtipy s kategorií výplň. Povolte ji v nastavení"
},
"dayAbbreviation": {
"message": "d",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -142,5 +142,453 @@
"submissionEditHint": { "submissionEditHint": {
"message": "Sektionsredigering vises, når du klikker på afsend", "message": "Sektionsredigering vises, når du klikker på afsend",
"description": "Appears in the popup to inform them that editing has been moved to the video player." "description": "Appears in the popup to inform them that editing has been moved to the video player."
},
"popupHint": {
"message": "Tip: Du kan opsætte keybinds til indsendelse i indstillingerne"
},
"clearTimesButton": {
"message": "Ryd Tider"
},
"submitTimesButton": {
"message": "Indsend Tider"
},
"publicStats": {
"message": "Dette bruges på siden med offentlige statistikker til at vise, hvor meget du har bidraget. Se det"
},
"Username": {
"message": "Brugernavn"
},
"setUsername": {
"message": "Angiv Brugernavn"
},
"copyPublicID": {
"message": "Kopier Offentligt Bruger-ID"
},
"discordAdvert": {
"message": "Kom til den officielle Discord-server for at give forslag og feedback!"
},
"hideThis": {
"message": "Skjul dette"
},
"Options": {
"message": "Indstillinger"
},
"showButtons": {
"message": "Vis Knapper På YouTube-Afspiller"
},
"hideButtons": {
"message": "Skjul Knapper På YouTube-Afspiller"
},
"hideButtonsDescription": {
"message": "Dette skjuler knapperne, der vises på YouTube-afspilleren for indsende springe segmenter."
},
"showSkipButton": {
"message": "Behold Knappen Spring Til Fremhævning På Afspilleren"
},
"showInfoButton": {
"message": "Vis Info-Knap På YouTube-Afspiller"
},
"hideInfoButton": {
"message": "Skjul Info-Knap På YouTube-Afspiller"
},
"autoHideInfoButton": {
"message": "Auto-Skjul Info-Knap"
},
"hideDeleteButton": {
"message": "Skjul Slet-Knappen på YouTube-Afspiller"
},
"showDeleteButton": {
"message": "Vis Slet-Knappen på YouTube-Afspiller"
},
"enableViewTracking": {
"message": "Aktiver Optælling Af Antal Spring Over"
},
"whatViewTracking": {
"message": "Denne funktion registrerer hvilke segmenter, du har sprunget over, så brugere kan se, hvor meget deres bidrag har hjulpet andre, og bruges som en måleenhed sammen med upvotes for at sikre, at spam ikke kommer ind i databasen. Udvidelsen sender en besked til serveren hver gang, du springer et segment over. Forhåbentlig ændrer de fleste ikke denne indstilling, så visningstallene er korrete. :)"
},
"enableViewTrackingInPrivate": {
"message": "Aktiver Optælling Af Antal Spring Over I Private-/Inkognitovinduer"
},
"enableQueryByHashPrefix": {
"message": "Forespørg Efter Hashpræfiks"
},
"whatQueryByHashPrefix": {
"message": "I stedet for at anmode om segmenter fra serveren ved hjælp af videoID'et, sendes de første 4 tegn i hashen af videoID'et. Serveren sender data tilbage for alle videoer med lignende hashes."
},
"enableRefetchWhenNotFound": {
"message": "Opdater Segmenter På Nye Videoer"
},
"whatRefetchWhenNotFound": {
"message": "Hvis videoen er ny, og der ikke er nogle segmenter fundet, vil den opdatere hvert par minutter, mens du ser."
},
"showNotice": {
"message": "Vis Bemærkning Igen"
},
"showSkipNotice": {
"message": "Vis Bemærkning Efter Et Segment Skippes"
},
"noticeVisibilityMode0": {
"message": "Fuld Størrelse Skip-Bemærkninger"
},
"noticeVisibilityMode1": {
"message": "Små Skip-Bemærkninger for Auto-Skip"
},
"noticeVisibilityMode2": {
"message": "Alle Små Skip-Bemærkninger"
},
"noticeVisibilityMode3": {
"message": "Faded Skip-Bemærkninger for Auto-Skip"
},
"noticeVisibilityMode4": {
"message": "Alle Faded Skip-Bemærkninger"
},
"longDescription": {
"message": "SponsoBlock lader dig skippe sponsorer, introer, outroer, abonnement påmindelser og andre irriterende dele af YouTube-Videoer. SponsorBlock er en crowdsourced browerudvidelse, hvor alle kan indsende start- og sluttidspunkter for sponsorerede og andre segmenter i YouTube-Videoer. Du kan også springe over de dele af musikvideoer, som ikke er musik.",
"description": "Full description of the extension on the store pages."
},
"website": {
"message": "Hjemmeside",
"description": "Used on Firefox Store Page"
},
"sourceCode": {
"message": "Kildekode",
"description": "Used on Firefox Store Page"
},
"noticeUpdate": {
"message": "Meddelelsen er blevet opgraderet!",
"description": "The first line of the message displayed after the notice was upgraded."
},
"noticeUpdate2": {
"message": "Hvis du stadig ikke kan lide det, så tryk på aldrig vis knappen.",
"description": "The second line of the message displayed after the notice was upgraded."
},
"setSkipShortcut": {
"message": "Indstil tast for at springe et segment over"
},
"setStartSponsorShortcut": {
"message": "Indstil tast til start/stop segment tastaturbinding"
},
"setSubmitKeybind": {
"message": "Indstil tast til indsendelse tastaturbinding"
},
"keybindDescription": {
"message": "Vælg en tast ved at skrive den"
},
"keybindDescriptionComplete": {
"message": "Tastaturbindingen er blevet sat til: "
},
"0": {
"message": "Forbindelsestimeout. Tjek din internetforbindelse. Hvis dit internet fungerer, er serveren sandsynligvis overbelastet eller nede."
},
"disableSkipping": {
"message": "Spring over er aktiveret"
},
"enableSkipping": {
"message": "Spring over er deaktiveret"
},
"yourWork": {
"message": "Dit Arbejde",
"description": "Used to describe the section that will show you the statistics from your submissions."
},
"502": {
"message": "Serveren virker at være overbelastet. Prøv igen om et par sekunder."
},
"errorCode": {
"message": "Fejlkode: "
},
"skip": {
"message": "Spring Over"
},
"mute": {
"message": "Gør Tavs"
},
"skip_category": {
"message": "Spring {0} over?"
},
"mute_category": {
"message": "Gør {0} tavs?"
},
"skip_to_category": {
"message": "Spring til {0}?",
"description": "Used for skipping to things (Skip to Highlight)"
},
"skipped": {
"message": "{0} Sprunget Over",
"description": "Example: Sponsor Skipped"
},
"muted": {
"message": "{0} Tavsgjort",
"description": "Example: Sponsor Muted"
},
"skipped_to_category": {
"message": "Skipped til {0}",
"description": "Used for skipping to things (Skipped to Highlight)"
},
"disableAutoSkip": {
"message": "Deaktiver Auto-Skip"
},
"enableAutoSkip": {
"message": "Aktiver Auto-Skip"
},
"audioNotification": {
"message": "Lydnofikation på Skip"
},
"audioNotificationDescription": {
"message": "Lydnotifikation ved skip vil spille en lyd når et segment skippes. Hvis deaktiveret (eller auto-skip er deaktiveret) vil ingen lyd blive spillet."
},
"showTimeWithSkips": {
"message": "Vis Tid Med Skip Fjernet"
},
"showTimeWithSkipsDescription": {
"message": "Denne tid vises i parantes ved siden af den aktuelle tid under søgelinjen. Dette viser den totale videovarighed minus alle segmenter. Dette inkluderer segmenter markeret som kun \"Vis I Søgelinjen\"."
},
"youHaveSkipped": {
"message": "Du har sprunget over "
},
"youHaveSaved": {
"message": "Du har gemt dig selv "
},
"minLower": {
"message": "minut"
},
"minsLower": {
"message": "minutter"
},
"hourLower": {
"message": "time"
},
"hoursLower": {
"message": "timer"
},
"youHaveSavedTime": {
"message": "Du har sparret folk"
},
"youHaveSavedTimeEnd": {
"message": " af deres liv"
},
"statusReminder": {
"message": "Tjek status.sponsor.ajay.app for serverstatus."
},
"changeUserID": {
"message": "Importer/Eksporter Dit Bruger-ID"
},
"whatChangeUserID": {
"message": "Dette bør holdes privat. Det er ligesom en adgangskode og bør ikke deles med nogen. Hvis nogen har dette, kan de udgive sig for at være dig. Hvis du leder efter dit offentlige bruger-ID, skal du klikke på udklipsholderikonet i popup-vinduet."
},
"setUserID": {
"message": "Indstil Bruger-ID"
},
"userIDChangeWarning": {
"message": "Advarsel: Ændring af Bruger-IDet er permanent. Er du sikker på, at du vil gøre det? Sørg for at sikkerhedskopiere din gamle for en sikkerheds skyld."
},
"createdBy": {
"message": "Oprettet Af"
},
"keybindCurrentlySet": {
"message": ". Det er i øjeblikket sat til:"
},
"supportOtherSites": {
"message": "Understøtter tredjeparts YouTube sider"
},
"supportOtherSitesDescription": {
"message": "Understøt tredjeparts YouTube klienter. For at aktivere understøttelse, skal du acceptere de ekstra tilladelser. Dette virker IKKE i inkognito på Chrome og andre Chromium varianter.",
"description": "This replaces the 'supports Invidious' option because it now works on other YouTube sites such as Cloudtube"
},
"supportedSites": {
"message": "Understøttede Sider: "
},
"optionsInfo": {
"message": "Aktiver Invidious understøttelse, deaktiver auto spring over, skjul knapper og mere."
},
"addInvidiousInstance": {
"message": "Tilføj Tredjeparts Klientinstans"
},
"addInvidiousInstanceDescription": {
"message": "Tilføj brugerdefineret instans. Dette skal formateres med KUN domænet. Eksempel: invidious.ajay.app"
},
"add": {
"message": "Tilføj"
},
"addInvidiousInstanceError": {
"message": "Dette er et ugyldigt domæne. Dette bør KUN omfatte domænedele. Eksempel: invidious.ajay.app"
},
"resetInvidiousInstance": {
"message": "Nulstil Liste over Invidious-Instanser"
},
"resetInvidiousInstanceAlert": {
"message": "Du er ved at nulstille listen over Invidious-instancer"
},
"currentInstances": {
"message": "Nuværende Instans:"
},
"minDuration": {
"message": "Minimumsvarighed (sekunder):"
},
"minDurationDescription": {
"message": "Segmenter kortere end den indstillede værdi vil ikke blive sprunget over eller vist i spilleren."
},
"skipNoticeDuration": {
"message": "Spring meddelelsesvarighed over (sekunder):"
},
"save": {
"message": "Gem"
},
"reset": {
"message": "Nulstil"
},
"areYouSureReset": {
"message": "Er du sikker på, at du ønsker at nulstille dette?"
},
"mobileUpdateInfo": {
"message": "m.youtube.com understøttes nu"
},
"exportOptions": {
"message": "Importer/Eksporter Alle Indstillinger"
},
"setOptions": {
"message": "Indstil Indstillinger"
},
"confirmNoticeTitle": {
"message": "Indsend Segment"
},
"submit": {
"message": "Indsend"
},
"cancel": {
"message": "Annuller"
},
"delete": {
"message": "Slet"
},
"preview": {
"message": "Forhåndsvisning"
},
"unsubmitted": {
"message": "Ikke Indsendt"
},
"inspect": {
"message": "Undersøg"
},
"edit": {
"message": "Rediger"
},
"theKey": {
"message": "Tasten"
},
"to": {
"message": "til",
"description": "Used between segments. Example: 1:20 to 1:30"
},
"category_sponsor": {
"message": "Sponsor"
},
"category_selfpromo": {
"message": "Ubetalt/Egen Markedsføring"
},
"category_interaction": {
"message": "Påmindelse Om Interaktion (Abonnement)"
},
"category_interaction_short": {
"message": "Påmindelse Om Interaktion"
},
"category_intro": {
"message": "Pause/Intro-Animation"
},
"category_intro_short": {
"message": "Pause"
},
"category_outro": {
"message": "Slutkort/Kreditter"
},
"category_preview": {
"message": "Forhåndsvisning/Opsamling"
},
"skipOption": {
"message": "Spring Over Indstillinger",
"description": "Used on the options page to describe the ways to skip the segment (auto skip, manual, etc.)"
},
"enableTestingServer": {
"message": "Aktiver Betatestserver"
},
"bracketNow": {
"message": "(Nu)"
},
"moreCategories": {
"message": "Flere Kategorier"
},
"chooseACategory": {
"message": "Vælg en Kategori"
},
"bracketEnd": {
"message": "(Slut)"
},
"hiddenDueToDownvote": {
"message": "skjult: downvote"
},
"hiddenDueToDuration": {
"message": "skjult: for kort"
},
"acceptPermission": {
"message": "Accepter tilladelse"
},
"permissionRequestSuccess": {
"message": "Tilladelsesandmodning lykkedes!"
},
"permissionRequestFailed": {
"message": "Tilladelsesanmodning mislykkedes, klikkede du på afvis?"
},
"downvoteDescription": {
"message": "Ukorrekt/Forkert Timing"
},
"incorrectCategory": {
"message": "Skift Kategori"
},
"multipleSegments": {
"message": "Adskillige Segmenter"
},
"guidelines": {
"message": "Retningslinjer"
},
"readTheGuidelines": {
"message": "Læs Retningslinjerne!!",
"description": "Show the first time they submit or if they are \"high risk\""
},
"categoryUpdate1": {
"message": "Kategorier er her!"
},
"help": {
"message": "Hjælp"
},
"GotIt": {
"message": "Forstået",
"description": "Used as the button to dismiss a tooltip"
},
"experiementOptOut": {
"message": "Fravælg alle fremtidige eksperimenter",
"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": {
"message": "Skjul for evigt"
},
"Donate": {
"message": "Doner"
},
"hideDonationLink": {
"message": "Skjul Donationslink"
},
"helpPageThanksForInstalling": {
"message": "Tak for at installere SponsorBlock."
},
"helpPageReviewOptions": {
"message": "Venligst gennemgå indstillingerne nedenfor"
},
"helpPageHowSkippingWorks": {
"message": "Hvordan spring over virker"
},
"Submitting": {
"message": "Indsendelse"
},
"Editing": {
"message": "Redigering"
} }
} }

View File

@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Neu! Überspringe Nebensächliches und Witze mit der Füller-Kategorie. Aktiviere sie in den Optionen" "message": "Neu! Überspringe Nebensächliches und Witze mit der Füller-Kategorie. Aktiviere sie in den Optionen"
},
"dayAbbreviation": {
"message": "T",
"description": "100d"
},
"hourAbbreviation": {
"message": "S",
"description": "100h"
} }
} }

View File

@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "New! Skip tangents and jokes with the filler category. Enable in options" "message": "New! Skip tangents and jokes with the filler category. Enable in options"
},
"dayAbbreviation": {
"message": "d",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -4,7 +4,7 @@
"description": "Name of the extension." "description": "Name of the extension."
}, },
"Description": { "Description": {
"message": "Salte todos los patrocinios, súplicas por suscripción y más en los vídeos de YouTube. Reporta secciones de patrocinio en los vídeos que veas para ahorrarle tiempo a los demás.", "message": "Salte todos los sponsors, súplicas de suscripción y más en vídeos de YouTube. Reporta sponsors en los vídeos que veas para ahorrarle tiempo a los demás.",
"description": "Description of the extension." "description": "Description of the extension."
}, },
"400": { "400": {
@@ -26,13 +26,13 @@
"message": "segmentos" "message": "segmentos"
}, },
"upvoteButtonInfo": { "upvoteButtonInfo": {
"message": "Votar a favor de esta sumisión" "message": "Votar positivamente este envío"
}, },
"reportButtonTitle": { "reportButtonTitle": {
"message": "Denunciar" "message": "Reportar"
}, },
"reportButtonInfo": { "reportButtonInfo": {
"message": "Denunciar esta sumisión como incorrecta." "message": "Reportar este envío como incorrecto."
}, },
"Dismiss": { "Dismiss": {
"message": "Descartar" "message": "Descartar"
@@ -53,7 +53,7 @@
"message": "Volver a saltar" "message": "Volver a saltar"
}, },
"unmute": { "unmute": {
"message": "Restaurar sonido" "message": "Quitar silencio"
}, },
"paused": { "paused": {
"message": "Pausado" "message": "Pausado"
@@ -156,7 +156,7 @@
"message": "Esto se utiliza en la página de estadísticas públicas para mostrar cuánto has contribuido. Véala" "message": "Esto se utiliza en la página de estadísticas públicas para mostrar cuánto has contribuido. Véala"
}, },
"Username": { "Username": {
"message": "Usuario" "message": "Nombre de Usuario"
}, },
"setUsername": { "setUsername": {
"message": "Escoger Nombre De Usuario" "message": "Escoger Nombre De Usuario"
@@ -204,7 +204,7 @@
"message": "Habilitar el conteo de omisiones" "message": "Habilitar el conteo de omisiones"
}, },
"whatViewTracking": { "whatViewTracking": {
"message": "Esta función rastrea los segmentos que se han saltado para que los usuarios sepan en qué medida sus aportes ayudaron a los demás y se utilizan como una métrica junto con los votos favorables para garantizar que no aparezca spam en la base de datos. La extensión envía un mensaje al servidor cada vez que se salta un segmento. Esperemos que la mayoría de la gente no cambie esta configuración para que los números de vista sean exactos. :)" "message": "Esta función rastrea los segmentos que se han saltado para que los usuarios sepan en qué medida sus envíos ayudaron a los demás y se utilizan como una métrica junto con los votos positivos para garantizar que no aparezca spam en la base de datos. La extensión envía un mensaje al servidor cada vez que se salta un segmento. Esperemos que la mayoría de la gente no cambie esta configuración para que los números de vistas sean exactos. :)"
}, },
"enableViewTrackingInPrivate": { "enableViewTrackingInPrivate": {
"message": "Activar el seguimiento del número de saltos en las pestañas privadas/de incógnito" "message": "Activar el seguimiento del número de saltos en las pestañas privadas/de incógnito"
@@ -269,13 +269,13 @@
"message": "Establecer tecla para iniciar/detener un segmento" "message": "Establecer tecla para iniciar/detener un segmento"
}, },
"setSubmitKeybind": { "setSubmitKeybind": {
"message": "Establecer botón de envío" "message": "Establecer tecla para el envío"
}, },
"keybindDescription": { "keybindDescription": {
"message": "Seleccione un botón escribiéndolo" "message": "Seleccione una tecla escribiéndola"
}, },
"keybindDescriptionComplete": { "keybindDescriptionComplete": {
"message": "El botón se ha establecido a: " "message": "Ese atajo de teclas se ha establecido como: "
}, },
"0": { "0": {
"message": "Tiempo de espera agotado. Compruebe su conexión a Internet. Si su internet está funcionando, el servidor probablemente esta sobrecargado o desconectado." "message": "Tiempo de espera agotado. Compruebe su conexión a Internet. Si su internet está funcionando, el servidor probablemente esta sobrecargado o desconectado."
@@ -434,7 +434,7 @@
"message": "El aviso de omisión permanecerá en la pantalla por lo menos este tiempo. Si la omisión es manual, podría ser visible por más tiempo." "message": "El aviso de omisión permanecerá en la pantalla por lo menos este tiempo. Si la omisión es manual, podría ser visible por más tiempo."
}, },
"shortCheck": { "shortCheck": {
"message": "La siguiente sumisión es más corto que su opción de duración mínima. Esto podría significar que esto ya se ha enviado y que simplemente se ha ignorado debido a esta opción. ¿Está seguro de que desea enviar?" "message": "El siguiente envío es más corto que su opción de duración mínima. Esto podría significar que esto ya se ha enviado y que simplemente se ha ignorado debido a esta opción. ¿Está seguro de que desea enviar?"
}, },
"showUploadButton": { "showUploadButton": {
"message": "Mostrar botón de subida" "message": "Mostrar botón de subida"
@@ -512,10 +512,10 @@
"message": "La información de depuración ha sido copiada al portapapeles. Siéntase libre de eliminar cualquier información que prefiera no compartir. Guarde esto en un archivo de texto o péguelo en el informe de errores." "message": "La información de depuración ha sido copiada al portapapeles. Siéntase libre de eliminar cualquier información que prefiera no compartir. Guarde esto en un archivo de texto o péguelo en el informe de errores."
}, },
"theKey": { "theKey": {
"message": "El botón" "message": "La tecla"
}, },
"keyAlreadyUsed": { "keyAlreadyUsed": {
"message": "está enlazado a otra acción. Por favor, seleccione otro botón." "message": "está enlazada a otra acción. Por favor, seleccione otra tecla."
}, },
"to": { "to": {
"message": "a", "message": "a",
@@ -525,7 +525,7 @@
"message": "Sponsor" "message": "Sponsor"
}, },
"category_sponsor_description": { "category_sponsor_description": {
"message": "Promoción pagada, referencias pagadas y anuncios directos. No para autopromoción o anuncios gratuitos a causas/creadores/sitios web/productos que les gusten." "message": "Promoción pagada, recomendaciones pagadas y anuncios directos. No para promoción propia o anuncios gratuitos a causas/creadores/sitios web/productos que les gusten."
}, },
"category_selfpromo": { "category_selfpromo": {
"message": "Promoción Propia/No Remunerada" "message": "Promoción Propia/No Remunerada"
@@ -563,6 +563,15 @@
"category_preview_description": { "category_preview_description": {
"message": "Recapitulación rápida de los episodios anteriores, o una vista previa de lo que va a ocurrir más adelante en el vídeo actual. Está pensado para clips editados juntos, no para resúmenes hablados." "message": "Recapitulación rápida de los episodios anteriores, o una vista previa de lo que va a ocurrir más adelante en el vídeo actual. Está pensado para clips editados juntos, no para resúmenes hablados."
}, },
"category_filler": {
"message": "Tangente de Relleno"
},
"category_filler_description": {
"message": "Escenas tangenciales añadidas solo para relleno o humor que no son necesarias para entender el contenido principal del video. Esto no debe incluir segmentos que proporcionen contexto o detalles de fondo."
},
"category_filler_short": {
"message": "Relleno"
},
"category_music_offtopic": { "category_music_offtopic": {
"message": "Música: Sección sin musica" "message": "Música: Sección sin musica"
}, },
@@ -719,7 +728,7 @@
"message": "¡Las categorías están aquí!" "message": "¡Las categorías están aquí!"
}, },
"categoryUpdate2": { "categoryUpdate2": {
"message": "Abre las opciones de saltarse intros, otros, mercantil, etc." "message": "Abre las opciones de saltarse intros, outros, mercancía, etc."
}, },
"help": { "help": {
"message": "Ayuda" "message": "Ayuda"
@@ -825,5 +834,16 @@
}, },
"SponsorTimeEditScrollNewFeature": { "SponsorTimeEditScrollNewFeature": {
"message": "Utilice la rueda del ratón mientras pasa el cursor por encima del cuadro de edición para ajustar el tiempo. Se pueden utilizar combinaciones de la tecla ctrl o shift para afinar los cambios." "message": "Utilice la rueda del ratón mientras pasa el cursor por encima del cuadro de edición para ajustar el tiempo. Se pueden utilizar combinaciones de la tecla ctrl o shift para afinar los cambios."
},
"fillerNewFeature": {
"message": "¡Nuevo! Omite tangentes y bromas con la categoría de relleno. Habilítala en opciones"
},
"dayAbbreviation": {
"message": "d",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -816,5 +816,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Uus! Jäta täitesisu ja naljad vahele täitesisu kategooriaga. Luba valikutes" "message": "Uus! Jäta täitesisu ja naljad vahele täitesisu kategooriaga. Luba valikutes"
},
"dayAbbreviation": {
"message": "p",
"description": "100d"
},
"hourAbbreviation": {
"message": "t",
"description": "100h"
} }
} }

View File

@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Uutta! Ohita epäolennaiset kohdat ja vitsit täytesisältö kategorialla. Ota se käyttöön asetuksista" "message": "Uutta! Ohita epäolennaiset kohdat ja vitsit täytesisältö kategorialla. Ota se käyttöön asetuksista"
},
"dayAbbreviation": {
"message": "pv",
"description": "100d"
},
"hourAbbreviation": {
"message": "t",
"description": "100h"
} }
} }

View File

@@ -183,7 +183,7 @@
"message": "Cela permet de cacher du lecteur YouTube les boutons utilisés pour soumettre des segments commerciaux. Je peux \ncomprendre que certaines personnes les trouvent perturbants. Au lieu d'utiliser ces boutons, cette fenêtre peut être utilisée \npour soumettre des segments commerciaux. Pour cacher la notification, utilisez le bouton \"Ne plus montrer\" sur la notification. Vous pouvez toujours réactiver ces paramètres plus tard." "message": "Cela permet de cacher du lecteur YouTube les boutons utilisés pour soumettre des segments commerciaux. Je peux \ncomprendre que certaines personnes les trouvent perturbants. Au lieu d'utiliser ces boutons, cette fenêtre peut être utilisée \npour soumettre des segments commerciaux. Pour cacher la notification, utilisez le bouton \"Ne plus montrer\" sur la notification. Vous pouvez toujours réactiver ces paramètres plus tard."
}, },
"showSkipButton": { "showSkipButton": {
"message": "Conserver le bouton \"Aller au point d'intérêt\" sur le lecteur" "message": "Conserver le bouton \"Aller au point essentiel\" sur le lecteur"
}, },
"showInfoButton": { "showInfoButton": {
"message": "Montrer le bouton Info sur le lecteur YouTube" "message": "Montrer le bouton Info sur le lecteur YouTube"
@@ -528,7 +528,7 @@
"message": "Promotion rémunérée, parrainage rémunéré et publicité directe. Pas pour l'autopromotion ou les présentations gratuites de causes, de créateurs, de sites web ou de produits qu'ils aiment." "message": "Promotion rémunérée, parrainage rémunéré et publicité directe. Pas pour l'autopromotion ou les présentations gratuites de causes, de créateurs, de sites web ou de produits qu'ils aiment."
}, },
"category_selfpromo": { "category_selfpromo": {
"message": "Promotion non rémunérée/autopromotion" "message": "Non rémunéré/autopromotion"
}, },
"category_selfpromo_description": { "category_selfpromo_description": {
"message": "Semblable au \"sponsor\", excepté pour la promotion non rémunérée ou l'auto-promotion. Cela inclut les marchandises, les dons et les informations sur leurs collaborateurs." "message": "Semblable au \"sponsor\", excepté pour la promotion non rémunérée ou l'auto-promotion. Cela inclut les marchandises, les dons et les informations sur leurs collaborateurs."
@@ -563,6 +563,15 @@
"category_preview_description": { "category_preview_description": {
"message": "Résumé rapide des épisodes précédents, ou aperçu de ce qui se passera plus tard dans la vidéo en cours. Pour les plans collectifs édités, pas pour les résumés parlés." "message": "Résumé rapide des épisodes précédents, ou aperçu de ce qui se passera plus tard dans la vidéo en cours. Pour les plans collectifs édités, pas pour les résumés parlés."
}, },
"category_filler": {
"message": "Digressions"
},
"category_filler_description": {
"message": "Des digressions ajoutées uniquement pour le remplissage ou l'humour qui ne sont pas requis pour comprendre le contenu principal de la vidéo. Cela ne devrait pas inclure des segments fournissant du contexte ou des détails de fond."
},
"category_filler_short": {
"message": "Remplissage"
},
"category_music_offtopic": { "category_music_offtopic": {
"message": "Musique : Segment non musical" "message": "Musique : Segment non musical"
}, },
@@ -573,7 +582,7 @@
"message": "Hors musique" "message": "Hors musique"
}, },
"category_poi_highlight": { "category_poi_highlight": {
"message": "Surligner" "message": "Point essentiel"
}, },
"category_poi_highlight_description": { "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\"." "message": "La partie de la vidéo que la plupart des gens veulent voir. Similaire à \"la vidéo commence à x mins\"."
@@ -651,7 +660,7 @@
"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": { "poiOnlyOneSegment": {
"message": "Avertissement : Ce type de segment ne peut avoir qu'un seul segment actif à la fois. Si vous en soumettez plusieurs, le choix sera fait au hasard." "message": "Avertissement: Ce type de segment peut avoir au maximum un seul actif à la fois. En soumettant plusieurs segments, un seul aléatoire sera affiché."
}, },
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Vous devez sélectionner une catégorie pour tous les segments que vous soumettez !" "message": "Vous devez sélectionner une catégorie pour tous les segments que vous soumettez !"
@@ -809,7 +818,7 @@
"message": "En savoir plus" "message": "En savoir plus"
}, },
"CopyDownvoteButtonInfo": { "CopyDownvoteButtonInfo": {
"message": "Vote négatif et crée une copie locale que vous pouvez soumettre à nouveau" "message": "Voter contre et crée une copie locale pour la resoumettre"
}, },
"OpenCategoryWikiPage": { "OpenCategoryWikiPage": {
"message": "Ouvrez la page wiki de cette catégorie." "message": "Ouvrez la page wiki de cette catégorie."
@@ -825,5 +834,16 @@
}, },
"SponsorTimeEditScrollNewFeature": { "SponsorTimeEditScrollNewFeature": {
"message": "Utilisez la molette de votre souris en survolant la boîte d'édition pour ajuster rapidement le minutage. Les combinaisons de touches Ctrl ou Shift peuvent être utilisées pour affiner les modifications." "message": "Utilisez la molette de votre souris en survolant la boîte d'édition pour ajuster rapidement le minutage. Les combinaisons de touches Ctrl ou Shift peuvent être utilisées pour affiner les modifications."
},
"fillerNewFeature": {
"message": "Nouveau ! Ignorer les digressions et les blagues avec la catégorie \"remplissage\". Activable dans les options"
},
"dayAbbreviation": {
"message": "j",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -152,6 +152,10 @@
"hideInfoButton": { "hideInfoButton": {
"message": "החבא כפתור מידע בנגן YouTube" "message": "החבא כפתור מידע בנגן YouTube"
}, },
"website": {
"message": "אתר",
"description": "Used on Firefox Store Page"
},
"sourceCode": { "sourceCode": {
"message": "קוד מקור", "message": "קוד מקור",
"description": "Used on Firefox Store Page" "description": "Used on Firefox Store Page"

View File

@@ -128,7 +128,7 @@
"message": "Glasaj za isječak" "message": "Glasaj za isječak"
}, },
"Submissions": { "Submissions": {
"message": "Podnesci" "message": "Prijava"
}, },
"savedPeopleFrom": { "savedPeopleFrom": {
"message": "Sačuvali ste ljude od" "message": "Sačuvali ste ljude od"
@@ -174,22 +174,34 @@
"message": "Opcije" "message": "Opcije"
}, },
"showButtons": { "showButtons": {
"message": "Pokažite gumbove na YouTube Player-u" "message": "Prikaži gumbe na YouTube Playeru"
}, },
"hideButtons": { "hideButtons": {
"message": "Sakrite gumbove na YouTube Player-u" "message": "Sakrij gumbe na YouTube playeru"
}, },
"hideButtonsDescription": { "hideButtonsDescription": {
"message": "Ovo sakrije gumbove za pridonose segmenta za preskočiti koje se pokažu na YouTuve Player-u." "message": "Ovo skriva gumbe koji se pojavljuju na YouTube playeru za slanje odsječaka za preskakanje."
}, },
"showSkipButton": { "showSkipButton": {
"message": "Ostavite gumb za preskakanje" "message": "Zadržite gumb za preskakanje i označavanje na playeru"
}, },
"showInfoButton": { "showInfoButton": {
"message": "Pokažite gumb za Informacije na YouTube Player-u" "message": "Prikaži gumb za informacije na YouTube Playeru"
}, },
"hideInfoButton": { "hideInfoButton": {
"message": "Sakrijte gumb za Informacije na YouTube Player-u" "message": "Sakrij gumb za informacije na YouTube Playeru"
},
"autoHideInfoButton": {
"message": "Automatski sakrij info gumb"
},
"hideDeleteButton": {
"message": "Sakrij gumb za brisanje na YouTube playeru"
},
"showDeleteButton": {
"message": "Pokaži gumb za brisanje na YouTube sviraču"
},
"enableViewTracking": {
"message": "Omogući brojanje preskakanja"
}, },
"showSkipNotice": { "showSkipNotice": {
"message": "Pokaži obavijest nakon preskakanja isječka" "message": "Pokaži obavijest nakon preskakanja isječka"
@@ -202,6 +214,9 @@
"message": "Izvorni kod", "message": "Izvorni kod",
"description": "Used on Firefox Store Page" "description": "Used on Firefox Store Page"
}, },
"0": {
"message": "Veza istekla. Provjerite svoju internetski vezu. Ako vaš internet radi, poslužitelj je vjerojatno preopterećen ili nedostupan."
},
"disableSkipping": { "disableSkipping": {
"message": "Preskakanje je aktivirano" "message": "Preskakanje je aktivirano"
}, },
@@ -212,6 +227,9 @@
"message": "Tvoja slanja", "message": "Tvoja slanja",
"description": "Used to describe the section that will show you the statistics from your submissions." "description": "Used to describe the section that will show you the statistics from your submissions."
}, },
"502": {
"message": "Čini se da je poslužitelj preopterećen. Pokušajte ponovno za nekoliko sekundi."
},
"errorCode": { "errorCode": {
"message": "Kȏd greške: " "message": "Kȏd greške: "
}, },
@@ -221,6 +239,17 @@
"skip_category": { "skip_category": {
"message": "Preskočiti {0}?" "message": "Preskočiti {0}?"
}, },
"mute_category": {
"message": "Utišati {0}?"
},
"skip_to_category": {
"message": "Preskočiti na {0}?",
"description": "Used for skipping to things (Skip to Highlight)"
},
"skipped_to_category": {
"message": "Preskočeno na {0}",
"description": "Used for skipping to things (Skipped to Highlight)"
},
"disableAutoSkip": { "disableAutoSkip": {
"message": "Deaktiviraj automatsko preskakanje" "message": "Deaktiviraj automatsko preskakanje"
}, },
@@ -239,6 +268,9 @@
"hoursLower": { "hoursLower": {
"message": "h" "message": "h"
}, },
"statusReminder": {
"message": "Provjerite status.sponsor.ajay.app za status poslužitelja."
},
"setUserID": { "setUserID": {
"message": "Postavi UserID" "message": "Postavi UserID"
}, },
@@ -251,6 +283,9 @@
"keybindCurrentlySet": { "keybindCurrentlySet": {
"message": ". Trenutno je postavljeno na:" "message": ". Trenutno je postavljeno na:"
}, },
"supportedSites": {
"message": "Podržane stranice: "
},
"optionsInfo": { "optionsInfo": {
"message": "Omogući podržavanje Invidiousa, onemogući automatsko preskakanje, sakrij gumbe i drugo." "message": "Omogući podržavanje Invidiousa, onemogući automatsko preskakanje, sakrij gumbe i drugo."
}, },
@@ -275,12 +310,24 @@
"minDurationDescription": { "minDurationDescription": {
"message": "Isječci kraći od postavljene vrijednosti neće biti preskočeni ili prikazani u playeru." "message": "Isječci kraći od postavljene vrijednosti neće biti preskočeni ili prikazani u playeru."
}, },
"skipNoticeDuration": {
"message": "Duljina trajanja obavijesti o preskakanju (sekunde):"
},
"skipNoticeDurationDescription": {
"message": "Obavijest o preskakanju ostat će na zaslonu barem ovoliko dugo. Za ručno preskakanje može biti duže vidljivo."
},
"customServerAddress": {
"message": "Adresa SponsorBlock poslužitelja"
},
"save": { "save": {
"message": "Spremi" "message": "Spremi"
}, },
"reset": { "reset": {
"message": "Resetiraj" "message": "Resetiraj"
}, },
"exportOptions": {
"message": "Uvezi/Izvezi sve postavke"
},
"setOptions": { "setOptions": {
"message": "Postavi opcije" "message": "Postavi opcije"
}, },
@@ -299,15 +346,34 @@
"preview": { "preview": {
"message": "Pregledaj" "message": "Pregledaj"
}, },
"unsubmitted": {
"message": "Neposlano"
},
"inspect": { "inspect": {
"message": "Provjeri" "message": "Provjeri"
}, },
"edit": { "edit": {
"message": "Uredi" "message": "Uredi"
}, },
"copyDebugInformationOptions": {
"message": "Kopira informacije u međuspremnik koje treba dati razvojnom programeru kada otkrije grešku / kada to programer zatraži. Osjetljive informacije kao što su vaš korisnički ID, kanali s popisa dopuštenih i prilagođena adresa poslužitelja uklonjeni su. Međutim, sadrži informacije kao što su vaš korisnički agent, preglednik, operativni sustav i broj verzije proširenja. "
},
"theKey": {
"message": "Tipka"
},
"keyAlreadyUsed": {
"message": "je vezana za drugu radnju. Molimo odaberite drugu tipku."
},
"to": {
"message": "do",
"description": "Used between segments. Example: 1:20 to 1:30"
},
"category_sponsor": { "category_sponsor": {
"message": "Sponzor" "message": "Sponzor"
}, },
"category_sponsor_description": {
"message": "Plaćene promocije, plaćene preporuke i izravne reklame. Nije za samopromociju ili besplatno pozivanje na događaje/kreatore/web stranice/proizvode koji im se sviđaju."
},
"category_selfpromo": { "category_selfpromo": {
"message": "Neplaćena promocija ili samopromocija" "message": "Neplaćena promocija ili samopromocija"
}, },
@@ -332,6 +398,15 @@
"category_outro": { "category_outro": {
"message": "Završni kadrovi/Zasluge" "message": "Završni kadrovi/Zasluge"
}, },
"category_preview": {
"message": "Pregled/Sažetak"
},
"category_filler": {
"message": "Popuna tangenti"
},
"category_filler_short": {
"message": "Popuna"
},
"category_music_offtopic": { "category_music_offtopic": {
"message": "Glazba: Ne-glazbeni dio" "message": "Glazba: Ne-glazbeni dio"
}, },
@@ -341,12 +416,28 @@
"category_music_offtopic_short": { "category_music_offtopic_short": {
"message": "Ne-glazbeni" "message": "Ne-glazbeni"
}, },
"category_poi_highlight": {
"message": "Istaknuto"
},
"category_livestream_messages": {
"message": "Livestream: čitanje donacija/poruka"
},
"category_livestream_messages_short": {
"message": "Čitanje poruka"
},
"autoSkip": { "autoSkip": {
"message": "Automatsko preskakanje" "message": "Automatsko preskakanje"
}, },
"manualSkip": { "manualSkip": {
"message": "Ručno preskakanje" "message": "Ručno preskakanje"
}, },
"muteSegments": {
"message": "Dopustite isječke koji isključuju zvuk umjesto da ga preskaču"
},
"previewColor": {
"message": "Boja neposlanog",
"description": "Referring to submissions that have not been sent to the server yet."
},
"category": { "category": {
"message": "Kategorija" "message": "Kategorija"
}, },
@@ -354,6 +445,9 @@
"message": "Preskoči opciju", "message": "Preskoči opciju",
"description": "Used on the options page to describe the ways to skip the segment (auto skip, manual, etc.)" "description": "Used on the options page to describe the ways to skip the segment (auto skip, manual, etc.)"
}, },
"enableTestingServer": {
"message": "Omogućite poslužitelj za beta testiranje"
},
"bracketNow": { "bracketNow": {
"message": "(sada)" "message": "(sada)"
}, },
@@ -363,6 +457,10 @@
"chooseACategory": { "chooseACategory": {
"message": "Odaberi kategoriju" "message": "Odaberi kategoriju"
}, },
"enableThisCategoryFirst": {
"message": "Da biste poslali segmente s kategorijom \"{0}\", morate je omogućiti u postavkama. Sada ćete biti preusmjereni na postavke.",
"description": "Used when submitting segments to only let them select a certain category if they have it enabled in the options."
},
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Moraš odabrati kategoriju za sve segmente koje šalješ!" "message": "Moraš odabrati kategoriju za sve segmente koje šalješ!"
}, },
@@ -372,6 +470,9 @@
"downvoteDescription": { "downvoteDescription": {
"message": "Neispravno/krivo vrijeme" "message": "Neispravno/krivo vrijeme"
}, },
"incorrectCategory": {
"message": "Promijenite kategoriju"
},
"nonMusicCategoryOnMusic": { "nonMusicCategoryOnMusic": {
"message": "Ovaj je video kategoriziran kao glazba. Je li stvarno ima sponzora? Ako je ovo zapravo „Ne-glazbeni segment”, otvori opcije proširenja i aktiviraj ovu kategoriju. Zatim ovaj segment možeš posalti kao „Ne-glazbeni” umjesto sponzora. Pročitaj smjernice ako nešto nije jasno." "message": "Ovaj je video kategoriziran kao glazba. Je li stvarno ima sponzora? Ako je ovo zapravo „Ne-glazbeni segment”, otvori opcije proširenja i aktiviraj ovu kategoriju. Zatim ovaj segment možeš posalti kao „Ne-glazbeni” umjesto sponzora. Pročitaj smjernice ako nešto nije jasno."
}, },
@@ -390,5 +491,44 @@
}, },
"categoryUpdate2": { "categoryUpdate2": {
"message": "Otvori opcije za preskakanje uvoda, kraja, proizvoda itd." "message": "Otvori opcije za preskakanje uvoda, kraja, proizvoda itd."
},
"Donate": {
"message": "Doniraj"
},
"helpPageThanksForInstalling": {
"message": "Hvala na instaliranju SponsorBlocka."
},
"Submitting": {
"message": "Slanje"
},
"helpPageSubmitting2": {
"message": "Klikom na gumb za reprodukciju označava se početak segmenta, a klik na ikonu za zaustavljanje označava kraj. Možete pripremiti više sponzora prije nego što pritisnete \"Pošalji\". Klikom na gumb za slanje bit će poslano. Klikom na kantu za smeće izbrisat će se."
},
"Editing": {
"message": "Uređivanje"
},
"helpPageTooSlow": {
"message": "Ovo je presporo"
},
"helpPageSourceCode": {
"message": "Gdje mogu pronaći izvorni kod?"
},
"Credits": {
"message": "Zasluge"
},
"LearnMore": {
"message": "Saznajte više"
},
"OpenCategoryWikiPage": {
"message": "Otvorite wiki stranicu ove kategorije."
},
"CopyAndDownvote": {
"message": "Kopiraj i glasaj protiv"
},
"ContinueVoting": {
"message": "Nastavite glasati"
},
"ChangeCategoryTooltip": {
"message": "Ovo će se odmah primijeniti na vaše isječke"
} }
} }

View File

@@ -1,6 +1,6 @@
{ {
"fullName": { "fullName": {
"message": "SponorBlock YouTube-ra - Szponzorok átugrására", "message": "SponsorBlock YouTube-ra - Szponzorok átugrására",
"description": "Name of the extension." "description": "Name of the extension."
}, },
"Description": { "Description": {
@@ -11,7 +11,7 @@
"message": "Szerver: Ez a kérés érvénytelen" "message": "Szerver: Ez a kérés érvénytelen"
}, },
"429": { "429": {
"message": "Túl sok szponzoridőt jelölt be ezen a videón. Biztos benne, hogy van ennyi?" "message": "Túl sok szponzoridőt jelöltél be ezen a videón. Biztosan van ennyi?"
}, },
"409": { "409": {
"message": "Ez már korábban be lett küldve" "message": "Ez már korábban be lett küldve"
@@ -44,7 +44,7 @@
"message": "Ne mutassa többé" "message": "Ne mutassa többé"
}, },
"hitGoBack": { "hitGoBack": {
"message": "Kattintson a visszaugrásra, hogy visszakerüljön oda, ahonnan ugrott." "message": "Kattints a visszaugrásra, hogy visszakerülj oda, ahonnan ugrottál."
}, },
"unskip": { "unskip": {
"message": "Visszaugrás" "message": "Visszaugrás"
@@ -62,13 +62,13 @@
"message": "Időzítő megállítva" "message": "Időzítő megállítva"
}, },
"confirmMSG": { "confirmMSG": {
"message": "Ahhoz, hogy értékeket szerkesszen, vagy töröljön kattintson az info gombra, vagy nyissa meg a bővítmény felugró ablakát a bővítmény ikonjával a jobb felső sarokban." "message": "Az egyes értékek szerkesztéséhez vagy törléséhez kattints az info gombra, vagy nyisd meg a bővítmény felugró ablakát a bővítmény ikonjával a jobb felső sarokban."
}, },
"clearThis": { "clearThis": {
"message": "Biztosan törölni akarja?\n\n" "message": "Biztosan törölni szeretnéd?\n\n"
}, },
"Unknown": { "Unknown": {
"message": "Hiba történt a szponzoridők bejelentésekor. Kérjük, próbálja újra." "message": "Hiba történt a szponzoridők beküldésekor. Kérjük, próbáld újra később."
}, },
"sponsorFound": { "sponsorFound": {
"message": "Ennek a videónak már vannak szegmensei az adatbázisban!" "message": "Ennek a videónak már vannak szegmensei az adatbázisban!"
@@ -95,10 +95,10 @@
"message": "Siker!" "message": "Siker!"
}, },
"voted": { "voted": {
"message": "Szavazott!" "message": "Szavaztál!"
}, },
"serverDown": { "serverDown": {
"message": "Úgy tűnik a szerver nem működik. Kérjük, mihamarabb értesítse a fejlesztőket." "message": "Úgy tűnik, a szerver nem működik. Kérjük, mihamarabb értesítsd a fejlesztőket!"
}, },
"connectionError": { "connectionError": {
"message": "Kapcsolódási probléma merült fel. Hibakód: " "message": "Kapcsolódási probléma merült fel. Hibakód: "
@@ -113,10 +113,10 @@
"message": "Felugró ablak bezárása" "message": "Felugró ablak bezárása"
}, },
"SubmitTimes": { "SubmitTimes": {
"message": "Szegmens beküldése" "message": "Szegmensek beküldése"
}, },
"submitCheck": { "submitCheck": {
"message": "Biztosan be akarja küldeni?" "message": "Biztosan be akarod küldeni?"
}, },
"whitelistChannel": { "whitelistChannel": {
"message": "Csatorna fehérlistára tétele" "message": "Csatorna fehérlistára tétele"
@@ -137,7 +137,7 @@
"message": "Ranglista" "message": "Ranglista"
}, },
"recordTimesDescription": { "recordTimesDescription": {
"message": "Küldés" "message": "Beküldés"
}, },
"submissionEditHint": { "submissionEditHint": {
"message": "A szegmens szerkesztés azután fog megjelenni, hogy a beküldésre kattintasz", "message": "A szegmens szerkesztés azután fog megjelenni, hogy a beküldésre kattintasz",
@@ -153,7 +153,7 @@
"message": "Időpontok beküldése" "message": "Időpontok beküldése"
}, },
"publicStats": { "publicStats": {
"message": "Ezt használja a nyilvános ranglistán, hogy megmutassa mennyit járult hozzá. Nézze meg" "message": "Ez a nyilvános ranglistán használatos, ami mutatja, mennyit segítettél. Nézd meg"
}, },
"Username": { "Username": {
"message": "Felhasználónév" "message": "Felhasználónév"
@@ -165,7 +165,7 @@
"message": "Nyilvános UserID másolása" "message": "Nyilvános UserID másolása"
}, },
"discordAdvert": { "discordAdvert": {
"message": "Csatlakozzon a hivatalos discord szerverhez, hogy javaslatokat és visszajelzést adhasson!" "message": "Gyere, csatlakozz a hivatalos discord szerverhez, hogy javaslatokat és visszajelzést adhass!"
}, },
"hideThis": { "hideThis": {
"message": "Elrejtés" "message": "Elrejtés"
@@ -192,7 +192,7 @@
"message": "Info gomb elrejtése a YouTube lejátszón" "message": "Info gomb elrejtése a YouTube lejátszón"
}, },
"autoHideInfoButton": { "autoHideInfoButton": {
"message": "Automatikus elrejtése az Információ Gombnak" "message": "Info gomb automatikus elrejtése"
}, },
"hideDeleteButton": { "hideDeleteButton": {
"message": "Törlés gomb elrejtése a YouTube lejátszón" "message": "Törlés gomb elrejtése a YouTube lejátszón"
@@ -204,7 +204,7 @@
"message": "Átugrás-számláló követés bekapcsolása" "message": "Átugrás-számláló követés bekapcsolása"
}, },
"whatViewTracking": { "whatViewTracking": {
"message": "Ez a funkció követi, mely szegmenseket ugrotta át, hogy más felhasználók megtudhassák mennyit segítettek a bejelentéseik és a szavazatokkal együtt egy mértékegységként van használva, hogy ne kerülhessen spam az adatbázisba. A bővítmény küld egy üzenetet a szervernek, minden alkalommal, mikor átugrik egy szegmenst. Remélhetőleg nem sokan állítják át ezt a beállítást, hogy a számok pontosak maradhassanak. :)" "message": "Ez a funkció követi, mely szegmenseket ugrottad át, hogy a felhasználók megtudhassák mennyit segítettek a bejelentéseik, és a szavazatokkal együtt egy mértékegységként van használva, hogy ne kerülhessen szemét az adatbázisba. A bővítmény küld egy üzenetet a szervernek, minden alkalommal, mikor átugrasz egy szegmenst. Remélhetőleg nem sokan állítják át ezt a beállítást, hogy a számok pontosak maradhassanak. :)"
}, },
"enableViewTrackingInPrivate": { "enableViewTrackingInPrivate": {
"message": "Átugrások számlálásának engedélyezése privát/inkognitó füleken" "message": "Átugrások számlálásának engedélyezése privát/inkognitó füleken"
@@ -219,7 +219,7 @@
"message": "Szegmensek újrakeresése új videókon" "message": "Szegmensek újrakeresése új videókon"
}, },
"whatRefetchWhenNotFound": { "whatRefetchWhenNotFound": {
"message": "Ha a videó új, és még nem találhatóak szegmensek, a bővítmény pár percenkét újra keresi őket, miközben nézi." "message": "Ha a videó új, és még nem találhatóak szegmensek, a bővítmény pár percenkét újra keresi őket, miközben nézed."
}, },
"showNotice": { "showNotice": {
"message": "Értesítés megjelenítése ismét" "message": "Értesítés megjelenítése ismét"
@@ -243,7 +243,7 @@
"message": "Csak halvány átugrási értesítők" "message": "Csak halvány átugrási értesítők"
}, },
"longDescription": { "longDescription": {
"message": "A SponsorBlock-al átugorhatja a szponzorokat, introkat, outrokat, feliratkozás emlékeztetőket és a YouTube videók többi idegesítő részeit. A SponsorBlock egy közösség által vezérelt böngészőbővítmény, ami lehetővé tesz bárkit arra, hogy megjelölhesse egy szponzor vagy más szegmens kezdő és végpontjait. Ha megosztja ezt az információt, mindenki más ennek a bővítménynek a birtokában egyenesen átugorja majd ezt a szponzorszegmenst. Emellett például a zene videók nem-zene részei is átugorhatóak.", "message": "A SponsorBlockkal átugorhatja a szponzorokat, introkat, outrokat, feliratkozás emlékeztetőket és a YouTube videók többi idegesítő részeit. A SponsorBlock egy közösség által vezérelt böngészőbővítmény, ami lehetővé teszi bárkinek, hogy megjelölhesse egy szponzor vagy más szegmens kezdő és végpontjait. Amint valaki megosztja ezt az információt, mindenki más ennek a bővítménynek a birtokában egyenesen átugorja majd ezt a szponzorszegmenst. Emellett például a videóklipek nem-zene részei is átugorhatóak.",
"description": "Full description of the extension on the store pages." "description": "Full description of the extension on the store pages."
}, },
"website": { "website": {
@@ -259,7 +259,7 @@
"description": "The first line of the message displayed after the notice was upgraded." "description": "The first line of the message displayed after the notice was upgraded."
}, },
"noticeUpdate2": { "noticeUpdate2": {
"message": "Ha még mindig nem tetszik, kattintson a ne mutassa többé gombra.", "message": "Ha még mindig nem tetszik, kattints a ne mutassa többé gombra.",
"description": "The second line of the message displayed after the notice was upgraded." "description": "The second line of the message displayed after the notice was upgraded."
}, },
"setSkipShortcut": { "setSkipShortcut": {
@@ -272,13 +272,13 @@
"message": "Billentyű beállítása a beküldés gombhoz" "message": "Billentyű beállítása a beküldés gombhoz"
}, },
"keybindDescription": { "keybindDescription": {
"message": "Válasszon billentyűt azzal, hogy lenyomja" "message": "Válassz egy billentyűt azzal, hogy lenyomod"
}, },
"keybindDescriptionComplete": { "keybindDescriptionComplete": {
"message": "A funkció erre a billentyűre lett állítva: " "message": "A funkció erre a billentyűre lett állítva: "
}, },
"0": { "0": {
"message": "Kapcsolati időtúllépés. Ellenőrizze az internetkapcsolatot. Ha az internet működik, a kiszolgáló valószínűleg túlterhelt vagy leállt." "message": "Kapcsolati időtúllépés. Ellenőrizd az internetkapcsolatodat! Ha az internet működik, a kiszolgáló valószínűleg túlterhelt vagy leállt."
}, },
"disableSkipping": { "disableSkipping": {
"message": "Átugrás bekapcsolva" "message": "Átugrás bekapcsolva"
@@ -291,7 +291,7 @@
"description": "Used to describe the section that will show you the statistics from your submissions." "description": "Used to describe the section that will show you the statistics from your submissions."
}, },
"502": { "502": {
"message": "Úgy tűnik, hogy a szerver túlterhelt. Néhány másodperc múlva próbálkozzon újra." "message": "Úgy tűnik, hogy a szerver túlterhelt. Próbálkozz újra néhány másodperc múlva."
}, },
"errorCode": { "errorCode": {
"message": "Hibakód: " "message": "Hibakód: "
@@ -334,7 +334,7 @@
"message": "Hangjelzés átugráskor" "message": "Hangjelzés átugráskor"
}, },
"audioNotificationDescription": { "audioNotificationDescription": {
"message": "A hangjelzés átugráskor lejátszik egy hangot minden alkalommal amikor átugrik egy szegmenst. Ha kikapcsolja (vagy az auto átugrás ki van kapcsolva) nem lesz hangjelzés lejátszva." "message": "A hangjelzés átugráskor lejátszik egy hangot minden alkalommal, amikor egy szegmens átugrásra kerül. Ha kikapcsolod (vagy az auto átugrás ki van kapcsolva), nem lesz hangjelzés lejátszva."
}, },
"showTimeWithSkips": { "showTimeWithSkips": {
"message": "Idő megtekintése az átugrandók nélkül" "message": "Idő megtekintése az átugrandók nélkül"
@@ -346,7 +346,7 @@
"message": "Átugrottál: " "message": "Átugrottál: "
}, },
"youHaveSaved": { "youHaveSaved": {
"message": "Megtakarított magának " "message": "Megtakarítottál magadnak: "
}, },
"minLower": { "minLower": {
"message": "perc" "message": "perc"
@@ -367,7 +367,7 @@
"message": " az életükből" "message": " az életükből"
}, },
"statusReminder": { "statusReminder": {
"message": "A szerver állapotához tekintse meg a status.sponsor.ajay.app oldalt." "message": "A szerver állapotához tekintsd meg a status.sponsor.ajay.app oldalt."
}, },
"changeUserID": { "changeUserID": {
"message": "UserID importálása / exportálása" "message": "UserID importálása / exportálása"
@@ -379,7 +379,7 @@
"message": "UserID beállítása" "message": "UserID beállítása"
}, },
"userIDChangeWarning": { "userIDChangeWarning": {
"message": "Figyelem: A UserID megváltoztatása végleges. Biztosan szeretné megtenni? Minden esetben készítsen biztonsági másolatot a régiről." "message": "Figyelem: A UserID megváltoztatása végleges. Biztosan szeretnéd megtenni? Minden esetben készíts biztonsági másolatot a régiről!"
}, },
"createdBy": { "createdBy": {
"message": "Készítette" "message": "Készítette"
@@ -416,7 +416,7 @@
"message": "Invidious példányok listájának visszaállítása" "message": "Invidious példányok listájának visszaállítása"
}, },
"resetInvidiousInstanceAlert": { "resetInvidiousInstanceAlert": {
"message": "Épp visszaállítja az Invidious példányok listát" "message": "Az Invidious példányok listájának visszaállítására készülsz"
}, },
"currentInstances": { "currentInstances": {
"message": "Jelenlegi példányok:" "message": "Jelenlegi példányok:"
@@ -428,13 +428,13 @@
"message": "A beállított értéknél rövidebb szegmenseket nem ugorja át és nem jeleníti meg a lejátszó." "message": "A beállított értéknél rövidebb szegmenseket nem ugorja át és nem jeleníti meg a lejátszó."
}, },
"skipNoticeDuration": { "skipNoticeDuration": {
"message": "Átugrási értesítés hossza (másodpercek):" "message": "Átugrási értesítés hossza (másodpercekben):"
}, },
"skipNoticeDurationDescription": { "skipNoticeDurationDescription": {
"message": "Az átugrási értesítés ennyi ideig marad a képernyőn. Manuális átugrásnál tovább is látható maradhat." "message": "Az átugrási értesítés ennyi ideig marad a képernyőn. Manuális átugrásnál tovább is látható maradhat."
}, },
"shortCheck": { "shortCheck": {
"message": "A következő szegmens rövidebb, mint az Ön által beállított minimális időtartam. Ez azt jelentheti, hogy már beküldhették, csak emiatt az opció miatt Önnek figyelmen kívül marad. Biztosan beküldi?" "message": "A következő szegmens rövidebb, mint az általad beállított minimális időtartam. Ez azt jelentheti, hogy már beküldhették, csak emiatt az opció miatt nálad nem jelenik meg. Biztosan beküldöd?"
}, },
"showUploadButton": { "showUploadButton": {
"message": "Feltöltés gomb megjelenítése" "message": "Feltöltés gomb megjelenítése"
@@ -443,7 +443,7 @@
"message": "SponsorBlock szerver címe" "message": "SponsorBlock szerver címe"
}, },
"customServerAddressDescription": { "customServerAddressDescription": {
"message": "A SponsorBlock által használt cím a szerverre történő hívások kezdeményezésére szolgál.\nHacsak nincs saját szerverpéldánya, ezt nem szabad megváltoztatni." "message": "A SponsorBlock által használt cím a szerverre történő hívások kezdeményezésére szolgál.\nHacsak nincs saját szerverpéldányod, ezt nem szabad megváltoztatni."
}, },
"save": { "save": {
"message": "Mentés" "message": "Mentés"
@@ -452,10 +452,10 @@
"message": "Visszaállítás" "message": "Visszaállítás"
}, },
"customAddressError": { "customAddressError": {
"message": "A cím helytelenül van formázva. Győződjön meg róla, hogy http:// vagy https:// van az elején, és nem fordított perjeleket használ." "message": "A cím helytelenül van formázva. Győződj meg róla, hogy http:// vagy https:// van az elején, és nincsenek perjelek a végén."
}, },
"areYouSureReset": { "areYouSureReset": {
"message": "Biztosan vissza szeretné állítani?" "message": "Biztosan vissza szeretnéd állítani?"
}, },
"mobileUpdateInfo": { "mobileUpdateInfo": {
"message": "az m.youtube.com már támogatott" "message": "az m.youtube.com már támogatott"
@@ -464,16 +464,16 @@
"message": "Összes beállítás importálása / exportálása" "message": "Összes beállítás importálása / exportálása"
}, },
"whatExportOptions": { "whatExportOptions": {
"message": "Ez az össze beállítása JSON-ban. Ebbe bele tartozik a userID-ja, szóval csak ésszel ossza meg." "message": "Ez az összes beállításod JSON formátumban. Ebbe bele tartozik a userID-d is, szóval csak ésszel oszd meg."
}, },
"setOptions": { "setOptions": {
"message": "Beállítások módosítása" "message": "Beállítások módosítása"
}, },
"exportOptionsWarning": { "exportOptionsWarning": {
"message": "Figyelem: Az beállítások megváltoztatása végleges, és tönkreteheti a bővítményét. Biztosan meg szeretné tenni? Készítsen egy biztonsági mentést a régi beállításairól, biztos, ami biztos." "message": "Figyelem: A beállítások megváltoztatása végleges, és tönkreteheti a bővítményed. Biztosan meg szeretnéd tenni? Készíts egy biztonsági mentést a régi beállításaidról, biztos, ami biztos."
}, },
"incorrectlyFormattedOptions": { "incorrectlyFormattedOptions": {
"message": "Ez a JSON helytelenül van formázva. A beállításai nem lettek megváltoztatva." "message": "Ez a JSON helytelenül van formázva. A beállításaid nem lettek megváltoztatva."
}, },
"confirmNoticeTitle": { "confirmNoticeTitle": {
"message": "Szegmens beküldése" "message": "Szegmens beküldése"
@@ -506,16 +506,16 @@
"message": "Hiba a vágólapra másoláskor" "message": "Hiba a vágólapra másoláskor"
}, },
"copyDebugInformationOptions": { "copyDebugInformationOptions": {
"message": "Információt másol a vágólapra, amit megadhat egy fejlesztőnek, ha bejelent egy hibát, vagy egy fejlesztő kéri öntől. Az érzékeny információkat, például a felhasználói azonosítót, az engedélyezőlistán szereplő csatornákat és az egyéni szerver címét eltávolítottuk. Azonban tartalmaz olyan információkat, mint a böngésző, az operációs rendszer és a bővítmény verziószáma. " "message": "Információt másol a vágólapra, amit megadhatsz egy fejlesztőnek, ha bejelentesz egy hibát, vagy egy fejlesztő kéri tőled. Az érzékeny információkat, például a userID-t, az engedélyezőlistán szereplő csatornákat és az egyéni szerver címét eltávolítottuk. Azonban tartalmaz olyan információkat, mint a böngésző, az operációs rendszer és a bővítmény verziószáma. "
}, },
"copyDebugInformationComplete": { "copyDebugInformationComplete": {
"message": "A hibakeresési információ másolva lett a vágólapjára. Nyugodtan távolítson el belőle olyan információkat, amiket nem szívesen osztana meg. Mentse el szöveges fájlként, vagy másolja a hibajelentésbe." "message": "A hibakeresési információ másolva lett a vágólapjára. Nyugodtan távolíts el belőle olyan információkat, amiket nem szívesen osztanál meg. Mentsd el szöveges fájlként, vagy másold a hibajelentésbe."
}, },
"theKey": { "theKey": {
"message": "A billentyű" "message": "A(z)"
}, },
"keyAlreadyUsed": { "keyAlreadyUsed": {
"message": "már máshoz van állítva. Kérem, válasszon egy másik billentyűt." "message": "billentyű már máshoz van állítva. Kérlek, válassz egy másik billentyűt."
}, },
"to": { "to": {
"message": "", "message": "",
@@ -525,19 +525,19 @@
"message": "Szponzor" "message": "Szponzor"
}, },
"category_sponsor_description": { "category_sponsor_description": {
"message": "Fizetett promóció, vagy közvetlen reklám. Nem ön-promóció vagy ingyenes ajánlat (/shoutout) emberekről/termékekről/weboldalakról amik tetszenek nekik." "message": "Fizetett promóció, vagy közvetlen reklám. Nem önpromóció vagy ingyenes ajánlat (shoutout) emberekről/termékekről/weboldalakról amik tetszenek nekik."
}, },
"category_selfpromo": { "category_selfpromo": {
"message": "Nem fizetett/ön-promóció" "message": "Nem fizetett/önpromóció"
}, },
"category_selfpromo_description": { "category_selfpromo_description": {
"message": "Hasonló a szponzorhoz, de nem fizetett vagy ön-promóció. Beletartozik a saját ruhaáru, adományok, vagy infó arról hogy kivel működtek együtt." "message": "Hasonló a szponzorhoz, de nem fizetett, vagy önpromóció. Beletartozik a saját ruhaáru, adományok, vagy infó arról, hogy kivel működtek együtt."
}, },
"category_interaction": { "category_interaction": {
"message": "Emlékeztető (Feliratkozás)" "message": "Emlékeztető (Feliratkozás)"
}, },
"category_interaction_description": { "category_interaction_description": {
"message": "Egy rövid emlékeztető arról, hogy likeoljunk, iratkozzunk fel, vagy kövessük a tartalom közben. Ha hosszabb szakasz, vagy egy adott témáról van, inkább a az ön-promóció alá tartozik." "message": "Egy rövid emlékeztető arról, hogy likeoljunk, iratkozzunk fel, vagy kövessük a tartalom közben. Ha hosszabb szakasz, vagy egy adott témáról van, inkább az önpromóció alá tartozik."
}, },
"category_interaction_short": { "category_interaction_short": {
"message": "Emlékeztető" "message": "Emlékeztető"
@@ -641,10 +641,10 @@
"message": "Bétateszt szerver bekapcsolása" "message": "Bétateszt szerver bekapcsolása"
}, },
"whatEnableTestingServer": { "whatEnableTestingServer": {
"message": "A hozzájárulásai/szavazatai NEM FOGNAK SZÁMÍTANI a fő szerveren. Csak tesztelésre használja." "message": "A beküldéseid és szavazataid NEM FOGNAK SZÁMÍTANI a fő szerveren. Csak tesztelésre használd."
}, },
"testingServerWarning": { "testingServerWarning": {
"message": "Az összes hozzájárulás/szavazat NEM FOG SZÁMÍTANI a fő szerverhez, amíg a tesztszerverhez kapcsolódik. Győződjön meg róla, hogy ki van kapcsolva, ha valódi hozzájárulásokat szeretne megosztani." "message": "Egyik beküldésed vagy szavazatod SEM FOG SZÁMÍTANI a fő szerverhez, amíg a tesztszerverhez kapcsolódsz. Győződj meg róla, hogy ki van kapcsolva, ha valódi beküldéseket akarsz végezni."
}, },
"bracketNow": { "bracketNow": {
"message": "(Most)" "message": "(Most)"
@@ -653,7 +653,7 @@
"message": "További kategóriák" "message": "További kategóriák"
}, },
"chooseACategory": { "chooseACategory": {
"message": "Válasszon kategóriát" "message": "Válassz egy kategóriát"
}, },
"enableThisCategoryFirst": { "enableThisCategoryFirst": {
"message": "Hogy \"{0}\" kategóriájú szegmenst küldhess be, először engedélyezned kell a beállításokban. Most átirányításra kerülsz a beállításokhoz.", "message": "Hogy \"{0}\" kategóriájú szegmenst küldhess be, először engedélyezned kell a beállításokban. Most átirányításra kerülsz a beállításokhoz.",
@@ -663,7 +663,7 @@
"message": "Figyelem: Az ilyen típusú szegmensekből egyszerre csak egy lehet aktív. Több beküldése esetén véletlenszerűen az egyik fog megjelenni." "message": "Figyelem: Az ilyen típusú szegmensekből egyszerre csak egy lehet aktív. Több beküldése esetén véletlenszerűen az egyik fog megjelenni."
}, },
"youMustSelectACategory": { "youMustSelectACategory": {
"message": "Minden szegmenshez kategóriát kell választania beküldés előtt!" "message": "Minden szegmenshez kategóriát kell választani beküldés előtt!"
}, },
"bracketEnd": { "bracketEnd": {
"message": "(Vége)" "message": "(Vége)"
@@ -700,7 +700,7 @@
"message": "Csatorna ellenőrzése átugrás előtt" "message": "Csatorna ellenőrzése átugrás előtt"
}, },
"whatForceChannelCheck": { "whatForceChannelCheck": {
"message": "Alapértelmezett állapotban, a bővítmény átugorhat szegmenseket, mielőtt tudná melyik csatornán van. Alapból ezért, néhány szegmens, ami a videók legelején van, engedélyezett csatornákon is átugródhat. Ennek a bekapcsolásával ez elkerülhető, de minden átugrás előtt lesz egy kis késleltetés, hiszen a channelID megszerzéséhez elkell egy kis idő. Ez a késleltetés akár észrevehetetlen is lehet, ha elég gyors a kapcsolata." "message": "Alapértelmezett állapotban a bővítmény átugorhat szegmenseket, mielőtt tudná melyik csatornán van. Alapból ezért néhány videó eleji szegmens engedélyezett csatornákon is átugródhat. Ennek a bekapcsolásával ez elkerülhető, de minden átugrás előtt lesz egy kis késleltetés, hiszen a channelID megszerzéséhez kell egy kis idő. Ez a késleltetés akár észrevehetetlen is lehet, ha elég gyors a kapcsolatod."
}, },
"forceChannelCheckPopup": { "forceChannelCheckPopup": {
"message": "Fontold meg a \"Csatorna ellenőrzése átugrás előtt\" bekapcsolását" "message": "Fontold meg a \"Csatorna ellenőrzése átugrás előtt\" bekapcsolását"
@@ -712,7 +712,7 @@
"message": "Kategória módosítása" "message": "Kategória módosítása"
}, },
"nonMusicCategoryOnMusic": { "nonMusicCategoryOnMusic": {
"message": "Ez a videó zeneként van kategorizálva. Biztos benne, hogy ennek van szponzora? Ha ez valójában egy \"nem-zene szegmens\", nyissa meg a bővítmény beállításait és kapcsolja be azt a kategóriát. Ezt követően elküldheti ezt a szegmenst \"nem-zene\"-ként szponzor helyett. Amennyiben nem érti, kérjük olvassa el az irányelveket." "message": "Ez a videó zeneként van kategorizálva. Biztos vagy benne, hogy ennek van szponzora? Ha ez valójában egy \"nem-zene szegmens\", nyisd meg a bővítmény beállításait és kapcsold be ezt a kategóriát. Ezt követően beküldheted a szegmenst \"nem-zene\"-ként szponzor helyett. Ha nem érthető, kérjük olvasd el az irányelveket."
}, },
"multipleSegments": { "multipleSegments": {
"message": "Több szegmens" "message": "Több szegmens"
@@ -721,14 +721,14 @@
"message": "Irányelvek" "message": "Irányelvek"
}, },
"readTheGuidelines": { "readTheGuidelines": {
"message": "Olvassa el az irányelveket!!", "message": "Olvasd el az irányelveket!!",
"description": "Show the first time they submit or if they are \"high risk\"" "description": "Show the first time they submit or if they are \"high risk\""
}, },
"categoryUpdate1": { "categoryUpdate1": {
"message": "Itt vannak a kategóriák!" "message": "Itt vannak a kategóriák!"
}, },
"categoryUpdate2": { "categoryUpdate2": {
"message": "Nyissa meg a beállításokat, hogy átugorhasson introkat, outrokat stb." "message": "Nyisd meg a beállításokat, hogy átugorhass introkat, outrokat stb."
}, },
"help": { "help": {
"message": "Segítség" "message": "Segítség"
@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Új! Ugorj át vicceket és a témához nem tartozó részeket a töltelék kategóriával. Engedélyezd a beállításokban" "message": "Új! Ugorj át vicceket és a témához nem tartozó részeket a töltelék kategóriával. Engedélyezd a beállításokban"
},
"dayAbbreviation": {
"message": "n",
"description": "100d"
},
"hourAbbreviation": {
"message": "ó",
"description": "100h"
} }
} }

View File

@@ -563,6 +563,15 @@
"category_preview_description": { "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." "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_filler": {
"message": "Pengisi Tangensial"
},
"category_filler_description": {
"message": "Adegan tangensial ditambahkan hanya untuk pengisi atau humor yang tidak diperlukan untuk memahami isi utama video. Ini tidak boleh mencakup segmen yang memberikan detail konteks atau latar belakang."
},
"category_filler_short": {
"message": "Isian"
},
"category_music_offtopic": { "category_music_offtopic": {
"message": "Musik: Bagian Non-Musik" "message": "Musik: Bagian Non-Musik"
}, },
@@ -699,6 +708,9 @@
"downvoteDescription": { "downvoteDescription": {
"message": "Salah, Waktu Tidak Tepat" "message": "Salah, Waktu Tidak Tepat"
}, },
"incorrectCategory": {
"message": "Ubah Kategori"
},
"nonMusicCategoryOnMusic": { "nonMusicCategoryOnMusic": {
"message": "Video ini dikategorikan sebagai musik. Apakah anda yakin ini berisi sponsor? Jika ini ternyata adalah \"Segmen non-musik\", buka pengaturan ekstensi dan aktifkan kategorinya. Lalu, anda bisa mengirim segmen ini sebagai \"Non-musik\" bukannya sponsor. Harap membaca panduan jika anda kebingungan." "message": "Video ini dikategorikan sebagai musik. Apakah anda yakin ini berisi sponsor? Jika ini ternyata adalah \"Segmen non-musik\", buka pengaturan ekstensi dan aktifkan kategorinya. Lalu, anda bisa mengirim segmen ini sebagai \"Non-musik\" bukannya sponsor. Harap membaca panduan jika anda kebingungan."
}, },
@@ -805,7 +817,25 @@
"LearnMore": { "LearnMore": {
"message": "Pelajari Lebih Lanjut" "message": "Pelajari Lebih Lanjut"
}, },
"CopyDownvoteButtonInfo": {
"message": "Menurunkan suara dan membuat salinan lokal untuk Anda kirim ulang"
},
"OpenCategoryWikiPage": {
"message": "Membuka halaman wiki kategori ini."
},
"CopyAndDownvote": {
"message": "Salin dan berikan turunkan suara"
},
"ContinueVoting": {
"message": "Lanjutkan Memvoting"
},
"ChangeCategoryTooltip": {
"message": "Ini akan menerapkan ke segmen Anda"
},
"SponsorTimeEditScrollNewFeature": { "SponsorTimeEditScrollNewFeature": {
"message": "Gunakan roda mouse ketika berada di kotak edit untuk mengatur waktu dengan cepat. Kombinasi dengan tombol [Ctrl + Shift] bisa digunakan untuk perubahan yang halus." "message": "Gunakan roda mouse ketika berada di kotak edit untuk mengatur waktu dengan cepat. Kombinasi dengan tombol [Ctrl + Shift] bisa digunakan untuk perubahan yang halus."
},
"fillerNewFeature": {
"message": "Baru! Lewati tangen dan lelucon dengan kategori pengisi. Aktifkan dalam opsi"
} }
} }

View File

@@ -834,5 +834,8 @@
}, },
"SponsorTimeEditScrollNewFeature": { "SponsorTimeEditScrollNewFeature": {
"message": "Usa la rotellina del mouse passando sulla casella di modifica per regolare rapidamente il tempo. Le combinazioni dei tasti ctrl o shift sono utilizzabili per perfezionare le modifiche." "message": "Usa la rotellina del mouse passando sulla casella di modifica per regolare rapidamente il tempo. Le combinazioni dei tasti ctrl o shift sono utilizzabili per perfezionare le modifiche."
},
"fillerNewFeature": {
"message": "Novità! Salta battute e tergiversazioni con il riempitivo. Attivala nelle opzioni"
} }
} }

View File

@@ -818,13 +818,13 @@
"message": "더보기" "message": "더보기"
}, },
"CopyDownvoteButtonInfo": { "CopyDownvoteButtonInfo": {
"message": "반대에 투표한 뒤 다시 제출할 수 있도록 미제출 사본을 생성합니다" "message": "비추천에 투표한 뒤 다시 제출할 수 있도록 미제출 사본을 생성합니다"
}, },
"OpenCategoryWikiPage": { "OpenCategoryWikiPage": {
"message": "해당 카테고리의 위키 페이지를 엽니다." "message": "해당 카테고리의 위키 페이지를 엽니다."
}, },
"CopyAndDownvote": { "CopyAndDownvote": {
"message": "복사 및 반대" "message": "복사 및 비추천"
}, },
"ContinueVoting": { "ContinueVoting": {
"message": "계속 투표" "message": "계속 투표"
@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "새 기능! 쓸데없는 말이나 농담 구간을 잡담 카테고리로 건너 뛰세요. 설정에서 활성화하세요" "message": "새 기능! 쓸데없는 말이나 농담 구간을 잡담 카테고리로 건너 뛰세요. 설정에서 활성화하세요"
},
"dayAbbreviation": {
"message": "일",
"description": "100d"
},
"hourAbbreviation": {
"message": "시간",
"description": "100h"
} }
} }

View File

@@ -836,6 +836,14 @@
"message": "Gebruik het muiswiel terwijl u over het invoerveld beweegt om de tijd snel aan te passen. Combinaties van de ctrl- of shift-toets kunnen worden gebruikt om de wijzigingen te verfijnen." "message": "Gebruik het muiswiel terwijl u over het invoerveld beweegt om de tijd snel aan te passen. Combinaties van de ctrl- of shift-toets kunnen worden gebruikt om de wijzigingen te verfijnen."
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Nieuw! Sla zijsporen en grapjes over met de opvulling-categorie. Schakel in via opties" "message": "Nieuw! Zijsporen en grapjes overslaan met de opvulling-categorie. Inschakelen via opties"
},
"dayAbbreviation": {
"message": " d",
"description": "100d"
},
"hourAbbreviation": {
"message": " h",
"description": "100h"
} }
} }

View File

@@ -563,6 +563,15 @@
"category_preview_description": { "category_preview_description": {
"message": "Szybkie podsumowanie poprzednich odcinków lub podgląd tego, co pojawia się później w bieżącym filmie. Dotyczy zmontowanych klipów, a nie ustnych podsumowań." "message": "Szybkie podsumowanie poprzednich odcinków lub podgląd tego, co pojawia się później w bieżącym filmie. Dotyczy zmontowanych klipów, a nie ustnych podsumowań."
}, },
"category_filler": {
"message": "Filtr nietematyczny"
},
"category_filler_description": {
"message": "Sceny nietematyczne dodawane tylko dla wypełniacza lub humoru, które nie są wymagane do zrozumienia głównej treści wideo. Nie powinno to obejmować segmentów zawierających informacje kontekstowe lub szczegółowe."
},
"category_filler_short": {
"message": "Wypełniacz"
},
"category_music_offtopic": { "category_music_offtopic": {
"message": "Muzyka: Sekcja niemuzyczna" "message": "Muzyka: Sekcja niemuzyczna"
}, },
@@ -825,5 +834,16 @@
}, },
"SponsorTimeEditScrollNewFeature": { "SponsorTimeEditScrollNewFeature": {
"message": "Użyj scroll'a myszy po najechaniu nad pole edycji, aby szybko dostosować czas. Kombinacje z ctrl'em i shift'em mogą być użyte, aby doszlifować zmiany." "message": "Użyj scroll'a myszy po najechaniu nad pole edycji, aby szybko dostosować czas. Kombinacje z ctrl'em i shift'em mogą być użyte, aby doszlifować zmiany."
},
"fillerNewFeature": {
"message": "Nowość! Pomiń nietematyczne sceny i żarty z kategorią wypełnienia. Włącz w opcjach"
},
"dayAbbreviation": {
"message": "d",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Novo! Pule tangentes e piadas com a categoria filler. Ative em opções" "message": "Novo! Pule tangentes e piadas com a categoria filler. Ative em opções"
},
"dayAbbreviation": {
"message": "d",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Новое! Пропускайте сегменты с отвлечёнными темами или шутками. Включите в настройках" "message": "Новое! Пропускайте сегменты с отвлечёнными темами или шутками. Включите в настройках"
},
"dayAbbreviation": {
"message": "д",
"description": "100d"
},
"hourAbbreviation": {
"message": "ч",
"description": "100h"
} }
} }

View File

@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Nové! Preskočte odbočky mimo tému a vtipy s kategóriou filler. Zapnite si ju v nastaveniach" "message": "Nové! Preskočte odbočky mimo tému a vtipy s kategóriou filler. Zapnite si ju v nastaveniach"
},
"dayAbbreviation": {
"message": "d",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -837,5 +837,13 @@
}, },
"fillerNewFeature": { "fillerNewFeature": {
"message": "Nytt! Hoppa över ämnesavvikelser och skämt med utfyllnadskategorin. Aktiveras i alternativen" "message": "Nytt! Hoppa över ämnesavvikelser och skämt med utfyllnadskategorin. Aktiveras i alternativen"
},
"dayAbbreviation": {
"message": "d",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -834,5 +834,13 @@
}, },
"SponsorTimeEditScrollNewFeature": { "SponsorTimeEditScrollNewFeature": {
"message": "Навівши курсор на поле редагування, користуйтеся колесом прокрутки, щоб швидко відрегулювати час. Комбінації клавіш ctrl або shift можуть бути використані для точнішої настройки змін." "message": "Навівши курсор на поле редагування, користуйтеся колесом прокрутки, щоб швидко відрегулювати час. Комбінації клавіш ctrl або shift можуть бути використані для точнішої настройки змін."
},
"dayAbbreviation": {
"message": "д",
"description": "100d"
},
"hourAbbreviation": {
"message": "г",
"description": "100h"
} }
} }

View File

@@ -74,7 +74,7 @@
"message": "Video này có đoạn quảng cáo trong kho dữ liệu rồi!" "message": "Video này có đoạn quảng cáo trong kho dữ liệu rồi!"
}, },
"sponsor404": { "sponsor404": {
"message": "Không tìm thấy đoạn nào" "message": "Không tìm thấy phân đoạn nào"
}, },
"sponsorStart": { "sponsorStart": {
"message": "Đoạn quảng cáo bắt đầu vào lúc này" "message": "Đoạn quảng cáo bắt đầu vào lúc này"
@@ -113,10 +113,10 @@
"message": "Đóng bảng popup" "message": "Đóng bảng popup"
}, },
"SubmitTimes": { "SubmitTimes": {
"message": "Đăng phân đoạn" "message": "Gửi phân đoạn"
}, },
"submitCheck": { "submitCheck": {
"message": "Bạn có chắc muốn đăng không?" "message": "Bạn có chắc chắn muốn gửi không?"
}, },
"whitelistChannel": { "whitelistChannel": {
"message": "Đưa kênh vào danh sách không chặn" "message": "Đưa kênh vào danh sách không chặn"
@@ -150,7 +150,7 @@
"message": "Xóa thời gian" "message": "Xóa thời gian"
}, },
"submitTimesButton": { "submitTimesButton": {
"message": "Đăng thời gian" "message": "Gửi thời gian"
}, },
"publicStats": { "publicStats": {
"message": "Tên này được dùng tại trang thông tin công khai để thể hiện lượng đóng góp của bạn. Xem" "message": "Tên này được dùng tại trang thông tin công khai để thể hiện lượng đóng góp của bạn. Xem"
@@ -305,6 +305,13 @@
"skip_category": { "skip_category": {
"message": "Bỏ qua {0}?" "message": "Bỏ qua {0}?"
}, },
"mute_category": {
"message": "Ngắt tiếng {0} chứ?"
},
"skip_to_category": {
"message": "Bỏ qua đến {0}?",
"description": "Used for skipping to things (Skip to Highlight)"
},
"skipped": { "skipped": {
"message": "{0} đã bỏ qua", "message": "{0} đã bỏ qua",
"description": "Example: Sponsor Skipped" "description": "Example: Sponsor Skipped"
@@ -313,6 +320,10 @@
"message": "{0} đã ngắt tiếng (Muted)", "message": "{0} đã ngắt tiếng (Muted)",
"description": "Example: Sponsor Muted" "description": "Example: Sponsor Muted"
}, },
"skipped_to_category": {
"message": "Đã bỏ qua đến {0}",
"description": "Used for skipping to things (Skipped to Highlight)"
},
"disableAutoSkip": { "disableAutoSkip": {
"message": "Tắt tự động bỏ qua" "message": "Tắt tự động bỏ qua"
}, },
@@ -465,10 +476,10 @@
"message": "Tệp JSON này không được định dạng đúng cách. Tùy chọn của bạn chưa được thay đổi." "message": "Tệp JSON này không được định dạng đúng cách. Tùy chọn của bạn chưa được thay đổi."
}, },
"confirmNoticeTitle": { "confirmNoticeTitle": {
"message": "Đăng phân đoạn" "message": "Gửi phân đoạn"
}, },
"submit": { "submit": {
"message": "Đăng" "message": "Gửi"
}, },
"cancel": { "cancel": {
"message": "Huỷ" "message": "Huỷ"
@@ -552,6 +563,15 @@
"category_preview_description": { "category_preview_description": {
"message": "Tóm tắt nhanh về tập trước/tập sau trong 1 chuỗi video (series) dài (hoặc cũng có thể là tóm tắt trước về video sắp chiếu)." "message": "Tóm tắt nhanh về tập trước/tập sau trong 1 chuỗi video (series) dài (hoặc cũng có thể là tóm tắt trước về video sắp chiếu)."
}, },
"category_filler": {
"message": "Cảnh phụ"
},
"category_filler_description": {
"message": "Tập hợp các cảnh không bắt buộc để xem trong video. Điều này không bao gồm các đoạn chứa nội dung hoặc nói về ngữ cảnh của video."
},
"category_filler_short": {
"message": "Cảnh phụ"
},
"category_music_offtopic": { "category_music_offtopic": {
"message": "Nhạc: Phần không nhạc" "message": "Nhạc: Phần không nhạc"
}, },
@@ -649,7 +669,7 @@
"message": "(Kết thúc)" "message": "(Kết thúc)"
}, },
"hiddenDueToDownvote": { "hiddenDueToDownvote": {
"message": "đã bị ẩn: Không tán thành" "message": "đã ẩn: hạ bình chọn"
}, },
"hiddenDueToDuration": { "hiddenDueToDuration": {
"message": "đã bị ẩn: quá ngắn" "message": "đã bị ẩn: quá ngắn"
@@ -686,7 +706,10 @@
"message": "Cân nhắc bật chế độ \"Bắt buộc kiểm tra kênh YouTube trước khi bỏ qua phân đoạn\"" "message": "Cân nhắc bật chế độ \"Bắt buộc kiểm tra kênh YouTube trước khi bỏ qua phân đoạn\""
}, },
"downvoteDescription": { "downvoteDescription": {
"message": "Phân đoạn sai / không đúng" "message": "Chỉnh thời gian sai/không đúng"
},
"incorrectCategory": {
"message": "Đổi danh mục"
}, },
"nonMusicCategoryOnMusic": { "nonMusicCategoryOnMusic": {
"message": "Video này đã được phân loại là âm nhạc. Bạn có chắc đây là quảng cáo nhà tài trợ không? Nếu đây là phân đoạn \"Không phải nhạc\", hãy mở Cài đặt tiện ích và bật lựa chọn đó. Rồi bạn có thể đăng tải phân đoạn lên dưới danh mục \"Không phải nhạc\" thay vì \"Quảng cáo nhà tài trợ\". Hãy đọc Hướng dẫn nếu bạn vẫn còn vướng mắc" "message": "Video này đã được phân loại là âm nhạc. Bạn có chắc đây là quảng cáo nhà tài trợ không? Nếu đây là phân đoạn \"Không phải nhạc\", hãy mở Cài đặt tiện ích và bật lựa chọn đó. Rồi bạn có thể đăng tải phân đoạn lên dưới danh mục \"Không phải nhạc\" thay vì \"Quảng cáo nhà tài trợ\". Hãy đọc Hướng dẫn nếu bạn vẫn còn vướng mắc"
@@ -729,7 +752,7 @@
"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": { "Donate": {
"message": "Donate" "message": "Ủng hộ"
}, },
"hideDonationLink": { "hideDonationLink": {
"message": "Ẩn link donate" "message": "Ẩn link donate"
@@ -753,7 +776,7 @@
"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." "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."
}, },
"Submitting": { "Submitting": {
"message": "Gửi lên" "message": "Đang gửi lên"
}, },
"helpPageSubmitting1": { "helpPageSubmitting1": {
"message": "Việc gửi một phân đoạn mới có thể được thực hiện trong cửa sổ bật lên bằng cách nhấn vào nút \"Đoạn quảng cáo bắt đầu vào lúc này\" hoặc trong trình phát video bằng các nút trên thanh trình phát." "message": "Việc gửi một phân đoạn mới có thể được thực hiện trong cửa sổ bật lên bằng cách nhấn vào nút \"Đoạn quảng cáo bắt đầu vào lúc này\" hoặc trong trình phát video bằng các nút trên thanh trình phát."
@@ -793,5 +816,34 @@
}, },
"LearnMore": { "LearnMore": {
"message": "Tìm hiểu thêm" "message": "Tìm hiểu thêm"
},
"CopyDownvoteButtonInfo": {
"message": "Hạ bình chọn và tạo một bản sao cục bộ cho bạn gửi lại"
},
"OpenCategoryWikiPage": {
"message": "Mở trang wiki của danh mục này để tìm hiểu thêm."
},
"CopyAndDownvote": {
"message": "Sao chép và hạ bình chọn"
},
"ContinueVoting": {
"message": "Tiếp tục bỏ phiếu"
},
"ChangeCategoryTooltip": {
"message": "Điều này sẽ ngay lập tức áp dụng cho phân đoạn của bạn"
},
"SponsorTimeEditScrollNewFeature": {
"message": "Sử dụng con lăn chuột của bạn khi di chuột qua hộp chỉnh sửa để nhanh chóng điều chỉnh thời gian. Kết hợp phím ctrl hoặc shift có thể được sử dụng để tinh chỉnh các thay đổi."
},
"fillerNewFeature": {
"message": "Mới! Bỏ qua các phân đoạn phụ và joke với danh mục \"Cảnh phụ\". Bật trong tùy chọn"
},
"dayAbbreviation": {
"message": "d",
"description": "100d"
},
"hourAbbreviation": {
"message": "h",
"description": "100h"
} }
} }

View File

@@ -281,6 +281,10 @@
"skip_category": { "skip_category": {
"message": "跳過 {0}" "message": "跳過 {0}"
}, },
"muted": {
"message": "{0} 已靜音",
"description": "Example: Sponsor Muted"
},
"disableAutoSkip": { "disableAutoSkip": {
"message": "停用自動跳過" "message": "停用自動跳過"
}, },
@@ -665,7 +669,16 @@
"hideForever": { "hideForever": {
"message": "永久隱藏" "message": "永久隱藏"
}, },
"Submitting": {
"message": "正在提交"
},
"Editing": {
"message": "編輯中"
},
"Credits": { "Credits": {
"message": "致謝" "message": "致謝"
},
"LearnMore": {
"message": "了解更多"
} }
} }

View File

@@ -26,6 +26,11 @@
height: 100%; height: 100%;
} }
/* Make sure settings are upfront */
.ytp-settings-menu {
z-index: 6000 !important;
}
/* Preview Bar page hacks */ /* Preview Bar page hacks */
.ytp-tooltip:not(.sponsorCategoryTooltipVisible) .sponsorCategoryTooltip { .ytp-tooltip:not(.sponsorCategoryTooltipVisible) .sponsorCategoryTooltip {
@@ -101,10 +106,6 @@
transform: translateX(-100%) scale(0); transform: translateX(-100%) scale(0);
} }
.playerButton.hidden {
display: none;
}
.sponsorSkipObject { .sponsorSkipObject {
font-family: Roboto, Arial, Helvetica, sans-serif; font-family: Roboto, Arial, Helvetica, sans-serif;

View File

@@ -16,8 +16,6 @@ export interface NoticeProps {
timed?: boolean, timed?: boolean,
idSuffix?: string, idSuffix?: string,
videoSpeed?: () => number,
fadeIn?: boolean, fadeIn?: boolean,
startFaded?: boolean, startFaded?: boolean,
firstColumn?: React.ReactElement, firstColumn?: React.ReactElement,
@@ -51,7 +49,6 @@ export interface NoticeState {
class NoticeComponent extends React.Component<NoticeProps, NoticeState> { class NoticeComponent extends React.Component<NoticeProps, NoticeState> {
countdownInterval: NodeJS.Timeout; countdownInterval: NodeJS.Timeout;
intervalVideoSpeed: number;
idSuffix: string; idSuffix: string;
@@ -259,10 +256,6 @@ class NoticeComponent extends React.Component<NoticeProps, NoticeState> {
const countdownTime = Math.min(this.state.countdownTime - 1, this.state.maxCountdownTime()); const countdownTime = Math.min(this.state.countdownTime - 1, this.state.maxCountdownTime());
if (this.props.videoSpeed && this.intervalVideoSpeed != this.props.videoSpeed()) {
this.setupInterval();
}
if (countdownTime <= 0) { if (countdownTime <= 0) {
//remove this from setInterval //remove this from setInterval
clearInterval(this.countdownInterval); clearInterval(this.countdownInterval);
@@ -325,10 +318,7 @@ class NoticeComponent extends React.Component<NoticeProps, NoticeState> {
setupInterval(): void { setupInterval(): void {
if (this.countdownInterval) clearInterval(this.countdownInterval); if (this.countdownInterval) clearInterval(this.countdownInterval);
const intervalDuration = this.props.videoSpeed ? 1000 / this.props.videoSpeed() : 1000; this.countdownInterval = setInterval(this.countdown.bind(this), 1000);
this.countdownInterval = setInterval(this.countdown.bind(this), intervalDuration);
if (this.props.videoSpeed) this.intervalVideoSpeed = this.props.videoSpeed();
} }
resetCountdown(): void { resetCountdown(): void {

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, ActionType } from "../types"; import { Category, ContentContainer, CategoryActionType, SponsorHideType, SponsorTime, NoticeVisbilityMode, ActionType, SponsorSourceType, SegmentUUID } from "../types";
import NoticeComponent from "./NoticeComponent"; import NoticeComponent from "./NoticeComponent";
import NoticeTextSelectionComponent from "./NoticeTextSectionComponent"; import NoticeTextSelectionComponent from "./NoticeTextSectionComponent";
import SubmissionNotice from "../render/SubmissionNotice"; import SubmissionNotice from "../render/SubmissionNotice";
@@ -74,7 +74,6 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
amountOfPreviousNotices: number; amountOfPreviousNotices: number;
showInSecondSlot: boolean; showInSecondSlot: boolean;
audio: HTMLAudioElement;
idSuffix: string; idSuffix: string;
@@ -96,7 +95,6 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
this.segments = props.segments; this.segments = props.segments;
this.autoSkip = props.autoSkip; this.autoSkip = props.autoSkip;
this.contentContainer = props.contentContainer; this.contentContainer = props.contentContainer;
this.audio = null;
const noticeTitle = getSkippingText(this.segments, this.props.autoSkip); const noticeTitle = getSkippingText(this.segments, this.props.autoSkip);
@@ -156,13 +154,6 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
} }
} }
componentDidMount(): void {
if (Config.config.audioNotificationOnSkip && this.audio) {
this.audio.volume = this.contentContainer().v.volume * 0.1;
if (this.autoSkip) this.audio.play();
}
}
render(): React.ReactElement { render(): React.ReactElement {
const noticeStyle: React.CSSProperties = { } const noticeStyle: React.CSSProperties = { }
if (this.contentContainer().onMobileYouTube) { if (this.contentContainer().onMobileYouTube) {
@@ -186,7 +177,6 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
|| (Config.config.noticeVisibilityMode >= NoticeVisbilityMode.FadedForAutoSkip && this.autoSkip)} || (Config.config.noticeVisibilityMode >= NoticeVisbilityMode.FadedForAutoSkip && this.autoSkip)}
timed={true} timed={true}
maxCountdownTime={this.state.maxCountdownTime} maxCountdownTime={this.state.maxCountdownTime}
videoSpeed={() => this.contentContainer().v?.playbackRate}
style={noticeStyle} style={noticeStyle}
biggerCloseButton={this.contentContainer().onMobileYouTube} biggerCloseButton={this.contentContainer().onMobileYouTube}
ref={this.noticeRef} ref={this.noticeRef}
@@ -196,10 +186,6 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
firstColumn={firstColumn} firstColumn={firstColumn}
bottomRow={[...this.getMessageBoxes(), ...this.getBottomRow() ]} bottomRow={[...this.getMessageBoxes(), ...this.getBottomRow() ]}
onMouseEnter={() => this.onMouseEnter() } > onMouseEnter={() => this.onMouseEnter() } >
{(Config.config.audioNotificationOnSkip) && <audio ref={(source) => { this.audio = source; }}>
<source src={chrome.extension.getURL("icons/beep.ogg")} type="audio/ogg"></source>
</audio>}
</NoticeComponent> </NoticeComponent>
); );
} }
@@ -534,10 +520,10 @@ class SkipNoticeComponent extends React.Component<SkipNoticeProps, SkipNoticeSta
const sponsorVideoID = this.props.contentContainer().sponsorVideoID; const sponsorVideoID = this.props.contentContainer().sponsorVideoID;
const sponsorTimesSubmitting : SponsorTime = { const sponsorTimesSubmitting : SponsorTime = {
segment: this.segments[index].segment, segment: this.segments[index].segment,
UUID: null, UUID: utils.generateUserID() as SegmentUUID,
category: this.segments[index].category, category: this.segments[index].category,
actionType: this.segments[index].actionType, actionType: this.segments[index].actionType,
source: 2 source: SponsorSourceType.Local
}; };
const segmentTimes = Config.config.segmentTimes.get(sponsorVideoID) || []; const segmentTimes = Config.config.segmentTimes.get(sponsorVideoID) || [];

View File

@@ -73,7 +73,7 @@ class SubmissionNoticeComponent extends React.Component<SubmissionNoticeProps, S
idSuffix={this.state.idSuffix} idSuffix={this.state.idSuffix}
ref={this.noticeRef} ref={this.noticeRef}
closeListener={this.cancel.bind(this)} closeListener={this.cancel.bind(this)}
zIndex={50000}> zIndex={5000}>
{/* Text Boxes */} {/* Text Boxes */}
{this.getMessageBoxes()} {this.getMessageBoxes()}
@@ -123,7 +123,7 @@ class SubmissionNoticeComponent extends React.Component<SubmissionNoticeProps, S
const timeRef = React.createRef<SponsorTimeEditComponent>(); const timeRef = React.createRef<SponsorTimeEditComponent>();
elements.push( elements.push(
<SponsorTimeEditComponent key={i} <SponsorTimeEditComponent key={sponsorTimes[i].UUID}
idSuffix={this.state.idSuffix + i} idSuffix={this.state.idSuffix + i}
index={i} index={i}
contentContainer={this.props.contentContainer} contentContainer={this.props.contentContainer}

View File

@@ -1,4 +1,5 @@
import * as CompileConfig from "../config.json"; import * as CompileConfig from "../config.json";
import * as invidiousList from "../ci/invidiouslist.json";
import { Category, CategorySelection, CategorySkipOption, NoticeVisbilityMode, PreviewBarOption, SponsorTime, StorageChangesObject, UnEncodedSegmentTimes as UnencodedSegmentTimes } from "./types"; import { Category, CategorySelection, CategorySkipOption, NoticeVisbilityMode, PreviewBarOption, SponsorTime, StorageChangesObject, UnEncodedSegmentTimes as UnencodedSegmentTimes } from "./types";
interface SBConfig { interface SBConfig {
@@ -51,7 +52,6 @@ interface SBConfig {
locked: string locked: string
}, },
scrollToEditTimeUpdate: boolean, scrollToEditTimeUpdate: boolean,
fillerUpdate: boolean,
// What categories should be skipped // What categories should be skipped
categorySelections: CategorySelection[], categorySelections: CategorySelection[],
@@ -188,7 +188,7 @@ const Config: SBObject = {
hideSkipButtonPlayerControls: false, hideSkipButtonPlayerControls: false,
hideDiscordLaunches: 0, hideDiscordLaunches: 0,
hideDiscordLink: false, hideDiscordLink: false,
invidiousInstances: ["invidious.snopyta.org"], invidiousInstances: ["invidious.snopyta.org"], // leave as default
supportInvidious: false, supportInvidious: false,
serverAddress: CompileConfig.serverAddress, serverAddress: CompileConfig.serverAddress,
minDuration: 0, minDuration: 0,
@@ -203,7 +203,6 @@ const Config: SBObject = {
autoHideInfoButton: true, autoHideInfoButton: true,
autoSkipOnMusicVideos: false, autoSkipOnMusicVideos: false,
scrollToEditTimeUpdate: false, // false means the tooltip will be shown scrollToEditTimeUpdate: false, // false means the tooltip will be shown
fillerUpdate: false,
categorySelections: [{ categorySelections: [{
name: "sponsor" as Category, name: "sponsor" as Category,
@@ -392,6 +391,9 @@ function fetchConfig(): Promise<void> {
} }
function migrateOldFormats(config: SBConfig) { function migrateOldFormats(config: SBConfig) {
if (config["fillerUpdate"] !== undefined) {
chrome.storage.sync.remove("fillerUpdate");
}
if (config["highlightCategoryAdded"] !== undefined) { if (config["highlightCategoryAdded"] !== undefined) {
chrome.storage.sync.remove("highlightCategoryAdded"); chrome.storage.sync.remove("highlightCategoryAdded");
} }
@@ -432,6 +434,11 @@ function migrateOldFormats(config: SBConfig) {
if (config["previousVideoID"] !== undefined) { if (config["previousVideoID"] !== undefined) {
chrome.storage.sync.remove("previousVideoID"); chrome.storage.sync.remove("previousVideoID");
} }
// populate invidiousInstances with new instances if 3p support is **DISABLED**
if (!config["supportInvidious"] && config["invidiousInstances"].length !== invidiousList.length) {
config["invidiousInstances"] = invidiousList;
}
} }
async function setupConfig() { async function setupConfig() {

View File

@@ -333,26 +333,6 @@ async function videoIDChange(id) {
// Clear unsubmitted segments from the previous video // Clear unsubmitted segments from the previous video
sponsorTimesSubmitting = []; sponsorTimesSubmitting = [];
updateSponsorTimesSubmitting(); updateSponsorTimesSubmitting();
// Filler update
if (!Config.config.fillerUpdate) {
Config.config.fillerUpdate = true;
utils.wait(getControls).then(() => {
const playButton = document.querySelector(".ytp-play-button") as HTMLElement;
const allCategories = ["sponsor", "intro", "outro", "selfpromo", "interaction"];
if (playButton && allCategories.every((name) => Config.config.categorySelections.some((selection) => selection.name === name))
&& utils.getCategorySelection("filler") === undefined) {
new Tooltip({
text: chrome.i18n.getMessage("fillerNewFeature"),
link: "https://wiki.sponsor.ajay.app/w/Filler_Tangent",
referenceNode: playButton.parentElement,
prependElement: playButton,
timeout: 10
});
}
});
}
} }
function handleMobileControlsMutations(): void { function handleMobileControlsMutations(): void {
@@ -1225,6 +1205,9 @@ function skipToTime({v, skipTime, skippingSegments, openNotice, forceAutoSkip, u
// for some reason you also can't skip to 1 second before the end // for some reason you also can't skip to 1 second before the end
if (v.loop && v.duration > 1 && skipTime[1] >= v.duration - 1) { if (v.loop && v.duration > 1 && skipTime[1] >= v.duration - 1) {
v.currentTime = 0; v.currentTime = 0;
} else if (navigator.vendor === "Apple Computer, Inc." && v.duration > 1 && skipTime[1] >= v.duration) {
// MacOS will loop otherwise #1027
v.currentTime = v.duration - 0.001;
} else { } else {
v.currentTime = skipTime[1]; v.currentTime = skipTime[1];
} }
@@ -1239,7 +1222,12 @@ function skipToTime({v, skipTime, skippingSegments, openNotice, forceAutoSkip, u
break; break;
} }
} }
}
if (autoSkip && Config.config.audioNotificationOnSkip) {
const beep = new Audio(chrome.runtime.getURL("icons/beep.ogg"));
beep.volume = video.volume * 0.1;
beep.play();
} }
if (!autoSkip if (!autoSkip
@@ -1445,7 +1433,7 @@ function startOrEndTimingNewSegment() {
if (!isSegmentCreationInProgress()) { if (!isSegmentCreationInProgress()) {
sponsorTimesSubmitting.push({ sponsorTimesSubmitting.push({
segment: [roundedTime], segment: [roundedTime],
UUID: null, UUID: utils.generateUserID() as SegmentUUID,
category: Config.config.defaultCategory, category: Config.config.defaultCategory,
actionType: ActionType.Skip, actionType: ActionType.Skip,
source: SponsorSourceType.Local source: SponsorSourceType.Local
@@ -1651,7 +1639,7 @@ function vote(type: number, UUID: SegmentUUID, category?: Category, skipNotice?:
const sponsorIndex = utils.getSponsorIndexFromUUID(sponsorTimes, UUID); const sponsorIndex = utils.getSponsorIndexFromUUID(sponsorTimes, UUID);
// Don't vote for preview sponsors // Don't vote for preview sponsors
if (sponsorIndex == -1 || sponsorTimes[sponsorIndex].UUID === null) return; if (sponsorIndex == -1 || sponsorTimes[sponsorIndex].source === SponsorSourceType.Local) return;
// See if the local time saved count and skip count should be saved // See if the local time saved count and skip count should be saved
if (type === 0 && sponsorSkipped[sponsorIndex] || type === 1 && !sponsorSkipped[sponsorIndex]) { if (type === 0 && sponsorSkipped[sponsorIndex] || type === 1 && !sponsorSkipped[sponsorIndex]) {
@@ -1781,6 +1769,7 @@ async function sendSubmitMessage() {
if (recievedNewSegments?.length === newSegments.length) { if (recievedNewSegments?.length === newSegments.length) {
for (let i = 0; i < recievedNewSegments.length; i++) { for (let i = 0; i < recievedNewSegments.length; i++) {
newSegments[i].UUID = recievedNewSegments[i].UUID; newSegments[i].UUID = recievedNewSegments[i].UUID;
newSegments[i].source = SponsorSourceType.Server;
} }
} }
} catch(e) {} // eslint-disable-line no-empty } catch(e) {} // eslint-disable-line no-empty

View File

@@ -79,7 +79,7 @@ export class SkipButtonControlBar {
mountingContainer.insertBefore(this.container, this.chapterText); mountingContainer.insertBefore(this.container, this.chapterText);
} }
if (Config.config.autoHideInfoButton && !this.onMobileYouTube) { if (!this.onMobileYouTube) {
utils.setupAutoHideAnimation(this.skipIcon, mountingContainer, false, false); utils.setupAutoHideAnimation(this.skipIcon, mountingContainer, false, false);
} else { } else {
const { hide, show } = utils.setupCustomHideAnimation(this.skipIcon, mountingContainer, false, false); const { hide, show } = utils.setupCustomHideAnimation(this.skipIcon, mountingContainer, false, false);

View File

@@ -1,5 +1,6 @@
import Config from "./config"; import Config from "./config";
import * as CompileConfig from "../config.json"; import * as CompileConfig from "../config.json";
import * as invidiousList from "../ci/invidiouslist.json";
// Make the config public for debugging purposes // Make the config public for debugging purposes
window.SB = Config; window.SB = Config;
@@ -297,8 +298,8 @@ function invidiousInstanceAddInit(element: HTMLElement, option: string) {
const resetButton = element.querySelector(".invidious-instance-reset"); const resetButton = element.querySelector(".invidious-instance-reset");
resetButton.addEventListener("click", function() { resetButton.addEventListener("click", function() {
if (confirm(chrome.i18n.getMessage("resetInvidiousInstanceAlert"))) { if (confirm(chrome.i18n.getMessage("resetInvidiousInstanceAlert"))) {
// Set to a clone of the default // Set to CI populated list
Config.config[option] = Config.defaults[option].slice(0); Config.config[option] = invidiousList;
} }
}); });
} }
@@ -512,6 +513,7 @@ function activatePrivateTextChange(element: HTMLElement) {
// See if anything extra must be done // See if anything extra must be done
switch (option) { switch (option) {
case "userID": case "userID":
if (Config.config[option]) {
utils.asyncRequestToServer("GET", "/api/userInfo", { utils.asyncRequestToServer("GET", "/api/userInfo", {
userID: Config.config[option], userID: Config.config[option],
values: ["warnings", "banned"] values: ["warnings", "banned"]
@@ -521,6 +523,7 @@ function activatePrivateTextChange(element: HTMLElement) {
setButton.classList.add("hidden"); setButton.classList.add("hidden");
} }
}); });
}
break; break;
} }

View File

@@ -731,16 +731,17 @@ async function runThePopup(messageListener?: MessageListener): Promise<void> {
} }
/** /**
* Converts time in hours to 5h 25.1 * Converts time in minutes to 2d 5h 25.1
* If less than 1 hour, just returns minutes * If less than 1 hour, just returns minutes
* *
* @param {float} seconds * @param {float} minutes
* @returns {string} * @returns {string}
*/ */
function getFormattedHours(minutes) { function getFormattedHours(minutes) {
minutes = Math.round(minutes * 10) / 10 minutes = Math.round(minutes * 10) / 10;
const hours = Math.floor(minutes / 60); const days = Math.floor(minutes / 3600);
return (hours > 0 ? hours + "h " : "") + (minutes % 60).toFixed(1); const hours = Math.floor(minutes / 60) % 24;
return (days > 0 ? days + chrome.i18n.getMessage("dayAbbreviation") + " " : "") + (hours > 0 ? hours + chrome.i18n.getMessage("hourAbbreviation") + " " : "") + (minutes % 60).toFixed(1);
} }
//end of function //end of function

View File

@@ -26,7 +26,10 @@ export default class Utils {
/** Function that can be used to wait for a condition before returning. */ /** Function that can be used to wait for a condition before returning. */
async wait<T>(condition: () => T | false, timeout = 5000, check = 100): Promise<T> { async wait<T>(condition: () => T | false, timeout = 5000, check = 100): Promise<T> {
return await new Promise((resolve, reject) => { return await new Promise((resolve, reject) => {
setTimeout(() => reject("TIMEOUT"), timeout); setTimeout(() => {
clearInterval(interval);
reject("TIMEOUT");
}, timeout);
const intervalCheck = () => { const intervalCheck = () => {
const result = condition(); const result = condition();