mirror of
				https://github.com/ImranR98/Obtainium.git
				synced 2025-10-26 03:03:45 +01:00 
			
		
		
		
	Add filename-only sort for HTML (#734)
This commit is contained in:
		| @@ -244,6 +244,7 @@ | |||||||
|    "addInfoInSettings": "Add this info in the Settings.", |    "addInfoInSettings": "Add this info in the Settings.", | ||||||
|    "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", |    "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", | ||||||
|    "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", |    "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", | ||||||
|  |    "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|    "removeAppQuestion": { |    "removeAppQuestion": { | ||||||
|       "one": "Želite li ukloniti aplikaciju?", |       "one": "Želite li ukloniti aplikaciju?", | ||||||
|       "other": "Želite li ukloniti aplikacije?" |       "other": "Želite li ukloniti aplikacije?" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "Fügen Sie diese Info in den Einstellungen hinzu.", |     "addInfoInSettings": "Fügen Sie diese Info in den Einstellungen hinzu.", | ||||||
|     "githubSourceNote": "Die GitHub-Ratenbegrenzung kann mit einem API-Schlüssel umgangen werden.", |     "githubSourceNote": "Die GitHub-Ratenbegrenzung kann mit einem API-Schlüssel umgangen werden.", | ||||||
|     "gitlabSourceNote": "GitLab APK-Extraktion funktioniert möglicherweise nicht ohne API-Schlüssel", |     "gitlabSourceNote": "GitLab APK-Extraktion funktioniert möglicherweise nicht ohne API-Schlüssel", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "App entfernen?", |         "one": "App entfernen?", | ||||||
|         "other": "Apps entfernen?" |         "other": "Apps entfernen?" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "Add this info in the Settings.", |     "addInfoInSettings": "Add this info in the Settings.", | ||||||
|     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", |     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", | ||||||
|     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", |     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Remove App?", |         "one": "Remove App?", | ||||||
|         "other": "Remove Apps?" |         "other": "Remove Apps?" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "Add this info in the Settings.", |     "addInfoInSettings": "Add this info in the Settings.", | ||||||
|     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", |     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", | ||||||
|     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", |     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "¿Eliminar Aplicación?", |         "one": "¿Eliminar Aplicación?", | ||||||
|         "other": "¿Eliminar Aplicaciones?" |         "other": "¿Eliminar Aplicaciones?" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "Add this info in the Settings.", |     "addInfoInSettings": "Add this info in the Settings.", | ||||||
|     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", |     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", | ||||||
|     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", |     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "برنامه حذف شود؟", |         "one": "برنامه حذف شود؟", | ||||||
|         "other": "برنامه ها حذف شوند؟" |         "other": "برنامه ها حذف شوند؟" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "Add this info in the Settings.", |     "addInfoInSettings": "Add this info in the Settings.", | ||||||
|     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", |     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", | ||||||
|     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", |     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Supprimer l'application ?", |         "one": "Supprimer l'application ?", | ||||||
|         "other": "Supprimer les applications ?" |         "other": "Supprimer les applications ?" | ||||||
|   | |||||||
| @@ -243,6 +243,7 @@ | |||||||
|     "addInfoInSettings": "Adja hozzá ezt az infót a Beállításokban.", |     "addInfoInSettings": "Adja hozzá ezt az infót a Beállításokban.", | ||||||
|     "githubSourceNote": "A GitHub értékelési korlátozása elkerülhető API-kulcs használatával.", |     "githubSourceNote": "A GitHub értékelési korlátozása elkerülhető API-kulcs használatával.", | ||||||
|     "gitlabSourceNote": "Előfordulhat, hogy a GitLab APK kibontása nem működik API-kulcs nélkül.", |     "gitlabSourceNote": "Előfordulhat, hogy a GitLab APK kibontása nem működik API-kulcs nélkül.", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Eltávolítja az alkalmazást?", |         "one": "Eltávolítja az alkalmazást?", | ||||||
|         "other": "Eltávolítja az alkalmazást?" |         "other": "Eltávolítja az alkalmazást?" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "Add this info in the Settings.", |     "addInfoInSettings": "Add this info in the Settings.", | ||||||
|     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", |     "githubSourceNote": "GitHub rate limiting can be avoided using an API key.", | ||||||
|     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", |     "gitlabSourceNote": "GitLab APK extraction may not work without an API key.", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Rimuovere l'app?", |         "one": "Rimuovere l'app?", | ||||||
|         "other": "Rimuovere le app?" |         "other": "Rimuovere le app?" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "設定でこの情報を追加してください。", |     "addInfoInSettings": "設定でこの情報を追加してください。", | ||||||
|     "githubSourceNote": "GitHubのレート制限はAPIキーを使うことで回避できます。", |     "githubSourceNote": "GitHubのレート制限はAPIキーを使うことで回避できます。", | ||||||
|     "gitlabSourceNote": "GitLabのAPK抽出はAPIキーがないと動作しない場合があります。", |     "gitlabSourceNote": "GitLabのAPK抽出はAPIキーがないと動作しない場合があります。", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "アプリを削除しますか?", |         "one": "アプリを削除しますか?", | ||||||
|         "other": "アプリを削除しますか?" |         "other": "アプリを削除しますか?" | ||||||
|   | |||||||
| @@ -248,6 +248,7 @@ | |||||||
|     "addInfoInSettings": "Dodaj tę informację w Ustawieniach.", |     "addInfoInSettings": "Dodaj tę informację w Ustawieniach.", | ||||||
|     "githubSourceNote": "Limit żądań GitHub można ominąć za pomocą klucza API.", |     "githubSourceNote": "Limit żądań GitHub można ominąć za pomocą klucza API.", | ||||||
|     "gitlabSourceNote": "Pozyskiwanie pliku APK z GitLab może nie działać bez klucza API.", |     "gitlabSourceNote": "Pozyskiwanie pliku APK z GitLab może nie działać bez klucza API.", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Usunąć aplikację?", |         "one": "Usunąć aplikację?", | ||||||
|         "other": "Usunąć aplikacje?" |         "other": "Usunąć aplikacje?" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "Добавьте эту информацию в Настройки.", |     "addInfoInSettings": "Добавьте эту информацию в Настройки.", | ||||||
|     "githubSourceNote": "Лимит запросов GitHub можно обойти, используя ключ API.", |     "githubSourceNote": "Лимит запросов GitHub можно обойти, используя ключ API.", | ||||||
|     "gitlabSourceNote": "Извлечение APK из GitLab может не работать без ключа API.", |     "gitlabSourceNote": "Извлечение APK из GitLab может не работать без ключа API.", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "Удалить приложение?", |         "one": "Удалить приложение?", | ||||||
|         "other": "Удалить приложения?" |         "other": "Удалить приложения?" | ||||||
|   | |||||||
| @@ -244,6 +244,7 @@ | |||||||
|     "addInfoInSettings": "在“设置”中添加此凭据。", |     "addInfoInSettings": "在“设置”中添加此凭据。", | ||||||
|     "githubSourceNote": "使用访问令牌可避免触发 GitHub 的 API 请求限制。", |     "githubSourceNote": "使用访问令牌可避免触发 GitHub 的 API 请求限制。", | ||||||
|     "gitlabSourceNote": "未使用访问令牌时可能无法从 GitLab 获取 APK 文件。", |     "gitlabSourceNote": "未使用访问令牌时可能无法从 GitLab 获取 APK 文件。", | ||||||
|  |     "sortByFileNamesNotLinks": "Sort by file names instead of full links", | ||||||
|     "removeAppQuestion": { |     "removeAppQuestion": { | ||||||
|         "one": "是否删除应用?", |         "one": "是否删除应用?", | ||||||
|         "other": "是否删除应用?" |         "other": "是否删除应用?" | ||||||
|   | |||||||
| @@ -1,6 +1,7 @@ | |||||||
| import 'package:easy_localization/easy_localization.dart'; | import 'package:easy_localization/easy_localization.dart'; | ||||||
| import 'package:html/parser.dart'; | import 'package:html/parser.dart'; | ||||||
| import 'package:http/http.dart'; | import 'package:http/http.dart'; | ||||||
|  | import 'package:obtainium/components/generated_form.dart'; | ||||||
| import 'package:obtainium/custom_errors.dart'; | import 'package:obtainium/custom_errors.dart'; | ||||||
| import 'package:obtainium/providers/source_provider.dart'; | import 'package:obtainium/providers/source_provider.dart'; | ||||||
|  |  | ||||||
| @@ -85,6 +86,15 @@ bool _isNumeric(String s) { | |||||||
| } | } | ||||||
|  |  | ||||||
| class HTML extends AppSource { | class HTML extends AppSource { | ||||||
|  |   HTML() { | ||||||
|  |     additionalSourceAppSpecificSettingFormItems = [ | ||||||
|  |       [ | ||||||
|  |         GeneratedFormSwitch('sortByFileNamesNotLinks', | ||||||
|  |             label: tr('sortByFileNamesNotLinks')) | ||||||
|  |       ] | ||||||
|  |     ]; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   @override |   @override | ||||||
|   // TODO: implement requestHeaders choice, hardcoded for now |   // TODO: implement requestHeaders choice, hardcoded for now | ||||||
|   Map<String, String>? get requestHeaders => { |   Map<String, String>? get requestHeaders => { | ||||||
| @@ -111,7 +121,9 @@ class HTML extends AppSource { | |||||||
|           .where((element) => |           .where((element) => | ||||||
|               Uri.parse(element).path.toLowerCase().endsWith('.apk')) |               Uri.parse(element).path.toLowerCase().endsWith('.apk')) | ||||||
|           .toList(); |           .toList(); | ||||||
|       links.sort((a, b) => compareAlphaNumeric(a, b)); |       links.sort((a, b) => additionalSettings['sortByFileNamesNotLinks'] == true | ||||||
|  |           ? compareAlphaNumeric(a.split('/').last, b.split('/').last) | ||||||
|  |           : compareAlphaNumeric(a, b)); | ||||||
|       if (additionalSettings['apkFilterRegEx'] != null) { |       if (additionalSettings['apkFilterRegEx'] != null) { | ||||||
|         var reg = RegExp(additionalSettings['apkFilterRegEx']); |         var reg = RegExp(additionalSettings['apkFilterRegEx']); | ||||||
|         links = links.where((element) => reg.hasMatch(element)).toList(); |         links = links.where((element) => reg.hasMatch(element)).toList(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user