From fd2cd292676208b90796858be50b74ebe6d683d0 Mon Sep 17 00:00:00 2001 From: idarlund Date: Tue, 10 Jan 2017 14:56:21 +0100 Subject: [PATCH 1/3] Create no.json norwegian translation first commit --- i18n/no.json | 151 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 151 insertions(+) create mode 100644 i18n/no.json diff --git a/i18n/no.json b/i18n/no.json new file mode 100644 index 00000000..05466d8a --- /dev/null +++ b/i18n/no.json @@ -0,0 +1,151 @@ +{ + "en": "no", + "Paste does not exist, has expired or has been deleted.": + "Innlegget eksisterer ikke, er utløpt eller har blitt slettet.", + "PrivateBin requires php 5.3.0 or above to work. Sorry.": + "Beklager, PrivateBin krever php 5.3.0 eller nyere for å kjøre.", + "PrivateBin requires configuration section [%s] to be present in configuration file.": + "PrivateBin krever konfigurasjonsdel [%s] å være til stede i konfigurasjonsfilen .", + "Please wait %d seconds between each post.": + "Vent %d sekunder mellom hvert innlegg.", + "Paste is limited to %s of encrypted data.": + "Innlegg er begrenset til %s av kryptert data.", + "Invalid data.": + "Ugyldige data.", + "You are unlucky. Try again.": + "Du er uheldig. Prøv igjen.", + "Error saving comment. Sorry.": + "Beklager, det oppstod en feil ved lagring kommentar.", + "Error saving paste. Sorry.": + "Beklager, det oppstod en feil ved lagring innlegg.", + "Invalid paste ID.": + "Feil innlegg ID.", + "Paste is not of burn-after-reading type.": + "Innlegg er ikke av slett-etter-lesing type.", + "Wrong deletion token. Paste was not deleted.": + "Feil slettenøkkel. Innlegg ble ikke slettet.", + "Paste was properly deleted.": + "Innlegget er slettet.", + "PrivateBin": "PrivateBin", + "PrivateBin is a minimalist, open source online pastebin where the server has zero knowledge of pasted data. Data is encrypted/decrypted in the browser using 256 bits AES. More information on the project page.": + "PrivateBin er en minimalistisk, åpen kildekode, elektronisk tilgjengelig pastebin hvor serveren ikke har kunnskap om dataene som limes inn. Dataene krypteres/dekrypteres i nettleseren ved hjelp av 256 bits AES. Mer informasjon om prosjektet på prosjektsiden.", + "Because ignorance is bliss": + "Fordi uvitenhet er lykke", + "JavaScript is required for PrivateBin to work.
Sorry for the inconvenience.": + "Beklager, Javascript kreves for at PrivateBin skal fungere.", + "PrivateBin requires a modern browser to work.": + "PrivateBin krever en moderne nettleser for å fungere.", + "Still using Internet Explorer? Do yourself a favor, switch to a modern browser:": + "Fortsatt bruker av Internet Explorer? Gjør deg selv en tjeneste, bytt til en moderne nettleser:", + "New": + "Ny", + "Send": + "Send", + "Clone": + "Kopier", + "Raw text": + "Ren tekst", + "Expires": + "Utgår", + "Burn after reading": + "Slett etter lesing", + "Open discussion": + "Åpen diskusjon", + "Password (recommended)": + "Passord (anbefalt)", + "Discussion": + "Diskusjon", + "Toggle navigation": + "Navigasjon", + "%d seconds": ["%d sekund", "%d sekunder"], + "%d minutes": ["%d minutt", "%d minutter"], + "%d hours": ["%d time", "%d timer"], + "%d days": ["%d dag", "%d dager"], + "%d weeks": ["%d uke", "%d uker"], + "%d months": ["%d måned", "%d måneder"], + "%d years": ["%d år", "%d år"], + "Never": + "Aldri", + "Note: This is a test service: Data may be deleted anytime. Kittens will die if you abuse this service.": + "Merk: Dette er en test tjeneste: Data kan slettes når som helst. Kattunger vil dø hvis du misbruker denne tjenesten.", + "This document will expire in %d seconds.": + ["Dette dokumentet vil utløpe om %d sekund.", "Dette dokumentet vil utløpe om %d sekunder."], + "This document will expire in %d minutes.": + ["Dette dokumentet vil utløpe om %d minutt.", "Dette dokumentet vil utløpe om %d minutter."], + "This document will expire in %d hours.": + ["Dette dokumentet vil utløpe om %d time.", "Dette dokumentet vil utløpe om %d timer."], + "This document will expire in %d days.": + ["Dette dokumentet vil utløpe om %d dag.", "Dette dokumentet vil utløpe om %d dager."], + "This document will expire in %d months.": + ["Dette dokumentet vil utløpe om %d måned.", "Dette dokumentet vil utløpe om %d måneder."], + "Please enter the password for this paste:": + "Skriv inn passordet for dette innlegget:", + "Could not decrypt data (Wrong key?)": + "Kunne ikke dekryptere data (feil nøkkel?)", + "Could not delete the paste, it was not stored in burn after reading mode.": + "Kan ikke slette innlegget, det ble ikke lagret i slett-etter-les modus.", + "FOR YOUR EYES ONLY. Don't close this window, this message can't be displayed again.": + "KUN FOR DINE ØYNE. Ikke lukk dette vinduet, denne meldingen kan ikke bli vist igjen.", + "Could not decrypt comment; Wrong key?": + "Kan ikke dekryptere kommentar; Feil nøkkel?", + "Reply": + "Svar", + "Anonymous": + "Anonym", + "Anonymous avatar (Vizhash of the IP address)": + "Anonym avatar (Vizhash av IP addressen)", + "Add comment": + "Legg inn kommentar", + "Optional nickname...": + "Valgfritt kallenavn...", + "Post comment": + "Send kommentar", + "Sending comment...": + "Sender Kommentar...", + "Comment posted.": + "Kommentar sendt.", + "Could not refresh display: %s": + "Kunne ikke oppdatere skjermen: %s", + "unknown status": + "ukjent status", + "server error or not responding": + "server feilet eller svarer ikke", + "Could not post comment: %s": + "Kunne ikke sende kommentar: %s", + "Sending paste (Please move your mouse for more entropy)...": + "Sender innlegg (Flytt musen for mere entropi)...", + "Sending paste...": + "Sender innlegg...", + "Your paste is %s (Hit [Ctrl]+[c] to copy)": + "Ditt innlegg er %s (Trykk [Ctrl]+[c] for å kopiere)", + "Delete data": + "Slett data", + "Could not create paste: %s": + "Kunne ikke opprette innlegg: %s", + "Cannot decrypt paste: Decryption key missing in URL (Did you use a redirector or an URL shortener which strips part of the URL?)": + "Kan ikke dekryptere innlegg: Dekrypteringsnøkkelen mangler i addressen (Har du bruket en redirector eller en addresse forkorter som fjerner en del av addressen?)", + "Format": "Format", + "Plain Text": "Ren Tekst", + "Source Code": "Kildekode", + "Markdown": "Oppmerket", + "Download attachment": "Last ned vedlegg", + "Cloned file attached.": "Kopier vedlegg.", + "Attach a file": "Legg til fil", + "Remove attachment": "Slett vedlegg", + "Your browser does not support uploading encrypted files. Please use a newer browser.": + "Nettleseren din støtter ikke å laste opp krypterte filer. Vennligst bruk en nyere nettleser.", + "Invalid attachment.": "Ugyldig vedlegg.", + "Options": "Opsjoner", + "Shorten URL": "Addresse forkorter", + "Editor": "Rediger", + "Preview": "Forhåndsvis", + "PrivateBin requires the PATH to end in a \"%s\". Please update the PATH in your index.php.": + "PrivateBin krever at PATH ender på \"%s\". Vennligst oppdater PATH i index.php.", + "Decrypt": + "Dekrypter", + "Enter password": + "Skriv inn passord", + "Loading…": "Laster…", + "In case this message never disappears please have a look at this FAQ for information to troubleshoot.": + "Hvis denne meldingen ikke forsvinner kan du ta en titt på denne FAQen for informasjon om feilsøking." +} From 4a49613b47119170fa0fa8fd4f51955e57e41bb2 Mon Sep 17 00:00:00 2001 From: El RIDO Date: Tue, 10 Jan 2017 20:28:15 +0100 Subject: [PATCH 2/3] improvements suggested by @atluxity --- i18n/no.json | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/i18n/no.json b/i18n/no.json index 05466d8a..40b6920a 100644 --- a/i18n/no.json +++ b/i18n/no.json @@ -135,8 +135,8 @@ "Your browser does not support uploading encrypted files. Please use a newer browser.": "Nettleseren din støtter ikke å laste opp krypterte filer. Vennligst bruk en nyere nettleser.", "Invalid attachment.": "Ugyldig vedlegg.", - "Options": "Opsjoner", - "Shorten URL": "Addresse forkorter", + "Options": "Innstillinger", + "Shorten URL": "Addresse-forkorter", "Editor": "Rediger", "Preview": "Forhåndsvis", "PrivateBin requires the PATH to end in a \"%s\". Please update the PATH in your index.php.": From a7de0e095b9cccbff4b4a3bfafa5de72506c074f Mon Sep 17 00:00:00 2001 From: El RIDO Date: Tue, 10 Jan 2017 20:37:14 +0100 Subject: [PATCH 3/3] added supported language, updated credits and changelog --- CHANGELOG.md | 2 +- CREDITS.md | 1 + js/privatebin.js | 4 ++-- lib/I18n.php | 2 +- tpl/bootstrap.php | 2 +- tpl/page.php | 2 +- tst/I18nTest.php | 10 ++++++++++ 7 files changed, 17 insertions(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 6197bb4b..2dc2e3c7 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,7 +1,7 @@ # PrivateBin version history * **next (not yet released)** - * ADDED: Translations for Spanish and Occitan + * ADDED: Translations for Spanish, Occitan and Norwegian * ADDED: Option in configuration to change the default "PrivateBin" title of the site * CHANGED: Cleanup of bootstrap template variants and moved icons to `img` directory * **1.1 (2016-12-26)** diff --git a/CREDITS.md b/CREDITS.md index 47d0bc2f..dfb2d83e 100644 --- a/CREDITS.md +++ b/CREDITS.md @@ -34,3 +34,4 @@ Sébastien Sauvage - original idea and main developer * R4SAS - Russian * Alfredo Fabián Altamirano Tena - Spanish * Quent-in - Occitan +* idarlund - Norwegian diff --git a/js/privatebin.js b/js/privatebin.js index 7030afb9..60e27754 100644 --- a/js/privatebin.js +++ b/js/privatebin.js @@ -329,7 +329,7 @@ $(function() { /** * supported languages, minus the built in 'en' */ - supportedLanguages: ['de', 'es', 'fr', 'it', 'pl', 'oc', 'ru', 'sl', 'zh'], + supportedLanguages: ['de', 'es', 'fr', 'it', 'no', 'pl', 'oc', 'ru', 'sl', 'zh'], /** * translate a string, alias for translate() @@ -420,7 +420,7 @@ $(function() { return (n % 10 === 1 && n % 100 !== 11 ? 0 : (n % 10 >= 2 && n % 10 <= 4 && (n % 100 < 10 || n % 100 >= 20) ? 1 : 2)); case 'sl': return (n % 100 === 1 ? 1 : (n % 100 === 2 ? 2 : (n % 100 === 3 || n % 100 === 4 ? 3 : 0))); - // de, en, es, it + // de, en, es, it, no default: return (n !== 1 ? 1 : 0); } diff --git a/lib/I18n.php b/lib/I18n.php index 6419fee3..4c59ef57 100644 --- a/lib/I18n.php +++ b/lib/I18n.php @@ -304,7 +304,7 @@ class I18n return $n % 10 == 1 && $n % 100 != 11 ? 0 : ($n % 10 >= 2 && $n % 10 <= 4 && ($n % 100 < 10 || $n % 100 >= 20) ? 1 : 2); case 'sl': return $n % 100 == 1 ? 1 : ($n % 100 == 2 ? 2 : ($n % 100 == 3 || $n % 100 == 4 ? 3 : 0)); - // de, en, es, it + // de, en, es, it, no default: return $n != 1 ? 1 : 0; } diff --git a/tpl/bootstrap.php b/tpl/bootstrap.php index 951ba1f6..aa91756c 100644 --- a/tpl/bootstrap.php +++ b/tpl/bootstrap.php @@ -69,7 +69,7 @@ if ($MARKDOWN): - + diff --git a/tpl/page.php b/tpl/page.php index a4bdce32..484b299e 100644 --- a/tpl/page.php +++ b/tpl/page.php @@ -47,7 +47,7 @@ if ($MARKDOWN): - + diff --git a/tst/I18nTest.php b/tst/I18nTest.php index 7c75b696..91c92aa6 100644 --- a/tst/I18nTest.php +++ b/tst/I18nTest.php @@ -58,6 +58,16 @@ class I18nTest extends PHPUnit_Framework_TestCase $this->assertEquals('2 heures', I18n::_('%d hours', 2), '2 hours in French'); } + public function testBrowserLanguageNoDetection() + { + $_SERVER['HTTP_ACCEPT_LANGUAGE'] = 'no;q=0.8,en-GB;q=0.6,en-US;q=0.4,en;q=0.2'; + I18n::loadTranslations(); + $this->assertEquals('no', I18n::_('en'), 'browser language no'); + $this->assertEquals('0 timer', I18n::_('%d hours', 0), '0 hours in Norwegian'); + $this->assertEquals('1 time', I18n::_('%d hours', 1), '1 hour in Norwegian'); + $this->assertEquals('2 timer', I18n::_('%d hours', 2), '2 hours in Norwegian'); + } + public function testBrowserLanguageOcDetection() { $_SERVER['HTTP_ACCEPT_LANGUAGE'] = 'oc;q=0.8,en-GB;q=0.6,en-US;q=0.4,en;q=0.2';