Added rudimentary translations (#11)

* Update picodulce.py

* Update picodulce.py

* Update picodulce.py

* Update picodulce.py

* Create healtcheck.py

* Update picodulce.py

* Update version.json

* Create locales-go-here

* Add files via upload

* Update version.json

* Update picodulce.py

* Update healtcheck.py

* Update picodulce.py

* Added more locales

* Update version.json

* Update picodulce.py
This commit is contained in:
Nix 2025-03-01 05:06:48 -03:00 committed by GitHub
parent ec99488326
commit 263e6eae07
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 453 additions and 292 deletions

152
healtcheck.py Normal file
View File

@ -0,0 +1,152 @@
import os
import json
import requests
class HealthCheck:
def __init__(self):
self.config = None
def check_config_file(self):
config_path = "config.json"
default_config = {
"IsRCPenabled": False,
"CheckUpdate": False,
"IsBleeding": False,
"LastPlayed": "",
"IsFirstLaunch": True,
"Instance": "default",
"Theme": "Dark.json",
"ThemeBackground": True,
"ThemeRepository": "https://raw.githubusercontent.com/nixietab/picodulce-themes/main/repo.json",
"Locale": "en"
}
# Step 1: Check if the file exists; if not, create it with default values
if not os.path.exists(config_path):
with open(config_path, "w") as config_file:
json.dump(default_config, config_file, indent=4)
self.config = default_config
return
# Step 2: Try loading the config file, handle invalid JSON
try:
with open(config_path, "r") as config_file:
self.config = json.load(config_file)
except (json.JSONDecodeError, ValueError):
# File is corrupted, overwrite it with default configuration
with open(config_path, "w") as config_file:
json.dump(default_config, config_file, indent=4)
self.config = default_config
return
# Step 3: Check for missing keys and add defaults if necessary
updated = False
for key, value in default_config.items():
if key not in self.config: # Field is missing
self.config[key] = value
updated = True
# Step 4: Save the repaired config back to the file
if updated:
with open(config_path, "w") as config_file:
json.dump(self.config, config_file, indent=4)
def themes_integrity(self):
# Define folder and file paths
themes_folder = "themes"
dark_theme_file = os.path.join(themes_folder, "Dark.json")
native_theme_file = os.path.join(themes_folder, "Native.json")
# Define the default content for Dark.json
dark_theme_content = {
"manifest": {
"name": "Dark",
"description": "The default picodulce launcher theme",
"author": "Nixietab",
"license": "MIT"
},
"palette": {
"Window": "#353535",
"WindowText": "#ffffff",
"Base": "#191919",
"AlternateBase": "#353535",
"ToolTipBase": "#ffffff",
"ToolTipText": "#ffffff",
"Text": "#ffffff",
"Button": "#353535",
"ButtonText": "#ffffff",
"BrightText": "#ff0000",
"Link": "#2a82da",
"Highlight": "#4bb679",
"HighlightedText": "#ffffff"
},
"background_image_base64": ""
}
# Define the default content for Native.json
native_theme_content = {
"manifest": {
"name": "Native",
"description": "The native looks of your OS",
"author": "Your Qt Style",
"license": "Any"
},
"palette": {}
}
# Step 1: Ensure the themes folder exists
if not os.path.exists(themes_folder):
print(f"Creating folder: {themes_folder}")
os.makedirs(themes_folder)
# Step 2: Ensure Dark.json exists
if not os.path.isfile(dark_theme_file):
print(f"Creating file: {dark_theme_file}")
with open(dark_theme_file, "w", encoding="utf-8") as file:
json.dump(dark_theme_content, file, indent=2)
print("Dark.json has been created successfully.")
# Step 3: Ensure Native.json exists
if not os.path.isfile(native_theme_file):
print(f"Creating file: {native_theme_file}")
with open(native_theme_file, "w", encoding="utf-8") as file:
json.dump(native_theme_content, file, indent=2)
print("Native.json has been created successfully.")
# Check if both files exist and print OK message
if os.path.isfile(dark_theme_file) and os.path.isfile(native_theme_file):
print("Theme Integrity OK")
def locales_integrity(self):
# Define the locales folder path
locales_folder = "locales"
version_url = "https://raw.githubusercontent.com/nixietab/picodulce/main/version.json"
# Step 1: Ensure the locales folder exists
if not os.path.exists(locales_folder):
print(f"Creating folder: {locales_folder}")
os.makedirs(locales_folder)
self.download_locales(version_url)
else:
print("Locales folder already exists.")
def download_locales(self, url):
response = requests.get(url)
if response.status_code == 200:
data = response.json()
locales_links = data.get("locales", [])
for link in locales_links:
locale_name = os.path.basename(link)
locale_path = os.path.join("locales", locale_name)
locale_response = requests.get(link)
if locale_response.status_code == 200:
with open(locale_path, "w", encoding="utf-8") as locale_file:
locale_file.write(locale_response.text)
print(f"Downloaded and created file: {locale_path}")
else:
print(f"Failed to download {link}")
else:
print("Failed to fetch version.json")

1
locales/locales-go-here Normal file
View File

@ -0,0 +1 @@

BIN
locales/picodulce_es.qm Normal file

Binary file not shown.

BIN
locales/picodulce_it.qm Normal file

Binary file not shown.

BIN
locales/picodulce_pt.qm Normal file

Binary file not shown.

File diff suppressed because it is too large Load Diff

View File

@ -1,5 +1,5 @@
{
"version": "0.12",
"version": "0.13",
"links": [
"https://raw.githubusercontent.com/nixietab/picodulce/main/version.json",
"https://raw.githubusercontent.com/nixietab/picodulce/main/picodulce.py",
@ -9,5 +9,10 @@
"https://raw.githubusercontent.com/nixietab/picodulce/main/holiday.ico",
"https://raw.githubusercontent.com/nixietab/picodulce/main/authser.py"
],
"locales": [
"https://raw.githubusercontent.com/nixietab/picodulce/main/locales/picodulce_es.qm",
"https://raw.githubusercontent.com/nixietab/picodulce/main/locales/picodulce_it.qm",
"https://raw.githubusercontent.com/nixietab/picodulce/main/locales/picodulce_pt.qm"
],
"versionBleeding": "0.12-174"
}