From 506129729e2c865326d8c20d8f81c8416bd6f56d Mon Sep 17 00:00:00 2001 From: Silversthorn Date: Sat, 5 Mar 2022 12:01:36 +0100 Subject: [PATCH] Update Translation - Adding Translation for Credits Page - Adding detection support for webpage --- app/classes/shared/helpers.py | 9 ++++++ app/classes/web/panel_handler.py | 14 +++++---- app/classes/web/public_handler.py | 6 +++- app/classes/web/server_handler.py | 5 +++- app/classes/web/status_handler.py | 1 + app/frontend/templates/base.html | 2 +- app/frontend/templates/panel/credits.html | 36 +++++++++++------------ app/frontend/templates/public_base.html | 2 +- app/translations/en_EN.json | 23 ++++++++++++++- app/translations/fr_FR.json | 26 ++++++++++++++-- 10 files changed, 94 insertions(+), 30 deletions(-) diff --git a/app/classes/shared/helpers.py b/app/classes/shared/helpers.py index 085c6921..8b0a9a84 100644 --- a/app/classes/shared/helpers.py +++ b/app/classes/shared/helpers.py @@ -862,4 +862,13 @@ class Helpers: return text[len(prefix):] return text + @staticmethod + def getLangPage(text): + lang = text.split("_")[0] + region = text.split("_")[1] + if region == 'EN': + return 'en' + else: + return lang+"-"+region + helper = Helpers() diff --git a/app/classes/web/panel_handler.py b/app/classes/web/panel_handler.py index 3de05375..2082006d 100644 --- a/app/classes/web/panel_handler.py +++ b/app/classes/web/panel_handler.py @@ -251,6 +251,7 @@ class PanelHandler(BaseHandler): 'error': error, 'time': formatted_time, 'lang': self.controller.users.get_user_lang_by_id(exec_user["user_id"]), + 'lang_page': helper.getLangPage(self.controller.users.get_user_lang_by_id(exec_user["user_id"])), 'super_user': superuser, 'api_key': { 'name': api_key.name, @@ -375,8 +376,6 @@ class PanelHandler(BaseHandler): user_order.remove(server_id) page_data['servers'] = page_servers - - #num players is set to zero here. If we poll all servers while dashboard is loading it takes FOREVER. We leave this to the #async polling once dashboard is served. page_data['num_players'] = 0 @@ -1596,7 +1595,8 @@ class PanelHandler(BaseHandler): user_id = self.controller.users.add_user(username, password=password0, email=email, enabled=enabled, superuser=superuser) user_data = { "roles": roles, - 'lang': lang + 'lang': lang, + 'lang_page': helper.getLangPage(lang), } user_crafty_data = { "permissions_mask": permissions_mask, @@ -1682,7 +1682,10 @@ class PanelHandler(BaseHandler): else: self.set_status(404) - page_data = {'lang': helper.get_setting('language')} + page_data = { + 'lang': helper.get_setting('language'), + 'lang_page': helper.getLangPage(helper.get_setting('language')), + } self.render( "public/404.html", translate=self.translator.translate, @@ -1704,7 +1707,8 @@ class PanelHandler(BaseHandler): 'user_data': exec_user, 'hosts_data': self.controller.management.get_latest_hosts_stats(), 'show_contribute': helper.get_setting("show_contribute_link", True), - 'lang': self.controller.users.get_user_lang_by_id(exec_user["user_id"]) + 'lang': self.controller.users.get_user_lang_by_id(exec_user["user_id"]), + 'lang_page': helper.getLangPage(self.controller.users.get_user_lang_by_id(exec_user["user_id"])), } if page == "remove_apikey": diff --git a/app/classes/web/public_handler.py b/app/classes/web/public_handler.py index 06a1d34c..95672130 100644 --- a/app/classes/web/public_handler.py +++ b/app/classes/web/public_handler.py @@ -39,7 +39,11 @@ class PublicHandler(BaseHandler): error = bleach.clean(self.get_argument('error', "Invalid Login!")) error_msg = bleach.clean(self.get_argument('error_msg', '')) - page_data = {'version': helper.get_version_string(), 'error': error, 'lang': helper.get_setting('language')} + page_data = { + 'version': helper.get_version_string(), + 'error': error, 'lang': helper.get_setting('language'), + 'lang_page': helper.getLangPage(helper.get_setting('language')) + } # sensible defaults template = "public/404.html" diff --git a/app/classes/web/server_handler.py b/app/classes/web/server_handler.py index e4009b11..d8855efa 100644 --- a/app/classes/web/server_handler.py +++ b/app/classes/web/server_handler.py @@ -75,6 +75,7 @@ class ServerHandler(BaseHandler): 'menu_servers': defined_servers, 'show_contribute': helper.get_setting("show_contribute_link", True), 'lang': self.controller.users.get_user_lang_by_id(exec_user["user_id"]), + 'lang_page': helper.getLangPage(self.controller.users.get_user_lang_by_id(exec_user["user_id"])), 'api_key': { 'name': api_key.name, 'created': api_key.created, @@ -84,6 +85,7 @@ class ServerHandler(BaseHandler): } if api_key is not None else None, 'superuser': superuser } + if helper.get_setting("allow_nsfw_profile_pictures"): rating = "x" else: @@ -139,7 +141,8 @@ class ServerHandler(BaseHandler): 'version_data': "version_data_here", # TODO 'user_data': exec_user, 'show_contribute': helper.get_setting("show_contribute_link", True), - 'lang': self.controller.users.get_user_lang_by_id(exec_user["user_id"]) + 'lang': self.controller.users.get_user_lang_by_id(exec_user["user_id"]), + 'lang_page': helper.getLangPage(self.controller.users.get_user_lang_by_id(exec_user["user_id"])) } if page == "command": diff --git a/app/classes/web/status_handler.py b/app/classes/web/status_handler.py index ebd5ab4a..ace2103a 100644 --- a/app/classes/web/status_handler.py +++ b/app/classes/web/status_handler.py @@ -9,6 +9,7 @@ class StatusHandler(BaseHandler): def get(self): page_data = {} page_data['lang'] = helper.get_setting('language') + page_data['lang_page'] = helper.getLangPage(helper.get_setting('language')) page_data['servers'] = self.controller.servers.get_all_servers_stats() for srv in page_data['servers']: server_data = srv.get('server_data', False) diff --git a/app/frontend/templates/base.html b/app/frontend/templates/base.html index 8f86cedf..bc81718d 100644 --- a/app/frontend/templates/base.html +++ b/app/frontend/templates/base.html @@ -1,5 +1,5 @@ - + diff --git a/app/frontend/templates/panel/credits.html b/app/frontend/templates/panel/credits.html index 3440e66d..4070e5dc 100644 --- a/app/frontend/templates/panel/credits.html +++ b/app/frontend/templates/panel/credits.html @@ -3,7 +3,7 @@ {% block meta %} {% end %} -{% block title %}Crafty Controller - Credits{% end %} +{% block title %}Crafty Controller - {{ translate('credits', 'pageTitle', data['lang']) }}{% end %} {% block content %} @@ -13,8 +13,8 @@
@@ -27,7 +27,7 @@
-

 Development Team

+

 {{ translate('credits', 'developmentTeam', data['lang']) }}

{% for person in data['staff']['development'] %} @@ -97,7 +97,7 @@
-

 Support and Documentation Team

+

 {{ translate('credits', 'supportTeam', data['lang']) }}

@@ -168,7 +168,7 @@
-

 Retired Staff

+

 {{ translate('credits', 'retiredStaff', data['lang']) }}

@@ -248,13 +248,13 @@
-

Patreon Supporters

-

A huge thank you  to our Patreon supporters! | Last Update: {{ data["lastUpdate"] }}

+

{{ translate('credits', 'patreonSupporter', data['lang']) }}

+

{{ translate('credits', 'hugeDesc', data['lang']) }} {{ translate('credits', 'thankYou', data['lang']) }}  {{ translate('credits', 'patreonDesc', data['lang']) }} | {{ translate('credits', 'patreonUpdate', data['lang']) }} {{ data["lastUpdate"] }}

- - + + @@ -263,13 +263,13 @@ @@ -284,13 +284,13 @@
-

Language Translation

-

A huge thank you  to our community who translate!

+

{{ translate('credits', 'translationTitle', data['lang']) }}

+

{{ translate('credits', 'hugeDesc', data['lang']) }} {{ translate('credits', 'thankYou', data['lang']) }}  {{ translate('credits', 'translationDesc', data['lang']) }}

NameLevel{{ translate('credits', 'patreonName', data['lang']) }}{{ translate('credits', 'patreonLevel', data['lang']) }}
{{ pat["name"] }} {% if pat["level"] == "Crafty Sustainer" %} - Sustainer + {{ translate('credits', 'patreonSustainer', data['lang']) }} {% elif pat["level"] == "Crafty Advocate" %} - Advocate + {{ translate('credits', 'patreonAdvocate', data['lang']) }} {% elif pat["level"] == "Crafty Supporter" %} - Supporter + {{ translate('credits', 'patreonSubs', data['lang']) }} {% else %} - Other + {{ translate('credits', 'patreonOther', data['lang']) }} {% end %}
- - + + diff --git a/app/frontend/templates/public_base.html b/app/frontend/templates/public_base.html index 3c9fa176..dcdb5b1b 100644 --- a/app/frontend/templates/public_base.html +++ b/app/frontend/templates/public_base.html @@ -1,5 +1,5 @@ - + diff --git a/app/translations/en_EN.json b/app/translations/en_EN.json index fcd04232..c365e0b0 100644 --- a/app/translations/en_EN.json +++ b/app/translations/en_EN.json @@ -510,6 +510,27 @@ "superUser": "Super User", "deleteKeyConfirmation": "Do you want to delete this API key? This cannot be undone.", "deleteKeyConfirmationTitle": "Remove API key ${keyId}?" + }, + "credits": { + "pageTitle": "Credits", + "pageDescription": "Without these people, you wouldn't have Crafty", + "developmentTeam": "Development Team", + "supportTeam": "Support and Documentation Team", + "retiredStaff": "Retired Staff", + "hugeDesc": "A huge", + "thankYou": "THANK YOU", + "patreonSupporter": "Patreon Supporters", + "patreonDesc": "to our Patreon supporters!", + "patreonUpdate": "Last Update:", + "patreonName": "Name", + "patreonLevel": "Level", + "patreonSustainer": "Sustainer", + "patreonAdvocate": "Advocate", + "patreonSubs": "Supporter", + "patreonOther": "Other", + "translationTitle": "Language Translation", + "translationDesc": "to our community who translate!", + "translationName": "Name", + "translator": "Translators" } - } \ No newline at end of file diff --git a/app/translations/fr_FR.json b/app/translations/fr_FR.json index 3f32aea4..ee2dfc31 100644 --- a/app/translations/fr_FR.json +++ b/app/translations/fr_FR.json @@ -89,7 +89,7 @@ "allServers": "Tous les Serverus", "server": "Serveur", "actions": "Actions", - "world": "Monde", + "size": "Taille du Serveur", "motd": "MOTD", "version": "Version", "status": "Statut", @@ -240,7 +240,7 @@ "options": "Options", "restoring": "Restauration de la sauvegarde. Cela peut prendre un peu de temps. S'il vous plaît soyez patient.", "restore": "Restaurer", - "confirmRestore": "Êtes-vous sûr de vouloir restaurer à partir de cette sauvegarde. Tous les fichiers du serveur actuel passeront à l'état de sauvegarde et seront irrécupérables.",, + "confirmRestore": "Êtes-vous sûr de vouloir restaurer à partir de cette sauvegarde. Tous les fichiers du serveur actuel passeront à l'état de sauvegarde et seront irrécupérables.", "excludedBackups": "Dossiers Exclus : ", "excludedChoose": "Choisir les dossiers à exclure de la sauvegarde", "clickExclude": "Cliquer pour sélectionner les Exclusions", @@ -510,5 +510,27 @@ "superUser": "Super Utilisateur", "deleteKeyConfirmation": "Es-tu sûr de vouloir supprimer cette clé API? Tu ne pourras plus revenir en arrière.", "deleteKeyConfirmationTitle": "Supprimer la clé API ${keyId}?" + }, + "credits": { + "pageTitle": "Crédits", + "pageDescription": "Sans ces personnes, vous n'auriez pas Crafty", + "developmentTeam": "Equipe de Développement", + "supportTeam": "Equipe de Support et de Documentation", + "retiredStaff": "Retraités de Crafty", + "hugeDesc": "Un Enorme", + "thankYou": "MERCI", + "patreonSupporter": "Soutiens Patreon", + "patreonDesc": "à nos Soutiens Patreon !", + "patreonUpdate": "Dernière mise à Jour :", + "patreonName": "Nom", + "patreonLevel": "Niveau", + "patreonSustainer": "Admirateur", + "patreonAdvocate": "Partisan", + "patreonSubs": "Supporter", + "patreonOther": "Autre", + "translationTitle": "Traductions", + "translationDesc": "à notre communauté qui traduit Crafty !", + "translationName": "Langue", + "translator": "Traducteurs" } }
NameStatus{{ translate('credits', 'translationName', data['lang']) }}{{ translate('credits', 'translator', data['lang']) }}