Compare commits

...

200 Commits

Author SHA1 Message Date
Lei Nelissen
f4f5089d7f chore: bump android version 2025-01-27 23:39:33 +01:00
Lei Nelissen
34916e4ca0 fix: force react-native-skia to adhere to ndk version 2025-01-27 23:35:06 +01:00
Lei Nelissen
b1c86f2142 fix: save store file to filesystem
AsyncStorage can only save 2MB on Android. This might not be enough for large libraries. Hence, we'll save the file to disk, where space is (virtually) unlimited
2025-01-27 17:21:44 +01:00
Lei Nelissen
4e30fa0a40 chore: update changelog 2025-01-27 17:20:51 +01:00
Lei Nelissen
3629f8c756 chore: finish v2.4.0 release 2025-01-26 23:44:39 +01:00
Lei Nelissen
314bc3b2c4 chore: prepare for release 2025-01-26 23:41:07 +01:00
Lei Nelissen
b9e8a94c7a fix: ensure all cover images load properly 2025-01-26 23:10:24 +01:00
Lei Nelissen
6316814eba feat: also store cover images for downloaded tracks 2025-01-26 22:55:09 +01:00
Lei Nelissen
8bef5c66e3 fix: bump blur-view 2025-01-26 22:07:05 +01:00
Lei Nelissen
96a11804ba fix: missing cover images in now playing view
(fixes #245 and fixes #209)
2025-01-26 21:59:46 +01:00
Lei Nelissen
9462a3e294 fix: more accurately return current track 2025-01-26 21:23:18 +01:00
Lei Nelissen
f90e9be378 feat: enable playlists for emby
(fixes #242)
2025-01-26 21:22:00 +01:00
Weblate (bot)
cacdba531d chore: Translations update from Hosted Weblate (#266)
* Translated using Weblate (Chinese (Simplified))

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (French)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/

* Translated using Weblate (French)

Currently translated at 100.0% (10 of 10 strings)

Translation: Fintunes/App Store
Translate-URL: https://hosted.weblate.org/projects/fintunes/app-store/fr/

* Translated using Weblate (French)

Currently translated at 100.0% (3 of 3 strings)

Translation: Fintunes/Play Store & F-Droid
Translate-URL: https://hosted.weblate.org/projects/fintunes/play-store-f-droid/fr/

* Translated using Weblate (Spanish)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/

* Translated using Weblate (Ukrainian)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/

* Translated using Weblate (German)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (German)

Currently translated at 100.0% (3 of 3 strings)

Translation: Fintunes/Play Store & F-Droid
Translate-URL: https://hosted.weblate.org/projects/fintunes/play-store-f-droid/de/

* Translated using Weblate (Dutch)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nl/

* Translated using Weblate (French)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (German)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (French)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/

* feat: Added translation using Weblate (Indonesian)

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (German)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (German)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* feat: Added translation using Weblate (Chinese (Traditional Han script))

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 1.2% (1 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hant/

* Translated using Weblate (Spanish)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Catalan)

Currently translated at 64.6% (53 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Czech)

Currently translated at 79.2% (65 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 1.2% (1 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hant/

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 1.2% (1 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hant/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Catalan)

Currently translated at 64.6% (53 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

* Translated using Weblate (Catalan)

Currently translated at 64.6% (53 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Czech)

Currently translated at 79.2% (65 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hant/

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 100.0% (10 of 10 strings)

Translation: Fintunes/App Store
Translate-URL: https://hosted.weblate.org/projects/fintunes/app-store/zh_Hant/

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 100.0% (3 of 3 strings)

Translation: Fintunes/Play Store & F-Droid
Translate-URL: https://hosted.weblate.org/projects/fintunes/play-store-f-droid/zh_Hant/

* feat: Added translation using Weblate (Finnish)

* Translated using Weblate (Finnish)

Currently translated at 2.4% (2 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fi/

* Translated using Weblate (Finnish)

Currently translated at 2.4% (2 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fi/

* Translated using Weblate (Finnish)

Currently translated at 2.4% (2 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fi/

* Translated using Weblate (Finnish)

Currently translated at 1.2% (1 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fi/

* Translated using Weblate (Finnish)

Currently translated at 1.2% (1 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fi/

* Translated using Weblate (Finnish)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fi/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Catalan)

Currently translated at 64.6% (53 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* feat: Added translation using Weblate (Tamil)

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ta/

* Translated using Weblate (Tamil)

Currently translated at 100.0% (10 of 10 strings)

Translation: Fintunes/App Store
Translate-URL: https://hosted.weblate.org/projects/fintunes/app-store/ta/

* Translated using Weblate (Tamil)

Currently translated at 100.0% (3 of 3 strings)

Translation: Fintunes/Play Store & F-Droid
Translate-URL: https://hosted.weblate.org/projects/fintunes/play-store-f-droid/ta/

* Translated using Weblate (Japanese)

Currently translated at 98.7% (81 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

---------

Co-authored-by: 無情天 <kofzhanganguo@126.com>
Co-authored-by: LibreTranslate <noreply-mt-libretranslate@weblate.org>
Co-authored-by: V M <lefoufou.du93@googlemail.com>
Co-authored-by: gallegonovato <fran-carro@hotmail.es>
Co-authored-by: Dan <jonweblin2205@protonmail.com>
Co-authored-by: Julius Mueller <tech_stuff@kaffeeschluerfer.com>
Co-authored-by: Justin Vorrink <justinvorrink@outlook.com>
Co-authored-by: Weblate Translation Memory <noreply-mt-weblate-translation-memory@weblate.org>
Co-authored-by: Jean Yves <darksnip83@gmail.com>
Co-authored-by: AGUNG ADI KURNIAWAN <agungadi.kurniawan25@gmail.com>
Co-authored-by: Whoever4976 <wolffjonas47@gmail.com>
Co-authored-by: Benediktisda <huber.bene@icloud.com>
Co-authored-by: lin49931104 <a82122794@gmail.com>
Co-authored-by: Franco Castillo <castillofrancodamian@gmail.com>
Co-authored-by: Meow Lu <ttsmcpe@gmail.com>
Co-authored-by: L4p3K <kyllonen@gmail.com>
Co-authored-by: தமிழ்நேரம் <anishprabu.t@gmail.com>
Co-authored-by: mict213 <ag625197@gmail.com>
2025-01-26 20:44:29 +01:00
Lei Nelissen
2f1b9c180d fix: clean up lyrics implementation 2025-01-26 20:37:28 +01:00
Weblate (bot)
dc9541eea7 chore: Translations update from Hosted Weblate (#237)
* Translated using Weblate (Chinese (Simplified))

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (French)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/

* Translated using Weblate (French)

Currently translated at 100.0% (10 of 10 strings)

Translation: Fintunes/App Store
Translate-URL: https://hosted.weblate.org/projects/fintunes/app-store/fr/

* Translated using Weblate (French)

Currently translated at 100.0% (3 of 3 strings)

Translation: Fintunes/Play Store & F-Droid
Translate-URL: https://hosted.weblate.org/projects/fintunes/play-store-f-droid/fr/

* Translated using Weblate (Spanish)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/

* Translated using Weblate (Ukrainian)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/

* Translated using Weblate (German)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (German)

Currently translated at 100.0% (3 of 3 strings)

Translation: Fintunes/Play Store & F-Droid
Translate-URL: https://hosted.weblate.org/projects/fintunes/play-store-f-droid/de/

* Translated using Weblate (Dutch)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nl/

* Translated using Weblate (French)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (German)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (French)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/

* feat: Added translation using Weblate (Indonesian)

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (German)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (German)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* feat: Added translation using Weblate (Chinese (Traditional Han script))

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 1.2% (1 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hant/

* Translated using Weblate (Spanish)

Currently translated at 100.0% (82 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Catalan)

Currently translated at 64.6% (53 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Czech)

Currently translated at 79.2% (65 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/

* Translated using Weblate (Indonesian)

Currently translated at 0.0% (0 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/id/

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 1.2% (1 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hant/

* Translated using Weblate (Chinese (Traditional Han script))

Currently translated at 1.2% (1 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hant/

---------

Co-authored-by: 無情天 <kofzhanganguo@126.com>
Co-authored-by: LibreTranslate <noreply-mt-libretranslate@weblate.org>
Co-authored-by: V M <lefoufou.du93@googlemail.com>
Co-authored-by: gallegonovato <fran-carro@hotmail.es>
Co-authored-by: Dan <jonweblin2205@protonmail.com>
Co-authored-by: Julius Mueller <tech_stuff@kaffeeschluerfer.com>
Co-authored-by: Justin Vorrink <justinvorrink@outlook.com>
Co-authored-by: Weblate Translation Memory <noreply-mt-weblate-translation-memory@weblate.org>
Co-authored-by: Jean Yves <darksnip83@gmail.com>
Co-authored-by: AGUNG ADI KURNIAWAN <agungadi.kurniawan25@gmail.com>
Co-authored-by: Whoever4976 <wolffjonas47@gmail.com>
Co-authored-by: Benediktisda <huber.bene@icloud.com>
Co-authored-by: lin49931104 <a82122794@gmail.com>
Co-authored-by: Franco Castillo <castillofrancodamian@gmail.com>
2024-11-11 12:33:59 +01:00
Lei Nelissen
b9a6c66584 fix: prevent error on lyrics screen when tab height is unavailable 2024-11-08 12:21:00 +01:00
Lei Nelissen
b03d449a1b fix: show past lyrics in grey 2024-10-25 00:27:37 +02:00
Lei Nelissen
77db5a51d2 fix: retrieve codec metadata and lyrics asynchronously 2024-10-25 00:25:01 +02:00
Lei Nelissen
4dd0d6e0e5 chore: release v.2.4.0-beta.5 2024-10-15 15:29:37 +02:00
Lei Nelissen
f2cac91e2f fix: missing background on track pop-up menu 2024-10-12 23:03:44 +02:00
Lei Nelissen
2c42a897d9 fix: accept any valid mime type for downloadable tracks 2024-10-12 22:57:20 +02:00
Lei Nelissen
502f39db0e chore: bump upload-artifact action 2024-10-11 11:12:56 +02:00
Lei Nelissen
1972f489aa fix: support audio/ogg in downloads 2024-10-11 10:50:42 +02:00
Lei Nelissen
95d8748936 chore: update testflight link 2024-08-12 14:20:04 +02:00
Lei Nelissen
38af15fe44 chore: release beta on testflight 2024-07-26 15:42:45 +02:00
Lei Nelissen
6283c8cfa5 chore: remove redundant log 2024-07-26 12:01:48 +02:00
Lei Nelissen
01e25a89b1 fix: missing image covers for emby 2024-07-26 12:01:21 +02:00
Lei Nelissen
399340127d fix: properly pre-insert queued tracks before played track 2024-07-26 10:40:52 +02:00
Lei Nelissen
b6431bf71d chore: fix nl translation 2024-07-26 10:26:30 +02:00
Weblate (bot)
6668479bc2 chore: Translations update from Hosted Weblate (#236)
* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Spanish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/

* Translated using Weblate (French)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Japanese)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Dutch)

Currently translated at 95.1% (78 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nl/

* Translated using Weblate (Chinese (Simplified))

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/

* Translated using Weblate (Ukrainian)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/

* Translated using Weblate (Polish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Italian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/

* Translated using Weblate (Swedish)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/

* Translated using Weblate (German)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (German)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Russian)

Currently translated at 86.5% (71 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Catalan)

Currently translated at 64.6% (53 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

* Translated using Weblate (Catalan)

Currently translated at 64.6% (53 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 89.0% (73 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Slovenian)

Currently translated at 87.8% (72 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sl/

* Translated using Weblate (Danish)

Currently translated at 59.7% (49 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Czech)

Currently translated at 79.2% (65 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/

* Translated using Weblate (Czech)

Currently translated at 79.2% (65 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/

---------

Co-authored-by: LibreTranslate <noreply-mt-libretranslate@weblate.org>
Co-authored-by: Weblate Translation Memory <noreply-mt-weblate-translation-memory@weblate.org>
2024-07-26 10:25:10 +02:00
Lei Nelissen
ba9d049699 Merge remote-tracking branch 'weblate/main' 2024-07-25 23:39:00 +02:00
Weblate Translation Memory
eb5cf684cd Translated using Weblate (Czech)
Currently translated at 82.9% (68 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/
2024-07-25 23:37:04 +02:00
LibreTranslate
6a950ecbad Translated using Weblate (Czech)
Currently translated at 82.9% (68 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/
2024-07-25 23:37:04 +02:00
Weblate Translation Memory
10547540f7 Translated using Weblate (Slovenian)
Currently translated at 91.4% (75 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sl/
2024-07-25 23:37:04 +02:00
Weblate Translation Memory
260674ece3 Translated using Weblate (Swedish)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/
2024-07-25 23:37:04 +02:00
LibreTranslate
8510fe358a Translated using Weblate (Swedish)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/
2024-07-25 23:37:04 +02:00
Weblate Translation Memory
eb6b4a05c8 Translated using Weblate (Italian)
Currently translated at 91.4% (75 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-25 23:37:04 +02:00
LibreTranslate
4dee62aaaa Translated using Weblate (Italian)
Currently translated at 91.4% (75 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-25 23:37:04 +02:00
Weblate Translation Memory
286509d1db Translated using Weblate (Polish)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-25 23:37:04 +02:00
LibreTranslate
7b723cd653 Translated using Weblate (Polish)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-25 23:37:04 +02:00
Weblate Translation Memory
1804e54f10 Translated using Weblate (Norwegian Bokmål)
Currently translated at 68.2% (56 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nb_NO/
2024-07-25 23:37:04 +02:00
Weblate Translation Memory
e91d34c9f1 Translated using Weblate (Chinese (Simplified))
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/
2024-07-25 23:37:04 +02:00
LibreTranslate
0bc6c91c2e Translated using Weblate (Chinese (Simplified))
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/
2024-07-25 23:37:04 +02:00
Weblate Translation Memory
c6026c8148 Translated using Weblate (French)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-25 23:37:03 +02:00
LibreTranslate
5bb633b836 Translated using Weblate (French)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-25 23:37:03 +02:00
Weblate Translation Memory
14f4a27ce6 Translated using Weblate (Spanish)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/
2024-07-25 23:37:03 +02:00
LibreTranslate
7afe170da5 Translated using Weblate (Spanish)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/
2024-07-25 23:37:03 +02:00
Lei Nelissen
a6452f0a5e feat: Emby support (#234)
* fix: support credential extraction from Emby

* fix: minor compatibility with emby for retrieving albums

* fix: rename credentials and save credentials type

* fix: weird issue when changing libraries

* fix: correctly map platform names in auth header

* chore: properly carry over old settings

* fix: only enable playlists on jellyfin

* fix: remove jellyfin mentions

* fix: incorporate jellyfin and emby as mentions
2024-07-25 23:37:00 +02:00
Weblate (bot)
c15f8fe1fc chore: Translations update from Hosted Weblate (#235)
* Translated using Weblate (Japanese)

Currently translated at 91.4% (75 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Japanese)

Currently translated at 91.4% (75 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/

* Translated using Weblate (Ukrainian)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/

* Translated using Weblate (Ukrainian)

Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/

* Translated using Weblate (German)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (German)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/

* Translated using Weblate (Russian)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Russian)

Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 92.6% (76 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Portuguese (Brazil))

Currently translated at 92.6% (76 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/

* Translated using Weblate (Danish)

Currently translated at 56.0% (46 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Danish)

Currently translated at 56.0% (46 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/

* Translated using Weblate (Bulgarian)

Currently translated at 92.6% (76 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/bg/

* Translated using Weblate (Catalan)

Currently translated at 60.9% (50 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

* Translated using Weblate (Catalan)

Currently translated at 60.9% (50 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/

---------

Co-authored-by: LibreTranslate <noreply-mt-libretranslate@weblate.org>
Co-authored-by: Weblate Translation Memory <noreply-mt-weblate-translation-memory@weblate.org>
2024-07-25 23:36:27 +02:00
Weblate Translation Memory
f223cbab3a Translated using Weblate (Catalan)
Currently translated at 60.9% (50 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/
2024-07-25 23:35:30 +02:00
LibreTranslate
6c7b3d2198 Translated using Weblate (Catalan)
Currently translated at 60.9% (50 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/
2024-07-25 23:35:30 +02:00
Weblate Translation Memory
806e8577f0 Translated using Weblate (Bulgarian)
Currently translated at 92.6% (76 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/bg/
2024-07-25 23:35:18 +02:00
Weblate Translation Memory
019cdd9e20 Translated using Weblate (Danish)
Currently translated at 56.0% (46 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/
2024-07-25 23:35:18 +02:00
LibreTranslate
766298c798 Translated using Weblate (Danish)
Currently translated at 56.0% (46 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/
2024-07-25 23:35:18 +02:00
Weblate Translation Memory
84429b91a4 Translated using Weblate (Portuguese (Brazil))
Currently translated at 92.6% (76 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-25 23:35:18 +02:00
LibreTranslate
2a669044dd Translated using Weblate (Portuguese (Brazil))
Currently translated at 92.6% (76 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-25 23:35:18 +02:00
Weblate Translation Memory
79942e38e5 Translated using Weblate (Russian)
Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-25 23:35:18 +02:00
LibreTranslate
ac50b2188d Translated using Weblate (Russian)
Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-25 23:35:18 +02:00
Weblate Translation Memory
b3b7ad9819 Translated using Weblate (German)
Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-25 23:35:18 +02:00
LibreTranslate
bbbd04405e Translated using Weblate (German)
Currently translated at 90.2% (74 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-25 23:35:18 +02:00
Weblate Translation Memory
29d6b03a8a Translated using Weblate (Ukrainian)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/
2024-07-25 23:35:18 +02:00
LibreTranslate
25f14e3f9b Translated using Weblate (Ukrainian)
Currently translated at 93.9% (77 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/
2024-07-25 23:35:18 +02:00
Weblate Translation Memory
8d4f199bfc Translated using Weblate (Japanese)
Currently translated at 91.4% (75 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-25 23:35:18 +02:00
LibreTranslate
144733a9bf Translated using Weblate (Japanese)
Currently translated at 91.4% (75 of 82 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-25 23:35:18 +02:00
Lei Nelissen
21a604a0f2 Merge remote-tracking branch 'weblate/main' 2024-07-25 23:34:09 +02:00
LibreTranslate
f2a8c4c9b2 Translated using Weblate (Czech)
Currently translated at 87.1% (68 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/
2024-07-25 23:14:27 +02:00
Weblate Translation Memory
f1232ba177 Translated using Weblate (Czech)
Currently translated at 87.1% (68 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/
2024-07-25 23:14:27 +02:00
Weblate Translation Memory
e19bc64dd2 Translated using Weblate (Bulgarian)
Currently translated at 97.4% (76 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/bg/
2024-07-25 23:14:26 +02:00
Weblate Translation Memory
e8413dd099 Translated using Weblate (Danish)
Currently translated at 58.9% (46 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/
2024-07-25 23:14:26 +02:00
Weblate Translation Memory
ef391f49d1 Translated using Weblate (Slovenian)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sl/
2024-07-25 23:14:26 +02:00
Weblate Translation Memory
5803cc199e Translated using Weblate (Portuguese (Brazil))
Currently translated at 97.4% (76 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-25 23:14:26 +02:00
Weblate Translation Memory
096182e753 Translated using Weblate (Catalan)
Currently translated at 64.1% (50 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/
2024-07-25 23:14:26 +02:00
LibreTranslate
4fc1431479 Translated using Weblate (Russian)
Currently translated at 94.8% (74 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-25 23:14:26 +02:00
Weblate Translation Memory
01c0c0280f Translated using Weblate (Russian)
Currently translated at 94.8% (74 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-25 23:14:26 +02:00
LibreTranslate
e8d674d369 Translated using Weblate (German)
Currently translated at 94.8% (74 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-25 23:14:26 +02:00
Weblate Translation Memory
cbd1882d36 Translated using Weblate (German)
Currently translated at 94.8% (74 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-25 23:14:25 +02:00
Weblate Translation Memory
a45f20a57d Translated using Weblate (Swedish)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/
2024-07-25 23:14:25 +02:00
LibreTranslate
712b086fb3 Translated using Weblate (Italian)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-25 23:14:25 +02:00
Weblate Translation Memory
7f70b93faa Translated using Weblate (Italian)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-25 23:14:25 +02:00
Weblate Translation Memory
3a45895b22 Translated using Weblate (Polish)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-25 23:14:25 +02:00
Weblate Translation Memory
d9f9226d62 Translated using Weblate (Ukrainian)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/
2024-07-25 23:14:25 +02:00
Weblate Translation Memory
4f04f68e76 Translated using Weblate (Norwegian Bokmål)
Currently translated at 71.7% (56 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nb_NO/
2024-07-25 23:14:25 +02:00
Weblate Translation Memory
84388bc28f Translated using Weblate (Chinese (Simplified))
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/
2024-07-25 23:14:25 +02:00
Weblate Translation Memory
3a90be2372 Translated using Weblate (Dutch)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nl/
2024-07-25 23:14:24 +02:00
LibreTranslate
a0c32fd5a8 Translated using Weblate (Japanese)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-25 23:14:14 +02:00
Weblate Translation Memory
887aa3ab75 Translated using Weblate (Japanese)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-25 23:14:14 +02:00
Weblate Translation Memory
a64bcec4b4 Translated using Weblate (French)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-25 23:14:14 +02:00
Weblate Translation Memory
75a333a17b Translated using Weblate (Spanish)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/
2024-07-25 23:14:14 +02:00
Lei Nelissen
0d09c6f0b8 feat: Media stream info in now playing modal (#233)
* feat: add base codec info to player

* fix: redundant console.log

* chore: translation

* fix: only overflow direct play
2024-07-25 17:16:30 +02:00
LibreTranslate
64db1e2a83 Translated using Weblate (Czech)
Currently translated at 87.1% (68 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/
2024-07-25 16:59:08 +02:00
Weblate Translation Memory
bb205fef34 Translated using Weblate (Czech)
Currently translated at 87.1% (68 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/
2024-07-25 16:59:07 +02:00
Weblate Translation Memory
7d9ccddc44 Translated using Weblate (Bulgarian)
Currently translated at 97.4% (76 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/bg/
2024-07-25 16:59:07 +02:00
Weblate Translation Memory
654e694d10 Translated using Weblate (Danish)
Currently translated at 58.9% (46 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/
2024-07-25 16:59:07 +02:00
Weblate Translation Memory
4a26b93b10 Translated using Weblate (Slovenian)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sl/
2024-07-25 16:59:07 +02:00
Weblate Translation Memory
1cafdc4759 Translated using Weblate (Portuguese (Brazil))
Currently translated at 97.4% (76 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-25 16:59:07 +02:00
Weblate Translation Memory
3229a0416b Translated using Weblate (Catalan)
Currently translated at 64.1% (50 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/
2024-07-25 16:59:07 +02:00
LibreTranslate
3ec7d95241 Translated using Weblate (Russian)
Currently translated at 94.8% (74 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-25 16:59:07 +02:00
Weblate Translation Memory
668e441e25 Translated using Weblate (Russian)
Currently translated at 94.8% (74 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-25 16:59:07 +02:00
LibreTranslate
27a200f291 Translated using Weblate (German)
Currently translated at 94.8% (74 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-25 16:59:07 +02:00
Weblate Translation Memory
9d8d8a2476 Translated using Weblate (German)
Currently translated at 94.8% (74 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-25 16:59:07 +02:00
Weblate Translation Memory
892c8134fa Translated using Weblate (Swedish)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/
2024-07-25 16:59:07 +02:00
LibreTranslate
385f44036a Translated using Weblate (Italian)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
f396712d3a Translated using Weblate (Italian)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
6578f0bc1d Translated using Weblate (Polish)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
16b11f24d1 Translated using Weblate (Ukrainian)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
5e872e8a58 Translated using Weblate (Norwegian Bokmål)
Currently translated at 71.7% (56 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nb_NO/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
14626fbe97 Translated using Weblate (Chinese (Simplified))
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
14206ba86e Translated using Weblate (Dutch)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nl/
2024-07-25 16:59:06 +02:00
LibreTranslate
aa26d46ba9 Translated using Weblate (Japanese)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
b0c85f4836 Translated using Weblate (Japanese)
Currently translated at 96.1% (75 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
10c2dcac8b Translated using Weblate (French)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-25 16:59:06 +02:00
Weblate Translation Memory
5528855128 Translated using Weblate (Spanish)
Currently translated at 98.7% (77 of 78 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/
2024-07-25 16:59:06 +02:00
Lei Nelissen
189491b90a chore: release testflight beta 2024-07-25 16:46:15 +02:00
Lei Nelissen
c9f7f71194 fix: further limit extraneous events from playback reporting 2024-07-25 15:45:26 +02:00
Lei Nelissen
0b13e69854 fix: make progress bars initialise out of view 2024-07-25 14:06:06 +02:00
Lei Nelissen
83b890192e chore: upgrade to react native 0.74 2024-07-25 13:55:00 +02:00
Abubakr Khabebulloev
c5b1406e16 Lyrics implementation prototype (#224)
* Lyrics implementation prototype

* feat: update lyrics view

* chore: add docs

* chore: cleanup

* feat: animate active text

* fix: hide lyrics button when there are none

* feat: create lyrics preview in now playing modal

* fix: header overlay color

Closes #224 
Closes #151 
Closes #100 

---------

Co-authored-by: Lei Nelissen <lei@codified.nl>
2024-07-25 13:07:23 +02:00
Lei Nelissen
a64f52c4f9 fix: dark mode inconsistencies
fixes #226
fixes #198
2024-07-22 13:17:26 +02:00
Lei Nelissen
87b08050e4 Merge pull request #197 from weblate/weblate-fintunes-app
chore: Translations update from Hosted Weblate
2024-07-21 23:56:44 +02:00
LibreTranslate
c34d7a8e71 Translated using Weblate (Czech)
Currently translated at 80.5% (62 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/
2024-07-21 23:55:21 +02:00
Lei Nelissen
7e165d3bcc Translated using Weblate (Bulgarian)
Currently translated at 98.7% (76 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/bg/
2024-07-21 23:55:20 +02:00
LibreTranslate
0944128290 Translated using Weblate (Danish)
Currently translated at 48.0% (37 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/
2024-07-21 23:55:20 +02:00
LibreTranslate
1b40f7257e Translated using Weblate (Portuguese (Brazil))
Currently translated at 97.4% (75 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-21 23:55:20 +02:00
LibreTranslate
e815dc89dc Translated using Weblate (Catalan)
Currently translated at 49.3% (38 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/
2024-07-21 23:55:20 +02:00
LibreTranslate
94593859e2 Translated using Weblate (Russian)
Currently translated at 92.2% (71 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-21 23:55:20 +02:00
LibreTranslate
30f410ee5e Translated using Weblate (German)
Currently translated at 93.5% (72 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-21 23:55:20 +02:00
LibreTranslate
0357cc61ef Translated using Weblate (Swedish)
Currently translated at 93.5% (72 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/
2024-07-21 23:55:20 +02:00
LibreTranslate
1e9dd2577b Translated using Weblate (Italian)
Currently translated at 92.2% (71 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-21 23:55:20 +02:00
LibreTranslate
7b02b72e24 Translated using Weblate (Polish)
Currently translated at 98.7% (76 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-21 23:55:20 +02:00
LibreTranslate
72f7c2cf5e Translated using Weblate (Ukrainian)
Currently translated at 98.7% (76 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/
2024-07-21 23:55:20 +02:00
LibreTranslate
0d2e502f2d Translated using Weblate (Chinese (Simplified))
Currently translated at 98.7% (76 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/
2024-07-21 23:55:20 +02:00
Lei Nelissen
14f56685df Translated using Weblate (Dutch)
Currently translated at 100.0% (77 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/nl/
2024-07-21 23:55:20 +02:00
LibreTranslate
10a9e60574 Translated using Weblate (Japanese)
Currently translated at 97.4% (75 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-21 23:55:20 +02:00
LibreTranslate
65e630025b Translated using Weblate (French)
Currently translated at 98.7% (76 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-21 23:55:20 +02:00
LibreTranslate
9410c26212 Translated using Weblate (Spanish)
Currently translated at 98.7% (76 of 77 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/
2024-07-21 23:55:20 +02:00
V M
f505f68981 Translated using Weblate (French)
Currently translated at 100.0% (76 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-21 23:48:39 +02:00
Weblate Translation Memory
ce0bacbfd6 Translated using Weblate (Czech)
Currently translated at 81.5% (62 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/cs/
2024-07-21 23:48:39 +02:00
LibreTranslate
4820f80cfa Translated using Weblate (Danish)
Currently translated at 48.6% (37 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/
2024-07-21 23:48:39 +02:00
Weblate Translation Memory
038b1bf437 Translated using Weblate (Portuguese (Brazil))
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-21 23:48:39 +02:00
LibreTranslate
7646a796b2 Translated using Weblate (Portuguese (Brazil))
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-21 23:48:39 +02:00
LibreTranslate
ff55f807cf Translated using Weblate (Catalan)
Currently translated at 50.0% (38 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/
2024-07-21 23:48:39 +02:00
Weblate Translation Memory
a3d266f01d Translated using Weblate (Russian)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-21 23:48:39 +02:00
Weblate Translation Memory
cd82377373 Translated using Weblate (German)
Currently translated at 94.7% (72 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-21 23:48:39 +02:00
Weblate Translation Memory
415fbdc528 Translated using Weblate (Italian)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-21 23:48:39 +02:00
Weblate Translation Memory
981a45fceb Translated using Weblate (Japanese)
Currently translated at 98.6% (75 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-21 23:48:39 +02:00
Weblate Translation Memory
b51a8a4caf Translated using Weblate (French)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-21 23:48:38 +02:00
mict213
71deca818d Translated using Weblate (Japanese)
Currently translated at 98.6% (75 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-21 23:48:38 +02:00
dasisteinvielzulangername
d6d21c0206 Translated using Weblate (German)
Currently translated at 94.7% (72 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-21 23:48:38 +02:00
LibreTranslate
aa575605c0 Translated using Weblate (Danish)
Currently translated at 48.6% (37 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/
2024-07-21 23:48:38 +02:00
LibreTranslate
15ffcfb0aa Translated using Weblate (Portuguese (Brazil))
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-21 23:48:38 +02:00
LibreTranslate
62e5309498 Translated using Weblate (Catalan)
Currently translated at 50.0% (38 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/
2024-07-21 23:48:38 +02:00
LibreTranslate
d3eb839ea2 Translated using Weblate (Russian)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-21 23:48:38 +02:00
LibreTranslate
0e9c3e116a Translated using Weblate (German)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-21 23:48:38 +02:00
LibreTranslate
8beefb4180 Translated using Weblate (Swedish)
Currently translated at 94.7% (72 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/
2024-07-21 23:48:38 +02:00
LibreTranslate
9131a601e8 Translated using Weblate (Italian)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-21 23:48:38 +02:00
LibreTranslate
5c4d8ea214 Translated using Weblate (Japanese)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-21 23:48:38 +02:00
LibreTranslate
0a8997588d Translated using Weblate (French)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-21 23:48:38 +02:00
LibreTranslate
621cf73e50 Translated using Weblate (Portuguese (Brazil))
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pt_BR/
2024-07-21 23:48:38 +02:00
LibreTranslate
02ff4dda3a Translated using Weblate (Russian)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ru/
2024-07-21 23:48:38 +02:00
LibreTranslate
03355c138c Translated using Weblate (German)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/de/
2024-07-21 23:48:38 +02:00
LibreTranslate
2d17bd7872 Translated using Weblate (Swedish)
Currently translated at 94.7% (72 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/sv/
2024-07-21 23:48:38 +02:00
LibreTranslate
c975455e94 Translated using Weblate (Italian)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/it/
2024-07-21 23:48:38 +02:00
LibreTranslate
746d67ed36 Translated using Weblate (Japanese)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ja/
2024-07-21 23:48:38 +02:00
LibreTranslate
1249857196 Translated using Weblate (French)
Currently translated at 93.4% (71 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/fr/
2024-07-21 23:48:38 +02:00
Wolenzi
c7d8ec3151 Translated using Weblate (Polish)
Currently translated at 100.0% (76 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-21 23:48:38 +02:00
Mistify
97b10a4faf Translated using Weblate (Polish)
Currently translated at 100.0% (3 of 3 strings)

Translation: Fintunes/Play Store & F-Droid
Translate-URL: https://hosted.weblate.org/projects/fintunes/play-store-f-droid/pl/
2024-07-21 23:48:38 +02:00
Mistify
7af98d0983 Translated using Weblate (Polish)
Currently translated at 42.1% (32 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-21 23:48:38 +02:00
Сергій
47c1782652 Translated using Weblate (Ukrainian)
Currently translated at 100.0% (76 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/uk/
2024-07-21 23:48:38 +02:00
gallegonovato
cb5ad032c5 Translated using Weblate (Spanish)
Currently translated at 100.0% (76 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/es/
2024-07-21 23:48:38 +02:00
Mistify
752dec5bc2 Translated using Weblate (Polish)
Currently translated at 66.6% (2 of 3 strings)

Translation: Fintunes/Play Store & F-Droid
Translate-URL: https://hosted.weblate.org/projects/fintunes/play-store-f-droid/pl/
2024-07-21 23:48:38 +02:00
LibreTranslate
0d5f4bd4e0 Translated using Weblate (Danish)
Currently translated at 48.6% (37 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/da/
2024-07-21 23:48:38 +02:00
LibreTranslate
cca8f43ada Translated using Weblate (Catalan)
Currently translated at 50.0% (38 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/ca/
2024-07-21 23:48:38 +02:00
Mistify
a8e024dd00 Translated using Weblate (Polish)
Currently translated at 10.0% (1 of 10 strings)

Translation: Fintunes/App Store
Translate-URL: https://hosted.weblate.org/projects/fintunes/app-store/pl/
2024-07-21 23:48:38 +02:00
LibreTranslate
902178c48b Translated using Weblate (Polish)
Currently translated at 13.1% (10 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-21 23:48:38 +02:00
Mistify
f73cec2097 Translated using Weblate (Polish)
Currently translated at 13.1% (10 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/pl/
2024-07-21 23:48:38 +02:00
無情天
f3388132c1 Translated using Weblate (Chinese (Simplified))
Currently translated at 100.0% (76 of 76 strings)

Translation: Fintunes/App
Translate-URL: https://hosted.weblate.org/projects/fintunes/app/zh_Hans/
2024-07-21 23:48:38 +02:00
Lei Nelissen
ec4a2b6831 feat: separate discs in album view when multiple are available
fixes #179
2024-07-21 23:48:33 +02:00
Lei Nelissen
7cdd01e713 fix: align all album titles in track list view
fixes #172
2024-07-21 23:02:02 +02:00
Lei Nelissen
38ce9986e5 fix: fine-tune default orderings
fixes #229
2024-07-21 22:45:07 +02:00
Lei Nelissen
9952b39044 chore: fix typescript api call overload 2024-07-21 22:37:42 +02:00
Lei Nelissen
e0177fb89b chore: fix typescript with optional return from api call 2024-07-21 22:30:06 +02:00
Lei Nelissen
68c8808188 fix: send last position for Stopped event
instead of the current position, which is `0` when we move to a new track
2024-07-21 22:10:10 +02:00
Lei Nelissen
746c96d459 fix: don't attempt to parse playback reporting responses
also: log all http requests on dev
2024-07-21 22:03:39 +02:00
Lei Nelissen
a97611c0ad chore: release v2.3.3 2024-06-15 23:23:15 +02:00
Lei Nelissen
e511f744ad chore: default xcode scheme to debug 2024-05-26 23:53:43 +02:00
Lei Nelissen
a6a306b5be fix: refactor JellyfinApi to be less burdensome to implement
Also, automatically catch errors
2024-05-26 23:53:29 +02:00
Lei Nelissen
881ab95029 fix: double-check albums have dates 2024-05-26 22:20:14 +02:00
Lei Nelissen
968e98d8df fix: react-native-screens android setup 2024-05-26 22:20:05 +02:00
Lei Nelissen
b01470bde8 fix: actually send out /Playing events as session updates.
This should more consistently result in output data in your play back reporting modules.

fixes #218
2024-05-26 18:00:05 +02:00
Lei Nelissen
823f7b59e8 Merge pull request #199 from leinelissen/dependabot/npm_and_yarn/ip-1.1.9
chore(deps): bump ip from 1.1.8 to 1.1.9
2024-05-26 17:07:09 +02:00
Lei Nelissen
16162d8e35 fix: throw errors when requests do not yield 200 OKs 2024-05-26 00:34:57 +02:00
Lei Nelissen
ea817025e1 fix: hermes version in cocoapods 2024-05-26 00:24:04 +02:00
Lei Nelissen
00675bbbd3 fix: do extra checks for album ids in 2024-05-26 00:23:29 +02:00
Lei Nelissen
24b5a47a7c Merge pull request #211 from Krafting/patch-1
Add spaces to privacy-policy.md
2024-04-19 17:27:18 +02:00
Krafting
bb655cb719 Add spaces to privacy-policy.md 2024-04-01 14:19:13 +02:00
Lei Nelissen
be0c7002ff chore: also release v2.3.2 for Android 2024-03-10 23:12:10 +01:00
dependabot[bot]
e472d043cf chore(deps): bump ip from 1.1.8 to 1.1.9
Bumps [ip](https://github.com/indutny/node-ip) from 1.1.8 to 1.1.9.
- [Commits](https://github.com/indutny/node-ip/compare/v1.1.8...v1.1.9)

---
updated-dependencies:
- dependency-name: ip
  dependency-type: indirect
...

Signed-off-by: dependabot[bot] <support@github.com>
2024-03-10 22:09:29 +00:00
Lei Nelissen
366d16c485 chore: release v2.3.2 2024-03-10 23:08:34 +01:00
Lei Nelissen
845eac70a0 fix: build with xcode 15.3 2024-03-10 22:54:02 +01:00
Lei Nelissen
c9662769fa fix: remove conflicting app transport properties 2024-03-10 22:53:46 +01:00
135 changed files with 4457 additions and 2555 deletions

View File

@@ -58,7 +58,8 @@ module.exports = {
{
ignoreProps: true
}
]
],
'react/react-in-jsx-scope': 'off',
},
settings: {
react: {

View File

@@ -32,7 +32,7 @@ jobs:
SENTRY_DISABLE_AUTO_UPLOAD: true
run: bundle exec fastlane android build
- name: Upload artifact
uses: actions/upload-artifact@v2
uses: actions/upload-artifact@v4
with:
name: jellyfin-audio-player-android-${{ steps.vars.outputs.sha_short }}.apk
path: android/app/build/outputs/**/*.apk

View File

@@ -1,3 +1,78 @@
## [2.4.1](https://github.com/leinelissen/jellyfin-audio-player/compare/v2.4.0...v2.4.1) (2025-01-27)
# [2.4.0](https://github.com/leinelissen/jellyfin-audio-player/compare/v2.3.3...v2.4.0) (2025-01-26)
### Bug Fixes
* accept any valid mime type for downloadable tracks ([2c42a89](https://github.com/leinelissen/jellyfin-audio-player/commit/2c42a897d9e77ba8f767896512b80c8c10a72e30))
* align all album titles in track list view ([7cdd01e](https://github.com/leinelissen/jellyfin-audio-player/commit/7cdd01e71378fded86411b8dc79c9748c315be96)), closes [#172](https://github.com/leinelissen/jellyfin-audio-player/issues/172)
* bump blur-view ([8bef5c6](https://github.com/leinelissen/jellyfin-audio-player/commit/8bef5c66e3242c1ad359eb3a96ef3177031cd22f))
* clean up lyrics implementation ([2f1b9c1](https://github.com/leinelissen/jellyfin-audio-player/commit/2f1b9c180d205228768d0d82b13e9f6e51944928))
* dark mode inconsistencies ([a64f52c](https://github.com/leinelissen/jellyfin-audio-player/commit/a64f52c4f913f92d8caeea74188d1260ff7c2ce5)), closes [#226](https://github.com/leinelissen/jellyfin-audio-player/issues/226) [#198](https://github.com/leinelissen/jellyfin-audio-player/issues/198)
* don't attempt to parse playback reporting responses ([746c96d](https://github.com/leinelissen/jellyfin-audio-player/commit/746c96d45932f3a23122ada165acc49e8053da11))
* ensure all cover images load properly ([b9e8a94](https://github.com/leinelissen/jellyfin-audio-player/commit/b9e8a94c7a4682076c05c4562b8996e47e84311f))
* fine-tune default orderings ([38ce998](https://github.com/leinelissen/jellyfin-audio-player/commit/38ce9986e590392667fae7c8119aa1057e95cd23)), closes [#229](https://github.com/leinelissen/jellyfin-audio-player/issues/229)
* further limit extraneous events from playback reporting ([c9f7f71](https://github.com/leinelissen/jellyfin-audio-player/commit/c9f7f71194105944f051e7329b88956e4c863976))
* make progress bars initialise out of view ([0b13e69](https://github.com/leinelissen/jellyfin-audio-player/commit/0b13e69854a361a67bcc67baaf22c9364a53378f))
* missing background on track pop-up menu ([f2cac91](https://github.com/leinelissen/jellyfin-audio-player/commit/f2cac91e2f08db7945a88e9ad29daa797ab96edd))
* missing cover images in now playing view ([96a1180](https://github.com/leinelissen/jellyfin-audio-player/commit/96a11804ba390dc665282f1fc49e7f0fb710e642)), closes [#245](https://github.com/leinelissen/jellyfin-audio-player/issues/245) [#209](https://github.com/leinelissen/jellyfin-audio-player/issues/209)
* missing image covers for emby ([01e25a8](https://github.com/leinelissen/jellyfin-audio-player/commit/01e25a89b1adcbacd7a58642d4d4ef8731480d8c))
* more accurately return current track ([9462a3e](https://github.com/leinelissen/jellyfin-audio-player/commit/9462a3e294bffc46f25797688aefec2a43f7cccb))
* prevent error on lyrics screen when tab height is unavailable ([b9a6c66](https://github.com/leinelissen/jellyfin-audio-player/commit/b9a6c66584b215e3ee86d1808864a04aa26065c9))
* properly pre-insert queued tracks before played track ([3993401](https://github.com/leinelissen/jellyfin-audio-player/commit/399340127dd4026881397a269381aaca72c07751))
* retrieve codec metadata and lyrics asynchronously ([77db5a5](https://github.com/leinelissen/jellyfin-audio-player/commit/77db5a51d2e2ba5ecd37439588dd83dcf2437b1c))
* send last position for `Stopped` event ([68c8808](https://github.com/leinelissen/jellyfin-audio-player/commit/68c88081885bb3bda196dfe71b684e21e678787e))
* show past lyrics in grey ([b03d449](https://github.com/leinelissen/jellyfin-audio-player/commit/b03d449a1bd5d16e16f15dbb215a75cfd2e0cc7c))
* support audio/ogg in downloads ([1972f48](https://github.com/leinelissen/jellyfin-audio-player/commit/1972f489aaed4780c74733532e3597dbb54a5536))
### Features
* also store cover images for downloaded tracks ([6316814](https://github.com/leinelissen/jellyfin-audio-player/commit/6316814eba59ed2bd2c0fe1a23ed64bfe2f1bed3))
* Emby support ([#234](https://github.com/leinelissen/jellyfin-audio-player/issues/234)) ([a6452f0](https://github.com/leinelissen/jellyfin-audio-player/commit/a6452f0a5e81b2f70ecdd7900138ef1a8ecb5554))
* enable playlists for emby ([f90e9be](https://github.com/leinelissen/jellyfin-audio-player/commit/f90e9be3783363bd65b4c8b7c15964338b19dc38)), closes [#242](https://github.com/leinelissen/jellyfin-audio-player/issues/242)
* Media stream info in now playing modal ([#233](https://github.com/leinelissen/jellyfin-audio-player/issues/233)) ([0d09c6f](https://github.com/leinelissen/jellyfin-audio-player/commit/0d09c6f0b8a5fc218af1182324a73cb667eccbce))
* separate discs in album view when multiple are available ([ec4a2b6](https://github.com/leinelissen/jellyfin-audio-player/commit/ec4a2b6831fb8aa3c5e8f1fc658c235ced59cfd9)), closes [#179](https://github.com/leinelissen/jellyfin-audio-player/issues/179)
## [2.3.3](https://github.com/leinelissen/jellyfin-audio-player/compare/v2.3.2...v2.3.3) (2024-06-15)
### Bug Fixes
* actually send out /Playing events as session updates. ([b01470b](https://github.com/leinelissen/jellyfin-audio-player/commit/b01470bde8ea353ea7139c0708ec9cfdaf600fe4)), closes [#218](https://github.com/leinelissen/jellyfin-audio-player/issues/218)
* do extra checks for album ids in ([00675bb](https://github.com/leinelissen/jellyfin-audio-player/commit/00675bbbd3e72e8e710d8aa9b73b491e65153d40))
* double-check albums have dates ([881ab95](https://github.com/leinelissen/jellyfin-audio-player/commit/881ab9502960786dc9685cf3612793fea3c1be4c))
* hermes version in cocoapods ([ea81702](https://github.com/leinelissen/jellyfin-audio-player/commit/ea817025e1bf67fcd3c183c12f4f1f93c3218785))
* react-native-screens android setup ([968e98d](https://github.com/leinelissen/jellyfin-audio-player/commit/968e98d8dffa79ea3165d1209542bd91dd914ef5))
* refactor JellyfinApi to be less burdensome to implement ([a6a306b](https://github.com/leinelissen/jellyfin-audio-player/commit/a6a306b5be6988469449b17ed527f1d365901e6d))
* throw errors when requests do not yield 200 OKs ([16162d8](https://github.com/leinelissen/jellyfin-audio-player/commit/16162d8e3505ea195c8aaf03b82df88405196025))
## [2.3.2](https://github.com/leinelissen/jellyfin-audio-player/compare/v2.3.1...v2.3.2) (2024-03-10)
### Bug Fixes
* build with xcode 15.3 ([845eac7](https://github.com/leinelissen/jellyfin-audio-player/commit/845eac70a0afa189cd76e97f739ad627f648566a))
* remove conflicting app transport properties ([c966276](https://github.com/leinelissen/jellyfin-audio-player/commit/c9662769faec8771b6a70da815ec36e62c8c43a2))
## [2.3.1](https://github.com/leinelissen/jellyfin-audio-player/compare/v2.3.0...v2.3.1) (2024-03-06)
### Bug Fixes
* revert to supporting HTTP-based backends ([f310bb8](https://github.com/leinelissen/jellyfin-audio-player/commit/f310bb82f61f532f9557787d364e9f342166806d)), closes [#205](https://github.com/leinelissen/jellyfin-audio-player/issues/205)
# [2.3.0](https://github.com/leinelissen/jellyfin-audio-player/compare/v2.2.0...v2.3.0) (2024-02-11)

View File

@@ -1,7 +1,9 @@
GEM
remote: https://rubygems.org/
specs:
CFPropertyList (3.0.6)
CFPropertyList (3.0.7)
base64
nkf
rexml
activesupport (6.1.7.6)
concurrent-ruby (~> 1.0, >= 1.0.2)
@@ -9,30 +11,31 @@ GEM
minitest (>= 5.1)
tzinfo (~> 2.0)
zeitwerk (~> 2.3)
addressable (2.8.6)
public_suffix (>= 2.0.2, < 6.0)
addressable (2.8.7)
public_suffix (>= 2.0.2, < 7.0)
algoliasearch (1.27.5)
httpclient (~> 2.8, >= 2.8.3)
json (>= 1.5.1)
artifactory (3.0.15)
artifactory (3.0.17)
atomos (0.1.3)
aws-eventstream (1.3.0)
aws-partitions (1.885.0)
aws-sdk-core (3.191.0)
aws-partitions (1.1042.0)
aws-sdk-core (3.217.0)
aws-eventstream (~> 1, >= 1.3.0)
aws-partitions (~> 1, >= 1.651.0)
aws-sigv4 (~> 1.8)
aws-partitions (~> 1, >= 1.992.0)
aws-sigv4 (~> 1.9)
jmespath (~> 1, >= 1.6.1)
aws-sdk-kms (1.77.0)
aws-sdk-core (~> 3, >= 3.191.0)
aws-sigv4 (~> 1.1)
aws-sdk-s3 (1.143.0)
aws-sdk-core (~> 3, >= 3.191.0)
aws-sdk-kms (1.97.0)
aws-sdk-core (~> 3, >= 3.216.0)
aws-sigv4 (~> 1.5)
aws-sdk-s3 (1.178.0)
aws-sdk-core (~> 3, >= 3.216.0)
aws-sdk-kms (~> 1)
aws-sigv4 (~> 1.8)
aws-sigv4 (1.8.0)
aws-sigv4 (~> 1.5)
aws-sigv4 (1.11.0)
aws-eventstream (~> 1, >= 1.0.2)
babosa (1.0.4)
base64 (0.2.0)
claide (1.1.0)
cocoapods (1.15.0)
addressable (~> 2.8)
@@ -87,7 +90,7 @@ GEM
ethon (0.16.0)
ffi (>= 1.15.0)
excon (0.109.0)
faraday (1.10.3)
faraday (1.10.4)
faraday-em_http (~> 1.0)
faraday-em_synchrony (~> 1.0)
faraday-excon (~> 1.1)
@@ -106,24 +109,24 @@ GEM
faraday-em_synchrony (1.0.0)
faraday-excon (1.1.0)
faraday-httpclient (1.0.1)
faraday-multipart (1.0.4)
multipart-post (~> 2)
faraday-net_http (1.0.1)
faraday-multipart (1.1.0)
multipart-post (~> 2.0)
faraday-net_http (1.0.2)
faraday-net_http_persistent (1.2.0)
faraday-patron (1.0.0)
faraday-rack (1.0.0)
faraday-retry (1.0.3)
faraday_middleware (1.2.0)
faraday_middleware (1.2.1)
faraday (~> 1.0)
fastimage (2.3.0)
fastlane (2.219.0)
fastimage (2.4.0)
fastlane (2.226.0)
CFPropertyList (>= 2.3, < 4.0.0)
addressable (>= 2.8, < 3.0.0)
artifactory (~> 3.0)
aws-sdk-s3 (~> 1.0)
babosa (>= 1.0.3, < 2.0.0)
bundler (>= 1.12.0, < 3.0.0)
colored
colored (~> 1.2)
commander (~> 4.6)
dotenv (>= 2.1.1, < 3.0.0)
emoji_regex (>= 0.1, < 4.0)
@@ -132,6 +135,7 @@ GEM
faraday-cookie_jar (~> 0.0.6)
faraday_middleware (~> 1.0)
fastimage (>= 2.1.0, < 3.0.0)
fastlane-sirp (>= 1.0.0)
gh_inspector (>= 1.1.2, < 2.0.0)
google-apis-androidpublisher_v3 (~> 0.3)
google-apis-playcustomapp_v1 (~> 0.1)
@@ -144,10 +148,10 @@ GEM
mini_magick (>= 4.9.4, < 5.0.0)
multipart-post (>= 2.0.0, < 3.0.0)
naturally (~> 2.2)
optparse (>= 0.1.1)
optparse (>= 0.1.1, < 1.0.0)
plist (>= 3.1.0, < 4.0.0)
rubyzip (>= 2.0.0, < 3.0.0)
security (= 0.1.3)
security (= 0.1.5)
simctl (~> 1.6.3)
terminal-notifier (>= 2.0.0, < 3.0.0)
terminal-table (~> 3)
@@ -155,12 +159,14 @@ GEM
tty-spinner (>= 0.8.0, < 1.0.0)
word_wrap (~> 1.0.0)
xcodeproj (>= 1.13.0, < 2.0.0)
xcpretty (~> 0.3.0)
xcpretty-travis-formatter (>= 0.0.3)
xcpretty (~> 0.4.0)
xcpretty-travis-formatter (>= 0.0.3, < 2.0.0)
fastlane-plugin-load_json (0.0.1)
fastlane-plugin-sentry (1.18.0)
os (~> 1.1, >= 1.1.4)
fastlane-plugin-versioning_android (0.1.1)
fastlane-sirp (1.0.0)
sysrandom (~> 1.0)
ffi (1.16.3)
fourflusher (2.3.1)
fuzzy_match (2.0.4)
@@ -202,40 +208,42 @@ GEM
os (>= 0.9, < 2.0)
signet (>= 0.16, < 2.a)
highline (2.0.3)
http-cookie (1.0.5)
http-cookie (1.0.8)
domain_name (~> 0.5)
httpclient (2.8.3)
i18n (1.14.1)
concurrent-ruby (~> 1.0)
jmespath (1.6.2)
json (2.7.1)
jwt (2.7.1)
mini_magick (4.12.0)
json (2.7.6)
jwt (2.10.1)
base64
mini_magick (4.13.2)
mini_mime (1.1.5)
minitest (5.21.2)
molinillo (0.8.0)
multi_json (1.15.0)
multipart-post (2.3.0)
nanaimo (0.3.0)
multipart-post (2.4.1)
nanaimo (0.4.0)
nap (1.1.0)
naturally (2.2.1)
netrc (0.11.0)
optparse (0.4.0)
nkf (0.2.0)
optparse (0.6.0)
os (1.1.4)
plist (3.7.1)
plist (3.7.2)
public_suffix (4.0.7)
rake (13.1.0)
rake (13.2.1)
representable (3.2.0)
declarative (< 0.1.0)
trailblazer-option (>= 0.1.1, < 0.2.0)
uber (< 0.2.0)
retriable (3.1.2)
rexml (3.2.6)
rouge (2.0.7)
rexml (3.4.0)
rouge (3.28.0)
ruby-macho (2.5.1)
ruby2_keywords (0.0.5)
rubyzip (2.3.2)
security (0.1.3)
rubyzip (2.4.1)
security (0.1.5)
signet (0.18.0)
addressable (~> 2.8)
faraday (>= 0.17.5, < 3.a)
@@ -244,6 +252,7 @@ GEM
simctl (1.6.10)
CFPropertyList
naturally
sysrandom (1.0.5)
terminal-notifier (2.0.0)
terminal-table (3.0.2)
unicode-display_width (>= 1.1.1, < 3)
@@ -257,20 +266,18 @@ GEM
tzinfo (2.0.6)
concurrent-ruby (~> 1.0)
uber (0.1.0)
unf (0.1.4)
unf_ext
unf_ext (0.0.9.1)
unicode-display_width (2.5.0)
unf (0.2.0)
unicode-display_width (2.6.0)
word_wrap (1.0.0)
xcodeproj (1.24.0)
xcodeproj (1.27.0)
CFPropertyList (>= 2.3.3, < 4.0)
atomos (~> 0.1.3)
claide (>= 1.0.2, < 2.0)
colored2 (~> 3.1)
nanaimo (~> 0.3.0)
rexml (~> 3.2.4)
xcpretty (0.3.0)
rouge (~> 2.0.7)
nanaimo (~> 0.4.0)
rexml (>= 3.3.6, < 4.0)
xcpretty (0.4.0)
rouge (~> 3.28.0)
xcpretty-travis-formatter (1.0.1)
xcpretty (~> 0.2, >= 0.0.7)
zeitwerk (2.6.12)

View File

@@ -13,7 +13,7 @@
[![Latest GitHub release](https://img.shields.io/github/v/release/leinelissen/jellyfin-audio-player?label=latest%20release)](https://github.com/leinelissen/jellyfin-audio-player/releases/latest)
[![Latest App Store release](https://img.shields.io/itunes/v/1527732194?label=app%20store)](https://apple.co/3MFYIJH)
[![Latest Google Play release](https://img.shields.io/endpoint?url=https%3A%2F%2Fplay.cuzi.workers.dev%2Fplay%3Fi%3Dnl.moeilijkedingen.jellyfinaudioplayer%26l%3Dgoogle%2520play%26m%3D%24version)](https://play.google.com/store/apps/details?id=nl.moeilijkedingen.jellyfinaudioplayer)
[![Join the TestFlight beta](https://img.shields.io/badge/TestFlight-beta-blue)](https://testflight.apple.com/join/cf2AMDpx)
[![Join the TestFlight beta](https://img.shields.io/badge/TestFlight-beta-blue)](https://testflight.apple.com/join/TpHWMmfM)
[![Latest F-Droid release](https://img.shields.io/f-droid/v/nl.moeilijkedingen.jellyfinaudioplayer)](https://f-droid.org/en/packages/nl.moeilijkedingen.jellyfinaudioplayer/)
![GitHub Workflow Status](https://img.shields.io/github/actions/workflow/status/leinelissen/jellyfin-audio-player/fastlane.yml)
[![MIT License](https://img.shields.io/github/license/leinelissen/jellyfin-audio-player)](./LICENSE.md)

View File

@@ -85,8 +85,8 @@ android {
applicationId "nl.moeilijkedingen.jellyfinaudioplayer"
minSdkVersion rootProject.ext.minSdkVersion
targetSdkVersion rootProject.ext.targetSdkVersion
versionCode 26
versionName "2.3.1"
versionCode 31
versionName "2.4.1"
}
signingConfigs {
@@ -126,7 +126,6 @@ android {
dependencies {
// The version of react-native is set by the React Native Gradle Plugin
implementation("com.facebook.react:react-android")
implementation("com.facebook.react:flipper-integration")
if (hermesEnabled.toBoolean()) {
implementation("com.facebook.react:hermes-android")

View File

@@ -5,6 +5,8 @@ import com.facebook.react.ReactActivityDelegate
import com.facebook.react.defaults.DefaultNewArchitectureEntryPoint.fabricEnabled
import com.facebook.react.defaults.DefaultReactActivityDelegate
import android.os.Bundle;
class MainActivity : ReactActivity() {
/**
@@ -19,4 +21,8 @@ class MainActivity : ReactActivity() {
*/
override fun createReactActivityDelegate(): ReactActivityDelegate =
DefaultReactActivityDelegate(this, mainComponentName, fabricEnabled)
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(null)
}
}

View File

@@ -9,7 +9,6 @@ import com.facebook.react.ReactPackage
import com.facebook.react.defaults.DefaultNewArchitectureEntryPoint.load
import com.facebook.react.defaults.DefaultReactHost.getDefaultReactHost
import com.facebook.react.defaults.DefaultReactNativeHost
import com.facebook.react.flipper.ReactNativeFlipper
import com.facebook.soloader.SoLoader
class MainApplication : Application(), ReactApplication {
@@ -31,7 +30,7 @@ class MainApplication : Application(), ReactApplication {
}
override val reactHost: ReactHost
get() = getDefaultReactHost(this.applicationContext, reactNativeHost)
get() = getDefaultReactHost(applicationContext, reactNativeHost)
override fun onCreate() {
super.onCreate()
@@ -40,6 +39,5 @@ class MainApplication : Application(), ReactApplication {
// If you opted-in for the New Architecture, we load the native entry point for this app.
load()
}
ReactNativeFlipper.initializeFlipper(this, reactNativeHost.reactInstanceManager)
}
}

View File

@@ -5,11 +5,11 @@ import org.apache.tools.ant.taskdefs.condition.Os
buildscript {
ext {
buildToolsVersion = "34.0.0"
minSdkVersion = 21
minSdkVersion = 23
compileSdkVersion = 34
targetSdkVersion = 34
ndkVersion = "25.1.8937393"
kotlinVersion = "1.8.0"
ndkVersion = "26.1.10909125"
kotlinVersion = "1.9.22"
}
repositories {
google()

View File

@@ -38,6 +38,4 @@ newArchEnabled=false
# Use this property to enable or disable the Hermes JS engine.
# If set to false, you will be using JSC instead.
hermesEnabled=true
FLIPPER_VERSION=0.201.0
hermesEnabled=true

View File

@@ -1,6 +1,6 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.3-all.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-all.zip
networkTimeout=10000
validateDistributionUrl=true
zipStoreBase=GRADLE_USER_HOME

14
android/gradlew vendored
View File

@@ -145,7 +145,7 @@ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
case $MAX_FD in #(
max*)
# In POSIX sh, ulimit -H is undefined. That's why the result is checked to see if it worked.
# shellcheck disable=SC3045
# shellcheck disable=SC2039,SC3045
MAX_FD=$( ulimit -H -n ) ||
warn "Could not query maximum file descriptor limit"
esac
@@ -153,7 +153,7 @@ if ! "$cygwin" && ! "$darwin" && ! "$nonstop" ; then
'' | soft) :;; #(
*)
# In POSIX sh, ulimit -n is undefined. That's why the result is checked to see if it worked.
# shellcheck disable=SC3045
# shellcheck disable=SC2039,SC3045
ulimit -n "$MAX_FD" ||
warn "Could not set maximum file descriptor limit to $MAX_FD"
esac
@@ -202,11 +202,11 @@ fi
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script.
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"'
# Collect all arguments for the java command;
# * $DEFAULT_JVM_OPTS, $JAVA_OPTS, and $GRADLE_OPTS can contain fragments of
# shell script including quotes and variable substitutions, so put them in
# double quotes to make sure that they get re-expanded; and
# * put everything else in single quotes, so that it's not re-expanded.
# Collect all arguments for the java command:
# * DEFAULT_JVM_OPTS, JAVA_OPTS, JAVA_OPTS, and optsEnvironmentVar are not allowed to contain shell fragments,
# and any embedded shellness will be escaped.
# * For example: A user cannot expect ${Hostname} to be expanded, as it is an environment variable and will be
# treated as '${Hostname}' itself on the command line.
set -- \
"-Dorg.gradle.appname=$APP_BASE_NAME" \

20
android/gradlew.bat vendored
View File

@@ -43,11 +43,11 @@ set JAVA_EXE=java.exe
%JAVA_EXE% -version >NUL 2>&1
if %ERRORLEVEL% equ 0 goto execute
echo.
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH.
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.
echo. 1>&2
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. 1>&2
echo. 1>&2
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
echo location of your Java installation. 1>&2
goto fail
@@ -57,11 +57,11 @@ set JAVA_EXE=%JAVA_HOME%/bin/java.exe
if exist "%JAVA_EXE%" goto execute
echo.
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME%
echo.
echo Please set the JAVA_HOME variable in your environment to match the
echo location of your Java installation.
echo. 1>&2
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% 1>&2
echo. 1>&2
echo Please set the JAVA_HOME variable in your environment to match the 1>&2
echo location of your Java installation. 1>&2
goto fail

View File

@@ -1,10 +1,10 @@
Privacy policy for Fintunes
Fintunes does not collect any personal data. Period. We respect your right to
Fintunes does not collect any personal data. Period. We respect your right to
autonomy and vow to not collect any information without user consent at all.
If you opt-in to crash logging, we will collect analytics data from your device,
every time a crash occurs. This data includes debugging information such as
devices, versions and the specific error. All data is sent to a server
controlled by the first party. No third parties can access this data in any
form. No personal data is included in the analytics data.
If you opt-in to crash logging, we will collect analytics data from your device,
every time a crash occurs. This data includes debugging information such as
devices, versions and the specific error. All data is sent to a server
controlled by the first party. No third parties can access this data in any
form. No personal data is included in the analytics data.

View File

@@ -1,5 +1,6 @@
package_name("nl.moeilijkedingen.jellyfinaudioplayer")
app_identifier("nl.moeilijkedingen.jellyfinaudioplayer")
apple_id("lei@moeilijkedingen.nl")
team_id("238P3C58WC")
json_key_file("./fastlane/play-store-credentials.json")
apple_id("lei@codified.nl")
team_id("HD2D35G9Y4")
json_key_file("./fastlane/play-store-credentials.json")
itc_team_id("127114471")

View File

@@ -4,6 +4,11 @@ package = load_json(json_path: "package.json")
platform :ios do
before_all do
app_store_connect_api_key(
key_id: "Z98N7N8ZMW",
issuer_id: "f0fa1c89-6a9a-4144-bfba-529dfe05f09b",
key_filepath: "./certificates/AuthKey_Z98N7N8ZMW.p8"
)
get_certificates(
output_path: "certificates/"
)

View File

@@ -1 +1 @@
Fintunes ist ein Streaming Audioplayer für das Jellyfin Media System. Es bietet eine großartige Benutzeroberfläche, welche Ihnen ermöglicht Ihre Lieblingsmusik mit Leichtigkeit wiedergeben zu können. Sie können Ihre gesammte Bibliothek nach einen Titel suchen oder einfach eine Playlist anhören, welche Sie zuvor in Jellyfin erstellt haben. Alle Titel werden direkt mit bester Qualität von Ihrer Jellyfin-Bibliothek gestreamt. Ist Streaming nicht immer möglich? Jeder Titel in Ihrer Jellyfin Bibliothek kann heruntergeladen und offline abgespielt werden.
Fintunes ist ein Streaming Audioplayer für das Jellyfin Media System. Es bietet eine großartige Benutzeroberfläche, welche Ihnen ermöglicht Ihre Lieblingsmusik mit Leichtigkeit wiedergeben zu können. Sie können Ihre gesamte Bibliothek nach einem beliebigen Titel durchsuchen, oder einfach eine Wiedergabeliste verwenden, die Sie zuvor in Jellyfin erstellt haben. Alle Titel werden direkt in höchster Qualität von Ihrer Jellyfin-Bibliothek gestreamt. Ist Streaming nicht immer eine Option? Jeder Titel in Ihrer Jellyfin Bibliothek kann heruntergeladen und offline abgespielt werden.

View File

@@ -1 +1 @@
Fintunes est un lecteur audio en streaming pour le système multimédia Jellyfin. Il dispose d'une interface magnifique qui vous permet de jouer facilement votre musique préférée. Vous pouvez rechercher n'importe quelle piste dans toute votre bibliothèque ou simplement vous détendre avec une liste de lecture que vous avez créée précédemment dans Jellyfin. Toutes les pistes sont diffusées directement à la plus haute qualité depuis votre bibliothèque Jellyfin. Le streaming n'est pas toujours une option ? N'importe quelle piste de votre bibliothèque Jellyfin peut être téléchargée et lue hors ligne.
Fintunes est un lecteur audio en streaming pour le système multimédia Jellyfin. Il dispose d'une magnifique interface qui vous permet de lire facilement votre musique préférée. Vous pouvez rechercher n'importe quelle piste dans toute votre bibliothèque ou simplement vous détendre avec une liste de lecture que vous avez créée précédemment dans Jellyfin. Toutes les pistes sont diffusées directement à la plus haute qualité depuis votre bibliothèque Jellyfin. Vous ne disposez pas d'une connexion à Internet en permanence? N'importe quelle piste de votre bibliothèque Jellyfin peut être téléchargée et lue hors ligne.

View File

@@ -0,0 +1 @@
Fintunes to strumieniowy odtwarzacz audio dla systemu multimedialnego Jellyfin. Posiada wspaniały interfejs, który pozwala z łatwością odtwarzać ulubioną muzykę. Możesz przeszukać całą bibliotekę w poszukiwaniu dowolnego utworu lub po prostu skorzystać z listy odtwarzania utworzonej wcześniej w Jellyfin. Wszystkie utwory są przesyłane strumieniowo bezpośrednio z biblioteki Jellyfin w najwyższej jakości. Streaming nie zawsze jest możliwy? Każdy utwór z biblioteki Jellyfin można pobrać i odtwarzać offline.

View File

@@ -0,0 +1 @@
Strumieniowy odtwarzacz audio dla Jellyfin

View File

@@ -0,0 +1 @@
Fintunes

View File

@@ -0,0 +1 @@
செல்லிஃபின் மீடியா சிச்டத்திற்கான ச்ட்ரீமிங் ஆடியோ பிளேயர் ஃபிண்டுன்ச் ஆகும். இது ஒரு அழகிய இடைமுகத்தைக் கொண்டுள்ளது, இது உங்களுக்கு பிடித்த இசையை எளிதாக இயக்க அனுமதிக்கிறது. எந்தவொரு தடத்திற்கும் உங்கள் முழு நூலகத்தையும் நீங்கள் தேடலாம் அல்லது செல்லிஃபினில் நீங்கள் முன்பு உருவாக்கிய பிளேலிச்ட்டுடன் எளிதாக எடுத்துக் கொள்ளலாம். அனைத்து தடங்களும் உங்கள் செல்லிஃபின் நூலகத்திலிருந்து மிக உயர்ந்த தரத்தில் நேரடியாக ச்ட்ரீம் செய்யப்படுகின்றன. ச்ட்ரீமிங் எப்போதும் ஒரு விருப்பமல்லவா? உங்கள் செல்லிஃபின் நூலகத்தில் உள்ள எந்த தடத்தையும் பதிவிறக்கம் செய்து ஆஃப்லைனில் இயக்கலாம்.

View File

@@ -0,0 +1 @@
செலிஃபினுக்கான ச்ட்ரீமிங் ஆடியோ பிளேயர்

View File

@@ -0,0 +1 @@
Fintunes

View File

@@ -0,0 +1 @@
Fintunes 是 Jellyfin 媒體系統的流媒體音訊播放器。 它具有華麗的介面,讓您輕鬆播放您最喜歡的音樂。 您可以在整個庫中搜索任何曲目,或者輕鬆使用您之前在 Jellyfin 中建立的播放列表。 所有曲目都直接從您的 Jellyfin 庫中以最高品質流式傳輸。 不一定每次播放都能連接到網路嗎? Jellyfin庫中的任何曲目都可以下載並離線播放。

View File

@@ -0,0 +1 @@
Jellyfin 的流媒體音訊播放器

View File

@@ -0,0 +1 @@
Fintunes

View File

@@ -1 +1 @@
Fintunes est un lecteur audio en streaming pour le système multimédia Jellyfin. Il dispose d'une interface magnifique qui vous permet de jouer facilement votre musique préférée. Vous pouvez rechercher n'importe quelle piste dans toute votre bibliothèque ou simplement vous détendre avec une liste de lecture que vous avez créée précédemment dans Jellyfin. Toutes les pistes sont diffusées directement à la plus haute qualité depuis votre bibliothèque Jellyfin. Le streaming n'est pas toujours une option ? N'importe quelle piste de votre bibliothèque Jellyfin peut être téléchargée et lue hors ligne.
Fintunes est un lecteur audio en streaming pour le système multimédia Jellyfin. Il dispose d'une magnifique interface qui vous permet de lire facilement votre musique préférée. Vous pouvez rechercher n'importe quelle piste dans toute votre bibliothèque ou simplement vous détendre avec une liste de lecture que vous avez créée précédemment dans Jellyfin. Toutes les pistes sont diffusées directement à la plus haute qualité depuis votre bibliothèque Jellyfin. Vous ne disposez pas d'une connexion à Internet en permanence? N'importe quelle piste de votre bibliothèque Jellyfin peut être téléchargée et lue hors ligne.

View File

@@ -1 +1 @@
jellyfin, audio, joueur, diffusion, téléchargements, musique
jellyfin, audio, lecteur, streaming, téléchargements, musique

View File

@@ -1 +1 @@
jellyfin, audio, odtwarzacz, przesyłanie strumieniowe, pobieranie, muzyka
jellyfin, audio, odtwarzacz, streaming, pobrane, muzyka

View File

@@ -0,0 +1 @@
https://github.com/leinelissen/jellyfin-audio-player/blob/master/docs/privacy-policy.md

View File

@@ -0,0 +1 @@
Fintunes 是 Jellyfin 媒體系統的流媒體音訊播放器。它具有華麗的介面,讓您輕鬆播放您最喜歡的音樂。您可以在整個庫中搜索任何曲目,或者輕鬆使用您之前在 Jellyfin 中建立的播放列表。所有曲目都直接從您的 Jellyfin 庫中以最高品質流式傳輸。不一定每次播放都能連接到網路嗎Jellyfin庫中的任何曲目都可以下載並離線播放。

View File

@@ -0,0 +1 @@
Jellyfin, 音訊, 播放器, 流媒體, 下載, 音樂

View File

@@ -0,0 +1 @@
https://fintunes.app/

View File

@@ -0,0 +1 @@
Fintunes

View File

@@ -0,0 +1 @@
https://github.com/leinelissen/jellyfin-audio-player/blob/master/docs/privacy-policy.md

View File

@@ -0,0 +1 @@
Jellyfin 的流媒體音訊播放器,支援搜尋和下載。

View File

@@ -0,0 +1 @@
這是一個緊急修復,讓您可以再次透過 HTTP 訪問您的 Jellyfin 伺服器。如果可能,請優先使用 HTTPS。

View File

@@ -0,0 +1 @@
Jellyfin 的音樂播放器

View File

@@ -0,0 +1 @@
https://github.com/leinelissen/jellyfin-audio-player

View File

@@ -7,16 +7,17 @@
objects = {
/* Begin PBXBuildFile section */
01DDB50991998A6D20A1A5CD /* libPods-Fintunes.a in Frameworks */ = {isa = PBXBuildFile; fileRef = E22EC545298DA9F9017776C0 /* libPods-Fintunes.a */; };
13B07FBC1A68108700A75B9A /* AppDelegate.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB01A68108700A75B9A /* AppDelegate.m */; };
13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB11A68108700A75B9A /* LaunchScreen.xib */; };
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 13B07FB51A68108700A75B9A /* Images.xcassets */; };
13B07FC11A68108700A75B9A /* main.m in Sources */ = {isa = PBXBuildFile; fileRef = 13B07FB71A68108700A75B9A /* main.m */; };
38B3606A2D29107567360ACF /* libPods-Fintunes-FintunesTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 8EBC468D2DE6EB8FF02B72B7 /* libPods-Fintunes-FintunesTests.a */; };
4C04FC6E055249ABB204D3BC /* Inter-VariableFont_slnt,wght.ttf in Resources */ = {isa = PBXBuildFile; fileRef = 4B4A0465FF364579B28CF5D7 /* Inter-VariableFont_slnt,wght.ttf */; };
4FA1B23D2550A94C007A035E /* File.swift in Sources */ = {isa = PBXBuildFile; fileRef = 4FA1B23C2550A94C007A035E /* File.swift */; };
96A76B2DA812E1F2E353959C /* libPods-Fintunes-FintunesTests.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 406012091F4F831F72DFB5D2 /* libPods-Fintunes-FintunesTests.a */; };
AB393FCA2857CC8400773469 /* SnapshotHelper.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB393FC92857CC8400773469 /* SnapshotHelper.swift */; };
AB4A8DFE2857C8DA005A1ED0 /* FintunesUITests.swift in Sources */ = {isa = PBXBuildFile; fileRef = AB4A8DFD2857C8DA005A1ED0 /* FintunesUITests.swift */; };
D7439709FB704B4FE23C538F /* libPods-Fintunes.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 12335560B9820FD5AD98AB8F /* libPods-Fintunes.a */; };
FA01635F2599C28FC19F2EC3 /* PrivacyInfo.xcprivacy in Resources */ = {isa = PBXBuildFile; fileRef = 3896494129CBC30258D9BB1C /* PrivacyInfo.xcprivacy */; };
/* End PBXBuildFile section */
/* Begin PBXContainerItemProxy section */
@@ -38,8 +39,6 @@
/* Begin PBXFileReference section */
00E356EE1AD99517003FC87E /* FintunesTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = FintunesTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
0973197F4BDB99413C326AD0 /* Pods-Fintunes.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Fintunes.release.xcconfig"; path = "Target Support Files/Pods-Fintunes/Pods-Fintunes.release.xcconfig"; sourceTree = "<group>"; };
12335560B9820FD5AD98AB8F /* libPods-Fintunes.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-Fintunes.a"; sourceTree = BUILT_PRODUCTS_DIR; };
13B07F961A680F5B00A75B9A /* Fintunes.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Fintunes.app; sourceTree = BUILT_PRODUCTS_DIR; };
13B07FAF1A68108700A75B9A /* AppDelegate.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = AppDelegate.h; path = Fintunes/AppDelegate.h; sourceTree = "<group>"; };
13B07FB01A68108700A75B9A /* AppDelegate.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = AppDelegate.m; path = Fintunes/AppDelegate.m; sourceTree = "<group>"; };
@@ -47,18 +46,19 @@
13B07FB51A68108700A75B9A /* Images.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; name = Images.xcassets; path = Fintunes/Images.xcassets; sourceTree = "<group>"; };
13B07FB61A68108700A75B9A /* Info.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = Info.plist; path = Fintunes/Info.plist; sourceTree = "<group>"; };
13B07FB71A68108700A75B9A /* main.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; name = main.m; path = Fintunes/main.m; sourceTree = "<group>"; };
3896494129CBC30258D9BB1C /* PrivacyInfo.xcprivacy */ = {isa = PBXFileReference; includeInIndex = 1; name = PrivacyInfo.xcprivacy; path = Fintunes/PrivacyInfo.xcprivacy; sourceTree = "<group>"; };
406012091F4F831F72DFB5D2 /* libPods-Fintunes-FintunesTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-Fintunes-FintunesTests.a"; sourceTree = BUILT_PRODUCTS_DIR; };
4B4A0465FF364579B28CF5D7 /* Inter-VariableFont_slnt,wght.ttf */ = {isa = PBXFileReference; explicitFileType = undefined; fileEncoding = 9; includeInIndex = 0; lastKnownFileType = unknown; name = "Inter-VariableFont_slnt,wght.ttf"; path = "../src/assets/fonts/Inter-VariableFont_slnt,wght.ttf"; sourceTree = "<group>"; };
4FA1B23B2550A94B007A035E /* Fintunes-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Fintunes-Bridging-Header.h"; sourceTree = "<group>"; };
4FA1B23C2550A94C007A035E /* File.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = File.swift; sourceTree = "<group>"; };
5370B45C5DDCD952C6569B8D /* Pods-Fintunes.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Fintunes.debug.xcconfig"; path = "Target Support Files/Pods-Fintunes/Pods-Fintunes.debug.xcconfig"; sourceTree = "<group>"; };
7D43C7610851B9666193E3F6 /* libPods-Fintunes-tvOSTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-Fintunes-tvOSTests.a"; sourceTree = BUILT_PRODUCTS_DIR; };
8EBC468D2DE6EB8FF02B72B7 /* libPods-Fintunes-FintunesTests.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-Fintunes-FintunesTests.a"; sourceTree = BUILT_PRODUCTS_DIR; };
55063C1C8FC150384B504BD6 /* Pods-Fintunes.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Fintunes.debug.xcconfig"; path = "Target Support Files/Pods-Fintunes/Pods-Fintunes.debug.xcconfig"; sourceTree = "<group>"; };
5892110C5BD456492E65B0FC /* Pods-Fintunes.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Fintunes.release.xcconfig"; path = "Target Support Files/Pods-Fintunes/Pods-Fintunes.release.xcconfig"; sourceTree = "<group>"; };
AB393FC92857CC8400773469 /* SnapshotHelper.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = SnapshotHelper.swift; sourceTree = "<group>"; };
AB4A8DFB2857C8DA005A1ED0 /* FintunesUITests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = FintunesUITests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
AB4A8DFD2857C8DA005A1ED0 /* FintunesUITests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = FintunesUITests.swift; sourceTree = "<group>"; };
AFAE700A256C6B0ED0D20FE3 /* Pods-Fintunes-FintunesTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Fintunes-FintunesTests.release.xcconfig"; path = "Target Support Files/Pods-Fintunes-FintunesTests/Pods-Fintunes-FintunesTests.release.xcconfig"; sourceTree = "<group>"; };
B20CBCFF11E124551F286B84 /* Pods-Fintunes-FintunesTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Fintunes-FintunesTests.debug.xcconfig"; path = "Target Support Files/Pods-Fintunes-FintunesTests/Pods-Fintunes-FintunesTests.debug.xcconfig"; sourceTree = "<group>"; };
E35451F7979C52C1692C4C9F /* libPods-Fintunes-tvOS.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-Fintunes-tvOS.a"; sourceTree = BUILT_PRODUCTS_DIR; };
BB181C2EAAC2E99F00A27B5F /* Pods-Fintunes-FintunesTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Fintunes-FintunesTests.release.xcconfig"; path = "Target Support Files/Pods-Fintunes-FintunesTests/Pods-Fintunes-FintunesTests.release.xcconfig"; sourceTree = "<group>"; };
E22EC545298DA9F9017776C0 /* libPods-Fintunes.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = "libPods-Fintunes.a"; sourceTree = BUILT_PRODUCTS_DIR; };
E9A22426CA08309D7A874468 /* Pods-Fintunes-FintunesTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Fintunes-FintunesTests.debug.xcconfig"; path = "Target Support Files/Pods-Fintunes-FintunesTests/Pods-Fintunes-FintunesTests.debug.xcconfig"; sourceTree = "<group>"; };
ED297162215061F000B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = System/Library/Frameworks/JavaScriptCore.framework; sourceTree = SDKROOT; };
ED2971642150620600B7C4FE /* JavaScriptCore.framework */ = {isa = PBXFileReference; lastKnownFileType = wrapper.framework; name = JavaScriptCore.framework; path = Platforms/AppleTVOS.platform/Developer/SDKs/AppleTVOS12.0.sdk/System/Library/Frameworks/JavaScriptCore.framework; sourceTree = DEVELOPER_DIR; };
/* End PBXFileReference section */
@@ -68,7 +68,7 @@
isa = PBXFrameworksBuildPhase;
buildActionMask = 2147483647;
files = (
38B3606A2D29107567360ACF /* libPods-Fintunes-FintunesTests.a in Frameworks */,
96A76B2DA812E1F2E353959C /* libPods-Fintunes-FintunesTests.a in Frameworks */,
);
runOnlyForDeploymentPostprocessing = 0;
};
@@ -76,7 +76,7 @@
isa = PBXFrameworksBuildPhase;
buildActionMask = 2147483647;
files = (
D7439709FB704B4FE23C538F /* libPods-Fintunes.a in Frameworks */,
01DDB50991998A6D20A1A5CD /* libPods-Fintunes.a in Frameworks */,
);
runOnlyForDeploymentPostprocessing = 0;
};
@@ -101,6 +101,7 @@
13B07FB71A68108700A75B9A /* main.m */,
4FA1B23C2550A94C007A035E /* File.swift */,
4FA1B23B2550A94B007A035E /* Fintunes-Bridging-Header.h */,
3896494129CBC30258D9BB1C /* PrivacyInfo.xcprivacy */,
);
name = Fintunes;
sourceTree = "<group>";
@@ -110,10 +111,8 @@
children = (
ED297162215061F000B7C4FE /* JavaScriptCore.framework */,
ED2971642150620600B7C4FE /* JavaScriptCore.framework */,
E35451F7979C52C1692C4C9F /* libPods-Fintunes-tvOS.a */,
7D43C7610851B9666193E3F6 /* libPods-Fintunes-tvOSTests.a */,
12335560B9820FD5AD98AB8F /* libPods-Fintunes.a */,
8EBC468D2DE6EB8FF02B72B7 /* libPods-Fintunes-FintunesTests.a */,
E22EC545298DA9F9017776C0 /* libPods-Fintunes.a */,
406012091F4F831F72DFB5D2 /* libPods-Fintunes-FintunesTests.a */,
);
name = Frameworks;
sourceTree = "<group>";
@@ -121,10 +120,10 @@
46001D7383D71A837AAF6E07 /* Pods */ = {
isa = PBXGroup;
children = (
5370B45C5DDCD952C6569B8D /* Pods-Fintunes.debug.xcconfig */,
0973197F4BDB99413C326AD0 /* Pods-Fintunes.release.xcconfig */,
B20CBCFF11E124551F286B84 /* Pods-Fintunes-FintunesTests.debug.xcconfig */,
AFAE700A256C6B0ED0D20FE3 /* Pods-Fintunes-FintunesTests.release.xcconfig */,
55063C1C8FC150384B504BD6 /* Pods-Fintunes.debug.xcconfig */,
5892110C5BD456492E65B0FC /* Pods-Fintunes.release.xcconfig */,
E9A22426CA08309D7A874468 /* Pods-Fintunes-FintunesTests.debug.xcconfig */,
BB181C2EAAC2E99F00A27B5F /* Pods-Fintunes-FintunesTests.release.xcconfig */,
);
path = Pods;
sourceTree = "<group>";
@@ -186,12 +185,12 @@
isa = PBXNativeTarget;
buildConfigurationList = 00E357021AD99517003FC87E /* Build configuration list for PBXNativeTarget "FintunesTests" */;
buildPhases = (
BBD71961640F29097BE9932A /* [CP] Check Pods Manifest.lock */,
4C89666008ED1AECA3700F1B /* [CP] Check Pods Manifest.lock */,
00E356EA1AD99517003FC87E /* Sources */,
00E356EB1AD99517003FC87E /* Frameworks */,
00E356EC1AD99517003FC87E /* Resources */,
BDE784ECF29EF861DBFF49D7 /* [CP] Copy Pods Resources */,
A02366876E56A727F566EC3A /* [CP] Embed Pods Frameworks */,
105D0C84EA50AA33C7A575A2 /* [CP] Embed Pods Frameworks */,
D9A3A76E8CEBB2167393A14A /* [CP] Copy Pods Resources */,
);
buildRules = (
);
@@ -207,13 +206,13 @@
isa = PBXNativeTarget;
buildConfigurationList = 13B07F931A680F5B00A75B9A /* Build configuration list for PBXNativeTarget "Fintunes" */;
buildPhases = (
E68FAF43791AC236CF4BF8CB /* [CP] Check Pods Manifest.lock */,
3A2533CC05843338D35BF11A /* [CP] Check Pods Manifest.lock */,
13B07F871A680F5B00A75B9A /* Sources */,
13B07F8C1A680F5B00A75B9A /* Frameworks */,
13B07F8E1A680F5B00A75B9A /* Resources */,
00DD1BFF1BD5951E006B06BC /* Bundle React Native code and images */,
B9FB8FC65CEFF9AFAC71127E /* [CP] Copy Pods Resources */,
2917566AA57EE087FC9FCCE9 /* [CP] Embed Pods Frameworks */,
062FA28CBD13CA4E60734D70 /* [CP] Embed Pods Frameworks */,
EDBDE27F51B5399CA455AD4D /* [CP] Copy Pods Resources */,
);
buildRules = (
);
@@ -253,19 +252,19 @@
TargetAttributes = {
00E356ED1AD99517003FC87E = {
CreatedOnToolsVersion = 6.2;
DevelopmentTeam = 238P3C58WC;
DevelopmentTeam = HD2D35G9Y4;
ProvisioningStyle = Manual;
TestTargetID = 13B07F861A680F5B00A75B9A;
};
13B07F861A680F5B00A75B9A = {
DevelopmentTeam = 238P3C58WC;
DevelopmentTeam = HD2D35G9Y4;
LastSwiftMigration = 1210;
ProvisioningStyle = Manual;
ProvisioningStyle = Automatic;
};
AB4A8DFA2857C8DA005A1ED0 = {
CreatedOnToolsVersion = 13.4.1;
DevelopmentTeam = 238P3C58WC;
ProvisioningStyle = Manual;
DevelopmentTeam = HD2D35G9Y4;
ProvisioningStyle = Automatic;
TestTargetID = 13B07F861A680F5B00A75B9A;
};
};
@@ -305,6 +304,7 @@
13B07FBF1A68108700A75B9A /* Images.xcassets in Resources */,
13B07FBD1A68108700A75B9A /* LaunchScreen.xib in Resources */,
4C04FC6E055249ABB204D3BC /* Inter-VariableFont_slnt,wght.ttf in Resources */,
FA01635F2599C28FC19F2EC3 /* PrivacyInfo.xcprivacy in Resources */,
);
runOnlyForDeploymentPostprocessing = 0;
};
@@ -332,25 +332,19 @@
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "set -e\n\nWITH_ENVIRONMENT=\"../node_modules/react-native/scripts/xcode/with-environment.sh\"\nREACT_NATIVE_XCODE=\"../node_modules/react-native/scripts/react-native-xcode.sh\"\n\n/bin/sh -c \"$WITH_ENVIRONMENT $REACT_NATIVE_XCODE\"\n";
shellScript = "set -e\n\nWITH_ENVIRONMENT=\"$REACT_NATIVE_PATH/scripts/xcode/with-environment.sh\"\nREACT_NATIVE_XCODE=\"$REACT_NATIVE_PATH/scripts/react-native-xcode.sh\"\n\n/bin/sh -c \"$WITH_ENVIRONMENT $REACT_NATIVE_XCODE\"\n";
};
2917566AA57EE087FC9FCCE9 /* [CP] Embed Pods Frameworks */ = {
062FA28CBD13CA4E60734D70 /* [CP] Embed Pods Frameworks */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
);
inputPaths = (
"${PODS_ROOT}/Target Support Files/Pods-Fintunes/Pods-Fintunes-frameworks.sh",
"${PODS_XCFRAMEWORKS_BUILD_DIR}/Flipper-DoubleConversion/double-conversion.framework/double-conversion",
"${PODS_XCFRAMEWORKS_BUILD_DIR}/Flipper-Glog/glog.framework/glog",
"${PODS_XCFRAMEWORKS_BUILD_DIR}/OpenSSL-Universal/OpenSSL.framework/OpenSSL",
"${PODS_XCFRAMEWORKS_BUILD_DIR}/hermes-engine/Pre-built/hermes.framework/hermes",
);
name = "[CP] Embed Pods Frameworks";
outputPaths = (
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/double-conversion.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/glog.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/OpenSSL.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/hermes.framework",
);
runOnlyForDeploymentPostprocessing = 0;
@@ -358,23 +352,17 @@
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Fintunes/Pods-Fintunes-frameworks.sh\"\n";
showEnvVarsInLog = 0;
};
A02366876E56A727F566EC3A /* [CP] Embed Pods Frameworks */ = {
105D0C84EA50AA33C7A575A2 /* [CP] Embed Pods Frameworks */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
);
inputPaths = (
"${PODS_ROOT}/Target Support Files/Pods-Fintunes-FintunesTests/Pods-Fintunes-FintunesTests-frameworks.sh",
"${PODS_XCFRAMEWORKS_BUILD_DIR}/Flipper-DoubleConversion/double-conversion.framework/double-conversion",
"${PODS_XCFRAMEWORKS_BUILD_DIR}/Flipper-Glog/glog.framework/glog",
"${PODS_XCFRAMEWORKS_BUILD_DIR}/OpenSSL-Universal/OpenSSL.framework/OpenSSL",
"${PODS_XCFRAMEWORKS_BUILD_DIR}/hermes-engine/Pre-built/hermes.framework/hermes",
);
name = "[CP] Embed Pods Frameworks";
outputPaths = (
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/double-conversion.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/glog.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/OpenSSL.framework",
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/hermes.framework",
);
runOnlyForDeploymentPostprocessing = 0;
@@ -382,27 +370,29 @@
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Fintunes-FintunesTests/Pods-Fintunes-FintunesTests-frameworks.sh\"\n";
showEnvVarsInLog = 0;
};
B9FB8FC65CEFF9AFAC71127E /* [CP] Copy Pods Resources */ = {
3A2533CC05843338D35BF11A /* [CP] Check Pods Manifest.lock */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
);
inputPaths = (
"${PODS_ROOT}/Target Support Files/Pods-Fintunes/Pods-Fintunes-resources.sh",
"${PODS_CONFIGURATION_BUILD_DIR}/React-Core/RCTI18nStrings.bundle",
"${PODS_ROOT}/Sentry/Sources/Resources/PrivacyInfo.xcprivacy",
inputFileListPaths = (
);
inputPaths = (
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
"${PODS_ROOT}/Manifest.lock",
);
name = "[CP] Check Pods Manifest.lock";
outputFileListPaths = (
);
name = "[CP] Copy Pods Resources";
outputPaths = (
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/RCTI18nStrings.bundle",
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/PrivacyInfo.xcprivacy",
"$(DERIVED_FILE_DIR)/Pods-Fintunes-checkManifestLockResult.txt",
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Fintunes/Pods-Fintunes-resources.sh\"\n";
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
showEnvVarsInLog = 0;
};
BBD71961640F29097BE9932A /* [CP] Check Pods Manifest.lock */ = {
4C89666008ED1AECA3700F1B /* [CP] Check Pods Manifest.lock */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
@@ -424,7 +414,7 @@
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
showEnvVarsInLog = 0;
};
BDE784ECF29EF861DBFF49D7 /* [CP] Copy Pods Resources */ = {
D9A3A76E8CEBB2167393A14A /* [CP] Copy Pods Resources */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
@@ -432,38 +422,36 @@
inputPaths = (
"${PODS_ROOT}/Target Support Files/Pods-Fintunes-FintunesTests/Pods-Fintunes-FintunesTests-resources.sh",
"${PODS_CONFIGURATION_BUILD_DIR}/React-Core/RCTI18nStrings.bundle",
"${PODS_ROOT}/Sentry/Sources/Resources/PrivacyInfo.xcprivacy",
"${PODS_CONFIGURATION_BUILD_DIR}/Sentry/Sentry.bundle",
);
name = "[CP] Copy Pods Resources";
outputPaths = (
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/RCTI18nStrings.bundle",
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/PrivacyInfo.xcprivacy",
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Sentry.bundle",
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Fintunes-FintunesTests/Pods-Fintunes-FintunesTests-resources.sh\"\n";
showEnvVarsInLog = 0;
};
E68FAF43791AC236CF4BF8CB /* [CP] Check Pods Manifest.lock */ = {
EDBDE27F51B5399CA455AD4D /* [CP] Copy Pods Resources */ = {
isa = PBXShellScriptBuildPhase;
buildActionMask = 2147483647;
files = (
);
inputFileListPaths = (
);
inputPaths = (
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
"${PODS_ROOT}/Manifest.lock",
);
name = "[CP] Check Pods Manifest.lock";
outputFileListPaths = (
"${PODS_ROOT}/Target Support Files/Pods-Fintunes/Pods-Fintunes-resources.sh",
"${PODS_CONFIGURATION_BUILD_DIR}/React-Core/RCTI18nStrings.bundle",
"${PODS_CONFIGURATION_BUILD_DIR}/Sentry/Sentry.bundle",
);
name = "[CP] Copy Pods Resources";
outputPaths = (
"$(DERIVED_FILE_DIR)/Pods-Fintunes-checkManifestLockResult.txt",
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/RCTI18nStrings.bundle",
"${TARGET_BUILD_DIR}/${UNLOCALIZED_RESOURCES_FOLDER_PATH}/Sentry.bundle",
);
runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh;
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Fintunes/Pods-Fintunes-resources.sh\"\n";
showEnvVarsInLog = 0;
};
/* End PBXShellScriptBuildPhase section */
@@ -525,12 +513,12 @@
/* Begin XCBuildConfiguration section */
00E356F61AD99517003FC87E /* Debug */ = {
isa = XCBuildConfiguration;
baseConfigurationReference = B20CBCFF11E124551F286B84 /* Pods-Fintunes-FintunesTests.debug.xcconfig */;
baseConfigurationReference = E9A22426CA08309D7A874468 /* Pods-Fintunes-FintunesTests.debug.xcconfig */;
buildSettings = {
ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;
BUNDLE_LOADER = "$(TEST_HOST)";
CODE_SIGN_STYLE = Manual;
DEVELOPMENT_TEAM = 238P3C58WC;
DEVELOPMENT_TEAM = HD2D35G9Y4;
GCC_PREPROCESSOR_DEFINITIONS = (
"DEBUG=1",
"$(inherited)",
@@ -555,13 +543,13 @@
};
00E356F71AD99517003FC87E /* Release */ = {
isa = XCBuildConfiguration;
baseConfigurationReference = AFAE700A256C6B0ED0D20FE3 /* Pods-Fintunes-FintunesTests.release.xcconfig */;
baseConfigurationReference = BB181C2EAAC2E99F00A27B5F /* Pods-Fintunes-FintunesTests.release.xcconfig */;
buildSettings = {
ALWAYS_EMBED_SWIFT_STANDARD_LIBRARIES = YES;
BUNDLE_LOADER = "$(TEST_HOST)";
CODE_SIGN_STYLE = Manual;
COPY_PHASE_STRIP = NO;
DEVELOPMENT_TEAM = 238P3C58WC;
DEVELOPMENT_TEAM = HD2D35G9Y4;
INFOPLIST_FILE = FintunesTests/Info.plist;
IPHONEOS_DEPLOYMENT_TARGET = 13.4;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks @loader_path/Frameworks";
@@ -584,15 +572,14 @@
};
13B07F941A680F5B00A75B9A /* Debug */ = {
isa = XCBuildConfiguration;
baseConfigurationReference = 5370B45C5DDCD952C6569B8D /* Pods-Fintunes.debug.xcconfig */;
baseConfigurationReference = 55063C1C8FC150384B504BD6 /* Pods-Fintunes.debug.xcconfig */;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CLANG_ENABLE_MODULES = YES;
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution";
CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Manual;
CURRENT_PROJECT_VERSION = 83;
DEVELOPMENT_TEAM = 238P3C58WC;
"DEVELOPMENT_TEAM[sdk=iphoneos*]" = 238P3C58WC;
CURRENT_PROJECT_VERSION = 102;
DEVELOPMENT_TEAM = HD2D35G9Y4;
ENABLE_BITCODE = NO;
GCC_PREPROCESSOR_DEFINITIONS = (
"$(inherited)",
@@ -613,7 +600,6 @@
PRODUCT_BUNDLE_IDENTIFIER = nl.moeilijkedingen.jellyfinaudioplayer;
PRODUCT_NAME = Fintunes;
PROVISIONING_PROFILE_SPECIFIER = "";
"PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = "nl.moeilijkedingen.jellyfinaudioplayer AppStore 1707846041";
SWIFT_OBJC_BRIDGING_HEADER = "Fintunes-Bridging-Header.h";
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
SWIFT_VERSION = 5.0;
@@ -623,16 +609,16 @@
};
13B07F951A680F5B00A75B9A /* Release */ = {
isa = XCBuildConfiguration;
baseConfigurationReference = 0973197F4BDB99413C326AD0 /* Pods-Fintunes.release.xcconfig */;
baseConfigurationReference = 5892110C5BD456492E65B0FC /* Pods-Fintunes.release.xcconfig */;
buildSettings = {
ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon;
CLANG_ENABLE_MODULES = YES;
CODE_SIGN_IDENTITY = "Apple Development";
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution";
CODE_SIGN_STYLE = Manual;
CURRENT_PROJECT_VERSION = 83;
DEVELOPMENT_TEAM = 238P3C58WC;
"DEVELOPMENT_TEAM[sdk=iphoneos*]" = 238P3C58WC;
CURRENT_PROJECT_VERSION = 102;
DEVELOPMENT_TEAM = HD2D35G9Y4;
"DEVELOPMENT_TEAM[sdk=iphoneos*]" = HD2D35G9Y4;
INFOPLIST_FILE = Fintunes/Info.plist;
LD_RUNPATH_SEARCH_PATHS = "$(inherited) @executable_path/Frameworks";
LIBRARY_SEARCH_PATHS = (
@@ -649,7 +635,7 @@
PRODUCT_NAME = Fintunes;
PROVISIONING_PROFILE = "915c5213-22f6-4f9d-8065-2a06300f9bfb";
PROVISIONING_PROFILE_SPECIFIER = "";
"PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = "nl.moeilijkedingen.jellyfinaudioplayer AppStore 1707846041";
"PROVISIONING_PROFILE_SPECIFIER[sdk=iphoneos*]" = "nl.moeilijkedingen.jellyfinaudioplayer AppStore";
SWIFT_OBJC_BRIDGING_HEADER = "Fintunes-Bridging-Header.h";
SWIFT_VERSION = 5.0;
VERSIONING_SYSTEM = "apple-generic";
@@ -660,6 +646,7 @@
isa = XCBuildConfiguration;
buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO;
CC = "";
CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES;
CLANG_CXX_LANGUAGE_STANDARD = "c++20";
CLANG_CXX_LIBRARY = "libc++";
@@ -687,6 +674,7 @@
CODE_SIGN_IDENTITY = "Apple Development";
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "Apple Development";
COPY_PHASE_STRIP = NO;
CXX = "";
ENABLE_STRICT_OBJC_MSGSEND = YES;
ENABLE_TESTABILITY = YES;
"EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386;
@@ -707,6 +695,8 @@
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 13.4;
LD = "";
LDPLUSPLUS = "";
LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)";
LIBRARY_SEARCH_PATHS = (
"$(SDKROOT)/usr/lib/swift",
@@ -729,6 +719,7 @@
isa = XCBuildConfiguration;
buildSettings = {
ALWAYS_SEARCH_USER_PATHS = NO;
CC = "";
CLANG_ANALYZER_LOCALIZABILITY_NONLOCALIZED = YES;
CLANG_CXX_LANGUAGE_STANDARD = "c++20";
CLANG_CXX_LIBRARY = "libc++";
@@ -756,6 +747,7 @@
CODE_SIGN_IDENTITY = "Apple Distribution: Bureau Moeilijke Dingen BV (238P3C58WC)";
"CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "Apple Distribution: Bureau Moeilijke Dingen BV (238P3C58WC)";
COPY_PHASE_STRIP = YES;
CXX = "";
ENABLE_NS_ASSERTIONS = NO;
ENABLE_STRICT_OBJC_MSGSEND = YES;
"EXCLUDED_ARCHS[sdk=iphonesimulator*]" = i386;
@@ -772,6 +764,8 @@
GCC_WARN_UNUSED_FUNCTION = YES;
GCC_WARN_UNUSED_VARIABLE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 13.4;
LD = "";
LDPLUSPLUS = "";
LD_RUNPATH_SEARCH_PATHS = "/usr/lib/swift $(inherited)";
LIBRARY_SEARCH_PATHS = (
"$(SDKROOT)/usr/lib/swift",
@@ -800,10 +794,11 @@
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;
CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Manual;
CURRENT_PROJECT_VERSION = 83;
CURRENT_PROJECT_VERSION = 102;
DEBUG_INFORMATION_FORMAT = dwarf;
DEVELOPMENT_TEAM = 238P3C58WC;
DEVELOPMENT_TEAM = HD2D35G9Y4;
GCC_C_LANGUAGE_STANDARD = gnu11;
GENERATE_INFOPLIST_FILE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 15.5;
@@ -813,6 +808,7 @@
PRODUCT_BUNDLE_IDENTIFIER = nl.moeilijkedingen.FintunesUITests;
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE = "915c5213-22f6-4f9d-8065-2a06300f9bfb";
PROVISIONING_PROFILE_SPECIFIER = "";
SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG;
SWIFT_EMIT_LOC_STRINGS = NO;
SWIFT_OPTIMIZATION_LEVEL = "-Onone";
@@ -832,11 +828,12 @@
CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;
CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
CODE_SIGN_IDENTITY = "Apple Development";
CODE_SIGN_STYLE = Manual;
COPY_PHASE_STRIP = NO;
CURRENT_PROJECT_VERSION = 83;
CURRENT_PROJECT_VERSION = 102;
DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
DEVELOPMENT_TEAM = 238P3C58WC;
DEVELOPMENT_TEAM = HD2D35G9Y4;
GCC_C_LANGUAGE_STANDARD = gnu11;
GENERATE_INFOPLIST_FILE = YES;
IPHONEOS_DEPLOYMENT_TARGET = 15.5;
@@ -845,6 +842,7 @@
PRODUCT_BUNDLE_IDENTIFIER = nl.moeilijkedingen.FintunesUITests;
PRODUCT_NAME = "$(TARGET_NAME)";
PROVISIONING_PROFILE = "915c5213-22f6-4f9d-8065-2a06300f9bfb";
PROVISIONING_PROFILE_SPECIFIER = "";
SWIFT_EMIT_LOC_STRINGS = NO;
SWIFT_OPTIMIZATION_LEVEL = "-Owholemodule";
SWIFT_VERSION = 5.0;

View File

@@ -55,7 +55,7 @@
</Testables>
</TestAction>
<LaunchAction
buildConfiguration = "Release"
buildConfiguration = "Debug"
selectedDebuggerIdentifier = "Xcode.DebuggerFoundation.Debugger.LLDB"
selectedLauncherIdentifier = "Xcode.DebuggerFoundation.Launcher.LLDB"
launchStyle = "0"

View File

@@ -16,10 +16,10 @@
- (NSURL *)sourceURLForBridge:(RCTBridge *)bridge
{
return [self getBundleURL];
return [self bundleURL];
}
- (NSURL *)getBundleURL
- (NSURL *)bundleURL
{
#if DEBUG
return [[RCTBundleURLProvider sharedSettings] jsBundleURLForBundleRoot:@"index"];

View File

@@ -17,19 +17,19 @@
<key>CFBundlePackageType</key>
<string>APPL</string>
<key>CFBundleShortVersionString</key>
<string>2.3.1</string>
<string>2.4.0</string>
<key>CFBundleSignature</key>
<string>????</string>
<key>CFBundleVersion</key>
<string>83</string>
<string>102</string>
<key>LSRequiresIPhoneOS</key>
<true/>
<key>LSSupportsOpeningDocumentsInPlace</key>
<true/>
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
<key>NSAllowsLocalNetworking</key>
<true/>
</dict>
<key>NSLocationWhenInUseUsageDescription</key>
<string></string>
@@ -42,11 +42,13 @@
<string>audio</string>
<string>fetch</string>
</array>
<key>UIFileSharingEnabled</key>
<true/>
<key>UILaunchStoryboardName</key>
<string>LaunchScreen</string>
<key>UIRequiredDeviceCapabilities</key>
<array>
<string>armv7</string>
<string>arm64</string>
</array>
<key>UISupportedInterfaceOrientations</key>
<array>
@@ -54,13 +56,9 @@
<string>UIInterfaceOrientationLandscapeLeft</string>
<string>UIInterfaceOrientationLandscapeRight</string>
</array>
<key>UISupportsDocumentBrowser</key>
<true/>
<key>UIViewControllerBasedStatusBarAppearance</key>
<false/>
<key>UIFileSharingEnabled</key>
<true/>
<key>LSSupportsOpeningDocumentsInPlace</key>
<true/>
<key>UISupportsDocumentBrowser</key>
<true/>
</dict>
</plist>

View File

@@ -0,0 +1,37 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>NSPrivacyAccessedAPITypes</key>
<array>
<dict>
<key>NSPrivacyAccessedAPIType</key>
<string>NSPrivacyAccessedAPICategoryUserDefaults</string>
<key>NSPrivacyAccessedAPITypeReasons</key>
<array>
<string>CA92.1</string>
</array>
</dict>
<dict>
<key>NSPrivacyAccessedAPIType</key>
<string>NSPrivacyAccessedAPICategorySystemBootTime</string>
<key>NSPrivacyAccessedAPITypeReasons</key>
<array>
<string>35F9.1</string>
</array>
</dict>
<dict>
<key>NSPrivacyAccessedAPIType</key>
<string>NSPrivacyAccessedAPICategoryFileTimestamp</string>
<key>NSPrivacyAccessedAPITypeReasons</key>
<array>
<string>C617.1</string>
</array>
</dict>
</array>
<key>NSPrivacyCollectedDataTypes</key>
<array/>
<key>NSPrivacyTracking</key>
<false/>
</dict>
</plist>

View File

@@ -8,17 +8,6 @@ require Pod::Executable.execute_command('node', ['-p',
platform :ios, min_ios_version_supported
prepare_react_native_project!
# If you are using a `react-native-flipper` your iOS build will fail when `NO_FLIPPER=1` is set.
# because `react-native-flipper` depends on (FlipperKit,...) that will be excluded
#
# To fix this you can also exclude `react-native-flipper` using a `react-native.config.js`
# ```js
# module.exports = {
# dependencies: {
# ...(process.env.NO_FLIPPER ? { 'react-native-flipper': { platforms: { ios: null } } } : {}),
# ```
flipper_config = ENV['NO_FLIPPER'] == "1" ? FlipperConfiguration.disabled : FlipperConfiguration.enabled
linkage = ENV['USE_FRAMEWORKS']
if linkage != nil
Pod::UI.puts "Configuring Pod with #{linkage}ally linked Frameworks".green
@@ -30,11 +19,6 @@ target 'Fintunes' do
use_react_native!(
:path => config[:reactNativePath],
# Enables Flipper.
#
# Note that if you have use_frameworks! enabled, Flipper will not work and
# you should disable the next line.
:flipper_configuration => flipper_config,
# An absolute path to your application root.
:app_path => "#{Pod::Config.instance.installation_root}/.."
)
@@ -49,7 +33,8 @@ target 'Fintunes' do
react_native_post_install(
installer,
config[:reactNativePath],
:mac_catalyst_enabled => false
:mac_catalyst_enabled => false,
# :ccache_enabled => true
)
end
end

File diff suppressed because it is too large Load Diff

1710
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@@ -1,6 +1,6 @@
{
"name": "fintunes",
"version": "2.3.1",
"version": "2.4.1",
"main": "src/index.js",
"private": true,
"scripts": {
@@ -13,7 +13,7 @@
},
"dependencies": {
"@react-native-async-storage/async-storage": "^1.21.0",
"@react-native-community/blur": "^4.4.0",
"@react-native-community/blur": "^4.4.1",
"@react-native-community/datetimepicker": "^7.6.2",
"@react-native-community/netinfo": "^11.2.1",
"@react-navigation/bottom-tabs": "^6.5.12",
@@ -28,9 +28,10 @@
"fuse.js": "^7.0.0",
"i18n-js": "^4.3.2",
"lodash": "^4.17.21",
"mime-db": "^1.53.0",
"react": "^18.2.0",
"react-airplay": "^1.2.0",
"react-native": "^0.73.4",
"react-native": "0.74.3",
"react-native-accessibility-settings": "^0.1.2",
"react-native-collapsible": "^1.6.1",
"react-native-dotenv": "^3.4.9",
@@ -39,8 +40,8 @@
"react-native-gesture-handler": "^2.15.0",
"react-native-localize": "^3.0.6",
"react-native-modal-datetime-picker": "^17.1.0",
"react-native-reanimated": "^3.7.0",
"react-native-safe-area-context": "^4.9.0",
"react-native-reanimated": "^3.14.0",
"react-native-safe-area-context": "^4.10.8",
"react-native-screens": "^3.29.0",
"react-native-shadow-2": "^7.0.8",
"react-native-svg": "^14.1.0",
@@ -48,24 +49,22 @@
"react-native-webview": "^13.7.1",
"react-redux": "^9.1.0",
"redux": "^5.0.1",
"redux-flipper": "^2.0.2",
"redux-logger": "^3.0.6",
"redux-persist": "^6.0.0",
"styled-components": "^6.1.8"
},
"devDependencies": {
"@babel/core": "^7.20.2",
"@babel/runtime": "^7.20.1",
"@react-native/babel-preset": "^0.73.21",
"@react-native/metro-config": "^0.73.5",
"@react-native/typescript-config": "^0.74.0",
"@sentry/cli": "^2.28.0",
"@sentry/react-native": "^5.18.0",
"@react-native/babel-preset": "0.74.85",
"@react-native/metro-config": "0.74.85",
"@react-native/typescript-config": "0.74.85",
"@sentry/cli": "^2.33.0",
"@sentry/react-native": "^5.26.0",
"@types/i18n-js": "^3.8.9",
"@types/lodash": "^4.14.202",
"@types/mime-db": "^1.43.5",
"@types/node": "^20.11.17",
"@types/react": "^18.2.55",
"@types/redux-logger": "^3.0.13",
"@typescript-eslint/eslint-plugin": "^6.21.0",
"@typescript-eslint/parser": "^6.21.0",
"babel-plugin-module-resolver": "^5.0.0",
@@ -74,7 +73,6 @@
"eslint-plugin-react-hooks": "^4.6.0",
"metro-react-native-babel-transformer": "^0.77.0",
"patch-package": "^8.0.0",
"react-native-flipper": "^0.212.0",
"react-native-svg-transformer": "^1.3.0",
"tslib": "^2.6.2",
"typescript": "^5.3.3"

View File

@@ -0,0 +1,13 @@
diff --git a/node_modules/@react-native-community/datetimepicker/ios/RNDateTimePickerShadowView.m b/node_modules/@react-native-community/datetimepicker/ios/RNDateTimePickerShadowView.m
index c139440..4ff3362 100644
--- a/node_modules/@react-native-community/datetimepicker/ios/RNDateTimePickerShadowView.m
+++ b/node_modules/@react-native-community/datetimepicker/ios/RNDateTimePickerShadowView.m
@@ -41,7 +41,7 @@
YGNodeMarkDirty(self.yogaNode);
}
-static YGSize RNDateTimePickerShadowViewMeasure(YGNodeRef node, float width, YGMeasureMode widthMode, float height, YGMeasureMode heightMode)
+static YGSize RNDateTimePickerShadowViewMeasure(YGNodeConstRef node, float width, YGMeasureMode widthMode, float height, YGMeasureMode heightMode)
{
RNDateTimePickerShadowView *shadowPickerView = (__bridge RNDateTimePickerShadowView *)YGNodeGetContext(node);

View File

@@ -0,0 +1,13 @@
diff --git a/node_modules/@shopify/react-native-skia/android/build.gradle b/node_modules/@shopify/react-native-skia/android/build.gradle
index 29e74bf..f2b35a5 100644
--- a/node_modules/@shopify/react-native-skia/android/build.gradle
+++ b/node_modules/@shopify/react-native-skia/android/build.gradle
@@ -135,6 +135,8 @@ android {
defaultConfig {
minSdkVersion safeExtGet('minSdkVersion', DEFAULT_MIN_SDK_VERSION)
targetSdkVersion safeExtGet('targetSdkVersion', DEFAULT_TARGET_SDK_VERSION)
+ ndkVersion safeExtGet('ndkVersion', '26.1.10909125')
+
versionCode 1
versionName "1.0"

View File

@@ -4,12 +4,4 @@ module.exports = {
android: {}
},
assets: ['./src/assets/fonts/'],
dependencies: {
// Deal with unruly react-native-flipper dependencies, per: https://github.com/facebook/flipper/issues/5266
'react-native-flipper': {
platforms: {
ios: null,
},
},
}
};

View File

@@ -0,0 +1,3 @@
<svg width="17" height="15" viewBox="0 0 17 15" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M0.314163 14.9808V3.01292C0.314163 2.68584 0.428955 2.40744 0.658538 2.17771C0.88826 1.94813 1.16659 1.83334 1.49354 1.83334H9.46791C9.795 1.83334 10.0733 1.94813 10.3029 2.17771C10.5326 2.40744 10.6475 2.68584 10.6475 3.01292V3.41021C10.4989 3.51605 10.3717 3.63598 10.266 3.77001C10.1602 3.90417 10.0651 4.05084 9.98083 4.21001V3.01292C9.98083 2.86334 9.93271 2.74042 9.83646 2.64417C9.74034 2.54806 9.6175 2.50001 9.46791 2.50001H1.49354C1.34395 2.50001 1.22111 2.54806 1.125 2.64417C1.02889 2.74042 0.98083 2.86334 0.98083 3.01292V12.5H9.46791C9.6175 12.5 9.74034 12.4519 9.83646 12.3558C9.93271 12.2596 9.98083 12.1367 9.98083 11.9871V8.79001C10.0651 8.94917 10.1633 9.09653 10.2752 9.23209C10.387 9.36764 10.5111 9.48688 10.6475 9.5898V11.9871C10.6475 12.3142 10.5326 12.5926 10.3029 12.8223C10.0733 13.0519 9.795 13.1667 9.46791 13.1667H2.12812L0.314163 14.9808ZM2.8975 10.5833H5.06416V9.91667H2.8975V10.5833ZM12.6796 8.58334C12.1026 8.58334 11.6112 8.38035 11.2052 7.97438C10.7992 7.56841 10.5962 7.07695 10.5962 6.50001C10.5962 5.92306 10.7992 5.4316 11.2052 5.02563C11.6112 4.61966 12.1026 4.41667 12.6796 4.41667C12.936 4.41667 13.1611 4.45806 13.355 4.54084C13.5489 4.62362 13.796 4.76917 14.0962 4.9775V0.416672H16.2629V1.08334H14.7629V6.50001C14.7629 7.07695 14.5599 7.56841 14.1537 7.97438C13.7478 8.38035 13.2564 8.58334 12.6796 8.58334ZM2.8975 7.83334H8.06416V7.16667H2.8975V7.83334ZM2.8975 5.08334H8.06416V4.41667H2.8975V5.08334Z"/>
</svg>

After

Width:  |  Height:  |  Size: 1.5 KiB

View File

@@ -0,0 +1,8 @@
<svg width="56" height="56" viewBox="0 0 56 56" fill="none" xmlns="http://www.w3.org/2000/svg">
<path d="M50.5303 36.5379C51.7368 36.5379 52.7016 35.573 52.7016 34.3935V21.6065C52.7016 20.427 51.7368 19.4352 50.5303 19.4352C49.2972 19.4352 48.3859 20.427 48.3859 21.6065V34.3935C48.3859 35.573 49.2972 36.5379 50.5303 36.5379Z" />
<path d="M41.5233 50.0488C42.7295 50.0488 43.6677 49.0839 43.6677 47.9043V8.09575C43.6677 6.91623 42.7295 5.92436 41.5233 5.92436C40.2633 5.92436 39.352 6.91623 39.352 8.09575V47.9043C39.352 49.0839 40.2633 50.0488 41.5233 50.0488Z" />
<path d="M32.4894 41.9261C33.7224 41.9261 34.6607 40.9879 34.6607 39.7817V16.2183C34.6607 15.012 33.7224 14.0469 32.4894 14.0469C31.256 14.0469 30.3447 15.012 30.3447 16.2183V39.7817C30.3447 40.9879 31.256 41.9261 32.4894 41.9261Z" />
<path d="M23.4553 56C24.6884 56 25.6535 55.0348 25.6535 53.8287V2.17137C25.6535 0.965053 24.6884 0 23.4553 0C22.249 0 21.3376 0.965053 21.3376 2.17137V53.8287C21.3376 55.0348 22.249 56 23.4553 56Z" />
<path d="M14.4481 45.1966C15.6812 45.1966 16.6195 44.2317 16.6195 43.0253V12.9746C16.6195 11.7683 15.6812 10.7764 14.4481 10.7764C13.2418 10.7764 12.3035 11.7683 12.3035 12.9746V43.0253C12.3035 44.2317 13.2418 45.1966 14.4481 45.1966Z" />
<path d="M5.41411 34.2326C6.67405 34.2326 7.61231 33.2675 7.61231 32.0613V23.9387C7.61231 22.7324 6.67405 21.7405 5.41411 21.7405C4.2078 21.7405 3.29636 22.7324 3.29636 23.9387V32.0613C3.29636 33.2675 4.2078 34.2326 5.41411 34.2326Z" />
</svg>

After

Width:  |  Height:  |  Size: 1.5 KiB

View File

@@ -3,16 +3,14 @@ import { Provider } from 'react-redux';
import TrackPlayer, { Capability } from 'react-native-track-player';
import { PersistGate } from 'redux-persist/integration/react';
import Routes from '../screens';
import store, { persistedStore, useTypedSelector } from '@/store';
import store, { persistedStore } from '@/store';
import {
NavigationContainer,
DefaultTheme,
DarkTheme as BaseDarkTheme,
} from '@react-navigation/native';
import { ColorSchemeProvider, themes } from './Colors';
import { ColorSchemeProvider, themes, useUserOrSystemScheme } from './Colors';
import DownloadManager from './DownloadManager';
import { useColorScheme } from 'react-native';
import { ColorScheme } from '@/store/settings/types';
const LightTheme = {
...DefaultTheme,
@@ -35,9 +33,7 @@ const DarkTheme = {
* right theme is selected based on OS color scheme settings along with user preferences.
*/
function ThemedNavigationContainer({ children }: PropsWithChildren<{}>) {
const systemScheme = useColorScheme();
const userScheme = useTypedSelector((state) => state.settings.colorScheme);
const scheme = userScheme === ColorScheme.System ? systemScheme : userScheme;
const scheme = useUserOrSystemScheme();
return (
<NavigationContainer

View File

@@ -62,6 +62,9 @@ function generateStyles(scheme: ColorSchemeName, highContrast: boolean) {
backgroundColor: scheme === 'dark' ? '#191919' : '#f3f3f3',
color: scheme === 'dark' ? '#fff' : '#000',
},
trackBackground: {
backgroundColor: scheme === 'dark' ? '#161616' : '#fff',
},
stackHeader: {
color: scheme === 'dark' ? 'white' : 'black'
},
@@ -108,14 +111,21 @@ export const themes: Record<'dark' | 'light' | 'dark-highcontrast' | 'light-high
// Create context for supplying the theming information
export const ColorSchemeContext = React.createContext(themes.dark);
/**
* This hook returns the proper color scheme, taking into account potential user overrides.
*/
export function useUserOrSystemScheme() {
const systemScheme = useColorScheme();
const userScheme = useTypedSelector((state) => state.settings.colorScheme);
return userScheme === ColorScheme.System ? systemScheme : userScheme;
}
/**
* This provider contains the logic for settings the right theme on the ColorSchemeContext.
*/
export function ColorSchemeProvider({ children }: PropsWithChildren<{}>) {
const systemScheme = useColorScheme();
const highContrast = useAccessibilitySetting('darkerSystemColors');
const userScheme = useTypedSelector((state) => state.settings.colorScheme);
const scheme = userScheme === ColorScheme.System ? systemScheme : userScheme;
const scheme = useUserOrSystemScheme();
const theme = highContrast
? themes[`${scheme || 'light'}-highcontrast`]
: themes[scheme || 'light'];

View File

@@ -1,7 +1,7 @@
import React, { useMemo } from 'react';
import { Dimensions, useColorScheme, ViewProps } from 'react-native';
import React, { useMemo, useState } from 'react';
import { Dimensions, ViewProps } from 'react-native';
import { Canvas, Blur, Image as SkiaImage, useImage, Offset, Mask, RoundedRect, Shadow } from '@shopify/react-native-skia';
import useDefaultStyles from './Colors';
import useDefaultStyles, { useUserOrSystemScheme } from './Colors';
import styled from 'styled-components/native';
const Screen = Dimensions.get('screen');
@@ -13,7 +13,7 @@ const Container = styled.View<{ size: number }>`
z-index: 0;
`;
const BlurContainer = styled(Canvas)<{ size: number, offset: number }>`
const BlurContainer = styled(Canvas) <{ size: number, offset: number }>`
position: absolute;
left: -${(props) => props.offset}px;
top: -${(props) => props.offset}px;
@@ -31,32 +31,34 @@ interface Props {
src: string;
}
const emptyAlbumLight = require('@/assets/images/empty-album-light.png');
const emptyAlbumDark = require('@/assets/images/empty-album-dark.png');
/**
* This will take a cover image, and apply shadows and a really nice background
* blur to the image in question. Additionally, we'll add some margin and radius
* to the corners.
*/
function CoverImage({
blurRadius = 256,
opacity = 0.85,
margin = 112,
radius = 12,
blurRadius = 256,
opacity = 0.85,
margin = 112,
radius = 12,
style,
src,
src,
}: Props) {
const defaultStyles = useDefaultStyles();
const colorScheme = useColorScheme();
const colorScheme = useUserOrSystemScheme();
const [hasFailed, setFailed] = useState(false);
const image = useImage(src || null);
const fallback = useImage(colorScheme === 'light' ? require('@/assets/images/empty-album-light.png') : require('@/assets/images/empty-album-dark.png'));
const image = useImage(src || null, () => setFailed(true));
const fallback = useImage(colorScheme === 'light' ? emptyAlbumLight : emptyAlbumDark);
const { canvasSize, imageSize } = useMemo(() => {
const imageSize = Screen.width - margin;
const canvasSize = imageSize + blurRadius * 2;
return { imageSize, canvasSize };
}, [blurRadius, margin]);
const skiaImage = useMemo(() => (image || fallback), [image, fallback]);
return (
<Container size={imageSize} style={style}>
<BlurContainer size={canvasSize} offset={blurRadius}>
@@ -67,19 +69,52 @@ function CoverImage({
<Shadow dx={0} dy={8} blur={16} color="#0000000d" />
<Shadow dx={0} dy={16} blur={32} color="#0000000d" />
</RoundedRect>
{skiaImage ? (
{src && (
<>
<SkiaImage image={skiaImage} width={imageSize} height={imageSize} opacity={opacity}>
<SkiaImage
image={image}
width={imageSize}
height={imageSize}
opacity={opacity}
key="image-blur"
>
<Offset x={blurRadius} y={blurRadius} />
<Blur blur={blurRadius / 2} />
</SkiaImage>
<Mask mask={<RoundedRect width={imageSize} height={imageSize} x={blurRadius} y={blurRadius} r={radius} />}>
<SkiaImage image={skiaImage} width={imageSize} height={imageSize}>
<Mask
mask={
<RoundedRect
width={imageSize}
height={imageSize}
x={blurRadius}
y={blurRadius} r={radius}
/>
}
key="image"
>
<SkiaImage image={image} width={imageSize} height={imageSize}>
<Offset x={blurRadius} y={blurRadius} />
</SkiaImage>
</Mask>
</>
) : null}
)}
{(!src || hasFailed) && (
<Mask
mask={
<RoundedRect
width={imageSize}
height={imageSize}
x={blurRadius}
y={blurRadius} r={radius}
/>
}
key="fallback"
>
<SkiaImage image={fallback} width={imageSize} height={imageSize}>
<Offset x={blurRadius} y={blurRadius} />
</SkiaImage>
</Mask>
)}
</BlurContainer>
</Container>
);

View File

@@ -3,6 +3,7 @@ import { useEffect, useRef, useState } from 'react';
import { DocumentDirectoryPath, readDir } from 'react-native-fs';
import { useAppDispatch, useTypedSelector } from '@/store';
import { completeDownload, downloadTrack } from '@/store/downloads/actions';
import { getMimeTypeForExtension } from '@/utility/mimeType';
/**
* The maximum number of concurrent downloads we allow to take place at once.
@@ -77,11 +78,17 @@ function DownloadManager () {
// Loop through the mp3 files
files.filter((file) => file.isFile())
.forEach((file) => {
const [id] = file.name.split('.');
const [id, extension] = file.name.split('.');
const mimeType = getMimeTypeForExtension(extension);
// GUARD: Only process audio mime types
if (!mimeType || mimeType.startsWith('audio')) {
return;
}
// GUARD: If the id is already in the store, there's nothing
// left for us to do.
if (ids.includes(id) && file.path === entities[id]?.location) {
if (ids.includes(id)) {
return;
}
@@ -90,6 +97,7 @@ function DownloadManager () {
id,
location: file.path,
size: file.size,
}));
});
}

View File

@@ -20,8 +20,8 @@ export function calculateProgressTranslation(
const completion = position / reference;
// GUARD: Check whether the calculated number is valid and not infinite
if (Number.isNaN(completion) || !Number.isFinite(completion)) {
return 0;
if (Number.isNaN(completion) || !Number.isFinite(completion) || !width) {
return -1_000;
}
const output = (1 - completion) * -1 * width;
@@ -29,6 +29,7 @@ export function calculateProgressTranslation(
return output;
}
// Progress track did not show up on Lyrics screen if min height is not set
export const ProgressTrackContainer = styled.View`
overflow: hidden;
height: 5px;
@@ -37,6 +38,7 @@ export const ProgressTrackContainer = styled.View`
align-items: center;
position: relative;
border-radius: 6px;
min-height: 5px;
`;
export interface ProgressTrackProps {

View File

@@ -1,12 +1,12 @@
{
"play-album": "Пусни албум",
"track": "Песен",
"jellyfin-user-id": "Jellyfin потребител",
"user-id": "Jellyfin потребител",
"play-playlist": "Пусни списък",
"color-scheme-system": "Система",
"streaming": "Предава се поточно",
"download-album": "Изтегли албум",
"jellyfin-access-token": "Jellyfin Жетон за достъп (access token)",
"access-token": "Jellyfin Жетон за достъп (access token)",
"delete-playlist": "Изтрий списък",
"add-to-queue": "Добави към опашката",
"playback-reporting": "Докладване на изпълненията",
@@ -16,7 +16,7 @@
"no-results": "Няма резултати…",
"total-duration": "Обща продължителност",
"error-reporting": "Доклаване на грешки",
"jellyfin-server-url": "Адрес на Jellyfin сървър",
"server-url": "Адрес на Jellyfin сървър",
"downloads": "Изтеглени",
"onboarding-cta": "За да започнете Ви трябва Jellyfin сървър. Натиснете бутона отдолу, за да въведете адресът на вашия Jellyfin сървър и се впишете в него.",
"shuffle-album": "Разбъркай албум",
@@ -26,7 +26,7 @@
"artists": "Изпълнители",
"queue": "Опашка",
"error-reporting-description": "Докато използвате приложението, може да срещнете грешки. Докладването на тези грешки помага на програмата да стане по-сигурна и стабилна.",
"set-jellyfin-server": "Настройте Jellyfin сървър",
"set-server": "Настройте Jellyfin сървър",
"similar-albums": "Подобни албуми",
"albums": "Албуми",
"why-use-tracking-description": "Проследяването помага да се ускори процесът по разработка на приложението, като се докладват странни гранични случаи и недоглеждания. Това помага на приложението да стане по стабилно и приятно за използване от всички.",
@@ -52,7 +52,7 @@
"disable": "Изключи",
"search": "Търси",
"download-playlist": "Изтегли списък",
"jellyfin-library": "Jellyfin Библиотека",
"library": "Jellyfin Библиотека",
"enable-error-reporting": "Желаете ли да пуснете докладването на грешки?",
"color-scheme-description": "По подразбиране Fintunes ще следва цветовата схмена на вашата операционна система. Вие обаче можете да изберете Fintunes да се показва винаги в тъмен или светъл режим.",
"color-scheme": "Цветова схема",
@@ -66,7 +66,7 @@
"setting-cache": "Кеш",
"local-playback": "Локално изпълняване",
"clear-queue": "Изчисти опашката",
"set-jellyfin-server-instruction": "Моля въведете адресът на вашия Jellyfin сървър. Трябва да включва протоколът и порта",
"set-server-instruction": "Моля въведете адресът на вашия Jellyfin сървър. Трябва да включва протоколът и порта",
"delete-all-tracks": "Изтрий всички песни",
"where-is-data-stored": "Къде се пазят данните?",
"color-scheme-light": "Светъл режим",
@@ -74,5 +74,8 @@
"sleep-timer": "Таймер за заспиване",
"confirm-delete-all-tracks": "Сигурни ли сте, че искате да изтриете всички текущо изтеглени песни?",
"cancel": "Отказ",
"delete": "Изтрий"
"delete": "Изтрий",
"disc": "диск",
"lyrics": "Текст на песен",
"kbps": "kbps"
}

View File

@@ -26,7 +26,7 @@
"streaming": "Transmissió",
"total-duration": "Durada total",
"similar-albums": "Àlbums similars",
"playback-reporting-description": "Amb Playback Reporting, tots els vostres esdeveniments de reproducció es retransmeten a Jellyfin. Aquest lloc web utilitza galetes per millorar la vostra experiència. Podeu desactivar-lo si ho voleu. Accepto Més informació.",
"playback-reporting-description": "Amb Playback Reporting, tots els vostres esdeveniments de reproducció es retransmeten al vostre servidor. Aquest lloc web utilitza galetes per millorar la vostra experiència. Podeu desactivar-lo si ho voleu. Accepto Més informació.",
"color-scheme": "Aspecte",
"color-scheme-description": "Per defecte, Fintunes farà servir l'aspecte del vostre sistema operatiu. Tanmateix, podeu optar per anul·lar-ho i així assegurar-vos que Fintunes estigui sempre en mode fosc o en mode clar.",
"color-scheme-system": "Sistema",
@@ -51,22 +51,22 @@
"now-playing": "Reproduïnt Ara",
"onboarding-welcome": "Benvinguts!",
"onboarding-intro": "Fintunes us permetrà reproduir la vostra biblioteca de música des de qualsevol lloc, amb total suport per a l'àudio en segon pla i l'enviament del so a altres dispositius.",
"onboarding-cta": "Per començar, necessiteu un servidor de Jellyfin. Si us plau, introdueix dins de la caixa de text els caràcters que veu a la imatge de sota. Això és requerit per evitar enviaments automàtics.",
"set-jellyfin-server": "Configura el servidor Jellyfin",
"set-jellyfin-server-instruction": "Introduïu l'URL del vostre servidor Jellyfin. Assegureu-vos d'incloure el protocol i el port",
"onboarding-cta": "Per començar, necessiteu un servidor de Jellyfin (o Emby). Si us plau, introdueix dins de la caixa de text els caràcters que veu a la imatge de sota. Això és requerit per evitar enviaments automàtics.",
"set-server": "Configura el servidor Jellyfin",
"set-server-instruction": "Introduïu l'URL del vostre servidor Jellyfin. Assegureu-vos d'incloure el protocol i el port",
"settings": "Configuració",
"jellyfin-library": "Biblioteca Jellyfin",
"jellyfin-server-url": "Preguntes Freqüents - FAQ",
"jellyfin-access-token": "Jellyfin Access Token",
"jellyfin-user-id": "Jellyfin User ID",
"library": "Biblioteca Jellyfin",
"server-url": "Preguntes Freqüents - FAQ",
"access-token": "Jellyfin Access Token",
"user-id": "Jellyfin User ID",
"setting-cache": "Caché",
"setting-cache-description": "Si heu actualitzat la vostra biblioteca de Jellyfin, però laplicació està subjectant a actius amagats, podeu esborrar la memòria cau amb aquest botó. Això obligarà laplicació a fer una cerca de la biblioteca des de zero.",
"setting-cache-description": "Si heu actualitzat la vostra biblioteca, però laplicació està subjectant a actius amagats, podeu esborrar la memòria cau amb aquest botó. Això obligarà laplicació a fer una cerca de la biblioteca des de zero.",
"recent-albums": "Afegit Recentment",
"error-reporting": "Informe d'errors",
"error-reporting-description": "Durant l'ús d'aquesta aplicació, es poden trobar errors. Lestudi daquests errors ajuda a crear una experiència daplicació més segura i estable.",
"error-reporting-rationale": "Quan activeu els informes d'errors, cada vegada que es produeix un error, es crea i s'envia automàticament a un servidor, juntament amb informació útil de depuració, com ara dispositius, versions i l'error específic.",
"error-reporting-description": "Durant l'ús d'aquesta aplicació, es poden trobar errors. Laplicació és més segura i estable.",
"error-reporting-rationale": "Quan activeu els informes d'errors, cada vegada que es produeix un error, es crea i s'envia automàticament a un servidor, juntament amb informació útil de depuració com ara dispositius, versions i l'error específic.",
"why-use-tracking": "Per què utilitzar el seguiment?",
"why-use-tracking-description": "El seguiment ajuda a accelerar el desenvolupament d'aquesta aplicació mitjançant l'informe de casos de vora estranys i oversights. Això ajuda a fer que laplicació sigui més estable i robusta, millorant així lexperiència de laplicació per a tothom.",
"why-use-tracking-description": "El seguiment ajuda a accelerar el desenvolupament d'aquesta aplicació mitjançant la presentació de casos de vora estranys i oversights. Això ajuda a fer que l'aplicació sigui més estable i robusta, millorant així l'experiència de l'aplicació per a tothom.",
"what-data-is-gathered": "Quines dades es recullen?",
"what-data-is-gathered-description": "Registrem l'error, el tipus de dispositiu, la versió del sistema operatiu, la versió de l'aplicació i l'identificador del dispositiu. No s'envia cap estat de l'aplicació en cap informe d'errors. L'identificador del dispositiu és un hash únic que es pot restablir a la configuració del dispositiu i no podem deduir cap informació personal d'aquest identificador.",
"where-is-data-stored": "On semmagatzemen les dades?",
@@ -74,5 +74,11 @@
"sleep-timer": "Temporitzador son",
"confirm-delete-all-tracks": "Estàs segur que vols eliminar totes les pistes descarregades actualment?",
"delete": "Esborrar",
"cancel": "Cancel·lar"
"cancel": "Cancel·lar",
"disc": "Disc",
"lyrics": "Lletra",
"khz": "k Hz",
"direct-play": "Joc directe",
"transcoded": "Transcodificat",
"kbps": "kbps"
}

View File

@@ -1,12 +1,12 @@
{
"play-album": "Přehrát Album",
"track": "Skladba",
"jellyfin-user-id": "ID uživatele Jellyfin",
"user-id": "ID uživatele Jellyfin",
"play-playlist": "Přehrát seznam skladeb",
"color-scheme-system": "Systém",
"streaming": "Streamování",
"download-album": "Stáhnout Album",
"jellyfin-access-token": "Přístupový token Jellyfin",
"access-token": "Přístupový token Jellyfin",
"delete-playlist": "Smazat seznam skladeb",
"add-to-queue": "Přidat do Fronty",
"playback-reporting": "Hlášení o přehrávání",
@@ -16,9 +16,9 @@
"no-results": "Žádné výsledky…",
"total-duration": "Celková doba trvání",
"error-reporting": "Hlášení chyb",
"jellyfin-server-url": "Adresa URL serveru Jellyfin",
"server-url": "Adresa URL serveru Jellyfin",
"downloads": "Ke stažení",
"onboarding-cta": "Abyste mohli začít, potřebujete server Jellyfin. Kliknutím na tlačítko níže zadejte adresu svého serveru Jellyfin a přihlaste se k němu.",
"onboarding-cta": "Chcete-li začít, potřebujete server Jellyfin (nebo Emby). Kliknutím na tlačítko níže zadejte adresu serveru a přihlaste se k němu.",
"shuffle-album": "Zamíchat album",
"total-download-size": "Celková velikost pro stažení",
"play-next": "Přehrát Další",
@@ -26,10 +26,10 @@
"artists": "Umělci",
"queue": "Fronta",
"error-reporting-description": "Během používání této aplikace můžete narazit na chyby. Nahlášení těchto chyb pomáhá vytvářet bezpečnější a stabilnější prostředí aplikace.",
"set-jellyfin-server": "Nastavit Jellyfin Server",
"set-server": "Nastavit Jellyfin Server",
"similar-albums": "Podobná alba",
"albums": "Alba",
"why-use-tracking-description": "Sledování pomáhá urychlit vývoj pro tuto aplikaci tím, že nahlásí divné případy hran a dohledy. To pomáhá, aby aplikace stabilnější a robustní, čímž zlepšuje zážitek z aplikace pro každého.",
"why-use-tracking-description": "Sledování pomáhá urychlit vývoj to aplikace hlášením podivných okrajových chyb a přehlédnutí. To pomáhá, aby byla aplikace stabilnější a robustnější, a tím se zlepšuje zážitek z aplikace pro každého.",
"onboarding-welcome": "Vítejte!",
"reset-cache": "Resetovat mezipaměť",
"album": "Album",
@@ -52,21 +52,21 @@
"disable": "Zakázat",
"search": "Vyhledat",
"download-playlist": "Stáhnnout seznam skladeb",
"jellyfin-library": "Knihovna Jellyfin",
"library": "Knihovna Jellyfin",
"enable-error-reporting": "Chcete povolit hlášení chyb?",
"color-scheme-description": "Ve výchozím nastavení bude Fintunes sledovat barevné schéma vašeho operačního systému. Můžete se však rozhodnout toto nastavení změnit, abyste zajistili, že Fintunes bude vždy v tmavém nebo světlém režimu.",
"color-scheme": "Barevné Schéma",
"color-scheme-dark": "Tmavý Režim",
"more-info": "Více informací",
"settings": "Nastavení",
"playback-reporting-description": "S hlášením o přehrávání jsou všechny vaše události přehrávání přenášeny zpět do Jellyfin. To vám umožní sledovat vaše nejposlouchanější skladby, zejména pomocí pluginů Jellyfin, jako je ListenBrainz.",
"playback-reporting-description": "S Playback Reporting, všechny vaše herní události jsou relé zpět do vašeho serveru. To vám umožní sledovat vaše nejvíce poslouchané písně, zejména s pluginy, jako je například Poslechy nebo LastFM.",
"what-data-is-gathered": "Jaká data se shromažďují?",
"all-albums": "Všechny Alba",
"onboarding-intro": "Fintunes vám umožní streamovat svou hudební knihovnu odkudkoli, s plnou podporou pro zvuk na pozadí a odlévání.",
"setting-cache": "Mezipaměť",
"local-playback": "Místní přehrávání",
"clear-queue": "Vymazat Frontu",
"set-jellyfin-server-instruction": "Zadejte adresu URL serveru Jellyfin. Nezapomeňte uvést protokol a port",
"set-server-instruction": "Zadejte adresu URL serveru Jellyfin. Nezapomeňte uvést protokol a port",
"delete-all-tracks": "Smazat Všechny Skladby",
"where-is-data-stored": "Kde jsou data uložena?",
"color-scheme-light": "Světlý Režim",
@@ -74,5 +74,11 @@
"sleep-timer": "Časovač spánku",
"confirm-delete-all-tracks": "Přejete si skutečně odstranit všechny stažené skladby?",
"delete": "Čeština",
"cancel": "Hledat"
"cancel": "Hledat",
"disc": "Čeština",
"lyrics": "Text skladby",
"direct-play": "Přímé hraní",
"transcoded": "Transcoded",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -3,7 +3,7 @@
"error-reporting": "Fejlrapportering",
"music": "Musik",
"album": "Album",
"jellyfin-server-url": "Jellyfin server URL",
"server-url": "Jellyfin server URL",
"setting-cache": "Cache",
"reset-cache": "Nulstil cache",
"enable": "Aktivér",
@@ -31,48 +31,54 @@
"play-album": "Afspil album",
"queue": "Kø",
"add-to-queue": "Tilføj til kø",
"jellyfin-library": "Jellyfin bibliotek",
"jellyfin-user-id": "Jellyfin bruger ID",
"library": "Jellyfin bibliotek",
"user-id": "Jellyfin bruger ID",
"recent-albums": "Seneste albummer",
"clear-queue": "Ryd kø",
"no-results": "Ingen resultater…",
"set-jellyfin-server": "Sæt Jellyfin Server",
"set-server": "Sæt Jellyfin Server",
"why-use-tracking": "Hvorfor bruge sporing?",
"what-data-is-gathered": "Hvilke data indsamles?",
"where-is-data-stored": "Hvor gemmes data?",
"where-is-data-stored": "Fintunes giver dig mulighed for at streame dit musikbibliotek overalt, med fuld støtte til baggrundslyd og støbning.",
"enable-error-reporting": "Vil du aktivere fejlrapportering?",
"playlists": "Spillelister",
"playlist": "Spilleliste",
"playlist": "Playlist",
"play-playlist": "Playlist",
"shuffle-playlist": "Shuffle Playlist",
"streaming": "Streaming",
"playback-reporting": "Tilbagemeldingsrapportering",
"color-scheme": "Farveskema",
"color-scheme": "Farvesammensætninger",
"color-scheme-system": "Systemsystem",
"why-use-tracking-description": "Tracing hjælper med at fremskynde udviklingen for denne app ved at rapportere underlige kantsager og tilsyn. Dette hjælper med at gøre appen mere stabil og robust og dermed forbedre appoplevelsen for alle.",
"sleep-timer": "Søvn timer",
"onboarding-intro": "Fineunes giver dig mulighed for at streame dit musikbibliotek overalt, med fuld støtte til baggrundslyd og støbning.",
"onboarding-cta": "For at komme i gang skal du bruge en Jellyfin server. Klik på knappen nedenfor for at indtaste din Jellyfin server adresse og logge ind på den.",
"set-jellyfin-server-instruction": "Indtast venligst din Jellyfin server URL. Sørg for at inkludere protokollen og havnen",
"jellyfin-access-token": "Jellyfin Access Token",
"setting-cache-description": "Hvis du har opdateret dit Jellyfin-bibliotek, men appen holder på cachelagrede aktiver, kan du tvinges til at rydde cachen ved hjælp af denne knap. Dette vil tvinge app til at hente biblioteket fra bunden.",
"onboarding-intro": "Fintunes giver dig mulighed for at streame dit musikbibliotek overalt, med fuld støtte til baggrundslyd og støbning.",
"onboarding-cta": "For at komme i gang skal du bruge en Jellyfin (eller Emby) server. Klik på knappen nedenfor for at indtaste din serveradresse og logge ind på den.",
"set-server-instruction": "Indtast venligst din Jellyfin server URL. Sørg for at inkludere protokollen og havnen",
"access-token": "Jellyfin Access Token",
"setting-cache-description": "Hvis du har opdateret dit bibliotek, men appen holder på cachelagrede aktiver, kan du tvinges til at rydde cachen ved hjælp af denne knap. Dette vil tvinge app til at hente biblioteket fra bunden.",
"error-reporting-description": "Under brug af denne app, kan du støde fejl. Rapportering af disse fejl hjælper med at skabe en mere sikker og stabil appoplevelse.",
"error-reporting-rationale": "Når du aktiverer fejlrapportering, hver gang en fejl opstår, oprettes en rapport automatisk og sendes til en server, sammen med nyttige fejlfindingsoplysninger såsom enheder, versioner og den specifikke fejl.",
"what-data-is-gathered-description": "Vi logger fejlen, enhedstype, OS-version, app-version og enhed id. Ingen ansøgningstilstand sendes i enhver fejlrapportering. Enheden id er et unikt hash, der kan nulstilles i dine enhedsindstillinger, og vi kan ikke deducere personlige oplysninger fra denne identifikator.",
"where-is-data-stored-description": "Sentry backend er selv-hosted på vores egen infrastruktur. Ingen, men vi har adgang til servere, databaser, ansøgning og dataloger, mindst af alle Sentry personale. infrastrukturen hostes i Den Europæiske Union.",
"downloads": "Downloads",
"download-track": "Download Track",
"download-track": "Annuller",
"download-album": "Download Album",
"download-playlist": "Download Playlist",
"no-downloads": "Du har endnu ikke downloadet nogen spor",
"delete-playlist": "Slet Playlist",
"total-download-size": "Samlet download Størrelse Størrelse Størrelse",
"total-download-size": "Samlet download Størrelse Størrelse Størrelse Størrelse",
"retry-failed-downloads": "Detaljerede downloads",
"you-are-offline-message": "Du er i øjeblikket offline. Du kan kun afspille tidligere downloadet musik.",
"playing-on": "At spille på",
"playback-reporting-description": "Med Playback Reporting bliver alle dine afspilningsbegivenheder sendt tilbage til Jellyfin. Dette giver dig mulighed for at spore dine mest lyttede sange, især med Jellyfin plugins såsom LytBrainz.",
"playback-reporting-description": "Med Playback Reporting bliver alle dine afspilningsbegivenheder sendt tilbage til din server. Dette giver dig mulighed for at spore dine mest lyttede sange, især med plugins såsom LytBrainz eller LastFM.",
"color-scheme-description": "Som standard vil Fineunes følge dit operativsystems farveordning. Du kan dog vælge at tilsidesætte dette for at sikre, at Fineunes altid er i mørk tilstand eller lystilstand.",
"delete": "Slet",
"cancel": "Annuller",
"confirm-delete-all-tracks": "Er du sikker på, at du vil slette alle aktuelt downloadede spor?"
"confirm-delete-all-tracks": "Er du sikker på, at du vil slette alle aktuelt downloadede spor?",
"disc": "Disk",
"lyrics": "Sangtekster",
"direct-play": "Direkte spil",
"transcoded": "Transkode",
"kbps": "kbps",
"khz": "kHz"
}

View File

@@ -1,7 +1,7 @@
{
"onboarding-welcome": "Willkommen!",
"settings": "Einstellungen",
"jellyfin-library": "Jellyfin-Bibliothek",
"library": "Jellyfin-Bibliothek",
"more-info": "Mehr Informationen",
"track": "Titel",
"playlists": "Wiedergabelisten",
@@ -14,7 +14,7 @@
"color-scheme-dark": "Dunkler-Modus",
"artists": "Künstler",
"privacy-policy": "Datenschutz-Bestimmungen",
"play-next": "Nächste Wiedergabe",
"play-next": "Als nächstes abspielen",
"play-album": "Album abspielen",
"queue": "Warteschlange",
"add-to-queue": "Zur Warteschlange hinzufügen",
@@ -27,21 +27,21 @@
"music": "Musik",
"now-playing": "Läuft gerade",
"onboarding-intro": "Mit Fintunes können Sie Ihre Musikbibliothek von überall aus streamen, mit voller Unterstützung für Hintergrundwiedergabe und Casting.",
"onboarding-cta": "Um loslegen zu können benötigen Sie einen Jellyfin Server. Klicken Sie auf den Button und geben Sie ihre Jellyfin Serveradresse und Logindaten ein.",
"set-jellyfin-server": "Legen Sie den Jellyfin-Server fest",
"set-jellyfin-server-instruction": "Bitte geben Sie die URL Ihres Jellyfin-Servers ein. Stellen Sie sicher, dass Sie das Protokoll und den Port angeben",
"jellyfin-server-url": "Jellyfin-Server-URL",
"jellyfin-access-token": "Jellyfin-Zugriffstoken",
"jellyfin-user-id": "Jellyfin-Benutzer-ID",
"onboarding-cta": "Um loslegen zu können, benötigen Sie einen Jellyfin (oder Emby) Server. Klicken Sie auf die Schaltfläche unten, um Ihre Serveradresse einzugeben und sich anzumelden.",
"set-server": "Legen Sie den Jellyfin-Server fest",
"set-server-instruction": "Bitte geben Sie die URL Ihres Jellyfin-Servers ein. Stellen Sie sicher, dass Sie das Protokoll und den Port angeben",
"server-url": "Jellyfin-Server-URL",
"access-token": "Jellyfin-Zugriffstoken",
"user-id": "Jellyfin-Benutzer-ID",
"setting-cache": "Zwischenspeicher",
"setting-cache-description": "Wenn Sie Ihre Jellyfin-Bibliothek aktualisiert haben, aber weiterhin zwischengespeicherte Elemente angezeigt werden kann man mit diesen Button erzwingen, den Zwischenspeicher vollständig zu leeren. Dies zwingt die App Ihre Bibliothek vollständig neu abzurufen.",
"setting-cache-description": "Wenn Sie Ihre Bibliothek aktualisiert haben, die App aber an zwischengespeicherten Inhalten festhält, können Sie den Pufferspeicher mit dieser Schaltfläche zwangsweise löschen. Dies zwingt die App, Ihre Bibliothek vollständig neu abzurufen.",
"reset-cache": "Zwischenspeicher zurücksetzen",
"recent-albums": "Aktuelle Alben",
"error-reporting": "Fehler melden",
"error-reporting-description": "Bei der Nutzung dieser App können Fehler auftreten. Das Melden dieser Fehler trägt dazu bei, ein sichereres und stabileres App-Erlebnis zu schaffen.",
"error-reporting-rationale": "Wenn Sie die Fehlerberichterstattung aktivieren, wird jedes Mal, wenn ein Fehler auftritt, automatisch ein Bericht erstellt und an einen Server gesendet, zusammen mit hilfreichen Debugging-Informationen wie Geräte, Versionen und der spezifische Fehler.",
"why-use-tracking": "Warum werden Tracker verwendet?",
"why-use-tracking-description": "Die Verfolgung hilft, die Entwicklung für diese App zu beschleunigen, indem sie seltsame Randfälle und Aufsichten meldet. Dies hilft, die App stabiler und robuster zu machen und so das App-Erlebnis für jeden zu verbessern.",
"why-use-tracking-description": "Tracer helfen, die Entwicklung dieser App zu beschleunigen, indem merkwürdige Sonderfälle oder übersehende Fehler direkt an uns gemeldet werden können. Dies hilft uns die App für alle zu verbessern.",
"what-data-is-gathered": "Welche Daten werden gesammelt?",
"what-data-is-gathered-description": "Wir protokollieren den Fehler, den Gerätetyp, die Betriebssystemversion, die App-Version und die Geräte-ID. In den Fehlerberichten wird kein Anwendungsstatus gesendet. Die Geräte-ID ist ein eindeutiger Hash, der in Ihren Geräteeinstellungen zurückgesetzt werden kann, und wir können aus dieser Kennung keine persönlichen Informationen ableiten.",
"where-is-data-stored": "Wo werden die Daten gespeichert?",
@@ -69,10 +69,16 @@
"total-duration": "Gesamtdauer",
"similar-albums": "Ähnliche Alben",
"playback-reporting": "Wiedergabeberichte",
"playback-reporting-description": "Mit Wiedergabeberichte werden alle Ihre Wiedergabeereignisse zurück an Jellyfin weitergeleitet. Auf diese Weise können Sie Ihre am häufigsten gehörten Songs verfolgen, insbesondere mit Jellyfin-Plugins wie ListenBrainz.",
"playback-reporting-description": "Mit der Wiedergabeberichterstattung werden alle Ihre Wiedergabeereignisse an Ihren Server zurückgesendet. So können Sie Ihre meistgehörten Songs verfolgen, insbesondere mit Plugins wie ListenBrainz oder LastFM.",
"color-scheme": "Farbschema",
"sleep-timer": "Schlafdauer",
"sleep-timer": "Schlummerfunktion",
"confirm-delete-all-tracks": "Sind Sie sicher, dass Sie alle aktuell heruntergeladenen Titel löschen möchten?",
"delete": "Löschen",
"cancel": "Abbrechen"
"cancel": "Abbrechen",
"disc": "Scheiben",
"lyrics": "Liedtexte",
"direct-play": "Direkte Wiedergabe",
"transcoded": "Transkodiert",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -13,16 +13,16 @@
"now-playing": "Now Playing",
"onboarding-welcome": "Welcome!",
"onboarding-intro": "Fintunes will allow you to stream your music library from anywhere, with full support for background audio and casting.",
"onboarding-cta": "In order to get started, you need a Jellyfin server. Click the button below to enter your Jellyfin server address and login to it.",
"set-jellyfin-server": "Set Jellyfin Server",
"set-jellyfin-server-instruction": "Please enter your Jellyfin server URL. Make sure to include the protocol and port",
"onboarding-cta": "In order to get started, you need a Jellyfin (or Emby) server. Click the button below to enter your server address and login to it.",
"set-server": "Set Server",
"set-server-instruction": "Please enter your server URL. Make sure to include the protocol and port",
"settings": "Settings",
"jellyfin-library": "Jellyfin Library",
"jellyfin-server-url": "Jellyfin Server URL",
"jellyfin-access-token": "Jellyfin Access Token",
"jellyfin-user-id": "Jellyfin User ID",
"library": "Library",
"server-url": "Server URL",
"access-token": "Access Token",
"user-id": "User ID",
"setting-cache": "Cache",
"setting-cache-description": "If you have updated your Jellyfin library, but the app is holding on to cached assets, you can forcefully clear the cache using this button. This will force the app to fetch the library from scratch.",
"setting-cache-description": "If you have updated your library, but the app is holding on to cached assets, you can forcefully clear the cache using this button. This will force the app to fetch the library from scratch.",
"reset-cache": "Reset Cache",
"recent-albums": "Recent Albums",
"error-reporting": "Error Reporting",
@@ -64,7 +64,7 @@
"total-duration": "Total duration",
"similar-albums": "Similar albums",
"playback-reporting": "Playback Reporting",
"playback-reporting-description": "With Playback Reporting, all your playback events are relayed back to Jellyfin. This allows you to track your most listened songs, particularly with Jellyfin plugins such as ListenBrainz.",
"playback-reporting-description": "With Playback Reporting, all your playback events are relayed back to your server. This allows you to track your most listened songs, particularly with plugins such as ListenBrainz or LastFM.",
"color-scheme": "Color Scheme",
"color-scheme-description": "By default, Fintunes will follow your operating system's color scheme. You can however choose to override this to make sure Fintunes is always in dark mode or light mode.",
"color-scheme-system": "System",
@@ -74,5 +74,11 @@
"privacy-policy": "Privacy Policy",
"sleep-timer": "Sleep timer",
"delete": "Delete",
"cancel": "Cancel"
"cancel": "Cancel",
"disc": "Disc",
"lyrics": "Lyrics",
"direct-play": "Direct play",
"transcoded": "Transcoded",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -13,17 +13,17 @@
"now-playing": "Reproduciendo ahora",
"onboarding-welcome": "Bienvenido!",
"onboarding-intro": "Fintunes te permitirá reproducir tu biblioteca musical desde cualquier sitio, con suporte completo para audio en segundo plano y casteo en otros dispositivos.",
"onboarding-cta": "Para empezar necesitas un servidor de Jellyfin. Pulsa el botón de abajo para introducir la dirección del servidor y autentifícate con tus credenciales.",
"set-jellyfin-server": "Introduce servidor de Jellyfin",
"set-jellyfin-server-instruction": "Por favor introduce la URL de tu servidor de Jellyfin. Acuérdate de incluir protocolo y puerto",
"onboarding-cta": "Para empezar, necesitas un servidor de Jellyfin (o Emby). Haz clic en el botón de abajo para introducir tu dirección de servidor e iniciar sesión.",
"set-server": "Introduce servidor de Jellyfin",
"set-server-instruction": "Por favor introduce la URL de tu servidor de Jellyfin. Acuérdate de incluir protocolo y puerto",
"settings": "Configuración",
"jellyfin-library": "Biblioteca Jellyfin",
"jellyfin-server-url": "Url del servidor Jellyfin",
"jellyfin-access-token": "Token de acceso Jellyfin",
"jellyfin-user-id": "ID de usuario Jellyfin",
"library": "Biblioteca Jellyfin",
"server-url": "Url del servidor Jellyfin",
"access-token": "Token de acceso Jellyfin",
"user-id": "ID de usuario Jellyfin",
"setting-cache": "Caché",
"setting-cache-description": "Si actualizó la biblioteca Jellyfin, pero el software aún muestra el contenido anterior, puede hacer clic en el botón a continuación para forzar una actualización. Esto obligará al software a recuperar la información del servidor.",
"reset-cache": "Resetear Caché",
"setting-cache-description": "Si has actualizado tu biblioteca, pero la aplicación conserva los recursos almacenados en caché, puedes borrar la caché de forma manual con este botón. Esto obligará a la aplicación a recuperar la biblioteca desde cero.",
"reset-cache": "Restablecer caché",
"recent-albums": "Álbumes recientes",
"error-reporting-rationale": "Cuando habilita el informe de errores, cada vez que ocurre un error, se crea y envía automáticamente un informe a un servidor, junto con información útil de depuración, como dispositivos, versiones y el error específico.",
"what-data-is-gathered": "¿Qué datos se recopilan?",
@@ -50,7 +50,7 @@
"playing-on": "Jugando en",
"local-playback": "Reproducción local",
"playback-reporting": "Informes de reproducción",
"playback-reporting-description": "Con los informes de reproducción, todos sus eventos de reproducción se transmiten a Jellyfin. Esto le permite rastrear sus canciones más escuchadas, particularmente con los complementos de Jellyfin como ListenBrainz.",
"playback-reporting-description": "Con Playback Reporting, todos los eventos de reproducción se retransmiten a tu servidor. Esto te permite realizar un seguimiento de las canciones más escuchadas, especialmente con complementos como ListenBrainz o LastFM.",
"color-scheme-description": "De forma predeterminada, Fintunes seguirá el esquema de color de su sistema operativo. Sin embargo, puede optar por anular esto para asegurarse de que Fintunes esté siempre en modo oscuro o en modo claro.",
"color-scheme-light": "Modo de luz",
"why-use-tracking": "¿Por qué usar el seguimiento?",
@@ -72,7 +72,13 @@
"color-scheme-system": "Sistema",
"privacy-policy": "Política de privacidad",
"sleep-timer": "Temporizador",
"confirm-delete-all-tracks": "¿Estás seguro de que quieres eliminar todas las pistas descargadas actualmente?",
"delete": "Suprimir",
"cancel": "Cancelar"
"confirm-delete-all-tracks": "¿Estás seguro de que quieres borrar todas las pistas descargadas actualmente?",
"delete": "Borrar",
"cancel": "Cancelar",
"disc": "Disco",
"lyrics": "Letras",
"direct-play": "Reproducción directa",
"transcoded": "Transcodificar",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -0,0 +1,84 @@
{
"albums": "Albumit",
"album": "Albumi",
"queue": "Jono",
"add-to-queue": "Lisää jonoon",
"clear-queue": "Tyhjennä jono",
"no-results": "Ei tuloksia…",
"play-next": "Toista seuraava",
"play-album": "Toista albumi",
"all-albums": "Kaikki albumit",
"search": "Etsi",
"sleep-timer": "Uniajastin",
"delete": "Poista",
"cancel": "Peruuta",
"disc": "Levy",
"lyrics": "Sanoitukset",
"khz": "kHz",
"kbps": "kbps",
"music": "Musiikki",
"now-playing": "Nyt soitetaan",
"onboarding-welcome": "Tervetuloa!",
"settings": "Asetukset",
"library": "Kirjasto",
"server-url": "Palvelimen URL-osoite",
"access-token": "Access Token",
"user-id": "Käyttäjätunnus",
"setting-cache": "Välimuisti",
"enable": "Ota käyttöön",
"disable": "Poista käytöstä",
"more-info": "Lisätietoja",
"track": "Kappale",
"playlists": "Soittolistat",
"playlist": "Soittolista",
"shuffle-playlist": "Sekoita soittolista",
"downloads": "Lataukset",
"delete-track": "Poista kappale",
"delete-playlist": "Poista soittolista",
"total-duration": "Kesto yhteensä",
"color-scheme": "Ulkoasu",
"color-scheme-system": "Järjestelmä",
"color-scheme-light": "Vaalea tila",
"color-scheme-dark": "Tumma tila",
"artists": "Artistit",
"privacy-policy": "Yksityisyydensuoja",
"why-use-tracking": "Miksi käyttää seurantaa?",
"what-data-is-gathered": "Mitä tietoja kerätään?",
"where-is-data-stored": "Missä tietoja säilytetään?",
"direct-play": "Toista heti",
"transcoded": "Transkoodattu",
"onboarding-intro": "Fintunesin avulla voit striimata musiikkia kirjastostasi missä tahansa. Tukee täysin tausta- ja suoratoistoa.",
"onboarding-cta": "Tarvitset Jellyfin (tai Emby) -palvelimen aloittaaksesi. Klikkaa alla olevaa painiketta syöttääksesi palvelinosoitteesi ja kirjautuaksesi siihen.",
"set-server": "Aseta palvelin",
"set-server-instruction": "Ole hyvä ja syötä palvelimesi URL-osoite ja lisää protokolla sekä portti",
"setting-cache-description": "Voit tyhjentää välimuistin tämän painikkeen avulla, jos sovellus säilyttää välimuistissa olevat tiedot kirjaston päivittämisen jälkeen. Tämä pakottaa sovelluksen hakemaan kirjaston uudelleen.",
"reset-cache": "Aseta välimuisti uudelleen",
"recent-albums": "Viimeaikaiset albumit",
"error-reporting": "Virheiden raportointi",
"error-reporting-description": "Tämän sovelluksen käytön aikana saatat huomata virheitä. Näiden virheiden ilmoittaminen auttaa luomaan turvallisemman ja vakaamman sovelluskokemuksen.",
"error-reporting-rationale": "Virhetilanteista luodaan raportti automaattisesti ja se lähetetään palvelimelle, kun virheiden raportointi on päällä. Raportissa on mukana tietoa laitteeseen, ohjelmaversioon ja virheeseen liittyviä tietoja.",
"why-use-tracking-description": "Seuranta ja virhetapausten raportointi nopeuttaa sovelluksen kehitystyötä. Tämä auttaa tekemään sovelluksesta vakaamman parantaen kaikkien käyttökokemusta.",
"what-data-is-gathered-description": "Kirjaamme lokiin virheen, laitteen tyypin, käyttöjärjestelmän version, sovelluksen version ja laitteen tunnisteen (device id). Virheraportissa ei lähetetä sovelluksen tilatietoja. Laitteen tunniste on yksilöllinen hash, joka voidaan nollata laitteen asetuksissa. Laitteen tunnisteesta ei voi päätellä käyttäjän henkilökohtaisia tietoja.",
"where-is-data-stored-description": "Sentryn taustapalvelinta ylläpidetään itse. Kenelläkään muulla, ei myöskään Sentryn henkilökunnalla, ei ole pääsyä palvelimille, tietokantoihin, sovellus- ja tietolokeihin. Infrastruktuuria ylläpidetään Euroopan Unionin alueella.",
"enable-error-reporting": "Haluatko sallia virheiden raportoinnin?",
"enable-error-reporting-description": "Tämä auttaa parantamaan sovelluskokemusta lähettämällä virheilmoituksia meille.",
"play-playlist": "Toista soittolista",
"shuffle-album": "Sekoita albumi",
"download-track": "Lataa kappale",
"download-album": "Lataa albumi",
"download-playlist": "Lataa soittolista",
"no-downloads": "Et ole vielä ladannut kappaleita",
"delete-all-tracks": "Poista kaikki kappaleet",
"confirm-delete-all-tracks": "Oletko varma, että haluat poistaa kaikki tällä hetkellä ladatut kappaleet?",
"delete-album": "Poista albumi",
"total-download-size": "Latauksen yhteenlaskettu koko",
"retry-failed-downloads": "Lataa epäonnistuneet uudelleen",
"you-are-offline-message": "Olet tällä hetkellä offline-tilassa. Voit toistaa vain aiemmin ladattua musiikkia.",
"playing-on": "Toistaa",
"local-playback": "Paikallinen toisto",
"streaming": "Striimaa",
"similar-albums": "Samanlaisia albumeja",
"playback-reporting": "Toiston raportointi",
"playback-reporting-description": "Toiston raportoinnin avulla kaikki toistotapahtumat palautetaan palvelimellesi. Näin voit seurata eniten kuunneltuja kappaleita, esimerkiksi pluginien, kuten ListenBrainz tai LastFM, avulla.",
"color-scheme-description": "Fintunes noudattaa oletuksena käyttöjärjestelmän ulkoasua. Voit kuitenkin ohittaa tämän varmistaaksesi, että Fintunes on aina tummassa tai vaaleassa tilassa."
}

View File

@@ -1,33 +1,33 @@
{
"play-next": "Lire ensuite",
"play-album": "Jouer l'album",
"play-album": "Lire l'album",
"queue": "File d'attente",
"add-to-queue": "Ajouter à la file d'attente",
"clear-queue": "Vider la file d'attente",
"no-results": "Pas de résultats…",
"no-results": "Aucun résultat…",
"album": "Album",
"albums": "Albums",
"all-albums": "Tous les Albums",
"search": "Rechercher",
"music": "Musique",
"now-playing": "En cours",
"onboarding-welcome": "Bienvenue !",
"onboarding-intro": "Fintunes vous permettra de diffuser votre bibliothèque musicale de n'importe où, avec un support de la lecture en arrière plan et la diffusion à distance.",
"onboarding-cta": "Pour utiliser Fintunes, vous avez besoin d'un serveur Jellyfin. Cliquez sur le bouton ci-dessous pour entrer l'adresse de votre serveur Jellyfin et vous y connecter.",
"set-jellyfin-server": "Configurer le serveur Jellyfin",
"set-jellyfin-server-instruction": "Veuillez entrer l'URL de votre serveur Jellyfin. Assurez-vous d'inclure le protocole et le port",
"onboarding-welcome": "Bienvenue!",
"onboarding-intro": "Fintunes vous permettra de diffuser votre bibliothèque musicale de n'importe où, avec un support de la lecture en arrière-plan et la diffusion à distance.",
"onboarding-cta": "Pour commencer, vous avez besoin d'un serveur Jellyfin (ou Emby). Cliquez sur le bouton ci-dessous pour entrer l'adresse du serveur et vous y connecter.",
"set-server": "Configurer le serveur Jellyfin",
"set-server-instruction": "Veuillez entrer l'URL de votre serveur Jellyfin. Assurez-vous d'inclure le protocole et le port",
"settings": "Réglages",
"jellyfin-library": "Bibliothèque Jellyfin",
"jellyfin-server-url": "URL du serveur Jellyfin",
"jellyfin-access-token": "Jeton d'accès à la Jellyfin",
"jellyfin-user-id": "ID utilisateur Jellyfin",
"library": "Bibliothèque Jellyfin",
"server-url": "URL du serveur Jellyfin",
"access-token": "Jeton d'accès au serveur Jellyfin",
"user-id": "ID utilisateur Jellyfin",
"setting-cache": "Cache",
"setting-cache-description": "Si vous avez mis à jour votre bibliothèque Jellyfin mais que l'application conserve toujours des ressources en cache, vous pouvez vider le cache en utilisant ce bouton. Cela forcera l'application à récupérer lintégralité de bibliothèque.",
"setting-cache-description": "Si vous avez mis à jour votre bibliothèque mais que l'application conserve toujours des ressources en cache, vous pouvez vider le cache en utilisant ce bouton. Cela forcera l'application à récupérer lintégralité de bibliothèque.",
"reset-cache": "Réinitialiser le cache",
"recent-albums": "Albums récents",
"what-data-is-gathered": "Quelles données sont collectées ?",
"error-reporting-rationale": "Lorsque vous activez le rapport d'erreurs, chaque fois qu'une erreur se produit, un rapport est automatiquement créé et envoyé à un serveur, avec des informations de débogage utiles telles que les périphériques, les versions et l'erreur spécifique.",
"why-use-tracking-description": "Le traçage permet d'accélérer le développement de cette application en signalant des cas bizarres et des surveillances. Cela permet de rendre l'application plus stable et robuste, améliorant ainsi l'expérience de l'application pour tous.",
"what-data-is-gathered": "Quelles données sont collectées?",
"error-reporting-rationale": "Lorsque vous activez le rapport d'erreurs, chaque fois qu'une erreur se produit, un rapport est automatiquement créé et envoyé à un serveur, avec des informations de débogage utiles telles que les périphériques, les versions et l'erreur en question.",
"why-use-tracking-description": "Le suivi aide à accélérer le développement de cette application en signalant les cas étranges et les oublis. Ceci contribue à rendre l'application plus stable et plus robuste, augmentant ainsi l'expérience de l'application pour tout le monde.",
"what-data-is-gathered-description": "Nous enregistrons l'erreur, le type d'appareil, la version du système d'exploitation, la version de l'application et l'identifiant de l'appareil. Aucun état d'application n'est envoyé dans les rapports d'erreurs. L'identifiant de l'appareil est un hachage unique qui peut être réinitialisé dans les paramètres de votre appareil, et nous ne pouvons déduire aucune information personnelle de cet identifiant.",
"more-info": "Plus d'informations",
"play-playlist": "Lire la liste de lecture",
@@ -37,16 +37,16 @@
"you-are-offline-message": "Vous êtes actuellement hors ligne. Vous ne pouvez lire que de la musique précédemment téléchargée.",
"similar-albums": "Albums similaires",
"playback-reporting": "Rapport de lecture",
"playback-reporting-description": "Avec Playback Reporting, tous vos évènements de lecture sont relayés vers Jellyfin. Ceci vous permet de suivre vos chansons les plus écoutées, notamment avec les greffons Jellyfin tels que ListenBrainz.",
"color-scheme-description": "Par défaut, Fintunes suivra le schéma de couleurs de votre système d'exploitation. Vous pouvez cependant choisir de remplacer cela pour vous assurer que Fintunes est toujours en mode sombre ou en mode clair.",
"why-use-tracking": "Pourquoi utiliser le suivi ?",
"where-is-data-stored": "Où sont stockées les données ?",
"enable-error-reporting": "Voulez-vous activer le rapport d'erreur ?",
"playback-reporting-description": "Grâce au \"Playback Reporting\", tous les évènements de playback sont relayés à votre serveur. Cela vous permet de retrouver vos chansons les plus écoutées, en particulier avec les plugins de ListenBrainz où LastFM.",
"color-scheme-description": "Par défaut, Fintunes suivra le thème de votre système d'exploitation. Vous pouvez cependant choisir d'imposer ce réglage pour vous assurer que Fintunes reste en mode sombre ou en mode clair.",
"why-use-tracking": "Pourquoi utiliser le suivi?",
"where-is-data-stored": "Où sont stockées les données?",
"enable-error-reporting": "Voulez-vous activer le rapport d'erreur?",
"local-playback": "Lecture locale",
"streaming": "Streaming",
"color-scheme": "Schéma de couleur",
"color-scheme": "Thème",
"color-scheme-system": "Système",
"where-is-data-stored-description": "Le backend Sentry est auto-hébergé sur notre propre infrastructure. Personne d'autre que nous n'a accès aux serveurs, aux bases de données, aux applications et aux journaux de données, et encore moins au personnel de Sentry. L'infrastructure est hébergée dans l'Union européenne.",
"where-is-data-stored-description": "Le backend Sentry est auto-hébergé sur notre propre infrastructure. Personne d'autre que nous n'a accès aux serveurs, aux bases de données, aux applications et aux journaux de données, et encore moins le personnel de Sentry. L'infrastructure est hébergée dans l'Union Européenne.",
"enable-error-reporting-description": "Cela permet d'améliorer l'expérience de l'application en nous envoyant des rapports de plantage et d'erreur.",
"enable": "Activer",
"disable": "Désactiver",
@@ -55,24 +55,30 @@
"download-album": "Télécharger l'album",
"delete-album": "Supprimer l'album",
"delete-playlist": "Supprimer la liste de lecture",
"total-download-size": "Taille totale de téléchargement",
"playing-on": "Jouer sur",
"total-download-size": "Taille totale des téléchargements",
"playing-on": "En lecture sur",
"total-duration": "Durée totale",
"color-scheme-light": "Mode clair",
"color-scheme-dark": "Mode sombre",
"artists": "Artistes",
"download-track": "Télécharger la piste",
"download-track": "Télécharger le morceau",
"download-playlist": "Télécharger la liste de lecture",
"delete-track": "Supprimer la piste",
"delete-all-tracks": "Supprimer toutes les pistes",
"delete-track": "Supprimer le morceau",
"delete-all-tracks": "Supprimer tous les morceaux",
"playlists": "Listes de lecture",
"downloads": "Téléchargements",
"track": "Piste",
"error-reporting-description": "Lors de l'utilisation de cette application, vous pouvez rencontrer des erreurs. Le signalement de ces erreurs aide à créer une expérience d'application plus sécurisée et stable.",
"track": "Morceau",
"error-reporting-description": "Lors de l'utilisation de cette application, vous pouvez rencontrer des erreurs. Le signalement de ces erreurs aide à créer une expérience d'application plus stable et sécurisée.",
"error-reporting": "Rapport d'erreur",
"privacy-policy": "Politique de confidentialité",
"sleep-timer": "Temporaire de sommeil",
"confirm-delete-all-tracks": "Êtes-vous sûr de vouloir supprimer toutes les pistes actuellement téléchargées?",
"sleep-timer": "Minuteur",
"confirm-delete-all-tracks": "Êtes-vous sûr de vouloir supprimer tous les morceaux actuellement téléchargées?",
"delete": "Supprimer",
"cancel": "Annuler"
"cancel": "Annuler",
"disc": "Disque",
"lyrics": "Paroles",
"direct-play": "Lecture directe",
"transcoded": "Converti",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -0,0 +1,84 @@
{
"play-next": "Sitemap",
"play-album": "Login",
"where-is-data-stored": "Hapus Semua Tracks",
"playing-on": "Bermain di",
"direct-play": "Bermain langsung",
"transcoded": "Login",
"khz": "login",
"add-to-queue": "Tambahkan ke Queue",
"clear-queue": "Login",
"onboarding-intro": "Fintunes akan memungkinkan Anda untuk streaming perpustakaan musik Anda dari mana saja, dengan dukungan penuh untuk audio latar belakang dan pengecoran.",
"onboarding-cta": "Untuk memulai, Anda membutuhkan server Jellyfin (atau Emby). Klik tombol di bawah ini untuk memasukkan alamat server dan login ke dalamnya.",
"set-server": "Login",
"set-server-instruction": "Silakan masukkan URL server Anda. Pastikan untuk menyertakan protokol dan port",
"access-token": "Token Akses",
"setting-cache-description": "Jika Anda telah memperbarui perpustakaan Anda, tetapi aplikasi ini memegang aset yang tersimpan, Anda dapat dengan kekuatan menghapus cache menggunakan tombol ini. Ini akan memaksa aplikasi untuk mengambil perpustakaan dari awal.",
"reset-cache": "Login",
"recent-albums": "Album terbaru",
"error-reporting": "Login",
"error-reporting-description": "Selama penggunaan aplikasi ini, Anda dapat menemukan kesalahan. Pelaporan kesalahan ini membantu dalam menciptakan pengalaman aplikasi yang lebih aman dan stabil.",
"error-reporting-rationale": "Ketika Anda mengaktifkan pelaporan kesalahan, setiap kali kesalahan terjadi, laporan secara otomatis diciptakan dan dikirim ke server, bersama dengan informasi debugging yang membantu seperti perangkat, versi dan kesalahan tertentu.",
"why-use-tracking": "Mengapa menggunakan pelacakan?",
"why-use-tracking-description": "Tracing membantu mempercepat pengembangan untuk aplikasi ini dengan melaporkan kasus tepi aneh dan pengawasan. Ini membantu membuat aplikasi lebih stabil dan kuat, sehingga meningkatkan pengalaman aplikasi untuk semua orang.",
"what-data-is-gathered": "Data apa yang dikumpulkan?",
"what-data-is-gathered-description": "Kami mencatat kesalahan, jenis perangkat, versi OS, versi aplikasi dan id perangkat. Tidak ada state aplikasi yang dikirim dalam laporan kesalahan. Perangkat id adalah hash unik yang dapat diatur dalam pengaturan perangkat Anda, dan kami tidak dapat mengurangi informasi pribadi dari pengidentifikasi ini.",
"where-is-data-stored-description": "Login",
"enable-error-reporting": "Apakah Anda ingin mengaktifkan pelaporan kesalahan?",
"enable-error-reporting-description": "Ini membantu meningkatkan pengalaman aplikasi dengan mengirimkan laporan kecelakaan dan kesalahan kepada kami.",
"play-playlist": "Login",
"shuffle-album": "Album di Shuffle",
"download-track": "Unduh Track",
"download-album": "Unduh Album",
"download-playlist": "Unduh Playlist",
"no-downloads": "Mode cahaya",
"delete-all-tracks": "Hapus Semua Tracks",
"confirm-delete-all-tracks": "Apakah Anda yakin Anda ingin menghapus semua trek yang diunduh saat ini?",
"delete-album": "Hapus Album",
"delete-playlist": "Hapus Playlist",
"total-download-size": "Login Login",
"retry-failed-downloads": "Sitemap",
"you-are-offline-message": "Anda saat ini offline. Anda hanya dapat bermain musik yang sebelumnya diunduh.",
"local-playback": "Pemutaran lokal",
"streaming": "Login",
"total-duration": "Total durasi",
"similar-albums": "Album serupa",
"playback-reporting": "Login",
"playback-reporting-description": "Dengan Pelaporan Playback, semua acara pemutaran Anda di relay kembali ke server Anda. Ini memungkinkan Anda untuk melacak lagu-lagu paling didengar Anda, terutama dengan plugin seperti ListenBrainz atau LastFM.",
"color-scheme-description": "Secara default, Fintunes akan mengikuti skema warna sistem operasi Anda. Anda dapat memilih untuk menimpa ini untuk memastikan Fintunes selalu dalam mode gelap atau mode cahaya.",
"color-scheme-light": "Mode cahaya",
"queue": "Antrean",
"disc": "Disk",
"lyrics": "Lirik",
"kbps": "kbps",
"no-results": "Tidak ada hasil",
"album": "Album",
"albums": "Album",
"all-albums": "Semua Album",
"search": "Cari",
"music": "Musik",
"now-playing": "Sekarang Bermain",
"onboarding-welcome": "Selamat Datang!",
"settings": "Pengaturan",
"library": "Perpustakaan",
"server-url": "URL server",
"user-id": "ID Pengguna",
"setting-cache": "Tembolok",
"enable": "Aktifkan",
"disable": "Matikan",
"more-info": "Lebih banyak info",
"track": "Jejak",
"playlists": "Daftar putar",
"playlist": "Daftar Putar",
"shuffle-playlist": "Acak Daftar Putar",
"downloads": "Unduhan",
"delete-track": "Delete Track",
"color-scheme": "Skema Warna",
"color-scheme-system": "Sistem",
"color-scheme-dark": "Modus Gelap",
"artists": "Artis",
"privacy-policy": "Kebijakan Privasi",
"sleep-timer": "Pengatur Waktu Tidur",
"delete": "Hapus",
"cancel": "Batal"
}

View File

@@ -1,5 +1,5 @@
{
"jellyfin-server-url": "URL del Server Jellyfin",
"server-url": "URL del Server Jellyfin",
"settings": "Impostazioni",
"why-use-tracking": "Perché utilizzare il Monitoraggio?",
"streaming": "Streaming",
@@ -22,12 +22,12 @@
"now-playing": "Ora in Riproduzione",
"onboarding-welcome": "Benvenuto!",
"onboarding-intro": "Fintunes ti consentirà di riprodurre in streaming la tua libreria musicale da dove vuoi, con pieno supporto per l'audio di sottofondo e la trasmissione.",
"onboarding-cta": "Per iniziare, hai bisogno di un server Jellyfin. Fai clic sul pulsante in basso per inserire l'indirizzo del tuo server Jellyfin e accedere.",
"set-jellyfin-server": "Imposta il Server Jellyfin",
"set-jellyfin-server-instruction": "Inserisci l'URL del tuo server Jellyfin. Assicurati di includere il protocollo e la porta",
"jellyfin-library": "Libreria Jellyfin",
"jellyfin-access-token": "Token di Accesso Jellyfin",
"jellyfin-user-id": "ID Utente Jellyfin",
"onboarding-cta": "Per iniziare, è necessario un server Jellyfin (o Emby). Fare clic sul pulsante qui sotto per inserire l'indirizzo del server e accedervi.",
"set-server": "Imposta il Server Jellyfin",
"set-server-instruction": "Inserisci l'URL del tuo server Jellyfin. Assicurati di includere il protocollo e la porta",
"library": "Libreria Jellyfin",
"access-token": "Token di Accesso Jellyfin",
"user-id": "ID Utente Jellyfin",
"setting-cache": "Cache",
"setting-cache-description": "Se hai aggiornato la tua libreria Jellyfin, ma l'app trattiene le risorse memorizzate nella cache, puoi forzare la cancellazione della cache utilizzando questo pulsante. Ciò costringerà l'app a recuperare la libreria da zero.",
"reset-cache": "Reimposta Cache",
@@ -35,7 +35,7 @@
"error-reporting": "Segnalazione Errori",
"error-reporting-description": "Durante l'utilizzo di questa app, potresti riscontrare errori. La segnalazione di questi errori ci aiuta a creare un'esperienza dell'app più sicura e stabile.",
"error-reporting-rationale": "Quando abiliti la segnalazione degli errori, ogni volta che si verifica un errore, viene creato automaticamente un rapporto e inviato a un server, insieme a utili informazioni di debug come dispositivi, versioni e l'errore specifico.",
"why-use-tracking-description": "Il tracciamento aiuta a velocizzare lo sviluppo di questa applicazione segnalando strani casi di bordo e sovratensioni. Questo aiuta a rendere l'applicazione più stabile e robusta, migliorando così l'esperienza app per tutti.",
"why-use-tracking-description": "Il monitoraggio aiuta ad accelerare lo sviluppo di questa app segnalando casi strani e sviste. Ciò ci aiuta a rendere l'app più stabile e robusta, aumentando così l'esperienza dell'app per tutti.",
"what-data-is-gathered": "Quali dati vengono raccolti?",
"what-data-is-gathered-description": "Registriamo l'errore, il tipo di dispositivo, la versione del sistema operativo, la versione dell'app e l'ID del dispositivo. Nessuno stato dell'applicazione viene inviato in nessuna segnalazione di errore. L'ID del dispositivo è un hash unico che può essere ripristinato nelle impostazioni del dispositivo e non possiamo dedurre alcuna informazione personale da questo identificatore.",
"where-is-data-stored": "Dove vengono archiviati i dati?",
@@ -68,11 +68,17 @@
"total-duration": "Durata Totale",
"similar-albums": "Album Simili",
"playback-reporting": "Rapporto di Riproduzione",
"playback-reporting-description": "Con il Rapporto di Riproduzione, tutti i tuoi eventi di riproduzione vengono ritrasmessi a Jellyfin. Ciò ti consente di tenere traccia delle tue canzoni più ascoltate, in particolare con i plug-in Jellyfin come ListenBrainz.",
"playback-reporting-description": "Gioco diretto",
"color-scheme-description": "Di default, Fintunes usa il tema colori del tuo sistema operativo. Puoi tuttavia scegliere di sovrascrivere questa impostazione per assicurarti che Fintunes sia sempre in modalità notte o luce.",
"privacy-policy": "Politica sulla riservatezza",
"sleep-timer": "Tempo di sonno",
"delete": "Cancella",
"cancel": "Annulla",
"confirm-delete-all-tracks": "Sei sicuro di voler eliminare tutte le tracce attualmente scaricate?"
"confirm-delete-all-tracks": "Sei sicuro di voler eliminare tutte le tracce attualmente scaricate?",
"disc": "Disc",
"lyrics": "Testi",
"direct-play": "Gioco diretto",
"transcoded": "Transcodifica",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -13,23 +13,23 @@
"now-playing": "再生中",
"onboarding-welcome": "ようこそ。",
"onboarding-intro": "Fintunes は、どこからでも音楽ライブラリをストリーミングすることができます。バックグラウンド・オーディオやキャスティングを完全にサポートします。",
"onboarding-cta": "始めるためには、Jellyfin サーバーが必要です。下のボタンをクリックして、Jellyfin サーバーアドレスを入力しログインしてください。",
"set-jellyfin-server": "Jellyfin サーバ を設定",
"set-jellyfin-server-instruction": "Jellyfin サーバの URL を入力してください。プロトコルとポートを必ず含めてください。",
"onboarding-cta": "起動するには、Jellyfin(または Embyサーバーが必要です。下のボタンをクリックして、サーバーアドレスを入力しログインします。",
"set-server": "Jellyfin サーバ を設定",
"set-server-instruction": "Jellyfin サーバの URL を入力してください。プロトコルとポートを必ず含めてください。",
"settings": "設定",
"jellyfin-library": "Jellyfin ライブライ",
"jellyfin-server-url": "Jellyfin サーバの URL",
"jellyfin-access-token": "Jellyfin アクセストークン",
"jellyfin-user-id": "Jellyfin ユーザ ID",
"library": "Jellyfin ライブライ",
"server-url": "Jellyfin サーバの URL",
"access-token": "Jellyfin アクセストークン",
"user-id": "Jellyfin ユーザ ID",
"setting-cache": "キャッシュ",
"setting-cache-description": "Jellyfinライブラリをアップデートしたにもかかわらず、アプリがキャッシュされたアセットを保持している場合、このボタンを使って強制的にキャッシュをクリアすることができます。これにより、アプリはライブラリを最初から取得するようになります。",
"setting-cache-description": "ライブラリをアップデートしたにもかかわらず、アプリがキャッシュされたアセットを保持している場合、このボタンを使って強制的にキャッシュをクリアすることができます。これにより、アプリはライブラリを最初から取得するようになります。",
"reset-cache": "キャッシュをリセット",
"recent-albums": "最近のアルバム",
"error-reporting": "エラー報告",
"error-reporting-description": "このアプリを使用中に、エラーの可能性があります。これらのエラーを報告することで、よりセキュアで安定したアプリ体験を実現することができます。",
"error-reporting-rationale": "エラーレポートを有効にすると、エラーが発生するたびにレポートが自動的に作成され、デバイス、バージョン、特定のエラーなど、デバッグに役立つ情報とともにサーバーに送信されます。",
"why-use-tracking": "なぜトラッキングを使うか?",
"why-use-tracking-description": "トレンドは、奇妙なエッジケースやオーバーサイトを報告することで、このアプリの開発をスピードアップするのに役立ちます。 これにより、アプリがより安定して堅牢になり、誰もがアプリ体験向上させることができます.",
"why-use-tracking-description": "トレースは、奇妙なエッジケースや見落としを報告することで、このアプリの開発を促進します。これにより、アプリの安定性と堅牢性が向上し、すべてのユーザーのアプリ体験向上ます",
"what-data-is-gathered": "どのデータが集まりますか?",
"what-data-is-gathered-description": "エラー、デバイスタイプ、OSバージョン、アプリバージョン、デバイスIDが記録されます。いかなるエラー報告においても、アプリケーションの状態は送信されません。デバイスIDは、デバイスの設定でリセット可能な一意のハッシュであり、この識別子から個人情報を推測することはできません。",
"where-is-data-stored": "データはどこに保存されていますか?",
@@ -58,7 +58,7 @@
"total-duration": "合計期間",
"similar-albums": "類似のアルバム",
"playback-reporting": "再生レポート",
"playback-reporting-description": "Playback Reporting を使用すると、すべての再生イベントが Jellyfin に中継されます。これにより、特に ListenBrainz などの Jellyfin プラグインを使用して、最もよく聴いている曲を追跡できます。",
"playback-reporting-description": "再生レポートを使用すると、すべての再生した曲がサーバーに中継されます。これにより、ListenBrainzやLastFMなどのプラグインを使用して、最もよく聴かれた曲を追跡することができます。",
"color-scheme-description": "デフォルトでは、Fintunes はオペレーティング システムの配色に従います。ただし、Fintunes が常にダーク モードまたはライト モードであることを確認するために、これをオーバーライドすることを選択できます。",
"color-scheme-light": "ライトモード",
"color-scheme-dark": "ダークモード",
@@ -66,13 +66,19 @@
"color-scheme": "カラースキーム",
"artists": "アーティスト",
"downloads": "ダウンロード",
"no-downloads": "まだトラックをダウンロードしていません",
"no-downloads": "まだ何もダウンロードしていません",
"streaming": "ストリーミング",
"local-playback": "ローカル再生",
"color-scheme-system": "システム",
"privacy-policy": "プライバシーポリシー",
"sleep-timer": "睡眠タイマー",
"confirm-delete-all-tracks": "現在ダウンロードしたすべてのトラックを削除したいですか?",
"sleep-timer": "スリープタイマー",
"confirm-delete-all-tracks": "ダウンロードしたすべてのトラックを削除したいですか?",
"delete": "削除",
"cancel": "キャンセル"
"cancel": "キャンセル",
"disc": "ディスク",
"lyrics": "歌詞",
"direct-play": "ダイレクトプレイ",
"transcoded": "トランスコード",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -26,13 +26,13 @@
"onboarding-welcome": "Velkommen.",
"onboarding-intro": "Fintunes lar deg strømme musikkbiblioteket ditt fra hvor som helst, med full støtte for bakgrunnslyd og casting.",
"onboarding-cta": "For å begynne trenger du en Jellyfin-tjener. Klikk på knappen nedenfor for å angi Jellyfin-tjeneradressen din og logge på den.",
"set-jellyfin-server": "Sett Jellyfin-tjener",
"set-jellyfin-server-instruction": "Skriv inn Jellyfin-tjenerens nettadresse. Sørg for å inkludere protokollen og porten.",
"set-server": "Sett Jellyfin-tjener",
"set-server-instruction": "Skriv inn Jellyfin-tjenerens nettadresse. Sørg for å inkludere protokollen og porten.",
"settings": "Innstillinger",
"jellyfin-library": "Jellyfin-bibliotek",
"jellyfin-server-url": "Jellyfin-tjenernettadresse",
"jellyfin-access-token": "Jellyfin-tilgangssymbol",
"jellyfin-user-id": "Jellyfin-bruker-ID",
"library": "Jellyfin-bibliotek",
"server-url": "Jellyfin-tjenernettadresse",
"access-token": "Jellyfin-tilgangssymbol",
"user-id": "Jellyfin-bruker-ID",
"setting-cache": "Mellomlager",
"setting-cache-description": "Du tømme hurtiglageret med denne knappen hvis du har oppdatert Jellyfin-biblioteket ditt, men programmet holder på hurtiglagrede eiendeler. Dette vil tvinge programmet til å hente biblioteket fra bunnen av.",
"reset-cache": "Tilbakestill hurtiglager",
@@ -74,5 +74,9 @@
"sleep-timer": "Sleep timer",
"delete": "Slett",
"cancel": "Avbryt",
"confirm-delete-all-tracks": "Er du sikker på at du vil slette alle nedlastede spor?"
"confirm-delete-all-tracks": "Er du sikker på at du vil slette alle nedlastede spor?",
"disc": "Plate",
"lyrics": "Sangtekster",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -13,16 +13,16 @@
"now-playing": "Nu spelend",
"onboarding-welcome": "Welkom!",
"onboarding-intro": "Fintunes maakt het mogelijk om van waar dan ook je muziek te streamen, met volledige support voor achtergroundaudio en casting.",
"onboarding-cta": "Om te starten moet je een Jellyfin server hebben. Klik de onderstaande knop om het adres van je Jellyfin server in te vullen en er in te loggen.",
"set-jellyfin-server": "Stel Jellyfin Server in",
"set-jellyfin-server-instruction": "Vul alsjeblieft je Jellyfin server URL in. Voeg ook het protocol en de poort toe",
"onboarding-cta": "Om te beginnen, heb je een Jellyfin (of Emby)-server nodig. Vul je serveradres in om daarop in te loggen.",
"set-server": "Stel server in",
"set-server-instruction": "Vul alsjeblieft je server URL in. Voeg ook het protocol en de poort toe",
"settings": "Instellingen",
"jellyfin-library": "Jellyfin Bibliotheek",
"jellyfin-server-url": "Jellyfin Server URL",
"jellyfin-access-token": "Jellyfin Toegangstoken",
"jellyfin-user-id": "Jellyfin Gebruiker ID",
"library": "Bibliotheek",
"server-url": "Server URL",
"access-token": "Toegangstoken",
"user-id": "Gebruiker ID",
"setting-cache": "Cache",
"setting-cache-description": "Als je Jellyfin bibliotheek geüpdatet hebt, maar de app nog aan elementen uit de cache vasthoudt, kun je de cache geforceerd leegmaken met deze knop. Dit forceert de app om de bibliotheek weer vanaf het begin op te bouwen.",
"setting-cache-description": "Als je jouw Jellyfin bibliotheek geüpdatet hebt, maar de app nog aan elementen uit de cache vasthoudt, kun je de cache geforceerd leegmaken met de knop \"Leeg Cache\". Dit forceert de app om de bibliotheek weer vanaf het begin op te bouwen.",
"reset-cache": "Leeg Cache",
"recent-albums": "Recente Albums",
"error-reporting": "Foutmeldingen Rapporteren",
@@ -63,7 +63,7 @@
"streaming": "Streamen",
"total-duration": "Totale duur",
"similar-albums": "Vergelijkbare albums",
"playback-reporting-description": "Met Playback Reporting worden al uw afspeelgebeurtenissen teruggestuurd naar Jellyfin. Hiermee kunt u uw meest beluisterde nummers volgen, vooral met Jellyfin-plug-ins zoals ListenBrainz.",
"playback-reporting-description": "Met afspeelrapportage, word je luistergeschiedenis doorgegeven aan je server. Hierdoor kun je jouw meest geluisterde liedjes volgen, met plug-ins zoals ListenBrainz of LastFM.",
"color-scheme-description": "Fintunes volgt standaard het kleurenschema van uw besturingssysteem. U kunt er echter voor kiezen om dit te overschrijven om ervoor te zorgen dat Fintunes altijd in de donkere of lichte modus staat.",
"color-scheme": "Kleurenschema",
"artists": "Artiesten",
@@ -74,5 +74,11 @@
"privacy-policy": "Privacybeleid",
"sleep-timer": "Slaaptimer",
"delete": "Verwijder",
"cancel": "Annuleer"
"cancel": "Annuleer",
"disc": "Schijf",
"direct-play": "Direct afgespeeld",
"transcoded": "Getranscodeerd",
"khz": "kHz",
"kbps": "kbps",
"lyrics": "Songtekst"
}

View File

@@ -1,78 +1,84 @@
{
"onboarding-welcome": "Welcome!",
"onboarding-intro": "Fintuny pozwolą ściągać swoją bibliotekę muzyczną z nigdzie, z pełnym wsparciem dla dźwięku i odlewu.",
"set-jellyfin-server": "Set Jellyfin Server (ang.)",
"settings": "Setting",
"reset-cache": "Reset Cache",
"color-scheme-light": "Przełomowy",
"color-scheme-dark": "Dark Mode",
"play-next": "Playować",
"play-album": "Play Album",
"queue": "Queue",
"add-to-queue": "Addd",
"clear-queue": "Clear Queue",
"no-results": "Nie ma rezultatów.",
"album": "Albumy",
"albums": "Album",
"onboarding-welcome": "Witaj!",
"onboarding-intro": "Fintunes umożliwia strumieniowe przesyłanie biblioteki muzycznej z dowolnego miejsca, z pełną obsługą dźwięku w tle i przesyłania.",
"set-server": "Ustaw Serwer Jellyfin",
"settings": "Ustawienia",
"reset-cache": "Zresetuj pamięć podręczną",
"color-scheme-light": "Jasny motyw",
"color-scheme-dark": "Ciemny motyw",
"play-next": "Odtwórz następne",
"play-album": "Odtwórz Album",
"queue": "Kolejka",
"add-to-queue": "Dodaj do kolejki",
"clear-queue": "Wyczyść kolejkę",
"no-results": "Brak wyników",
"album": "Album",
"albums": "Albumy",
"all-albums": "Wszystkie albumy",
"search": "Search",
"music": "Music",
"now-playing": "Teraz grasz",
"onboarding-cta": "Aby rozpocząć pracę, potrzebuje serwera Jellyfin. Click the button below to enter your Jellyfin server address and login to it.",
"set-jellyfin-server-instruction": "Wstęp do serwera Jellyfin URL. Umożliwia to łączenie protokołu i portu",
"jellyfin-library": "Biblioteka Jellyfin",
"jellyfin-server-url": "Jellyfin Server URL",
"jellyfin-access-token": "Jellyfin Access Token (ang.)",
"jellyfin-user-id": "Jellyfin User ID",
"setting-cache": "Kache",
"setting-cache-description": "Jeśli uaktualnisz swoją bibliotekę Jellyfin, ale aplikacja trzymana jest w pamięci podręcznej, możesz wyjaśnić pamięć podręczną używając tego przycisku. Wykorzystuje to aplikację, aby uwolnić bibliotekę z odrzutu.",
"recent-albums": "Recent Album",
"error-reporting": "Error Reporting (ang.)",
"error-reporting-description": "Podczas korzystania z tej aplikacji może poznać błędy. Odnotowując te błędy pomagają stworzyć bardziej bezpieczne i stabilne doświadczenie.",
"error-reporting-rationale": "Kiedy umożliwiasz informację błędów, każdy czas, gdy następuje błąd, automatycznie zostaje stworzony i wysłany do serwera, wraz z pomocnym w debugowaniu informacji takich jak urządzenia, wersje i błąd.",
"why-use-tracking": "Dlaczego użyczasz?",
"why-use-tracking-description": "Tracing pomaga szybko rozwijać się na tę aplikację poprzez sprawdzenie dziwnych przypadków brzegowych i nadzorów. Pomoże to uczynić aplikację bardziej stabilną i solidną, tym samym poprawiając doświadczenie aplikacji dla wszystkich.",
"what-data-is-gathered": "Jakie dane są zebrane?",
"what-data-is-gathered-description": "Wykorzystujemy błąd, typ urządzenia, wersja OS, wersja aplikacji i urządzenie. Żaden z nich nie jest wysyłany w żadnym raporcie. Urządzenie id jest unikalnym hasłem, który może być resetowany w twoich ustawieniach urządzeniem, i nie można wywnioskować żadnych informacji osobistych z tych identyfikatorów.",
"where-is-data-stored": "Gdzie jest przechowywane dane?",
"where-is-data-stored-description": "Sentry backend jest samoprowadzany na własną infrastrukturę. Nikt nie ma dostępu do serwerów, baz danych, aplikacji i logów danych, przynajmniej dla wszystkich pracowników Sentry. Infrastruktura jest organizowana w Unii Europejskiej.",
"enable-error-reporting": "Czy chcesz pozwolić na błędy?",
"enable-error-reporting-description": "Umożliwia to poprawę doświadczenia aplikacji poprzez wysłanie raportów zderzenia i błędów.",
"enable": "Pełny",
"disable": "Dyskretny",
"more-info": "Info",
"track": "Track",
"playlists": "Playlista",
"playlist": "Playlista",
"play-playlist": "Playlista",
"shuffle-album": "Album Shuffle Album",
"shuffle-playlist": "Oficjalna strona Shuffle Play",
"downloads": "Download",
"download-track": "Download Track",
"download-album": "Download Album",
"download-playlist": "Download Playlist",
"no-downloads": "Nie można jeszcze pobrać żadnych utworów",
"delete-track": "Trasa Delete",
"delete-all-tracks": "Delete All Tracks",
"delete-album": "Album Delete",
"delete-playlist": "Delete Playlista",
"total-download-size": "Total Download Size",
"retry-failed-downloads": "Retry Failed Download (ang.)",
"you-are-offline-message": "Obecnie są one offline. Mogą grać tylko wcześniej.",
"playing-on": "Zagrać",
"local-playback": "Local playback",
"streaming": "Streaming (ang.)",
"total-duration": "Czas trwania Totalna",
"similar-albums": "Album",
"playback-reporting": "Playback Reporting",
"playback-reporting-description": "Z Playback Reporting wszystkie wydarzenia z playbacku zostały przekazane Jellyfinowi. Pozwala to na śledzenie najbardziej wysłuchanych piosenek, zwłaszcza z wtyczkami Jellyfin, takimi jak ListenBrainz.",
"color-scheme": "Color Scheme",
"color-scheme-description": "Domyślnie, Fintunes będzie podążał za kolorem systemu operacyjnego. Możesz jednak zdecydować, że Fintunes jest zawsze w trybie ciemnym lub lekkim.",
"search": "Szukaj",
"music": "Muzyka",
"now-playing": "Teraz gra",
"onboarding-cta": "Aby się rozpocząć, potrzebuje serwera Jellyfin (lub Emby). Click the button below to enter your server address and login to it.",
"set-server-instruction": "Wprowadź adres URL serwera Jellyfin. Upewnij się, że podałeś protokół i port",
"library": "Biblioteka Jellyfin",
"server-url": "URL do serwera Jellyfin",
"access-token": "Token dostępowy do Jellyfin",
"user-id": "ID użytkownika Jellyfin",
"setting-cache": "Pamięć podręczna",
"setting-cache-description": "Jeśli zaktualizowałeś bibliotekę Jellyfin, ale aplikacja przechowuje zasoby w pamięci podręcznej, możesz wymusić wyczyszczenie pamięci podręcznej za pomocą tego przycisku. Zmusi to aplikację do pobrania biblioteki od zera.",
"recent-albums": "Ostatnie Albumy",
"error-reporting": "Reportowanie błędów",
"error-reporting-description": "Podczas korzystania z tej aplikacji mogą wystąpić błędy. Zgłaszanie tych błędów pomaga w tworzeniu bezpieczniejszej i stabilniejszej aplikacji.",
"error-reporting-rationale": "Po włączeniu raportowania błędów za każdym razem, gdy wystąpi błąd, raport jest automatycznie tworzony i wysyłany na serwer wraz z pomocnymi informacjami dotyczącymi debugowania, takimi jak urządzenia, wersje i konkretny błąd.",
"why-use-tracking": "Dlaczego warto korzystać z funkcji śledzenia?",
"why-use-tracking-description": "Śledzenie pomaga przyspieszyć rozwój tej aplikacji poprzez zgłaszanie dziwnych przypadków brzegowych i niedopatrzeń. Pomaga to uczynić aplikację bardziej stabilną i solidną, poprawiając w ten sposób wrażenia z korzystania z niej dla wszystkich.",
"what-data-is-gathered": "Jakie dane są zbierane?",
"what-data-is-gathered-description": "Rejestrujemy błąd, typ urządzenia, wersję systemu operacyjnego, wersję aplikacji i identyfikator urządzenia. W raportach o błędach nie jest wysyłany stan aplikacji. Identyfikator urządzenia jest unikalnym skrótem, który można zresetować w ustawieniach urządzenia i nie możemy wywnioskować z niego żadnych danych osobowych.",
"where-is-data-stored": "Gdzie przechowywane dane?",
"where-is-data-stored-description": "Backend Sentry jest hostowany na naszej własnej infrastrukturze. Nikt poza nami nie ma dostępu do serwerów, baz danych, aplikacji i logów danych, a już w szczególności żaden personel Sentry. Infrastruktura jest hostowana na terenie Unii Europejskiej.",
"enable-error-reporting": "Czy chcesz włączyć raportowanie błędów?",
"enable-error-reporting-description": "Pomaga to ulepszyć działanie aplikacji, wysyłając do nas raporty o awariach i błędach.",
"enable": "Włączony",
"disable": "Wyłączony",
"more-info": "Więcej Informacji",
"track": "Utwór",
"playlists": "Listy odtwarzania",
"playlist": "Lista odtwarzania",
"play-playlist": "Odtwórz listę odtwarzania",
"shuffle-album": "Przemieszaj album",
"shuffle-playlist": "Losuj listę odtwarzania",
"downloads": "Pobrane",
"download-track": "Pobrane Utwory",
"download-album": "Pobrane Albumy",
"download-playlist": "Pobrane listy odtwarzania",
"no-downloads": "Nie pobrałeś jeszcze żadnych utworów",
"delete-track": "Usuń utwór",
"delete-all-tracks": "Usuń wszystkie utwory",
"delete-album": "Usuń album",
"delete-playlist": "Usuń listę odtwarzania",
"total-download-size": "Całkowity rozmiar pobierania",
"retry-failed-downloads": "Ponów nieudane pobieranie",
"you-are-offline-message": "Aktualnie jesteś offline. Można odtwarzać tylko wcześniej pobraną muzykę.",
"playing-on": "Gra dalej",
"local-playback": "Odtwarzanie lokalne",
"streaming": "Transmisja strumieniowa",
"total-duration": "Całkowity czas trwania",
"similar-albums": "Podobne albumy",
"playback-reporting": "Raportowanie odtwarzania",
"playback-reporting-description": "Dyrektywa",
"color-scheme": "Schemat kolorów",
"color-scheme-description": "Domyślnie Fintunes będzie stosować się do schematu kolorów Twojego systemu operacyjnego. Możesz jednak pominąć tę opcję, aby mieć pewność, że Fintunes jest zawsze w trybie ciemnym lub jasnym.",
"color-scheme-system": "System",
"artists": "Artysta",
"privacy-policy": "Polityka prywatna",
"sleep-timer": "Sleep timer",
"delete": "Delete",
"cancel": "Cancel",
"confirm-delete-all-tracks": "Czy chcesz usunąć wszystkie aktualne utwory?"
"privacy-policy": "Polityka prywatności",
"sleep-timer": "Timer uśpienia",
"delete": "Usuń",
"cancel": "Anuluj",
"confirm-delete-all-tracks": "Czy na pewno chcesz usunąć wszystkie aktualnie pobrane utwory?",
"disc": "Disc disc",
"lyrics": "Tekst",
"direct-play": "Dyrektywa",
"transcoded": "Transkod",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -23,22 +23,22 @@
"now-playing": "Tocando agora",
"onboarding-welcome": "Boas-vindas!",
"onboarding-intro": "O Fintunes permite a você fazer streaming de sua biblioteca de músicas de qualquer lugar, com suporte total para reprodução de áudio em segundo plano e transmissão de áudio.",
"onboarding-cta": "Para usar o Fintunes, você precisa de um servidor Jellyfin. Clique no botão abaixo para inserir o endereço do servidor Jellyfin e fazer login.",
"set-jellyfin-server": "Configurar o servidor Jellyfin",
"set-jellyfin-server-instruction": "Insira a URL do servidor Jellyfin. Certifique-se de incluir o protocolo e a porta",
"onboarding-cta": "Para começar, você precisa de um servidor Jellyfin (ou Emby). Clique no botão abaixo para inserir o endereço do servidor e iniciá-lo.",
"set-server": "Configurar o servidor Jellyfin",
"set-server-instruction": "Insira a URL do servidor Jellyfin. Certifique-se de incluir o protocolo e a porta",
"settings": "Configurações",
"error-reporting-description": "Durante o uso deste aplicativo, você pode encontrar erros. Relatar esses erros ajuda a criar uma experiência de aplicativo mais segura e estável.",
"error-reporting-rationale": "Quando você ativa o relatório de erros, toda vez que ocorre um erro, um relatório é criado automaticamente e enviado a um servidor, juntamente com informações úteis de depuração, como dispositivos, versões e o erro específico.",
"jellyfin-library": "Biblioteca do Jellyfin",
"jellyfin-server-url": "URL do servidor Jellyfin",
"jellyfin-access-token": "Token de acesso do Jellyfin",
"jellyfin-user-id": "ID de usuário do Jellyfin",
"library": "Biblioteca do Jellyfin",
"server-url": "URL do servidor Jellyfin",
"access-token": "Token de acesso do Jellyfin",
"user-id": "ID de usuário do Jellyfin",
"setting-cache": "Cache",
"setting-cache-description": "Se você atualizou sua biblioteca do Jellyfin, mas o aplicativo continua usando os recursos em cache, você pode forçar a limpeza do cache usando este botão. Isso forçará o aplicativo a recuperar a biblioteca do zero.",
"reset-cache": "Redefinir cache",
"recent-albums": "Álbuns recentes",
"error-reporting": "Relatório de erros",
"why-use-tracking-description": "Tracing ajuda a acelerar o desenvolvimento para este aplicativo, relatando casos de borda estranha e supervisão. Isso ajuda a tornar o aplicativo mais estável e robusto, melhorando assim a experiência do aplicativo para todos.",
"why-use-tracking-description": "O rastreamento de erros ajuda a acelerar o desenvolvimento deste aplicativo, relatando casos raros estranhos e descuidos. Isso ajuda a tornar o aplicativo mais estável e robusto, melhorando assim a experiência do aplicativo para todos.",
"what-data-is-gathered": "Quais dados são coletados?",
"what-data-is-gathered-description": "Registramos o erro, o tipo de dispositivo, a versão do sistema operacional, a versão do aplicativo e a identificação do dispositivo. Nenhum estado do aplicativo é enviado em nenhum relatório de erro. A ID do dispositivo é um hash exclusivo que pode ser redefinido nas configurações do seu dispositivo, e não podemos deduzir nenhuma informação pessoal desse identificador.",
"enable-error-reporting-description": "Isso ajuda a melhorar a experiência do aplicativo, enviando relatórios de falhas e erros para nós.",
@@ -63,7 +63,7 @@
"delete-album": "Excluir álbum",
"delete-playlist": "Excluir playlist",
"total-download-size": "Tamanho total dos downloads",
"playback-reporting-description": "Com o relatório de reprodução, todos os seus eventos de reprodução são retransmitidos para o Jellyfin. Isso permite que você monitore suas músicas mais ouvidas, principalmente com plug-ins do Jellyfin como o ListenBrainz.",
"playback-reporting-description": "Jogo direto",
"color-scheme": "Tema",
"color-scheme-description": "Por padrão, o Fintunes segue o esquema de cores do seu sistema operacional. No entanto, você pode mudar isso, para garantir que o Fintunes fique sempre no modo escuro ou no modo claro.",
"color-scheme-system": "Sistema",
@@ -72,7 +72,13 @@
"artists": "Artistas",
"privacy-policy": "Política de Privacidade",
"sleep-timer": "Temporizador de sono",
"confirm-delete-all-tracks": "Você tem certeza de que deseja excluir todas as faixas atualmente baixadas?",
"confirm-delete-all-tracks": "Tem a certeza de que deseja excluir todas as faixas atualmente baixadas?",
"delete": "Excluir",
"cancel": "Cancelar"
"cancel": "Cancelar",
"disc": "Disco",
"lyrics": "Letras",
"direct-play": "Jogo direto",
"transcoded": "Transcodificado",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -26,14 +26,14 @@
"now-playing": "Сейчас играет",
"onboarding-welcome": "Добро пожаловать!",
"onboarding-intro": "Fintunes позволит вам транслировать вашу музыкальную библиотеку из любого места с полной поддержкой фонового воспроизведения и трансляций.",
"onboarding-cta": "Для начала вам нужен сервер Jellyfin. Нажмите кнопку ниже, чтобы ввести адрес своего сервера Jellyfin и авторизоваться на нем.",
"set-jellyfin-server": "Установить сервер Jellyfin",
"set-jellyfin-server-instruction": "Пожалуйста, введите URL вашего сервера Jellyfin. Обязательно укажите протокол и порт",
"onboarding-cta": "Для начала вам нужен сервер Jellyfin (или Emby). Нажмите на кнопку ниже, чтобы ввести свой адрес сервера и войти в него.",
"set-server": "Установить сервер Jellyfin",
"set-server-instruction": "Пожалуйста, введите URL вашего сервера Jellyfin. Обязательно укажите протокол и порт",
"settings": "Настройки",
"jellyfin-library": "Библиотека Jellyfin",
"jellyfin-server-url": "URL сервера Jellyfin",
"jellyfin-access-token": "Токен доступа Jellyfin",
"jellyfin-user-id": "Идентификатор пользователя Jellyfin",
"library": "Библиотека Jellyfin",
"server-url": "URL сервера Jellyfin",
"access-token": "Токен доступа Jellyfin",
"user-id": "Идентификатор пользователя Jellyfin",
"setting-cache": "Кэш",
"setting-cache-description": "Если вы обновили свою библиотеку Jellyfin, но приложение сохраняет кэшированные ресурсы, вы можете принудительно очистить кэш с помощью этой кнопки. Это заставит приложение обновить библиотеку.",
"reset-cache": "Сбросить кеш",
@@ -42,7 +42,7 @@
"error-reporting-description": "Во время использования этого приложения вы можете столкнуться с ошибками. Сообщение об этих ошибках помогает сделать приложение более безопасным и стабильным.",
"error-reporting-rationale": "Когда вы включаете создание отчетов об ошибках, при каждом возникновении ошибки автоматически создается отчет и отправляется на сервер вместе с полезной отладочной информацией, такой как устройства, версии и конкретная ошибка.",
"why-use-tracking": "Зачем использовать отслеживание?",
"why-use-tracking-description": "Отслеживание помогает ускорить разработку этого приложения, сообщая о странных случаях и надзорах. Это помогает сделать приложение более стабильным и надежным, тем самым улучшая опыт приложений для всех.",
"why-use-tracking-description": "Отслеживание помогает ускорить разработку этого приложения, сообщая о странных случаях и упущениях. Это помогает сделать приложение более стабильным и надежным, тем самым повышая удобство работы с приложением для всех.",
"what-data-is-gathered": "Какие данные собираются?",
"what-data-is-gathered-description": "Мы собираем ошибки, тип устройства, версию ОС, версию приложения и идентификатор устройства. Ни в одном отчете об ошибках не передается состояние приложения. Идентификатор устройства - это уникальный хэш, который можно сбросить в настройках вашего устройства, и мы не можем извлечь какую-либо личную информацию из этого идентификатора.",
"where-is-data-stored": "Где хранятся данные?",
@@ -63,7 +63,7 @@
"total-duration": "Общая продолжительность",
"similar-albums": "Похожие альбомы",
"playback-reporting": "Отчет о воспроизведении",
"playback-reporting-description": "С помощью отчетов о воспроизведении все ваши события воспроизведения передаются обратно в Jellyfin. Это позволяет вам отслеживать ваши наиболее прослушиваемые песни, особенно с помощью плагинов Jellyfin, таких как ListenBrainz.",
"playback-reporting-description": "Прямая игра",
"color-scheme": "Цветовая тема",
"color-scheme-description": "По умолчанию, Fintunes будет следовать цветовой теме вашей операционной системы. Однако вы можете переназначить это, чтобы Fintunes всегда находился в темной или светлой теме.",
"color-scheme-system": "Система",
@@ -74,5 +74,11 @@
"sleep-timer": "Время сна",
"confirm-delete-all-tracks": "Вы уверены, что хотите удалить все загруженные в настоящее время треки?",
"delete": "Удалить",
"cancel": "Отмена"
"cancel": "Отмена",
"disc": "Disc",
"lyrics": "Текст песни",
"direct-play": "Прямая игра",
"transcoded": "Transcode",
"khz": "кГц",
"kbps": "кбит/с"
}

View File

@@ -13,13 +13,13 @@
"search": "Iskanje",
"music": "Glasba",
"now-playing": "Zdaj igra",
"set-jellyfin-server": "Nastavite strežnik Jellyfin",
"set-jellyfin-server-instruction": "Vnesite URL svojega strežnika Jellyfin. Ne pozabite vključiti protokola in vrat",
"set-server": "Nastavite strežnik Jellyfin",
"set-server-instruction": "Vnesite URL svojega strežnika Jellyfin. Ne pozabite vključiti protokola in vrat",
"settings": "Nastavitve",
"jellyfin-library": "Knjižnica Jellyfin",
"jellyfin-server-url": "URL strežnika Jellyfin",
"jellyfin-access-token": "Žeton za dostop Jellyfin",
"jellyfin-user-id": "ID uporabnika Jellyfin",
"library": "Knjižnica Jellyfin",
"server-url": "URL strežnika Jellyfin",
"access-token": "Žeton za dostop Jellyfin",
"user-id": "ID uporabnika Jellyfin",
"setting-cache": "Predpomnilnik",
"setting-cache-description": "Če ste posodobili knjižnico Jellyfin, vendar aplikacija zadržuje predpomnjena sredstva, lahko s tem gumbom prisilno počistite predpomnilnik. To bo prisililo aplikacijo, da znova pridobi knjižnico.",
"reset-cache": "Ponastavi predpomnilnik",
@@ -74,5 +74,9 @@
"sleep-timer": "Časovnik za spanje",
"cancel": "Prekliči",
"confirm-delete-all-tracks": "Ali ste prepričani, da želite izbrisati vse trenutno prenesene skladbe?",
"delete": "Izbriši"
"delete": "Izbriši",
"disc": "Disk",
"lyrics": "Besedilo",
"khz": "kHz",
"transcoded": "prekodiraj [▲]"
}

View File

@@ -17,14 +17,14 @@
"now-playing": "Nu spelas",
"onboarding-welcome": "Välkommen!",
"onboarding-intro": "Fintunes låter dig strömma ditt musikbibliotek var som helst, med fullt stöd för bakgrundsljud och casting.",
"onboarding-cta": "För att komma igång behöver du en Jellyfin-server. Klicka på knappen nedan för att ange din Jellyfin-serveradress och logga in på den.",
"set-jellyfin-server": "Ställ in Jellyfin-server",
"set-jellyfin-server-instruction": "Ange din Jellyfin-server-URL. Se till att inkludera protokoll och port",
"onboarding-cta": "För att komma igång behöver du en Jellyfin-server. Klicka på knappen nedan för att ange din serveradress och logga in på den.",
"set-server": "Ställ in Jellyfin-server",
"set-server-instruction": "Ange din Jellyfin-server-URL. Se till att inkludera protokoll och port",
"settings": "inställningar",
"jellyfin-library": "Jellyfin-bibliotek",
"jellyfin-server-url": "Jellyfin Server URL",
"jellyfin-access-token": "Jellyfin Access Token",
"jellyfin-user-id": "Jellyfin användar-ID",
"library": "Jellyfin-bibliotek",
"server-url": "Jellyfin Server URL",
"access-token": "Jellyfin Access Token",
"user-id": "Jellyfin användar-ID",
"setting-cache": "Cache",
"setting-cache-description": "Om du har uppdaterat ditt Jellyfin-bibliotek men appen håller kvar cachelagrade tillgångar kan du tvångsrensa cachen med den här knappen. Detta kommer att tvinga appen att hämta biblioteket från början.",
"reset-cache": "Töm cache",
@@ -65,7 +65,7 @@
"total-duration": "Total varaktighet",
"similar-albums": "Liknande album",
"playback-reporting": "Uppspelningsrapportering",
"playback-reporting-description": "Med uppspelningsrapportering skickas alla dina uppspelningshändelser tillbaka till Jellyfin. Detta låter dig spåra dina mest lyssnade låtar, särskilt med Jellyfin-plugins som ListenBrainz.",
"playback-reporting-description": "Direkt spel",
"color-scheme": "Färgschema",
"color-scheme-description": "Som standard följer Fintunes ditt operativsystems färgschema. Du kan dock välja att åsidosätta detta för att se till att Fintunes alltid är i mörkt läge eller ljust läge.",
"color-scheme-system": "System",
@@ -74,5 +74,11 @@
"sleep-timer": "Sova timer",
"delete": "Delete",
"cancel": "Avbokning",
"confirm-delete-all-tracks": "Är du säker på att du vill ta bort alla för närvarande nedladdade spår?"
"confirm-delete-all-tracks": "Är du säker på att du vill ta bort alla för närvarande nedladdade spår?",
"disc": "Disc",
"lyrics": "Låttext",
"direct-play": "Direkt spel",
"transcoded": "Transkoded",
"khz": "kHz",
"kbps": "kb/s"
}

View File

@@ -0,0 +1,84 @@
{
"queue": "வரிசை",
"clear-queue": "தெளிவான வரிசை",
"no-results": "முடிவுகள் இல்லை…",
"album": "ஆல்பம்",
"albums": "ஆல்பம்",
"search": "தேடல்",
"music": "இசை",
"enable": "இயக்கு",
"delete": "நீக்கு",
"now-playing": "இப்போது விளையாடுகிறது",
"onboarding-welcome": "வரவேற்கிறோம்!",
"settings": "அமைப்புகள்",
"library": "நூலகம்",
"server-url": "சேவையக முகவரி",
"user-id": "பயனர் ஐடி",
"setting-cache": "கேச்",
"disable": "முடக்கு",
"more-info": "மேலும் செய்தி",
"track": "மின்தடம்",
"playlists": "பிளேலிச்ட்கள்",
"playlist": "பிளேலிச்ட்",
"shuffle-album": "கலக்கு ஆல்பம்",
"downloads": "பதிவிறக்கங்கள்",
"delete-track": "தடத்தை நீக்கு",
"delete-all-tracks": "எல்லா தடங்களையும் நீக்கு",
"delete-playlist": "பிளேலிச்ட்டை நீக்கு",
"color-scheme": "வண்ணத் திட்டம்",
"color-scheme-system": "மண்டலம்",
"color-scheme-light": "ஒளி பயன்முறை",
"color-scheme-dark": "இருண்ட முறை",
"artists": "கலைஞர்கள்",
"privacy-policy": "தனியுரிமைக் கொள்கை",
"sleep-timer": "தூக்க நேரங்குறிகருவி",
"cancel": "ரத்துசெய்",
"disc": "வட்டு",
"lyrics": "பாடல்",
"khz": "khz",
"play-next": "அடுத்து விளையாடுங்கள்",
"play-album": "ஆல்பம்",
"add-to-queue": "வரிசையில் சேர்க்கவும்",
"all-albums": "அனைத்து ஆல்பங்களும்",
"onboarding-cta": "தொடங்குவதற்கு, உங்களுக்கு செல்லிஃபின் (அல்லது எம்பி) சேவையகம் தேவை. உங்கள் சேவையக முகவரியை உள்ளிட கீழே உள்ள பொத்தானைக் சொடுக்கு செய்து அதில் உள்நுழைக.",
"onboarding-intro": "பின்னணி ஆடியோ மற்றும் வார்ப்புகளுக்கு முழு ஆதரவோடு, உங்கள் இசை நூலகத்தை எங்கிருந்தும் ச்ட்ரீம் செய்ய ஃபிண்டுன்ச் உங்களை அனுமதிக்கும்.",
"set-server": "சேவையகத்தை அமைக்கவும்",
"set-server-instruction": "உங்கள் சேவையக முகவரி ஐ உள்ளிடவும். நெறிமுறை மற்றும் துறைமுகத்தை சேர்க்க உறுதிப்படுத்தவும்",
"access-token": "அணுகல் கிள்ளாக்கு",
"setting-cache-description": "உங்கள் நூலகத்தை நீங்கள் புதுப்பித்திருந்தால், ஆனால் பயன்பாடு தற்காலிக சேமிப்பு சொத்துக்களை வைத்திருந்தால், இந்த பொத்தானைப் பயன்படுத்தி தற்காலிக சேமிப்பை நீங்கள் வலுக்கட்டாயமாக அழிக்கலாம். இது புதிதாக நூலகத்தை பெற பயன்பாட்டை கட்டாயப்படுத்தும்.",
"reset-cache": "தற்காலிக சேமிப்பை மீட்டமைக்கவும்",
"recent-albums": "அண்மைக் கால ஆல்பங்கள்",
"error-reporting": "பிழை அறிக்கை",
"error-reporting-description": "இந்த பயன்பாட்டின் போது, நீங்கள் பிழைகளை சந்திக்க நேரிடும். இந்த பிழைகளைப் புகாரளிப்பது மிகவும் பாதுகாப்பான மற்றும் நிலையான பயன்பாட்டு அனுபவத்தை உருவாக்க உதவுகிறது.",
"error-reporting-rationale": "பிழை அறிக்கையிடலை நீங்கள் இயக்கும்போது, ஒவ்வொரு முறையும் ஒரு பிழை ஏற்படும் போது, ஒரு அறிக்கை தானாகவே உருவாக்கப்பட்டு சேவையகத்திற்கு அனுப்பப்படும், மேலும் சாதனங்கள், பதிப்புகள் மற்றும் குறிப்பிட்ட பிழை போன்ற பயனுள்ள பிழைத்திருத்த தகவலுடன்.",
"why-use-tracking": "கண்காணிப்பை ஏன் பயன்படுத்த வேண்டும்?",
"why-use-tracking-description": "வித்தியாசமான விளிம்பு வழக்குகள் மற்றும் மேற்பார்வைகளைப் புகாரளிப்பதன் மூலம் இந்த பயன்பாட்டிற்கான வளர்ச்சியை விரைவுபடுத்த உதவுகிறது. இது பயன்பாட்டை மிகவும் நிலையானதாகவும் வலுவானதாகவும் மாற்ற உதவுகிறது, இதனால் அனைவருக்கும் பயன்பாட்டு அனுபவத்தை மேம்படுத்துகிறது.",
"what-data-is-gathered": "என்ன தரவு சேகரிக்கப்படுகிறது?",
"what-data-is-gathered-description": "பிழை, சாதன வகை, OS பதிப்பு, பயன்பாட்டு பதிப்பு மற்றும் சாதன ஐடி ஆகியவற்றை நாங்கள் பதிவு செய்கிறோம். எந்தவொரு பிழை அறிக்கையிலும் விண்ணப்ப நிலை அனுப்பப்படவில்லை. சாதன ஐடி என்பது உங்கள் சாதன அமைப்புகளில் மீட்டமைக்கக்கூடிய ஒரு தனித்துவமான ஆச் ஆகும், மேலும் இந்த அடையாளங்காட்டியிலிருந்து எந்தவொரு தனிப்பட்ட தகவலையும் எங்களால் குறைக்க முடியாது.",
"where-is-data-stored": "தரவு எங்கே சேமிக்கப்படுகிறது?",
"where-is-data-stored-description": "சென்ட்ரி பின்தளத்தில் எங்கள் சொந்த உள்கட்டமைப்பில் சுயமாக புரவலன் செய்யப்படுகிறது. சேவையகங்கள், தரவுத்தளங்கள், பயன்பாடு மற்றும் தரவு பதிவுகள், குறைந்தது எந்தவொரு சென்ட்ரி ஊழியர்களுக்கும் அணுகல் இல்லை. உள்கட்டமைப்பு ஐரோப்பிய ஒன்றியத்தில் வழங்கப்படுகிறது.",
"enable-error-reporting": "பிழை அறிக்கையிடலை இயக்க விரும்புகிறீர்களா?",
"enable-error-reporting-description": "விபத்து மற்றும் பிழை அறிக்கைகளை எங்களுக்கு அனுப்புவதன் மூலம் பயன்பாட்டு அனுபவத்தை மேம்படுத்த இது உதவுகிறது.",
"play-playlist": "பிளேலிச்ட்டை விளையாடுங்கள்",
"shuffle-playlist": "கலக்கு பிளேலிச்ட்",
"download-track": "டிராக் பதிவிறக்க",
"download-album": "ஆல்பத்தைப் பதிவிறக்கவும்",
"download-playlist": "பிளேலிச்ட்டைப் பதிவிறக்கவும்",
"no-downloads": "நீங்கள் இதுவரை எந்த தடங்களையும் பதிவிறக்கம் செய்யவில்லை",
"confirm-delete-all-tracks": "தற்போது பதிவிறக்கம் செய்யப்பட்ட அனைத்து தடங்களையும் நீக்க விரும்புகிறீர்களா?",
"delete-album": "ஆல்பத்தை நீக்கு",
"playback-reporting-description": "பிளேபேக் அறிக்கையிடலுடன், உங்கள் பிளேபேக் நிகழ்வுகள் அனைத்தும் உங்கள் சேவையகத்திற்கு மீண்டும் அனுப்பப்படுகின்றன. இது மிகவும் கேட்கப்பட்ட பாடல்களைக் கண்காணிக்க உங்களை அனுமதிக்கிறது, குறிப்பாக கேட்பது பிரெய்ன்ச் அல்லது லாச்ட்எம் போன்ற செருகுநிரல்களுடன்.",
"total-download-size": "மொத்த பதிவிறக்க அளவு",
"retry-failed-downloads": "மீண்டும் பதிவிறக்கங்களை மீண்டும் முயற்சிக்கவும்",
"you-are-offline-message": "நீங்கள் தற்போது ஆஃப்லைனில் இருக்கிறீர்கள். நீங்கள் முன்பு பதிவிறக்கம் செய்யப்பட்ட இசையை மட்டுமே இயக்க முடியும்.",
"playing-on": "விளையாடுவது",
"local-playback": "உள்ளக பின்னணி",
"streaming": "ச்ட்ரீமிங்",
"total-duration": "மொத்த காலம்",
"similar-albums": "ஒத்த ஆல்பங்கள்",
"playback-reporting": "பின்னணி அறிக்கை",
"color-scheme-description": "இயல்பாக, உங்கள் இயக்க முறைமையின் வண்ணத் திட்டத்தை FINTUNES பின்பற்றும். இருப்பினும் நீங்கள் இதை மேலெழுத தேர்வு செய்யலாம் fintunes எப்போதும் இருண்ட பயன்முறையில் அல்லது ஒளி பயன்முறையில் இருப்பதை உறுதிப்படுத்தலாம்.",
"direct-play": "நேரடி நாடகம்",
"transcoded": "டிரான்ச்கோடட்",
"kbps": "கே.பி.பி.எச்"
}

View File

@@ -13,16 +13,16 @@
"now-playing": "Зараз грає",
"onboarding-welcome": "Ласкаво просимо!",
"onboarding-intro": "Fintunes дозволить вам транслювати свою музичну бібліотеку з будь-якого місця з повною підтримкою фонового звуку та трансляції.",
"onboarding-cta": "Щоб почати, вам потрібен сервер Jellyfin. Натисніть кнопку нижче, щоб ввести адресу свого сервера Jellyfin і увійти на нього.",
"set-jellyfin-server": "Встановити сервер Jellyfin",
"set-jellyfin-server-instruction": "Будь ласка, введіть URL-адресу вашого сервера Jellyfin. Не забудьте вказати протокол і порт",
"onboarding-cta": "Для того, щоб розпочати роботу, потрібно сервер Jellyfin (або Emby) Натисніть кнопку нижче, щоб ввести адресу сервера і увійти до неї.",
"set-server": "Встановити сервер Jellyfin",
"set-server-instruction": "Будь ласка, введіть URL-адресу вашого сервера Jellyfin. Не забудьте вказати протокол і порт",
"settings": "Налаштування",
"jellyfin-library": "Бібліотека Jellyfin",
"jellyfin-server-url": "URL-адреса сервера Jellyfin",
"jellyfin-access-token": "Токен доступу Jellyfin",
"jellyfin-user-id": "ID користувача Jellyfin",
"library": "Бібліотека Jellyfin",
"server-url": "URL-адреса сервера Jellyfin",
"access-token": "Токен доступу Jellyfin",
"user-id": "ID користувача Jellyfin",
"setting-cache": "Кеш",
"setting-cache-description": "Якщо ви оновили свою бібліотеку Jellyfin, але застосунок зберігає кешовані ресурси, ви можете примусово очистити кеш за допомогою цієї кнопки. Це змусить застосунок отримати бібліотеку з нуля.",
"setting-cache-description": "Якщо ви оновили свою бібліотеку, але застосунок зберігає кешовані ресурси, ви можете примусово очистити кеш за допомогою цієї кнопки. Це змусить застосунок отримати бібліотеку з нуля.",
"reset-cache": "Скинути кеш",
"recent-albums": "Останні альбоми",
"error-reporting": "Звіт про помилку",
@@ -50,7 +50,7 @@
"total-duration": "Загальна тривалість",
"similar-albums": "Схожі альбоми",
"playback-reporting": "Звіт про відтворення",
"playback-reporting-description": "Завдяки звіту про відтворення всі ваші події відтворення передаються назад до Jellyfin. Це дозволяє відстежувати пісні, які ви найчастіше слухаєте, зокрема за допомогою плаґінів Jellyfin, таких як ListenBrainz.",
"playback-reporting-description": "З повідомленням відтворення, всі ваші події відтворюються назад на сервер. Це дозволяє відслідковувати свої найслуховіші пісні, зокрема, плагіни, такі як RadioBrainz або LastFM.",
"color-scheme": "Кольорова схема",
"color-scheme-description": "За замовчуванням Fintunes дотримуватиметься колірної схеми вашої операційної системи. Однак ви можете змінити це, щоб Fintunes завжди перебував у темному або світлому режимі.",
"color-scheme-system": "Системна",
@@ -73,6 +73,12 @@
"privacy-policy": "Політика конфіденційності",
"sleep-timer": "Таймер сну",
"confirm-delete-all-tracks": "Ви впевнені, що ви хочете видалити всі завантажені треки?",
"delete": "Делет",
"cancel": "Зареєструватися"
"delete": "Видалити",
"cancel": "Скасувати",
"disc": "Диски",
"lyrics": "Текст пісень",
"direct-play": "Пряме відтворення",
"transcoded": "Перекодований",
"khz": "кГц",
"kbps": "кбіт/с"
}

View File

@@ -13,16 +13,16 @@
"now-playing": "正在播放",
"onboarding-welcome": "欢迎",
"onboarding-intro": "Fintunes可以在任何地方播放Jellyfin库中的音乐。",
"onboarding-cta": "在开始前,你需要一个Jellyfin服务器。击下的按钮连接到服务器并登录。",
"set-jellyfin-server": "设置Jellyfin服务器",
"set-jellyfin-server-instruction": "设置Jellyfin服务器的完整网址包括HTTP/HTTS和端口。",
"onboarding-cta": "首先,您需要一个 Jellyfin(或 Emby服务器。击下的按钮输入您的服务器地址并登录。",
"set-server": "设置Jellyfin服务器",
"set-server-instruction": "设置Jellyfin服务器的完整网址包括HTTP/HTTS和端口。",
"settings": "设置",
"jellyfin-library": "Jellyfin库",
"jellyfin-server-url": "Jellyfin服务器网址",
"jellyfin-access-token": "Jellyfin Access Token",
"jellyfin-user-id": "Jellyfin用户ID",
"library": "Jellyfin库",
"server-url": "Jellyfin服务器网址",
"access-token": "Jellyfin Access Token",
"user-id": "Jellyfin用户ID",
"setting-cache": "缓存",
"setting-cache-description": "如果你更新了Jellyfin库但软件仍显示之前的内容你可以点击下面的按钮强制刷新。这将强制软件重新从服务器获取信息。",
"setting-cache-description": "如果您已更新库,但应用仍保留缓存的资源,则可以使用此按钮强制清除缓存。这将强制应用从头开始获取库。",
"reset-cache": "清除缓存",
"recent-albums": "最近专辑",
"error-reporting": "报告错误",
@@ -68,11 +68,17 @@
"color-scheme-system": "系统",
"artists": "艺术家",
"color-scheme-dark": "深色模式",
"playback-reporting-description": "借助回放报告,您的所有放事件都会转发回 Jellyfin。这使您可以跟踪您最常听的歌曲,尤其是使用 ListenBrainz 等 Jellyfin 插件时。",
"playback-reporting-description": "使用播放报告,您的所有放事件都会转发回您的服务器。这您可以跟踪您最常听的歌曲,特别是使用 ListenBrainz 或 LastFM 等插件时。",
"color-scheme-light": "灯光模式",
"privacy-policy": "隐私政策",
"sleep-timer": "睡眠定时器",
"confirm-delete-all-tracks": "你们是否希望删除目前下载的所有轨道?",
"confirm-delete-all-tracks": "您确定要删除所有当前下载的曲目吗?",
"delete": "删除",
"cancel": "取消"
"cancel": "取消",
"disc": "光盘",
"lyrics": "歌词",
"direct-play": "直接播放",
"transcoded": "转码",
"khz": "kHz",
"kbps": "kbps"
}

View File

@@ -0,0 +1,84 @@
{
"play-next": "播放下一首",
"onboarding-welcome": "歡迎!",
"settings": "設定",
"library": "音樂庫",
"server-url": "伺服器 URL",
"access-token": "存取令牌",
"user-id": "使用者 ID",
"setting-cache": "快取",
"error-reporting": "錯誤報告",
"enable": "啟用",
"disable": "停用",
"more-info": "更多資訊",
"track": "音軌",
"playlists": "播放清單",
"playlist": "播放清單",
"shuffle-playlist": "隨機播放清單",
"downloads": "下載",
"delete-track": "刪除音軌",
"total-duration": "總播放時長",
"color-scheme": "色調配置",
"color-scheme-system": "系統",
"color-scheme-dark": "深色模式",
"khz": "kHz",
"kbps": "kbps",
"queue": "佇列",
"add-to-queue": "加入佇列",
"clear-queue": "清除佇列",
"no-results": "沒找到結果…",
"album": "專輯",
"albums": "專輯",
"all-albums": "全部專輯",
"search": "搜尋",
"music": "音樂",
"now-playing": "正在播放",
"artists": "藝術家",
"privacy-policy": "隱私權政策",
"sleep-timer": "睡眠倒數",
"delete": "刪除",
"cancel": "取消",
"disc": "碟片",
"lyrics": "歌詞",
"onboarding-intro": "Fintunes 將允許您從任何地方流式傳輸您的音樂庫,並完全支援背景播放和投放。",
"onboarding-cta": "為了開始您需要一個Jellyfin或Emby伺服器。 點選下面的按鈕輸入您的伺服器地址並登入。",
"set-server": "設定伺服器",
"set-server-instruction": "請輸入您的伺服器 URL。 確保包括協議和端口",
"setting-cache-description": "如果您已經更新了音樂庫,但應用程式保留了快取的資料,您可以使用此按鈕強制清除快取。 這將迫使應用程式從頭開始獲取音樂庫資料。",
"reset-cache": "重設快取",
"recent-albums": "最近的專輯",
"error-reporting-description": "在使用此應用程式時,您可能會遇到錯誤。 報告這些錯誤有助於建立更安全、更穩定的應用程式體驗。",
"error-reporting-rationale": "當您啟用錯誤報告時,每次出現錯誤時,都會自動建立報告併發送到伺服器,以及有用的除錯資訊,如裝置、版本和特定錯誤。",
"what-data-is-gathered-description": "我們記錄錯誤、裝置型別、作業系統版本、應用程式版本和裝置ID。 在任何錯誤報告中都不會傳送應用程式狀態。 裝置ID是一個唯一的雜湊可以在您的裝置設定中重置我們無法從此識別符號中推斷出任何個人資訊。",
"where-is-data-stored": "資料儲存在哪裡?",
"where-is-data-stored-description": "Sentry 的後端部署在我們自有的基礎設施上只有我們能夠訪問伺服器、資料庫、應用程序和數據日誌Sentry 的員工更無法接觸到。基礎設施托管於歐盟境內。",
"enable-error-reporting": "您想啟用錯誤報告嗎?",
"play-playlist": "播放播放清單",
"shuffle-album": "隨機專輯",
"download-track": "下載音軌",
"download-album": "下載專輯",
"download-playlist": "下載播放清單",
"no-downloads": "您尚未下載任何曲目",
"delete-all-tracks": "删除所有音軌",
"confirm-delete-all-tracks": "您確定要刪除所有當前下載的曲目嗎?",
"delete-album": "删除專輯",
"delete-playlist": "删除播放清單",
"total-download-size": "總下載大小",
"retry-failed-downloads": "重試下載失敗",
"you-are-offline-message": "您當前離線。 您只能播放之前下載的音樂。",
"playing-on": "播放 在",
"local-playback": "本地回放",
"streaming": "串流",
"similar-albums": "相似專輯",
"playback-reporting": "播放報告",
"playback-reporting-description": "透過播放報告,您的所有播放事件都會轉發回您的伺服器。 這允許您跟蹤收聽最多的歌曲特別是使用ListenBrainz或LastFM等外掛。",
"color-scheme-description": "預設情況下Fintunes將遵循您作業系統的配色方案。 然而您可以選擇覆蓋此選項以確保Fintunes始終處於深色或淺色模式。",
"color-scheme-light": "淺色模式",
"direct-play": "直接播放",
"transcoded": "已轉碼",
"play-album": "播放專輯",
"why-use-tracking": "為什麼要使用跟蹤?",
"why-use-tracking-description": "跟蹤透過報告奇怪的邊緣案例和疏忽來幫助加快此應用程式的開發。 這有助於使應用程式更加穩定和強大,從而改善每個人的應用程式體驗。",
"what-data-is-gathered": "收集了哪些資料?",
"enable-error-reporting-description": "這透過向我們傳送崩潰和錯誤報告來幫助改善應用程式體驗。"
}

View File

@@ -13,13 +13,13 @@ export type LocaleKeys = 'play-next'
| 'onboarding-welcome'
| 'onboarding-intro'
| 'onboarding-cta'
| 'set-jellyfin-server'
| 'set-jellyfin-server-instruction'
| 'set-server'
| 'set-server-instruction'
| 'settings'
| 'jellyfin-library'
| 'jellyfin-server-url'
| 'jellyfin-access-token'
| 'jellyfin-user-id'
| 'library'
| 'server-url'
| 'access-token'
| 'user-id'
| 'setting-cache'
| 'setting-cache-description'
| 'reset-cache'
@@ -73,4 +73,10 @@ export type LocaleKeys = 'play-next'
| 'privacy-policy'
| 'sleep-timer'
| 'delete'
| 'cancel'
| 'cancel'
| 'disc'
| 'lyrics'
| 'direct-play'
| 'transcoded'
| 'khz'
| 'kbps'

View File

@@ -12,7 +12,7 @@ import DownloadIcon from '@/components/DownloadIcon';
import styled from 'styled-components/native';
import { Text } from '@/components/Typography';
import FastImage from 'react-native-fast-image';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import { ShadowWrapper } from '@/components/Shadow';
import { SafeFlatList } from '@/components/SafeNavigatorView';
import { t } from '@/localisation';
@@ -136,7 +136,7 @@ function Downloads() {
<DownloadedTrack>
<View style={{ marginRight: 12 }}>
<ShadowWrapper size="small">
<AlbumImage source={{ uri: getImage(item as string) }} style={defaultStyles.imageBackground} />
<AlbumImage source={{ uri: getImage(item) }} style={defaultStyles.imageBackground} />
</ShadowWrapper>
</View>
<View style={{ flexShrink: 1, marginRight: 8 }}>

View File

@@ -1,4 +1,4 @@
import React, { useCallback, useEffect, useRef } from 'react';
import React, { useCallback, useContext, useEffect, useRef } from 'react';
import { ActivityIndicator, Animated, Dimensions, Platform, Pressable, View } from 'react-native';
import FastImage from 'react-native-fast-image';
import styled, { css } from 'styled-components/native';
@@ -16,10 +16,12 @@ import { useNavigation } from '@react-navigation/native';
import { calculateProgressTranslation } from '@/components/Progresstrack';
import { NavigationProp } from '@/screens/types';
import { ShadowWrapper } from '@/components/Shadow';
import { useBottomTabBarHeight } from '@react-navigation/bottom-tabs';
import { BottomTabBarHeightContext } from '@react-navigation/bottom-tabs';
import { useSafeAreaInsets } from 'react-native-safe-area-context';
const NOW_PLAYING_POPOVER_MARGIN = 6;
const NOW_PLAYING_POPOVER_WIDTH = Dimensions.get('screen').width - 2 * NOW_PLAYING_POPOVER_MARGIN;
export const NOW_PLAYING_POPOVER_MARGIN = 6;
export const NOW_PLAYING_POPOVER_WIDTH = Dimensions.get('screen').width - 2 * NOW_PLAYING_POPOVER_MARGIN;
export const NOW_PLAYING_POPOVER_HEIGHT = 58;
const PopoverPosition = css`
position: absolute;
@@ -34,6 +36,7 @@ const Container = styled.ScrollView`
`;
const InnerContainer = styled.TouchableOpacity`
height: ${NOW_PLAYING_POPOVER_HEIGHT}px;
padding: 12px;
overflow: hidden;
flex: 1;
@@ -105,18 +108,25 @@ function SelectActionButton() {
}
}
function NowPlaying({ offset = 0 }: { offset?: number }) {
function NowPlaying({ offset = 0, inset }: { offset?: number, inset?: boolean }) {
const { index, track } = useCurrentTrack();
const { buffered, position } = useProgress();
const defaultStyles = useDefaultStyles();
const tabBarHeight = useBottomTabBarHeight();
// The regular `useBottomTabBarHeight` hook will throw an error when it
// cannot find a height. Since we might use this component in places where
// it is unavailable, we'll just use the context directly, which will output
// `undefined` when it's not set.
const tabBarHeight = useContext(BottomTabBarHeightContext);
const insets = useSafeAreaInsets();
const previousBuffered = usePrevious(buffered);
const previousPosition = usePrevious(position);
const navigation = useNavigation<NavigationProp>();
const bufferAnimation = useRef(new Animated.Value(0));
const progressAnimation = useRef(new Animated.Value(0));
const bufferAnimation = useRef(new Animated.Value(-1_000));
const progressAnimation = useRef(new Animated.Value(-1_000));
const openNowPlayingModal = useCallback(() => {
navigation.navigate('Player');
@@ -163,7 +173,14 @@ function NowPlaying({ offset = 0 }: { offset?: number }) {
}
return (
<Container style={{ bottom: tabBarHeight + NOW_PLAYING_POPOVER_MARGIN + offset }}>
<Container
style={{
bottom: (tabBarHeight || 0)
+ (inset ? insets.bottom : 0)
+ NOW_PLAYING_POPOVER_MARGIN
+ offset
}}
>
{/** TODO: Fix shadow overflow on Android */}
{Platform.OS === 'ios' ? (
<ShadowOverlay pointerEvents='none'>

View File

@@ -2,14 +2,14 @@ import React, { useCallback, useEffect } from 'react';
import { useRoute, RouteProp, useNavigation } from '@react-navigation/native';
import { useAppDispatch, useTypedSelector } from '@/store';
import TrackListView from './components/TrackListView';
import { fetchAlbum, fetchTracksByAlbum } from '@/store/music/actions';
import { fetchAlbum, fetchSimilarAlbums, fetchTracksByAlbum } from '@/store/music/actions';
import { differenceInDays } from 'date-fns';
import { ALBUM_CACHE_AMOUNT_OF_DAYS } from '@/CONSTANTS';
import { t } from '@/localisation';
import { NavigationProp, StackParams } from '@/screens/types';
import { SubHeader, Text } from '@/components/Typography';
import { ScrollView } from 'react-native-gesture-handler';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import styled from 'styled-components';
import { Dimensions, Pressable } from 'react-native';
import AlbumImage from './components/AlbumImage';
@@ -33,7 +33,7 @@ function SimilarAlbum({ id }: { id: string }) {
const handlePress = useCallback(() => {
album && navigation.push('Album', { id, album });
}, [id, album, navigation]);
return (
<Pressable
style={({ pressed }) => ({
@@ -43,7 +43,7 @@ function SimilarAlbum({ id }: { id: string }) {
})}
onPress={handlePress}
>
<Cover key={id} source={{ uri: getImage(id) }} />
<Cover key={id} source={{ uri: getImage(album) }} />
<Text numberOfLines={1} style={{ fontSize: 13, marginBottom: 2 }}>{album?.Name}</Text>
<Text numberOfLines={1} style={{ opacity: 0.5, fontSize: 13 }}>{album?.Artists.join(', ')}</Text>
</Pressable>
@@ -62,6 +62,7 @@ const Album: React.FC = () => {
const refresh = useCallback(() => {
dispatch(fetchTracksByAlbum(id));
dispatch(fetchAlbum(id));
dispatch(fetchSimilarAlbums(id));
}, [id, dispatch]);
// Auto-fetch the track data periodically
@@ -76,7 +77,7 @@ const Album: React.FC = () => {
trackIds={albumTracks || []}
title={album?.Name}
artist={album?.AlbumArtist}
entityId={id}
entityId={album?.PrimaryImageItemId || album.Id}
refresh={refresh}
playButtonText={t('play-album')}
shuffleButtonText={t('shuffle-album')}

View File

@@ -1,5 +1,5 @@
import React, { useCallback, useEffect, useRef, ReactText, useMemo } from 'react';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import { SectionList, View } from 'react-native';
import { useNavigation } from '@react-navigation/native';
import { differenceInDays } from 'date-fns';
@@ -149,7 +149,7 @@ const Albums: React.FC = () => {
<GeneratedAlbumItem
key={id}
id={id}
imageUrl={getImage(id as string)}
imageUrl={getImage(albums[id])}
name={albums[id]?.Name || ''}
artist={albums[id]?.AlbumArtist || ''}
onPress={selectAlbum}

View File

@@ -1,5 +1,5 @@
import React, { useCallback, useEffect, ReactText } from 'react';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import { View } from 'react-native';
import { RouteProp, useNavigation, useRoute } from '@react-navigation/native';
import { differenceInDays } from 'date-fns';
@@ -68,7 +68,7 @@ const Artist: React.FC = () => {
<GeneratedAlbumItem
key={id}
id={id}
imageUrl={getImage(id as string)}
imageUrl={getImage(albums[id])}
name={albums[id]?.Name || ''}
artist={albums[id]?.AlbumArtist || ''}
onPress={selectAlbum}

View File

@@ -1,5 +1,5 @@
import React, { useCallback, useEffect, useRef, useMemo } from 'react';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import { SectionList, View } from 'react-native';
import { useNavigation } from '@react-navigation/native';
import { differenceInDays } from 'date-fns';
@@ -178,7 +178,7 @@ const Artists: React.FC = () => {
key={item.Id}
item={item}
onPress={selectArtist}
imageURL={getImage(item.Id)}
imageURL={getImage(item)}
/>
</View>
);

View File

@@ -1,5 +1,5 @@
import React, { useCallback, useEffect, useRef, ReactText } from 'react';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import { Text, View, FlatList, ListRenderItem, RefreshControl } from 'react-native';
import { useNavigation } from '@react-navigation/native';
import { differenceInDays } from 'date-fns';
@@ -70,14 +70,14 @@ const Playlists: React.FC = () => {
<View style={{ flexDirection: 'row', marginLeft: 10, marginRight: 10 }} key={item}>
<GeneratedPlaylistItem
id={item}
imageUrl={getImage(item as string)}
imageUrl={getImage(entities[item])}
name={entities[item]?.Name || ''}
onPress={selectAlbum}
/>
{nextItem &&
<GeneratedPlaylistItem
id={nextItemId}
imageUrl={getImage(nextItemId as string)}
imageUrl={getImage(nextItem)}
name={nextItem.Name || ''}
onPress={selectAlbum}
/>

View File

@@ -1,5 +1,5 @@
import React, { useCallback, useEffect } from 'react';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import { Text, SafeAreaView, StyleSheet } from 'react-native';
import { useNavigation } from '@react-navigation/native';
import { useAppDispatch, useTypedSelector } from '@/store';
@@ -39,9 +39,15 @@ const NavigationHeader: React.FC = () => {
return (
<>
<ListButton onPress={handleAllAlbumsClick} testID="all-albums">{t('all-albums')}</ListButton>
<ListButton onPress={handleArtistsClick} testID="artists">{t('artists')}</ListButton>
<ListButton onPress={handlePlaylistsClick} testID="playlists">{t('playlists')}</ListButton>
<ListButton onPress={handleAllAlbumsClick} testID="all-albums">
{t('all-albums')}
</ListButton>
<ListButton onPress={handleArtistsClick} testID="artists">
{t('artists')}
</ListButton>
<ListButton onPress={handlePlaylistsClick} testID="playlists">
{t('playlists')}
</ListButton>
<ListContainer>
<HeaderContainer>
<Header>{t('recent-albums')}</Header>
@@ -86,7 +92,7 @@ const RecentAlbums: React.FC = () => {
<TouchableHandler id={item} onPress={selectAlbum} testID={`select-album-${item}`}>
<AlbumItem>
<ShadowWrapper size="medium">
<AlbumImage source={{ uri: getImage(item) }} style={defaultStyles.imageBackground} />
<AlbumImage source={{ uri: getImage(albums[item]) }} style={defaultStyles.imageBackground} />
</ShadowWrapper>
<Text style={defaultStyles.text} numberOfLines={1}>{albums[item]?.Name}</Text>
<Text style={defaultStyles.textHalfOpacity} numberOfLines={1}>{albums[item]?.AlbumArtist}</Text>

View File

@@ -1,7 +1,8 @@
import React, { useState } from 'react';
import styled from 'styled-components/native';
import FastImage, { FastImageProps } from 'react-native-fast-image';
import { Dimensions, useColorScheme } from 'react-native';
import { Dimensions } from 'react-native';
import { useUserOrSystemScheme } from '@/components/Colors';
const Screen = Dimensions.get('screen');
export const AlbumWidth = Screen.width / 2 - 24;
@@ -23,11 +24,17 @@ const Container = styled(FastImage)`
function AlbumImage(props: FastImageProps) {
const [hasError, setError] = useState(false);
const colorScheme = useColorScheme();
const colorScheme = useUserOrSystemScheme();
if (!props.source || hasError) {
return (
<Container {...props} source={colorScheme === 'light' ? require('@/assets/images/empty-album-light.png') : require('@/assets/images/empty-album-dark.png')} />
<Container
{...props}
source={colorScheme === 'light'
? require('@/assets/images/empty-album-light.png')
: require('@/assets/images/empty-album-dark.png')
}
/>
);
}

View File

@@ -1,12 +1,11 @@
import React, { PropsWithChildren, useCallback, useMemo } from 'react';
import { Platform, RefreshControl, StyleSheet, View } from 'react-native';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import styled, { css } from 'styled-components/native';
import { useNavigation } from '@react-navigation/native';
import { useAppDispatch, useTypedSelector } from '@/store';
import TouchableHandler from '@/components/TouchableHandler';
import useCurrentTrack from '@/utility/useCurrentTrack';
import TrackPlayer from 'react-native-track-player';
import Play from '@/assets/icons/play.svg';
import Shuffle from '@/assets/icons/shuffle.svg';
import useDefaultStyles from '@/components/Colors';
@@ -25,14 +24,23 @@ import CoverImage from '@/components/CoverImage';
import ticksToDuration from '@/utility/ticksToDuration';
import { t } from '@/localisation';
import { SafeScrollView, useNavigationOffsets } from '@/components/SafeNavigatorView';
import { groupBy } from 'lodash';
import Divider from '@/components/Divider';
const styles = StyleSheet.create({
index: {
marginRight: 12
marginRight: 12,
textAlign: 'right',
},
activeText: {
fontWeight: '500',
},
discContainer: {
flexDirection: 'row',
gap: 24,
alignItems: 'center',
marginBottom: 12,
}
});
const AlbumImageContainer = styled.View`
@@ -53,7 +61,7 @@ const TrackContainer = styled.View<{ isPlaying: boolean, small?: boolean }>`
`}
${props => props.small && css`
padding: ${Platform.select({ ios: '8px 4px', android: '4px'})};
padding: ${Platform.select({ ios: '8px 4px', android: '4px' })};
`}
`;
@@ -98,6 +106,18 @@ const TrackListView: React.FC<TrackListViewProps> = ({
), 0)
), [trackIds, tracks]);
// Split all tracks into trackgroups depending on their parent id (i.e. disc
// number).
const trackGroups: [string, string[]][] = useMemo(() => {
// GUARD: Only apply this rendering style for albums
if (listNumberingStyle !== 'album') {
return [['0', trackIds]];
}
const groups = groupBy(trackIds, (id) => tracks[id]?.ParentIndexNumber);
return Object.entries(groups);
}, [trackIds, tracks, listNumberingStyle]);
// Retrieve helpers
const getImage = useGetImage();
const playTracks = usePlayTracks();
@@ -105,16 +125,34 @@ const TrackListView: React.FC<TrackListViewProps> = ({
const navigation = useNavigation<NavigationProp>();
const dispatch = useAppDispatch();
// Visual helpers
const { indexWidth } = useMemo(() => {
// Retrieve the largest index in the current set of tracks
const largestIndex = trackIds.reduce((max, trackId, i) => {
// Retrieve the index for this trackid, depending on settings
const index = listNumberingStyle === 'index'
? i + 1
: tracks[trackId]?.IndexNumber;
// Check that the current index is larger than the current max.
return index > max ? index : max;
}, 0);
// Retrieve the number of digits in the largest index
const noDigits = largestIndex.toFixed(0).toString().length;
// Set a minWidth proportional to the largest amount of digits in an index
return StyleSheet.create({ indexWidth: { minWidth: noDigits * 8 } });
}, [trackIds, tracks, listNumberingStyle]);
// Setup callbacks
const playEntity = useCallback(() => { playTracks(trackIds); }, [playTracks, trackIds]);
const shuffleEntity = useCallback(() => { playTracks(trackIds, { shuffle: true }); }, [playTracks, trackIds]);
const selectTrack = useCallback(async (index: number) => {
await playTracks(trackIds, { play: false });
await TrackPlayer.skip(index);
await TrackPlayer.play();
await playTracks(trackIds, { playIndex: index });
}, [playTracks, trackIds]);
const longPressTrack = useCallback((index: number) => {
navigation.navigate('TrackPopupMenu', { trackId: trackIds[index].toString() });
const longPressTrack = useCallback((index: number) => {
navigation.navigate('TrackPopupMenu', { trackId: trackIds[index].toString() });
}, [navigation, trackIds]);
const downloadAllTracks = useCallback(() => {
trackIds.forEach((trackId) => dispatch(queueTrackForDownload(trackId)));
@@ -141,85 +179,96 @@ const TrackListView: React.FC<TrackListViewProps> = ({
<WrappableButton title={shuffleButtonText} icon={Shuffle} onPress={shuffleEntity} testID="shuffle-album" />
</WrappableButtonRow>
<View style={{ marginTop: 8 }}>
{trackIds.map((trackId, i) =>
<TouchableHandler
key={trackId}
id={i}
onPress={selectTrack}
onLongPress={longPressTrack}
testID={`play-track-${trackId}`}
>
<TrackContainer
isPlaying={currentTrack?.backendId === trackId || false}
style={[
defaultStyles.border,
currentTrack?.backendId === trackId ? defaultStyles.activeBackground : null
]}
>
<Text
style={[
styles.index,
defaultStyles.textQuarterOpacity,
currentTrack?.backendId === trackId && styles.activeText,
currentTrack?.backendId === trackId && defaultStyles.themeColorQuarterOpacity,
]}
numberOfLines={1}
{trackGroups.map(([discNo, groupTrackIds]) => (
<View key={`disc_${discNo}`} style={{ marginBottom: 24 }}>
{trackGroups.length > 1 && (
<View style={styles.discContainer}>
<SubHeader>{t('disc')} {discNo}</SubHeader>
<Divider />
</View>
)}
{groupTrackIds.map((trackId, i) =>
<TouchableHandler
key={trackId}
id={i}
onPress={selectTrack}
onLongPress={longPressTrack}
testID={`play-track-${trackId}`}
>
{listNumberingStyle === 'index'
? i + 1
: tracks[trackId]?.IndexNumber}
</Text>
<View style={{ flexShrink: 1 }}>
<Text
<TrackContainer
isPlaying={currentTrack?.backendId === trackId || false}
style={[
currentTrack?.backendId === trackId && styles.activeText,
currentTrack?.backendId === trackId && defaultStyles.themeColor,
{
flexShrink: 1,
marginRight: 4,
}
defaultStyles.border,
currentTrack?.backendId === trackId ? defaultStyles.activeBackground : null
]}
numberOfLines={1}
>
{tracks[trackId]?.Name}
</Text>
{itemDisplayStyle === 'playlist' && (
<Text
style={[
styles.index,
defaultStyles.textQuarterOpacity,
currentTrack?.backendId === trackId && styles.activeText,
currentTrack?.backendId === trackId && defaultStyles.themeColor,
{
flexShrink: 1,
marginRight: 4,
opacity: currentTrack?.backendId === trackId ? 0.5 : 0.25,
}
currentTrack?.backendId === trackId && defaultStyles.themeColorQuarterOpacity,
indexWidth,
]}
numberOfLines={1}
>
{tracks[trackId]?.Artists.join(', ')}
{listNumberingStyle === 'index'
? i + 1
: tracks[trackId]?.IndexNumber}
</Text>
)}
</View>
<View style={{ marginLeft: 'auto', flexDirection: 'row' }}>
<Text
style={[
{ marginRight: 12 },
defaultStyles.textQuarterOpacity,
currentTrack?.backendId === trackId && styles.activeText,
currentTrack?.backendId === trackId && defaultStyles.themeColorQuarterOpacity,
]}
numberOfLines={1}
>
{ticksToDuration(tracks[trackId]?.RunTimeTicks || 0)}
</Text>
<DownloadIcon
trackId={trackId}
fill={currentTrack?.backendId === trackId ? defaultStyles.themeColorQuarterOpacity.color : undefined}
/>
</View>
</TrackContainer>
</TouchableHandler>
)}
<View style={{ flexShrink: 1 }}>
<Text
style={[
currentTrack?.backendId === trackId && styles.activeText,
currentTrack?.backendId === trackId && defaultStyles.themeColor,
{
flexShrink: 1,
marginRight: 4,
}
]}
numberOfLines={1}
>
{tracks[trackId]?.Name}
</Text>
{itemDisplayStyle === 'playlist' && (
<Text
style={[
currentTrack?.backendId === trackId && styles.activeText,
currentTrack?.backendId === trackId && defaultStyles.themeColor,
{
flexShrink: 1,
marginRight: 4,
opacity: currentTrack?.backendId === trackId ? 0.5 : 0.25,
}
]}
numberOfLines={1}
>
{tracks[trackId]?.Artists.join(', ')}
</Text>
)}
</View>
<View style={{ marginLeft: 'auto', flexDirection: 'row' }}>
<Text
style={[
{ marginRight: 12 },
defaultStyles.textQuarterOpacity,
currentTrack?.backendId === trackId && styles.activeText,
currentTrack?.backendId === trackId && defaultStyles.themeColorQuarterOpacity,
]}
numberOfLines={1}
>
{ticksToDuration(tracks[trackId]?.RunTimeTicks || 0)}
</Text>
<DownloadIcon
trackId={trackId}
fill={currentTrack?.backendId === trackId ? defaultStyles.themeColorQuarterOpacity.color : undefined}
/>
</View>
</TrackContainer>
</TouchableHandler>
)}
</View>
))}
<Text style={{ paddingTop: 24, paddingBottom: 12, textAlign: 'center', opacity: 0.5 }}>
{t('total-duration')}{': '}{ticksToDuration(totalDuration)}
</Text>

View File

@@ -38,7 +38,7 @@ const Logo = styled.Image`
function Onboarding() {
// Get account from Redux and dispatcher
const account = useTypedSelector(state => state.settings.jellyfin);
const account = useTypedSelector(state => state.settings.credentials);
const dispatch = useAppDispatch();
// Also retrieve the navigation handler so that we can open the modal in
@@ -71,7 +71,7 @@ function Onboarding() {
</Text>
<ButtonContainer>
<Button
title={t('set-jellyfin-server')}
title={t('set-server')}
onPress={handleClick}/>
</ButtonContainer>
</TextContainer>

View File

@@ -8,7 +8,7 @@ import { Album, AlbumTrack } from '@/store/music/types';
import { FlatList } from 'react-native-gesture-handler';
import TouchableHandler from '@/components/TouchableHandler';
import { useNavigation } from '@react-navigation/native';
import { useGetImage } from '@/utility/JellyfinApi';
import { useGetImage } from '@/utility/JellyfinApi/lib';
import FastImage from 'react-native-fast-image';
import { t } from '@/localisation';
import useDefaultStyles, { ColoredBlurView } from '@/components/Colors';
@@ -298,7 +298,7 @@ export default function Search() {
<TouchableHandler<string> id={album.Id} onPress={selectAlbum} testID={`search-result-${album.Id}`}>
<SearchResult>
<ShadowWrapper>
<AlbumImage source={{ uri: getImage(album.Id) }} style={defaultStyles.imageBackground} />
<AlbumImage source={{ uri: getImage(album) }} style={defaultStyles.imageBackground} />
</ShadowWrapper>
<View style={{ flex: 1 }}>
<Text numberOfLines={1}>

View File

@@ -27,7 +27,7 @@ export function SettingsList() {
return (
<SafeScrollView>
<ListButton onPress={handleLibraryClick}>{t('jellyfin-library')}</ListButton>
<ListButton onPress={handleLibraryClick}>{t('library')}</ListButton>
<ListButton onPress={handleCacheClick}>{t('setting-cache')}</ListButton>
<ListButton onPress={handleSentryClick}>{t('error-reporting')}</ListButton>
<ListButton onPress={handlePlaybackReportingClick}>{t('playback-reporting')}</ListButton>
@@ -50,7 +50,7 @@ export default function Settings() {
headerBackground: () => <ColoredBlurView style={StyleSheet.absoluteFill} />,
}}>
<Stack.Screen name="SettingList" component={SettingsList} options={{ headerTitle: t('settings') }} />
<Stack.Screen name="Library" component={Library} options={{ headerTitle: t('jellyfin-library') }} />
<Stack.Screen name="Library" component={Library} options={{ headerTitle: t('library') }} />
<Stack.Screen name="Cache" component={Cache} options={{ headerTitle: t('setting-cache') }} />
<Stack.Screen name="Sentry" component={Sentry} options={{ headerTitle: t('error-reporting') }} />
<Stack.Screen name="Playback Reporting" component={PlaybackReporting} options={{ headerTitle: t('playback-reporting')}} />

View File

@@ -11,25 +11,25 @@ import { InputContainer, Input } from '../components/Input';
export default function LibrarySettings() {
const defaultStyles = useDefaultStyles();
const { jellyfin } = useTypedSelector(state => state.settings);
const { credentials } = useTypedSelector(state => state.settings);
const navigation = useNavigation<NavigationProp>();
const handleSetLibrary = useCallback(() => navigation.navigate('SetJellyfinServer'), [navigation]);
return (
<Container>
<InputContainer>
<Paragraph style={defaultStyles.text}>{t('jellyfin-server-url')}</Paragraph>
<Input placeholder="https://jellyfin.yourserver.com/" value={jellyfin?.uri} editable={false} style={defaultStyles.input} />
<Paragraph style={defaultStyles.text}>{t('server-url')}</Paragraph>
<Input placeholder="https://jellyfin.yourserver.com/" value={credentials?.uri} editable={false} style={defaultStyles.input} />
</InputContainer>
<InputContainer>
<Paragraph style={defaultStyles.text}>{t('jellyfin-access-token')}</Paragraph>
<Input placeholder="deadbeefdeadbeefdeadbeef" value={jellyfin?.access_token} editable={false} style={defaultStyles.input} />
<Paragraph style={defaultStyles.text}>{t('access-token')}</Paragraph>
<Input placeholder="deadbeefdeadbeefdeadbeef" value={credentials?.access_token} editable={false} style={defaultStyles.input} />
</InputContainer>
<InputContainer>
<Paragraph style={defaultStyles.text}>{t('jellyfin-user-id')}</Paragraph>
<Input placeholder="deadbeefdeadbeefdeadbeef" value={jellyfin?.user_id} editable={false} style={defaultStyles.input} />
<Paragraph style={defaultStyles.text}>{t('user-id')}</Paragraph>
<Input placeholder="deadbeefdeadbeefdeadbeef" value={credentials?.user_id} editable={false} style={defaultStyles.input} />
</InputContainer>
<Button title={t('set-jellyfin-server')} onPress={handleSetLibrary} />
<Button title={t('set-server')} onPress={handleSetLibrary} />
</Container>
);
}

View File

@@ -1,4 +1,5 @@
import React from 'react';
import { StyleSheet } from 'react-native';
import { createBottomTabNavigator, BottomTabNavigationProp } from '@react-navigation/bottom-tabs';
import { StackNavigationProp } from '@react-navigation/stack';
import { createNativeStackNavigator } from '@react-navigation/native-stack';
@@ -11,6 +12,7 @@ import Downloads from './Downloads';
import Onboarding from './Onboarding';
import TrackPopupMenu from './modals/TrackPopupMenu';
import SetJellyfinServer from './modals/SetJellyfinServer';
import ErrorReportingPopup from './modals/ErrorReportingPopup';
import SearchIcon from '@/assets/icons/magnifying-glass.svg';
import NotesIcon from '@/assets/icons/notes.svg';
@@ -19,11 +21,10 @@ import DownloadsIcon from '@/assets/icons/arrow-down-to-line.svg';
import { useTypedSelector } from '@/store';
import { t } from '@/localisation';
import ErrorReportingAlert from '@/utility/ErrorReportingAlert';
import ErrorReportingPopup from './modals/ErrorReportingPopup';
import Player from './modals/Player';
import { StyleSheet } from 'react-native';
import useDefaultStyles, { ColoredBlurView } from '@/components/Colors';
import Player from './modals/Player';
import { StackParams } from './types';
import Lyrics from './modals/Lyrics';
const Stack = createNativeStackNavigator<StackParams>();
const Tab = createBottomTabNavigator();
@@ -36,7 +37,7 @@ type Screens = {
function Screens() {
const styles = useDefaultStyles();
const isOnboardingComplete = useTypedSelector(state => state.settings.isOnboardingComplete);
// GUARD: If onboarding has not been completed, we instead render the
// onboarding component, so that the user can get setup in the app.
if (!isOnboardingComplete) {
@@ -91,12 +92,16 @@ export default function Routes() {
<Stack.Navigator screenOptions={{
presentation: 'modal',
headerShown: false,
contentStyle: {
backgroundColor: 'transparent'
}
}} id="MAIN">
<Stack.Screen name="Screens" component={Screens} />
<Stack.Screen name="SetJellyfinServer" component={SetJellyfinServer} />
<Stack.Screen name="TrackPopupMenu" component={TrackPopupMenu} options={{ presentation: 'formSheet' }} />
<Stack.Screen name="ErrorReporting" component={ErrorReportingPopup} />
<Stack.Screen name="Player" component={Player} />
<Stack.Screen name="Lyrics" component={Lyrics} />
</Stack.Navigator>
);
}
@@ -104,4 +109,4 @@ export default function Routes() {
export type NavigationProp = CompositeNavigationProp<
StackNavigationProp<Routes>,
BottomTabNavigationProp<Screens>
>;
>;

View File

@@ -0,0 +1,73 @@
import React, { memo, useCallback, useEffect, useMemo } from 'react';
import useDefaultStyles from '@/components/Colors';
import {LayoutChangeEvent, StyleProp, TextStyle, ViewProps} from 'react-native';
import styled from 'styled-components/native';
import Animated, { useAnimatedStyle, useDerivedValue, withTiming } from 'react-native-reanimated';
const Container = styled(Animated.View)`
`;
const LyricsText = styled(Animated.Text)`
flex: 1;
font-size: 24px;
`;
export interface LyricsLineProps extends Omit<ViewProps, 'onLayout'> {
text?: string;
start: number;
end: number;
position: number;
index: number;
onActive: (index: number) => void;
onLayout: (index: number, event: LayoutChangeEvent) => void;
size: 'small' | 'full';
}
/**
* A single lyric line
*/
function LyricsLine({
text, start, end, position, size, onLayout, onActive, index, ...viewProps
}: LyricsLineProps) {
const defaultStyles = useDefaultStyles();
// Pass on layout changes to the parent
const handleLayout = useCallback((e: LayoutChangeEvent) => {
onLayout?.(index, e);
}, [onLayout, index]);
// Determine whether the loader should be displayed
const active = useMemo(() => (
position > start && position < end
), [start, end, position]);
const past = useMemo(() => position > end, [end, position]);
// Call the parent when the active state changes
useEffect(() => {
if (active) onActive(index);
}, [onActive, active, index]);
// Determine the current style for this line
const lyricsTextStyle: StyleProp<TextStyle> = useMemo(() => ({
color: active ? defaultStyles.themeColor.color : defaultStyles.text.color,
opacity: active ? 1 : (past ? 0.25 : 0.7),
transformOrigin: 'left center',
fontSize: size === 'full' ? 24 : 18,
}), [active, defaultStyles, size, past]);
const scale = useDerivedValue(() => withTiming(active ? 1.05 : 1));
const animatedStyle = useAnimatedStyle(() => ({
transform: [{ scale: scale.value }],
}));
return (
<Container {...viewProps} onLayout={handleLayout} >
<LyricsText style={[lyricsTextStyle, animatedStyle]}>
{text}
</LyricsText>
</Container>
);
}
export default memo(LyricsLine);

View File

@@ -0,0 +1,86 @@
import useDefaultStyles from '@/components/Colors';
import ProgressTrack, { calculateProgressTranslation, ProgressTrackContainer } from '@/components/Progresstrack';
import React, { useCallback, useEffect, useMemo } from 'react';
import { LayoutChangeEvent } from 'react-native';
import { useDerivedValue, useAnimatedStyle, useSharedValue, withTiming } from 'react-native-reanimated';
import { ViewProps } from 'react-native-svg/lib/typescript/fabric/utils';
export interface LyricsProgressProps extends Omit<ViewProps, 'onLayout'> {
start: number;
end: number;
position: number;
index: number;
onActive: (index: number) => void;
onLayout: (index: number, event: LayoutChangeEvent) => void;
}
/**
* Displays a loading bar when there is a silence in the lyrics.
*/
export default function LyricsProgress({
start, end, position, index, onLayout, onActive, style, ...props
}: LyricsProgressProps) {
const defaultStyles = useDefaultStyles();
// Keep a reference to the width of the container
const width = useSharedValue(0);
// Pass on layout changes to the parent
const handleLayout = useCallback((e: LayoutChangeEvent) => {
onLayout?.(index, e);
width.value = e.nativeEvent.layout.width;
}, [onLayout, index, width]);
// Determine whether the loader should be displayed
const active = useMemo(() => (
position > start && position < end
), [start, end, position]);
// Call the parent when the active state changes
useEffect(() => {
if (active) onActive(index);
}, [onActive, active, index]);
// Determine the duration of the progress bar
const duration = useMemo(() => (end - start), [end, start]);
// Calculate the progress animation
const progressAnimation = useDerivedValue(() => {
// GUARD: If the animatino is not active, hide the progress bar
if (!active) return -1_000;
// Calculate how far along we are
const progress = calculateProgressTranslation(position - start, end - start, width.value);
// Move to that position with easing
return withTiming(progress, { duration: 200 });
});
// Calculate the styles according to the progress
const progressStyles = useAnimatedStyle(() => {
return {
transform: [
{ translateX: progressAnimation.value }
]
};
});
// GUARD: Only show durations if they last for more than 5 seconds.
if (duration < 5e7) {
return null;
}
return (
<ProgressTrackContainer
{...props}
style={[
defaultStyles.trackBackground,
{ flexGrow: 0, marginVertical: 8 },
style
]}
onLayout={handleLayout}
>
<ProgressTrack style={[progressStyles, defaultStyles.themeBackground]} />
</ProgressTrackContainer>
);
}

Some files were not shown because too many files have changed in this diff Show More