mirror of
				https://github.com/ImranR98/Obtainium.git
				synced 2025-10-31 05:23:28 +01:00 
			
		
		
		
	Compare commits
	
		
			40 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 7e9e6958a3 | ||
|  | 9de082f684 | ||
|  | b40afc7329 | ||
|  | 4fb3da45e9 | ||
|  | 1f8e051ed6 | ||
|  | adc4e7c2b4 | ||
|  | 325d2f48dc | ||
|  | aa00f42a23 | ||
|  | 62dbffab52 | ||
|  | fd38444836 | ||
|  | 71cc49a30f | ||
|  | e4187c8e17 | ||
|  | 15ae98d426 | ||
|  | 7b4fa2269e | ||
|  | 656e14793d | ||
|  | d23381147b | ||
|  | cfe184c6d5 | ||
|  | 9c16f24a08 | ||
|  | ce200403e0 | ||
|  | caca84f84d | ||
|  | ac2d7b9639 | ||
|  | 78069a9b26 | ||
|  | 3e23fffaea | ||
|  | 624b9fb6dc | ||
|  | fbd6189721 | ||
|  | 6a44fe227c | ||
|  | d1cb2688c6 | ||
|  | b43b2f9740 | ||
|  | 6288a9cb8d | ||
|  | 18c6f75054 | ||
|  | 1f8d187b84 | ||
|  | 77618ad1ff | ||
|  | 75efd335e9 | ||
|  | c4438de200 | ||
|  | e3c9a227d3 | ||
|  | 548f859349 | ||
|  | db413badec | ||
|  | dfac3af3f5 | ||
|  | 5eceaeecde | ||
|  | 62c23004f7 | 
							
								
								
									
										2
									
								
								.flutter
									
									
									
									
									
								
							
							
								
								
								
								
								
							
						
						
									
										2
									
								
								.flutter
									
									
									
									
									
								
							 Submodule .flutter updated: 761747bfc5...b0850beeb2
									
								
							
							
								
								
									
										14
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -6,7 +6,10 @@ on: | ||||
|       beta: | ||||
|         type: boolean | ||||
|         description: Is beta? | ||||
|      | ||||
|       draft: | ||||
|         type: boolean | ||||
|         description: Is draft? | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     runs-on: ubuntu-latest | ||||
| @@ -35,13 +38,7 @@ jobs: | ||||
|       - name: Check submodule | ||||
|         id: check_submodule | ||||
|         run: | | ||||
|           SUBMODULE_COMMIT_LONG="$(git submodule status | head -1 | tail -c +2 | awk '{print $1}')" | ||||
|           FLUTTER_COMMIT_SHORT="$(flutter --version | head -2 | tail -1 | awk '{print $4}')" | ||||
|           echo "SUBMODULE_COMMIT_LONG=$SUBMODULE_COMMIT_LONG, FLUTTER_COMMIT_SHORT=$FLUTTER_COMMIT_SHORT" | ||||
|           if ! [[ "$SUBMODULE_COMMIT_LONG" =~ ^$FLUTTER_COMMIT_SHORT ]]; then | ||||
|             echo "Your submodule has not been updated!" | ||||
|             exit 1 | ||||
|           fi | ||||
|           git checkout ${{ inputs.checkout }} | ||||
|  | ||||
|       - name: Extract Version | ||||
|         id: extract_version       | ||||
| @@ -92,5 +89,6 @@ jobs: | ||||
|           token: ${{ secrets.GH_ACCESS_TOKEN }} | ||||
|           tag: "${{ steps.extract_version.outputs.tag }}" | ||||
|           prerelease: "${{ steps.extract_version.outputs.beta }}" | ||||
|           draft: "${{ inputs.draft }}" | ||||
|           artifacts: ./build/app/outputs/flutter-apk/*-release*.apk* | ||||
|           generateReleaseNotes: true | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|  | ||||
| [](https://techforpalestine.org/learn-more) | ||||
|  | ||||
| Get Android App Updates Directly From the Source. | ||||
| Get Android app updates straight from the source. | ||||
|  | ||||
| Obtainium allows you to install and update apps directly from their releases pages, and receive notifications when new releases are made available. | ||||
|  | ||||
| @@ -16,7 +16,7 @@ Currently supported App sources: | ||||
| - Open Source - General: | ||||
|   - [GitHub](https://github.com/) | ||||
|   - [GitLab](https://gitlab.com/) | ||||
|   - [Codeberg](https://codeberg.org/) | ||||
|   - [Forgejo](https://forgejo.org/) ([Codeberg](https://codeberg.org/)) | ||||
|   - [F-Droid](https://f-droid.org/) | ||||
|   - Third Party F-Droid Repos | ||||
|   - [IzzyOnDroid](https://android.izzysoft.de/) | ||||
|   | ||||
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								assets/fonts/WixMadeforDisplay-Regular.otf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								assets/fonts/WixMadeforDisplay-Regular.otf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| @@ -24,7 +24,7 @@ | ||||
|     "colour": "Boja", | ||||
|     "standard": "Standard", | ||||
|     "custom": "Custom", | ||||
|     "useMaterialYou": "Use Material You", | ||||
|     "useMaterialYou": "Koristi Material You temu", | ||||
|     "githubStarredRepos": "GitHub repo-i sa zvjezdicom", | ||||
|     "uname": "Korisničko ime", | ||||
|     "wrongArgNum": "Naveden je pogrešan broj argumenata", | ||||
| @@ -113,7 +113,7 @@ | ||||
|     "dark": "Tamna", | ||||
|     "light": "Svijetla", | ||||
|     "followSystem": "Pratite sistem", | ||||
|     "followSystemThemeExplanation": "Following system theme is possible only by using third-party applications", | ||||
|     "followSystemThemeExplanation": "Praćenje sistemske teme je moguće jedino koristeći aplikacije treće strane", | ||||
|     "useBlackTheme": "Koristite čisto crnu tamnu temu", | ||||
|     "appSortBy": "Aplikacije sortirane po", | ||||
|     "authorName": "Autor/Ime", | ||||
| @@ -147,10 +147,10 @@ | ||||
|     "noNewUpdates": "Nema novih ažuriranja.", | ||||
|     "xHasAnUpdate": "{} ima ažuriranje.", | ||||
|     "appsUpdated": "Aplikacije su ažurirane", | ||||
|     "appsNotUpdated": "Failed to update applications", | ||||
|     "appsNotUpdated": "Neuspješno ažuriranje aplikacija", | ||||
|     "appsUpdatedNotifDescription": "Obavještava korisnika da su u pozadini primijenjena ažuriranja na jednu ili više aplikacija", | ||||
|     "xWasUpdatedToY": "{} je ažuriran na {}.", | ||||
|     "xWasNotUpdatedToY": "Failed to update {} to {}.", | ||||
|     "xWasNotUpdatedToY": "Neuspješno ažuriranje {} na {}.", | ||||
|     "errorCheckingUpdates": "Greška pri provjeri ažuriranja", | ||||
|     "errorCheckingUpdatesNotifDescription": "Obavijest koja se prikazuje kada provjera sigurnosnog ažuriranja ne uspije", | ||||
|     "appsRemoved": "Aplikacije su uklonjene", | ||||
| @@ -191,7 +191,7 @@ | ||||
|     "downloadingX": "Preuzimanje {}", | ||||
|     "downloadX": "Download {}", | ||||
|     "downloadedX": "Downloaded {}", | ||||
|     "releaseAsset": "Release Asset", | ||||
|     "releaseAsset": "Fajlovi verzije", | ||||
|     "downloadNotifDescription": "Obavještava korisnika o napretku u preuzimanju aplikacije", | ||||
|     "noAPKFound": "APK nije pronađen", | ||||
|     "noVersionDetection": "Nema detekcije verzije", | ||||
| @@ -253,12 +253,14 @@ | ||||
|     "verifyLatestTag": "Provjerite 'posljednu' ('latest') oznaku", | ||||
|     "intermediateLinkRegex": "Filter za 'srednju' vezu za posjetu", | ||||
|     "filterByLinkText": "Filtriraj linkove prema tekstu linka", | ||||
|     "intermediateLinkNotFound": "Intermediate link nije nađen", | ||||
|     "intermediateLink": "srednja karika", | ||||
|     "intermediateLinkNotFound": "Intermediate veza nije nađena", | ||||
|     "intermediateLink": "Intermediate veza", | ||||
|     "exemptFromBackgroundUpdates": "Izuzmi iz ažuriranja u pozadini (ako su uključeni)", | ||||
|     "bgUpdatesOnWiFiOnly": "Isključite ažuriranje u pozadini kada niste na WiFi-ju", | ||||
|     "autoSelectHighestVersionCode": "Automatski izaberite najveću (verziju) versionCode APK-a", | ||||
|     "versionExtractionRegEx": "RegEx ekstrakcija verzije", | ||||
|     "trimVersionString": "Trim Version String With RegEx", | ||||
|     "matchGroupToUseForX": "Match Group to Use for \"{}\"", | ||||
|     "matchGroupToUse": "Podjesite grupu za upotebu", | ||||
|     "highlightTouchTargets": "Istaknite manje vidljive touch mete", | ||||
|     "pickExportDir": "Izaberite datoteku za izvoz", | ||||
| @@ -288,11 +290,11 @@ | ||||
|     "supportFixedAPKURL": "Podržite fiksne APK URL-ove", | ||||
|     "selectX": "Izaberite {}", | ||||
|     "parallelDownloads": "Dozvoli paralelna preuzimanja", | ||||
|     "useShizuku": "Use Shizuku or Sui to install", | ||||
|     "shizukuBinderNotFound": "Shizuku is not running", | ||||
|     "shizukuOld": "Old Shizuku version (<11) - update it", | ||||
|     "shizukuOldAndroidWithADB": "Shizuku running on Android < 8.1 with ADB - update Android or use Sui instead", | ||||
|     "shizukuPretendToBeGooglePlay": "Set Google Play as the installation source (if Shizuku is used)", | ||||
|     "useShizuku": "Koristi Shizuku ili Sui za instaliranje", | ||||
|     "shizukuBinderNotFound": "Shizuku nije pokrenut", | ||||
|     "shizukuOld": "Stara Shizuku verzija (<11) - ažurirajte je", | ||||
|     "shizukuOldAndroidWithADB": "Shizuku pokrenut na Android-u < 8.1 pomoću ADB-a - ažurirajte Android ili koristite Sui", | ||||
|     "shizukuPretendToBeGooglePlay": "Postavi Google Play kao izvor instalacije (samo ako je Shizuku u upotrebi)", | ||||
|     "useSystemFont": "Koristite sistemski font", | ||||
|     "useVersionCodeAsOSVersion": "Koristite kod verzije aplikacije kao verziju koju je otkrio OS", | ||||
|     "requestHeader": "Zaglavlje zahtjeva", | ||||
| @@ -305,13 +307,13 @@ | ||||
|     "installed": "Instalirano", | ||||
|     "latest": "Najnoviji", | ||||
|     "invertRegEx": "Obrni regularni izraz", | ||||
|     "note": "Note", | ||||
|     "selfHostedNote": "The \"{}\" dropdown can be used to reach self-hosted/custom instances of any source.", | ||||
|     "badDownload": "The APK could not be parsed (incompatible or partial download)", | ||||
|     "beforeNewInstallsShareToAppVerifier": "Share new Apps with AppVerifier (if available)", | ||||
|     "appVerifierInstructionToast": "Share to AppVerifier, then return here when ready.", | ||||
|     "wiki": "Help/Wiki", | ||||
|     "crowdsourcedConfigsLabel": "Crowdsourced App Configurations (use at your own risk)", | ||||
|     "note": "Zabelješke", | ||||
|     "selfHostedNote": "\"{}\" padajući meni se može koristiti da dosegnete vlastite/prilagođene instance bilo kojeg izvora.", | ||||
|     "badDownload": "APK ne može biti raščlanjen (nekomaptibilno ili delimično preuzimanje)", | ||||
|     "beforeNewInstallsShareToAppVerifier": "Dijeli nove aplikacije sa AppVerifier-om (ako je dostupno)", | ||||
|     "appVerifierInstructionToast": "Dijeli sa AppVerifier-om, zatim se vratite kada ste spremni.", | ||||
|     "wiki": "Pomoć/Wiki", | ||||
|     "crowdsourcedConfigsLabel": "Konfiguracije aplikacije obezbeđene pomoću velikog broja ljudi (crowdsourcing) (koristite na svoju odgovornost)", | ||||
|     "removeAppQuestion": { | ||||
|         "one": "Želite li ukloniti aplikaciju?", | ||||
|         "other": "Želite li ukloniti aplikacije?" | ||||
| @@ -370,6 +372,6 @@ | ||||
|     }, | ||||
|     "apk": { | ||||
|         "one": "{} APK", | ||||
|         "other": "{} APKs" | ||||
|         "other": "{} APK-a" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Deaktivovat aktualizace na pozadí, pokud není k dispozici Wi-Fi", | ||||
|     "autoSelectHighestVersionCode": "Automaticky vybrat nejvyšší verzi APK", | ||||
|     "versionExtractionRegEx": "Extrakce verze pomocí RegEx", | ||||
|     "trimVersionString": "Oříznutí řetězce verze pomocí příkazu RegEx", | ||||
|     "matchGroupToUseForX": "Skupina shody, která se použije pro \"{}\"", | ||||
|     "matchGroupToUse": "Odpovídá použité skupině", | ||||
|     "highlightTouchTargets": "Zvýraznit méně zjevné cíle dotyku", | ||||
|     "pickExportDir": "Vybrat adresář pro export", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Deaktivér baggrundsopdateringer, når du ikke er på WiFi", | ||||
|     "autoSelectHighestVersionCode": "Auto-vælg højeste versionKode af APK", | ||||
|     "versionExtractionRegEx": "RegEx for versionsstrengsudtrækning", | ||||
|     "trimVersionString": "Trim versionsstrengen med RegEx", | ||||
|     "matchGroupToUseForX": "Matchgruppe til brug for \"{}\"", | ||||
|     "matchGroupToUse": "Match gruppe til brug til RegEx for versionsstrengsudtrækning", | ||||
|     "highlightTouchTargets": "Fremhæv mindre åbenlyse berøringsmål", | ||||
|     "pickExportDir": "Vælg eksportmappe", | ||||
| @@ -305,7 +307,7 @@ | ||||
|     "installed": "Installeret", | ||||
|     "latest": "Seneste", | ||||
|     "invertRegEx": "Inverter regulært udtryk", | ||||
|     "note": "Note", | ||||
|     "note": "Bemærk", | ||||
|     "selfHostedNote": "Rullemenuen \"{}\" kan bruges til at nå selvhostede/brugerdefinerede instanser af enhver kilde.", | ||||
|     "badDownload": "APK'en kunne ikke analyseres (inkompatibel eller delvis hentning)", | ||||
|     "beforeNewInstallsShareToAppVerifier": "Del nye apps med AppVerifier (hvis tilgængelig)", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Hintergrundaktualisierungen deaktivieren, wenn kein WLAN vorhanden ist", | ||||
|     "autoSelectHighestVersionCode": "Automatisch höchste APK-Version auswählen", | ||||
|     "versionExtractionRegEx": "Versions-Extraktion per RegEx", | ||||
|     "trimVersionString": "Trim Version String mit RegEx", | ||||
|     "matchGroupToUseForX": "Zu verwendende Abgleichsgruppe für \"{}\"", | ||||
|     "matchGroupToUse": "zu verwendende Gruppe abgleichen", | ||||
|     "highlightTouchTargets": "Weniger offensichtliche Touch-Ziele hervorheben", | ||||
|     "pickExportDir": "Export-Verzeichnis wählen", | ||||
| @@ -329,12 +331,12 @@ | ||||
|         "other": "Die Hintergrundaktualisierungsprüfung fand {} Aktualisierungen – benachrichtigt den Benutzer, falls erforderlich" | ||||
|     }, | ||||
|     "apps": { | ||||
|         "eine": "{} App", | ||||
|         "andere": "{} Apps" | ||||
|         "one": "{} App", | ||||
|         "other": "{} Apps" | ||||
|     }, | ||||
|     "url": { | ||||
|         "eine": "{} URL", | ||||
|         "andere": "{} URLs" | ||||
|         "one": "{} URL", | ||||
|         "other": "{} URLs" | ||||
|     }, | ||||
|     "minute": { | ||||
|         "one": "{} Minute", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Disable background updates when not on WiFi", | ||||
|     "autoSelectHighestVersionCode": "Auto-select highest versionCode APK", | ||||
|     "versionExtractionRegEx": "Version String Extraction RegEx", | ||||
|     "trimVersionString": "Trim Version String With RegEx", | ||||
|     "matchGroupToUseForX": "Match Group to Use for \"{}\"", | ||||
|     "matchGroupToUse": "Match Group to Use for Version String Extraction RegEx", | ||||
|     "highlightTouchTargets": "Highlight less obvious touch targets", | ||||
|     "pickExportDir": "Pick Export Directory", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Deshabilitar las actualizaciones en segundo plano sin WiFi", | ||||
|     "autoSelectHighestVersionCode": "Auto selección del paquete APK con versión más reciente", | ||||
|     "versionExtractionRegEx": "Versión de extracción regex", | ||||
|     "trimVersionString": "Recortar cadena de versión con RegEx", | ||||
|     "matchGroupToUseForX": "Grupo de coincidencia a utilizar para \"{}\"", | ||||
|     "matchGroupToUse": "Grupo a usar para versión de extracción regex", | ||||
|     "highlightTouchTargets": "Resaltar objetivos menos obvios", | ||||
|     "pickExportDir": "Directorio para exportar", | ||||
| @@ -333,8 +335,8 @@ | ||||
|         "other": "{} Aplicaciones" | ||||
|     }, | ||||
|     "url": { | ||||
|         "uno": "{} URL", | ||||
|         "otro": "{} URL" | ||||
|         "one": "{} URL", | ||||
|         "other": "{} URL" | ||||
|     }, | ||||
|     "minute": { | ||||
|         "one": "{} minuto", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "بهروزرسانیهای پسزمینه را در صورت عدم اتصال به WiFi غیرفعال کنید", | ||||
|     "autoSelectHighestVersionCode": "انتخاب خودکار بالاترین نسخه کد APK", | ||||
|     "versionExtractionRegEx": "نسخه استخراج RegEx", | ||||
|     "trimVersionString": "Trim Version String With RegEx", | ||||
|     "matchGroupToUseForX": "Match Group to Use for \"{}\"", | ||||
|     "matchGroupToUse": "گروه مورد استفاده را مطابقت دهید", | ||||
|     "highlightTouchTargets": "اهداف لمسی کمتر واضح را برجسته کنید", | ||||
|     "pickExportDir": "فهرست برون ریزی را انتخاب کنید", | ||||
|   | ||||
| @@ -1,86 +1,86 @@ | ||||
| { | ||||
|     "invalidURLForSource": "URL d'application {} invalide", | ||||
|     "noReleaseFound": "Impossible de trouver une version adaptée", | ||||
|     "noVersionFound": "Impossible de déterminer la variante de la version", | ||||
|     "invalidURLForSource": "URL de l'application {} n'es pas valide", | ||||
|     "noReleaseFound": "Impossible de trouver une publication correspondante", | ||||
|     "noVersionFound": "Impossible de déterminer la version de la publication", | ||||
|     "urlMatchesNoSource": "L'URL ne correspond pas à une source connue", | ||||
|     "cantInstallOlderVersion": "Impossible d'installer une ancienne version d'une application", | ||||
|     "appIdMismatch": "L'ID de paquet téléchargé ne correspond pas à l'ID de l'application existante", | ||||
|     "functionNotImplemented": "Cette classe n'a pas implémenté cette fonction", | ||||
|     "cantInstallOlderVersion": "Impossible d'installer une ancienne version de l'application", | ||||
|     "appIdMismatch": "L'ID du paquet téléchargé ne correspond pas à l'ID de l'application existante", | ||||
|     "functionNotImplemented": "Cette classe n'implémente pas cette fonction", | ||||
|     "placeholder": "Espace réservé", | ||||
|     "someErrors": "Des erreurs se sont produites", | ||||
|     "unexpectedError": "Erreur inattendue", | ||||
|     "ok": "D'accord", | ||||
|     "ok": "Ok", | ||||
|     "and": "et", | ||||
|     "githubPATLabel": "Jeton d'Accès Personnel GitHub (augmente la limite de débit)", | ||||
|     "includePrereleases": "Inclure les avant-premières", | ||||
|     "githubPATLabel": "Jeton d'accès personnel GitHub (augmente la limite de débit)", | ||||
|     "includePrereleases": "Inclure les versions préliminaires", | ||||
|     "fallbackToOlderReleases": "Retour aux anciennes versions", | ||||
|     "filterReleaseTitlesByRegEx": "Filtrer les titres de version par expression régulière", | ||||
|     "invalidRegEx": "Expression régulière invalide", | ||||
|     "noDescription": "Pas de description", | ||||
|     "noDescription": "Aucune description", | ||||
|     "cancel": "Annuler", | ||||
|     "continue": "Continuer", | ||||
|     "requiredInBrackets": "(Requis)", | ||||
|     "dropdownNoOptsError": "ERREUR : LE DÉROULEMENT DOIT AVOIR AU MOINS UNE OPT", | ||||
|     "dropdownNoOptsError": "ERREUR: LE DÉROULEMENT DOIT AVOIR AU MOINS UNE OPT", | ||||
|     "colour": "Couleur", | ||||
|     "standard": "Standard", | ||||
|     "custom": "Sur mesure", | ||||
|     "custom": "Personnalisé", | ||||
|     "useMaterialYou": "Utiliser Material You", | ||||
|     "githubStarredRepos": "Dépôts étoilés GitHub", | ||||
|     "uname": "Nom d'utilisateur", | ||||
|     "wrongArgNum": "Mauvais nombre d'arguments fournis", | ||||
|     "xIsTrackOnly": "{} est en 'Suivi uniquement'", | ||||
|     "wrongArgNum": "Nombre incorrect des arguments fournis", | ||||
|     "xIsTrackOnly": "{} est en Suivi uniquement", | ||||
|     "source": "Source", | ||||
|     "app": "Application", | ||||
|     "appsFromSourceAreTrackOnly": "Les applications de cette source sont en 'Suivi uniquement'.", | ||||
|     "youPickedTrackOnly": "Vous avez sélectionné l'option 'Suivi uniquement'.", | ||||
|     "trackOnlyAppDescription": "L'application sera suivie pour les mises à jour, mais Obtainium ne pourra pas la télécharger ou l'installer.", | ||||
|     "trackOnlyAppDescription": "L'application sera suivie pour les mises à jour, mais Obtainium ne pourra pas le télécharger ou l'installer.", | ||||
|     "cancelled": "Annulé", | ||||
|     "appAlreadyAdded": "Application déjà ajoutée", | ||||
|     "alreadyUpToDateQuestion": "Application déjà à jour ?", | ||||
|     "addApp": "Ajouter une application", | ||||
|     "appSourceURL": "URL de la source de l'application", | ||||
|     "appAlreadyAdded": "L'application a déjà été ajoutée", | ||||
|     "alreadyUpToDateQuestion": "L'application est déjà à jour ?", | ||||
|     "addApp": "Ajouter Appli", | ||||
|     "appSourceURL": "URL source de l'application", | ||||
|     "error": "Erreur", | ||||
|     "add": "Ajouter", | ||||
|     "searchSomeSourcesLabel": "Rechercher (certaines sources uniquement)", | ||||
|     "search": "Rechercher", | ||||
|     "additionalOptsFor": "Options supplémentaires pour {}", | ||||
|     "supportedSources": "Sources prises en charge ", | ||||
|     "supportedSources": "Sources prises en charge", | ||||
|     "trackOnlyInBrackets": "(Suivi uniquement)", | ||||
|     "searchableInBrackets": "(Interrogeable)", | ||||
|     "appsString": "Applications", | ||||
|     "noApps": "Aucune application", | ||||
|     "noAppsForFilter": "Aucune application pour le filtre", | ||||
|     "noApps": "Aucune applications", | ||||
|     "noAppsForFilter": "Aucune application à Filtrer", | ||||
|     "byX": "Par {}", | ||||
|     "percentProgress": "Progrès : {}%", | ||||
|     "percentProgress": "Progression: {}%", | ||||
|     "pleaseWait": "Veuillez patienter", | ||||
|     "updateAvailable": "Mise à jour disponible", | ||||
|     "notInstalled": "Non installé", | ||||
|     "pseudoVersion": "pseudo-version", | ||||
|     "pseudoVersion": "Version fictive", | ||||
|     "selectAll": "Tout sélectionner", | ||||
|     "deselectX": "Déselectionner {}", | ||||
|     "xWillBeRemovedButRemainInstalled": "{} sera supprimé d'Obtainium mais restera installé sur l'appareil.", | ||||
|     "removeSelectedAppsQuestion": "Supprimer les applications sélectionnées ?", | ||||
|     "removeSelectedApps": "Supprimer les applications sélectionnées", | ||||
|     "xWillBeRemovedButRemainInstalled": "{} sera supprimée d'Obtainium mais restera installée sur l'appareil.", | ||||
|     "removeSelectedAppsQuestion": "Supprimer les applications sélectionnées ?", | ||||
|     "removeSelectedApps": "Les applications sélectionnées ont étés supprimés", | ||||
|     "updateX": "Mise à jour {}", | ||||
|     "installX": "Installer {}", | ||||
|     "markXTrackOnlyAsUpdated": "Marquer {}\n(Suivi uniquement)\n comme mis à jour", | ||||
|     "markXTrackOnlyAsUpdated": "Marquer {}\n(Suivi uniquement)\ncomme étant à jour", | ||||
|     "changeX": "Changer {}", | ||||
|     "installUpdateApps": "Installer/Mettre à jour les applications", | ||||
|     "installUpdateSelectedApps": "Installer/Mettre à jour les applications sélectionnées", | ||||
|     "markXSelectedAppsAsUpdated": "Marquer {} les applications sélectionnées comme étant à jour ?", | ||||
|     "markXSelectedAppsAsUpdated": "Marquer les {} applications sélectionnées comme étant à jour ?", | ||||
|     "no": "Non", | ||||
|     "yes": "Oui", | ||||
|     "markSelectedAppsUpdated": "Marquer les applications sélectionnées comme étant à jour", | ||||
|     "markSelectedAppsUpdated": "Les applications sélectionnées sont marqués comme étant à jour", | ||||
|     "pinToTop": "Épingler en haut", | ||||
|     "unpinFromTop": "Désépingler du haut", | ||||
|     "resetInstallStatusForSelectedAppsQuestion": "Réinitialiser le statut d'installation des applications sélectionnées ?", | ||||
|     "installStatusOfXWillBeResetExplanation": "Le statut d'installation de toutes les applications sélectionnées sera réinitialisé.\n\nCela peut aider lorsque la version de l'application affichée dans Obtainium est incorrecte en raison d'échecs de mises à jour ou d'autres problèmes.", | ||||
|     "resetInstallStatusForSelectedAppsQuestion": "Réinitialiser l'état d'installation des applications sélectionnées ?", | ||||
|     "installStatusOfXWillBeResetExplanation": "L'état d'installation de toutes les applications sélectionnées sera réinitialisé.\n\nCela peut être utile lorsque la version de l'application affichée dans Obtainium est incorrecte en raison de l'échec des mises à jour ou d'autres problèmes.", | ||||
|     "customLinkMessage": "Ces liens fonctionnent sur les appareils sur lesquels Obtainium est installé", | ||||
|     "shareAppConfigLinks": "Partager la configuration de l'application sous forme de lien HTML", | ||||
|     "shareSelectedAppURLs": "Partager les URL d'applications sélectionnées", | ||||
|     "resetInstallStatus": "Réinitialiser le statut d'installation", | ||||
|     "shareSelectedAppURLs": "Partager les URL des applications sélectionnées", | ||||
|     "resetInstallStatus": "L'état d'installation des applications ont étés réinitialisés", | ||||
|     "more": "Plus", | ||||
|     "removeOutdatedFilter": "Supprimer le filtre d'application obsolète", | ||||
|     "removeOutdatedFilter": "Supprimer le filtre des applications obsolètes", | ||||
|     "showOutdatedOnly": "Afficher uniquement les applications obsolètes", | ||||
|     "filter": "Filtre", | ||||
|     "filterApps": "Filtrer les applications", | ||||
| @@ -89,78 +89,78 @@ | ||||
|     "upToDateApps": "Applications à jour", | ||||
|     "nonInstalledApps": "Applications non installées", | ||||
|     "importExport": "Importer/Exporter", | ||||
|     "settings": "Paramètres", | ||||
|     "settings": "Paramètre", | ||||
|     "exportedTo": "Exporté vers {}", | ||||
|     "obtainiumExport": "Exporter d'Obtainium", | ||||
|     "obtainiumExport": "Exporter Obtainium", | ||||
|     "invalidInput": "Entrée invalide", | ||||
|     "importedX": "Importé {}", | ||||
|     "obtainiumImport": "Importer d'Obtainium", | ||||
|     "importFromURLList": "Importer à partir de la liste d'URL", | ||||
|     "searchQuery": "Requête", | ||||
|     "appURLList": "Liste d'URL d'application", | ||||
|     "obtainiumImport": "Importer Obtainium", | ||||
|     "importFromURLList": "Importer depuis une liste d'URL", | ||||
|     "searchQuery": "Requête de recherche", | ||||
|     "appURLList": "Liste d'URL de l'application", | ||||
|     "line": "File d'attente", | ||||
|     "searchX": "Rechercher {}", | ||||
|     "noResults": "Aucun résultat trouvé", | ||||
|     "noResults": "Aucun résultat", | ||||
|     "importX": "Importer {}", | ||||
|     "importedAppsIdDisclaimer": "Les applications importées peuvent s'afficher à tort comme \"Non installées\".\nPour résoudre ce problème, réinstallez-les via Obtainium.\nCela ne devrait pas affecter les données de l'application.\n\nN'affecte que les URL et les méthodes d'importation tierces.", | ||||
|     "importedAppsIdDisclaimer": "Les applications importées peuvent s'afficher de manière incorrecte comme \"Non installées\".\nPour résoudre ce problème, réinstallez-les via Obtainium.\nCela n'affectera pas les données des applications. Cela n'affecte que la méthode d'importation par URL et par des tiers.", | ||||
|     "importErrors": "Erreurs d'importation", | ||||
|     "importedXOfYApps": "{} sur {} applications importées.", | ||||
|     "followingURLsHadErrors": "Les URL suivantes comportaient des erreurs :", | ||||
|     "selectURL": "Sélectionnez l'URL", | ||||
|     "selectURLs": "Sélectionnez les URL", | ||||
|     "pick": "Prendre", | ||||
|     "importedXOfYApps": "{} applications sur {} ont étés importées.", | ||||
|     "followingURLsHadErrors": "Les URL suivants comportent des erreurs :", | ||||
|     "selectURL": "Sélectionner l'URL", | ||||
|     "selectURLs": "Sélectionner les URL", | ||||
|     "pick": "Choisir", | ||||
|     "theme": "Thème", | ||||
|     "dark": "Sombre", | ||||
|     "light": "Clair", | ||||
|     "followSystem": "Suivre le système", | ||||
|     "followSystemThemeExplanation": "Il n'est possible de suivre le thème du système qu'en utilisant des applications tierces.", | ||||
|     "followSystem": "Correspondre au système", | ||||
|     "followSystemThemeExplanation": "Correspondre au thème du système est possible en utilisant des applications tierces.", | ||||
|     "useBlackTheme": "Utiliser le thème noir pur", | ||||
|     "appSortBy": "Applications triées par", | ||||
|     "appSortBy": "Trier les applications par", | ||||
|     "authorName": "Auteur/Nom", | ||||
|     "nameAuthor": "Nom/Auteur", | ||||
|     "asAdded": "Comme ajouté", | ||||
|     "asAdded": "Date d'ajout", | ||||
|     "appSortOrder": "Ordre de tri des applications", | ||||
|     "ascending": "Ascendant", | ||||
|     "descending": "Descendant", | ||||
|     "bgUpdateCheckInterval": "Intervalle de vérification des mises à jour en arrière-plan", | ||||
|     "neverManualOnly": "Jamais — Manuel uniquement", | ||||
|     "bgUpdateCheckInterval": "Intervalle de recherche de mises à jour en arrière-plan", | ||||
|     "neverManualOnly": "Jamais - Manuellement uniquement", | ||||
|     "appearance": "Apparence", | ||||
|     "showWebInAppView": "Afficher la page Web source dans la vue de l'application", | ||||
|     "pinUpdates": "Épingler les mises à jour en tête de la vue Applications", | ||||
|     "pinUpdates": "Épingler les mises à jour en haut de la vue de l'applications", | ||||
|     "updates": "Mises à jour", | ||||
|     "sourceSpecific": "Spécifique à la source", | ||||
|     "appSource": "Source de l'application", | ||||
|     "noLogs": "Aucun journal", | ||||
|     "appLogs": "Journaux d'application", | ||||
|     "appLogs": "Journaux d'applications", | ||||
|     "close": "Fermer", | ||||
|     "share": "Partager", | ||||
|     "appNotFound": "Application introuvable", | ||||
|     "obtainiumExportHyphenatedLowercase": "Exportation-Obtainium", | ||||
|     "pickAnAPK": "Choisissez un APK", | ||||
|     "appHasMoreThanOnePackage": "{} a plus d'un paquet :", | ||||
|     "obtainiumExportHyphenatedLowercase": "export-obtainium", | ||||
|     "pickAnAPK": "Selectionner une APK", | ||||
|     "appHasMoreThanOnePackage": "{} a plus d'un paquet :", | ||||
|     "deviceSupportsXArch": "Votre appareil prend en charge l'architecture CPU {}.", | ||||
|     "deviceSupportsFollowingArchs": "Votre appareil prend en charge les architectures CPU suivantes :", | ||||
|     "deviceSupportsFollowingArchs": "Votre appareil prend en charge les architectures CPU suivantes :", | ||||
|     "warning": "Avertissement", | ||||
|     "sourceIsXButPackageFromYPrompt": "La source de l'application est '{}' mais la version du paquet provient de '{}'. Continuer ?", | ||||
|     "sourceIsXButPackageFromYPrompt": "La source de l'application est '{}' mais le paquet de mise à jour provient de '{}'. Continuer ?", | ||||
|     "updatesAvailable": "Mises à jour disponibles", | ||||
|     "updatesAvailableNotifDescription": "Avertit l'utilisateur que des mises à jour sont disponibles pour une ou plusieurs applications suivies par Obtainium", | ||||
|     "updatesAvailableNotifDescription": "Notifie à l'utilisateur que des mises à jour sont disponibles pour une ou plusieurs applications suivies par Obtainium.", | ||||
|     "noNewUpdates": "Aucune nouvelle mise à jour.", | ||||
|     "xHasAnUpdate": "{} a une mise à jour.", | ||||
|     "appsUpdated": "Applications mises à jour", | ||||
|     "appsNotUpdated": "Échec de la mise à jour des applications", | ||||
|     "appsUpdatedNotifDescription": "Avertit l'utilisateur que les mises à jour d'une ou plusieurs applications ont été appliquées en arrière-plan", | ||||
|     "xWasUpdatedToY": "{} a été mis à jour pour {}.", | ||||
|     "appsUpdatedNotifDescription": "Notifie à l'utilisateur que des mises à jour d'une ou plusieurs applications ont été installés en arrière-plan.", | ||||
|     "xWasUpdatedToY": "{} a été mis à jour en {}.", | ||||
|     "xWasNotUpdatedToY": "Échec de la mise à jour de {} vers {}.", | ||||
|     "errorCheckingUpdates": "Erreur lors de la vérification des mises à jour", | ||||
|     "errorCheckingUpdatesNotifDescription": "Une notification qui s'affiche lorsque la vérification de la mise à jour en arrière-plan échoue", | ||||
|     "errorCheckingUpdates": "Erreur lors de la recherche de mises à jour", | ||||
|     "errorCheckingUpdatesNotifDescription": "Notifie l'utilisateur lorsque la recherche de mises à jour en arrière-plan échoue.", | ||||
|     "appsRemoved": "Applications supprimées", | ||||
|     "appsRemovedNotifDescription": "Avertit l'utilisateur qu'une ou plusieurs applications ont été supprimées en raison d'erreurs lors de leur chargement", | ||||
|     "xWasRemovedDueToErrorY": "{} a été supprimé en raison de cette erreur : {}", | ||||
|     "appsRemovedNotifDescription": "Notifie à l'utilisateur qu'une ou plusieurs applications ont été supprimées en raison d'erreurs lors de leur chargement.", | ||||
|     "xWasRemovedDueToErrorY": "{} a été supprimée en raison de cette erreur : {}", | ||||
|     "completeAppInstallation": "Installation complète de l'application", | ||||
|     "obtainiumMustBeOpenToInstallApps": "Obtainium doit être ouvert pour installer des applications", | ||||
|     "obtainiumMustBeOpenToInstallApps": "Obtainium doit être ouvert pour installer les applications", | ||||
|     "completeAppInstallationNotifDescription": "Demande à l'utilisateur de retourner sur Obtainium pour terminer l'installation d'une application", | ||||
|     "checkingForUpdates": "Vérification des mises à jour", | ||||
|     "checkingForUpdatesNotifDescription": "Notification transitoire qui apparaît lors de la recherche de mises à jour", | ||||
|     "checkingForUpdates": "Recherche de mises à jour", | ||||
|     "checkingForUpdatesNotifDescription": "Notification temporaire qui apparaît lors de la recherche de mises à jour", | ||||
|     "pleaseAllowInstallPerm": "Veuillez autoriser Obtainium à installer des applications", | ||||
|     "trackOnly": "Suivi uniquement", | ||||
|     "errorWithHttpStatusCode": "Erreur {}", | ||||
| @@ -168,165 +168,167 @@ | ||||
|     "unknown": "Inconnu", | ||||
|     "none": "Aucun", | ||||
|     "never": "Jamais", | ||||
|     "latestVersionX": "Dernière version : {}", | ||||
|     "installedVersionX": "Version installée : {}", | ||||
|     "lastUpdateCheckX": "Vérification de la dernière mise à jour : {}", | ||||
|     "latestVersionX": "Dernière version : {}", | ||||
|     "installedVersionX": "Version installée : {}", | ||||
|     "lastUpdateCheckX": "Dernière recherche de mises à jour : {}", | ||||
|     "remove": "Retirer", | ||||
|     "yesMarkUpdated": "Oui, marquer comme mis à jour", | ||||
|     "yesMarkUpdated": "Oui, Marquer comme étant à jour", | ||||
|     "fdroid": "F-Droid Officiel", | ||||
|     "appIdOrName": "ID ou nom de l'application", | ||||
|     "appId": "ID de l'application", | ||||
|     "appWithIdOrNameNotFound": "Aucune application n'a été trouvée avec cet identifiant ou ce nom", | ||||
|     "reposHaveMultipleApps": "Les dépôts peuvent contenir plusieurs applications", | ||||
|     "fdroidThirdPartyRepo": "Dépôt tiers F-Droid", | ||||
|     "steamMobile": "Application mobile Steam", | ||||
|     "steamMobile": "Steam Mobile", | ||||
|     "steamChat": "Steam Chat", | ||||
|     "install": "Installer", | ||||
|     "markInstalled": "Marquer comme installée", | ||||
|     "markInstalled": "Marquer comme étant installé", | ||||
|     "update": "Mettre à jour", | ||||
|     "markUpdated": "Marquer comme étant à jour", | ||||
|     "additionalOptions": "Options additionnelles", | ||||
|     "disableVersionDetection": "Désactiver la détection de version", | ||||
|     "noVersionDetectionExplanation": "Cette option être utilisée uniquement pour les applications où la détection de version ne fonctionne pas correctement.", | ||||
|     "additionalOptions": "Options supplémentaires", | ||||
|     "disableVersionDetection": "Désactiver la détection de la version", | ||||
|     "noVersionDetectionExplanation": "Cette option ne doit être utilisée que pour les applications où la détection de la version ne fonctionne pas correctement.", | ||||
|     "downloadingX": "Téléchargement {}", | ||||
|     "downloadX": "Télécharger {}", | ||||
|     "downloadedX": "Téléchargé {}", | ||||
|     "releaseAsset": "Actif libéré", | ||||
|     "downloadNotifDescription": "Avertit l'utilisateur de la progression du téléchargement d'une application", | ||||
|     "releaseAsset": "Version actif", | ||||
|     "downloadNotifDescription": "Notifie l'utilisateur sur l'avancement du téléchargement d'une application", | ||||
|     "noAPKFound": "Aucun APK trouvé", | ||||
|     "noVersionDetection": "Aucune de détection de version", | ||||
|     "noVersionDetection": "Aucune version trouvée", | ||||
|     "categorize": "Catégoriser", | ||||
|     "categories": "Catégories", | ||||
|     "category": "Catégorie", | ||||
|     "noCategory": "Aucune catégorie", | ||||
|     "noCategories": "Aucune catégories", | ||||
|     "deleteCategoriesQuestion": "Supprimer les catégories ?", | ||||
|     "categoryDeleteWarning": "Toutes les applications dans les catégories supprimées ne seront plus catégorisées.", | ||||
|     "noCategory": "Aucune Catégorie", | ||||
|     "noCategories": "Aucune Catégories", | ||||
|     "deleteCategoriesQuestion": "Supprimer les Catégories ?", | ||||
|     "categoryDeleteWarning": "Toutes les applications des catégories supprimées seront définies comme non catégorisées.", | ||||
|     "addCategory": "Ajouter une catégorie", | ||||
|     "label": "Étiquette", | ||||
|     "label": "Nom", | ||||
|     "language": "Langue", | ||||
|     "copiedToClipboard": "Copié dans le presse-papier", | ||||
|     "storagePermissionDenied": "Autorisation de stockage refusée", | ||||
|     "selectedCategorizeWarning": "Cela remplacera toutes les catégorie définies pour les applications sélectionnées.", | ||||
|     "storagePermissionDenied": "Permission de stockage refusée", | ||||
|     "selectedCategorizeWarning": "Cela remplacera toutes les catégories définies pour les applications sélectionnées.", | ||||
|     "filterAPKsByRegEx": "Filtrer les APK par expression régulière", | ||||
|     "removeFromObtainium": "Supprimer d'Obtainium", | ||||
|     "uninstallFromDevice": "Désinstaller de l'appareil", | ||||
|     "onlyWorksWithNonVersionDetectApps": "Fonctionne uniquement pour les applications avec la détection de version désactivée.", | ||||
|     "onlyWorksWithNonVersionDetectApps": "Ne fonctionne que pour les applications dont la détection de la version est désactivée.", | ||||
|     "releaseDateAsVersion": "Utiliser la date de sortie comme version", | ||||
|     "releaseDateAsVersionExplanation": "Cette option ne doit être utilisée que pour les applications où la détection de version ne fonctionne pas correctement, mais dont une date de sortie est disponible.", | ||||
|     "changes": "Changements", | ||||
|     "releaseDateAsVersionExplanation": "Cette option ne doit être utilisée que pour les applications pour lesquelles la détection de la version ne fonctionne pas correctement, mais pour lesquelles une date de sortie est disponible.", | ||||
|     "changes": "Correctifs", | ||||
|     "releaseDate": "Date de sortie", | ||||
|     "importFromURLsInFile": "Importer à partir d'URL dans un fichier (comme OPML)", | ||||
|     "versionDetectionExplanation": "Réconcilier la chaîne de version avec la version détectée à partir du système d'exploitation", | ||||
|     "versionDetection": "Détection des versions", | ||||
|     "standardVersionDetection": "Détection de version standard", | ||||
|     "groupByCategory": "Regrouper par catégorie", | ||||
|     "autoApkFilterByArch": "Si possible, essayer de filtrer les APK par architecture CPU", | ||||
|     "importFromURLsInFile": "Importer à partir des URLs d'un fichier (Comme OPML)", | ||||
|     "versionDetectionExplanation": "Reporter la chaîne de version par la version détectée par le système d'exploitation", | ||||
|     "versionDetection": "Détection de la version", | ||||
|     "standardVersionDetection": "Détection de la version standard", | ||||
|     "groupByCategory": "Grouper par Catégorie", | ||||
|     "autoApkFilterByArch": "Essayer de filtrer les APKs par architecture CPU si possible", | ||||
|     "overrideSource": "Remplacer la source", | ||||
|     "dontShowAgain": "Ne plus montrer", | ||||
|     "dontShowTrackOnlyWarnings": "Ne pas afficher l'avertissement 'Suivi uniquement'", | ||||
|     "dontShowAPKOriginWarnings": "Ne pas afficher les avertissements sur l'origine de l'APK", | ||||
|     "moveNonInstalledAppsToBottom": "Déplacer les applications non installées vers le bas de la vue Applications", | ||||
|     "dontShowAgain": "Ne plus afficher", | ||||
|     "dontShowTrackOnlyWarnings": "Ne plus afficher les erreurs 'Suivi uniquement'", | ||||
|     "dontShowAPKOriginWarnings": "Ne plus afficher les erreurs sur l'origine de l'APK", | ||||
|     "moveNonInstalledAppsToBottom": "Déplacer les applications non installés vers le bas de la vue Applications", | ||||
|     "gitlabPATLabel": "Jeton d'accès personnel GitLab", | ||||
|     "about": "À propos de", | ||||
|     "requiresCredentialsInSettings": "{} : Cela nécessite des identifiants supplémentaires (dans Paramètres)", | ||||
|     "checkOnStart": "Vérifier les mises à jour au démarrage", | ||||
|     "tryInferAppIdFromCode": "Essayer de déduire l'ID de l'application à partir du code source", | ||||
|     "removeOnExternalUninstall": "Supprimer automatiquement les applications désinstallées depuis l'extérieur", | ||||
|     "pickHighestVersionCode": "Sélectionner automatiquement le code de version de l'APK la plus élevée", | ||||
|     "checkUpdateOnDetailPage": "Vérifier les mises à jour lors de l'ouverture de la page détaillée d'une application", | ||||
|     "about": "À propos", | ||||
|     "requiresCredentialsInSettings": "{} a besoin d'un complément d'information (dans les Paramètres)", | ||||
|     "checkOnStart": "Rechercher les mises à jour au démarrage", | ||||
|     "tryInferAppIdFromCode": "Essayer de déduire l'identifiant de l'application à partir du code source", | ||||
|     "removeOnExternalUninstall": "Supprimer automatiquement les applications désinstallées de l'extérieur", | ||||
|     "pickHighestVersionCode": "Sélectionner automatiquement la version la plus récente du code APK", | ||||
|     "checkUpdateOnDetailPage": "Rechercher les mises à jour lors de l'ouverture de la page détaillée d'une application", | ||||
|     "disablePageTransitions": "Désactiver les animations de transition de page", | ||||
|     "reversePageTransitions": "Inverser les animations de transition de page", | ||||
|     "minStarCount": "Nombre minimum d'étoiles", | ||||
|     "addInfoBelow": "Ajoutez ces informations ci-dessous.", | ||||
|     "addInfoInSettings": "Ajoutez ces informations dans les paramètres.", | ||||
|     "githubSourceNote": "La limite de débit GitHub peut être évitée à l'aide d'une clé API.", | ||||
|     "sortByLastLinkSegment": "Trier uniquement sur le dernier segment du lien", | ||||
|     "addInfoBelow": "Ajoutez cette information ci-dessous.", | ||||
|     "addInfoInSettings": "Ajoutez cette information dans les paramètres.", | ||||
|     "githubSourceNote": "La limitation du débit de GitHub peut être évitée à l'aide d'une clé d'API.", | ||||
|     "sortByLastLinkSegment": "Trier par le dernier segment du lien", | ||||
|     "filterReleaseNotesByRegEx": "Filtrer les notes de version par expression régulière", | ||||
|     "customLinkFilterRegex": "Filtre du lien APK personnalisé par expression régulière (par défaut '.apk$')", | ||||
|     "appsPossiblyUpdated": "Tentative de mise à jour de l'application", | ||||
|     "appsPossiblyUpdatedNotifDescription": "Avertit l'utilisateur que des mises à jour d'une ou plusieurs applications ont été potentiellement appliquées en arrière-plan", | ||||
|     "xWasPossiblyUpdatedToY": "{} pourrait avoir été mis à jour vers {}.", | ||||
|     "customLinkFilterRegex": "Filtre de lien APK personnalisé par expression régulière (par défaut '.apk$')", | ||||
|     "appsPossiblyUpdated": "Tentative de mise à jour des applications", | ||||
|     "appsPossiblyUpdatedNotifDescription": "Notifie à l'utilisateur que des mises à jour d'une ou plusieurs applications ont potentiellement été appliquées en arrière-plan", | ||||
|     "xWasPossiblyUpdatedToY": "{} peut être mis à jour en {}.", | ||||
|     "enableBackgroundUpdates": "Activer les mises à jour en arrière-plan", | ||||
|     "backgroundUpdateReqsExplanation": "Les mises à jour en arrière-plan peuvent ne pas être possibles pour toutes les applications.", | ||||
|     "backgroundUpdateLimitsExplanation": "Le succès d'une installation en arrière-plan ne peut être déterminé qu'à l'ouverture d'Obtainium.", | ||||
|     "backgroundUpdateLimitsExplanation": "Le résultat d'une installation en arrière-plan ne peut être déterminé qu'à l'ouverture d'Obtainium.", | ||||
|     "verifyLatestTag": "Vérifier la balise 'latest'", | ||||
|     "intermediateLinkRegex": " Filtrer un lien \" intermédiaire \" à visiter ", | ||||
|     "filterByLinkText": "Filtrer les liens par le texte du lien", | ||||
|     "intermediateLinkRegex": "Filtrer un lien 'intermédiaire' à visiter", | ||||
|     "filterByLinkText": "Filtrer les liens par texte du lien", | ||||
|     "intermediateLinkNotFound": "Lien intermédiaire introuvable", | ||||
|     "intermediateLink": "Lien intermédiaire", | ||||
|     "exemptFromBackgroundUpdates": "Exempté des mises à jour en arrière-plan (si activé)", | ||||
|     "bgUpdatesOnWiFiOnly": "Désactiver les mises à jour en arrière-plan lorsque vous n'êtes pas connecté au WiFi", | ||||
|     "autoSelectHighestVersionCode": "Sélection automatique du code de version le plus élevé de l'APK", | ||||
|     "versionExtractionRegEx": "Expression régulière d'extraction de version", | ||||
|     "matchGroupToUse": "Groupe de correspondance pour l'expression régulière d'extraction de version", | ||||
|     "highlightTouchTargets": "Mettre en évidence les cibles tactiles moins évidentes", | ||||
|     "pickExportDir": "Choisir le répertoire d'exportation", | ||||
|     "autoExportOnChanges": "Exporter automatiquement après modification", | ||||
|     "exemptFromBackgroundUpdates": "Exclure de la mise à jour en arrière-plan (si activé)", | ||||
|     "bgUpdatesOnWiFiOnly": "Désactiver les mises à jour en arrière-plan lorsque vous n'êtes pas en WiFi", | ||||
|     "autoSelectHighestVersionCode": "Sélectionner automatiquement la version la plus récente du code APK", | ||||
|     "versionExtractionRegEx": "Extraire la version par Expression régulière", | ||||
|     "trimVersionString": "Découper la version par Expression régulière", | ||||
|     "matchGroupToUseForX": "Groupe de correspondance à utiliser pour \"{}\"", | ||||
|     "matchGroupToUse": "Groupe de correspondance à utiliser pour l'extraction de la version par Expression régulière", | ||||
|     "highlightTouchTargets": "Mettre en évidence les touches moins évidentes", | ||||
|     "pickExportDir": "Selectionner le dossier pour l'exportation", | ||||
|     "autoExportOnChanges": "Exportation automatique lors de modification", | ||||
|     "includeSettings": "Inclure les paramètres", | ||||
|     "filterVersionsByRegEx": "Filtrer les versions par expression régulière", | ||||
|     "trySelectingSuggestedVersionCode": "Essayer de sélectionner le code de la version suggérée de l'APK", | ||||
|     "dontSortReleasesList": "Conserver l'ordre des versions de l'API", | ||||
|     "trySelectingSuggestedVersionCode": "Essayez de sélectionner la version suggérée du Code APK", | ||||
|     "dontSortReleasesList": "Conserver l'ordre de la version de l'API", | ||||
|     "reverseSort": "Tri inversé", | ||||
|     "takeFirstLink": "Prendre le premier lien", | ||||
|     "skipSort": "Éviter le tri", | ||||
|     "debugMenu": "Menu de débogage", | ||||
|     "bgTaskStarted": "Tâche en arrière-plan démarrée — vérifier les journaux.", | ||||
|     "runBgCheckNow": "Exécuter maintenant la vérification de la mise à jour en arrière-plan", | ||||
|     "versionExtractWholePage": "Appliquer l'expression régulière d'extraction de version sur l'ensemble de la page", | ||||
|     "takeFirstLink": "Utiliser le premier lien", | ||||
|     "skipSort": "Ignorer le tri", | ||||
|     "debugMenu": "Menu de déboggage", | ||||
|     "bgTaskStarted": "Tâche en arrière plan démarrée - vérifier les journaux.", | ||||
|     "runBgCheckNow": "Exécuter la recherche de la mise à jour en l'arrière-plan maintenant", | ||||
|     "versionExtractWholePage": "Appliquer l'extraction de la version par expression régulière à l'ensemble de la page", | ||||
|     "installing": "Installation", | ||||
|     "skipUpdateNotifications": "Ignorer les notifications de mise à jour", | ||||
|     "updatesAvailableNotifChannel": "Mises à jour disponibles", | ||||
|     "appsUpdatedNotifChannel": "Applications mises à jour", | ||||
|     "appsPossiblyUpdatedNotifChannel": "Tentative de mise à jour de l'application", | ||||
|     "errorCheckingUpdatesNotifChannel": "Erreur lors de la vérification des mises à jour", | ||||
|     "appsPossiblyUpdatedNotifChannel": "Essayer de mettre à jour les applications", | ||||
|     "errorCheckingUpdatesNotifChannel": "Erreur lors de la recherche de mises à jour", | ||||
|     "appsRemovedNotifChannel": "Applications supprimées", | ||||
|     "downloadingXNotifChannel": "Téléchargement {}", | ||||
|     "completeAppInstallationNotifChannel": "Installation complète de l'application", | ||||
|     "checkingForUpdatesNotifChannel": "Vérification des mises à jour", | ||||
|     "onlyCheckInstalledOrTrackOnlyApps": "Vérifier uniquement les mises à jour des applications installées et 'Suivi uniquement'", | ||||
|     "checkingForUpdatesNotifChannel": "Recherche de mises à jour", | ||||
|     "onlyCheckInstalledOrTrackOnlyApps": "Rechercher uniquement les mises à jour des applications installées et des applications 'Suivi uniquement'", | ||||
|     "supportFixedAPKURL": "Prise en charge des URL APK fixes", | ||||
|     "selectX": "Sélectionner {}", | ||||
|     "parallelDownloads": "Autoriser le téléchargement en parallèle", | ||||
|     "selectX": "Selectionner {}", | ||||
|     "parallelDownloads": "Autoriser les téléchargements simultanés", | ||||
|     "useShizuku": "Utiliser Shizuku ou Sui pour l'installation", | ||||
|     "shizukuBinderNotFound": "Service Shizuku compatible non trouvé", | ||||
|     "shizukuOld": "Ancienne version de Shizuku (<11) — la mettre à jour", | ||||
|     "shizukuOldAndroidWithADB": "Shizuku fonctionne sur Android < 8.1 avec ADB — mettez à jour Android ou utilisez Sui à la place", | ||||
|     "shizukuBinderNotFound": "Le service Shizuku n'es pas démarré", | ||||
|     "shizukuOld": "Ancienne version de Shizuku (<11) - veuillez le mettre à jour", | ||||
|     "shizukuOldAndroidWithADB": "Shizuku fonctionne sur Android < 8.1 avec ADB - veuillez mettre à jour Android ou utiliser Sui à la place", | ||||
|     "shizukuPretendToBeGooglePlay": "Définir Google Play comme source d'installation (si Shizuku est utilisé)", | ||||
|     "useSystemFont": "Utiliser la police du système", | ||||
|     "useVersionCodeAsOSVersion": "Utiliser le code de version de l'application comme version détectée par le système d'exploitation", | ||||
|     "requestHeader": "En-tête de demande", | ||||
|     "useLatestAssetDateAsReleaseDate": "Utiliser le dernier élément téléversé comme date de sortie", | ||||
|     "defaultPseudoVersioningMethod": "Méthode de pseudo-version par défaut", | ||||
|     "partialAPKHash": "Hash APK partiel", | ||||
|     "APKLinkHash": "Hash de lien APK", | ||||
|     "directAPKLink": "Lien APK direct", | ||||
|     "pseudoVersionInUse": "Une pseudo-version est utilisée", | ||||
|     "useVersionCodeAsOSVersion": "Utiliser le code de version de l'application détectée par le système d'exploitation", | ||||
|     "requestHeader": "Intitulé de la demande", | ||||
|     "useLatestAssetDateAsReleaseDate": "Utiliser le dernier élément mis en ligne comme date de sortie", | ||||
|     "defaultPseudoVersioningMethod": "Methode de version fictive par défaut", | ||||
|     "partialAPKHash": "Hash partiel de l'APK", | ||||
|     "APKLinkHash": "Hash du lien APK", | ||||
|     "directAPKLink": "Lien direct de l'APK", | ||||
|     "pseudoVersionInUse": "Une version fictive est utilisé", | ||||
|     "installed": "Installée", | ||||
|     "latest": "Dernier", | ||||
|     "latest": "Latest", | ||||
|     "invertRegEx": "Inverser l'expression régulière", | ||||
|     "note": "Note", | ||||
|     "selfHostedNote": "La liste déroulante \"{}\" peut être utilisée pour accéder aux instances auto-hébergées/personnalisées de n'importe quelle source.", | ||||
|     "selfHostedNote": "La liste déroulante \"{}\" peut être utilisé pour accéder à des instances auto-hébergées/personnalisées de n'importe quelle source.", | ||||
|     "badDownload": "L'APK n'a pas pu être analysé (téléchargement incompatible ou partiel)", | ||||
|     "beforeNewInstallsShareToAppVerifier": "Partager les nouvelles applications avec AppVerifier (si disponible)", | ||||
|     "appVerifierInstructionToast": "Partagez avec AppVerifier, puis revenez ici lorsque vous êtes prêt.", | ||||
|     "appVerifierInstructionToast": "Partagez avec AppVerifier, puis revenez ici lorsque tout est prêt.", | ||||
|     "wiki": "Aide/Wiki", | ||||
|     "crowdsourcedConfigsLabel": "Configurations d'applications participative (utilisation à vos risques et périls)", | ||||
|     "crowdsourcedConfigsLabel": "Configurations d'applications par la communauté (à utiliser à vos risques et périls)", | ||||
|     "removeAppQuestion": { | ||||
|         "one": "Supprimer l'application ?", | ||||
|         "other": "Supprimer les applications ?" | ||||
|     }, | ||||
|     "tooManyRequestsTryAgainInMinutes": { | ||||
|         "one": "Trop de demandes (taux limité) — réessayez dans {} minute", | ||||
|         "other": "Trop de demandes (taux limité) — réessayez dans {} minutes" | ||||
|         "one": "Trop de requêtes (taux limité) - réessayez dans {} minute", | ||||
|         "other": "Trop de requêtes (taux limité) - réessayez dans {} minutes" | ||||
|     }, | ||||
|     "bgUpdateGotErrorRetryInMinutes": { | ||||
|         "one": "La vérification de la mise à jour en arrière-plan a rencontré un {}, une nouvelle tentative de vérification sera planifié dans {} minute", | ||||
|         "other": "La vérification de la mise à jour en arrière-plan a rencontré un {}, une nouvelle tentative de vérification sera planifié dans {} minutes" | ||||
|         "one": "La recherche de mise à jour en arrière-plan a rencontré un {}, une nouvelle tentative programmée dans {} minute", | ||||
|         "other": "La recherche de mise à jour en arrière-plan a rencontré un {}, une nouvelle tentative programmée dans {} minutes" | ||||
|     }, | ||||
|     "bgCheckFoundUpdatesWillNotifyIfNeeded": { | ||||
|         "one": "La vérification des mises à jour en arrière-plan a trouvée {} mise à jour — l'utilisateur sera notifié si nécessaire", | ||||
|         "other": "La vérification des mises à jour en arrière-plan a trouvée {} mises à jour — l'utilisateur sera notifié si nécessaire" | ||||
|         "one": "La recherche de mises à jour en arrière-plan à trouvée {} mise à jour - l'utilisateur sera notifié si nécessaire", | ||||
|         "other": "La recherche de mises à jour en arrière-plan à trouvée {} mises à jour - l'utilisateur sera notifié si nécessaire" | ||||
|     }, | ||||
|     "apps": { | ||||
|         "one": "{} Application", | ||||
| @@ -337,7 +339,7 @@ | ||||
|         "other": "{} URL" | ||||
|     }, | ||||
|     "minute": { | ||||
|         "one": "{} Minutes", | ||||
|         "one": "{} Minute", | ||||
|         "other": "{} Minutes" | ||||
|     }, | ||||
|     "hour": { | ||||
| @@ -349,24 +351,24 @@ | ||||
|         "other": "{} Jours" | ||||
|     }, | ||||
|     "clearedNLogsBeforeXAfterY": { | ||||
|         "one": "{n} journal effacé (avant = {before}, après = {after})", | ||||
|         "other": "{n} journaux effacés (avant = {before}, après = {after})" | ||||
|         "one": "Nettoyage du journal {n} (avant = {before}, après = {after})", | ||||
|         "other": "Nettoyage des journaux {n} (avant = {before}, après = {after})" | ||||
|     }, | ||||
|     "xAndNMoreUpdatesAvailable": { | ||||
|         "one": "{} et 1 autre application ont des mises à jour.", | ||||
|         "other": "{} et {} autres applications ont des mises à jour." | ||||
|     }, | ||||
|     "xAndNMoreUpdatesInstalled": { | ||||
|         "one": "{} et 1 autre application ont été mises à jour.", | ||||
|         "other": "{} et {} autres applications ont été mises à jour." | ||||
|         "one": "{} et 1 autre application ont étés mis à jour.", | ||||
|         "other": "{} et {} autres applications ont étés mis à jour." | ||||
|     }, | ||||
|     "xAndNMoreUpdatesFailed": { | ||||
|         "one": "Échec de la mise à jour de {} et d'une autre application.", | ||||
|         "one": "Échec de la mise à jour de {} et 1 autre application.", | ||||
|         "other": "Échec de la mise à jour de {} et {} autres applications." | ||||
|     }, | ||||
|     "xAndNMoreUpdatesPossiblyInstalled": { | ||||
|         "une": "{} et 1 application supplémentaire pourraient avoir été mises à jour.", | ||||
|         "other": "{} et {} autres applications pourraient avoir été mises à jour." | ||||
|         "one": "{} et 1 autre application ont peut-être étés mis à jour.", | ||||
|         "other": "{} et {} autres applications ont peut-être étés mis à jour." | ||||
|     }, | ||||
|     "apk": { | ||||
|         "one": "{} APK", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Tiltsa le a háttérben frissítéseket, ha nincs Wi-Fi-n", | ||||
|     "autoSelectHighestVersionCode": "A legmagasabb verziószámú APK auto. kiválasztása", | ||||
|     "versionExtractionRegEx": "Verzió kibontása reguláris kifejezéssel", | ||||
|     "trimVersionString": "Trim Version String RegEx-szel", | ||||
|     "matchGroupToUseForX": "A \"{}\" csoporthoz használandó csoport egyeztetése", | ||||
|     "matchGroupToUse": "Párosítsa a csoportot a használathoz", | ||||
|     "highlightTouchTargets": "Emelje ki a kevésbé nyilvánvaló érintési célokat", | ||||
|     "pickExportDir": "Válassza az Exportálási könyvtárat", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Disattiva aggiornamenti in secondo piano quando non si usa il WiFi", | ||||
|     "autoSelectHighestVersionCode": "Auto-seleziona APK con versionCode più alto", | ||||
|     "versionExtractionRegEx": "RegEx di estrazione versione", | ||||
|     "trimVersionString": "Tagliare la stringa della versione con RegEx", | ||||
|     "matchGroupToUseForX": "Gruppo di corrispondenza da utilizzare per \"{}\"", | ||||
|     "matchGroupToUse": "Gruppo da usare", | ||||
|     "highlightTouchTargets": "Evidenzia elementi toccabili meno ovvi", | ||||
|     "pickExportDir": "Scegli cartella esp.", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "WiFiを使用していない場合、バックグラウンドアップデートを無効にする", | ||||
|     "autoSelectHighestVersionCode": "最も高いバージョンコードのAPKを自動で選択する", | ||||
|     "versionExtractionRegEx": "バージョン抽出の正規表現", | ||||
|     "trimVersionString": "正規表現でバージョン文字列をトリムする", | ||||
|     "matchGroupToUseForX": "\"{}\"に使用するマッチしたグループ", | ||||
|     "matchGroupToUse": "使用するマッチしたグループ", | ||||
|     "highlightTouchTargets": "目立たないタップ可能な対象をハイライトする", | ||||
|     "pickExportDir": "エクスポートディレクトリを選択", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Achtergrond-updates uitschakelen wanneer niet verbonden met WiFi", | ||||
|     "autoSelectHighestVersionCode": "De APK met de hoogste versiecode automatisch selecteren", | ||||
|     "versionExtractionRegEx": "Reguliere expressie voor versie-extractie", | ||||
|     "trimVersionString": "Versie string trimmen met RegEx", | ||||
|     "matchGroupToUseForX": "Overeenkomende groep te gebruiken voor \"{}\"", | ||||
|     "matchGroupToUse": "Overeenkomende groep om te gebruiken voor de reguliere expressie voor versie-extractie", | ||||
|     "highlightTouchTargets": "Minder voor de hand liggende aanraakdoelen markeren.", | ||||
|     "pickExportDir": "Kies de exportmap", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Wyłącz aktualizacje w tle, gdy nie ma połączenia z Wi-Fi", | ||||
|     "autoSelectHighestVersionCode": "Automatycznie wybierz najwyższy kod wersji APK", | ||||
|     "versionExtractionRegEx": "Wyrażenie regularne wyodrębniające wersję", | ||||
|     "trimVersionString": "Przycinanie łańcucha wersji za pomocą RegEx", | ||||
|     "matchGroupToUseForX": "Dopasuj grupę do użycia dla \"{}\"", | ||||
|     "matchGroupToUse": "Dopasuj grupę do użycia dla wyrażenia regularnego wyodrębniania wersji", | ||||
|     "highlightTouchTargets": "Wyróżnij mniej oczywiste elementy dotykowe", | ||||
|     "pickExportDir": "Wybierz katalog eksportu", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Desative as atualizações em segundo-plano quando não estiver conectado no Wi-Fi", | ||||
|     "autoSelectHighestVersionCode": "Auto-selecionar a versão mais recente", | ||||
|     "versionExtractionRegEx": "Regex de extração de versão", | ||||
|     "trimVersionString": "Cortar a cadeia de caracteres da versão com RegEx", | ||||
|     "matchGroupToUseForX": "Grupo de correspondência a utilizar para \"{}\"", | ||||
|     "matchGroupToUse": "Grupo correspondente a ser usado no Regex de extração de versão", | ||||
|     "highlightTouchTargets": "Realçar áreas sensíveis ao toque que são menos óbvias", | ||||
|     "pickExportDir": "Escolher diretório para exportação", | ||||
|   | ||||
| @@ -129,7 +129,7 @@ | ||||
|     "pinUpdates": "Отображать обновления приложений сверху списка", | ||||
|     "updates": "Обновления", | ||||
|     "sourceSpecific": "Настройки источников", | ||||
|     "appSource": "Исходный код", | ||||
|     "appSource": "Источник", | ||||
|     "noLogs": "Нет журналов", | ||||
|     "appLogs": "Логи", | ||||
|     "close": "Закрыть", | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Отключить фоновые обновления, если нет соединения с Wi-Fi", | ||||
|     "autoSelectHighestVersionCode": "Автоматически выбирать APK с актуальной версией кода", | ||||
|     "versionExtractionRegEx": "Регулярное выражение для извлечения версии", | ||||
|     "trimVersionString": "Обрезка строки версии с помощью RegEx", | ||||
|     "matchGroupToUseForX": "Группа соответствия, которую следует использовать для \"{}\"", | ||||
|     "matchGroupToUse": "Выберите группу для использования", | ||||
|     "highlightTouchTargets": "Выделить менее очевидные элементы управления касанием", | ||||
|     "pickExportDir": "Выбрать каталог для экспорта", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Inaktivera Bakgrundsuppdateringar utan WiFi", | ||||
|     "autoSelectHighestVersionCode": "Välj automatiskt högsta versionskod APK", | ||||
|     "versionExtractionRegEx": "Version Extraction RegEx", | ||||
|     "trimVersionString": "Trimma versionssträng med RegEx", | ||||
|     "matchGroupToUseForX": "Matchningsgrupp att använda för \"{}\"", | ||||
|     "matchGroupToUse": "Match Group to Use", | ||||
|     "highlightTouchTargets": "Markera mindre uppenbara beröringsobjekt", | ||||
|     "pickExportDir": "Välj Exportsökväg", | ||||
|   | ||||
| @@ -3,7 +3,7 @@ | ||||
|     "noReleaseFound": "Uygun bir sürüm bulunamadı", | ||||
|     "noVersionFound": "Sürüm bulunamadı", | ||||
|     "urlMatchesNoSource": "URL, bilinen bir kaynağa uymuyor", | ||||
|     "cantInstallOlderVersion": "Eski bir sürümü yükleyemem", | ||||
|     "cantInstallOlderVersion": "Eski bir sürüm yüklenemez", | ||||
|     "appIdMismatch": "İndirilen paket kimliği mevcut Uygulama kimliği ile eşleşmiyor", | ||||
|     "functionNotImplemented": "Bu sınıf bu işlevi uygulamamıştır", | ||||
|     "placeholder": "Yer Tutucu", | ||||
| @@ -13,22 +13,22 @@ | ||||
|     "and": "ve", | ||||
|     "githubPATLabel": "GitHub Kişisel Erişim Anahtarı (Sınırlamayı Artırır)", | ||||
|     "includePrereleases": "Ön sürümleri dahil et", | ||||
|     "fallbackToOlderReleases": "Daha eski sürümlere geri dön", | ||||
|     "fallbackToOlderReleases": "Daha eski sürümleri alternatif olarak tut", | ||||
|     "filterReleaseTitlesByRegEx": "Düzenli İfadelerle Sürüm Başlıklarını Filtrele", | ||||
|     "invalidRegEx": "Geçersiz düzenli ifade", | ||||
|     "noDescription": "Açıklama yok", | ||||
|     "cancel": "İptal", | ||||
|     "continue": "Devam Et", | ||||
|     "requiredInBrackets": "(Gerekli)", | ||||
|     "dropdownNoOptsError": "HATA: DİPLOMADA EN AZ BİR SEÇENEK OLMALI", | ||||
|     "dropdownNoOptsError": "HATA: AÇILIR MENÜDE EN AZ BİR SEÇENEK OLMALI", | ||||
|     "colour": "Renk", | ||||
|     "standard": "Standart", | ||||
|     "custom": "Özel", | ||||
|     "useMaterialYou": "Sizin Malzemenizi Kullanın", | ||||
|     "githubStarredRepos": "GitHub'a Yıldızlı Depolar", | ||||
|     "useMaterialYou": "MaterialYou Kullanın", | ||||
|     "githubStarredRepos": "GitHub Yıldızlı Depolar", | ||||
|     "uname": "Kullanıcı Adı", | ||||
|     "wrongArgNum": "Hatalı argüman sayısı sağlandı", | ||||
|     "xIsTrackOnly": "{} yalnızca Takip Edilen", | ||||
|     "wrongArgNum": "Hatalı sayıda argüman sağlandı", | ||||
|     "xIsTrackOnly": "{} yalnızca Takip Ediliyor", | ||||
|     "source": "Kaynak", | ||||
|     "app": "Uygulama", | ||||
|     "appsFromSourceAreTrackOnly": "Bu kaynaktan gelen uygulamalar 'Yalnızca Takip Edilen'dir.", | ||||
| @@ -41,9 +41,9 @@ | ||||
|     "appSourceURL": "Uygulama Kaynak URL'si", | ||||
|     "error": "Hata", | ||||
|     "add": "Ekle", | ||||
|     "searchSomeSourcesLabel": "Ara (Bazı Kaynaklar Yalnızca)", | ||||
|     "searchSomeSourcesLabel": "Ara (Yalnızca Bazı Kaynaklar)", | ||||
|     "search": "Ara", | ||||
|     "additionalOptsFor": "{} İçin Ek Seçenekler", | ||||
|     "additionalOptsFor": "{} için Ek Seçenekler", | ||||
|     "supportedSources": "Desteklenen Kaynaklar", | ||||
|     "trackOnlyInBrackets": "(Yalnızca Takip)", | ||||
|     "searchableInBrackets": "(Aranabilir)", | ||||
| @@ -173,13 +173,13 @@ | ||||
|     "lastUpdateCheckX": "Son Güncelleme Kontrolü: {}", | ||||
|     "remove": "Kaldır", | ||||
|     "yesMarkUpdated": "Evet, Güncellendi olarak İşaretle", | ||||
|     "fdroid": "F-Droid Resmi", | ||||
|     "fdroid": "Resmi F-Droid", | ||||
|     "appIdOrName": "Uygulama Kimliği veya Adı", | ||||
|     "appId": "Uygulama Kimliği", | ||||
|     "appWithIdOrNameNotFound": "Bu kimlik veya ada sahip bir uygulama bulunamadı", | ||||
|     "reposHaveMultipleApps": "Depolar birden fazla uygulama içerebilir", | ||||
|     "fdroidThirdPartyRepo": "F-Droid Üçüncü Taraf Depo", | ||||
|     "steamMobile": "Buhar Mobil", | ||||
|     "fdroidThirdPartyRepo": "F-Droid Üçüncü Parti Depo", | ||||
|     "steamMobile": "Steam Mobil", | ||||
|     "steamChat": "Steam Sohbet", | ||||
|     "install": "Yükle", | ||||
|     "markInstalled": "Yüklendi olarak İşaretle", | ||||
| @@ -222,7 +222,7 @@ | ||||
|     "standardVersionDetection": "Standart sürüm tespiti", | ||||
|     "groupByCategory": "Kategoriye Göre Grupla", | ||||
|     "autoApkFilterByArch": "Mümkünse APK'leri CPU mimarisi ile filtreleme girişimi", | ||||
|     "overrideSource": "Kaynağı Geçersiz Kıl", | ||||
|     "overrideSource": "Öncelenecek Kaynak", | ||||
|     "dontShowAgain": "Bunu tekrar gösterme", | ||||
|     "dontShowTrackOnlyWarnings": "'Yalnızca Takip Edilen' uyarılarını gösterme", | ||||
|     "dontShowAPKOriginWarnings": "APK kaynağı uyarılarını gösterme", | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "WiFi olmadığında arka plan güncellemelerini devre dışı bırak", | ||||
|     "autoSelectHighestVersionCode": "Otomatik olarak en yüksek sürüm kodunu seç", | ||||
|     "versionExtractionRegEx": "Sürüm Çıkarma Düzenli İfade", | ||||
|     "trimVersionString": "RegEx ile Sürüm Dizesini Kırpma", | ||||
|     "matchGroupToUseForX": "\"{}\" için Kullanılacak Grubu Eşleştirin", | ||||
|     "matchGroupToUse": "Sürüm Çıkarma Regex için Kullanılacak Eşleşme Grubu", | ||||
|     "highlightTouchTargets": "Daha az belirgin dokunma hedeflerini vurgula", | ||||
|     "pickExportDir": "Dışa Aktarılacak Klasörü Seç", | ||||
| @@ -286,10 +288,10 @@ | ||||
|     "checkingForUpdatesNotifChannel": "Güncellemeler Kontrol Ediliyor", | ||||
|     "onlyCheckInstalledOrTrackOnlyApps": "Yalnızca yüklü ve Yalnızca İzleme Uygulamalarını güncelleme", | ||||
|     "supportFixedAPKURL": "Sabit APK URL'lerini destekleyin", | ||||
|     "selectX": "Seçme {}", | ||||
|     "selectX": "{} Tanesini Seç", | ||||
|     "parallelDownloads": "Paralel indirmelere izin ver", | ||||
|     "useShizuku": "Yüklemek için Shizuku veya Sui'yi kullanın", | ||||
|     "shizukuBinderNotFound": "Shizuku is not running", | ||||
|     "shizukuBinderNotFound": "Shizuku servisi çalışmıyor", | ||||
|     "shizukuOld": "Eski Shizuku sürümü (<11) - güncelleyin", | ||||
|     "shizukuOldAndroidWithADB": "Shizuku ADB ile Android < 8.1 üzerinde çalışıyor - Android'i güncelleyin veya bunun yerine Sui kullanın", | ||||
|     "shizukuPretendToBeGooglePlay": "Google Play'i yükleme kaynağı olarak ayarlayın (Shizuku kullanılıyorsa)", | ||||
| @@ -334,7 +336,7 @@ | ||||
|     }, | ||||
|     "url": { | ||||
|         "one": "{} URL", | ||||
|         "other": "{} URL'ler" | ||||
|         "other": "{} URL" | ||||
|     }, | ||||
|     "minute": { | ||||
|         "one": "{} Dakika", | ||||
| @@ -370,6 +372,6 @@ | ||||
|     }, | ||||
|     "apk": { | ||||
|         "one": "{} APK", | ||||
|         "other": "{} APK'lar" | ||||
|         "other": "{} APK" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Вимкнути фонові оновлення поза Wi-Fi", | ||||
|     "autoSelectHighestVersionCode": "Автоматичний вибір APK з найвищим кодом версії", | ||||
|     "versionExtractionRegEx": "Регулярний вираз для вилучення рядка версії", | ||||
|     "trimVersionString": "Обрізати рядок версії за допомогою RegEx", | ||||
|     "matchGroupToUseForX": "Група збігів для \"{}\"", | ||||
|     "matchGroupToUse": "Група співпадінь для використання в регулярному виразі вилучення версії", | ||||
|     "highlightTouchTargets": "Підсвічувати менш очевидні області дотику", | ||||
|     "pickExportDir": "Вибрати каталог експорту", | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "Tắt cập nhật nền khi không có WiFi", | ||||
|     "autoSelectHighestVersionCode": "Tự động chọn APK mã phiên bản cao nhất", | ||||
|     "versionExtractionRegEx": "Trích xuất phiên bản RegEx", | ||||
|     "trimVersionString": "Trim Version String With RegEx", | ||||
|     "matchGroupToUseForX": "Match Group to Use for \"{}\"", | ||||
|     "matchGroupToUse": "Nhóm đối sánh để sử dụng cho Regex trích xuất phiên bản", | ||||
|     "highlightTouchTargets": "Đánh dấu các mục tiêu cảm ứng ít rõ ràng hơn", | ||||
|     "pickExportDir": "Chọn thư mục xuất", | ||||
|   | ||||
| @@ -1,375 +1,377 @@ | ||||
| { | ||||
|   "invalidURLForSource": "不是有效的 {} 應用程式 URL", | ||||
|   "noReleaseFound": "找不到合適的版本", | ||||
|   "noVersionFound": "無法確定版本", | ||||
|   "urlMatchesNoSource": "URL 不符合已知來源", | ||||
|   "cantInstallOlderVersion": "無法安裝舊版本的應用程式", | ||||
|   "appIdMismatch": "下載的套件 ID 與現有的應用程式 ID 不匹配", | ||||
|   "functionNotImplemented": "此類別尚未實作此功能", | ||||
|   "placeholder": "佔位", | ||||
|   "someErrors": "發生了一些錯誤", | ||||
|   "unexpectedError": "意外錯誤", | ||||
|   "ok": "確定", | ||||
|   "and": "和", | ||||
|   "githubPATLabel": "GitHub 個人存取權杖(增加速率限制)", | ||||
|   "includePrereleases": "包含預發佈版本", | ||||
|   "fallbackToOlderReleases": "回退到舊版本", | ||||
|   "filterReleaseTitlesByRegEx": "用正則表達式過濾版本標題", | ||||
|   "invalidRegEx": "無效的正則表達式", | ||||
|   "noDescription": "無描述", | ||||
|   "cancel": "取消", | ||||
|   "continue": "繼續", | ||||
|   "requiredInBrackets": "(必填)", | ||||
|   "dropdownNoOptsError": "錯誤:下拉選單必須至少有一個選項", | ||||
|   "colour": "顏色", | ||||
|   "standard": "標準", | ||||
|   "custom": "自訂", | ||||
|   "useMaterialYou": "使用 Material You", | ||||
|   "githubStarredRepos": "GitHub Starred Repos", | ||||
|   "uname": "使用者名稱", | ||||
|   "wrongArgNum": "提供的參數數量錯誤", | ||||
|   "xIsTrackOnly": "{} 是僅追蹤", | ||||
|   "source": "來源", | ||||
|   "app": "應用程式", | ||||
|   "appsFromSourceAreTrackOnly": "來自此來源的應用程式是「僅追蹤」。", | ||||
|   "youPickedTrackOnly": "您已選擇「僅追蹤」選項。", | ||||
|   "trackOnlyAppDescription": "該應用程式將被追蹤更新,但 Obtainium 將無法下載或安裝它。", | ||||
|   "cancelled": "已取消", | ||||
|   "appAlreadyAdded": "應用程式已添加", | ||||
|   "alreadyUpToDateQuestion": "應用程式已經是最新的?", | ||||
|   "addApp": "添加應用程式", | ||||
|   "appSourceURL": "應用程式來源 URL", | ||||
|   "error": "錯誤", | ||||
|   "add": "添加", | ||||
|   "searchSomeSourcesLabel": "搜尋(僅限部分來源)", | ||||
|   "search": "搜尋", | ||||
|   "additionalOptsFor": "{} 的其他選項", | ||||
|   "supportedSources": "支持的來源", | ||||
|   "trackOnlyInBrackets": "(僅追蹤)", | ||||
|   "searchableInBrackets": "(可搜尋)", | ||||
|   "appsString": "應用程式", | ||||
|   "noApps": "無應用程式", | ||||
|   "noAppsForFilter": "無符合過濾條件的應用程式", | ||||
|   "byX": "由 {}", | ||||
|   "percentProgress": "進度:{}%", | ||||
|   "pleaseWait": "請稍候", | ||||
|   "updateAvailable": "有可用的更新", | ||||
|   "notInstalled": "未安裝", | ||||
|   "pseudoVersion": "偽版本", | ||||
|   "selectAll": "全選", | ||||
|   "deselectX": "取消選取 {}", | ||||
|   "xWillBeRemovedButRemainInstalled": "{} 將從 Obtainium 中移除,但仍然安裝在設備上。", | ||||
|   "removeSelectedAppsQuestion": "移除選取的應用程式?", | ||||
|   "removeSelectedApps": "移除選取的應用程式", | ||||
|   "updateX": "更新 {}", | ||||
|   "installX": "安裝 {}", | ||||
|   "markXTrackOnlyAsUpdated": "標記 {}\n(僅追蹤)\n為已更新", | ||||
|   "changeX": "更改 {}", | ||||
|   "installUpdateApps": "安裝/更新應用程式", | ||||
|   "installUpdateSelectedApps": "安裝/更新選取的應用程式", | ||||
|   "markXSelectedAppsAsUpdated": "標記 {} 個選取的應用程式為已更新?", | ||||
|   "no": "否", | ||||
|   "yes": "是", | ||||
|   "markSelectedAppsUpdated": "標記選取的應用程式為已更新", | ||||
|   "pinToTop": "釘選到頂部", | ||||
|   "unpinFromTop": "取消釘選", | ||||
|   "resetInstallStatusForSelectedAppsQuestion": "重設選取應用程式的安裝狀態?", | ||||
|   "installStatusOfXWillBeResetExplanation": "任何選取應用程式的安裝狀態將被重設。\n\n這可以在由於更新失敗或其他問題導致 Obtainium 顯示的應用程式版本不正確時有所幫助。", | ||||
|   "customLinkMessage": "這些連結適用於已安裝 Obtainium 的設備", | ||||
|   "shareAppConfigLinks": "分享應用程式配置為 HTML 連結", | ||||
|   "shareSelectedAppURLs": "分享選取的應用程式 URL", | ||||
|   "resetInstallStatus": "重設安裝狀態", | ||||
|   "more": "更多", | ||||
|   "removeOutdatedFilter": "移除過時應用程式過濾", | ||||
|   "showOutdatedOnly": "僅顯示過時的應用程式", | ||||
|   "filter": "過濾", | ||||
|   "filterApps": "過濾應用程式", | ||||
|   "appName": "應用程式名稱", | ||||
|   "author": "作者", | ||||
|   "upToDateApps": "最新的應用程式", | ||||
|   "nonInstalledApps": "未安裝的應用程式", | ||||
|   "importExport": "匯入/匯出", | ||||
|   "settings": "設定", | ||||
|   "exportedTo": "匯出到 {}", | ||||
|   "obtainiumExport": "Obtainium 匯出", | ||||
|   "invalidInput": "無效的輸入", | ||||
|   "importedX": "已匯入 {}", | ||||
|   "obtainiumImport": "Obtainium 匯入", | ||||
|   "importFromURLList": "從 URL 列表匯入", | ||||
|   "searchQuery": "搜尋查詢", | ||||
|   "appURLList": "應用程式 URL 清單", | ||||
|   "line": "行", | ||||
|   "searchX": "搜尋 {}", | ||||
|   "noResults": "未找到結果", | ||||
|   "importX": "匯入 {}", | ||||
|   "importedAppsIdDisclaimer": "匯入的應用程式可能會錯誤地顯示為「未安裝」。\n要修正此問題,請通過 Obtainium 重新安裝它們。\n這不應該影響應用程式數據。\n\n僅影響 URL 和第三方匯入方法。", | ||||
|   "importErrors": "匯入錯誤", | ||||
|   "importedXOfYApps": "已匯入 {} 個中的 {} 個應用程式。", | ||||
|   "followingURLsHadErrors": "以下 URL 有錯誤:", | ||||
|   "selectURL": "選擇 URL", | ||||
|   "selectURLs": "選擇多個 URL", | ||||
|   "pick": "選取", | ||||
|   "theme": "主題", | ||||
|   "dark": "深色", | ||||
|   "light": "淺色", | ||||
|   "followSystem": "跟隨系統", | ||||
|   "followSystemThemeExplanation": "僅使用第三方應用程式時才可跟隨系統主題", | ||||
|   "useBlackTheme": "使用純黑色深色主題", | ||||
|   "appSortBy": "應用程式排序依據", | ||||
|   "authorName": "作者/名稱", | ||||
|   "nameAuthor": "名稱/作者", | ||||
|   "asAdded": "添加順序", | ||||
|   "appSortOrder": "應用程式排序順序", | ||||
|   "ascending": "升序", | ||||
|   "descending": "降序", | ||||
|   "bgUpdateCheckInterval": "背景更新檢查間隔", | ||||
|   "neverManualOnly": "從不 - 僅手動", | ||||
|   "appearance": "外觀", | ||||
|   "showWebInAppView": "在應用程式檢視中顯示來源網頁", | ||||
|   "pinUpdates": "將更新釘選至應用程式檢視的頂端", | ||||
|   "updates": "更新", | ||||
|   "sourceSpecific": "特定來源", | ||||
|   "appSource": "應用程式來源", | ||||
|   "noLogs": "無日誌", | ||||
|   "appLogs": "應用程式日誌", | ||||
|   "close": "關閉", | ||||
|   "share": "分享", | ||||
|   "appNotFound": "未找到應用程式", | ||||
|   "obtainiumExportHyphenatedLowercase": "obtainium-export", | ||||
|   "pickAnAPK": "選擇一個 APK", | ||||
|   "appHasMoreThanOnePackage": "{} 有多個套件:", | ||||
|   "deviceSupportsXArch": "您的設備支持 {} CPU 架構。", | ||||
|   "deviceSupportsFollowingArchs": "您的設備支持以下 CPU 架構:", | ||||
|   "warning": "警告", | ||||
|   "sourceIsXButPackageFromYPrompt": "應用程式來源是 「{}」,但發佈套件來自 「{}」。要繼續嗎?", | ||||
|   "updatesAvailable": "有可用的更新", | ||||
|   "updatesAvailableNotifDescription": "通知使用者有一個或多個由 Obtainium 追蹤的應用程式有更新", | ||||
|   "noNewUpdates": "沒有新更新。", | ||||
|   "xHasAnUpdate": "{} 有一個更新。", | ||||
|   "appsUpdated": "應用程式已更新", | ||||
|   "appsNotUpdated": "未能更新應用程式", | ||||
|   "appsUpdatedNotifDescription": "通知使用者一個或多個應用程式的更新已在背景中應用", | ||||
|   "xWasUpdatedToY": "{} 已更新到 {}。", | ||||
|   "xWasNotUpdatedToY": "未能將 {} 更新到 {}。", | ||||
|   "errorCheckingUpdates": "檢查更新時出錯", | ||||
|   "errorCheckingUpdatesNotifDescription": "背景檢查更新失敗時顯示的通知", | ||||
|   "appsRemoved": "應用程式已移除", | ||||
|   "appsRemovedNotifDescription": "通知使用者由於載入時出錯,一個或多個應用程式已被移除", | ||||
|   "xWasRemovedDueToErrorY": "{} 已因以下錯誤被移除:{}", | ||||
|   "completeAppInstallation": "完成應用程式安裝", | ||||
|   "obtainiumMustBeOpenToInstallApps": "Obtainium 必須開啟才能安裝應用程式", | ||||
|   "completeAppInstallationNotifDescription": "請使用者返回 Obtainium 以完成應用程式安裝", | ||||
|   "checkingForUpdates": "正在檢查更新", | ||||
|   "checkingForUpdatesNotifDescription": "檢查更新時顯示的暫時性通知", | ||||
|   "pleaseAllowInstallPerm": "請允許 Obtainium 安裝應用程式", | ||||
|   "trackOnly": "僅追蹤", | ||||
|   "errorWithHttpStatusCode": "錯誤 {}", | ||||
|   "versionCorrectionDisabled": "版本校正已禁用(外掛程式似乎無法正常工作)", | ||||
|   "unknown": "未知", | ||||
|   "none": "無", | ||||
|   "never": "從不", | ||||
|   "latestVersionX": "最新版本:{}", | ||||
|   "installedVersionX": "已安裝版本:{}", | ||||
|   "lastUpdateCheckX": "上次檢查更新時間:{}", | ||||
|   "remove": "移除", | ||||
|   "yesMarkUpdated": "是,標記為已更新", | ||||
|   "fdroid": "F-Droid 官方", | ||||
|   "appIdOrName": "應用程式 ID 或名稱", | ||||
|   "appId": "應用程式 ID", | ||||
|   "appWithIdOrNameNotFound": "找不到具有該 ID 或名稱的應用程式", | ||||
|   "reposHaveMultipleApps": "倉庫可能包含多個應用程式", | ||||
|   "fdroidThirdPartyRepo": "F-Droid 第三方倉庫", | ||||
|   "steamMobile": "Steam 行動版", | ||||
|   "steamChat": "Steam 聊天", | ||||
|   "install": "安裝", | ||||
|   "markInstalled": "標記為已安裝", | ||||
|   "update": "更新", | ||||
|   "markUpdated": "標記為已更新", | ||||
|   "additionalOptions": "額外選項", | ||||
|   "disableVersionDetection": "禁用版本檢測", | ||||
|   "noVersionDetectionExplanation": "此選項僅應用於版本檢測無法正確工作的應用程式。", | ||||
|   "downloadingX": "正在下載 {}", | ||||
|   "downloadX": "下載 {}", | ||||
|   "downloadedX": "已下載 {}", | ||||
|   "releaseAsset": "發佈資源", | ||||
|   "downloadNotifDescription": "通知使用者應用程式下載進度", | ||||
|   "noAPKFound": "未找到 APK", | ||||
|   "noVersionDetection": "無版本檢測", | ||||
|   "categorize": "分類", | ||||
|   "categories": "類別", | ||||
|   "category": "類別", | ||||
|   "noCategory": "無類別", | ||||
|   "noCategories": "無類別", | ||||
|   "deleteCategoriesQuestion": "刪除類別?", | ||||
|   "categoryDeleteWarning": "所有在已刪除類別中的應用程式將被設置為未分類。", | ||||
|   "addCategory": "新增類別", | ||||
|   "label": "標籤", | ||||
|   "language": "語言", | ||||
|   "copiedToClipboard": "已複製到剪貼簿", | ||||
|   "storagePermissionDenied": "存取權限被拒絕", | ||||
|   "selectedCategorizeWarning": "這將替換選取應用程式的任何現有類別設置。", | ||||
|   "filterAPKsByRegEx": "用正則表達式過濾 APK", | ||||
|   "removeFromObtainium": "從 Obtainium 移除", | ||||
|   "uninstallFromDevice": "從設備解除安裝", | ||||
|   "onlyWorksWithNonVersionDetectApps": "僅適用於禁用版本檢測的應用程式。", | ||||
|   "releaseDateAsVersion": "使用發佈日期作為版本字串", | ||||
|   "releaseDateAsVersionExplanation": "此選項僅應用於版本檢測無法正確工作但有發佈日期的應用程式。", | ||||
|   "changes": "變更", | ||||
|   "releaseDate": "發佈日期", | ||||
|   "importFromURLsInFile": "從文件中的 URL 匯入(如 OPML)", | ||||
|   "versionDetectionExplanation": "將版本字串與作業系統檢測到的版本對比", | ||||
|   "versionDetection": "版本檢測", | ||||
|   "standardVersionDetection": "標準版本檢測", | ||||
|   "groupByCategory": "按類別分組", | ||||
|   "autoApkFilterByArch": "如果可能,嘗試按 CPU 架構過濾 APK", | ||||
|   "overrideSource": "覆蓋來源", | ||||
|   "dontShowAgain": "不要再顯示", | ||||
|   "dontShowTrackOnlyWarnings": "不要顯示「僅追蹤」警告", | ||||
|   "dontShowAPKOriginWarnings": "不要顯示 APK 來源警告", | ||||
|   "moveNonInstalledAppsToBottom": "將未安裝的應用程式移到應用程式視圖的底部", | ||||
|   "gitlabPATLabel": "GitLab 個人存取權杖", | ||||
|   "about": "關於", | ||||
|   "requiresCredentialsInSettings": "{} 需要額外的憑證(在設定中)", | ||||
|   "checkOnStart": "啟動時檢查更新", | ||||
|   "tryInferAppIdFromCode": "嘗試從原始碼推斷應用程式 ID", | ||||
|   "removeOnExternalUninstall": "自動移除外部解除安裝的應用程式", | ||||
|   "pickHighestVersionCode": "自動選取最高版本號的 APK", | ||||
|   "checkUpdateOnDetailPage": "在打開應用程式詳細頁面時檢查更新", | ||||
|   "disablePageTransitions": "禁用頁面過渡動畫", | ||||
|   "reversePageTransitions": "反轉頁面過渡動畫", | ||||
|   "minStarCount": "最少星數", | ||||
|   "addInfoBelow": "在下方添加此資訊。", | ||||
|   "addInfoInSettings": "在設定中增加此資訊。", | ||||
|   "githubSourceNote": "使用 API 金鑰可以避免 GitHub 的速率限制。", | ||||
|   "sortByLastLinkSegment": "僅按連結的最後一段排序", | ||||
|   "filterReleaseNotesByRegEx": "用正則表達式過濾發佈說明", | ||||
|   "customLinkFilterRegex": "自定 APK 連結過濾正則表達式(預設為 '.apk$')", | ||||
|   "appsPossiblyUpdated": "嘗試更新應用程式", | ||||
|   "appsPossiblyUpdatedNotifDescription": "通知使用者一個或多個應用程式的更新可能已在背景中應用", | ||||
|   "xWasPossiblyUpdatedToY": "{} 可能已更新到 {}。", | ||||
|   "enableBackgroundUpdates": "啟用背景更新", | ||||
|   "backgroundUpdateReqsExplanation": "並非所有應用程式都能進行背景更新。", | ||||
|   "backgroundUpdateLimitsExplanation": "背景安裝的成功與否只能在打開 Obtainium 時確定。", | ||||
|   "verifyLatestTag": "驗證「最新」標籤", | ||||
|   "intermediateLinkRegex": "過濾要訪問的「中間」連結", | ||||
|   "filterByLinkText": "按連結文本過濾連結", | ||||
|   "intermediateLinkNotFound": "未找到中間連結", | ||||
|   "intermediateLink": "中間連結", | ||||
|   "exemptFromBackgroundUpdates": "免除背景更新(若已啟用)", | ||||
|   "bgUpdatesOnWiFiOnly": "禁用非 WiFi 的背景更新", | ||||
|   "autoSelectHighestVersionCode": "自動選擇最高 versionCode 的 APK", | ||||
|   "versionExtractionRegEx": "版本字串提取正則表達式", | ||||
|   "matchGroupToUse": "要用於版本字串提取的匹配組", | ||||
|   "highlightTouchTargets": "突出顯示不明顯的觸控目標", | ||||
|   "pickExportDir": "選擇匯出目錄", | ||||
|   "autoExportOnChanges": "更改時自動匯出", | ||||
|   "includeSettings": "包含設定", | ||||
|   "filterVersionsByRegEx": "用正則表達式過濾版本", | ||||
|   "trySelectingSuggestedVersionCode": "嘗試選擇建議的 versionCode APK", | ||||
|   "dontSortReleasesList": "保留 API 的發佈順序", | ||||
|   "reverseSort": "反向排序", | ||||
|   "takeFirstLink": "使用第一個連結", | ||||
|   "skipSort": "跳過排序", | ||||
|   "debugMenu": "除錯選單", | ||||
|   "bgTaskStarted": "背景任務已啟動 - 檢查日誌。", | ||||
|   "runBgCheckNow": "立即執行背景更新檢查", | ||||
|   "versionExtractWholePage": "將版本字串提取正則表達式應用於整個頁面", | ||||
|   "installing": "正在安裝", | ||||
|   "skipUpdateNotifications": "跳過更新通知", | ||||
|   "updatesAvailableNotifChannel": "有可用的更新", | ||||
|   "appsUpdatedNotifChannel": "應用程式已更新", | ||||
|   "appsPossiblyUpdatedNotifChannel": "嘗試更新應用程式", | ||||
|   "errorCheckingUpdatesNotifChannel": "檢查更新錯誤", | ||||
|   "appsRemovedNotifChannel": "應用程式已移除", | ||||
|   "downloadingXNotifChannel": "正在下載 {}", | ||||
|   "completeAppInstallationNotifChannel": "完成應用程式安裝", | ||||
|   "checkingForUpdatesNotifChannel": "正在檢查更新", | ||||
|   "onlyCheckInstalledOrTrackOnlyApps": "僅檢查已安裝和僅追蹤的應用程式更新", | ||||
|   "supportFixedAPKURL": "支援固定的 APK 網址", | ||||
|   "selectX": "選擇 {}", | ||||
|   "parallelDownloads": "允許平行下載", | ||||
|   "useShizuku": "使用 Shizuku 或 Sui 來安裝", | ||||
|   "shizukuBinderNotFound": "Shizuku 服務未運行", | ||||
|   "shizukuOld": "舊版 Shizuku (<11) - 請更新", | ||||
|   "shizukuOldAndroidWithADB": "Shizuku 在 Android 8.1 以下版本使用 ADB 運行 - 請更新 Android 或改用 Sui", | ||||
|   "shizukuPretendToBeGooglePlay": "設置 Google Play 為安裝來源(如果使用 Shizuku)", | ||||
|   "useSystemFont": "使用系統字體", | ||||
|   "useVersionCodeAsOSVersion": "使用應用程式 versionCode 作為操作系統檢測的版本", | ||||
|   "requestHeader": "請求標頭", | ||||
|   "useLatestAssetDateAsReleaseDate": "使用最新資源上傳日期作為發佈日期", | ||||
|   "defaultPseudoVersioningMethod": "預設偽版本管理方法", | ||||
|   "partialAPKHash": "部分 APK Hash", | ||||
|   "APKLinkHash": "APK 連結 Hash", | ||||
|   "directAPKLink": "直接 APK 連結", | ||||
|   "pseudoVersionInUse": "正在使用偽版本", | ||||
|   "installed": "已安裝", | ||||
|   "latest": "最新", | ||||
|   "invertRegEx": "反轉正則表達式", | ||||
|   "note": "備註", | ||||
|   "selfHostedNote": "可使用「{}」下拉選單來訪問任何來源的自託管/自定義實例。", | ||||
|   "badDownload": "無法解析 APK(不兼容或下載不完整)", | ||||
|   "beforeNewInstallsShareToAppVerifier": "將新應用程式分享到 AppVerifier(如果可用)", | ||||
|   "appVerifierInstructionToast": "分享至 AppVerifier,然後準備好時返回此處。", | ||||
|   "wiki": "幫助/維基", | ||||
|   "crowdsourcedConfigsLabel": "群眾外包的應用程式配置(使用風險自負)", | ||||
|   "removeAppQuestion": { | ||||
|     "one": "移除應用程式?", | ||||
|     "other": "移除應用程式?" | ||||
|   }, | ||||
|   "tooManyRequestsTryAgainInMinutes": { | ||||
|     "one": "請求過多(速率限制)- {} 分鐘後重試", | ||||
|     "other": "請求過多(速率限制)- {} 分鐘後重試" | ||||
|   }, | ||||
|   "bgUpdateGotErrorRetryInMinutes": { | ||||
|     "one": "背景更新檢查遇到 {},將在 {} 分鐘後重新檢查", | ||||
|     "other": "背景更新檢查遇到 {},將在 {} 分鐘後重新檢查" | ||||
|   }, | ||||
|   "bgCheckFoundUpdatesWillNotifyIfNeeded": { | ||||
|     "one": "背景更新檢查發現 {} 個更新 - 如果需要將通知使用者", | ||||
|     "other": "背景更新檢查發現 {} 個更新 - 如果需要將通知使用者" | ||||
|   }, | ||||
|   "apps": { | ||||
|     "one": "{} 個應用程式", | ||||
|     "other": "{} 個應用程式" | ||||
|   }, | ||||
|   "url": { | ||||
|     "one": "{} 個 URL", | ||||
|     "other": "{} 個 URL" | ||||
|   }, | ||||
|   "minute": { | ||||
|     "one": "{} 分鐘", | ||||
|     "other": "{} 分鐘" | ||||
|   }, | ||||
|   "hour": { | ||||
|     "one": "{} 小時", | ||||
|     "other": "{} 小時" | ||||
|   }, | ||||
|   "day": { | ||||
|     "one": "{} 天", | ||||
|     "other": "{} 天" | ||||
|   }, | ||||
|   "clearedNLogsBeforeXAfterY": { | ||||
|     "one": "清除 {n} 個日誌(之前 = {before},之後 = {after})", | ||||
|     "other": "清除 {n} 個日誌(之前 = {before},之後 = {after})" | ||||
|   }, | ||||
|   "xAndNMoreUpdatesAvailable": { | ||||
|     "one": "{} 和另外 1 個應用程式有更新。", | ||||
|     "other": "{} 和另外 {} 個應用程式有更新。" | ||||
|   }, | ||||
|   "xAndNMoreUpdatesInstalled": { | ||||
|     "one": "{} 和另外 1 個應用程式已更新。", | ||||
|     "other": "{} 和另外 {} 個應用程式已更新。" | ||||
|   }, | ||||
|   "xAndNMoreUpdatesFailed": { | ||||
|     "one": "更新 {} 和另外 1 個應用程式失敗。", | ||||
|     "other": "更新 {} 和另外 {} 個應用程式失敗。" | ||||
|   }, | ||||
|   "xAndNMoreUpdatesPossiblyInstalled": { | ||||
|     "one": "{} 和另外 1 個應用程式可能已更新。", | ||||
|     "other": "{} 和另外 {} 個應用程式可能已更新。" | ||||
|   }, | ||||
|   "apk": { | ||||
|     "one": "{} 個 APK", | ||||
|     "other": "{} 個 APK" | ||||
|   } | ||||
|     "invalidURLForSource": "不是有效的 {} 應用程式 URL", | ||||
|     "noReleaseFound": "找不到合適的版本", | ||||
|     "noVersionFound": "無法確定版本", | ||||
|     "urlMatchesNoSource": "URL 不符合已知來源", | ||||
|     "cantInstallOlderVersion": "無法安裝舊版本的應用程式", | ||||
|     "appIdMismatch": "下載的套件 ID 與現有的應用程式 ID 不匹配", | ||||
|     "functionNotImplemented": "此類別尚未實作此功能", | ||||
|     "placeholder": "佔位", | ||||
|     "someErrors": "發生了一些錯誤", | ||||
|     "unexpectedError": "意外錯誤", | ||||
|     "ok": "確定", | ||||
|     "and": "和", | ||||
|     "githubPATLabel": "GitHub 個人存取權杖(增加速率限制)", | ||||
|     "includePrereleases": "包含預發佈版本", | ||||
|     "fallbackToOlderReleases": "回退到舊版本", | ||||
|     "filterReleaseTitlesByRegEx": "用正則表達式過濾版本標題", | ||||
|     "invalidRegEx": "無效的正則表達式", | ||||
|     "noDescription": "無描述", | ||||
|     "cancel": "取消", | ||||
|     "continue": "繼續", | ||||
|     "requiredInBrackets": "(必填)", | ||||
|     "dropdownNoOptsError": "錯誤:下拉選單必須至少有一個選項", | ||||
|     "colour": "顏色", | ||||
|     "standard": "標準", | ||||
|     "custom": "自訂", | ||||
|     "useMaterialYou": "使用 Material You", | ||||
|     "githubStarredRepos": "GitHub Starred Repos", | ||||
|     "uname": "使用者名稱", | ||||
|     "wrongArgNum": "提供的參數數量錯誤", | ||||
|     "xIsTrackOnly": "{} 是僅追蹤", | ||||
|     "source": "來源", | ||||
|     "app": "應用程式", | ||||
|     "appsFromSourceAreTrackOnly": "來自此來源的應用程式是「僅追蹤」。", | ||||
|     "youPickedTrackOnly": "您已選擇「僅追蹤」選項。", | ||||
|     "trackOnlyAppDescription": "該應用程式將被追蹤更新,但 Obtainium 將無法下載或安裝它。", | ||||
|     "cancelled": "已取消", | ||||
|     "appAlreadyAdded": "應用程式已添加", | ||||
|     "alreadyUpToDateQuestion": "應用程式已經是最新的?", | ||||
|     "addApp": "添加應用程式", | ||||
|     "appSourceURL": "應用程式來源 URL", | ||||
|     "error": "錯誤", | ||||
|     "add": "添加", | ||||
|     "searchSomeSourcesLabel": "搜尋(僅限部分來源)", | ||||
|     "search": "搜尋", | ||||
|     "additionalOptsFor": "{} 的其他選項", | ||||
|     "supportedSources": "支持的來源", | ||||
|     "trackOnlyInBrackets": "(僅追蹤)", | ||||
|     "searchableInBrackets": "(可搜尋)", | ||||
|     "appsString": "應用程式", | ||||
|     "noApps": "無應用程式", | ||||
|     "noAppsForFilter": "無符合過濾條件的應用程式", | ||||
|     "byX": "由 {}", | ||||
|     "percentProgress": "進度:{}%", | ||||
|     "pleaseWait": "請稍候", | ||||
|     "updateAvailable": "有可用的更新", | ||||
|     "notInstalled": "未安裝", | ||||
|     "pseudoVersion": "偽版本", | ||||
|     "selectAll": "全選", | ||||
|     "deselectX": "取消選取 {}", | ||||
|     "xWillBeRemovedButRemainInstalled": "{} 將從 Obtainium 中移除,但仍然安裝在設備上。", | ||||
|     "removeSelectedAppsQuestion": "移除選取的應用程式?", | ||||
|     "removeSelectedApps": "移除選取的應用程式", | ||||
|     "updateX": "更新 {}", | ||||
|     "installX": "安裝 {}", | ||||
|     "markXTrackOnlyAsUpdated": "標記 {}\n(僅追蹤)\n為已更新", | ||||
|     "changeX": "更改 {}", | ||||
|     "installUpdateApps": "安裝/更新應用程式", | ||||
|     "installUpdateSelectedApps": "安裝/更新選取的應用程式", | ||||
|     "markXSelectedAppsAsUpdated": "標記 {} 個選取的應用程式為已更新?", | ||||
|     "no": "否", | ||||
|     "yes": "是", | ||||
|     "markSelectedAppsUpdated": "標記選取的應用程式為已更新", | ||||
|     "pinToTop": "釘選到頂部", | ||||
|     "unpinFromTop": "取消釘選", | ||||
|     "resetInstallStatusForSelectedAppsQuestion": "重設選取應用程式的安裝狀態?", | ||||
|     "installStatusOfXWillBeResetExplanation": "任何選取應用程式的安裝狀態將被重設。\n\n這可以在由於更新失敗或其他問題導致 Obtainium 顯示的應用程式版本不正確時有所幫助。", | ||||
|     "customLinkMessage": "這些連結適用於已安裝 Obtainium 的設備", | ||||
|     "shareAppConfigLinks": "分享應用程式配置為 HTML 連結", | ||||
|     "shareSelectedAppURLs": "分享選取的應用程式 URL", | ||||
|     "resetInstallStatus": "重設安裝狀態", | ||||
|     "more": "更多", | ||||
|     "removeOutdatedFilter": "移除過時應用程式過濾", | ||||
|     "showOutdatedOnly": "僅顯示過時的應用程式", | ||||
|     "filter": "過濾", | ||||
|     "filterApps": "過濾應用程式", | ||||
|     "appName": "應用程式名稱", | ||||
|     "author": "作者", | ||||
|     "upToDateApps": "最新的應用程式", | ||||
|     "nonInstalledApps": "未安裝的應用程式", | ||||
|     "importExport": "匯入/匯出", | ||||
|     "settings": "設定", | ||||
|     "exportedTo": "匯出到 {}", | ||||
|     "obtainiumExport": "Obtainium 匯出", | ||||
|     "invalidInput": "無效的輸入", | ||||
|     "importedX": "已匯入 {}", | ||||
|     "obtainiumImport": "Obtainium 匯入", | ||||
|     "importFromURLList": "從 URL 列表匯入", | ||||
|     "searchQuery": "搜尋查詢", | ||||
|     "appURLList": "應用程式 URL 清單", | ||||
|     "line": "行", | ||||
|     "searchX": "搜尋 {}", | ||||
|     "noResults": "未找到結果", | ||||
|     "importX": "匯入 {}", | ||||
|     "importedAppsIdDisclaimer": "匯入的應用程式可能會錯誤地顯示為「未安裝」。\n要修正此問題,請通過 Obtainium 重新安裝它們。\n這不應該影響應用程式數據。\n\n僅影響 URL 和第三方匯入方法。", | ||||
|     "importErrors": "匯入錯誤", | ||||
|     "importedXOfYApps": "已匯入 {} 個中的 {} 個應用程式。", | ||||
|     "followingURLsHadErrors": "以下 URL 有錯誤:", | ||||
|     "selectURL": "選擇 URL", | ||||
|     "selectURLs": "選擇多個 URL", | ||||
|     "pick": "選取", | ||||
|     "theme": "主題", | ||||
|     "dark": "深色", | ||||
|     "light": "淺色", | ||||
|     "followSystem": "跟隨系統", | ||||
|     "followSystemThemeExplanation": "僅使用第三方應用程式時才可跟隨系統主題", | ||||
|     "useBlackTheme": "使用純黑色深色主題", | ||||
|     "appSortBy": "應用程式排序依據", | ||||
|     "authorName": "作者/名稱", | ||||
|     "nameAuthor": "名稱/作者", | ||||
|     "asAdded": "添加順序", | ||||
|     "appSortOrder": "應用程式排序順序", | ||||
|     "ascending": "升序", | ||||
|     "descending": "降序", | ||||
|     "bgUpdateCheckInterval": "背景更新檢查間隔", | ||||
|     "neverManualOnly": "從不 - 僅手動", | ||||
|     "appearance": "外觀", | ||||
|     "showWebInAppView": "在應用程式檢視中顯示來源網頁", | ||||
|     "pinUpdates": "將更新釘選至應用程式檢視的頂端", | ||||
|     "updates": "更新", | ||||
|     "sourceSpecific": "特定來源", | ||||
|     "appSource": "應用程式來源", | ||||
|     "noLogs": "無日誌", | ||||
|     "appLogs": "應用程式日誌", | ||||
|     "close": "關閉", | ||||
|     "share": "分享", | ||||
|     "appNotFound": "未找到應用程式", | ||||
|     "obtainiumExportHyphenatedLowercase": "obtainium-export", | ||||
|     "pickAnAPK": "選擇一個 APK", | ||||
|     "appHasMoreThanOnePackage": "{} 有多個套件:", | ||||
|     "deviceSupportsXArch": "您的設備支持 {} CPU 架構。", | ||||
|     "deviceSupportsFollowingArchs": "您的設備支持以下 CPU 架構:", | ||||
|     "warning": "警告", | ||||
|     "sourceIsXButPackageFromYPrompt": "應用程式來源是 「{}」,但發佈套件來自 「{}」。要繼續嗎?", | ||||
|     "updatesAvailable": "有可用的更新", | ||||
|     "updatesAvailableNotifDescription": "通知使用者有一個或多個由 Obtainium 追蹤的應用程式有更新", | ||||
|     "noNewUpdates": "沒有新更新。", | ||||
|     "xHasAnUpdate": "{} 有一個更新。", | ||||
|     "appsUpdated": "應用程式已更新", | ||||
|     "appsNotUpdated": "未能更新應用程式", | ||||
|     "appsUpdatedNotifDescription": "通知使用者一個或多個應用程式的更新已在背景中應用", | ||||
|     "xWasUpdatedToY": "{} 已更新到 {}。", | ||||
|     "xWasNotUpdatedToY": "未能將 {} 更新到 {}。", | ||||
|     "errorCheckingUpdates": "檢查更新時出錯", | ||||
|     "errorCheckingUpdatesNotifDescription": "背景檢查更新失敗時顯示的通知", | ||||
|     "appsRemoved": "應用程式已移除", | ||||
|     "appsRemovedNotifDescription": "通知使用者由於載入時出錯,一個或多個應用程式已被移除", | ||||
|     "xWasRemovedDueToErrorY": "{} 已因以下錯誤被移除:{}", | ||||
|     "completeAppInstallation": "完成應用程式安裝", | ||||
|     "obtainiumMustBeOpenToInstallApps": "Obtainium 必須開啟才能安裝應用程式", | ||||
|     "completeAppInstallationNotifDescription": "請使用者返回 Obtainium 以完成應用程式安裝", | ||||
|     "checkingForUpdates": "正在檢查更新", | ||||
|     "checkingForUpdatesNotifDescription": "檢查更新時顯示的暫時性通知", | ||||
|     "pleaseAllowInstallPerm": "請允許 Obtainium 安裝應用程式", | ||||
|     "trackOnly": "僅追蹤", | ||||
|     "errorWithHttpStatusCode": "錯誤 {}", | ||||
|     "versionCorrectionDisabled": "版本校正已禁用(外掛程式似乎無法正常工作)", | ||||
|     "unknown": "未知", | ||||
|     "none": "無", | ||||
|     "never": "從不", | ||||
|     "latestVersionX": "最新版本:{}", | ||||
|     "installedVersionX": "已安裝版本:{}", | ||||
|     "lastUpdateCheckX": "上次檢查更新時間:{}", | ||||
|     "remove": "移除", | ||||
|     "yesMarkUpdated": "是,標記為已更新", | ||||
|     "fdroid": "F-Droid 官方", | ||||
|     "appIdOrName": "應用程式 ID 或名稱", | ||||
|     "appId": "應用程式 ID", | ||||
|     "appWithIdOrNameNotFound": "找不到具有該 ID 或名稱的應用程式", | ||||
|     "reposHaveMultipleApps": "倉庫可能包含多個應用程式", | ||||
|     "fdroidThirdPartyRepo": "F-Droid 第三方倉庫", | ||||
|     "steamMobile": "Steam 行動版", | ||||
|     "steamChat": "Steam 聊天", | ||||
|     "install": "安裝", | ||||
|     "markInstalled": "標記為已安裝", | ||||
|     "update": "更新", | ||||
|     "markUpdated": "標記為已更新", | ||||
|     "additionalOptions": "額外選項", | ||||
|     "disableVersionDetection": "禁用版本檢測", | ||||
|     "noVersionDetectionExplanation": "此選項僅應用於版本檢測無法正確工作的應用程式。", | ||||
|     "downloadingX": "正在下載 {}", | ||||
|     "downloadX": "下載 {}", | ||||
|     "downloadedX": "已下載 {}", | ||||
|     "releaseAsset": "發佈資源", | ||||
|     "downloadNotifDescription": "通知使用者應用程式下載進度", | ||||
|     "noAPKFound": "未找到 APK", | ||||
|     "noVersionDetection": "無版本檢測", | ||||
|     "categorize": "分類", | ||||
|     "categories": "類別", | ||||
|     "category": "類別", | ||||
|     "noCategory": "無類別", | ||||
|     "noCategories": "無類別", | ||||
|     "deleteCategoriesQuestion": "刪除類別?", | ||||
|     "categoryDeleteWarning": "所有在已刪除類別中的應用程式將被設置為未分類。", | ||||
|     "addCategory": "新增類別", | ||||
|     "label": "標籤", | ||||
|     "language": "語言", | ||||
|     "copiedToClipboard": "已複製到剪貼簿", | ||||
|     "storagePermissionDenied": "存取權限被拒絕", | ||||
|     "selectedCategorizeWarning": "這將替換選取應用程式的任何現有類別設置。", | ||||
|     "filterAPKsByRegEx": "用正則表達式過濾 APK", | ||||
|     "removeFromObtainium": "從 Obtainium 移除", | ||||
|     "uninstallFromDevice": "從設備解除安裝", | ||||
|     "onlyWorksWithNonVersionDetectApps": "僅適用於禁用版本檢測的應用程式。", | ||||
|     "releaseDateAsVersion": "使用發佈日期作為版本字串", | ||||
|     "releaseDateAsVersionExplanation": "此選項僅應用於版本檢測無法正確工作但有發佈日期的應用程式。", | ||||
|     "changes": "變更", | ||||
|     "releaseDate": "發佈日期", | ||||
|     "importFromURLsInFile": "從文件中的 URL 匯入(如 OPML)", | ||||
|     "versionDetectionExplanation": "將版本字串與作業系統檢測到的版本對比", | ||||
|     "versionDetection": "版本檢測", | ||||
|     "standardVersionDetection": "標準版本檢測", | ||||
|     "groupByCategory": "按類別分組", | ||||
|     "autoApkFilterByArch": "如果可能,嘗試按 CPU 架構過濾 APK", | ||||
|     "overrideSource": "覆蓋來源", | ||||
|     "dontShowAgain": "不要再顯示", | ||||
|     "dontShowTrackOnlyWarnings": "不要顯示「僅追蹤」警告", | ||||
|     "dontShowAPKOriginWarnings": "不要顯示 APK 來源警告", | ||||
|     "moveNonInstalledAppsToBottom": "將未安裝的應用程式移到應用程式視圖的底部", | ||||
|     "gitlabPATLabel": "GitLab 個人存取權杖", | ||||
|     "about": "關於", | ||||
|     "requiresCredentialsInSettings": "{} 需要額外的憑證(在設定中)", | ||||
|     "checkOnStart": "啟動時檢查更新", | ||||
|     "tryInferAppIdFromCode": "嘗試從原始碼推斷應用程式 ID", | ||||
|     "removeOnExternalUninstall": "自動移除外部解除安裝的應用程式", | ||||
|     "pickHighestVersionCode": "自動選取最高版本號的 APK", | ||||
|     "checkUpdateOnDetailPage": "在打開應用程式詳細頁面時檢查更新", | ||||
|     "disablePageTransitions": "禁用頁面過渡動畫", | ||||
|     "reversePageTransitions": "反轉頁面過渡動畫", | ||||
|     "minStarCount": "最少星數", | ||||
|     "addInfoBelow": "在下方添加此資訊。", | ||||
|     "addInfoInSettings": "在設定中增加此資訊。", | ||||
|     "githubSourceNote": "使用 API 金鑰可以避免 GitHub 的速率限制。", | ||||
|     "sortByLastLinkSegment": "僅按連結的最後一段排序", | ||||
|     "filterReleaseNotesByRegEx": "用正則表達式過濾發佈說明", | ||||
|     "customLinkFilterRegex": "自定 APK 連結過濾正則表達式(預設為 '.apk$')", | ||||
|     "appsPossiblyUpdated": "嘗試更新應用程式", | ||||
|     "appsPossiblyUpdatedNotifDescription": "通知使用者一個或多個應用程式的更新可能已在背景中應用", | ||||
|     "xWasPossiblyUpdatedToY": "{} 可能已更新到 {}。", | ||||
|     "enableBackgroundUpdates": "啟用背景更新", | ||||
|     "backgroundUpdateReqsExplanation": "並非所有應用程式都能進行背景更新。", | ||||
|     "backgroundUpdateLimitsExplanation": "背景安裝的成功與否只能在打開 Obtainium 時確定。", | ||||
|     "verifyLatestTag": "驗證「最新」標籤", | ||||
|     "intermediateLinkRegex": "過濾要訪問的「中間」連結", | ||||
|     "filterByLinkText": "按連結文本過濾連結", | ||||
|     "intermediateLinkNotFound": "未找到中間連結", | ||||
|     "intermediateLink": "中間連結", | ||||
|     "exemptFromBackgroundUpdates": "免除背景更新(若已啟用)", | ||||
|     "bgUpdatesOnWiFiOnly": "禁用非 WiFi 的背景更新", | ||||
|     "autoSelectHighestVersionCode": "自動選擇最高 versionCode 的 APK", | ||||
|     "versionExtractionRegEx": "版本字串提取正則表達式", | ||||
|     "trimVersionString": "Trim Version String With RegEx", | ||||
|     "matchGroupToUseForX": "Match Group to Use for \"{}\"", | ||||
|     "matchGroupToUse": "要用於版本字串提取的匹配組", | ||||
|     "highlightTouchTargets": "突出顯示不明顯的觸控目標", | ||||
|     "pickExportDir": "選擇匯出目錄", | ||||
|     "autoExportOnChanges": "更改時自動匯出", | ||||
|     "includeSettings": "包含設定", | ||||
|     "filterVersionsByRegEx": "用正則表達式過濾版本", | ||||
|     "trySelectingSuggestedVersionCode": "嘗試選擇建議的 versionCode APK", | ||||
|     "dontSortReleasesList": "保留 API 的發佈順序", | ||||
|     "reverseSort": "反向排序", | ||||
|     "takeFirstLink": "使用第一個連結", | ||||
|     "skipSort": "跳過排序", | ||||
|     "debugMenu": "除錯選單", | ||||
|     "bgTaskStarted": "背景任務已啟動 - 檢查日誌。", | ||||
|     "runBgCheckNow": "立即執行背景更新檢查", | ||||
|     "versionExtractWholePage": "將版本字串提取正則表達式應用於整個頁面", | ||||
|     "installing": "正在安裝", | ||||
|     "skipUpdateNotifications": "跳過更新通知", | ||||
|     "updatesAvailableNotifChannel": "有可用的更新", | ||||
|     "appsUpdatedNotifChannel": "應用程式已更新", | ||||
|     "appsPossiblyUpdatedNotifChannel": "嘗試更新應用程式", | ||||
|     "errorCheckingUpdatesNotifChannel": "檢查更新錯誤", | ||||
|     "appsRemovedNotifChannel": "應用程式已移除", | ||||
|     "downloadingXNotifChannel": "正在下載 {}", | ||||
|     "completeAppInstallationNotifChannel": "完成應用程式安裝", | ||||
|     "checkingForUpdatesNotifChannel": "正在檢查更新", | ||||
|     "onlyCheckInstalledOrTrackOnlyApps": "僅檢查已安裝和僅追蹤的應用程式更新", | ||||
|     "supportFixedAPKURL": "支援固定的 APK 網址", | ||||
|     "selectX": "選擇 {}", | ||||
|     "parallelDownloads": "允許平行下載", | ||||
|     "useShizuku": "使用 Shizuku 或 Sui 來安裝", | ||||
|     "shizukuBinderNotFound": "Shizuku 服務未運行", | ||||
|     "shizukuOld": "舊版 Shizuku (<11) - 請更新", | ||||
|     "shizukuOldAndroidWithADB": "Shizuku 在 Android 8.1 以下版本使用 ADB 運行 - 請更新 Android 或改用 Sui", | ||||
|     "shizukuPretendToBeGooglePlay": "設置 Google Play 為安裝來源(如果使用 Shizuku)", | ||||
|     "useSystemFont": "使用系統字體", | ||||
|     "useVersionCodeAsOSVersion": "使用應用程式 versionCode 作為操作系統檢測的版本", | ||||
|     "requestHeader": "請求標頭", | ||||
|     "useLatestAssetDateAsReleaseDate": "使用最新資源上傳日期作為發佈日期", | ||||
|     "defaultPseudoVersioningMethod": "預設偽版本管理方法", | ||||
|     "partialAPKHash": "部分 APK Hash", | ||||
|     "APKLinkHash": "APK 連結 Hash", | ||||
|     "directAPKLink": "直接 APK 連結", | ||||
|     "pseudoVersionInUse": "正在使用偽版本", | ||||
|     "installed": "已安裝", | ||||
|     "latest": "最新", | ||||
|     "invertRegEx": "反轉正則表達式", | ||||
|     "note": "備註", | ||||
|     "selfHostedNote": "可使用「{}」下拉選單來訪問任何來源的自託管/自定義實例。", | ||||
|     "badDownload": "無法解析 APK(不兼容或下載不完整)", | ||||
|     "beforeNewInstallsShareToAppVerifier": "將新應用程式分享到 AppVerifier(如果可用)", | ||||
|     "appVerifierInstructionToast": "分享至 AppVerifier,然後準備好時返回此處。", | ||||
|     "wiki": "幫助/維基", | ||||
|     "crowdsourcedConfigsLabel": "群眾外包的應用程式配置(使用風險自負)", | ||||
|     "removeAppQuestion": { | ||||
|         "one": "移除應用程式?", | ||||
|         "other": "移除應用程式?" | ||||
|     }, | ||||
|     "tooManyRequestsTryAgainInMinutes": { | ||||
|         "one": "請求過多(速率限制)- {} 分鐘後重試", | ||||
|         "other": "請求過多(速率限制)- {} 分鐘後重試" | ||||
|     }, | ||||
|     "bgUpdateGotErrorRetryInMinutes": { | ||||
|         "one": "背景更新檢查遇到 {},將在 {} 分鐘後重新檢查", | ||||
|         "other": "背景更新檢查遇到 {},將在 {} 分鐘後重新檢查" | ||||
|     }, | ||||
|     "bgCheckFoundUpdatesWillNotifyIfNeeded": { | ||||
|         "one": "背景更新檢查發現 {} 個更新 - 如果需要將通知使用者", | ||||
|         "other": "背景更新檢查發現 {} 個更新 - 如果需要將通知使用者" | ||||
|     }, | ||||
|     "apps": { | ||||
|         "one": "{} 個應用程式", | ||||
|         "other": "{} 個應用程式" | ||||
|     }, | ||||
|     "url": { | ||||
|         "one": "{} 個 URL", | ||||
|         "other": "{} 個 URL" | ||||
|     }, | ||||
|     "minute": { | ||||
|         "one": "{} 分鐘", | ||||
|         "other": "{} 分鐘" | ||||
|     }, | ||||
|     "hour": { | ||||
|         "one": "{} 小時", | ||||
|         "other": "{} 小時" | ||||
|     }, | ||||
|     "day": { | ||||
|         "one": "{} 天", | ||||
|         "other": "{} 天" | ||||
|     }, | ||||
|     "clearedNLogsBeforeXAfterY": { | ||||
|         "one": "清除 {n} 個日誌(之前 = {before},之後 = {after})", | ||||
|         "other": "清除 {n} 個日誌(之前 = {before},之後 = {after})" | ||||
|     }, | ||||
|     "xAndNMoreUpdatesAvailable": { | ||||
|         "one": "{} 和另外 1 個應用程式有更新。", | ||||
|         "other": "{} 和另外 {} 個應用程式有更新。" | ||||
|     }, | ||||
|     "xAndNMoreUpdatesInstalled": { | ||||
|         "one": "{} 和另外 1 個應用程式已更新。", | ||||
|         "other": "{} 和另外 {} 個應用程式已更新。" | ||||
|     }, | ||||
|     "xAndNMoreUpdatesFailed": { | ||||
|         "one": "更新 {} 和另外 1 個應用程式失敗。", | ||||
|         "other": "更新 {} 和另外 {} 個應用程式失敗。" | ||||
|     }, | ||||
|     "xAndNMoreUpdatesPossiblyInstalled": { | ||||
|         "one": "{} 和另外 1 個應用程式可能已更新。", | ||||
|         "other": "{} 和另外 {} 個應用程式可能已更新。" | ||||
|     }, | ||||
|     "apk": { | ||||
|         "one": "{} 個 APK", | ||||
|         "other": "{} 個 APK" | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -259,6 +259,8 @@ | ||||
|     "bgUpdatesOnWiFiOnly": "未连接 Wi-Fi 时禁用后台更新", | ||||
|     "autoSelectHighestVersionCode": "自动选择内部版本号最高的 APK 文件", | ||||
|     "versionExtractionRegEx": "提取版本号的正则表达式", | ||||
|     "trimVersionString": "使用 RegEx 修剪版本字符串", | ||||
|     "matchGroupToUseForX": "用于\"{}\"的匹配组", | ||||
|     "matchGroupToUse": "从上述匹配结果中引用的捕获组", | ||||
|     "highlightTouchTargets": "突出展示不明显的可交互区域", | ||||
|     "pickExportDir": "选择导出文件夹", | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
| 		<ul> | ||||
| 			<li>GitHub</li> | ||||
| 			<li>GitLab</li> | ||||
| 			<li>Codeberg</li> | ||||
| 			<li>Forgejo (Codeberg)</li> | ||||
| 			<li>F-Droid</li> | ||||
| 			<li>Third Party F-Droid Repos</li> | ||||
| 			<li>IzzyOnDroid</li> | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
| 		<ul> | ||||
| 			<li>GitHub</li> | ||||
| 			<li>GitLab</li> | ||||
| 			<li>Codeberg</li> | ||||
| 			<li>Forgejo (Codeberg)</li> | ||||
| 			<li>F-Droid</li> | ||||
| 			<li>Third Party F-Droid Repos</li> | ||||
| 			<li>IzzyOnDroid</li> | ||||
|   | ||||
| @@ -1,5 +1,7 @@ | ||||
| import 'package:device_info_plus/device_info_plus.dart'; | ||||
| import 'package:easy_localization/easy_localization.dart'; | ||||
| import 'package:html/parser.dart'; | ||||
| import 'package:obtainium/app_sources/html.dart'; | ||||
| import 'package:obtainium/custom_errors.dart'; | ||||
| import 'package:obtainium/providers/source_provider.dart'; | ||||
|  | ||||
| @@ -58,40 +60,97 @@ class APKPure extends AppSource { | ||||
|   ) async { | ||||
|     String appId = (await tryInferringAppId(standardUrl))!; | ||||
|     String host = Uri.parse(standardUrl).host; | ||||
|     var res = await sourceRequest('$standardUrl/download', additionalSettings); | ||||
|     var resChangelog = await sourceRequest(standardUrl, additionalSettings); | ||||
|     if (res.statusCode == 200 && resChangelog.statusCode == 200) { | ||||
|       var html = parse(res.body); | ||||
|       var htmlChangelog = parse(resChangelog.body); | ||||
|       String? version = html.querySelector('span.info-sdk span')?.text.trim(); | ||||
|       if (version == null) { | ||||
|         throw NoVersionError(); | ||||
|       } | ||||
|       String? dateString = | ||||
|           html.querySelector('span.info-other span.date')?.text.trim(); | ||||
|       DateTime? releaseDate = parseDateTimeMMMddCommayyyy(dateString); | ||||
|       String type = html.querySelector('a.info-tag')?.text.trim() ?? 'APK'; | ||||
|       List<MapEntry<String, String>> apkUrls = [ | ||||
|         MapEntry('$appId.apk', | ||||
|             'https://d.${hosts.contains(host) ? 'cdnpure.com' : host}/b/$type/$appId?version=latest') | ||||
|       ]; | ||||
|       String author = html | ||||
|               .querySelector('span.info-sdk') | ||||
|               ?.text | ||||
|               .trim() | ||||
|               .substring(version.length + 4) ?? | ||||
|           Uri.parse(standardUrl).pathSegments.reversed.last; | ||||
|       String appName = | ||||
|           html.querySelector('h1.info-title')?.text.trim() ?? appId; | ||||
|       String? changeLog = htmlChangelog | ||||
|           .querySelector("div.whats-new-info p:not(.date)") | ||||
|           ?.innerHtml | ||||
|           .trim() | ||||
|           .replaceAll("<br>", "  \n"); | ||||
|       return APKDetails(version, apkUrls, AppNames(author, appName), | ||||
|           releaseDate: releaseDate, changeLog: changeLog); | ||||
|     } else { | ||||
|       throw getObtainiumHttpError(res); | ||||
|  | ||||
|     var res0 = await sourceRequest('$standardUrl/versions', additionalSettings); | ||||
|     var versionLinks = await grabLinksCommon(res0, { | ||||
|       'skipSort': true, | ||||
|       'customLinkFilterRegex': '$standardUrl/download/[^/]+\$' | ||||
|     }); | ||||
|  | ||||
|     // if (versionLinks.length > 7) { | ||||
|     //   // Returns up to 30 which is too much - would take too long and possibly get blocked/rate-limited | ||||
|     //   versionLinks = versionLinks.sublist(0, 7); | ||||
|     // } | ||||
|  | ||||
|     var supportedArchs = (await DeviceInfoPlugin().androidInfo).supportedAbis; | ||||
|  | ||||
|     if (additionalSettings['autoApkFilterByArch'] != true) { | ||||
|       // No need to request multiple versions when we're not going to filter them (always pick the top one) | ||||
|       versionLinks = versionLinks.sublist(0, 1); | ||||
|     } | ||||
|     if (versionLinks.isEmpty) { | ||||
|       throw NoReleasesError(); | ||||
|     } | ||||
|  | ||||
|     for (var i = 0; i < versionLinks.length; i++) { | ||||
|       var link = versionLinks[i]; | ||||
|       var res = await sourceRequest(link.key, additionalSettings); | ||||
|       if (res.statusCode == 200) { | ||||
|         var html = parse(res.body); | ||||
|         var apksDiv = | ||||
|             html.querySelector('#version-list div div.show-more-content'); | ||||
|         DateTime? topReleaseDate; | ||||
|         var apkUrls = apksDiv | ||||
|                 ?.querySelectorAll('div.group-title') | ||||
|                 .map((e) { | ||||
|                   String? architecture = e.text.trim(); | ||||
|                   // Only take the first APK for each architecture, ignore others for now, for simplicity | ||||
|                   // Unclear why there can even be multiple APKs for the same version and arch | ||||
|                   var apkInfo = e.nextElementSibling?.querySelector('div.info'); | ||||
|                   String? versionCode = RegExp('[0-9]+') | ||||
|                       .firstMatch(apkInfo | ||||
|                               ?.querySelector('div.info-top span.code') | ||||
|                               ?.text ?? | ||||
|                           '') | ||||
|                       ?.group(0) | ||||
|                       ?.trim(); | ||||
|                   String? type = apkInfo | ||||
|                           ?.querySelector('div.info-top span.tag') | ||||
|                           ?.text | ||||
|                           .trim() ?? | ||||
|                       'APK'; | ||||
|                   String? dateString = apkInfo | ||||
|                       ?.querySelector('div.info-bottom span.time') | ||||
|                       ?.text | ||||
|                       .trim(); | ||||
|                   DateTime? releaseDate = | ||||
|                       parseDateTimeMMMddCommayyyy(dateString); | ||||
|                   if (additionalSettings['autoApkFilterByArch'] == true && | ||||
|                       !supportedArchs.contains(architecture)) { | ||||
|                     return const MapEntry('', ''); | ||||
|                   } | ||||
|                   topReleaseDate ??= | ||||
|                       releaseDate; // Just use the release date of the first APK in the list as the release date for this version | ||||
|                   return MapEntry( | ||||
|                       '$appId-$versionCode-$architecture.${type.toLowerCase()}', | ||||
|                       'https://d.${hosts.contains(host) ? 'cdnpure.com' : host}/b/$type/$appId?versionCode=$versionCode'); | ||||
|                 }) | ||||
|                 .where((e) => e.key.isNotEmpty) | ||||
|                 .toList() ?? | ||||
|             []; | ||||
|         if (apkUrls.isEmpty) { | ||||
|           continue; | ||||
|         } | ||||
|         String version = Uri.parse(link.key).pathSegments.last; | ||||
|         String author = html | ||||
|                 .querySelector('span.info-sdk') | ||||
|                 ?.text | ||||
|                 .trim() | ||||
|                 .substring(version.length + 4) ?? | ||||
|             Uri.parse(standardUrl).pathSegments.reversed.last; | ||||
|         String appName = | ||||
|             html.querySelector('h1.info-title')?.text.trim() ?? appId; | ||||
|         String? changeLog = html | ||||
|             .querySelector('div.module.change-log') | ||||
|             ?.innerHtml | ||||
|             .trim() | ||||
|             .replaceAll("<br>", "  \n"); | ||||
|         return APKDetails(version, apkUrls, AppNames(author, appName), | ||||
|             releaseDate: topReleaseDate, changeLog: changeLog); | ||||
|       } else { | ||||
|         throw getObtainiumHttpError(res); | ||||
|       } | ||||
|     } | ||||
|     throw NoAPKError(); | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -5,6 +5,7 @@ import 'package:obtainium/providers/source_provider.dart'; | ||||
| class Codeberg extends AppSource { | ||||
|   GitHub gh = GitHub(); | ||||
|   Codeberg() { | ||||
|     name = 'Forgejo (Codeberg)'; | ||||
|     hosts = ['codeberg.org']; | ||||
|  | ||||
|     additionalSourceAppSpecificSettingFormItems = | ||||
|   | ||||
| @@ -88,8 +88,8 @@ class FDroidRepo extends AppSource { | ||||
|  | ||||
|   @override | ||||
|   void runOnAddAppInputChange(String userInput) { | ||||
|     this.additionalSourceAppSpecificSettingFormItems = | ||||
|         this.additionalSourceAppSpecificSettingFormItems.map((row) { | ||||
|     additionalSourceAppSpecificSettingFormItems = | ||||
|         additionalSourceAppSpecificSettingFormItems.map((row) { | ||||
|       row = row.map((item) { | ||||
|         if (item.key == 'appIdOrName') { | ||||
|           try { | ||||
|   | ||||
| @@ -171,7 +171,7 @@ class GitHub extends AppSource { | ||||
|       {bool forAPKDownload = false}) async { | ||||
|     var token = await getTokenIfAny(additionalSettings); | ||||
|     var headers = <String, String>{}; | ||||
|     if (token != null) { | ||||
|     if (token != null && token.isNotEmpty) { | ||||
|       headers[HttpHeaders.authorizationHeader] = 'Token $token'; | ||||
|     } | ||||
|     if (forAPKDownload == true) { | ||||
|   | ||||
| @@ -131,6 +131,18 @@ class GitLab extends AppSource { | ||||
|  | ||||
|     bool trackOnly = additionalSettings['trackOnly'] == true; | ||||
|  | ||||
|     // Get project ID | ||||
|     Response res0 = await sourceRequest( | ||||
|         'https://${hosts[0]}/api/v4/projects/${names.author}%2F${names.name}?$optionalAuth', | ||||
|         additionalSettings); | ||||
|     if (res0.statusCode != 200) { | ||||
|       throw getObtainiumHttpError(res0); | ||||
|     } | ||||
|     int? projectId = jsonDecode(res0.body)['id']; | ||||
|     if (projectId == null) { | ||||
|       throw NoReleasesError(); | ||||
|     } | ||||
|  | ||||
|     // Request data from REST API | ||||
|     Response res = await sourceRequest( | ||||
|         'https://${hosts[0]}/api/v4/projects/${names.author}%2F${names.name}/${trackOnly ? 'repository/tags' : 'releases'}?$optionalAuth', | ||||
| @@ -157,7 +169,7 @@ class GitLab extends AppSource { | ||||
|               .join('.apk\n') | ||||
|               .split('\n') | ||||
|               .where((s) => s.startsWith('/uploads/') && s.endsWith('apk')) | ||||
|               .map((s) => '$standardUrl$s') | ||||
|               .map((s) => 'https://${hosts[0]}/-/project/$projectId$s') | ||||
|               .toList(); | ||||
|       var apkUrlsSet = apkUrlsFromAssets.toSet(); | ||||
|       apkUrlsSet.addAll(uploadedAPKsFromDescription); | ||||
|   | ||||
| @@ -92,7 +92,89 @@ bool _isNumeric(String s) { | ||||
|   return s.codeUnitAt(0) >= 48 && s.codeUnitAt(0) <= 57; | ||||
| } | ||||
|  | ||||
| // Given an HTTP response, grab some links according to the common additional settings | ||||
| // (those that apply to intermediate and final steps) | ||||
| Future<List<MapEntry<String, String>>> grabLinksCommon( | ||||
|     Response res, Map<String, dynamic> additionalSettings) async { | ||||
|   if (res.statusCode != 200) { | ||||
|     throw getObtainiumHttpError(res); | ||||
|   } | ||||
|   var html = parse(res.body); | ||||
|   List<MapEntry<String, String>> allLinks = html | ||||
|       .querySelectorAll('a') | ||||
|       .map((element) => MapEntry( | ||||
|           element.attributes['href'] ?? '', | ||||
|           element.text.isNotEmpty | ||||
|               ? element.text | ||||
|               : (element.attributes['href'] ?? '').split('/').last)) | ||||
|       .where((element) => element.key.isNotEmpty) | ||||
|       .map((e) => MapEntry(ensureAbsoluteUrl(e.key, res.request!.url), e.value)) | ||||
|       .toList(); | ||||
|   if (allLinks.isEmpty) { | ||||
|     allLinks = RegExp( | ||||
|             r'(http|ftp|https)://([\w_-]+(?:(?:\.[\w_-]+)+))([\w.,@?^=%&:/~+#-]*[\w@?^=%&/~+#-])?') | ||||
|         .allMatches(res.body) | ||||
|         .map((match) => | ||||
|             MapEntry(match.group(0)!, match.group(0)?.split('/').last ?? '')) | ||||
|         .toList(); | ||||
|   } | ||||
|   List<MapEntry<String, String>> links = []; | ||||
|   bool skipSort = additionalSettings['skipSort'] == true; | ||||
|   bool filterLinkByText = additionalSettings['filterByLinkText'] == true; | ||||
|   if ((additionalSettings['customLinkFilterRegex'] as String?)?.isNotEmpty == | ||||
|       true) { | ||||
|     var reg = RegExp(additionalSettings['customLinkFilterRegex']); | ||||
|     links = allLinks.where((element) { | ||||
|       var link = element.key; | ||||
|       try { | ||||
|         link = Uri.decodeFull(element.key); | ||||
|       } catch (e) { | ||||
|         // Some links may not have valid encoding | ||||
|       } | ||||
|       return reg.hasMatch(filterLinkByText ? element.value : link); | ||||
|     }).toList(); | ||||
|   } else { | ||||
|     links = allLinks.where((element) { | ||||
|       var link = element.key; | ||||
|       try { | ||||
|         link = Uri.decodeFull(element.key); | ||||
|       } catch (e) { | ||||
|         // Some links may not have valid encoding | ||||
|       } | ||||
|       return Uri.parse(filterLinkByText ? element.value : link) | ||||
|           .path | ||||
|           .toLowerCase() | ||||
|           .endsWith('.apk'); | ||||
|     }).toList(); | ||||
|   } | ||||
|   if (!skipSort) { | ||||
|     links.sort((a, b) => additionalSettings['sortByLastLinkSegment'] == true | ||||
|         ? compareAlphaNumeric(a.key.split('/').where((e) => e.isNotEmpty).last, | ||||
|             b.key.split('/').where((e) => e.isNotEmpty).last) | ||||
|         : compareAlphaNumeric(a.key, b.key)); | ||||
|   } | ||||
|   if (additionalSettings['reverseSort'] == true) { | ||||
|     links = links.reversed.toList(); | ||||
|   } | ||||
|   return links; | ||||
| } | ||||
|  | ||||
| class HTML extends AppSource { | ||||
|   @override | ||||
|   List<List<GeneratedFormItem>> get combinedAppSpecificSettingFormItems { | ||||
|     return super.combinedAppSpecificSettingFormItems.map((r) { | ||||
|       return r.map((e) { | ||||
|         if (e.key == 'versionExtractionRegEx') { | ||||
|           e.label = tr('versionExtractionRegEx'); | ||||
|         } | ||||
|         if (e.key == 'matchGroupToUse') { | ||||
|           e.label = tr('matchGroupToUse'); | ||||
|         } | ||||
|         return e; | ||||
|       }).toList(); | ||||
|     }).toList(); | ||||
|   } | ||||
|  | ||||
|   var finalStepFormitems = [ | ||||
|     [ | ||||
|       GeneratedFormTextField('customLinkFilterRegex', | ||||
| @@ -210,75 +292,6 @@ class HTML extends AppSource { | ||||
|     return url; | ||||
|   } | ||||
|  | ||||
|   // Given an HTTP response, grab some links according to the common additional settings | ||||
|   // (those that apply to intermediate and final steps) | ||||
|   Future<List<MapEntry<String, String>>> grabLinksCommon( | ||||
|       Response res, Map<String, dynamic> additionalSettings) async { | ||||
|     if (res.statusCode != 200) { | ||||
|       throw getObtainiumHttpError(res); | ||||
|     } | ||||
|     var html = parse(res.body); | ||||
|     List<MapEntry<String, String>> allLinks = html | ||||
|         .querySelectorAll('a') | ||||
|         .map((element) => MapEntry( | ||||
|             element.attributes['href'] ?? '', | ||||
|             element.text.isNotEmpty | ||||
|                 ? element.text | ||||
|                 : (element.attributes['href'] ?? '').split('/').last)) | ||||
|         .where((element) => element.key.isNotEmpty) | ||||
|         .map((e) => | ||||
|             MapEntry(ensureAbsoluteUrl(e.key, res.request!.url), e.value)) | ||||
|         .toList(); | ||||
|     if (allLinks.isEmpty) { | ||||
|       allLinks = RegExp( | ||||
|               r'(http|ftp|https)://([\w_-]+(?:(?:\.[\w_-]+)+))([\w.,@?^=%&:/~+#-]*[\w@?^=%&/~+#-])?') | ||||
|           .allMatches(res.body) | ||||
|           .map((match) => | ||||
|               MapEntry(match.group(0)!, match.group(0)?.split('/').last ?? '')) | ||||
|           .toList(); | ||||
|     } | ||||
|     List<MapEntry<String, String>> links = []; | ||||
|     bool skipSort = additionalSettings['skipSort'] == true; | ||||
|     bool filterLinkByText = additionalSettings['filterByLinkText'] == true; | ||||
|     if ((additionalSettings['customLinkFilterRegex'] as String?)?.isNotEmpty == | ||||
|         true) { | ||||
|       var reg = RegExp(additionalSettings['customLinkFilterRegex']); | ||||
|       links = allLinks.where((element) { | ||||
|         var link = element.key; | ||||
|         try { | ||||
|           link = Uri.decodeFull(element.key); | ||||
|         } catch (e) { | ||||
|           // Some links may not have valid encoding | ||||
|         } | ||||
|         return reg.hasMatch(filterLinkByText ? element.value : link); | ||||
|       }).toList(); | ||||
|     } else { | ||||
|       links = allLinks.where((element) { | ||||
|         var link = element.key; | ||||
|         try { | ||||
|           link = Uri.decodeFull(element.key); | ||||
|         } catch (e) { | ||||
|           // Some links may not have valid encoding | ||||
|         } | ||||
|         return Uri.parse(filterLinkByText ? element.value : link) | ||||
|             .path | ||||
|             .toLowerCase() | ||||
|             .endsWith('.apk'); | ||||
|       }).toList(); | ||||
|     } | ||||
|     if (!skipSort) { | ||||
|       links.sort((a, b) => additionalSettings['sortByLastLinkSegment'] == true | ||||
|           ? compareAlphaNumeric( | ||||
|               a.key.split('/').where((e) => e.isNotEmpty).last, | ||||
|               b.key.split('/').where((e) => e.isNotEmpty).last) | ||||
|           : compareAlphaNumeric(a.key, b.key)); | ||||
|     } | ||||
|     if (additionalSettings['reverseSort'] == true) { | ||||
|       links = links.reversed.toList(); | ||||
|     } | ||||
|     return links; | ||||
|   } | ||||
|  | ||||
|   @override | ||||
|   Future<APKDetails> getLatestAPKDetails( | ||||
|     String standardUrl, | ||||
|   | ||||
| @@ -246,14 +246,14 @@ class _ObtainiumState extends State<Obtainium> { | ||||
|                   ? darkColorScheme | ||||
|                   : lightColorScheme, | ||||
|               fontFamily: | ||||
|                   settingsProvider.useSystemFont ? 'SystemFont' : 'Metropolis'), | ||||
|                   settingsProvider.useSystemFont ? 'SystemFont' : 'Wix-Madefor-Display'), | ||||
|           darkTheme: ThemeData( | ||||
|               useMaterial3: true, | ||||
|               colorScheme: settingsProvider.theme == ThemeSettings.light | ||||
|                   ? lightColorScheme | ||||
|                   : darkColorScheme, | ||||
|               fontFamily: | ||||
|                   settingsProvider.useSystemFont ? 'SystemFont' : 'Metropolis'), | ||||
|                   settingsProvider.useSystemFont ? 'SystemFont' : 'Wix-Madefor-Display'), | ||||
|           home: Shortcuts(shortcuts: <LogicalKeySet, Intent>{ | ||||
|             LogicalKeySet(LogicalKeyboardKey.select): const ActivateIntent(), | ||||
|           }, child: const HomePage())); | ||||
|   | ||||
| @@ -917,6 +917,27 @@ class AppsPageState extends State<AppsPage> { | ||||
|                                 }, | ||||
|                           child: Text(tr('shareAppConfigLinks'))), | ||||
|                       const Divider(), | ||||
|                       TextButton( | ||||
|                           onPressed: selectedAppIds.isEmpty | ||||
|                               ? null | ||||
|                               : () { | ||||
|                                   var exportJSON = jsonEncode( | ||||
|                                       appsProvider.generateExportJSON( | ||||
|                                           appIds: selectedApps | ||||
|                                               .map((e) => e.id) | ||||
|                                               .toList(), | ||||
|                                           overrideExportSettings: false)); | ||||
|                                   XFile f = XFile.fromData( | ||||
|                                       Uint8List.fromList( | ||||
|                                           utf8.encode(exportJSON)), | ||||
|                                       mimeType: 'application/json', | ||||
|                                       name: | ||||
|                                           '${tr('obtainiumExportHyphenatedLowercase')}-${selectedApps.length}-${DateTime.now().millisecondsSinceEpoch}'); | ||||
|                                   Share.shareXFiles([f]); | ||||
|                                 }, | ||||
|                           child: Text( | ||||
|                               '${tr('share')} - ${tr('obtainiumExport')}')), | ||||
|                       const Divider(), | ||||
|                       TextButton( | ||||
|                           onPressed: () { | ||||
|                             appsProvider | ||||
| @@ -1056,7 +1077,9 @@ class AppsPageState extends State<AppsPage> { | ||||
|           IconButton( | ||||
|               color: Theme.of(context).colorScheme.primary, | ||||
|               style: const ButtonStyle(visualDensity: VisualDensity.compact), | ||||
|               tooltip: '${tr('filter')}${isFilterOff ? '' : ' *'}', | ||||
|               tooltip: isFilterOff | ||||
|                   ? tr('filterApps') | ||||
|                   : '${tr('filter')} - ${tr('remove')}', | ||||
|               onPressed: isFilterOff | ||||
|                   ? showFilterDialog | ||||
|                   : () { | ||||
| @@ -1065,8 +1088,8 @@ class AppsPageState extends State<AppsPage> { | ||||
|                       }); | ||||
|                     }, | ||||
|               icon: Icon(isFilterOff | ||||
|                   ? Icons.filter_list_rounded | ||||
|                   : Icons.filter_list_off_rounded)), | ||||
|                   ? Icons.search_rounded | ||||
|                   : Icons.search_off_rounded)), | ||||
|           const SizedBox( | ||||
|             width: 10, | ||||
|           ), | ||||
|   | ||||
| @@ -220,7 +220,9 @@ Future<File> downloadFile(String url, String fileName, bool fileNameHasExt, | ||||
|   if (ext.endsWith('"') || ext.endsWith("other")) { | ||||
|     ext = ext.substring(0, ext.length - 1); | ||||
|   } | ||||
|   if (url.toLowerCase().endsWith('.apk') && ext != 'apk') { | ||||
|   if (((Uri.tryParse(url)?.path ?? url).toLowerCase().endsWith('.apk') || | ||||
|           ext == 'attachment') && | ||||
|       ext != 'apk') { | ||||
|     ext = 'apk'; | ||||
|   } | ||||
|   fileName = fileName.split('/').last; // Ensure the fileName is a file name | ||||
| @@ -365,7 +367,7 @@ class AppsProvider with ChangeNotifier { | ||||
|  | ||||
|   AppsProvider({isBg = false}) { | ||||
|     // Subscribe to changes in the app foreground status | ||||
|     foregroundStream = FGBGEvents.stream.asBroadcastStream(); | ||||
|     foregroundStream = FGBGEvents.instance.stream.asBroadcastStream(); | ||||
|     foregroundSubscription = foregroundStream?.listen((event) async { | ||||
|       isForeground = event == FGBGType.foreground; | ||||
|       if (isForeground) { | ||||
| @@ -570,7 +572,7 @@ class AppsProvider with ChangeNotifier { | ||||
|     if (!isForeground) { | ||||
|       await notificationsProvider.notify(completeInstallationNotification, | ||||
|           cancelExisting: true); | ||||
|       while (await FGBGEvents.stream.first != FGBGType.foreground) {} | ||||
|       while (await FGBGEvents.instance.stream.first != FGBGType.foreground) {} | ||||
|       await notificationsProvider.cancel(completeInstallationNotification.id); | ||||
|     } | ||||
|   } | ||||
| @@ -1499,6 +1501,34 @@ class AppsProvider with ChangeNotifier { | ||||
|     return updateAppIds; | ||||
|   } | ||||
|  | ||||
|   Map<String, dynamic> generateExportJSON( | ||||
|       {List<String>? appIds, bool? overrideExportSettings}) { | ||||
|     Map<String, dynamic> finalExport = {}; | ||||
|     finalExport['apps'] = apps.values | ||||
|         .where((e) { | ||||
|           if (appIds == null) { | ||||
|             return true; | ||||
|           } else { | ||||
|             return appIds.contains(e.app.id); | ||||
|           } | ||||
|         }) | ||||
|         .map((e) => e.app.toJson()) | ||||
|         .toList(); | ||||
|     bool shouldExportSettings = settingsProvider.exportSettings; | ||||
|     if (overrideExportSettings != null) { | ||||
|       shouldExportSettings = overrideExportSettings; | ||||
|     } | ||||
|     if (shouldExportSettings) { | ||||
|       finalExport['settings'] = Map<String, Object?>.fromEntries( | ||||
|           (settingsProvider.prefs | ||||
|                   ?.getKeys() | ||||
|                   .map((key) => MapEntry(key, settingsProvider.prefs?.get(key))) | ||||
|                   .toList()) ?? | ||||
|               []); | ||||
|     } | ||||
|     return finalExport; | ||||
|   } | ||||
|  | ||||
|   Future<String?> export( | ||||
|       {bool pickOnly = false, isAuto = false, SettingsProvider? sp}) async { | ||||
|     SettingsProvider settingsProvider = sp ?? this.settingsProvider; | ||||
| @@ -1529,17 +1559,7 @@ class AppsProvider with ChangeNotifier { | ||||
|     } | ||||
|     String? returnPath; | ||||
|     if (!pickOnly) { | ||||
|       Map<String, dynamic> finalExport = {}; | ||||
|       finalExport['apps'] = apps.values.map((e) => e.app.toJson()).toList(); | ||||
|       if (settingsProvider.exportSettings) { | ||||
|         finalExport['settings'] = Map<String, Object?>.fromEntries( | ||||
|             (settingsProvider.prefs | ||||
|                     ?.getKeys() | ||||
|                     .map((key) => | ||||
|                         MapEntry(key, settingsProvider.prefs?.get(key))) | ||||
|                     .toList()) ?? | ||||
|                 []); | ||||
|       } | ||||
|       Map<String, dynamic> finalExport = generateExportJSON(); | ||||
|       var result = await saf.createFile(exportDir, | ||||
|           displayName: | ||||
|               '${tr('obtainiumExportHyphenatedLowercase')}-${DateTime.now().toIso8601String().replaceAll(':', '-')}${isAuto ? '-auto' : ''}.json', | ||||
| @@ -1768,7 +1788,9 @@ Future<void> bgUpdateCheck(String taskId, Map<String, dynamic>? params) async { | ||||
|   int maxRetryWaitSeconds = 5; | ||||
|  | ||||
|   var netResult = await (Connectivity().checkConnectivity()); | ||||
|   if (netResult.contains(ConnectivityResult.none)) { | ||||
|   if (netResult.contains(ConnectivityResult.none) || | ||||
|       netResult.isEmpty || | ||||
|       (netResult.contains(ConnectivityResult.vpn) && netResult.length == 1)) { | ||||
|     logs.add('BG update task: No network.'); | ||||
|     return; | ||||
|   } | ||||
|   | ||||
| @@ -355,8 +355,10 @@ preStandardizeUrl(String url) { | ||||
|     url = 'https://$url'; | ||||
|   } | ||||
|   var uri = Uri.tryParse(url); | ||||
|   var trailingSlash = (uri?.path.endsWith('/') ?? false) && | ||||
|   var trailingSlash = ((uri?.path.endsWith('/') ?? false) || | ||||
|           ((uri?.path.isEmpty ?? false) && url.endsWith('/'))) && | ||||
|       (uri?.queryParameters.isEmpty ?? false); | ||||
|  | ||||
|   url = url | ||||
|           .split('/') | ||||
|           .where((e) => e.isNotEmpty) | ||||
| @@ -493,13 +495,15 @@ abstract class AppSource { | ||||
|     ], | ||||
|     [ | ||||
|       GeneratedFormTextField('versionExtractionRegEx', | ||||
|           label: tr('versionExtractionRegEx'), | ||||
|           label: tr('trimVersionString'), | ||||
|           required: false, | ||||
|           additionalValidators: [(value) => regExValidator(value)]), | ||||
|     ], | ||||
|     [ | ||||
|       GeneratedFormTextField('matchGroupToUse', | ||||
|           label: tr('matchGroupToUse'), required: false, hint: '\$0') | ||||
|           label: tr('matchGroupToUseForX', args: [tr('trimVersionString')]), | ||||
|           required: false, | ||||
|           hint: '\$0') | ||||
|     ], | ||||
|     [ | ||||
|       GeneratedFormSwitch('versionDetection', | ||||
|   | ||||
							
								
								
									
										180
									
								
								pubspec.lock
									
									
									
									
									
								
							
							
						
						
									
										180
									
								
								pubspec.lock
									
									
									
									
									
								
							| @@ -5,10 +5,10 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: android_intent_plus | ||||
|       sha256: "2bfdbee8d65e7c26f88b66f0a91f2863da4d3596d8a658b4162c8de5cf04b074" | ||||
|       sha256: "007703c1b2cac7ca98add3336b98cffa4baa11d5133cc463293dba9daa39cdf6" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "5.0.2" | ||||
|     version: "5.1.0" | ||||
|   android_package_installer: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
| @@ -47,34 +47,34 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: app_links | ||||
|       sha256: a9905d6a60e814503fabc7523a9ed161b812d7ca69c99ad8ceea14279dc4f06b | ||||
|       sha256: ae5f9a1b7d40d26178f605414be81ed4260350b4fae8259fe5ca4f89fe70c4af | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "6.1.3" | ||||
|     version: "6.1.4" | ||||
|   app_links_linux: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: app_links_linux | ||||
|       sha256: "567139eca3ca9fb113f2082f3aaa75a26f30f0ebdbe5fa7f09a3913c5bebd630" | ||||
|       sha256: f5f7173a78609f3dfd4c2ff2c95bd559ab43c80a87dc6a095921d96c05688c81 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "1.0.2" | ||||
|     version: "1.0.3" | ||||
|   app_links_platform_interface: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: app_links_platform_interface | ||||
|       sha256: "58cff6f11df59b0e514dd5e4a61e988348ad5662f0e75d45d4e214ebea55c94c" | ||||
|       sha256: "05f5379577c513b534a29ddea68176a4d4802c46180ee8e2e966257158772a3f" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.0.0" | ||||
|     version: "2.0.2" | ||||
|   app_links_web: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: app_links_web | ||||
|       sha256: "74586ed5f3c4786341e82a0fa43c39ec3f13108a550f74e80d8bf68aa11349d1" | ||||
|       sha256: af060ed76183f9e2b87510a9480e56a5352b6c249778d07bd2c95fc35632a555 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "1.0.3" | ||||
|     version: "1.0.4" | ||||
|   archive: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -159,26 +159,26 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: connectivity_plus | ||||
|       sha256: db7a4e143dc72cc3cb2044ef9b052a7ebfe729513e6a82943bc3526f784365b8 | ||||
|       sha256: "3e7d1d9dbae40ae82cbe6c23c518f0c4ffe32764ee9749b9a99d32cbac8734f6" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "6.0.3" | ||||
|     version: "6.0.4" | ||||
|   connectivity_plus_platform_interface: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: connectivity_plus_platform_interface | ||||
|       sha256: b6a56efe1e6675be240de39107281d4034b64ac23438026355b4234042a35adb | ||||
|       sha256: "42657c1715d48b167930d5f34d00222ac100475f73d10162ddf43e714932f204" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.0.0" | ||||
|     version: "2.0.1" | ||||
|   cross_file: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: cross_file | ||||
|       sha256: "55d7b444feb71301ef6b8838dbc1ae02e63dd48c8773f3810ff53bb1e2945b32" | ||||
|       sha256: "7caf6a750a0c04effbb52a676dce9a4a592e10ad35c34d6d2d0e4811160d5670" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "0.3.4+1" | ||||
|     version: "0.3.4+2" | ||||
|   crypto: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
| @@ -215,18 +215,18 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: device_info_plus | ||||
|       sha256: eead12d1a1ed83d8283ab4c2f3fca23ac4082f29f25f29dff0f758f57d06ec91 | ||||
|       sha256: "93429694c9253d2871b3af80cf11b3cbb5c65660d402ed7bf69854ce4a089f82" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "10.1.0" | ||||
|     version: "10.1.1" | ||||
|   device_info_plus_platform_interface: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: device_info_plus_platform_interface | ||||
|       sha256: d3b01d5868b50ae571cd1dc6e502fc94d956b665756180f7b16ead09e836fd64 | ||||
|       sha256: "282d3cf731045a2feb66abfe61bbc40870ae50a3ed10a4d3d217556c35c8c2ba" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "7.0.0" | ||||
|     version: "7.0.1" | ||||
|   dynamic_color: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
| @@ -287,10 +287,10 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: file_picker | ||||
|       sha256: "2ca051989f69d1b2ca012b2cf3ccf78c70d40144f0861ff2c063493f7c8c3d45" | ||||
|       sha256: "824f5b9f389bfc4dddac3dea76cd70c51092d9dff0b2ece7ef4f53db8547d258" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "8.0.5" | ||||
|     version: "8.0.6" | ||||
|   fixnum: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -311,10 +311,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: flex_seed_scheme | ||||
|       sha256: "6c595e545b0678e1fe17e8eec3d1fbca7237482da194fadc20ad8607dc7a7f3d" | ||||
|       sha256: cc08c81879ecfd2ab840664ce4770980da0b8a319e35f51bcf763849b7f7596b | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "3.0.0" | ||||
|     version: "3.1.2" | ||||
|   flutter: | ||||
|     dependency: "direct main" | ||||
|     description: flutter | ||||
| @@ -332,10 +332,10 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: flutter_fgbg | ||||
|       sha256: "08c4d2fd229e3df26083d5aecc3dea9ff4f2d188f8cd57aaf2b3f047bd08a047" | ||||
|       sha256: "5e61a2ff2e2e83614ae7690bea3dfa74bbd91b5c083e81ce07692411ce65e3d7" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "0.3.0" | ||||
|     version: "0.4.0" | ||||
|   flutter_keyboard_visibility: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -404,18 +404,18 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: flutter_local_notifications | ||||
|       sha256: ced76d337f54de33d7d9f06092137b4ac2da5079e00cee8a11a1794ffc7c61c6 | ||||
|       sha256: dd6676d8c2926537eccdf9f72128bbb2a9d0814689527b17f92c248ff192eaf3 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "17.2.1" | ||||
|     version: "17.2.1+2" | ||||
|   flutter_local_notifications_linux: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: flutter_local_notifications_linux | ||||
|       sha256: "33f741ef47b5f63cc7f78fe75eeeac7e19f171ff3c3df054d84c1e38bedb6a03" | ||||
|       sha256: c49bd06165cad9beeb79090b18cd1eb0296f4bf4b23b84426e37dd7c027fc3af | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "4.0.0+1" | ||||
|     version: "4.0.1" | ||||
|   flutter_local_notifications_platform_interface: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -441,10 +441,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: flutter_plugin_android_lifecycle | ||||
|       sha256: c6b0b4c05c458e1c01ad9bcc14041dd7b1f6783d487be4386f793f47a8a4d03e | ||||
|       sha256: "9d98bd47ef9d34e803d438f17fd32b116d31009f534a6fa5ce3a1167f189a6de" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.0.20" | ||||
|     version: "2.0.21" | ||||
|   flutter_test: | ||||
|     dependency: "direct dev" | ||||
|     description: flutter | ||||
| @@ -475,10 +475,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: fraction | ||||
|       sha256: "09e9504c9177bbd77df56e5d147abfbb3b43360e64bf61510059c14d6a82d524" | ||||
|       sha256: ac0d9904bb8211eb28606bdf623ff9f222c53240d8e9b927a07c149d356eddc2 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "5.0.2" | ||||
|     version: "5.0.3" | ||||
|   gtk: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -507,10 +507,10 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: http | ||||
|       sha256: "761a297c042deedc1ffbb156d6e2af13886bb305c2a343a4d972504cd67dd938" | ||||
|       sha256: b9c29a161230ee03d3ccf545097fccd9b87a5264228c5d348202e0f0c28f9010 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "1.2.1" | ||||
|     version: "1.2.2" | ||||
|   http_parser: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -643,18 +643,18 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: path_provider | ||||
|       sha256: c9e7d3a4cd1410877472158bee69963a4579f78b68c65a2b7d40d1a7a88bb161 | ||||
|       sha256: fec0d61223fba3154d87759e3cc27fe2c8dc498f6386c6d6fc80d1afdd1bf378 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.1.3" | ||||
|     version: "2.1.4" | ||||
|   path_provider_android: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: path_provider_android | ||||
|       sha256: bca87b0165ffd7cdb9cad8edd22d18d2201e886d9a9f19b4fb3452ea7df3a72a | ||||
|       sha256: "490539678396d4c3c0b06efdaab75ae60675c3e0c66f72bc04c2e2c1e0e2abeb" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.2.6" | ||||
|     version: "2.2.9" | ||||
|   path_provider_foundation: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -683,10 +683,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: path_provider_windows | ||||
|       sha256: "8bc9f22eee8690981c22aa7fc602f5c85b497a6fb2ceb35ee5a5e5ed85ad8170" | ||||
|       sha256: bd6f00dbd873bfb70d0761682da2b3a2c2fccc2b9e84c495821639601d81afe7 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.2.1" | ||||
|     version: "2.3.0" | ||||
|   permission_handler: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
| @@ -699,10 +699,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: permission_handler_android | ||||
|       sha256: b29a799ca03be9f999aa6c39f7de5209482d638e6f857f6b93b0875c618b7e54 | ||||
|       sha256: eaf2a1ec4472775451e88ca6a7b86559ef2f1d1ed903942ed135e38ea0097dca | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "12.0.7" | ||||
|     version: "12.0.8" | ||||
|   permission_handler_apple: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -715,18 +715,18 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: permission_handler_html | ||||
|       sha256: "54bf176b90f6eddd4ece307e2c06cf977fb3973719c35a93b85cc7093eb6070d" | ||||
|       sha256: "6cac773d389e045a8d4f85418d07ad58ef9e42a56e063629ce14c4c26344de24" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "0.1.1" | ||||
|     version: "0.1.2" | ||||
|   permission_handler_platform_interface: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: permission_handler_platform_interface | ||||
|       sha256: "48d4fcf201a1dad93ee869ab0d4101d084f49136ec82a8a06ed9cfeacab9fd20" | ||||
|       sha256: fe0ffe274d665be8e34f9c59705441a7d248edebbe5d9e3ec2665f88b79358ea | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "4.2.1" | ||||
|     version: "4.2.2" | ||||
|   permission_handler_windows: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -763,10 +763,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: pointer_interceptor | ||||
|       sha256: d0a8e660d1204eaec5bd34b34cc92174690e076d2e4f893d9d68c486a13b07c4 | ||||
|       sha256: "57210410680379aea8b1b7ed6ae0c3ad349bfd56fe845b8ea934a53344b9d523" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "0.10.1+1" | ||||
|     version: "0.10.1+2" | ||||
|   pointer_interceptor_ios: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -787,10 +787,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: pointer_interceptor_web | ||||
|       sha256: a6237528b46c411d8d55cdfad8fcb3269fc4cbb26060b14bff94879165887d1e | ||||
|       sha256: "7a7087782110f8c1827170660b09f8aa893e0e9a61431dbbe2ac3fc482e8c044" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "0.10.2" | ||||
|     version: "0.10.2+1" | ||||
|   provider: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
| @@ -803,74 +803,74 @@ packages: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: share_plus | ||||
|       sha256: ef3489a969683c4f3d0239010cc8b7a2a46543a8d139e111c06c558875083544 | ||||
|       sha256: "59dfd53f497340a0c3a81909b220cfdb9b8973a91055c4e5ab9b9b9ad7c513c0" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "9.0.0" | ||||
|     version: "10.0.0" | ||||
|   share_plus_platform_interface: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: share_plus_platform_interface | ||||
|       sha256: "0f9e4418835d1b2c3ae78fdb918251959106cefdbc4dd43526e182f80e82f6d4" | ||||
|       sha256: "6ababf341050edff57da8b6990f11f4e99eaba837865e2e6defe16d039619db5" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "4.0.0" | ||||
|     version: "5.0.0" | ||||
|   shared_preferences: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
|       name: shared_preferences | ||||
|       sha256: d3bbe5553a986e83980916ded2f0b435ef2e1893dfaa29d5a7a790d0eca12180 | ||||
|       sha256: c272f9cabca5a81adc9b0894381e9c1def363e980f960fa903c604c471b22f68 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.2.3" | ||||
|     version: "2.3.1" | ||||
|   shared_preferences_android: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: shared_preferences_android | ||||
|       sha256: "93d0ec9dd902d85f326068e6a899487d1f65ffcd5798721a95330b26c8131577" | ||||
|       sha256: "041be4d9d2dc6079cf342bc8b761b03787e3b71192d658220a56cac9c04a0294" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.2.3" | ||||
|     version: "2.3.0" | ||||
|   shared_preferences_foundation: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: shared_preferences_foundation | ||||
|       sha256: "0a8a893bf4fd1152f93fec03a415d11c27c74454d96e2318a7ac38dd18683ab7" | ||||
|       sha256: "671e7a931f55a08aa45be2a13fe7247f2a41237897df434b30d2012388191833" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.4.0" | ||||
|     version: "2.5.0" | ||||
|   shared_preferences_linux: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: shared_preferences_linux | ||||
|       sha256: "9f2cbcf46d4270ea8be39fa156d86379077c8a5228d9dfdb1164ae0bb93f1faa" | ||||
|       sha256: "2ba0510d3017f91655b7543e9ee46d48619de2a2af38e5c790423f7007c7ccc1" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.3.2" | ||||
|     version: "2.4.0" | ||||
|   shared_preferences_platform_interface: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: shared_preferences_platform_interface | ||||
|       sha256: "22e2ecac9419b4246d7c22bfbbda589e3acf5c0351137d87dd2939d984d37c3b" | ||||
|       sha256: "57cbf196c486bc2cf1f02b85784932c6094376284b3ad5779d1b1c6c6a816b80" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.3.2" | ||||
|     version: "2.4.1" | ||||
|   shared_preferences_web: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: shared_preferences_web | ||||
|       sha256: "9aee1089b36bd2aafe06582b7d7817fd317ef05fc30e6ba14bff247d0933042a" | ||||
|       sha256: "59dc807b94d29d52ddbb1b3c0d3b9d0a67fc535a64e62a5542c8db0513fcb6c2" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.3.0" | ||||
|     version: "2.4.1" | ||||
|   shared_preferences_windows: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: shared_preferences_windows | ||||
|       sha256: "841ad54f3c8381c480d0c9b508b89a34036f512482c407e6df7a9c4aa2ef8f59" | ||||
|       sha256: "398084b47b7f92110683cac45c6dc4aae853db47e470e5ddcd52cab7f7196ab2" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.3.2" | ||||
|     version: "2.4.0" | ||||
|   shared_storage: | ||||
|     dependency: "direct main" | ||||
|     description: | ||||
| @@ -977,10 +977,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: timezone | ||||
|       sha256: a6ccda4a69a442098b602c44e61a1e2b4bf6f5516e875bbf0f427d5df14745d5 | ||||
|       sha256: "2236ec079a174ce07434e89fcd3fcda430025eb7692244139a9cf54fdcf1fc7d" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "0.9.3" | ||||
|     version: "0.9.4" | ||||
|   typed_data: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -1001,18 +1001,18 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: url_launcher_android | ||||
|       sha256: ceb2625f0c24ade6ef6778d1de0b2e44f2db71fded235eb52295247feba8c5cf | ||||
|       sha256: "94d8ad05f44c6d4e2ffe5567ab4d741b82d62e3c8e288cc1fcea45965edf47c9" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "6.3.3" | ||||
|     version: "6.3.8" | ||||
|   url_launcher_ios: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: url_launcher_ios | ||||
|       sha256: "7068716403343f6ba4969b4173cbf3b84fc768042124bc2c011e5d782b24fe89" | ||||
|       sha256: e43b677296fadce447e987a2f519dcf5f6d1e527dc35d01ffab4fff5b8a7063e | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "6.3.0" | ||||
|     version: "6.3.1" | ||||
|   url_launcher_linux: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -1041,26 +1041,26 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: url_launcher_web | ||||
|       sha256: "8d9e750d8c9338601e709cd0885f95825086bd8b642547f26bda435aade95d8a" | ||||
|       sha256: a36e2d7981122fa185006b216eb6b5b97ede3f9a54b7a511bc966971ab98d049 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "2.3.1" | ||||
|     version: "2.3.2" | ||||
|   url_launcher_windows: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: url_launcher_windows | ||||
|       sha256: ecf9725510600aa2bb6d7ddabe16357691b6d2805f66216a97d1b881e21beff7 | ||||
|       sha256: "49c10f879746271804767cb45551ec5592cdab00ee105c06dddde1a98f73b185" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "3.1.1" | ||||
|     version: "3.1.2" | ||||
|   uuid: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: uuid | ||||
|       sha256: "814e9e88f21a176ae1359149021870e87f7cddaf633ab678a5d2b0bff7fd1ba8" | ||||
|       sha256: "83d37c7ad7aaf9aa8e275490669535c8080377cfa7a7004c24dfac53afffaa90" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "4.4.0" | ||||
|     version: "4.4.2" | ||||
|   vector_math: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -1097,10 +1097,10 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: webview_flutter_android | ||||
|       sha256: f42447ca49523f11d8f70abea55ea211b3cafe172dd7a0e7ac007bb35dd356dc | ||||
|       sha256: c66651fba15f9d7ddd31daec42da8d6bce46c85610a7127e3ebcb39a4395c3c9 | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "3.16.4" | ||||
|     version: "3.16.6" | ||||
|   webview_flutter_platform_interface: | ||||
|     dependency: transitive | ||||
|     description: | ||||
| @@ -1113,26 +1113,26 @@ packages: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: webview_flutter_wkwebview | ||||
|       sha256: "7affdf9d680c015b11587181171d3cad8093e449db1f7d9f0f08f4f33d24f9a0" | ||||
|       sha256: "9c62cc46fa4f2d41e10ab81014c1de470a6c6f26051a2de32111b2ee55287feb" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "3.13.1" | ||||
|     version: "3.14.0" | ||||
|   win32: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: win32 | ||||
|       sha256: a79dbe579cb51ecd6d30b17e0cae4e0ea15e2c0e66f69ad4198f22a6789e94f4 | ||||
|       sha256: "015002c060f1ae9f41a818f2d5640389cc05283e368be19dc8d77cecb43c40c9" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "5.5.1" | ||||
|     version: "5.5.3" | ||||
|   win32_registry: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|       name: win32_registry | ||||
|       sha256: "10589e0d7f4e053f2c61023a31c9ce01146656a70b7b7f0828c0b46d7da2a9bb" | ||||
|       sha256: "723b7f851e5724c55409bb3d5a32b203b3afe8587eaf5dafb93a5fed8ecda0d6" | ||||
|       url: "https://pub.dev" | ||||
|     source: hosted | ||||
|     version: "1.1.3" | ||||
|     version: "1.1.4" | ||||
|   xdg_directories: | ||||
|     dependency: transitive | ||||
|     description: | ||||
|   | ||||
							
								
								
									
										12
									
								
								pubspec.yaml
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								pubspec.yaml
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| name: obtainium | ||||
| description: Get Android App Updates Directly From the Source. | ||||
| description: Get Android app updates straight from the source. | ||||
|  | ||||
| # The following line prevents the package from being accidentally published to | ||||
| # pub.dev using `flutter pub publish`. This is preferred for private packages. | ||||
| @@ -17,7 +17,7 @@ publish_to: 'none' # Remove this line if you wish to publish to pub.dev | ||||
| # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html | ||||
| # In Windows, build-name is used as the major, minor, and patch parts | ||||
| # of the product and file versions while build-number is used as the build suffix. | ||||
| version: 1.1.12+2269 | ||||
| version: 1.1.16+2273 | ||||
|  | ||||
| environment: | ||||
|   sdk: '>=3.0.0 <4.0.0' | ||||
| @@ -37,7 +37,7 @@ dependencies: | ||||
|   # Use with the CupertinoIcons class for iOS style icons. | ||||
|   cupertino_icons: ^1.0.5 | ||||
|   path_provider: ^2.0.11 | ||||
|   flutter_fgbg: ^0.3.0 # Try removing reliance on this | ||||
|   flutter_fgbg: ^0.4.0 | ||||
|   flutter_local_notifications: ^17.0.0 | ||||
|   provider: ^6.0.3 | ||||
|   http: ^1.0.0 | ||||
| @@ -56,7 +56,7 @@ dependencies: | ||||
|       url: https://github.com/ImranR98/android_package_installer | ||||
|       ref: main | ||||
|   android_package_manager: ^0.7.0 | ||||
|   share_plus: ^9.0.0 | ||||
|   share_plus: ^10.0.0 | ||||
|   sqflite: ^2.2.0+3 | ||||
|   easy_localization: ^3.0.1 | ||||
|   android_intent_plus: ^5.0.1 | ||||
| @@ -145,6 +145,6 @@ flutter: | ||||
|   # see https://flutter.dev/custom-fonts/#from-packages | ||||
|  | ||||
|   fonts: | ||||
|       - family: Metropolis | ||||
|       - family: Wix-Madefor-Display | ||||
|         fonts: | ||||
|           - asset: assets/fonts/Metropolis-Regular.otf | ||||
|           - asset: assets/fonts/WixMadeforDisplay-Regular.otf | ||||
		Reference in New Issue
	
	Block a user