feat(ui): add custom theme color support and share app functionality

Introduce a new custom theme feature that allows users to personalize the application background color using RGB sliders, hex input, or a set of predefined palettes.

Key changes include:
* **Custom Theme Engine**: Added `CustomThemeFragment` and `ThemeHelper` to manage color selection and application. The UI dynamically updates the background color across the `MainActivity` and `PlayerFragment` when preferences change.
* **Android TV Support**: Provided a specialized layout for television devices (`fragment_custom_theme.xml` in `layout-television`) with optimized focus handling for D-pad navigation.
* **Share Feature**: Implemented a "Share App" preference in `SettingsFragment` that triggers a standard Android share intent and displays a thank-you notification upon use.
* **Localization**: Added Ukrainian language support and updated string resources for multiple locales (DE, DA, EL, FR, JA, NL, PL, RU) to include the new theme and share options.
* **Persistence**: Updated `PreferencesHelper` and `Keys` to store theme-related settings, including the enabled state, selected color, and predefined color index.
This commit is contained in:
2026-06-01 19:32:46 +02:00
parent 4429ed4057
commit 181ebd47df
29 changed files with 947 additions and 3 deletions
+19
View File
@@ -160,5 +160,24 @@
<string name="media_route_menu_title">Streamen</string>
<string name="pref_visualizer_title">Spektrumanzeige</string>
<string name="pref_visualizer_summary">Sehe die Spektrumanzeige.</string>
<string name="pref_share_app_title">App teilen</string>
<string name="pref_share_app_summary">Empfehle diese App einem Freund.</string>
<string name="pref_share_app_share_text">Schau dir diese tolle Radio-App an: https://github.com/michatec/Radio</string>
<string name="pref_share_app_thank_title">Vielen Dank!</string>
<string name="pref_share_app_thank_message">Ein großes Dankeschön von den Entwicklern.</string>
<string name="loading">Lade…</string>
<!-- Custom Theme -->
<string name="pref_custom_theme_enabled_summary">Aktiviert den Tab für das benutzerdefinierte Design.</string>
<string name="pref_custom_theme_disabled_summary">Deaktiviert den Tab für das benutzerdefinierte Design.</string>
<string name="pref_custom_theme_summary">Passen Sie die Hintergrundfarbe der Anwendung an.</string>
<string name="pref_custom_theme_title">Benutzerdefiniertes Design</string>
<string name="pref_custom_theme_enabled_title">Benutzerdefiniertes Design aktivieren</string>
<string name="theme_predefined_colors">Vordefinierte Farben (Hell/Dunkel):</string>
<string name="theme_custom_rgb">Benutzerdefiniertes RGB (bitte an die App anpassen):</string>
<string name="theme_red">Rot</string>
<string name="theme_green">Grün</string>
<string name="theme_blue">Blau</string>
<string name="hex_code">Hex-Code</string>
</resources>