mirror of
https://github.com/ImranR98/Obtainium.git
synced 2025-08-19 13:09:30 +02:00
Compare commits
8 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
0fd496e660 | ||
|
b3af899ba1 | ||
|
9a58643088 | ||
|
b223522801 | ||
|
375caa4511 | ||
|
92ebbd9138 | ||
|
a3c2761aba | ||
|
68e38259bd |
@@ -28,11 +28,11 @@
|
||||
"githubStarredRepos": "Csillagozott GitHub tárolók",
|
||||
"uname": "Felhasználónév",
|
||||
"wrongArgNum": "A megadott argumentumok száma nem megfelelő",
|
||||
"xIsTrackOnly": "A(z) {} csak nyomonkövethető",
|
||||
"xIsTrackOnly": "A(z) {} csak nyomon-követhető",
|
||||
"source": "Forrás",
|
||||
"app": "Alkalmazás",
|
||||
"appsFromSourceAreTrackOnly": "Az ebből a forrásból származó alkalmazások „csak nyomonkövethetők”.",
|
||||
"youPickedTrackOnly": "„Csak nyomonkövetés” opciót választotta.",
|
||||
"appsFromSourceAreTrackOnly": "Az ebből a forrásból származó alkalmazások „csak nyomon-követhetők”.",
|
||||
"youPickedTrackOnly": "„Csak nyomon-követés” opciót választotta.",
|
||||
"trackOnlyAppDescription": "Az alkalmazás frissítéseit nyomon követi, de az Obtainium nem tudja letölteni vagy telepíteni.",
|
||||
"cancelled": "Visszavonva",
|
||||
"appAlreadyAdded": "Az alkalmazás már hozzá van adva",
|
||||
@@ -45,7 +45,7 @@
|
||||
"search": "Keresés",
|
||||
"additionalOptsFor": "További lehetőségek a következőhöz: {}",
|
||||
"supportedSources": "Támogatott források",
|
||||
"trackOnlyInBrackets": "(Csak nyomonkövetés)",
|
||||
"trackOnlyInBrackets": "(Csak nyomon-követés)",
|
||||
"searchableInBrackets": "(Kereshető)",
|
||||
"appsString": "Alkalmazások",
|
||||
"noApps": "Nincsenek alkalmazások",
|
||||
@@ -63,7 +63,7 @@
|
||||
"removeSelectedApps": "A kiválasztott alkalmazások eltávolítása",
|
||||
"updateX": "{} frissítése",
|
||||
"installX": "{} telepítése",
|
||||
"markXTrackOnlyAsUpdated": "Megjelölés: {}\n(Csak nyomonkövetés)\nFrissítettként",
|
||||
"markXTrackOnlyAsUpdated": "Megjelölés: {}\n(Csak nyomon-követés)\nFrissítettként",
|
||||
"changeX": "{}-változás",
|
||||
"installUpdateApps": "Alkalmazások telepítése/frissítése",
|
||||
"installUpdateSelectedApps": "A kiválasztott alkalmazások telepítése/frissítése",
|
||||
@@ -88,13 +88,13 @@
|
||||
"author": "Szerző",
|
||||
"upToDateApps": "Naprakész alkalmazások",
|
||||
"nonInstalledApps": "Nem telepített alkalmazások",
|
||||
"importExport": "Import/Export",
|
||||
"importExport": "Adatmozgatás",
|
||||
"settings": "Beállítások",
|
||||
"exportedTo": "Exportálva ide: {}",
|
||||
"obtainiumExport": "Obtainium adatok exportálása",
|
||||
"obtainiumExport": "Obtainium-adatok exportálása",
|
||||
"invalidInput": "Hibás bemenet",
|
||||
"importedX": "Importálva innen: {}",
|
||||
"obtainiumImport": "Obtainium adatok importálása",
|
||||
"obtainiumImport": "Obtainium-adatok importálása",
|
||||
"importFromURLList": "Importálás webcímlistából",
|
||||
"searchQuery": "Keresési lekérdezés",
|
||||
"appURLList": "Alkalmazás-webcímlista",
|
||||
@@ -143,7 +143,7 @@
|
||||
"warning": "Figyelem",
|
||||
"sourceIsXButPackageFromYPrompt": "Az alkalmazás forrása a(z) „{}” tároló, de a kiadási csomag innen származik: „{}”. Folytatja?",
|
||||
"updatesAvailable": "Frissítések érhetők el",
|
||||
"updatesAvailableNotifDescription": "Értesíti a felhasználót, hogy egy vagy több, az Obtainium által nyomonkövetett alkalmazáshoz frissítések állnak rendelkezésre",
|
||||
"updatesAvailableNotifDescription": "Értesíti a felhasználót, hogy egy vagy több, az Obtainium által nyomon-követett alkalmazáshoz frissítések állnak rendelkezésre",
|
||||
"noNewUpdates": "Nincsenek új frissítések.",
|
||||
"xHasAnUpdate": "A(z) {} frissítést kapott.",
|
||||
"appsUpdated": "Alkalmazások frissítve",
|
||||
@@ -154,15 +154,15 @@
|
||||
"errorCheckingUpdates": "Hiba a frissítések ellenőrzésekor",
|
||||
"errorCheckingUpdatesNotifDescription": "Értesítés, amely akkor jelenik meg, amikor a frissítések ellenőrzése a háttérben nem sikerül",
|
||||
"appsRemoved": "Alkalmazások eltávolítva",
|
||||
"appsRemovedNotifDescription": "Értesíti a felhasználót, hogy egy vagy több alkalmazás betöltés közbeni hiba miatt eltávolításra került",
|
||||
"xWasRemovedDueToErrorY": "A(z) {} eltávolításra került a következő hiba miatt: {}",
|
||||
"appsRemovedNotifDescription": "Értesíti a felhasználót, hogy egy vagy több alkalmazás egy betöltés közbeni hiba miatt el lesz(nek) távolítva",
|
||||
"xWasRemovedDueToErrorY": "A(z) {} el lett távolítva a következő hiba miatt: {}",
|
||||
"completeAppInstallation": "Teljes alkalmazástelepítés",
|
||||
"obtainiumMustBeOpenToInstallApps": "Az alkalmazások telepítéséhez az Obtainiumnak megnyitva kell lennie",
|
||||
"completeAppInstallationNotifDescription": "Megkéri a felhasználót, hogy térjen vissza az Obtainiumhoz, hogy befejezze az alkalmazás telepítését",
|
||||
"checkingForUpdates": "Frissítések ellenőrzése",
|
||||
"checkingForUpdatesNotifDescription": "Átmeneti értesítés, amely a frissítések ellenőrzésekor jelenik meg",
|
||||
"pleaseAllowInstallPerm": "Engedélyezze az Obtainiumnak az alkalmazások telepítését",
|
||||
"trackOnly": "Csak nyomonkövetés",
|
||||
"trackOnly": "Csak nyomon-követés",
|
||||
"errorWithHttpStatusCode": "Hiba {}",
|
||||
"versionCorrectionDisabled": "Verzió-korrekció letiltva (úgy tűnik, hogy a bővítmény nem működik)",
|
||||
"unknown": "Ismeretlen",
|
||||
@@ -223,7 +223,7 @@
|
||||
"autoApkFilterByArch": "Ha lehetséges, próbálja CPU architektúra szerint szűrni az APK-kat",
|
||||
"overrideSource": "Forrás felülírása",
|
||||
"dontShowAgain": "Ne jelenítse meg ezt többé",
|
||||
"dontShowTrackOnlyWarnings": "Ne jelenítse meg a „Csak nyomonkövetés” figyelmeztetést",
|
||||
"dontShowTrackOnlyWarnings": "Ne jelenítse meg a „Csak nyomon-követés” figyelmeztetést",
|
||||
"dontShowAPKOriginWarnings": "Ne jelenítse meg az APK eredetére vonatkozó figyelmeztetéseket",
|
||||
"moveNonInstalledAppsToBottom": "Helyezze át a nem telepített alkalmazásokat az alkalmazásnézet aljára",
|
||||
"gitlabPATLabel": "GitLab személyes hozzáférési token",
|
||||
@@ -261,7 +261,7 @@
|
||||
"versionExtractionRegEx": "Verzió-karakterlánc kivonatolása reguláris kifejezéssel",
|
||||
"trimVersionString": "Verzió-karakterlánc levágása reguláris kifejezéssel",
|
||||
"matchGroupToUseForX": "A(z) „{}” esetén használandó csoport egyeztetése",
|
||||
"matchGroupToUse": "Verziókarakterlánc-kivonatoláshoz használandó csoport reguláris kifejezéssel való egyeztetése",
|
||||
"matchGroupToUse": "A verzió-karakterlánc kivonatolásához használandó csoport reguláris kifejezéssel való egyeztetése",
|
||||
"highlightTouchTargets": "A kevésbé nyilvánvaló érintési pontok kiemelése",
|
||||
"pickExportDir": "Válassza ki a könyvtárat, ahová exportálni szeretne",
|
||||
"autoExportOnChanges": "Automatikus exportálás a változtatások után",
|
||||
@@ -286,7 +286,7 @@
|
||||
"downloadingXNotifChannel": "A(z) {} letöltése",
|
||||
"completeAppInstallationNotifChannel": "Teljes alkalmazás telepítés",
|
||||
"checkingForUpdatesNotifChannel": "Frissítések ellenőrzése",
|
||||
"onlyCheckInstalledOrTrackOnlyApps": "Csak a telepített és a csak nyomonkövethető alkalmazások frissítéseinek ellenőrzése",
|
||||
"onlyCheckInstalledOrTrackOnlyApps": "Csak a telepített és a csak nyomon-követhető alkalmazások frissítéseinek ellenőrzése",
|
||||
"supportFixedAPKURL": "Támogatja a rögzített APK webcímeket",
|
||||
"selectX": "{} kiválasztása",
|
||||
"parallelDownloads": "Párhuzamos letöltések engedélyezése",
|
||||
@@ -318,7 +318,7 @@
|
||||
"allowInsecure": "Nem biztonságos HTTP-kérések engedélyezése",
|
||||
"stayOneVersionBehind": "Maradjon egy verzióval a legújabb mögött",
|
||||
"refreshBeforeDownload": "Az alkalmazás adatainak frissítése a letöltés előtt",
|
||||
"tencentAppStore": "Tencent App Store",
|
||||
"tencentAppStore": "Tencent Appstore",
|
||||
"removeAppQuestion": {
|
||||
"one": "Eltávolítja az alkalmazást?",
|
||||
"other": "Eltávolítja az alkalmazásokat?"
|
||||
|
@@ -58,7 +58,7 @@ class GitLab extends AppSource {
|
||||
url =
|
||||
urlSegments.sublist(0, cutOffIndex <= 0 ? null : cutOffIndex).join('/');
|
||||
RegExp standardUrlRegEx = RegExp(
|
||||
'^https?://(www\\.)?${getSourceRegex(hosts)}/[^/]+(/[^/-]+){1,20}',
|
||||
'^https?://(www\\.)?${getSourceRegex(hosts)}/[^/]+(/[^((\b/\b)|(\b/-/\b))]+){1,20}',
|
||||
caseSensitive: false);
|
||||
RegExpMatch? match = standardUrlRegEx.firstMatch(url);
|
||||
if (match == null) {
|
||||
|
@@ -313,7 +313,7 @@ class HTML extends AppSource {
|
||||
await sourceRequest(currentUrl, additionalSettings),
|
||||
additionalSettings['intermediateLink'][i]);
|
||||
if (intLinks.isEmpty) {
|
||||
throw NoReleasesError();
|
||||
throw NoReleasesError(note: currentUrl);
|
||||
} else {
|
||||
currentUrl = intLinks.last.key;
|
||||
}
|
||||
@@ -329,7 +329,7 @@ class HTML extends AppSource {
|
||||
links = filterApks(links, additionalSettings['apkFilterRegEx'],
|
||||
additionalSettings['invertAPKFilter']);
|
||||
if (links.isEmpty) {
|
||||
throw NoReleasesError();
|
||||
throw NoReleasesError(note: currentUrl);
|
||||
}
|
||||
} else {
|
||||
links = [MapEntry(currentUrl, currentUrl)];
|
||||
|
@@ -300,7 +300,7 @@ class _AppPageState extends State<AppPage> {
|
||||
? Theme.of(context).textTheme.displaySmall
|
||||
: Theme.of(context).textTheme.displayLarge,
|
||||
),
|
||||
Text(tr('byX', args: [app?.app.author ?? tr('unknown')]),
|
||||
Text(tr('byX', args: [app?.author ?? tr('unknown')]),
|
||||
textAlign: TextAlign.center,
|
||||
style: small
|
||||
? Theme.of(context).textTheme.headlineSmall
|
||||
|
@@ -216,7 +216,7 @@ class AppsPageState extends State<AppsPage> {
|
||||
}
|
||||
}
|
||||
for (var t in authorTokens) {
|
||||
if (!app.app.author.toLowerCase().contains(t.toLowerCase())) {
|
||||
if (!app.author.toLowerCase().contains(t.toLowerCase())) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
@@ -247,11 +247,11 @@ class AppsPageState extends State<AppsPage> {
|
||||
listedApps.sort((a, b) {
|
||||
int result = 0;
|
||||
if (settingsProvider.sortColumn == SortColumnSettings.authorName) {
|
||||
result = ((a.app.author + a.name).toLowerCase())
|
||||
.compareTo((b.app.author + b.name).toLowerCase());
|
||||
result = ((a.author + a.name).toLowerCase())
|
||||
.compareTo((b.author + b.name).toLowerCase());
|
||||
} else if (settingsProvider.sortColumn == SortColumnSettings.nameAuthor) {
|
||||
result = ((a.name + a.app.author).toLowerCase())
|
||||
.compareTo((b.name + b.app.author).toLowerCase());
|
||||
result = ((a.name + a.author).toLowerCase())
|
||||
.compareTo((b.name + b.author).toLowerCase());
|
||||
} else if (settingsProvider.sortColumn ==
|
||||
SortColumnSettings.releaseDate) {
|
||||
result = (a.app.releaseDate)?.compareTo(
|
||||
@@ -570,7 +570,7 @@ class AppsPageState extends State<AppsPage> {
|
||||
: FontWeight.normal,
|
||||
),
|
||||
),
|
||||
subtitle: Text(tr('byX', args: [listedApps[index].app.author]),
|
||||
subtitle: Text(tr('byX', args: [listedApps[index].author]),
|
||||
maxLines: 1,
|
||||
style: TextStyle(
|
||||
overflow: TextOverflow.ellipsis,
|
||||
|
@@ -53,6 +53,7 @@ class AppInMemory {
|
||||
AppInMemory(app.deepCopy(), downloadProgress, installedInfo, icon);
|
||||
|
||||
String get name => app.overrideName ?? app.finalName;
|
||||
String get author => app.overrideAuthor ?? app.finalAuthor;
|
||||
}
|
||||
|
||||
class DownloadedApk {
|
||||
|
@@ -330,6 +330,15 @@ class App {
|
||||
return overrideName ?? name;
|
||||
}
|
||||
|
||||
String? get overrideAuthor =>
|
||||
additionalSettings['appAuthor']?.toString().trim().isNotEmpty == true
|
||||
? additionalSettings['appAuthor']
|
||||
: null;
|
||||
|
||||
String get finalAuthor {
|
||||
return overrideAuthor ?? author;
|
||||
}
|
||||
|
||||
App deepCopy() => App(
|
||||
id,
|
||||
url,
|
||||
@@ -622,6 +631,7 @@ abstract class AppSource {
|
||||
label: tr('autoApkFilterByArch'), defaultValue: true)
|
||||
],
|
||||
[GeneratedFormTextField('appName', label: tr('appName'), required: false)],
|
||||
[GeneratedFormTextField('appAuthor', label: tr('author'), required: false)],
|
||||
[
|
||||
GeneratedFormSwitch('shizukuPretendToBeGooglePlay',
|
||||
label: tr('shizukuPretendToBeGooglePlay'), defaultValue: false)
|
||||
|
@@ -80,10 +80,10 @@ packages:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: archive
|
||||
sha256: "6199c74e3db4fbfbd04f66d739e72fe11c8a8957d5f219f1f4482dbde6420b5a"
|
||||
sha256: "528579c7e4579719f04b21eeeeddfd73a18b31dabc22766893b7d1be7f49b967"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "4.0.2"
|
||||
version: "4.0.3"
|
||||
args:
|
||||
dependency: transitive
|
||||
description:
|
||||
@@ -580,10 +580,10 @@ packages:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: image
|
||||
sha256: "8346ad4b5173924b5ddddab782fc7d8a6300178c8b1dc427775405a01701c4a6"
|
||||
sha256: "13d3349ace88f12f4a0d175eb5c12dcdd39d35c4c109a8a13dfeb6d0bd9e31c3"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "4.5.2"
|
||||
version: "4.5.3"
|
||||
intl:
|
||||
dependency: transitive
|
||||
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
|
||||
# In Windows, build-name is used as the major, minor, and patch parts
|
||||
# of the product and file versions while build-number is used as the build suffix.
|
||||
version: 1.1.44+2301
|
||||
version: 1.1.45+2302
|
||||
|
||||
environment:
|
||||
sdk: ^3.6.0
|
||||
|
Reference in New Issue
Block a user