Clean up pre-Lollipop checks
This commit is contained in:
parent
7cb137ae8d
commit
99104fc11d
|
@ -1,7 +1,6 @@
|
||||||
package org.schabi.newpipe;
|
package org.schabi.newpipe;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Build;
|
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
@ -14,33 +13,18 @@ import org.schabi.newpipe.extractor.downloader.Response;
|
||||||
import org.schabi.newpipe.extractor.exceptions.ReCaptchaException;
|
import org.schabi.newpipe.extractor.exceptions.ReCaptchaException;
|
||||||
import org.schabi.newpipe.util.CookieUtils;
|
import org.schabi.newpipe.util.CookieUtils;
|
||||||
import org.schabi.newpipe.util.InfoCache;
|
import org.schabi.newpipe.util.InfoCache;
|
||||||
import org.schabi.newpipe.util.TLSSocketFactoryCompat;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.security.KeyManagementException;
|
|
||||||
import java.security.KeyStore;
|
|
||||||
import java.security.KeyStoreException;
|
|
||||||
import java.security.NoSuchAlgorithmException;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
import javax.net.ssl.SSLSocketFactory;
|
|
||||||
import javax.net.ssl.TrustManager;
|
|
||||||
import javax.net.ssl.TrustManagerFactory;
|
|
||||||
import javax.net.ssl.X509TrustManager;
|
|
||||||
|
|
||||||
import okhttp3.CipherSuite;
|
|
||||||
import okhttp3.ConnectionSpec;
|
|
||||||
import okhttp3.OkHttpClient;
|
import okhttp3.OkHttpClient;
|
||||||
import okhttp3.RequestBody;
|
import okhttp3.RequestBody;
|
||||||
import okhttp3.ResponseBody;
|
import okhttp3.ResponseBody;
|
||||||
|
|
||||||
import static org.schabi.newpipe.MainActivity.DEBUG;
|
|
||||||
|
|
||||||
public final class DownloaderImpl extends Downloader {
|
public final class DownloaderImpl extends Downloader {
|
||||||
public static final String USER_AGENT
|
public static final String USER_AGENT
|
||||||
= "Mozilla/5.0 (Windows NT 10.0; rv:91.0) Gecko/20100101 Firefox/91.0";
|
= "Mozilla/5.0 (Windows NT 10.0; rv:91.0) Gecko/20100101 Firefox/91.0";
|
||||||
|
@ -54,9 +38,6 @@ public final class DownloaderImpl extends Downloader {
|
||||||
private final OkHttpClient client;
|
private final OkHttpClient client;
|
||||||
|
|
||||||
private DownloaderImpl(final OkHttpClient.Builder builder) {
|
private DownloaderImpl(final OkHttpClient.Builder builder) {
|
||||||
if (Build.VERSION.SDK_INT == Build.VERSION_CODES.KITKAT) {
|
|
||||||
enableModernTLS(builder);
|
|
||||||
}
|
|
||||||
this.client = builder
|
this.client = builder
|
||||||
.readTimeout(30, TimeUnit.SECONDS)
|
.readTimeout(30, TimeUnit.SECONDS)
|
||||||
// .cache(new Cache(new File(context.getExternalCacheDir(), "okhttp"),
|
// .cache(new Cache(new File(context.getExternalCacheDir(), "okhttp"),
|
||||||
|
@ -81,55 +62,6 @@ public final class DownloaderImpl extends Downloader {
|
||||||
return instance;
|
return instance;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Enable TLS 1.2 and 1.1 on Android Kitkat. This function is mostly taken
|
|
||||||
* from the documentation of OkHttpClient.Builder.sslSocketFactory(_,_).
|
|
||||||
* <p>
|
|
||||||
* If there is an error, the function will safely fall back to doing nothing
|
|
||||||
* and printing the error to the console.
|
|
||||||
* </p>
|
|
||||||
*
|
|
||||||
* @param builder The HTTPClient Builder on which TLS is enabled on (will be modified in-place)
|
|
||||||
*/
|
|
||||||
private static void enableModernTLS(final OkHttpClient.Builder builder) {
|
|
||||||
try {
|
|
||||||
// get the default TrustManager
|
|
||||||
final TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(
|
|
||||||
TrustManagerFactory.getDefaultAlgorithm());
|
|
||||||
trustManagerFactory.init((KeyStore) null);
|
|
||||||
final TrustManager[] trustManagers = trustManagerFactory.getTrustManagers();
|
|
||||||
if (trustManagers.length != 1 || !(trustManagers[0] instanceof X509TrustManager)) {
|
|
||||||
throw new IllegalStateException("Unexpected default trust managers:"
|
|
||||||
+ Arrays.toString(trustManagers));
|
|
||||||
}
|
|
||||||
final X509TrustManager trustManager = (X509TrustManager) trustManagers[0];
|
|
||||||
|
|
||||||
// insert our own TLSSocketFactory
|
|
||||||
final SSLSocketFactory sslSocketFactory = TLSSocketFactoryCompat.getInstance();
|
|
||||||
|
|
||||||
builder.sslSocketFactory(sslSocketFactory, trustManager);
|
|
||||||
|
|
||||||
// This will try to enable all modern CipherSuites(+2 more)
|
|
||||||
// that are supported on the device.
|
|
||||||
// Necessary because some servers (e.g. Framatube.org)
|
|
||||||
// don't support the old cipher suites.
|
|
||||||
// https://github.com/square/okhttp/issues/4053#issuecomment-402579554
|
|
||||||
final List<CipherSuite> cipherSuites =
|
|
||||||
new ArrayList<>(ConnectionSpec.MODERN_TLS.cipherSuites());
|
|
||||||
cipherSuites.add(CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA);
|
|
||||||
cipherSuites.add(CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA);
|
|
||||||
final ConnectionSpec legacyTLS = new ConnectionSpec.Builder(ConnectionSpec.MODERN_TLS)
|
|
||||||
.cipherSuites(cipherSuites.toArray(new CipherSuite[0]))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
builder.connectionSpecs(Arrays.asList(legacyTLS, ConnectionSpec.CLEARTEXT));
|
|
||||||
} catch (final KeyManagementException | NoSuchAlgorithmException | KeyStoreException e) {
|
|
||||||
if (DEBUG) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public String getCookies(final String url) {
|
public String getCookies(final String url) {
|
||||||
final List<String> resultCookies = new ArrayList<>();
|
final List<String> resultCookies = new ArrayList<>();
|
||||||
if (url.contains(YOUTUBE_DOMAIN)) {
|
if (url.contains(YOUTUBE_DOMAIN)) {
|
||||||
|
|
|
@ -3,7 +3,6 @@ package org.schabi.newpipe;
|
||||||
import android.annotation.SuppressLint;
|
import android.annotation.SuppressLint;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
|
||||||
import org.schabi.newpipe.util.NavigationHelper;
|
import org.schabi.newpipe.util.NavigationHelper;
|
||||||
|
@ -44,11 +43,7 @@ public class ExitActivity extends Activity {
|
||||||
protected void onCreate(final Bundle savedInstanceState) {
|
protected void onCreate(final Bundle savedInstanceState) {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
finishAndRemoveTask();
|
finishAndRemoveTask();
|
||||||
} else {
|
|
||||||
finish();
|
|
||||||
}
|
|
||||||
|
|
||||||
NavigationHelper.restartApp(this);
|
NavigationHelper.restartApp(this);
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,7 +28,6 @@ import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
import android.content.IntentFilter;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.content.pm.PackageManager;
|
import android.content.pm.PackageManager;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
|
@ -86,7 +85,6 @@ import org.schabi.newpipe.util.PermissionHelper;
|
||||||
import org.schabi.newpipe.util.SerializedCache;
|
import org.schabi.newpipe.util.SerializedCache;
|
||||||
import org.schabi.newpipe.util.ServiceHelper;
|
import org.schabi.newpipe.util.ServiceHelper;
|
||||||
import org.schabi.newpipe.util.StateSaver;
|
import org.schabi.newpipe.util.StateSaver;
|
||||||
import org.schabi.newpipe.util.TLSSocketFactoryCompat;
|
|
||||||
import org.schabi.newpipe.util.ThemeHelper;
|
import org.schabi.newpipe.util.ThemeHelper;
|
||||||
import org.schabi.newpipe.views.FocusOverlayView;
|
import org.schabi.newpipe.views.FocusOverlayView;
|
||||||
|
|
||||||
|
@ -131,11 +129,6 @@ public class MainActivity extends AppCompatActivity {
|
||||||
+ "savedInstanceState = [" + savedInstanceState + "]");
|
+ "savedInstanceState = [" + savedInstanceState + "]");
|
||||||
}
|
}
|
||||||
|
|
||||||
// enable TLS1.1/1.2 for kitkat devices, to fix download and play for media.ccc.de sources
|
|
||||||
if (Build.VERSION.SDK_INT == Build.VERSION_CODES.KITKAT) {
|
|
||||||
TLSSocketFactoryCompat.setAsDefault();
|
|
||||||
}
|
|
||||||
|
|
||||||
ThemeHelper.setDayNightMode(this);
|
ThemeHelper.setDayNightMode(this);
|
||||||
ThemeHelper.setTheme(this, ServiceHelper.getSelectedServiceId(this));
|
ThemeHelper.setTheme(this, ServiceHelper.getSelectedServiceId(this));
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,6 @@ package org.schabi.newpipe;
|
||||||
import android.annotation.SuppressLint;
|
import android.annotation.SuppressLint;
|
||||||
import android.app.Activity;
|
import android.app.Activity;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -40,10 +39,6 @@ public class PanicResponderActivity extends Activity {
|
||||||
ExitActivity.exitAndRemoveFromRecentApps(this);
|
ExitActivity.exitAndRemoveFromRecentApps(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
finishAndRemoveTask();
|
finishAndRemoveTask();
|
||||||
} else {
|
|
||||||
finish();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,6 @@ package org.schabi.newpipe.error;
|
||||||
import android.annotation.SuppressLint;
|
import android.annotation.SuppressLint;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
|
@ -107,12 +106,7 @@ public class ReCaptchaActivity extends AppCompatActivity {
|
||||||
// cleaning cache, history and cookies from webView
|
// cleaning cache, history and cookies from webView
|
||||||
recaptchaBinding.reCaptchaWebView.clearCache(true);
|
recaptchaBinding.reCaptchaWebView.clearCache(true);
|
||||||
recaptchaBinding.reCaptchaWebView.clearHistory();
|
recaptchaBinding.reCaptchaWebView.clearHistory();
|
||||||
final CookieManager cookieManager = CookieManager.getInstance();
|
CookieManager.getInstance().removeAllCookies(null);
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
cookieManager.removeAllCookies(value -> { });
|
|
||||||
} else {
|
|
||||||
cookieManager.removeAllCookie();
|
|
||||||
}
|
|
||||||
|
|
||||||
recaptchaBinding.reCaptchaWebView.loadUrl(url);
|
recaptchaBinding.reCaptchaWebView.loadUrl(url);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1922,13 +1922,7 @@ public final class VideoDetailFragment
|
||||||
}
|
}
|
||||||
scrollToTop();
|
scrollToTop();
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
addVideoPlayerView();
|
addVideoPlayerView();
|
||||||
} else {
|
|
||||||
// KitKat needs a delay before addVideoPlayerView call or it reports wrong height in
|
|
||||||
// activity.getWindow().getDecorView().getHeight()
|
|
||||||
new Handler().post(this::addVideoPlayerView);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1991,11 +1985,9 @@ public final class VideoDetailFragment
|
||||||
}
|
}
|
||||||
activity.getWindow().getDecorView().setSystemUiVisibility(0);
|
activity.getWindow().getDecorView().setSystemUiVisibility(0);
|
||||||
activity.getWindow().clearFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
|
activity.getWindow().clearFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
activity.getWindow().setStatusBarColor(ThemeHelper.resolveColorFromAttr(
|
activity.getWindow().setStatusBarColor(ThemeHelper.resolveColorFromAttr(
|
||||||
requireContext(), android.R.attr.colorPrimary));
|
requireContext(), android.R.attr.colorPrimary));
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
private void hideSystemUi() {
|
private void hideSystemUi() {
|
||||||
if (DEBUG) {
|
if (DEBUG) {
|
||||||
|
@ -2025,8 +2017,7 @@ public final class VideoDetailFragment
|
||||||
}
|
}
|
||||||
activity.getWindow().getDecorView().setSystemUiVisibility(visibility);
|
activity.getWindow().getDecorView().setSystemUiVisibility(visibility);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP
|
if (isInMultiWindow || (isPlayerAvailable() && player.isFullscreen())) {
|
||||||
&& (isInMultiWindow || (isPlayerAvailable() && player.isFullscreen()))) {
|
|
||||||
activity.getWindow().setStatusBarColor(Color.TRANSPARENT);
|
activity.getWindow().setStatusBarColor(Color.TRANSPARENT);
|
||||||
activity.getWindow().setNavigationBarColor(Color.TRANSPARENT);
|
activity.getWindow().setNavigationBarColor(Color.TRANSPARENT);
|
||||||
}
|
}
|
||||||
|
|
|
@ -497,9 +497,6 @@ public class SearchFragment extends BaseListFragment<SearchInfo, ListExtractor.I
|
||||||
+ lastSearchedString);
|
+ lastSearchedString);
|
||||||
}
|
}
|
||||||
searchEditText.setText(searchString);
|
searchEditText.setText(searchString);
|
||||||
if (android.os.Build.VERSION.SDK_INT < android.os.Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
searchEditText.setHintTextColor(searchEditText.getTextColors().withAlpha(128));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (TextUtils.isEmpty(searchString) || TextUtils.isEmpty(searchEditText.getText())) {
|
if (TextUtils.isEmpty(searchString) || TextUtils.isEmpty(searchEditText.getText())) {
|
||||||
searchToolbarContainer.setTranslationX(100);
|
searchToolbarContainer.setTranslationX(100);
|
||||||
|
|
|
@ -8,12 +8,10 @@ import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import android.view.inputmethod.InputMethodManager
|
import android.view.inputmethod.InputMethodManager
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.appcompat.content.res.AppCompatResources
|
|
||||||
import androidx.core.content.getSystemService
|
import androidx.core.content.getSystemService
|
||||||
import androidx.core.os.bundleOf
|
import androidx.core.os.bundleOf
|
||||||
import androidx.core.view.isGone
|
import androidx.core.view.isGone
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
import androidx.core.widget.ImageViewCompat
|
|
||||||
import androidx.core.widget.doOnTextChanged
|
import androidx.core.widget.doOnTextChanged
|
||||||
import androidx.fragment.app.DialogFragment
|
import androidx.fragment.app.DialogFragment
|
||||||
import androidx.lifecycle.Observer
|
import androidx.lifecycle.Observer
|
||||||
|
@ -124,14 +122,6 @@ class FeedGroupDialog : DialogFragment(), BackPressable {
|
||||||
_feedGroupCreateBinding = DialogFeedGroupCreateBinding.bind(view)
|
_feedGroupCreateBinding = DialogFeedGroupCreateBinding.bind(view)
|
||||||
_searchLayoutBinding = feedGroupCreateBinding.subscriptionsHeaderSearchContainer
|
_searchLayoutBinding = feedGroupCreateBinding.subscriptionsHeaderSearchContainer
|
||||||
|
|
||||||
if (android.os.Build.VERSION.SDK_INT < android.os.Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
// KitKat doesn't apply container's theme to <include> content
|
|
||||||
val contrastColor = AppCompatResources.getColorStateList(requireContext(), R.color.contrastColor)
|
|
||||||
searchLayoutBinding.toolbarSearchEditText.setTextColor(contrastColor)
|
|
||||||
searchLayoutBinding.toolbarSearchEditText.setHintTextColor(contrastColor.withAlpha(128))
|
|
||||||
ImageViewCompat.setImageTintList(searchLayoutBinding.toolbarSearchClearIcon, contrastColor)
|
|
||||||
}
|
|
||||||
|
|
||||||
viewModel = ViewModelProvider(
|
viewModel = ViewModelProvider(
|
||||||
this,
|
this,
|
||||||
FeedGroupDialogViewModel.Factory(
|
FeedGroupDialogViewModel.Factory(
|
||||||
|
|
|
@ -1963,10 +1963,9 @@ public final class Player implements
|
||||||
private void showSystemUIPartially() {
|
private void showSystemUIPartially() {
|
||||||
final AppCompatActivity activity = getParentActivity();
|
final AppCompatActivity activity = getParentActivity();
|
||||||
if (isFullscreen && activity != null) {
|
if (isFullscreen && activity != null) {
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
activity.getWindow().setStatusBarColor(Color.TRANSPARENT);
|
activity.getWindow().setStatusBarColor(Color.TRANSPARENT);
|
||||||
activity.getWindow().setNavigationBarColor(Color.TRANSPARENT);
|
activity.getWindow().setNavigationBarColor(Color.TRANSPARENT);
|
||||||
}
|
|
||||||
final int visibility = View.SYSTEM_UI_FLAG_LAYOUT_STABLE
|
final int visibility = View.SYSTEM_UI_FLAG_LAYOUT_STABLE
|
||||||
| View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
|
| View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
|
||||||
| View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION;
|
| View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION;
|
||||||
|
|
|
@ -74,7 +74,7 @@ public class AppearanceSettingsFragment extends BasePreferenceFragment {
|
||||||
defaultPreferences.edit().putBoolean(Constants.KEY_THEME_CHANGE, true).apply();
|
defaultPreferences.edit().putBoolean(Constants.KEY_THEME_CHANGE, true).apply();
|
||||||
defaultPreferences.edit().putString(themeKey, newValue.toString()).apply();
|
defaultPreferences.edit().putString(themeKey, newValue.toString()).apply();
|
||||||
|
|
||||||
ThemeHelper.setDayNightMode(getContext(), newValue.toString());
|
ThemeHelper.setDayNightMode(requireContext(), newValue.toString());
|
||||||
|
|
||||||
if (!newValue.equals(beginningThemeKey) && getActivity() != null) {
|
if (!newValue.equals(beginningThemeKey) && getActivity() != null) {
|
||||||
// if it's not the current theme
|
// if it's not the current theme
|
||||||
|
|
|
@ -66,16 +66,10 @@ public class DownloadSettingsFragment extends BasePreferenceFragment {
|
||||||
prefStorageAsk = findPreference(downloadStorageAsk);
|
prefStorageAsk = findPreference(downloadStorageAsk);
|
||||||
|
|
||||||
final SwitchPreferenceCompat prefUseSaf = findPreference(storageUseSafPreference);
|
final SwitchPreferenceCompat prefUseSaf = findPreference(storageUseSafPreference);
|
||||||
prefUseSaf.setDefaultValue(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP);
|
|
||||||
prefUseSaf.setChecked(NewPipeSettings.useStorageAccessFramework(ctx));
|
prefUseSaf.setChecked(NewPipeSettings.useStorageAccessFramework(ctx));
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q
|
|
||||||
|| Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
prefUseSaf.setEnabled(false);
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
|
||||||
|
prefUseSaf.setEnabled(false);
|
||||||
prefUseSaf.setSummary(R.string.downloads_storage_use_saf_summary_api_29);
|
prefUseSaf.setSummary(R.string.downloads_storage_use_saf_summary_api_29);
|
||||||
} else {
|
|
||||||
prefUseSaf.setSummary(R.string.downloads_storage_use_saf_summary_api_19);
|
|
||||||
}
|
|
||||||
prefStorageAsk.setSummary(R.string.downloads_storage_ask_summary_no_saf_notice);
|
prefStorageAsk.setSummary(R.string.downloads_storage_ask_summary_no_saf_notice);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -253,8 +247,7 @@ public class DownloadSettingsFragment extends BasePreferenceFragment {
|
||||||
|
|
||||||
forgetSAFTree(context, defaultPreferences.getString(key, ""));
|
forgetSAFTree(context, defaultPreferences.getString(key, ""));
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP
|
if (!FilePickerActivityHelper.isOwnFileUri(context, uri)) {
|
||||||
&& !FilePickerActivityHelper.isOwnFileUri(context, uri)) {
|
|
||||||
// steps to acquire the selected path:
|
// steps to acquire the selected path:
|
||||||
// 1. acquire permissions on the new save path
|
// 1. acquire permissions on the new save path
|
||||||
// 2. save the new path, if step(2) was successful
|
// 2. save the new path, if step(2) was successful
|
||||||
|
|
|
@ -116,7 +116,7 @@ public final class NewPipeSettings {
|
||||||
public static boolean useStorageAccessFramework(final Context context) {
|
public static boolean useStorageAccessFramework(final Context context) {
|
||||||
// There's a FireOS bug which prevents SAF open/close dialogs from being confirmed with a
|
// There's a FireOS bug which prevents SAF open/close dialogs from being confirmed with a
|
||||||
// remote (see #6455).
|
// remote (see #6455).
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP || DeviceUtils.isFireTv()) {
|
if (DeviceUtils.isFireTv()) {
|
||||||
return false;
|
return false;
|
||||||
} else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
|
} else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) {
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -1,19 +1,9 @@
|
||||||
package org.schabi.newpipe.settings
|
package org.schabi.newpipe.settings
|
||||||
|
|
||||||
import android.os.Build
|
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import androidx.preference.Preference
|
|
||||||
import org.schabi.newpipe.R
|
|
||||||
|
|
||||||
class NotificationSettingsFragment : BasePreferenceFragment() {
|
class NotificationSettingsFragment : BasePreferenceFragment() {
|
||||||
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
|
override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) {
|
||||||
addPreferencesFromResourceRegistry()
|
addPreferencesFromResourceRegistry()
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
val colorizePref: Preference? = findPreference(getString(R.string.notification_colorize_key))
|
|
||||||
colorizePref?.let {
|
|
||||||
preferenceScreen.removePreference(it)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,7 +2,6 @@ package org.schabi.newpipe.settings;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.os.Build;
|
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import androidx.preference.PreferenceManager;
|
import androidx.preference.PreferenceManager;
|
||||||
|
@ -71,12 +70,12 @@ public final class SettingMigrations {
|
||||||
// and standard way to access folders and files to be used consistently everywhere.
|
// and standard way to access folders and files to be used consistently everywhere.
|
||||||
// We reset the setting to its default value, i.e. "use SAF", since now there are no
|
// We reset the setting to its default value, i.e. "use SAF", since now there are no
|
||||||
// more issues with SAF and users should use that one instead of the old
|
// more issues with SAF and users should use that one instead of the old
|
||||||
// NoNonsenseFilePicker. SAF does not work on KitKat and below, though, so the setting
|
// NoNonsenseFilePicker. Also, there's a bug on FireOS in which SAF open/close
|
||||||
// is set to false in that case. Also, there's a bug on FireOS in which SAF open/close
|
|
||||||
// dialogs cannot be confirmed with a remote (see #6455).
|
// dialogs cannot be confirmed with a remote (see #6455).
|
||||||
sp.edit().putBoolean(context.getString(R.string.storage_use_saf),
|
sp.edit().putBoolean(
|
||||||
Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP
|
context.getString(R.string.storage_use_saf),
|
||||||
&& !DeviceUtils.isFireTv()).apply();
|
!DeviceUtils.isFireTv()
|
||||||
|
).apply();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,6 @@ import android.graphics.PorterDuff;
|
||||||
import android.graphics.PorterDuffColorFilter;
|
import android.graphics.PorterDuffColorFilter;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.graphics.drawable.RippleDrawable;
|
import android.graphics.drawable.RippleDrawable;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Looper;
|
import android.os.Looper;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
@ -65,8 +64,7 @@ public final class PreferenceSearchResultHighlighter {
|
||||||
recyclerView.findViewHolderForAdapterPosition(position);
|
recyclerView.findViewHolderForAdapterPosition(position);
|
||||||
if (holder != null) {
|
if (holder != null) {
|
||||||
final Drawable background = holder.itemView.getBackground();
|
final Drawable background = holder.itemView.getBackground();
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP
|
if (background instanceof RippleDrawable) {
|
||||||
&& background instanceof RippleDrawable) {
|
|
||||||
showRippleAnimation((RippleDrawable) background);
|
showRippleAnimation((RippleDrawable) background);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@ import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.database.Cursor;
|
import android.database.Cursor;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Build;
|
|
||||||
import android.provider.DocumentsContract;
|
import android.provider.DocumentsContract;
|
||||||
|
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
|
@ -53,10 +52,6 @@ public class StoredDirectoryHelper {
|
||||||
throw new IOException(e);
|
throw new IOException(e);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
throw new IOException("Storage Access Framework with Directory API is not available");
|
|
||||||
}
|
|
||||||
|
|
||||||
this.docTree = DocumentFile.fromTreeUri(context, path);
|
this.docTree = DocumentFile.fromTreeUri(context, path);
|
||||||
|
|
||||||
if (this.docTree == null) {
|
if (this.docTree == null) {
|
||||||
|
@ -73,7 +68,7 @@ public class StoredDirectoryHelper {
|
||||||
final String[] filename = splitFilename(name);
|
final String[] filename = splitFilename(name);
|
||||||
final String lcFilename = filename[0].toLowerCase();
|
final String lcFilename = filename[0].toLowerCase();
|
||||||
|
|
||||||
if (docTree == null || Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
|
if (docTree == null) {
|
||||||
for (final File file : ioTree.listFiles()) {
|
for (final File file : ioTree.listFiles()) {
|
||||||
addIfStartWith(matches, lcFilename, file.getName());
|
addIfStartWith(matches, lcFilename, file.getName());
|
||||||
}
|
}
|
||||||
|
@ -277,7 +272,7 @@ public class StoredDirectoryHelper {
|
||||||
*/
|
*/
|
||||||
static DocumentFile findFileSAFHelper(@Nullable final Context context, final DocumentFile tree,
|
static DocumentFile findFileSAFHelper(@Nullable final Context context, final DocumentFile tree,
|
||||||
final String filename) {
|
final String filename) {
|
||||||
if (context == null || Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
|
if (context == null) {
|
||||||
return tree.findFile(filename); // warning: this is very slow
|
return tree.findFile(filename); // warning: this is very slow
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package org.schabi.newpipe.streams.io;
|
package org.schabi.newpipe.streams.io;
|
||||||
|
|
||||||
import android.annotation.TargetApi;
|
|
||||||
import android.content.ContentResolver;
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
@ -74,7 +73,6 @@ public class StoredFileHelper implements Serializable {
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
}
|
}
|
||||||
|
|
||||||
@TargetApi(Build.VERSION_CODES.LOLLIPOP)
|
|
||||||
StoredFileHelper(@Nullable final Context context, final DocumentFile tree,
|
StoredFileHelper(@Nullable final Context context, final DocumentFile tree,
|
||||||
final String filename, final String mime, final boolean safe)
|
final String filename, final String mime, final boolean safe)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
|
@ -124,7 +122,6 @@ public class StoredFileHelper implements Serializable {
|
||||||
this.srcType = mime;
|
this.srcType = mime;
|
||||||
}
|
}
|
||||||
|
|
||||||
@TargetApi(Build.VERSION_CODES.KITKAT)
|
|
||||||
public StoredFileHelper(final Context context, @Nullable final Uri parent,
|
public StoredFileHelper(final Context context, @Nullable final Uri parent,
|
||||||
@NonNull final Uri path, final String tag) throws IOException {
|
@NonNull final Uri path, final String tag) throws IOException {
|
||||||
this.tag = tag;
|
this.tag = tag;
|
||||||
|
|
|
@ -65,7 +65,7 @@ public final class DeviceUtils {
|
||||||
boolean isTv = ContextCompat.getSystemService(context, UiModeManager.class)
|
boolean isTv = ContextCompat.getSystemService(context, UiModeManager.class)
|
||||||
.getCurrentModeType() == Configuration.UI_MODE_TYPE_TELEVISION
|
.getCurrentModeType() == Configuration.UI_MODE_TYPE_TELEVISION
|
||||||
|| isFireTv()
|
|| isFireTv()
|
||||||
|| pm.hasSystemFeature(PackageManager.FEATURE_TELEVISION);
|
|| pm.hasSystemFeature(PackageManager.FEATURE_LEANBACK);
|
||||||
|
|
||||||
// from https://stackoverflow.com/a/58932366
|
// from https://stackoverflow.com/a/58932366
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
|
||||||
|
@ -77,10 +77,6 @@ public final class DeviceUtils {
|
||||||
&& pm.hasSystemFeature(PackageManager.FEATURE_ETHERNET));
|
&& pm.hasSystemFeature(PackageManager.FEATURE_ETHERNET));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
isTv = isTv || pm.hasSystemFeature(PackageManager.FEATURE_LEANBACK);
|
|
||||||
}
|
|
||||||
|
|
||||||
DeviceUtils.isTV = isTv;
|
DeviceUtils.isTV = isTv;
|
||||||
return DeviceUtils.isTV;
|
return DeviceUtils.isTV;
|
||||||
}
|
}
|
||||||
|
@ -131,11 +127,10 @@ public final class DeviceUtils {
|
||||||
/**
|
/**
|
||||||
* Some devices have broken tunneled video playback but claim to support it.
|
* Some devices have broken tunneled video playback but claim to support it.
|
||||||
* See https://github.com/TeamNewPipe/NewPipe/issues/5911
|
* See https://github.com/TeamNewPipe/NewPipe/issues/5911
|
||||||
* @return false if Kitkat (does not support tunneling) or affected device
|
* @return false if affected device
|
||||||
*/
|
*/
|
||||||
public static boolean shouldSupportMediaTunneling() {
|
public static boolean shouldSupportMediaTunneling() {
|
||||||
return Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP
|
return !HI3798MV200
|
||||||
&& !HI3798MV200
|
|
||||||
&& !CVT_MT5886_EU_1G
|
&& !CVT_MT5886_EU_1G
|
||||||
&& !REALTEKATV
|
&& !REALTEKATV
|
||||||
&& !QM16XE_U;
|
&& !QM16XE_U;
|
||||||
|
|
|
@ -37,7 +37,6 @@ public final class PermissionHelper {
|
||||||
return checkWriteStoragePermissions(activity, requestCode);
|
return checkWriteStoragePermissions(activity, requestCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
|
|
||||||
public static boolean checkReadStoragePermissions(final Activity activity,
|
public static boolean checkReadStoragePermissions(final Activity activity,
|
||||||
final int requestCode) {
|
final int requestCode) {
|
||||||
if (ContextCompat.checkSelfPermission(activity, Manifest.permission.READ_EXTERNAL_STORAGE)
|
if (ContextCompat.checkSelfPermission(activity, Manifest.permission.READ_EXTERNAL_STORAGE)
|
||||||
|
|
|
@ -1,104 +0,0 @@
|
||||||
package org.schabi.newpipe.util;
|
|
||||||
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.net.InetAddress;
|
|
||||||
import java.net.Socket;
|
|
||||||
import java.security.KeyManagementException;
|
|
||||||
import java.security.NoSuchAlgorithmException;
|
|
||||||
|
|
||||||
import javax.net.ssl.HttpsURLConnection;
|
|
||||||
import javax.net.ssl.SSLContext;
|
|
||||||
import javax.net.ssl.SSLSocket;
|
|
||||||
import javax.net.ssl.SSLSocketFactory;
|
|
||||||
|
|
||||||
import android.util.Log;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This is an extension of the SSLSocketFactory which enables TLS 1.2 and 1.1.
|
|
||||||
* Created for usage on Android 4.1-4.4 devices, which haven't enabled those by default.
|
|
||||||
*/
|
|
||||||
public class TLSSocketFactoryCompat extends SSLSocketFactory {
|
|
||||||
|
|
||||||
private static final String TAG = "TLSSocketFactoryCom";
|
|
||||||
|
|
||||||
private static TLSSocketFactoryCompat instance = null;
|
|
||||||
|
|
||||||
private final SSLSocketFactory internalSSLSocketFactory;
|
|
||||||
|
|
||||||
public TLSSocketFactoryCompat() throws KeyManagementException, NoSuchAlgorithmException {
|
|
||||||
final SSLContext context = SSLContext.getInstance("TLS");
|
|
||||||
context.init(null, null, null);
|
|
||||||
internalSSLSocketFactory = context.getSocketFactory();
|
|
||||||
}
|
|
||||||
|
|
||||||
public static TLSSocketFactoryCompat getInstance()
|
|
||||||
throws NoSuchAlgorithmException, KeyManagementException {
|
|
||||||
if (instance != null) {
|
|
||||||
return instance;
|
|
||||||
}
|
|
||||||
instance = new TLSSocketFactoryCompat();
|
|
||||||
return instance;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void setAsDefault() {
|
|
||||||
try {
|
|
||||||
HttpsURLConnection.setDefaultSSLSocketFactory(getInstance());
|
|
||||||
} catch (NoSuchAlgorithmException | KeyManagementException e) {
|
|
||||||
Log.e(TAG, "Unable to setAsDefault", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String[] getDefaultCipherSuites() {
|
|
||||||
return internalSSLSocketFactory.getDefaultCipherSuites();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public String[] getSupportedCipherSuites() {
|
|
||||||
return internalSSLSocketFactory.getSupportedCipherSuites();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Socket createSocket() throws IOException {
|
|
||||||
return enableTLSOnSocket(internalSSLSocketFactory.createSocket());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Socket createSocket(final Socket s, final String host, final int port,
|
|
||||||
final boolean autoClose) throws IOException {
|
|
||||||
return enableTLSOnSocket(internalSSLSocketFactory.createSocket(s, host, port, autoClose));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Socket createSocket(final String host, final int port) throws IOException {
|
|
||||||
return enableTLSOnSocket(internalSSLSocketFactory.createSocket(host, port));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Socket createSocket(final String host, final int port, final InetAddress localHost,
|
|
||||||
final int localPort) throws IOException {
|
|
||||||
return enableTLSOnSocket(internalSSLSocketFactory.createSocket(
|
|
||||||
host, port, localHost, localPort));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Socket createSocket(final InetAddress host, final int port) throws IOException {
|
|
||||||
return enableTLSOnSocket(internalSSLSocketFactory.createSocket(host, port));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public Socket createSocket(final InetAddress address, final int port,
|
|
||||||
final InetAddress localAddress, final int localPort)
|
|
||||||
throws IOException {
|
|
||||||
return enableTLSOnSocket(internalSSLSocketFactory.createSocket(
|
|
||||||
address, port, localAddress, localPort));
|
|
||||||
}
|
|
||||||
|
|
||||||
private Socket enableTLSOnSocket(final Socket socket) {
|
|
||||||
if (socket instanceof SSLSocket) {
|
|
||||||
((SSLSocket) socket).setEnabledProtocols(new String[]{"TLSv1.1", "TLSv1.2"});
|
|
||||||
}
|
|
||||||
return socket;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -185,17 +185,10 @@ public final class ShareUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Migrate any clip data and flags from the original intent.
|
// Migrate any clip data and flags from the original intent.
|
||||||
final int permFlags;
|
final int permFlags = intent.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
permFlags = intent.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION
|
|
||||||
| Intent.FLAG_GRANT_WRITE_URI_PERMISSION
|
| Intent.FLAG_GRANT_WRITE_URI_PERMISSION
|
||||||
| Intent.FLAG_GRANT_PERSISTABLE_URI_PERMISSION
|
| Intent.FLAG_GRANT_PERSISTABLE_URI_PERMISSION
|
||||||
| Intent.FLAG_GRANT_PREFIX_URI_PERMISSION);
|
| Intent.FLAG_GRANT_PREFIX_URI_PERMISSION);
|
||||||
} else {
|
|
||||||
permFlags = intent.getFlags() & (Intent.FLAG_GRANT_READ_URI_PERMISSION
|
|
||||||
| Intent.FLAG_GRANT_WRITE_URI_PERMISSION
|
|
||||||
| Intent.FLAG_GRANT_PERSISTABLE_URI_PERMISSION);
|
|
||||||
}
|
|
||||||
if (permFlags != 0) {
|
if (permFlags != 0) {
|
||||||
ClipData targetClipData = intent.getClipData();
|
ClipData targetClipData = intent.getClipData();
|
||||||
if (targetClipData == null && intent.getData() != null) {
|
if (targetClipData == null && intent.getData() != null) {
|
||||||
|
|
|
@ -21,7 +21,6 @@ package org.schabi.newpipe.views;
|
||||||
|
|
||||||
import android.animation.ValueAnimator;
|
import android.animation.ValueAnimator;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Parcelable;
|
import android.os.Parcelable;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
@ -29,7 +28,6 @@ import android.widget.LinearLayout;
|
||||||
|
|
||||||
import androidx.annotation.IntDef;
|
import androidx.annotation.IntDef;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.annotation.RequiresApi;
|
|
||||||
|
|
||||||
import org.schabi.newpipe.ktx.ViewUtils;
|
import org.schabi.newpipe.ktx.ViewUtils;
|
||||||
|
|
||||||
|
@ -76,7 +74,6 @@ public class CollapsibleView extends LinearLayout {
|
||||||
super(context, attrs, defStyleAttr);
|
super(context, attrs, defStyleAttr);
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
|
|
||||||
public CollapsibleView(final Context context, final AttributeSet attrs, final int defStyleAttr,
|
public CollapsibleView(final Context context, final AttributeSet attrs, final int defStyleAttr,
|
||||||
final int defStyleRes) {
|
final int defStyleRes) {
|
||||||
super(context, attrs, defStyleAttr, defStyleRes);
|
super(context, attrs, defStyleAttr, defStyleRes);
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
package org.schabi.newpipe.views;
|
package org.schabi.newpipe.views;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.os.Build;
|
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.view.SurfaceView;
|
import android.view.SurfaceView;
|
||||||
|
|
||||||
|
@ -45,10 +44,7 @@ public class ExpandableSurfaceView extends SurfaceView {
|
||||||
scaleX = 1.0f;
|
scaleX = 1.0f;
|
||||||
scaleY = 1.0f;
|
scaleY = 1.0f;
|
||||||
|
|
||||||
if (resizeMode == RESIZE_MODE_FIT
|
if (resizeMode == RESIZE_MODE_FIT) {
|
||||||
// KitKat doesn't work well when a view has a scale like needed for ZOOM
|
|
||||||
|| (resizeMode == RESIZE_MODE_ZOOM
|
|
||||||
&& Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP)) {
|
|
||||||
if (aspectDeformation > 0) {
|
if (aspectDeformation > 0) {
|
||||||
height = (int) (width / videoAspectRatio);
|
height = (int) (width / videoAspectRatio);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -17,10 +17,8 @@
|
||||||
*/
|
*/
|
||||||
package org.schabi.newpipe.views;
|
package org.schabi.newpipe.views;
|
||||||
|
|
||||||
import android.annotation.TargetApi;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.Rect;
|
import android.graphics.Rect;
|
||||||
import android.os.Build;
|
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
@ -74,7 +72,6 @@ public final class FocusAwareCoordinator extends CoordinatorLayout {
|
||||||
* Makes possible for multiple fragments to co-exist. Without this code
|
* Makes possible for multiple fragments to co-exist. Without this code
|
||||||
* the first ViewGroup who consumes will be the last who receive the insets
|
* the first ViewGroup who consumes will be the last who receive the insets
|
||||||
*/
|
*/
|
||||||
@TargetApi(Build.VERSION_CODES.LOLLIPOP)
|
|
||||||
@Override
|
@Override
|
||||||
public WindowInsets dispatchApplyWindowInsets(final WindowInsets insets) {
|
public WindowInsets dispatchApplyWindowInsets(final WindowInsets insets) {
|
||||||
boolean consumed = false;
|
boolean consumed = false;
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package us.shandian.giga.get;
|
package us.shandian.giga.get;
|
||||||
|
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.system.ErrnoException;
|
import android.system.ErrnoException;
|
||||||
import android.system.OsConstants;
|
import android.system.OsConstants;
|
||||||
|
@ -316,7 +315,6 @@ public class DownloadMission extends Mission {
|
||||||
|
|
||||||
public synchronized void notifyError(int code, Exception err) {
|
public synchronized void notifyError(int code, Exception err) {
|
||||||
Log.e(TAG, "notifyError() code = " + code, err);
|
Log.e(TAG, "notifyError() code = " + code, err);
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
if (err != null && err.getCause() instanceof ErrnoException) {
|
if (err != null && err.getCause() instanceof ErrnoException) {
|
||||||
int errno = ((ErrnoException) err.getCause()).errno;
|
int errno = ((ErrnoException) err.getCause()).errno;
|
||||||
if (errno == OsConstants.ENOSPC) {
|
if (errno == OsConstants.ENOSPC) {
|
||||||
|
@ -327,7 +325,6 @@ public class DownloadMission extends Mission {
|
||||||
err = null;
|
err = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (err instanceof IOException) {
|
if (err instanceof IOException) {
|
||||||
if (err.getMessage().contains("Permission denied")) {
|
if (err.getMessage().contains("Permission denied")) {
|
||||||
|
|
|
@ -4,10 +4,8 @@ import android.app.Notification;
|
||||||
import android.app.NotificationManager;
|
import android.app.NotificationManager;
|
||||||
import android.app.PendingIntent;
|
import android.app.PendingIntent;
|
||||||
import android.app.Service;
|
import android.app.Service;
|
||||||
import android.content.BroadcastReceiver;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentFilter;
|
|
||||||
import android.content.SharedPreferences;
|
import android.content.SharedPreferences;
|
||||||
import android.content.SharedPreferences.OnSharedPreferenceChangeListener;
|
import android.content.SharedPreferences.OnSharedPreferenceChangeListener;
|
||||||
import android.graphics.Bitmap;
|
import android.graphics.Bitmap;
|
||||||
|
@ -18,7 +16,6 @@ import android.net.NetworkInfo;
|
||||||
import android.net.NetworkRequest;
|
import android.net.NetworkRequest;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Binder;
|
import android.os.Binder;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
import android.os.Handler.Callback;
|
import android.os.Handler.Callback;
|
||||||
import android.os.IBinder;
|
import android.os.IBinder;
|
||||||
|
@ -100,7 +97,6 @@ public class DownloadManagerService extends Service {
|
||||||
private final ArrayList<Callback> mEchoObservers = new ArrayList<>(1);
|
private final ArrayList<Callback> mEchoObservers = new ArrayList<>(1);
|
||||||
|
|
||||||
private ConnectivityManager mConnectivityManager;
|
private ConnectivityManager mConnectivityManager;
|
||||||
private BroadcastReceiver mNetworkStateListener = null;
|
|
||||||
private ConnectivityManager.NetworkCallback mNetworkStateListenerL = null;
|
private ConnectivityManager.NetworkCallback mNetworkStateListenerL = null;
|
||||||
|
|
||||||
private SharedPreferences mPrefs = null;
|
private SharedPreferences mPrefs = null;
|
||||||
|
@ -166,7 +162,6 @@ public class DownloadManagerService extends Service {
|
||||||
mConnectivityManager = ContextCompat.getSystemService(this,
|
mConnectivityManager = ContextCompat.getSystemService(this,
|
||||||
ConnectivityManager.class);
|
ConnectivityManager.class);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
mNetworkStateListenerL = new ConnectivityManager.NetworkCallback() {
|
mNetworkStateListenerL = new ConnectivityManager.NetworkCallback() {
|
||||||
@Override
|
@Override
|
||||||
public void onAvailable(Network network) {
|
public void onAvailable(Network network) {
|
||||||
|
@ -179,15 +174,6 @@ public class DownloadManagerService extends Service {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
mConnectivityManager.registerNetworkCallback(new NetworkRequest.Builder().build(), mNetworkStateListenerL);
|
mConnectivityManager.registerNetworkCallback(new NetworkRequest.Builder().build(), mNetworkStateListenerL);
|
||||||
} else {
|
|
||||||
mNetworkStateListener = new BroadcastReceiver() {
|
|
||||||
@Override
|
|
||||||
public void onReceive(Context context, Intent intent) {
|
|
||||||
handleConnectivityState(false);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
registerReceiver(mNetworkStateListener, new IntentFilter(ConnectivityManager.CONNECTIVITY_ACTION));
|
|
||||||
}
|
|
||||||
|
|
||||||
mPrefs.registerOnSharedPreferenceChangeListener(mPrefChangeListener);
|
mPrefs.registerOnSharedPreferenceChangeListener(mPrefChangeListener);
|
||||||
|
|
||||||
|
@ -246,10 +232,7 @@ public class DownloadManagerService extends Service {
|
||||||
|
|
||||||
manageLock(false);
|
manageLock(false);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP)
|
|
||||||
mConnectivityManager.unregisterNetworkCallback(mNetworkStateListenerL);
|
mConnectivityManager.unregisterNetworkCallback(mNetworkStateListenerL);
|
||||||
else
|
|
||||||
unregisterReceiver(mNetworkStateListener);
|
|
||||||
|
|
||||||
mPrefs.unregisterOnSharedPreferenceChangeListener(mPrefChangeListener);
|
mPrefs.unregisterOnSharedPreferenceChangeListener(mPrefChangeListener);
|
||||||
|
|
||||||
|
@ -263,21 +246,6 @@ public class DownloadManagerService extends Service {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IBinder onBind(Intent intent) {
|
public IBinder onBind(Intent intent) {
|
||||||
/*
|
|
||||||
int permissionCheck;
|
|
||||||
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.JELLY_BEAN) {
|
|
||||||
permissionCheck = PermissionChecker.checkSelfPermission(this, Manifest.permission.READ_EXTERNAL_STORAGE);
|
|
||||||
if (permissionCheck == PermissionChecker.PERMISSION_DENIED) {
|
|
||||||
Toast.makeText(this, "Permission denied (read)", Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
permissionCheck = PermissionChecker.checkSelfPermission(this, Manifest.permission.WRITE_EXTERNAL_STORAGE);
|
|
||||||
if (permissionCheck == PermissionChecker.PERMISSION_DENIED) {
|
|
||||||
Toast.makeText(this, "Permission denied (write)", Toast.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
return mBinder;
|
return mBinder;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -473,12 +441,7 @@ public class DownloadManagerService extends Service {
|
||||||
if (downloadDoneCount == 1) {
|
if (downloadDoneCount == 1) {
|
||||||
downloadDoneList.append(name);
|
downloadDoneList.append(name);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
downloadDoneNotification.setContentTitle(getString(R.string.app_name));
|
|
||||||
} else {
|
|
||||||
downloadDoneNotification.setContentTitle(null);
|
downloadDoneNotification.setContentTitle(null);
|
||||||
}
|
|
||||||
|
|
||||||
downloadDoneNotification.setContentText(Localization.downloadCount(this, downloadDoneCount));
|
downloadDoneNotification.setContentText(Localization.downloadCount(this, downloadDoneCount));
|
||||||
downloadDoneNotification.setStyle(new NotificationCompat.BigTextStyle()
|
downloadDoneNotification.setStyle(new NotificationCompat.BigTextStyle()
|
||||||
.setBigContentTitle(Localization.downloadCount(this, downloadDoneCount))
|
.setBigContentTitle(Localization.downloadCount(this, downloadDoneCount))
|
||||||
|
@ -511,16 +474,10 @@ public class DownloadManagerService extends Service {
|
||||||
.setContentIntent(mOpenDownloadList);
|
.setContentIntent(mOpenDownloadList);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
downloadFailedNotification.setContentTitle(getString(R.string.app_name));
|
|
||||||
downloadFailedNotification.setStyle(new NotificationCompat.BigTextStyle()
|
|
||||||
.bigText(getString(R.string.download_failed).concat(": ").concat(mission.storage.getName())));
|
|
||||||
} else {
|
|
||||||
downloadFailedNotification.setContentTitle(getString(R.string.download_failed));
|
downloadFailedNotification.setContentTitle(getString(R.string.download_failed));
|
||||||
downloadFailedNotification.setContentText(mission.storage.getName());
|
downloadFailedNotification.setContentText(mission.storage.getName());
|
||||||
downloadFailedNotification.setStyle(new NotificationCompat.BigTextStyle()
|
downloadFailedNotification.setStyle(new NotificationCompat.BigTextStyle()
|
||||||
.bigText(mission.storage.getName()));
|
.bigText(mission.storage.getName()));
|
||||||
}
|
|
||||||
|
|
||||||
mNotificationManager.notify(id, downloadFailedNotification.build());
|
mNotificationManager.notify(id, downloadFailedNotification.build());
|
||||||
}
|
}
|
||||||
|
@ -556,12 +513,7 @@ public class DownloadManagerService extends Service {
|
||||||
|
|
||||||
if (path.charAt(0) == File.separatorChar) {
|
if (path.charAt(0) == File.separatorChar) {
|
||||||
Log.i(TAG, "Old save path style present: " + path);
|
Log.i(TAG, "Old save path style present: " + path);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP)
|
|
||||||
path = Uri.fromFile(new File(path)).toString();
|
|
||||||
else
|
|
||||||
path = "";
|
path = "";
|
||||||
|
|
||||||
mPrefs.edit().putString(getString(prefKey), "").apply();
|
mPrefs.edit().putString(getString(prefKey), "").apply();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -350,10 +350,8 @@ public class MissionAdapter extends Adapter<ViewHolder> implements Handler.Callb
|
||||||
Intent intent = new Intent(Intent.ACTION_VIEW);
|
Intent intent = new Intent(Intent.ACTION_VIEW);
|
||||||
intent.setDataAndType(resolveShareableUri(mission), mimeType);
|
intent.setDataAndType(resolveShareableUri(mission), mimeType);
|
||||||
intent.addFlags(FLAG_GRANT_READ_URI_PERMISSION);
|
intent.addFlags(FLAG_GRANT_READ_URI_PERMISSION);
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
|
||||||
intent.addFlags(FLAG_GRANT_PREFIX_URI_PERMISSION);
|
intent.addFlags(FLAG_GRANT_PREFIX_URI_PERMISSION);
|
||||||
}
|
|
||||||
if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.M) {
|
if (Build.VERSION.SDK_INT <= Build.VERSION_CODES.M) {
|
||||||
intent.addFlags(FLAG_ACTIVITY_NEW_TASK);
|
intent.addFlags(FLAG_ACTIVITY_NEW_TASK);
|
||||||
}
|
}
|
||||||
|
|
|
@ -673,7 +673,6 @@
|
||||||
<string name="feed_load_error_account_info">تعذر تحميل تغذية لـ\'%s\'.</string>
|
<string name="feed_load_error_account_info">تعذر تحميل تغذية لـ\'%s\'.</string>
|
||||||
<string name="feed_load_error">خطأ في تحميل الخلاصة</string>
|
<string name="feed_load_error">خطأ في تحميل الخلاصة</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">بدءًا من Android 10، يتم دعم \"Storage Access Framework\" فقط</string>
|
<string name="downloads_storage_use_saf_summary_api_29">بدءًا من Android 10، يتم دعم \"Storage Access Framework\" فقط</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\"Storage Access Framework\" غير مدعوم على Android KitKat والإصدارات الأقدم</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">سيتم سؤالك عن مكان حفظ كل تنزيل</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">سيتم سؤالك عن مكان حفظ كل تنزيل</string>
|
||||||
<string name="no_dir_yet">لم يتم تعيين مجلد التحميل، الرجاء اختيار مجلد التحميل الافتراضي الآن</string>
|
<string name="no_dir_yet">لم يتم تعيين مجلد التحميل، الرجاء اختيار مجلد التحميل الافتراضي الآن</string>
|
||||||
<string name="off">إيقاف</string>
|
<string name="off">إيقاف</string>
|
||||||
|
|
|
@ -463,7 +463,6 @@
|
||||||
<string name="error_http_no_content">Server məlumat göndərmir</string>
|
<string name="error_http_no_content">Server məlumat göndərmir</string>
|
||||||
<string name="error_download_resource_gone">Bu endirməni bərpa etmək mümkün deyil</string>
|
<string name="error_download_resource_gone">Bu endirməni bərpa etmək mümkün deyil</string>
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Sizdən hər endirmənin harada saxlanacağı soruşulacaq</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Sizdən hər endirmənin harada saxlanacağı soruşulacaq</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Yaddaş Giriş Çərçivəsi\' Android KitKat və ondan aşağı versiyalarda dəstəklənmir</string>
|
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">\"Yaddaş Giriş Çərçivəsi\"yalnız Android 10\'dan başlayaraq dəstəklənir</string>
|
<string name="downloads_storage_use_saf_summary_api_29">\"Yaddaş Giriş Çərçivəsi\"yalnız Android 10\'dan başlayaraq dəstəklənir</string>
|
||||||
<string name="detail_sub_channel_thumbnail_view_description">Kanalın avatar miniatürü</string>
|
<string name="detail_sub_channel_thumbnail_view_description">Kanalın avatar miniatürü</string>
|
||||||
<string name="select_night_theme_toast">Sevdiyiniz gecə mövzusunu aşağıda seçə bilərsiniz</string>
|
<string name="select_night_theme_toast">Sevdiyiniz gecə mövzusunu aşağıda seçə bilərsiniz</string>
|
||||||
|
|
|
@ -675,7 +675,6 @@
|
||||||
<item quantity="one">S\'ha suprimit %1$s baixada</item>
|
<item quantity="one">S\'ha suprimit %1$s baixada</item>
|
||||||
<item quantity="other">S\'han suprimit %1$s baixades</item>
|
<item quantity="other">S\'han suprimit %1$s baixades</item>
|
||||||
</plurals>
|
</plurals>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">El \"Sistema d\'Accés a l\'Emmagatzematge\" no està implementat a Android KitKat i a versions anteriors</string>
|
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">A partir de l\'Android 10 només s\'admet el \"Sistema d\'Accés a l\'Emmagatzematge\"</string>
|
<string name="downloads_storage_use_saf_summary_api_29">A partir de l\'Android 10 només s\'admet el \"Sistema d\'Accés a l\'Emmagatzematge\"</string>
|
||||||
<string name="feed_new_items">Elements de feed nous</string>
|
<string name="feed_new_items">Elements de feed nous</string>
|
||||||
<string name="feed_load_error_fast_unknown">El mode d\'alimentació ràpida no proporciona més informació sobre això.</string>
|
<string name="feed_load_error_fast_unknown">El mode d\'alimentació ràpida no proporciona més informació sobre això.</string>
|
||||||
|
|
|
@ -625,7 +625,6 @@
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">بۆ دابهزاندنی ههر بابهتێك پرست پێ دهكرێت لهبارهی شوێنی دابهزاندنیان</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">بۆ دابهزاندنی ههر بابهتێك پرست پێ دهكرێت لهبارهی شوێنی دابهزاندنیان</string>
|
||||||
<string name="disable_media_tunneling_title">ناكاراكردنی تونێلكردنی میدیا</string>
|
<string name="disable_media_tunneling_title">ناكاراكردنی تونێلكردنی میدیا</string>
|
||||||
<string name="show_age_restricted_content_summary">ئهو بابهتانهی نهگونجاون بۆ منداڵان پیشان بدرێن كه سنووری تهمهن دهیانگرێتهوه (وهك +18)</string>
|
<string name="show_age_restricted_content_summary">ئهو بابهتانهی نهگونجاون بۆ منداڵان پیشان بدرێن كه سنووری تهمهن دهیانگرێتهوه (وهك +18)</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' پشتگیری نهكراوه لهسهر وهشانهكانی ئهندرۆید كیتكات و نزمتر</string>
|
|
||||||
<string name="crash_the_app">كڕاشی بهرنامهكه</string>
|
<string name="crash_the_app">كڕاشی بهرنامهكه</string>
|
||||||
<string name="show_memory_leaks">پیشاندانی دزهكردنی بیرگه</string>
|
<string name="show_memory_leaks">پیشاندانی دزهكردنی بیرگه</string>
|
||||||
<string name="enqueued">لهنۆبهت دانرا</string>
|
<string name="enqueued">لهنۆبهت دانرا</string>
|
||||||
|
|
|
@ -643,7 +643,6 @@
|
||||||
<string name="feed_load_error_account_info">Feed pro \'%s\' nemohl být načten.</string>
|
<string name="feed_load_error_account_info">Feed pro \'%s\' nemohl být načten.</string>
|
||||||
<string name="feed_load_error">Chyba při načítání feedu</string>
|
<string name="feed_load_error">Chyba při načítání feedu</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Počínaje Android 10 je podporován pouze \"Storage Access Framework\"</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Počínaje Android 10 je podporován pouze \"Storage Access Framework\"</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\"Storage Access Framework\" není podporován na KitKat a níže</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Budete dotázáni, kde uložit každý stažený soubor</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Budete dotázáni, kde uložit každý stažený soubor</string>
|
||||||
<string name="no_dir_yet">Adresář pro stažené soubory dosud nenastaven, zvolte, prosím, výchozí adresář nyní</string>
|
<string name="no_dir_yet">Adresář pro stažené soubory dosud nenastaven, zvolte, prosím, výchozí adresář nyní</string>
|
||||||
<string name="off">Vypnuto</string>
|
<string name="off">Vypnuto</string>
|
||||||
|
|
|
@ -638,7 +638,6 @@
|
||||||
<string name="no_dir_yet">Noch kein Downloadordner festgelegt, wähle jetzt den Standard-Downloadordner</string>
|
<string name="no_dir_yet">Noch kein Downloadordner festgelegt, wähle jetzt den Standard-Downloadordner</string>
|
||||||
<string name="open_website_license">Webseite öffnen</string>
|
<string name="open_website_license">Webseite öffnen</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Ab Android 10 wird nur noch „Storage Access Framework“ unterstützt</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Ab Android 10 wird nur noch „Storage Access Framework“ unterstützt</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Das „Storage Access Framework“ wird auf Android KitKat und niedriger nicht unterstützt</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Du wirst jedes Mal gefragt werden, wohin der Download gespeichert werden soll</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Du wirst jedes Mal gefragt werden, wohin der Download gespeichert werden soll</string>
|
||||||
<string name="feed_load_error">Fehler beim Laden des Feeds</string>
|
<string name="feed_load_error">Fehler beim Laden des Feeds</string>
|
||||||
<string name="feed_load_error_account_info">Konnte Feed für \'%s\' nicht laden.</string>
|
<string name="feed_load_error_account_info">Konnte Feed für \'%s\' nicht laden.</string>
|
||||||
|
|
|
@ -632,7 +632,6 @@
|
||||||
<string name="feed_load_error_account_info">Αδυναμία φόρτωσης τροφοδοσίας για \'%s\'.</string>
|
<string name="feed_load_error_account_info">Αδυναμία φόρτωσης τροφοδοσίας για \'%s\'.</string>
|
||||||
<string name="feed_load_error">Σφάλμα φόρτωσης τροφοδοσίας</string>
|
<string name="feed_load_error">Σφάλμα φόρτωσης τροφοδοσίας</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Από το Android 10 και μετά, μόνο το SAF υποστηρίζεται</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Από το Android 10 και μετά, μόνο το SAF υποστηρίζεται</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Το «Πλαίσιο Πρόσβασης Αποθήκευσης» δεν υποστηρίζεται σε Android KitKat και παλαιότερο</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Θα ερωτηθείτε πού να αποθηκεύσετε κάθε λήψη</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Θα ερωτηθείτε πού να αποθηκεύσετε κάθε λήψη</string>
|
||||||
<string name="no_dir_yet">Δεν έχει ορισθεί φάκελος λήψεων ακόμα, eπιλέξτε τον προεπιλεγμένο φάκελο τώρα</string>
|
<string name="no_dir_yet">Δεν έχει ορισθεί φάκελος λήψεων ακόμα, eπιλέξτε τον προεπιλεγμένο φάκελο τώρα</string>
|
||||||
<string name="metadata_host">Host</string>
|
<string name="metadata_host">Host</string>
|
||||||
|
|
|
@ -633,7 +633,6 @@
|
||||||
\n¿Desea desuscribirse de este canal\?</string>
|
\n¿Desea desuscribirse de este canal\?</string>
|
||||||
<string name="feed_load_error">Error al cargar el muro</string>
|
<string name="feed_load_error">Error al cargar el muro</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Desde Android 10 solo el \'Sistema de Acceso al Almacenamiento\' es soportado</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Desde Android 10 solo el \'Sistema de Acceso al Almacenamiento\' es soportado</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">El \'Sistema de Acceso al Almacenamiento\' no es sorportado en Android KitKat o versiones anteriores</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Se le preguntará dónde guardar cada descarga</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Se le preguntará dónde guardar cada descarga</string>
|
||||||
<string name="disable_media_tunneling_summary">Deshabilitar el túnel de medios si experimenta una pantalla negra o interrupciones en la reproduccción de videos</string>
|
<string name="disable_media_tunneling_summary">Deshabilitar el túnel de medios si experimenta una pantalla negra o interrupciones en la reproduccción de videos</string>
|
||||||
<string name="disable_media_tunneling_title">Deshabilitar el túnel de medios</string>
|
<string name="disable_media_tunneling_title">Deshabilitar el túnel de medios</string>
|
||||||
|
|
|
@ -632,7 +632,6 @@
|
||||||
<string name="settings_category_feed_title">Voog</string>
|
<string name="settings_category_feed_title">Voog</string>
|
||||||
<string name="choose_instance_prompt">Vali eksemplar</string>
|
<string name="choose_instance_prompt">Vali eksemplar</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Android 10st alates on toetatud ainult salvestusjuurdepääsu raamistik \'Storage Access Framework\'</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Android 10st alates on toetatud ainult salvestusjuurdepääsu raamistik \'Storage Access Framework\'</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Android KitKat ja vanemad versioonid ei toeta salvestusjuurdepääsu raamistikku \'Storage Access Framework\'</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Sinult küsitakse iga kord, kuhu alla laadimine salvestada</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Sinult küsitakse iga kord, kuhu alla laadimine salvestada</string>
|
||||||
<string name="detail_heart_img_view_description">Südamlik autor</string>
|
<string name="detail_heart_img_view_description">Südamlik autor</string>
|
||||||
<string name="feed_use_dedicated_fetch_method_help_text">Kas sinu meelest on voo laadimine aeglane\? Sel juhul proovi lubada kiire laadimine (seda saad muuta seadetes või vajutades allolevat nuppu).
|
<string name="feed_use_dedicated_fetch_method_help_text">Kas sinu meelest on voo laadimine aeglane\? Sel juhul proovi lubada kiire laadimine (seda saad muuta seadetes või vajutades allolevat nuppu).
|
||||||
|
|
|
@ -626,7 +626,6 @@
|
||||||
<string name="feed_load_error_account_info">Ezin izan da \'%s\' jarioa kargatu.</string>
|
<string name="feed_load_error_account_info">Ezin izan da \'%s\' jarioa kargatu.</string>
|
||||||
<string name="feed_load_error">Errorea jarioa kargatzean</string>
|
<string name="feed_load_error">Errorea jarioa kargatzean</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Android 10etik aurrera \'Biltegiaren Sarrera Framework\'a soilik onartzen da</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Android 10etik aurrera \'Biltegiaren Sarrera Framework\'a soilik onartzen da</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Biltegiaren Sarrera Framework\'a ez da Android KitKat eta aurreko bertsioetan onartzen</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Non gorde galdetuko zaizu deskarga bakoitzean</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Non gorde galdetuko zaizu deskarga bakoitzean</string>
|
||||||
<string name="no_dir_yet">Ez da deskargatzeko karpetarik ezarri oraindik, aukeratu lehenetsitako deskargatzeko karpeta orain</string>
|
<string name="no_dir_yet">Ez da deskargatzeko karpetarik ezarri oraindik, aukeratu lehenetsitako deskargatzeko karpeta orain</string>
|
||||||
<string name="metadata_privacy">Pribatutasuna</string>
|
<string name="metadata_privacy">Pribatutasuna</string>
|
||||||
|
|
|
@ -636,7 +636,6 @@
|
||||||
<string name="description_select_note">اکنون میتوانید متن درون شرخ را برگزینید. به یاد داشته باشید که در حالت گزینش، ممکن است صفحه چشمک زده و پیوندها قابل کلیک نباشند.</string>
|
<string name="description_select_note">اکنون میتوانید متن درون شرخ را برگزینید. به یاد داشته باشید که در حالت گزینش، ممکن است صفحه چشمک زده و پیوندها قابل کلیک نباشند.</string>
|
||||||
<string name="no_dir_yet">هنوز شاخهٔ بارگیریای تنظیم نشده. اکنون شاخهٔ بارگیری پیشگزیده را برگزینید</string>
|
<string name="no_dir_yet">هنوز شاخهٔ بارگیریای تنظیم نشده. اکنون شاخهٔ بارگیری پیشگزیده را برگزینید</string>
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">برای ذخیرهٔ هر بارگیری از شما پرسیده خواهد شد</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">برای ذخیرهٔ هر بارگیری از شما پرسیده خواهد شد</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">«چارچوب دسترسی ذخیره» روی اندروید کیتکت و پایینتر پشتیبانی نمیشود</string>
|
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">از اندروید ۱۰، تنها «چارچوب دسترسی ذخیره» پشتیبانی میشود</string>
|
<string name="downloads_storage_use_saf_summary_api_29">از اندروید ۱۰، تنها «چارچوب دسترسی ذخیره» پشتیبانی میشود</string>
|
||||||
<string name="feed_load_error_account_info">نتوانست خوراک را برای «%s» بار کند.</string>
|
<string name="feed_load_error_account_info">نتوانست خوراک را برای «%s» بار کند.</string>
|
||||||
<string name="feed_load_error_terminated">حساب این نگارنده نابود شده است.
|
<string name="feed_load_error_terminated">حساب این نگارنده نابود شده است.
|
||||||
|
|
|
@ -638,7 +638,6 @@
|
||||||
\nHaluatko poistaa kanavan tilauksesta\?</string>
|
\nHaluatko poistaa kanavan tilauksesta\?</string>
|
||||||
<string name="feed_load_error_account_info">Ei voitu ladata syötettä hakusanalle \'%s\'.</string>
|
<string name="feed_load_error_account_info">Ei voitu ladata syötettä hakusanalle \'%s\'.</string>
|
||||||
<string name="feed_load_error">Virhe syötteen lataamisessa</string>
|
<string name="feed_load_error">Virhe syötteen lataamisessa</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' ei ole tuettu Android KitKatissa tai vanhemmissa versioissa</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Sinulta kysytään joka kerta, minne tiedosto ladataan</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Sinulta kysytään joka kerta, minne tiedosto ladataan</string>
|
||||||
<string name="dont_show">Älä näytä</string>
|
<string name="dont_show">Älä näytä</string>
|
||||||
<string name="low_quality_smaller">Matala laatu (pienempi)</string>
|
<string name="low_quality_smaller">Matala laatu (pienempi)</string>
|
||||||
|
|
|
@ -640,7 +640,6 @@
|
||||||
\nNewPipe ne sera plus en mesure de charger ce flux à l’avenir.
|
\nNewPipe ne sera plus en mesure de charger ce flux à l’avenir.
|
||||||
\nSouhaitez-vous vous désabonner de cette chaîne \?</string>
|
\nSouhaitez-vous vous désabonner de cette chaîne \?</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">À partir d’Android 10, seule « l’Infrastructure d’accès au stockage » est prise en charge</string>
|
<string name="downloads_storage_use_saf_summary_api_29">À partir d’Android 10, seule « l’Infrastructure d’accès au stockage » est prise en charge</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">L’« Infrastructure d’accès au stockage » n’est pas prise en charge par Android KitKat et les versions antérieures</string>
|
|
||||||
<string name="feed_load_error_fast_unknown">Le mode flux rapide ne fournit pas plus d’info à ce sujet.</string>
|
<string name="feed_load_error_fast_unknown">Le mode flux rapide ne fournit pas plus d’info à ce sujet.</string>
|
||||||
<string name="comments_are_disabled">Les commentaires sont désactivés</string>
|
<string name="comments_are_disabled">Les commentaires sont désactivés</string>
|
||||||
<string name="dont_show">Ne pas afficher</string>
|
<string name="dont_show">Ne pas afficher</string>
|
||||||
|
|
|
@ -678,7 +678,6 @@
|
||||||
<string name="processing_may_take_a_moment">Procesando... Pode devagar un momento</string>
|
<string name="processing_may_take_a_moment">Procesando... Pode devagar un momento</string>
|
||||||
<string name="create_error_notification">Crear unha notificación de erro</string>
|
<string name="create_error_notification">Crear unha notificación de erro</string>
|
||||||
<string name="show_image_indicators_summary">Amosar fitas coloridas de Picasso na cima das imaxes que indican a súa fonte: vermello para a rede, azul para o disco e verde para a memoria</string>
|
<string name="show_image_indicators_summary">Amosar fitas coloridas de Picasso na cima das imaxes que indican a súa fonte: vermello para a rede, azul para o disco e verde para a memoria</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">O \'Sistema de Acceso ao almacenamento\' non está soportado en Android KitKat e anteriores</string>
|
|
||||||
<string name="feed_new_items">Novos elementos</string>
|
<string name="feed_new_items">Novos elementos</string>
|
||||||
<string name="progressive_load_interval_exoplayer_default">Predefinido do ExoPlayer</string>
|
<string name="progressive_load_interval_exoplayer_default">Predefinido do ExoPlayer</string>
|
||||||
<string name="show_crash_the_player_title">Amosar \"Travar o reprodutor\"</string>
|
<string name="show_crash_the_player_title">Amosar \"Travar o reprodutor\"</string>
|
||||||
|
|
|
@ -653,7 +653,6 @@
|
||||||
<string name="feed_load_error_account_info">לא ניתן לטעון את ההזנה עבור ‚%s’.</string>
|
<string name="feed_load_error_account_info">לא ניתן לטעון את ההזנה עבור ‚%s’.</string>
|
||||||
<string name="feed_load_error">שגיאה בהורדת ההזנה</string>
|
<string name="feed_load_error">שגיאה בהורדת ההזנה</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">התמיכה ב‚תשתית גישה לאחסון’ נתמכת מ־Android 10 בלבד</string>
|
<string name="downloads_storage_use_saf_summary_api_29">התמיכה ב‚תשתית גישה לאחסון’ נתמכת מ־Android 10 בלבד</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">‚תשתית הגישה לאחסון’ אינה נתמכת על ידי Android KitKat ומטה</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">תופיע שאלה לאן לשמור כל הורדה</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">תופיע שאלה לאן לשמור כל הורדה</string>
|
||||||
<string name="no_dir_yet">טרם הוגדרה תיקיית הורדה, נא לבחור את תיקיית ההורדה כעת</string>
|
<string name="no_dir_yet">טרם הוגדרה תיקיית הורדה, נא לבחור את תיקיית ההורדה כעת</string>
|
||||||
<string name="off">כבוי</string>
|
<string name="off">כבוי</string>
|
||||||
|
|
|
@ -643,7 +643,6 @@
|
||||||
<string name="feed_load_error_account_info">Nije moguće učitati feed za \'%s\'.</string>
|
<string name="feed_load_error_account_info">Nije moguće učitati feed za \'%s\'.</string>
|
||||||
<string name="feed_load_error">Pogreška pri učitavanju feeda</string>
|
<string name="feed_load_error">Pogreška pri učitavanju feeda</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Počevši od Androida 10, podržan je samo \'Storage Access Framework\'</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Počevši od Androida 10, podržan je samo \'Storage Access Framework\'</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">„Storage Access Framework“ nije podržan na Androidu KitKat i starijim</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Od vas će se tražiti gdje spremiti svako preuzimanje</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Od vas će se tražiti gdje spremiti svako preuzimanje</string>
|
||||||
<string name="dont_show">Ne prikazuj</string>
|
<string name="dont_show">Ne prikazuj</string>
|
||||||
<string name="low_quality_smaller">Niska kvaliteta (manji)</string>
|
<string name="low_quality_smaller">Niska kvaliteta (manji)</string>
|
||||||
|
|
|
@ -582,7 +582,6 @@
|
||||||
<string name="disable_media_tunneling_summary">Tiltsa le a médiacsatornázást, ha fekete képernyőt vagy akadozást tapasztal videólejátszáskor</string>
|
<string name="disable_media_tunneling_summary">Tiltsa le a médiacsatornázást, ha fekete képernyőt vagy akadozást tapasztal videólejátszáskor</string>
|
||||||
<string name="show_image_indicators_summary">Picasso színes szalagok megjelenítése a képek fölött, megjelölve a forrásukat: piros a hálózathoz, kék a lemezhez, zöld a memóriához</string>
|
<string name="show_image_indicators_summary">Picasso színes szalagok megjelenítése a képek fölött, megjelölve a forrásukat: piros a hálózathoz, kék a lemezhez, zöld a memóriához</string>
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Minden letöltésnél meg fogja kérdezni, hogy hova mentse el</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Minden letöltésnél meg fogja kérdezni, hogy hova mentse el</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">A „Storage Access Framework” nem támogatott Android KitKaten vagy régebbin</string>
|
|
||||||
<string name="choose_instance_prompt">Válasszon egy példányt</string>
|
<string name="choose_instance_prompt">Válasszon egy példányt</string>
|
||||||
<string name="feed_oldest_subscription_update">Lista legutóbbi frissítése: %s</string>
|
<string name="feed_oldest_subscription_update">Lista legutóbbi frissítése: %s</string>
|
||||||
<string name="feed_notification_loading">Lista betöltése…</string>
|
<string name="feed_notification_loading">Lista betöltése…</string>
|
||||||
|
|
|
@ -623,7 +623,6 @@
|
||||||
<string name="feed_load_error_account_info">Tidak bisa memuat langganan untuk \'%s\'.</string>
|
<string name="feed_load_error_account_info">Tidak bisa memuat langganan untuk \'%s\'.</string>
|
||||||
<string name="feed_load_error">Galat memuat langganan</string>
|
<string name="feed_load_error">Galat memuat langganan</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Mulai Android 10, hanya \'Storage Access Framework\' yang didukung</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Mulai Android 10, hanya \'Storage Access Framework\' yang didukung</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' tidak didukung pada Android KitKat dan yang lebih rendah</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Anda akan ditanya lokasi penyimpanan berkas unduhan</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Anda akan ditanya lokasi penyimpanan berkas unduhan</string>
|
||||||
<string name="no_dir_yet">Belum ada folder unduhan, pilih folder unduhan sekarang</string>
|
<string name="no_dir_yet">Belum ada folder unduhan, pilih folder unduhan sekarang</string>
|
||||||
<string name="off">Nonaktif</string>
|
<string name="off">Nonaktif</string>
|
||||||
|
|
|
@ -633,7 +633,6 @@
|
||||||
<string name="feed_load_error_account_info">Impossibile caricare feed per \"%s\".</string>
|
<string name="feed_load_error_account_info">Impossibile caricare feed per \"%s\".</string>
|
||||||
<string name="feed_load_error">Errore caricamento feed</string>
|
<string name="feed_load_error">Errore caricamento feed</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">A partire da Android 10 è supportato solo il Framework di accesso all\'archiviazione</string>
|
<string name="downloads_storage_use_saf_summary_api_29">A partire da Android 10 è supportato solo il Framework di accesso all\'archiviazione</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Il Framework di accesso all\'archiviazione non è supportato su Android KitKat e versioni precedenti</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">È necessario specificare la destinazione di ogni dowload</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">È necessario specificare la destinazione di ogni dowload</string>
|
||||||
<string name="no_dir_yet">Non è impostata alcuna cartella per i file scaricati, scegliere quella predefinita</string>
|
<string name="no_dir_yet">Non è impostata alcuna cartella per i file scaricati, scegliere quella predefinita</string>
|
||||||
<string name="off">Disattivata</string>
|
<string name="off">Disattivata</string>
|
||||||
|
|
|
@ -614,7 +614,6 @@
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">ダウンロードのたびに保存する場所を尋ねます</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">ダウンロードのたびに保存する場所を尋ねます</string>
|
||||||
<string name="no_dir_yet">ダウンロードフォルダがまだ設定されていません。今すぐデフォルトのフォルダを選択してください</string>
|
<string name="no_dir_yet">ダウンロードフォルダがまだ設定されていません。今すぐデフォルトのフォルダを選択してください</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Android 10 以降は \'Storage Access Framework\' のみがサポートされます</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Android 10 以降は \'Storage Access Framework\' のみがサポートされます</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' は Android KitKat 以下ではサポートされていません</string>
|
|
||||||
<string name="feed_load_error_fast_unknown">高速モードでこの情報の詳細は提供されません。</string>
|
<string name="feed_load_error_fast_unknown">高速モードでこの情報の詳細は提供されません。</string>
|
||||||
<string name="feed_load_error_account_info">\'%s\' のフィードを読み込めませんでした。</string>
|
<string name="feed_load_error_account_info">\'%s\' のフィードを読み込めませんでした。</string>
|
||||||
<string name="feed_load_error">フィードの読み込みエラー</string>
|
<string name="feed_load_error">フィードの読み込みエラー</string>
|
||||||
|
|
|
@ -647,7 +647,6 @@
|
||||||
\nAr norite atsisakyti šio kanalo prenumeratos\?</string>
|
\nAr norite atsisakyti šio kanalo prenumeratos\?</string>
|
||||||
<string name="feed_load_error">Klaida įkeliant srautą</string>
|
<string name="feed_load_error">Klaida įkeliant srautą</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Pradedant Android 10 palaikoma tik \'Storage Access Framework\'</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Pradedant Android 10 palaikoma tik \'Storage Access Framework\'</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' nėra palaikomas Android KitKat ir žemesnėse versijose</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Jūsų bus paklausta, kur išsaugoti kiekvieną atsiuntimą</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Jūsų bus paklausta, kur išsaugoti kiekvieną atsiuntimą</string>
|
||||||
<string name="no_dir_yet">Atsiuntimo aplankas dar nenustatytas, pasirinkite numatytąjį atsiuntimų aplanką dabar</string>
|
<string name="no_dir_yet">Atsiuntimo aplankas dar nenustatytas, pasirinkite numatytąjį atsiuntimų aplanką dabar</string>
|
||||||
<string name="comments_are_disabled">Komentarai yra išjungti</string>
|
<string name="comments_are_disabled">Komentarai yra išjungti</string>
|
||||||
|
|
|
@ -636,7 +636,6 @@
|
||||||
<string name="disable_media_tunneling_title">Izslēgt multivides tuneļošanu</string>
|
<string name="disable_media_tunneling_title">Izslēgt multivides tuneļošanu</string>
|
||||||
<string name="disable_media_tunneling_summary">Izslēdziet multivides tuneļošanu, ja jums video atskaņošanas laikā parādās melns ekrāns vai aizķeršanās</string>
|
<string name="disable_media_tunneling_summary">Izslēdziet multivides tuneļošanu, ja jums video atskaņošanas laikā parādās melns ekrāns vai aizķeršanās</string>
|
||||||
<string name="show_image_indicators_summary">Rādīt krāsainas lentes virs attēliem, norādot to avotu: sarkana - tīkls, zila - disks, zaļa - atmiņa</string>
|
<string name="show_image_indicators_summary">Rādīt krāsainas lentes virs attēliem, norādot to avotu: sarkana - tīkls, zila - disks, zaļa - atmiņa</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">“Krātuves Piekļuves Sistēma” ir neatbalstīta uz Android KitKat un zemākām versijām</string>
|
|
||||||
<string name="description_select_enable">Ieslēgt teksta atlasīšanu video aprakstā</string>
|
<string name="description_select_enable">Ieslēgt teksta atlasīšanu video aprakstā</string>
|
||||||
<string name="no_dir_yet">Lejupielādes mape vēl nav iestatīta, izvēlieties noklusējuma lejupielādes mapi</string>
|
<string name="no_dir_yet">Lejupielādes mape vēl nav iestatīta, izvēlieties noklusējuma lejupielādes mapi</string>
|
||||||
<string name="main_page_content_swipe_remove">Pārvelciet objektus, lai tos noņemtu</string>
|
<string name="main_page_content_swipe_remove">Pārvelciet objektus, lai tos noņemtu</string>
|
||||||
|
|
|
@ -639,7 +639,6 @@
|
||||||
<string name="feed_load_error">ഫീഡ് ലോഡ് ചെയ്യുന്നതിൽ പിശക് സംഭവിച്ചിരിക്കുന്നു</string>
|
<string name="feed_load_error">ഫീഡ് ലോഡ് ചെയ്യുന്നതിൽ പിശക് സംഭവിച്ചിരിക്കുന്നു</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">ആൻഡ്രോയ്ഡ് 10 മുതൽ മാത്രമേ \"സ്റ്റോറേജ് അക്സസ് ഫ്രെയിംവർക്ക്\" പിന്തുണക്കു</string>
|
<string name="downloads_storage_use_saf_summary_api_29">ആൻഡ്രോയ്ഡ് 10 മുതൽ മാത്രമേ \"സ്റ്റോറേജ് അക്സസ് ഫ്രെയിംവർക്ക്\" പിന്തുണക്കു</string>
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">എവിടെ ആണ് ഡൌൺലോഡ് ചെയ്യ്യപെടുന്ന ഓരോ ഫയൽലും സംരക്ഷിക്കപ്പെടേണ്ടത് എന്ന് തങ്കളോട് ചോദിക്കും</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">എവിടെ ആണ് ഡൌൺലോഡ് ചെയ്യ്യപെടുന്ന ഓരോ ഫയൽലും സംരക്ഷിക്കപ്പെടേണ്ടത് എന്ന് തങ്കളോട് ചോദിക്കും</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">ആൻഡ്രോയ്ഡ് കിറ്റ് ക്യാറ്റോ അതിനു താഴെക്കോ ഉള്ളതിൽ \"സ്റ്റോറേജ് ആസസ്സ് ഫ്രെയിംവർക്ക് പിന്തുണക്കുന്നില്ല</string>
|
|
||||||
<string name="dont_show">കാണിക്കരുത്</string>
|
<string name="dont_show">കാണിക്കരുത്</string>
|
||||||
<string name="low_quality_smaller">കുറഞ്ഞ നിലവാരം (ചെറുത് )</string>
|
<string name="low_quality_smaller">കുറഞ്ഞ നിലവാരം (ചെറുത് )</string>
|
||||||
<string name="high_quality_larger">ഉയർന്ന നിലവാരം (വലിയത് )</string>
|
<string name="high_quality_larger">ഉയർന്ന നിലവാരം (വലിയത് )</string>
|
||||||
|
|
|
@ -618,7 +618,6 @@
|
||||||
<string name="feed_load_error_account_info">Kunne ikke laste inn informasjonskanal for «%s».</string>
|
<string name="feed_load_error_account_info">Kunne ikke laste inn informasjonskanal for «%s».</string>
|
||||||
<string name="feed_load_error">Kunne ikke laste inn informasjonskanal</string>
|
<string name="feed_load_error">Kunne ikke laste inn informasjonskanal</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Fra Android 10 er kun «lagringstilgangsrammeverk» støttet</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Fra Android 10 er kun «lagringstilgangsrammeverk» støttet</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">«Lagringstilgangsrammeverket» støttes ikke på Android KitKat og tidligere.</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Du vil bli spurt om hvor du vil lagre hver nedlastning</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Du vil bli spurt om hvor du vil lagre hver nedlastning</string>
|
||||||
<string name="seekbar_preview_thumbnail_title">Miniatyrbildeforhåndsvisning</string>
|
<string name="seekbar_preview_thumbnail_title">Miniatyrbildeforhåndsvisning</string>
|
||||||
<string name="no_dir_yet">Ingen nedlastingsmappe valgt. Velg forvalgt nedlastingsmappe nå.</string>
|
<string name="no_dir_yet">Ingen nedlastingsmappe valgt. Velg forvalgt nedlastingsmappe nå.</string>
|
||||||
|
|
|
@ -637,7 +637,6 @@
|
||||||
<string name="feed_load_error_account_info">Kan geen feed laden voor \'%s\'.</string>
|
<string name="feed_load_error_account_info">Kan geen feed laden voor \'%s\'.</string>
|
||||||
<string name="feed_load_error">Error bij het inladen van de feed</string>
|
<string name="feed_load_error">Error bij het inladen van de feed</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Vanaf Android 10 is enkel \'Storage Access Framework\' ondersteund</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Vanaf Android 10 is enkel \'Storage Access Framework\' ondersteund</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Het \'Storage Access Framework\' is niet ondersteund op Android KitKat en lager</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">U wordt gevraagd waar elk bestand wordt opgeslagen</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">U wordt gevraagd waar elk bestand wordt opgeslagen</string>
|
||||||
<string name="no_dir_yet">Nog geen downloadfolder gekozen, kies de standaard downloadfolder</string>
|
<string name="no_dir_yet">Nog geen downloadfolder gekozen, kies de standaard downloadfolder</string>
|
||||||
<string name="detail_heart_img_view_description">Geliefd door de maker</string>
|
<string name="detail_heart_img_view_description">Geliefd door de maker</string>
|
||||||
|
|
|
@ -529,7 +529,6 @@
|
||||||
<string name="app_language_title">ਐਪ ਭਾਸ਼ਾ</string>
|
<string name="app_language_title">ਐਪ ਭਾਸ਼ਾ</string>
|
||||||
<string name="choose_instance_prompt">ਕੋਈ ਸਥਿਤੀ ਚੁਣੋ</string>
|
<string name="choose_instance_prompt">ਕੋਈ ਸਥਿਤੀ ਚੁਣੋ</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">\'ਸਟੋਰੇਜ ਐਕਸੈੱਸ ਫ਼ਰੇਮਵਰਕ\' ਐਂਡਰਾਇਡ 10 ਤੋਂ ਕੰਮ ਕਰਨਾ ਸ਼ੁਰੂ ਕਰਦਾ ਹੈ</string>
|
<string name="downloads_storage_use_saf_summary_api_29">\'ਸਟੋਰੇਜ ਐਕਸੈੱਸ ਫ਼ਰੇਮਵਰਕ\' ਐਂਡਰਾਇਡ 10 ਤੋਂ ਕੰਮ ਕਰਨਾ ਸ਼ੁਰੂ ਕਰਦਾ ਹੈ</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'ਸਟੋਰੇਜ ਐਕਸੈੱਸ ਫ਼ਰੇਮਵਰਕ\' ਐਂਡਰਾਇਡ ਕਿਟਕੈਟ ਅਤੇ ਇਸਤੋਂ ਹੇਠਾਂ ਦੇ ਵਰਜਨਾਂ \'ਤੇ ਕੰਮ ਨਹੀਂ ਕਰਦਾ</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">ਤੁਹਾਨੂੰ ਹਰ ਵਾਰ ਪੁੱਛਿਆ ਜਾਵੇਗਾ ਕਿ ਡਾਊਨਲੋਡ ਨੂੰ ਕਿੱਥੇ ਸਾਂਭਣਾ ਹੈ</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">ਤੁਹਾਨੂੰ ਹਰ ਵਾਰ ਪੁੱਛਿਆ ਜਾਵੇਗਾ ਕਿ ਡਾਊਨਲੋਡ ਨੂੰ ਕਿੱਥੇ ਸਾਂਭਣਾ ਹੈ</string>
|
||||||
<string name="delete_downloaded_files">ਡਾਊਨਲੋਡ ਕੀਤੀਆਂ ਫ਼ਾਈਲਾਂ ਮਿਟਾਓ</string>
|
<string name="delete_downloaded_files">ਡਾਊਨਲੋਡ ਕੀਤੀਆਂ ਫ਼ਾਈਲਾਂ ਮਿਟਾਓ</string>
|
||||||
<string name="clear_download_history">ਡਾਊਨਲੋਡ ਇਤਿਹਾਸ ਸਾਫ਼ ਕਰੋ</string>
|
<string name="clear_download_history">ਡਾਊਨਲੋਡ ਇਤਿਹਾਸ ਸਾਫ਼ ਕਰੋ</string>
|
||||||
|
|
|
@ -646,7 +646,6 @@
|
||||||
\nCzy chcesz anulować subskrypcję tego kanału\?</string>
|
\nCzy chcesz anulować subskrypcję tego kanału\?</string>
|
||||||
<string name="feed_load_error_account_info">Nie udało się załadować kanału dla „%s”.</string>
|
<string name="feed_load_error_account_info">Nie udało się załadować kanału dla „%s”.</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Począwszy od Androida 10 obsługiwany jest tylko systemowy selektor folderów (SAF)</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Począwszy od Androida 10 obsługiwany jest tylko systemowy selektor folderów (SAF)</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Systemowy selektor folderów (SAF) nie jest obsługiwany przez system Android KitKat i niższy</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Zostaniesz zapytany(-na), gdzie zapisać każdy pobierany plik</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Zostaniesz zapytany(-na), gdzie zapisać każdy pobierany plik</string>
|
||||||
<string name="no_dir_yet">Nie ustawiono jeszcze folderu zapisywania, wybierz domyślny teraz</string>
|
<string name="no_dir_yet">Nie ustawiono jeszcze folderu zapisywania, wybierz domyślny teraz</string>
|
||||||
<string name="feed_load_error">Błąd podczas ładowania kanału</string>
|
<string name="feed_load_error">Błąd podczas ładowania kanału</string>
|
||||||
|
|
|
@ -633,7 +633,6 @@
|
||||||
<string name="feed_load_error_account_info">Não foi possível carregar o feed para \'%s\'.</string>
|
<string name="feed_load_error_account_info">Não foi possível carregar o feed para \'%s\'.</string>
|
||||||
<string name="feed_load_error">Erro ao carregar o feed</string>
|
<string name="feed_load_error">Erro ao carregar o feed</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">O \'Storage Access Framework\' é compatível apenas com versões a partir do Android 10</string>
|
<string name="downloads_storage_use_saf_summary_api_29">O \'Storage Access Framework\' é compatível apenas com versões a partir do Android 10</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">O \'Storage Access Framework\' não é compatível com Android KitKat e versões anteriores</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Você será questionado onde salvar cada download</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Você será questionado onde salvar cada download</string>
|
||||||
<string name="no_dir_yet">Nenhuma pasta de download definida ainda, escolha a pasta de download padrão agora</string>
|
<string name="no_dir_yet">Nenhuma pasta de download definida ainda, escolha a pasta de download padrão agora</string>
|
||||||
<string name="off">Desligado</string>
|
<string name="off">Desligado</string>
|
||||||
|
|
|
@ -638,7 +638,6 @@
|
||||||
<string name="feed_load_error_account_info">Não foi possível carregar o feed para \'%s\'.</string>
|
<string name="feed_load_error_account_info">Não foi possível carregar o feed para \'%s\'.</string>
|
||||||
<string name="feed_load_error">Erro ao carregar o feed</string>
|
<string name="feed_load_error">Erro ao carregar o feed</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">A partir do Android 10, apenas o \'Storage Access Framework\' é compatível</string>
|
<string name="downloads_storage_use_saf_summary_api_29">A partir do Android 10, apenas o \'Storage Access Framework\' é compatível</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' não é compatível com Android KitKat e versões anteriores</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Sempre que descarregar um ficheiro, terá que indicar o local para o guardar</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Sempre que descarregar um ficheiro, terá que indicar o local para o guardar</string>
|
||||||
<string name="dont_show">Não mostrar</string>
|
<string name="dont_show">Não mostrar</string>
|
||||||
<string name="low_quality_smaller">Baixa qualidade (menor)</string>
|
<string name="low_quality_smaller">Baixa qualidade (menor)</string>
|
||||||
|
|
|
@ -619,7 +619,6 @@
|
||||||
<string name="feed_load_error_account_info">Não foi possível carregar o feed para \'%s\'.</string>
|
<string name="feed_load_error_account_info">Não foi possível carregar o feed para \'%s\'.</string>
|
||||||
<string name="feed_load_error">Erro ao carregar o feed</string>
|
<string name="feed_load_error">Erro ao carregar o feed</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">A partir do Android 10, apenas o \'Storage Access Framework\' é compatível</string>
|
<string name="downloads_storage_use_saf_summary_api_29">A partir do Android 10, apenas o \'Storage Access Framework\' é compatível</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">A \'Framework de acesso ao armazenamento\' não está disponível no Android KitKat e anteriores</string>
|
|
||||||
<string name="seekbar_preview_thumbnail_title">Pré-visualização da miniatura da barra de pesquisa</string>
|
<string name="seekbar_preview_thumbnail_title">Pré-visualização da miniatura da barra de pesquisa</string>
|
||||||
<string name="mark_as_watched">Marcar como visto</string>
|
<string name="mark_as_watched">Marcar como visto</string>
|
||||||
<string name="off">Desligado</string>
|
<string name="off">Desligado</string>
|
||||||
|
|
|
@ -649,7 +649,6 @@
|
||||||
<string name="feed_load_error_account_info">Nu s-a putut încărca fluxul pentru \"%s\".</string>
|
<string name="feed_load_error_account_info">Nu s-a putut încărca fluxul pentru \"%s\".</string>
|
||||||
<string name="feed_load_error">Eroare la încărcarea fluxului</string>
|
<string name="feed_load_error">Eroare la încărcarea fluxului</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Începând cu Android 10, este acceptat doar \"Storage Access Framework\"</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Începând cu Android 10, este acceptat doar \"Storage Access Framework\"</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\"Storage Access Framework\" nu este acceptat pe Android KitKat și versiunile ulterioare</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Veți fi întrebat unde să salvați fiecare descărcare</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Veți fi întrebat unde să salvați fiecare descărcare</string>
|
||||||
<plurals name="deleted_downloads_toast">
|
<plurals name="deleted_downloads_toast">
|
||||||
<item quantity="one">S-a șters %1$s descărcare</item>
|
<item quantity="one">S-a șters %1$s descărcare</item>
|
||||||
|
|
|
@ -651,7 +651,6 @@
|
||||||
<string name="service_provides_reason">%s указывает следующую причину:</string>
|
<string name="service_provides_reason">%s указывает следующую причину:</string>
|
||||||
<string name="account_terminated">Аккаунт отключён</string>
|
<string name="account_terminated">Аккаунт отключён</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Начиная с Android 10 поддерживается только \"Storage Access Framework\"</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Начиная с Android 10 поддерживается только \"Storage Access Framework\"</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\"Storage Access Framework\" не поддерживается на Android KitKat и ниже</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Спрашивать, куда сохранять каждую загрузку</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Спрашивать, куда сохранять каждую загрузку</string>
|
||||||
<string name="no_dir_yet">Папка для загрузки ещё не выбрана, укажите папку для загрузки сейчас</string>
|
<string name="no_dir_yet">Папка для загрузки ещё не выбрана, укажите папку для загрузки сейчас</string>
|
||||||
<string name="off">Отключить</string>
|
<string name="off">Отключить</string>
|
||||||
|
|
|
@ -633,7 +633,6 @@
|
||||||
\nCheres bogare s\'iscritzione a custu canale\?</string>
|
\nCheres bogare s\'iscritzione a custu canale\?</string>
|
||||||
<string name="feed_load_error_account_info">Carrigamentu de su flussu pro \'%s\' fallidu.</string>
|
<string name="feed_load_error_account_info">Carrigamentu de su flussu pro \'%s\' fallidu.</string>
|
||||||
<string name="feed_load_error">Errore carrighende su flussu</string>
|
<string name="feed_load_error">Errore carrighende su flussu</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Su \'Storage Access Framework\' no est suportadu in Android KitKat e versiones prus betzas</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">T\'at a bènnere pedidu in ue sarvare cada documentu</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">T\'at a bènnere pedidu in ue sarvare cada documentu</string>
|
||||||
<string name="no_dir_yet">Non b\'at galu peruna cartella de iscarrigamentu impostada. Issèbera como sa cartella de iscarrigamentu predefinida</string>
|
<string name="no_dir_yet">Non b\'at galu peruna cartella de iscarrigamentu impostada. Issèbera como sa cartella de iscarrigamentu predefinida</string>
|
||||||
<string name="off">Istudadu</string>
|
<string name="off">Istudadu</string>
|
||||||
|
|
|
@ -643,7 +643,6 @@
|
||||||
<string name="feed_load_error_account_info">Nemožno načítať informačný kanál \'%s\'.</string>
|
<string name="feed_load_error_account_info">Nemožno načítať informačný kanál \'%s\'.</string>
|
||||||
<string name="feed_load_error">Chyba pri načítaní kanála</string>
|
<string name="feed_load_error">Chyba pri načítaní kanála</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">\'Storage Access Framework\' je podporovaný len od Androidu 10 a vyššie</string>
|
<string name="downloads_storage_use_saf_summary_api_29">\'Storage Access Framework\' je podporovaný len od Androidu 10 a vyššie</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' nie je podporovaný v systéme Android KitKat a ani v starších verziách</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Pri každom sťahovaní sa zobrazí výzva kam uložiť súbor</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Pri každom sťahovaní sa zobrazí výzva kam uložiť súbor</string>
|
||||||
<string name="no_dir_yet">Nie je nastavený adresár na sťahovanie, nastavte ho teraz</string>
|
<string name="no_dir_yet">Nie je nastavený adresár na sťahovanie, nastavte ho teraz</string>
|
||||||
<string name="mark_as_watched">Označiť ako videné</string>
|
<string name="mark_as_watched">Označiť ako videné</string>
|
||||||
|
|
|
@ -633,7 +633,6 @@
|
||||||
<string name="feed_load_error_account_info">Lama soo kicin karo bandhigga: \'%s\'.</string>
|
<string name="feed_load_error_account_info">Lama soo kicin karo bandhigga: \'%s\'.</string>
|
||||||
<string name="feed_load_error">Khalad ayaa ka dhacay sookicintii</string>
|
<string name="feed_load_error">Khalad ayaa ka dhacay sookicintii</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Laga bilaabo Android 10 kaliya waxaa la isticmaali \'SAF\'</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Laga bilaabo Android 10 kaliya waxaa la isticmaali \'SAF\'</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'SAF\' kuma shaqeeyo Android KitKat iyo wixii ka hooseeya</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Dajin walba meeshii lagu kaydin lahaa ayaa lagu waydiin</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Dajin walba meeshii lagu kaydin lahaa ayaa lagu waydiin</string>
|
||||||
<string name="disable_media_tunneling_summary">Iska xidh kala-leexinta muuqaalada/dhagaysiga hadaad lakulanto shaashad madow ama muuqaalka oo isistaaga</string>
|
<string name="disable_media_tunneling_summary">Iska xidh kala-leexinta muuqaalada/dhagaysiga hadaad lakulanto shaashad madow ama muuqaalka oo isistaaga</string>
|
||||||
<string name="disable_media_tunneling_title">Xidh kala-leexinta</string>
|
<string name="disable_media_tunneling_title">Xidh kala-leexinta</string>
|
||||||
|
|
|
@ -626,7 +626,6 @@
|
||||||
<string name="feed_load_error_account_info">Nuk u arrit të ngarkohej feed-i për \'%s\'.</string>
|
<string name="feed_load_error_account_info">Nuk u arrit të ngarkohej feed-i për \'%s\'.</string>
|
||||||
<string name="feed_load_error">Gabim gjatë ngarkimit të feed-it</string>
|
<string name="feed_load_error">Gabim gjatë ngarkimit të feed-it</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Duke nisur nga Android 10 vetëm \'Storage Access Framework\' është i mbështetur</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Duke nisur nga Android 10 vetëm \'Storage Access Framework\' është i mbështetur</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' nuk është e mbështetur në Android KitKat dhe më poshtë</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Ju do të pyeteni se ku doni të ruani çdo shkarkim</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Ju do të pyeteni se ku doni të ruani çdo shkarkim</string>
|
||||||
<string name="crash_the_app">Rrëzoje aplikacionin manualisht</string>
|
<string name="crash_the_app">Rrëzoje aplikacionin manualisht</string>
|
||||||
<string name="disable_media_tunneling_summary">Ç\'aktivizo tunelin e medias nëse po hasni një ekran të zi apo ngecje gjatë luajtjes së një videoje</string>
|
<string name="disable_media_tunneling_summary">Ç\'aktivizo tunelin e medias nëse po hasni një ekran të zi apo ngecje gjatë luajtjes së një videoje</string>
|
||||||
|
|
|
@ -642,7 +642,6 @@
|
||||||
<string name="feed_load_error_account_info">Не могу да учитам довод за „%s“.</string>
|
<string name="feed_load_error_account_info">Не могу да учитам довод за „%s“.</string>
|
||||||
<string name="feed_load_error">Грешка учитавања довода</string>
|
<string name="feed_load_error">Грешка учитавања довода</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Од Андроида 10 само „Storage Access Framework“ је подржан</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Од Андроида 10 само „Storage Access Framework“ је подржан</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">„Storage Access Framework“ није подржан на Андроиду 4.4 и старијим</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Питаће вас где да сачувате свако преузимање</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Питаће вас где да сачувате свако преузимање</string>
|
||||||
<string name="no_dir_yet">Фасцикла за преузимање није одређена. Изаберите подразумевану фасциклу</string>
|
<string name="no_dir_yet">Фасцикла за преузимање није одређена. Изаберите подразумевану фасциклу</string>
|
||||||
<string name="off">искљ</string>
|
<string name="off">искљ</string>
|
||||||
|
|
|
@ -633,7 +633,6 @@
|
||||||
<string name="feed_toggle_show_played_items">Visa sedda objekt</string>
|
<string name="feed_toggle_show_played_items">Visa sedda objekt</string>
|
||||||
<string name="feed_load_error_fast_unknown">Det snabba flödesläget ger inte mer information om detta.</string>
|
<string name="feed_load_error_fast_unknown">Det snabba flödesläget ger inte mer information om detta.</string>
|
||||||
<string name="feed_load_error">Fel vid inläsning av flödet</string>
|
<string name="feed_load_error">Fel vid inläsning av flödet</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\"Storage Access Framework\" är inte tillgängligt på Android KitKat och tidigare versioner</string>
|
|
||||||
<string name="mark_as_watched">Markera som sedd</string>
|
<string name="mark_as_watched">Markera som sedd</string>
|
||||||
<string name="metadata_privacy_unlisted">Ej listad</string>
|
<string name="metadata_privacy_unlisted">Ej listad</string>
|
||||||
<string name="featured">Aktuellt</string>
|
<string name="featured">Aktuellt</string>
|
||||||
|
|
|
@ -633,7 +633,6 @@
|
||||||
<string name="feed_load_error_account_info">\'%s\' için besleme yüklenemedi.</string>
|
<string name="feed_load_error_account_info">\'%s\' için besleme yüklenemedi.</string>
|
||||||
<string name="feed_load_error">Besleme yüklenirken hata</string>
|
<string name="feed_load_error">Besleme yüklenirken hata</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">\'Depolama Erişimi Çerçevesi\' yalnızca Android 10\'dan başlayarak desteklenmektedir</string>
|
<string name="downloads_storage_use_saf_summary_api_29">\'Depolama Erişimi Çerçevesi\' yalnızca Android 10\'dan başlayarak desteklenmektedir</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Depolama Erişimi Çerçevesi\' Android KitKat ve altında desteklenmez</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Her indirmede nereye kaydedileceği sorulacak</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Her indirmede nereye kaydedileceği sorulacak</string>
|
||||||
<string name="no_dir_yet">İndirme klasörü belirlenmedi, şimdi öntanımlı indirme klasörünü seçin</string>
|
<string name="no_dir_yet">İndirme klasörü belirlenmedi, şimdi öntanımlı indirme klasörünü seçin</string>
|
||||||
<string name="off">Kapat</string>
|
<string name="off">Kapat</string>
|
||||||
|
|
|
@ -620,7 +620,6 @@
|
||||||
<string name="disable_media_tunneling_summary">Вимкнення тунелювання медіаданих за наявності чорного екрана або гальмування під час відтворення відео</string>
|
<string name="disable_media_tunneling_summary">Вимкнення тунелювання медіаданих за наявності чорного екрана або гальмування під час відтворення відео</string>
|
||||||
<string name="disable_media_tunneling_title">Вимкнути тунелювання медіа</string>
|
<string name="disable_media_tunneling_title">Вимкнути тунелювання медіа</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">«Фреймворк доступу до сховища» (SAF) підтримується лише починаючи з Android 10</string>
|
<string name="downloads_storage_use_saf_summary_api_29">«Фреймворк доступу до сховища» (SAF) підтримується лише починаючи з Android 10</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">«Фреймворк доступу до сховища» (SAF) не підтримується в KitKat і нижче</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Вас питатиме, куди зберігати кожне завантаження</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Вас питатиме, куди зберігати кожне завантаження</string>
|
||||||
<string name="no_dir_yet">Не вказано теки завантаження, оберіть типову теку завантаження зараз</string>
|
<string name="no_dir_yet">Не вказано теки завантаження, оберіть типову теку завантаження зараз</string>
|
||||||
<string name="open_website_license">Відкрити вебсайт</string>
|
<string name="open_website_license">Відкрити вебсайт</string>
|
||||||
|
|
|
@ -627,7 +627,6 @@
|
||||||
<string name="feed_load_error_account_info">Không thể tải nguồn dữ liệu cho \'%s\'.</string>
|
<string name="feed_load_error_account_info">Không thể tải nguồn dữ liệu cho \'%s\'.</string>
|
||||||
<string name="feed_load_error">Lỗi khi tải nguồn dữ liệu</string>
|
<string name="feed_load_error">Lỗi khi tải nguồn dữ liệu</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">\'Storage Access Framework\' chỉ được hỗ trợ từ Android 10 trở đi</string>
|
<string name="downloads_storage_use_saf_summary_api_29">\'Storage Access Framework\' chỉ được hỗ trợ từ Android 10 trở đi</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">\'Storage Access Framework\' không được hỗ trợ trên Android KitKat và cũ hơn</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">Bạn sẽ được hỏi nơi bạn muốn lưu mỗi mục tải xuống</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">Bạn sẽ được hỏi nơi bạn muốn lưu mỗi mục tải xuống</string>
|
||||||
<string name="no_dir_yet">Chưa có thư mục tải xuống nào được đặt, hãy chọn thư mục tải xuống mặc định ngay</string>
|
<string name="no_dir_yet">Chưa có thư mục tải xuống nào được đặt, hãy chọn thư mục tải xuống mặc định ngay</string>
|
||||||
<string name="dont_show">Không hiện</string>
|
<string name="dont_show">Không hiện</string>
|
||||||
|
|
|
@ -623,7 +623,6 @@
|
||||||
<string name="feed_load_error_account_info">无法加载“%s”的 Feed。</string>
|
<string name="feed_load_error_account_info">无法加载“%s”的 Feed。</string>
|
||||||
<string name="feed_load_error">加载 Feed 时出错</string>
|
<string name="feed_load_error">加载 Feed 时出错</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">仅 Android 10 及以上版本支持“存储访问框架”</string>
|
<string name="downloads_storage_use_saf_summary_api_29">仅 Android 10 及以上版本支持“存储访问框架”</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Android KitKat 及更低版本不支持“存储访问框架”</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">你会被问到在哪里保存每个下载</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">你会被问到在哪里保存每个下载</string>
|
||||||
<string name="no_dir_yet">尚未设置下载文件夹,现在选择默认下载文件夹</string>
|
<string name="no_dir_yet">尚未设置下载文件夹,现在选择默认下载文件夹</string>
|
||||||
<string name="tablet_mode_title">平板模式</string>
|
<string name="tablet_mode_title">平板模式</string>
|
||||||
|
|
|
@ -563,7 +563,6 @@
|
||||||
<string name="preferred_open_action_settings_summary">預設開啟內容嘅時候做咩好 — %s</string>
|
<string name="preferred_open_action_settings_summary">預設開啟內容嘅時候做咩好 — %s</string>
|
||||||
<string name="unhook_checkbox">脫鈎 (聲音可能會失真)</string>
|
<string name="unhook_checkbox">脫鈎 (聲音可能會失真)</string>
|
||||||
<string name="playback_step">飛前一格</string>
|
<string name="playback_step">飛前一格</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Android KitKat 以及樓下唔支援「儲存空間存取框架」</string>
|
|
||||||
<string name="no_playlist_bookmarked_yet">未有收起嘅播放清單</string>
|
<string name="no_playlist_bookmarked_yet">未有收起嘅播放清單</string>
|
||||||
<string name="play_all">照單全播</string>
|
<string name="play_all">照單全播</string>
|
||||||
<string name="no_channel_subscribed_yet">未有頻道訂閱</string>
|
<string name="no_channel_subscribed_yet">未有頻道訂閱</string>
|
||||||
|
|
|
@ -623,7 +623,6 @@
|
||||||
<string name="feed_load_error_account_info">無法載入「%s」。</string>
|
<string name="feed_load_error_account_info">無法載入「%s」。</string>
|
||||||
<string name="feed_load_error">載入 feed 時發生錯誤</string>
|
<string name="feed_load_error">載入 feed 時發生錯誤</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">從 Android 10 開始僅支援「儲存空間存取框架」</string>
|
<string name="downloads_storage_use_saf_summary_api_29">從 Android 10 開始僅支援「儲存空間存取框架」</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">Android KitKat 或更舊的版本不支援「儲存空間存取框架」</string>
|
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">每次下載都會詢問您要下載到哪裡</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">每次下載都會詢問您要下載到哪裡</string>
|
||||||
<string name="no_dir_yet">尚未設定下載資料夾,立刻選擇預設的下載資料夾</string>
|
<string name="no_dir_yet">尚未設定下載資料夾,立刻選擇預設的下載資料夾</string>
|
||||||
<string name="off">關閉</string>
|
<string name="off">關閉</string>
|
||||||
|
|
|
@ -615,7 +615,6 @@
|
||||||
<string name="downloads_storage_ask_summary_no_saf_notice">You will be asked where to save each download</string>
|
<string name="downloads_storage_ask_summary_no_saf_notice">You will be asked where to save each download</string>
|
||||||
<string name="downloads_storage_use_saf_title">Use system folder picker (SAF)</string>
|
<string name="downloads_storage_use_saf_title">Use system folder picker (SAF)</string>
|
||||||
<string name="downloads_storage_use_saf_summary">The \'Storage Access Framework\' allows downloads to an external SD card</string>
|
<string name="downloads_storage_use_saf_summary">The \'Storage Access Framework\' allows downloads to an external SD card</string>
|
||||||
<string name="downloads_storage_use_saf_summary_api_19">The \'Storage Access Framework\' is not supported on Android KitKat and below</string>
|
|
||||||
<string name="downloads_storage_use_saf_summary_api_29">Starting from Android 10 only \'Storage Access Framework\' is supported</string>
|
<string name="downloads_storage_use_saf_summary_api_29">Starting from Android 10 only \'Storage Access Framework\' is supported</string>
|
||||||
<string name="choose_instance_prompt">Choose an instance</string>
|
<string name="choose_instance_prompt">Choose an instance</string>
|
||||||
<string name="app_language_title">App language</string>
|
<string name="app_language_title">App language</string>
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
app:iconSpaceReserved="false" />
|
app:iconSpaceReserved="false" />
|
||||||
|
|
||||||
<SwitchPreferenceCompat
|
<SwitchPreferenceCompat
|
||||||
|
android:defaultValue="true"
|
||||||
android:key="@string/storage_use_saf"
|
android:key="@string/storage_use_saf"
|
||||||
android:summary="@string/downloads_storage_use_saf_summary"
|
android:summary="@string/downloads_storage_use_saf_summary"
|
||||||
android:title="@string/downloads_storage_use_saf_title"
|
android:title="@string/downloads_storage_use_saf_title"
|
||||||
|
|
Loading…
Reference in New Issue