mirror of
				https://github.com/ImranR98/Obtainium.git
				synced 2025-10-25 03:43:46 +02:00 
			
		
		
		
	Compare commits
	
		
			14 Commits
		
	
	
		
			3af185b0f8
			...
			dev
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | d21feaaf74 | ||
|  | c0c0e2a5c5 | ||
|  | 60e7bba5d9 | ||
|  | 6654406c81 | ||
|  | f5cbbfcace | ||
|  | 8bdc0f8d12 | ||
|  | a980b00600 | ||
|  | 7a385843f9 | ||
|  | 7cb9ca128b | ||
|  | ced7b13777 | ||
|  | 41f37f6d32 | ||
|  | fef0120732 | ||
|  | 6830eb64d0 | ||
|  | b4506c4c3f | 
							
								
								
									
										2
									
								
								.flutter
									
									
									
									
									
								
							
							
								
								
								
								
								
							
						
						
									
										2
									
								
								.flutter
									
									
									
									
									
								
							 Submodule .flutter updated: d693b4b9db...9f455d2486
									
								
							| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "هذا الإشعار مطلوب للتحقق من التحديث في الخلفية (يمكن إخفاؤه في إعدادات نظام التشغيل)", |     "fgServiceNotice": "هذا الإشعار مطلوب للتحقق من التحديث في الخلفية (يمكن إخفاؤه في إعدادات نظام التشغيل)", | ||||||
|     "excludeSecrets": "استبعاد الأسرار", |     "excludeSecrets": "استبعاد الأسرار", | ||||||
|     "GHReqPrefix": "مثيل \"sky22333/hubproxy\" لطلبات GitHub", |     "GHReqPrefix": "مثيل \"sky22333/hubproxy\" لطلبات GitHub", | ||||||
|  |     "includeZips": "تضمين ملفات ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "تصفية ملفات APK داخل ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "إزالة التطبيق؟", |         "one": "إزالة التطبيق؟", | ||||||
|         "other": "إزالة التطبيقات؟" |         "other": "إزالة التطبيقات؟" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", |     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", | ||||||
|     "excludeSecrets": "Exclude secrets", |     "excludeSecrets": "Exclude secrets", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", |     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", | ||||||
|  |     "includeZips": "Include ZIP files", | ||||||
|  |     "zippedApkFilterRegEx": "Filter APKs inside ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Želite li ukloniti aplikaciju?", |         "one": "Želite li ukloniti aplikaciju?", | ||||||
|         "other": "Želite li ukloniti aplikacije?" |         "other": "Želite li ukloniti aplikacije?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Aquesta notificació és necessària per comprovar les actualitzacions en segon pla (la pots ocultar als paràmetres del Sistema Operatiu)", |     "fgServiceNotice": "Aquesta notificació és necessària per comprovar les actualitzacions en segon pla (la pots ocultar als paràmetres del Sistema Operatiu)", | ||||||
|     "excludeSecrets": "Exclude secrets", |     "excludeSecrets": "Exclude secrets", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", |     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", | ||||||
|  |     "includeZips": "Include ZIP files", | ||||||
|  |     "zippedApkFilterRegEx": "Filter APKs inside ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "¿Suprimeixo l'aplicació?", |         "one": "¿Suprimeixo l'aplicació?", | ||||||
|         "other": "¿Suprimeixo les aplicacions?" |         "other": "¿Suprimeixo les aplicacions?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Toto oznámení je nutné pro kontrolu aktualizací na pozadí (lze jej skrýt v nastavení systému)", |     "fgServiceNotice": "Toto oznámení je nutné pro kontrolu aktualizací na pozadí (lze jej skrýt v nastavení systému)", | ||||||
|     "excludeSecrets": "Vyloučit tajemství", |     "excludeSecrets": "Vyloučit tajemství", | ||||||
|     "GHReqPrefix": "instance 'sky22333/hubproxy' pro požadavky GitHubu", |     "GHReqPrefix": "instance 'sky22333/hubproxy' pro požadavky GitHubu", | ||||||
|  |     "includeZips": "Zahrnout soubory ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrování souborů APK uvnitř ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Odstranit aplikaci?", |         "one": "Odstranit aplikaci?", | ||||||
|         "other": "Odstranit aplikace?" |         "other": "Odstranit aplikace?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Denne meddelelse er nødvendig for baggrundsopdateringskontrol (den kan skjules i OS-indstillingerne).", |     "fgServiceNotice": "Denne meddelelse er nødvendig for baggrundsopdateringskontrol (den kan skjules i OS-indstillingerne).", | ||||||
|     "excludeSecrets": "Udeluk hemmeligheder", |     "excludeSecrets": "Udeluk hemmeligheder", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy'-instans til GitHub-anmodninger", |     "GHReqPrefix": "'sky22333/hubproxy'-instans til GitHub-anmodninger", | ||||||
|  |     "includeZips": "Inkluder ZIP-filer", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrer APK'er inde i ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Fjern app?", |         "one": "Fjern app?", | ||||||
|         "other": "Fjern apps?" |         "other": "Fjern apps?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Diese Benachrichtigung ist für die Prüfung von Updates im Hintergrund erforderlich (sie kann in den Betriebssystemeinstellungen ausgeblendet werden)", |     "fgServiceNotice": "Diese Benachrichtigung ist für die Prüfung von Updates im Hintergrund erforderlich (sie kann in den Betriebssystemeinstellungen ausgeblendet werden)", | ||||||
|     "excludeSecrets": "Geheimnisse ausschließen", |     "excludeSecrets": "Geheimnisse ausschließen", | ||||||
|     "GHReqPrefix": "sky22333/hubproxy'-Instanz für GitHub-Anfragen", |     "GHReqPrefix": "sky22333/hubproxy'-Instanz für GitHub-Anfragen", | ||||||
|  |     "includeZips": "ZIP-Dateien einbeziehen", | ||||||
|  |     "zippedApkFilterRegEx": "APKs in ZIP filtern", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "App entfernen?", |         "one": "App entfernen?", | ||||||
|         "other": "Apps entfernen?" |         "other": "Apps entfernen?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", |     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", | ||||||
|     "excludeSecrets": "Exclude secrets", |     "excludeSecrets": "Exclude secrets", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", |     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", | ||||||
|  |     "includeZips": "Include ZIP files", | ||||||
|  |     "zippedApkFilterRegEx": "Filter APKs inside ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Forigi la aplikaĵon?", |         "one": "Forigi la aplikaĵon?", | ||||||
|         "other": "Forigi la aplikaĵojn?" |         "other": "Forigi la aplikaĵojn?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", |     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", | ||||||
|     "excludeSecrets": "Exclude secrets", |     "excludeSecrets": "Exclude secrets", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", |     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", | ||||||
|  |     "includeZips": "Include ZIP files", | ||||||
|  |     "zippedApkFilterRegEx": "Filter APKs inside ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Remove app?", |         "one": "Remove app?", | ||||||
|         "other": "Remove apps?" |         "other": "Remove apps?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Esta notificación es necesaria para la comprobación de actualizaciones en segundo plano (puede ocultarse en la configuración del sistema operativo).", |     "fgServiceNotice": "Esta notificación es necesaria para la comprobación de actualizaciones en segundo plano (puede ocultarse en la configuración del sistema operativo).", | ||||||
|     "excludeSecrets": "Excluir secretos", |     "excludeSecrets": "Excluir secretos", | ||||||
|     "GHReqPrefix": "Instancia \"sky22333/hubproxy\" para las solicitudes de GitHub", |     "GHReqPrefix": "Instancia \"sky22333/hubproxy\" para las solicitudes de GitHub", | ||||||
|  |     "includeZips": "Incluir archivos ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrar APKs dentro de ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "¿Eliminar aplicación?", |         "one": "¿Eliminar aplicación?", | ||||||
|         "other": "¿Eliminar aplicaciones?" |         "other": "¿Eliminar aplicaciones?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", |     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", | ||||||
|     "excludeSecrets": "Exclude secrets", |     "excludeSecrets": "Exclude secrets", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", |     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", | ||||||
|  |     "includeZips": "Include ZIP files", | ||||||
|  |     "zippedApkFilterRegEx": "Filter APKs inside ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "برنامه حذف شود؟", |         "one": "برنامه حذف شود؟", | ||||||
|         "other": "برنامه ها حذف شوند؟" |         "other": "برنامه ها حذف شوند؟" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Cette notification est nécessaire pour la vérification des mises à jour en arrière-plan (elle peut être masquée dans les paramètres du système d'exploitation).", |     "fgServiceNotice": "Cette notification est nécessaire pour la vérification des mises à jour en arrière-plan (elle peut être masquée dans les paramètres du système d'exploitation).", | ||||||
|     "excludeSecrets": "Exclure les secrets", |     "excludeSecrets": "Exclure les secrets", | ||||||
|     "GHReqPrefix": "instance 'sky22333/hubproxy' pour les requêtes GitHub", |     "GHReqPrefix": "instance 'sky22333/hubproxy' pour les requêtes GitHub", | ||||||
|  |     "includeZips": "Inclure les fichiers ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrer les APK à l'intérieur du ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Supprimer l'application ?", |         "one": "Supprimer l'application ?", | ||||||
|         "other": "Supprimer les applications ?" |         "other": "Supprimer les applications ?" | ||||||
|   | |||||||
| @@ -336,7 +336,9 @@ | |||||||
|     "foregroundServiceExplanation": "Előtér-szolgáltatás használata a frissítések ellenőrzéséhez (megbízhatóbb, de több energiát fogyaszt)", |     "foregroundServiceExplanation": "Előtér-szolgáltatás használata a frissítések ellenőrzéséhez (megbízhatóbb, de több energiát fogyaszt)", | ||||||
|     "fgServiceNotice": "Ez az értesítés a háttérben történő frissítésellenőrzéshez szükséges (a rendszer beállításaiban elrejthető).", |     "fgServiceNotice": "Ez az értesítés a háttérben történő frissítésellenőrzéshez szükséges (a rendszer beállításaiban elrejthető).", | ||||||
|     "excludeSecrets": "Érzékeny adatok (például: személyes hozzáférési tokenek) kihagyása", |     "excludeSecrets": "Érzékeny adatok (például: személyes hozzáférési tokenek) kihagyása", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' példány a GitHub kérésekhez", |     "GHReqPrefix": "„sky22333/hubproxy” példány a GitHub lekérdezéséhez", | ||||||
|  |     "includeZips": "ZIP fájlok belefoglalása", | ||||||
|  |     "zippedApkFilterRegEx": "APK-k szűrése a ZIP-en belül", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Eltávolítja az alkalmazást?", |         "one": "Eltávolítja az alkalmazást?", | ||||||
|         "other": "Eltávolítja az alkalmazásokat?" |         "other": "Eltávolítja az alkalmazásokat?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Pemberitahuan ini diperlukan untuk pemeriksaan pembaruan latar belakang (dapat disembunyikan dalam pengaturan OS)", |     "fgServiceNotice": "Pemberitahuan ini diperlukan untuk pemeriksaan pembaruan latar belakang (dapat disembunyikan dalam pengaturan OS)", | ||||||
|     "excludeSecrets": "Mengecualikan rahasia", |     "excludeSecrets": "Mengecualikan rahasia", | ||||||
|     "GHReqPrefix": "Instance 'sky22333/hubproxy' untuk permintaan GitHub", |     "GHReqPrefix": "Instance 'sky22333/hubproxy' untuk permintaan GitHub", | ||||||
|  |     "includeZips": "Menyertakan file ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Saring APK di dalam ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Hapus aplikasi?", |         "one": "Hapus aplikasi?", | ||||||
|         "other": "Hapus aplikasi?" |         "other": "Hapus aplikasi?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Questa notifica è necessaria per il controllo degli aggiornamenti in background (può essere nascosta nelle impostazioni del sistema operativo).", |     "fgServiceNotice": "Questa notifica è necessaria per il controllo degli aggiornamenti in background (può essere nascosta nelle impostazioni del sistema operativo).", | ||||||
|     "excludeSecrets": "Escludere i segreti", |     "excludeSecrets": "Escludere i segreti", | ||||||
|     "GHReqPrefix": "istanza 'sky22333/hubproxy' per le richieste a GitHub", |     "GHReqPrefix": "istanza 'sky22333/hubproxy' per le richieste a GitHub", | ||||||
|  |     "includeZips": "Includere file ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrare gli APK all'interno dello ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Rimuovere l'app?", |         "one": "Rimuovere l'app?", | ||||||
|         "other": "Rimuovere le app?" |         "other": "Rimuovere le app?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "この通知は、バックグラウンドでアップデートを確認するために必要です(OSの設定で非表示にできます)。", |     "fgServiceNotice": "この通知は、バックグラウンドでアップデートを確認するために必要です(OSの設定で非表示にできます)。", | ||||||
|     "excludeSecrets": "シークレットを除く", |     "excludeSecrets": "シークレットを除く", | ||||||
|     "GHReqPrefix": "GitHub リクエスト用の 'sky22333/hubproxy' インスタンス", |     "GHReqPrefix": "GitHub リクエスト用の 'sky22333/hubproxy' インスタンス", | ||||||
|  |     "includeZips": "ZIPファイルを含む", | ||||||
|  |     "zippedApkFilterRegEx": "ZIP内のAPKをフィルタリングする", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "アプリを削除しますか?", |         "one": "アプリを削除しますか?", | ||||||
|         "other": "アプリを削除しますか?" |         "other": "アプリを削除しますか?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "이 알림은 백그라운드 업데이트 확인에 필요합니다(OS 설정에서 숨길 수 있음).", |     "fgServiceNotice": "이 알림은 백그라운드 업데이트 확인에 필요합니다(OS 설정에서 숨길 수 있음).", | ||||||
|     "excludeSecrets": "비밀 제외", |     "excludeSecrets": "비밀 제외", | ||||||
|     "GHReqPrefix": "GitHub 요청을 위한 'sky22333/hubproxy' 인스턴스", |     "GHReqPrefix": "GitHub 요청을 위한 'sky22333/hubproxy' 인스턴스", | ||||||
|  |     "includeZips": "ZIP 파일 포함", | ||||||
|  |     "zippedApkFilterRegEx": "ZIP 내 APK 필터링", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "앱을 제거하시겠습니까?", |         "one": "앱을 제거하시겠습니까?", | ||||||
|         "other": "앱을 제거하시겠습니까?" |         "other": "앱을 제거하시겠습니까?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", |     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", | ||||||
|     "excludeSecrets": "Exclude secrets", |     "excludeSecrets": "Exclude secrets", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", |     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", | ||||||
|  |     "includeZips": "Include ZIP files", | ||||||
|  |     "zippedApkFilterRegEx": "Filter APKs inside ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "ആപ്പ് നീക്കം ചെയ്യണോ?", |         "one": "ആപ്പ് നീക്കം ചെയ്യണോ?", | ||||||
|         "other": "ആപ്പുകൾ നീക്കം ചെയ്യണോ?" |         "other": "ആപ്പുകൾ നീക്കം ചെയ്യണോ?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Deze melding is nodig voor het controleren van updates op de achtergrond (kan worden verborgen in de OS-instellingen)", |     "fgServiceNotice": "Deze melding is nodig voor het controleren van updates op de achtergrond (kan worden verborgen in de OS-instellingen)", | ||||||
|     "excludeSecrets": "Geheimen uitsluiten", |     "excludeSecrets": "Geheimen uitsluiten", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' instantie voor GitHub verzoeken", |     "GHReqPrefix": "'sky22333/hubproxy' instantie voor GitHub verzoeken", | ||||||
|  |     "includeZips": "ZIP-bestanden opnemen", | ||||||
|  |     "zippedApkFilterRegEx": "APK's filteren in ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "App verwijderen?", |         "one": "App verwijderen?", | ||||||
|         "other": "Apps verwijderen?" |         "other": "Apps verwijderen?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "To powiadomienie jest wymagane do sprawdzania aktualizacji w tle (można je ukryć w ustawieniach systemu operacyjnego).", |     "fgServiceNotice": "To powiadomienie jest wymagane do sprawdzania aktualizacji w tle (można je ukryć w ustawieniach systemu operacyjnego).", | ||||||
|     "excludeSecrets": "Wyklucz sekrety", |     "excludeSecrets": "Wyklucz sekrety", | ||||||
|     "GHReqPrefix": "Instancja \"sky22333/hubproxy\" dla żądań GitHub", |     "GHReqPrefix": "Instancja \"sky22333/hubproxy\" dla żądań GitHub", | ||||||
|  |     "includeZips": "Dołączanie plików ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrowanie plików APK wewnątrz ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Usunąć aplikację?", |         "one": "Usunąć aplikację?", | ||||||
|         "few": "Usunąć aplikacje?", |         "few": "Usunąć aplikacje?", | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Essa notificação é necessária para a verificação de atualizações em segundo plano (ela pode ser ocultada nas configurações do sistema operacional)", |     "fgServiceNotice": "Essa notificação é necessária para a verificação de atualizações em segundo plano (ela pode ser ocultada nas configurações do sistema operacional)", | ||||||
|     "excludeSecrets": "Excluir segredos", |     "excludeSecrets": "Excluir segredos", | ||||||
|     "GHReqPrefix": "Instância \"sky22333/hubproxy\" para solicitações do GitHub", |     "GHReqPrefix": "Instância \"sky22333/hubproxy\" para solicitações do GitHub", | ||||||
|  |     "includeZips": "Incluir arquivos ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrar APKs dentro do ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Remover app?", |         "one": "Remover app?", | ||||||
|         "other": "Remover apps?" |         "other": "Remover apps?" | ||||||
|   | |||||||
| @@ -3,8 +3,8 @@ | |||||||
|     "noReleaseFound": "Não foi possível encontrar uma versão adequada", |     "noReleaseFound": "Não foi possível encontrar uma versão adequada", | ||||||
|     "noVersionFound": "Não foi possível encontrar uma versão", |     "noVersionFound": "Não foi possível encontrar uma versão", | ||||||
|     "urlMatchesNoSource": "A URL não corresponde a uma fonte conhecida", |     "urlMatchesNoSource": "A URL não corresponde a uma fonte conhecida", | ||||||
|     "cantInstallOlderVersion": "Não é permitido instalar uma versão anterior de um aplicativo", |     "cantInstallOlderVersion": "Não é permitido instalar uma versão anterior de uma aplicação", | ||||||
|     "appIdMismatch": "ID do pacote baixado não é igual ao ID do aplicativo instalado", |     "appIdMismatch": "O ID do pacote descarregado não é igual ao ID da aplicação instalada", | ||||||
|     "functionNotImplemented": "Esta classe não implementou essa função", |     "functionNotImplemented": "Esta classe não implementou essa função", | ||||||
|     "placeholder": "Espaço reservado", |     "placeholder": "Espaço reservado", | ||||||
|     "someErrors": "Alguns erros ocorreram", |     "someErrors": "Alguns erros ocorreram", | ||||||
| @@ -30,15 +30,15 @@ | |||||||
|     "wrongArgNum": "Número de argumentos errado", |     "wrongArgNum": "Número de argumentos errado", | ||||||
|     "xIsTrackOnly": "{} é 'Apenas monitorar'", |     "xIsTrackOnly": "{} é 'Apenas monitorar'", | ||||||
|     "source": "Fonte", |     "source": "Fonte", | ||||||
|     "app": "Aplicativo", |     "app": "Aplicação", | ||||||
|     "appsFromSourceAreTrackOnly": "Os aplicativos desta fonte são 'Apenas monitorar'.", |     "appsFromSourceAreTrackOnly": "As aplicações desta fonte são 'Apenas monitorar'.", | ||||||
|     "youPickedTrackOnly": "Você selecionou a opção 'Apenas monitorar'.", |     "youPickedTrackOnly": "Você selecionou a opção 'Apenas monitorar'.", | ||||||
|     "trackOnlyAppDescription": "As atualizações desse aplicativo serão monitoradas, mas o Obtainium não poderá baixá-lo ou instalá-lo.", |     "trackOnlyAppDescription": "As atualizações desta aplicação serão monitorizadas, mas o Obtainium não poderá descarregá-la ou instalá-la.", | ||||||
|     "cancelled": "Cancelado", |     "cancelled": "Cancelado", | ||||||
|     "appAlreadyAdded": "Aplicativo já adicionado", |     "appAlreadyAdded": "Aplicação já adicionada", | ||||||
|     "alreadyUpToDateQuestion": "Aplicativo já foi atualizado?", |     "alreadyUpToDateQuestion": "Aplicação já foi atualizada?", | ||||||
|     "addApp": "Adicionar aplicativo", |     "addApp": "Adicionar aplicação", | ||||||
|     "appSourceURL": "URL de origem do aplicativo", |     "appSourceURL": "URL de origem da aplicação", | ||||||
|     "error": "Erro", |     "error": "Erro", | ||||||
|     "add": "Adicionar", |     "add": "Adicionar", | ||||||
|     "searchSomeSourcesLabel": "Procurar (apenas algumas fontes)", |     "searchSomeSourcesLabel": "Procurar (apenas algumas fontes)", | ||||||
| @@ -47,9 +47,9 @@ | |||||||
|     "supportedSources": "Fontes compatíveis", |     "supportedSources": "Fontes compatíveis", | ||||||
|     "trackOnlyInBrackets": "(apenas monitorar)", |     "trackOnlyInBrackets": "(apenas monitorar)", | ||||||
|     "searchableInBrackets": "(pesquisável)", |     "searchableInBrackets": "(pesquisável)", | ||||||
|     "appsString": "Aplicativos", |     "appsString": "Aplicações", | ||||||
|     "noApps": "Não há aplicativos", |     "noApps": "Não há aplicações", | ||||||
|     "noAppsForFilter": "Sem aplicativos para filtrar", |     "noAppsForFilter": "Sem aplicações para filtrar", | ||||||
|     "byX": "Por {}", |     "byX": "Por {}", | ||||||
|     "percentProgress": "Progresso: {}%", |     "percentProgress": "Progresso: {}%", | ||||||
|     "pleaseWait": "Por favor, espere", |     "pleaseWait": "Por favor, espere", | ||||||
| @@ -59,35 +59,35 @@ | |||||||
|     "selectAll": "Selecionar todos", |     "selectAll": "Selecionar todos", | ||||||
|     "deselectX": "Deselecionar {}", |     "deselectX": "Deselecionar {}", | ||||||
|     "xWillBeRemovedButRemainInstalled": "{} será removido do Obtainium mais permanecerá instalado no dispositivo.", |     "xWillBeRemovedButRemainInstalled": "{} será removido do Obtainium mais permanecerá instalado no dispositivo.", | ||||||
|     "removeSelectedAppsQuestion": "Remover aplicativos selecionados?", |     "removeSelectedAppsQuestion": "Remover aplicações selecionadas?", | ||||||
|     "removeSelectedApps": "Remover aplicativos selecionados", |     "removeSelectedApps": "Remover aplicações selecionadas", | ||||||
|     "updateX": "Atualizar {}", |     "updateX": "Atualizar {}", | ||||||
|     "installX": "Instalar {}", |     "installX": "Instalar {}", | ||||||
|     "markXTrackOnlyAsUpdated": "Marcar {}\n(Apenas monitorar)\ncomo Atualizado", |     "markXTrackOnlyAsUpdated": "Marcar {}\n(Apenas monitorar)\ncomo Atualizado", | ||||||
|     "changeX": "Mudar {}", |     "changeX": "Mudar {}", | ||||||
|     "installUpdateApps": "Instalar/Atualizar aplicativos", |     "installUpdateApps": "Instalar/Atualizar aplicações", | ||||||
|     "installUpdateSelectedApps": "Instalar/Atualizar aplicativos selecionados", |     "installUpdateSelectedApps": "Instalar/Atualizar aplicações selecionadas", | ||||||
|     "markXSelectedAppsAsUpdated": "Marcar {} aplicativos selecionados como atualizados?", |     "markXSelectedAppsAsUpdated": "Marcar {} aplicações selecionadas como atualizadas?", | ||||||
|     "no": "Não", |     "no": "Não", | ||||||
|     "yes": "Sim", |     "yes": "Sim", | ||||||
|     "markSelectedAppsUpdated": "Marcar aplicativos selecionados como Atualizados", |     "markSelectedAppsUpdated": "Marcar aplicações selecionadas como Atualizadas", | ||||||
|     "pinToTop": "Fixar no topo", |     "pinToTop": "Fixar no topo", | ||||||
|     "unpinFromTop": "Desafixar do topo", |     "unpinFromTop": "Desafixar do topo", | ||||||
|     "resetInstallStatusForSelectedAppsQuestion": "Reiniciar status de instalação nos aplicativos selecionados?", |     "resetInstallStatusForSelectedAppsQuestion": "Reiniciar o estado de instalação das aplicações selecionadas?", | ||||||
|     "installStatusOfXWillBeResetExplanation": "O status de instalação de todos os aplicativos selecionados será reiniciado.\n\nIsso pode ajudar quando uma versão de um aplicativo mostrada no Obtainium é incorreta devido a falhas ao atualizar ou outros problemas.", |     "installStatusOfXWillBeResetExplanation": "O estado de instalação de todas as aplicações selecionadas será reiniciado.\n\nIsto pode ajudar quando uma versão de uma aplicação mostrada no Obtainium está incorreta devido a falhas na atualização ou outros problemas.", | ||||||
|     "customLinkMessage": "Esses links funcionam em dispositivos com o Obtainium instalado", |     "customLinkMessage": "Esses links funcionam em dispositivos com o Obtainium instalado", | ||||||
|     "shareAppConfigLinks": "Compartilhar configuração do aplicativo como link HTML", |     "shareAppConfigLinks": "Partilhar a configuração da aplicação como um link HTML", | ||||||
|     "shareSelectedAppURLs": "Compartilhar URLs de aplicativos selecionados", |     "shareSelectedAppURLs": "Partilhar URLs de aplicações selecionadas", | ||||||
|     "resetInstallStatus": "Reiniciar status de instalação", |     "resetInstallStatus": "Reiniciar status de instalação", | ||||||
|     "more": "Mais", |     "more": "Mais", | ||||||
|     "removeOutdatedFilter": "Remover filtro de aplicativos desatualizados", |     "removeOutdatedFilter": "Remover filtro de aplicações desatualizadas", | ||||||
|     "showOutdatedOnly": "Mostrar apenas aplicativos desatualizados", |     "showOutdatedOnly": "Mostrar apenas aplicações desatualizadas", | ||||||
|     "filter": "Filtro", |     "filter": "Filtro", | ||||||
|     "filterApps": "Filtrar aplicativos", |     "filterApps": "Filtrar aplicações", | ||||||
|     "appName": "Nome do aplicativo", |     "appName": "Nome da aplicação", | ||||||
|     "author": "Autor", |     "author": "Autor", | ||||||
|     "upToDateApps": "Aplicativos atualizados", |     "upToDateApps": "Aplicações atualizadas", | ||||||
|     "nonInstalledApps": "Aplicativos não instalados", |     "nonInstalledApps": "Aplicações não instaladas", | ||||||
|     "importExport": "Importar/Exportar", |     "importExport": "Importar/Exportar", | ||||||
|     "settings": "Configurações", |     "settings": "Configurações", | ||||||
|     "exportedTo": "Exportado para {}", |     "exportedTo": "Exportado para {}", | ||||||
| @@ -97,14 +97,14 @@ | |||||||
|     "obtainiumImport": "Importar dados do Obtainium", |     "obtainiumImport": "Importar dados do Obtainium", | ||||||
|     "importFromURLList": "Importar de lista de URLs", |     "importFromURLList": "Importar de lista de URLs", | ||||||
|     "searchQuery": "Pesquisa", |     "searchQuery": "Pesquisa", | ||||||
|     "appURLList": "Lista de URLs de aplicativos", |     "appURLList": "Lista de URLs de aplicações", | ||||||
|     "line": "Linha", |     "line": "Linha", | ||||||
|     "searchX": "Pesquisar na/o {}", |     "searchX": "Pesquisar na/o {}", | ||||||
|     "noResults": "Nenhum resultado encontrado", |     "noResults": "Nenhum resultado encontrado", | ||||||
|     "importX": "Importar {}", |     "importX": "Importar {}", | ||||||
|     "importedAppsIdDisclaimer": "Aplicativos Importados podem ser mostrados incorretamente como \"Não Instalado\".\nPara consertar, reinstale-os usando o Obtainium.\nIsso não deve afetar dados do aplicativo.\n\nAfeta apenas métodos de importação de URL e de terceiros.", |     "importedAppsIdDisclaimer": "Aplicações Importadas podem ser mostradas incorretamente como \"Não Instalado\".\nPara corrigir, reinstale-as usando o Obtainium.\nIsto não deve afetar os dados da aplicação.\n\nAfeta apenas os métodos de importação de URL e de terceiros.", | ||||||
|     "importErrors": "Erros de importação", |     "importErrors": "Erros de importação", | ||||||
|     "importedXOfYApps": "{} de {} aplicativos importados.", |     "importedXOfYApps": "{} de {} aplicações importadas.", | ||||||
|     "followingURLsHadErrors": "As seguintes URLs apresentaram erros:", |     "followingURLsHadErrors": "As seguintes URLs apresentaram erros:", | ||||||
|     "selectURL": "Selecionar URL", |     "selectURL": "Selecionar URL", | ||||||
|     "selectURLs": "Selecionar URLs", |     "selectURLs": "Selecionar URLs", | ||||||
| @@ -115,53 +115,53 @@ | |||||||
|     "followSystem": "Padrão do sistema", |     "followSystem": "Padrão do sistema", | ||||||
|     "followSystemThemeExplanation": "O tema do sistema seguinte só é possível através da utilização de aplicações de terceiros", |     "followSystemThemeExplanation": "O tema do sistema seguinte só é possível através da utilização de aplicações de terceiros", | ||||||
|     "useBlackTheme": "Usar tema preto AMOLED", |     "useBlackTheme": "Usar tema preto AMOLED", | ||||||
|     "appSortBy": "Classificar aplicativo por", |     "appSortBy": "Classificar aplicação por", | ||||||
|     "authorName": "Autor/Nome", |     "authorName": "Autor/Nome", | ||||||
|     "nameAuthor": "Nome/Autor", |     "nameAuthor": "Nome/Autor", | ||||||
|     "asAdded": "Como adicionado", |     "asAdded": "Como adicionado", | ||||||
|     "appSortOrder": "Ordem de classificação de aplicativos", |     "appSortOrder": "Ordem de classificação das aplicações", | ||||||
|     "ascending": "Ascendente", |     "ascending": "Ascendente", | ||||||
|     "descending": "Descendente", |     "descending": "Descendente", | ||||||
|     "bgUpdateCheckInterval": "Intervalo de verificação de atualizações em segundo-plano", |     "bgUpdateCheckInterval": "Intervalo de verificação de atualizações em segundo-plano", | ||||||
|     "neverManualOnly": "Nunca - apenas manual", |     "neverManualOnly": "Nunca - apenas manual", | ||||||
|     "appearance": "Aparência", |     "appearance": "Aparência", | ||||||
|     "showWebInAppView": "Mostrar página web do aplicativo em informações do aplicativo", |     "showWebInAppView": "Mostrar a página web da aplicação nas informações da aplicação", | ||||||
|     "pinUpdates": "Fixar atualizações no topo da janela de aplicativos", |     "pinUpdates": "Fixar atualizações no topo da janela das aplicações", | ||||||
|     "updates": "Atualizações", |     "updates": "Atualizações", | ||||||
|     "sourceSpecific": "Token de acesso", |     "sourceSpecific": "Token de acesso", | ||||||
|     "appSource": "Fonte do aplicativo", |     "appSource": "Fonte da aplicação", | ||||||
|     "noLogs": "Sem logs", |     "noLogs": "Sem logs", | ||||||
|     "appLogs": "Logs do aplicativo", |     "appLogs": "Logs da aplicação", | ||||||
|     "close": "Fechar", |     "close": "Fechar", | ||||||
|     "share": "Compartilhar", |     "share": "Compartilhar", | ||||||
|     "appNotFound": "Aplicativo não encontrado", |     "appNotFound": "Aplicação não encontrada", | ||||||
|     "obtainiumExportHyphenatedLowercase": "exportação de obtainium", |     "obtainiumExportHyphenatedLowercase": "exportação de obtainium", | ||||||
|     "pickAnAPK": "Selecionar um APK", |     "pickAnAPK": "Selecionar um APK", | ||||||
|     "appHasMoreThanOnePackage": "{} tem mais de um pacote:", |     "appHasMoreThanOnePackage": "{} tem mais de um pacote:", | ||||||
|     "deviceSupportsXArch": "Seu dispositivo suporta a arquitetura de CPU {}.", |     "deviceSupportsXArch": "Seu dispositivo suporta a arquitetura de CPU {}.", | ||||||
|     "deviceSupportsFollowingArchs": "Seu dispositivo suporta as seguintes arquiteturas de CPU:", |     "deviceSupportsFollowingArchs": "Seu dispositivo suporta as seguintes arquiteturas de CPU:", | ||||||
|     "warning": "Aviso", |     "warning": "Aviso", | ||||||
|     "sourceIsXButPackageFromYPrompt": "A fonte do aplicativo é '{}' mas a origem do pacote é '{}'. Continuar?", |     "sourceIsXButPackageFromYPrompt": "A fonte da aplicação é '{}' mas a origem do pacote é '{}'. Continuar?", | ||||||
|     "updatesAvailable": "Atualizações disponíveis", |     "updatesAvailable": "Atualizações disponíveis", | ||||||
|     "updatesAvailableNotifDescription": "Notifica o usuário quando atualizações de um ou mais aplicativos monitorados pelo Obtainium estão disponíveis", |     "updatesAvailableNotifDescription": "Notifica o utilizador quando as atualizações de uma ou mais aplicações monitorizadas pelo Obtainium estão disponíveis", | ||||||
|     "noNewUpdates": "Sem novas atualizações.", |     "noNewUpdates": "Sem novas atualizações.", | ||||||
|     "xHasAnUpdate": "{} tem uma atualização.", |     "xHasAnUpdate": "{} tem uma atualização.", | ||||||
|     "appsUpdated": "Aplicativos atualizados", |     "appsUpdated": "Aplicações atualizadas", | ||||||
|     "appsNotUpdated": "Falha na atualização das aplicações", |     "appsNotUpdated": "Falha na atualização das aplicações", | ||||||
|     "appsUpdatedNotifDescription": "Notifica o usuário quando atualizações foram aplicadas em segundo-plano para um ou mais aplicativos ", |     "appsUpdatedNotifDescription": "Notifica o utilizador quando as atualizações foram aplicadas em segundo plano para uma ou mais aplicações ", | ||||||
|     "xWasUpdatedToY": "{} foi atualizado para {}.", |     "xWasUpdatedToY": "{} foi atualizado para {}.", | ||||||
|     "xWasNotUpdatedToY": "Falha ao atualizar {} para {}.", |     "xWasNotUpdatedToY": "Falha ao atualizar {} para {}.", | ||||||
|     "errorCheckingUpdates": "Erro ao procurar por atualizações", |     "errorCheckingUpdates": "Erro ao procurar por atualizações", | ||||||
|     "errorCheckingUpdatesNotifDescription": "Uma notificação que mostra quando a checagem por atualizações em segundo-plano falha", |     "errorCheckingUpdatesNotifDescription": "Uma notificação que mostra quando a checagem por atualizações em segundo-plano falha", | ||||||
|     "appsRemoved": "Aplicativos removidos", |     "appsRemoved": "Aplicações removidas", | ||||||
|     "appsRemovedNotifDescription": "Notifica o usuário quando um ou mais aplicativos foram removidos devido a erros de carregamento", |     "appsRemovedNotifDescription": "Notifica o utilizador quando uma ou mais aplicações foram removidas devido a erros de carregamento", | ||||||
|     "xWasRemovedDueToErrorY": "{} foi removido devido a este erro: {}", |     "xWasRemovedDueToErrorY": "{} foi removido devido a este erro: {}", | ||||||
|     "completeAppInstallation": "Instalação do aplicativo concluída", |     "completeAppInstallation": "Instalação da aplicação concluída", | ||||||
|     "obtainiumMustBeOpenToInstallApps": "Obtainium deve estar aberto para instalar os aplicativos", |     "obtainiumMustBeOpenToInstallApps": "O Obtainium deve estar aberto para instalar as aplicações", | ||||||
|     "completeAppInstallationNotifDescription": "Pede ao usuário que retorne ao Obtainium para finalizar a instalação de um aplicativo", |     "completeAppInstallationNotifDescription": "Pede ao usuário que retorne ao Obtainium para finalizar a instalação de uma aplicação", | ||||||
|     "checkingForUpdates": "Verificando atualizações", |     "checkingForUpdates": "Verificando atualizações", | ||||||
|     "checkingForUpdatesNotifDescription": "Notificação transiente que aparece quando o Obtainium está verificando se há atualizações", |     "checkingForUpdatesNotifDescription": "Notificação transiente que aparece quando o Obtainium está verificando se há atualizações", | ||||||
|     "pleaseAllowInstallPerm": "Por favor, permita que o Obtainium possa instalar aplicativos", |     "pleaseAllowInstallPerm": "Por favor, permita que o Obtainium instale aplicações", | ||||||
|     "trackOnly": "Apenas monitorar", |     "trackOnly": "Apenas monitorar", | ||||||
|     "errorWithHttpStatusCode": "Erro {}", |     "errorWithHttpStatusCode": "Erro {}", | ||||||
|     "versionCorrectionDisabled": "Correção de versão desativada (plugin parece não funcionar)", |     "versionCorrectionDisabled": "Correção de versão desativada (plugin parece não funcionar)", | ||||||
| @@ -175,10 +175,10 @@ | |||||||
|     "remove": "Remover", |     "remove": "Remover", | ||||||
|     "yesMarkUpdated": "Sim, marcar como atualizado", |     "yesMarkUpdated": "Sim, marcar como atualizado", | ||||||
|     "fdroid": "Oficial F-Droid", |     "fdroid": "Oficial F-Droid", | ||||||
|     "appIdOrName": "ID do aplicativo ou nome", |     "appIdOrName": "ID da aplicação ou nome", | ||||||
|     "appId": "ID do aplicativo", |     "appId": "ID da aplicação", | ||||||
|     "appWithIdOrNameNotFound": "Nenhum aplicativo foi encontrado com esse ID ou nome", |     "appWithIdOrNameNotFound": "Nenhuma aplicação foi encontrada com esse ID ou nome", | ||||||
|     "reposHaveMultipleApps": "Repositórios podem conter múltiplos aplicativos", |     "reposHaveMultipleApps": "Os repositórios podem conter múltiplas aplicações", | ||||||
|     "fdroidThirdPartyRepo": "Repositórios de terceiros F-Droid", |     "fdroidThirdPartyRepo": "Repositórios de terceiros F-Droid", | ||||||
|     "install": "Instalar", |     "install": "Instalar", | ||||||
|     "markInstalled": "Marcar instalado", |     "markInstalled": "Marcar instalado", | ||||||
| @@ -186,12 +186,12 @@ | |||||||
|     "markUpdated": "Marcar como atualizado", |     "markUpdated": "Marcar como atualizado", | ||||||
|     "additionalOptions": "Opções adicionais", |     "additionalOptions": "Opções adicionais", | ||||||
|     "disableVersionDetection": "Desativar detecção de versão", |     "disableVersionDetection": "Desativar detecção de versão", | ||||||
|     "noVersionDetectionExplanation": "Essa opção deve apenas ser usada por aplicativos onde a detecção de versão não funciona corretamente.", |     "noVersionDetectionExplanation": "Esta opção deve ser usada apenas por aplicações onde a deteção de versão não funciona corretamente.", | ||||||
|     "downloadingX": "Baixando {}", |     "downloadingX": "Baixando {}", | ||||||
|     "downloadX": "Descarregar {}", |     "downloadX": "Descarregar {}", | ||||||
|     "downloadedX": "Descarregado {}", |     "downloadedX": "Descarregado {}", | ||||||
|     "releaseAsset": "Libertação de activos", |     "releaseAsset": "Libertação de activos", | ||||||
|     "downloadNotifDescription": "Notifica o usuário o progresso do download de um aplicativo", |     "downloadNotifDescription": "Notifica o utilizador sobre o progresso do download de uma aplicação", | ||||||
|     "noAPKFound": "APK não encontrado", |     "noAPKFound": "APK não encontrado", | ||||||
|     "noVersionDetection": "Sem detecção de versão", |     "noVersionDetection": "Sem detecção de versão", | ||||||
|     "categorize": "Categorizar", |     "categorize": "Categorizar", | ||||||
| @@ -200,20 +200,20 @@ | |||||||
|     "noCategory": "Sem categoria", |     "noCategory": "Sem categoria", | ||||||
|     "noCategories": "Sem categorias", |     "noCategories": "Sem categorias", | ||||||
|     "deleteCategoriesQuestion": "Deletar  categorias?", |     "deleteCategoriesQuestion": "Deletar  categorias?", | ||||||
|     "categoryDeleteWarning": "Todos os aplicativos em categorias removidas serão descategorizados.", |     "categoryDeleteWarning": "Todas as aplicações em categorias removidas serão descategorizadas.", | ||||||
|     "addCategory": "Adicionar categoria", |     "addCategory": "Adicionar categoria", | ||||||
|     "label": "Etiqueta", |     "label": "Etiqueta", | ||||||
|     "language": "Linguagem", |     "language": "Linguagem", | ||||||
|     "copiedToClipboard": "Copiado para a área de transferência", |     "copiedToClipboard": "Copiado para a área de transferência", | ||||||
|     "storagePermissionDenied": "Permissão de armazenamento negada", |     "storagePermissionDenied": "Permissão de armazenamento negada", | ||||||
|     "selectedCategorizeWarning": "Isso vai substituir qualquer configuração de categoria para os aplicativos selecionados.", |     "selectedCategorizeWarning": "Isto irá substituir qualquer configuração de categoria para as aplicações selecionadas.", | ||||||
|     "filterAPKsByRegEx": "Filtrar APKs usando expressão regular", |     "filterAPKsByRegEx": "Filtrar APKs usando expressão regular", | ||||||
|     "removeFromObtainium": "Remover do Obtainium", |     "removeFromObtainium": "Remover do Obtainium", | ||||||
|     "uninstallFromDevice": "Desinstalar do dispositivo", |     "uninstallFromDevice": "Desinstalar do dispositivo", | ||||||
|     "onlyWorksWithNonVersionDetectApps": "Apenas funciona para aplicativos com detecção de versão desativada.", |     "onlyWorksWithNonVersionDetectApps": "Apenas funciona para aplicações com a deteção de versão desativada.", | ||||||
|     "releaseDateAsVersion": "Usar data de lançamento como versão", |     "releaseDateAsVersion": "Usar data de lançamento como versão", | ||||||
|     "releaseTitleAsVersion": "Utilizar o título da versão como cadeia de versões", |     "releaseTitleAsVersion": "Utilizar o título da versão como cadeia de versões", | ||||||
|     "releaseDateAsVersionExplanation": "Esta opção só deve ser usada para aplicativos onde a detecção de versão não funciona corretamente, mas há uma data de lançamento disponível.", |     "releaseDateAsVersionExplanation": "Esta opção só deve ser usada para aplicações onde a deteção de versão não funciona corretamente, mas existe uma data de lançamento disponível.", | ||||||
|     "changes": "Alterações", |     "changes": "Alterações", | ||||||
|     "releaseDate": "Data de lançamento", |     "releaseDate": "Data de lançamento", | ||||||
|     "importFromURLsInFile": "Importar de URLs em arquivo (formato OPML)", |     "importFromURLsInFile": "Importar de URLs em arquivo (formato OPML)", | ||||||
| @@ -227,15 +227,15 @@ | |||||||
|     "dontShowAgain": "Não mostrar isso novamente", |     "dontShowAgain": "Não mostrar isso novamente", | ||||||
|     "dontShowTrackOnlyWarnings": "Não mostrar avisos 'Apenas monitorar'", |     "dontShowTrackOnlyWarnings": "Não mostrar avisos 'Apenas monitorar'", | ||||||
|     "dontShowAPKOriginWarnings": "Não mostrar avisos de origem da APK", |     "dontShowAPKOriginWarnings": "Não mostrar avisos de origem da APK", | ||||||
|     "moveNonInstalledAppsToBottom": "Mover aplicativos não instalados para o fundo da lista de aplicativos", |     "moveNonInstalledAppsToBottom": "Mover aplicações não instaladas para o fundo da lista de aplicações", | ||||||
|     "gitlabPATLabel": "Token de acesso pessoal do Gitlab", |     "gitlabPATLabel": "Token de acesso pessoal do Gitlab", | ||||||
|     "about": "Sobre", |     "about": "Sobre", | ||||||
|     "requiresCredentialsInSettings": "{}: Isso requer credenciais adicionais (em Configurações)", |     "requiresCredentialsInSettings": "{}: Isso requer credenciais adicionais (em Configurações)", | ||||||
|     "checkOnStart": "Verificar se há atualizações ao iniciar", |     "checkOnStart": "Verificar se há atualizações ao iniciar", | ||||||
|     "tryInferAppIdFromCode": "Tente inferir o ID do aplicativo pelo código-fonte", |     "tryInferAppIdFromCode": "Tentar inferir o ID da aplicação a partir do código-fonte", | ||||||
|     "removeOnExternalUninstall": "Remover automaticamente aplicativos desinstalados externamente", |     "removeOnExternalUninstall": "Remover automaticamente aplicações desinstaladas externamente", | ||||||
|     "pickHighestVersionCode": "Auto-selecionar o maior número de versão do APK", |     "pickHighestVersionCode": "Auto-selecionar o maior número de versão do APK", | ||||||
|     "checkUpdateOnDetailPage": "Checar por atualizações ao abrir a página de detalhes de um aplicativo", |     "checkUpdateOnDetailPage": "Checar por atualizações ao abrir a página de detalhes de uma aplicação", | ||||||
|     "disablePageTransitions": "Desativar animações de transição de página", |     "disablePageTransitions": "Desativar animações de transição de página", | ||||||
|     "reversePageTransitions": "Animações de transição de página invertidas", |     "reversePageTransitions": "Animações de transição de página invertidas", | ||||||
|     "minStarCount": "Contagem mínima de estrelas", |     "minStarCount": "Contagem mínima de estrelas", | ||||||
| @@ -245,11 +245,11 @@ | |||||||
|     "sortByLastLinkSegment": "Ordenar apenas usando o último segmento do link", |     "sortByLastLinkSegment": "Ordenar apenas usando o último segmento do link", | ||||||
|     "filterReleaseNotesByRegEx": "Filtrar notas de versão usando Regex", |     "filterReleaseNotesByRegEx": "Filtrar notas de versão usando Regex", | ||||||
|     "customLinkFilterRegex": "Filtro de link personalizado usando expressão regular (Padrão '.apk$')", |     "customLinkFilterRegex": "Filtro de link personalizado usando expressão regular (Padrão '.apk$')", | ||||||
|     "appsPossiblyUpdated": "Tentativas de atualização de aplicativos", |     "appsPossiblyUpdated": "Aplicações possivelmente atualizadas", | ||||||
|     "appsPossiblyUpdatedNotifDescription": "Notifica o usuário de que atualizações de um ou mais aplicativos foram potencialmente aplicadas em segundo-plano", |     "appsPossiblyUpdatedNotifDescription": "Notifica o utilizador de que as atualizações de uma ou mais aplicações foram potencialmente aplicadas em segundo plano", | ||||||
|     "xWasPossiblyUpdatedToY": "{} pode ter sido atualizado para {}.", |     "xWasPossiblyUpdatedToY": "{} pode ter sido atualizado para {}.", | ||||||
|     "enableBackgroundUpdates": "Ativar atualizações em segundo-plano", |     "enableBackgroundUpdates": "Ativar atualizações em segundo-plano", | ||||||
|     "backgroundUpdateReqsExplanation": "Atualizações em segundo-plano podem não ser possíveis para todos os aplicativos.", |     "backgroundUpdateReqsExplanation": "As atualizações em segundo plano podem não ser possíveis para todas as aplicações.", | ||||||
|     "backgroundUpdateLimitsExplanation": "O sucesso de uma instalação em segundo-plano só pode ser determinado quando o Obtainium é aberto.", |     "backgroundUpdateLimitsExplanation": "O sucesso de uma instalação em segundo-plano só pode ser determinado quando o Obtainium é aberto.", | ||||||
|     "verifyLatestTag": "Verifique a 'última' etiqueta", |     "verifyLatestTag": "Verifique a 'última' etiqueta", | ||||||
|     "intermediateLinkRegex": "Filtrar um link 'intermediário' para visitar", |     "intermediateLinkRegex": "Filtrar um link 'intermediário' para visitar", | ||||||
| @@ -282,14 +282,14 @@ | |||||||
|     "installing": "Instalando", |     "installing": "Instalando", | ||||||
|     "skipUpdateNotifications": "Pular notificações de update", |     "skipUpdateNotifications": "Pular notificações de update", | ||||||
|     "updatesAvailableNotifChannel": "Atualizações disponíveis", |     "updatesAvailableNotifChannel": "Atualizações disponíveis", | ||||||
|     "appsUpdatedNotifChannel": "Aplicativos atualizados", |     "appsUpdatedNotifChannel": "Aplicações atualizadas", | ||||||
|     "appsPossiblyUpdatedNotifChannel": "Tentativas de atualização de aplicativos", |     "appsPossiblyUpdatedNotifChannel": "Aplicações possivelmente atualizadas", | ||||||
|     "errorCheckingUpdatesNotifChannel": "Erro ao procurar por atualizações", |     "errorCheckingUpdatesNotifChannel": "Erro ao procurar por atualizações", | ||||||
|     "appsRemovedNotifChannel": "Aplicativos removidos", |     "appsRemovedNotifChannel": "Aplicações removidas", | ||||||
|     "downloadingXNotifChannel": "Baixando {}", |     "downloadingXNotifChannel": "Baixando {}", | ||||||
|     "completeAppInstallationNotifChannel": "Instalação completa do aplicativo", |     "completeAppInstallationNotifChannel": "Instalação da aplicação concluída", | ||||||
|     "checkingForUpdatesNotifChannel": "Checando por atualizações", |     "checkingForUpdatesNotifChannel": "Checando por atualizações", | ||||||
|     "onlyCheckInstalledOrTrackOnlyApps": "Apenas verificar atualizações de aplicativos instalados e 'Apenas monitorar'", |     "onlyCheckInstalledOrTrackOnlyApps": "Apenas verificar atualizações de aplicações instaladas e 'Apenas monitorizar'", | ||||||
|     "supportFixedAPKURL": "Suporte a APK com URLs fixas", |     "supportFixedAPKURL": "Suporte a APK com URLs fixas", | ||||||
|     "selectX": "Selecionar {}", |     "selectX": "Selecionar {}", | ||||||
|     "parallelDownloads": "Permitir downloads paralelos", |     "parallelDownloads": "Permitir downloads paralelos", | ||||||
| @@ -299,7 +299,7 @@ | |||||||
|     "shizukuOldAndroidWithADB": "Shizuku a funcionar no Android < 8.1 com ADB - atualizar o Android ou utilizar o Sui", |     "shizukuOldAndroidWithADB": "Shizuku a funcionar no Android < 8.1 com ADB - atualizar o Android ou utilizar o Sui", | ||||||
|     "shizukuPretendToBeGooglePlay": "Definir o Google Play como fonte de instalação (se for utilizado o Shizuku)", |     "shizukuPretendToBeGooglePlay": "Definir o Google Play como fonte de instalação (se for utilizado o Shizuku)", | ||||||
|     "useSystemFont": "Usar fonte padrão do sistema", |     "useSystemFont": "Usar fonte padrão do sistema", | ||||||
|     "useVersionCodeAsOSVersion": "Usar versionCode do aplicativo como versão detectada pelo sistema operacional", |     "useVersionCodeAsOSVersion": "Usar o versionCode da aplicação como a versão detetada pelo sistema operativo", | ||||||
|     "requestHeader": "Requisitar cabeçalho", |     "requestHeader": "Requisitar cabeçalho", | ||||||
|     "useLatestAssetDateAsReleaseDate": "Use o último upload de recursos como data de lançamento", |     "useLatestAssetDateAsReleaseDate": "Use o último upload de recursos como data de lançamento", | ||||||
|     "defaultPseudoVersioningMethod": "Método de pseudo-versionamento padrão", |     "defaultPseudoVersioningMethod": "Método de pseudo-versionamento padrão", | ||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Esta notificação é necessária para a verificação de actualizações em segundo plano (pode ser ocultada nas definições do SO)", |     "fgServiceNotice": "Esta notificação é necessária para a verificação de actualizações em segundo plano (pode ser ocultada nas definições do SO)", | ||||||
|     "excludeSecrets": "Excluir segredos", |     "excludeSecrets": "Excluir segredos", | ||||||
|     "GHReqPrefix": "Instância 'sky22333/hubproxy' para pedidos de GitHub", |     "GHReqPrefix": "Instância 'sky22333/hubproxy' para pedidos de GitHub", | ||||||
|  |     "includeZips": "Incluir ficheiros ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrar APKs dentro do ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Remover aplicação?", |         "one": "Remover aplicação?", | ||||||
|         "other": "Remover aplicações?" |         "other": "Remover aplicações?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Это уведомление необходимо для фоновой проверки обновлений (оно может быть скрыто в настройках ОС)", |     "fgServiceNotice": "Это уведомление необходимо для фоновой проверки обновлений (оно может быть скрыто в настройках ОС)", | ||||||
|     "excludeSecrets": "Исключить секреты", |     "excludeSecrets": "Исключить секреты", | ||||||
|     "GHReqPrefix": "Экземпляр 'sky22333/hubproxy' для запросов на GitHub", |     "GHReqPrefix": "Экземпляр 'sky22333/hubproxy' для запросов на GitHub", | ||||||
|  |     "includeZips": "Включить ZIP-файлы", | ||||||
|  |     "zippedApkFilterRegEx": "Фильтр APK внутри ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Удалить приложение?", |         "one": "Удалить приложение?", | ||||||
|         "other": "Удалить приложения?" |         "other": "Удалить приложения?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Detta meddelande krävs för bakgrundsuppdateringskontroll (det kan döljas i OS-inställningarna)", |     "fgServiceNotice": "Detta meddelande krävs för bakgrundsuppdateringskontroll (det kan döljas i OS-inställningarna)", | ||||||
|     "excludeSecrets": "Utesluta hemligheter", |     "excludeSecrets": "Utesluta hemligheter", | ||||||
|     "GHReqPrefix": "Instansen \"sky22333/hubproxy\" för GitHub-förfrågningar", |     "GHReqPrefix": "Instansen \"sky22333/hubproxy\" för GitHub-förfrågningar", | ||||||
|  |     "includeZips": "Inkludera ZIP-filer", | ||||||
|  |     "zippedApkFilterRegEx": "Filtrera APK:er inuti ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Ta Bort App?", |         "one": "Ta Bort App?", | ||||||
|         "other": "Ta Bort Appar?" |         "other": "Ta Bort Appar?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Bu bildirim arka planda güncelleme kontrolü için gereklidir (işletim sistemi ayarlarından gizlenebilir)", |     "fgServiceNotice": "Bu bildirim arka planda güncelleme kontrolü için gereklidir (işletim sistemi ayarlarından gizlenebilir)", | ||||||
|     "excludeSecrets": "Sırları hariç tut", |     "excludeSecrets": "Sırları hariç tut", | ||||||
|     "GHReqPrefix": "GitHub istekleri için 'sky22333/hubproxy' örneği", |     "GHReqPrefix": "GitHub istekleri için 'sky22333/hubproxy' örneği", | ||||||
|  |     "includeZips": "ZIP dosyalarını dahil edin", | ||||||
|  |     "zippedApkFilterRegEx": "ZIP içindeki APK'ları filtreleme", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Uygulamayı Kaldır?", |         "one": "Uygulamayı Kaldır?", | ||||||
|         "other": "Uygulamaları Kaldır?" |         "other": "Uygulamaları Kaldır?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Це сповіщення необхідне для фонової перевірки оновлень (його можна приховати в налаштуваннях ОС)", |     "fgServiceNotice": "Це сповіщення необхідне для фонової перевірки оновлень (його можна приховати в налаштуваннях ОС)", | ||||||
|     "excludeSecrets": "Виключити секрети", |     "excludeSecrets": "Виключити секрети", | ||||||
|     "GHReqPrefix": "екземпляр 'sky22333/hubproxy' для запитів на GitHub", |     "GHReqPrefix": "екземпляр 'sky22333/hubproxy' для запитів на GitHub", | ||||||
|  |     "includeZips": "Додайте ZIP-файли", | ||||||
|  |     "zippedApkFilterRegEx": "Фільтруйте APK-файли всередині ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Видалити застосунок?", |         "one": "Видалити застосунок?", | ||||||
|         "other": "Видалити застосунки?" |         "other": "Видалити застосунки?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "Thông báo này là bắt buộc để kiểm tra cập nhật nền (có thể ẩn trong cài đặt hệ điều hành).", |     "fgServiceNotice": "Thông báo này là bắt buộc để kiểm tra cập nhật nền (có thể ẩn trong cài đặt hệ điều hành).", | ||||||
|     "excludeSecrets": "Loại trừ thông tin bí mật", |     "excludeSecrets": "Loại trừ thông tin bí mật", | ||||||
|     "GHReqPrefix": "Thực thể 'sky22333/hubproxy' cho các yêu cầu GitHub", |     "GHReqPrefix": "Thực thể 'sky22333/hubproxy' cho các yêu cầu GitHub", | ||||||
|  |     "includeZips": "Ba gồm các tệp ZIP", | ||||||
|  |     "zippedApkFilterRegEx": "Lọc các tệp APK bên trong tệp ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Gỡ ứng dụng?", |         "one": "Gỡ ứng dụng?", | ||||||
|         "other": "Gỡ ứng dụng?" |         "other": "Gỡ ứng dụng?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", |     "fgServiceNotice": "This notification is required for background update checking (it can be hidden in the OS settings)", | ||||||
|     "excludeSecrets": "Exclude secrets", |     "excludeSecrets": "Exclude secrets", | ||||||
|     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", |     "GHReqPrefix": "'sky22333/hubproxy' instance for GitHub requests", | ||||||
|  |     "includeZips": "Include ZIP files", | ||||||
|  |     "zippedApkFilterRegEx": "Filter APKs inside ZIP", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "移除應用程式?", |         "one": "移除應用程式?", | ||||||
|         "other": "移除應用程式?" |         "other": "移除應用程式?" | ||||||
|   | |||||||
| @@ -337,6 +337,8 @@ | |||||||
|     "fgServiceNotice": "后台检查更新时需要此通知(可在操作系统设置中隐藏)", |     "fgServiceNotice": "后台检查更新时需要此通知(可在操作系统设置中隐藏)", | ||||||
|     "excludeSecrets": "排除机密", |     "excludeSecrets": "排除机密", | ||||||
|     "GHReqPrefix": "用于 GitHub 请求的 \"sky22333/hubproxy \"实例", |     "GHReqPrefix": "用于 GitHub 请求的 \"sky22333/hubproxy \"实例", | ||||||
|  |     "includeZips": "包含 ZIP 文件", | ||||||
|  |     "zippedApkFilterRegEx": "过滤 ZIP 内的 APK", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "是否删除应用?", |         "one": "是否删除应用?", | ||||||
|         "other": "是否删除应用?" |         "other": "是否删除应用?" | ||||||
|   | |||||||
| @@ -18,6 +18,7 @@ class GitHub extends AppSource { | |||||||
|     appIdInferIsOptional = true; |     appIdInferIsOptional = true; | ||||||
|     showReleaseDateAsVersionToggle = true; |     showReleaseDateAsVersionToggle = true; | ||||||
|     this.hostChanged = hostChanged; |     this.hostChanged = hostChanged; | ||||||
|  |     allowIncludeZips = true; | ||||||
|  |  | ||||||
|     sourceConfigSettingFormItems = [ |     sourceConfigSettingFormItems = [ | ||||||
|       GeneratedFormTextField( |       GeneratedFormTextField( | ||||||
| @@ -53,11 +54,12 @@ class GitHub extends AppSource { | |||||||
|         additionalValidators: [ |         additionalValidators: [ | ||||||
|           (value) { |           (value) { | ||||||
|             try { |             try { | ||||||
|               if (Uri.parse( |               if (value != null && Uri.parse(value).scheme.isNotEmpty) { | ||||||
|                 'https://${value}/api.github.com', |  | ||||||
|               ).scheme.isNotEmpty) { |  | ||||||
|                 throw true; |                 throw true; | ||||||
|               } |               } | ||||||
|  |               if (value != null) { | ||||||
|  |                 Uri.parse('https://${value}/api.github.com'); | ||||||
|  |               } | ||||||
|             } catch (e) { |             } catch (e) { | ||||||
|               return tr('invalidInput'); |               return tr('invalidInput'); | ||||||
|             } |             } | ||||||
| @@ -288,6 +290,9 @@ class GitHub extends AppSource { | |||||||
|       settingsProvider, |       settingsProvider, | ||||||
|     ); |     ); | ||||||
|     String? creds = sourceConfig['github-creds']; |     String? creds = sourceConfig['github-creds']; | ||||||
|  |     if ((additionalSettings['GHReqPrefix'] as String? ?? '').isNotEmpty) { | ||||||
|  |       creds = null; | ||||||
|  |     } | ||||||
|     if (creds != null) { |     if (creds != null) { | ||||||
|       var userNameEndIndex = creds.indexOf(':'); |       var userNameEndIndex = creds.indexOf(':'); | ||||||
|       if (userNameEndIndex > 0) { |       if (userNameEndIndex > 0) { | ||||||
| @@ -366,6 +371,7 @@ class GitHub extends AppSource { | |||||||
|         additionalSettings['useLatestAssetDateAsReleaseDate'] == true; |         additionalSettings['useLatestAssetDateAsReleaseDate'] == true; | ||||||
|     String sortMethod = |     String sortMethod = | ||||||
|         additionalSettings['sortMethodChoice'] ?? 'smartname-datefallback'; |         additionalSettings['sortMethodChoice'] ?? 'smartname-datefallback'; | ||||||
|  |     bool includeZips = additionalSettings['includeZips'] == true; | ||||||
|     dynamic latestRelease; |     dynamic latestRelease; | ||||||
|     if (verifyLatestTag) { |     if (verifyLatestTag) { | ||||||
|       var temp = requestUrl.split('?'); |       var temp = requestUrl.split('?'); | ||||||
| @@ -398,7 +404,8 @@ class GitHub extends AppSource { | |||||||
|  |  | ||||||
|       findReleaseAssetUrls(dynamic release) => |       findReleaseAssetUrls(dynamic release) => | ||||||
|           (release['assets'] as List<dynamic>?)?.map((e) { |           (release['assets'] as List<dynamic>?)?.map((e) { | ||||||
|             var url = !e['name'].toString().toLowerCase().endsWith('.apk') |             var ext = e['name'].toString().toLowerCase().split('.').last; | ||||||
|  |             var url = !(ext == 'apk' || (includeZips && ext == 'zip')) | ||||||
|                 ? (e['browser_download_url'] ?? e['url']) |                 ? (e['browser_download_url'] ?? e['url']) | ||||||
|                 : (e['url'] ?? e['browser_download_url']); |                 : (e['url'] ?? e['browser_download_url']); | ||||||
|             url = undoGHProxyMod(url, sourceConfigSettingValues); |             url = undoGHProxyMod(url, sourceConfigSettingValues); | ||||||
| @@ -538,14 +545,13 @@ class GitHub extends AppSource { | |||||||
|         List<MapEntry<String, String>> allAssetUrls = allAssetsWithUrls |         List<MapEntry<String, String>> allAssetUrls = allAssetsWithUrls | ||||||
|             .map((e) => e['final_url'] as MapEntry<String, String>) |             .map((e) => e['final_url'] as MapEntry<String, String>) | ||||||
|             .toList(); |             .toList(); | ||||||
|         var apkAssetsWithUrls = allAssetsWithUrls |         var apkAssetsWithUrls = allAssetsWithUrls.where((element) { | ||||||
|             .where( |           var ext = (element['final_url'] as MapEntry<String, String>).key | ||||||
|               (element) => (element['final_url'] as MapEntry<String, String>) |  | ||||||
|                   .key |  | ||||||
|               .toLowerCase() |               .toLowerCase() | ||||||
|                   .endsWith('.apk'), |               .split('.') | ||||||
|             ) |               .last; | ||||||
|             .toList(); |           return ext == 'apk' || (includeZips && ext == 'zip'); | ||||||
|  |         }).toList(); | ||||||
|  |  | ||||||
|         var filteredApkUrls = filterApks( |         var filteredApkUrls = filterApks( | ||||||
|           apkAssetsWithUrls |           apkAssetsWithUrls | ||||||
|   | |||||||
| @@ -203,11 +203,11 @@ class AddAppPageState extends State<AddAppPage> { | |||||||
|               notificationsProvider: notificationsProvider, |               notificationsProvider: notificationsProvider, | ||||||
|             ); |             ); | ||||||
|             DownloadedApk? downloadedFile; |             DownloadedApk? downloadedFile; | ||||||
|             DownloadedXApkDir? downloadedDir; |             DownloadedDir? downloadedDir; | ||||||
|             if (downloadedArtifact is DownloadedApk) { |             if (downloadedArtifact is DownloadedApk) { | ||||||
|               downloadedFile = downloadedArtifact; |               downloadedFile = downloadedArtifact; | ||||||
|             } else { |             } else { | ||||||
|               downloadedDir = downloadedArtifact as DownloadedXApkDir; |               downloadedDir = downloadedArtifact as DownloadedDir; | ||||||
|             } |             } | ||||||
|             app.id = downloadedFile?.appId ?? downloadedDir!.appId; |             app.id = downloadedFile?.appId ?? downloadedDir!.appId; | ||||||
|           } |           } | ||||||
|   | |||||||
| @@ -1010,6 +1010,7 @@ class AppsPageState extends State<AppsPage> { | |||||||
|                       selectedApps.where((element) => element.pinned).isEmpty |                       selectedApps.where((element) => element.pinned).isEmpty | ||||||
|                           ? tr('pinToTop') |                           ? tr('pinToTop') | ||||||
|                           : tr('unpinFromTop'), |                           : tr('unpinFromTop'), | ||||||
|  |                       textAlign: TextAlign.center, | ||||||
|                     ), |                     ), | ||||||
|                   ), |                   ), | ||||||
|                   const Divider(), |                   const Divider(), | ||||||
| @@ -1026,7 +1027,10 @@ class AppsPageState extends State<AppsPage> { | |||||||
|                       ); |                       ); | ||||||
|                       Navigator.of(context).pop(); |                       Navigator.of(context).pop(); | ||||||
|                     }, |                     }, | ||||||
|                     child: Text(tr('shareSelectedAppURLs')), |                     child: Text( | ||||||
|  |                       tr('shareSelectedAppURLs'), | ||||||
|  |                       textAlign: TextAlign.center, | ||||||
|  |                     ), | ||||||
|                   ), |                   ), | ||||||
|                   const Divider(), |                   const Divider(), | ||||||
|                   TextButton( |                   TextButton( | ||||||
| @@ -1043,7 +1047,10 @@ class AppsPageState extends State<AppsPage> { | |||||||
|                               subject: 'Obtainium - ${tr('appsString')}', |                               subject: 'Obtainium - ${tr('appsString')}', | ||||||
|                             ); |                             ); | ||||||
|                           }, |                           }, | ||||||
|                     child: Text(tr('shareAppConfigLinks')), |                     child: Text( | ||||||
|  |                       tr('shareAppConfigLinks'), | ||||||
|  |                       textAlign: TextAlign.center, | ||||||
|  |                     ), | ||||||
|                   ), |                   ), | ||||||
|                   const Divider(), |                   const Divider(), | ||||||
|                   TextButton( |                   TextButton( | ||||||
| @@ -1069,7 +1076,10 @@ class AppsPageState extends State<AppsPage> { | |||||||
|                               fileNameOverrides: ['$fn.json'], |                               fileNameOverrides: ['$fn.json'], | ||||||
|                             ); |                             ); | ||||||
|                           }, |                           }, | ||||||
|                     child: Text('${tr('share')} - ${tr('obtainiumExport')}'), |                     child: Text( | ||||||
|  |                       '${tr('share')} - ${tr('obtainiumExport')}', | ||||||
|  |                       textAlign: TextAlign.center, | ||||||
|  |                     ), | ||||||
|                   ), |                   ), | ||||||
|                   const Divider(), |                   const Divider(), | ||||||
|                   TextButton( |                   TextButton( | ||||||
| @@ -1093,6 +1103,7 @@ class AppsPageState extends State<AppsPage> { | |||||||
|                         'downloadX', |                         'downloadX', | ||||||
|                         args: [lowerCaseIfEnglish(tr('releaseAsset'))], |                         args: [lowerCaseIfEnglish(tr('releaseAsset'))], | ||||||
|                       ), |                       ), | ||||||
|  |                       textAlign: TextAlign.center, | ||||||
|                     ), |                     ), | ||||||
|                   ), |                   ), | ||||||
|                   const Divider(), |                   const Divider(), | ||||||
| @@ -1100,7 +1111,10 @@ class AppsPageState extends State<AppsPage> { | |||||||
|                     onPressed: appsProvider.areDownloadsRunning() |                     onPressed: appsProvider.areDownloadsRunning() | ||||||
|                         ? null |                         ? null | ||||||
|                         : showMassMarkDialog, |                         : showMassMarkDialog, | ||||||
|                     child: Text(tr('markSelectedAppsUpdated')), |                     child: Text( | ||||||
|  |                       tr('markSelectedAppsUpdated'), | ||||||
|  |                       textAlign: TextAlign.center, | ||||||
|  |                     ), | ||||||
|                   ), |                   ), | ||||||
|                 ], |                 ], | ||||||
|               ), |               ), | ||||||
|   | |||||||
| @@ -62,11 +62,14 @@ class DownloadedApk { | |||||||
|   DownloadedApk(this.appId, this.file); |   DownloadedApk(this.appId, this.file); | ||||||
| } | } | ||||||
|  |  | ||||||
| class DownloadedXApkDir { | enum DownloadedDirType { XAPK, ZIP } | ||||||
|  |  | ||||||
|  | class DownloadedDir { | ||||||
|   String appId; |   String appId; | ||||||
|   File file; |   File file; | ||||||
|   Directory extracted; |   Directory extracted; | ||||||
|   DownloadedXApkDir(this.appId, this.file, this.extracted); |   DownloadedDirType type; | ||||||
|  |   DownloadedDir(this.appId, this.file, this.extracted, this.type); | ||||||
| } | } | ||||||
|  |  | ||||||
| List<String> generateStandardVersionRegExStrings() { | List<String> generateStandardVersionRegExStrings() { | ||||||
| @@ -664,17 +667,18 @@ class AppsProvider with ChangeNotifier { | |||||||
|       } |       } | ||||||
|       PackageInfo? newInfo; |       PackageInfo? newInfo; | ||||||
|       var isAPK = downloadedFile.path.toLowerCase().endsWith('.apk'); |       var isAPK = downloadedFile.path.toLowerCase().endsWith('.apk'); | ||||||
|       Directory? xapkDir; |       var isXAPK = downloadedFile.path.toLowerCase().endsWith('.xapk'); | ||||||
|  |       Directory? apkDir; | ||||||
|       if (isAPK) { |       if (isAPK) { | ||||||
|         newInfo = await pm.getPackageArchiveInfo( |         newInfo = await pm.getPackageArchiveInfo( | ||||||
|           archiveFilePath: downloadedFile.path, |           archiveFilePath: downloadedFile.path, | ||||||
|         ); |         ); | ||||||
|       } else { |       } else { | ||||||
|         // Assume XAPK |         // Assume XAPK or ZIP | ||||||
|         String xapkDirPath = '${downloadedFile.path}-dir'; |         String apkDirPath = '${downloadedFile.path}-dir'; | ||||||
|         await unzipFile(downloadedFile.path, '${downloadedFile.path}-dir'); |         await unzipFile(downloadedFile.path, '${downloadedFile.path}-dir'); | ||||||
|         xapkDir = Directory(xapkDirPath); |         apkDir = Directory(apkDirPath); | ||||||
|         var apks = xapkDir |         var apks = apkDir | ||||||
|             .listSync() |             .listSync() | ||||||
|             .where((e) => e.path.toLowerCase().endsWith('.apk')) |             .where((e) => e.path.toLowerCase().endsWith('.apk')) | ||||||
|             .toList(); |             .toList(); | ||||||
| @@ -691,6 +695,22 @@ class AppsProvider with ChangeNotifier { | |||||||
|           apks = [temp!, ...apks]; |           apks = [temp!, ...apks]; | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if (app.additionalSettings['zippedApkFilterRegEx']?.isNotEmpty == | ||||||
|  |             true) { | ||||||
|  |           var reg = RegExp(app.additionalSettings['zippedApkFilterRegEx']); | ||||||
|  |           apks.removeWhere((apk) { | ||||||
|  |             var shouldDelete = !reg.hasMatch(apk.uri.pathSegments.last); | ||||||
|  |             if (shouldDelete) { | ||||||
|  |               apk.delete(); | ||||||
|  |             } | ||||||
|  |             return shouldDelete; | ||||||
|  |           }); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         if (apks.isEmpty) { | ||||||
|  |           throw NoAPKError(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         for (var i = 0; i < apks.length; i++) { |         for (var i = 0; i < apks.length; i++) { | ||||||
|           try { |           try { | ||||||
|             newInfo = await pm.getPackageArchiveInfo( |             newInfo = await pm.getPackageArchiveInfo( | ||||||
| @@ -728,7 +748,12 @@ class AppsProvider with ChangeNotifier { | |||||||
|       if (isAPK) { |       if (isAPK) { | ||||||
|         return DownloadedApk(app.id, downloadedFile); |         return DownloadedApk(app.id, downloadedFile); | ||||||
|       } else { |       } else { | ||||||
|         return DownloadedXApkDir(app.id, downloadedFile, xapkDir!); |         return DownloadedDir( | ||||||
|  |           app.id, | ||||||
|  |           downloadedFile, | ||||||
|  |           apkDir!, | ||||||
|  |           isXAPK ? DownloadedDirType.XAPK : DownloadedDirType.ZIP, | ||||||
|  |         ); | ||||||
|       } |       } | ||||||
|     } finally { |     } finally { | ||||||
|       notificationsProvider?.cancel(notifId); |       notificationsProvider?.cancel(notifId); | ||||||
| @@ -826,15 +851,16 @@ class AppsProvider with ChangeNotifier { | |||||||
|     ); |     ); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   Future<bool> installXApkDir( |   Future<bool> installApkDir( | ||||||
|     DownloadedXApkDir dir, |     DownloadedDir dir, | ||||||
|     BuildContext? firstTimeWithContext, { |     BuildContext? firstTimeWithContext, { | ||||||
|     bool needsBGWorkaround = false, |     bool needsBGWorkaround = false, | ||||||
|     bool shizukuPretendToBeGooglePlay = false, |     bool shizukuPretendToBeGooglePlay = false, | ||||||
|   }) async { |   }) async { | ||||||
|     // We don't know which APKs in an XAPK are supported by the user's device |     // We don't know which APKs in an XAPK or ZIP are supported by the user's device | ||||||
|     // So we try installing all of them and assume success if at least one installed |     // So we try installing all of them and assume success if at least one installed | ||||||
|     // If 0 APKs installed, throw the first install error encountered |     // If 0 APKs installed, throw the first install error encountered | ||||||
|  |     // Obviously this approach is naive and is undesirable in many cases, needs to be improved | ||||||
|     var somethingInstalled = false; |     var somethingInstalled = false; | ||||||
|     try { |     try { | ||||||
|       MultiAppMultiError errors = MultiAppMultiError(); |       MultiAppMultiError errors = MultiAppMultiError(); | ||||||
| @@ -863,7 +889,7 @@ class AppsProvider with ChangeNotifier { | |||||||
|       } |       } | ||||||
|  |  | ||||||
|       try { |       try { | ||||||
|         await installApk( |         var wasInstalled = await installApk( | ||||||
|           DownloadedApk(dir.appId, APKFiles[0]), |           DownloadedApk(dir.appId, APKFiles[0]), | ||||||
|           firstTimeWithContext, |           firstTimeWithContext, | ||||||
|           needsBGWorkaround: needsBGWorkaround, |           needsBGWorkaround: needsBGWorkaround, | ||||||
| @@ -872,10 +898,10 @@ class AppsProvider with ChangeNotifier { | |||||||
|             1, |             1, | ||||||
|           ).map((a) => DownloadedApk(dir.appId, a)).toList(), |           ).map((a) => DownloadedApk(dir.appId, a)).toList(), | ||||||
|         ); |         ); | ||||||
|         somethingInstalled = true; |         somethingInstalled = somethingInstalled || wasInstalled; | ||||||
|         dir.file.delete(recursive: true); |         dir.file.delete(recursive: true); | ||||||
|       } catch (e) { |       } catch (e) { | ||||||
|         logs.add('Could not install APKs from XAPK: ${e.toString()}'); |         logs.add('Could not install APKs from ${dir.type}: ${e.toString()}'); | ||||||
|         errors.add(dir.appId, e, appName: apps[dir.appId]?.name); |         errors.add(dir.appId, e, appName: apps[dir.appId]?.name); | ||||||
|       } |       } | ||||||
|       if (errors.idsByErrorString.isNotEmpty) { |       if (errors.idsByErrorString.isNotEmpty) { | ||||||
| @@ -1148,7 +1174,7 @@ class AppsProvider with ChangeNotifier { | |||||||
|       String id, |       String id, | ||||||
|       bool willBeSilent, |       bool willBeSilent, | ||||||
|       DownloadedApk? downloadedFile, |       DownloadedApk? downloadedFile, | ||||||
|       DownloadedXApkDir? downloadedDir, |       DownloadedDir? downloadedDir, | ||||||
|     ) async { |     ) async { | ||||||
|       apps[id]?.downloadProgress = -1; |       apps[id]?.downloadProgress = -1; | ||||||
|       notifyListeners(); |       notifyListeners(); | ||||||
| @@ -1183,14 +1209,14 @@ class AppsProvider with ChangeNotifier { | |||||||
|         } else { |         } else { | ||||||
|           if (needBGWorkaround) { |           if (needBGWorkaround) { | ||||||
|             // ignore: use_build_context_synchronously |             // ignore: use_build_context_synchronously | ||||||
|             installXApkDir( |             installApkDir( | ||||||
|               downloadedDir!, |               downloadedDir!, | ||||||
|               contextIfNewInstall, |               contextIfNewInstall, | ||||||
|               needsBGWorkaround: true, |               needsBGWorkaround: true, | ||||||
|             ); |             ); | ||||||
|           } else { |           } else { | ||||||
|             // ignore: use_build_context_synchronously |             // ignore: use_build_context_synchronously | ||||||
|             sayInstalled = await installXApkDir( |             sayInstalled = await installApkDir( | ||||||
|               downloadedDir!, |               downloadedDir!, | ||||||
|               contextIfNewInstall, |               contextIfNewInstall, | ||||||
|               shizukuPretendToBeGooglePlay: shizukuPretendToBeGooglePlay, |               shizukuPretendToBeGooglePlay: shizukuPretendToBeGooglePlay, | ||||||
| @@ -1227,7 +1253,7 @@ class AppsProvider with ChangeNotifier { | |||||||
|     }) async { |     }) async { | ||||||
|       bool willBeSilent = false; |       bool willBeSilent = false; | ||||||
|       DownloadedApk? downloadedFile; |       DownloadedApk? downloadedFile; | ||||||
|       DownloadedXApkDir? downloadedDir; |       DownloadedDir? downloadedDir; | ||||||
|       try { |       try { | ||||||
|         var downloadedArtifact = |         var downloadedArtifact = | ||||||
|             // ignore: use_build_context_synchronously |             // ignore: use_build_context_synchronously | ||||||
| @@ -1240,7 +1266,7 @@ class AppsProvider with ChangeNotifier { | |||||||
|         if (downloadedArtifact is DownloadedApk) { |         if (downloadedArtifact is DownloadedApk) { | ||||||
|           downloadedFile = downloadedArtifact; |           downloadedFile = downloadedArtifact; | ||||||
|         } else { |         } else { | ||||||
|           downloadedDir = downloadedArtifact as DownloadedXApkDir; |           downloadedDir = downloadedArtifact as DownloadedDir; | ||||||
|         } |         } | ||||||
|         id = downloadedFile?.appId ?? downloadedDir!.appId; |         id = downloadedFile?.appId ?? downloadedDir!.appId; | ||||||
|         willBeSilent = await canInstallSilently(apps[id]!.app); |         willBeSilent = await canInstallSilently(apps[id]!.app); | ||||||
| @@ -1292,7 +1318,7 @@ class AppsProvider with ChangeNotifier { | |||||||
|             res['id'] as String, |             res['id'] as String, | ||||||
|             res['willBeSilent'] as bool, |             res['willBeSilent'] as bool, | ||||||
|             res['downloadedFile'] as DownloadedApk?, |             res['downloadedFile'] as DownloadedApk?, | ||||||
|             res['downloadedDir'] as DownloadedXApkDir?, |             res['downloadedDir'] as DownloadedDir?, | ||||||
|           ); |           ); | ||||||
|         } catch (e) { |         } catch (e) { | ||||||
|           var id = res['id'] as String; |           var id = res['id'] as String; | ||||||
| @@ -1323,6 +1349,7 @@ class AppsProvider with ChangeNotifier { | |||||||
|       MapEntry<String, String>? fileUrl; |       MapEntry<String, String>? fileUrl; | ||||||
|       var refreshBeforeDownload = |       var refreshBeforeDownload = | ||||||
|           apps[id]!.app.additionalSettings['refreshBeforeDownload'] == true || |           apps[id]!.app.additionalSettings['refreshBeforeDownload'] == true || | ||||||
|  |           apps[id]!.app.apkUrls.isNotEmpty && | ||||||
|               apps[id]!.app.apkUrls.first.value == 'placeholder'; |               apps[id]!.app.apkUrls.first.value == 'placeholder'; | ||||||
|       if (refreshBeforeDownload) { |       if (refreshBeforeDownload) { | ||||||
|         await checkUpdate(apps[id]!.app.id); |         await checkUpdate(apps[id]!.app.id); | ||||||
|   | |||||||
| @@ -636,6 +636,7 @@ abstract class AppSource { | |||||||
|   bool versionDetectionDisallowed = false; |   bool versionDetectionDisallowed = false; | ||||||
|   List<String> excludeCommonSettingKeys = []; |   List<String> excludeCommonSettingKeys = []; | ||||||
|   bool urlsAlwaysHaveExtension = false; |   bool urlsAlwaysHaveExtension = false; | ||||||
|  |   bool allowIncludeZips = false; | ||||||
|  |  | ||||||
|   AppSource() { |   AppSource() { | ||||||
|     name = runtimeType.toString(); |     name = runtimeType.toString(); | ||||||
| @@ -834,7 +835,7 @@ abstract class AppSource { | |||||||
|     ], |     ], | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
|   // Previous 2 variables combined into one at runtime for convenient usage |   // Previous 2 variables combined into one at runtime for convenient usage + additional processing | ||||||
|   List<List<GeneratedFormItem>> get combinedAppSpecificSettingFormItems { |   List<List<GeneratedFormItem>> get combinedAppSpecificSettingFormItems { | ||||||
|     if (showReleaseDateAsVersionToggle == true) { |     if (showReleaseDateAsVersionToggle == true) { | ||||||
|       if (additionalAppSpecificSourceAgnosticSettingFormItemsNeverUseDirectly |       if (additionalAppSpecificSourceAgnosticSettingFormItemsNeverUseDirectly | ||||||
| @@ -878,6 +879,32 @@ abstract class AppSource { | |||||||
|             ) |             ) | ||||||
|             .where((e) => e.isNotEmpty) |             .where((e) => e.isNotEmpty) | ||||||
|             .toList(); |             .toList(); | ||||||
|  |  | ||||||
|  |     var moreConditionalItems = []; | ||||||
|  |     if (allowIncludeZips) { | ||||||
|  |       moreConditionalItems.addAll([ | ||||||
|  |         [ | ||||||
|  |           GeneratedFormSwitch( | ||||||
|  |             'includeZips', | ||||||
|  |             label: tr('includeZips'), | ||||||
|  |             defaultValue: false, | ||||||
|  |           ), | ||||||
|  |         ], | ||||||
|  |         [ | ||||||
|  |           GeneratedFormTextField( | ||||||
|  |             'zippedApkFilterRegEx', | ||||||
|  |             label: tr('zippedApkFilterRegEx'), | ||||||
|  |             required: false, | ||||||
|  |             additionalValidators: [ | ||||||
|  |               (value) { | ||||||
|  |                 return regExValidator(value); | ||||||
|  |               }, | ||||||
|  |             ], | ||||||
|  |           ), | ||||||
|  |         ], | ||||||
|  |       ]); | ||||||
|  |     } | ||||||
|  |  | ||||||
|     if (versionDetectionDisallowed) { |     if (versionDetectionDisallowed) { | ||||||
|       overrideAdditionalAppSpecificSourceAgnosticSettingSwitch( |       overrideAdditionalAppSpecificSourceAgnosticSettingSwitch( | ||||||
|         'versionDetection', |         'versionDetection', | ||||||
| @@ -893,6 +920,7 @@ abstract class AppSource { | |||||||
|     return [ |     return [ | ||||||
|       ...additionalSourceAppSpecificSettingFormItems, |       ...additionalSourceAppSpecificSettingFormItems, | ||||||
|       ...additionalAppSpecificSourceAgnosticSettingFormItemsNeverUseDirectly, |       ...additionalAppSpecificSourceAgnosticSettingFormItemsNeverUseDirectly, | ||||||
|  |       ...moreConditionalItems, | ||||||
|     ]; |     ]; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										28
									
								
								pubspec.lock
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								pubspec.lock
									
									
									
									
									
								
							| @@ -40,10 +40,10 @@ packages: | |||||||
|     dependency: "direct main" |     dependency: "direct main" | ||||||
|     description: |     description: | ||||||
|       name: animations |       name: animations | ||||||
|       sha256: d3d6dcfb218225bbe68e87ccf6378bbb2e32a94900722c5f81611dad089911cb |       sha256: a8031b276f0a7986ac907195f10ca7cd04ecf2a8a566bd6dbe03018a9b02b427 | ||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "2.0.11" |     version: "2.1.0" | ||||||
|   app_links: |   app_links: | ||||||
|     dependency: "direct main" |     dependency: "direct main" | ||||||
|     description: |     description: | ||||||
| @@ -482,10 +482,10 @@ packages: | |||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
|       name: flutter_plugin_android_lifecycle |       name: flutter_plugin_android_lifecycle | ||||||
|       sha256: b0694b7fb1689b0e6cc193b3f1fcac6423c4f93c74fb20b806c6b6f196db0c31 |       sha256: c2fe1001710127dfa7da89977a08d591398370d099aacdaa6d44da7eb14b8476 | ||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "2.0.30" |     version: "2.0.31" | ||||||
|   flutter_test: |   flutter_test: | ||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: flutter |     description: flutter | ||||||
| @@ -676,10 +676,10 @@ packages: | |||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
|       name: path_provider_android |       name: path_provider_android | ||||||
|       sha256: "993381400e94d18469750e5b9dcb8206f15bc09f9da86b9e44a9b0092a0066db" |       sha256: "3b4c1fc3aa55ddc9cd4aa6759984330d5c8e66aa7702a6223c61540dc6380c37" | ||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "2.2.18" |     version: "2.2.19" | ||||||
|   path_provider_foundation: |   path_provider_foundation: | ||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
| @@ -852,10 +852,10 @@ packages: | |||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
|       name: shared_preferences_android |       name: shared_preferences_android | ||||||
|       sha256: a2608114b1ffdcbc9c120eb71a0e207c71da56202852d4aab8a5e30a82269e74 |       sha256: "34266009473bf71d748912da4bf62d439185226c03e01e2d9687bc65bbfcb713" | ||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "2.4.12" |     version: "2.4.15" | ||||||
|   shared_preferences_foundation: |   shared_preferences_foundation: | ||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
| @@ -1059,10 +1059,10 @@ packages: | |||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
|       name: url_launcher_android |       name: url_launcher_android | ||||||
|       sha256: "199bc33e746088546a39cc5f36bac5a278c5e53b40cb3196f99e7345fdcfae6b" |       sha256: "5c8b6c2d89a78f5a1cca70a73d9d5f86c701b36b42f9c9dac7bad592113c28e9" | ||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "6.3.22" |     version: "6.3.24" | ||||||
|   url_launcher_ios: |   url_launcher_ios: | ||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
| @@ -1155,10 +1155,10 @@ packages: | |||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
|       name: webview_flutter_android |       name: webview_flutter_android | ||||||
|       sha256: "3c4eb4fcc252b40c2b5ce7be20d0481428b70f3ff589b0a8b8aaeb64c6bed701" |       sha256: e5201c620eb2637dca88a756961fae4a7191bb30b4f2271e08b746405ffdf3fd | ||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "4.10.2" |     version: "4.10.5" | ||||||
|   webview_flutter_platform_interface: |   webview_flutter_platform_interface: | ||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
| @@ -1179,10 +1179,10 @@ packages: | |||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
|       name: win32 |       name: win32 | ||||||
|       sha256: "66814138c3562338d05613a6e368ed8cfb237ad6d64a9e9334be3f309acfca03" |       sha256: d7cb55e04cd34096cd3a79b3330245f54cb96a370a1c27adb3c84b917de8b08e | ||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "5.14.0" |     version: "5.15.0" | ||||||
|   win32_registry: |   win32_registry: | ||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
|   | |||||||
| @@ -16,7 +16,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 | # 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 | # 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. | # of the product and file versions while build-number is used as the build suffix. | ||||||
| version: 1.2.5+2321 | version: 1.2.7+2323 | ||||||
|  |  | ||||||
| environment: | environment: | ||||||
|   sdk: ^3.8.1 |   sdk: ^3.8.1 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user