mirror of
https://github.com/penpot/penpot.git
synced 2025-01-26 00:19:07 -05:00
Merge pull request #2485 from penpot/niwinz-new-langs
Add new langs and some fixes
This commit is contained in:
commit
8f325e4303
3 changed files with 34 additions and 18 deletions
|
@ -11,6 +11,7 @@
|
||||||
- Fix shortcut texts alignment [Taiga #4275](https://tree.taiga.io/project/penpot/issue/4275)
|
- Fix shortcut texts alignment [Taiga #4275](https://tree.taiga.io/project/penpot/issue/4275)
|
||||||
- Fix some texts and a typo [Taiga #4215](https://tree.taiga.io/project/penpot/issue/4215)
|
- Fix some texts and a typo [Taiga #4215](https://tree.taiga.io/project/penpot/issue/4215)
|
||||||
- Fix twitter support account link [Taiga #4279](https://tree.taiga.io/project/penpot/issue/4279)
|
- Fix twitter support account link [Taiga #4279](https://tree.taiga.io/project/penpot/issue/4279)
|
||||||
|
- Fix lang autodetect issue [Taiga #4277](https://tree.taiga.io/project/penpot/issue/4277)
|
||||||
|
|
||||||
### :arrow_up: Deps updates
|
### :arrow_up: Deps updates
|
||||||
### :heart: Community contributions by (Thank you!)
|
### :heart: Community contributions by (Thank you!)
|
||||||
|
|
|
@ -44,11 +44,23 @@ marked.use({renderer});
|
||||||
// Templates
|
// Templates
|
||||||
|
|
||||||
function readLocales() {
|
function readLocales() {
|
||||||
const langs = ["ar", "ca", "de", "el", "en", "eu", "it", "es", "fa", "fr", "he", "nb_NO", "pl", "pt_BR", "ro", "ru", "tr", "zh_CN", "zh_Hant"];
|
const langs = ["ar", "ca", "de", "el", "en", "eu", "it", "es",
|
||||||
|
"fa", "fr", "he", "nb_NO", "pl", "pt_BR", "ro",
|
||||||
|
"ru", "tr", "zh_CN", "zh_Hant", "hr", "gl", "pt_PT",
|
||||||
|
// this happens when file does not matches correct
|
||||||
|
// iso code for the language.
|
||||||
|
["ja_jp", "jpn_JP"]
|
||||||
|
];
|
||||||
const result = {};
|
const result = {};
|
||||||
|
|
||||||
for (let lang of langs) {
|
for (let lang of langs) {
|
||||||
const content = fs.readFileSync(`./translations/${lang}.po`, {encoding:"utf-8"});
|
let filename = `${lang}.po`;
|
||||||
|
if (l.isArray(lang)) {
|
||||||
|
filename = `${lang[1]}.po`;
|
||||||
|
lang = lang[0]
|
||||||
|
}
|
||||||
|
|
||||||
|
const content = fs.readFileSync(`./translations/${filename}`, {encoding:"utf-8"});
|
||||||
|
|
||||||
lang = lang.toLowerCase();
|
lang = lang.toLowerCase();
|
||||||
|
|
||||||
|
|
|
@ -24,20 +24,24 @@
|
||||||
[{:label "English" :value "en"}
|
[{:label "English" :value "en"}
|
||||||
{:label "Español" :value "es"}
|
{:label "Español" :value "es"}
|
||||||
{:label "Català" :value "ca"}
|
{:label "Català" :value "ca"}
|
||||||
{:label "Français (community)" :value "fr"}
|
|
||||||
{:label "Deutsch (community)" :value "de"}
|
{:label "Deutsch (community)" :value "de"}
|
||||||
{:label "Italiano (community)" :value "it"}
|
|
||||||
{:label "Euskera (community)" :value "eu"}
|
{:label "Euskera (community)" :value "eu"}
|
||||||
|
{:label "Français (community)" :value "fr"}
|
||||||
|
{:label "Gallego (Community)" :value "gl"}
|
||||||
|
{:label "Hrvatski (Community)" :value "hr"}
|
||||||
|
{:label "Italiano (community)" :value "it"}
|
||||||
{:label "Norsk - Bokmål (community)" :value "nb_no"}
|
{:label "Norsk - Bokmål (community)" :value "nb_no"}
|
||||||
{:label "Portuguese - Brazil (community)" :value "pt_br"}
|
|
||||||
{:label "Polski (community)" :value "pl"}
|
{:label "Polski (community)" :value "pl"}
|
||||||
{:label "Русский (community)" :value "ru"}
|
{:label "Portuguese - Brazil (community)" :value "pt_br"}
|
||||||
|
{:label "Portuguese - Portugal (community)" :value "pt_pt"}
|
||||||
{:label "Rumanian (community)" :value "ro"}
|
{:label "Rumanian (community)" :value "ro"}
|
||||||
{:label "Türkçe (community)" :value "tr"}
|
{:label "Türkçe (community)" :value "tr"}
|
||||||
{:label "Ελληνική γλώσσα (community)" :value "el"}
|
{:label "Ελληνική γλώσσα (community)" :value "el"}
|
||||||
|
{:label "Русский (community)" :value "ru"}
|
||||||
{:label "עִבְרִית (community)" :value "he"}
|
{:label "עִבְרִית (community)" :value "he"}
|
||||||
{:label "عربي/عربى (community)" :value "ar"}
|
{:label "عربي/عربى (community)" :value "ar"}
|
||||||
{:label "فارسی (community)" :value "fa"}
|
{:label "فارسی (community)" :value "fa"}
|
||||||
|
{:label "日本語 (Community)" :value "ja_jp"}
|
||||||
{:label "简体中文 (community)" :value "zh_cn"}
|
{:label "简体中文 (community)" :value "zh_cn"}
|
||||||
{:label "繁體中文 (community)" :value "zh_hant"}])
|
{:label "繁體中文 (community)" :value "zh_hant"}])
|
||||||
|
|
||||||
|
@ -68,19 +72,22 @@
|
||||||
(defonce locale (l/atom (or (get @storage ::locale)
|
(defonce locale (l/atom (or (get @storage ::locale)
|
||||||
(autodetect))))
|
(autodetect))))
|
||||||
|
|
||||||
;; The translations `data` is a javascript object and should be treated
|
|
||||||
;; with `goog.object` namespace functions instead of a standard
|
|
||||||
;; clojure functions. This is for performance reasons because this
|
|
||||||
;; code is executed in the critical part (application bootstrap) and
|
|
||||||
;; used in many parts of the application.
|
|
||||||
|
|
||||||
(defn init!
|
(defn init!
|
||||||
|
"Initialize the i18n module with translations.
|
||||||
|
|
||||||
|
The `data` is a javascript object for performance reasons. This code
|
||||||
|
is executed in the critical part (application bootstrap) and used in
|
||||||
|
many parts of the application."
|
||||||
[data]
|
[data]
|
||||||
(set! translations data))
|
(set! translations data))
|
||||||
|
|
||||||
(defn set-locale!
|
(defn set-locale!
|
||||||
[lname]
|
[lname]
|
||||||
(if lname
|
(if (or (nil? lname)
|
||||||
|
(str/empty? lname))
|
||||||
|
(let [lname (autodetect)]
|
||||||
|
(swap! storage dissoc ::locale)
|
||||||
|
(reset! locale lname))
|
||||||
(let [supported (into #{} (map :value supported-locales))
|
(let [supported (into #{} (map :value supported-locales))
|
||||||
lname (loop [locales (seq (parse-locale lname))]
|
lname (loop [locales (seq (parse-locale lname))]
|
||||||
(if-let [locale (first locales)]
|
(if-let [locale (first locales)]
|
||||||
|
@ -88,11 +95,7 @@
|
||||||
locale
|
locale
|
||||||
(recur (rest locales)))
|
(recur (rest locales)))
|
||||||
cfg/default-language))]
|
cfg/default-language))]
|
||||||
|
|
||||||
(swap! storage assoc ::locale lname)
|
(swap! storage assoc ::locale lname)
|
||||||
(reset! locale lname))
|
|
||||||
(let [lname (autodetect)]
|
|
||||||
(swap! storage dissoc ::locale)
|
|
||||||
(reset! locale lname))))
|
(reset! locale lname))))
|
||||||
|
|
||||||
(defn reset-locale
|
(defn reset-locale
|
||||||
|
@ -102,7 +105,7 @@
|
||||||
(swap! storage dissoc ::locale)
|
(swap! storage dissoc ::locale)
|
||||||
(reset! locale (autodetect)))
|
(reset! locale (autodetect)))
|
||||||
|
|
||||||
(add-watch locale ::browser-font
|
(add-watch locale "browser-font"
|
||||||
(fn [_ _ _ locale]
|
(fn [_ _ _ locale]
|
||||||
(log/info :hint "locale changed" :locale locale)
|
(log/info :hint "locale changed" :locale locale)
|
||||||
(dom/set-html-lang! locale)
|
(dom/set-html-lang! locale)
|
||||||
|
|
Loading…
Add table
Reference in a new issue