mirror of
https://github.com/markqvist/reticulum_website.git
synced 2024-10-01 03:15:41 -04:00
Added multilingual support to build script
This commit is contained in:
parent
58daac8d5b
commit
801a8bb7a4
4
Makefile
4
Makefile
@ -10,8 +10,8 @@ website:
|
||||
python ./build.py
|
||||
cp assets/css/* build/css/
|
||||
cp assets/gfx/* build/gfx/
|
||||
cp -rv ../../Reticulum/docs/manual/* build/manual/
|
||||
cp -rv ../../Reticulum/docs/Reticulum\ Manual.pdf build/manual/
|
||||
cp -r ../../Reticulum/docs/manual/* build/manual/
|
||||
cp -r ../../Reticulum/docs/Reticulum\ Manual.pdf build/manual/
|
||||
|
||||
upload:
|
||||
. ./build.env; \
|
||||
|
89
build.py
89
build.py
@ -23,10 +23,85 @@ document_end = """
|
||||
</html>
|
||||
"""
|
||||
|
||||
menu_md = """
|
||||
<center>[Reticulum](index.html) | [Start](start.html) | [Hardware](hardware.html) | [Testnet](connect.html) | [Manual](docs.html) | [Crypto](crypto.html) | [Credits](credits.html) | [Source](https://github.com/markqvist/reticulum) | [Donate](donate.html)</center>
|
||||
langs_md = """
|
||||
<center>{LANGS}</center>
|
||||
"""
|
||||
|
||||
menu_md = """
|
||||
<center>[{RETICULUM}](index{LANG_EXT}.html) | [{START}](start{LANG_EXT}.html) | [{HARDWARE}](hardware{LANG_EXT}.html) | [{TESTNET}](connect{LANG_EXT}.html) | [{MANUAL}](docs{LANG_EXT}.html) | [{CRYPTO}](crypto{LANG_EXT}.html) | [{CREDITS}](credits{LANG_EXT}.html) | [{SOURCE}](https://github.com/markqvist/reticulum) | [{DONATE}](donate{LANG_EXT}.html)</center>
|
||||
"""
|
||||
|
||||
primary_lang = "en"
|
||||
langs = [
|
||||
{"name": "English", "ext": "en"},
|
||||
{"name": "Português", "ext": "pt-br"},
|
||||
]
|
||||
|
||||
menu_translations = {
|
||||
"en": {
|
||||
"RETICULUM": "Reticulum",
|
||||
"START": "Start",
|
||||
"HARDWARE": "Hardware",
|
||||
"TESTNET": "Testnet",
|
||||
"MANUAL": "Manual",
|
||||
"CRYPTO": "Crypto",
|
||||
"CREDITS": "Credits",
|
||||
"SOURCE": "Source",
|
||||
"DONATE": "Donate",
|
||||
},
|
||||
"pt-br": {
|
||||
"RETICULUM": "Reticulum",
|
||||
"START": "Começar",
|
||||
"HARDWARE": "Hardware",
|
||||
"TESTNET": "Rede de Teste",
|
||||
"MANUAL": "Manual",
|
||||
"CRYPTO": "Cripto",
|
||||
"CREDITS": "Créditos",
|
||||
"SOURCE": "Código",
|
||||
"DONATE": "Ajude",
|
||||
}
|
||||
}
|
||||
|
||||
def get_page_lang(page):
|
||||
page_lang = primary_lang
|
||||
for lang in langs:
|
||||
base_name = mdf.replace(".md", "")
|
||||
if lang["ext"] != primary_lang:
|
||||
if base_name.endswith(lang["ext"]):
|
||||
page_lang = lang["ext"]
|
||||
return page_lang
|
||||
|
||||
def get_languages_md(page):
|
||||
page = page.replace(SOURCES_PATH, ".")
|
||||
current_page_lang = get_page_lang(page)
|
||||
if current_page_lang != primary_lang:
|
||||
page_base_name = page.replace("_"+current_page_lang+".md", "")
|
||||
else:
|
||||
page_base_name = page.replace(".md", "")
|
||||
|
||||
lang_list = ""
|
||||
for lang_entry in langs:
|
||||
lang = lang_entry["name"]
|
||||
lang_ext = lang_entry["ext"]
|
||||
if lang_ext != primary_lang:
|
||||
lang_ext_str = "_"+lang_ext
|
||||
else:
|
||||
lang_ext_str = ""
|
||||
|
||||
link_target = page_base_name+lang_ext_str+".html"
|
||||
link_md = "["+lang+"]("+link_target+") |"
|
||||
lang_list += link_md
|
||||
|
||||
return langs_md.replace("{LANGS}", lang_list[:-2])
|
||||
|
||||
|
||||
def get_menu_md(lang):
|
||||
local_menu_md = menu_md
|
||||
for entry in menu_translations[lang]:
|
||||
local_menu_md = local_menu_md.replace("{"+entry+"}", menu_translations[lang][entry])
|
||||
|
||||
return local_menu_md
|
||||
|
||||
def scan_pages(base_path):
|
||||
files = [file for file in os.listdir(base_path) if os.path.isfile(os.path.join(base_path, file)) and file[:1] != "."]
|
||||
directories = [file for file in os.listdir(base_path) if os.path.isdir(os.path.join(base_path, file)) and file[:1] != "."]
|
||||
@ -46,8 +121,16 @@ source_files = scan_pages(SOURCES_PATH)
|
||||
|
||||
for mdf in source_files:
|
||||
with open(mdf, "rb") as f:
|
||||
page_lang = get_page_lang(mdf)
|
||||
|
||||
if page_lang != primary_lang:
|
||||
page_lang_ext = "_"+page_lang
|
||||
else:
|
||||
page_lang_ext = ""
|
||||
|
||||
md = f.read().decode(INPUT_ENCODING)
|
||||
html = markdown.markdown(menu_md + md, extensions=["markdown.extensions.fenced_code"])
|
||||
page_md = get_languages_md(mdf)+get_menu_md(page_lang).replace("{LANG_EXT}", page_lang_ext) + md
|
||||
html = markdown.markdown(page_md, extensions=["markdown.extensions.fenced_code"])
|
||||
html = document_start + html + document_end
|
||||
|
||||
of = BUILD_PATH+mdf.replace(SOURCES_PATH, "").replace(".md", ".html")
|
||||
|
@ -1,15 +1,20 @@
|
||||
## Ajude o Reticulum
|
||||
Você pode ajudar na continuação do desenvolvimento de sistemas de comunicação abertos, livres e privados, doando através de um dos seguintes canais:
|
||||
|
||||
**Monero**
|
||||
```
|
||||
84FpY1QbxHcgdseePYNmhTHcrgMX4nFfBYtz2GKYToqHVVhJp8Eaw1Z1EedRnKD19b3B8NiLCGVxzKV17UMmmeEsCrPyA5w
|
||||
```
|
||||
**Ethereum**
|
||||
```
|
||||
0x81F7B979fEa6134bA9FD5c701b3501A2e61E897a
|
||||
```
|
||||
**Bitcoin**
|
||||
```
|
||||
3CPmacGm34qYvR6XWLVEJmi2aNe3PZqUuq
|
||||
```
|
||||
- Monero<br/>
|
||||
```
|
||||
84FpY1QbxHcgdseePYNmhTHcrgMX4nFfBYtz2GKYToqHVVhJp8Eaw1Z1EedRnKD19b3B8NiLCGVxzKV17UMmmeEsCrPyA5w
|
||||
```
|
||||
<br/><br/>
|
||||
- Ethereum<br/>
|
||||
```
|
||||
0x81F7B979fEa6134bA9FD5c701b3501A2e61E897a
|
||||
```
|
||||
<br/><br/>
|
||||
- Bitcoin<br/>
|
||||
```
|
||||
3CPmacGm34qYvR6XWLVEJmi2aNe3PZqUuq
|
||||
```
|
||||
<br/><br/>
|
||||
- Ko-Fi<br/>
|
||||
<a href="https://ko-fi.com/markqvist">`https://ko-fi.com/markqvist`</a>
|
Loading…
Reference in New Issue
Block a user