From 88ac94ebeb0ab0f552ad86ce93c8f2a4f5466570 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:24:24 +0100 Subject: [PATCH 01/39] chore(deps): Update actions/checkout action to v6.0.2 (#1398) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/build-apps.yml | 8 ++++---- .github/workflows/check-lockfile.yml | 2 +- .github/workflows/ci-codeql.yml | 2 +- .github/workflows/crowdin.yml | 2 +- .github/workflows/linting.yml | 6 +++--- .github/workflows/update-issue-form.yml | 2 +- 6 files changed, 11 insertions(+), 11 deletions(-) diff --git a/.github/workflows/build-apps.yml b/.github/workflows/build-apps.yml index 39f9057b..8bc71bfb 100644 --- a/.github/workflows/build-apps.yml +++ b/.github/workflows/build-apps.yml @@ -33,7 +33,7 @@ jobs: swap-storage: false - name: ๐Ÿ“ฅ Checkout code - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: ref: ${{ github.event.pull_request.head.sha || github.sha }} fetch-depth: 0 @@ -116,7 +116,7 @@ jobs: swap-storage: false - name: ๐Ÿ“ฅ Checkout code - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: ref: ${{ github.event.pull_request.head.sha || github.sha }} fetch-depth: 0 @@ -187,7 +187,7 @@ jobs: steps: - name: ๐Ÿ“ฅ Checkout code - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: ref: ${{ github.event.pull_request.head.sha || github.sha }} fetch-depth: 0 @@ -251,7 +251,7 @@ jobs: steps: - name: ๐Ÿ“ฅ Checkout code - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: ref: ${{ github.event.pull_request.head.sha || github.sha }} fetch-depth: 0 diff --git a/.github/workflows/check-lockfile.yml b/.github/workflows/check-lockfile.yml index 2173ccfc..dd765c2a 100644 --- a/.github/workflows/check-lockfile.yml +++ b/.github/workflows/check-lockfile.yml @@ -19,7 +19,7 @@ jobs: steps: - name: ๐Ÿ“ฅ Checkout repository - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: ref: ${{ github.event.pull_request.head.sha || github.sha }} show-progress: false diff --git a/.github/workflows/ci-codeql.yml b/.github/workflows/ci-codeql.yml index 58d806b5..bc2808bf 100644 --- a/.github/workflows/ci-codeql.yml +++ b/.github/workflows/ci-codeql.yml @@ -24,7 +24,7 @@ jobs: steps: - name: ๐Ÿ“ฅ Checkout repository - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - name: ๐Ÿ Initialize CodeQL uses: github/codeql-action/init@cdefb33c0f6224e58673d9004f47f7cb3e328b89 # v4.31.10 diff --git a/.github/workflows/crowdin.yml b/.github/workflows/crowdin.yml index 69a3c86d..c99342d2 100644 --- a/.github/workflows/crowdin.yml +++ b/.github/workflows/crowdin.yml @@ -23,7 +23,7 @@ jobs: steps: - name: ๐Ÿ“ฅ Checkout Repository - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: fetch-depth: 0 diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index af981cd1..f72afbe6 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -51,7 +51,7 @@ jobs: contents: read steps: - name: Checkout Repository - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: ref: ${{ github.event.pull_request.head.sha || github.sha }} fetch-depth: 0 @@ -69,7 +69,7 @@ jobs: runs-on: ubuntu-24.04 steps: - name: ๐Ÿ›’ Checkout repository - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: ref: ${{ github.event.pull_request.head.sha || github.sha }} submodules: recursive @@ -100,7 +100,7 @@ jobs: steps: - name: "๐Ÿ“ฅ Checkout PR code" - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 with: ref: ${{ github.event.pull_request.head.sha || github.sha }} submodules: recursive diff --git a/.github/workflows/update-issue-form.yml b/.github/workflows/update-issue-form.yml index 7a7b0763..6ca9d320 100644 --- a/.github/workflows/update-issue-form.yml +++ b/.github/workflows/update-issue-form.yml @@ -18,7 +18,7 @@ jobs: steps: - name: ๐Ÿ“ฅ Checkout repository - uses: actions/checkout@8e8c483db84b4bee98b60c0593521ed34d9990e8 # v6.0.1 + uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - name: "๐ŸŸข Setup Node.js" uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 From b063fd640529152309a7ef6d54564a200b205fb5 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:24:35 +0100 Subject: [PATCH 02/39] chore(deps): Update oven-sh/setup-bun action to v2.1.2 (#1399) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/build-apps.yml | 8 ++++---- .github/workflows/check-lockfile.yml | 2 +- .github/workflows/linting.yml | 4 ++-- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/.github/workflows/build-apps.yml b/.github/workflows/build-apps.yml index 8bc71bfb..4580e18b 100644 --- a/.github/workflows/build-apps.yml +++ b/.github/workflows/build-apps.yml @@ -41,7 +41,7 @@ jobs: show-progress: false - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@b7a1c7ccf290d58743029c4f6903da283811b979 # v2.1.0 + uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 with: bun-version: latest @@ -124,7 +124,7 @@ jobs: show-progress: false - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@b7a1c7ccf290d58743029c4f6903da283811b979 # v2.1.0 + uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 with: bun-version: latest @@ -195,7 +195,7 @@ jobs: show-progress: false - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@b7a1c7ccf290d58743029c4f6903da283811b979 # v2.1.0 + uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 with: bun-version: latest @@ -259,7 +259,7 @@ jobs: show-progress: false - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@b7a1c7ccf290d58743029c4f6903da283811b979 # v2.1.0 + uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 with: bun-version: latest diff --git a/.github/workflows/check-lockfile.yml b/.github/workflows/check-lockfile.yml index dd765c2a..61f9f6cc 100644 --- a/.github/workflows/check-lockfile.yml +++ b/.github/workflows/check-lockfile.yml @@ -27,7 +27,7 @@ jobs: fetch-depth: 0 - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@b7a1c7ccf290d58743029c4f6903da283811b979 # v2.1.0 + uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 with: bun-version: latest diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index f72afbe6..08e0a884 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -76,7 +76,7 @@ jobs: fetch-depth: 0 - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@b7a1c7ccf290d58743029c4f6903da283811b979 # v2.1.0 + uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 with: bun-version: latest @@ -112,7 +112,7 @@ jobs: node-version: '24.x' - name: "๐Ÿž Setup Bun" - uses: oven-sh/setup-bun@b7a1c7ccf290d58743029c4f6903da283811b979 # v2.1.0 + uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 with: bun-version: latest From f762b9017f2a3570a190d31bc0d088a1151188d5 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:24:43 +0100 Subject: [PATCH 03/39] chore(deps): Update crowdin/github-action action to v2.14.0 (#1400) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/crowdin.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/crowdin.yml b/.github/workflows/crowdin.yml index c99342d2..c73cad70 100644 --- a/.github/workflows/crowdin.yml +++ b/.github/workflows/crowdin.yml @@ -28,7 +28,7 @@ jobs: fetch-depth: 0 - name: ๐ŸŒ Sync Translations with Crowdin - uses: crowdin/github-action@60debf382ee245b21794321190ad0501db89d8c1 # v2.13.0 + uses: crowdin/github-action@b4b468cffefb50bdd99dd83e5d2eaeb63c880380 # v2.14.0 with: upload_sources: true upload_translations: true From 0b61fb7d9853a697edce06c209d744df2c61e002 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:24:53 +0100 Subject: [PATCH 04/39] chore(deps): Update peter-evans/create-pull-request action to v8.1.0 (#1401) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/update-issue-form.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/update-issue-form.yml b/.github/workflows/update-issue-form.yml index 6ca9d320..25fa3319 100644 --- a/.github/workflows/update-issue-form.yml +++ b/.github/workflows/update-issue-form.yml @@ -54,7 +54,7 @@ jobs: dry_run: no-push - name: ๐Ÿ“ฌ Commit and create pull request - uses: peter-evans/create-pull-request@98357b18bf14b5342f975ff684046ec3b2a07725 # v8.0.0 + uses: peter-evans/create-pull-request@c0f553fe549906ede9cf27b5156039d195d2ece0 # v8.1.0 with: add-paths: .github/ISSUE_TEMPLATE/bug_report.yml branch: ci-update-bug-report From cb5cb8bff70ffab9f035ac41f7efbadac21820b2 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:25:02 +0100 Subject: [PATCH 05/39] chore(deps): Update dependency lodash to v4.17.23 [SECURITY] (#1394) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- bun.lock | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/bun.lock b/bun.lock index bdcea301..43fce316 100644 --- a/bun.lock +++ b/bun.lock @@ -52,7 +52,7 @@ "expo-web-browser": "~15.0.10", "i18next": "^25.0.0", "jotai": "2.16.2", - "lodash": "4.17.21", + "lodash": "4.17.23", "nativewind": "^2.0.11", "patch-package": "^8.0.0", "react": "19.1.0", @@ -1376,7 +1376,7 @@ "locate-path": ["locate-path@6.0.0", "", { "dependencies": { "p-locate": "^5.0.0" } }, "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw=="], - "lodash": ["lodash@4.17.21", "", {}, "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg=="], + "lodash": ["lodash@4.17.23", "", {}, "sha512-LgVTMpQtIopCi79SJeDiP0TfWi5CNEc/L/aRdTh3yIvmZXTnheWpKjSZhnvMl8iXbC1tFg9gdHHDMLoV7CnG+w=="], "lodash.debounce": ["lodash.debounce@4.0.8", "", {}, "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow=="], diff --git a/package.json b/package.json index 2679912c..c2968426 100644 --- a/package.json +++ b/package.json @@ -72,7 +72,7 @@ "expo-web-browser": "~15.0.10", "i18next": "^25.0.0", "jotai": "2.16.2", - "lodash": "4.17.21", + "lodash": "4.17.23", "nativewind": "^2.0.11", "patch-package": "^8.0.0", "react": "19.1.0", From 9d82549cd6e27aaa033013654c0712e7ca6a6932 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:25:12 +0100 Subject: [PATCH 06/39] chore(deps): Update dependency @tanstack/react-query to v5.90.20 (#1405) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- bun.lock | 6 +++--- package.json | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/bun.lock b/bun.lock index 43fce316..984ad0a2 100644 --- a/bun.lock +++ b/bun.lock @@ -19,7 +19,7 @@ "@shopify/flash-list": "2.0.2", "@tanstack/query-sync-storage-persister": "^5.90.18", "@tanstack/react-pacer": "^0.19.1", - "@tanstack/react-query": "5.90.17", + "@tanstack/react-query": "5.90.20", "@tanstack/react-query-persist-client": "^5.90.18", "axios": "^1.7.9", "expo": "~54.0.31", @@ -602,7 +602,7 @@ "@tanstack/react-pacer": ["@tanstack/react-pacer@0.19.1", "", { "dependencies": { "@tanstack/pacer": "0.17.1", "@tanstack/react-store": "^0.8.0" }, "peerDependencies": { "react": ">=16.8", "react-dom": ">=16.8" } }, "sha512-wfGwKLo2gosKr5tsXico+jWJ8LsWsBC8MA1HVtUY/D6dhFduEVizKxRUcvP60I3dRvnoXDbN202g4feJHlivnA=="], - "@tanstack/react-query": ["@tanstack/react-query@5.90.17", "", { "dependencies": { "@tanstack/query-core": "5.90.17" }, "peerDependencies": { "react": "^18 || ^19" } }, "sha512-PGc2u9KLwohDUSchjW9MZqeDQJfJDON7y4W7REdNBgiFKxQy+Pf7eGjiFWEj5xPqKzAeHYdAb62IWI1a9UJyGQ=="], + "@tanstack/react-query": ["@tanstack/react-query@5.90.20", "", { "dependencies": { "@tanstack/query-core": "5.90.20" }, "peerDependencies": { "react": "^18 || ^19" } }, "sha512-vXBxa+qeyveVO7OA0jX1z+DeyCA4JKnThKv411jd5SORpBKgkcVnYKCiBgECvADvniBX7tobwBmg01qq9JmMJw=="], "@tanstack/react-query-persist-client": ["@tanstack/react-query-persist-client@5.90.18", "", { "dependencies": { "@tanstack/query-persist-client-core": "5.91.15" }, "peerDependencies": { "@tanstack/react-query": "^5.90.16", "react": "^18 || ^19" } }, "sha512-ToVRTVpjzTrd9S/p7JIvGdLs+Xtz9aDMM/7+TQGSV9notY8Jt64irfAAAkZ05syftLKS+3KPgyKAnHcVeKVbWQ=="], @@ -2242,7 +2242,7 @@ "@react-navigation/native-stack/color": ["color@4.2.3", "", { "dependencies": { "color-convert": "^2.0.1", "color-string": "^1.9.0" } }, "sha512-1rXeuUUiGGrykh+CeBdu5Ie7OJwinCgQY0bc7GCRxy5xVHy+moaqkpL/jqQq0MtQOeYcrqEz4abc5f0KtU7W4A=="], - "@tanstack/react-query/@tanstack/query-core": ["@tanstack/query-core@5.90.17", "", {}, "sha512-hDww+RyyYhjhUfoYQ4es6pbgxY7LNiPWxt4l1nJqhByjndxJ7HIjDxTBtfvMr5HwjYavMrd+ids5g4Rfev3lVQ=="], + "@tanstack/react-query/@tanstack/query-core": ["@tanstack/query-core@5.90.20", "", {}, "sha512-OMD2HLpNouXEfZJWcKeVKUgQ5n+n3A2JFmBaScpNDUqSrQSjiveC7dKMe53uJUg1nDG16ttFPz2xfilz6i2uVg=="], "@types/babel__core/@babel/parser": ["@babel/parser@7.28.5", "", { "dependencies": { "@babel/types": "^7.28.5" }, "bin": "./bin/babel-parser.js" }, "sha512-KKBU1VGYR7ORr3At5HAtUQ+TV3SzRCXmA/8OdDZiLDBIZxVyzXuztPjfLd3BV1PRAQGCMWWSHYhL0F8d5uHBDQ=="], diff --git a/package.json b/package.json index c2968426..d916d4f7 100644 --- a/package.json +++ b/package.json @@ -39,7 +39,7 @@ "@shopify/flash-list": "2.0.2", "@tanstack/query-sync-storage-persister": "^5.90.18", "@tanstack/react-pacer": "^0.19.1", - "@tanstack/react-query": "5.90.17", + "@tanstack/react-query": "5.90.20", "@tanstack/react-query-persist-client": "^5.90.18", "axios": "^1.7.9", "expo": "~54.0.31", From a77e86be21de334727cfebb27c34a98c25e8251b Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:25:22 +0100 Subject: [PATCH 07/39] chore(deps): Update github/codeql-action action to v4.32.0 (#1410) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/ci-codeql.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/ci-codeql.yml b/.github/workflows/ci-codeql.yml index bc2808bf..29330ac7 100644 --- a/.github/workflows/ci-codeql.yml +++ b/.github/workflows/ci-codeql.yml @@ -27,13 +27,13 @@ jobs: uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - name: ๐Ÿ Initialize CodeQL - uses: github/codeql-action/init@cdefb33c0f6224e58673d9004f47f7cb3e328b89 # v4.31.10 + uses: github/codeql-action/init@b20883b0cd1f46c72ae0ba6d1090936928f9fa30 # v4.32.0 with: languages: ${{ matrix.language }} queries: +security-extended,security-and-quality - name: ๐Ÿ› ๏ธ Autobuild - uses: github/codeql-action/autobuild@cdefb33c0f6224e58673d9004f47f7cb3e328b89 # v4.31.10 + uses: github/codeql-action/autobuild@b20883b0cd1f46c72ae0ba6d1090936928f9fa30 # v4.32.0 - name: ๐Ÿงช Perform CodeQL Analysis - uses: github/codeql-action/analyze@cdefb33c0f6224e58673d9004f47f7cb3e328b89 # v4.31.10 + uses: github/codeql-action/analyze@b20883b0cd1f46c72ae0ba6d1090936928f9fa30 # v4.32.0 From 5443222e4e3e3c3ccd40fe37d511451a4b93f5cc Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:25:31 +0100 Subject: [PATCH 08/39] chore(deps): Update actions/cache action to v5.0.2 (#1397) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/build-apps.yml | 16 ++++++++-------- .github/workflows/check-lockfile.yml | 2 +- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.github/workflows/build-apps.yml b/.github/workflows/build-apps.yml index 4580e18b..b300c04d 100644 --- a/.github/workflows/build-apps.yml +++ b/.github/workflows/build-apps.yml @@ -46,7 +46,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: ~/.bun/install/cache key: ${{ runner.os }}-${{ runner.arch }}-bun-develop-${{ hashFiles('bun.lock') }} @@ -60,7 +60,7 @@ jobs: bun run submodule-reload - name: ๐Ÿ’พ Cache Gradle global - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: | ~/.gradle/caches @@ -73,7 +73,7 @@ jobs: run: bun run prebuild - name: ๐Ÿ’พ Cache project Gradle (.gradle) - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: android/.gradle key: ${{ runner.os }}-android-gradle-develop-${{ hashFiles('android/**/build.gradle', 'android/gradle/wrapper/gradle-wrapper.properties') }} @@ -129,7 +129,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: ~/.bun/install/cache key: ${{ runner.os }}-${{ runner.arch }}-bun-develop-${{ hashFiles('bun.lock') }} @@ -143,7 +143,7 @@ jobs: bun run submodule-reload - name: ๐Ÿ’พ Cache Gradle global - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: | ~/.gradle/caches @@ -156,7 +156,7 @@ jobs: run: bun run prebuild:tv - name: ๐Ÿ’พ Cache project Gradle (.gradle) - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: android/.gradle key: ${{ runner.os }}-android-gradle-develop-${{ hashFiles('android/**/build.gradle', 'android/gradle/wrapper/gradle-wrapper.properties') }} @@ -200,7 +200,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: ~/.bun/install/cache key: ${{ runner.os }}-bun-cache-${{ hashFiles('bun.lock') }} @@ -264,7 +264,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: ~/.bun/install/cache key: ${{ runner.os }}-bun-cache-${{ hashFiles('bun.lock') }} diff --git a/.github/workflows/check-lockfile.yml b/.github/workflows/check-lockfile.yml index 61f9f6cc..ad189f7f 100644 --- a/.github/workflows/check-lockfile.yml +++ b/.github/workflows/check-lockfile.yml @@ -32,7 +32,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@9255dc7a253b0ccc959486e2bca901246202afeb # v5.0.1 + uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 with: path: | ~/.bun/install/cache From 7d0b6c37b89ac56967d7b115532ee04bbdbce434 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:26:01 +0100 Subject: [PATCH 09/39] chore(deps): Update dependency react-i18next to v16.5.4 (#1414) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- bun.lock | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/bun.lock b/bun.lock index 984ad0a2..3cc1111b 100644 --- a/bun.lock +++ b/bun.lock @@ -57,7 +57,7 @@ "patch-package": "^8.0.0", "react": "19.1.0", "react-dom": "19.1.0", - "react-i18next": "16.5.3", + "react-i18next": "16.5.4", "react-native": "0.81.5", "react-native-awesome-slider": "^2.9.0", "react-native-bottom-tabs": "1.1.0", @@ -1640,7 +1640,7 @@ "react-freeze": ["react-freeze@1.0.4", "", { "peerDependencies": { "react": ">=17.0.0" } }, "sha512-r4F0Sec0BLxWicc7HEyo2x3/2icUTrRmDjaaRyzzn+7aDyFZliszMDOgLVwSnQnYENOlL1o569Ze2HZefk8clA=="], - "react-i18next": ["react-i18next@16.5.3", "", { "dependencies": { "@babel/runtime": "^7.28.4", "html-parse-stringify": "^3.0.1", "use-sync-external-store": "^1.6.0" }, "peerDependencies": { "i18next": ">= 25.6.2", "react": ">= 16.8.0", "typescript": "^5" }, "optionalPeers": ["typescript"] }, "sha512-fo+/NNch37zqxOzlBYrWMx0uy/yInPkRfjSuy4lqKdaecR17nvCHnEUt3QyzA8XjQ2B/0iW/5BhaHR3ZmukpGw=="], + "react-i18next": ["react-i18next@16.5.4", "", { "dependencies": { "@babel/runtime": "^7.28.4", "html-parse-stringify": "^3.0.1", "use-sync-external-store": "^1.6.0" }, "peerDependencies": { "i18next": ">= 25.6.2", "react": ">= 16.8.0", "typescript": "^5" }, "optionalPeers": ["typescript"] }, "sha512-6yj+dcfMncEC21QPhOTsW8mOSO+pzFmT6uvU7XXdvM/Cp38zJkmTeMeKmTrmCMD5ToT79FmiE/mRWiYWcJYW4g=="], "react-is": ["react-is@19.2.3", "", {}, "sha512-qJNJfu81ByyabuG7hPFEbXqNcWSU3+eVus+KJs+0ncpGfMyYdvSmxiJxbWR65lYi1I+/0HBcliO029gc4F+PnA=="], diff --git a/package.json b/package.json index d916d4f7..a25118f2 100644 --- a/package.json +++ b/package.json @@ -77,7 +77,7 @@ "patch-package": "^8.0.0", "react": "19.1.0", "react-dom": "19.1.0", - "react-i18next": "16.5.3", + "react-i18next": "16.5.4", "react-native": "0.81.5", "react-native-awesome-slider": "^2.9.0", "react-native-bottom-tabs": "1.1.0", From 8a782fb0c911246006164f6d86b134c1307197e5 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Sat, 31 Jan 2026 17:26:38 +0100 Subject: [PATCH 10/39] chore(deps): Update dependency @react-native-community/cli to v20.1.1 (#1413) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- bun.lock | 28 +++++++++++++++------------- package.json | 2 +- 2 files changed, 16 insertions(+), 14 deletions(-) diff --git a/bun.lock b/bun.lock index 3cc1111b..326bd749 100644 --- a/bun.lock +++ b/bun.lock @@ -97,7 +97,7 @@ "devDependencies": { "@babel/core": "7.28.6", "@biomejs/biome": "2.3.11", - "@react-native-community/cli": "20.1.0", + "@react-native-community/cli": "20.1.1", "@react-native-tvos/config-tv": "0.1.4", "@types/jest": "29.5.14", "@types/lodash": "4.17.23", @@ -512,29 +512,29 @@ "@radix-ui/react-use-layout-effect": ["@radix-ui/react-use-layout-effect@1.1.1", "", { "peerDependencies": { "@types/react": "*", "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" }, "optionalPeers": ["@types/react"] }, "sha512-RbJRS4UWQFkzHTTwVymMTUv8EqYhOp8dOOviLj2ugtTiXRaRQS7GLGxZTLL1jWhMeoSCf5zmcZkqTl9IiYfXcQ=="], - "@react-native-community/cli": ["@react-native-community/cli@20.1.0", "", { "dependencies": { "@react-native-community/cli-clean": "20.1.0", "@react-native-community/cli-config": "20.1.0", "@react-native-community/cli-doctor": "20.1.0", "@react-native-community/cli-server-api": "20.1.0", "@react-native-community/cli-tools": "20.1.0", "@react-native-community/cli-types": "20.1.0", "commander": "^9.4.1", "deepmerge": "^4.3.0", "execa": "^5.0.0", "find-up": "^5.0.0", "fs-extra": "^8.1.0", "graceful-fs": "^4.1.3", "picocolors": "^1.1.1", "prompts": "^2.4.2", "semver": "^7.5.2" }, "bin": { "rnc-cli": "build/bin.js" } }, "sha512-441WsVtRe4nGJ9OzA+QMU1+22lA6Q2hRWqqIMKD0wjEMLqcSfOZyu2UL9a/yRpL/dRpyUsU4n7AxqKfTKO/Csg=="], + "@react-native-community/cli": ["@react-native-community/cli@20.1.1", "", { "dependencies": { "@react-native-community/cli-clean": "20.1.1", "@react-native-community/cli-config": "20.1.1", "@react-native-community/cli-doctor": "20.1.1", "@react-native-community/cli-server-api": "20.1.1", "@react-native-community/cli-tools": "20.1.1", "@react-native-community/cli-types": "20.1.1", "commander": "^9.4.1", "deepmerge": "^4.3.0", "execa": "^5.0.0", "find-up": "^5.0.0", "fs-extra": "^8.1.0", "graceful-fs": "^4.1.3", "picocolors": "^1.1.1", "prompts": "^2.4.2", "semver": "^7.5.2" }, "bin": { "rnc-cli": "build/bin.js" } }, "sha512-aLPUx43+WSeTOaUepR2FBD5a1V0OAZ1QB2DOlRlW4fOEjtBXgv40eM/ho8g3WCvAOKfPvTvx4fZdcuovTyV81Q=="], - "@react-native-community/cli-clean": ["@react-native-community/cli-clean@20.1.0", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.0", "execa": "^5.0.0", "fast-glob": "^3.3.2", "picocolors": "^1.1.1" } }, "sha512-77L4DifWfxAT8ByHnkypge7GBMYpbJAjBGV+toowt5FQSGaTBDcBHCX+FFqFRukD5fH6i8sZ41Gtw+nbfCTTIA=="], + "@react-native-community/cli-clean": ["@react-native-community/cli-clean@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "execa": "^5.0.0", "fast-glob": "^3.3.2", "picocolors": "^1.1.1" } }, "sha512-6nGQ08w2+EcDwTFC4JFiW/wI2pLwzMrk9thz4um7tKRNW8sADX0IyCsfM2F4rHS720C0UNKYBZE9nAsfp8Vkcw=="], - "@react-native-community/cli-config": ["@react-native-community/cli-config@20.1.0", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.0", "cosmiconfig": "^9.0.0", "deepmerge": "^4.3.0", "fast-glob": "^3.3.2", "joi": "^17.2.1", "picocolors": "^1.1.1" } }, "sha512-1x9rhLLR/dKKb92Lb5O0l0EmUG08FHf+ZVyVEf9M+tX+p5QIm52MRiy43R0UAZ2jJnFApxRk+N3sxoYK4Dtnag=="], + "@react-native-community/cli-config": ["@react-native-community/cli-config@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "cosmiconfig": "^9.0.0", "deepmerge": "^4.3.0", "fast-glob": "^3.3.2", "joi": "^17.2.1", "picocolors": "^1.1.1" } }, "sha512-ajs2i56MANie/v0bMQ1BmRcrOb6MEvLT2rh/I1CA62NXGqF1Rxv6QwsN84LrADMXHRg8QiEMAIADkyDeQHt7Kg=="], - "@react-native-community/cli-config-android": ["@react-native-community/cli-config-android@20.1.0", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.0", "fast-glob": "^3.3.2", "fast-xml-parser": "^4.4.1", "picocolors": "^1.1.1" } }, "sha512-3A01ZDyFeCALzzPcwP/fleHoP3sGNq1UX7FzxkTrOFX8RRL9ntXNXQd27E56VU4BBxGAjAJT4Utw8pcOjJceIA=="], + "@react-native-community/cli-config-android": ["@react-native-community/cli-config-android@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "fast-glob": "^3.3.2", "fast-xml-parser": "^4.4.1", "picocolors": "^1.1.1" } }, "sha512-1iUV2rPAyoWPo8EceAFC2vZTF+pEd9YqS87c0aqpbGOFE0gs1rHEB+auVR8CdjzftR4U9sq6m2jrdst0rvpIkg=="], - "@react-native-community/cli-config-apple": ["@react-native-community/cli-config-apple@20.1.0", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.0", "execa": "^5.0.0", "fast-glob": "^3.3.2", "picocolors": "^1.1.1" } }, "sha512-n6JVs8Q3yxRbtZQOy05ofeb1kGtspGN3SgwPmuaqvURF9fsuS7c4/9up2Kp9C+1D2J1remPJXiZLNGOcJvfpOA=="], + "@react-native-community/cli-config-apple": ["@react-native-community/cli-config-apple@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "execa": "^5.0.0", "fast-glob": "^3.3.2", "picocolors": "^1.1.1" } }, "sha512-doepJgLJVqeJb5tNoP9hyFIcoZ1OMGO7QN/YMuCCIjbThUQe/J87XdwPol3Qrjr58KRt9xeBVz+kHeW5mtSutw=="], - "@react-native-community/cli-doctor": ["@react-native-community/cli-doctor@20.1.0", "", { "dependencies": { "@react-native-community/cli-config": "20.1.0", "@react-native-community/cli-platform-android": "20.1.0", "@react-native-community/cli-platform-apple": "20.1.0", "@react-native-community/cli-platform-ios": "20.1.0", "@react-native-community/cli-tools": "20.1.0", "command-exists": "^1.2.8", "deepmerge": "^4.3.0", "envinfo": "^7.13.0", "execa": "^5.0.0", "node-stream-zip": "^1.9.1", "ora": "^5.4.1", "picocolors": "^1.1.1", "semver": "^7.5.2", "wcwidth": "^1.0.1", "yaml": "^2.2.1" } }, "sha512-QfJF1GVjA4PBrIT3SJ0vFFIu0km1vwOmLDlOYVqfojajZJ+Dnvl0f94GN1il/jT7fITAxom///XH3/URvi7YTQ=="], + "@react-native-community/cli-doctor": ["@react-native-community/cli-doctor@20.1.1", "", { "dependencies": { "@react-native-community/cli-config": "20.1.1", "@react-native-community/cli-platform-android": "20.1.1", "@react-native-community/cli-platform-apple": "20.1.1", "@react-native-community/cli-platform-ios": "20.1.1", "@react-native-community/cli-tools": "20.1.1", "command-exists": "^1.2.8", "deepmerge": "^4.3.0", "envinfo": "^7.13.0", "execa": "^5.0.0", "node-stream-zip": "^1.9.1", "ora": "^5.4.1", "picocolors": "^1.1.1", "semver": "^7.5.2", "wcwidth": "^1.0.1", "yaml": "^2.2.1" } }, "sha512-eFpg5wWnV7uGqvLemshpgj2trPD8cckqxBuI4nT7sxKF/YpA/e3nnnyytHxPP5EnYfWbMcqfaq8hDJoOnJinGQ=="], - "@react-native-community/cli-platform-android": ["@react-native-community/cli-platform-android@20.1.0", "", { "dependencies": { "@react-native-community/cli-config-android": "20.1.0", "@react-native-community/cli-tools": "20.1.0", "execa": "^5.0.0", "logkitty": "^0.7.1", "picocolors": "^1.1.1" } }, "sha512-TeHPDThOwDppQRpndm9kCdRCBI8AMy3HSIQ+iy7VYQXL5BtZ5LfmGdusoj7nVN/ZGn0Lc6Gwts5qowyupXdeKg=="], + "@react-native-community/cli-platform-android": ["@react-native-community/cli-platform-android@20.1.1", "", { "dependencies": { "@react-native-community/cli-config-android": "20.1.1", "@react-native-community/cli-tools": "20.1.1", "execa": "^5.0.0", "logkitty": "^0.7.1", "picocolors": "^1.1.1" } }, "sha512-KPheizJQI0tVvBLy9owzpo+A9qDsDAa87e7a8xNaHnwqGpExnIzFPrbdvrltiZjstU2eB/+/UgNQxYIEd4Oc+g=="], - "@react-native-community/cli-platform-apple": ["@react-native-community/cli-platform-apple@20.1.0", "", { "dependencies": { "@react-native-community/cli-config-apple": "20.1.0", "@react-native-community/cli-tools": "20.1.0", "execa": "^5.0.0", "fast-xml-parser": "^4.4.1", "picocolors": "^1.1.1" } }, "sha512-0ih1hrYezSM2cuOlVnwBEFtMwtd8YgpTLmZauDJCv50rIumtkI1cQoOgLoS4tbPCj9U/Vn2a9BFH0DLFOOIacg=="], + "@react-native-community/cli-platform-apple": ["@react-native-community/cli-platform-apple@20.1.1", "", { "dependencies": { "@react-native-community/cli-config-apple": "20.1.1", "@react-native-community/cli-tools": "20.1.1", "execa": "^5.0.0", "fast-xml-parser": "^4.4.1", "picocolors": "^1.1.1" } }, "sha512-mQEjOzRFCcQTrCt73Q/+5WWTfUg6U2vLZv5rPuFiNrLbrwRqxVH3OLaXg5gilJkDTJC80z8iOSsdd8MRxONOig=="], - "@react-native-community/cli-platform-ios": ["@react-native-community/cli-platform-ios@20.1.0", "", { "dependencies": { "@react-native-community/cli-platform-apple": "20.1.0" } }, "sha512-XN7Da9z4WsJxtqVtEzY8q2bv22OsvzaFP5zy5+phMWNoJlU4lf7IvBSxqGYMpQ9XhYP7arDw5vmW4W34s06rnA=="], + "@react-native-community/cli-platform-ios": ["@react-native-community/cli-platform-ios@20.1.1", "", { "dependencies": { "@react-native-community/cli-platform-apple": "20.1.1" } }, "sha512-6vr10/oSjKkZO/BBgfFJNQTC/0CDF4WrN8iW9ss+Kt6ZL2QrBXLYz7fobrrboOlHwqqs5EyQadlEaNii7gKRJg=="], - "@react-native-community/cli-server-api": ["@react-native-community/cli-server-api@20.1.0", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.0", "body-parser": "^1.20.3", "compression": "^1.7.1", "connect": "^3.6.5", "errorhandler": "^1.5.1", "nocache": "^3.0.1", "open": "^6.2.0", "pretty-format": "^29.7.0", "serve-static": "^1.13.1", "ws": "^6.2.3" } }, "sha512-Tb415Oh8syXNT2zOzLzFkBXznzGaqKCiaichxKzGCDKg6JGHp3jSuCmcTcaPeYC7oc32n/S3Psw7798r4Q/7lA=="], + "@react-native-community/cli-server-api": ["@react-native-community/cli-server-api@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "body-parser": "^1.20.3", "compression": "^1.7.1", "connect": "^3.6.5", "errorhandler": "^1.5.1", "nocache": "^3.0.1", "open": "^6.2.0", "pretty-format": "^29.7.0", "serve-static": "^1.13.1", "strict-url-sanitise": "0.0.1", "ws": "^6.2.3" } }, "sha512-phHfiCa4WqfKfaoV2vGVR3ZrYQDQTpI1k+C+i6rXAxFGxPuy8IgFFVOSL543qjKPpHBVwLcA+/xAJCVpdyCtVQ=="], - "@react-native-community/cli-tools": ["@react-native-community/cli-tools@20.1.0", "", { "dependencies": { "@vscode/sudo-prompt": "^9.0.0", "appdirsjs": "^1.2.4", "execa": "^5.0.0", "find-up": "^5.0.0", "launch-editor": "^2.9.1", "mime": "^2.4.1", "ora": "^5.4.1", "picocolors": "^1.1.1", "prompts": "^2.4.2", "semver": "^7.5.2" } }, "sha512-/YmzHGOkY6Bgrv4OaA1L8rFqsBlQd1EB2/ipAoKPiieV0EcB5PUamUSuNeFU3sBZZTYQCUENwX4wgOHgFUlDnQ=="], + "@react-native-community/cli-tools": ["@react-native-community/cli-tools@20.1.1", "", { "dependencies": { "@vscode/sudo-prompt": "^9.0.0", "appdirsjs": "^1.2.4", "execa": "^5.0.0", "find-up": "^5.0.0", "launch-editor": "^2.9.1", "mime": "^2.4.1", "ora": "^5.4.1", "picocolors": "^1.1.1", "prompts": "^2.4.2", "semver": "^7.5.2" } }, "sha512-j+zX/H2X+6ZGneIDj56tZ1Hbnip5nSfnq7yGlMyF/zm3U1hKp3G1jN5v0YEfnz/zEmjr7zruh4Y06KmZrF1lrA=="], - "@react-native-community/cli-types": ["@react-native-community/cli-types@20.1.0", "", { "dependencies": { "joi": "^17.2.1" } }, "sha512-D0kDspcwgbVXyNjwicT7Bb1JgXjijTw1JJd+qxyF/a9+sHv7TU4IchV+gN38QegeXqVyM4Ym7YZIvXMFBmyJqA=="], + "@react-native-community/cli-types": ["@react-native-community/cli-types@20.1.1", "", { "dependencies": { "joi": "^17.2.1" } }, "sha512-Tp+s27I/RDONrGvWVj4IzEmga2HhJhXi8ZlZTfycMMyAcv4LG/CTPira+BUZs8nzLAJNrlJ79pVVPJPqQAe+aw=="], "@react-native-community/netinfo": ["@react-native-community/netinfo@11.4.1", "", { "peerDependencies": { "react-native": ">=0.59" } }, "sha512-B0BYAkghz3Q2V09BF88RA601XursIEA111tnc2JOaN7axJWmNefmfjZqw/KdSxKZp7CZUuPpjBmz/WCR9uaHYg=="], @@ -1854,6 +1854,8 @@ "strict-uri-encode": ["strict-uri-encode@2.0.0", "", {}, "sha512-QwiXZgpRcKkhTj2Scnn++4PKtWsH0kpzZ62L2R6c/LUVYv7hVnZqcg2+sMuT6R7Jusu1vviK/MFsu6kNJfWlEQ=="], + "strict-url-sanitise": ["strict-url-sanitise@0.0.1", "", {}, "sha512-nuFtF539K8jZg3FjaWH/L8eocCR6gegz5RDOsaWxfdbF5Jqr2VXWxZayjTwUzsWJDC91k2EbnJXp6FuWW+Z4hg=="], + "string-argv": ["string-argv@0.3.2", "", {}, "sha512-aqD2Q0144Z+/RqG52NeHEkZauTAUWJO8c6yTftGJKO3Tja5tUgIfmIl6kExvhtxSDP7fXB6DvzkfMpCd/F3G+Q=="], "string-width": ["string-width@4.2.3", "", { "dependencies": { "emoji-regex": "^8.0.0", "is-fullwidth-code-point": "^3.0.0", "strip-ansi": "^6.0.1" } }, "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g=="], diff --git a/package.json b/package.json index a25118f2..9864985a 100644 --- a/package.json +++ b/package.json @@ -117,7 +117,7 @@ "devDependencies": { "@babel/core": "7.28.6", "@biomejs/biome": "2.3.11", - "@react-native-community/cli": "20.1.0", + "@react-native-community/cli": "20.1.1", "@react-native-tvos/config-tv": "0.1.4", "@types/jest": "29.5.14", "@types/lodash": "4.17.23", From 9f9d9498917305b79008f43527bfb92a76932cc0 Mon Sep 17 00:00:00 2001 From: Alex <111128610+Alexk2309@users.noreply.github.com> Date: Thu, 19 Feb 2026 17:38:01 +1100 Subject: [PATCH 11/39] feat: Re-add native apple controls for mpv (#1411) --- app/(auth)/player/direct-player.tsx | 27 +++ .../expo/modules/mpvplayer/MpvPlayerModule.kt | 6 + modules/mpv-player/ios/MPVLayerRenderer.swift | 13 +- .../mpv-player/ios/MPVNowPlayingManager.swift | 188 ++++++++++++++++++ modules/mpv-player/ios/MpvPlayerModule.swift | 15 ++ modules/mpv-player/ios/MpvPlayerView.swift | 112 ++++++++++- modules/mpv-player/src/MpvPlayer.types.ts | 9 + 7 files changed, 361 insertions(+), 9 deletions(-) create mode 100644 modules/mpv-player/ios/MPVNowPlayingManager.swift diff --git a/app/(auth)/player/direct-player.tsx b/app/(auth)/player/direct-player.tsx index b5dcac73..a4cffe77 100644 --- a/app/(auth)/player/direct-player.tsx +++ b/app/(auth)/player/direct-player.tsx @@ -48,6 +48,7 @@ import { apiAtom, userAtom } from "@/providers/JellyfinProvider"; import { OfflineModeProvider } from "@/providers/OfflineModeProvider"; import { useSettings } from "@/utils/atoms/settings"; +import { getPrimaryImageUrl } from "@/utils/jellyfin/image/getPrimaryImageUrl"; import { getStreamUrl } from "@/utils/jellyfin/media/getStreamUrl"; import { getMpvAudioId, @@ -504,6 +505,31 @@ export default function page() { return ticksToSeconds(getInitialPlaybackTicks()); }, [getInitialPlaybackTicks]); + /** Prepare metadata for iOS native media controls (Control Center, Lock Screen) */ + const nowPlayingMetadata = useMemo(() => { + if (!item || !api) return undefined; + + const artworkUri = getPrimaryImageUrl({ + api, + item, + quality: 90, + width: 500, + }); + + return { + title: item.Name || "", + artist: + item.Type === "Episode" + ? item.SeriesName || "" + : item.AlbumArtist || "", + albumTitle: + item.Type === "Episode" && item.SeasonName + ? item.SeasonName + : undefined, + artworkUri: artworkUri || undefined, + }; + }, [item, api]); + /** Build video source config for MPV */ const videoSource = useMemo(() => { if (!stream?.url) return undefined; @@ -932,6 +958,7 @@ export default function page() { ref={videoRef} source={videoSource} style={{ width: "100%", height: "100%" }} + nowPlayingMetadata={nowPlayingMetadata} onProgress={onProgress} onPlaybackStateChange={onPlaybackStateChanged} onLoad={() => setIsVideoLoaded(true)} diff --git a/modules/mpv-player/android/src/main/java/expo/modules/mpvplayer/MpvPlayerModule.kt b/modules/mpv-player/android/src/main/java/expo/modules/mpvplayer/MpvPlayerModule.kt index 245c4ef5..1735c14c 100644 --- a/modules/mpv-player/android/src/main/java/expo/modules/mpvplayer/MpvPlayerModule.kt +++ b/modules/mpv-player/android/src/main/java/expo/modules/mpvplayer/MpvPlayerModule.kt @@ -43,6 +43,12 @@ class MpvPlayerModule : Module() { view.loadVideo(config) } + // Now Playing metadata for media controls (iOS-only, no-op on Android) + // Android handles media session differently via MediaSessionCompat + Prop("nowPlayingMetadata") { _: MpvPlayerView, _: Map? -> + // No-op on Android - media session integration would require MediaSessionCompat + } + // Async function to play video AsyncFunction("play") { view: MpvPlayerView -> view.play() diff --git a/modules/mpv-player/ios/MPVLayerRenderer.swift b/modules/mpv-player/ios/MPVLayerRenderer.swift index e2c4573a..9cb5540c 100644 --- a/modules/mpv-player/ios/MPVLayerRenderer.swift +++ b/modules/mpv-player/ios/MPVLayerRenderer.swift @@ -10,6 +10,7 @@ protocol MPVLayerRendererDelegate: AnyObject { func renderer(_ renderer: MPVLayerRenderer, didChangeLoading isLoading: Bool) func renderer(_ renderer: MPVLayerRenderer, didBecomeReadyToSeek: Bool) func renderer(_ renderer: MPVLayerRenderer, didBecomeTracksReady: Bool) + func renderer(_ renderer: MPVLayerRenderer, didSelectAudioOutput audioOutput: String) } /// MPV player using vo_avfoundation for video output. @@ -347,7 +348,8 @@ final class MPVLayerRenderer { ("pause", MPV_FORMAT_FLAG), ("track-list/count", MPV_FORMAT_INT64), ("paused-for-cache", MPV_FORMAT_FLAG), - ("demuxer-cache-duration", MPV_FORMAT_DOUBLE) + ("demuxer-cache-duration", MPV_FORMAT_DOUBLE), + ("current-ao", MPV_FORMAT_STRING) ] for (name, format) in properties { mpv_observe_property(handle, 0, name, format) @@ -552,6 +554,15 @@ final class MPVLayerRenderer { self.delegate?.renderer(self, didBecomeTracksReady: true) } } + case "current-ao": + // Audio output is now active - notify delegate + if let aoName = getStringProperty(handle: handle, name: name) { + print("[MPV] ๐Ÿ”Š Audio output selected: \(aoName)") + DispatchQueue.main.async { [weak self] in + guard let self else { return } + self.delegate?.renderer(self, didSelectAudioOutput: aoName) + } + } default: break } diff --git a/modules/mpv-player/ios/MPVNowPlayingManager.swift b/modules/mpv-player/ios/MPVNowPlayingManager.swift new file mode 100644 index 00000000..73dafdbc --- /dev/null +++ b/modules/mpv-player/ios/MPVNowPlayingManager.swift @@ -0,0 +1,188 @@ +import Foundation +import MediaPlayer +import UIKit +import AVFoundation + +/// Simple manager for Now Playing info and remote commands. +/// Stores all state internally and updates Now Playing when ready. +class MPVNowPlayingManager { + static let shared = MPVNowPlayingManager() + + // State + private var title: String? + private var artist: String? + private var albumTitle: String? + private var cachedArtwork: MPMediaItemArtwork? + private var duration: TimeInterval = 0 + private var position: TimeInterval = 0 + private var isPlaying: Bool = false + private var isCommandsSetup = false + + private var artworkTask: URLSessionDataTask? + + private init() {} + + // MARK: - Audio Session + + func activateAudioSession() { + do { + let session = AVAudioSession.sharedInstance() + try session.setCategory(.playback, mode: .moviePlayback) + try session.setActive(true) + print("[NowPlaying] Audio session activated") + } catch { + print("[NowPlaying] Audio session error: \(error)") + } + } + + func deactivateAudioSession() { + do { + try AVAudioSession.sharedInstance().setActive(false, options: .notifyOthersOnDeactivation) + print("[NowPlaying] Audio session deactivated") + } catch { + print("[NowPlaying] Deactivation error: \(error)") + } + } + + // MARK: - Remote Commands + + func setupRemoteCommands( + playHandler: @escaping () -> Void, + pauseHandler: @escaping () -> Void, + toggleHandler: @escaping () -> Void, + seekHandler: @escaping (TimeInterval) -> Void, + skipForward: @escaping (TimeInterval) -> Void, + skipBackward: @escaping (TimeInterval) -> Void + ) { + guard !isCommandsSetup else { return } + isCommandsSetup = true + + DispatchQueue.main.async { + UIApplication.shared.beginReceivingRemoteControlEvents() + } + + let cc = MPRemoteCommandCenter.shared() + + cc.playCommand.isEnabled = true + cc.playCommand.addTarget { _ in playHandler(); return .success } + + cc.pauseCommand.isEnabled = true + cc.pauseCommand.addTarget { _ in pauseHandler(); return .success } + + cc.togglePlayPauseCommand.isEnabled = true + cc.togglePlayPauseCommand.addTarget { _ in toggleHandler(); return .success } + + cc.skipForwardCommand.isEnabled = true + cc.skipForwardCommand.preferredIntervals = [15] + cc.skipForwardCommand.addTarget { e in + if let ev = e as? MPSkipIntervalCommandEvent { skipForward(ev.interval) } + return .success + } + + cc.skipBackwardCommand.isEnabled = true + cc.skipBackwardCommand.preferredIntervals = [15] + cc.skipBackwardCommand.addTarget { e in + if let ev = e as? MPSkipIntervalCommandEvent { skipBackward(ev.interval) } + return .success + } + + cc.changePlaybackPositionCommand.isEnabled = true + cc.changePlaybackPositionCommand.addTarget { e in + if let ev = e as? MPChangePlaybackPositionCommandEvent { seekHandler(ev.positionTime) } + return .success + } + + print("[NowPlaying] Remote commands ready") + } + + func cleanupRemoteCommands() { + guard isCommandsSetup else { return } + + let cc = MPRemoteCommandCenter.shared() + cc.playCommand.removeTarget(nil) + cc.pauseCommand.removeTarget(nil) + cc.togglePlayPauseCommand.removeTarget(nil) + cc.skipForwardCommand.removeTarget(nil) + cc.skipBackwardCommand.removeTarget(nil) + cc.changePlaybackPositionCommand.removeTarget(nil) + + DispatchQueue.main.async { + UIApplication.shared.endReceivingRemoteControlEvents() + } + + isCommandsSetup = false + print("[NowPlaying] Remote commands cleaned up") + } + + // MARK: - State Updates (call these whenever data changes) + + /// Set metadata (title, artist, artwork URL) + func setMetadata(title: String?, artist: String?, albumTitle: String?, artworkUrl: String?) { + self.title = title + self.artist = artist + self.albumTitle = albumTitle + + print("[NowPlaying] Metadata: \(title ?? "nil")") + + // Load artwork async + artworkTask?.cancel() + if let urlString = artworkUrl, let url = URL(string: urlString) { + artworkTask = URLSession.shared.dataTask(with: url) { [weak self] data, _, _ in + if let data = data, let image = UIImage(data: data) { + self?.cachedArtwork = MPMediaItemArtwork(boundsSize: image.size) { _ in image } + print("[NowPlaying] Artwork loaded") + DispatchQueue.main.async { self?.refresh() } + } + } + artworkTask?.resume() + } + + refresh() + } + + /// Update playback state (position, duration, playing) + func updatePlayback(position: TimeInterval, duration: TimeInterval, isPlaying: Bool) { + self.position = position + self.duration = duration + self.isPlaying = isPlaying + refresh() + } + + /// Clear everything + func clear() { + artworkTask?.cancel() + title = nil + artist = nil + albumTitle = nil + cachedArtwork = nil + duration = 0 + position = 0 + isPlaying = false + MPNowPlayingInfoCenter.default().nowPlayingInfo = nil + print("[NowPlaying] Cleared") + } + + // MARK: - Private + + /// Refresh Now Playing info if we have enough data + private func refresh() { + guard duration > 0 else { + print("[NowPlaying] refresh skipped - duration is 0") + return + } + + var info: [String: Any] = [ + MPMediaItemPropertyPlaybackDuration: duration, + MPNowPlayingInfoPropertyElapsedPlaybackTime: position, + MPNowPlayingInfoPropertyPlaybackRate: isPlaying ? 1.0 : 0.0 + ] + + if let title { info[MPMediaItemPropertyTitle] = title } + if let artist { info[MPMediaItemPropertyArtist] = artist } + if let albumTitle { info[MPMediaItemPropertyAlbumTitle] = albumTitle } + if let cachedArtwork { info[MPMediaItemPropertyArtwork] = cachedArtwork } + + MPNowPlayingInfoCenter.default().nowPlayingInfo = info + print("[NowPlaying] โœ… Set info: title=\(title ?? "nil"), dur=\(Int(duration))s, pos=\(Int(position))s, rate=\(isPlaying ? 1.0 : 0.0)") + } +} diff --git a/modules/mpv-player/ios/MpvPlayerModule.swift b/modules/mpv-player/ios/MpvPlayerModule.swift index b60a3d40..feaf27f6 100644 --- a/modules/mpv-player/ios/MpvPlayerModule.swift +++ b/modules/mpv-player/ios/MpvPlayerModule.swift @@ -43,6 +43,21 @@ public class MpvPlayerModule: Module { view.loadVideo(config: config) } + // Now Playing metadata for iOS Control Center and Lock Screen + Prop("nowPlayingMetadata") { (view: MpvPlayerView, metadata: [String: Any]?) in + guard let metadata = metadata else { return } + // Convert Any values to String, filtering out nil/null values + var stringMetadata: [String: String] = [:] + for (key, value) in metadata { + if let stringValue = value as? String { + stringMetadata[key] = stringValue + } + } + if !stringMetadata.isEmpty { + view.setNowPlayingMetadata(stringMetadata) + } + } + // Async function to play video AsyncFunction("play") { (view: MpvPlayerView) in view.play() diff --git a/modules/mpv-player/ios/MpvPlayerView.swift b/modules/mpv-player/ios/MpvPlayerView.swift index 89502a9a..35e0d19b 100644 --- a/modules/mpv-player/ios/MpvPlayerView.swift +++ b/modules/mpv-player/ios/MpvPlayerView.swift @@ -1,6 +1,7 @@ import AVFoundation import CoreMedia import ExpoModulesCore +import MediaPlayer import UIKit /// Configuration for loading a video @@ -41,7 +42,6 @@ class MpvPlayerView: ExpoView { private var renderer: MPVLayerRenderer? private var videoContainer: UIView! private var pipController: PiPController? - let onLoad = EventDispatcher() let onPlaybackStateChange = EventDispatcher() let onProgress = EventDispatcher() @@ -53,11 +53,14 @@ class MpvPlayerView: ExpoView { private var cachedDuration: Double = 0 private var intendedPlayState: Bool = false private var _isZoomedToFill: Bool = false + + // Reference to now playing manager + private let nowPlayingManager = MPVNowPlayingManager.shared required init(appContext: AppContext? = nil) { super.init(appContext: appContext) + setupNotifications() setupView() - // Note: Decoder reset is handled automatically via KVO in MPVLayerRenderer } private func setupView() { @@ -109,6 +112,77 @@ class MpvPlayerView: ExpoView { CATransaction.commit() } + // MARK: - Audio Session & Notifications + + private func setupNotifications() { + // Handle audio session interruptions (e.g., incoming calls, other apps playing audio) + NotificationCenter.default.addObserver( + self, selector: #selector(handleAudioSessionInterruption), + name: AVAudioSession.interruptionNotification, object: nil) + } + + @objc func handleAudioSessionInterruption(_ notification: Notification) { + guard let userInfo = notification.userInfo, + let typeValue = userInfo[AVAudioSessionInterruptionTypeKey] as? UInt, + let type = AVAudioSession.InterruptionType(rawValue: typeValue) else { + return + } + + switch type { + case .began: + // Interruption began - pause the video + print("[MPV] Audio session interrupted - pausing video") + self.pause() + + case .ended: + // Interruption ended - check if we should resume + if let optionsValue = userInfo[AVAudioSessionInterruptionOptionKey] as? UInt { + let options = AVAudioSession.InterruptionOptions(rawValue: optionsValue) + if options.contains(.shouldResume) { + print("[MPV] Audio session interruption ended - can resume") + // Don't auto-resume - let user manually resume playback + } else { + print("[MPV] Audio session interruption ended - should not resume") + } + } + + @unknown default: + break + } + } + + private func setupRemoteCommands() { + nowPlayingManager.setupRemoteCommands( + playHandler: { [weak self] in self?.play() }, + pauseHandler: { [weak self] in self?.pause() }, + toggleHandler: { [weak self] in + guard let self else { return } + if self.intendedPlayState { self.pause() } else { self.play() } + }, + seekHandler: { [weak self] time in self?.seekTo(position: time) }, + skipForward: { [weak self] interval in self?.seekBy(offset: interval) }, + skipBackward: { [weak self] interval in self?.seekBy(offset: -interval) } + ) + } + + // MARK: - Now Playing Info + + func setNowPlayingMetadata(_ metadata: [String: String]) { + print("[MPV] setNowPlayingMetadata: \(metadata["title"] ?? "nil")") + nowPlayingManager.setMetadata( + title: metadata["title"], + artist: metadata["artist"], + albumTitle: metadata["albumTitle"], + artworkUrl: metadata["artworkUri"] + ) + } + + private func clearNowPlayingInfo() { + nowPlayingManager.cleanupRemoteCommands() + nowPlayingManager.deactivateAudioSession() + nowPlayingManager.clear() + } + func loadVideo(config: VideoLoadConfig) { // Skip reload if same URL is already playing if currentURL == config.url { @@ -149,6 +223,7 @@ class MpvPlayerView: ExpoView { func play() { intendedPlayState = true + setupRemoteCommands() renderer?.play() pipController?.setPlaybackRate(1.0) pipController?.updatePlaybackState() @@ -162,10 +237,17 @@ class MpvPlayerView: ExpoView { } func seekTo(position: Double) { + // Update cached position and Now Playing immediately for smooth Control Center feedback + cachedPosition = position + syncNowPlaying(isPlaying: !isPaused()) renderer?.seek(to: position) } func seekBy(offset: Double) { + // Update cached position and Now Playing immediately for smooth Control Center feedback + let newPosition = max(0, min(cachedPosition + offset, cachedDuration)) + cachedPosition = newPosition + syncNowPlaying(isPlaying: !isPaused()) renderer?.seek(by: offset) } @@ -292,23 +374,32 @@ class MpvPlayerView: ExpoView { pipController?.stopPictureInPicture() renderer?.stop() displayLayer.removeFromSuperlayer() + clearNowPlayingInfo() + NotificationCenter.default.removeObserver(self) } } // MARK: - MPVLayerRendererDelegate extension MpvPlayerView: MPVLayerRendererDelegate { + + // MARK: - Single location for Now Playing updates + private func syncNowPlaying(isPlaying: Bool) { + print("[MPV] syncNowPlaying: pos=\(Int(cachedPosition))s, dur=\(Int(cachedDuration))s, playing=\(isPlaying)") + nowPlayingManager.updatePlayback(position: cachedPosition, duration: cachedDuration, isPlaying: isPlaying) + } + func renderer(_: MPVLayerRenderer, didUpdatePosition position: Double, duration: Double, cacheSeconds: Double) { cachedPosition = position cachedDuration = duration DispatchQueue.main.async { [weak self] in guard let self else { return } - // Update PiP current time for progress bar + if self.pipController?.isPictureInPictureActive == true { self.pipController?.setCurrentTimeFromSeconds(position, duration: duration) } - + self.onProgress([ "position": position, "duration": duration, @@ -321,12 +412,10 @@ extension MpvPlayerView: MPVLayerRendererDelegate { func renderer(_: MPVLayerRenderer, didChangePause isPaused: Bool) { DispatchQueue.main.async { [weak self] in guard let self else { return } - // Don't update intendedPlayState here - it's only set by user actions (play/pause) - // This prevents PiP UI flicker during seeking - // Sync timebase rate with actual playback state + print("[MPV] didChangePause: isPaused=\(isPaused), cachedDuration=\(self.cachedDuration)") self.pipController?.setPlaybackRate(isPaused ? 0.0 : 1.0) - + self.syncNowPlaying(isPlaying: !isPaused) self.onPlaybackStateChange([ "isPaused": isPaused, "isPlaying": !isPaused, @@ -358,6 +447,13 @@ extension MpvPlayerView: MPVLayerRendererDelegate { self.onTracksReady([:]) } } + + func renderer(_: MPVLayerRenderer, didSelectAudioOutput audioOutput: String) { + // Audio output is now active - this is the right time to activate audio session and set Now Playing + print("[MPV] Audio output ready (\(audioOutput)), activating audio session and syncing Now Playing") + nowPlayingManager.activateAudioSession() + syncNowPlaying(isPlaying: !isPaused()) + } } // MARK: - PiPControllerDelegate diff --git a/modules/mpv-player/src/MpvPlayer.types.ts b/modules/mpv-player/src/MpvPlayer.types.ts index 23f86093..8f42c8d9 100644 --- a/modules/mpv-player/src/MpvPlayer.types.ts +++ b/modules/mpv-player/src/MpvPlayer.types.ts @@ -25,6 +25,13 @@ export type OnErrorEventPayload = { export type OnTracksReadyEventPayload = Record; +export type NowPlayingMetadata = { + title?: string; + artist?: string; + albumTitle?: string; + artworkUri?: string; +}; + export type MpvPlayerModuleEvents = { onChange: (params: ChangeEventPayload) => void; }; @@ -48,6 +55,8 @@ export type VideoSource = { export type MpvPlayerViewProps = { source?: VideoSource; style?: StyleProp; + /** Metadata for iOS Control Center and Lock Screen now playing info */ + nowPlayingMetadata?: NowPlayingMetadata; onLoad?: (event: { nativeEvent: OnLoadEventPayload }) => void; onPlaybackStateChange?: (event: { nativeEvent: OnPlaybackStateChangePayload; From 8c0cbffd98a42c3da20fb3264fdce9c0f0296d3c Mon Sep 17 00:00:00 2001 From: quang-tran Date: Thu, 19 Feb 2026 01:39:29 -0500 Subject: [PATCH 12/39] =?UTF-8?q?fix(logs):=20change=20the=20mimeType=20an?= =?UTF-8?q?d=20UTI=20to=20the=20proper=20types=20for=20log=20ex=E2=80=A6?= =?UTF-8?q?=20(#1424)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- app/(auth)/(tabs)/(home)/settings/logs/page.tsx | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/app/(auth)/(tabs)/(home)/settings/logs/page.tsx b/app/(auth)/(tabs)/(home)/settings/logs/page.tsx index 87831925..fdd5a2b3 100644 --- a/app/(auth)/(tabs)/(home)/settings/logs/page.tsx +++ b/app/(auth)/(tabs)/(home)/settings/logs/page.tsx @@ -61,7 +61,10 @@ export default function Page() { setLoading(true); try { logsFile.write(JSON.stringify(filteredLogs)); - await Sharing.shareAsync(logsFile.uri, { mimeType: "txt", UTI: "txt" }); + await Sharing.shareAsync(logsFile.uri, { + mimeType: "text/plain", + UTI: "public.plain-text", + }); } catch (e: any) { writeErrorLog("Something went wrong attempting to export", e); } finally { From 54d86939996cf51fb9d2507ba214ce3c24c48580 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Thu, 19 Feb 2026 07:44:30 +0100 Subject: [PATCH 13/39] chore(deps): Update crowdin/github-action action to v2.14.1 (#1453) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/crowdin.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/crowdin.yml b/.github/workflows/crowdin.yml index c73cad70..66ce0559 100644 --- a/.github/workflows/crowdin.yml +++ b/.github/workflows/crowdin.yml @@ -28,7 +28,7 @@ jobs: fetch-depth: 0 - name: ๐ŸŒ Sync Translations with Crowdin - uses: crowdin/github-action@b4b468cffefb50bdd99dd83e5d2eaeb63c880380 # v2.14.0 + uses: crowdin/github-action@5587c43063e52090026857d386174d2599ad323b # v2.14.1 with: upload_sources: true upload_translations: true From 019f863b3e2299ea7c314b8bb696fa5536b11d2d Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" <41898282+github-actions[bot]@users.noreply.github.com> Date: Thu, 19 Feb 2026 07:45:11 +0100 Subject: [PATCH 14/39] feat: New Crowdin Translations (#1346) Co-authored-by: Crowdin Bot --- translations/de.json | 658 ++++++++++++++++++++--------------------- translations/es.json | 158 +++++----- translations/fr.json | 238 +++++++-------- translations/it.json | 8 +- translations/nl.json | 366 +++++++++++------------ translations/tr.json | 688 +++++++++++++++++++++---------------------- 6 files changed, 1058 insertions(+), 1058 deletions(-) diff --git a/translations/de.json b/translations/de.json index bfb614b7..3d3001dc 100644 --- a/translations/de.json +++ b/translations/de.json @@ -7,7 +7,7 @@ "username_placeholder": "Benutzername", "password_placeholder": "Passwort", "login_button": "Anmelden", - "quick_connect": "Schnellverbindung", + "quick_connect": "Quick Connect", "enter_code_to_login": "Gib den Code {{code}} ein, um dich anzumelden", "failed_to_initiate_quick_connect": "Fehler beim Initiieren der Schnellverbindung", "got_it": "Verstanden", @@ -30,48 +30,48 @@ "connect_button": "Verbinden", "previous_servers": "Vorherige Server", "clear_button": "Lรถschen", - "swipe_to_remove": "Swipe to remove", + "swipe_to_remove": "Wischen, um zu entfernen", "search_for_local_servers": "Nach lokalen Servern suchen", "searching": "Suche...", "servers": "Server", - "saved": "Saved", - "session_expired": "Session Expired", - "please_login_again": "Your saved session has expired. Please log in again.", - "remove_saved_login": "Remove Saved Login", - "remove_saved_login_description": "This will remove your saved credentials for this server. You'll need to enter your username and password again next time.", - "accounts_count": "{{count}} accounts", - "select_account": "Select Account", - "add_account": "Add Account", - "remove_account_description": "This will remove the saved credentials for {{username}}." + "saved": "Gespeichert", + "session_expired": "Sitzung abgelaufen", + "please_login_again": "Ihre Sitzung ist abgelaufen. Bitte erneut anmelden.", + "remove_saved_login": "Gespeicherte Zugangsdaten entfernen", + "remove_saved_login_description": "Hiermit werden ihre gespeicherten Zugangsdaten fรผr diesen Server entfernt. Sie mรผssen sich dann erneut anmelden.", + "accounts_count": "{{count}} Konten", + "select_account": "Konto auswรคhlen", + "add_account": "Konto hinzufรผgen", + "remove_account_description": "Hiermit werden die gespeicherten Zugangsdaten fรผr {{username}} entfernt." }, "save_account": { - "title": "Save Account", - "save_for_later": "Save this account", - "security_option": "Security Option", - "no_protection": "No protection", - "no_protection_desc": "Quick login without authentication", - "pin_code": "PIN code", - "pin_code_desc": "4-digit PIN required when switching", - "password": "Re-enter password", - "password_desc": "Password required when switching", - "save_button": "Save", - "cancel_button": "Cancel" + "title": "Konto speichern", + "save_for_later": "Dieses Konto speichern", + "security_option": "Sicherheitseinstellung", + "no_protection": "Keine", + "no_protection_desc": "Schnellanmeldung ohne Authentifizierung", + "pin_code": "PIN", + "pin_code_desc": "4-stellige PIN bei Konto-Wechsel erforderlich", + "password": "Passwort wiederholen", + "password_desc": "Passwort bei Konto-Wechsel erforderlich", + "save_button": "Speichern", + "cancel_button": "Abbrechen" }, "pin": { - "enter_pin": "Enter PIN", - "enter_pin_for": "Enter PIN for {{username}}", - "enter_4_digits": "Enter 4 digits", - "invalid_pin": "Invalid PIN", - "setup_pin": "Set Up PIN", - "confirm_pin": "Confirm PIN", - "pins_dont_match": "PINs don't match", - "forgot_pin": "Forgot PIN?", - "forgot_pin_desc": "Your saved credentials will be removed" + "enter_pin": "PIN eingeben", + "enter_pin_for": "PIN fรผr {{username}} eingeben", + "enter_4_digits": "4 Ziffern eingeben", + "invalid_pin": "Ungรผltige PIN", + "setup_pin": "PIN festlegen", + "confirm_pin": "PIN bestรคtigen", + "pins_dont_match": "PIN stimmt nicht รผberein", + "forgot_pin": "PIN vergessen?", + "forgot_pin_desc": "Ihre gespeicherten Zugangsdaten werden entfernt" }, "password": { - "enter_password": "Enter Password", - "enter_password_for": "Enter password for {{username}}", - "invalid_password": "Invalid password" + "enter_password": "Passwort eingeben", + "enter_password_for": "Passwort fรผr {{username}} eingeben", + "invalid_password": "Ungรผltiges Passwort" }, "home": { "checking_server_connection": "รœberprรผfe Serververbindung...", @@ -87,7 +87,7 @@ "error_message": "Etwas ist schiefgelaufen.\nBitte melde dich ab und wieder an.", "continue_watching": "Weiterschauen", "next_up": "Als nรคchstes", - "continue_and_next_up": "Continue & Next Up", + "continue_and_next_up": "\"Weiterschauen\" und \"Als Nรคchstes\"", "recently_added_in": "Kรผrzlich hinzugefรผgt in {{libraryName}}", "suggested_movies": "Empfohlene Filme", "suggested_episodes": "Empfohlene Episoden", @@ -120,36 +120,36 @@ }, "appearance": { "title": "Aussehen", - "merge_next_up_continue_watching": "Merge Continue Watching & Next Up", - "hide_remote_session_button": "Hide Remote Session Button" + "merge_next_up_continue_watching": "\"Weiterschauen\" und \"Als Nรคchstes\" kombinieren", + "hide_remote_session_button": "Button fรผr Remote-Sitzung ausblenden" }, "network": { - "title": "Network", - "local_network": "Local Network", - "auto_switch_enabled": "Auto-switch when at home", - "auto_switch_description": "Automatically switch to local URL when connected to home WiFi", - "local_url": "Local URL", - "local_url_hint": "Enter your local server address (e.g., http://192.168.1.100:8096)", + "title": "Netzwerk", + "local_network": "Lokales Netzwerk", + "auto_switch_enabled": "Zuhause automatisch wechseln", + "auto_switch_description": "Im WLAN Zuhause automatisch zu lokaler URL wechseln", + "local_url": "Lokale URL", + "local_url_hint": "Lokale Server-URL eingeben (zB. http://192.168.1.100:8096)", "local_url_placeholder": "http://192.168.1.100:8096", - "home_wifi_networks": "Home WiFi Networks", - "add_current_network": "Add \"{{ssid}}\"", - "not_connected_to_wifi": "Not connected to WiFi", - "no_networks_configured": "No networks configured", - "add_network_hint": "Add your home WiFi network to enable auto-switching", - "current_wifi": "Current WiFi", - "using_url": "Using", - "local": "Local URL", + "home_wifi_networks": "Private WLAN-Netze", + "add_current_network": "{{ssid}} hinzufรผgen", + "not_connected_to_wifi": "Nicht mit WLAN verbunden", + "no_networks_configured": "Keine Netzwerke konfiguriert", + "add_network_hint": "Fรผge dein privates WLAN-Netz hinzu um automatischen Wechsel zu aktivieren", + "current_wifi": "Aktuelles WLAN-Netz", + "using_url": "Verwendet", + "local": "Lokale URL", "remote": "Remote URL", - "not_connected": "Not connected", - "current_server": "Current Server", + "not_connected": "Nicht verbunden", + "current_server": "Aktueller Server", "remote_url": "Remote URL", - "active_url": "Active URL", - "not_configured": "Not configured", - "network_added": "Network added", - "network_already_added": "Network already added", - "no_wifi_connected": "Not connected to WiFi", - "permission_denied": "Location permission denied", - "permission_denied_explanation": "Location permission is required to detect WiFi network for auto-switching. Please enable it in Settings." + "active_url": "Aktive URL", + "not_configured": "Nicht konfiguriert", + "network_added": "Netzwerk hinzugefรผgt", + "network_already_added": "Netzwerk bereits hinzugefรผgt", + "no_wifi_connected": "Nicht mit WLAN verbunden", + "permission_denied": "Standortberechtigung nicht verfรผgbar", + "permission_denied_explanation": "Standortberechtigung ist nรถtig um WLAN-Netze fรผr den automatischen Wechsel zu erkennen. Bitte in den Einstellungen aktivieren." }, "user_info": { "user_info_title": "Benutzerinformationen", @@ -159,82 +159,82 @@ "app_version": "App-Version" }, "quick_connect": { - "quick_connect_title": "Schnellverbindung", - "authorize_button": "Schnellverbindung autorisieren", - "enter_the_quick_connect_code": "Gib den Schnellverbindungscode ein...", - "success": "Erfolg", - "quick_connect_autorized": "Schnellverbindung autorisiert", + "quick_connect_title": "Quick Connect", + "authorize_button": "Quick Connect autorisieren", + "enter_the_quick_connect_code": "Quick Connect-Code eingeben...", + "success": "Erfolgreich verbunden", + "quick_connect_autorized": "Quick Connect autorisiert", "error": "Fehler", "invalid_code": "Ungรผltiger Code", "authorize": "Autorisieren" }, "media_controls": { "media_controls_title": "Mediensteuerung", - "forward_skip_length": "Vorspulzeit", - "rewind_length": "Rรผckspulzeit", + "forward_skip_length": "Vorspullรคnge", + "rewind_length": "Rรผckspullรคnge", "seconds_unit": "s" }, "gesture_controls": { "gesture_controls_title": "Gestensteuerung", - "horizontal_swipe_skip": "Horizontales Wischen zum รœberspringen", - "horizontal_swipe_skip_description": "Wische links/rechts, wenn Steuerelemente ausgeblendet werden um zu รผberspringen", - "left_side_brightness": "Helligkeitskontrolle der linken Seite", - "left_side_brightness_description": "Wischen Sie auf der linken Seite nach oben/runter, um die Helligkeit anzupassen", - "right_side_volume": "Lautstรคrkeregelung der rechten Seite", - "right_side_volume_description": "Auf der rechten Seite nach oben/unten wischen, um Lautstรคrke anzupassen", - "hide_volume_slider": "Hide Volume Slider", - "hide_volume_slider_description": "Hide the volume slider in the video player", - "hide_brightness_slider": "Hide Brightness Slider", - "hide_brightness_slider_description": "Hide the brightness slider in the video player" + "horizontal_swipe_skip": "Horizontal Wischen zum รœberspringen", + "horizontal_swipe_skip_description": "Wische links/rechts, wenn Steuerelemente ausgeblendet sind um zu รผberspringen", + "left_side_brightness": "Helligkeitsregler Links", + "left_side_brightness_description": "Links nach oben/unten wischen um Helligkeit anzupassen", + "right_side_volume": "Lautstรคrkeregler Rechts", + "right_side_volume_description": "Rechts nach oben/unten wischen um Lautstรคrke anzupassen", + "hide_volume_slider": "Lautstรคrkeregler ausblenden", + "hide_volume_slider_description": "Lautstรคrkeregler im Videoplayer ausblenden", + "hide_brightness_slider": "Helligkeitsregler ausblenden", + "hide_brightness_slider_description": "Helligkeitsregler im Videoplayer ausblenden" }, "audio": { "audio_title": "Audio", - "set_audio_track": "Audiospur aus dem vorherigen Element festlegen", + "set_audio_track": "Audiospur aus dem vorherigen Element รผbernehmen", "audio_language": "Audio-Sprache", - "audio_hint": "Wรคhl die Standardsprache fรผr Audio aus.", + "audio_hint": "Standardsprache fรผr Audio auswรคhlen.", "none": "Keine", "language": "Sprache", "transcode_mode": { - "title": "Audio Transcoding", - "description": "Controls how surround audio (7.1, TrueHD, DTS-HD) is handled", + "title": "Audio-Transcoding", + "description": "Legt fest, wie Surround-Audio (7.1, TrueHD, DTS-HD) behandelt wird", "auto": "Auto", - "stereo": "Force Stereo", - "5_1": "Allow 5.1", + "stereo": "Stereo erzwingen", + "5_1": "5.1 erlauben", "passthrough": "Passthrough" } }, "subtitles": { "subtitle_title": "Untertitel", - "subtitle_hint": "Konfigurier die Untertitel-Prรคferenzen.", + "subtitle_hint": "Untertitel-Erscheinungsbild und Verhalten konfigurieren.", "subtitle_language": "Untertitel-Sprache", "subtitle_mode": "Untertitel-Modus", - "set_subtitle_track": "Untertitel-Spur aus dem vorherigen Element festlegen", + "set_subtitle_track": "Untertitel-Spur aus dem vorherigen Element รผbernehmen", "subtitle_size": "Untertitel-GrรถรŸe", "none": "Keine", "language": "Sprache", "loading": "Lรคdt", "modes": { "Default": "Standard", - "Smart": "Intelligent", + "Smart": "Smart", "Always": "Immer", "None": "Keine", - "OnlyForced": "Nur erzwungen" + "OnlyForced": "Nur erzwungene" }, "text_color": "Textfarbe", "background_color": "Hintergrundfarbe", "outline_color": "Konturfarbe", - "outline_thickness": "Umriss Dicke", + "outline_thickness": "Konturdicke", "background_opacity": "Hintergrundtransparenz", - "outline_opacity": "Kontur-Deckkraft", - "bold_text": "Bold Text", + "outline_opacity": "Konturtransparenz", + "bold_text": "Fettgedruckter Text", "colors": { "Black": "Schwarz", "Gray": "Grau", "Silver": "Silber", "White": "WeiรŸ", - "Maroon": "Marotte", + "Maroon": "Rotbraun", "Red": "Rot", - "Fuchsia": "Fuchsia", + "Fuchsia": "Magenta", "Yellow": "Gelb", "Olive": "Olivgrรผn", "Green": "Grรผn", @@ -251,29 +251,29 @@ "Normal": "Normal", "Thick": "Dick" }, - "subtitle_color": "Subtitle Color", - "subtitle_background_color": "Background Color", - "subtitle_font": "Subtitle Font", - "ksplayer_title": "KSPlayer Settings", + "subtitle_color": "Untertitelfarbe", + "subtitle_background_color": "Hintergrundfarbe", + "subtitle_font": "Untertitel-Schriftart", + "ksplayer_title": "KSPlayer Einstellungen", "hardware_decode": "Hardware Decoding", - "hardware_decode_description": "Use hardware acceleration for video decoding. Disable if you experience playback issues." + "hardware_decode_description": "Hardwarebeschleunigung fรผr Video Decoding verwenden. Deaktivieren wenn Wiedergabeprobleme auftreten." }, "vlc_subtitles": { - "title": "VLC Subtitle Settings", - "hint": "Customize subtitle appearance for VLC player. Changes take effect on next playback.", - "text_color": "Text Color", - "background_color": "Background Color", - "background_opacity": "Background Opacity", - "outline_color": "Outline Color", - "outline_opacity": "Outline Opacity", - "outline_thickness": "Outline Thickness", - "bold": "Bold Text", - "margin": "Bottom Margin" + "title": "VLC Untertitel-Einstellungen", + "hint": "Anpassen des Untertitel-Erscheinungsbildes fรผr VLC. ร„nderungen werden bei der nรคchsten Wiedergabe รผbernommen.", + "text_color": "Schriftfarbe", + "background_color": "Hintergrundfarbe", + "background_opacity": "Hintergrundtransparenz", + "outline_color": "Konturfarbe", + "outline_opacity": "Konturtransparenz", + "outline_thickness": "Konturdicke", + "bold": "Fettgedruckter Text", + "margin": "Unterer Abstand" }, "video_player": { - "title": "Video Player", - "video_player": "Video Player", - "video_player_description": "Choose which video player to use on iOS.", + "title": "Videoplayer", + "video_player": "Videoplayer", + "video_player_description": "Videoplayer auf iOS auswรคhlen.", "ksplayer": "KSPlayer", "vlc": "VLC" }, @@ -282,7 +282,7 @@ "video_orientation": "Videoausrichtung", "orientation": "Ausrichtung", "orientations": { - "DEFAULT": "Standard", + "DEFAULT": "Gerรคteausrichtung folgen", "ALL": "Alle", "PORTRAIT": "Hochformat", "PORTRAIT_UP": "Hochformat oben", @@ -294,54 +294,54 @@ "UNKNOWN": "Unbekannt" }, "safe_area_in_controls": "Sicherer Bereich in den Steuerungen", - "video_player": "Video player", + "video_player": "Videoplayer", "video_players": { "VLC_3": "VLC 3", "VLC_4": "VLC 4 (Experimentell + PiP)" }, "show_custom_menu_links": "Benutzerdefinierte Menรผlinks anzeigen", - "show_large_home_carousel": "Zeige GroรŸes Heimkarussell (Beta)", + "show_large_home_carousel": "Zeige groรŸe Startseiten-รœbersicht (Beta)", "hide_libraries": "Bibliotheken ausblenden", - "select_liraries_you_want_to_hide": "Wรคhl die Bibliotheken aus, die du im Bibliothekstab und auf der Startseite ausblenden mรถchtest.", + "select_liraries_you_want_to_hide": "Bibliotheken auswรคhlen die aus dem Bibliothekstab und der Startseite ausgeblendet werden sollen.", "disable_haptic_feedback": "Haptisches Feedback deaktivieren", "default_quality": "Standardqualitรคt", - "default_playback_speed": "Default Playback Speed", - "auto_play_next_episode": "Auto-play Next Episode", - "max_auto_play_episode_count": "Max. automatische Wiedergabe Episodenanzahl", + "default_playback_speed": "Standard-Wiedergabegeschwindigkeit", + "auto_play_next_episode": "Automatisch nรคchste Episode abspielen", + "max_auto_play_episode_count": "Maximale automatisch abzuspielende Episodenanzahl", "disabled": "Deaktiviert" }, "downloads": { "downloads_title": "Downloads" }, "music": { - "title": "Music", - "playback_title": "Playback", - "playback_description": "Configure how music is played.", - "prefer_downloaded": "Prefer Downloaded Songs", + "title": "Musik", + "playback_title": "Wiedergabe", + "playback_description": "Konfigurieren, wie Musik abgespielt wird.", + "prefer_downloaded": "Bevorzuge heruntergeladene Titel", "caching_title": "Caching", - "caching_description": "Automatically cache upcoming tracks for smoother playback.", - "lookahead_enabled": "Enable Look-Ahead Caching", - "lookahead_count": "Tracks to Pre-cache", - "max_cache_size": "Max Cache Size" + "caching_description": "Automatisches Caching anstehender Titel fรผr bessere Wiedergabe.", + "lookahead_enabled": "Look-Ahead Caching aktivieren", + "lookahead_count": "Titel vorher in den Cache laden", + "max_cache_size": "Maximale Cache-GrรถรŸe" }, "plugins": { - "plugins_title": "Erweiterungen", + "plugins_title": "Plugins", "jellyseerr": { - "jellyseerr_warning": "Diese integration ist in einer frรผhen Entwicklungsphase. Erwarte Verรคnderungen.", - "server_url": "Server Adresse", - "server_url_hint": "Beispiel: http(s)://your-host.url\n(Portnummer hinzufรผgen, falls erforderlich)", - "server_url_placeholder": "Jellyseerr URL...", + "jellyseerr_warning": "Diese Integration ist in einer frรผhen Entwicklungsphase und kann jederzeit geรคndert werden.", + "server_url": "Server URL", + "server_url_hint": "Beispiel: http(s)://your-host.url\n(Port hinzufรผgen, falls erforderlich)", + "server_url_placeholder": "Seerr URL", "password": "Passwort", "password_placeholder": "Passwort fรผr Jellyfin Benutzer {{username}} eingeben", "login_button": "Anmelden", "total_media_requests": "Gesamtanfragen", "movie_quota_limit": "Film-Anfragelimit", - "movie_quota_days": "Film-Anfragetage", - "tv_quota_limit": "TV-Anfragelimit", - "tv_quota_days": "TV-Anfragetage", - "reset_jellyseerr_config_button": "Setze Jellyseerr-Konfiguration zurรผck", + "movie_quota_days": "Film-Anfragetagelimit", + "tv_quota_limit": "Serien-Anfragelimit", + "tv_quota_days": "Serien-Anfragetagelimit", + "reset_jellyseerr_config_button": "Seerr-Konfiguration zurรผcksetzen", "unlimited": "Unlimitiert", - "plus_n_more": "+{{n}} more", + "plus_n_more": "+{{n}} weitere", "order_by": { "DEFAULT": "Standard", "VOTE_COUNT_AND_AVERAGE": "Stimmenanzahl und Durchschnitt", @@ -352,71 +352,71 @@ "enable_marlin_search": "Aktiviere Marlin Search", "url": "URL", "server_url_placeholder": "http(s)://domain.org:port", - "marlin_search_hint": "Gib die URL fรผr den Marlin Server ein. Die URL sollte http oder https enthalten und optional den Port.", + "marlin_search_hint": "URL fรผr den Marlin Server eingeben. Die URL sollte http oder https enthalten und optional den Port.", "read_more_about_marlin": "Erfahre mehr รผber Marlin.", "save_button": "Speichern", "toasts": { "saved": "Gespeichert", - "refreshed": "Settings refreshed from server" + "refreshed": "Einstellungen vom Server aktualisiert" }, - "refresh_from_server": "Refresh Settings from Server" + "refresh_from_server": "Einstellungen vom Server aktualisieren" }, "streamystats": { - "enable_streamystats": "Enable Streamystats", - "disable_streamystats": "Disable Streamystats", - "enable_search": "Use for Search", + "enable_streamystats": "Streamystats aktivieren", + "disable_streamystats": "Streamystats deaktivieren", + "enable_search": "Zum Suchen verwenden", "url": "URL", "server_url_placeholder": "http(s)://streamystats.example.com", - "streamystats_search_hint": "Enter the URL for your Streamystats server. The URL should include http or https and optionally the port.", - "read_more_about_streamystats": "Read More About Streamystats.", - "save_button": "Save", - "save": "Save", + "streamystats_search_hint": "URL fรผr den Streamystats-Server eingeben.", + "read_more_about_streamystats": "Mehr รผber Streamystats erfahren.", + "save_button": "Speichern", + "save": "Gespeichert", "features_title": "Features", - "home_sections_title": "Home Sections", - "enable_movie_recommendations": "Movie Recommendations", - "enable_series_recommendations": "Series Recommendations", - "enable_promoted_watchlists": "Promoted Watchlists", - "hide_watchlists_tab": "Hide Watchlists Tab", - "home_sections_hint": "Show personalized recommendations and promoted watchlists from Streamystats on the home page.", - "recommended_movies": "Recommended Movies", - "recommended_series": "Recommended Series", + "home_sections_title": "Startseitenbereiche", + "enable_movie_recommendations": "Filmempfehlungen", + "enable_series_recommendations": "Serienempfehlungen", + "enable_promoted_watchlists": "Empfohlene Merklisten", + "hide_watchlists_tab": "Merklisten-Tab ausblenden", + "home_sections_hint": "Zeige personalisierte Empfehlungen und empfohlene Merklisten von Streamystats auf der Startseite.", + "recommended_movies": "Empfohlene Filme", + "recommended_series": "Empfohlene Serien", "toasts": { - "saved": "Saved", - "refreshed": "Settings refreshed from server", - "disabled": "Streamystats disabled" + "saved": "Gespeichert", + "refreshed": "Einstellungen vom Server aktualisiert", + "disabled": "Streamystats deaktiviert" }, - "refresh_from_server": "Refresh Settings from Server" + "refresh_from_server": "Einstellungen vom Server aktualisieren" }, "kefinTweaks": { - "watchlist_enabler": "Enable our Watchlist integration", - "watchlist_button": "Toggle Watchlist integration" + "watchlist_enabler": "Merklisten-Integration aktivieren", + "watchlist_button": "Merklisten-Integration umschalten" } }, "storage": { "storage_title": "Speicher", "app_usage": "App {{usedSpace}}%", "device_usage": "Gerรคt {{availableSpace}}%", - "size_used": "{{used}} von {{total}} benutzt", - "delete_all_downloaded_files": "Alle Downloads lรถschen", - "music_cache_title": "Music Cache", - "music_cache_description": "Automatically cache songs as you listen for smoother playback and offline support", - "enable_music_cache": "Enable Music Cache", - "clear_music_cache": "Clear Music Cache", - "music_cache_size": "{{size}} cached", - "music_cache_cleared": "Music cache cleared", - "delete_all_downloaded_songs": "Delete All Downloaded Songs", - "downloaded_songs_size": "{{size}} downloaded", - "downloaded_songs_deleted": "Downloaded songs deleted" + "size_used": "{{used}} von {{total}} genutzt", + "delete_all_downloaded_files": "Alle heruntergeladenen Dateien lรถschen", + "music_cache_title": "Musik-Cache", + "music_cache_description": "Beim Anhรถren Titel automatisch in den Cache laden um bessere Wiedergabe und Offline-Wiedergabe zu ermรถglichen", + "enable_music_cache": "Musik-Cache aktivieren", + "clear_music_cache": "Musik-Cache leeren", + "music_cache_size": "{{size}} gechached", + "music_cache_cleared": "Musik-Cache geleert", + "delete_all_downloaded_songs": "Alle heruntergeladenen Titel lรถschen", + "downloaded_songs_size": "{{size}} heruntergeladen", + "downloaded_songs_deleted": "Heruntergeladene Titel gelรถscht" }, "intro": { - "title": "Intro ", - "show_intro": "Show intro", - "reset_intro": "Reset intro" + "title": "Einfรผhrung", + "show_intro": "Einfรผhrung anzeigen", + "reset_intro": "Einfรผhrung zurรผcksetzen" }, "logs": { "logs_title": "Logs", - "export_logs": "Export logs", - "click_for_more_info": "Click for more info", + "export_logs": "Logs exportieren", + "click_for_more_info": "Fรผr mehr Informationen klicken", "level": "Level", "no_logs_available": "Keine Logs verfรผgbar", "delete_all_logs": "Alle Logs lรถschen" @@ -438,21 +438,21 @@ }, "downloads": { "downloads_title": "Downloads", - "tvseries": "TV-Serien", + "tvseries": "Serien", "movies": "Filme", "queue": "Warteschlange", "other_media": "Andere Medien", - "queue_hint": "Warteschlange und aktive Downloads gehen verloren bei App-Neustart", + "queue_hint": "Warteschlange und aktive Downloads gehen verloren wenn die App neu gestartet wird", "no_items_in_queue": "Keine Elemente in der Warteschlange", "no_downloaded_items": "Keine heruntergeladenen Elemente", "delete_all_movies_button": "Alle Filme lรถschen", - "delete_all_tvseries_button": "Alle TV-Serien lรถschen", + "delete_all_tvseries_button": "Alle Serien lรถschen", "delete_all_button": "Alles lรถschen", - "delete_all_other_media_button": "Andere Medien lรถschen", + "delete_all_other_media_button": "Alle anderen Medien lรถschen", "active_download": "Aktiver Download", "no_active_downloads": "Keine aktiven Downloads", "active_downloads": "Aktive Downloads", - "new_app_version_requires_re_download": "Die neue App-Version erfordert das erneute Herunterladen.", + "new_app_version_requires_re_download": "Neue App-Version erfordert erneutes Herunterladen", "new_app_version_requires_re_download_description": "Die neue App-Version erfordert das erneute Herunterladen von Filmen und Serien. Bitte lรถsche alle heruntergeladenen Elemente und starte den Download erneut.", "back": "Zurรผck", "delete": "Lรถschen", @@ -463,8 +463,8 @@ "you_are_not_allowed_to_download_files": "Du hast keine Berechtigung, Dateien herunterzuladen", "deleted_all_movies_successfully": "Alle Filme erfolgreich gelรถscht!", "failed_to_delete_all_movies": "Fehler beim Lรถschen aller Filme", - "deleted_all_tvseries_successfully": "Alle TV-Serien erfolgreich gelรถscht!", - "failed_to_delete_all_tvseries": "Fehler beim Lรถschen aller TV-Serien", + "deleted_all_tvseries_successfully": "Alle Serien erfolgreich gelรถscht!", + "failed_to_delete_all_tvseries": "Fehler beim Lรถschen aller Serien", "deleted_media_successfully": "Andere Medien erfolgreich gelรถscht!", "failed_to_delete_media": "Fehler beim Lรถschen anderer Medien", "download_deleted": "Download gelรถscht", @@ -486,7 +486,7 @@ "all_files_folders_and_jobs_deleted_successfully": "Alle Dateien, Ordner und Jobs erfolgreich gelรถscht", "failed_to_clean_cache_directory": "Fehler beim Bereinigen des Cache-Verzeichnisses", "could_not_get_download_url_for_item": "Download-URL fรผr {{itemName}} konnte nicht geladen werden", - "go_to_downloads": "Gehe zu den Downloads", + "go_to_downloads": "Zu Downloads gehen", "file_deleted": "{{item}} gelรถscht" } } @@ -499,18 +499,18 @@ "subtitle": "Untertitel", "play": "Abspielen", "none": "Keine", - "track": "Track", - "cancel": "Cancel", - "delete": "Delete", + "track": "Spur", + "cancel": "Abbrechen", + "delete": "Lรถschen", "ok": "OK", - "remove": "Remove", - "next": "Next", - "back": "Back", - "continue": "Continue", - "verifying": "Verifying..." + "remove": "Entfernen", + "next": "Weiter", + "back": "Zurรผck", + "continue": "Fortsetzen", + "verifying": "Verifiziere..." }, "search": { - "search": "Suche...", + "search": "Suchen...", "x_items": "{{count}} Elemente", "library": "Bibliothek", "discover": "Entdecken", @@ -521,33 +521,33 @@ "episodes": "Episoden", "collections": "Sammlungen", "actors": "Schauspieler", - "artists": "Artists", - "albums": "Albums", - "songs": "Songs", + "artists": "Kรผnstler", + "albums": "Alben", + "songs": "Titel", "playlists": "Playlists", "request_movies": "Film anfragen", "request_series": "Serie anfragen", "recently_added": "Kรผrzlich hinzugefรผgt", "recent_requests": "Kรผrzlich angefragt", - "plex_watchlist": "Plex Watchlist", - "trending": "In den Trends", + "plex_watchlist": "Plex Merkliste", + "trending": "Beliebt", "popular_movies": "Beliebte Filme", "movie_genres": "Film-Genres", "upcoming_movies": "Kommende Filme", "studios": "Studios", - "popular_tv": "Beliebte TV-Serien", - "tv_genres": "TV-Serien-Genres", - "upcoming_tv": "Kommende TV-Serien", - "networks": "Netzwerke", + "popular_tv": "Beliebte Serien", + "tv_genres": "Serien-Genres", + "upcoming_tv": "Kommende Serien", + "networks": "Sender", "tmdb_movie_keyword": "TMDB Film-Schlรผsselwort", "tmdb_movie_genre": "TMDB Film-Genre", - "tmdb_tv_keyword": "TMDB TV-Serien-Schlรผsselwort", - "tmdb_tv_genre": "TMDB TV-Serien-Genre", + "tmdb_tv_keyword": "TMDB Serien-Schlรผsselwort", + "tmdb_tv_genre": "TMDB Serien-Genre", "tmdb_search": "TMDB Suche", "tmdb_studio": "TMDB Studio", "tmdb_network": "TMDB Netzwerk", "tmdb_movie_streaming_services": "TMDB Film-Streaming-Dienste", - "tmdb_tv_streaming_services": "TMDB TV-Serien-Streaming-Dienste" + "tmdb_tv_streaming_services": "TMDB Serien-Streaming-Dienste" }, "library": { "no_results": "Keine Ergebnisse", @@ -572,7 +572,7 @@ "genres": "Genres", "years": "Jahre", "sort_by": "Sortieren nach", - "filter_by": "Filter By", + "filter_by": "Filtern nach", "sort_order": "Sortierreihenfolge", "tags": "Tags" } @@ -585,7 +585,7 @@ "boxsets": "Boxsets", "playlists": "Wiedergabelisten", "noDataTitle": "Noch keine Favoriten", - "noData": "Markiere Elemente als Favoriten, damit sie hier fรผr einen schnellen Zugriff angezeigt werden." + "noData": "Elemente als Favoriten markieren, um sie hier anzuzeigen." }, "custom_links": { "no_links": "Keine Links" @@ -593,7 +593,7 @@ "player": { "error": "Fehler", "failed_to_get_stream_url": "Fehler beim Abrufen der Stream-URL", - "an_error_occured_while_playing_the_video": "Ein Fehler ist beim Abspielen des Videos aufgetreten. รœberprรผf die Logs in den Einstellungen.", + "an_error_occured_while_playing_the_video": "Ein Fehler ist beim Abspielen des Videos aufgetreten. Logs in den Einstellungen รผberprรผfen.", "client_error": "Client-Fehler", "could_not_create_stream_for_chromecast": "Konnte keinen Stream fรผr Chromecast erstellen", "message_from_server": "Nachricht vom Server: {{message}}", @@ -602,17 +602,17 @@ "audio_tracks": "Audiospuren:", "playback_state": "Wiedergabestatus:", "index": "Index:", - "continue_watching": "Weiterschauen", + "continue_watching": "Fortsetzen", "go_back": "Zurรผck", - "downloaded_file_title": "Diese Datei wurde heruntergeladen", - "downloaded_file_message": "Mรถchten Sie die heruntergeladene Datei abspielen?", + "downloaded_file_title": "Diese Datei wurde bereits heruntergeladen", + "downloaded_file_message": "Heruntergeladene Datei abspielen?", "downloaded_file_yes": "Ja", "downloaded_file_no": "Nein", "downloaded_file_cancel": "Abbrechen" }, "item_card": { "next_up": "Als Nรคchstes", - "no_items_to_display": "Keine Elemente zum Anzeigen", + "no_items_to_display": "Keine Elemente", "cast_and_crew": "Besetzung und Crew", "series": "Serien", "seasons": "Staffeln", @@ -630,7 +630,7 @@ "subtitles": "Untertitel", "show_more": "Mehr anzeigen", "show_less": "Weniger anzeigen", - "appeared_in": "Erschienen in", + "appeared_in": "Erschien in", "could_not_load_item": "Konnte Element nicht laden", "none": "Keine", "download": { @@ -639,13 +639,13 @@ "download_episode": "Episode herunterladen", "download_movie": "Film herunterladen", "download_x_item": "{{item_count}} Elemente herunterladen", - "download_unwatched_only": "Nur unbeobachtete", + "download_unwatched_only": "Nur Ungesehene", "download_button": "Herunterladen" } }, "live_tv": { - "next": "Nรคchster", - "previous": "Vorheriger", + "next": "Nรคchste", + "previous": "Vorherige", "coming_soon": "Demnรคchst", "on_now": "Jetzt", "shows": "Serien", @@ -658,10 +658,10 @@ "confirm": "Bestรคtigen", "cancel": "Abbrechen", "yes": "Ja", - "whats_wrong": "Hast du Probleme?", - "issue_type": "Fehlerart", - "select_an_issue": "Wรคhle einen Fehlerart aus", - "types": "Arten", + "whats_wrong": "Was stimmt nicht?", + "issue_type": "Art des Problems", + "select_an_issue": "Wรคhle die Art des Problems aus", + "types": "Problem-Arten", "describe_the_issue": "(optional) Beschreibe das Problem", "submit_button": "Absenden", "report_issue_button": "Fehler melden", @@ -671,7 +671,7 @@ "cast": "Besetzung", "details": "Details", "status": "Status", - "original_title": "Original Titel", + "original_title": "Originaltitel", "series_type": "Serien Typ", "release_dates": "Verรถffentlichungsdaten", "first_air_date": "Erstausstrahlungsdatum", @@ -687,10 +687,10 @@ "request_as": "Anfragen als", "tags": "Tags", "quality_profile": "Qualitรคtsprofil", - "root_folder": "Root-Ordner", - "season_all": "Season (all)", + "root_folder": "Stammverzeichnis", + "season_all": "Staffeln (alle)", "season_number": "Staffel {{season_number}}", - "number_episodes": "{{episode_number}} Folgen", + "number_episodes": "{{episode_number}} Episoden", "born": "Geboren", "appearances": "Auftritte", "approve": "Genehmigen", @@ -698,9 +698,9 @@ "requested_by": "Angefragt von {{user}}", "unknown_user": "Unbekannter Nutzer", "toasts": { - "jellyseer_does_not_meet_requirements": "Jellyseerr Server erfรผllt nicht die Anforderungsversion. Bitte aktualisiere deinen Jellyseerr Server auf mindestens 2.0.0", - "jellyseerr_test_failed": "Jellyseerr-Test fehlgeschlagen. Bitte versuche es erneut.", - "failed_to_test_jellyseerr_server_url": "Fehler beim Testen der Jellyseerr-Server-URL", + "jellyseer_does_not_meet_requirements": "Seerr-Server erfรผllt nicht die minimalen Versionsanforderungen. Bitte den Seerr-Server auf mindestens 2.0.0 aktualisieren.", + "jellyseerr_test_failed": "Seerr-Test fehlgeschlagen. Bitte erneut versuchen.", + "failed_to_test_jellyseerr_server_url": "Fehler beim Test der Seerr-Server-URL", "issue_submitted": "Problem eingereicht!", "requested_item": "{{item}} angefragt!", "you_dont_have_permission_to_request": "Du hast keine Berechtigung Anfragen zu stellen", @@ -715,131 +715,131 @@ "home": "Startseite", "search": "Suche", "library": "Bibliothek", - "custom_links": "Benutzerdefinierte Links", + "custom_links": "Links", "favorites": "Favoriten" }, "music": { - "title": "Music", + "title": "Musik", "tabs": { - "suggestions": "Suggestions", - "albums": "Albums", - "artists": "Artists", + "suggestions": "Vorschlรคge", + "albums": "Alben", + "artists": "Kรผnstler", "playlists": "Playlists", - "tracks": "tracks" + "tracks": "Titel" }, "filters": { - "all": "All" + "all": "Alle" }, - "recently_added": "Recently Added", - "recently_played": "Recently Played", - "frequently_played": "Frequently Played", - "explore": "Explore", - "top_tracks": "Top Tracks", - "play": "Play", + "recently_added": "Kรผrzlich hinzugefรผgt", + "recently_played": "Vor kurzem gehรถrt", + "frequently_played": "Oft gehรถrt", + "explore": "Entdecken", + "top_tracks": "Top-Titel", + "play": "Abspielen", "shuffle": "Shuffle", - "play_top_tracks": "Play Top Tracks", - "no_suggestions": "No suggestions available", - "no_albums": "No albums found", - "no_artists": "No artists found", - "no_playlists": "No playlists found", - "album_not_found": "Album not found", - "artist_not_found": "Artist not found", - "playlist_not_found": "Playlist not found", + "play_top_tracks": "Top-Tracks abspielen", + "no_suggestions": "Keine Vorschlรคge verfรผgbar", + "no_albums": "Keine Alben gefunden", + "no_artists": "Keine Kรผnstler gefunden", + "no_playlists": "Keine Playlists gefunden", + "album_not_found": "Album nicht gefunden", + "artist_not_found": "Kรผnstler nicht gefunden", + "playlist_not_found": "Playlist nicht gefunden", "track_options": { - "play_next": "Play Next", - "add_to_queue": "Add to Queue", - "add_to_playlist": "Add to Playlist", - "download": "Download", - "downloaded": "Downloaded", - "downloading": "Downloading...", - "cached": "Cached", - "delete_download": "Delete Download", - "delete_cache": "Remove from Cache", - "go_to_artist": "Go to Artist", - "go_to_album": "Go to Album", - "add_to_favorites": "Add to Favorites", - "remove_from_favorites": "Remove from Favorites", - "remove_from_playlist": "Remove from Playlist" + "play_next": "Als Nรคchstes wiedergeben", + "add_to_queue": "Zur Warteschlange hinzufรผgen", + "add_to_playlist": "Zur Playlist hinzufรผgen", + "download": "Herunterladen", + "downloaded": "Heruntergeladen", + "downloading": "Wird heruntergeladen...", + "cached": "Gecached", + "delete_download": "Download lรถschen", + "delete_cache": "Aus dem Cache lรถschen", + "go_to_artist": "Zum Kรผnstler gehen", + "go_to_album": "Zum Album gehen", + "add_to_favorites": "Zu Favoriten hinzufรผgen", + "remove_from_favorites": "Aus Favoriten entfernen", + "remove_from_playlist": "Aus Playlist entfernen" }, "playlists": { - "create_playlist": "Create Playlist", + "create_playlist": "Playlist erstellen", "playlist_name": "Playlist Name", - "enter_name": "Enter playlist name", - "create": "Create", - "search_playlists": "Search playlists...", - "added_to": "Added to {{name}}", - "added": "Added to playlist", - "removed_from": "Removed from {{name}}", - "removed": "Removed from playlist", - "created": "Playlist created", - "create_new": "Create New Playlist", - "failed_to_add": "Failed to add to playlist", - "failed_to_remove": "Failed to remove from playlist", - "failed_to_create": "Failed to create playlist", - "delete_playlist": "Delete Playlist", - "delete_confirm": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "deleted": "Playlist deleted", - "failed_to_delete": "Failed to delete playlist" + "enter_name": "Playlist Name eingeben", + "create": "Erstellen", + "search_playlists": "Playlisten durchsuchen...", + "added_to": "Zu {{name}} hinzugefรผgt", + "added": "Zur Playlist hinzugefรผgt", + "removed_from": "Aus {{name}} entfernt", + "removed": "Aus Playlist entfernt", + "created": "Playlist erstellt", + "create_new": "Neue Playlist erstellen", + "failed_to_add": "Fehler beim Hinzufรผgen zur Playlist", + "failed_to_remove": "Fehler beim Entfernen aus der Playlist", + "failed_to_create": "Fehler beim Erstellen der Playlist", + "delete_playlist": "Playlist lรถschen", + "delete_confirm": "Bist Du sicher, dass Du \"{{name}}\" lรถschen mรถchtest? Das kann nicht rรผckgรคngig gemacht werden.", + "deleted": "Playlist gelรถscht", + "failed_to_delete": "Fehler beim Lรถschen der Playlist" }, "sort": { - "title": "Sort By", - "alphabetical": "Alphabetical", - "date_created": "Date Created" + "title": "Sortieren nach", + "alphabetical": "Alphabetisch", + "date_created": "Erstellungsdatum" } }, "watchlists": { - "title": "Watchlists", - "my_watchlists": "My Watchlists", - "public_watchlists": "Public Watchlists", - "create_title": "Create Watchlist", - "edit_title": "Edit Watchlist", - "create_button": "Create Watchlist", - "save_button": "Save Changes", - "delete_button": "Delete", - "remove_button": "Remove", - "cancel_button": "Cancel", + "title": "Merklisten", + "my_watchlists": "Meine Merklisten", + "public_watchlists": "ร–ffentliche Merklisten", + "create_title": "Merkliste erstellen", + "edit_title": "Merkliste bearbeiten", + "create_button": "Merkliste erstellen", + "save_button": "ร„nderungen speichern", + "delete_button": "Lรถschen", + "remove_button": "Entfernen", + "cancel_button": "Abbrechen", "name_label": "Name", - "name_placeholder": "Enter watchlist name", - "description_label": "Description", - "description_placeholder": "Enter description (optional)", - "is_public_label": "Public Watchlist", - "is_public_description": "Allow others to view this watchlist", - "allowed_type_label": "Content Type", - "sort_order_label": "Default Sort Order", - "empty_title": "No Watchlists", - "empty_description": "Create your first watchlist to start organizing your media", - "empty_watchlist": "This watchlist is empty", - "empty_watchlist_hint": "Add items from your library to this watchlist", - "not_configured_title": "Streamystats Not Configured", - "not_configured_description": "Configure Streamystats in settings to use watchlists", - "go_to_settings": "Go to Settings", - "add_to_watchlist": "Add to Watchlist", - "remove_from_watchlist": "Remove from Watchlist", - "select_watchlist": "Select Watchlist", - "create_new": "Create New Watchlist", - "item": "item", - "items": "items", - "public": "Public", - "private": "Private", - "you": "You", - "by_owner": "By another user", - "not_found": "Watchlist not found", - "delete_confirm_title": "Delete Watchlist", - "delete_confirm_message": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "remove_item_title": "Remove from Watchlist", - "remove_item_message": "Remove \"{{name}}\" from this watchlist?", - "loading": "Loading watchlists...", - "no_compatible_watchlists": "No compatible watchlists", - "create_one_first": "Create a watchlist that accepts this content type" + "name_placeholder": "Merklistenname eingeben", + "description_label": "Beschreibung", + "description_placeholder": "Beschreibung eingeben (optional)", + "is_public_label": "ร–ffentliche Merkliste", + "is_public_description": "Anderen erlauben diese Merkliste anzusehen", + "allowed_type_label": "Inhaltstyp", + "sort_order_label": "Standard-Sortierreihenfolge", + "empty_title": "Keine Merklisten", + "empty_description": "Erstelle deine erste Merkliste um deine Medien zu organisieren", + "empty_watchlist": "Diese Merkliste ist leer", + "empty_watchlist_hint": "Fรผge Elemente aus deiner Bibliothek zu dieser Merkliste hinzu", + "not_configured_title": "Streamystats nicht konfiguriert", + "not_configured_description": "Streamystats in den Einstellungen konfigurieren, um Merklisten zu verwenden", + "go_to_settings": "Gehe zu Einstellungen", + "add_to_watchlist": "Zur Merkliste hinzufรผgen", + "remove_from_watchlist": "Von Merkliste entfernen", + "select_watchlist": "Merkliste auswรคhlen", + "create_new": "Neue Merkliste erstellen", + "item": "Element", + "items": "Elemente", + "public": "ร–ffentlich", + "private": "Privat", + "you": "Du", + "by_owner": "Von einem anderen Benutzer", + "not_found": "Merkliste nicht gefunden", + "delete_confirm_title": "Merkliste lรถschen", + "delete_confirm_message": "Bist Du sicher, dass Du \"{{name}}\" lรถschen mรถchtest? Das kann nicht rรผckgรคngig gemacht werden.", + "remove_item_title": "Von Merkliste entfernen", + "remove_item_message": "\"{{name}}\" von dieser Merkliste entfernen?", + "loading": "Lade Merklisten...", + "no_compatible_watchlists": "Keine kompatiblen Merklisten", + "create_one_first": "Erstelle eine Merkliste, welche diesen Inhaltstyp akzeptiert" }, "playback_speed": { - "title": "Playback Speed", - "apply_to": "Apply To", - "speed": "Speed", + "title": "Wiedergabegeschwindigkeit", + "apply_to": "Anwenden auf", + "speed": "Geschwindigkeit", "scope": { - "media": "This media only", - "show": "This show", - "all": "All media (default)" + "media": "Nur hier", + "show": "Nur diese Serie", + "all": "Alle (Standard)" } } } diff --git a/translations/es.json b/translations/es.json index 9ab662eb..c98493d9 100644 --- a/translations/es.json +++ b/translations/es.json @@ -39,39 +39,39 @@ "please_login_again": "Su sesiรณn guardada ha caducado. Por favor, inicie sesiรณn de nuevo.", "remove_saved_login": "Eliminar inicio de sesiรณn guardado", "remove_saved_login_description": "Esto eliminarรก tus credenciales guardadas para este servidor. Tendrรกs que volver a introducir tu nombre de usuario y contraseรฑa la prรณxima vez.", - "accounts_count": "{{count}} accounts", - "select_account": "Select Account", - "add_account": "Add Account", - "remove_account_description": "This will remove the saved credentials for {{username}}." + "accounts_count": "{{count}} cuentas", + "select_account": "Seleccione una cuenta", + "add_account": "Aรฑadir cuenta", + "remove_account_description": "Esto eliminarรก las credenciales guardadas para {{username}}." }, "save_account": { - "title": "Save Account", - "save_for_later": "Save this account", - "security_option": "Security Option", - "no_protection": "No protection", - "no_protection_desc": "Quick login without authentication", - "pin_code": "PIN code", - "pin_code_desc": "4-digit PIN required when switching", - "password": "Re-enter password", - "password_desc": "Password required when switching", - "save_button": "Save", - "cancel_button": "Cancel" + "title": "Guardar Cuenta", + "save_for_later": "Guardar esta cuenta", + "security_option": "Opciones de seguridad", + "no_protection": "Sin Protecciรณn", + "no_protection_desc": "Inicio de sesiรณn rรกpido sin autenticaciรณn", + "pin_code": "Cรณdigo PIN", + "pin_code_desc": "PIN de 4 dรญgitos requerido al cambiar", + "password": "Vuelva a introducir la contraseรฑa", + "password_desc": "Contraseรฑa requerida al cambiar", + "save_button": "Guardar", + "cancel_button": "Cancelar" }, "pin": { - "enter_pin": "Enter PIN", - "enter_pin_for": "Enter PIN for {{username}}", - "enter_4_digits": "Enter 4 digits", - "invalid_pin": "Invalid PIN", - "setup_pin": "Set Up PIN", - "confirm_pin": "Confirm PIN", - "pins_dont_match": "PINs don't match", - "forgot_pin": "Forgot PIN?", - "forgot_pin_desc": "Your saved credentials will be removed" + "enter_pin": "Introduce el PIN", + "enter_pin_for": "Introduzca el PIN para {{username}}", + "enter_4_digits": "Introduce 4 dรญgitos", + "invalid_pin": "PIN invรกlido", + "setup_pin": "Configurar PIN", + "confirm_pin": "Confirmar PIN", + "pins_dont_match": "Los cรณdigos PIN no coinciden", + "forgot_pin": "ยฟOlvidรณ el PIN?", + "forgot_pin_desc": "Sus credenciales guardadas serรกn eliminadas" }, "password": { - "enter_password": "Enter Password", - "enter_password_for": "Enter password for {{username}}", - "invalid_password": "Invalid password" + "enter_password": "Introduzca la contraseรฑa", + "enter_password_for": "Introduzca la contraseรฑa para {{username}}", + "invalid_password": "Contraseรฑa invรกlida" }, "home": { "checking_server_connection": "Comprobando conexiรณn con el servidor...", @@ -124,32 +124,32 @@ "hide_remote_session_button": "Ocultar botรณn de sesiรณn remota" }, "network": { - "title": "Network", - "local_network": "Local Network", - "auto_switch_enabled": "Auto-switch when at home", - "auto_switch_description": "Automatically switch to local URL when connected to home WiFi", - "local_url": "Local URL", - "local_url_hint": "Enter your local server address (e.g., http://192.168.1.100:8096)", + "title": "Cadena", + "local_network": "Red local", + "auto_switch_enabled": "Cambiar automรกticamente en casa", + "auto_switch_description": "Cambiar automรกticamente a la URL local cuando se conecta a la WiFi de casa", + "local_url": "URL local", + "local_url_hint": "Introduzca la direcciรณn de su servidor local (por ejemplo, http://192.168.1.100:8096)", "local_url_placeholder": "http://192.168.1.100:8096", - "home_wifi_networks": "Home WiFi Networks", - "add_current_network": "Add \"{{ssid}}\"", - "not_connected_to_wifi": "Not connected to WiFi", - "no_networks_configured": "No networks configured", - "add_network_hint": "Add your home WiFi network to enable auto-switching", - "current_wifi": "Current WiFi", - "using_url": "Using", - "local": "Local URL", - "remote": "Remote URL", - "not_connected": "Not connected", - "current_server": "Current Server", - "remote_url": "Remote URL", - "active_url": "Active URL", - "not_configured": "Not configured", - "network_added": "Network added", - "network_already_added": "Network already added", - "no_wifi_connected": "Not connected to WiFi", - "permission_denied": "Location permission denied", - "permission_denied_explanation": "Location permission is required to detect WiFi network for auto-switching. Please enable it in Settings." + "home_wifi_networks": "Redes WiFi domรฉsticas", + "add_current_network": "Aรฑadir \"{{ssid}}\"", + "not_connected_to_wifi": "No estรก conectado a WiFi", + "no_networks_configured": "No hay redes configuradas", + "add_network_hint": "Aรฑade tu red WiFi domรฉstica para activar el cambio automรกtico", + "current_wifi": "WiFi actual", + "using_url": "Utilizando", + "local": "URL local", + "remote": "URL Remota", + "not_connected": "Sin conexiรณn", + "current_server": "Servidor actual", + "remote_url": "URL Remota", + "active_url": "URL Activa", + "not_configured": "Sin configurar", + "network_added": "Red aรฑadida", + "network_already_added": "Red ya aรฑadida", + "no_wifi_connected": "Sin conexiรณn a WiFi", + "permission_denied": "Permiso de ubicaciรณn denegado", + "permission_denied_explanation": "Se necesita el permiso de ubicaciรณn para detectar la red WiFi para cambiar automรกticamente. Por favor, actรญvala en Configuraciรณn." }, "user_info": { "user_info_title": "Informaciรณn de usuario", @@ -195,12 +195,12 @@ "none": "Ninguno", "language": "Idioma", "transcode_mode": { - "title": "Audio Transcoding", - "description": "Controls how surround audio (7.1, TrueHD, DTS-HD) is handled", + "title": "Transcodificaciรณn de audio", + "description": "Controla cรณmo el audio envolvente (7.1, TrueHD, DTS-HD) es manejado", "auto": "Auto", - "stereo": "Force Stereo", - "5_1": "Allow 5.1", - "passthrough": "Passthrough" + "stereo": "Forzar salida estรฉreo", + "5_1": "Permitir 5.1", + "passthrough": "Directo" } }, "subtitles": { @@ -259,16 +259,16 @@ "hardware_decode_description": "Utilizar la aceleraciรณn de hardware para la decodificaciรณn de vรญdeo. Deshabilite si experimenta problemas de reproducciรณn." }, "vlc_subtitles": { - "title": "VLC Subtitle Settings", - "hint": "Customize subtitle appearance for VLC player. Changes take effect on next playback.", - "text_color": "Text Color", - "background_color": "Background Color", - "background_opacity": "Background Opacity", - "outline_color": "Outline Color", - "outline_opacity": "Outline Opacity", - "outline_thickness": "Outline Thickness", - "bold": "Bold Text", - "margin": "Bottom Margin" + "title": "Configuraciรณn de subtรญtulos VLC", + "hint": "Personalizar la apariencia de los subtรญtulos para el reproductor VLC. Los cambios tendrรกn efecto en la prรณxima reproducciรณn.", + "text_color": "Color del texto", + "background_color": "Color del fondo", + "background_opacity": "Opacidad del fondo", + "outline_color": "Color del contorno", + "outline_opacity": "Opacidad del contorno", + "outline_thickness": "Grosor del contorno", + "bold": "Texto en negrita", + "margin": "Margen inferior" }, "video_player": { "title": "Reproductor de vรญdeo", @@ -300,13 +300,13 @@ "VLC_4": "VLC 4 (Experimental + PiP)" }, "show_custom_menu_links": "Mostrar enlaces de menรบ personalizados", - "show_large_home_carousel": "Show Large Home Carousel (beta)", + "show_large_home_carousel": "Mostrar carrusel del menรบ principal grande (beta)", "hide_libraries": "Ocultar bibliotecas", "select_liraries_you_want_to_hide": "Selecciona las bibliotecas que quieres ocultar de la pestaรฑa Bibliotecas y de Inicio.", "disable_haptic_feedback": "Desactivar feedback hรกptico", "default_quality": "Calidad por defecto", "default_playback_speed": "Velocidad de reproducciรณn predeterminada", - "auto_play_next_episode": "Auto-play Next Episode", + "auto_play_next_episode": "Reproducir automรกticamente el siguiente episodio", "max_auto_play_episode_count": "Mรกximo nรบmero de episodios de Auto Play", "disabled": "Deshabilitado" }, @@ -317,10 +317,10 @@ "title": "Mรบsica", "playback_title": "Reproducir", "playback_description": "Configurar cรณmo se reproduce la mรบsica.", - "prefer_downloaded": "Prefer Downloaded Songs", + "prefer_downloaded": "Preferir las canciones descargadas", "caching_title": "Almacenando en cachรฉ", - "caching_description": "Automatically cache upcoming tracks for smoother playback.", - "lookahead_enabled": "Enable Look-Ahead Caching", + "caching_description": "Cachear automรกticamente las prรณximas canciones para una reproducciรณn mรกs suave.", + "lookahead_enabled": "Activar el look-Ahead Cache", "lookahead_count": "", "max_cache_size": "Tamaรฑo mรกximo del cachรฉ" }, @@ -399,7 +399,7 @@ "size_used": "{{used}} de {{total}} usado", "delete_all_downloaded_files": "Eliminar todos los archivos descargados", "music_cache_title": "Cachรฉ de mรบsica", - "music_cache_description": "Automatically cache songs as you listen for smoother playback and offline support", + "music_cache_description": "Cachear automรกticamente las canciones mientras escuchas una reproducciรณn mรกs suave y soporte sin conexiรณn", "enable_music_cache": "Activar Cachรฉ de Mรบsica", "clear_music_cache": "Borrar Cachรฉ de Mรบsica", "music_cache_size": "Cachรฉ {{Tamaรฑo}}", @@ -504,10 +504,10 @@ "delete": "Borrar", "ok": "Aceptar", "remove": "Eliminar", - "next": "Next", - "back": "Back", - "continue": "Continue", - "verifying": "Verifying..." + "next": "Siguiente", + "back": "Atrรกs", + "continue": "Continuar", + "verifying": "Verificando..." }, "search": { "search": "Buscar...", @@ -753,8 +753,8 @@ "downloaded": "Descargado", "downloading": "Descargando...", "cached": "En cachรฉ", - "delete_download": "Delete Download", - "delete_cache": "Remove from Cache", + "delete_download": "Eliminar descarga", + "delete_cache": "Borrar del cachรฉ", "go_to_artist": "Ir al artista", "go_to_album": "Ir al รกlbum", "add_to_favorites": "Aรฑadir a Favoritos", diff --git a/translations/fr.json b/translations/fr.json index 21fef280..b2663cd6 100644 --- a/translations/fr.json +++ b/translations/fr.json @@ -305,8 +305,8 @@ "select_liraries_you_want_to_hide": "Sรฉlectionnez les bibliothรจques que vous souhaitez masquer dans l'onglet Bibliothรจque et les sections de la page d'accueil.", "disable_haptic_feedback": "Dรฉsactiver le retour haptique", "default_quality": "Qualitรฉ par dรฉfaut", - "default_playback_speed": "Default Playback Speed", - "auto_play_next_episode": "Auto-play Next Episode", + "default_playback_speed": "Vitesse de lecture par dรฉfaut", + "auto_play_next_episode": "Lecture automatique de l'รฉpisode suivant", "max_auto_play_episode_count": "Nombre d'รฉpisodes en lecture automatique max", "disabled": "Dรฉsactivรฉ" }, @@ -314,15 +314,15 @@ "downloads_title": "Tรฉlรฉchargements" }, "music": { - "title": "Music", - "playback_title": "Playback", - "playback_description": "Configure how music is played.", - "prefer_downloaded": "Prefer Downloaded Songs", - "caching_title": "Caching", - "caching_description": "Automatically cache upcoming tracks for smoother playback.", - "lookahead_enabled": "Enable Look-Ahead Caching", - "lookahead_count": "Tracks to Pre-cache", - "max_cache_size": "Max Cache Size" + "title": "Musique", + "playback_title": "Lecture", + "playback_description": "Configurer le mode de lecture de la musique.", + "prefer_downloaded": "Supprimer toutes les musiques tรฉlรฉchargรฉes", + "caching_title": "Mise en cache", + "caching_description": "Mettre automatiquement en cache les pistes ร  venir pour une lecture plus fluide.", + "lookahead_enabled": "Activer la mise en cache guidรฉe", + "lookahead_count": "Pistes ร  prรฉ-mettre en cache", + "max_cache_size": "Taille max de cache" }, "plugins": { "plugins_title": "Plugins", @@ -357,19 +357,19 @@ "save_button": "Enregistrer", "toasts": { "saved": "Enregistrรฉ", - "refreshed": "Settings refreshed from server" + "refreshed": "Paramรจtres actualisรฉs depuis le serveur" }, - "refresh_from_server": "Refresh Settings from Server" + "refresh_from_server": "Rafraรฎchir les paramรจtres depuis le serveur" }, "streamystats": { - "enable_streamystats": "Enable Streamystats", - "disable_streamystats": "Disable Streamystats", - "enable_search": "Use for Search", + "enable_streamystats": "Activer Streamystats", + "disable_streamystats": "Dรฉsactiver Streamystats", + "enable_search": "Utiliser pour la recherche", "url": "URL", "server_url_placeholder": "http(s)://streamystats.example.com", - "streamystats_search_hint": "Enter the URL for your Streamystats server. The URL should include http or https and optionally the port.", - "read_more_about_streamystats": "Read More About Streamystats.", - "save_button": "Save", + "streamystats_search_hint": "Entrez l'URL de votre serveur Streamystats. L'URL doit inclure http ou https et รฉventuellement le port.", + "read_more_about_streamystats": "En savoir plus sur Streamystats.", + "save_button": "Enregistrer", "save": "Enregistrer", "features_title": "Fonctionnalitรฉs", "home_sections_title": "Sections de la page dยดaccueil", @@ -572,7 +572,7 @@ "genres": "Genres", "years": "Annรฉes", "sort_by": "Trier par", - "filter_by": "Filter By", + "filter_by": "Filtrer par", "sort_order": "Ordre de tri", "tags": "Tags" } @@ -719,127 +719,127 @@ "favorites": "Favoris" }, "music": { - "title": "Music", + "title": "Musique", "tabs": { "suggestions": "Suggestions", "albums": "Albums", - "artists": "Artists", + "artists": "Artistes", "playlists": "Playlists", - "tracks": "tracks" + "tracks": "morceaux" }, "filters": { - "all": "All" + "all": "Toutes" }, - "recently_added": "Recently Added", - "recently_played": "Recently Played", - "frequently_played": "Frequently Played", - "explore": "Explore", - "top_tracks": "Top Tracks", - "play": "Play", - "shuffle": "Shuffle", - "play_top_tracks": "Play Top Tracks", - "no_suggestions": "No suggestions available", - "no_albums": "No albums found", - "no_artists": "No artists found", - "no_playlists": "No playlists found", - "album_not_found": "Album not found", - "artist_not_found": "Artist not found", - "playlist_not_found": "Playlist not found", + "recently_added": "Ajoutรฉs rรฉcemment", + "recently_played": "Rรฉcemment jouรฉ", + "frequently_played": "Frรฉquemment jouรฉ", + "explore": "Explorez", + "top_tracks": "Top chansons", + "play": "Lecture", + "shuffle": "Alรฉatoire", + "play_top_tracks": "Jouer les pistes les plus populaires", + "no_suggestions": "Pas de suggestion disponible", + "no_albums": "Pas d'albums trouvรฉs", + "no_artists": "Pas d'artistes trouvรฉ", + "no_playlists": "Pas de playlists trouvรฉes", + "album_not_found": "Album introuvable", + "artist_not_found": "Artiste introuvable", + "playlist_not_found": "Playlist introuvable", "track_options": { - "play_next": "Play Next", - "add_to_queue": "Add to Queue", - "add_to_playlist": "Add to Playlist", - "download": "Download", - "downloaded": "Downloaded", - "downloading": "Downloading...", - "cached": "Cached", - "delete_download": "Delete Download", - "delete_cache": "Remove from Cache", - "go_to_artist": "Go to Artist", - "go_to_album": "Go to Album", - "add_to_favorites": "Add to Favorites", - "remove_from_favorites": "Remove from Favorites", - "remove_from_playlist": "Remove from Playlist" + "play_next": "Lecture suivante", + "add_to_queue": "Ajouter ร  la file d'attente", + "add_to_playlist": "Ajouter ร  la playlist", + "download": "Tรฉlรฉcharger", + "downloaded": "Tรฉlรฉchargรฉ", + "downloading": "Tรฉlรฉchargement en cours...", + "cached": "En cache", + "delete_download": "Supprimer un tรฉlรฉchargement", + "delete_cache": "Supprimer du cache", + "go_to_artist": "Voir l'artiste", + "go_to_album": "Aller ร  lโ€™album", + "add_to_favorites": "Ajouter aux favoris", + "remove_from_favorites": "Retirer des favoris", + "remove_from_playlist": "Retirer de la playlist" }, "playlists": { - "create_playlist": "Create Playlist", - "playlist_name": "Playlist Name", - "enter_name": "Enter playlist name", - "create": "Create", - "search_playlists": "Search playlists...", - "added_to": "Added to {{name}}", - "added": "Added to playlist", - "removed_from": "Removed from {{name}}", - "removed": "Removed from playlist", - "created": "Playlist created", - "create_new": "Create New Playlist", - "failed_to_add": "Failed to add to playlist", - "failed_to_remove": "Failed to remove from playlist", - "failed_to_create": "Failed to create playlist", - "delete_playlist": "Delete Playlist", - "delete_confirm": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "deleted": "Playlist deleted", - "failed_to_delete": "Failed to delete playlist" + "create_playlist": "Crรฉer une Playlist", + "playlist_name": "Nom de la Playlist", + "enter_name": "Entrer le nom de la playlist", + "create": "Crรฉer", + "search_playlists": "Rechercher des playlists...", + "added_to": "Ajoutรฉ ร  {{name}}", + "added": "Ajoutรฉ ร  la playlist", + "removed_from": "Retirรฉ de {{name}}", + "removed": "Retirรฉ de la playlist", + "created": "Playlist crรฉรฉe", + "create_new": "Crรฉer une nouvelle playlist", + "failed_to_add": "ร‰chec de l'ajout ร  la playlist", + "failed_to_remove": "ร‰chec de la suppression de la playlist", + "failed_to_create": "ร‰chec de la suppression de la playlist", + "delete_playlist": "Supprimer la playlist", + "delete_confirm": "รŠtes-vous sรปr de vouloir supprimer ยซ {{ name }} ยป ? Cette action est irrรฉversible.", + "deleted": "Playlist supprimรฉe", + "failed_to_delete": "ร‰chec de la suppression de la playlist" }, "sort": { - "title": "Sort By", - "alphabetical": "Alphabetical", - "date_created": "Date Created" + "title": "Trier par", + "alphabetical": "Ordre alphabรฉtique", + "date_created": "Date de crรฉation" } }, "watchlists": { "title": "Watchlists", "my_watchlists": "My Watchlists", - "public_watchlists": "Public Watchlists", - "create_title": "Create Watchlist", - "edit_title": "Edit Watchlist", - "create_button": "Create Watchlist", - "save_button": "Save Changes", - "delete_button": "Delete", - "remove_button": "Remove", - "cancel_button": "Cancel", - "name_label": "Name", - "name_placeholder": "Enter watchlist name", + "public_watchlists": "Watchlist publique", + "create_title": "Crรฉer une Watchlist", + "edit_title": "Modifier la Watchlist", + "create_button": "Crรฉer une Watchlist", + "save_button": "Enregistrer les modifications", + "delete_button": "Supprimer", + "remove_button": "Retirer", + "cancel_button": "Annuler", + "name_label": "Nom", + "name_placeholder": "Entrer le nom de la playlist", "description_label": "Description", - "description_placeholder": "Enter description (optional)", + "description_placeholder": "Entrez la description (facultatif)", "is_public_label": "Public Watchlist", - "is_public_description": "Allow others to view this watchlist", - "allowed_type_label": "Content Type", - "sort_order_label": "Default Sort Order", - "empty_title": "No Watchlists", - "empty_description": "Create your first watchlist to start organizing your media", - "empty_watchlist": "This watchlist is empty", - "empty_watchlist_hint": "Add items from your library to this watchlist", - "not_configured_title": "Streamystats Not Configured", - "not_configured_description": "Configure Streamystats in settings to use watchlists", - "go_to_settings": "Go to Settings", - "add_to_watchlist": "Add to Watchlist", - "remove_from_watchlist": "Remove from Watchlist", - "select_watchlist": "Select Watchlist", - "create_new": "Create New Watchlist", - "item": "item", - "items": "items", - "public": "Public", - "private": "Private", - "you": "You", - "by_owner": "By another user", - "not_found": "Watchlist not found", - "delete_confirm_title": "Delete Watchlist", - "delete_confirm_message": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "remove_item_title": "Remove from Watchlist", - "remove_item_message": "Remove \"{{name}}\" from this watchlist?", - "loading": "Loading watchlists...", - "no_compatible_watchlists": "No compatible watchlists", - "create_one_first": "Create a watchlist that accepts this content type" + "is_public_description": "Autoriser d'autres personnes ร  voir cette liste de suivi", + "allowed_type_label": "Type de contenu", + "sort_order_label": "Ordre de tri par dรฉfaut", + "empty_title": "Pas de Watchlists", + "empty_description": "Crรฉez votre premiรจre liste de suivi pour commencer ร  organiser vos mรฉdias", + "empty_watchlist": "Cette liste de suivi est vide", + "empty_watchlist_hint": "Ajouter des รฉlรฉments de votre bibliothรจque ร  cette liste de suivi", + "not_configured_title": "Streamystats non configurรฉ", + "not_configured_description": "Configurer Streamystats dans les paramรจtres pour utiliser les listes de suivi", + "go_to_settings": "Accรฉdez aux Paramรจtres", + "add_to_watchlist": "Ajouter ร  la Watchlist", + "remove_from_watchlist": "Retirer de la Watchlist", + "select_watchlist": "Sรฉlectionner la liste de suivi", + "create_new": "Crรฉer une Watchlist", + "item": "mรฉdias", + "items": "รฉlรฉment", + "public": "Publique", + "private": "Privรฉe", + "you": "Vous-mรชme", + "by_owner": "Par un autre utilisateur", + "not_found": "Playlist introuvable", + "delete_confirm_title": "Supprimer la Watchlist", + "delete_confirm_message": "Tous les mรฉdias (par dรฉfaut)", + "remove_item_title": "Retirer de la Watchlist", + "remove_item_message": "Retirer ยซ{{name}}ยป de cette liste de suivi?", + "loading": "Chargement des listes de suivi...", + "no_compatible_watchlists": "Aucune liste de suivi compatible", + "create_one_first": "Crรฉer une liste de suivi qui accepte ce type de contenu" }, "playback_speed": { - "title": "Playback Speed", - "apply_to": "Apply To", - "speed": "Speed", + "title": "Vitesse de lecture", + "apply_to": "Appliquer ร ", + "speed": "Vitesse", "scope": { - "media": "This media only", - "show": "This show", - "all": "All media (default)" + "media": "Ce mรฉdia uniquement", + "show": "Cette sรฉrie", + "all": "Tous les mรฉdias (par dรฉfaut)" } } } diff --git a/translations/it.json b/translations/it.json index a6de11c1..604934b7 100644 --- a/translations/it.json +++ b/translations/it.json @@ -34,9 +34,9 @@ "search_for_local_servers": "Ricerca dei server locali", "searching": "Cercando...", "servers": "Server", - "saved": "Saved", + "saved": "Salvato", "session_expired": "Session Expired", - "please_login_again": "Your saved session has expired. Please log in again.", + "please_login_again": "La tua sessione รจ scaduta. Si prega di eseguire nuovamente l'accesso.", "remove_saved_login": "Remove Saved Login", "remove_saved_login_description": "This will remove your saved credentials for this server. You'll need to enter your username and password again next time.", "accounts_count": "{{count}} accounts", @@ -125,7 +125,7 @@ }, "network": { "title": "Network", - "local_network": "Local Network", + "local_network": "", "auto_switch_enabled": "Auto-switch when at home", "auto_switch_description": "Automatically switch to local URL when connected to home WiFi", "local_url": "Local URL", @@ -137,7 +137,7 @@ "no_networks_configured": "No networks configured", "add_network_hint": "Add your home WiFi network to enable auto-switching", "current_wifi": "Current WiFi", - "using_url": "Using", + "using_url": "Sta utilizzando", "local": "Local URL", "remote": "Remote URL", "not_connected": "Not connected", diff --git a/translations/nl.json b/translations/nl.json index 326f9a1e..375aeab1 100644 --- a/translations/nl.json +++ b/translations/nl.json @@ -30,7 +30,7 @@ "connect_button": "Verbinden", "previous_servers": "vorige servers", "clear_button": "Wissen", - "swipe_to_remove": "Swipe to remove", + "swipe_to_remove": "Swipe om te verwijderen.", "search_for_local_servers": "Zoek naar lokale servers", "searching": "Zoeken...", "servers": "Servers", @@ -40,38 +40,38 @@ "remove_saved_login": "Opgeslagen login verwijderen", "remove_saved_login_description": "Hiermee worden uw opgeslagen gegevens voor deze server verwijderd. U moet uw gebruikersnaam en wachtwoord de volgende keer opnieuw invoeren.", "accounts_count": "{{count}} accounts", - "select_account": "Select Account", - "add_account": "Add Account", - "remove_account_description": "This will remove the saved credentials for {{username}}." + "select_account": "Account selecteren", + "add_account": "Account toevoegen", + "remove_account_description": "Hiermee worden de opgeslagen inloggegevens voor {{username}} verwijderd." }, "save_account": { - "title": "Save Account", - "save_for_later": "Save this account", - "security_option": "Security Option", - "no_protection": "No protection", - "no_protection_desc": "Quick login without authentication", - "pin_code": "PIN code", - "pin_code_desc": "4-digit PIN required when switching", - "password": "Re-enter password", - "password_desc": "Password required when switching", - "save_button": "Save", - "cancel_button": "Cancel" + "title": "Account opslaan", + "save_for_later": "Dit account opslaan", + "security_option": "Beveiligingsopties", + "no_protection": "Geen beveiliging", + "no_protection_desc": "Snelle login zonder authenticatie", + "pin_code": "Pincode", + "pin_code_desc": "4-cijferige pincode vereist bij wisselen", + "password": "Wachtwoord opnieuw invoeren", + "password_desc": "Wachtwoord vereist bij wisselen", + "save_button": "Opslaan", + "cancel_button": "Annuleren" }, "pin": { - "enter_pin": "Enter PIN", - "enter_pin_for": "Enter PIN for {{username}}", - "enter_4_digits": "Enter 4 digits", - "invalid_pin": "Invalid PIN", - "setup_pin": "Set Up PIN", - "confirm_pin": "Confirm PIN", - "pins_dont_match": "PINs don't match", - "forgot_pin": "Forgot PIN?", - "forgot_pin_desc": "Your saved credentials will be removed" + "enter_pin": "Pincode invoeren", + "enter_pin_for": "Pincode voor {{username}} invoeren", + "enter_4_digits": "Voer 6 cijfers in", + "invalid_pin": "Ongeldige pincode", + "setup_pin": "Pincode instellen", + "confirm_pin": "Pincode bevestigen", + "pins_dont_match": "Pincodes komen niet overeen", + "forgot_pin": "Pincode vergeten?", + "forgot_pin_desc": "Je opgeslagen inloggegevens worden verwijderd" }, "password": { - "enter_password": "Enter Password", - "enter_password_for": "Enter password for {{username}}", - "invalid_password": "Invalid password" + "enter_password": "Voer wachtwoord in", + "enter_password_for": "Voer wachtwoord voor {{username}} in", + "invalid_password": "Ongeldig wachtwoord" }, "home": { "checking_server_connection": "Serververbinding controleren...", @@ -84,7 +84,7 @@ "server_unreachable": "Server onbereikbaar", "server_unreachable_message": "Kon de server niet bereiken.\nControleer uw netwerkverbinding.", "oops": "Oeps!", - "error_message": "Er ging iets fout\nGelieve af en aan te melden.", + "error_message": "Er ging iets fout\nProbeer opnieuw in te loggen.", "continue_watching": "Verder Kijken", "next_up": "Volgende", "continue_and_next_up": "Doorgaan & Volgende", @@ -124,32 +124,32 @@ "hide_remote_session_button": "Verberg Knop voor Externe Sessie" }, "network": { - "title": "Network", - "local_network": "Local Network", - "auto_switch_enabled": "Auto-switch when at home", - "auto_switch_description": "Automatically switch to local URL when connected to home WiFi", - "local_url": "Local URL", - "local_url_hint": "Enter your local server address (e.g., http://192.168.1.100:8096)", + "title": "Netwerk", + "local_network": "Lokaal netwerk", + "auto_switch_enabled": "Automatisch wisselen wanneer thuis", + "auto_switch_description": "Automatisch wisselen naar lokale URL wanneer verbonden met thuisnetwerk", + "local_url": "Lokale URL", + "local_url_hint": "Voer uw lokale serveradres in (bijv. http://192.168.1.100:8096)", "local_url_placeholder": "http://192.168.1.100:8096", - "home_wifi_networks": "Home WiFi Networks", - "add_current_network": "Add \"{{ssid}}\"", - "not_connected_to_wifi": "Not connected to WiFi", - "no_networks_configured": "No networks configured", - "add_network_hint": "Add your home WiFi network to enable auto-switching", - "current_wifi": "Current WiFi", - "using_url": "Using", - "local": "Local URL", - "remote": "Remote URL", - "not_connected": "Not connected", - "current_server": "Current Server", - "remote_url": "Remote URL", - "active_url": "Active URL", - "not_configured": "Not configured", - "network_added": "Network added", - "network_already_added": "Network already added", - "no_wifi_connected": "Not connected to WiFi", - "permission_denied": "Location permission denied", - "permission_denied_explanation": "Location permission is required to detect WiFi network for auto-switching. Please enable it in Settings." + "home_wifi_networks": "Wi-Fi netwerken", + "add_current_network": "Voeg \"{{ssid}} \" toe", + "not_connected_to_wifi": "Niet verbonden met Wi-Fi", + "no_networks_configured": "Geen netwerken geconfigureerd", + "add_network_hint": "Voeg je thuisnetwerk toe om automatisch wisselen in te schakelen", + "current_wifi": "Huidige Wi-Fi", + "using_url": "Gebruik makend van", + "local": "Lokale URL", + "remote": "Externe URL", + "not_connected": "Niet verbonden", + "current_server": "Huidige Server", + "remote_url": "Externe URL", + "active_url": "Actieve URL", + "not_configured": "Niet geconfigureerd", + "network_added": "Netwerk toegevoegd", + "network_already_added": "Netwerk reeds toegevoegd", + "no_wifi_connected": "Niet verbonden met Wi-Fi", + "permission_denied": "Locatie toestemming geweigerd", + "permission_denied_explanation": "Locatie permissie is vereist om Wifi-netwerk te kunnen detecteren voor automatisch wisselen. Schakel het in via Instellingen." }, "user_info": { "user_info_title": "Gebruiker Info", @@ -195,11 +195,11 @@ "none": "Geen", "language": "Taal", "transcode_mode": { - "title": "Audio Transcoding", - "description": "Controls how surround audio (7.1, TrueHD, DTS-HD) is handled", - "auto": "Auto", - "stereo": "Force Stereo", - "5_1": "Allow 5.1", + "title": "Audio-transcoding", + "description": "Bepaalt hoe surround audio (7.1, TrueHD, DTS-HD) wordt behandeld", + "auto": "Automatisch", + "stereo": "Stereo forceren", + "5_1": "5.1 toestaan", "passthrough": "Passthrough" } }, @@ -231,7 +231,7 @@ "Black": "Zwart", "Gray": "Grijs", "Silver": "Zilver", - "White": "wit", + "White": "Wit", "Maroon": "Kastanjebruin", "Red": "Rood", "Fuchsia": "Fuchsia", @@ -259,14 +259,14 @@ "hardware_decode_description": "Gebruik hardware acceleratie voor video-decodering. Uitschakelen als u problemen met afspelen ondervindt." }, "vlc_subtitles": { - "title": "VLC Subtitle Settings", - "hint": "Customize subtitle appearance for VLC player. Changes take effect on next playback.", - "text_color": "Text Color", - "background_color": "Background Color", - "background_opacity": "Background Opacity", - "outline_color": "Outline Color", - "outline_opacity": "Outline Opacity", - "outline_thickness": "Outline Thickness", + "title": "VLC ondertitel instellingen", + "hint": "Aanpassen van ondertiteling voor VLC-speler. Wijzigingen worden toegepast bij het afspelen.", + "text_color": "Tekstkleur", + "background_color": "Achtergrondkleur", + "background_opacity": "Doorzichtigheid achtergrond", + "outline_color": "Kleur omlijning", + "outline_opacity": "Omtrek opaciteit", + "outline_thickness": "Omtrek dikte", "bold": "Bold Text", "margin": "Bottom Margin" }, @@ -306,7 +306,7 @@ "disable_haptic_feedback": "Haptische feedback uitschakelen", "default_quality": "Standaard kwaliteit", "default_playback_speed": "Standaard Afspeelsnelheid", - "auto_play_next_episode": "Auto-play Next Episode", + "auto_play_next_episode": "Volgende aflevering automatisch afspelen", "max_auto_play_episode_count": "Max Automatisch Aflevering Aantal", "disabled": "Uitgeschakeld" }, @@ -378,12 +378,12 @@ "enable_promoted_watchlists": "Gepromote Kijklijst", "hide_watchlists_tab": "Hide Watchlists Tab", "home_sections_hint": "Show personalized recommendations and promoted watchlists from Streamystats on the home page.", - "recommended_movies": "Recommended Movies", - "recommended_series": "Recommended Series", + "recommended_movies": "Aanbevolen films", + "recommended_series": "Aanbevolen serie", "toasts": { - "saved": "Saved", + "saved": "Opgeslagen", "refreshed": "Settings refreshed from server", - "disabled": "Streamystats disabled" + "disabled": "Streamystats uitgeschakeld" }, "refresh_from_server": "Refresh Settings from Server" }, @@ -402,24 +402,24 @@ "music_cache_description": "Automatically cache songs as you listen for smoother playback and offline support", "enable_music_cache": "Enable Music Cache", "clear_music_cache": "Clear Music Cache", - "music_cache_size": "{{size}} cached", - "music_cache_cleared": "Music cache cleared", - "delete_all_downloaded_songs": "Delete All Downloaded Songs", - "downloaded_songs_size": "{{size}} downloaded", + "music_cache_size": "{{size}} gecached", + "music_cache_cleared": "Muziek cache gewist", + "delete_all_downloaded_songs": "Verwijder alle gedownloade liedjes", + "downloaded_songs_size": "{{size}} gedownload", "downloaded_songs_deleted": "Downloaded songs deleted" }, "intro": { "title": "Intro", "show_intro": "Toon intro", - "reset_intro": "intro opnieuw instellen" + "reset_intro": "Reset Intro" }, "logs": { "logs_title": "Logboek", "export_logs": "Export logs", - "click_for_more_info": "Click for more info", + "click_for_more_info": "Klik voor meer info", "level": "Niveau", "no_logs_available": "Geen logs beschikbaar", - "delete_all_logs": "Verwijder alle logs" + "delete_all_logs": "Alle logs verwijderen" }, "languages": { "title": "Talen", @@ -500,14 +500,14 @@ "play": "Afspelen", "none": "Geen", "track": "Spoor", - "cancel": "Cancel", - "delete": "Delete", - "ok": "OK", - "remove": "Remove", - "next": "Next", - "back": "Back", - "continue": "Continue", - "verifying": "Verifying..." + "cancel": "Annuleren", + "delete": "Verwijderen", + "ok": "Okรฉ", + "remove": "Verwijderen", + "next": "Volgende", + "back": "Terug", + "continue": "Doorgaan", + "verifying": "Verifiรซren..." }, "search": { "search": "Zoek...", @@ -521,10 +521,10 @@ "episodes": "Afleveringen", "collections": "Collecties", "actors": "Acteurs", - "artists": "Artists", + "artists": "Artiesten", "albums": "Albums", - "songs": "Songs", - "playlists": "Playlists", + "songs": "Nummers", + "playlists": "Afspeellijsten", "request_movies": "Vraag films aan", "request_series": "Vraag series aan", "recently_added": "Recent Toegevoegd", @@ -572,7 +572,7 @@ "genres": "Genres", "years": "Jaren", "sort_by": "Sorteren op", - "filter_by": "Filter By", + "filter_by": "Filteren op", "sort_order": "Sorteer volgorde", "tags": "Labels" } @@ -719,127 +719,127 @@ "favorites": "Favorieten" }, "music": { - "title": "Music", + "title": "Muziek", "tabs": { - "suggestions": "Suggestions", + "suggestions": "Suggesties", "albums": "Albums", - "artists": "Artists", - "playlists": "Playlists", - "tracks": "tracks" + "artists": "Artiesten", + "playlists": "Afspeellijsten", + "tracks": "Nummers" }, "filters": { - "all": "All" + "all": "Alle" }, - "recently_added": "Recently Added", - "recently_played": "Recently Played", - "frequently_played": "Frequently Played", - "explore": "Explore", + "recently_added": "Recent toegevoegd", + "recently_played": "Onlangs afgespeeld", + "frequently_played": "Vaak afgespeeld", + "explore": "Ontdek", "top_tracks": "Top Tracks", - "play": "Play", + "play": "Afspelen", "shuffle": "Shuffle", "play_top_tracks": "Play Top Tracks", - "no_suggestions": "No suggestions available", - "no_albums": "No albums found", - "no_artists": "No artists found", - "no_playlists": "No playlists found", - "album_not_found": "Album not found", - "artist_not_found": "Artist not found", - "playlist_not_found": "Playlist not found", + "no_suggestions": "Geen suggesties beschikbaar", + "no_albums": "Geen albums gevonden", + "no_artists": "Geen artiesten gevonden", + "no_playlists": "Geen afspeellijsten gevonden", + "album_not_found": "Album niet gevonden", + "artist_not_found": "Artiest niet gevonden", + "playlist_not_found": "Afspeellijst niet gevonden", "track_options": { - "play_next": "Play Next", - "add_to_queue": "Add to Queue", - "add_to_playlist": "Add to Playlist", - "download": "Download", - "downloaded": "Downloaded", - "downloading": "Downloading...", - "cached": "Cached", - "delete_download": "Delete Download", - "delete_cache": "Remove from Cache", - "go_to_artist": "Go to Artist", - "go_to_album": "Go to Album", - "add_to_favorites": "Add to Favorites", - "remove_from_favorites": "Remove from Favorites", - "remove_from_playlist": "Remove from Playlist" + "play_next": "Speel volgende af", + "add_to_queue": "Toevoegen aan wachtrij", + "add_to_playlist": "Voeg toe aan afspeellijst", + "download": "Downloaden", + "downloaded": "Gedownload", + "downloading": "Downloaden...", + "cached": "Gecached", + "delete_download": "Download verwijderen", + "delete_cache": "Verwijderen uit cache", + "go_to_artist": "Ga naar artiest", + "go_to_album": "Ga naar album", + "add_to_favorites": "Toevoegen aan favorieten", + "remove_from_favorites": "Verwijderen uit favorieten", + "remove_from_playlist": "Verwijder uit afspeellijst" }, "playlists": { - "create_playlist": "Create Playlist", - "playlist_name": "Playlist Name", + "create_playlist": "Afspeellijst aanmaken", + "playlist_name": "Afspeellijst naam", "enter_name": "Enter playlist name", - "create": "Create", - "search_playlists": "Search playlists...", - "added_to": "Added to {{name}}", - "added": "Added to playlist", - "removed_from": "Removed from {{name}}", - "removed": "Removed from playlist", + "create": "Aanmaken", + "search_playlists": "Playlist zoeken...", + "added_to": "Toegevoegd aan {{name}}", + "added": "Toegevoegd aan playlist", + "removed_from": "Verwijderd uit {{name}}", + "removed": "Verwijderd uit playlist", "created": "Playlist created", "create_new": "Create New Playlist", "failed_to_add": "Failed to add to playlist", - "failed_to_remove": "Failed to remove from playlist", - "failed_to_create": "Failed to create playlist", - "delete_playlist": "Delete Playlist", - "delete_confirm": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "deleted": "Playlist deleted", - "failed_to_delete": "Failed to delete playlist" + "failed_to_remove": "Verwijderen uit afspeellijst is mislukt", + "failed_to_create": "Het maken van de afspeellijst is mislukt", + "delete_playlist": "Afspeellijst verwijderen", + "delete_confirm": "Weet u zeker dat u \"{{name}}\"wilt verwijderen? Deze actie kan niet ongedaan worden gemaakt.", + "deleted": "Afspeellijst verwijderd.", + "failed_to_delete": "Verwijderen van afspeellijst mislukt" }, "sort": { - "title": "Sort By", - "alphabetical": "Alphabetical", - "date_created": "Date Created" + "title": "Sorteren op", + "alphabetical": "Alfabetisch", + "date_created": "Aanmaakdatum" } }, "watchlists": { - "title": "Watchlists", - "my_watchlists": "My Watchlists", + "title": "Watchlist", + "my_watchlists": "Mijn watchlists", "public_watchlists": "Public Watchlists", "create_title": "Create Watchlist", "edit_title": "Edit Watchlist", "create_button": "Create Watchlist", - "save_button": "Save Changes", - "delete_button": "Delete", - "remove_button": "Remove", - "cancel_button": "Cancel", - "name_label": "Name", - "name_placeholder": "Enter watchlist name", - "description_label": "Description", - "description_placeholder": "Enter description (optional)", - "is_public_label": "Public Watchlist", - "is_public_description": "Allow others to view this watchlist", - "allowed_type_label": "Content Type", - "sort_order_label": "Default Sort Order", - "empty_title": "No Watchlists", - "empty_description": "Create your first watchlist to start organizing your media", - "empty_watchlist": "This watchlist is empty", - "empty_watchlist_hint": "Add items from your library to this watchlist", - "not_configured_title": "Streamystats Not Configured", - "not_configured_description": "Configure Streamystats in settings to use watchlists", - "go_to_settings": "Go to Settings", - "add_to_watchlist": "Add to Watchlist", - "remove_from_watchlist": "Remove from Watchlist", - "select_watchlist": "Select Watchlist", - "create_new": "Create New Watchlist", + "save_button": "Wijzigingen opslaan", + "delete_button": "Verwijder", + "remove_button": "Verwijderen", + "cancel_button": "Annuleren", + "name_label": "Naam", + "name_placeholder": "Voer naam van kijklijst in", + "description_label": "Beschrijving", + "description_placeholder": "Voer beschrijving in (optioneel)", + "is_public_label": "Openbare Kijklijst", + "is_public_description": "Sta anderen toe om deze kijklijst te bekijken", + "allowed_type_label": "Inhoudstype", + "sort_order_label": "Standaard Sortering", + "empty_title": "Geen Kijklijsten", + "empty_description": "Maak je eerste kijklijst om je media te organiseren", + "empty_watchlist": "Deze watchlist is leeg", + "empty_watchlist_hint": "Voeg items uit je bibliotheek toe aan deze kijklijst", + "not_configured_title": "Streamystats niet geconfigureerd", + "not_configured_description": "Configureer Streamystats in instellingen om kijklijsten te gebruiken", + "go_to_settings": "Ga naar Instellingen", + "add_to_watchlist": "Voeg toe aan kijklijst", + "remove_from_watchlist": "Verwijder van kijklijst", + "select_watchlist": "Selecteer kijklijst", + "create_new": "Nieuwe kijklijst aanmaken", "item": "item", "items": "items", - "public": "Public", - "private": "Private", - "you": "You", - "by_owner": "By another user", - "not_found": "Watchlist not found", - "delete_confirm_title": "Delete Watchlist", - "delete_confirm_message": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "remove_item_title": "Remove from Watchlist", - "remove_item_message": "Remove \"{{name}}\" from this watchlist?", - "loading": "Loading watchlists...", - "no_compatible_watchlists": "No compatible watchlists", - "create_one_first": "Create a watchlist that accepts this content type" + "public": "Publiek", + "private": "Privรฉ", + "you": "Jij", + "by_owner": "Door een andere gebruiker", + "not_found": "Kijklijst niet gevonden", + "delete_confirm_title": "Verwijder kijklijst", + "delete_confirm_message": "Weet u zeker dat u \"{{name}}\"wilt verwijderen? Deze actie kan niet ongedaan worden gemaakt.", + "remove_item_title": "Verwijder van watchlist", + "remove_item_message": "Verwijder \"{{name}}\" uit deze watchlist?", + "loading": "Laden van watchlists...", + "no_compatible_watchlists": "Geen compatibele watchlist", + "create_one_first": "Maak een watchlist aan die dit inhoudstype accepteert" }, "playback_speed": { - "title": "Playback Speed", - "apply_to": "Apply To", - "speed": "Speed", + "title": "Afspeelsnelheid", + "apply_to": "Toepassen op", + "speed": "Snelheid", "scope": { - "media": "This media only", - "show": "This show", - "all": "All media (default)" + "media": "Alleen deze media", + "show": "Deze serie", + "all": "Alle media (standaard)" } } } diff --git a/translations/tr.json b/translations/tr.json index 15bbebf8..667c2039 100644 --- a/translations/tr.json +++ b/translations/tr.json @@ -7,88 +7,88 @@ "username_placeholder": "Kullanฤฑcฤฑ adฤฑ", "password_placeholder": "ลžifre", "login_button": "GiriลŸ yap", - "quick_connect": "Hฤฑzlฤฑ BaฤŸlantฤฑ", + "quick_connect": "Hฤฑzlฤฑ BaฤŸlan", "enter_code_to_login": "GiriลŸ yapmak iรงin {{code}} kodunu girin", - "failed_to_initiate_quick_connect": "Quick Connect baลŸlatฤฑlamadฤฑ", + "failed_to_initiate_quick_connect": "Hฤฑzlฤฑ BaฤŸlan baลŸlatฤฑlamadฤฑ", "got_it": "AnlaลŸฤฑldฤฑ", "connection_failed": "BaฤŸlantฤฑ baลŸarฤฑsฤฑz", - "could_not_connect_to_server": "Sunucuya baฤŸlanฤฑlamadฤฑ. Lรผtfen URL'yi ve aฤŸ baฤŸlantฤฑnฤฑzฤฑ kontrol edin", + "could_not_connect_to_server": "Sunucuya baฤŸlanฤฑlamadฤฑ. Lรผtfen URL'yi ve aฤŸ baฤŸlantฤฑnฤฑzฤฑ kontrol edin.", "an_unexpected_error_occured": "Beklenmedik bir hata oluลŸtu", - "change_server": "Sunucuyu deฤŸiลŸtir", + "change_server": "Sunucu deฤŸiลŸtir", "invalid_username_or_password": "Geรงersiz kullanฤฑcฤฑ adฤฑ veya ลŸifre", "user_does_not_have_permission_to_log_in": "Kullanฤฑcฤฑnฤฑn giriลŸ yapma izni yok", - "server_is_taking_too_long_to_respond_try_again_later": "Sunucu yanฤฑt vermekte รงok uzun sรผrรผyor, lรผtfen tekrar deneyin", - "server_received_too_many_requests_try_again_later": "Sunucu รงok fazla istek aldฤฑ, lรผtfen tekrar deneyin.", + "server_is_taking_too_long_to_respond_try_again_later": "Sunucunun yanฤฑt vermesi รงok uzun sรผrรผyor, lรผtfen daha sonra tekrar deneyin", + "server_received_too_many_requests_try_again_later": "Sunucu รงok fazla istek aldฤฑ, lรผtfen daha sonra tekrar deneyin.", "there_is_a_server_error": "Sunucu hatasฤฑ var", - "an_unexpected_error_occured_did_you_enter_the_correct_url": "Beklenmedik bir hata oluลŸtu. Sunucu URL'sini doฤŸru girdiฤŸinizden emin oldunuz mu?", - "too_old_server_text": "Unsupported Jellyfin Server Discovered", - "too_old_server_description": "Please update Jellyfin to the latest version" + "an_unexpected_error_occured_did_you_enter_the_correct_url": "Beklenmedik bir hata oluลŸtu. Sunucu URL'sini doฤŸru girdiฤŸinizden emin misiniz?", + "too_old_server_text": "Desteklenmeyen Jellyfin Sunucu sรผrรผmรผ bulundu.", + "too_old_server_description": "Lรผtfen Jellyfin'i en son sรผrรผme gรผncelleyin." }, "server": { - "enter_url_to_jellyfin_server": "Jellyfin sunucunusun URL'sini girin", + "enter_url_to_jellyfin_server": "Jellyfin sunucunusun URL adresini girin", "server_url_placeholder": "http(s)://sunucunuz.com", "connect_button": "BaฤŸlan", "previous_servers": "ร–nceki sunucular", "clear_button": "Temizle", - "swipe_to_remove": "Swipe to remove", + "swipe_to_remove": "Kaldฤฑrmak iรงin kaydฤฑrฤฑn", "search_for_local_servers": "Yerel sunucularฤฑ ara", "searching": "Aranฤฑyor...", "servers": "Sunucular", - "saved": "Saved", - "session_expired": "Session Expired", - "please_login_again": "Your saved session has expired. Please log in again.", - "remove_saved_login": "Remove Saved Login", - "remove_saved_login_description": "This will remove your saved credentials for this server. You'll need to enter your username and password again next time.", - "accounts_count": "{{count}} accounts", - "select_account": "Select Account", - "add_account": "Add Account", - "remove_account_description": "This will remove the saved credentials for {{username}}." + "saved": "Kaydedildi", + "session_expired": "Oturum sรผresi doldu", + "please_login_again": "KaydedilmiลŸ oturumunuzun sรผresi doldu. Lรผtfen tekrar giriลŸ yapฤฑn.", + "remove_saved_login": "Kayฤฑtlฤฑ oturumu kaldฤฑr", + "remove_saved_login_description": "Bu sunucu iรงin kaydedilmiลŸ kimlik bilgileriniz kaldฤฑrฤฑlacaktฤฑr. Bir sonraki sefere kullanฤฑcฤฑ adฤฑ ve ลŸifrenizi yeniden girmeniz gerekecek.", + "accounts_count": "{{count}} hesap", + "select_account": "Hesap Seรง", + "add_account": "Hesap Ekle", + "remove_account_description": "{{username}} iรงin kayฤฑtlฤฑ bilgiler kaldฤฑrฤฑlacaktฤฑr." }, "save_account": { - "title": "Save Account", - "save_for_later": "Save this account", - "security_option": "Security Option", + "title": "Hesabฤฑ Kaydet", + "save_for_later": "Bu hesabฤฑ kaydet", + "security_option": "Gรผvenlik SeรงeneฤŸi", "no_protection": "No protection", - "no_protection_desc": "Quick login without authentication", - "pin_code": "PIN code", - "pin_code_desc": "4-digit PIN required when switching", - "password": "Re-enter password", - "password_desc": "Password required when switching", - "save_button": "Save", - "cancel_button": "Cancel" + "no_protection_desc": "Kimlik doฤŸrulamasฤฑz hฤฑzlฤฑ giriลŸ", + "pin_code": "PIN kodu", + "pin_code_desc": "GeรงiลŸ yaparken 4 haneli PIN kodu gereklidir", + "password": "ลžifrenizi tekrar girin ", + "password_desc": "GeรงiลŸ yaparken ลŸifre gereklidir", + "save_button": "Kaydet", + "cancel_button": "Vazgeรง" }, "pin": { - "enter_pin": "Enter PIN", - "enter_pin_for": "Enter PIN for {{username}}", - "enter_4_digits": "Enter 4 digits", - "invalid_pin": "Invalid PIN", - "setup_pin": "Set Up PIN", - "confirm_pin": "Confirm PIN", - "pins_dont_match": "PINs don't match", - "forgot_pin": "Forgot PIN?", - "forgot_pin_desc": "Your saved credentials will be removed" + "enter_pin": "PIN kodunu girin", + "enter_pin_for": "{{username}} iรงin PIN kodunu girin", + "enter_4_digits": "4 hane girin", + "invalid_pin": "Geรงersiz PIN kodu", + "setup_pin": "PIN kodunu ayarla", + "confirm_pin": "PIN kodunu onayla", + "pins_dont_match": "PIN kodlarฤฑ eลŸleลŸmiyor", + "forgot_pin": "PIN kodunu mu unuttunuz?", + "forgot_pin_desc": "Kayฤฑtlฤฑ bilgileriniz kaldฤฑrฤฑlacaktฤฑr" }, "password": { - "enter_password": "Enter Password", - "enter_password_for": "Enter password for {{username}}", - "invalid_password": "Invalid password" + "enter_password": "ลžifrenizi girin", + "enter_password_for": "{{username}} iรงin ลŸifrenizi girin", + "invalid_password": "Geรงersiz ลŸifre" }, "home": { - "checking_server_connection": "Checking server connection...", + "checking_server_connection": "Sunucu baฤŸlantฤฑsฤฑ kontrol ediliyor...", "no_internet": "ฤฐnternet Yok", "no_items": "ร–ge Yok", - "no_internet_message": "EndiลŸelenmeyin, hala\ndownloaded iรงerik izleyebilirsiniz.", - "checking_server_connection_message": "Checking connection to server", - "go_to_downloads": "ฤฐndirmelere Git", - "retry": "Retry", - "server_unreachable": "Server Unreachable", - "server_unreachable_message": "Could not reach the server.\nPlease check your network connection.", + "no_internet_message": "EndiลŸelenmeyin, indirilmiลŸ iรงerikleri izleyebilirsiniz.", + "checking_server_connection_message": "Sunucuya baฤŸlantฤฑ kontrol ediliyor", + "go_to_downloads": "ฤฐndirilenlere git", + "retry": "Tekrar dene", + "server_unreachable": "Sunucuya ulaลŸฤฑlamฤฑyor", + "server_unreachable_message": "Sunucuya baฤŸlanฤฑlamadฤฑ. Lรผtfen aฤŸ baฤŸlantฤฑnฤฑzฤฑ kontrol edin.", "oops": "Hups!", - "error_message": "Bir ลŸeyler ters gitti.\nLรผtfen รงฤฑkฤฑลŸ yapฤฑn ve tekrar giriลŸ yapฤฑn.", + "error_message": "Bir ลŸeyler ters gitti.\nLรผtfen รงฤฑkฤฑลŸ yapฤฑp tekrar giriลŸ yapฤฑn.", "continue_watching": "ฤฐzlemeye Devam Et", "next_up": "Sonraki", - "continue_and_next_up": "Continue & Next Up", - "recently_added_in": "{{libraryName}}'de Yakฤฑnlarda Eklendi", + "continue_and_next_up": "ฤฐzlemeye Devam Et & Sฤฑradakiler", + "recently_added_in": "{{libraryName}} Kรผtรผphanesine Son Eklenenler", "suggested_movies": "ร–nerilen Filmler", "suggested_episodes": "ร–nerilen Bรถlรผmler", "intro": { @@ -110,52 +110,52 @@ "settings_title": "Ayarlar", "log_out_button": "ร‡ฤฑkฤฑลŸ Yap", "categories": { - "title": "Categories" + "title": "Kategoriler" }, "playback_controls": { - "title": "Playback & Controls" + "title": "Oynatma & Kontroller" }, "audio_subtitles": { - "title": "Audio & Subtitles" + "title": "Ses & Altyazฤฑlar" }, "appearance": { - "title": "Appearance", - "merge_next_up_continue_watching": "Merge Continue Watching & Next Up", - "hide_remote_session_button": "Hide Remote Session Button" + "title": "Gรถrรผnรผm", + "merge_next_up_continue_watching": "ฤฐzlemeye Devam Et & Sฤฑradakiler'i birleลŸtir", + "hide_remote_session_button": "Uzak Oturum Butonunu Gizle" }, "network": { - "title": "Network", - "local_network": "Local Network", - "auto_switch_enabled": "Auto-switch when at home", - "auto_switch_description": "Automatically switch to local URL when connected to home WiFi", - "local_url": "Local URL", - "local_url_hint": "Enter your local server address (e.g., http://192.168.1.100:8096)", + "title": "AฤŸ", + "local_network": "Yerel AฤŸ", + "auto_switch_enabled": "Evdeyken otomatik geรงiลŸ yap", + "auto_switch_description": "Ev WiFi'sine baฤŸlanฤฑnca otomatik olarak yerek URL adresine geรงiลŸ yap", + "local_url": "Yerel URL Adresi", + "local_url_hint": "Yerel sunucu adresinizi girin (http://192.168.1.100:8096, gibi)", "local_url_placeholder": "http://192.168.1.100:8096", - "home_wifi_networks": "Home WiFi Networks", - "add_current_network": "Add \"{{ssid}}\"", - "not_connected_to_wifi": "Not connected to WiFi", - "no_networks_configured": "No networks configured", - "add_network_hint": "Add your home WiFi network to enable auto-switching", - "current_wifi": "Current WiFi", - "using_url": "Using", - "local": "Local URL", - "remote": "Remote URL", - "not_connected": "Not connected", - "current_server": "Current Server", - "remote_url": "Remote URL", - "active_url": "Active URL", - "not_configured": "Not configured", - "network_added": "Network added", - "network_already_added": "Network already added", - "no_wifi_connected": "Not connected to WiFi", - "permission_denied": "Location permission denied", - "permission_denied_explanation": "Location permission is required to detect WiFi network for auto-switching. Please enable it in Settings." + "home_wifi_networks": "Ev WiFi aฤŸlarฤฑ", + "add_current_network": "\"{{ssid}}\"'yi ekle", + "not_connected_to_wifi": "WiFi'a baฤŸlฤฑ deฤŸil", + "no_networks_configured": "Herhangi bir aฤŸ ayarlanmadฤฑ", + "add_network_hint": "Otomatik geรงiลŸi etkinleลŸtirmek iรงin ev WiFi'nizi ekleyin", + "current_wifi": "ลžu anki WiFi", + "using_url": "Kullanฤฑlฤฑyor", + "local": "Yerel URL Adresi", + "remote": "Uzak URL Adresi", + "not_connected": "BaฤŸlฤฑ deฤŸil", + "current_server": "Geรงerli Sunucu", + "remote_url": "Uzak URL Adresi", + "active_url": "Aktif URL Adresi", + "not_configured": "YapฤฑlandฤฑrฤฑlmamฤฑลŸ", + "network_added": "AฤŸ eklendi", + "network_already_added": "AฤŸ zaten eklendi", + "no_wifi_connected": "WiFi'a baฤŸlฤฑ deฤŸil", + "permission_denied": "Konum izni reddedildi", + "permission_denied_explanation": "Otomatik geรงiลŸ yapabilmek iรงin WiFi aฤŸฤฑnฤฑ algฤฑlayabilmek iรงin konum izni gereklidir. Lรผtfen Ayarlarda etkinleลŸtirin." }, "user_info": { "user_info_title": "Kullanฤฑcฤฑ Bilgisi", "user": "Kullanฤฑcฤฑ", "server": "Sunucu", - "token": "Token", + "token": "EriลŸim Anahtarฤฑ", "app_version": "Uygulama Sรผrรผmรผ" }, "quick_connect": { @@ -172,20 +172,20 @@ "media_controls_title": "Medya Kontrolleri", "forward_skip_length": "ฤฐleri Sarma UzunluฤŸu", "rewind_length": "Geri Sarma UzunluฤŸu", - "seconds_unit": "s" + "seconds_unit": "sn" }, "gesture_controls": { - "gesture_controls_title": "Gesture Controls", - "horizontal_swipe_skip": "Horizontal Swipe to Skip", - "horizontal_swipe_skip_description": "Swipe left/right when controls are hidden to skip", - "left_side_brightness": "Left Side Brightness Control", - "left_side_brightness_description": "Swipe up/down on left side to adjust brightness", - "right_side_volume": "Right Side Volume Control", - "right_side_volume_description": "Swipe up/down on right side to adjust volume", - "hide_volume_slider": "Hide Volume Slider", - "hide_volume_slider_description": "Hide the volume slider in the video player", - "hide_brightness_slider": "Hide Brightness Slider", - "hide_brightness_slider_description": "Hide the brightness slider in the video player" + "gesture_controls_title": "Hareketle Kontrol", + "horizontal_swipe_skip": "Atlamak iรงin yatay kaydฤฑrma", + "horizontal_swipe_skip_description": "Kontroller gizliyken sola/saฤŸa kaydฤฑrarak atlama", + "left_side_brightness": "Sol Taraf Parlaklฤฑk Kontrolรผ", + "left_side_brightness_description": "Sol tarafta aลŸaฤŸฤฑ/yukarฤฑ kaydฤฑrarak parlaklฤฑk ayarฤฑ", + "right_side_volume": "SaฤŸ Taraf Ses Kontrolรผ", + "right_side_volume_description": "SaฤŸ tarafta aลŸaฤŸฤฑ/yukarฤฑ kaydฤฑrarak ses ayarฤฑ", + "hide_volume_slider": "Ses Ayarฤฑnฤฑ Gizle", + "hide_volume_slider_description": "Video oynatฤฑcฤฑda ses ayarฤฑnฤฑ gizle", + "hide_brightness_slider": "Parlaklฤฑk Ayarฤฑnฤฑ Gizle", + "hide_brightness_slider_description": "Video oynatฤฑcฤฑda parlaklฤฑk ayarฤฑnฤฑ gizle" }, "audio": { "audio_title": "Ses", @@ -195,12 +195,12 @@ "none": "Yok", "language": "Dil", "transcode_mode": { - "title": "Audio Transcoding", - "description": "Controls how surround audio (7.1, TrueHD, DTS-HD) is handled", - "auto": "Auto", - "stereo": "Force Stereo", - "5_1": "Allow 5.1", - "passthrough": "Passthrough" + "title": "Ses Kod DรถnรผลŸtรผrmesi", + "description": "Surround sesin (7.1, TrueHD, DTS-HD) nasฤฑl iลŸleneceฤŸini kontrol eder.", + "auto": "Oto", + "stereo": "Stereo'ya zorla", + "5_1": "5.1'e izin ver", + "passthrough": "DoฤŸrudan geรงiลŸ" } }, "subtitles": { @@ -220,60 +220,60 @@ "None": "Yok", "OnlyForced": "Sadece Zorunlu" }, - "text_color": "Text Color", - "background_color": "Background Color", - "outline_color": "Outline Color", - "outline_thickness": "Outline Thickness", - "background_opacity": "Background Opacity", - "outline_opacity": "Outline Opacity", - "bold_text": "Bold Text", + "text_color": "Metin Rengi", + "background_color": "Arkaplan Rengi", + "outline_color": "Kenarlฤฑk Rengi", + "outline_thickness": "Kenarlฤฑk kalฤฑnlฤฑฤŸฤฑ", + "background_opacity": "Arkaplan OpaklฤฑฤŸฤฑ", + "outline_opacity": "Kenarlฤฑk OpaklฤฑฤŸฤฑ", + "bold_text": "Kalฤฑn Metin", "colors": { - "Black": "Black", - "Gray": "Gray", - "Silver": "Silver", - "White": "White", - "Maroon": "Maroon", - "Red": "Red", - "Fuchsia": "Fuchsia", - "Yellow": "Yellow", - "Olive": "Olive", - "Green": "Green", - "Teal": "Teal", - "Lime": "Lime", - "Purple": "Purple", - "Navy": "Navy", - "Blue": "Blue", - "Aqua": "Aqua" + "Black": "Siyah", + "Gray": "Gri", + "Silver": "GรผmรผลŸ", + "White": "Beyaz", + "Maroon": "Kestane", + "Red": "Kฤฑrmฤฑzฤฑ", + "Fuchsia": "FuลŸya", + "Yellow": "Sarฤฑ", + "Olive": "Zeytin yeลŸili", + "Green": "YeลŸil", + "Teal": "Deniz mavisi", + "Lime": "Limon", + "Purple": "Mor", + "Navy": "Lacivert", + "Blue": "Mavi", + "Aqua": "Aรงฤฑk Mavi" }, "thickness": { "None": "Hiรงbiri", - "Thin": "Thin", + "Thin": "ฤฐnce", "Normal": "Normal", - "Thick": "Thick" + "Thick": "Kalฤฑn" }, - "subtitle_color": "Subtitle Color", - "subtitle_background_color": "Background Color", - "subtitle_font": "Subtitle Font", - "ksplayer_title": "KSPlayer Settings", - "hardware_decode": "Hardware Decoding", - "hardware_decode_description": "Use hardware acceleration for video decoding. Disable if you experience playback issues." + "subtitle_color": "Altyazฤฑ Rengi", + "subtitle_background_color": "Arkaplan Rengi", + "subtitle_font": "Altyazฤฑ Yazฤฑ Tipi", + "ksplayer_title": "KSPlayer Ayarlarฤฑ", + "hardware_decode": "Donanฤฑmsal Kod ร‡รถzme", + "hardware_decode_description": "Video kod รงรถzme iรงin donanฤฑmsal hฤฑzlandฤฑrma kullan. Oynatma sorunlarฤฑ yaลŸฤฑyorsanฤฑz devre dฤฑลŸฤฑ bฤฑrakฤฑn." }, "vlc_subtitles": { - "title": "VLC Subtitle Settings", - "hint": "Customize subtitle appearance for VLC player. Changes take effect on next playback.", - "text_color": "Text Color", - "background_color": "Background Color", - "background_opacity": "Background Opacity", - "outline_color": "Outline Color", - "outline_opacity": "Outline Opacity", - "outline_thickness": "Outline Thickness", - "bold": "Bold Text", - "margin": "Bottom Margin" + "title": "VLC Altyazฤฑ Ayarlarฤฑ", + "hint": "VLC oynatฤฑcฤฑ iรงin altyazฤฑ gรถrรผnรผmรผnรผ deฤŸiลŸtirin. DeฤŸiลŸiklikler bir sonraki oynatmada etkili olacak.", + "text_color": "Metin Rengi", + "background_color": "Arkaplan Rengi", + "background_opacity": "Arkaplan OpaklฤฑฤŸฤฑ", + "outline_color": "Kenarlฤฑk Rengi", + "outline_opacity": "Kenarlฤฑk OpaklฤฑฤŸฤฑ", + "outline_thickness": "Kenarlฤฑk KalฤฑnlฤฑฤŸฤฑ", + "bold": "Kalฤฑn Metin", + "margin": "Alt Kenar BoลŸluฤŸu" }, "video_player": { - "title": "Video Player", - "video_player": "Video Player", - "video_player_description": "Choose which video player to use on iOS.", + "title": "Video oynatฤฑcฤฑsฤฑ", + "video_player": "Video oynatฤฑcฤฑsฤฑ", + "video_player_description": "iOS'da hangi video oynatฤฑcฤฑnฤฑn kullanฤฑlacaฤŸฤฑnฤฑ seรงin.", "ksplayer": "KSPlayer", "vlc": "VLC" }, @@ -297,7 +297,7 @@ "video_player": "Video player", "video_players": { "VLC_3": "VLC 3", - "VLC_4": "VLC 4 (Experimental + PiP)" + "VLC_4": "VLC 4 (Deneysel + PiP)" }, "show_custom_menu_links": "ร–zel Menรผ BaฤŸlantฤฑlarฤฑnฤฑ Gรถster", "show_large_home_carousel": "Show Large Home Carousel (beta)", @@ -305,24 +305,24 @@ "select_liraries_you_want_to_hide": "Kรผtรผphane sekmesinden ve ana sayfa bรถlรผmlerinden gizlemek istediฤŸiniz kรผtรผphaneleri seรงin.", "disable_haptic_feedback": "Dokunsal Geri Bildirimi Devre DฤฑลŸฤฑ Bฤฑrak", "default_quality": "Varsayฤฑlan kalite", - "default_playback_speed": "Default Playback Speed", - "auto_play_next_episode": "Auto-play Next Episode", - "max_auto_play_episode_count": "Max Auto Play Episode Count", + "default_playback_speed": "Varsayฤฑlan Oynatma Hฤฑzฤฑ", + "auto_play_next_episode": "Otomatik Sonraki Bรถlรผmรผ Oynat", + "max_auto_play_episode_count": "En Fazla Otomatik Oynatฤฑlacak Bรถlรผm Sayฤฑsฤฑ", "disabled": "Devre dฤฑลŸฤฑ" }, "downloads": { "downloads_title": "ฤฐndirmeler" }, "music": { - "title": "Music", - "playback_title": "Playback", - "playback_description": "Configure how music is played.", - "prefer_downloaded": "Prefer Downloaded Songs", - "caching_title": "Caching", - "caching_description": "Automatically cache upcoming tracks for smoother playback.", + "title": "Mรผzik", + "playback_title": "Oynatma", + "playback_description": "MรผziฤŸin nasฤฑl รงalฤฑnacaฤŸฤฑnฤฑ ayarlayฤฑn.", + "prefer_downloaded": "ฤฐndirilmiลŸ ลžarkฤฑlarฤฑ Tercih Et", + "caching_title": "ร–nbellekleme", + "caching_description": "Akฤฑcฤฑ oynatฤฑm iรงin gelecek ลŸarkฤฑlarฤฑ otomatik รถnbelleฤŸe al.", "lookahead_enabled": "Enable Look-Ahead Caching", - "lookahead_count": "Tracks to Pre-cache", - "max_cache_size": "Max Cache Size" + "lookahead_count": "ร–nden ร–nbelleklenecek Parรงa Sayฤฑsฤฑ", + "max_cache_size": "Maksimum ร–nbellek Boyutu" }, "plugins": { "plugins_title": "Eklentiler", @@ -345,7 +345,7 @@ "order_by": { "DEFAULT": "Varsayฤฑlan", "VOTE_COUNT_AND_AVERAGE": "Vote count and average", - "POPULARITY": "Popularity" + "POPULARITY": "Popรผlerlik" } }, "marlin_search": { @@ -357,35 +357,35 @@ "save_button": "Kaydet", "toasts": { "saved": "Kaydedildi", - "refreshed": "Settings refreshed from server" + "refreshed": "Ayarlar sunucudan yeniden alฤฑndฤฑ" }, - "refresh_from_server": "Refresh Settings from Server" + "refresh_from_server": "Ayarlarฤฑ Sunucudan Yeniden Al" }, "streamystats": { - "enable_streamystats": "Enable Streamystats", - "disable_streamystats": "Disable Streamystats", - "enable_search": "Use for Search", - "url": "URL", + "enable_streamystats": "Streamystats'ฤฑ EtkinleลŸtir", + "disable_streamystats": "Streamystats'ฤฑ Devre DฤฑลŸฤฑ Bฤฑrak", + "enable_search": "Arama iรงin kullan", + "url": "URL Adresi", "server_url_placeholder": "http(s)://streamystats.example.com", - "streamystats_search_hint": "Enter the URL for your Streamystats server. The URL should include http or https and optionally the port.", - "read_more_about_streamystats": "Read More About Streamystats.", - "save_button": "Save", - "save": "Save", - "features_title": "Features", + "streamystats_search_hint": "Streamystats sunucu URL'sini girin. URL, http veya https iรงermeli ve isteฤŸe baฤŸlฤฑ olarak portu iรงerebilir.", + "read_more_about_streamystats": "Streamystats hakkฤฑnda daha fazla bilgi.", + "save_button": "Kaydet", + "save": "Kaydet", + "features_title": "ร–zellikler", "home_sections_title": "Home Sections", - "enable_movie_recommendations": "Movie Recommendations", - "enable_series_recommendations": "Series Recommendations", + "enable_movie_recommendations": "Film ร–nerileri", + "enable_series_recommendations": "Dizi ร–nerileri", "enable_promoted_watchlists": "Promoted Watchlists", "hide_watchlists_tab": "Hide Watchlists Tab", "home_sections_hint": "Show personalized recommendations and promoted watchlists from Streamystats on the home page.", - "recommended_movies": "Recommended Movies", - "recommended_series": "Recommended Series", + "recommended_movies": "ร–nerilen Filmler", + "recommended_series": "ร–nerilen Diziler", "toasts": { - "saved": "Saved", - "refreshed": "Settings refreshed from server", - "disabled": "Streamystats disabled" + "saved": "Kaydedildi", + "refreshed": "Ayarlar sunucudan yeniden alฤฑndฤฑ", + "disabled": "Streamystats devre dฤฑลŸฤฑ" }, - "refresh_from_server": "Refresh Settings from Server" + "refresh_from_server": "Ayarlarฤฑ Sunucudan Yeniden Al" }, "kefinTweaks": { "watchlist_enabler": "Enable our Watchlist integration", @@ -398,18 +398,18 @@ "device_usage": "Cihaz {{availableSpace}}%", "size_used": "{{used}} / {{total}} kullanฤฑldฤฑ", "delete_all_downloaded_files": "Tรผm indirilen dosyalarฤฑ sil", - "music_cache_title": "Music Cache", + "music_cache_title": "Mรผzik ร–n BelleฤŸi", "music_cache_description": "Automatically cache songs as you listen for smoother playback and offline support", - "enable_music_cache": "Enable Music Cache", - "clear_music_cache": "Clear Music Cache", - "music_cache_size": "{{size}} cached", - "music_cache_cleared": "Music cache cleared", - "delete_all_downloaded_songs": "Delete All Downloaded Songs", - "downloaded_songs_size": "{{size}} downloaded", - "downloaded_songs_deleted": "Downloaded songs deleted" + "enable_music_cache": "Mรผzik ร–n BelleฤŸini EtkinleลŸtir", + "clear_music_cache": "Mรผzik ร–n BelleฤŸini Temizle", + "music_cache_size": "{{size}} รถn belleklendi", + "music_cache_cleared": "Mรผzik รถn belleฤŸi temizlendi", + "delete_all_downloaded_songs": "Tรผm ฤฐndirilen Mรผzikleri Sil", + "downloaded_songs_size": "{{size}} indirildi", + "downloaded_songs_deleted": "ฤฐndirilen mรผzikler silindi" }, "intro": { - "title": "Intro", + "title": "GiriลŸ", "show_intro": "Tanฤฑtฤฑmฤฑ Gรถster", "reset_intro": "Tanฤฑtฤฑmฤฑ Sฤฑfฤฑrla" }, @@ -417,7 +417,7 @@ "logs_title": "Gรผnlรผkler", "export_logs": "Export logs", "click_for_more_info": "Click for more info", - "level": "Level", + "level": "Dรผzey", "no_logs_available": "Gรผnlรผkler mevcut deฤŸil", "delete_all_logs": "Tรผm gรผnlรผkleri sil" }, @@ -433,22 +433,22 @@ } }, "sessions": { - "title": "Sessions", - "no_active_sessions": "No Active Sessions" + "title": "Oturumlar", + "no_active_sessions": "Aktif Oturum Yok" }, "downloads": { "downloads_title": "ฤฐndirilenler", "tvseries": "Diziler", "movies": "Filmler", "queue": "Sฤฑra", - "other_media": "Other media", + "other_media": "DiฤŸer medya", "queue_hint": "Sฤฑra ve indirmeler uygulama yeniden baลŸlatฤฑldฤฑฤŸฤฑnda kaybolacaktฤฑr", "no_items_in_queue": "Sฤฑrada รถฤŸe yok", "no_downloaded_items": "ฤฐndirilen รถฤŸe yok", "delete_all_movies_button": "Tรผm Filmleri Sil", "delete_all_tvseries_button": "Tรผm Dizileri Sil", "delete_all_button": "Tรผmรผnรผ Sil", - "delete_all_other_media_button": "Delete other media", + "delete_all_other_media_button": "DiฤŸer medyayฤฑ sil", "active_download": "Aktif indirme", "no_active_downloads": "Aktif indirme yok", "active_downloads": "Aktif indirmeler", @@ -465,49 +465,49 @@ "failed_to_delete_all_movies": "Filmler silinemedi", "deleted_all_tvseries_successfully": "Tรผm diziler baลŸarฤฑyla silindi!", "failed_to_delete_all_tvseries": "Diziler silinemedi", - "deleted_media_successfully": "Deleted other media Successfully!", + "deleted_media_successfully": "DiฤŸer medya baลŸarฤฑyla silindi!", "failed_to_delete_media": "Failed to Delete other media", - "download_deleted": "Download Deleted", + "download_deleted": "ฤฐndirme silindi", "download_cancelled": "ฤฐndirme iptal edildi", - "could_not_delete_download": "Could Not Delete Download", - "download_paused": "Download Paused", - "could_not_pause_download": "Could Not Pause Download", - "download_resumed": "Download Resumed", - "could_not_resume_download": "Could Not Resume Download", + "could_not_delete_download": "ฤฐndirme Silinemedi", + "download_paused": "ฤฐndirme Duraklatฤฑldฤฑ", + "could_not_pause_download": "ฤฐndirme Duraklatฤฑlamadฤฑ", + "download_resumed": "ฤฐndirme Devam Ediyor", + "could_not_resume_download": "ฤฐndirme Devam Ettirilemedi", "download_completed": "ฤฐndirme tamamlandฤฑ", - "download_failed": "Download Failed", + "download_failed": "ฤฐndirme baลŸarฤฑsฤฑz oldu", "download_failed_for_item": "{{item}} iรงin indirme baลŸarฤฑsฤฑz oldu - {{error}}", "download_completed_for_item": "{{item}} iรงin indirme tamamlandฤฑ", - "download_started_for_item": "Download Started for {{item}}", - "failed_to_start_download": "Failed to start download", - "item_already_downloading": "{{item}} is already downloading", - "all_files_deleted": "All Downloads Deleted Successfully", - "files_deleted_by_type": "{{count}} {{type}} deleted", + "download_started_for_item": "{{item}} iรงin indirme baลŸladฤฑ", + "failed_to_start_download": "ฤฐndirme baลŸlatฤฑlamadฤฑ", + "item_already_downloading": "{{item}} zaten indiriliyor", + "all_files_deleted": "Bรผtรผn indirilenler baลŸarฤฑyla silindi", + "files_deleted_by_type": "{{count}} {{type}} silindi", "all_files_folders_and_jobs_deleted_successfully": "Tรผm dosyalar, klasรถrler ve iลŸler baลŸarฤฑyla silindi", - "failed_to_clean_cache_directory": "Failed to clean cache directory", - "could_not_get_download_url_for_item": "Could not get download URL for {{itemName}}", + "failed_to_clean_cache_directory": "ร–nbellek dizini temizlenemedi", + "could_not_get_download_url_for_item": "{{itemName}} iรงin indirme URL'si alฤฑnamadฤฑ", "go_to_downloads": "ฤฐndirmelere git", - "file_deleted": "{{item}} deleted" + "file_deleted": "{{item}} silindi" } } }, "common": { - "select": "Select", - "no_trailer_available": "No trailer available", + "select": "Seรง", + "no_trailer_available": "Fragman mevcut deฤŸil", "video": "Video", "audio": "Ses", "subtitle": "Altyazฤฑ", - "play": "Play", - "none": "None", - "track": "Track", - "cancel": "Cancel", - "delete": "Delete", - "ok": "OK", - "remove": "Remove", - "next": "Next", - "back": "Back", - "continue": "Continue", - "verifying": "Verifying..." + "play": "Oynat", + "none": "Hiรงbiri", + "track": "Parรงa", + "cancel": "Vazgeรง", + "delete": "Sil", + "ok": "Tamam", + "remove": "Kaldฤฑr", + "next": "Sonraki", + "back": "Geri", + "continue": "Devam", + "verifying": "DoฤŸrulanฤฑyor..." }, "search": { "search": "Ara...", @@ -521,10 +521,10 @@ "episodes": "Bรถlรผmler", "collections": "Koleksiyonlar", "actors": "Oyuncular", - "artists": "Artists", - "albums": "Albums", - "songs": "Songs", - "playlists": "Playlists", + "artists": "Sanatรงฤฑlar", + "albums": "Albรผmler", + "songs": "ลžarkฤฑlar", + "playlists": "ร‡alma listeleri", "request_movies": "Film Talep Et", "request_series": "Dizi Talep Et", "recently_added": "Son Eklenenler", @@ -572,7 +572,7 @@ "genres": "Tรผrler", "years": "Yฤฑllar", "sort_by": "Sฤฑrala", - "filter_by": "Filter By", + "filter_by": "Filtrele", "sort_order": "Sฤฑralama dรผzeni", "tags": "Etiketler" } @@ -604,11 +604,11 @@ "index": "ฤฐndeks:", "continue_watching": "ฤฐzlemeye devam et", "go_back": "Geri", - "downloaded_file_title": "You have this file downloaded", - "downloaded_file_message": "Do you want to play the downloaded file?", - "downloaded_file_yes": "Yes", - "downloaded_file_no": "No", - "downloaded_file_cancel": "Cancel" + "downloaded_file_title": "Bu dosya indirilmiลŸ", + "downloaded_file_message": "ฤฐndirilmiลŸ dosyayฤฑ oynatmak ister misiniz?", + "downloaded_file_yes": "Evet", + "downloaded_file_no": "Hayฤฑr", + "downloaded_file_cancel": "Vazgeรง" }, "item_card": { "next_up": "Sฤฑradaki", @@ -624,7 +624,7 @@ "no_similar_items_found": "Benzer รถge bulunamadฤฑ", "video": "Video", "more_details": "Daha fazla detay", - "media_options": "Media Options", + "media_options": "Medya Seรงenekleri", "quality": "Kalite", "audio": "Ses", "subtitles": "Altyazฤฑ", @@ -639,7 +639,7 @@ "download_episode": "Bรถlรผmรผ indir", "download_movie": "Filmi indir", "download_x_item": "{{item_count}} tane รถgeyi indir", - "download_unwatched_only": "Unwatched Only", + "download_unwatched_only": "Yalnฤฑzca ฤฐzlenmemiลŸler", "download_button": "ฤฐndir" } }, @@ -693,10 +693,10 @@ "number_episodes": "Bรถlรผm {{episode_number}}", "born": "DoฤŸum", "appearances": "Gรถrรผnmeler", - "approve": "Approve", - "decline": "Decline", - "requested_by": "Requested by {{user}}", - "unknown_user": "Unknown User", + "approve": "Onayla", + "decline": "Reddet", + "requested_by": "{{user}} tarafฤฑndan istendi", + "unknown_user": "Bilinmeyen Kullanฤฑcฤฑ", "toasts": { "jellyseer_does_not_meet_requirements": "Jellyseerr sunucusu minimum sรผrรผm gereksinimlerini karลŸฤฑlamฤฑyor! Lรผtfen en az 2.0.0 sรผrรผmรผne gรผncelleyin", "jellyseerr_test_failed": "Jellyseerr testi baลŸarฤฑsฤฑz oldu. Lรผtfen tekrar deneyin.", @@ -705,10 +705,10 @@ "requested_item": "{{item}} talep edildi!", "you_dont_have_permission_to_request": "ฤฐstek gรถndermeye izniniz yok!", "something_went_wrong_requesting_media": "Medya talep edilirken bir ลŸeyler ters gitti!", - "request_approved": "Request Approved!", - "request_declined": "Request Declined!", - "failed_to_approve_request": "Failed to Approve Request", - "failed_to_decline_request": "Failed to Decline Request" + "request_approved": "ฤฐstek Onaylandฤฑ!", + "request_declined": "ฤฐstek Reddedildi!", + "failed_to_approve_request": "ฤฐsteฤŸi Onaylama BaลŸarฤฑsฤฑz Oldu", + "failed_to_decline_request": "ฤฐsteฤŸi Reddetme BaลŸarฤฑsฤฑz Oldu" } }, "tabs": { @@ -719,127 +719,127 @@ "favorites": "Favoriler" }, "music": { - "title": "Music", + "title": "Mรผzik", "tabs": { - "suggestions": "Suggestions", - "albums": "Albums", - "artists": "Artists", - "playlists": "Playlists", - "tracks": "tracks" + "suggestions": "ร–neriler", + "albums": "Albรผmler", + "artists": "Sanatรงฤฑlar", + "playlists": "ร‡alma listeleri", + "tracks": "parรงalar" }, "filters": { - "all": "All" + "all": "Tรผmรผ" }, - "recently_added": "Recently Added", - "recently_played": "Recently Played", - "frequently_played": "Frequently Played", - "explore": "Explore", - "top_tracks": "Top Tracks", - "play": "Play", - "shuffle": "Shuffle", - "play_top_tracks": "Play Top Tracks", - "no_suggestions": "No suggestions available", - "no_albums": "No albums found", - "no_artists": "No artists found", - "no_playlists": "No playlists found", - "album_not_found": "Album not found", - "artist_not_found": "Artist not found", - "playlist_not_found": "Playlist not found", + "recently_added": "Son Eklenenler", + "recently_played": "Son Oynatฤฑlanlar", + "frequently_played": "Sฤฑk Oynatฤฑlanlar", + "explore": "KeลŸfet", + "top_tracks": "En Popรผlar Parรงalar", + "play": "Oynat", + "shuffle": "KarฤฑลŸtฤฑr", + "play_top_tracks": "En ร‡ok Oynatฤฑlan Parรงalarฤฑ Oynat", + "no_suggestions": "ร–neri mevcut deฤŸil", + "no_albums": "Hiรง albรผm bulunamadฤฑ", + "no_artists": "Hiรง sanatรงฤฑ bulunamadฤฑ", + "no_playlists": "Hiรง รงalma listesi bulunamadฤฑ", + "album_not_found": "Albรผm bulunamadฤฑ", + "artist_not_found": "Sanatรงฤฑ bulunamadฤฑ", + "playlist_not_found": "ร‡alma listesi bulunamadฤฑ", "track_options": { - "play_next": "Play Next", - "add_to_queue": "Add to Queue", - "add_to_playlist": "Add to Playlist", - "download": "Download", - "downloaded": "Downloaded", - "downloading": "Downloading...", - "cached": "Cached", - "delete_download": "Delete Download", - "delete_cache": "Remove from Cache", - "go_to_artist": "Go to Artist", - "go_to_album": "Go to Album", - "add_to_favorites": "Add to Favorites", - "remove_from_favorites": "Remove from Favorites", - "remove_from_playlist": "Remove from Playlist" + "play_next": "Sฤฑradakini ร‡al", + "add_to_queue": "Sฤฑraya Ekle", + "add_to_playlist": "ร‡alma listesine ekle", + "download": "ฤฐndir", + "downloaded": "ฤฐndirildi", + "downloading": "ฤฐndiriliyor...", + "cached": "ร–nbellekte", + "delete_download": "ฤฐndirmeyi Sil", + "delete_cache": "ร–n bellekten kaldฤฑr", + "go_to_artist": "Sanatรงฤฑya Git", + "go_to_album": "Albรผme Git", + "add_to_favorites": "Favorilere Ekle", + "remove_from_favorites": "Favorilerden Kaldฤฑr", + "remove_from_playlist": "ร‡alma Listesinden Kaldฤฑr" }, "playlists": { - "create_playlist": "Create Playlist", - "playlist_name": "Playlist Name", - "enter_name": "Enter playlist name", - "create": "Create", - "search_playlists": "Search playlists...", - "added_to": "Added to {{name}}", - "added": "Added to playlist", - "removed_from": "Removed from {{name}}", - "removed": "Removed from playlist", - "created": "Playlist created", - "create_new": "Create New Playlist", - "failed_to_add": "Failed to add to playlist", - "failed_to_remove": "Failed to remove from playlist", - "failed_to_create": "Failed to create playlist", - "delete_playlist": "Delete Playlist", - "delete_confirm": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "deleted": "Playlist deleted", - "failed_to_delete": "Failed to delete playlist" + "create_playlist": "ร‡alma Listesi OluลŸtur", + "playlist_name": "ร‡alma Listesi Adฤฑ", + "enter_name": "ร‡alma listesi adฤฑ girin", + "create": "OluลŸtur", + "search_playlists": "ร‡alma listelerini ara...", + "added_to": "ลžu รงalma listesine eklendi: {{name}}", + "added": "ร‡alma listesine eklendi", + "removed_from": "ลžu รงalma listesinden kaldฤฑrฤฑldฤฑ: {{name}}", + "removed": "ร‡alma listesinden kaldฤฑr", + "created": "ร‡alma listesi oluลŸturuldu", + "create_new": "Yeni ร‡alma Listesi OluลŸtur", + "failed_to_add": "ร‡alma listesine eklenemedi", + "failed_to_remove": "ร‡alma listesinden kaldฤฑrฤฑlamadฤฑ", + "failed_to_create": "ร‡alma listesi oluลŸturulamadฤฑ", + "delete_playlist": "ร‡alma Listesini Sil", + "delete_confirm": "\"{{name}}\" adlฤฑ รงalma listesini silmek istediฤŸinize emin misiniz? Bu iลŸlem geri alฤฑnamaz.", + "deleted": "ร‡alma listesi silindi", + "failed_to_delete": "ร‡alma listesi oluลŸturulamadฤฑ" }, "sort": { - "title": "Sort By", - "alphabetical": "Alphabetical", - "date_created": "Date Created" + "title": "Sฤฑrala", + "alphabetical": "Alfabetik", + "date_created": "OluลŸturulma Tarihi" } }, "watchlists": { - "title": "Watchlists", - "my_watchlists": "My Watchlists", - "public_watchlists": "Public Watchlists", - "create_title": "Create Watchlist", - "edit_title": "Edit Watchlist", - "create_button": "Create Watchlist", - "save_button": "Save Changes", - "delete_button": "Delete", - "remove_button": "Remove", - "cancel_button": "Cancel", + "title": "ฤฐzleme listeleri", + "my_watchlists": "ฤฐzleme listelerim", + "public_watchlists": "Herkese aรงฤฑk izleme listeleri", + "create_title": "ฤฐzleme listesi oluลŸtur", + "edit_title": "ฤฐzleme listesini dรผzenle", + "create_button": "ฤฐzleme listesi oluลŸtur", + "save_button": "DeฤŸiลŸiklikleri Kaydet", + "delete_button": "Sil", + "remove_button": "Kaldฤฑr", + "cancel_button": "Vazgeรง", "name_label": "Name", - "name_placeholder": "Enter watchlist name", - "description_label": "Description", - "description_placeholder": "Enter description (optional)", - "is_public_label": "Public Watchlist", - "is_public_description": "Allow others to view this watchlist", - "allowed_type_label": "Content Type", - "sort_order_label": "Default Sort Order", - "empty_title": "No Watchlists", + "name_placeholder": "ฤฐzleme listesi adฤฑnฤฑ girin", + "description_label": "Aรงฤฑklama", + "description_placeholder": "Aรงฤฑklama girin (isteฤŸe baฤŸlฤฑ)", + "is_public_label": "Herkese aรงฤฑk izleme listesi", + "is_public_description": "BaลŸkalarฤฑnฤฑn da bu izleme listesini gรถrmesine izin ver", + "allowed_type_label": "ฤฐรงerik Tรผrรผ", + "sort_order_label": "Varsayฤฑlan Sฤฑralama", + "empty_title": "ฤฐzleme listesi yok", "empty_description": "Create your first watchlist to start organizing your media", - "empty_watchlist": "This watchlist is empty", - "empty_watchlist_hint": "Add items from your library to this watchlist", - "not_configured_title": "Streamystats Not Configured", - "not_configured_description": "Configure Streamystats in settings to use watchlists", - "go_to_settings": "Go to Settings", - "add_to_watchlist": "Add to Watchlist", - "remove_from_watchlist": "Remove from Watchlist", - "select_watchlist": "Select Watchlist", - "create_new": "Create New Watchlist", - "item": "item", - "items": "items", - "public": "Public", - "private": "Private", - "you": "You", - "by_owner": "By another user", - "not_found": "Watchlist not found", - "delete_confirm_title": "Delete Watchlist", + "empty_watchlist": "Bu izleme listesi boลŸ", + "empty_watchlist_hint": "Kรผtรผphanenizdeki nesneleri bu izleme listesine ekleyin", + "not_configured_title": "Streamystats ayarlanmamฤฑลŸ", + "not_configured_description": "ฤฐzleme listelerini kullanmak iรงin ayarlardan Streamystats'ฤฑ ayarlayฤฑn", + "go_to_settings": "Ayarlara git", + "add_to_watchlist": "ฤฐzleme Listesine Ekle", + "remove_from_watchlist": "ฤฐzleme Listesinden Kaldฤฑr", + "select_watchlist": "ฤฐzleme Listesi Seรง", + "create_new": "Yeni ฤฐzleme Listesi OluลŸtur", + "item": "รถฤŸe", + "items": "รถฤŸeler", + "public": "Herkese Aรงฤฑk", + "private": "ร–zel", + "you": "Siz", + "by_owner": "BaลŸka kullanฤฑcฤฑ tarafฤฑndan", + "not_found": "ฤฐzleme listesi bulunamadฤฑ", + "delete_confirm_title": "ฤฐzleme listesini sil", "delete_confirm_message": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "remove_item_title": "Remove from Watchlist", - "remove_item_message": "Remove \"{{name}}\" from this watchlist?", - "loading": "Loading watchlists...", - "no_compatible_watchlists": "No compatible watchlists", - "create_one_first": "Create a watchlist that accepts this content type" + "remove_item_title": "ฤฐzleme Listesinden Kaldฤฑr", + "remove_item_message": "{{name}} bu izleme listesinden kaldฤฑrฤฑlsฤฑn mฤฑ?", + "loading": "ฤฐzleme listeleri yรผkleniyor...", + "no_compatible_watchlists": "Uyumlu izleme listesi yok", + "create_one_first": "Bu iรงerik tรผrรผnรผ kabul eden bir izleme listesi oluลŸturun" }, "playback_speed": { - "title": "Playback Speed", - "apply_to": "Apply To", - "speed": "Speed", + "title": "Oynatma Hฤฑzฤฑ", + "apply_to": "ลžuna Uygula", + "speed": "Hฤฑz", "scope": { - "media": "This media only", - "show": "This show", - "all": "All media (default)" + "media": "Yalnฤฑzca bu medyada", + "show": "Bu dizide", + "all": "Bรผtรผn medyalarda (varsayฤฑlan)" } } } From 479e23f001c09ee0ddd3f6c70341e0226a5b4527 Mon Sep 17 00:00:00 2001 From: Gallyam Biktashev Date: Sat, 21 Feb 2026 22:51:01 +0500 Subject: [PATCH 15/39] fix(i18n): Update transalation for Russian lang (#1427) Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- translations/ru.json | 632 +++++++++++++++++++++---------------------- 1 file changed, 316 insertions(+), 316 deletions(-) diff --git a/translations/ru.json b/translations/ru.json index 17f526d5..a49a5409 100644 --- a/translations/ru.json +++ b/translations/ru.json @@ -34,44 +34,44 @@ "search_for_local_servers": "ะŸะพะธัะบ ะปะพะบะฐะปัŒะฝั‹ั… ัะตั€ะฒะตั€ะพะฒ", "searching": "ะŸะพะธัะบ...", "servers": "ะกะตั€ะฒะตั€ะฐ", - "saved": "Saved", - "session_expired": "Session Expired", - "please_login_again": "Your saved session has expired. Please log in again.", - "remove_saved_login": "Remove Saved Login", - "remove_saved_login_description": "This will remove your saved credentials for this server. You'll need to enter your username and password again next time.", - "accounts_count": "{{count}} accounts", - "select_account": "Select Account", - "add_account": "Add Account", - "remove_account_description": "This will remove the saved credentials for {{username}}." + "saved": "ะกะพั…ั€ะฐะฝะตะฝะพ", + "session_expired": "ะกะตััะธั ะธัั‚ะตะบะปะฐ", + "please_login_again": "ะ’ะฐัˆะฐ ัะตััะธั ะธัั‚ะตะบะปะฐ. ะŸะพะถะฐะปัƒะนัั‚ะฐ, ะฒะพะนะดะธั‚ะต ัะฝะพะฒะฐ.", + "remove_saved_login": "ะฃะดะฐะปะธั‚ัŒ ัะพั…ั€ะฐะฝะตะฝะฝั‹ะน ะฐะบะบะฐัƒะฝั‚", + "remove_saved_login_description": "ะ’ะฐัˆะธ ัะพั…ั€ะฐะฝั‘ะฝะฝั‹ะต ะดะฐะฝะฝั‹ะต ะดะปั ะฒั…ะพะดะฐ ะพั‚ ัั‚ะพะณะพ ัะตั€ะฒะตั€ะฐ ะฑัƒะดัƒั‚ ัƒะดะฐะปะตะฝั‹. ะ’ะฐะผ ะฟั€ะธะดั‘ั‚ัั ะฒะฒะตัั‚ะธ ะฒะฐัˆะธ ะปะพะณะธะฝ ะธ ะฟะฐั€ะพะปัŒ ะตั‰ั‘ ั€ะฐะท.", + "accounts_count": "{{count}} ะฐะบะบะฐัƒะฝั‚ะพะฒ", + "select_account": "ะ’ั‹ะฑั€ะฐั‚ัŒ ะฐะบะบะฐัƒะฝั‚", + "add_account": "ะ”ะพะฑะฐะฒะธั‚ัŒ ะฐะบะบะฐัƒะฝั‚", + "remove_account_description": "ะ”ะฐะฝะฝั‹ะต ะดะปั ะฒั…ะพะดะฐ {{username}} ะฑัƒะดัƒั‚ ัƒะดะฐะปะตะฝั‹." }, "save_account": { - "title": "Save Account", - "save_for_later": "Save this account", - "security_option": "Security Option", - "no_protection": "No protection", - "no_protection_desc": "Quick login without authentication", - "pin_code": "PIN code", - "pin_code_desc": "4-digit PIN required when switching", - "password": "Re-enter password", - "password_desc": "Password required when switching", - "save_button": "Save", - "cancel_button": "Cancel" + "title": "ะกะพั…ั€ะฐะฝะธั‚ัŒ ะฐะบะบะฐัƒะฝั‚", + "save_for_later": "ะกะพั…ั€ะฐะฝะธั‚ัŒ ัั‚ะพั‚ ะฐะบะบะฐัƒะฝั‚", + "security_option": "ะžะฟั†ะธะธ ะฑะตะทะพะฟะฐัะฝะพัั‚ะธ", + "no_protection": "ะ‘ะตะท ะทะฐั‰ะธั‚ั‹", + "no_protection_desc": "ะ‘ั‹ัั‚ั€ั‹ะน ะฒั…ะพะด ะฑะตะท ะฒะฒะพะดะฐ ะดะฐะฝะฝั‹ั…", + "pin_code": "PIN-ะบะพะด", + "pin_code_desc": "ะŸั€ะธ ะฟะตั€ะตะบะปัŽั‡ะตะฝะธะธ ะฑัƒะดะตั‚ ั‚ั€ะตะฑะพะฒะฐั‚ัŒัั 4-ะทะฝะฐั‡ะฝั‹ะน PIN", + "password": "ะŸะฐั€ะพะปัŒ", + "password_desc": "ะŸั€ะธ ะฟะตั€ะตะบะปัŽั‡ะตะฝะธะธ ะฑัƒะดะตั‚ ั‚ั€ะตะฑะพะฒะฐั‚ัŒัั ะฟะฐั€ะพะปัŒ", + "save_button": "ะกะพั…ั€ะฐะฝะธั‚ัŒ", + "cancel_button": "ะžั‚ะผะตะฝะฐ" }, "pin": { - "enter_pin": "Enter PIN", - "enter_pin_for": "Enter PIN for {{username}}", - "enter_4_digits": "Enter 4 digits", - "invalid_pin": "Invalid PIN", - "setup_pin": "Set Up PIN", - "confirm_pin": "Confirm PIN", - "pins_dont_match": "PINs don't match", - "forgot_pin": "Forgot PIN?", - "forgot_pin_desc": "Your saved credentials will be removed" + "enter_pin": "ะ’ะฒะตะดะธั‚ะต PIN", + "enter_pin_for": "ะ’ะฒะตะดะธั‚ะต PIN ะดะปั {{username}}", + "enter_4_digits": "ะ’ะฒะตะดะธั‚ะต 4 ั†ะธั„ั€ั‹", + "invalid_pin": "ะะตะบะพั€ั€ะตะบั‚ะฝั‹ะน PIN", + "setup_pin": "ะฃัั‚ะฐะฝะพะฒะธั‚ัŒ PIN", + "confirm_pin": "ะŸะพะดั‚ะฒะตั€ะดะธั‚ะต PIN", + "pins_dont_match": "PIN-ะบะพะดั‹ ะฝะต ัะพะฒะฟะฐะดะฐัŽั‚", + "forgot_pin": "ะ—ะฐะฑั‹ะปะธ PIN?", + "forgot_pin_desc": "ะ’ะฐัˆะธ ะดะฐะฝะฝั‹ะต ะดะปั ะฒั…ะพะดะฐ ะฑัƒะดัƒั‚ ัƒะดะฐะปะตะฝั‹" }, "password": { - "enter_password": "Enter Password", - "enter_password_for": "Enter password for {{username}}", - "invalid_password": "Invalid password" + "enter_password": "ะ’ะฒะตะดะธั‚ะต ะฟะฐั€ะพะปัŒ", + "enter_password_for": "ะ’ะฒะตะดะธั‚ะต ะฟะฐั€ะพะปัŒ ะดะปั {{username}}", + "invalid_password": "ะะตะฒะตั€ะฝั‹ะน ะฟะฐั€ะพะปัŒ" }, "home": { "checking_server_connection": "ะŸั€ะพะฒะตั€ะบะฐ ัะพะตะดะธะฝะตะฝะธั ั ัะตั€ะฒะตั€ะพะผ...", @@ -82,12 +82,12 @@ "go_to_downloads": "ะ’ ะทะฐะณั€ัƒะทะบะธ", "retry": "ะŸะพะฒั‚ะพั€ะธั‚ัŒ", "server_unreachable": "ะกะตั€ะฒะตั€ ะฝะตะดะพัั‚ัƒะฟะตะฝ", - "server_unreachable_message": "Could not reach the server.\nPlease check your network connection.", + "server_unreachable_message": "ะะต ัƒะดะฐะปะพััŒ ัะพะตะดะธะฝะธั‚ัŒัั ั ัะตั€ะฒะตั€ะพะผ.\nะŸะพะถะฐะปัƒะนัั‚ะฐ, ะฟั€ะพะฒะตั€ัŒั‚ะต ะฝะฐัั‚ั€ะพะนะบะธ ัะตั‚ะธ.", "oops": "ะฃะฟั!", "error_message": "ะงั‚ะพ-ั‚ะพ ะฟะพัˆะปะพ ะฝะต ั‚ะฐะบ.\nะŸะพะถะฐะปัƒะนัั‚ะฐ ะฒั‹ะนะดะธั‚ะต ะธ ะทะฐะนะดะธั‚ะต ัะฝะพะฒะฐ.", - "continue_watching": "ะŸั€ะพะดะพะปะถะธั‚ัŒ ะฟั€ะพัะผะพั‚ั€", - "next_up": "ะกะปะตะดัƒัŽั‰ะตะต", - "continue_and_next_up": "Continue & Next Up", + "continue_watching": "ะŸั€ะพะดะพะปะถะธั‚ัŒ", + "next_up": "ะ”ะฐะปะตะต", + "continue_and_next_up": "ะŸั€ะพะดะพะปะถะธั‚ัŒ ะธ ะ”ะฐะปะตะต", "recently_added_in": "ะะตะดะฐะฒะฝะพ ะดะพะฑะฐะฒะปะตะฝะพ ะฒ {{libraryName}}", "suggested_movies": "ะŸั€ะตะดะปะพะถะตะฝะฝั‹ะต ั„ะธะปัŒะผั‹", "suggested_episodes": "ะŸั€ะตะดะปะพะถะตะฝะฝั‹ะต ัะตั€ะธะธ", @@ -110,46 +110,46 @@ "settings_title": "ะะฐัั‚ั€ะพะนะบะธ", "log_out_button": "ะ’ั‹ะนั‚ะธ", "categories": { - "title": "Categories" + "title": "ะšะฐั‚ะตะณะพั€ะธะธ" }, "playback_controls": { - "title": "Playback & Controls" + "title": "ะ’ะพัะฟั€ะพะธะทะฒะตะดะตะฝะธะต ะธ ัƒะฟั€ะฐะฒะปะตะฝะธะต" }, "audio_subtitles": { - "title": "Audio & Subtitles" + "title": "ะัƒะดะธะพ ะธ ััƒะฑั‚ะธั‚ั€ั‹" }, "appearance": { - "title": "Appearance", - "merge_next_up_continue_watching": "Merge Continue Watching & Next Up", - "hide_remote_session_button": "Hide Remote Session Button" + "title": "ะ’ะฝะตัˆะฝะธะน ะฒะธะด", + "merge_next_up_continue_watching": "ะžะฑัŠะตะดะธะฝะธั‚ัŒ ยซะŸั€ะพะดะพะปะถะธั‚ัŒยป ะธ ยซะ”ะฐะปะตะตยป", + "hide_remote_session_button": "ะกะบั€ั‹ั‚ัŒ ะบะฝะพะฟะบัƒ ยซะฃะดะฐะปั‘ะฝะฝั‹ะน ัะตะฐะฝัยป" }, "network": { - "title": "Network", - "local_network": "Local Network", - "auto_switch_enabled": "Auto-switch when at home", - "auto_switch_description": "Automatically switch to local URL when connected to home WiFi", - "local_url": "Local URL", - "local_url_hint": "Enter your local server address (e.g., http://192.168.1.100:8096)", + "title": "ะกะตั‚ัŒ", + "local_network": "ะ›ะพะบะฐะปัŒะฝะฐั ัะตั‚ัŒ", + "auto_switch_enabled": "ะŸะตั€ะตะบะปัŽั‡ะฐั‚ัŒัั ะดะพะผะฐ ะฐะฒั‚ะพะผะฐั‚ะธั‡ะตัะบะธ", + "auto_switch_description": "ะะฒั‚ะพะผะฐั‚ะธั‡ะตัะบะธ ะฟะตั€ะตะบะปัŽั‡ะฐั‚ัŒัั ะฝะฐ ะปะพะบะฐะปัŒะฝั‹ะน URL ะฟั€ะธ ะฟั€ะธัะพะตะดะธะฝะตะฝะธะธ ะบ ะดะพะผะฐัˆะฝะตะน WiFi ัะตั‚ะธ", + "local_url": "ะ›ะพะบะฐะปัŒะฝั‹ะน URL", + "local_url_hint": "ะ’ะฒะตะดะธั‚ะต ะปะพะบะฐะปัŒะฝั‹ะน URL ะฒะฐัˆะตะณะพ ัะตั€ะฒะตั€ะฐ (e.g., http://192.168.1.100:8096)", "local_url_placeholder": "http://192.168.1.100:8096", - "home_wifi_networks": "Home WiFi Networks", - "add_current_network": "Add \"{{ssid}}\"", - "not_connected_to_wifi": "Not connected to WiFi", - "no_networks_configured": "No networks configured", - "add_network_hint": "Add your home WiFi network to enable auto-switching", - "current_wifi": "Current WiFi", - "using_url": "Using", - "local": "Local URL", - "remote": "Remote URL", - "not_connected": "Not connected", - "current_server": "Current Server", - "remote_url": "Remote URL", - "active_url": "Active URL", - "not_configured": "Not configured", - "network_added": "Network added", - "network_already_added": "Network already added", - "no_wifi_connected": "Not connected to WiFi", - "permission_denied": "Location permission denied", - "permission_denied_explanation": "Location permission is required to detect WiFi network for auto-switching. Please enable it in Settings." + "home_wifi_networks": "ะ”ะพะผะฐัˆะฝะธะต WiFi ัะตั‚ะธ", + "add_current_network": "ะ”ะพะฑะฐะฒะธั‚ัŒ \"{{ssid}}\"", + "not_connected_to_wifi": "ะะตั‚ WiFi ัะพะตะดะธะฝะตะฝะธั", + "no_networks_configured": "ะะตั‚ ะฝะฐัั‚ั€ะพะตะฝะฝั‹ั… ัะตั‚ะตะน", + "add_network_hint": "ะ”ะพะฑะฐะฒัŒั‚ะต ะฒะฐัˆัƒ ะดะพะผะฐัˆะฝัŽัŽ ัะตั‚ัŒ WiFi ะดะปั ะฒะบะปัŽั‡ะตะฝะธั ะฐะฒั‚ะพะผะฐั‚ะธั‡ะตัะบะพะณะพ ะฟะตั€ะตะบะปัŽั‡ะตะฝะธั", + "current_wifi": "ะขะตะบัƒั‰ะฐั WiFi ัะตั‚ัŒ", + "using_url": "ะ˜ัะฟะพะปัŒะทัƒะตั‚ัั", + "local": "ะ›ะพะบะฐะปัŒะฝั‹ะน", + "remote": "ะ’ะฝะตัˆะฝะธะน", + "not_connected": "ะะตั‚ ัะพะตะดะธะฝะตะฝะธั", + "current_server": "ะขะตะบัƒั‰ะธะน ัะตั€ะฒะตั€", + "remote_url": "ะ’ะฝะตัˆะฝะธะน URL", + "active_url": "ะะบั‚ะธะฒะฝั‹ะน URL", + "not_configured": "ะะต ะฝะฐัั‚ั€ะพะตะฝะพ", + "network_added": "ะกะตั‚ัŒ ะดะพะฑะฐะฒะปะตะฝะฐ", + "network_already_added": "ะกะตั‚ัŒ ัƒะถะต ะดะพะฑะฐะฒะปะตะฝะฐ", + "no_wifi_connected": "ะะตั‚ WiFi ัะพะตะดะธะฝะตะฝะธั", + "permission_denied": "ะะตั‚ ะดะพัั‚ัƒะฟะฐ ะบ ะผะตัั‚ะพะฟะพะปะพะถะตะฝะธัŽ", + "permission_denied_explanation": "ะ ะฐะทั€ะตัˆะตะฝะธะต ะฝะฐ ะดะพัั‚ัƒะฟ ะบ ะผะตัั‚ะพะฟะพะปะพะถะตะฝะธัŽ ะพะฑัะทะฐั‚ะตะปัŒะฝะพ ะดะปั ะพะฑะฝะฐั€ัƒะถะตะฝะธั WiFi ัะตั‚ะธ ะฟั€ะธ ะฐะฒั‚ะพะผะฐั‚ะธั‡ะตัะบะพะผ ะฟะตั€ะตะบะปัŽั‡ะตะฝะธะธ. ะŸะพะถะฐะปัƒะนัั‚ะฐ, ะฒะบะปัŽั‡ะธั‚ะต ะตะณะพ ะฒ ะฝะฐัั‚ั€ะพะนะบะฐั…." }, "user_info": { "user_info_title": "ะ˜ะฝั„ะพั€ะผะฐั†ะธั ะพ ะฟะพะปัŒะทะพะฒะฐั‚ะตะปะต", @@ -170,22 +170,22 @@ }, "media_controls": { "media_controls_title": "ะœะตะดะธะฐ-ะบะพะฝั‚ั€ะพะปัŒ", - "forward_skip_length": "ะ”ะปะธะฝะฐ ะฟั€ะพะฟัƒัะบะฐ ะฒะฟะตั€ะตะด", - "rewind_length": "ะ”ะปะธะฝะฐ ะฟะตั€ะตะผะพั‚ะบะธ", + "forward_skip_length": "ะจะฐะณ ะฟะตั€ะตะผะพั‚ะบะธ ะฒะฟะตั€ั‘ะด", + "rewind_length": "ะจะฐะณ ะฟะตั€ะตะผะพั‚ะบะธ ะฝะฐะทะฐะด", "seconds_unit": "c" }, "gesture_controls": { "gesture_controls_title": "ะฃะฟั€ะฐะฒะปะตะฝะธะต ะถะตัั‚ะฐะผะธ", - "horizontal_swipe_skip": "ะ“ะพั€ะธะทะพะฝั‚ะฐะปัŒะฝั‹ะน ัะฒะฐะนะฟ, ั‡ั‚ะพะฑั‹ ะฟั€ะพะฟัƒัั‚ะธั‚ัŒ", + "horizontal_swipe_skip": "ะ“ะพั€ะธะทะพะฝั‚ะฐะปัŒะฝั‹ะน ัะฒะฐะนะฟ ะดะปั ะฟะตั€ะตะผะพั‚ะบะธ", "horizontal_swipe_skip_description": "ะŸั€ะพะฒะตะดะธั‚ะต ะฒะปะตะฒะพ/ะฒะฟั€ะฐะฒะพ, ะบะพะณะดะฐ ัะปะตะผะตะฝั‚ั‹ ัƒะฟั€ะฐะฒะปะตะฝะธั ัะบั€ั‹ั‚ั‹, ั‡ั‚ะพะฑั‹ ะฟั€ะพะฟัƒัั‚ะธั‚ัŒ", "left_side_brightness": "ะฃะฟั€ะฐะฒะปะตะฝะธะต ัั€ะบะพัั‚ัŒัŽ ะปะตะฒะพะน ัั‚ะพั€ะพะฝั‹", "left_side_brightness_description": "ะกะผะฐั…ะฝะธั‚ะต ะฒะฒะตั€ั…/ะฒะฝะธะท ะฝะฐ ะปะตะฒะพะน ัั‚ะพั€ะพะฝะต ะดะปั ะฝะฐัั‚ั€ะพะนะบะธ ัั€ะบะพัั‚ะธ", "right_side_volume": "ะฃะฟั€ะฐะฒะปะตะฝะธะต ะณั€ะพะผะบะพัั‚ัŒัŽ ัะฟั€ะฐะฒะฐ", "right_side_volume_description": "ะกะฒะฐะนะฟ ะฒะฒะตั€ั…/ะฒะฝะธะท ั ะฟั€ะฐะฒะพะน ัั‚ะพั€ะพะฝั‹ ะดะปั ะฝะฐัั‚ั€ะพะนะบะธ ะณั€ะพะผะบะพัั‚ะธ", - "hide_volume_slider": "Hide Volume Slider", - "hide_volume_slider_description": "Hide the volume slider in the video player", - "hide_brightness_slider": "Hide Brightness Slider", - "hide_brightness_slider_description": "Hide the brightness slider in the video player" + "hide_volume_slider": "ะกะบั€ั‹ั‚ัŒ ะธะฝะดะธะบะฐั‚ะพั€ ะณั€ะพะผะบะพัั‚ะธ", + "hide_volume_slider_description": "ะกะบั€ั‹ะฒะฐะตั‚ ะธะฝะดะธะบะฐั‚ะพั€ ะณั€ะพะผะบะพัั‚ะธ ะฒ ะฟะปะตะตั€ะต", + "hide_brightness_slider": "ะกะบั€ั‹ั‚ัŒ ะธะฝะดะธะบะฐั‚ะพั€ ัั€ะบะพัั‚ะธ", + "hide_brightness_slider_description": "ะกะบั€ั‹ะฒะฐะตั‚ ะธะฝะดะธะบะฐั‚ะพั€ ัั€ะบะพัั‚ะธ ะฒ ะฟะปะตะตั€ะต" }, "audio": { "audio_title": "ะัƒะดะธะพ", @@ -195,17 +195,17 @@ "none": "ะžั‚ััƒั‚ัั‚ะฒัƒะตั‚", "language": "ะฏะทั‹ะบ", "transcode_mode": { - "title": "Audio Transcoding", - "description": "Controls how surround audio (7.1, TrueHD, DTS-HD) is handled", - "auto": "Auto", - "stereo": "Force Stereo", - "5_1": "Allow 5.1", - "passthrough": "Passthrough" + "title": "ะŸะตั€ะตะบะพะดะธั€ะพะฒะบะฐ ะฐัƒะดะธะพ", + "description": "ะฃะฟั€ะฐะฒะปัะตั‚ ะพะฑั€ะฐะฑะพั‚ะบะพะน ะฟั€ะพัั‚ั€ะฐะฝัั‚ะฒะตะฝะฝะพะณะพ ะทะฒัƒะบะฐ (7.1, TrueHD, DTS-HD)", + "auto": "ะะฒั‚ะพ", + "stereo": "ะŸั€ะธะฝัƒะดะธั‚ะตะปัŒะฝะพ ะฒ ัั‚ะตั€ะตะพ", + "5_1": "ะ ะฐะทั€ะตัˆะธั‚ัŒ 5.1", + "passthrough": "ะะธั‡ะตะณะพ ะฝะต ะธะทะผะตะฝัั‚ัŒ" } }, "subtitles": { "subtitle_title": "ะกัƒะฑั‚ะธั‚ั€ั‹", - "subtitle_hint": "ะะฐัั‚ั€ะพะธั‚ัŒ ััƒะฑั‚ะธั‚ั€ั‹.", + "subtitle_hint": "ะะฐัั‚ั€ะพะนะบะธ ะพั‚ะพะฑั€ะฐะถะตะฝะธั ััƒะฑั‚ะธั‚ั€ะพะฒ", "subtitle_language": "ะฏะทั‹ะบ ััƒะฑั‚ะธั‚ั€ะพะฒ", "subtitle_mode": "ะ ะตะถะธะผ ััƒะฑั‚ะธั‚ั€ะพะฒ", "set_subtitle_track": "ะฃัั‚ะฐะฝะฐะฒะปะธะฒะฐั‚ัŒ ััƒะฑั‚ะธั‚ั€ั‹ ะธะท ะฟั€ะตะดั‹ะดัƒั‰ะตะณะพ ัะปะตะผะตะฝั‚ะฐ", @@ -226,24 +226,24 @@ "outline_thickness": "ะขะพะปั‰ะธะฝะฐ ะบะพะฝั‚ัƒั€ะฐ", "background_opacity": "ะŸั€ะพะทั€ะฐั‡ะฝะพัั‚ัŒ ั„ะพะฝะฐ", "outline_opacity": "ะŸั€ะพะทั€ะฐั‡ะฝะพัั‚ัŒ ะบะพะฝั‚ัƒั€ะฐ", - "bold_text": "Bold Text", + "bold_text": "ะ–ะธั€ะฝั‹ะน", "colors": { "Black": "ะงะตั€ะฝั‹ะน", "Gray": "ะกะตั€ั‹ะน", - "Silver": "ะกะตั€ะตะฑั€ัะฝั‹ะน", + "Silver": "ะกะตั€ะตะฑั€ะธัั‚ั‹ะน", "White": "ะ‘ะตะปั‹ะน", - "Maroon": "ะœะฐั€ัƒะฝ", + "Maroon": "ะ‘ะพั€ะดะพะฒั‹ะน", "Red": "ะšั€ะฐัะฝั‹ะน", - "Fuchsia": "Fuchsia", + "Fuchsia": "ะŸัƒั€ะฟัƒั€ะฝั‹ะน", "Yellow": "ะ–ั‘ะปั‚ั‹ะน", - "Olive": "ะžะปะธะฒ", + "Olive": "ะžะปะธะฒะบะพะฒั‹ะน", "Green": "ะ—ะตะปั‘ะฝั‹ะน", "Teal": "ะ‘ะธั€ัŽะทะพะฒั‹ะน", "Lime": "ะ›ะฐะนะผะพะฒั‹ะน", "Purple": "ะคะธะพะปะตั‚ะพะฒั‹ะน", "Navy": "ะขั‘ะผะฝะพ-ัะธะฝะธะน", "Blue": "ะกะธะฝะธะน", - "Aqua": "ะะบะฒะฐะฐ" + "Aqua": "ะ“ะพะปัƒะฑะพะน" }, "thickness": { "None": "ะžั‚ััƒั‚ัั‚ะฒัƒะตั‚", @@ -251,29 +251,29 @@ "Normal": "ะžะฑั‹ั‡ะฝั‹ะน", "Thick": "ะขะพะปัั‚ั‹ะน" }, - "subtitle_color": "Subtitle Color", - "subtitle_background_color": "Background Color", - "subtitle_font": "Subtitle Font", - "ksplayer_title": "KSPlayer Settings", - "hardware_decode": "Hardware Decoding", - "hardware_decode_description": "Use hardware acceleration for video decoding. Disable if you experience playback issues." + "subtitle_color": "ะฆะฒะตั‚ ััƒะฑั‚ะธั‚ั€ะพะฒ", + "subtitle_background_color": "ะฆะฒะตั‚ ั„ะพะฝะฐ", + "subtitle_font": "ะจั€ะธั„ั‚ ััƒะฑั‚ะธั‚ั€ะพะฒ", + "ksplayer_title": "ะะฐัั‚ั€ะพะนะบะธ KSPlayer", + "hardware_decode": "ะะฟะฟะฐั€ะฐั‚ะฝะพะต ะดะตะบะพะดะธั€ะพะฒะฐะฝะธะต", + "hardware_decode_description": "ะ˜ัะฟะพะปัŒะทะพะฒะฐั‚ัŒ ะฐะฟะฟะฐั€ะฐั‚ะฝะพะต ัƒัะบะพั€ะตะฝะธะต ะดะปั ะดะตะบะพะดะธั€ะพะฒะฐะฝะธั ะฒะธะดะตะพ. ะ’ั‹ะบะปัŽั‡ะธั‚ะต, ะตัะปะธ ะฝะฐะฑะปัŽะดะฐะตั‚ะต ะฟั€ะพะฑะปะตะผั‹ ั ะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะธะตะผ." }, "vlc_subtitles": { - "title": "VLC Subtitle Settings", - "hint": "Customize subtitle appearance for VLC player. Changes take effect on next playback.", - "text_color": "Text Color", - "background_color": "Background Color", - "background_opacity": "Background Opacity", - "outline_color": "Outline Color", - "outline_opacity": "Outline Opacity", - "outline_thickness": "Outline Thickness", - "bold": "Bold Text", - "margin": "Bottom Margin" + "title": "ะะฐัั‚ั€ะพะนะบะธ ััƒะฑั‚ะธั‚ั€ะพะฒ ะฒ VLC", + "hint": "ะะฐัั‚ั€ะพะนั‚ะต ะฒะฝะตัˆะฝะธะน ะฒะธะด ััƒะฑั‚ะธั‚ั€ะพะฒ ะฒ VLC ะฟะปะตะตั€ะต. ะ˜ะทะผะตะฝะตะฝะธั ะฟั€ะธะผะตะฝัั‚ัั ะฟั€ะธ ัะปะตะดัƒัŽั‰ะตะผ ะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะธะธ.", + "text_color": "ะฆะฒะตั‚ ั‚ะตะบัั‚ะฐ", + "background_color": "ะฆะฒะตั‚ ั„ะพะฝะฐ", + "background_opacity": "ะŸั€ะพะทั€ะฐั‡ะฝะพัั‚ัŒ ั„ะพะฝะฐ", + "outline_color": "ะฆะฒะตั‚ ะบะพะฝั‚ัƒั€ะฐ", + "outline_opacity": "ะŸั€ะพะทั€ะฐั‡ะฝะพัั‚ัŒ ะบะพะฝั‚ัƒั€ะฐ", + "outline_thickness": "ะขะพะปั‰ะธะฝะฐ ะบะพะฝั‚ัƒั€ะฐ", + "bold": "ะ–ะธั€ะฝั‹ะน", + "margin": "ะžั‚ัั‚ัƒะฟ ัะฝะธะทัƒ" }, "video_player": { - "title": "Video Player", - "video_player": "Video Player", - "video_player_description": "Choose which video player to use on iOS.", + "title": "ะ’ะธะดะตะพะฟะปะตะตั€", + "video_player": "ะ’ะธะดะตะพะฟะปะตะตั€", + "video_player_description": "ะ’ั‹ะฑะตั€ะธั‚ะต ะฒะธะดะตะพะฟะปะตะตั€ ะฒ iOS.", "ksplayer": "KSPlayer", "vlc": "VLC" }, @@ -294,19 +294,19 @@ "UNKNOWN": "ะะตะธะทะฒะตัั‚ะฝะพะต" }, "safe_area_in_controls": "ะ‘ะตะทะพะฟะฐัะฝะฐั ะทะพะฝะฐ ะฒ ัะปะตะผะตะฝั‚ะฐั… ัƒะฟั€ะฐะฒะปะตะฝะธั", - "video_player": "ะ’ะธะดะตะพ ะฟั€ะตะนะตั€", + "video_player": "ะ’ะธะดะตะพะฟะปะตะตั€", "video_players": { "VLC_3": "VLC 3", "VLC_4": "VLC 4 (ะญะบัะฟะตั€ะธะผะตะฝั‚ะฐะปัŒะฝั‹ะน + PiP)" }, "show_custom_menu_links": "ะŸะพะบะฐะทะฐั‚ัŒ ััั‹ะปะบะธ ะบะฐัั‚ะพะผะฝะพะณะพ ะผะตะฝัŽ", - "show_large_home_carousel": "Show Large Home Carousel (beta)", + "show_large_home_carousel": "ะŸะพะบะฐะทั‹ะฒะฐั‚ัŒ ะฑะพะปัŒัˆัƒัŽ ะบะฐั€ัƒัะตะปัŒ (beta)", "hide_libraries": "ะกะบั€ั‹ั‚ัŒ ะฑะธะฑะปะธะพั‚ะตะบะธ", "select_liraries_you_want_to_hide": "ะ’ั‹ะฑะตั€ะธั‚ะต ะ‘ะธะฑะปะธะพั‚ะตะบะธ, ะบะพั‚ะพั€ะพะต ั…ะพั‚ะธั‚ะต ัะฟั€ัั‚ะฐั‚ัŒ ะธะท ะฒะบะปะฐะดะบะธ ะ‘ะธะฑะปะธะพั‚ะตะบะธ ะธ ะดะพะผะฐัˆะฝะตะน ัั‚ั€ะฐะฝะธั†ั‹.", "disable_haptic_feedback": "ะžั‚ะบะปัŽั‡ะธั‚ัŒ ั‚ะฐะบั‚ะธะปัŒะฝัƒัŽ ะพะฑั€ะฐั‚ะฝัƒัŽ ัะฒัะทัŒ", "default_quality": "ะšะฐั‡ะตัั‚ะฒะพ ะฟะพ ัƒะผะพะปั‡ะฐะฝะธัŽ", - "default_playback_speed": "Default Playback Speed", - "auto_play_next_episode": "Auto-play Next Episode", + "default_playback_speed": "ะกะบะพั€ะพัั‚ัŒ ะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะธั ะฟะพ ัƒะผะพะปั‡ะฐะฝะธัŽ", + "auto_play_next_episode": "ะะฒั‚ะพะผะฐั‚ะธั‡ะตัะบะธ ะฒะพัะฟั€ะพะธะทะฒะพะดะธั‚ัŒ ัะปะตะดัƒัŽั‰ะธะน ัะฟะธะทะพะด", "max_auto_play_episode_count": "ะœะฐะบัะธะผะฐะปัŒะฝะพะต ะบะพะปะธั‡ะตัั‚ะฒะพ ะฐะฒั‚ะพะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะธั ัะฟะธะทะพะดะพะฒ", "disabled": "ะžั‚ะบะปัŽั‡ะตะฝะพ" }, @@ -314,15 +314,15 @@ "downloads_title": "ะ—ะฐะณั€ัƒะทะบะธ" }, "music": { - "title": "Music", - "playback_title": "Playback", - "playback_description": "Configure how music is played.", - "prefer_downloaded": "Prefer Downloaded Songs", - "caching_title": "Caching", - "caching_description": "Automatically cache upcoming tracks for smoother playback.", - "lookahead_enabled": "Enable Look-Ahead Caching", - "lookahead_count": "Tracks to Pre-cache", - "max_cache_size": "Max Cache Size" + "title": "ะœัƒะทั‹ะบะฐ", + "playback_title": "ะ’ะพัะฟั€ะพะธะทะฒะตะดะตะฝะธะต", + "playback_description": "ะะฐัั‚ั€ะพะนั‚ะต ะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะธะต ะผัƒะทั‹ะบะธ.", + "prefer_downloaded": "ะŸั€ะตะดะฟะพั‡ะธั‚ะฐั‚ัŒ ัะบะฐั‡ะฐะฝะฝั‹ะต ะฟะตัะฝะธ", + "caching_title": "ะšะตัˆะธั€ะพะฒะฐะฝะธะต", + "caching_description": "ะะฒั‚ะพะผะฐั‚ะธั‡ะตัะบะธ ะฟั€ะตะดะบะตัˆะธั€ะพะฒะฐั‚ัŒ ัะปะตะดัƒัŽั‰ะธะต ั‚ั€ะตะบะธ ะดะปั ัั‚ะฐะฑะธะปัŒะฝะพะณะพ ะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะธั.", + "lookahead_enabled": "ะ’ะบะปัŽั‡ะธั‚ัŒ ะฟั€ะตะดะบะตัˆะธั€ะพะฒะฐะฝะธะต", + "lookahead_count": "ะกะบะพะปัŒะบะพ ะฟั€ะตะดะบะตัˆะธั€ะพะฒะฐั‚ัŒ", + "max_cache_size": "ะœะฐะบัะธะผะฐะปัŒะฝะพะต ั‡ะธัะปะพ ะฟั€ะตะดะบะตัˆะธั€ะพะฒะฐะฝะฝั‹ั… ั‚ั€ะตะบะพะฒ" }, "plugins": { "plugins_title": "ะŸะปะฐะณะธะฝั‹", @@ -357,39 +357,39 @@ "save_button": "ะกะพั…ั€ะฐะฝะธั‚ัŒ", "toasts": { "saved": "ะกะพั…ั€ะฐะฝะตะฝะพ", - "refreshed": "Settings refreshed from server" + "refreshed": "ะะฐัั‚ั€ะพะนะบะธ ะพะฑะฝะพะฒะปะตะฝั‹ ั ัะตั€ะฒะตั€ะฐ" }, - "refresh_from_server": "Refresh Settings from Server" + "refresh_from_server": "ะžะฑะฝะพะฒะธั‚ัŒ ะฝะฐัั‚ั€ะพะนะบะธ ั ัะตั€ะฒะตั€ะฐ" }, "streamystats": { - "enable_streamystats": "Enable Streamystats", - "disable_streamystats": "Disable Streamystats", - "enable_search": "Use for Search", + "enable_streamystats": "ะ’ะบะปัŽั‡ะธั‚ัŒ Streamystats", + "disable_streamystats": "ะ’ั‹ะบะปัŽั‡ะธั‚ัŒ Streamystats", + "enable_search": "ะ˜ัะฟะพะปัŒะทะพะฒะฐั‚ัŒ ะฒ ะฟะพะธัะบะต", "url": "URL", "server_url_placeholder": "http(s)://streamystats.example.com", - "streamystats_search_hint": "Enter the URL for your Streamystats server. The URL should include http or https and optionally the port.", - "read_more_about_streamystats": "Read More About Streamystats.", - "save_button": "Save", - "save": "Save", - "features_title": "Features", - "home_sections_title": "Home Sections", - "enable_movie_recommendations": "Movie Recommendations", - "enable_series_recommendations": "Series Recommendations", - "enable_promoted_watchlists": "Promoted Watchlists", - "hide_watchlists_tab": "Hide Watchlists Tab", - "home_sections_hint": "Show personalized recommendations and promoted watchlists from Streamystats on the home page.", - "recommended_movies": "Recommended Movies", - "recommended_series": "Recommended Series", + "streamystats_search_hint": "ะ’ะฒะตะดะธั‚ะต URL ะฒะฐัˆะตะณะพ ัะตั€ะฒะตั€ะฐ Streamystats. URL ะดะพะปะถะตะฝ ะฒะบะปัŽั‡ะฐั‚ัŒ http/https ะธ ะฟะพั€ั‚ ะฟั€ะธ ะฝะตะพะฑั…ะพะดะธะผะพัั‚ะธ.", + "read_more_about_streamystats": "ะฃะทะฝะฐั‚ัŒ ะฑะพะปัŒัˆะต ะฟั€ะพ Streamystats.", + "save_button": "ะกะพั…ั€ะฐะฝะธั‚ัŒ", + "save": "ะกะพั…ั€ะฐะฝะธั‚ัŒ", + "features_title": "ะคัƒะฝะบั†ะธะธ", + "home_sections_title": "ะŸะพะบะฐะทั‹ะฒะฐั‚ัŒ ะฝะฐ ะณะปะฐะฒะฝะพะน", + "enable_movie_recommendations": "ะ ะตะบะพะผะตะฝะดะฐั†ะธะธ ั„ะธะปัŒะผะพะฒ", + "enable_series_recommendations": "ะ ะตะบะพะผะตะฝะดะฐั†ะธะธ ัะตั€ะธะฐะปะพะฒ", + "enable_promoted_watchlists": "ะŸั€ะพะดะฒะธะณะฐะตะผั‹ะต ัะฟะธัะบะธ ะฟั€ะพัะผะพั‚ั€ะฐ", + "hide_watchlists_tab": "ะกะบั€ั‹ั‚ัŒ ะฒะบะปะฐะดะบัƒ ัะพ ัะฟะธัะบะฐะผะธ", + "home_sections_hint": "ะŸะพะบะฐะทั‹ะฒะฐั‚ัŒ ะฟะตั€ัะพะฝะฐะปะธะทะธั€ะพะฒะฐะฝะฝั‹ะต ั€ะตะบะพะผะตะฝะดะฐั†ะธะธ ะธ ะฟะพะดั…ะพะดัั‰ะธะต ัะฟะธัะบะธ ะฟั€ะพัะผะพั‚ั€ะพะฒ ะธะท Streamystats ะฝะฐ ะณะปะฐะฒะฝะพะน ัั‚ั€ะฐะฝะธั†ะต.", + "recommended_movies": "ะ ะตะบะพะผะตะฝะดะพะฒะฐะฝะฝั‹ะต ั„ะธะปัŒะผั‹", + "recommended_series": "ะ ะตะบะพะผะตะฝะดะพะฒะฐะฝะฝั‹ะต ัะตั€ะธะฐะปั‹", "toasts": { - "saved": "Saved", - "refreshed": "Settings refreshed from server", - "disabled": "Streamystats disabled" + "saved": "ะกะพั…ั€ะฐะฝะตะฝะพ", + "refreshed": "ะะฐัั‚ั€ะพะนะบะธ ะพะฑะฝะพะฒะปะตะฝั‹ ั ัะตั€ะฒะตั€ะฐ", + "disabled": "Streamystats ะพั‚ะบะปัŽั‡ะตะฝ" }, - "refresh_from_server": "Refresh Settings from Server" + "refresh_from_server": "ะžะฑะฝะพะฒะธั‚ัŒ ะฝะฐัั‚ั€ะพะนะบะธ ั ัะตั€ะฒะตั€ะฐ" }, "kefinTweaks": { - "watchlist_enabler": "Enable our Watchlist integration", - "watchlist_button": "Toggle Watchlist integration" + "watchlist_enabler": "ะ’ะบะปัŽั‡ะธั‚ัŒ ะธะฝั‚ะตะณั€ะฐั†ะธัŽ ัะพ ัะฟะธัะบะฐะผะธ ะฟั€ะพัะผะพั‚ั€ะฐ", + "watchlist_button": "ะ˜ะทะผะตะฝะธั‚ัŒ ะธะฝั‚ะตะณั€ะฐั†ะธัŽ ัะพ ัะฟะธัะบะฐะผะธ ะฟั€ะพัะผะพั‚ั€ะฐ" } }, "storage": { @@ -398,18 +398,18 @@ "device_usage": "ะฃัั‚ั€ะพะนัั‚ะฒะพ {{availableSpace}}%", "size_used": "{{used}} ะธะท {{total}} ะธัะฟะพะปัŒะทะพะฒะฐะฝะพ", "delete_all_downloaded_files": "ะฃะดะฐะปะธั‚ัŒ ะฒัะต ะทะฐะณั€ัƒะถะตะฝะฝั‹ะต ั„ะฐะนะปั‹", - "music_cache_title": "Music Cache", - "music_cache_description": "Automatically cache songs as you listen for smoother playback and offline support", - "enable_music_cache": "Enable Music Cache", - "clear_music_cache": "Clear Music Cache", - "music_cache_size": "{{size}} cached", - "music_cache_cleared": "Music cache cleared", - "delete_all_downloaded_songs": "Delete All Downloaded Songs", - "downloaded_songs_size": "{{size}} downloaded", - "downloaded_songs_deleted": "Downloaded songs deleted" + "music_cache_title": "ะšะตัˆ ะผัƒะทั‹ะบะธ", + "music_cache_description": "ะะฒั‚ะพะผะฐั‚ะธั‡ะตัะบะธ ะฟั€ะตะบะตัˆะธั€ะพะฒะฐั‚ัŒ ะฟะตัะฝะธ ะฟะพ ะผะตั€ะต ะฟั€ะพัะปัƒัˆะธะฒะฐะฝะธั ะดะปั ะฟะปะฐะฒะฝะพะณะพ ะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะธั ะธ ะฟะพะดะดะตั€ะถะบะธ ะพั‚ััƒั‚ัั‚ะฒะธั ะธะฝั‚ะตั€ะฝะตั‚ะฐ", + "enable_music_cache": "ะšะตัˆะธั€ะพะฒะฐั‚ัŒ ะผัƒะทั‹ะบัƒ", + "clear_music_cache": "ะžั‡ะธัั‚ะธั‚ัŒ ะบะตัˆ ะผัƒะทั‹ะบะธ", + "music_cache_size": "{{size}} ะบะตัˆะธั€ะพะฒะฐะฝะพ", + "music_cache_cleared": "ะšะตัˆ ะผัƒะทั‹ะบะธ ะพั‡ะธั‰ะตะฝ", + "delete_all_downloaded_songs": "ะฃะดะฐะปะธั‚ัŒ ะฒัะต ัะบะฐั‡ะฐะฝะฝั‹ะต ะฟะตัะฝะธ", + "downloaded_songs_size": "{{size}} ัะบะฐั‡ะฐะฝะพ", + "downloaded_songs_deleted": "ะกะบะฐั‡ะฐะฝะฝั‹ะต ะฟะตัะฝะธ ัƒะดะฐะปะตะฝั‹" }, "intro": { - "title": "Intro", + "title": "ะ’ัั‚ัƒะฟะปะตะฝะธะต", "show_intro": "ะŸะพะบะฐะทะฐั‚ัŒ ะฒัั‚ัƒะฟะปะตะฝะธะต", "reset_intro": "ะกะฑั€ะพัะธั‚ัŒ ะฒัั‚ัƒะฟะปะตะฝะธะต" }, @@ -441,24 +441,24 @@ "tvseries": "ะกะตั€ะธะฐะปั‹", "movies": "ะคะธะปัŒะผั‹", "queue": "ะžั‡ะตั€ะตะดัŒ", - "other_media": "ะ”ั€ัƒะณะธะต ะผะตะดะธะฐ", - "queue_hint": "ะžั‡ะตั€ะตะดัŒ ะธ ะทะฐะณั€ัƒะทะบะธ ะฑัƒะดัƒั‚ ัƒะดะฐะปะตะฝั‹ ะฟั€ะธ ะฟะตั€ะตะทะฐะณั€ัƒะทะบะต ะฟั€ะธะปะพะถะตะฝะธั", + "other_media": "ะŸั€ะพั‡ะธะต ั„ะฐะนะปั‹", + "queue_hint": "ะžั‡ะตั€ะตะดัŒ ะพั‡ะธัั‚ะธั‚ัั ะฟะพัะปะต ะฟะตั€ะตะทะฐะฟัƒัะบะฐ", "no_items_in_queue": "ะะตั‚ ัะปะตะผะตะฝั‚ะพะฒ ะฒ ะพั‡ะตั€ะตะดะธ", - "no_downloaded_items": "ะะตั‚ ะทะฐะณั€ัƒะถะตะฝั‹ั… ะฟั€ะตะดะผะตั‚ะพะฒ", + "no_downloaded_items": "ะะตั‚ ะทะฐะณั€ัƒะถะตะฝะฝั‹ั… ั„ะฐะนะปะพะฒ", "delete_all_movies_button": "ะฃะดะฐะปะธั‚ัŒ ะฒัะต ั„ะธะปัŒะผั‹", "delete_all_tvseries_button": "ะฃะดะฐะปะธั‚ัŒ ะฒัะต ัะตั€ะธะฐะปั‹", "delete_all_button": "ะฃะดะฐะปะธั‚ัŒ ะฒัะต", - "delete_all_other_media_button": "ะฃะดะฐะปะธั‚ัŒ ะดั€ัƒะณะพะน ะผะฐั‚ะตั€ะธะฐะป", - "active_download": "ะะบั‚ะธะฒะฝะพ ะทะฐะณั€ัƒะถะฐะตั‚ัั", + "delete_all_other_media_button": "ะฃะดะฐะปะธั‚ัŒ ะฟั€ะพั‡ะธะต ั„ะฐะนะปั‹", + "active_download": "ะ—ะฐะณั€ัƒะถะฐะตั‚ัั", "no_active_downloads": "ะะตั‚ ะฐะบั‚ะธะฒะฝั‹ั… ะทะฐะณั€ัƒะทะพะบ", - "active_downloads": "ะะบั‚ะธะฒะฝั‹ะต ะทะฐะณั€ัƒะทะบะธ", + "active_downloads": "ะะบั‚ะธะฒะฝั‹ะต", "new_app_version_requires_re_download": "ะะพะฒะฐั ะฒะตั€ัะธั ะฟั€ะธะปะพะถะตะฝะธั ั‚ั€ะตะฑัƒะตั‚ ะฟะพะฒั‚ะพั€ะฝะพะน ะทะฐะณั€ัƒะทะบะธ", "new_app_version_requires_re_download_description": "ะะพะฒะฐั ะฒะตั€ัะธั ะฟั€ะธะปะพะถะตะฝะธั ั‚ั€ะตะฑัƒะตั‚ ะฟะพะฒั‚ะพั€ะฝะพะน ะทะฐะณั€ัƒะทะบะธ. ะŸะพะถะฐะปัƒะนัั‚ะฐ ัƒะดะฐะปะธั‚ะต ะฒัั‘ ะธ ะฟะพะฟั€ะพะฑัƒะนั‚ะต ะทะฐะฝะพะฒะพ.", "back": "ะะฐะทะฐะด", "delete": "ะฃะดะฐะปะธั‚ัŒ", "something_went_wrong": "ะงั‚ะพ-ั‚ะพ ะฟะพัˆะปะพ ะฝะต ั‚ะฐะบ", "could_not_get_stream_url_from_jellyfin": "ะะต ัƒะดะฐะปะพััŒ ะฟะพะปัƒั‡ะธั‚ัŒ ััั‹ะปะบัƒ ั‚ั€ะฐะฝัะปัั†ะธะธ ะธะท Jellyfin", - "eta": "ETA {{eta}}", + "eta": "ะžัั‚ะฐะปะพััŒ {{eta}}", "toasts": { "you_are_not_allowed_to_download_files": "ะะตั‚ ั€ะฐะทั€ะตัˆะตะฝะธั ะฝะฐ ัะบะฐั‡ะธะฒะฐะฝะธะต ั„ะฐะนะปะพะฒ.", "deleted_all_movies_successfully": "ะ’ัะต ั„ะธะปัŒะผั‹ ะฑั‹ะปะธ ัƒัะฟะตัˆะฝะพ ัƒะดะฐะปะตะฝั‹!", @@ -467,64 +467,64 @@ "failed_to_delete_all_tvseries": "ะ’ะพะทะฝะธะบะปะฐ ะพัˆะธะฑะบะฐ ะฟั€ะธ ัƒะดะฐะปะตะฝะธะธ ะฒัะตั… ัะตั€ะธะฐะปะพะฒ", "deleted_media_successfully": "ะ”ั€ัƒะณะธะต ะฝะพัะธั‚ะตะปะธ ัƒัะฟะตัˆะฝะพ ัƒะดะฐะปะตะฝั‹!", "failed_to_delete_media": "ะะต ัƒะดะฐะปะพััŒ ัƒะดะฐะปะธั‚ัŒ ะดั€ัƒะณะพะน ั„ะฐะนะป", - "download_deleted": "ะ—ะฐะณั€ัƒะทะบะฐ ัƒะดะฐะปะตะฝะฐ", + "download_deleted": "ะฃะดะฐะปะตะฝะพ", "download_cancelled": "ะ—ะฐะณั€ัƒะทะบะฐ ะพั‚ะผะตะฝะตะฝะฐ", "could_not_delete_download": "ะะต ัƒะดะฐะปะพััŒ ัƒะดะฐะปะธั‚ัŒ ะทะฐะณั€ัƒะทะบัƒ", - "download_paused": "ะ—ะฐะณั€ัƒะทะบะฐ ะฟั€ะธะพัั‚ะฐะฝะพะฒะปะตะฝะฐ", + "download_paused": "ะะฐ ะฟะฐัƒะทะต", "could_not_pause_download": "ะะต ัƒะดะฐะปะพััŒ ะฟั€ะธะพัั‚ะฐะฝะพะฒะธั‚ัŒ ะทะฐะณั€ัƒะทะบัƒ", - "download_resumed": "ะ—ะฐะณั€ัƒะทะบะฐ ะฒะพะทะพะฑะฝะพะฒะปะตะฝะฐ", + "download_resumed": "ะŸั€ะพะดะพะปะถะตะฝะพ", "could_not_resume_download": "ะะต ัƒะดะฐะปะพััŒ ะฟั€ะพะดะพะปะถะธั‚ัŒ ะทะฐะณั€ัƒะทะบัƒ", - "download_completed": "ะ—ะฐะณั€ัƒะทะบะฐ ะทะฐะฒะตั€ัˆะตะฝะฐ", - "download_failed": "Download Failed", + "download_completed": "ะ—ะฐะฒะตั€ัˆะตะฝะพ", + "download_failed": "ะะต ัƒะดะฐะปะพััŒ ะทะฐะณั€ัƒะทะธั‚ัŒ", "download_failed_for_item": "ะ—ะฐะณั€ัƒะทะบะฐ {{item}} ะฟั€ะพะฒะฐะปะธะปะฐััŒ ั ะพัˆะธะฑะบะพะน: {{error}}", "download_completed_for_item": "{{item}} ัƒัะฟะตัˆะฝะพ ะทะฐะณั€ัƒะถะตะฝ", "download_started_for_item": "ะ—ะฐะณั€ัƒะทะบะฐ ะฝะฐั‡ะฐะปะฐััŒ ะดะปั {{item}}", "failed_to_start_download": "ะะต ัƒะดะฐะปะพััŒ ะฝะฐั‡ะฐั‚ัŒ ะทะฐะณั€ัƒะทะบัƒ", - "item_already_downloading": "{{item}} is already downloading", - "all_files_deleted": "All Downloads Deleted Successfully", - "files_deleted_by_type": "{{count}} {{type}} deleted", + "item_already_downloading": "{{item}} ัƒะถะต ะทะฐะณั€ัƒะถะฐะตั‚ัั", + "all_files_deleted": "ะ’ัะต ะทะฐะณั€ัƒะทะบะธ ัƒะดะฐะปะตะฝั‹", + "files_deleted_by_type": "{{count}} {{type}} ัƒะดะฐะปั‘ะฝ(ะพ)", "all_files_folders_and_jobs_deleted_successfully": "ะ’ัะต ั„ะฐะนะปั‹, ะฟะฐะฟะบะธ, ะธ ะทะฐะดะฐั‡ะธ ะฑั‹ะปะธ ัƒัะฟะตัˆะฝะพ ัƒะดะฐะปะตะฝั‹", "failed_to_clean_cache_directory": "ะะต ัƒะดะฐะปะพััŒ ะพั‡ะธัั‚ะธั‚ัŒ ะดะธั€ะตะบั‚ะพั€ะธัŽ ะบััˆะฐ", "could_not_get_download_url_for_item": "ะะต ัƒะดะฐะปะพััŒ ะฟะพะปัƒั‡ะธั‚ัŒ URL ะทะฐะณั€ัƒะทะบะธ ะดะปั {{itemName}}", "go_to_downloads": "ะ’ ะทะฐะณั€ัƒะทะบะธ", - "file_deleted": "{{item}} deleted" + "file_deleted": "{{item}} ัƒะดะฐะปั‘ะฝ" } } }, "common": { "select": "ะ’ั‹ะฑั€ะฐั‚ัŒ", - "no_trailer_available": "ะŸั€ะธั†ะตะฟ ะฝะตะดะพัั‚ัƒะฟะตะฝ", + "no_trailer_available": "ะขั€ะตะนะปะตั€ ะฝะตะดะพัั‚ัƒะฟะตะฝ", "video": "ะ’ะธะดะตะพ", "audio": "ะ—ะฒัƒะบ", "subtitle": "ะกัƒะฑั‚ะธั‚ั€ั‹", - "play": "ะ˜ะณั€ะฐั‚ัŒ", - "none": "None", - "track": "Track", - "cancel": "Cancel", - "delete": "Delete", - "ok": "OK", - "remove": "Remove", - "next": "Next", - "back": "Back", - "continue": "Continue", - "verifying": "Verifying..." + "play": "ะ’ะพัะฟั€ะพะธะทะฒะตัั‚ะธ", + "none": "ะžั‚ััƒั‚ัั‚ะฒัƒะตั‚", + "track": "ะขั€ะตะบ", + "cancel": "ะžั‚ะผะตะฝะฐ", + "delete": "ะฃะดะฐะปะธั‚ัŒ", + "ok": "ะžะš", + "remove": "ะฃะดะฐะปะธั‚ัŒ", + "next": "ะ’ะฟะตั€ะตะด", + "back": "ะะฐะทะฐะด", + "continue": "ะŸั€ะพะดะพะปะถะธั‚ัŒ", + "verifying": "ะŸั€ะพะฒะตั€ะบะฐ..." }, "search": { "search": "ะŸะพะธัะบ...", - "x_items": "{{count}} ะฟั€ะตะดะผะตั‚ะพะฒ", + "x_items": "{{count}} ัะปะตะผะตะฝั‚ะพะฒ", "library": "ะ‘ะธะฑะปะธะพั‚ะตะบะฐ", "discover": "ะะฐะนั‚ะธ ะฝะพะฒะพะต", - "no_results": "ะะตั‚ ั€ะตะทัƒะปัŒั‚ะฐั‚ะพะฒ", - "no_results_found_for": "ะะต ะฑั‹ะปะพ ั€ะตะทัƒะปัŒั‚ะฐั‚ะพะฒ ะฟั€ะธ ะฟะพะธัะบะต", + "no_results": "ะะธั‡ะตะณะพ ะฝะต ะฝะฐะนะดะตะฝะพ", + "no_results_found_for": "ะะธั‡ะตะณะพ ะฝะต ะฝะฐะนะดะตะฝะพ ะฟะพ ะทะฐะฟั€ะพััƒ", "movies": "ะคะธะปัŒะผั‹", "series": "ะกะตั€ะธะฐะปั‹", "episodes": "ะกะตั€ะธะธ", "collections": "ะšะพะปะปะตะบั†ะธะธ", "actors": "ะะบั‚ะตั€ั‹", - "artists": "Artists", - "albums": "Albums", - "songs": "Songs", - "playlists": "Playlists", + "artists": "ะั€ั‚ะธัั‚ั‹", + "albums": "ะะปัŒะฑะพะผั‹", + "songs": "ะŸะตัะฝะธ", + "playlists": "ะŸะปะตะนะปะธัั‚ั‹", "request_movies": "ะ—ะฐะฟั€ะพัะธั‚ัŒ ั„ะธะปัŒะผั‹", "request_series": "ะ—ะฐะฟั€ะพัะธั‚ัŒ ัะตั€ะธะฐะปั‹", "recently_added": "ะะตะดะฐะฒะฝะพ ะดะพะฑะฐะฒะปะตะฝะพ", @@ -553,7 +553,7 @@ "no_results": "ะะตั‚ ั€ะตะทัƒะปัŒั‚ะฐั‚ะพะฒ", "no_libraries_found": "ะ‘ะธะฑะปะธะพั‚ะตะบะธ ะฝะต ะฝะฐะนะดะตะฝั‹", "item_types": { - "movies": "ั„ะธะปัŒะผั‹", + "movies": "ะคะธะปัŒะผั‹", "series": "ะกะตั€ะธะฐะปั‹", "boxsets": "ะšะพะปะปะตะบั†ะธะธ", "items": "ัะปะตะผะตะฝั‚ั‹" @@ -571,9 +571,9 @@ "filters": { "genres": "ะ–ะฐะฝั€ั‹", "years": "ะ“ะพะดะฐ", - "sort_by": "ะกะพั€ั‚ะธั€ะพะฒะฐั‚ัŒ ะฟะพ", - "filter_by": "Filter By", - "sort_order": "ะŸะพั€ัะดะพะบ ัะพั€ั‚ะธั€ะพะฒะบะธ", + "sort_by": "ะกะพั€ั‚ะธั€ะพะฒะบะฐ", + "filter_by": "ะคะธะปัŒั‚ั€", + "sort_order": "ะŸะพั€ัะดะพะบ", "tags": "ะขัะณะธ" } }, @@ -604,14 +604,14 @@ "index": "ะ˜ะฝะดะตะบั:", "continue_watching": "ะŸั€ะพะดะพะปะถะธั‚ัŒ ะฟั€ะพัะผะพั‚ั€", "go_back": "ะะฐะทะฐะด", - "downloaded_file_title": "You have this file downloaded", - "downloaded_file_message": "Do you want to play the downloaded file?", - "downloaded_file_yes": "Yes", - "downloaded_file_no": "No", - "downloaded_file_cancel": "Cancel" + "downloaded_file_title": "ะญั‚ะพั‚ ั„ะฐะนะป ัƒะถะต ัะบะฐั‡ะฐะฝ", + "downloaded_file_message": "ะฅะพั‚ะธั‚ะต ะฒะพัะฟั€ะพะธะทะฒะตัั‚ะธ ัะบะฐั‡ะฐะฝะฝั‹ะน ั„ะฐะนะป?", + "downloaded_file_yes": "ะ”ะฐ", + "downloaded_file_no": "ะะตั‚", + "downloaded_file_cancel": "ะžั‚ะผะตะฝะฐ" }, "item_card": { - "next_up": "ะกะปะตะดัƒัŽั‰ะตะต", + "next_up": "ะ”ะฐะปะตะต", "no_items_to_display": "ะะตั‚ ัะปะตะผะตะฝั‚ะพะฒ ะดะปั ะพั‚ะพะฑั€ะฐะถะตะฝะธั", "cast_and_crew": "ะะบั‚ะตั€ั‹ ะธ ััŠะตะผะพั‡ะฝะฐั ะณั€ัƒะฟะฟะฐ", "series": "ะกะตั€ะธะธ", @@ -644,7 +644,7 @@ } }, "live_tv": { - "next": "ะกะปะตะดัƒัŽั‰ะฐั", + "next": "ะ”ะฐะปะตะต", "previous": "ะŸั€ะตะดั‹ะดัƒั‰ะฐั", "coming_soon": "ะกะบะพั€ะพ", "on_now": "ะกะตะนั‡ะฐั ะฒ ัั„ะธั€ะต", @@ -675,7 +675,7 @@ "series_type": "ะขะธะฟ ัะตั€ะธะฐะปะฐ", "release_dates": "ะ”ะฐั‚ะฐ ั€ะตะปะธะทะฐ", "first_air_date": "ะŸะตั€ะฒะฐั ะดะฐั‚ะฐ ะฒั‹ั…ะพะดะฐ ะฒ ัั„ะธั€", - "next_air_date": "ะกะปะตะดัƒัŽั‰ะฐั ะดะฐั‚ะฐ ะฒั‹ั…ะพะดะฐ ะฒ ัั„ะธั€", + "next_air_date": "ะ‘ะปะธะถะฐะนัˆะฐั ะดะฐั‚ะฐ ะฒั‹ั…ะพะดะฐ ะฒ ัั„ะธั€", "revenue": "ะŸั€ะธะฑั‹ะปัŒ", "budget": "ะ‘ัŽะดะถะตั‚", "original_language": "ะžั€ะธะณะธะฝะฐะปัŒะฝั‹ะน ัะทั‹ะบ", @@ -693,10 +693,10 @@ "number_episodes": "{{episode_number}} ัะตั€ะธะน", "born": "ะ ะพะถะดะตะฝ", "appearances": "ะŸะพัะฒะปะตะฝะธั", - "approve": "Approve", - "decline": "Decline", - "requested_by": "Requested by {{user}}", - "unknown_user": "Unknown User", + "approve": "ะžะดะพะฑั€ะธั‚ัŒ", + "decline": "ะžั‚ะบะปะพะฝะธั‚ัŒ", + "requested_by": "ะ—ะฐะฟั€ะพัˆะตะฝะพ {{user}}", + "unknown_user": "ะะตะธะทะฒะตัั‚ะฝั‹ะน ะฟะพะปัŒะทะพะฒะฐั‚ะตะปัŒ", "toasts": { "jellyseer_does_not_meet_requirements": "ะกะตั€ะฒะตั€ Jellyseerr ะฝะต ัะพะพั‚ะฒะตั‚ัั‚ะฒัƒะตั‚ ะผะธะฝะธะผะฐะปัŒะฝั‹ะผ ั‚ั€ะตะฑะพะฒะฐะฝะธัะผ ะฒะตั€ัะธะธ! ะŸะพะถะฐะปัƒะนัั‚ะฐ, ะพะฑะฝะพะฒะธั‚ะต ะดะพ ะฒะตั€ัะธะธ ะฝะต ะฝะธะถะต 2.0.0", "jellyseerr_test_failed": "ะขะตัั‚ Jellyseerr ะฝะต ะฟั€ะพะนะดะตะฝ. ะŸะพะฟั€ะพะฑัƒะนั‚ะต ะตั‰ะต ั€ะฐะท.", @@ -705,141 +705,141 @@ "requested_item": "ะ—ะฐะฟั€ะพัˆะตะฝะพ {{item}}!", "you_dont_have_permission_to_request": "ะฃ ะฒะฐั ะฝะตั‚ ั€ะฐะทั€ะตัˆะตะฝะธั ะฝะฐ ะทะฐะฟั€ะพั!", "something_went_wrong_requesting_media": "ะงั‚ะพ-ั‚ะพ ะฟะพัˆะปะพ ะฝะต ั‚ะฐะบ ะฟั€ะธ ะทะฐะฟั€ะพัะต ะผะตะดะธะฐั„ะฐะนะปะพะฒ!", - "request_approved": "Request Approved!", - "request_declined": "Request Declined!", - "failed_to_approve_request": "Failed to Approve Request", - "failed_to_decline_request": "Failed to Decline Request" + "request_approved": "ะ—ะฐะฟั€ะพั ะพะดะพะฑั€ะตะฝ!", + "request_declined": "ะ—ะฐะฟั€ะพั ะพั‚ะบะปะพะฝั‘ะฝ!", + "failed_to_approve_request": "ะะต ัƒะดะฐะปะพััŒ ะพะดะพะฑั€ะธั‚ัŒ ะทะฐะฟั€ะพั", + "failed_to_decline_request": "ะะต ัƒะดะฐะปะพััŒ ะพั‚ะบะปะพะฝะธั‚ัŒ ะทะฐะฟั€ะพั" } }, "tabs": { - "home": "ะ”ะพะผ", + "home": "ะ“ะปะฐะฒะฝะฐั", "search": "ะŸะพะธัะบ", "library": "ะ‘ะธะฑะปะธะพั‚ะตะบะฐ", - "custom_links": "ะšะฐัั‚ะพะผะฝั‹ะต ััั‹ะปะบะธ", + "custom_links": "ะกัั‹ะปะบะธ", "favorites": "ะ˜ะทะฑั€ะฐะฝะฝะพะต" }, "music": { - "title": "Music", + "title": "ะœัƒะทั‹ะบะฐ", "tabs": { - "suggestions": "Suggestions", - "albums": "Albums", - "artists": "Artists", - "playlists": "Playlists", - "tracks": "tracks" + "suggestions": "ะ ะตะบะพะผะตะฝะดะฐั†ะธะธ", + "albums": "ะะปัŒะฑะพะผั‹", + "artists": "ะ˜ัะฟะพะปะฝะธั‚ะตะปะธ", + "playlists": "ะŸะปะตะนะปะธัั‚ั‹", + "tracks": "ั‚ั€ะตะบะธ" }, "filters": { - "all": "All" + "all": "ะ’ัะต" }, - "recently_added": "Recently Added", - "recently_played": "Recently Played", - "frequently_played": "Frequently Played", - "explore": "Explore", - "top_tracks": "Top Tracks", - "play": "Play", - "shuffle": "Shuffle", - "play_top_tracks": "Play Top Tracks", - "no_suggestions": "No suggestions available", - "no_albums": "No albums found", - "no_artists": "No artists found", - "no_playlists": "No playlists found", - "album_not_found": "Album not found", - "artist_not_found": "Artist not found", - "playlist_not_found": "Playlist not found", + "recently_added": "ะะตะดะฐะฒะฝะพ ะดะพะฑะฐะฒะปะตะฝะพ", + "recently_played": "ะะตะดะฐะฒะฝะพ ะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะพ", + "frequently_played": "ะงะฐัั‚ะพ ะธะณั€ะฐะตั‚", + "explore": "ะะฐะนั‚ะธ ะฝะพะฒะพะต", + "top_tracks": "ะขะพะฟ", + "play": "ะ’ะพัะฟั€ะพะธะทะฒะตัั‚ะธ", + "shuffle": "ะŸะตั€ะตะผะตัˆะฐั‚ัŒ", + "play_top_tracks": "ะ’ะพัะฟั€ะพะธะทะฒะตัั‚ะธ ั‚ะพะฟ", + "no_suggestions": "ะะตั‚ ั€ะตะบะพะผะตะฝะดะฐั†ะธะน", + "no_albums": "ะะปัŒะฑะพะผั‹ ะฝะต ะฝะฐะนะดะตะฝั‹", + "no_artists": "ะ˜ัะฟะพะปะฝะธั‚ะตะปะธ ะฝะต ะฝะฐะนะดะตะฝั‹", + "no_playlists": "ะŸะปะตะนะปะธัั‚ั‹ ะฝะต ะฝะฐะนะดะตะฝั‹", + "album_not_found": "ะะปัŒะฑะพะผ ะฝะต ะฝะฐะนะดะตะฝ", + "artist_not_found": "ะ˜ัะฟะพะปะฝะธั‚ะตะปัŒ ะฝะต ะฝะฐะนะดะตะฝ", + "playlist_not_found": "ะŸะปะตะนะปะธัั‚ ะฝะต ะฝะฐะนะดะตะฝ", "track_options": { - "play_next": "Play Next", - "add_to_queue": "Add to Queue", - "add_to_playlist": "Add to Playlist", - "download": "Download", - "downloaded": "Downloaded", - "downloading": "Downloading...", - "cached": "Cached", - "delete_download": "Delete Download", - "delete_cache": "Remove from Cache", - "go_to_artist": "Go to Artist", - "go_to_album": "Go to Album", - "add_to_favorites": "Add to Favorites", - "remove_from_favorites": "Remove from Favorites", - "remove_from_playlist": "Remove from Playlist" + "play_next": "ะ”ะฐะปะตะต", + "add_to_queue": "ะ”ะพะฑะฐะฒะธั‚ัŒ ะฒ ะพั‡ะตั€ะตะดัŒ", + "add_to_playlist": "ะ”ะพะฑะฐะฒะธั‚ัŒ ะฒ ะฟะปะตะนะปะธัั‚", + "download": "ะกะบะฐั‡ะฐั‚ัŒ", + "downloaded": "ะกะบะฐั‡ะฐะฝะพ", + "downloading": "ะกะบะฐั‡ะธะฒะฐะตั‚ัั...", + "cached": "ะšะตัˆะธั€ะพะฒะฐะฝะพ", + "delete_download": "ะฃะดะฐะปะธั‚ัŒ ะทะฐะณั€ัƒะทะบัƒ", + "delete_cache": "ะฃะดะฐะปะธั‚ัŒ ะธะท ะบะตัˆะฐ", + "go_to_artist": "ะš ะธัะฟะพะปะฝะธั‚ะตะปัŽ", + "go_to_album": "ะš ะฐะปัŒะฑะพะผัƒ", + "add_to_favorites": "ะ’ ะธะทะฑั€ะฐะฝะฝะพะต", + "remove_from_favorites": "ะฃะดะฐะปะธั‚ัŒ ะธะท ะธะทะฑั€ะฐะฝะฝะพะณะพ", + "remove_from_playlist": "ะฃะดะฐะปะธั‚ัŒ ะธะท ะฟะปะตะนะปะธัั‚ะฐ" }, "playlists": { - "create_playlist": "Create Playlist", - "playlist_name": "Playlist Name", - "enter_name": "Enter playlist name", - "create": "Create", - "search_playlists": "Search playlists...", - "added_to": "Added to {{name}}", - "added": "Added to playlist", - "removed_from": "Removed from {{name}}", - "removed": "Removed from playlist", - "created": "Playlist created", - "create_new": "Create New Playlist", - "failed_to_add": "Failed to add to playlist", - "failed_to_remove": "Failed to remove from playlist", - "failed_to_create": "Failed to create playlist", - "delete_playlist": "Delete Playlist", - "delete_confirm": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "deleted": "Playlist deleted", - "failed_to_delete": "Failed to delete playlist" + "create_playlist": "ะกะพะทะดะฐั‚ัŒ ะฟะปะตะนะปะธัั‚", + "playlist_name": "ะะฐะทะฒะฐะฝะธะต ะฟะปะตะนะปะธัั‚ะฐ", + "enter_name": "ะ’ะฒะตะดะธั‚ะต ะฝะฐะทะฒะฐะฝะธะต ะฟะปะตะนะปะธัั‚ะฐ", + "create": "ะกะพะทะดะฐั‚ัŒ", + "search_playlists": "ะŸะพะธัะบ ะฟะปะตะนะปะธัั‚ะพะฒ...", + "added_to": "ะ”ะพะฑะฐะฒะปะตะฝะพ ะฒ {{name}}", + "added": "ะ”ะพะฑะฐะฒะปะตะฝะพ ะฒ ะฟะปะตะนะปะธัั‚", + "removed_from": "ะฃะดะฐะปะตะฝะพ ะธะท {{name}}", + "removed": "ะฃะดะฐะปะตะฝะพ ะธะท ะฟะปะตะนะปะธัั‚ะฐ", + "created": "ะŸะปะตะนะปะธัั‚ ัะพะทะดะฐะฝ", + "create_new": "ะ”ะพะฑะฐะฒะธั‚ัŒ ะฝะพะฒั‹ะน ะฟะปะตะนะปะธัั‚", + "failed_to_add": "ะะต ัƒะดะฐะปะพััŒ ะดะพะฑะฐะฒะธั‚ัŒ ะฒ ะฟะปะตะนะปะธัั‚", + "failed_to_remove": "ะะต ัƒะดะฐะปะพััŒ ัƒะดะฐะปะธั‚ัŒ ะธะท ะฟะปะตะนะปะธัั‚ะฐ", + "failed_to_create": "ะะต ัƒะดะฐะปะพััŒ ัะพะทะดะฐั‚ัŒ ะฟะปะตะนะปะธัั‚", + "delete_playlist": "ะฃะดะฐะปะธั‚ัŒ ะฟะปะตะนะปะธัั‚", + "delete_confirm": "ะ’ั‹ ัƒะฒะตั€ะตะฝั‹, ั‡ั‚ะพ ั…ะพั‚ะธั‚ะต ัƒะดะฐะปะธั‚ัŒ \"{{name}}\"? ะญั‚ะพ ะดะตะนัั‚ะฒะธะต ะฝะตะพะฑั€ะฐั‚ะธะผะพ.", + "deleted": "ะŸะปะตะนะปะธัั‚ ัƒะดะฐะปั‘ะฝ", + "failed_to_delete": "ะะต ัƒะดะฐะปะพััŒ ัƒะดะฐะปะธั‚ัŒ ะฟะปะตะนะปะธัั‚" }, "sort": { - "title": "Sort By", - "alphabetical": "Alphabetical", - "date_created": "Date Created" + "title": "ะกะพั€ั‚ะธั€ะพะฒะบะฐ", + "alphabetical": "ะŸะพ ะฐะปั„ะฐะฒะธั‚ัƒ", + "date_created": "ะŸะพ ะดะฐั‚ะต ัะพะทะดะฐะฝะธั" } }, "watchlists": { - "title": "Watchlists", - "my_watchlists": "My Watchlists", - "public_watchlists": "Public Watchlists", - "create_title": "Create Watchlist", - "edit_title": "Edit Watchlist", - "create_button": "Create Watchlist", - "save_button": "Save Changes", - "delete_button": "Delete", - "remove_button": "Remove", - "cancel_button": "Cancel", - "name_label": "Name", - "name_placeholder": "Enter watchlist name", - "description_label": "Description", - "description_placeholder": "Enter description (optional)", - "is_public_label": "Public Watchlist", - "is_public_description": "Allow others to view this watchlist", - "allowed_type_label": "Content Type", - "sort_order_label": "Default Sort Order", - "empty_title": "No Watchlists", - "empty_description": "Create your first watchlist to start organizing your media", - "empty_watchlist": "This watchlist is empty", - "empty_watchlist_hint": "Add items from your library to this watchlist", - "not_configured_title": "Streamystats Not Configured", - "not_configured_description": "Configure Streamystats in settings to use watchlists", - "go_to_settings": "Go to Settings", - "add_to_watchlist": "Add to Watchlist", - "remove_from_watchlist": "Remove from Watchlist", - "select_watchlist": "Select Watchlist", - "create_new": "Create New Watchlist", - "item": "item", - "items": "items", - "public": "Public", - "private": "Private", - "you": "You", - "by_owner": "By another user", - "not_found": "Watchlist not found", - "delete_confirm_title": "Delete Watchlist", - "delete_confirm_message": "Are you sure you want to delete \"{{name}}\"? This action cannot be undone.", - "remove_item_title": "Remove from Watchlist", - "remove_item_message": "Remove \"{{name}}\" from this watchlist?", - "loading": "Loading watchlists...", - "no_compatible_watchlists": "No compatible watchlists", - "create_one_first": "Create a watchlist that accepts this content type" + "title": "ะกะฟะธัะบะธ ะฟั€ะพัะผะพั‚ั€ะพะฒ", + "my_watchlists": "ะœะพะธ ัะฟะธัะบะธ", + "public_watchlists": "ะŸัƒะฑะปะธั‡ะฝั‹ะต ัะฟะธัะบะธ", + "create_title": "ะกะพะทะดะฐั‚ัŒ ัะฟะธัะพะบ", + "edit_title": "ะ ะตะดะฐะบั‚ะธั€ะพะฒะฐั‚ัŒ ัะฟะธัะพะบ", + "create_button": "ะกะพะทะดะฐั‚ัŒ ัะฟะธัะพะบ", + "save_button": "ะกะพั…ั€ะฐะฝะธั‚ัŒ ะธะทะผะตะฝะตะฝะธั", + "delete_button": "ะฃะดะฐะปะธั‚ัŒ", + "remove_button": "ะฃะดะฐะปะธั‚ัŒ", + "cancel_button": "ะžั‚ะผะตะฝะฐ", + "name_label": "ะะฐะทะฒะฐะฝะธะต", + "name_placeholder": "ะ’ะฒะตะดะธั‚ะต ะฝะฐะทะฒะฐะฝะธะต ัะฟะธัะบะฐ", + "description_label": "ะžะฟะธัะฐะฝะธะต", + "description_placeholder": "ะ’ะฒะตะดะธั‚ะต ะพะฟะธัะฐะฝะธะต (ะฝะต ะพะฑัะทะฐั‚ะตะปัŒะฝะพ)", + "is_public_label": "ะŸัƒะฑะปะธั‡ะฝั‹ะน", + "is_public_description": "ะ ะฐะทั€ะตัˆะธั‚ัŒ ะพัั‚ะฐะปัŒะฝั‹ะผ ะฟะพะปัŒะทะพะฒะฐั‚ะตะปัะผ ะฒะธะดะตั‚ัŒ ัั‚ะพั‚ ัะฟะธัะพะบ", + "allowed_type_label": "ะขะธะฟ ะบะพะฝั‚ะตะฝั‚ะฐ", + "sort_order_label": "ะกะพั€ั‚ะธั€ะพะฒะบะฐ ะฟะพ ัƒะผะพะปั‡ะฐะฝะธัŽ", + "empty_title": "ะะตั‚ ัะฟะธัะบะพะฒ", + "empty_description": "ะกะพะทะดะฐะนั‚ะต ะฒะฐัˆ ะฟะตั€ะฒั‹ะน ัะฟะธัะพะบ ะดะปั ัƒะฟั€ะฐะฒะปะตะฝะธั ะฒะฐัˆะธะผะธ ะผะตะดะธะฐ", + "empty_watchlist": "ะญั‚ะพั‚ ัะฟะธัะพะบ ะฟัƒัั‚", + "empty_watchlist_hint": "ะ”ะพะฑะฐะฒะปัะนั‚ะต ัะปะตะผะตะฝั‚ั‹ ะธะท ะฑะธะฑะปะธะพั‚ะตะบะธ ะฒ ัั‚ะพั‚ ัะฟะธัะพะบ", + "not_configured_title": "Streamystats ะฝะต ะฝะฐัั‚ั€ะพะตะฝ", + "not_configured_description": "ะะฐัั‚ั€ะพะนั‚ะต Streamystats ะดะปั ะธัะฟะพะปัŒะทะพะฒะฐะฝะธั ั„ัƒะฝะบั†ะธะพะฝะฐะปะฐ ัะฟะธัะบะพะฒ", + "go_to_settings": "ะ’ ะฝะฐัั‚ั€ะพะนะบะธ", + "add_to_watchlist": "ะ”ะพะฑะฐะฒะธั‚ัŒ ะฒ ัะฟะธัะพะบ ะฟั€ะพัะผะพั‚ั€ะฐ", + "remove_from_watchlist": "ะฃะดะฐะปะธั‚ัŒ ะธะท ัะฟะธัะบะฐ ะฟั€ะพัะผะพั‚ั€ะฐ", + "select_watchlist": "ะ’ั‹ะฑั€ะฐั‚ัŒ ัะฟะธัะพะบ", + "create_new": "ะกะพะทะดะฐั‚ัŒ ะฝะพะฒั‹ะน ัะฟะธัะพะบ", + "item": "ัะปะตะผะตะฝั‚", + "items": "ัะปะตะผะตะฝั‚ั‹", + "public": "ะŸัƒะฑะปะธั‡ะฝั‹ะน", + "private": "ะ›ะธั‡ะฝั‹ะน", + "you": "ะ’ะฐัˆ", + "by_owner": "ะ”ั€ัƒะณะธะผ ะฟะพะปัŒะทะพะฒะฐั‚ะตะปะตะผ", + "not_found": "ะกะฟะธัะพะบ ะฝะต ะฝะฐะนะดะตะฝ", + "delete_confirm_title": "ะฃะดะฐะปะธั‚ัŒ ัะฟะธัะพะบ", + "delete_confirm_message": "ะ’ั‹ ัƒะฒะตั€ะตะฝั‹, ั‡ั‚ะพ ั…ะพั‚ะธั‚ะต ัƒะดะฐะปะธั‚ัŒ ัะฟะธัะพะบ \"{{name}}\"? ะญั‚ะพ ะดะตะนัั‚ะฒะธะต ะฝะตะพะฑั€ะฐั‚ะธะผะพ.", + "remove_item_title": "ะฃะดะฐะปะธั‚ัŒ ะธะท ัะฟะธัะบะฐ", + "remove_item_message": "ะฃะดะฐะปะธั‚ัŒ \"{{name}}\" ะธะท ัะฟะธัะบะฐ?", + "loading": "ะ—ะฐะณั€ัƒะทะบะฐ ัะฟะธัะบะพะฒ...", + "no_compatible_watchlists": "ะะตั‚ ัะพะฒะผะตัั‚ะธะผั‹ั… ัะฟะธัะบะพะฒ", + "create_one_first": "ะกะพะทะดะฐะนั‚ะต ัะฟะธัะพะบ ะฟั€ะพัะผะพั‚ั€ะฐ ั ะฟะพะดั…ะพะดัั‰ะธะผ ั‚ะธะฟะพะผ ะบะพะฝั‚ะตะฝั‚ะฐ" }, "playback_speed": { - "title": "Playback Speed", - "apply_to": "Apply To", - "speed": "Speed", + "title": "ะกะบะพั€ะพัั‚ัŒ ะฒะพัะฟั€ะพะธะทะฒะตะดะตะฝะธั", + "apply_to": "ะŸั€ะธะผะตะฝัั‚ัŒ ะบ", + "speed": "ะกะบะพั€ะพัั‚ัŒ", "scope": { - "media": "This media only", - "show": "This show", - "all": "All media (default)" + "media": "ะขะพะปัŒะบะพ ะฒ ัั‚ะพั‚ ั€ะฐะท", + "show": "ะšะพ ะฒัะตะผัƒ ัะตั€ะธะฐะปัƒ", + "all": "ะšะพ ะฒัะตะผ ั„ะฐะนะปะฐะผ (ะฟะพ ัƒะผะพะปั‡ะฐะฝะธัŽ)" } } } From 564a593a3aabd01f732982f22e1a93b216e72953 Mon Sep 17 00:00:00 2001 From: Alex Collado <57129654+a-collado@users.noreply.github.com> Date: Thu, 12 Mar 2026 13:45:17 +0100 Subject: [PATCH 16/39] fix: Close modal when back button is pressed on Android (#1487) --- providers/GlobalModalProvider.tsx | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/providers/GlobalModalProvider.tsx b/providers/GlobalModalProvider.tsx index 76ced95a..c2268899 100644 --- a/providers/GlobalModalProvider.tsx +++ b/providers/GlobalModalProvider.tsx @@ -5,10 +5,13 @@ import { type ReactNode, useCallback, useContext, + useEffect, useRef, useState, } from "react"; +import { BackHandler, Platform } from "react-native"; + interface ModalOptions { enableDynamicSizing?: boolean; snapPoints?: (string | number)[]; @@ -73,6 +76,25 @@ export const GlobalModalProvider: React.FC = ({ }); }, []); + useEffect(() => { + if (Platform.OS !== "android") return; + + const onBackPress = () => { + if (isVisible) { + hideModal(); + return true; + } + return false; + }; + + const subscription = BackHandler.addEventListener( + "hardwareBackPress", + onBackPress, + ); + + return () => subscription.remove(); + }, [isVisible, hideModal]); + const value = { showModal, hideModal, From 2ce810c191bea6a2c558a610825307388e5277f1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Th=C3=A9o=20FORTIN?= <38886040+topiga@users.noreply.github.com> Date: Fri, 24 Apr 2026 10:44:30 +0200 Subject: [PATCH 17/39] fix(player/ios): Disable subtitles embedding for iOS simulator (#1544) --- modules/mpv-player/ios/MPVLayerRenderer.swift | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/modules/mpv-player/ios/MPVLayerRenderer.swift b/modules/mpv-player/ios/MPVLayerRenderer.swift index 9cb5540c..e6686a81 100644 --- a/modules/mpv-player/ios/MPVLayerRenderer.swift +++ b/modules/mpv-player/ios/MPVLayerRenderer.swift @@ -171,7 +171,11 @@ final class MPVLayerRenderer { // Enable composite OSD mode - renders subtitles directly onto video frames using GPU // This is better for PiP as subtitles are baked into the video // NOTE: Must be set BEFORE the #if targetEnvironment check or tvOS will freeze on player exit + #if targetEnvironment(simulator) + checkError(mpv_set_option_string(handle, "avfoundation-composite-osd", "no")) + #else checkError(mpv_set_option_string(handle, "avfoundation-composite-osd", "yes")) + #endif // Hardware decoding with VideoToolbox // On simulator, use software decoding since VideoToolbox is not available From 0e0e722e1c74a512185c54d5f23e5a6524e12394 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Tue, 19 May 2026 19:58:56 +0200 Subject: [PATCH 18/39] chore(deps): Update crowdin/github-action action to v2.16.2 (#1504) --- .github/workflows/crowdin.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/crowdin.yml b/.github/workflows/crowdin.yml index 66ce0559..c6effebf 100644 --- a/.github/workflows/crowdin.yml +++ b/.github/workflows/crowdin.yml @@ -28,7 +28,7 @@ jobs: fetch-depth: 0 - name: ๐ŸŒ Sync Translations with Crowdin - uses: crowdin/github-action@5587c43063e52090026857d386174d2599ad323b # v2.14.1 + uses: crowdin/github-action@8868a33591d21088edfc398968173a3b98d51706 # v2.16.2 with: upload_sources: true upload_translations: true From fec8df37f773e59b360702fbcb5b15e99c102b9c Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Tue, 19 May 2026 23:40:40 +0200 Subject: [PATCH 19/39] chore(deps): Pin dependencies (#1537) --- .github/workflows/build-apps.yml | 2 +- .github/workflows/update-issue-form.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-apps.yml b/.github/workflows/build-apps.yml index b300c04d..9a03648c 100644 --- a/.github/workflows/build-apps.yml +++ b/.github/workflows/build-apps.yml @@ -221,7 +221,7 @@ jobs: xcode-version: "26.2" - name: ๐Ÿ—๏ธ Setup EAS - uses: expo/expo-github-action@main + uses: expo/expo-github-action@b184ff86a3c926240f1b6db41764c83a01c02eef # main with: eas-version: latest token: ${{ secrets.EXPO_TOKEN }} diff --git a/.github/workflows/update-issue-form.yml b/.github/workflows/update-issue-form.yml index 25fa3319..d0463116 100644 --- a/.github/workflows/update-issue-form.yml +++ b/.github/workflows/update-issue-form.yml @@ -28,7 +28,7 @@ jobs: - name: ๐Ÿ” Extract minor version from app.json id: minor - uses: actions/github-script@main + uses: actions/github-script@3a2844b7e9c422d3c10d287c895573f7108da1b3 # main with: result-encoding: string script: | From 222ae696449f990ca97e1067e026d7fc54f84397 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 00:03:36 +0200 Subject: [PATCH 20/39] chore(deps): Update marocchino/sticky-pull-request-comment action to v3 (#1512) --- .github/workflows/linting.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index 08e0a884..1a9c3e39 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -25,7 +25,7 @@ jobs: env: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - uses: marocchino/sticky-pull-request-comment@773744901bac0e8cbb5a0dc842800d45e9b2b405 # v2.9.4 + - uses: marocchino/sticky-pull-request-comment@0ea0beb66eb9baf113663a64ec522f60e49231c0 # v3.0.4 if: always() && (steps.lint_pr_title.outputs.error_message != null) with: header: pr-title-lint-error @@ -39,7 +39,7 @@ jobs: ``` - if: ${{ steps.lint_pr_title.outputs.error_message == null }} - uses: marocchino/sticky-pull-request-comment@773744901bac0e8cbb5a0dc842800d45e9b2b405 # v2.9.4 + uses: marocchino/sticky-pull-request-comment@0ea0beb66eb9baf113663a64ec522f60e49231c0 # v3.0.4 with: header: pr-title-lint-error delete: true From 7ed0c00ce7506700be0272b933333837c07d9bb2 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 00:24:58 +0200 Subject: [PATCH 21/39] chore(deps): Update actions/upload-artifact action to v7 (#1510) --- .github/workflows/build-apps.yml | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/build-apps.yml b/.github/workflows/build-apps.yml index 9a03648c..82c4a418 100644 --- a/.github/workflows/build-apps.yml +++ b/.github/workflows/build-apps.yml @@ -88,7 +88,7 @@ jobs: run: echo "DATE_TAG=$(date +%d-%m-%Y_%H-%M-%S)" >> $GITHUB_ENV - name: ๐Ÿ“ค Upload APK artifact - uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0 + uses: actions/upload-artifact@043fb46d1a93c77aae656e7c1c64a875d1fc6a0a # v7.0.1 with: name: streamyfin-android-phone-apk-${{ env.DATE_TAG }} path: | @@ -171,7 +171,7 @@ jobs: run: echo "DATE_TAG=$(date +%d-%m-%Y_%H-%M-%S)" >> $GITHUB_ENV - name: ๐Ÿ“ค Upload APK artifact - uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0 + uses: actions/upload-artifact@043fb46d1a93c77aae656e7c1c64a875d1fc6a0a # v7.0.1 with: name: streamyfin-android-tv-apk-${{ env.DATE_TAG }} path: | @@ -236,7 +236,7 @@ jobs: run: echo "DATE_TAG=$(date +%d-%m-%Y_%H-%M-%S)" >> $GITHUB_ENV - name: ๐Ÿ“ค Upload IPA artifact - uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0 + uses: actions/upload-artifact@043fb46d1a93c77aae656e7c1c64a875d1fc6a0a # v7.0.1 with: name: streamyfin-ios-phone-ipa-${{ env.DATE_TAG }} path: build-*.ipa @@ -293,7 +293,7 @@ jobs: run: echo "DATE_TAG=$(date +%d-%m-%Y_%H-%M-%S)" >> $GITHUB_ENV - name: ๐Ÿ“ค Upload IPA artifact - uses: actions/upload-artifact@b7c566a772e6b6bfb58ed0dc250532a479d7789f # v6.0.0 + uses: actions/upload-artifact@043fb46d1a93c77aae656e7c1c64a875d1fc6a0a # v7.0.1 with: name: streamyfin-ios-phone-unsigned-ipa-${{ env.DATE_TAG }} path: build/*.ipa From 8c749cdc4d5524594edf18e6195eaa01429fe9cf Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 00:44:45 +0200 Subject: [PATCH 22/39] chore(deps): Update oven-sh/setup-bun action to v2.2.0 (#1509) --- .github/workflows/build-apps.yml | 8 ++++---- .github/workflows/check-lockfile.yml | 2 +- .github/workflows/linting.yml | 4 ++-- 3 files changed, 7 insertions(+), 7 deletions(-) diff --git a/.github/workflows/build-apps.yml b/.github/workflows/build-apps.yml index 82c4a418..492c0a63 100644 --- a/.github/workflows/build-apps.yml +++ b/.github/workflows/build-apps.yml @@ -41,7 +41,7 @@ jobs: show-progress: false - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 + uses: oven-sh/setup-bun@0c5077e51419868618aeaa5fe8019c62421857d6 # v2.2.0 with: bun-version: latest @@ -124,7 +124,7 @@ jobs: show-progress: false - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 + uses: oven-sh/setup-bun@0c5077e51419868618aeaa5fe8019c62421857d6 # v2.2.0 with: bun-version: latest @@ -195,7 +195,7 @@ jobs: show-progress: false - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 + uses: oven-sh/setup-bun@0c5077e51419868618aeaa5fe8019c62421857d6 # v2.2.0 with: bun-version: latest @@ -259,7 +259,7 @@ jobs: show-progress: false - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 + uses: oven-sh/setup-bun@0c5077e51419868618aeaa5fe8019c62421857d6 # v2.2.0 with: bun-version: latest diff --git a/.github/workflows/check-lockfile.yml b/.github/workflows/check-lockfile.yml index ad189f7f..99a2a490 100644 --- a/.github/workflows/check-lockfile.yml +++ b/.github/workflows/check-lockfile.yml @@ -27,7 +27,7 @@ jobs: fetch-depth: 0 - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 + uses: oven-sh/setup-bun@0c5077e51419868618aeaa5fe8019c62421857d6 # v2.2.0 with: bun-version: latest diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index 1a9c3e39..9cc1b4bf 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -76,7 +76,7 @@ jobs: fetch-depth: 0 - name: ๐Ÿž Setup Bun - uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 + uses: oven-sh/setup-bun@0c5077e51419868618aeaa5fe8019c62421857d6 # v2.2.0 with: bun-version: latest @@ -112,7 +112,7 @@ jobs: node-version: '24.x' - name: "๐Ÿž Setup Bun" - uses: oven-sh/setup-bun@3d267786b128fe76c2f16a390aa2448b815359f3 # v2.1.2 + uses: oven-sh/setup-bun@0c5077e51419868618aeaa5fe8019c62421857d6 # v2.2.0 with: bun-version: latest From 428455f6a66686cfbe5392ad701acc66ac1341ec Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 01:08:17 +0200 Subject: [PATCH 23/39] chore(deps): Update actions/setup-node action to v6.4.0 (#1503) --- .github/workflows/linting.yml | 2 +- .github/workflows/update-issue-form.yml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index 9cc1b4bf..45ee39f3 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -107,7 +107,7 @@ jobs: fetch-depth: 0 - name: "๐ŸŸข Setup Node.js" - uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 + uses: actions/setup-node@48b55a011bda9f5d6aeb4c2d9c7362e8dae4041e # v6.4.0 with: node-version: '24.x' diff --git a/.github/workflows/update-issue-form.yml b/.github/workflows/update-issue-form.yml index d0463116..69fad2eb 100644 --- a/.github/workflows/update-issue-form.yml +++ b/.github/workflows/update-issue-form.yml @@ -21,7 +21,7 @@ jobs: uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - name: "๐ŸŸข Setup Node.js" - uses: actions/setup-node@6044e13b5dc448c55e2357c09f80417699197238 # v6.2.0 + uses: actions/setup-node@48b55a011bda9f5d6aeb4c2d9c7362e8dae4041e # v6.4.0 with: node-version: '24.x' cache: 'npm' From 2e7079cb5abb7b329e3c1472645f3b763885a489 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 12:54:50 +0200 Subject: [PATCH 24/39] chore(deps): Update github/codeql-action action to v4.35.5 (#1508) --- .github/workflows/ci-codeql.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/ci-codeql.yml b/.github/workflows/ci-codeql.yml index 29330ac7..e2b52fcf 100644 --- a/.github/workflows/ci-codeql.yml +++ b/.github/workflows/ci-codeql.yml @@ -27,13 +27,13 @@ jobs: uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6.0.2 - name: ๐Ÿ Initialize CodeQL - uses: github/codeql-action/init@b20883b0cd1f46c72ae0ba6d1090936928f9fa30 # v4.32.0 + uses: github/codeql-action/init@9e0d7b8d25671d64c341c19c0152d693099fb5ba # v4.35.5 with: languages: ${{ matrix.language }} queries: +security-extended,security-and-quality - name: ๐Ÿ› ๏ธ Autobuild - uses: github/codeql-action/autobuild@b20883b0cd1f46c72ae0ba6d1090936928f9fa30 # v4.32.0 + uses: github/codeql-action/autobuild@9e0d7b8d25671d64c341c19c0152d693099fb5ba # v4.35.5 - name: ๐Ÿงช Perform CodeQL Analysis - uses: github/codeql-action/analyze@b20883b0cd1f46c72ae0ba6d1090936928f9fa30 # v4.32.0 + uses: github/codeql-action/analyze@9e0d7b8d25671d64c341c19c0152d693099fb5ba # v4.35.5 From 55776d887f14adfcdf8773b6c7a100470f874399 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 13:17:20 +0200 Subject: [PATCH 25/39] chore(deps): Update maxim-lobanov/setup-xcode digest to ed7a3b1 (#1498) --- .github/workflows/build-apps.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/build-apps.yml b/.github/workflows/build-apps.yml index 492c0a63..e580846d 100644 --- a/.github/workflows/build-apps.yml +++ b/.github/workflows/build-apps.yml @@ -216,7 +216,7 @@ jobs: run: bun run prebuild - name: ๐Ÿ”ง Setup Xcode - uses: maxim-lobanov/setup-xcode@60606e260d2fc5762a71e64e74b2174e8ea3c8bd # v1 + uses: maxim-lobanov/setup-xcode@ed7a3b1fda3918c0306d1b724322adc0b8cc0a90 # v1 with: xcode-version: "26.2" @@ -280,7 +280,7 @@ jobs: run: bun run prebuild - name: ๐Ÿ”ง Setup Xcode - uses: maxim-lobanov/setup-xcode@60606e260d2fc5762a71e64e74b2174e8ea3c8bd # v1 + uses: maxim-lobanov/setup-xcode@ed7a3b1fda3918c0306d1b724322adc0b8cc0a90 # v1 with: xcode-version: "26.2" From 8df61838d4c64e031e44d8bb26d3115b21972cbe Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 13:43:17 +0200 Subject: [PATCH 26/39] chore(deps): Update actions/cache action to v5.0.5 (#1429) --- .github/workflows/build-apps.yml | 16 ++++++++-------- .github/workflows/check-lockfile.yml | 2 +- 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.github/workflows/build-apps.yml b/.github/workflows/build-apps.yml index e580846d..324b82c0 100644 --- a/.github/workflows/build-apps.yml +++ b/.github/workflows/build-apps.yml @@ -46,7 +46,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: ~/.bun/install/cache key: ${{ runner.os }}-${{ runner.arch }}-bun-develop-${{ hashFiles('bun.lock') }} @@ -60,7 +60,7 @@ jobs: bun run submodule-reload - name: ๐Ÿ’พ Cache Gradle global - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: | ~/.gradle/caches @@ -73,7 +73,7 @@ jobs: run: bun run prebuild - name: ๐Ÿ’พ Cache project Gradle (.gradle) - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: android/.gradle key: ${{ runner.os }}-android-gradle-develop-${{ hashFiles('android/**/build.gradle', 'android/gradle/wrapper/gradle-wrapper.properties') }} @@ -129,7 +129,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: ~/.bun/install/cache key: ${{ runner.os }}-${{ runner.arch }}-bun-develop-${{ hashFiles('bun.lock') }} @@ -143,7 +143,7 @@ jobs: bun run submodule-reload - name: ๐Ÿ’พ Cache Gradle global - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: | ~/.gradle/caches @@ -156,7 +156,7 @@ jobs: run: bun run prebuild:tv - name: ๐Ÿ’พ Cache project Gradle (.gradle) - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: android/.gradle key: ${{ runner.os }}-android-gradle-develop-${{ hashFiles('android/**/build.gradle', 'android/gradle/wrapper/gradle-wrapper.properties') }} @@ -200,7 +200,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: ~/.bun/install/cache key: ${{ runner.os }}-bun-cache-${{ hashFiles('bun.lock') }} @@ -264,7 +264,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: ~/.bun/install/cache key: ${{ runner.os }}-bun-cache-${{ hashFiles('bun.lock') }} diff --git a/.github/workflows/check-lockfile.yml b/.github/workflows/check-lockfile.yml index 99a2a490..ae4c0fe0 100644 --- a/.github/workflows/check-lockfile.yml +++ b/.github/workflows/check-lockfile.yml @@ -32,7 +32,7 @@ jobs: bun-version: latest - name: ๐Ÿ’พ Cache Bun dependencies - uses: actions/cache@8b402f58fbc84540c8b491a91e594a4576fec3d7 # v5.0.2 + uses: actions/cache@27d5ce7f107fe9357f9df03efb73ab90386fccae # v5.0.5 with: path: | ~/.bun/install/cache From 7bccafc476405c3e344963392d70ab1e0eb78ecc Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 14:49:24 +0200 Subject: [PATCH 27/39] chore(deps): Update actions/dependency-review-action action to v4.8.3 (#1499) --- .github/workflows/linting.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index 45ee39f3..bfc3a9a9 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -57,7 +57,7 @@ jobs: fetch-depth: 0 - name: Dependency Review - uses: actions/dependency-review-action@3c4e3dcb1aa7874d2c16be7d79418e9b7efd6261 # v4.8.2 + uses: actions/dependency-review-action@05fe4576374b728f0c523d6a13d64c25081e0803 # v4.8.3 with: fail-on-severity: high base-ref: ${{ github.event.pull_request.base.sha || 'develop' }} From 52bc5e912dd426936e2cfff7e2d9fc35df3a43f7 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 15:28:34 +0200 Subject: [PATCH 28/39] chore(deps): Update actions/dependency-review-action action to v4.9.0 (#1502) --- .github/workflows/linting.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index bfc3a9a9..b8695bf9 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -57,7 +57,7 @@ jobs: fetch-depth: 0 - name: Dependency Review - uses: actions/dependency-review-action@05fe4576374b728f0c523d6a13d64c25081e0803 # v4.8.3 + uses: actions/dependency-review-action@2031cfc080254a8a887f58cffee85186f0e49e48 # v4.9.0 with: fail-on-severity: high base-ref: ${{ github.event.pull_request.base.sha || 'develop' }} From 1321a5c00019dd56674aff65131385bede657625 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 17:05:10 +0200 Subject: [PATCH 29/39] chore(deps): Update actions/dependency-review-action action to v5 (#1567) --- .github/workflows/linting.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/linting.yml b/.github/workflows/linting.yml index b8695bf9..50013ba2 100644 --- a/.github/workflows/linting.yml +++ b/.github/workflows/linting.yml @@ -57,7 +57,7 @@ jobs: fetch-depth: 0 - name: Dependency Review - uses: actions/dependency-review-action@2031cfc080254a8a887f58cffee85186f0e49e48 # v4.9.0 + uses: actions/dependency-review-action@a1d282b36b6f3519aa1f3fc636f609c47dddb294 # v5.0.0 with: fail-on-severity: high base-ref: ${{ github.event.pull_request.base.sha || 'develop' }} From f1188c090abd56eea4e72dcae327a89841aeb569 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 17:37:53 +0200 Subject: [PATCH 30/39] chore(deps): Update peter-evans/create-pull-request action to v8.1.1 (#1566) --- .github/workflows/update-issue-form.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/update-issue-form.yml b/.github/workflows/update-issue-form.yml index 69fad2eb..7cc32197 100644 --- a/.github/workflows/update-issue-form.yml +++ b/.github/workflows/update-issue-form.yml @@ -54,7 +54,7 @@ jobs: dry_run: no-push - name: ๐Ÿ“ฌ Commit and create pull request - uses: peter-evans/create-pull-request@c0f553fe549906ede9cf27b5156039d195d2ece0 # v8.1.0 + uses: peter-evans/create-pull-request@5f6978faf089d4d20b00c7766989d076bb2fc7f1 # v8.1.1 with: add-paths: .github/ISSUE_TEMPLATE/bug_report.yml branch: ci-update-bug-report From 1fd3574520abadd983e9b9f6c04b3b77f6e98d21 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 18:36:38 +0200 Subject: [PATCH 31/39] chore(deps): Update actions/github-script action to v9 (#1568) --- .github/workflows/artifact-comment.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/artifact-comment.yml b/.github/workflows/artifact-comment.yml index 8528a95b..e5c9f4ac 100644 --- a/.github/workflows/artifact-comment.yml +++ b/.github/workflows/artifact-comment.yml @@ -26,7 +26,7 @@ jobs: steps: - name: ๐Ÿ” Get PR and Artifacts - uses: actions/github-script@ed597411d8f924073f98dfc5c65a23a2325f34cd # v8 + uses: actions/github-script@3a2844b7e9c422d3c10d287c895573f7108da1b3 # v9 with: script: | // Check if we're running from a fork (more precise detection) From 284a4e3d41775edb32e7feda2a2009eb45708551 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 19:10:36 +0200 Subject: [PATCH 32/39] chore(deps): Update dependency expo-doctor to v1.18.22 (#1506) --- bun.lock | 6 +++--- package.json | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/bun.lock b/bun.lock index 326bd749..bea4e3bf 100644 --- a/bun.lock +++ b/bun.lock @@ -104,7 +104,7 @@ "@types/react": "19.1.17", "@types/react-test-renderer": "19.1.0", "cross-env": "10.1.0", - "expo-doctor": "1.17.14", + "expo-doctor": "1.18.22", "husky": "9.1.7", "lint-staged": "16.2.7", "react-test-renderer": "19.2.3", @@ -1030,7 +1030,7 @@ "expo-device": ["expo-device@8.0.10", "", { "dependencies": { "ua-parser-js": "^0.7.33" }, "peerDependencies": { "expo": "*" } }, "sha512-jd5BxjaF7382JkDMaC+P04aXXknB2UhWaVx5WiQKA05ugm/8GH5uaz9P9ckWdMKZGQVVEOC8MHaUADoT26KmFA=="], - "expo-doctor": ["expo-doctor@1.17.14", "", { "bin": { "expo-doctor": "build/index.js" } }, "sha512-+UsXFP5ZTVobDuGS5Du8aKU6O6s2sa49QOdGHdzP8UEjQKH8gPb59uw6hxEQmo6YtVboLwQd13QEdcSolBMvLw=="], + "expo-doctor": ["expo-doctor@1.18.22", "", { "bin": { "expo-doctor": "build/index.js" } }, "sha512-AEGwceidWxyYpWEfIf3XnUvc+FbI3OjjyBaXctuoZg10x9An+utrdRf6go/3UFRAG5EkpMOWgUT0j1TKcYDsSQ=="], "expo-file-system": ["expo-file-system@19.0.21", "", { "peerDependencies": { "expo": "*", "react-native": "*" } }, "sha512-s3DlrDdiscBHtab/6W1osrjGL+C2bvoInPJD7sOwmxfJ5Woynv2oc+Fz1/xVXaE/V7HE/+xrHC/H45tu6lZzzg=="], @@ -1696,7 +1696,7 @@ "react-native-text-ticker": ["react-native-text-ticker@1.15.0", "", {}, "sha512-d/uK+PIOhsYMy1r8h825iq/nADiHsabz3WMbRJSnkpQYn+K9aykUAXRRhu8ZbTAzk4CgnUWajJEFxS5ZDygsdg=="], - "react-native-track-player": ["react-native-track-player@github:lovegaoshi/react-native-track-player#003afd0", { "peerDependencies": { "react": "*", "react-native": "*", "react-native-windows": "*", "shaka-player": "^4.7.9" }, "optionalPeers": ["react-native-windows", "shaka-player"] }, "lovegaoshi-react-native-track-player-003afd0"], + "react-native-track-player": ["react-native-track-player@github:lovegaoshi/react-native-track-player#003afd0", { "peerDependencies": { "react": "*", "react-native": "*", "react-native-windows": "*", "shaka-player": "^4.7.9" }, "optionalPeers": ["react-native-windows", "shaka-player"] }, "lovegaoshi-react-native-track-player-003afd0", "sha512-HR7BaMDMBhQ4xAy5XeQEkT0fBosWw2x9+X2QOD4buocxuX03D770LaRKm5rgQ/qDzchr92KW7+d8fISI14fRLA=="], "react-native-udp": ["react-native-udp@4.1.7", "", { "dependencies": { "buffer": "^5.6.0", "events": "^3.1.0" } }, "sha512-NUE3zewu61NCdSsLlj+l0ad6qojcVEZPT4hVG/x6DU9U4iCzwtfZSASh9vm7teAcVzLkdD+cO3411LHshAi/wA=="], diff --git a/package.json b/package.json index 9864985a..f0adf6e0 100644 --- a/package.json +++ b/package.json @@ -124,7 +124,7 @@ "@types/react": "19.1.17", "@types/react-test-renderer": "19.1.0", "cross-env": "10.1.0", - "expo-doctor": "1.17.14", + "expo-doctor": "1.18.22", "husky": "9.1.7", "lint-staged": "16.2.7", "react-test-renderer": "19.2.3", From 235ba1473f3774c69934fe33f0ba3ce362d444c0 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 22:40:20 +0200 Subject: [PATCH 33/39] chore(deps): Update dependency lint-staged to v16.4.0 (#1507) --- bun.lock | 36 +++++++++++++++++++++++++----------- package.json | 2 +- 2 files changed, 26 insertions(+), 12 deletions(-) diff --git a/bun.lock b/bun.lock index bea4e3bf..b66f5dee 100644 --- a/bun.lock +++ b/bun.lock @@ -106,7 +106,7 @@ "cross-env": "10.1.0", "expo-doctor": "1.18.22", "husky": "9.1.7", - "lint-staged": "16.2.7", + "lint-staged": "16.4.0", "react-test-renderer": "19.2.3", "typescript": "5.9.3", }, @@ -1370,7 +1370,7 @@ "lines-and-columns": ["lines-and-columns@1.2.4", "", {}, "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg=="], - "lint-staged": ["lint-staged@16.2.7", "", { "dependencies": { "commander": "^14.0.2", "listr2": "^9.0.5", "micromatch": "^4.0.8", "nano-spawn": "^2.0.0", "pidtree": "^0.6.0", "string-argv": "^0.3.2", "yaml": "^2.8.1" }, "bin": { "lint-staged": "bin/lint-staged.js" } }, "sha512-lDIj4RnYmK7/kXMya+qJsmkRFkGolciXjrsZ6PC25GdTfWOAWetR0ZbsNXRAj1EHHImRSalc+whZFg56F5DVow=="], + "lint-staged": ["lint-staged@16.4.0", "", { "dependencies": { "commander": "^14.0.3", "listr2": "^9.0.5", "picomatch": "^4.0.3", "string-argv": "^0.3.2", "tinyexec": "^1.0.4", "yaml": "^2.8.2" }, "bin": { "lint-staged": "bin/lint-staged.js" } }, "sha512-lBWt8hujh/Cjysw5GYVmZpFHXDCgZzhrOm8vbcUdobADZNOK/bRshr2kM3DfgrrtR1DQhfupW9gnIXOfiFi+bw=="], "listr2": ["listr2@9.0.5", "", { "dependencies": { "cli-truncate": "^5.0.0", "colorette": "^2.0.20", "eventemitter3": "^5.0.1", "log-update": "^6.1.0", "rfdc": "^1.4.1", "wrap-ansi": "^9.0.0" } }, "sha512-ME4Fb83LgEgwNw96RKNvKV4VTLuXfoKudAmm2lP8Kk87KaMK0/Xrx/aAkMWmT8mDb+3MlFDspfbCs7adjRxA2g=="], @@ -1462,8 +1462,6 @@ "mz": ["mz@2.7.0", "", { "dependencies": { "any-promise": "^1.0.0", "object-assign": "^4.0.1", "thenify-all": "^1.0.0" } }, "sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q=="], - "nano-spawn": ["nano-spawn@2.0.0", "", {}, "sha512-tacvGzUY5o2D8CBh2rrwxyNojUsZNU2zjNTzKQrkgGJQTbGAfArVWXSKMBokBeeg6C7OLRGUEyoFlYbfeWQIqw=="], - "nanoid": ["nanoid@3.3.11", "", { "bin": { "nanoid": "bin/nanoid.cjs" } }, "sha512-N8SpfPUnUp1bK+PMYW8qSWdl9U+wwNWI4QKxOYDy9JAro3WMX7p2OeVRF9v+347pnakNevPmiHhNmZ2HbFA76w=="], "nativewind": ["nativewind@2.0.11", "", { "dependencies": { "@babel/generator": "^7.18.7", "@babel/helper-module-imports": "7.18.6", "@babel/types": "7.19.0", "css-mediaquery": "^0.1.2", "css-to-react-native": "^3.0.0", "micromatch": "^4.0.5", "postcss": "^8.4.12", "postcss-calc": "^8.2.4", "postcss-color-functional-notation": "^4.2.2", "postcss-css-variables": "^0.18.0", "postcss-nested": "^5.0.6", "react-is": "^18.1.0", "use-sync-external-store": "^1.1.0" }, "peerDependencies": { "tailwindcss": "~3" } }, "sha512-qCEXUwKW21RYJ33KRAJl3zXq2bCq82WoI564fI21D/TiqhfmstZOqPN53RF8qK1NDK6PGl56b2xaTxgObEePEg=="], @@ -1558,9 +1556,7 @@ "picocolors": ["picocolors@1.1.1", "", {}, "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA=="], - "picomatch": ["picomatch@2.3.1", "", {}, "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="], - - "pidtree": ["pidtree@0.6.0", "", { "bin": { "pidtree": "bin/pidtree.js" } }, "sha512-eG2dWTVw5bzqGRztnHExczNxt5VGsE6OwTeCG3fdUf9KBsZzO3R5OIIIzWR+iZA0NtZ+RDVdaoE2dK1cn6jH4g=="], + "picomatch": ["picomatch@4.0.3", "", {}, "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q=="], "pify": ["pify@2.3.0", "", {}, "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog=="], @@ -1910,6 +1906,8 @@ "tinycolor2": ["tinycolor2@1.6.0", "", {}, "sha512-XPaBkWQJdsf3pLKJV9p4qN/S+fm2Oj8AIPo1BTUhg5oxkvm9+SVEGFdhyOz7tTdUTfvxMiAs4sp6/eZO2Ew+pw=="], + "tinyexec": ["tinyexec@1.1.2", "", {}, "sha512-dAqSqE/RabpBKI8+h26GfLq6Vb3JVXs30XYQjdMjaj/c2tS8IYYMbIzP599KtRj7c57/wYApb3QjgRgXmrCukA=="], + "tinyglobby": ["tinyglobby@0.2.15", "", { "dependencies": { "fdir": "^6.5.0", "picomatch": "^4.0.3" } }, "sha512-j2Zq4NyQYG5XMST4cbs02Ak8iJUdxRM0XI5QyxXuZOzKOINmWurp3smXu3y5wDcJrptwpSjgXHzIQxR0omXljQ=="], "tmp": ["tmp@0.2.5", "", {}, "sha512-voyz6MApa1rQGUxT3E+BK7/ROe8itEx7vD8/HEvt4xwXucvQ5G5oeEiHkmHZJuBO21RpOf+YYm9MOivj709jow=="], @@ -2034,7 +2032,7 @@ "yallist": ["yallist@3.1.1", "", {}, "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g=="], - "yaml": ["yaml@2.8.1", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw=="], + "yaml": ["yaml@2.9.0", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-2AvhNX3mb8zd6Zy7INTtSpl1F15HW6Wnqj0srWlkKLcpYl/gMIMJiyuGq2KeI2YFxUPjdlB+3Lc10seMLtL4cA=="], "yargs": ["yargs@17.7.2", "", { "dependencies": { "cliui": "^8.0.1", "escalade": "^3.1.1", "get-caller-file": "^2.0.5", "require-directory": "^2.1.1", "string-width": "^4.2.3", "y18n": "^5.0.5", "yargs-parser": "^21.1.1" } }, "sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w=="], @@ -2208,6 +2206,8 @@ "@react-native-community/cli-doctor/semver": ["semver@7.7.2", "", { "bin": { "semver": "bin/semver.js" } }, "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA=="], + "@react-native-community/cli-doctor/yaml": ["yaml@2.8.1", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw=="], + "@react-native-community/cli-server-api/open": ["open@6.4.0", "", { "dependencies": { "is-wsl": "^1.1.0" } }, "sha512-IFenVPgF70fSm1keSd2iDBIDIBZkroLeuffXq+wKTzTJlBpesFWojV9lb8mzOfaAzM1sr7HQHuO0vtV0zYekGg=="], "@react-native-community/cli-tools/semver": ["semver@7.7.2", "", { "bin": { "semver": "bin/semver.js" } }, "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA=="], @@ -2266,6 +2266,8 @@ "ansi-fragments/strip-ansi": ["strip-ansi@5.2.0", "", { "dependencies": { "ansi-regex": "^4.1.0" } }, "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA=="], + "anymatch/picomatch": ["picomatch@2.3.1", "", {}, "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="], + "babel-jest/slash": ["slash@3.0.0", "", {}, "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q=="], "babel-plugin-jest-hoist/@babel/template": ["@babel/template@7.27.2", "", { "dependencies": { "@babel/code-frame": "^7.27.1", "@babel/parser": "^7.27.2", "@babel/types": "^7.27.1" } }, "sha512-LPDZ85aEJyYSd18/DkjNh4/y1ntkE5KwUHWTiqgRxruuZL2F1yuHligVHLvcHY2vMHXttKFpJn6LwfI7cw7ODw=="], @@ -2340,11 +2342,13 @@ "jest-message-util/slash": ["slash@3.0.0", "", {}, "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q=="], + "jest-util/picomatch": ["picomatch@2.3.1", "", {}, "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="], + "jest-worker/supports-color": ["supports-color@8.1.1", "", { "dependencies": { "has-flag": "^4.0.0" } }, "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q=="], "lighthouse-logger/debug": ["debug@2.6.9", "", { "dependencies": { "ms": "2.0.0" } }, "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA=="], - "lint-staged/commander": ["commander@14.0.2", "", {}, "sha512-TywoWNNRbhoD0BXs1P3ZEScW8W5iKrnbithIl0YH+uCmBd0QpPOA8yc82DS3BIE5Ma6FnBVUsJ7wVUDz4dvOWQ=="], + "lint-staged/commander": ["commander@14.0.3", "", {}, "sha512-H+y0Jo/T1RZ9qPP4Eh1pkcQcLRglraJaSLoyOtHxu6AapkjWVCy2Sit1QQ4x3Dng8qDlSsZEet7g5Pq06MvTgw=="], "log-update/cli-cursor": ["cli-cursor@5.0.0", "", { "dependencies": { "restore-cursor": "^5.0.0" } }, "sha512-aCj4O5wKyszjMmDT4tZj93kxyydN/K5zPWSCe6/0AV/AA1pqe5ZBIw0a2ZfPQV7lL5/yb5HsUreJ6UFAF1tEQw=="], @@ -2376,6 +2380,8 @@ "metro-babel-transformer/hermes-parser": ["hermes-parser@0.32.0", "", { "dependencies": { "hermes-estree": "0.32.0" } }, "sha512-g4nBOWFpuiTqjR3LZdRxKUkij9iyveWeuks7INEsMX741f3r9xxrOe8TeQfUxtda0eXmiIFiMQzoeSQEno33Hw=="], + "metro-config/yaml": ["yaml@2.8.1", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw=="], + "metro-source-map/@babel/traverse": ["@babel/traverse@7.28.5", "", { "dependencies": { "@babel/code-frame": "^7.27.1", "@babel/generator": "^7.28.5", "@babel/helper-globals": "^7.28.0", "@babel/parser": "^7.28.5", "@babel/template": "^7.27.2", "@babel/types": "^7.28.5", "debug": "^4.3.1" } }, "sha512-TCCj4t55U90khlYkVV/0TfkJkAkUg3jZFA3Neb7unZT8CPok7iiRfaX0F+WnqWqt7OxhOn0uBKXCw4lbL8W0aQ=="], "metro-source-map/@babel/types": ["@babel/types@7.28.5", "", { "dependencies": { "@babel/helper-string-parser": "^7.27.1", "@babel/helper-validator-identifier": "^7.28.5" } }, "sha512-qQ5m48eI/MFLQ5PxQj4PFaprjyCTLI37ElWMmNs0K8Lk3dVeOdNpB3ks8jc7yM5CDmVC73eMVk/trk3fgmrUpA=="], @@ -2396,6 +2402,8 @@ "metro-transform-worker/@babel/types": ["@babel/types@7.28.5", "", { "dependencies": { "@babel/helper-string-parser": "^7.27.1", "@babel/helper-validator-identifier": "^7.28.5" } }, "sha512-qQ5m48eI/MFLQ5PxQj4PFaprjyCTLI37ElWMmNs0K8Lk3dVeOdNpB3ks8jc7yM5CDmVC73eMVk/trk3fgmrUpA=="], + "micromatch/picomatch": ["picomatch@2.3.1", "", {}, "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="], + "nativewind/@babel/generator": ["@babel/generator@7.28.5", "", { "dependencies": { "@babel/parser": "^7.28.5", "@babel/types": "^7.28.5", "@jridgewell/gen-mapping": "^0.3.12", "@jridgewell/trace-mapping": "^0.3.28", "jsesc": "^3.0.2" } }, "sha512-3EwLFhZ38J4VyIP6WNtt2kUdW9dokXA9Cr4IVIFHuCpZ3H8/YFOl5JjZHisrn1fATPBmKKqXzDFvh9fUwHz6CQ=="], "nativewind/@babel/types": ["@babel/types@7.19.0", "", { "dependencies": { "@babel/helper-string-parser": "^7.18.10", "@babel/helper-validator-identifier": "^7.18.6", "to-fast-properties": "^2.0.0" } }, "sha512-YuGopBq3ke25BVSiS6fgF49Ul9gH1x70Bcr6bqRLjWCkcX8Hre1/5+z+IiWOIerRMSSEfGZVB9z9kyq7wVs9YA=="], @@ -2412,12 +2420,16 @@ "patch-package/semver": ["semver@7.6.3", "", { "bin": { "semver": "bin/semver.js" } }, "sha512-oVekP1cKtI+CTDvHWYFUcMtsK/00wmAEfyqKfNdARm8u1wNVhSgaX7A8d4UuIlUI5e84iEwOhs7ZPYRmzU9U6A=="], + "patch-package/yaml": ["yaml@2.8.1", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw=="], + "path-scurry/lru-cache": ["lru-cache@11.2.4", "", {}, "sha512-B5Y16Jr9LB9dHVkh6ZevG+vAbOsNOYCX+sXvFWFu7B3Iz5mijW3zdbMyhsh8ANd2mSWBYdJgnqi+mL7/LrOPYg=="], "postcss-css-variables/escape-string-regexp": ["escape-string-regexp@1.0.5", "", {}, "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg=="], "postcss-load-config/lilconfig": ["lilconfig@3.1.3", "", {}, "sha512-/vlFKAoH5Cgt3Ie+JLhRbwOsCQePABiU3tJ1egGvyQ+33R/vcwM2Zl2QR/LzjsBeItPt3oSVXapn+m4nQDvpzw=="], + "postcss-load-config/yaml": ["yaml@2.8.1", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw=="], + "pretty-format/react-is": ["react-is@18.3.1", "", {}, "sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg=="], "prop-types/react-is": ["react-is@16.13.1", "", {}, "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ=="], @@ -2442,6 +2454,8 @@ "readable-web-to-node-stream/readable-stream": ["readable-stream@4.7.0", "", { "dependencies": { "abort-controller": "^3.0.0", "buffer": "^6.0.3", "events": "^3.3.0", "process": "^0.11.10", "string_decoder": "^1.3.0" } }, "sha512-oIGGmcpTLwPga8Bn6/Z75SVaH1z5dUut2ibSyAMVhmUggWpmDn2dapB0n7f8nwaSiRtepAsfJyfXIO5DCVAODg=="], + "readdirp/picomatch": ["picomatch@2.3.1", "", {}, "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA=="], + "requireg/resolve": ["resolve@1.7.1", "", { "dependencies": { "path-parse": "^1.0.5" } }, "sha512-c7rwLofp8g1U+h1KNyHL/jicrKg1Ek4q+Lr33AL65uZTinUZHe30D5HlyN5V9NW0JX1D5dXQ4jqW5l7Sy/kGfw=="], "send/debug": ["debug@2.6.9", "", { "dependencies": { "ms": "2.0.0" } }, "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA=="], @@ -2474,8 +2488,6 @@ "test-exclude/minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], - "tinyglobby/picomatch": ["picomatch@4.0.3", "", {}, "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q=="], - "whatwg-url/webidl-conversions": ["webidl-conversions@3.0.1", "", {}, "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ=="], "wrap-ansi/ansi-styles": ["ansi-styles@6.2.3", "", {}, "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg=="], @@ -2800,6 +2812,8 @@ "@react-native/community-cli-plugin/metro-config/metro-runtime": ["metro-runtime@0.83.2", "", { "dependencies": { "@babel/runtime": "^7.25.0", "flow-enums-runtime": "^0.0.6" } }, "sha512-nnsPtgRvFbNKwemqs0FuyFDzXLl+ezuFsUXDbX8o0SXOfsOPijqiQrf3kuafO1Zx1aUWf4NOrKJMAQP5EEHg9A=="], + "@react-native/community-cli-plugin/metro-config/yaml": ["yaml@2.8.1", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw=="], + "@react-native/community-cli-plugin/metro-core/metro-resolver": ["metro-resolver@0.83.2", "", { "dependencies": { "flow-enums-runtime": "^0.0.6" } }, "sha512-Yf5mjyuiRE/Y+KvqfsZxrbHDA15NZxyfg8pIk0qg47LfAJhpMVEX+36e6ZRBq7KVBqy6VDX5Sq55iHGM4xSm7Q=="], "@react-navigation/bottom-tabs/color/color-convert": ["color-convert@2.0.1", "", { "dependencies": { "color-name": "~1.1.4" } }, "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ=="], diff --git a/package.json b/package.json index f0adf6e0..2fd86ee2 100644 --- a/package.json +++ b/package.json @@ -126,7 +126,7 @@ "cross-env": "10.1.0", "expo-doctor": "1.18.22", "husky": "9.1.7", - "lint-staged": "16.2.7", + "lint-staged": "16.4.0", "react-test-renderer": "19.2.3", "typescript": "5.9.3" }, From c7cd8217c943e385374e997c1ffc870067c0dd3e Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 23:03:35 +0200 Subject: [PATCH 34/39] chore(deps): Update dependency react-i18next to v16.5.8 (#1500) --- bun.lock | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/bun.lock b/bun.lock index b66f5dee..17d53fb3 100644 --- a/bun.lock +++ b/bun.lock @@ -57,7 +57,7 @@ "patch-package": "^8.0.0", "react": "19.1.0", "react-dom": "19.1.0", - "react-i18next": "16.5.4", + "react-i18next": "16.5.8", "react-native": "0.81.5", "react-native-awesome-slider": "^2.9.0", "react-native-bottom-tabs": "1.1.0", @@ -1636,7 +1636,7 @@ "react-freeze": ["react-freeze@1.0.4", "", { "peerDependencies": { "react": ">=17.0.0" } }, "sha512-r4F0Sec0BLxWicc7HEyo2x3/2icUTrRmDjaaRyzzn+7aDyFZliszMDOgLVwSnQnYENOlL1o569Ze2HZefk8clA=="], - "react-i18next": ["react-i18next@16.5.4", "", { "dependencies": { "@babel/runtime": "^7.28.4", "html-parse-stringify": "^3.0.1", "use-sync-external-store": "^1.6.0" }, "peerDependencies": { "i18next": ">= 25.6.2", "react": ">= 16.8.0", "typescript": "^5" }, "optionalPeers": ["typescript"] }, "sha512-6yj+dcfMncEC21QPhOTsW8mOSO+pzFmT6uvU7XXdvM/Cp38zJkmTeMeKmTrmCMD5ToT79FmiE/mRWiYWcJYW4g=="], + "react-i18next": ["react-i18next@16.5.8", "", { "dependencies": { "@babel/runtime": "^7.28.4", "html-parse-stringify": "^3.0.1", "use-sync-external-store": "^1.6.0" }, "peerDependencies": { "i18next": ">= 25.6.2", "react": ">= 16.8.0", "react-dom": "*", "react-native": "*", "typescript": "^5" }, "optionalPeers": ["react-dom", "react-native", "typescript"] }, "sha512-2ABeHHlakxVY+LSirD+OiERxFL6+zip0PaHo979bgwzeHg27Sqc82xxXWIrSFmfWX0ZkrvXMHwhsi/NGUf5VQg=="], "react-is": ["react-is@19.2.3", "", {}, "sha512-qJNJfu81ByyabuG7hPFEbXqNcWSU3+eVus+KJs+0ncpGfMyYdvSmxiJxbWR65lYi1I+/0HBcliO029gc4F+PnA=="], diff --git a/package.json b/package.json index 2fd86ee2..09324760 100644 --- a/package.json +++ b/package.json @@ -77,7 +77,7 @@ "patch-package": "^8.0.0", "react": "19.1.0", "react-dom": "19.1.0", - "react-i18next": "16.5.4", + "react-i18next": "16.5.8", "react-native": "0.81.5", "react-native-awesome-slider": "^2.9.0", "react-native-bottom-tabs": "1.1.0", From 8bb0d845a238595553344071953523d6a79bc368 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Wed, 20 May 2026 23:29:39 +0200 Subject: [PATCH 35/39] chore(deps): Update dependency lint-staged to v17 (#1570) --- bun.lock | 52 ++++++++++++++++++++++++++++++++++------------------ package.json | 2 +- 2 files changed, 35 insertions(+), 19 deletions(-) diff --git a/bun.lock b/bun.lock index 17d53fb3..c81a4a33 100644 --- a/bun.lock +++ b/bun.lock @@ -106,7 +106,7 @@ "cross-env": "10.1.0", "expo-doctor": "1.18.22", "husky": "9.1.7", - "lint-staged": "16.4.0", + "lint-staged": "17.0.5", "react-test-renderer": "19.2.3", "typescript": "5.9.3", }, @@ -828,7 +828,7 @@ "cli-spinners": ["cli-spinners@2.9.2", "", {}, "sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg=="], - "cli-truncate": ["cli-truncate@5.1.1", "", { "dependencies": { "slice-ansi": "^7.1.0", "string-width": "^8.0.0" } }, "sha512-SroPvNHxUnk+vIW/dOSfNqdy1sPEFkrTk6TUtqLCnBlo3N7TNYYkzzN7uSD6+jVjrdO4+p8nH7JzH6cIvUem6A=="], + "cli-truncate": ["cli-truncate@5.2.0", "", { "dependencies": { "slice-ansi": "^8.0.0", "string-width": "^8.2.0" } }, "sha512-xRwvIOMGrfOAnM1JYtqQImuaNtDEv9v6oIYAs4LIHwTiKee8uwvIi363igssOC0O5U04i4AlENs79LQLu9tEMw=="], "client-only": ["client-only@0.0.1", "", {}, "sha512-IV3Ou0jSMzZrd3pZ48nLkT9DA7Ag1pnPzaiQhpW7c3RbcqqzvzzVu+L8gfqMp/8IM2MQtSiqaCxrrcfu8I8rMA=="], @@ -844,7 +844,7 @@ "color-string": ["color-string@2.1.2", "", { "dependencies": { "color-name": "^2.0.0" } }, "sha512-RxmjYxbWemV9gKu4zPgiZagUxbH3RQpEIO77XoSSX0ivgABDZ+h8Zuash/EMFLTI4N9QgFPOJ6JQpPZKFxa+dA=="], - "colorette": ["colorette@2.0.20", "", {}, "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w=="], + "colorette": ["colorette@1.4.0", "", {}, "sha512-Y2oEozpomLn7Q3HFP7dpww7AtMJplbM9lGZP6RDfHqmbeRjiwRg4n6VM6j4KLmRke85uWEI7JqF17f3pqdRA0g=="], "combined-stream": ["combined-stream@1.0.8", "", { "dependencies": { "delayed-stream": "~1.0.0" } }, "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg=="], @@ -990,7 +990,7 @@ "event-target-shim": ["event-target-shim@5.0.1", "", {}, "sha512-i/2XbnSz/uxRCU6+NdVJgKWDTM427+MqYbkQzD321DuCQJUqOuJKIA0IM2+W2xtYHdKOmZ4dR6fExsd4SXL+WQ=="], - "eventemitter3": ["eventemitter3@5.0.1", "", {}, "sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA=="], + "eventemitter3": ["eventemitter3@5.0.4", "", {}, "sha512-mlsTRyGaPBjPedk6Bvw+aqbsXDtoAyAzm5MO7JgU+yVRyMQ5O8bD4Kcci7BS85f93veegeCPkL8R4GLClnjLFw=="], "events": ["events@3.3.0", "", {}, "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q=="], @@ -1148,7 +1148,7 @@ "get-caller-file": ["get-caller-file@2.0.5", "", {}, "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg=="], - "get-east-asian-width": ["get-east-asian-width@1.4.0", "", {}, "sha512-QZjmEOC+IT1uk6Rx0sX22V6uHWVwbdbxf1faPqJ1QhLdGgsRGCZoyaQBm/piRdJy/D2um6hM1UP7ZEeQ4EkP+Q=="], + "get-east-asian-width": ["get-east-asian-width@1.6.0", "", {}, "sha512-QRbvDIbx6YklUe6RxeTeleMR0yv3cYH6PsPZHcnVn7xv7zO1BHN8r0XETu8n6Ye3Q+ahtSarc3WgtNWmehIBfA=="], "get-intrinsic": ["get-intrinsic@1.3.0", "", { "dependencies": { "call-bind-apply-helpers": "^1.0.2", "es-define-property": "^1.0.1", "es-errors": "^1.3.0", "es-object-atoms": "^1.1.1", "function-bind": "^1.1.2", "get-proto": "^1.0.1", "gopd": "^1.2.0", "has-symbols": "^1.1.0", "hasown": "^2.0.2", "math-intrinsics": "^1.1.0" } }, "sha512-9fSjSaos/fRIVIp+xSJlE6lfwhES7LNtKaCBIamHsjr2na1BiABJPo0mOjjz8GJDURarmCPGqaiVg5mfjb98CQ=="], @@ -1370,9 +1370,9 @@ "lines-and-columns": ["lines-and-columns@1.2.4", "", {}, "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg=="], - "lint-staged": ["lint-staged@16.4.0", "", { "dependencies": { "commander": "^14.0.3", "listr2": "^9.0.5", "picomatch": "^4.0.3", "string-argv": "^0.3.2", "tinyexec": "^1.0.4", "yaml": "^2.8.2" }, "bin": { "lint-staged": "bin/lint-staged.js" } }, "sha512-lBWt8hujh/Cjysw5GYVmZpFHXDCgZzhrOm8vbcUdobADZNOK/bRshr2kM3DfgrrtR1DQhfupW9gnIXOfiFi+bw=="], + "lint-staged": ["lint-staged@17.0.5", "", { "dependencies": { "listr2": "^10.2.1", "picomatch": "^4.0.4", "string-argv": "^0.3.2", "tinyexec": "^1.1.2" }, "optionalDependencies": { "yaml": "^2.8.4" }, "bin": { "lint-staged": "bin/lint-staged.js" } }, "sha512-d12yC+/e8RhBjZtaxZn71FyrgU/P5e+uAPifhCLwdosQZP/zamSdKRWDC30ocVIbzDKiFG1McHc/LUgB92GIPw=="], - "listr2": ["listr2@9.0.5", "", { "dependencies": { "cli-truncate": "^5.0.0", "colorette": "^2.0.20", "eventemitter3": "^5.0.1", "log-update": "^6.1.0", "rfdc": "^1.4.1", "wrap-ansi": "^9.0.0" } }, "sha512-ME4Fb83LgEgwNw96RKNvKV4VTLuXfoKudAmm2lP8Kk87KaMK0/Xrx/aAkMWmT8mDb+3MlFDspfbCs7adjRxA2g=="], + "listr2": ["listr2@10.2.1", "", { "dependencies": { "cli-truncate": "^5.2.0", "eventemitter3": "^5.0.4", "log-update": "^6.1.0", "rfdc": "^1.4.1", "wrap-ansi": "^10.0.0" } }, "sha512-7I5knELsJKTUjXG+A6BkKAiGkW1i25fNa/xlUl9hFtk15WbE9jndA89xu5FzQKrY5llajE1hfZZFMILXkDHk/Q=="], "locate-path": ["locate-path@6.0.0", "", { "dependencies": { "p-locate": "^5.0.0" } }, "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw=="], @@ -1556,7 +1556,7 @@ "picocolors": ["picocolors@1.1.1", "", {}, "sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA=="], - "picomatch": ["picomatch@4.0.3", "", {}, "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q=="], + "picomatch": ["picomatch@4.0.4", "", {}, "sha512-QP88BAKvMam/3NxH6vj2o21R6MjxZUAd6nlwAS/pnGvN9IVLocLHxGYIzFhg6fUQ+5th6P4dv4eW9jX3DSIj7A=="], "pify": ["pify@2.3.0", "", {}, "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog=="], @@ -1822,7 +1822,7 @@ "slash": ["slash@2.0.0", "", {}, "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A=="], - "slice-ansi": ["slice-ansi@7.1.2", "", { "dependencies": { "ansi-styles": "^6.2.1", "is-fullwidth-code-point": "^5.0.0" } }, "sha512-iOBWFgUX7caIZiuutICxVgX1SdxwAVFFKwt1EvMYYec/NWO5meOJ6K5uQxhrYBdQJne4KxiqZc+KptFOWFSI9w=="], + "slice-ansi": ["slice-ansi@8.0.0", "", { "dependencies": { "ansi-styles": "^6.2.3", "is-fullwidth-code-point": "^5.1.0" } }, "sha512-stxByr12oeeOyY2BlviTNQlYV5xOj47GirPr4yA1hE9JCtxfQN0+tVbkxwCtYDQWhEKWFHsEK48ORg5jrouCAg=="], "slugify": ["slugify@1.6.6", "", {}, "sha512-h+z7HKHYXj6wJU+AnS/+IH8Uh9fdcX1Lrhg1/VMdf9PwoBQXFcXiAdsy2tSK0P6gKwJLXp02r90ahUCqHk9rrw=="], @@ -2012,7 +2012,7 @@ "wonka": ["wonka@6.3.5", "", {}, "sha512-SSil+ecw6B4/Dm7Pf2sAshKQ5hWFvfyGlfPbEd6A14dOH6VDjrmbY86u6nZvy9omGwwIPFR8V41+of1EezgoUw=="], - "wrap-ansi": ["wrap-ansi@9.0.2", "", { "dependencies": { "ansi-styles": "^6.2.1", "string-width": "^7.0.0", "strip-ansi": "^7.1.0" } }, "sha512-42AtmgqjV+X1VpdOfyTGOYRi0/zsoLqtXQckTmqTeybT+BDIbM/Guxo7x3pE2vtpr1ok6xRqM9OpBe+Jyoqyww=="], + "wrap-ansi": ["wrap-ansi@10.0.0", "", { "dependencies": { "ansi-styles": "^6.2.3", "string-width": "^8.2.0", "strip-ansi": "^7.1.2" } }, "sha512-SGcvg80f0wUy2/fXES19feHMz8E0JoXv2uNgHOu4Dgi2OrCy1lqwFYEJz1BLbDI0exjPMe/ZdzZ/YpGECBG/aQ=="], "wrap-ansi-cjs": ["wrap-ansi@7.0.0", "", { "dependencies": { "ansi-styles": "^4.0.0", "string-width": "^4.1.0", "strip-ansi": "^6.0.0" } }, "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q=="], @@ -2260,8 +2260,6 @@ "accepts/negotiator": ["negotiator@0.6.3", "", {}, "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg=="], - "ansi-fragments/colorette": ["colorette@1.4.0", "", {}, "sha512-Y2oEozpomLn7Q3HFP7dpww7AtMJplbM9lGZP6RDfHqmbeRjiwRg4n6VM6j4KLmRke85uWEI7JqF17f3pqdRA0g=="], - "ansi-fragments/slice-ansi": ["slice-ansi@2.1.0", "", { "dependencies": { "ansi-styles": "^3.2.0", "astral-regex": "^1.0.0", "is-fullwidth-code-point": "^2.0.0" } }, "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ=="], "ansi-fragments/strip-ansi": ["strip-ansi@5.2.0", "", { "dependencies": { "ansi-regex": "^4.1.0" } }, "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA=="], @@ -2288,7 +2286,7 @@ "chokidar/glob-parent": ["glob-parent@5.1.2", "", { "dependencies": { "is-glob": "^4.0.1" } }, "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow=="], - "cli-truncate/string-width": ["string-width@8.1.0", "", { "dependencies": { "get-east-asian-width": "^1.3.0", "strip-ansi": "^7.1.0" } }, "sha512-Kxl3KJGb/gxkaUMOjRsQ8IrXiGW75O4E3RPjFIINOVH8AMl2SQ/yWdTzWwF3FevIX9LcMAjJW+GRwAlAbTSXdg=="], + "cli-truncate/string-width": ["string-width@8.2.1", "", { "dependencies": { "get-east-asian-width": "^1.5.0", "strip-ansi": "^7.1.2" } }, "sha512-IIaP0g3iy9Cyy18w3M9YcaDudujEAVHKt3a3QJg1+sr/oX96TbaGUubG0hJyCjCBThFH+tFpcIyoUHUn1ogaLA=="], "cliui/wrap-ansi": ["wrap-ansi@7.0.0", "", { "dependencies": { "ansi-styles": "^4.0.0", "string-width": "^4.1.0", "strip-ansi": "^6.0.0" } }, "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q=="], @@ -2348,12 +2346,14 @@ "lighthouse-logger/debug": ["debug@2.6.9", "", { "dependencies": { "ms": "2.0.0" } }, "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA=="], - "lint-staged/commander": ["commander@14.0.3", "", {}, "sha512-H+y0Jo/T1RZ9qPP4Eh1pkcQcLRglraJaSLoyOtHxu6AapkjWVCy2Sit1QQ4x3Dng8qDlSsZEet7g5Pq06MvTgw=="], - "log-update/cli-cursor": ["cli-cursor@5.0.0", "", { "dependencies": { "restore-cursor": "^5.0.0" } }, "sha512-aCj4O5wKyszjMmDT4tZj93kxyydN/K5zPWSCe6/0AV/AA1pqe5ZBIw0a2ZfPQV7lL5/yb5HsUreJ6UFAF1tEQw=="], + "log-update/slice-ansi": ["slice-ansi@7.1.2", "", { "dependencies": { "ansi-styles": "^6.2.1", "is-fullwidth-code-point": "^5.0.0" } }, "sha512-iOBWFgUX7caIZiuutICxVgX1SdxwAVFFKwt1EvMYYec/NWO5meOJ6K5uQxhrYBdQJne4KxiqZc+KptFOWFSI9w=="], + "log-update/strip-ansi": ["strip-ansi@7.1.2", "", { "dependencies": { "ansi-regex": "^6.0.1" } }, "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA=="], + "log-update/wrap-ansi": ["wrap-ansi@9.0.2", "", { "dependencies": { "ansi-styles": "^6.2.1", "string-width": "^7.0.0", "strip-ansi": "^7.1.0" } }, "sha512-42AtmgqjV+X1VpdOfyTGOYRi0/zsoLqtXQckTmqTeybT+BDIbM/Guxo7x3pE2vtpr1ok6xRqM9OpBe+Jyoqyww=="], + "logkitty/yargs": ["yargs@15.4.1", "", { "dependencies": { "cliui": "^6.0.0", "decamelize": "^1.2.0", "find-up": "^4.1.0", "get-caller-file": "^2.0.1", "require-directory": "^2.1.1", "require-main-filename": "^2.0.0", "set-blocking": "^2.0.0", "string-width": "^4.2.0", "which-module": "^2.0.0", "y18n": "^4.0.0", "yargs-parser": "^18.1.2" } }, "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A=="], "metro/@babel/code-frame": ["@babel/code-frame@7.27.1", "", { "dependencies": { "@babel/helper-validator-identifier": "^7.27.1", "js-tokens": "^4.0.0", "picocolors": "^1.1.1" } }, "sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg=="], @@ -2488,11 +2488,13 @@ "test-exclude/minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], + "tinyglobby/picomatch": ["picomatch@4.0.3", "", {}, "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q=="], + "whatwg-url/webidl-conversions": ["webidl-conversions@3.0.1", "", {}, "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ=="], "wrap-ansi/ansi-styles": ["ansi-styles@6.2.3", "", {}, "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg=="], - "wrap-ansi/string-width": ["string-width@7.2.0", "", { "dependencies": { "emoji-regex": "^10.3.0", "get-east-asian-width": "^1.0.0", "strip-ansi": "^7.1.0" } }, "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ=="], + "wrap-ansi/string-width": ["string-width@8.2.1", "", { "dependencies": { "get-east-asian-width": "^1.5.0", "strip-ansi": "^7.1.2" } }, "sha512-IIaP0g3iy9Cyy18w3M9YcaDudujEAVHKt3a3QJg1+sr/oX96TbaGUubG0hJyCjCBThFH+tFpcIyoUHUn1ogaLA=="], "wrap-ansi/strip-ansi": ["strip-ansi@7.1.2", "", { "dependencies": { "ansi-regex": "^6.0.1" } }, "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA=="], @@ -2898,8 +2900,16 @@ "log-update/cli-cursor/restore-cursor": ["restore-cursor@5.1.0", "", { "dependencies": { "onetime": "^7.0.0", "signal-exit": "^4.1.0" } }, "sha512-oMA2dcrw6u0YfxJQXm342bFKX/E4sG9rbTzO9ptUcR/e8A33cHuvStiYOwH7fszkZlZ1z/ta9AAoPk2F4qIOHA=="], + "log-update/slice-ansi/ansi-styles": ["ansi-styles@6.2.3", "", {}, "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg=="], + + "log-update/slice-ansi/is-fullwidth-code-point": ["is-fullwidth-code-point@5.1.0", "", { "dependencies": { "get-east-asian-width": "^1.3.1" } }, "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ=="], + "log-update/strip-ansi/ansi-regex": ["ansi-regex@6.2.2", "", {}, "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg=="], + "log-update/wrap-ansi/ansi-styles": ["ansi-styles@6.2.3", "", {}, "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg=="], + + "log-update/wrap-ansi/string-width": ["string-width@7.2.0", "", { "dependencies": { "emoji-regex": "^10.3.0", "get-east-asian-width": "^1.0.0", "strip-ansi": "^7.1.0" } }, "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ=="], + "logkitty/yargs/cliui": ["cliui@6.0.0", "", { "dependencies": { "string-width": "^4.2.0", "strip-ansi": "^6.0.0", "wrap-ansi": "^6.2.0" } }, "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ=="], "logkitty/yargs/find-up": ["find-up@4.1.0", "", { "dependencies": { "locate-path": "^5.0.0", "path-exists": "^4.0.0" } }, "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw=="], @@ -3004,6 +3014,8 @@ "serve-static/send/mime": ["mime@1.6.0", "", { "bin": { "mime": "cli.js" } }, "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="], + "slice-ansi/is-fullwidth-code-point/get-east-asian-width": ["get-east-asian-width@1.4.0", "", {}, "sha512-QZjmEOC+IT1uk6Rx0sX22V6uHWVwbdbxf1faPqJ1QhLdGgsRGCZoyaQBm/piRdJy/D2um6hM1UP7ZEeQ4EkP+Q=="], + "sucrase/glob/path-scurry": ["path-scurry@1.11.1", "", { "dependencies": { "lru-cache": "^10.2.0", "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" } }, "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA=="], "terminal-link/ansi-escapes/type-fest": ["type-fest@0.21.3", "", {}, "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w=="], @@ -3012,8 +3024,6 @@ "wrap-ansi-cjs/ansi-styles/color-convert": ["color-convert@2.0.1", "", { "dependencies": { "color-name": "~1.1.4" } }, "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ=="], - "wrap-ansi/string-width/emoji-regex": ["emoji-regex@10.6.0", "", {}, "sha512-toUI84YS5YmxW219erniWD0CIVOo46xGKColeNQRgOzDorgBi1v4D71/OFzgD9GO2UGKIv1C3Sp8DAn0+j5w7A=="], - "wrap-ansi/strip-ansi/ansi-regex": ["ansi-regex@6.2.2", "", {}, "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg=="], "@babel/highlight/chalk/ansi-styles/color-convert": ["color-convert@1.9.3", "", { "dependencies": { "color-name": "1.1.3" } }, "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg=="], @@ -3156,6 +3166,12 @@ "log-update/cli-cursor/restore-cursor/signal-exit": ["signal-exit@4.1.0", "", {}, "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw=="], + "log-update/slice-ansi/is-fullwidth-code-point/get-east-asian-width": ["get-east-asian-width@1.4.0", "", {}, "sha512-QZjmEOC+IT1uk6Rx0sX22V6uHWVwbdbxf1faPqJ1QhLdGgsRGCZoyaQBm/piRdJy/D2um6hM1UP7ZEeQ4EkP+Q=="], + + "log-update/wrap-ansi/string-width/emoji-regex": ["emoji-regex@10.6.0", "", {}, "sha512-toUI84YS5YmxW219erniWD0CIVOo46xGKColeNQRgOzDorgBi1v4D71/OFzgD9GO2UGKIv1C3Sp8DAn0+j5w7A=="], + + "log-update/wrap-ansi/string-width/get-east-asian-width": ["get-east-asian-width@1.4.0", "", {}, "sha512-QZjmEOC+IT1uk6Rx0sX22V6uHWVwbdbxf1faPqJ1QhLdGgsRGCZoyaQBm/piRdJy/D2um6hM1UP7ZEeQ4EkP+Q=="], + "logkitty/yargs/cliui/wrap-ansi": ["wrap-ansi@6.2.0", "", { "dependencies": { "ansi-styles": "^4.0.0", "string-width": "^4.1.0", "strip-ansi": "^6.0.0" } }, "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA=="], "logkitty/yargs/find-up/locate-path": ["locate-path@5.0.0", "", { "dependencies": { "p-locate": "^4.1.0" } }, "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g=="], diff --git a/package.json b/package.json index 09324760..9da99df8 100644 --- a/package.json +++ b/package.json @@ -126,7 +126,7 @@ "cross-env": "10.1.0", "expo-doctor": "1.18.22", "husky": "9.1.7", - "lint-staged": "16.4.0", + "lint-staged": "17.0.5", "react-test-renderer": "19.2.3", "typescript": "5.9.3" }, From f79cf1925daa600c7bc35f02f7e937554eb1ca0e Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Thu, 21 May 2026 00:18:29 +0200 Subject: [PATCH 36/39] chore(deps): Update dependency @react-native-tvos/config-tv to v0.1.6 (#1430) --- bun.lock | 78 +++++++++++++++++++++++++++++++++------------------- package.json | 2 +- 2 files changed, 51 insertions(+), 29 deletions(-) diff --git a/bun.lock b/bun.lock index c81a4a33..1e8c5c4d 100644 --- a/bun.lock +++ b/bun.lock @@ -98,7 +98,7 @@ "@babel/core": "7.28.6", "@biomejs/biome": "2.3.11", "@react-native-community/cli": "20.1.1", - "@react-native-tvos/config-tv": "0.1.4", + "@react-native-tvos/config-tv": "0.1.6", "@types/jest": "29.5.14", "@types/lodash": "4.17.23", "@types/react": "19.1.17", @@ -404,7 +404,7 @@ "@isaacs/brace-expansion": ["@isaacs/brace-expansion@5.0.0", "", { "dependencies": { "@isaacs/balanced-match": "^4.0.1" } }, "sha512-ZT55BDLV0yv0RBm2czMiZ+SqCGO7AvmOM3G/w2xhVPH+te0aKgFjmBvGlL1dH+ql2tgGO3MVrbb3jCKyvpgnxA=="], - "@isaacs/cliui": ["@isaacs/cliui@8.0.2", "", { "dependencies": { "string-width": "^5.1.2", "string-width-cjs": "npm:string-width@^4.2.0", "strip-ansi": "^7.0.1", "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", "wrap-ansi": "^8.1.0", "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" } }, "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA=="], + "@isaacs/cliui": ["@isaacs/cliui@9.0.0", "", {}, "sha512-AokJm4tuBHillT+FpMtxQ60n8ObyXBatq7jD2/JA9dxbDDokKQm8KMht5ibGzLVU9IJDIKK4TPKgMHEYMn3lMg=="], "@isaacs/fs-minipass": ["@isaacs/fs-minipass@4.0.1", "", { "dependencies": { "minipass": "^7.0.4" } }, "sha512-wgm9Ehl2jpeqP3zw/7mo3kRHFp5MEDhqAdwy1fTGkHAwnkGOVsgpvQhL8B5n1qlb01jV3n/bI0ZfZp5lWA1k4w=="], @@ -538,7 +538,7 @@ "@react-native-community/netinfo": ["@react-native-community/netinfo@11.4.1", "", { "peerDependencies": { "react-native": ">=0.59" } }, "sha512-B0BYAkghz3Q2V09BF88RA601XursIEA111tnc2JOaN7axJWmNefmfjZqw/KdSxKZp7CZUuPpjBmz/WCR9uaHYg=="], - "@react-native-tvos/config-tv": ["@react-native-tvos/config-tv@0.1.4", "", { "dependencies": { "getenv": "^1.0.0" }, "peerDependencies": { "expo": ">=52.0.0" } }, "sha512-xfVDqSFjEUsb+xcMk0hE2Z/M6QZH0QzAJOSQZwo7W/ZRaLrd+xFQnx0LaXqt3kxlR3P7wskKHByDP/FSoUZnbA=="], + "@react-native-tvos/config-tv": ["@react-native-tvos/config-tv@0.1.6", "", { "dependencies": { "getenv": "^1.0.0", "glob": "^11.0.0" }, "peerDependencies": { "expo": ">=52.0.0" } }, "sha512-VxMSIcro+U1EVb64pYShZsc+uE3HNGhfHppoUhTyGwx9ELQkhWvReRTOI4gpb/qeRWEcT+UbUc9Gd9Zlwm572w=="], "@react-native/assets-registry": ["@react-native/assets-registry@0.81.5", "", {}, "sha512-705B6x/5Kxm1RKRvSv0ADYWm5JOnoiQ1ufW7h8uu2E6G9Of/eE6hP/Ivw3U5jI16ERqZxiKQwk34VJbB0niX9w=="], @@ -1164,7 +1164,7 @@ "gifwrap": ["gifwrap@0.10.1", "", { "dependencies": { "image-q": "^4.0.0", "omggif": "^1.0.10" } }, "sha512-2760b1vpJHNmLzZ/ubTtNnEx5WApN/PYWJvXvgS+tL1egTTthayFYIQQNi136FLEDcN/IyEY2EcGpIITD6eYUw=="], - "glob": ["glob@7.2.3", "", { "dependencies": { "fs.realpath": "^1.0.0", "inflight": "^1.0.4", "inherits": "2", "minimatch": "^3.1.1", "once": "^1.3.0", "path-is-absolute": "^1.0.0" } }, "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q=="], + "glob": ["glob@11.1.0", "", { "dependencies": { "foreground-child": "^3.3.1", "jackspeak": "^4.1.1", "minimatch": "^10.1.1", "minipass": "^7.1.2", "package-json-from-dist": "^1.0.0", "path-scurry": "^2.0.0" }, "bin": { "glob": "dist/esm/bin.mjs" } }, "sha512-vuNwKSaKiqm7g0THUBu2x7ckSs3XJLXE+2ssL7/MfTGPLLcrJQ/4Uq1CjPTtO5cCIiRxqvN6Twy1qOwhL0Xjcw=="], "glob-parent": ["glob-parent@6.0.2", "", { "dependencies": { "is-glob": "^4.0.3" } }, "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A=="], @@ -1276,7 +1276,7 @@ "istanbul-lib-instrument": ["istanbul-lib-instrument@5.2.1", "", { "dependencies": { "@babel/core": "^7.12.3", "@babel/parser": "^7.14.7", "@istanbuljs/schema": "^0.1.2", "istanbul-lib-coverage": "^3.2.0", "semver": "^6.3.0" } }, "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg=="], - "jackspeak": ["jackspeak@3.4.3", "", { "dependencies": { "@isaacs/cliui": "^8.0.2" }, "optionalDependencies": { "@pkgjs/parseargs": "^0.11.0" } }, "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw=="], + "jackspeak": ["jackspeak@4.2.3", "", { "dependencies": { "@isaacs/cliui": "^9.0.0" } }, "sha512-ykkVRwrYvFm1nb2AJfKKYPr0emF6IiXDYUaFx4Zn9ZuIH7MrzEZ3sD5RlqGXNRpHtvUHJyOnCEFxOlNDtGo7wg=="], "jest-diff": ["jest-diff@29.7.0", "", { "dependencies": { "chalk": "^4.0.0", "diff-sequences": "^29.6.3", "jest-get-type": "^29.6.3", "pretty-format": "^29.7.0" } }, "sha512-LMIgiIrhigmPrs03JHpxUh2yISK3vLFPkAodPeo0+BuF7wA2FoQbkEg1u8gBYBThncu7e1oEDUfIXVuTqLRUjw=="], @@ -1448,7 +1448,7 @@ "mimic-function": ["mimic-function@5.0.1", "", {}, "sha512-VP79XUPxV2CigYP3jWwAUFSku2aKqBH7uTAapFWCBqutsbmDo96KY5o8uh6U+/YSIn5OxJnXp73beVkpqMIGhA=="], - "minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], + "minimatch": ["minimatch@10.1.1", "", { "dependencies": { "@isaacs/brace-expansion": "^5.0.0" } }, "sha512-enIvLvRAFZYXJzkCYG5RKmPfrFArdLv+R+lbQ53BmIMLIry74bjKzX6iHAm8WYamJkhSSEabrWN5D97XnKObjQ=="], "minimist": ["minimist@1.2.8", "", {}, "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA=="], @@ -2116,6 +2116,8 @@ "@expo/cli/glob": ["glob@13.0.0", "", { "dependencies": { "minimatch": "^10.1.1", "minipass": "^7.1.2", "path-scurry": "^2.0.0" } }, "sha512-tvZgpqk6fz4BaNZ66ZsRaZnbHvP/jG3uKJvAZOwEVUL4RTA5nJeeLYfyN9/VA8NX/V3IBG+hkeuGpKjvELkVhA=="], + "@expo/cli/minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], + "@expo/cli/ora": ["ora@3.4.0", "", { "dependencies": { "chalk": "^2.4.2", "cli-cursor": "^2.1.0", "cli-spinners": "^2.0.0", "log-symbols": "^2.2.0", "strip-ansi": "^5.2.0", "wcwidth": "^1.0.1" } }, "sha512-eNwHudNbO1folBP3JsZ19v9azXWtQZjICdr3Q0TDPIaeBQ3mXLrh54wM+er0+hSp+dWKf+Z8KM58CYzEyIYxYg=="], "@expo/cli/picomatch": ["picomatch@3.0.1", "", {}, "sha512-I3EurrIQMlRc9IaAZnqRR044Phh2DXY+55o7uJ0V+hYZAcQYSuFWsc9q5PvyDHUSCe1Qxn/iBz+78s86zWnGag=="], @@ -2152,6 +2154,8 @@ "@expo/fingerprint/glob": ["glob@13.0.0", "", { "dependencies": { "minimatch": "^10.1.1", "minipass": "^7.1.2", "path-scurry": "^2.0.0" } }, "sha512-tvZgpqk6fz4BaNZ66ZsRaZnbHvP/jG3uKJvAZOwEVUL4RTA5nJeeLYfyN9/VA8NX/V3IBG+hkeuGpKjvELkVhA=="], + "@expo/fingerprint/minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], + "@expo/fingerprint/semver": ["semver@7.7.2", "", { "bin": { "semver": "bin/semver.js" } }, "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA=="], "@expo/image-utils/getenv": ["getenv@2.0.0", "", {}, "sha512-VilgtJj/ALgGY77fiLam5iD336eSWi96Q15JSAG1zi8NRBysm3LXKdGnHb4m5cuyxvOLQQKWpBZAT6ni4FI2iQ=="], @@ -2170,6 +2174,8 @@ "@expo/metro-config/glob": ["glob@13.0.0", "", { "dependencies": { "minimatch": "^10.1.1", "minipass": "^7.1.2", "path-scurry": "^2.0.0" } }, "sha512-tvZgpqk6fz4BaNZ66ZsRaZnbHvP/jG3uKJvAZOwEVUL4RTA5nJeeLYfyN9/VA8NX/V3IBG+hkeuGpKjvELkVhA=="], + "@expo/metro-config/minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], + "@expo/metro-config/postcss": ["postcss@8.4.49", "", { "dependencies": { "nanoid": "^3.3.7", "picocolors": "^1.1.1", "source-map-js": "^1.2.1" } }, "sha512-OCVPnIObs4N29kxTjzLfUryOkvZEq+pf8jTF0lg8E7uETuWHA+v7j3c/xJmiqpX450191LlmZfUKkXxkTry7nA=="], "@expo/package-manager/ora": ["ora@3.4.0", "", { "dependencies": { "chalk": "^2.4.2", "cli-cursor": "^2.1.0", "cli-spinners": "^2.0.0", "log-symbols": "^2.2.0", "strip-ansi": "^5.2.0", "wcwidth": "^1.0.1" } }, "sha512-eNwHudNbO1folBP3JsZ19v9azXWtQZjICdr3Q0TDPIaeBQ3mXLrh54wM+er0+hSp+dWKf+Z8KM58CYzEyIYxYg=="], @@ -2178,12 +2184,6 @@ "@expo/xcpretty/@babel/code-frame": ["@babel/code-frame@7.10.4", "", { "dependencies": { "@babel/highlight": "^7.10.4" } }, "sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg=="], - "@isaacs/cliui/string-width": ["string-width@5.1.2", "", { "dependencies": { "eastasianwidth": "^0.2.0", "emoji-regex": "^9.2.2", "strip-ansi": "^7.0.1" } }, "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA=="], - - "@isaacs/cliui/strip-ansi": ["strip-ansi@7.1.2", "", { "dependencies": { "ansi-regex": "^6.0.1" } }, "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA=="], - - "@isaacs/cliui/wrap-ansi": ["wrap-ansi@8.1.0", "", { "dependencies": { "ansi-styles": "^6.1.0", "string-width": "^5.0.1", "strip-ansi": "^7.0.1" } }, "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ=="], - "@istanbuljs/load-nyc-config/camelcase": ["camelcase@5.3.1", "", {}, "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg=="], "@istanbuljs/load-nyc-config/find-up": ["find-up@4.1.0", "", { "dependencies": { "locate-path": "^5.0.0", "path-exists": "^4.0.0" } }, "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw=="], @@ -2222,6 +2222,8 @@ "@react-native/codegen/@babel/parser": ["@babel/parser@7.28.5", "", { "dependencies": { "@babel/types": "^7.28.5" }, "bin": "./bin/babel-parser.js" }, "sha512-KKBU1VGYR7ORr3At5HAtUQ+TV3SzRCXmA/8OdDZiLDBIZxVyzXuztPjfLd3BV1PRAQGCMWWSHYhL0F8d5uHBDQ=="], + "@react-native/codegen/glob": ["glob@7.2.3", "", { "dependencies": { "fs.realpath": "^1.0.0", "inflight": "^1.0.4", "inherits": "2", "minimatch": "^3.1.1", "once": "^1.3.0", "path-is-absolute": "^1.0.0" } }, "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q=="], + "@react-native/community-cli-plugin/metro": ["metro@0.83.2", "", { "dependencies": { "@babel/code-frame": "^7.24.7", "@babel/core": "^7.25.2", "@babel/generator": "^7.25.0", "@babel/parser": "^7.25.3", "@babel/template": "^7.25.0", "@babel/traverse": "^7.25.3", "@babel/types": "^7.25.2", "accepts": "^1.3.7", "chalk": "^4.0.0", "ci-info": "^2.0.0", "connect": "^3.6.5", "debug": "^4.4.0", "error-stack-parser": "^2.0.6", "flow-enums-runtime": "^0.0.6", "graceful-fs": "^4.2.4", "hermes-parser": "0.32.0", "image-size": "^1.0.2", "invariant": "^2.2.4", "jest-worker": "^29.7.0", "jsc-safe-url": "^0.2.2", "lodash.throttle": "^4.1.1", "metro-babel-transformer": "0.83.2", "metro-cache": "0.83.2", "metro-cache-key": "0.83.2", "metro-config": "0.83.2", "metro-core": "0.83.2", "metro-file-map": "0.83.2", "metro-resolver": "0.83.2", "metro-runtime": "0.83.2", "metro-source-map": "0.83.2", "metro-symbolicate": "0.83.2", "metro-transform-plugins": "0.83.2", "metro-transform-worker": "0.83.2", "mime-types": "^2.1.27", "nullthrows": "^1.1.1", "serialize-error": "^2.1.0", "source-map": "^0.5.6", "throat": "^5.0.0", "ws": "^7.5.10", "yargs": "^17.6.2" }, "bin": { "metro": "src/cli.js" } }, "sha512-HQgs9H1FyVbRptNSMy/ImchTTE5vS2MSqLoOo7hbDoBq6hPPZokwJvBMwrYSxdjQZmLXz2JFZtdvS+ZfgTc9yw=="], "@react-native/community-cli-plugin/metro-config": ["metro-config@0.83.2", "", { "dependencies": { "connect": "^3.6.5", "flow-enums-runtime": "^0.0.6", "jest-validate": "^29.7.0", "metro": "0.83.2", "metro-cache": "0.83.2", "metro-core": "0.83.2", "metro-runtime": "0.83.2", "yaml": "^2.6.1" } }, "sha512-1FjCcdBe3e3D08gSSiU9u3Vtxd7alGH3x/DNFqWDFf5NouX4kLgbVloDDClr1UrLz62c0fHh2Vfr9ecmrOZp+g=="], @@ -2322,8 +2324,6 @@ "foreground-child/signal-exit": ["signal-exit@4.1.0", "", {}, "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw=="], - "glob/minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], - "hoist-non-react-statics/react-is": ["react-is@16.13.1", "", {}, "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ=="], "hosted-git-info/lru-cache": ["lru-cache@10.4.3", "", {}, "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ=="], @@ -2440,6 +2440,8 @@ "react-native/commander": ["commander@12.1.0", "", {}, "sha512-Vw8qHK3bZM9y/P10u3Vib8o/DdkvA2OtPtZvD871QKjy74Wj1WSKFILMPRPSdUSx5RFK1arlJzEtA4PkFgnbuA=="], + "react-native/glob": ["glob@7.2.3", "", { "dependencies": { "fs.realpath": "^1.0.0", "inflight": "^1.0.4", "inherits": "2", "minimatch": "^3.1.1", "once": "^1.3.0", "path-is-absolute": "^1.0.0" } }, "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q=="], + "react-native/scheduler": ["scheduler@0.26.0", "", {}, "sha512-NlHwttCI/l5gCPR3D1nNXtWABUmBwvZpEQiD4IXSbIDq8BzLIK/7Ir5gTFSGZDUu37K5cMNp0hFtzO38sC7gWA=="], "react-native/semver": ["semver@7.7.2", "", { "bin": { "semver": "bin/semver.js" } }, "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA=="], @@ -2458,6 +2460,8 @@ "requireg/resolve": ["resolve@1.7.1", "", { "dependencies": { "path-parse": "^1.0.5" } }, "sha512-c7rwLofp8g1U+h1KNyHL/jicrKg1Ek4q+Lr33AL65uZTinUZHe30D5HlyN5V9NW0JX1D5dXQ4jqW5l7Sy/kGfw=="], + "rimraf/glob": ["glob@7.2.3", "", { "dependencies": { "fs.realpath": "^1.0.0", "inflight": "^1.0.4", "inherits": "2", "minimatch": "^3.1.1", "once": "^1.3.0", "path-is-absolute": "^1.0.0" } }, "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q=="], + "send/debug": ["debug@2.6.9", "", { "dependencies": { "ms": "2.0.0" } }, "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA=="], "send/mime": ["mime@1.6.0", "", { "bin": { "mime": "cli.js" } }, "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="], @@ -2486,6 +2490,8 @@ "terser/commander": ["commander@2.20.3", "", {}, "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ=="], + "test-exclude/glob": ["glob@7.2.3", "", { "dependencies": { "fs.realpath": "^1.0.0", "inflight": "^1.0.4", "inherits": "2", "minimatch": "^3.1.1", "once": "^1.3.0", "path-is-absolute": "^1.0.0" } }, "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q=="], + "test-exclude/minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], "tinyglobby/picomatch": ["picomatch@4.0.3", "", {}, "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q=="], @@ -2654,10 +2660,6 @@ "@expo/cli/wrap-ansi/ansi-styles": ["ansi-styles@4.3.0", "", { "dependencies": { "color-convert": "^2.0.1" } }, "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg=="], - "@expo/config-plugins/glob/minimatch": ["minimatch@10.1.1", "", { "dependencies": { "@isaacs/brace-expansion": "^5.0.0" } }, "sha512-enIvLvRAFZYXJzkCYG5RKmPfrFArdLv+R+lbQ53BmIMLIry74bjKzX6iHAm8WYamJkhSSEabrWN5D97XnKObjQ=="], - - "@expo/config/glob/minimatch": ["minimatch@10.1.1", "", { "dependencies": { "@isaacs/brace-expansion": "^5.0.0" } }, "sha512-enIvLvRAFZYXJzkCYG5RKmPfrFArdLv+R+lbQ53BmIMLIry74bjKzX6iHAm8WYamJkhSSEabrWN5D97XnKObjQ=="], - "@expo/config/sucrase/commander": ["commander@4.1.1", "", {}, "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA=="], "@expo/fingerprint/glob/minimatch": ["minimatch@10.1.1", "", { "dependencies": { "@isaacs/brace-expansion": "^5.0.0" } }, "sha512-enIvLvRAFZYXJzkCYG5RKmPfrFArdLv+R+lbQ53BmIMLIry74bjKzX6iHAm8WYamJkhSSEabrWN5D97XnKObjQ=="], @@ -2690,12 +2692,6 @@ "@expo/package-manager/ora/strip-ansi": ["strip-ansi@5.2.0", "", { "dependencies": { "ansi-regex": "^4.1.0" } }, "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA=="], - "@isaacs/cliui/string-width/emoji-regex": ["emoji-regex@9.2.2", "", {}, "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg=="], - - "@isaacs/cliui/strip-ansi/ansi-regex": ["ansi-regex@6.2.2", "", {}, "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg=="], - - "@isaacs/cliui/wrap-ansi/ansi-styles": ["ansi-styles@6.2.3", "", {}, "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg=="], - "@istanbuljs/load-nyc-config/find-up/locate-path": ["locate-path@5.0.0", "", { "dependencies": { "p-locate": "^4.1.0" } }, "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g=="], "@istanbuljs/load-nyc-config/js-yaml/argparse": ["argparse@1.0.10", "", { "dependencies": { "sprintf-js": "~1.0.2" } }, "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg=="], @@ -2770,6 +2766,8 @@ "@react-native/codegen/@babel/parser/@babel/types": ["@babel/types@7.28.5", "", { "dependencies": { "@babel/helper-string-parser": "^7.27.1", "@babel/helper-validator-identifier": "^7.28.5" } }, "sha512-qQ5m48eI/MFLQ5PxQj4PFaprjyCTLI37ElWMmNs0K8Lk3dVeOdNpB3ks8jc7yM5CDmVC73eMVk/trk3fgmrUpA=="], + "@react-native/codegen/glob/minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], + "@react-native/community-cli-plugin/metro/@babel/code-frame": ["@babel/code-frame@7.27.1", "", { "dependencies": { "@babel/helper-validator-identifier": "^7.27.1", "js-tokens": "^4.0.0", "picocolors": "^1.1.1" } }, "sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg=="], "@react-native/community-cli-plugin/metro/@babel/core": ["@babel/core@7.28.5", "", { "dependencies": { "@babel/code-frame": "^7.27.1", "@babel/generator": "^7.28.5", "@babel/helper-compilation-targets": "^7.27.2", "@babel/helper-module-transforms": "^7.28.3", "@babel/helpers": "^7.28.4", "@babel/parser": "^7.28.5", "@babel/template": "^7.27.2", "@babel/traverse": "^7.28.5", "@babel/types": "^7.28.5", "@jridgewell/remapping": "^2.3.5", "convert-source-map": "^2.0.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", "json5": "^2.2.3", "semver": "^6.3.1" } }, "sha512-e7jT4DxYvIDLk1ZHmU/m/mB19rex9sv0c2ftBtjSBv+kVM/902eh0fINUzD7UwLLNR+jU585GxUJ8/EBfAM5fw=="], @@ -2876,8 +2874,6 @@ "finalhandler/debug/ms": ["ms@2.0.0", "", {}, "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="], - "glob/minimatch/brace-expansion": ["brace-expansion@1.1.12", "", { "dependencies": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" } }, "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg=="], - "istanbul-lib-instrument/@babel/core/@babel/code-frame": ["@babel/code-frame@7.27.1", "", { "dependencies": { "@babel/helper-validator-identifier": "^7.27.1", "js-tokens": "^4.0.0", "picocolors": "^1.1.1" } }, "sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg=="], "istanbul-lib-instrument/@babel/core/@babel/generator": ["@babel/generator@7.28.5", "", { "dependencies": { "@babel/parser": "^7.28.5", "@babel/types": "^7.28.5", "@jridgewell/gen-mapping": "^0.3.12", "@jridgewell/trace-mapping": "^0.3.28", "jsesc": "^3.0.2" } }, "sha512-3EwLFhZ38J4VyIP6WNtt2kUdW9dokXA9Cr4IVIFHuCpZ3H8/YFOl5JjZHisrn1fATPBmKKqXzDFvh9fUwHz6CQ=="], @@ -3004,8 +3000,12 @@ "patch-package/fs-extra/universalify": ["universalify@2.0.1", "", {}, "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw=="], + "react-native/glob/minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], + "readable-web-to-node-stream/readable-stream/buffer": ["buffer@6.0.3", "", { "dependencies": { "base64-js": "^1.3.1", "ieee754": "^1.2.1" } }, "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA=="], + "rimraf/glob/minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], + "send/debug/ms": ["ms@2.0.0", "", {}, "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="], "serve-static/send/debug": ["debug@2.6.9", "", { "dependencies": { "ms": "2.0.0" } }, "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA=="], @@ -3016,6 +3016,10 @@ "slice-ansi/is-fullwidth-code-point/get-east-asian-width": ["get-east-asian-width@1.4.0", "", {}, "sha512-QZjmEOC+IT1uk6Rx0sX22V6uHWVwbdbxf1faPqJ1QhLdGgsRGCZoyaQBm/piRdJy/D2um6hM1UP7ZEeQ4EkP+Q=="], + "sucrase/glob/jackspeak": ["jackspeak@3.4.3", "", { "dependencies": { "@isaacs/cliui": "^8.0.2" }, "optionalDependencies": { "@pkgjs/parseargs": "^0.11.0" } }, "sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw=="], + + "sucrase/glob/minimatch": ["minimatch@9.0.5", "", { "dependencies": { "brace-expansion": "^2.0.1" } }, "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow=="], + "sucrase/glob/path-scurry": ["path-scurry@1.11.1", "", { "dependencies": { "lru-cache": "^10.2.0", "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" } }, "sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA=="], "terminal-link/ansi-escapes/type-fest": ["type-fest@0.21.3", "", {}, "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w=="], @@ -3106,6 +3110,8 @@ "@react-native/codegen/@babel/core/@babel/helper-module-transforms/@babel/helper-module-imports": ["@babel/helper-module-imports@7.27.1", "", { "dependencies": { "@babel/traverse": "^7.27.1", "@babel/types": "^7.27.1" } }, "sha512-0gSFWUPNXNopqtIPQvlD5WgXYI5GY2kP2cCvoT8kczjbfcfuIljTbcWrulD1CIPIX2gt1wghbDy08yE1p+/r3w=="], + "@react-native/codegen/glob/minimatch/brace-expansion": ["brace-expansion@1.1.12", "", { "dependencies": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" } }, "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg=="], + "@react-native/community-cli-plugin/metro/@babel/core/@babel/helper-compilation-targets": ["@babel/helper-compilation-targets@7.27.2", "", { "dependencies": { "@babel/compat-data": "^7.27.2", "@babel/helper-validator-option": "^7.27.1", "browserslist": "^4.24.0", "lru-cache": "^5.1.1", "semver": "^6.3.1" } }, "sha512-2+1thGUUWWjLTYTHZWK1n8Yga0ijBz1XAhUXcKy81rd5g6yh7hGqMp45v7cadSbEHc9G3OTv45SyneRN3ps4DQ=="], "@react-native/community-cli-plugin/metro/@babel/core/@babel/helper-module-transforms": ["@babel/helper-module-transforms@7.28.3", "", { "dependencies": { "@babel/helper-module-imports": "^7.27.1", "@babel/helper-validator-identifier": "^7.27.1", "@babel/traverse": "^7.28.3" }, "peerDependencies": { "@babel/core": "^7.0.0" } }, "sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw=="], @@ -3154,8 +3160,6 @@ "expo-manifests/@expo/config/@expo/config-plugins/slash": ["slash@3.0.0", "", {}, "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q=="], - "expo-manifests/@expo/config/glob/minimatch": ["minimatch@10.1.1", "", { "dependencies": { "@isaacs/brace-expansion": "^5.0.0" } }, "sha512-enIvLvRAFZYXJzkCYG5RKmPfrFArdLv+R+lbQ53BmIMLIry74bjKzX6iHAm8WYamJkhSSEabrWN5D97XnKObjQ=="], - "expo-manifests/@expo/config/sucrase/commander": ["commander@4.1.1", "", {}, "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA=="], "istanbul-lib-instrument/@babel/core/@babel/helper-compilation-targets/@babel/compat-data": ["@babel/compat-data@7.28.5", "", {}, "sha512-6uFXyCayocRbqhZOB+6XcuZbkMNimwfVGFji8CTZnCzOHVGvDqzvitu1re2AU5LROliz7eQPhB8CpAMvnx9EjA=="], @@ -3194,8 +3198,14 @@ "metro/@babel/core/@babel/helper-module-transforms/@babel/helper-module-imports": ["@babel/helper-module-imports@7.27.1", "", { "dependencies": { "@babel/traverse": "^7.27.1", "@babel/types": "^7.27.1" } }, "sha512-0gSFWUPNXNopqtIPQvlD5WgXYI5GY2kP2cCvoT8kczjbfcfuIljTbcWrulD1CIPIX2gt1wghbDy08yE1p+/r3w=="], + "react-native/glob/minimatch/brace-expansion": ["brace-expansion@1.1.12", "", { "dependencies": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" } }, "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg=="], + + "rimraf/glob/minimatch/brace-expansion": ["brace-expansion@1.1.12", "", { "dependencies": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" } }, "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg=="], + "serve-static/send/debug/ms": ["ms@2.0.0", "", {}, "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="], + "sucrase/glob/jackspeak/@isaacs/cliui": ["@isaacs/cliui@8.0.2", "", { "dependencies": { "string-width": "^5.1.2", "string-width-cjs": "npm:string-width@^4.2.0", "strip-ansi": "^7.0.1", "strip-ansi-cjs": "npm:strip-ansi@^6.0.1", "wrap-ansi": "^8.1.0", "wrap-ansi-cjs": "npm:wrap-ansi@^7.0.0" } }, "sha512-O8jcjabXaleOG9DQ0+ARXWZBTfnP4WNAqzuiJK7ll44AmxGKv/J2M4TPjxjY3znBCfvBXFzucm1twdyFybFqEA=="], + "sucrase/glob/path-scurry/lru-cache": ["lru-cache@10.4.3", "", {}, "sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ=="], "wrap-ansi-cjs/ansi-styles/color-convert/color-name": ["color-name@1.1.4", "", {}, "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA=="], @@ -3230,6 +3240,12 @@ "logkitty/yargs/find-up/locate-path/p-locate": ["p-locate@4.1.0", "", { "dependencies": { "p-limit": "^2.2.0" } }, "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A=="], + "sucrase/glob/jackspeak/@isaacs/cliui/string-width": ["string-width@5.1.2", "", { "dependencies": { "eastasianwidth": "^0.2.0", "emoji-regex": "^9.2.2", "strip-ansi": "^7.0.1" } }, "sha512-HnLOCR3vjcY8beoNLtcjZ5/nxn2afmME6lhrDrebokqMap+XbeW8n9TXpPDOqdGK5qcI3oT0GKTW6wC7EMiVqA=="], + + "sucrase/glob/jackspeak/@isaacs/cliui/strip-ansi": ["strip-ansi@7.1.2", "", { "dependencies": { "ansi-regex": "^6.0.1" } }, "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA=="], + + "sucrase/glob/jackspeak/@isaacs/cliui/wrap-ansi": ["wrap-ansi@8.1.0", "", { "dependencies": { "ansi-styles": "^6.1.0", "string-width": "^5.0.1", "strip-ansi": "^7.0.1" } }, "sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ=="], + "@expo/cli/ora/chalk/ansi-styles/color-convert/color-name": ["color-name@1.1.3", "", {}, "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw=="], "@expo/cli/ora/cli-cursor/restore-cursor/onetime/mimic-fn": ["mimic-fn@1.2.0", "", {}, "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ=="], @@ -3242,6 +3258,12 @@ "logkitty/yargs/find-up/locate-path/p-locate/p-limit": ["p-limit@2.3.0", "", { "dependencies": { "p-try": "^2.0.0" } }, "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w=="], + "sucrase/glob/jackspeak/@isaacs/cliui/string-width/emoji-regex": ["emoji-regex@9.2.2", "", {}, "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg=="], + + "sucrase/glob/jackspeak/@isaacs/cliui/strip-ansi/ansi-regex": ["ansi-regex@6.2.2", "", {}, "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg=="], + + "sucrase/glob/jackspeak/@isaacs/cliui/wrap-ansi/ansi-styles": ["ansi-styles@6.2.3", "", {}, "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg=="], + "logkitty/yargs/cliui/wrap-ansi/ansi-styles/color-convert/color-name": ["color-name@1.1.4", "", {}, "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA=="], } } diff --git a/package.json b/package.json index 9da99df8..7fa2998b 100644 --- a/package.json +++ b/package.json @@ -118,7 +118,7 @@ "@babel/core": "7.28.6", "@biomejs/biome": "2.3.11", "@react-native-community/cli": "20.1.1", - "@react-native-tvos/config-tv": "0.1.4", + "@react-native-tvos/config-tv": "0.1.6", "@types/jest": "29.5.14", "@types/lodash": "4.17.23", "@types/react": "19.1.17", From 80fdd579f381c87847dd56466394f3d7a631f113 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Thu, 21 May 2026 02:28:38 +0200 Subject: [PATCH 37/39] chore(deps): Update dependency @react-native-community/cli to v20.1.3 (#1571) --- bun.lock | 66 +++++++++++++++++++++++++++++++--------------------- package.json | 2 +- 2 files changed, 40 insertions(+), 28 deletions(-) diff --git a/bun.lock b/bun.lock index 1e8c5c4d..6ad282b9 100644 --- a/bun.lock +++ b/bun.lock @@ -97,7 +97,7 @@ "devDependencies": { "@babel/core": "7.28.6", "@biomejs/biome": "2.3.11", - "@react-native-community/cli": "20.1.1", + "@react-native-community/cli": "20.1.3", "@react-native-tvos/config-tv": "0.1.6", "@types/jest": "29.5.14", "@types/lodash": "4.17.23", @@ -462,6 +462,8 @@ "@jridgewell/trace-mapping": ["@jridgewell/trace-mapping@0.3.31", "", { "dependencies": { "@jridgewell/resolve-uri": "^3.1.0", "@jridgewell/sourcemap-codec": "^1.4.14" } }, "sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw=="], + "@nodable/entities": ["@nodable/entities@2.1.0", "", {}, "sha512-nyT7T3nbMyBI/lvr6L5TyWbFJAI9FTgVRakNoBqCD+PmID8DzFrrNdLLtHMwMszOtqZa8PAOV24ZqDnQrhQINA=="], + "@nodelib/fs.scandir": ["@nodelib/fs.scandir@2.1.5", "", { "dependencies": { "@nodelib/fs.stat": "2.0.5", "run-parallel": "^1.1.9" } }, "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g=="], "@nodelib/fs.stat": ["@nodelib/fs.stat@2.0.5", "", {}, "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A=="], @@ -512,29 +514,29 @@ "@radix-ui/react-use-layout-effect": ["@radix-ui/react-use-layout-effect@1.1.1", "", { "peerDependencies": { "@types/react": "*", "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc" }, "optionalPeers": ["@types/react"] }, "sha512-RbJRS4UWQFkzHTTwVymMTUv8EqYhOp8dOOviLj2ugtTiXRaRQS7GLGxZTLL1jWhMeoSCf5zmcZkqTl9IiYfXcQ=="], - "@react-native-community/cli": ["@react-native-community/cli@20.1.1", "", { "dependencies": { "@react-native-community/cli-clean": "20.1.1", "@react-native-community/cli-config": "20.1.1", "@react-native-community/cli-doctor": "20.1.1", "@react-native-community/cli-server-api": "20.1.1", "@react-native-community/cli-tools": "20.1.1", "@react-native-community/cli-types": "20.1.1", "commander": "^9.4.1", "deepmerge": "^4.3.0", "execa": "^5.0.0", "find-up": "^5.0.0", "fs-extra": "^8.1.0", "graceful-fs": "^4.1.3", "picocolors": "^1.1.1", "prompts": "^2.4.2", "semver": "^7.5.2" }, "bin": { "rnc-cli": "build/bin.js" } }, "sha512-aLPUx43+WSeTOaUepR2FBD5a1V0OAZ1QB2DOlRlW4fOEjtBXgv40eM/ho8g3WCvAOKfPvTvx4fZdcuovTyV81Q=="], + "@react-native-community/cli": ["@react-native-community/cli@20.1.3", "", { "dependencies": { "@react-native-community/cli-clean": "20.1.3", "@react-native-community/cli-config": "20.1.3", "@react-native-community/cli-doctor": "20.1.3", "@react-native-community/cli-server-api": "20.1.3", "@react-native-community/cli-tools": "20.1.3", "@react-native-community/cli-types": "20.1.3", "commander": "^9.4.1", "deepmerge": "^4.3.0", "execa": "^5.0.0", "find-up": "^5.0.0", "fs-extra": "^8.1.0", "graceful-fs": "^4.1.3", "picocolors": "^1.1.1", "prompts": "^2.4.2", "semver": "^7.5.2" }, "bin": { "rnc-cli": "build/bin.js" } }, "sha512-sLo8cu9JyFNfuuF1C+8NJ4DHE/PEFaXGd4enkcxi/OJjGG8+sOQrdjNQ4i+cVh/2c+ah1mEMwsYjc3z0+/MqSg=="], - "@react-native-community/cli-clean": ["@react-native-community/cli-clean@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "execa": "^5.0.0", "fast-glob": "^3.3.2", "picocolors": "^1.1.1" } }, "sha512-6nGQ08w2+EcDwTFC4JFiW/wI2pLwzMrk9thz4um7tKRNW8sADX0IyCsfM2F4rHS720C0UNKYBZE9nAsfp8Vkcw=="], + "@react-native-community/cli-clean": ["@react-native-community/cli-clean@20.1.3", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.3", "execa": "^5.0.0", "fast-glob": "^3.3.2", "picocolors": "^1.1.1" } }, "sha512-sFLdLzapfC0scjgzBJJWYDY2RhHPjuuPkA5r6q0gc/UQH/izXpMpLrhh1DW84cMDraNACK0U62tU7ebNaQ1LMQ=="], - "@react-native-community/cli-config": ["@react-native-community/cli-config@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "cosmiconfig": "^9.0.0", "deepmerge": "^4.3.0", "fast-glob": "^3.3.2", "joi": "^17.2.1", "picocolors": "^1.1.1" } }, "sha512-ajs2i56MANie/v0bMQ1BmRcrOb6MEvLT2rh/I1CA62NXGqF1Rxv6QwsN84LrADMXHRg8QiEMAIADkyDeQHt7Kg=="], + "@react-native-community/cli-config": ["@react-native-community/cli-config@20.1.3", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.3", "cosmiconfig": "^9.0.0", "deepmerge": "^4.3.0", "fast-glob": "^3.3.2", "joi": "^17.2.1", "picocolors": "^1.1.1" } }, "sha512-n73nW0cG92oNF0r994pPqm0DjAShOm3F8LSffDYhJqNAno+h/csmv/37iL4NtSpmKIO8xqsG3uVTXz9X/hzNaQ=="], - "@react-native-community/cli-config-android": ["@react-native-community/cli-config-android@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "fast-glob": "^3.3.2", "fast-xml-parser": "^4.4.1", "picocolors": "^1.1.1" } }, "sha512-1iUV2rPAyoWPo8EceAFC2vZTF+pEd9YqS87c0aqpbGOFE0gs1rHEB+auVR8CdjzftR4U9sq6m2jrdst0rvpIkg=="], + "@react-native-community/cli-config-android": ["@react-native-community/cli-config-android@20.1.3", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.3", "fast-glob": "^3.3.2", "fast-xml-parser": "^5.3.6", "picocolors": "^1.1.1" } }, "sha512-DNHDP+OWLyhKShGciBqPcxhxfp1Z/7GQcb4F+TGyCeKQAr+JdnUjRXN3X+YCU/v+g2kbYYyRJKlGabzkVvdrAw=="], - "@react-native-community/cli-config-apple": ["@react-native-community/cli-config-apple@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "execa": "^5.0.0", "fast-glob": "^3.3.2", "picocolors": "^1.1.1" } }, "sha512-doepJgLJVqeJb5tNoP9hyFIcoZ1OMGO7QN/YMuCCIjbThUQe/J87XdwPol3Qrjr58KRt9xeBVz+kHeW5mtSutw=="], + "@react-native-community/cli-config-apple": ["@react-native-community/cli-config-apple@20.1.3", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.3", "execa": "^5.0.0", "fast-glob": "^3.3.2", "picocolors": "^1.1.1" } }, "sha512-QX9B83nAfCPs0KiaYz61kAEHWr9sttooxzRzNdQwvZTwnsIpvWOT9GvMMj/19OeXiQzMJBzZX0Pgt6+spiUsDQ=="], - "@react-native-community/cli-doctor": ["@react-native-community/cli-doctor@20.1.1", "", { "dependencies": { "@react-native-community/cli-config": "20.1.1", "@react-native-community/cli-platform-android": "20.1.1", "@react-native-community/cli-platform-apple": "20.1.1", "@react-native-community/cli-platform-ios": "20.1.1", "@react-native-community/cli-tools": "20.1.1", "command-exists": "^1.2.8", "deepmerge": "^4.3.0", "envinfo": "^7.13.0", "execa": "^5.0.0", "node-stream-zip": "^1.9.1", "ora": "^5.4.1", "picocolors": "^1.1.1", "semver": "^7.5.2", "wcwidth": "^1.0.1", "yaml": "^2.2.1" } }, "sha512-eFpg5wWnV7uGqvLemshpgj2trPD8cckqxBuI4nT7sxKF/YpA/e3nnnyytHxPP5EnYfWbMcqfaq8hDJoOnJinGQ=="], + "@react-native-community/cli-doctor": ["@react-native-community/cli-doctor@20.1.3", "", { "dependencies": { "@react-native-community/cli-config": "20.1.3", "@react-native-community/cli-platform-android": "20.1.3", "@react-native-community/cli-platform-apple": "20.1.3", "@react-native-community/cli-platform-ios": "20.1.3", "@react-native-community/cli-tools": "20.1.3", "command-exists": "^1.2.8", "deepmerge": "^4.3.0", "envinfo": "^7.13.0", "execa": "^5.0.0", "node-stream-zip": "^1.9.1", "ora": "^5.4.1", "picocolors": "^1.1.1", "semver": "^7.5.2", "wcwidth": "^1.0.1", "yaml": "^2.2.1" } }, "sha512-EI+mAPWn255/WZ4CQohy1I049yiaxVr41C3BeQ2BCyhxODIDR8XRsLzYb1t9MfqK/C3ZncUN2mPSRXFeKPPI1w=="], - "@react-native-community/cli-platform-android": ["@react-native-community/cli-platform-android@20.1.1", "", { "dependencies": { "@react-native-community/cli-config-android": "20.1.1", "@react-native-community/cli-tools": "20.1.1", "execa": "^5.0.0", "logkitty": "^0.7.1", "picocolors": "^1.1.1" } }, "sha512-KPheizJQI0tVvBLy9owzpo+A9qDsDAa87e7a8xNaHnwqGpExnIzFPrbdvrltiZjstU2eB/+/UgNQxYIEd4Oc+g=="], + "@react-native-community/cli-platform-android": ["@react-native-community/cli-platform-android@20.1.3", "", { "dependencies": { "@react-native-community/cli-config-android": "20.1.3", "@react-native-community/cli-tools": "20.1.3", "execa": "^5.0.0", "logkitty": "^0.7.1", "picocolors": "^1.1.1" } }, "sha512-bzB9ELPOISuqgtDZXFPQlkuxx1YFkNx3cNgslc5ElCrk+5LeCLQLIBh/dmIuK8rwUrPcrramjeBj++Noc+TaAA=="], - "@react-native-community/cli-platform-apple": ["@react-native-community/cli-platform-apple@20.1.1", "", { "dependencies": { "@react-native-community/cli-config-apple": "20.1.1", "@react-native-community/cli-tools": "20.1.1", "execa": "^5.0.0", "fast-xml-parser": "^4.4.1", "picocolors": "^1.1.1" } }, "sha512-mQEjOzRFCcQTrCt73Q/+5WWTfUg6U2vLZv5rPuFiNrLbrwRqxVH3OLaXg5gilJkDTJC80z8iOSsdd8MRxONOig=="], + "@react-native-community/cli-platform-apple": ["@react-native-community/cli-platform-apple@20.1.3", "", { "dependencies": { "@react-native-community/cli-config-apple": "20.1.3", "@react-native-community/cli-tools": "20.1.3", "execa": "^5.0.0", "fast-xml-parser": "^5.3.6", "picocolors": "^1.1.1" } }, "sha512-XJ+DqAD4hkplWVXK5AMgN7pP9+4yRSe5KfZ/b42+ofkDBI55ALlUmX+9HWE3fMuRjcotTCoNZqX2ov97cFDXpQ=="], - "@react-native-community/cli-platform-ios": ["@react-native-community/cli-platform-ios@20.1.1", "", { "dependencies": { "@react-native-community/cli-platform-apple": "20.1.1" } }, "sha512-6vr10/oSjKkZO/BBgfFJNQTC/0CDF4WrN8iW9ss+Kt6ZL2QrBXLYz7fobrrboOlHwqqs5EyQadlEaNii7gKRJg=="], + "@react-native-community/cli-platform-ios": ["@react-native-community/cli-platform-ios@20.1.3", "", { "dependencies": { "@react-native-community/cli-platform-apple": "20.1.3" } }, "sha512-2qL48SINotuHbZO73cgqSwqd/OWNx0xTbFSdujhpogV4p8BNwYYypfjh4vJY5qJEB5PxuoVkMXT+aCADpg9nBg=="], - "@react-native-community/cli-server-api": ["@react-native-community/cli-server-api@20.1.1", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.1", "body-parser": "^1.20.3", "compression": "^1.7.1", "connect": "^3.6.5", "errorhandler": "^1.5.1", "nocache": "^3.0.1", "open": "^6.2.0", "pretty-format": "^29.7.0", "serve-static": "^1.13.1", "strict-url-sanitise": "0.0.1", "ws": "^6.2.3" } }, "sha512-phHfiCa4WqfKfaoV2vGVR3ZrYQDQTpI1k+C+i6rXAxFGxPuy8IgFFVOSL543qjKPpHBVwLcA+/xAJCVpdyCtVQ=="], + "@react-native-community/cli-server-api": ["@react-native-community/cli-server-api@20.1.3", "", { "dependencies": { "@react-native-community/cli-tools": "20.1.3", "body-parser": "^2.2.2", "compression": "^1.7.1", "connect": "^3.6.5", "errorhandler": "^1.5.1", "nocache": "^3.0.1", "open": "^6.2.0", "pretty-format": "^29.7.0", "serve-static": "^1.13.1", "strict-url-sanitise": "0.0.1", "ws": "^6.2.3" } }, "sha512-hsNsdUKZDd2T99OuNuiXz4VuvLa1UN0zcxefmPjXQgI0byrBLzzDr+o7p03sKuODSzKi2h+BMnUxiS07HACQLA=="], - "@react-native-community/cli-tools": ["@react-native-community/cli-tools@20.1.1", "", { "dependencies": { "@vscode/sudo-prompt": "^9.0.0", "appdirsjs": "^1.2.4", "execa": "^5.0.0", "find-up": "^5.0.0", "launch-editor": "^2.9.1", "mime": "^2.4.1", "ora": "^5.4.1", "picocolors": "^1.1.1", "prompts": "^2.4.2", "semver": "^7.5.2" } }, "sha512-j+zX/H2X+6ZGneIDj56tZ1Hbnip5nSfnq7yGlMyF/zm3U1hKp3G1jN5v0YEfnz/zEmjr7zruh4Y06KmZrF1lrA=="], + "@react-native-community/cli-tools": ["@react-native-community/cli-tools@20.1.3", "", { "dependencies": { "@vscode/sudo-prompt": "^9.0.0", "appdirsjs": "^1.2.4", "execa": "^5.0.0", "find-up": "^5.0.0", "launch-editor": "^2.9.1", "mime": "^2.4.1", "ora": "^5.4.1", "picocolors": "^1.1.1", "prompts": "^2.4.2", "semver": "^7.5.2" } }, "sha512-EAn0vPCMxtHhfWk2UwLmSUfPfLUnFgC7NjiVJVTKJyVk5qGnkPfoT8te/1IUXFTysUB0F0RIi+NgDB4usFOLeA=="], - "@react-native-community/cli-types": ["@react-native-community/cli-types@20.1.1", "", { "dependencies": { "joi": "^17.2.1" } }, "sha512-Tp+s27I/RDONrGvWVj4IzEmga2HhJhXi8ZlZTfycMMyAcv4LG/CTPira+BUZs8nzLAJNrlJ79pVVPJPqQAe+aw=="], + "@react-native-community/cli-types": ["@react-native-community/cli-types@20.1.3", "", { "dependencies": { "joi": "^17.2.1" } }, "sha512-IdAcegf0pH1hVraxWTG1ACLkYC0LDQfqtaEf42ESyLIF3Xap70JzL/9tAlxw7lSCPZPFWhrcgU0TBc4SkC/ecw=="], "@react-native-community/netinfo": ["@react-native-community/netinfo@11.4.1", "", { "peerDependencies": { "react-native": ">=0.59" } }, "sha512-B0BYAkghz3Q2V09BF88RA601XursIEA111tnc2JOaN7axJWmNefmfjZqw/KdSxKZp7CZUuPpjBmz/WCR9uaHYg=="], @@ -774,7 +776,7 @@ "bmp-js": ["bmp-js@0.1.0", "", {}, "sha512-vHdS19CnY3hwiNdkaqk93DvjVLfbEcI8mys4UjuWrlX1haDmroo8o4xCzh4wD6DGV6HxRCyauwhHRqMTfERtjw=="], - "body-parser": ["body-parser@1.20.3", "", { "dependencies": { "bytes": "3.1.2", "content-type": "~1.0.5", "debug": "2.6.9", "depd": "2.0.0", "destroy": "1.2.0", "http-errors": "2.0.0", "iconv-lite": "0.4.24", "on-finished": "2.4.1", "qs": "6.13.0", "raw-body": "2.5.2", "type-is": "~1.6.18", "unpipe": "1.0.0" } }, "sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g=="], + "body-parser": ["body-parser@2.2.2", "", { "dependencies": { "bytes": "^3.1.2", "content-type": "^1.0.5", "debug": "^4.4.3", "http-errors": "^2.0.0", "iconv-lite": "^0.7.0", "on-finished": "^2.4.1", "qs": "^6.14.1", "raw-body": "^3.0.1", "type-is": "^2.0.1" } }, "sha512-oP5VkATKlNwcgvxi0vM0p/D3n2C3EReYVX+DNYs5TjZFn/oQt2j+4sVJtSMr18pdRr8wjTcBl6LoV+FUwzPmNA=="], "boolbase": ["boolbase@1.0.0", "", {}, "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww=="], @@ -1094,7 +1096,9 @@ "fast-uri": ["fast-uri@3.1.0", "", {}, "sha512-iPeeDKJSWf4IEOasVVrknXpaBV0IApz/gp7S2bb7Z4Lljbl2MGJRqInZiUrQwV16cpzw/D3S5j5Julj/gT52AA=="], - "fast-xml-parser": ["fast-xml-parser@4.5.3", "", { "dependencies": { "strnum": "^1.1.1" }, "bin": { "fxparser": "src/cli/cli.js" } }, "sha512-RKihhV+SHsIUGXObeVy9AXiBbFwkVk7Syp8XgwN5U3JV416+Gwp/GO9i0JYKmikykgz/UHRrrV4ROuZEo/T0ig=="], + "fast-xml-builder": ["fast-xml-builder@1.2.0", "", { "dependencies": { "path-expression-matcher": "^1.5.0", "xml-naming": "^0.1.0" } }, "sha512-00aAWieqff+ZJhsXA4g1g7M8k+7AYoMUUHF+/zFb5U6Uv/P0Vl4QZo84/IcufzYalLuEj9928bXN9PbbFzMF0Q=="], + + "fast-xml-parser": ["fast-xml-parser@5.8.0", "", { "dependencies": { "@nodable/entities": "^2.1.0", "fast-xml-builder": "^1.2.0", "path-expression-matcher": "^1.5.0", "strnum": "^2.3.0", "xml-naming": "^0.1.0" }, "bin": { "fxparser": "src/cli/cli.js" } }, "sha512-6bIM7fsJxeo3uXv7OncQYsBAMPJ7V16Slahl/6M98C/i2q+vB1+4a0MtrvYwDFEUrwDSbAmeLDRXsOBwrL7yAg=="], "fastq": ["fastq@1.19.1", "", { "dependencies": { "reusify": "^1.0.4" } }, "sha512-GwLTyxkCXjXbxqIhTsMI2Nui8huMPtnxg7krajPJAjnEG/iiOS7i+zCtWGZR9G0NBKbXKh6X9m9UIsYX/N6vvQ=="], @@ -1206,7 +1210,7 @@ "i18next": ["i18next@25.6.1", "", { "dependencies": { "@babel/runtime": "^7.27.6" }, "peerDependencies": { "typescript": "^5" }, "optionalPeers": ["typescript"] }, "sha512-yUWvdXtalZztmKrKw3yz/AvSP3yKyqIkVPx/wyvoYy9lkLmwzItLxp0iHZLG5hfVQ539Jor4XLO+U+NHIXg7pw=="], - "iconv-lite": ["iconv-lite@0.4.24", "", { "dependencies": { "safer-buffer": ">= 2.1.2 < 3" } }, "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA=="], + "iconv-lite": ["iconv-lite@0.7.2", "", { "dependencies": { "safer-buffer": ">= 2.1.2 < 3.0.0" } }, "sha512-im9DjEDQ55s9fL4EYzOAv0yMqmMBSZp6G0VvFyTMPKWxiSBHUj9NW/qqLmXUwXrrM7AvqSlTCfvqRb0cM8yYqw=="], "ieee754": ["ieee754@1.2.1", "", {}, "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA=="], @@ -1400,7 +1404,7 @@ "mdn-data": ["mdn-data@2.0.14", "", {}, "sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow=="], - "media-typer": ["media-typer@0.3.0", "", {}, "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ=="], + "media-typer": ["media-typer@1.1.0", "", {}, "sha512-aisnrDP4GNe06UcKFnV5bfMNPBUw4jsLGaWwWfnH3v02GnBuXX2MCVn5RbrWo0j3pczUilYblq7fQ7Nw2t5XKw=="], "memoize-one": ["memoize-one@5.2.1", "", {}, "sha512-zYiwtZUcYyXKo/np96AGZAckk+FWWsUdJ3cHGGmld7+AhvcWmQyGCYUh1hc4Q/pkOhb65dQR/pqCyK0cOaHz4Q=="], @@ -1544,6 +1548,8 @@ "path-exists": ["path-exists@4.0.0", "", {}, "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w=="], + "path-expression-matcher": ["path-expression-matcher@1.5.0", "", {}, "sha512-cbrerZV+6rvdQrrD+iGMcZFEiiSrbv9Tfdkvnusy6y0x0GKBXREFg/Y65GhIfm0tnLntThhzCnfKwp1WRjeCyQ=="], + "path-is-absolute": ["path-is-absolute@1.0.1", "", {}, "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg=="], "path-key": ["path-key@3.1.1", "", {}, "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q=="], @@ -1612,7 +1618,7 @@ "qrcode-terminal": ["qrcode-terminal@0.11.0", "", { "bin": { "qrcode-terminal": "./bin/qrcode-terminal.js" } }, "sha512-Uu7ii+FQy4Qf82G4xu7ShHhjhGahEpCWc3x8UavY3CTcWV+ufmmCtwkr7ZKsX42jdL0kr1B5FKUeqJvAn51jzQ=="], - "qs": ["qs@6.13.0", "", { "dependencies": { "side-channel": "^1.0.6" } }, "sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg=="], + "qs": ["qs@6.15.2", "", { "dependencies": { "side-channel": "^1.1.0" } }, "sha512-Rzq0KEyX/w/tEybncDgdkZrJgVUsUMk3xjh3t5bv3S1HTAtg+uOYt72+ZfwiQwKdysThkTBdL/rTi6HDmX9Ddw=="], "query-string": ["query-string@7.1.3", "", { "dependencies": { "decode-uri-component": "^0.2.2", "filter-obj": "^1.1.0", "split-on-first": "^1.0.0", "strict-uri-encode": "^2.0.0" } }, "sha512-hh2WYhq4fi8+b+/2Kg9CEge4fDPvHS534aOOvOZeQ3+Vf2mCFsaFBYj0i+iXcAq6I9Vzp5fjMFBlONvayDC1qg=="], @@ -1622,7 +1628,7 @@ "range-parser": ["range-parser@1.2.1", "", {}, "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg=="], - "raw-body": ["raw-body@2.5.2", "", { "dependencies": { "bytes": "3.1.2", "http-errors": "2.0.0", "iconv-lite": "0.4.24", "unpipe": "1.0.0" } }, "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA=="], + "raw-body": ["raw-body@3.0.2", "", { "dependencies": { "bytes": "~3.1.2", "http-errors": "~2.0.1", "iconv-lite": "~0.7.0", "unpipe": "~1.0.0" } }, "sha512-K5zQjDllxWkf7Z5xJdV0/B0WTNqx6vxG70zJE4N0kBs4LovmEYWJzQGxC9bS9RAKu3bgM40lrd5zoLJ12MQ5BA=="], "rc": ["rc@1.2.8", "", { "dependencies": { "deep-extend": "^0.6.0", "ini": "~1.3.0", "minimist": "^1.2.0", "strip-json-comments": "~2.0.1" }, "bin": { "rc": "./cli.js" } }, "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw=="], @@ -1868,7 +1874,7 @@ "strip-json-comments": ["strip-json-comments@2.0.1", "", {}, "sha512-4gB8na07fecVVkOI6Rs4e7T6NOTki5EmL7TUduTs6bu3EdnSycntVJ4re8kgZA+wx9IueI2Y11bfbgwtzuE0KQ=="], - "strnum": ["strnum@1.1.2", "", {}, "sha512-vrN+B7DBIoTTZjnPNewwhx6cBA/H+IS7rfW68n7XxC1y7uoiGQBxaKzqucGUgavX15dJgiGztLJ8vxuEzwqBdA=="], + "strnum": ["strnum@2.3.0", "", {}, "sha512-ums3KNd42PGyx5xaoVTO1mjU1bH3NpY4vsrVlnv9PNGqQj8wd7rJ6nEypLrJ7z5vxK5RP0yMLo6J/Gsm62DI5Q=="], "strtok3": ["strtok3@6.3.0", "", { "dependencies": { "@tokenizer/token": "^0.3.0", "peek-readable": "^4.1.0" } }, "sha512-fZtbhtvI9I48xDSywd/somNqgUHl2L2cstmXCCif0itOf96jeW18MBSyrLuNicYQVkvpOxkZtkzujiTJ9LW5Jw=="], @@ -1932,7 +1938,7 @@ "type-fest": ["type-fest@0.7.1", "", {}, "sha512-Ne2YiiGN8bmrmJJEuTWTLJR32nh/JdL1+PSicowtNb0WFpn59GK8/lfD61bVtzguz7b3PBt74nxpv/Pw5po5Rg=="], - "type-is": ["type-is@1.6.18", "", { "dependencies": { "media-typer": "0.3.0", "mime-types": "~2.1.24" } }, "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g=="], + "type-is": ["type-is@2.1.0", "", { "dependencies": { "content-type": "^2.0.0", "media-typer": "^1.1.0", "mime-types": "^3.0.0" } }, "sha512-faYHw0anBbc/kWF3zFTEnxSFOAGUX9GFbOBthvDdLsIlEoWOFOtS0zgCiQYwIskL9iGXZL3kAXD8OoZ4GmMATA=="], "typescript": ["typescript@5.9.3", "", { "bin": { "tsc": "bin/tsc", "tsserver": "bin/tsserver" } }, "sha512-jl1vZzPDinLr9eUt3J/t7V6FgNEw9QjvBPdysz9KfQDD41fQrC2Y4vKQdiaUpFT4bXlb1RHhLpp8wtm6M5TgSw=="], @@ -2024,6 +2030,8 @@ "xcode": ["xcode@3.0.1", "", { "dependencies": { "simple-plist": "^1.1.0", "uuid": "^7.0.3" } }, "sha512-kCz5k7J7XbJtjABOvkc5lJmkiDh8VhjVCGNiqdKCscmVpdVUpEAyXv1xmCLkQJ5dsHqx3IPO4XW+NTDhU/fatA=="], + "xml-naming": ["xml-naming@0.1.0", "", {}, "sha512-k8KO9hrMyNk6tUWqUfkTEZbezRRpONVOzUTnc97VnCvyj6Tf9lyUR9EDAIeiVLv56jsMcoXEwjW8Kv5yPY52lw=="], + "xml2js": ["xml2js@0.6.0", "", { "dependencies": { "sax": ">=0.6.0", "xmlbuilder": "~11.0.0" } }, "sha512-eLTh0kA8uHceqesPqSE+VvO1CDDJWMwlQfB6LuN6T8w6MaDJ8Txm8P7s5cHD0miF0V+GGTZrDQfxPZQVsur33w=="], "xmlbuilder": ["xmlbuilder@15.1.1", "", {}, "sha512-yMqGBqtXyeN1e3TGYvgNgDVZ3j84W4cwkOXQswghol6APgZWaff9lnbvN7MHYJOiXsvGPXtjTYJEiC9J2wv9Eg=="], @@ -2206,8 +2214,6 @@ "@react-native-community/cli-doctor/semver": ["semver@7.7.2", "", { "bin": { "semver": "bin/semver.js" } }, "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA=="], - "@react-native-community/cli-doctor/yaml": ["yaml@2.8.1", "", { "bin": { "yaml": "bin.mjs" } }, "sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw=="], - "@react-native-community/cli-server-api/open": ["open@6.4.0", "", { "dependencies": { "is-wsl": "^1.1.0" } }, "sha512-IFenVPgF70fSm1keSd2iDBIDIBZkroLeuffXq+wKTzTJlBpesFWojV9lb8mzOfaAzM1sr7HQHuO0vtV0zYekGg=="], "@react-native-community/cli-tools/semver": ["semver@7.7.2", "", { "bin": { "semver": "bin/semver.js" } }, "sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA=="], @@ -2282,8 +2288,6 @@ "better-opn/open": ["open@8.4.2", "", { "dependencies": { "define-lazy-prop": "^2.0.0", "is-docker": "^2.1.1", "is-wsl": "^2.2.0" } }, "sha512-7x81NCL719oNbsq/3mh+hVrAWmFuEYUqrq/Iw3kUzH8ReypT9QQ0BLoJS7/G9k6N81XjW4qHWtjWwe/9eLy1EQ=="], - "body-parser/debug": ["debug@2.6.9", "", { "dependencies": { "ms": "2.0.0" } }, "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA=="], - "chalk/ansi-styles": ["ansi-styles@4.3.0", "", { "dependencies": { "color-convert": "^2.0.1" } }, "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg=="], "chokidar/glob-parent": ["glob-parent@5.1.2", "", { "dependencies": { "is-glob": "^4.0.1" } }, "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow=="], @@ -2434,6 +2438,8 @@ "prop-types/react-is": ["react-is@16.13.1", "", {}, "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ=="], + "raw-body/http-errors": ["http-errors@2.0.1", "", { "dependencies": { "depd": "~2.0.0", "inherits": "~2.0.4", "setprototypeof": "~1.2.0", "statuses": "~2.0.2", "toidentifier": "~1.0.1" } }, "sha512-4FbRdAX+bSdmo4AUFuS0WNiPz8NgFt+r8ThgNWmlrjQjt1Q7ZR9+zTlce2859x4KSXrwIsaeTqDoKQmtP8pLmQ=="], + "react-devtools-core/ws": ["ws@7.5.10", "", { "peerDependencies": { "bufferutil": "^4.0.1", "utf-8-validate": "^5.0.2" }, "optionalPeers": ["bufferutil", "utf-8-validate"] }, "sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ=="], "react-dom/scheduler": ["scheduler@0.26.0", "", {}, "sha512-NlHwttCI/l5gCPR3D1nNXtWABUmBwvZpEQiD4IXSbIDq8BzLIK/7Ir5gTFSGZDUu37K5cMNp0hFtzO38sC7gWA=="], @@ -2496,6 +2502,10 @@ "tinyglobby/picomatch": ["picomatch@4.0.3", "", {}, "sha512-5gTmgEY/sqK6gFXLIsQNH19lWb4ebPDLA4SdLP7dsWkIXHWlG66oPuVvXSGFPppYZz8ZDZq0dYYrbHfBCVUb1Q=="], + "type-is/content-type": ["content-type@2.0.0", "", {}, "sha512-j/O/d7GcZCyNl7/hwZAb606rzqkyvaDctLmckbxLzHvFBzTJHuGEdodATcP3yIRoDrLHkIATJuvzbFlp/ki2cQ=="], + + "type-is/mime-types": ["mime-types@3.0.2", "", { "dependencies": { "mime-db": "^1.54.0" } }, "sha512-Lbgzdk0h4juoQ9fCKXW4by0UJqj+nOOrI9MJ1sSj4nI8aI2eo1qmvQEie4VD1glsS250n15LsWsYtCugiStS5A=="], + "whatwg-url/webidl-conversions": ["webidl-conversions@3.0.1", "", {}, "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ=="], "wrap-ansi/ansi-styles": ["ansi-styles@6.2.3", "", {}, "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg=="], @@ -2846,8 +2856,6 @@ "babel-preset-expo/@babel/helper-module-imports/@babel/types": ["@babel/types@7.28.5", "", { "dependencies": { "@babel/helper-string-parser": "^7.27.1", "@babel/helper-validator-identifier": "^7.28.5" } }, "sha512-qQ5m48eI/MFLQ5PxQj4PFaprjyCTLI37ElWMmNs0K8Lk3dVeOdNpB3ks8jc7yM5CDmVC73eMVk/trk3fgmrUpA=="], - "body-parser/debug/ms": ["ms@2.0.0", "", {}, "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A=="], - "chalk/ansi-styles/color-convert": ["color-convert@2.0.1", "", { "dependencies": { "color-name": "~1.1.4" } }, "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ=="], "cli-truncate/string-width/strip-ansi": ["strip-ansi@7.1.2", "", { "dependencies": { "ansi-regex": "^6.0.1" } }, "sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA=="], @@ -3000,6 +3008,8 @@ "patch-package/fs-extra/universalify": ["universalify@2.0.1", "", {}, "sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw=="], + "raw-body/http-errors/statuses": ["statuses@2.0.2", "", {}, "sha512-DvEy55V3DB7uknRo+4iOGT5fP1slR8wQohVdknigZPMpMstaKJQWhwiYBACJE3Ul2pTnATihhBYnRhZQHGBiRw=="], + "react-native/glob/minimatch": ["minimatch@3.1.2", "", { "dependencies": { "brace-expansion": "^1.1.7" } }, "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw=="], "readable-web-to-node-stream/readable-stream/buffer": ["buffer@6.0.3", "", { "dependencies": { "base64-js": "^1.3.1", "ieee754": "^1.2.1" } }, "sha512-FTiCpNxtwiZZHEZbcbTIcZjERVICn9yq/pDFkTl95/AxzD1naBctN7YO68riM/gLSDY7sdrMby8hofADYuuqOA=="], @@ -3026,6 +3036,8 @@ "test-exclude/minimatch/brace-expansion": ["brace-expansion@1.1.12", "", { "dependencies": { "balanced-match": "^1.0.0", "concat-map": "0.0.1" } }, "sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg=="], + "type-is/mime-types/mime-db": ["mime-db@1.54.0", "", {}, "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ=="], + "wrap-ansi-cjs/ansi-styles/color-convert": ["color-convert@2.0.1", "", { "dependencies": { "color-name": "~1.1.4" } }, "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ=="], "wrap-ansi/strip-ansi/ansi-regex": ["ansi-regex@6.2.2", "", {}, "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg=="], diff --git a/package.json b/package.json index 7fa2998b..d882ab4b 100644 --- a/package.json +++ b/package.json @@ -117,7 +117,7 @@ "devDependencies": { "@babel/core": "7.28.6", "@biomejs/biome": "2.3.11", - "@react-native-community/cli": "20.1.1", + "@react-native-community/cli": "20.1.3", "@react-native-tvos/config-tv": "0.1.6", "@types/jest": "29.5.14", "@types/lodash": "4.17.23", From da9afacbf7536d7b3f3f3bc279fa315149c80c93 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Fri, 22 May 2026 01:07:52 +0200 Subject: [PATCH 38/39] chore(deps): Update dependency react-i18next to v17 (#1574) --- bun.lock | 6 ++++-- package.json | 2 +- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/bun.lock b/bun.lock index 6ad282b9..03f85758 100644 --- a/bun.lock +++ b/bun.lock @@ -57,7 +57,7 @@ "patch-package": "^8.0.0", "react": "19.1.0", "react-dom": "19.1.0", - "react-i18next": "16.5.8", + "react-i18next": "17.0.8", "react-native": "0.81.5", "react-native-awesome-slider": "^2.9.0", "react-native-bottom-tabs": "1.1.0", @@ -1642,7 +1642,7 @@ "react-freeze": ["react-freeze@1.0.4", "", { "peerDependencies": { "react": ">=17.0.0" } }, "sha512-r4F0Sec0BLxWicc7HEyo2x3/2icUTrRmDjaaRyzzn+7aDyFZliszMDOgLVwSnQnYENOlL1o569Ze2HZefk8clA=="], - "react-i18next": ["react-i18next@16.5.8", "", { "dependencies": { "@babel/runtime": "^7.28.4", "html-parse-stringify": "^3.0.1", "use-sync-external-store": "^1.6.0" }, "peerDependencies": { "i18next": ">= 25.6.2", "react": ">= 16.8.0", "react-dom": "*", "react-native": "*", "typescript": "^5" }, "optionalPeers": ["react-dom", "react-native", "typescript"] }, "sha512-2ABeHHlakxVY+LSirD+OiERxFL6+zip0PaHo979bgwzeHg27Sqc82xxXWIrSFmfWX0ZkrvXMHwhsi/NGUf5VQg=="], + "react-i18next": ["react-i18next@17.0.8", "", { "dependencies": { "@babel/runtime": "^7.29.2", "html-parse-stringify": "^3.0.1", "use-sync-external-store": "^1.6.0" }, "peerDependencies": { "i18next": ">= 26.2.0", "react": ">= 16.8.0", "react-dom": "*", "react-native": "*", "typescript": "^5 || ^6" }, "optionalPeers": ["react-dom", "react-native", "typescript"] }, "sha512-0ooKbGLU8JXhe1zwpQUWIeXSgLPOfwJmgheWRIUpcoA0CpyabpGhayjdG+/eA5esC1AQ8h2jWpXjJfzQzeDOCw=="], "react-is": ["react-is@19.2.3", "", {}, "sha512-qJNJfu81ByyabuG7hPFEbXqNcWSU3+eVus+KJs+0ncpGfMyYdvSmxiJxbWR65lYi1I+/0HBcliO029gc4F+PnA=="], @@ -2444,6 +2444,8 @@ "react-dom/scheduler": ["scheduler@0.26.0", "", {}, "sha512-NlHwttCI/l5gCPR3D1nNXtWABUmBwvZpEQiD4IXSbIDq8BzLIK/7Ir5gTFSGZDUu37K5cMNp0hFtzO38sC7gWA=="], + "react-i18next/@babel/runtime": ["@babel/runtime@7.29.2", "", {}, "sha512-JiDShH45zKHWyGe4ZNVRrCjBz8Nh9TMmZG1kh4QTK8hCBTWBi8Da+i7s1fJw7/lYpM4ccepSNfqzZ/QvABBi5g=="], + "react-native/commander": ["commander@12.1.0", "", {}, "sha512-Vw8qHK3bZM9y/P10u3Vib8o/DdkvA2OtPtZvD871QKjy74Wj1WSKFILMPRPSdUSx5RFK1arlJzEtA4PkFgnbuA=="], "react-native/glob": ["glob@7.2.3", "", { "dependencies": { "fs.realpath": "^1.0.0", "inflight": "^1.0.4", "inherits": "2", "minimatch": "^3.1.1", "once": "^1.3.0", "path-is-absolute": "^1.0.0" } }, "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q=="], diff --git a/package.json b/package.json index d882ab4b..e230a342 100644 --- a/package.json +++ b/package.json @@ -77,7 +77,7 @@ "patch-package": "^8.0.0", "react": "19.1.0", "react-dom": "19.1.0", - "react-i18next": "16.5.8", + "react-i18next": "17.0.8", "react-native": "0.81.5", "react-native-awesome-slider": "^2.9.0", "react-native-bottom-tabs": "1.1.0", From e7f200a114168b926db1aeb50872fce3403fa3cc Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Fri, 22 May 2026 01:32:27 +0200 Subject: [PATCH 39/39] chore(deps): Update dependency i18next to v26 (#1573) --- bun.lock | 4 ++-- package.json | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/bun.lock b/bun.lock index 03f85758..43fb9ece 100644 --- a/bun.lock +++ b/bun.lock @@ -50,7 +50,7 @@ "expo-system-ui": "~6.0.9", "expo-task-manager": "14.0.9", "expo-web-browser": "~15.0.10", - "i18next": "^25.0.0", + "i18next": "^26.0.0", "jotai": "2.16.2", "lodash": "4.17.23", "nativewind": "^2.0.11", @@ -1208,7 +1208,7 @@ "hyphenate-style-name": ["hyphenate-style-name@1.1.0", "", {}, "sha512-WDC/ui2VVRrz3jOVi+XtjqkDjiVjTtFaAGiW37k6b+ohyQ5wYDOGkvCZa8+H0nx3gyvv0+BST9xuOgIyGQ00gw=="], - "i18next": ["i18next@25.6.1", "", { "dependencies": { "@babel/runtime": "^7.27.6" }, "peerDependencies": { "typescript": "^5" }, "optionalPeers": ["typescript"] }, "sha512-yUWvdXtalZztmKrKw3yz/AvSP3yKyqIkVPx/wyvoYy9lkLmwzItLxp0iHZLG5hfVQ539Jor4XLO+U+NHIXg7pw=="], + "i18next": ["i18next@26.2.0", "", { "peerDependencies": { "typescript": "^5 || ^6" }, "optionalPeers": ["typescript"] }, "sha512-zwBHldHdTmwN7r6UNc7lC6GWNN+YYg3DrRSeHR5PRRBf5QnJZcYHrQc0uaU26qZeYxR7iFZD+Y315dPnKP47wA=="], "iconv-lite": ["iconv-lite@0.7.2", "", { "dependencies": { "safer-buffer": ">= 2.1.2 < 3.0.0" } }, "sha512-im9DjEDQ55s9fL4EYzOAv0yMqmMBSZp6G0VvFyTMPKWxiSBHUj9NW/qqLmXUwXrrM7AvqSlTCfvqRb0cM8yYqw=="], diff --git a/package.json b/package.json index e230a342..20659183 100644 --- a/package.json +++ b/package.json @@ -70,7 +70,7 @@ "expo-system-ui": "~6.0.9", "expo-task-manager": "14.0.9", "expo-web-browser": "~15.0.10", - "i18next": "^25.0.0", + "i18next": "^26.0.0", "jotai": "2.16.2", "lodash": "4.17.23", "nativewind": "^2.0.11",