mirror of
https://code.briarproject.org/briar/briar.git
synced 2026-02-19 06:09:55 +01:00
Merge branch '2277-activity-not-found-exception' into 'master'
Catch ActivityNotFoundException when choosing files Closes #2277 See merge request briar/briar!1628
This commit is contained in:
@@ -58,6 +58,7 @@ import org.briarproject.briar.android.privategroup.conversation.GroupActivity;
|
|||||||
import org.briarproject.briar.android.removabledrive.RemovableDriveActivity;
|
import org.briarproject.briar.android.removabledrive.RemovableDriveActivity;
|
||||||
import org.briarproject.briar.android.util.ActivityLaunchers.GetImageAdvanced;
|
import org.briarproject.briar.android.util.ActivityLaunchers.GetImageAdvanced;
|
||||||
import org.briarproject.briar.android.util.ActivityLaunchers.GetMultipleImagesAdvanced;
|
import org.briarproject.briar.android.util.ActivityLaunchers.GetMultipleImagesAdvanced;
|
||||||
|
import org.briarproject.briar.android.util.ActivityLaunchers.OpenMultipleImageDocumentsAdvanced;
|
||||||
import org.briarproject.briar.android.util.BriarSnackbarBuilder;
|
import org.briarproject.briar.android.util.BriarSnackbarBuilder;
|
||||||
import org.briarproject.briar.android.view.BriarRecyclerView;
|
import org.briarproject.briar.android.view.BriarRecyclerView;
|
||||||
import org.briarproject.briar.android.view.ImagePreview;
|
import org.briarproject.briar.android.view.ImagePreview;
|
||||||
@@ -143,6 +144,7 @@ import static org.briarproject.briar.android.conversation.ImageActivity.ATTACHME
|
|||||||
import static org.briarproject.briar.android.conversation.ImageActivity.DATE;
|
import static org.briarproject.briar.android.conversation.ImageActivity.DATE;
|
||||||
import static org.briarproject.briar.android.conversation.ImageActivity.ITEM_ID;
|
import static org.briarproject.briar.android.conversation.ImageActivity.ITEM_ID;
|
||||||
import static org.briarproject.briar.android.conversation.ImageActivity.NAME;
|
import static org.briarproject.briar.android.conversation.ImageActivity.NAME;
|
||||||
|
import static org.briarproject.briar.android.util.UiUtils.launchActivityToOpenFile;
|
||||||
import static org.briarproject.briar.android.util.UiUtils.observeOnce;
|
import static org.briarproject.briar.android.util.UiUtils.observeOnce;
|
||||||
import static org.briarproject.briar.android.view.AuthorView.setAvatar;
|
import static org.briarproject.briar.android.view.AuthorView.setAvatar;
|
||||||
import static org.briarproject.briar.api.messaging.MessagingConstants.MAX_ATTACHMENTS_PER_MESSAGE;
|
import static org.briarproject.briar.api.messaging.MessagingConstants.MAX_ATTACHMENTS_PER_MESSAGE;
|
||||||
@@ -196,12 +198,18 @@ public class ConversationActivity extends BriarActivity
|
|||||||
requireNonNull(name);
|
requireNonNull(name);
|
||||||
loadMessages();
|
loadMessages();
|
||||||
};
|
};
|
||||||
private final ActivityResultLauncher<String> launcher = SDK_INT >= 18 ?
|
@Nullable
|
||||||
registerForActivityResult(new GetMultipleImagesAdvanced(),
|
private final ActivityResultLauncher<String[]> docLauncher = SDK_INT >= 19 ?
|
||||||
|
registerForActivityResult(new OpenMultipleImageDocumentsAdvanced(),
|
||||||
this::onImagesChosen) :
|
this::onImagesChosen) :
|
||||||
registerForActivityResult(new GetImageAdvanced(), uri -> {
|
null;
|
||||||
if (uri != null) onImagesChosen(singletonList(uri));
|
private final ActivityResultLauncher<String> contentLauncher =
|
||||||
});
|
SDK_INT >= 18 ?
|
||||||
|
registerForActivityResult(new GetMultipleImagesAdvanced(),
|
||||||
|
this::onImagesChosen) :
|
||||||
|
registerForActivityResult(new GetImageAdvanced(), uri -> {
|
||||||
|
if (uri != null) onImagesChosen(singletonList(uri));
|
||||||
|
});
|
||||||
|
|
||||||
private AttachmentRetriever attachmentRetriever;
|
private AttachmentRetriever attachmentRetriever;
|
||||||
private ConversationViewModel viewModel;
|
private ConversationViewModel viewModel;
|
||||||
@@ -424,9 +432,11 @@ public class ConversationActivity extends BriarActivity
|
|||||||
startActivity(intent);
|
startActivity(intent);
|
||||||
return true;
|
return true;
|
||||||
} else if (itemId == R.id.action_transfer_data) {
|
} else if (itemId == R.id.action_transfer_data) {
|
||||||
Intent intent = new Intent(this, RemovableDriveActivity.class);
|
if (SDK_INT >= 19) {
|
||||||
intent.putExtra(CONTACT_ID, contactId.getInt());
|
Intent intent = new Intent(this, RemovableDriveActivity.class);
|
||||||
startActivity(intent);
|
intent.putExtra(CONTACT_ID, contactId.getInt());
|
||||||
|
startActivity(intent);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
} else if (itemId == R.id.action_delete_all_messages) {
|
} else if (itemId == R.id.action_delete_all_messages) {
|
||||||
askToDeleteAllMessages();
|
askToDeleteAllMessages();
|
||||||
@@ -774,7 +784,7 @@ public class ConversationActivity extends BriarActivity
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onAttachImageClicked() {
|
public void onAttachImageClicked() {
|
||||||
launcher.launch("image/*");
|
launchActivityToOpenFile(this, docLauncher, contentLauncher, "image/*");
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onImagesChosen(@Nullable List<Uri> uris) {
|
private void onImagesChosen(@Nullable List<Uri> uris) {
|
||||||
|
|||||||
@@ -33,7 +33,6 @@ import javax.inject.Inject;
|
|||||||
|
|
||||||
import androidx.activity.result.ActivityResultLauncher;
|
import androidx.activity.result.ActivityResultLauncher;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.annotation.RequiresApi;
|
|
||||||
import androidx.appcompat.app.AlertDialog.Builder;
|
import androidx.appcompat.app.AlertDialog.Builder;
|
||||||
import androidx.appcompat.widget.Toolbar;
|
import androidx.appcompat.widget.Toolbar;
|
||||||
import androidx.fragment.app.Fragment;
|
import androidx.fragment.app.Fragment;
|
||||||
@@ -65,7 +64,6 @@ public class ImageActivity extends BriarActivity
|
|||||||
final static String DATE = "date";
|
final static String DATE = "date";
|
||||||
final static String ITEM_ID = "itemId";
|
final static String ITEM_ID = "itemId";
|
||||||
|
|
||||||
@RequiresApi(api = 16)
|
|
||||||
private final static int UI_FLAGS_DEFAULT =
|
private final static int UI_FLAGS_DEFAULT =
|
||||||
SYSTEM_UI_FLAG_LAYOUT_STABLE | SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN;
|
SYSTEM_UI_FLAG_LAYOUT_STABLE | SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN;
|
||||||
|
|
||||||
@@ -79,9 +77,11 @@ public class ImageActivity extends BriarActivity
|
|||||||
private List<AttachmentItem> attachments;
|
private List<AttachmentItem> attachments;
|
||||||
private MessageId conversationMessageId;
|
private MessageId conversationMessageId;
|
||||||
|
|
||||||
private final ActivityResultLauncher<String> launcher =
|
@Nullable
|
||||||
|
private final ActivityResultLauncher<String> launcher = SDK_INT >= 19 ?
|
||||||
registerForActivityResult(new CreateDocumentAdvanced(),
|
registerForActivityResult(new CreateDocumentAdvanced(),
|
||||||
this::onImageUriSelected);
|
this::onImageUriSelected) :
|
||||||
|
null;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void injectActivity(ActivityComponent component) {
|
public void injectActivity(ActivityComponent component) {
|
||||||
@@ -209,14 +209,12 @@ public class ImageActivity extends BriarActivity
|
|||||||
super.onBackPressed();
|
super.onBackPressed();
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequiresApi(api = 16)
|
|
||||||
private void onImageClicked(@Nullable Boolean clicked) {
|
private void onImageClicked(@Nullable Boolean clicked) {
|
||||||
if (clicked != null && clicked) {
|
if (clicked != null && clicked) {
|
||||||
toggleSystemUi();
|
toggleSystemUi();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequiresApi(api = 16)
|
|
||||||
private void toggleSystemUi() {
|
private void toggleSystemUi() {
|
||||||
View decorView = getWindow().getDecorView();
|
View decorView = getWindow().getDecorView();
|
||||||
if (appBarLayout.getVisibility() == VISIBLE) {
|
if (appBarLayout.getVisibility() == VISIBLE) {
|
||||||
@@ -226,7 +224,6 @@ public class ImageActivity extends BriarActivity
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequiresApi(api = 16)
|
|
||||||
private void hideSystemUi(View decorView) {
|
private void hideSystemUi(View decorView) {
|
||||||
decorView.setSystemUiVisibility(
|
decorView.setSystemUiVisibility(
|
||||||
SYSTEM_UI_FLAG_FULLSCREEN | UI_FLAGS_DEFAULT);
|
SYSTEM_UI_FLAG_FULLSCREEN | UI_FLAGS_DEFAULT);
|
||||||
@@ -237,7 +234,6 @@ public class ImageActivity extends BriarActivity
|
|||||||
.start();
|
.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
@RequiresApi(api = 16)
|
|
||||||
private void showSystemUi(View decorView) {
|
private void showSystemUi(View decorView) {
|
||||||
decorView.setSystemUiVisibility(UI_FLAGS_DEFAULT);
|
decorView.setSystemUiVisibility(UI_FLAGS_DEFAULT);
|
||||||
appBarLayout.animate()
|
appBarLayout.animate()
|
||||||
@@ -265,7 +261,7 @@ public class ImageActivity extends BriarActivity
|
|||||||
String name = viewModel.getFileName() + "." +
|
String name = viewModel.getFileName() + "." +
|
||||||
getVisibleAttachment().getExtension();
|
getVisibleAttachment().getExtension();
|
||||||
try {
|
try {
|
||||||
launcher.launch(name);
|
requireNonNull(launcher).launch(name);
|
||||||
} catch (ActivityNotFoundException e) {
|
} catch (ActivityNotFoundException e) {
|
||||||
viewModel.onSaveImageError();
|
viewModel.onSaveImageError();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -34,6 +34,7 @@ import static android.os.Build.VERSION.SDK_INT;
|
|||||||
import static android.view.View.INVISIBLE;
|
import static android.view.View.INVISIBLE;
|
||||||
import static android.view.View.VISIBLE;
|
import static android.view.View.VISIBLE;
|
||||||
import static androidx.transition.TransitionManager.beginDelayedTransition;
|
import static androidx.transition.TransitionManager.beginDelayedTransition;
|
||||||
|
import static org.briarproject.bramble.api.nullsafety.NullSafety.requireNonNull;
|
||||||
import static org.briarproject.briar.android.AppModule.getAndroidComponent;
|
import static org.briarproject.briar.android.AppModule.getAndroidComponent;
|
||||||
import static org.briarproject.briar.android.hotspot.HotspotViewModel.getApkFileName;
|
import static org.briarproject.briar.android.hotspot.HotspotViewModel.getApkFileName;
|
||||||
|
|
||||||
@@ -47,9 +48,11 @@ public class FallbackFragment extends BaseFragment {
|
|||||||
ViewModelProvider.Factory viewModelFactory;
|
ViewModelProvider.Factory viewModelFactory;
|
||||||
|
|
||||||
private HotspotViewModel viewModel;
|
private HotspotViewModel viewModel;
|
||||||
private final ActivityResultLauncher<String> launcher =
|
@Nullable
|
||||||
|
private final ActivityResultLauncher<String> launcher = SDK_INT >= 19 ?
|
||||||
registerForActivityResult(new CreateDocumentAdvanced(),
|
registerForActivityResult(new CreateDocumentAdvanced(),
|
||||||
this::onDocumentCreated);
|
this::onDocumentCreated) :
|
||||||
|
null;
|
||||||
private Button fallbackButton;
|
private Button fallbackButton;
|
||||||
private ProgressBar progressBar;
|
private ProgressBar progressBar;
|
||||||
|
|
||||||
@@ -87,8 +90,11 @@ public class FallbackFragment extends BaseFragment {
|
|||||||
fallbackButton.setVisibility(INVISIBLE);
|
fallbackButton.setVisibility(INVISIBLE);
|
||||||
progressBar.setVisibility(VISIBLE);
|
progressBar.setVisibility(VISIBLE);
|
||||||
|
|
||||||
if (SDK_INT >= 19) launcher.launch(getApkFileName());
|
if (SDK_INT >= 19) {
|
||||||
else viewModel.exportApk();
|
requireNonNull(launcher).launch(getApkFileName());
|
||||||
|
} else {
|
||||||
|
viewModel.exportApk();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
viewModel.getSavedApkToUri().observeEvent(this, this::shareUri);
|
viewModel.getSavedApkToUri().observeEvent(this, this::shareUri);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -15,11 +15,13 @@ import org.briarproject.bramble.api.nullsafety.MethodsNotNullByDefault;
|
|||||||
import org.briarproject.bramble.api.nullsafety.ParametersNotNullByDefault;
|
import org.briarproject.bramble.api.nullsafety.ParametersNotNullByDefault;
|
||||||
import org.briarproject.briar.R;
|
import org.briarproject.briar.R;
|
||||||
import org.briarproject.briar.android.util.ActivityLaunchers.GetContentAdvanced;
|
import org.briarproject.briar.android.util.ActivityLaunchers.GetContentAdvanced;
|
||||||
|
import org.briarproject.briar.android.util.ActivityLaunchers.OpenDocumentAdvanced;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
|
||||||
import androidx.activity.result.ActivityResultLauncher;
|
import androidx.activity.result.ActivityResultLauncher;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.annotation.RequiresApi;
|
||||||
import androidx.fragment.app.Fragment;
|
import androidx.fragment.app.Fragment;
|
||||||
import androidx.fragment.app.FragmentActivity;
|
import androidx.fragment.app.FragmentActivity;
|
||||||
import androidx.lifecycle.ViewModelProvider;
|
import androidx.lifecycle.ViewModelProvider;
|
||||||
@@ -28,14 +30,19 @@ import static android.view.View.FOCUS_DOWN;
|
|||||||
import static android.view.View.VISIBLE;
|
import static android.view.View.VISIBLE;
|
||||||
import static android.widget.Toast.LENGTH_LONG;
|
import static android.widget.Toast.LENGTH_LONG;
|
||||||
import static org.briarproject.briar.android.AppModule.getAndroidComponent;
|
import static org.briarproject.briar.android.AppModule.getAndroidComponent;
|
||||||
|
import static org.briarproject.briar.android.util.UiUtils.launchActivityToOpenFile;
|
||||||
|
|
||||||
|
@RequiresApi(19)
|
||||||
@MethodsNotNullByDefault
|
@MethodsNotNullByDefault
|
||||||
@ParametersNotNullByDefault
|
@ParametersNotNullByDefault
|
||||||
public class ReceiveFragment extends Fragment {
|
public class ReceiveFragment extends Fragment {
|
||||||
|
|
||||||
final static String TAG = ReceiveFragment.class.getName();
|
final static String TAG = ReceiveFragment.class.getName();
|
||||||
|
|
||||||
private final ActivityResultLauncher<String> launcher =
|
private final ActivityResultLauncher<String[]> docLauncher =
|
||||||
|
registerForActivityResult(new OpenDocumentAdvanced(),
|
||||||
|
this::onDocumentChosen);
|
||||||
|
private final ActivityResultLauncher<String> contentLauncher =
|
||||||
registerForActivityResult(new GetContentAdvanced(),
|
registerForActivityResult(new GetContentAdvanced(),
|
||||||
this::onDocumentChosen);
|
this::onDocumentChosen);
|
||||||
|
|
||||||
@@ -69,8 +76,8 @@ public class ReceiveFragment extends Fragment {
|
|||||||
progressBar = v.findViewById(R.id.progressBar);
|
progressBar = v.findViewById(R.id.progressBar);
|
||||||
button = v.findViewById(R.id.fileButton);
|
button = v.findViewById(R.id.fileButton);
|
||||||
button.setOnClickListener(view ->
|
button.setOnClickListener(view ->
|
||||||
launcher.launch("*/*")
|
launchActivityToOpenFile(requireContext(),
|
||||||
);
|
docLauncher, contentLauncher, "*/*"));
|
||||||
viewModel.getOldTaskResumedEvent()
|
viewModel.getOldTaskResumedEvent()
|
||||||
.observeEvent(getViewLifecycleOwner(), this::onOldTaskResumed);
|
.observeEvent(getViewLifecycleOwner(), this::onOldTaskResumed);
|
||||||
viewModel.getState()
|
viewModel.getState()
|
||||||
|
|||||||
@@ -1,5 +1,6 @@
|
|||||||
package org.briarproject.briar.android.removabledrive;
|
package org.briarproject.briar.android.removabledrive;
|
||||||
|
|
||||||
|
import android.content.ActivityNotFoundException;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
@@ -18,10 +19,13 @@ import org.briarproject.bramble.api.plugin.file.RemovableDriveTask;
|
|||||||
import org.briarproject.briar.R;
|
import org.briarproject.briar.R;
|
||||||
import org.briarproject.briar.android.util.ActivityLaunchers.CreateDocumentAdvanced;
|
import org.briarproject.briar.android.util.ActivityLaunchers.CreateDocumentAdvanced;
|
||||||
|
|
||||||
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
|
||||||
import androidx.activity.result.ActivityResultLauncher;
|
import androidx.activity.result.ActivityResultLauncher;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.annotation.RequiresApi;
|
||||||
import androidx.fragment.app.Fragment;
|
import androidx.fragment.app.Fragment;
|
||||||
import androidx.fragment.app.FragmentActivity;
|
import androidx.fragment.app.FragmentActivity;
|
||||||
import androidx.lifecycle.ViewModelProvider;
|
import androidx.lifecycle.ViewModelProvider;
|
||||||
@@ -30,13 +34,18 @@ import static android.os.Build.VERSION.SDK_INT;
|
|||||||
import static android.view.View.FOCUS_DOWN;
|
import static android.view.View.FOCUS_DOWN;
|
||||||
import static android.view.View.VISIBLE;
|
import static android.view.View.VISIBLE;
|
||||||
import static android.widget.Toast.LENGTH_LONG;
|
import static android.widget.Toast.LENGTH_LONG;
|
||||||
|
import static java.util.logging.Level.WARNING;
|
||||||
|
import static java.util.logging.Logger.getLogger;
|
||||||
|
import static org.briarproject.bramble.util.LogUtils.logException;
|
||||||
import static org.briarproject.briar.android.AppModule.getAndroidComponent;
|
import static org.briarproject.briar.android.AppModule.getAndroidComponent;
|
||||||
|
|
||||||
|
@RequiresApi(19)
|
||||||
@MethodsNotNullByDefault
|
@MethodsNotNullByDefault
|
||||||
@ParametersNotNullByDefault
|
@ParametersNotNullByDefault
|
||||||
public class SendFragment extends Fragment {
|
public class SendFragment extends Fragment {
|
||||||
|
|
||||||
final static String TAG = SendFragment.class.getName();
|
final static String TAG = SendFragment.class.getName();
|
||||||
|
private static final Logger LOG = getLogger(TAG);
|
||||||
|
|
||||||
private final ActivityResultLauncher<String> launcher =
|
private final ActivityResultLauncher<String> launcher =
|
||||||
registerForActivityResult(new CreateDocumentAdvanced(),
|
registerForActivityResult(new CreateDocumentAdvanced(),
|
||||||
@@ -73,9 +82,15 @@ public class SendFragment extends Fragment {
|
|||||||
introTextView = v.findViewById(R.id.introTextView);
|
introTextView = v.findViewById(R.id.introTextView);
|
||||||
progressBar = v.findViewById(R.id.progressBar);
|
progressBar = v.findViewById(R.id.progressBar);
|
||||||
button = v.findViewById(R.id.fileButton);
|
button = v.findViewById(R.id.fileButton);
|
||||||
button.setOnClickListener(view ->
|
button.setOnClickListener(view -> {
|
||||||
launcher.launch(viewModel.getFileName())
|
try {
|
||||||
);
|
launcher.launch(viewModel.getFileName());
|
||||||
|
} catch (ActivityNotFoundException e) {
|
||||||
|
logException(LOG, WARNING, e);
|
||||||
|
Toast.makeText(requireContext(),
|
||||||
|
R.string.error_start_activity, LENGTH_LONG).show();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
viewModel.getOldTaskResumedEvent()
|
viewModel.getOldTaskResumedEvent()
|
||||||
.observeEvent(getViewLifecycleOwner(), this::onOldTaskResumed);
|
.observeEvent(getViewLifecycleOwner(), this::onOldTaskResumed);
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ import org.briarproject.bramble.api.nullsafety.ParametersNotNullByDefault;
|
|||||||
import org.briarproject.briar.R;
|
import org.briarproject.briar.R;
|
||||||
import org.briarproject.briar.android.mailbox.MailboxActivity;
|
import org.briarproject.briar.android.mailbox.MailboxActivity;
|
||||||
import org.briarproject.briar.android.util.ActivityLaunchers.GetImageAdvanced;
|
import org.briarproject.briar.android.util.ActivityLaunchers.GetImageAdvanced;
|
||||||
|
import org.briarproject.briar.android.util.ActivityLaunchers.OpenImageDocumentAdvanced;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
|
||||||
@@ -23,9 +24,11 @@ import androidx.preference.Preference;
|
|||||||
import androidx.preference.PreferenceFragmentCompat;
|
import androidx.preference.PreferenceFragmentCompat;
|
||||||
import androidx.preference.PreferenceGroup;
|
import androidx.preference.PreferenceGroup;
|
||||||
|
|
||||||
|
import static android.os.Build.VERSION.SDK_INT;
|
||||||
import static java.util.Objects.requireNonNull;
|
import static java.util.Objects.requireNonNull;
|
||||||
import static org.briarproject.briar.android.AppModule.getAndroidComponent;
|
import static org.briarproject.briar.android.AppModule.getAndroidComponent;
|
||||||
import static org.briarproject.briar.android.TestingConstants.IS_DEBUG_BUILD;
|
import static org.briarproject.briar.android.TestingConstants.IS_DEBUG_BUILD;
|
||||||
|
import static org.briarproject.briar.android.util.UiUtils.launchActivityToOpenFile;
|
||||||
import static org.briarproject.briar.android.util.UiUtils.triggerFeedback;
|
import static org.briarproject.briar.android.util.UiUtils.triggerFeedback;
|
||||||
|
|
||||||
@MethodsNotNullByDefault
|
@MethodsNotNullByDefault
|
||||||
@@ -46,7 +49,12 @@ public class SettingsFragment extends PreferenceFragmentCompat {
|
|||||||
private SettingsViewModel viewModel;
|
private SettingsViewModel viewModel;
|
||||||
private AvatarPreference prefAvatar;
|
private AvatarPreference prefAvatar;
|
||||||
|
|
||||||
private final ActivityResultLauncher<String> launcher =
|
@Nullable
|
||||||
|
private final ActivityResultLauncher<String[]> docLauncher = SDK_INT >= 19 ?
|
||||||
|
registerForActivityResult(new OpenImageDocumentAdvanced(),
|
||||||
|
this::onImageSelected) :
|
||||||
|
null;
|
||||||
|
private final ActivityResultLauncher<String> contentLauncher =
|
||||||
registerForActivityResult(new GetImageAdvanced(),
|
registerForActivityResult(new GetImageAdvanced(),
|
||||||
this::onImageSelected);
|
this::onImageSelected);
|
||||||
|
|
||||||
@@ -65,7 +73,8 @@ public class SettingsFragment extends PreferenceFragmentCompat {
|
|||||||
prefAvatar = requireNonNull(findPreference(PREF_KEY_AVATAR));
|
prefAvatar = requireNonNull(findPreference(PREF_KEY_AVATAR));
|
||||||
if (viewModel.shouldEnableProfilePictures()) {
|
if (viewModel.shouldEnableProfilePictures()) {
|
||||||
prefAvatar.setOnPreferenceClickListener(preference -> {
|
prefAvatar.setOnPreferenceClickListener(preference -> {
|
||||||
launcher.launch("image/*");
|
launchActivityToOpenFile(requireContext(),
|
||||||
|
docLauncher, contentLauncher, "image/*");
|
||||||
return true;
|
return true;
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
package org.briarproject.briar.android.util;
|
package org.briarproject.briar.android.util;
|
||||||
|
|
||||||
import android.annotation.TargetApi;
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
|
|
||||||
@@ -10,8 +9,11 @@ import androidx.activity.result.contract.ActivityResultContract;
|
|||||||
import androidx.activity.result.contract.ActivityResultContracts.CreateDocument;
|
import androidx.activity.result.contract.ActivityResultContracts.CreateDocument;
|
||||||
import androidx.activity.result.contract.ActivityResultContracts.GetContent;
|
import androidx.activity.result.contract.ActivityResultContracts.GetContent;
|
||||||
import androidx.activity.result.contract.ActivityResultContracts.GetMultipleContents;
|
import androidx.activity.result.contract.ActivityResultContracts.GetMultipleContents;
|
||||||
|
import androidx.activity.result.contract.ActivityResultContracts.OpenDocument;
|
||||||
|
import androidx.activity.result.contract.ActivityResultContracts.OpenMultipleDocuments;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.annotation.RequiresApi;
|
||||||
|
|
||||||
import static android.app.Activity.RESULT_CANCELED;
|
import static android.app.Activity.RESULT_CANCELED;
|
||||||
import static android.bluetooth.BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE;
|
import static android.bluetooth.BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE;
|
||||||
@@ -24,6 +26,7 @@ import static org.briarproject.bramble.util.AndroidUtils.getSupportedImageConten
|
|||||||
@NotNullByDefault
|
@NotNullByDefault
|
||||||
public class ActivityLaunchers {
|
public class ActivityLaunchers {
|
||||||
|
|
||||||
|
@RequiresApi(19)
|
||||||
public static class CreateDocumentAdvanced extends CreateDocument {
|
public static class CreateDocumentAdvanced extends CreateDocument {
|
||||||
@NonNull
|
@NonNull
|
||||||
@Override
|
@Override
|
||||||
@@ -45,6 +48,19 @@ public class ActivityLaunchers {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@RequiresApi(19)
|
||||||
|
public static class OpenDocumentAdvanced extends OpenDocument {
|
||||||
|
@NonNull
|
||||||
|
@Override
|
||||||
|
public Intent createIntent(Context context, String[] input) {
|
||||||
|
Intent i = super.createIntent(context, input);
|
||||||
|
putShowAdvancedExtra(i);
|
||||||
|
i.setType("/*");
|
||||||
|
i.addFlags(FLAG_GRANT_READ_URI_PERMISSION);
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static class GetImageAdvanced extends GetContent {
|
public static class GetImageAdvanced extends GetContent {
|
||||||
@NonNull
|
@NonNull
|
||||||
@Override
|
@Override
|
||||||
@@ -59,7 +75,7 @@ public class ActivityLaunchers {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@TargetApi(18)
|
@RequiresApi(18)
|
||||||
public static class GetMultipleImagesAdvanced extends GetMultipleContents {
|
public static class GetMultipleImagesAdvanced extends GetMultipleContents {
|
||||||
@NonNull
|
@NonNull
|
||||||
@Override
|
@Override
|
||||||
@@ -74,6 +90,37 @@ public class ActivityLaunchers {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@RequiresApi(19)
|
||||||
|
public static class OpenImageDocumentAdvanced extends OpenDocument {
|
||||||
|
@NonNull
|
||||||
|
@Override
|
||||||
|
public Intent createIntent(Context context, String[] input) {
|
||||||
|
Intent i = super.createIntent(context, input);
|
||||||
|
putShowAdvancedExtra(i);
|
||||||
|
i.setType("image/*");
|
||||||
|
i.addFlags(FLAG_GRANT_READ_URI_PERMISSION);
|
||||||
|
if (SDK_INT >= 19)
|
||||||
|
i.putExtra(EXTRA_MIME_TYPES, getSupportedImageContentTypes());
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequiresApi(19)
|
||||||
|
public static class OpenMultipleImageDocumentsAdvanced
|
||||||
|
extends OpenMultipleDocuments {
|
||||||
|
@NonNull
|
||||||
|
@Override
|
||||||
|
public Intent createIntent(Context context, String[] input) {
|
||||||
|
Intent i = super.createIntent(context, input);
|
||||||
|
putShowAdvancedExtra(i);
|
||||||
|
i.setType("image/*");
|
||||||
|
i.addFlags(FLAG_GRANT_READ_URI_PERMISSION);
|
||||||
|
if (SDK_INT >= 19)
|
||||||
|
i.putExtra(EXTRA_MIME_TYPES, getSupportedImageContentTypes());
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static class RequestBluetoothDiscoverable
|
public static class RequestBluetoothDiscoverable
|
||||||
extends ActivityResultContract<Integer, Boolean> {
|
extends ActivityResultContract<Integer, Boolean> {
|
||||||
@NonNull
|
@NonNull
|
||||||
|
|||||||
@@ -42,6 +42,7 @@ import org.briarproject.briar.android.view.ArticleMovementMethod;
|
|||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
|
import androidx.activity.result.ActivityResultLauncher;
|
||||||
import androidx.annotation.AnyThread;
|
import androidx.annotation.AnyThread;
|
||||||
import androidx.annotation.AttrRes;
|
import androidx.annotation.AttrRes;
|
||||||
import androidx.annotation.ColorInt;
|
import androidx.annotation.ColorInt;
|
||||||
@@ -103,6 +104,7 @@ import static androidx.core.view.ViewCompat.LAYOUT_DIRECTION_RTL;
|
|||||||
import static java.util.Objects.requireNonNull;
|
import static java.util.Objects.requireNonNull;
|
||||||
import static java.util.concurrent.TimeUnit.DAYS;
|
import static java.util.concurrent.TimeUnit.DAYS;
|
||||||
import static java.util.logging.Level.WARNING;
|
import static java.util.logging.Level.WARNING;
|
||||||
|
import static java.util.logging.Logger.getLogger;
|
||||||
import static org.briarproject.bramble.util.LogUtils.logException;
|
import static org.briarproject.bramble.util.LogUtils.logException;
|
||||||
import static org.briarproject.briar.BuildConfig.APPLICATION_ID;
|
import static org.briarproject.briar.BuildConfig.APPLICATION_ID;
|
||||||
import static org.briarproject.briar.android.TestingConstants.EXPIRY_DATE;
|
import static org.briarproject.briar.android.TestingConstants.EXPIRY_DATE;
|
||||||
@@ -117,6 +119,8 @@ import static org.briarproject.briar.android.reporting.CrashReportActivity.EXTRA
|
|||||||
@ParametersNotNullByDefault
|
@ParametersNotNullByDefault
|
||||||
public class UiUtils {
|
public class UiUtils {
|
||||||
|
|
||||||
|
private static final Logger LOG = getLogger(UiUtils.class.getName());
|
||||||
|
|
||||||
public static final long MIN_DATE_RESOLUTION = MINUTE_IN_MILLIS;
|
public static final long MIN_DATE_RESOLUTION = MINUTE_IN_MILLIS;
|
||||||
public static final int TEASER_LENGTH = 320;
|
public static final int TEASER_LENGTH = 320;
|
||||||
public static final float GREY_OUT = 0.5f;
|
public static final float GREY_OUT = 0.5f;
|
||||||
@@ -579,4 +583,26 @@ public class UiUtils {
|
|||||||
(dialog, which) -> requestPermissions.run());
|
(dialog, which) -> requestPermissions.run());
|
||||||
builder.show();
|
builder.show();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void launchActivityToOpenFile(Context ctx,
|
||||||
|
@Nullable ActivityResultLauncher<String[]> docLauncher,
|
||||||
|
ActivityResultLauncher<String> contentLauncher,
|
||||||
|
String contentType) {
|
||||||
|
// Try GET_CONTENT, fall back to OPEN_DOCUMENT if available
|
||||||
|
try {
|
||||||
|
contentLauncher.launch(contentType);
|
||||||
|
return;
|
||||||
|
} catch (ActivityNotFoundException e) {
|
||||||
|
logException(LOG, WARNING, e);
|
||||||
|
}
|
||||||
|
if (docLauncher != null) {
|
||||||
|
try {
|
||||||
|
docLauncher.launch(new String[] {contentType});
|
||||||
|
return;
|
||||||
|
} catch (ActivityNotFoundException e) {
|
||||||
|
logException(LOG, WARNING, e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Toast.makeText(ctx, R.string.error_start_activity, LENGTH_LONG).show();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user