mirror of
https://github.com/ImranR98/Obtainium.git
synced 2025-10-23 19:03:46 +02:00
Compare commits
34 Commits
v1.1.53
...
c45aaff610
Author | SHA1 | Date | |
---|---|---|---|
|
c45aaff610 | ||
|
bd32a10de7 | ||
|
ef83be07cd | ||
|
9fe33737eb | ||
|
51c7acf466 | ||
|
d8490c289d | ||
|
1d73d4dcbb | ||
|
6d28d15d4f | ||
|
3890785fc7 | ||
|
38d34c810b | ||
|
b2d6752b80 | ||
|
47a6e0dc7c | ||
|
5b6299496f | ||
|
369127806f | ||
|
ee9b0e710c | ||
|
6e0819b0a7 | ||
|
d8c9cd6579 | ||
|
ae2dad01ff | ||
|
3345b26fa9 | ||
|
99e3b8ac4f | ||
|
7d01141db5 | ||
|
195c0d1f11 | ||
|
6b8bb095d4 | ||
|
fd9bf721d4 | ||
|
1a058a1959 | ||
|
f78beff5d8 | ||
|
39757a3416 | ||
|
e7ff0bb2cb | ||
|
b1bd488f22 | ||
|
8201348995 | ||
|
c1ddc57126 | ||
|
b41b9d3109 | ||
|
add2574c25 | ||
|
d9c29c6751 |
15
.dockerignore
Normal file
15
.dockerignore
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
LICENSE.md
|
||||||
|
README.md
|
||||||
|
analysis_options.yaml
|
||||||
|
android
|
||||||
|
assets
|
||||||
|
build
|
||||||
|
build.sh
|
||||||
|
data
|
||||||
|
docker
|
||||||
|
fastlane
|
||||||
|
lib
|
||||||
|
pubspec.lock
|
||||||
|
pubspec.yaml
|
||||||
|
sign.sh
|
||||||
|
test
|
1
.gitignore
vendored
1
.gitignore
vendored
@@ -49,3 +49,4 @@ app.*.map.json
|
|||||||
|
|
||||||
# Custom
|
# Custom
|
||||||
TODO.txt
|
TODO.txt
|
||||||
|
data
|
@@ -19,7 +19,7 @@ pluginManagement {
|
|||||||
plugins {
|
plugins {
|
||||||
id "dev.flutter.flutter-plugin-loader" version "1.0.0"
|
id "dev.flutter.flutter-plugin-loader" version "1.0.0"
|
||||||
id "com.android.application" version "8.1.0" apply false
|
id "com.android.application" version "8.1.0" apply false
|
||||||
id "org.jetbrains.kotlin.android" version "1.8.22" apply false
|
id "org.jetbrains.kotlin.android" version "2.1.21" apply false
|
||||||
}
|
}
|
||||||
|
|
||||||
include ":app"
|
include ":app"
|
||||||
|
392
assets/translations/ar.json
Normal file
392
assets/translations/ar.json
Normal file
@@ -0,0 +1,392 @@
|
|||||||
|
{
|
||||||
|
"invalidURLForSource": "رابط تطبيق {} غير صالح",
|
||||||
|
"noReleaseFound": "تعذر العثور على إصدار مناسب",
|
||||||
|
"noVersionFound": "تعذر تحديد إصدار التطبيق",
|
||||||
|
"urlMatchesNoSource": "الرابط لا يتطابق مع مصدر معروف",
|
||||||
|
"cantInstallOlderVersion": "لا يمكن تثبيت إصدار أقدم من التطبيق",
|
||||||
|
"appIdMismatch": "معرّف الحزمة المحملة لا يتطابق مع معرّف التطبيق الحالي",
|
||||||
|
"functionNotImplemented": "هذه الوظيفة غير مطبقة في هذا الصنف",
|
||||||
|
"placeholder": "عنصر نائب",
|
||||||
|
"someErrors": "حدثت بعض الأخطاء",
|
||||||
|
"unexpectedError": "خطأ غير متوقع",
|
||||||
|
"ok": "موافق",
|
||||||
|
"and": "و",
|
||||||
|
"githubPATLabel": "رمز الوصول الشخصي لـ GitHub (يزيد من الحد المسموح)",
|
||||||
|
"includePrereleases": "تضمين الإصدارات الأولية",
|
||||||
|
"fallbackToOlderReleases": "الرجوع إلى الإصدارات الأقدم",
|
||||||
|
"filterReleaseTitlesByRegEx": "تصفية عناوين الإصدارات باستخدام تعبير نمطي",
|
||||||
|
"invalidRegEx": "تعبير نمطي غير صالح",
|
||||||
|
"noDescription": "لا يوجد وصف",
|
||||||
|
"cancel": "إلغاء",
|
||||||
|
"continue": "متابعة",
|
||||||
|
"requiredInBrackets": "(مطلوب)",
|
||||||
|
"dropdownNoOptsError": "خطأ: يجب أن يحتوي القائمة المنسدلة على خيار واحد على الأقل",
|
||||||
|
"colour": "لون",
|
||||||
|
"standard": "قياسي",
|
||||||
|
"custom": "مخصص",
|
||||||
|
"useMaterialYou": "استخدم Material You",
|
||||||
|
"githubStarredRepos": "مستودعات GitHub المفضلة",
|
||||||
|
"uname": "اسم المستخدم",
|
||||||
|
"wrongArgNum": "عدد وسائط غير صحيح",
|
||||||
|
"xIsTrackOnly": "{} للتعقب فقط",
|
||||||
|
"source": "المصدر",
|
||||||
|
"app": "التطبيق",
|
||||||
|
"appsFromSourceAreTrackOnly": "تطبيقات هذا المصدر للتعقب فقط.",
|
||||||
|
"youPickedTrackOnly": "لقد اخترت خيار 'التعقب فقط'.",
|
||||||
|
"trackOnlyAppDescription": "سيتم تعقب التطبيق للتحديثات، لكن Obtainium لن يتمكن من تنزيله أو تثبيته.",
|
||||||
|
"cancelled": "تم الإلغاء",
|
||||||
|
"appAlreadyAdded": "التطبيق مضاف بالفعل",
|
||||||
|
"alreadyUpToDateQuestion": "التطبيق محدث بالفعل؟",
|
||||||
|
"addApp": "إضافة تطبيق",
|
||||||
|
"appSourceURL": "رابط مصدر التطبيق",
|
||||||
|
"error": "خطأ",
|
||||||
|
"add": "إضافة",
|
||||||
|
"searchSomeSourcesLabel": "بحث (بعض المصادر فقط)",
|
||||||
|
"search": "بحث",
|
||||||
|
"additionalOptsFor": "خيارات إضافية لـ {}",
|
||||||
|
"supportedSources": "المصادر المدعومة",
|
||||||
|
"trackOnlyInBrackets": "(للتعقب فقط)",
|
||||||
|
"searchableInBrackets": "(قابل للبحث)",
|
||||||
|
"appsString": "التطبيقات",
|
||||||
|
"noApps": "لا توجد تطبيقات",
|
||||||
|
"noAppsForFilter": "لا توجد تطبيقات تطابق الفلتر",
|
||||||
|
"byX": "بواسطة {}",
|
||||||
|
"percentProgress": "التقدم: {}%",
|
||||||
|
"pleaseWait": "يرجى الانتظار",
|
||||||
|
"updateAvailable": "تحديث متاح",
|
||||||
|
"notInstalled": "غير مثبت",
|
||||||
|
"pseudoVersion": "إصدار وهمي",
|
||||||
|
"selectAll": "تحديد الكل",
|
||||||
|
"deselectX": "إلغاء تحديد {}",
|
||||||
|
"xWillBeRemovedButRemainInstalled": "سيتم إزالة {} من Obtainium لكنه سيظل مثبتًا على الجهاز.",
|
||||||
|
"removeSelectedAppsQuestion": "إزالة التطبيقات المحددة؟",
|
||||||
|
"removeSelectedApps": "إزالة التطبيقات المحددة",
|
||||||
|
"updateX": "تحديث {}",
|
||||||
|
"installX": "تثبيت {}",
|
||||||
|
"markXTrackOnlyAsUpdated": "تعليم {}\n(للتعقب فقط)\nكمحدث",
|
||||||
|
"changeX": "تغيير {}",
|
||||||
|
"installUpdateApps": "تثبيت/تحديث التطبيقات",
|
||||||
|
"installUpdateSelectedApps": "تثبيت/تحديث التطبيقات المحددة",
|
||||||
|
"markXSelectedAppsAsUpdated": "تعليم {} تطبيقات محددة كمحدثة؟",
|
||||||
|
"no": "لا",
|
||||||
|
"yes": "نعم",
|
||||||
|
"markSelectedAppsUpdated": "تعليم التطبيقات المحددة كمحدثة",
|
||||||
|
"pinToTop": "تثبيت في الأعلى",
|
||||||
|
"unpinFromTop": "إلغاء التثبيت من الأعلى",
|
||||||
|
"resetInstallStatusForSelectedAppsQuestion": "إعادة تعيين حالة التثبيت للتطبيقات المحددة؟",
|
||||||
|
"installStatusOfXWillBeResetExplanation": "سيتم إعادة تعيين حالة التثبيت لأي تطبيقات محددة.\n\nقد يساعد هذا عندما يكون إصدار التطبيق المعروض في Obtainium غير صحيح بسبب فشل التحديثات أو مشاكل أخرى.",
|
||||||
|
"customLinkMessage": "هذه الروابط تعمل على الأجهزة التي بها Obtainium مثبتًا",
|
||||||
|
"shareAppConfigLinks": "مشاركة تكوين التطبيق كرابط HTML",
|
||||||
|
"shareSelectedAppURLs": "مشاركة روابط التطبيقات المحددة",
|
||||||
|
"resetInstallStatus": "إعادة تعيين حالة التثبيت",
|
||||||
|
"more": "المزيد",
|
||||||
|
"removeOutdatedFilter": "إزالة فلتر التطبيقات غير المحدثة",
|
||||||
|
"showOutdatedOnly": "عرض التطبيقات غير المحدثة فقط",
|
||||||
|
"filter": "تصفية",
|
||||||
|
"filterApps": "تصفية التطبيقات",
|
||||||
|
"appName": "اسم التطبيق",
|
||||||
|
"author": "المؤلف",
|
||||||
|
"upToDateApps": "تطبيقات محدثة",
|
||||||
|
"nonInstalledApps": "تطبيقات غير مثبتة",
|
||||||
|
"importExport": "استيراد/تصدير",
|
||||||
|
"settings": "الإعدادات",
|
||||||
|
"exportedTo": "تم التصدير إلى {}",
|
||||||
|
"obtainiumExport": "تصدير Obtainium",
|
||||||
|
"invalidInput": "إدخال غير صالح",
|
||||||
|
"importedX": "تم استيراد {}",
|
||||||
|
"obtainiumImport": "استيراد Obtainium",
|
||||||
|
"importFromURLList": "استيراد من قائمة الروابط",
|
||||||
|
"searchQuery": "استعلام البحث",
|
||||||
|
"appURLList": "قائمة روابط التطبيقات",
|
||||||
|
"line": "سطر",
|
||||||
|
"searchX": "بحث {}",
|
||||||
|
"noResults": "لا توجد نتائج",
|
||||||
|
"importX": "استيراد {}",
|
||||||
|
"importedAppsIdDisclaimer": "قد تظهر التطبيقات المستوردة بشكل غير صحيح كـ \"غير مثبتة\".\nلإصلاح هذا، قم بإعادة تثبيتها عبر Obtainium.\nهذا لا يؤثر على بيانات التطبيق.\n\nينطبق فقط على طرق الاستيراد عبر الروابط أو الطرف الثالث.",
|
||||||
|
"importErrors": "أخطاء الاستيراد",
|
||||||
|
"importedXOfYApps": "تم استيراد {} من {} تطبيقات.",
|
||||||
|
"followingURLsHadErrors": "حدثت أخطاء في الروابط التالية:",
|
||||||
|
"selectURL": "اختر رابطًا",
|
||||||
|
"selectURLs": "اختر روابط",
|
||||||
|
"pick": "اختر",
|
||||||
|
"theme": "المظهر",
|
||||||
|
"dark": "مظلم",
|
||||||
|
"light": "فاتح",
|
||||||
|
"followSystem": "اتباع النظام",
|
||||||
|
"followSystemThemeExplanation": "اتباع مظهر النظام ممكن فقط باستخدام تطبيقات طرف ثالث",
|
||||||
|
"useBlackTheme": "استخدام المظهر الأسود الداكن بالكامل",
|
||||||
|
"appSortBy": "ترتيب التطبيقات حسب",
|
||||||
|
"authorName": "المؤلف/الاسم",
|
||||||
|
"nameAuthor": "الاسم/المؤلف",
|
||||||
|
"asAdded": "كما تمت إضافتها",
|
||||||
|
"appSortOrder": "ترتيب التطبيقات",
|
||||||
|
"ascending": "تصاعدي",
|
||||||
|
"descending": "تنازلي",
|
||||||
|
"bgUpdateCheckInterval": "فترة التحقق من التحديثات في الخلفية",
|
||||||
|
"neverManualOnly": "أبدًا - يدوي فقط",
|
||||||
|
"appearance": "المظهر",
|
||||||
|
"showWebInAppView": "عرض صفحة الويب المصدر في عرض التطبيق",
|
||||||
|
"pinUpdates": "تثبيت التحديثات في أعلى قائمة التطبيقات",
|
||||||
|
"updates": "التحديثات",
|
||||||
|
"sourceSpecific": "خاص بالمصدر",
|
||||||
|
"appSource": "مصدر التطبيق",
|
||||||
|
"noLogs": "لا توجد سجلات",
|
||||||
|
"appLogs": "سجلات التطبيق",
|
||||||
|
"close": "إغلاق",
|
||||||
|
"share": "مشاركة",
|
||||||
|
"appNotFound": "التطبيق غير موجود",
|
||||||
|
"obtainiumExportHyphenatedLowercase": "تصدير-obtainium",
|
||||||
|
"pickAnAPK": "اختر ملف APK",
|
||||||
|
"appHasMoreThanOnePackage": "{} يحتوي على أكثر من حزمة:",
|
||||||
|
"deviceSupportsXArch": "جهازك يدعم بنية المعالج {}.",
|
||||||
|
"deviceSupportsFollowingArchs": "جهازك يدعم بنى المعالج التالية:",
|
||||||
|
"warning": "تحذير",
|
||||||
|
"sourceIsXButPackageFromYPrompt": "مصدر التطبيق هو '{}' لكن الحزمة تأتي من '{}'. هل تتابع؟",
|
||||||
|
"updatesAvailable": "تحديثات متاحة",
|
||||||
|
"updatesAvailableNotifDescription": "يخطر المستخدم بوجود تحديثات لواحد أو أكثر من التطبيقات التي يتعقبها Obtainium",
|
||||||
|
"noNewUpdates": "لا توجد تحديثات جديدة.",
|
||||||
|
"xHasAnUpdate": "{} لديه تحديث.",
|
||||||
|
"appsUpdated": "تم تحديث التطبيقات",
|
||||||
|
"appsNotUpdated": "فشل تحديث التطبيقات",
|
||||||
|
"appsUpdatedNotifDescription": "يخطر المستخدم بأن تحديثات لواحد أو أكثر من التطبيقات تم تطبيقها في الخلفية",
|
||||||
|
"xWasUpdatedToY": "تم تحديث {} إلى {}.",
|
||||||
|
"xWasNotUpdatedToY": "فشل تحديث {} إلى {}.",
|
||||||
|
"errorCheckingUpdates": "خطأ في التحقق من التحديثات",
|
||||||
|
"errorCheckingUpdatesNotifDescription": "إشعار يظهر عند فشل التحقق من التحديثات في الخلفية",
|
||||||
|
"appsRemoved": "تمت إزالة التطبيقات",
|
||||||
|
"appsRemovedNotifDescription": "يخطر المستخدم بأنه تمت إزالة واحد أو أكثر من التطبيقات بسبب أخطاء أثناء تحميلها",
|
||||||
|
"xWasRemovedDueToErrorY": "تمت إزالة {} بسبب هذا الخطأ: {}",
|
||||||
|
"completeAppInstallation": "إكمال تثبيت التطبيق",
|
||||||
|
"obtainiumMustBeOpenToInstallApps": "يجب فتح Obtainium لتثبيت التطبيقات",
|
||||||
|
"completeAppInstallationNotifDescription": "يطلب من المستخدم العودة إلى Obtainium لإكمال تثبيت التطبيق",
|
||||||
|
"checkingForUpdates": "جاري التحقق من التحديثات",
|
||||||
|
"checkingForUpdatesNotifDescription": "إشعار مؤقت يظهر عند التحقق من التحديثات",
|
||||||
|
"pleaseAllowInstallPerm": "يرجى السماح لـ Obtainium بتثبيت التطبيقات",
|
||||||
|
"trackOnly": "للتعقب فقط",
|
||||||
|
"errorWithHttpStatusCode": "خطأ {}",
|
||||||
|
"versionCorrectionDisabled": "تعطيل تصحيح الإصدار (يبدو أن الملحق لا يعمل)",
|
||||||
|
"unknown": "غير معروف",
|
||||||
|
"none": "لا شيء",
|
||||||
|
"never": "أبدًا",
|
||||||
|
"latestVersionX": "الأحدث: {}",
|
||||||
|
"installedVersionX": "المثبت: {}",
|
||||||
|
"lastUpdateCheckX": "آخر تحقق من التحديثات: {}",
|
||||||
|
"remove": "إزالة",
|
||||||
|
"yesMarkUpdated": "نعم، تعليم كمحدث",
|
||||||
|
"fdroid": "F-Droid الرسمي",
|
||||||
|
"appIdOrName": "معرّف التطبيق أو الاسم",
|
||||||
|
"appId": "معرّف التطبيق",
|
||||||
|
"appWithIdOrNameNotFound": "لم يتم العثور على تطبيق بهذا المعرّف أو الاسم",
|
||||||
|
"reposHaveMultipleApps": "قد تحتوي المستودعات على عدة تطبيقات",
|
||||||
|
"fdroidThirdPartyRepo": "مستودع F-Droid طرف ثالث",
|
||||||
|
"install": "تثبيت",
|
||||||
|
"markInstalled": "تعليم كمثبت",
|
||||||
|
"update": "تحديث",
|
||||||
|
"markUpdated": "تعليم كمحدث",
|
||||||
|
"additionalOptions": "خيارات إضافية",
|
||||||
|
"disableVersionDetection": "تعطيل اكتشاف الإصدار",
|
||||||
|
"noVersionDetectionExplanation": "يجب استخدام هذا الخيار فقط للتطبيقات التي لا يعمل فيها اكتشاف الإصدار بشكل صحيح.",
|
||||||
|
"downloadingX": "جاري تنزيل {}",
|
||||||
|
"downloadX": "تنزيل {}",
|
||||||
|
"downloadedX": "تم تنزيل {}",
|
||||||
|
"releaseAsset": "ملف الإصدار",
|
||||||
|
"downloadNotifDescription": "يخطر المستخدم بالتقدم في تنزيل التطبيق",
|
||||||
|
"noAPKFound": "لم يتم العثور على ملف APK",
|
||||||
|
"noVersionDetection": "لا يوجد اكتشاف للإصدار",
|
||||||
|
"categorize": "تصنيف",
|
||||||
|
"categories": "التصنيفات",
|
||||||
|
"category": "تصنيف",
|
||||||
|
"noCategory": "بدون تصنيف",
|
||||||
|
"noCategories": "لا توجد تصنيفات",
|
||||||
|
"deleteCategoriesQuestion": "حذف التصنيفات؟",
|
||||||
|
"categoryDeleteWarning": "سيتم تعيين جميع التطبيقات في التصنيفات المحذوفة كغير مصنفة.",
|
||||||
|
"addCategory": "إضافة تصنيف",
|
||||||
|
"label": "تسمية",
|
||||||
|
"language": "اللغة",
|
||||||
|
"copiedToClipboard": "تم النسخ إلى الحافظة",
|
||||||
|
"storagePermissionDenied": "تم رفض إذن التخزين",
|
||||||
|
"selectedCategorizeWarning": "سيؤدي هذا إلى استبدال أي إعدادات تصنيف موجودة للتطبيقات المحددة.",
|
||||||
|
"filterAPKsByRegEx": "تصفية ملفات APK باستخدام تعبير نمطي",
|
||||||
|
"removeFromObtainium": "إزالة من Obtainium",
|
||||||
|
"uninstallFromDevice": "إلغاء التثبيت من الجهاز",
|
||||||
|
"onlyWorksWithNonVersionDetectApps": "يعمل فقط مع التطبيقات التي تم تعطيل اكتشاف الإصدار لها.",
|
||||||
|
"releaseDateAsVersion": "استخدام تاريخ الإصدار كسلسلة إصدار",
|
||||||
|
"releaseTitleAsVersion": "استخدام عنوان الإصدار كسلسلة إصدار",
|
||||||
|
"releaseDateAsVersionExplanation": "يجب استخدام هذا الخيار فقط للتطبيقات التي لا يعمل فيها اكتشاف الإصدار بشكل صحيح، ولكن تاريخ الإصدار متاح.",
|
||||||
|
"changes": "التغييرات",
|
||||||
|
"releaseDate": "تاريخ الإصدار",
|
||||||
|
"importFromURLsInFile": "استيراد من روابط في ملف (مثل OPML)",
|
||||||
|
"versionDetectionExplanation": "تنسيق سلسلة الإصدار مع الإصدار المكتشف من النظام",
|
||||||
|
"versionDetection": "اكتشاف الإصدار",
|
||||||
|
"standardVersionDetection": "اكتشاف الإصدار القياسي",
|
||||||
|
"groupByCategory": "التجميع حسب التصنيف",
|
||||||
|
"autoApkFilterByArch": "محاولة تصفية ملفات APK حسب بنية المعالج إذا أمكن",
|
||||||
|
"autoLinkFilterByArch": "محاولة تصفية الروابط حسب بنية المعالج إذا أمكن",
|
||||||
|
"overrideSource": "تجاوز المصدر",
|
||||||
|
"dontShowAgain": "عدم إظهار هذا مرة أخرى",
|
||||||
|
"dontShowTrackOnlyWarnings": "عدم إظهار تحذيرات 'للتعقب فقط'",
|
||||||
|
"dontShowAPKOriginWarnings": "عدم إظهار تحذيرات مصدر APK",
|
||||||
|
"moveNonInstalledAppsToBottom": "نقل التطبيقات غير المثبتة إلى أسفل قائمة التطبيقات",
|
||||||
|
"gitlabPATLabel": "رمز الوصول الشخصي لـ GitLab",
|
||||||
|
"about": "حول",
|
||||||
|
"requiresCredentialsInSettings": "{} يحتاج إلى بيانات اعتماد إضافية (في الإعدادات)",
|
||||||
|
"checkOnStart": "التحقق من التحديثات عند البدء",
|
||||||
|
"tryInferAppIdFromCode": "محاولة استنتاج معرّف التطبيق من الكود المصدري",
|
||||||
|
"removeOnExternalUninstall": "إزالة التطبيقات المثبتة خارجيًا تلقائيًا",
|
||||||
|
"pickHighestVersionCode": "تحديد أعلى إصدار تلقائيًا",
|
||||||
|
"checkUpdateOnDetailPage": "التحقق من التحديثات عند فتح صفحة التفاصيل",
|
||||||
|
"disablePageTransitions": "تعطيل انتقالات الصفحات",
|
||||||
|
"reversePageTransitions": "عكس انتقالات الصفحات",
|
||||||
|
"minStarCount": "الحد الأدنى لعدد النجوم",
|
||||||
|
"addInfoBelow": "أضف هذه المعلومات أدناه.",
|
||||||
|
"addInfoInSettings": "أضف هذه المعلومات في الإعدادات.",
|
||||||
|
"githubSourceNote": "يمكن تجنب الحد المسموح لـ GitHub باستخدام مفتاح API.",
|
||||||
|
"sortByLastLinkSegment": "الفرز حسب الجزء الأخير من الرابط فقط",
|
||||||
|
"filterReleaseNotesByRegEx": "تصفية ملاحظات الإصدار باستخدام تعبير نمطي",
|
||||||
|
"customLinkFilterRegex": "تصفية روابط APK المخصصة باستخدام تعبير نمطي (افتراضيًا '.apk$')",
|
||||||
|
"appsPossiblyUpdated": "تمت محاولة تحديث التطبيقات",
|
||||||
|
"appsPossiblyUpdatedNotifDescription": "يخطر المستخدم بأن تحديثات لواحد أو أكثر من التطبيقات قد تم تطبيقها في الخلفية",
|
||||||
|
"xWasPossiblyUpdatedToY": "{} قد تم تحديثه إلى {}.",
|
||||||
|
"enableBackgroundUpdates": "تمكين التحديثات في الخلفية",
|
||||||
|
"backgroundUpdateReqsExplanation": "قد لا تكون التحديثات في الخلفية ممكنة لجميع التطبيقات.",
|
||||||
|
"backgroundUpdateLimitsExplanation": "يمكن تحديد نجاح التثبيت في الخلفية فقط عند فتح Obtainium.",
|
||||||
|
"verifyLatestTag": "التحقق من علامة 'الأحدث'",
|
||||||
|
"intermediateLinkRegex": "تصفية للوصول إلى رابط 'وسيط'",
|
||||||
|
"filterByLinkText": "تصفية الروابط حسب نص الرابط",
|
||||||
|
"intermediateLinkNotFound": "لم يتم العثور على رابط وسيط",
|
||||||
|
"intermediateLink": "رابط وسيط",
|
||||||
|
"exemptFromBackgroundUpdates": "إعفاء من التحديثات في الخلفية (إذا تم تمكينها)",
|
||||||
|
"bgUpdatesOnWiFiOnly": "تعطيل التحديثات في الخلفية عند عدم الاتصال بشبكة Wi-Fi",
|
||||||
|
"bgUpdatesWhileChargingOnly": "تعطيل التحديثات في الخلفية عند عدم الشحن",
|
||||||
|
"autoSelectHighestVersionCode": "تحديد أعلى إصدار تلقائيًا",
|
||||||
|
"versionExtractionRegEx": "تعبير نمطي لاستخراج الإصدار",
|
||||||
|
"trimVersionString": "قص سلسلة الإصدار باستخدام تعبير نمطي",
|
||||||
|
"matchGroupToUseForX": "مجموعة المطابقة لاستخدامها لـ \"{}\"",
|
||||||
|
"matchGroupToUse": "مجموعة المطابقة لاستخدامها في تعبير استخراج الإصدار",
|
||||||
|
"highlightTouchTargets": "تمييز أهداف اللمس الأقل وضوحًا",
|
||||||
|
"pickExportDir": "اختر دليل التصدير",
|
||||||
|
"autoExportOnChanges": "تصدير تلقائي عند التغييرات",
|
||||||
|
"includeSettings": "تضمين الإعدادات",
|
||||||
|
"filterVersionsByRegEx": "تصفية الإصدارات باستخدام تعبير نمطي",
|
||||||
|
"trySelectingSuggestedVersionCode": "محاولة تحديد الإصدار المقترح تلقائيًا",
|
||||||
|
"dontSortReleasesList": "الحفاظ على ترتيب الإصدارات من API",
|
||||||
|
"reverseSort": "فرز عكسي",
|
||||||
|
"takeFirstLink": "أخذ أول رابط",
|
||||||
|
"skipSort": "تخطي الفرز",
|
||||||
|
"debugMenu": "قائمة التصحيح",
|
||||||
|
"bgTaskStarted": "بدأت المهمة في الخلفية - تحقق من السجلات.",
|
||||||
|
"runBgCheckNow": "تشغيل التحقق من التحديثات في الخلفية الآن",
|
||||||
|
"versionExtractWholePage": "تطبيق تعبير استخراج الإصدار على الصفحة بأكملها",
|
||||||
|
"installing": "جاري التثبيت",
|
||||||
|
"skipUpdateNotifications": "تخطي إشعارات التحديث",
|
||||||
|
"updatesAvailableNotifChannel": "تحديثات متاحة",
|
||||||
|
"appsUpdatedNotifChannel": "تم تحديث التطبيقات",
|
||||||
|
"appsPossiblyUpdatedNotifChannel": "تمت محاولة تحديث التطبيقات",
|
||||||
|
"errorCheckingUpdatesNotifChannel": "خطأ في التحقق من التحديثات",
|
||||||
|
"appsRemovedNotifChannel": "تمت إزالة التطبيقات",
|
||||||
|
"downloadingXNotifChannel": "جاري تنزيل {}",
|
||||||
|
"completeAppInstallationNotifChannel": "إكمال تثبيت التطبيق",
|
||||||
|
"checkingForUpdatesNotifChannel": "جاري التحقق من التحديثات",
|
||||||
|
"onlyCheckInstalledOrTrackOnlyApps": "التحقق فقط من التطبيقات المثبتة أو للتعقب فقط",
|
||||||
|
"supportFixedAPKURL": "دعم روابط APK الثابتة",
|
||||||
|
"selectX": "اختر {}",
|
||||||
|
"parallelDownloads": "السماح بالتنزيل المتوازي",
|
||||||
|
"useShizuku": "استخدم Shizuku أو Sui للتثبيت",
|
||||||
|
"shizukuBinderNotFound": "خدمة Shizuku غير قيد التشغيل",
|
||||||
|
"shizukuOld": "إصدار قديم من Shizuku (<11) - قم بتحديثه",
|
||||||
|
"shizukuOldAndroidWithADB": "Shizuku يعمل على إصدار أندرويد < 8.1 مع ADB - قم بتحديث أندرويد أو استخدم Sui بدلاً من ذلك",
|
||||||
|
"shizukuPretendToBeGooglePlay": "تعيين Google Play كمصدر التثبيت (إذا تم استخدام Shizuku)",
|
||||||
|
"useSystemFont": "استخدم خط النظام",
|
||||||
|
"useVersionCodeAsOSVersion": "استخدم versionCode كإصدار مكتشف من النظام",
|
||||||
|
"requestHeader": "رأس الطلب",
|
||||||
|
"useLatestAssetDateAsReleaseDate": "استخدام أحدث تاريخ تحميل كتاريخ إصدار",
|
||||||
|
"defaultPseudoVersioningMethod": "طريقة الإصدار الوهمي الافتراضية",
|
||||||
|
"partialAPKHash": "جزء من تجزئة APK",
|
||||||
|
"APKLinkHash": "تجزئة رابط APK",
|
||||||
|
"directAPKLink": "رابط APK مباشر",
|
||||||
|
"pseudoVersionInUse": "يتم استخدام إصدار وهمي",
|
||||||
|
"installed": "مثبت",
|
||||||
|
"latest": "الأحدث",
|
||||||
|
"invertRegEx": "عكس التعبير النمطي",
|
||||||
|
"note": "ملاحظة",
|
||||||
|
"selfHostedNote": "يمكن استخدام القائمة المنسدلة \"{}\" للوصول إلى نسخ مخصصة/مستضافة ذاتيًا لأي مصدر.",
|
||||||
|
"badDownload": "تعذر تحليل ملف APK (تنزيل غير متوافق أو غير مكتمل)",
|
||||||
|
"beforeNewInstallsShareToAppVerifier": "مشاركة التطبيقات الجديدة مع AppVerifier (إذا كان متاحًا)",
|
||||||
|
"appVerifierInstructionToast": "شارك مع AppVerifier، ثم عد هنا عندما تكون جاهزًا.",
|
||||||
|
"wiki": "المساعدة/ويكي",
|
||||||
|
"crowdsourcedConfigsLabel": "تكوينات التطبيقات المقدمة من الجمهور (استخدم على مسؤوليتك)",
|
||||||
|
"crowdsourcedConfigsShort": "تكوينات التطبيقات المقدمة من الجمهور",
|
||||||
|
"allowInsecure": "السماح بطلبات HTTP غير الآمنة",
|
||||||
|
"stayOneVersionBehind": "البقاء بإصدار واحد خلف الأحدث",
|
||||||
|
"useFirstApkOfVersion": "التحديد التلقائي الأول من بين عدة ملفات APK",
|
||||||
|
"refreshBeforeDownload": "تحديث تفاصيل التطبيق قبل التنزيل",
|
||||||
|
"tencentAppStore": "متجر Tencent للتطبيقات",
|
||||||
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "متجر vivo للتطبيقات (CN)",
|
||||||
|
"name": "الاسم",
|
||||||
|
"smartname": "الاسم (ذكي)",
|
||||||
|
"sortMethod": "طريقة الفرز",
|
||||||
|
"welcome": "مرحبًا",
|
||||||
|
"documentationLinksNote": "تحتوي صفحة Obtainium على GitHub المرتبطة أدناه على روابط لمقاطع فيديو، مقالات، مناقشات وموارد أخرى ستساعدك على فهم كيفية استخدام التطبيق.",
|
||||||
|
"batteryOptimizationNote": "لاحظ أن التنزيلات في الخلفية قد تعمل بشكل أكثر موثوقية إذا قمت بتعطيل تحسينات بطارية النظام لـ Obtainium.",
|
||||||
|
"removeAppQuestion": {
|
||||||
|
"one": "إزالة التطبيق؟",
|
||||||
|
"other": "إزالة التطبيقات؟"
|
||||||
|
},
|
||||||
|
"tooManyRequestsTryAgainInMinutes": {
|
||||||
|
"one": "طلبات كثيرة جدًا (تم تحديد المعدل) - حاول مرة أخرى بعد {} دقيقة",
|
||||||
|
"other": "طلبات كثيرة جدًا (تم تحديد المعدل) - حاول مرة أخرى بعد {} دقائق"
|
||||||
|
},
|
||||||
|
"bgUpdateGotErrorRetryInMinutes": {
|
||||||
|
"one": "واجه التحقق من التحديثات في الخلفية {}، سيتم جدولة محاولة أخرى بعد {} دقيقة",
|
||||||
|
"other": "واجه التحقق من التحديثات في الخلفية {}، سيتم جدولة محاولة أخرى بعد {} دقائق"
|
||||||
|
},
|
||||||
|
"bgCheckFoundUpdatesWillNotifyIfNeeded": {
|
||||||
|
"one": "وجد التحقق من التحديثات في الخلفية {} تحديث - سيتم إخطار المستخدم إذا لزم الأمر",
|
||||||
|
"other": "وجد التحقق من التحديثات في الخلفية {} تحديثات - سيتم إخطار المستخدم إذا لزم الأمر"
|
||||||
|
},
|
||||||
|
"apps": {
|
||||||
|
"one": "{} تطبيق",
|
||||||
|
"other": "{} تطبيقات"
|
||||||
|
},
|
||||||
|
"url": {
|
||||||
|
"one": "{} رابط",
|
||||||
|
"other": "{} روابط"
|
||||||
|
},
|
||||||
|
"minute": {
|
||||||
|
"one": "{} دقيقة",
|
||||||
|
"other": "{} دقائق"
|
||||||
|
},
|
||||||
|
"hour": {
|
||||||
|
"one": "{} ساعة",
|
||||||
|
"other": "{} ساعات"
|
||||||
|
},
|
||||||
|
"day": {
|
||||||
|
"one": "{} يوم",
|
||||||
|
"other": "{} أيام"
|
||||||
|
},
|
||||||
|
"clearedNLogsBeforeXAfterY": {
|
||||||
|
"one": "تم مسح {n} سجل (قبل = {before}, بعد = {after})",
|
||||||
|
"other": "تم مسح {n} سجلات (قبل = {before}, بعد = {after})"
|
||||||
|
},
|
||||||
|
"xAndNMoreUpdatesAvailable": {
|
||||||
|
"one": "{} وتطبيق واحد آخر لديه تحديثات.",
|
||||||
|
"other": "{} و{} تطبيقات أخرى لديها تحديثات."
|
||||||
|
},
|
||||||
|
"xAndNMoreUpdatesInstalled": {
|
||||||
|
"one": "{} وتطبيق واحد آخر تم تحديثه.",
|
||||||
|
"other": "{} و{} تطبيقات أخرى تم تحديثها."
|
||||||
|
},
|
||||||
|
"xAndNMoreUpdatesFailed": {
|
||||||
|
"one": "فشل تحديث {} وتطبيق واحد آخر.",
|
||||||
|
"other": "فشل تحديث {} و{} تطبيقات أخرى."
|
||||||
|
},
|
||||||
|
"xAndNMoreUpdatesPossiblyInstalled": {
|
||||||
|
"one": "{} وتطبيق واحد آخر قد تم تحديثه.",
|
||||||
|
"other": "{} و{} تطبيقات أخرى قد تم تحديثها."
|
||||||
|
},
|
||||||
|
"apk": {
|
||||||
|
"one": "{} APK",
|
||||||
|
"other": "{} APKs"
|
||||||
|
}
|
||||||
|
}
|
@@ -318,9 +318,11 @@
|
|||||||
"crowdsourcedConfigsShort": "Crowdsourced App Configurations",
|
"crowdsourcedConfigsShort": "Crowdsourced App Configurations",
|
||||||
"allowInsecure": "Allow insecure HTTP requests",
|
"allowInsecure": "Allow insecure HTTP requests",
|
||||||
"stayOneVersionBehind": "Stay one version behind latest",
|
"stayOneVersionBehind": "Stay one version behind latest",
|
||||||
|
"useFirstApkOfVersion": "Auto-select first of multiple APKs",
|
||||||
"refreshBeforeDownload": "Refresh app details before download",
|
"refreshBeforeDownload": "Refresh app details before download",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Name",
|
"name": "Name",
|
||||||
"smartname": "Name (Smart)",
|
"smartname": "Name (Smart)",
|
||||||
"sortMethod": "Sort Method",
|
"sortMethod": "Sort Method",
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Configuració de les aplicacions crowdsourcing",
|
"crowdsourcedConfigsShort": "Configuració de les aplicacions crowdsourcing",
|
||||||
"allowInsecure": "Permet les sol·licituds HTTP insegures",
|
"allowInsecure": "Permet les sol·licituds HTTP insegures",
|
||||||
"stayOneVersionBehind": "Roman a la versió anterior a l'última",
|
"stayOneVersionBehind": "Roman a la versió anterior a l'última",
|
||||||
|
"useFirstApkOfVersion": "Auto-select first of multiple APKs",
|
||||||
"refreshBeforeDownload": "Actualitza les dades de l'aplicació abans de descarregar-la",
|
"refreshBeforeDownload": "Actualitza les dades de l'aplicació abans de descarregar-la",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Nom",
|
"name": "Nom",
|
||||||
"smartname": "Nom (smart)",
|
"smartname": "Nom (smart)",
|
||||||
"sortMethod": "Mètode d'ordenació",
|
"sortMethod": "Mètode d'ordenació",
|
||||||
"welcome": "Benvinguda",
|
"welcome": "Benvinguda",
|
||||||
"documentationLinksNote": "La pàgina GitHub d'Obtainium enllaçada a sota conté enllaços a vídeos, articles, debats i altres recursos que t'ajudaran a entendre com usar l'aplicació.",
|
"documentationLinksNote": "La pàgina GitHub d'Obtainium enllaçada a sota conté enllaços a vídeos, articles, debats i altres recursos que t'ajudaran a entendre com usar l'aplicació.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Tingues present que les descàrregues en segon pla funcionaran millor si inhabilites l'optimització de bateria per a Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "¿Suprimeixo l'aplicació?",
|
"one": "¿Suprimeixo l'aplicació?",
|
||||||
"other": "¿Suprimeixo les aplicacions?"
|
"other": "¿Suprimeixo les aplicacions?"
|
||||||
|
@@ -36,7 +36,7 @@
|
|||||||
"trackOnlyAppDescription": "Aplikace je sledována kvůli aktualizacím, ale Obtainium ji nebude stahovat ani instalovat.",
|
"trackOnlyAppDescription": "Aplikace je sledována kvůli aktualizacím, ale Obtainium ji nebude stahovat ani instalovat.",
|
||||||
"cancelled": "Zrušeno",
|
"cancelled": "Zrušeno",
|
||||||
"appAlreadyAdded": "Aplikace již přidána",
|
"appAlreadyAdded": "Aplikace již přidána",
|
||||||
"alreadyUpToDateQuestion": "App already up to date?",
|
"alreadyUpToDateQuestion": "Aplikace je již aktualizovaná?",
|
||||||
"addApp": "Přidat aplikaci",
|
"addApp": "Přidat aplikaci",
|
||||||
"appSourceURL": "Zdrojová adresa URL aplikace",
|
"appSourceURL": "Zdrojová adresa URL aplikace",
|
||||||
"error": "Chyba",
|
"error": "Chyba",
|
||||||
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Konfigurace aplikací s využitím crowdsourcingu",
|
"crowdsourcedConfigsShort": "Konfigurace aplikací s využitím crowdsourcingu",
|
||||||
"allowInsecure": "Povolení nezabezpečených požadavků HTTP",
|
"allowInsecure": "Povolení nezabezpečených požadavků HTTP",
|
||||||
"stayOneVersionBehind": "Zůstaňte o jednu verzi pozadu za nejnovější",
|
"stayOneVersionBehind": "Zůstaňte o jednu verzi pozadu za nejnovější",
|
||||||
|
"useFirstApkOfVersion": "Automatický výběr prvního z více souborů APK",
|
||||||
"refreshBeforeDownload": "Obnovení údajů o aplikaci před stažením",
|
"refreshBeforeDownload": "Obnovení údajů o aplikaci před stažením",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Název",
|
"name": "Název",
|
||||||
"smartname": "Název (Smart)",
|
"smartname": "Název (Smart)",
|
||||||
"sortMethod": "Metoda třídění",
|
"sortMethod": "Metoda třídění",
|
||||||
"welcome": "Vítejte na",
|
"welcome": "Vítejte na",
|
||||||
"documentationLinksNote": "Níže odkazovaná stránka Obtainium GitHub obsahuje odkazy na videa, články, diskuse a další zdroje, které vám pomohou pochopit, jak aplikaci používat.",
|
"documentationLinksNote": "Níže odkazovaná stránka Obtainium GitHub obsahuje odkazy na videa, články, diskuse a další zdroje, které vám pomohou pochopit, jak aplikaci používat.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Všimněte si, že stahování na pozadí může fungovat spolehlivěji, pokud vypnete optimalizaci baterie operačního systému pro Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Odstranit Apku?",
|
"one": "Odstranit Apku?",
|
||||||
"other": "Odstranit Apky?"
|
"other": "Odstranit Apky?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Crowdsourcede app-konfigurationer",
|
"crowdsourcedConfigsShort": "Crowdsourcede app-konfigurationer",
|
||||||
"allowInsecure": "Tillad usikre HTTP-anmodninger",
|
"allowInsecure": "Tillad usikre HTTP-anmodninger",
|
||||||
"stayOneVersionBehind": "Forbliv én version bagud den seneste",
|
"stayOneVersionBehind": "Forbliv én version bagud den seneste",
|
||||||
|
"useFirstApkOfVersion": "Vælg automatisk den første af flere APK'er",
|
||||||
"refreshBeforeDownload": "Opdater app-detaljer før download",
|
"refreshBeforeDownload": "Opdater app-detaljer før download",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Navn",
|
"name": "Navn",
|
||||||
"smartname": "Navn (Smart)",
|
"smartname": "Navn (Smart)",
|
||||||
"sortMethod": "Sorteringsmetode",
|
"sortMethod": "Sorteringsmetode",
|
||||||
"welcome": "Velkommen",
|
"welcome": "Velkommen",
|
||||||
"documentationLinksNote": "Obtainiums GitHub-side, som der linkes til nedenfor, indeholder links til videoer, artikler, diskussioner og andre ressourcer, som kan hjælpe dig med at forstå, hvordan du bruger appen.",
|
"documentationLinksNote": "Obtainiums GitHub-side, som der linkes til nedenfor, indeholder links til videoer, artikler, diskussioner og andre ressourcer, som kan hjælpe dig med at forstå, hvordan du bruger appen.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Bemærk, at baggrundsdownloads kan fungere mere pålideligt, hvis du deaktiverer OS-batterioptimering for Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Fjern app?",
|
"one": "Fjern app?",
|
||||||
"other": "Fjern apps?"
|
"other": "Fjern apps?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Crowdsourced App-Konfigurationen",
|
"crowdsourcedConfigsShort": "Crowdsourced App-Konfigurationen",
|
||||||
"allowInsecure": "Unsichere HTTP-Anfragen zulassen",
|
"allowInsecure": "Unsichere HTTP-Anfragen zulassen",
|
||||||
"stayOneVersionBehind": "Eine Version hinter der neuesten Version bleiben",
|
"stayOneVersionBehind": "Eine Version hinter der neuesten Version bleiben",
|
||||||
|
"useFirstApkOfVersion": "Automatische Auswahl der ersten von mehreren APKs",
|
||||||
"refreshBeforeDownload": "App-Details vor dem Download aktualisieren",
|
"refreshBeforeDownload": "App-Details vor dem Download aktualisieren",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Name",
|
"name": "Name",
|
||||||
"smartname": "Name (Smart)",
|
"smartname": "Name (Smart)",
|
||||||
"sortMethod": "Sortierverfahren",
|
"sortMethod": "Sortierverfahren",
|
||||||
"welcome": "Willkommen",
|
"welcome": "Willkommen",
|
||||||
"documentationLinksNote": "Die unten verlinkte GitHub-Seite von Obtainium enthält Links zu Videos, Artikeln, Diskussionen und anderen Ressourcen, die Ihnen helfen werden, die Verwendung der App zu verstehen.",
|
"documentationLinksNote": "Die unten verlinkte GitHub-Seite von Obtainium enthält Links zu Videos, Artikeln, Diskussionen und anderen Ressourcen, die Ihnen helfen werden, die Verwendung der App zu verstehen.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Beachten Sie, dass Downloads im Hintergrund möglicherweise zuverlässiger funktionieren, wenn Sie die Batterieoptimierung des Betriebssystems für Obtainium deaktivieren.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "App entfernen?",
|
"one": "App entfernen?",
|
||||||
"other": "Apps entfernen?"
|
"other": "Apps entfernen?"
|
||||||
|
@@ -318,9 +318,11 @@
|
|||||||
"crowdsourcedConfigsShort": "Crowdsourced App Configurations",
|
"crowdsourcedConfigsShort": "Crowdsourced App Configurations",
|
||||||
"allowInsecure": "Allow insecure HTTP requests",
|
"allowInsecure": "Allow insecure HTTP requests",
|
||||||
"stayOneVersionBehind": "Stay one version behind latest",
|
"stayOneVersionBehind": "Stay one version behind latest",
|
||||||
|
"useFirstApkOfVersion": "Auto-select first of multiple APKs",
|
||||||
"refreshBeforeDownload": "Refresh app details before download",
|
"refreshBeforeDownload": "Refresh app details before download",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Name",
|
"name": "Name",
|
||||||
"smartname": "Name (Smart)",
|
"smartname": "Name (Smart)",
|
||||||
"sortMethod": "Sort Method",
|
"sortMethod": "Sort Method",
|
||||||
|
@@ -318,6 +318,7 @@
|
|||||||
"crowdsourcedConfigsShort": "Crowdsourced app configurations",
|
"crowdsourcedConfigsShort": "Crowdsourced app configurations",
|
||||||
"allowInsecure": "Allow insecure HTTP requests",
|
"allowInsecure": "Allow insecure HTTP requests",
|
||||||
"stayOneVersionBehind": "Stay one version behind latest",
|
"stayOneVersionBehind": "Stay one version behind latest",
|
||||||
|
"useFirstApkOfVersion": "Auto-select first of multiple APKs",
|
||||||
"refreshBeforeDownload": "Refresh app details before download",
|
"refreshBeforeDownload": "Refresh app details before download",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Configuración de aplicaciones por crowdsourcing",
|
"crowdsourcedConfigsShort": "Configuración de aplicaciones por crowdsourcing",
|
||||||
"allowInsecure": "Permitir peticiones HTTP inseguras",
|
"allowInsecure": "Permitir peticiones HTTP inseguras",
|
||||||
"stayOneVersionBehind": "Mantenerse una versión por detrás de la última",
|
"stayOneVersionBehind": "Mantenerse una versión por detrás de la última",
|
||||||
|
"useFirstApkOfVersion": "Auto-selección del primero de múltiples APKs",
|
||||||
"refreshBeforeDownload": "Actualiza los datos de la aplicación antes de descargarla",
|
"refreshBeforeDownload": "Actualiza los datos de la aplicación antes de descargarla",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Nombre",
|
"name": "Nombre",
|
||||||
"smartname": "Nombre (Smart)",
|
"smartname": "Nombre (Smart)",
|
||||||
"sortMethod": "Método de clasificación",
|
"sortMethod": "Método de clasificación",
|
||||||
"welcome": "Bienvenido",
|
"welcome": "Bienvenido",
|
||||||
"documentationLinksNote": "La página GitHub de Obtainium enlazada a continuación contiene enlaces a vídeos, artículos, debates y otros recursos que te ayudarán a entender cómo utilizar la aplicación.",
|
"documentationLinksNote": "La página GitHub de Obtainium enlazada a continuación contiene enlaces a vídeos, artículos, debates y otros recursos que te ayudarán a entender cómo utilizar la aplicación.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Ten en cuenta que las descargas en segundo plano pueden funcionar de forma más fiable si desactivas las optimizaciones de batería del sistema operativo para Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "¿Eliminar aplicación?",
|
"one": "¿Eliminar aplicación?",
|
||||||
"other": "¿Eliminar aplicaciones?"
|
"other": "¿Eliminar aplicaciones?"
|
||||||
|
@@ -318,9 +318,11 @@
|
|||||||
"crowdsourcedConfigsShort": "تنظیمات برنامه های مشارکت جمعی",
|
"crowdsourcedConfigsShort": "تنظیمات برنامه های مشارکت جمعی",
|
||||||
"allowInsecure": "درخواست های HTTP ناامن را مجاز کنید",
|
"allowInsecure": "درخواست های HTTP ناامن را مجاز کنید",
|
||||||
"stayOneVersionBehind": "یک نسخه از آخرین نسخه پشت سر بگذارید",
|
"stayOneVersionBehind": "یک نسخه از آخرین نسخه پشت سر بگذارید",
|
||||||
|
"useFirstApkOfVersion": "Auto-select first of multiple APKs",
|
||||||
"refreshBeforeDownload": "قبل از دانلود، جزئیات برنامه را بازخوانی کنید",
|
"refreshBeforeDownload": "قبل از دانلود، جزئیات برنامه را بازخوانی کنید",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Name",
|
"name": "Name",
|
||||||
"smartname": "Name (Smart)",
|
"smartname": "Name (Smart)",
|
||||||
"sortMethod": "Sort Method",
|
"sortMethod": "Sort Method",
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Applications communautaires",
|
"crowdsourcedConfigsShort": "Applications communautaires",
|
||||||
"allowInsecure": "Autoriser les requêtes HTTP non sécurisées",
|
"allowInsecure": "Autoriser les requêtes HTTP non sécurisées",
|
||||||
"stayOneVersionBehind": "Rester une version en arrière de la dernière",
|
"stayOneVersionBehind": "Rester une version en arrière de la dernière",
|
||||||
|
"useFirstApkOfVersion": "Sélection automatique du premier APK parmi plusieurs",
|
||||||
"refreshBeforeDownload": "Actualiser les détails de l'application avant de la télécharger",
|
"refreshBeforeDownload": "Actualiser les détails de l'application avant de la télécharger",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Nom",
|
"name": "Nom",
|
||||||
"smartname": "Nom (Smart)",
|
"smartname": "Nom (Smart)",
|
||||||
"sortMethod": "Méthode de tri",
|
"sortMethod": "Méthode de tri",
|
||||||
"welcome": "Bienvenue",
|
"welcome": "Bienvenue",
|
||||||
"documentationLinksNote": "La page GitHub d'Obtainium, dont le lien figure ci-dessous, contient des liens vers des vidéos, des articles, des discussions et d'autres ressources qui vous aideront à comprendre comment utiliser l'application.",
|
"documentationLinksNote": "La page GitHub d'Obtainium, dont le lien figure ci-dessous, contient des liens vers des vidéos, des articles, des discussions et d'autres ressources qui vous aideront à comprendre comment utiliser l'application.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Notez que les téléchargements en arrière-plan peuvent fonctionner de manière plus fiable si vous désactivez les optimisations de la batterie du système d'exploitation pour Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Supprimer l'application ?",
|
"one": "Supprimer l'application ?",
|
||||||
"other": "Supprimer les applications ?"
|
"other": "Supprimer les applications ?"
|
||||||
|
@@ -28,11 +28,11 @@
|
|||||||
"githubStarredRepos": "Csillagozott GitHub tárolók",
|
"githubStarredRepos": "Csillagozott GitHub tárolók",
|
||||||
"uname": "Felhasználónév",
|
"uname": "Felhasználónév",
|
||||||
"wrongArgNum": "A megadott argumentumok száma nem megfelelő",
|
"wrongArgNum": "A megadott argumentumok száma nem megfelelő",
|
||||||
"xIsTrackOnly": "A(z) {} csak nyomon-követhető",
|
"xIsTrackOnly": "A(z) {} csak nyomon követhető",
|
||||||
"source": "Forrás",
|
"source": "Forrás",
|
||||||
"app": "Alkalmazás",
|
"app": "Alkalmazás",
|
||||||
"appsFromSourceAreTrackOnly": "Az ebből a forrásból származó alkalmazások „csak nyomon-követhetők”.",
|
"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.",
|
"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.",
|
"trackOnlyAppDescription": "Az alkalmazás frissítéseit nyomon követi, de az Obtainium nem tudja letölteni vagy telepíteni.",
|
||||||
"cancelled": "Visszavonva",
|
"cancelled": "Visszavonva",
|
||||||
"appAlreadyAdded": "Az alkalmazás már hozzá van adva",
|
"appAlreadyAdded": "Az alkalmazás már hozzá van adva",
|
||||||
@@ -45,7 +45,7 @@
|
|||||||
"search": "Keresés",
|
"search": "Keresés",
|
||||||
"additionalOptsFor": "További lehetőségek a következőhöz: {}",
|
"additionalOptsFor": "További lehetőségek a következőhöz: {}",
|
||||||
"supportedSources": "Támogatott források",
|
"supportedSources": "Támogatott források",
|
||||||
"trackOnlyInBrackets": "(Csak nyomon-követés)",
|
"trackOnlyInBrackets": "(Csak nyomon követés)",
|
||||||
"searchableInBrackets": "(Kereshető)",
|
"searchableInBrackets": "(Kereshető)",
|
||||||
"appsString": "Alkalmazások",
|
"appsString": "Alkalmazások",
|
||||||
"noApps": "Nincsenek alkalmazások",
|
"noApps": "Nincsenek alkalmazások",
|
||||||
@@ -63,7 +63,7 @@
|
|||||||
"removeSelectedApps": "A kiválasztott alkalmazások eltávolítása",
|
"removeSelectedApps": "A kiválasztott alkalmazások eltávolítása",
|
||||||
"updateX": "{} frissítése",
|
"updateX": "{} frissítése",
|
||||||
"installX": "{} telepítése",
|
"installX": "{} telepítése",
|
||||||
"markXTrackOnlyAsUpdated": "Megjelölés: {}\n(Csak nyomon-követés)\nFrissítettként",
|
"markXTrackOnlyAsUpdated": "Megjelölés: {}\n(Csak nyomon követés)\nFrissítettként",
|
||||||
"changeX": "{}-változás",
|
"changeX": "{}-változás",
|
||||||
"installUpdateApps": "Alkalmazások telepítése/frissítése",
|
"installUpdateApps": "Alkalmazások telepítése/frissítése",
|
||||||
"installUpdateSelectedApps": "A kiválasztott alkalmazások telepítése/frissítése",
|
"installUpdateSelectedApps": "A kiválasztott alkalmazások telepítése/frissítése",
|
||||||
@@ -143,7 +143,7 @@
|
|||||||
"warning": "Figyelem",
|
"warning": "Figyelem",
|
||||||
"sourceIsXButPackageFromYPrompt": "Az alkalmazás forrása a(z) „{}” tároló, de a kiadási csomag innen származik: „{}”. Folytatja?",
|
"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",
|
"updatesAvailable": "Frissítések érhetők el",
|
||||||
"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",
|
"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.",
|
"noNewUpdates": "Nincsenek új frissítések.",
|
||||||
"xHasAnUpdate": "A(z) {} frissítést kapott.",
|
"xHasAnUpdate": "A(z) {} frissítést kapott.",
|
||||||
"appsUpdated": "Alkalmazások frissítve",
|
"appsUpdated": "Alkalmazások frissítve",
|
||||||
@@ -162,7 +162,7 @@
|
|||||||
"checkingForUpdates": "Frissítések ellenőrzése",
|
"checkingForUpdates": "Frissítések ellenőrzése",
|
||||||
"checkingForUpdatesNotifDescription": "Átmeneti értesítés, amely a frissítések ellenőrzésekor jelenik meg",
|
"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",
|
"pleaseAllowInstallPerm": "Engedélyezze az Obtainiumnak az alkalmazások telepítését",
|
||||||
"trackOnly": "Csak nyomon-követés",
|
"trackOnly": "Csak nyomon követés",
|
||||||
"errorWithHttpStatusCode": "Hiba {}",
|
"errorWithHttpStatusCode": "Hiba {}",
|
||||||
"versionCorrectionDisabled": "Verzió-korrekció letiltva (úgy tűnik, hogy a bővítmény nem működik)",
|
"versionCorrectionDisabled": "Verzió-korrekció letiltva (úgy tűnik, hogy a bővítmény nem működik)",
|
||||||
"unknown": "Ismeretlen",
|
"unknown": "Ismeretlen",
|
||||||
@@ -224,7 +224,7 @@
|
|||||||
"autoLinkFilterByArch": "Ha lehetséges, próbálja meg a hivatkozásokat CPU-architektúra szerint szűrni",
|
"autoLinkFilterByArch": "Ha lehetséges, próbálja meg a hivatkozásokat CPU-architektúra szerint szűrni",
|
||||||
"overrideSource": "Forrás felülírása",
|
"overrideSource": "Forrás felülírása",
|
||||||
"dontShowAgain": "Ne jelenítse meg ezt többé",
|
"dontShowAgain": "Ne jelenítse meg ezt többé",
|
||||||
"dontShowTrackOnlyWarnings": "Ne jelenítse meg a „Csak nyomon-kö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",
|
"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",
|
"moveNonInstalledAppsToBottom": "Helyezze át a nem telepített alkalmazásokat az alkalmazásnézet aljára",
|
||||||
"gitlabPATLabel": "GitLab személyes hozzáférési token",
|
"gitlabPATLabel": "GitLab személyes hozzáférési token",
|
||||||
@@ -287,7 +287,7 @@
|
|||||||
"downloadingXNotifChannel": "A(z) {} letöltése",
|
"downloadingXNotifChannel": "A(z) {} letöltése",
|
||||||
"completeAppInstallationNotifChannel": "Teljes alkalmazás telepítés",
|
"completeAppInstallationNotifChannel": "Teljes alkalmazás telepítés",
|
||||||
"checkingForUpdatesNotifChannel": "Frissítések ellenőrzése",
|
"checkingForUpdatesNotifChannel": "Frissítések ellenőrzése",
|
||||||
"onlyCheckInstalledOrTrackOnlyApps": "Csak a telepített és a csak nyomon-kö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",
|
"supportFixedAPKURL": "Támogatja a rögzített APK webcímeket",
|
||||||
"selectX": "{} kiválasztása",
|
"selectX": "{} kiválasztása",
|
||||||
"parallelDownloads": "Párhuzamos letöltések engedélyezése",
|
"parallelDownloads": "Párhuzamos letöltések engedélyezése",
|
||||||
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Alkalmazáslista",
|
"crowdsourcedConfigsShort": "Alkalmazáslista",
|
||||||
"allowInsecure": "Nem biztonságos HTTP-kérések engedélyezése",
|
"allowInsecure": "Nem biztonságos HTTP-kérések engedélyezése",
|
||||||
"stayOneVersionBehind": "Maradjon egy verzióval a legújabb mögött",
|
"stayOneVersionBehind": "Maradjon egy verzióval a legújabb mögött",
|
||||||
|
"useFirstApkOfVersion": "Több APK közül az első automatikus kiválasztása",
|
||||||
"refreshBeforeDownload": "Az alkalmazás adatainak frissítése a letöltés előtt",
|
"refreshBeforeDownload": "Az alkalmazás adatainak frissítése a letöltés előtt",
|
||||||
"tencentAppStore": "Tencent Appstore",
|
"tencentAppStore": "Tencent Appstore",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Név",
|
"name": "Név",
|
||||||
"smartname": "Név (Okos)",
|
"smartname": "Név (Okos)",
|
||||||
"sortMethod": "Rendezési eljárás",
|
"sortMethod": "Rendezési eljárás",
|
||||||
"welcome": "Üdvözöljük!",
|
"welcome": "Üdvözöljük!",
|
||||||
"documentationLinksNote": "Az alábbi hivatkozás az Obtainium GitHub oldalára vezet, amely további videók, cikkek, beszélgetések és egyéb források hivatkozásait tartalmazza, amelyek segítenek megérteni az alkalmazás használatát.",
|
"documentationLinksNote": "Az alábbi hivatkozás az Obtainium GitHub oldalára vezet, amely további videók, cikkek, beszélgetések és egyéb források hivatkozásait tartalmazza, amelyek segítenek megérteni az alkalmazás használatát.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Megjegyzés: A háttérfrissítések megbízhatóbban működhetnek, ha kikapcsolja a rendszer akkumulátor-optimalizálását az Obtainium számára.",
|
||||||
"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?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Konfigurasi Aplikasi Crowdsourced",
|
"crowdsourcedConfigsShort": "Konfigurasi Aplikasi Crowdsourced",
|
||||||
"allowInsecure": "Izinkan permintaan HTTP yang tidak aman",
|
"allowInsecure": "Izinkan permintaan HTTP yang tidak aman",
|
||||||
"stayOneVersionBehind": "Tetap satu versi di belakang versi terbaru",
|
"stayOneVersionBehind": "Tetap satu versi di belakang versi terbaru",
|
||||||
|
"useFirstApkOfVersion": "Pilih otomatis yang pertama dari beberapa APK",
|
||||||
"refreshBeforeDownload": "Segarkan detail aplikasi sebelum mengunduh",
|
"refreshBeforeDownload": "Segarkan detail aplikasi sebelum mengunduh",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Nama",
|
"name": "Nama",
|
||||||
"smartname": "Nama (Cerdas)",
|
"smartname": "Nama (Cerdas)",
|
||||||
"sortMethod": "Metode Penyortiran",
|
"sortMethod": "Metode Penyortiran",
|
||||||
"welcome": "Selamat datang.",
|
"welcome": "Selamat datang.",
|
||||||
"documentationLinksNote": "Halaman GitHub Obtainium yang ditautkan di bawah ini berisi tautan ke video, artikel, diskusi, dan sumber daya lain yang akan membantu Anda memahami cara menggunakan aplikasi.",
|
"documentationLinksNote": "Halaman GitHub Obtainium yang ditautkan di bawah ini berisi tautan ke video, artikel, diskusi, dan sumber daya lain yang akan membantu Anda memahami cara menggunakan aplikasi.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Perhatikan bahwa unduhan latar belakang dapat bekerja lebih andal jika Anda menonaktifkan optimasi baterai OS untuk Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Hapus aplikasi?",
|
"one": "Hapus aplikasi?",
|
||||||
"other": "Hapus aplikasi?"
|
"other": "Hapus aplikasi?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Configurazioni di app in crowdsourcing",
|
"crowdsourcedConfigsShort": "Configurazioni di app in crowdsourcing",
|
||||||
"allowInsecure": "Consentire le richieste HTTP non sicure",
|
"allowInsecure": "Consentire le richieste HTTP non sicure",
|
||||||
"stayOneVersionBehind": "Rimanere una versione indietro rispetto alla più recente",
|
"stayOneVersionBehind": "Rimanere una versione indietro rispetto alla più recente",
|
||||||
|
"useFirstApkOfVersion": "Selezione automatica del primo di più APK",
|
||||||
"refreshBeforeDownload": "Aggiornare i dettagli dell'app prima del download",
|
"refreshBeforeDownload": "Aggiornare i dettagli dell'app prima del download",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Nome",
|
"name": "Nome",
|
||||||
"smartname": "Nome (intelligente)",
|
"smartname": "Nome (intelligente)",
|
||||||
"sortMethod": "Metodo di ordinamento",
|
"sortMethod": "Metodo di ordinamento",
|
||||||
"welcome": "Benvenuti",
|
"welcome": "Benvenuti",
|
||||||
"documentationLinksNote": "La pagina GitHub di Obtainium collegata qui sotto contiene collegamenti a video, articoli, discussioni e altre risorse che vi aiuteranno a capire come utilizzare l'applicazione.",
|
"documentationLinksNote": "La pagina GitHub di Obtainium collegata qui sotto contiene collegamenti a video, articoli, discussioni e altre risorse che vi aiuteranno a capire come utilizzare l'applicazione.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Si noti che i download in background potrebbero funzionare in modo più affidabile se si disabilita l'ottimizzazione della batteria del sistema operativo per Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Rimuovere l'app?",
|
"one": "Rimuovere l'app?",
|
||||||
"other": "Rimuovere le app?"
|
"other": "Rimuovere le app?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "クラウドソーシングによるアプリの設定",
|
"crowdsourcedConfigsShort": "クラウドソーシングによるアプリの設定",
|
||||||
"allowInsecure": "安全でないHTTPリクエストを許可する",
|
"allowInsecure": "安全でないHTTPリクエストを許可する",
|
||||||
"stayOneVersionBehind": "最新のバージョンから1つ前のものを使用する",
|
"stayOneVersionBehind": "最新のバージョンから1つ前のものを使用する",
|
||||||
|
"useFirstApkOfVersion": "複数のAPKから最初のAPKを自動選択する",
|
||||||
"refreshBeforeDownload": "ダウンロード前にアプリの詳細を更新する",
|
"refreshBeforeDownload": "ダウンロード前にアプリの詳細を更新する",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "名称",
|
"name": "名称",
|
||||||
"smartname": "名前(スマート)",
|
"smartname": "名前(スマート)",
|
||||||
"sortMethod": "ソート方法",
|
"sortMethod": "ソート方法",
|
||||||
"welcome": "ようこそ",
|
"welcome": "ようこそ",
|
||||||
"documentationLinksNote": "以下のリンクにあるObtainium GitHubページには、ビデオ、記事、ディスカッション、その他のリソースへのリンクがあり、アプリの使い方を理解するのに役立ちます。",
|
"documentationLinksNote": "以下のリンクにあるObtainium GitHubページには、ビデオ、記事、ディスカッション、その他のリソースへのリンクがあり、アプリの使い方を理解するのに役立ちます。",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "ObtainiumのOSバッテリー最適化を無効にすると、バックグラウンドダウンロードがより確実に動作するようになります。",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "アプリを削除しますか?",
|
"one": "アプリを削除しますか?",
|
||||||
"other": "アプリを削除しますか?"
|
"other": "アプリを削除しますか?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "크라우드소싱 앱 구성",
|
"crowdsourcedConfigsShort": "크라우드소싱 앱 구성",
|
||||||
"allowInsecure": "안전하지 않은 HTTP 요청 허용",
|
"allowInsecure": "안전하지 않은 HTTP 요청 허용",
|
||||||
"stayOneVersionBehind": "최신 버전보다 한 버전 뒤에 머무르기",
|
"stayOneVersionBehind": "최신 버전보다 한 버전 뒤에 머무르기",
|
||||||
|
"useFirstApkOfVersion": "여러 앱 중 첫 번째 앱 자동 선택",
|
||||||
"refreshBeforeDownload": "다운로드 전에 앱 세부 정보 새로 고침",
|
"refreshBeforeDownload": "다운로드 전에 앱 세부 정보 새로 고침",
|
||||||
"tencentAppStore": "텐센트 앱 스토어",
|
"tencentAppStore": "텐센트 앱 스토어",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "이름",
|
"name": "이름",
|
||||||
"smartname": "이름(스마트)",
|
"smartname": "이름(스마트)",
|
||||||
"sortMethod": "정렬 방법",
|
"sortMethod": "정렬 방법",
|
||||||
"welcome": "환영",
|
"welcome": "환영",
|
||||||
"documentationLinksNote": "아래에 링크된 Obtainium 깃허브 페이지에는 앱 사용 방법을 이해하는 데 도움이 되는 동영상, 기사, 토론 및 기타 리소스에 대한 링크가 포함되어 있습니다.",
|
"documentationLinksNote": "아래에 링크된 Obtainium 깃허브 페이지에는 앱 사용 방법을 이해하는 데 도움이 되는 동영상, 기사, 토론 및 기타 리소스에 대한 링크가 포함되어 있습니다.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Obtainium의 OS 배터리 최적화를 비활성화하면 백그라운드 다운로드가 더 안정적으로 작동할 수 있습니다.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "앱을 제거하시겠습니까?",
|
"one": "앱을 제거하시겠습니까?",
|
||||||
"other": "앱을 제거하시겠습니까?"
|
"other": "앱을 제거하시겠습니까?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "App-configuraties door menigte",
|
"crowdsourcedConfigsShort": "App-configuraties door menigte",
|
||||||
"allowInsecure": "Onveilige HTTP-verzoeken toestaan",
|
"allowInsecure": "Onveilige HTTP-verzoeken toestaan",
|
||||||
"stayOneVersionBehind": "Blijf een versie achter op de nieuwste",
|
"stayOneVersionBehind": "Blijf een versie achter op de nieuwste",
|
||||||
|
"useFirstApkOfVersion": "Automatisch de eerste van meerdere APK's selecteren",
|
||||||
"refreshBeforeDownload": "Vernieuw app details voor download",
|
"refreshBeforeDownload": "Vernieuw app details voor download",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Naam",
|
"name": "Naam",
|
||||||
"smartname": "Naam (Slim)",
|
"smartname": "Naam (Slim)",
|
||||||
"sortMethod": "Sorteermethode",
|
"sortMethod": "Sorteermethode",
|
||||||
"welcome": "Welkom",
|
"welcome": "Welkom",
|
||||||
"documentationLinksNote": "De GitHub pagina van Obtainium waarnaar hieronder wordt gelinkt bevat links naar video's, artikelen, discussies en andere bronnen die je zullen helpen begrijpen hoe je de app kunt gebruiken.",
|
"documentationLinksNote": "De GitHub pagina van Obtainium waarnaar hieronder wordt gelinkt bevat links naar video's, artikelen, discussies en andere bronnen die je zullen helpen begrijpen hoe je de app kunt gebruiken.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Merk op dat downloads op de achtergrond mogelijk betrouwbaarder werken als je de batterijoptimalisatie van het besturingssysteem voor Obtainium uitschakelt.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "App verwijderen?",
|
"one": "App verwijderen?",
|
||||||
"other": "Apps verwijderen?"
|
"other": "Apps verwijderen?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Baza konfiguracji",
|
"crowdsourcedConfigsShort": "Baza konfiguracji",
|
||||||
"allowInsecure": "Zezwalaj na niezabezpieczone żądania HTTP",
|
"allowInsecure": "Zezwalaj na niezabezpieczone żądania HTTP",
|
||||||
"stayOneVersionBehind": "Pozostań jedną wersję w tyle za najnowszą",
|
"stayOneVersionBehind": "Pozostań jedną wersję w tyle za najnowszą",
|
||||||
|
"useFirstApkOfVersion": "Automatyczny wybór pierwszego z wielu plików APK",
|
||||||
"refreshBeforeDownload": "Odśwież szczegóły aplikacji przed pobraniem",
|
"refreshBeforeDownload": "Odśwież szczegóły aplikacji przed pobraniem",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Nazwa",
|
"name": "Nazwa",
|
||||||
"smartname": "Nazwa (Smart)",
|
"smartname": "Nazwa (Smart)",
|
||||||
"sortMethod": "Metoda sortowania",
|
"sortMethod": "Metoda sortowania",
|
||||||
"welcome": "Witamy",
|
"welcome": "Witamy",
|
||||||
"documentationLinksNote": "Strona Obtainium GitHub, do której link znajduje się poniżej, zawiera linki do filmów, artykułów, dyskusji i innych zasobów, które pomogą ci zrozumieć, jak korzystać z aplikacji.",
|
"documentationLinksNote": "Strona Obtainium GitHub, do której link znajduje się poniżej, zawiera linki do filmów, artykułów, dyskusji i innych zasobów, które pomogą ci zrozumieć, jak korzystać z aplikacji.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Należy pamiętać, że pobieranie w tle może działać bardziej niezawodnie po wyłączeniu optymalizacji baterii systemu operacyjnego dla Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Usunąć aplikację?",
|
"one": "Usunąć aplikację?",
|
||||||
"few": "Usunąć aplikacje?",
|
"few": "Usunąć aplikacje?",
|
||||||
|
@@ -30,7 +30,7 @@
|
|||||||
"wrongArgNum": "Número errado de argumentos fornecidos",
|
"wrongArgNum": "Número errado de argumentos fornecidos",
|
||||||
"xIsTrackOnly": "{} é somente de rastreio",
|
"xIsTrackOnly": "{} é somente de rastreio",
|
||||||
"source": "Fonte",
|
"source": "Fonte",
|
||||||
"app": "App",
|
"app": "Aplicativo",
|
||||||
"appsFromSourceAreTrackOnly": "Apps desta fonte são somente para rastreamento.",
|
"appsFromSourceAreTrackOnly": "Apps desta fonte são somente para rastreamento.",
|
||||||
"youPickedTrackOnly": "Você selecionou a opção de somente rastreamento.",
|
"youPickedTrackOnly": "Você selecionou a opção de somente rastreamento.",
|
||||||
"trackOnlyAppDescription": "As atualizações do app serão rastreadas, mas o Obtainium não baixará ou instalará elas.",
|
"trackOnlyAppDescription": "As atualizações do app serão rastreadas, mas o Obtainium não baixará ou instalará elas.",
|
||||||
@@ -47,7 +47,7 @@
|
|||||||
"supportedSources": "Fontes suportadas",
|
"supportedSources": "Fontes suportadas",
|
||||||
"trackOnlyInBrackets": "(somente rastreamento)",
|
"trackOnlyInBrackets": "(somente rastreamento)",
|
||||||
"searchableInBrackets": "(pesquisável)",
|
"searchableInBrackets": "(pesquisável)",
|
||||||
"appsString": "Apps",
|
"appsString": "Aplicativos",
|
||||||
"noApps": "Nenhum app",
|
"noApps": "Nenhum app",
|
||||||
"noAppsForFilter": "Nenhum app pro filtro",
|
"noAppsForFilter": "Nenhum app pro filtro",
|
||||||
"byX": "Por {}",
|
"byX": "Por {}",
|
||||||
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Configurações de app da comunidade",
|
"crowdsourcedConfigsShort": "Configurações de app da comunidade",
|
||||||
"allowInsecure": "Permitir solicitações de HTTP inseguras",
|
"allowInsecure": "Permitir solicitações de HTTP inseguras",
|
||||||
"stayOneVersionBehind": "Ficar uma versão antes da mais recente",
|
"stayOneVersionBehind": "Ficar uma versão antes da mais recente",
|
||||||
|
"useFirstApkOfVersion": "Seleção automática do primeiro de vários APKs",
|
||||||
"refreshBeforeDownload": "Atualizar detalhes do app antes de baixar",
|
"refreshBeforeDownload": "Atualizar detalhes do app antes de baixar",
|
||||||
"tencentAppStore": "Loja de Apps da Tencent",
|
"tencentAppStore": "Loja de Apps da Tencent",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "Vivo App Store (CN)",
|
||||||
"name": "Nome",
|
"name": "Nome",
|
||||||
"smartname": "Nome (inteligente)",
|
"smartname": "Nome (inteligente)",
|
||||||
"sortMethod": "Método de ordenação",
|
"sortMethod": "Método de ordenação",
|
||||||
"welcome": "Boas vindas",
|
"welcome": "Boas vindas",
|
||||||
"documentationLinksNote": "A página do Obtainium no GitHub visível abaixo contém links de vídeos, artigos, discussões, e outros recursos que podem te ajudar ao usar o app.",
|
"documentationLinksNote": "A página do Obtainium no GitHub visível abaixo contém links de vídeos, artigos, discussões, e outros recursos que podem te ajudar ao usar o app.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Observe que os downloads em segundo plano podem funcionar de forma mais confiável se você desativar as otimizações de bateria do sistema operacional para o Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Remover app?",
|
"one": "Remover app?",
|
||||||
"other": "Remover apps?"
|
"other": "Remover apps?"
|
||||||
@@ -340,8 +342,8 @@
|
|||||||
"other": "A busca de atualizações em segundo plano encontrou um {}, será agendado uma nova tentativa em {} minutos"
|
"other": "A busca de atualizações em segundo plano encontrou um {}, será agendado uma nova tentativa em {} minutos"
|
||||||
},
|
},
|
||||||
"bgCheckFoundUpdatesWillNotifyIfNeeded": {
|
"bgCheckFoundUpdatesWillNotifyIfNeeded": {
|
||||||
"one": "BG update checking found {} update - will notify user if needed",
|
"one": "Verificação da atualização do BG encontrada {} atualização - notificará o usuário se necessário",
|
||||||
"other": "BG update checking found {} updates - will notify user if needed"
|
"other": "Verificação de atualização do BG encontrou atualizações {} - notificará o usuário se necessário"
|
||||||
},
|
},
|
||||||
"apps": {
|
"apps": {
|
||||||
"one": "{} app",
|
"one": "{} app",
|
||||||
@@ -364,8 +366,8 @@
|
|||||||
"other": "{} dias"
|
"other": "{} dias"
|
||||||
},
|
},
|
||||||
"clearedNLogsBeforeXAfterY": {
|
"clearedNLogsBeforeXAfterY": {
|
||||||
"one": "Cleared {n} log (before = {before}, after = {after})",
|
"one": "Limpou {n} registros (before = {before}, after = {after})",
|
||||||
"other": "Cleared {n} logs (before = {before}, after = {after})"
|
"other": "Limpou {n} registros (antes = {before}, depois = {after})"
|
||||||
},
|
},
|
||||||
"xAndNMoreUpdatesAvailable": {
|
"xAndNMoreUpdatesAvailable": {
|
||||||
"one": "{} e mais 1 app têm atualizações.",
|
"one": "{} e mais 1 app têm atualizações.",
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Configurações de aplicações com base em crowdsourcing",
|
"crowdsourcedConfigsShort": "Configurações de aplicações com base em crowdsourcing",
|
||||||
"allowInsecure": "Permitir pedidos HTTP inseguros",
|
"allowInsecure": "Permitir pedidos HTTP inseguros",
|
||||||
"stayOneVersionBehind": "Manter-se uma versão atrás da mais recente",
|
"stayOneVersionBehind": "Manter-se uma versão atrás da mais recente",
|
||||||
|
"useFirstApkOfVersion": "Seleção automática do primeiro de vários APKs",
|
||||||
"refreshBeforeDownload": "Atualizar os detalhes da aplicação antes da transferência",
|
"refreshBeforeDownload": "Atualizar os detalhes da aplicação antes da transferência",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Nome",
|
"name": "Nome",
|
||||||
"smartname": "Nome (Smart)",
|
"smartname": "Nome (Smart)",
|
||||||
"sortMethod": "Método de ordenação",
|
"sortMethod": "Método de ordenação",
|
||||||
"welcome": "Bem-vindo",
|
"welcome": "Bem-vindo",
|
||||||
"documentationLinksNote": "A página do Obtainium no GitHub com a ligação abaixo contém ligações para vídeos, artigos, discussões e outros recursos que o ajudarão a compreender como utilizar a aplicação.",
|
"documentationLinksNote": "A página do Obtainium no GitHub com a ligação abaixo contém ligações para vídeos, artigos, discussões e outros recursos que o ajudarão a compreender como utilizar a aplicação.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Note que os downloads em segundo plano podem funcionar de forma mais fiável se desativar as optimizações da bateria do SO para o Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Remover aplicativo?",
|
"one": "Remover aplicativo?",
|
||||||
"other": "Remover aplicativos?"
|
"other": "Remover aplicativos?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Конфиги приложений с помощью краудсорсинга",
|
"crowdsourcedConfigsShort": "Конфиги приложений с помощью краудсорсинга",
|
||||||
"allowInsecure": "Разрешить небезопасные HTTP-запросы",
|
"allowInsecure": "Разрешить небезопасные HTTP-запросы",
|
||||||
"stayOneVersionBehind": "Не отставайте от последней версии",
|
"stayOneVersionBehind": "Не отставайте от последней версии",
|
||||||
|
"useFirstApkOfVersion": "Автоматический выбор первого из нескольких APK",
|
||||||
"refreshBeforeDownload": "Обновляйте информацию о приложении перед загрузкой",
|
"refreshBeforeDownload": "Обновляйте информацию о приложении перед загрузкой",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Имя",
|
"name": "Имя",
|
||||||
"smartname": "Имя (умное)",
|
"smartname": "Имя (умное)",
|
||||||
"sortMethod": "Метод сортировки",
|
"sortMethod": "Метод сортировки",
|
||||||
"welcome": "Добро пожаловать",
|
"welcome": "Добро пожаловать",
|
||||||
"documentationLinksNote": "На странице Obtainium GitHub, ссылка на которую приведена ниже, содержатся ссылки на видео, статьи, обсуждения и другие ресурсы, которые помогут вам понять, как пользоваться приложением.",
|
"documentationLinksNote": "На странице Obtainium GitHub, ссылка на которую приведена ниже, содержатся ссылки на видео, статьи, обсуждения и другие ресурсы, которые помогут вам понять, как пользоваться приложением.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Обратите внимание, что фоновая загрузка может работать более надежно, если отключить оптимизацию батареи ОС для Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Удалить приложение?",
|
"one": "Удалить приложение?",
|
||||||
"other": "Удалить приложения?"
|
"other": "Удалить приложения?"
|
||||||
|
@@ -16,6 +16,10 @@ const neverAutoTranslate = {
|
|||||||
placeholder: ['pl'],
|
placeholder: ['pl'],
|
||||||
importExport: ['fr'],
|
importExport: ['fr'],
|
||||||
url: ['fr'],
|
url: ['fr'],
|
||||||
|
vivoAppStore: ['cs', 'ja', 'ko'],
|
||||||
|
coolapk: ['ja'],
|
||||||
|
obtainiumImport: ['nl'],
|
||||||
|
appLogs: ['nl'],
|
||||||
tencentAppStore: ['*']
|
tencentAppStore: ['*']
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Appkonfigurationer med hjälp av crowdsourcing",
|
"crowdsourcedConfigsShort": "Appkonfigurationer med hjälp av crowdsourcing",
|
||||||
"allowInsecure": "Tillåt osäkra HTTP-förfrågningar",
|
"allowInsecure": "Tillåt osäkra HTTP-förfrågningar",
|
||||||
"stayOneVersionBehind": "Håll dig en version bakom den senaste",
|
"stayOneVersionBehind": "Håll dig en version bakom den senaste",
|
||||||
|
"useFirstApkOfVersion": "Välj automatiskt den första av flera APK:er",
|
||||||
"refreshBeforeDownload": "Uppdatera appdetaljerna före nedladdning",
|
"refreshBeforeDownload": "Uppdatera appdetaljerna före nedladdning",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Namn",
|
"name": "Namn",
|
||||||
"smartname": "Namn (Smart)",
|
"smartname": "Namn (Smart)",
|
||||||
"sortMethod": "Sorteringsmetod",
|
"sortMethod": "Sorteringsmetod",
|
||||||
"welcome": "Välkommen",
|
"welcome": "Välkommen",
|
||||||
"documentationLinksNote": "Obtainium GitHub-sidan som länkas nedan innehåller länkar till videor, artiklar, diskussioner och andra resurser som hjälper dig att förstå hur du använder appen.",
|
"documentationLinksNote": "Obtainium GitHub-sidan som länkas nedan innehåller länkar till videor, artiklar, diskussioner och andra resurser som hjälper dig att förstå hur du använder appen.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Observera att nedladdningar i bakgrunden kan fungera mer tillförlitligt om du inaktiverar OS-batterioptimeringar för Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Ta Bort App?",
|
"one": "Ta Bort App?",
|
||||||
"other": "Ta Bort Appar?"
|
"other": "Ta Bort Appar?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Kitle Kaynaklı Uygulama Yapılandırmaları",
|
"crowdsourcedConfigsShort": "Kitle Kaynaklı Uygulama Yapılandırmaları",
|
||||||
"allowInsecure": "Güvensiz HTTP isteklerine izin ver",
|
"allowInsecure": "Güvensiz HTTP isteklerine izin ver",
|
||||||
"stayOneVersionBehind": "En son sürümün bir sürüm gerisinde kalın",
|
"stayOneVersionBehind": "En son sürümün bir sürüm gerisinde kalın",
|
||||||
|
"useFirstApkOfVersion": "Birden fazla APK arasından ilkini otomatik seçme",
|
||||||
"refreshBeforeDownload": "İndirmeden önce uygulama ayrıntılarını yenileyin",
|
"refreshBeforeDownload": "İndirmeden önce uygulama ayrıntılarını yenileyin",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "İsim",
|
"name": "İsim",
|
||||||
"smartname": "İsim (Akıllı)",
|
"smartname": "İsim (Akıllı)",
|
||||||
"sortMethod": "Sıralama Yöntemi",
|
"sortMethod": "Sıralama Yöntemi",
|
||||||
"welcome": "Hoş geldiniz",
|
"welcome": "Hoş geldiniz",
|
||||||
"documentationLinksNote": "Aşağıda bağlantısı verilen Obtainium GitHub sayfası, uygulamayı nasıl kullanacağınızı anlamanıza yardımcı olacak videolara, makalelere, tartışmalara ve diğer kaynaklara bağlantılar içerir.",
|
"documentationLinksNote": "Aşağıda bağlantısı verilen Obtainium GitHub sayfası, uygulamayı nasıl kullanacağınızı anlamanıza yardımcı olacak videolara, makalelere, tartışmalara ve diğer kaynaklara bağlantılar içerir.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Obtainium için işletim sistemi pil optimizasyonlarını devre dışı bırakırsanız arka planda indirmelerin daha güvenilir şekilde çalışabileceğini unutmayın.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Uygulamayı Kaldır?",
|
"one": "Uygulamayı Kaldır?",
|
||||||
"other": "Uygulamaları Kaldır?"
|
"other": "Uygulamaları Kaldır?"
|
||||||
|
@@ -318,15 +318,17 @@
|
|||||||
"crowdsourcedConfigsShort": "Налаштування краудсорсингових додатків",
|
"crowdsourcedConfigsShort": "Налаштування краудсорсингових додатків",
|
||||||
"allowInsecure": "Дозволити незахищені HTTP-запити",
|
"allowInsecure": "Дозволити незахищені HTTP-запити",
|
||||||
"stayOneVersionBehind": "Залишайтеся на одну версію актуальнішою",
|
"stayOneVersionBehind": "Залишайтеся на одну версію актуальнішою",
|
||||||
|
"useFirstApkOfVersion": "Автоматичний вибір першого з декількох APK",
|
||||||
"refreshBeforeDownload": "Оновіть інформацію про програму перед завантаженням",
|
"refreshBeforeDownload": "Оновіть інформацію про програму перед завантаженням",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Ім'я",
|
"name": "Ім'я",
|
||||||
"smartname": "Ім'я (Smart)",
|
"smartname": "Ім'я (Smart)",
|
||||||
"sortMethod": "Метод сортування",
|
"sortMethod": "Метод сортування",
|
||||||
"welcome": "Ласкаво просимо.",
|
"welcome": "Ласкаво просимо.",
|
||||||
"documentationLinksNote": "Сторінка Obtainium на GitHub, посилання на яку наведено нижче, містить посилання на відео, статті, дискусії та інші ресурси, які допоможуть вам зрозуміти, як користуватися додатком.",
|
"documentationLinksNote": "Сторінка Obtainium на GitHub, посилання на яку наведено нижче, містить посилання на відео, статті, дискусії та інші ресурси, які допоможуть вам зрозуміти, як користуватися додатком.",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "Зауважте, що фонові завантаження можуть працювати надійніше, якщо ви вимкнете оптимізацію батареї ОС для Obtainium.",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "Видалити застосунок?",
|
"one": "Видалити застосунок?",
|
||||||
"other": "Видалити застосунки?"
|
"other": "Видалити застосунки?"
|
||||||
|
@@ -318,9 +318,11 @@
|
|||||||
"crowdsourcedConfigsShort": "Crowdsourced App Configurations",
|
"crowdsourcedConfigsShort": "Crowdsourced App Configurations",
|
||||||
"allowInsecure": "Allow insecure HTTP requests",
|
"allowInsecure": "Allow insecure HTTP requests",
|
||||||
"stayOneVersionBehind": "Stay one version behind latest",
|
"stayOneVersionBehind": "Stay one version behind latest",
|
||||||
|
"useFirstApkOfVersion": "Auto-select first of multiple APKs",
|
||||||
"refreshBeforeDownload": "Refresh app details before download",
|
"refreshBeforeDownload": "Refresh app details before download",
|
||||||
"tencentAppStore": "Tencent App Store",
|
"tencentAppStore": "Tencent App Store",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "Name",
|
"name": "Name",
|
||||||
"smartname": "Name (Smart)",
|
"smartname": "Name (Smart)",
|
||||||
"sortMethod": "Sort Method",
|
"sortMethod": "Sort Method",
|
||||||
|
@@ -318,9 +318,11 @@
|
|||||||
"crowdsourcedConfigsShort": "群眾外包的應用程式設定",
|
"crowdsourcedConfigsShort": "群眾外包的應用程式設定",
|
||||||
"allowInsecure": "允許不安全的 HTTP 請求",
|
"allowInsecure": "允許不安全的 HTTP 請求",
|
||||||
"stayOneVersionBehind": "保持比最新版本落後一個版本",
|
"stayOneVersionBehind": "保持比最新版本落後一個版本",
|
||||||
|
"useFirstApkOfVersion": "Auto-select first of multiple APKs",
|
||||||
"refreshBeforeDownload": "下載前刷新應用程式詳細資訊",
|
"refreshBeforeDownload": "下載前刷新應用程式詳細資訊",
|
||||||
"tencentAppStore": "騰訊應用寶",
|
"tencentAppStore": "騰訊應用寶",
|
||||||
"coolApk": "CoolApk",
|
"coolApk": "CoolApk",
|
||||||
|
"vivoAppStore": "vivo App Store (CN)",
|
||||||
"name": "名稱",
|
"name": "名稱",
|
||||||
"smartname": "名稱(智慧)",
|
"smartname": "名稱(智慧)",
|
||||||
"sortMethod": "排序方式",
|
"sortMethod": "排序方式",
|
||||||
|
@@ -318,6 +318,7 @@
|
|||||||
"crowdsourcedConfigsShort": "众包应用程序配置",
|
"crowdsourcedConfigsShort": "众包应用程序配置",
|
||||||
"allowInsecure": "允许不安全的 HTTP 请求",
|
"allowInsecure": "允许不安全的 HTTP 请求",
|
||||||
"stayOneVersionBehind": "比最新版本晚一个版本",
|
"stayOneVersionBehind": "比最新版本晚一个版本",
|
||||||
|
"useFirstApkOfVersion": "从多个 APK 中自动选择第一个",
|
||||||
"refreshBeforeDownload": "下载前刷新应用程序详细信息",
|
"refreshBeforeDownload": "下载前刷新应用程序详细信息",
|
||||||
"tencentAppStore": "腾讯应用宝",
|
"tencentAppStore": "腾讯应用宝",
|
||||||
"coolApk": "酷安",
|
"coolApk": "酷安",
|
||||||
@@ -327,7 +328,7 @@
|
|||||||
"sortMethod": "排序方法",
|
"sortMethod": "排序方法",
|
||||||
"welcome": "欢迎光临",
|
"welcome": "欢迎光临",
|
||||||
"documentationLinksNote": "下面链接的 Obtainium GitHub 页面包含视频、文章、讨论和其他资源的链接,可帮助您了解如何使用该应用程序。",
|
"documentationLinksNote": "下面链接的 Obtainium GitHub 页面包含视频、文章、讨论和其他资源的链接,可帮助您了解如何使用该应用程序。",
|
||||||
"batteryOptimizationNote": "Note that background downloads may work more reliably if you disable OS battery optimizations for Obtainium.",
|
"batteryOptimizationNote": "请注意,如果为 Obtainium 禁用操作系统电池优化功能,后台下载可能会更稳定。",
|
||||||
"removeAppQuestion": {
|
"removeAppQuestion": {
|
||||||
"one": "是否删除应用?",
|
"one": "是否删除应用?",
|
||||||
"other": "是否删除应用?"
|
"other": "是否删除应用?"
|
||||||
|
86
docker/Dockerfile
Normal file
86
docker/Dockerfile
Normal file
@@ -0,0 +1,86 @@
|
|||||||
|
FROM ubuntu:22.04
|
||||||
|
|
||||||
|
ENV DEBIAN_FRONTEND noninteractive
|
||||||
|
ENV ANDROID_SDK_ROOT /opt/android-sdk-linux
|
||||||
|
ENV PATH "${PATH}:/opt/flutter/bin:/root/.pub-cache/bin:${ANDROID_SDK_ROOT}/cmdline-tools/latest/bin:/opt/android-sdk-linux/platform-tools"
|
||||||
|
|
||||||
|
ENV HOME=/root
|
||||||
|
|
||||||
|
# Prereqs
|
||||||
|
RUN \
|
||||||
|
apt-get update &&\
|
||||||
|
apt-get install -y --no-install-recommends \
|
||||||
|
bash \
|
||||||
|
curl \
|
||||||
|
file \
|
||||||
|
git 2.x \
|
||||||
|
unzip \
|
||||||
|
xz-utils \
|
||||||
|
zip \
|
||||||
|
libglu1-mesa \
|
||||||
|
libxi-dev \
|
||||||
|
libxmu-dev \
|
||||||
|
libglu1-mesa-dev \
|
||||||
|
git-lfs \
|
||||||
|
openssl \
|
||||||
|
wget
|
||||||
|
|
||||||
|
# Build prereqs
|
||||||
|
RUN \
|
||||||
|
apt-get install -y \
|
||||||
|
cmake curl git wget unzip libgconf-2-4 gdb libstdc++6 libglu1-mesa fonts-droid-fallback lib32stdc++6 python3 sed \
|
||||||
|
cmake ninja-build build-essential libgl1-mesa-dev libegl1-mesa-dev libgles2-mesa-dev clang pkg-config libgtk-3-dev \
|
||||||
|
liblzma-dev libmount-dev libblkid-dev libgcrypt20-dev libgpg-error-dev libssl-dev libpng-dev libjpeg-dev \
|
||||||
|
libtiff-dev libgif-dev libgtk-3-dev
|
||||||
|
|
||||||
|
# Android SDK prequisites
|
||||||
|
# https://developer.android.com/studio#command-tools
|
||||||
|
RUN \
|
||||||
|
apt-get install -y --no-install-recommends \
|
||||||
|
git \
|
||||||
|
git-lfs \
|
||||||
|
openssl \
|
||||||
|
wget \
|
||||||
|
unzip
|
||||||
|
|
||||||
|
# Android SDK
|
||||||
|
RUN \
|
||||||
|
wget --quiet https://dl.google.com/android/repository/commandlinetools-linux-13114758_latest.zip -O /tmp/tools.zip && \
|
||||||
|
mkdir -p ${ANDROID_SDK_ROOT}/cmdline-tools && \
|
||||||
|
unzip -q /tmp/tools.zip -d ${ANDROID_SDK_ROOT}/cmdline-tools && \
|
||||||
|
mv ${ANDROID_SDK_ROOT}/cmdline-tools/cmdline-tools ${ANDROID_SDK_ROOT}/cmdline-tools/latest && \
|
||||||
|
rm -v /tmp/tools.zip && \
|
||||||
|
mkdir -p /root/.android/ && touch /root/.android/repositories.cfg &&\
|
||||||
|
apt-get install -y --no-install-recommends openjdk-17-jdk openjdk-17-jre &&\
|
||||||
|
yes | sdkmanager --licenses &&\
|
||||||
|
sdkmanager --update
|
||||||
|
|
||||||
|
# Platform tools
|
||||||
|
# Get latest with sdkmanager --list
|
||||||
|
RUN sdkmanager --install "build-tools;33.0.1"
|
||||||
|
RUN sdkmanager --install "ndk;26.3.11579264"
|
||||||
|
RUN sdkmanager --install "cmake;4.0.2"
|
||||||
|
RUN sdkmanager --install platform-tools
|
||||||
|
RUN sdkmanager --install emulator
|
||||||
|
RUN sdkmanager --install tools
|
||||||
|
RUN sdkmanager --install "platforms;android-28"
|
||||||
|
RUN sdkmanager --install "platforms;android-31"
|
||||||
|
RUN sdkmanager --install "platforms;android-32"
|
||||||
|
RUN sdkmanager --install "platforms;android-33"
|
||||||
|
RUN sdkmanager --install "platforms;android-34"
|
||||||
|
RUN sdkmanager --install "platforms;android-35"
|
||||||
|
|
||||||
|
# Flutter
|
||||||
|
ARG DEV_UID=0
|
||||||
|
RUN \
|
||||||
|
wget --quiet https://storage.googleapis.com/flutter_infra_release/releases/stable/linux/flutter_linux_3.29.3-stable.tar.xz -O /tmp/flutter.tar.xz &&\
|
||||||
|
mkdir -p /opt &&\
|
||||||
|
cd /opt &&\
|
||||||
|
tar xf /tmp/flutter.tar.xz &&\
|
||||||
|
rm /tmp/flutter.tar.xz &&\
|
||||||
|
git config --global --add safe.directory /opt/flutter &&\
|
||||||
|
dart pub global activate cider &&\
|
||||||
|
chown -R ${DEV_UID} /opt/flutter
|
||||||
|
RUN flutter --disable-analytics
|
||||||
|
RUN flutter upgrade
|
||||||
|
RUN chmod a+w /opt/flutter/packages -R
|
21
docker/builder.sh
Executable file
21
docker/builder.sh
Executable file
@@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
||||||
|
|
||||||
|
cd ${SCRIPT_DIR}/..
|
||||||
|
mkdir -p ./data/home
|
||||||
|
docker run \
|
||||||
|
--rm \
|
||||||
|
-ti \
|
||||||
|
--net host \
|
||||||
|
-v "${PWD}/../:${PWD}/../":z \
|
||||||
|
-w "${PWD}" \
|
||||||
|
--name flutter-dev-obtainium \
|
||||||
|
--user $(id -u) \
|
||||||
|
-v ./data/home:/home/${USER}:z \
|
||||||
|
-e USER=${USER} \
|
||||||
|
-e HOME=/home/${USER} \
|
||||||
|
-e ANDROID_USER_HOME=${HOME}/.android \
|
||||||
|
-e GRADLE_USER_HOME=${HOME}/.gradle \
|
||||||
|
-e PS1="${debian_chroot:+($debian_chroot)}${USER}@\h:\w\$ " \
|
||||||
|
flutter-builder-obtainium
|
14
docker/mkbuilder.sh
Executable file
14
docker/mkbuilder.sh
Executable file
@@ -0,0 +1,14 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
SCRIPT_DIR=$( cd -- "$( dirname -- "${BASH_SOURCE[0]}" )" &> /dev/null && pwd )
|
||||||
|
D=$(date +'%Y%m%d.%H%M%S%3N')
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
cd "${SCRIPT_DIR}/.."
|
||||||
|
# Create the builder image
|
||||||
|
docker build \
|
||||||
|
-t flutter-builder-obtainium \
|
||||||
|
-f ./docker/Dockerfile \
|
||||||
|
--build-arg="DEV_UID=$(id -u)" \
|
||||||
|
.
|
@@ -1,24 +1,18 @@
|
|||||||
|
import 'dart:convert';
|
||||||
|
|
||||||
import 'package:device_info_plus/device_info_plus.dart';
|
import 'package:device_info_plus/device_info_plus.dart';
|
||||||
import 'package:easy_localization/easy_localization.dart';
|
import 'package:easy_localization/easy_localization.dart';
|
||||||
import 'package:html/parser.dart';
|
|
||||||
import 'package:obtainium/app_sources/html.dart';
|
|
||||||
import 'package:obtainium/components/generated_form.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';
|
||||||
|
|
||||||
parseDateTimeMMMddCommayyyy(String? dateString) {
|
extension Unique<E, Id> on List<E> {
|
||||||
DateTime? releaseDate;
|
List<E> unique([Id Function(E element)? id, bool inplace = true]) {
|
||||||
try {
|
final ids = Set();
|
||||||
releaseDate = dateString != null
|
var list = inplace ? this : List<E>.from(this);
|
||||||
? DateFormat('MMM dd, yyyy').parse(dateString)
|
list.retainWhere((x) => ids.add(id != null ? id(x) : x as Id));
|
||||||
: null;
|
return list;
|
||||||
releaseDate = dateString != null && releaseDate == null
|
|
||||||
? DateFormat('MMMM dd, yyyy').parse(dateString)
|
|
||||||
: releaseDate;
|
|
||||||
} catch (err) {
|
|
||||||
// ignore
|
|
||||||
}
|
}
|
||||||
return releaseDate;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class APKPure extends AppSource {
|
class APKPure extends AppSource {
|
||||||
@@ -35,6 +29,10 @@ class APKPure extends AppSource {
|
|||||||
[
|
[
|
||||||
GeneratedFormSwitch('stayOneVersionBehind',
|
GeneratedFormSwitch('stayOneVersionBehind',
|
||||||
label: tr('stayOneVersionBehind'), defaultValue: false)
|
label: tr('stayOneVersionBehind'), defaultValue: false)
|
||||||
|
],
|
||||||
|
[
|
||||||
|
GeneratedFormSwitch('useFirstApkOfVersion',
|
||||||
|
label: tr('useFirstApkOfVersion'), defaultValue: true)
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
@@ -65,109 +63,73 @@ class APKPure extends AppSource {
|
|||||||
return Uri.parse(standardUrl).pathSegments.last;
|
return Uri.parse(standardUrl).pathSegments.last;
|
||||||
}
|
}
|
||||||
|
|
||||||
getDetailsForVersionLink(
|
getDetailsForVersion(
|
||||||
String standardUrl,
|
List<Map<String, dynamic>> versionVariants,
|
||||||
String appId,
|
|
||||||
String host,
|
|
||||||
List<String> supportedArchs,
|
List<String> supportedArchs,
|
||||||
String link,
|
|
||||||
Map<String, dynamic> additionalSettings) async {
|
Map<String, dynamic> additionalSettings) async {
|
||||||
var res = await sourceRequest(link, additionalSettings);
|
var apkUrls = versionVariants
|
||||||
if (res.statusCode == 200) {
|
|
||||||
var html = parse(res.body);
|
|
||||||
var apksDiv =
|
|
||||||
html.querySelector('#version-list div div.show-more-content');
|
|
||||||
DateTime? topReleaseDate;
|
|
||||||
var apkUrls = apksDiv
|
|
||||||
?.querySelectorAll('div.group-title')
|
|
||||||
.map((e) {
|
.map((e) {
|
||||||
String architectureString = e.text.trim();
|
String appId = e['package_name'];
|
||||||
if (architectureString.toLowerCase() == 'unlimited' ||
|
String versionCode = e['version_code'];
|
||||||
architectureString.toLowerCase() == 'universal') {
|
|
||||||
architectureString = '';
|
List<String> architectures = e['native_code']?.cast<String>();
|
||||||
|
String architectureString = architectures.join(',');
|
||||||
|
if (architectures.contains("universal") ||
|
||||||
|
architectures.contains("unlimited")) {
|
||||||
|
architectures = [];
|
||||||
}
|
}
|
||||||
List<String> architectures = architectureString
|
|
||||||
.split(',')
|
|
||||||
.map((e) => e.trim())
|
|
||||||
.where((e) => e.isNotEmpty)
|
|
||||||
.toList();
|
|
||||||
// Only take the first APK for each architecture, ignore others for now, for simplicity
|
|
||||||
// Unclear why there can even be multiple APKs for the same version and arch
|
|
||||||
var apkInfo = e.nextElementSibling?.querySelector('div.info');
|
|
||||||
String? versionCode = RegExp('[0-9]+')
|
|
||||||
.firstMatch(
|
|
||||||
apkInfo?.querySelector('div.info-top .code')?.text ??
|
|
||||||
'')
|
|
||||||
?.group(0)
|
|
||||||
?.trim();
|
|
||||||
var types = apkInfo
|
|
||||||
?.querySelectorAll('div.info-top span.tag')
|
|
||||||
.map((e) => e.text.trim())
|
|
||||||
.map((t) => t == 'APKs' ? 'APK' : t) ??
|
|
||||||
[];
|
|
||||||
String type = types.isEmpty ? 'APK' : types.first;
|
|
||||||
String? dateString = apkInfo
|
|
||||||
?.querySelector('div.info-bottom span.time')
|
|
||||||
?.text
|
|
||||||
.trim();
|
|
||||||
DateTime? releaseDate = parseDateTimeMMMddCommayyyy(dateString);
|
|
||||||
if (additionalSettings['autoApkFilterByArch'] == true &&
|
if (additionalSettings['autoApkFilterByArch'] == true &&
|
||||||
architectures.isNotEmpty &&
|
architectures.isNotEmpty &&
|
||||||
architectures
|
architectures.where((a) => supportedArchs.contains(a)).isEmpty) {
|
||||||
.where((a) => supportedArchs.contains(a))
|
return null;
|
||||||
.isEmpty) {
|
|
||||||
return const MapEntry('', '');
|
|
||||||
}
|
}
|
||||||
topReleaseDate ??=
|
|
||||||
releaseDate; // Just use the release date of the first APK in the list as the release date for this version
|
String type = e['asset']['type'];
|
||||||
|
String downloadUri = e['asset']['url'];
|
||||||
|
|
||||||
return MapEntry(
|
return MapEntry(
|
||||||
'$appId-$versionCode-$architectureString.${type.toLowerCase()}',
|
'$appId-$versionCode-$architectureString.${type.toLowerCase()}',
|
||||||
'https://d.${hosts.contains(host) ? 'cdnpure.com' : host}/b/$type/$appId?versionCode=$versionCode');
|
downloadUri);
|
||||||
})
|
})
|
||||||
.where((e) => e.key.isNotEmpty)
|
.nonNulls
|
||||||
.toList() ??
|
.toList()
|
||||||
[];
|
.unique((e) => e.key);
|
||||||
|
|
||||||
if (apkUrls.isEmpty) {
|
if (apkUrls.isEmpty) {
|
||||||
var link =
|
|
||||||
html.querySelector("a.download-start-btn")?.attributes['href'];
|
|
||||||
RegExp downloadLinkRegEx = RegExp(
|
|
||||||
r'^https:\/\/d\.[^/]+\/b\/([^/]+)\/[^/?]+\?versionCode=([0-9]+).$',
|
|
||||||
caseSensitive: false);
|
|
||||||
RegExpMatch? match = downloadLinkRegEx.firstMatch(link ?? '');
|
|
||||||
if (match == null) {
|
|
||||||
throw NoAPKError();
|
throw NoAPKError();
|
||||||
}
|
}
|
||||||
String type = match.group(1)!;
|
|
||||||
String versionCode = match.group(2)!;
|
// get version details from first variant
|
||||||
apkUrls = [
|
var v = versionVariants.first;
|
||||||
MapEntry('$appId-$versionCode-.${type.toLowerCase()}',
|
String version = v['version_name'];
|
||||||
'https://d.${hosts.contains(host) ? 'cdnpure.com' : host}/b/$type/$appId?versionCode=$versionCode')
|
String author = v['developer'];
|
||||||
];
|
String appName = v['title'];
|
||||||
|
DateTime releaseDate = DateTime.parse(v['update_date']);
|
||||||
|
String? changeLog = v['whatsnew'];
|
||||||
|
if (changeLog != null && changeLog.isEmpty) {
|
||||||
|
changeLog = null;
|
||||||
}
|
}
|
||||||
String version = Uri.parse(link).pathSegments.last;
|
|
||||||
String? author;
|
if (additionalSettings['useFirstApkOfVersion'] == true) {
|
||||||
try {
|
apkUrls = [apkUrls.first];
|
||||||
author = html
|
|
||||||
.querySelector('span.info-sdk')
|
|
||||||
?.text
|
|
||||||
.trim()
|
|
||||||
.substring(version.length + 4) ??
|
|
||||||
Uri.parse(standardUrl).pathSegments.reversed.last;
|
|
||||||
} catch (e) {
|
|
||||||
author = html.querySelector('span.info-sdk')?.text.trim() ??
|
|
||||||
Uri.parse(standardUrl).pathSegments.reversed.last;
|
|
||||||
}
|
}
|
||||||
String appName =
|
|
||||||
html.querySelector('h1.info-title')?.text.trim() ?? appId;
|
|
||||||
String? changeLog = html
|
|
||||||
.querySelector('div.module.change-log')
|
|
||||||
?.innerHtml
|
|
||||||
.trim()
|
|
||||||
.replaceAll("<br>", " \n");
|
|
||||||
return APKDetails(version, apkUrls, AppNames(author, appName),
|
return APKDetails(version, apkUrls, AppNames(author, appName),
|
||||||
releaseDate: topReleaseDate, changeLog: changeLog);
|
releaseDate: releaseDate, changeLog: changeLog);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Future<Map<String, String>?> getRequestHeaders(
|
||||||
|
Map<String, dynamic> additionalSettings,
|
||||||
|
{bool forAPKDownload = false}) async {
|
||||||
|
if (forAPKDownload) {
|
||||||
|
return null;
|
||||||
} else {
|
} else {
|
||||||
throw getObtainiumHttpError(res);
|
return {
|
||||||
|
"Ual-Access-Businessid": "projecta",
|
||||||
|
"Ual-Access-ProjectA":
|
||||||
|
'{"device_info":{"os_ver":"${((await DeviceInfoPlugin().androidInfo).version.sdkInt)}"}}',
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -177,41 +139,50 @@ class APKPure extends AppSource {
|
|||||||
Map<String, dynamic> additionalSettings,
|
Map<String, dynamic> additionalSettings,
|
||||||
) async {
|
) async {
|
||||||
String appId = (await tryInferringAppId(standardUrl))!;
|
String appId = (await tryInferringAppId(standardUrl))!;
|
||||||
String host = Uri.parse(standardUrl).host;
|
|
||||||
|
|
||||||
var res0 = await sourceRequest('$standardUrl/versions', additionalSettings);
|
List<String> supportedArchs =
|
||||||
var decodedStandardUrl = standardUrl;
|
(await DeviceInfoPlugin().androidInfo).supportedAbis;
|
||||||
try {
|
|
||||||
decodedStandardUrl = Uri.decodeFull(decodedStandardUrl);
|
// request versions from API
|
||||||
} catch (e) {
|
var res = await sourceRequest(
|
||||||
//
|
"https://tapi.pureapk.com/v3/get_app_his_version?package_name=$appId&hl=en",
|
||||||
|
additionalSettings);
|
||||||
|
if (res.statusCode != 200) {
|
||||||
|
throw getObtainiumHttpError(res);
|
||||||
}
|
}
|
||||||
var versionLinks = await grabLinksCommon(res0, {
|
List<Map<String, dynamic>> apks =
|
||||||
'skipSort': true,
|
jsonDecode(res.body)['version_list'].cast<Map<String, dynamic>>();
|
||||||
'customLinkFilterRegex': '$decodedStandardUrl/download/[^/]+\$'
|
|
||||||
});
|
|
||||||
|
|
||||||
var supportedArchs = (await DeviceInfoPlugin().androidInfo).supportedAbis;
|
// group by version
|
||||||
|
List<List<Map<String, dynamic>>> versions = apks
|
||||||
if (additionalSettings['autoApkFilterByArch'] != true) {
|
.fold<Map<String, List<Map<String, dynamic>>>>({},
|
||||||
// No need to request multiple versions when we're not going to filter them (always pick the top one)
|
(Map<String, List<Map<String, dynamic>>> val,
|
||||||
versionLinks = versionLinks.sublist(0, 1);
|
Map<String, dynamic> element) {
|
||||||
|
String v = element['version_name'];
|
||||||
|
if (!val.containsKey(v)) {
|
||||||
|
val[v] = [];
|
||||||
}
|
}
|
||||||
if (versionLinks.isEmpty) {
|
val[v]?.add(element);
|
||||||
|
return val;
|
||||||
|
})
|
||||||
|
.values
|
||||||
|
.toList();
|
||||||
|
|
||||||
|
if (versions.isEmpty) {
|
||||||
throw NoReleasesError();
|
throw NoReleasesError();
|
||||||
}
|
}
|
||||||
|
|
||||||
for (var i = 0; i < versionLinks.length; i++) {
|
for (var i = 0; i < versions.length; i++) {
|
||||||
var link = versionLinks[i];
|
var v = versions[i];
|
||||||
try {
|
try {
|
||||||
if (i == 0 && additionalSettings['stayOneVersionBehind'] == true) {
|
if (i == 0 && additionalSettings['stayOneVersionBehind'] == true) {
|
||||||
throw NoReleasesError();
|
throw NoReleasesError();
|
||||||
}
|
}
|
||||||
return await getDetailsForVersionLink(standardUrl, appId, host,
|
return await getDetailsForVersion(
|
||||||
supportedArchs, link.key, additionalSettings);
|
v, supportedArchs, additionalSettings);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
if (additionalSettings['fallbackToOlderReleases'] != true ||
|
if (additionalSettings['fallbackToOlderReleases'] != true ||
|
||||||
i == versionLinks.length - 1) {
|
i == versions.length - 1) {
|
||||||
rethrow;
|
rethrow;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -33,6 +33,16 @@ class RuStore extends AppSource {
|
|||||||
return Uri.parse(standardUrl).pathSegments.last;
|
return Uri.parse(standardUrl).pathSegments.last;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<String> decodeString(String str) async {
|
||||||
|
try {
|
||||||
|
return (await CharsetDetector.autoDecode(
|
||||||
|
Uint8List.fromList(str.codeUnits)))
|
||||||
|
.string;
|
||||||
|
} catch (e) {
|
||||||
|
return str;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<APKDetails> getLatestAPKDetails(
|
Future<APKDetails> getLatestAPKDetails(
|
||||||
String standardUrl,
|
String standardUrl,
|
||||||
@@ -73,17 +83,9 @@ class RuStore extends AppSource {
|
|||||||
throw NoAPKError();
|
throw NoAPKError();
|
||||||
}
|
}
|
||||||
|
|
||||||
appName = (await CharsetDetector.autoDecode(
|
appName = await decodeString(appName);
|
||||||
Uint8List.fromList(appName.codeUnits)))
|
author = await decodeString(author);
|
||||||
.string;
|
changeLog = changeLog != null ? await decodeString(changeLog) : null;
|
||||||
author =
|
|
||||||
(await CharsetDetector.autoDecode(Uint8List.fromList(author.codeUnits)))
|
|
||||||
.string;
|
|
||||||
changeLog = changeLog != null
|
|
||||||
? (await CharsetDetector.autoDecode(
|
|
||||||
Uint8List.fromList(changeLog.codeUnits)))
|
|
||||||
.string
|
|
||||||
: null;
|
|
||||||
|
|
||||||
return APKDetails(
|
return APKDetails(
|
||||||
version,
|
version,
|
||||||
|
@@ -1,9 +1,23 @@
|
|||||||
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:obtainium/app_sources/apkpure.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';
|
||||||
|
|
||||||
|
parseDateTimeMMMddCommayyyy(String? dateString) {
|
||||||
|
DateTime? releaseDate;
|
||||||
|
try {
|
||||||
|
releaseDate = dateString != null
|
||||||
|
? DateFormat('MMM dd, yyyy').parse(dateString)
|
||||||
|
: null;
|
||||||
|
releaseDate = dateString != null && releaseDate == null
|
||||||
|
? DateFormat('MMMM dd, yyyy').parse(dateString)
|
||||||
|
: releaseDate;
|
||||||
|
} catch (err) {
|
||||||
|
// ignore
|
||||||
|
}
|
||||||
|
return releaseDate;
|
||||||
|
}
|
||||||
|
|
||||||
class Uptodown extends AppSource {
|
class Uptodown extends AppSource {
|
||||||
Uptodown() {
|
Uptodown() {
|
||||||
hosts = ['uptodown.com'];
|
hosts = ['uptodown.com'];
|
||||||
|
@@ -48,6 +48,7 @@ List<MapEntry<Locale, String>> supportedLocales = const [
|
|||||||
MapEntry(Locale('in'), 'Bahasa Indonesia'),
|
MapEntry(Locale('in'), 'Bahasa Indonesia'),
|
||||||
MapEntry(Locale('ko'), '한국어'),
|
MapEntry(Locale('ko'), '한국어'),
|
||||||
MapEntry(Locale('ca'), 'Català'),
|
MapEntry(Locale('ca'), 'Català'),
|
||||||
|
MapEntry(Locale('ar'), 'العربية'),
|
||||||
];
|
];
|
||||||
const fallbackLocale = Locale('en');
|
const fallbackLocale = Locale('en');
|
||||||
const localeDir = 'assets/translations';
|
const localeDir = 'assets/translations';
|
||||||
|
@@ -1203,10 +1203,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: webview_flutter_android
|
name: webview_flutter_android
|
||||||
sha256: "5ece28a317a9f76ad5ee17c78dbacc8a491687cec85ee19c1643761bf8d678ef"
|
sha256: f6e6afef6e234801da77170f7a1847ded8450778caf2fe13979d140484be3678
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "4.6.0"
|
version: "4.7.0"
|
||||||
webview_flutter_platform_interface:
|
webview_flutter_platform_interface:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -1219,10 +1219,10 @@ packages:
|
|||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: webview_flutter_wkwebview
|
name: webview_flutter_wkwebview
|
||||||
sha256: "6af7d1908c9c89311c2dffcc2c9b51b88a6f055ba16fa0aa8a04cbb1c3afc9ce"
|
sha256: a3d461fe3467014e05f3ac4962e5fdde2a4bf44c561cb53e9ae5c586600fdbc3
|
||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "3.21.0"
|
version: "3.22.0"
|
||||||
win32:
|
win32:
|
||||||
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.1.53+2310
|
version: 1.1.55+2312
|
||||||
|
|
||||||
environment:
|
environment:
|
||||||
sdk: ^3.6.0
|
sdk: ^3.6.0
|
||||||
|
Reference in New Issue
Block a user