Remove save support for Android < 4.4 (OKC-01-014)
This commit is contained in:
@@ -257,7 +257,6 @@ public class DecryptListFragment
|
|||||||
}
|
}
|
||||||
|
|
||||||
OpenPgpMetadata metadata = result.mMetadata.get(index);
|
OpenPgpMetadata metadata = result.mMetadata.get(index);
|
||||||
Uri saveUri = Uri.fromFile(activity.getExternalFilesDir(metadata.getMimeType()));
|
|
||||||
mCurrentSaveFileUri = result.getOutputUris().get(index);
|
mCurrentSaveFileUri = result.getOutputUris().get(index);
|
||||||
|
|
||||||
String filename = metadata.getFilename();
|
String filename = metadata.getFilename();
|
||||||
@@ -266,7 +265,7 @@ public class DecryptListFragment
|
|||||||
filename = "decrypted" + (ext != null ? "."+ext : "");
|
filename = "decrypted" + (ext != null ? "."+ext : "");
|
||||||
}
|
}
|
||||||
|
|
||||||
FileHelper.saveDocument(this, filename, saveUri, metadata.getMimeType(),
|
FileHelper.saveDocument(this, filename, null, metadata.getMimeType(),
|
||||||
R.string.title_decrypt_to_file, R.string.specify_file_to_decrypt_to, REQUEST_CODE_OUTPUT);
|
R.string.title_decrypt_to_file, R.string.specify_file_to_decrypt_to, REQUEST_CODE_OUTPUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -447,6 +446,7 @@ public class DecryptListFragment
|
|||||||
displayWithViewIntent(result, index, true, true);
|
displayWithViewIntent(result, index, true, true);
|
||||||
break;
|
break;
|
||||||
case R.id.decrypt_save:
|
case R.id.decrypt_save:
|
||||||
|
// only inside the menu xml for Android >= 4.4
|
||||||
saveFileDialog(result, index);
|
saveFileDialog(result, index);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -308,6 +308,17 @@ public class EncryptFilesFragment
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPrepareOptionsMenu(Menu menu) {
|
||||||
|
super.onPrepareOptionsMenu(menu);
|
||||||
|
|
||||||
|
// Show save only on Android >= 4.4 (Document Provider)
|
||||||
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) {
|
||||||
|
MenuItem save = menu.findItem(R.id.encrypt_save);
|
||||||
|
save.setVisible(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void toggleUseArmor(MenuItem item, final boolean useArmor) {
|
public void toggleUseArmor(MenuItem item, final boolean useArmor) {
|
||||||
|
|
||||||
mUseArmor = useArmor;
|
mUseArmor = useArmor;
|
||||||
|
|||||||
@@ -107,7 +107,7 @@ public class ViewKeyAdvShareFragment extends LoaderFragment implements
|
|||||||
View vFingerprintShareButton = view.findViewById(R.id.view_key_action_fingerprint_share);
|
View vFingerprintShareButton = view.findViewById(R.id.view_key_action_fingerprint_share);
|
||||||
View vFingerprintClipboardButton = view.findViewById(R.id.view_key_action_fingerprint_clipboard);
|
View vFingerprintClipboardButton = view.findViewById(R.id.view_key_action_fingerprint_clipboard);
|
||||||
View vKeyShareButton = view.findViewById(R.id.view_key_action_key_share);
|
View vKeyShareButton = view.findViewById(R.id.view_key_action_key_share);
|
||||||
View vKeySafeButton = view.findViewById(R.id.view_key_action_key_export);
|
View vKeySaveButton = view.findViewById(R.id.view_key_action_key_export);
|
||||||
View vKeyNfcButton = view.findViewById(R.id.view_key_action_key_nfc);
|
View vKeyNfcButton = view.findViewById(R.id.view_key_action_key_nfc);
|
||||||
View vKeyClipboardButton = view.findViewById(R.id.view_key_action_key_clipboard);
|
View vKeyClipboardButton = view.findViewById(R.id.view_key_action_key_clipboard);
|
||||||
ImageButton vKeySafeSlingerButton = (ImageButton) view.findViewById(R.id.view_key_action_key_safeslinger);
|
ImageButton vKeySafeSlingerButton = (ImageButton) view.findViewById(R.id.view_key_action_key_safeslinger);
|
||||||
@@ -133,7 +133,11 @@ public class ViewKeyAdvShareFragment extends LoaderFragment implements
|
|||||||
share(false, false);
|
share(false, false);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
vKeySafeButton.setOnClickListener(new View.OnClickListener() {
|
// Show save only on Android >= 4.4 (Document Provider)
|
||||||
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) {
|
||||||
|
vKeySaveButton.setVisibility(View.GONE);
|
||||||
|
}
|
||||||
|
vKeySaveButton.setOnClickListener(new View.OnClickListener() {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
exportToFile();
|
exportToFile();
|
||||||
|
|||||||
@@ -1,234 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2012-2014 Dominik Schürmann <dominik@dominikschuermann.de>
|
|
||||||
*
|
|
||||||
* This program is free software: you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation, either version 3 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package org.sufficientlysecure.keychain.ui.dialog;
|
|
||||||
|
|
||||||
import android.app.Activity;
|
|
||||||
import android.app.Dialog;
|
|
||||||
import android.content.Context;
|
|
||||||
import android.content.DialogInterface;
|
|
||||||
import android.content.Intent;
|
|
||||||
import android.net.Uri;
|
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
|
||||||
import android.os.Message;
|
|
||||||
import android.os.Messenger;
|
|
||||||
import android.os.RemoteException;
|
|
||||||
import android.support.v4.app.DialogFragment;
|
|
||||||
import android.view.LayoutInflater;
|
|
||||||
import android.view.View;
|
|
||||||
import android.widget.CheckBox;
|
|
||||||
import android.widget.EditText;
|
|
||||||
import android.widget.ImageButton;
|
|
||||||
import android.widget.TextView;
|
|
||||||
|
|
||||||
import org.sufficientlysecure.keychain.Constants;
|
|
||||||
import org.sufficientlysecure.keychain.R;
|
|
||||||
import org.sufficientlysecure.keychain.ui.util.Notify;
|
|
||||||
import org.sufficientlysecure.keychain.util.FileHelper;
|
|
||||||
import org.sufficientlysecure.keychain.util.Log;
|
|
||||||
|
|
||||||
import java.io.File;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This is a file chooser dialog no longer used with KitKat
|
|
||||||
*/
|
|
||||||
public class FileDialogFragment extends DialogFragment {
|
|
||||||
private static final String ARG_MESSENGER = "messenger";
|
|
||||||
private static final String ARG_TITLE = "title";
|
|
||||||
private static final String ARG_MESSAGE = "message";
|
|
||||||
private static final String ARG_DEFAULT_FILE = "default_file";
|
|
||||||
private static final String ARG_CHECKBOX_TEXT = "checkbox_text";
|
|
||||||
|
|
||||||
public static final int MESSAGE_OKAY = 1;
|
|
||||||
|
|
||||||
public static final String MESSAGE_DATA_FILE = "file";
|
|
||||||
public static final String MESSAGE_DATA_CHECKED = "checked";
|
|
||||||
|
|
||||||
private Messenger mMessenger;
|
|
||||||
|
|
||||||
private EditText mFilename;
|
|
||||||
private ImageButton mBrowse;
|
|
||||||
private CheckBox mCheckBox;
|
|
||||||
private TextView mMessageTextView;
|
|
||||||
|
|
||||||
private File mFile;
|
|
||||||
|
|
||||||
private static final int REQUEST_CODE = 0x00007004;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates new instance of this file dialog fragment
|
|
||||||
*/
|
|
||||||
public static FileDialogFragment newInstance(Messenger messenger, String title, String message,
|
|
||||||
File defaultFile, String checkboxText) {
|
|
||||||
FileDialogFragment frag = new FileDialogFragment();
|
|
||||||
Bundle args = new Bundle();
|
|
||||||
args.putParcelable(ARG_MESSENGER, messenger);
|
|
||||||
|
|
||||||
args.putString(ARG_TITLE, title);
|
|
||||||
args.putString(ARG_MESSAGE, message);
|
|
||||||
args.putString(ARG_DEFAULT_FILE, defaultFile.getAbsolutePath());
|
|
||||||
args.putString(ARG_CHECKBOX_TEXT, checkboxText);
|
|
||||||
|
|
||||||
frag.setArguments(args);
|
|
||||||
|
|
||||||
return frag;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates dialog
|
|
||||||
*/
|
|
||||||
@Override
|
|
||||||
public Dialog onCreateDialog(Bundle savedInstanceState) {
|
|
||||||
final Activity activity = getActivity();
|
|
||||||
|
|
||||||
mMessenger = getArguments().getParcelable(ARG_MESSENGER);
|
|
||||||
|
|
||||||
String title = getArguments().getString(ARG_TITLE);
|
|
||||||
String message = getArguments().getString(ARG_MESSAGE);
|
|
||||||
mFile = new File(getArguments().getString(ARG_DEFAULT_FILE));
|
|
||||||
if (!mFile.isAbsolute()) {
|
|
||||||
// We use OK dir by default
|
|
||||||
mFile = new File(Constants.Path.APP_DIR.getAbsolutePath(), mFile.getName());
|
|
||||||
}
|
|
||||||
String checkboxText = getArguments().getString(ARG_CHECKBOX_TEXT);
|
|
||||||
|
|
||||||
LayoutInflater inflater = (LayoutInflater) activity
|
|
||||||
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
|
||||||
CustomAlertDialogBuilder alert = new CustomAlertDialogBuilder(activity);
|
|
||||||
alert.setTitle(title);
|
|
||||||
|
|
||||||
View view = inflater.inflate(R.layout.file_dialog, null);
|
|
||||||
|
|
||||||
mMessageTextView = (TextView) view.findViewById(R.id.message);
|
|
||||||
mMessageTextView.setText(message);
|
|
||||||
|
|
||||||
mFilename = (EditText) view.findViewById(R.id.input);
|
|
||||||
mFilename.setText(mFile.getName());
|
|
||||||
mBrowse = (ImageButton) view.findViewById(R.id.btn_browse);
|
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) {
|
|
||||||
mBrowse.setVisibility(View.GONE);
|
|
||||||
} else {
|
|
||||||
mBrowse.setOnClickListener(new View.OnClickListener() {
|
|
||||||
public void onClick(View v) {
|
|
||||||
// only .asc or .gpg files
|
|
||||||
// setting it to text/plain prevents Cynaogenmod's file manager from selecting asc
|
|
||||||
// or gpg types!
|
|
||||||
FileHelper.saveDocumentKitKat(
|
|
||||||
FileDialogFragment.this, "*/*", mFile.getName(), REQUEST_CODE);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
mCheckBox = (CheckBox) view.findViewById(R.id.checkbox);
|
|
||||||
if (checkboxText == null) {
|
|
||||||
mCheckBox.setEnabled(false);
|
|
||||||
mCheckBox.setVisibility(View.GONE);
|
|
||||||
} else {
|
|
||||||
mCheckBox.setEnabled(true);
|
|
||||||
mCheckBox.setVisibility(View.VISIBLE);
|
|
||||||
mCheckBox.setText(checkboxText);
|
|
||||||
mCheckBox.setChecked(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
alert.setView(view);
|
|
||||||
|
|
||||||
alert.setPositiveButton(android.R.string.ok, new DialogInterface.OnClickListener() {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int id) {
|
|
||||||
dismiss();
|
|
||||||
|
|
||||||
String currentFilename = mFilename.getText().toString();
|
|
||||||
if (currentFilename == null || currentFilename.isEmpty()) {
|
|
||||||
// No file is like pressing cancel, UI: maybe disable positive button in this case?
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mFile == null || currentFilename.startsWith("/")) {
|
|
||||||
mFile = new File(currentFilename);
|
|
||||||
} else if (!mFile.getName().equals(currentFilename)) {
|
|
||||||
// We update our File object if user changed name!
|
|
||||||
mFile = new File(mFile.getParentFile(), currentFilename);
|
|
||||||
}
|
|
||||||
|
|
||||||
boolean checked = mCheckBox.isEnabled() && mCheckBox.isChecked();
|
|
||||||
|
|
||||||
// return resulting data back to activity
|
|
||||||
Bundle data = new Bundle();
|
|
||||||
data.putString(MESSAGE_DATA_FILE, mFile.getAbsolutePath());
|
|
||||||
data.putBoolean(MESSAGE_DATA_CHECKED, checked);
|
|
||||||
|
|
||||||
sendMessageToHandler(MESSAGE_OKAY, data);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
alert.setNegativeButton(android.R.string.cancel, new DialogInterface.OnClickListener() {
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onClick(DialogInterface dialog, int id) {
|
|
||||||
dismiss();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return alert.show();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onActivityResult(int requestCode, int resultCode, Intent data) {
|
|
||||||
switch (requestCode & 0xFFFF) {
|
|
||||||
case REQUEST_CODE: {
|
|
||||||
if (resultCode == Activity.RESULT_OK && data != null) {
|
|
||||||
File file = new File(data.getData().getPath());
|
|
||||||
if (file.getParentFile().exists()) {
|
|
||||||
mFile = file;
|
|
||||||
mFilename.setText(mFile.getName());
|
|
||||||
} else {
|
|
||||||
Notify.create(getActivity(), R.string.no_file_selected, Notify.Style.ERROR).show();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
default:
|
|
||||||
super.onActivityResult(requestCode, resultCode, data);
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Send message back to handler which is initialized in a activity
|
|
||||||
*
|
|
||||||
* @param what Message integer you want to send
|
|
||||||
*/
|
|
||||||
private void sendMessageToHandler(Integer what, Bundle data) {
|
|
||||||
Message msg = Message.obtain();
|
|
||||||
msg.what = what;
|
|
||||||
if (data != null) {
|
|
||||||
msg.setData(data);
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
mMessenger.send(msg);
|
|
||||||
} catch (RemoteException e) {
|
|
||||||
Log.w(Constants.TAG, "Exception sending message, Is handler present?", e);
|
|
||||||
} catch (NullPointerException e) {
|
|
||||||
Log.w(Constants.TAG, "Messenger is null!", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -134,6 +134,7 @@ public class LinkedIdCreateHttpsStep2Fragment extends LinkedIdCreateFinalFragmen
|
|||||||
|
|
||||||
String targetName = "pgpkey.txt";
|
String targetName = "pgpkey.txt";
|
||||||
|
|
||||||
|
// TODO: not supported on Android < 4.4
|
||||||
FileHelper.saveDocument(this,
|
FileHelper.saveDocument(this,
|
||||||
targetName, Uri.fromFile(new File(Constants.Path.APP_DIR, targetName)),
|
targetName, Uri.fromFile(new File(Constants.Path.APP_DIR, targetName)),
|
||||||
"text/plain", R.string.title_decrypt_to_file, R.string.specify_file_to_decrypt_to,
|
"text/plain", R.string.title_decrypt_to_file, R.string.specify_file_to_decrypt_to,
|
||||||
|
|||||||
@@ -69,13 +69,14 @@ public class ExportHelper
|
|||||||
: R.string.specify_backup_dest_single);
|
: R.string.specify_backup_dest_single);
|
||||||
}
|
}
|
||||||
|
|
||||||
FileHelper.saveDocumentDialog(new FileHelper.FileDialogCallback() {
|
// TODO: for valodim
|
||||||
@Override
|
// FileHelper.saveDocumentDialog(new FileHelper.FileDialogCallback() {
|
||||||
public void onFileSelected(File file, boolean checked) {
|
// @Override
|
||||||
mExportFile = file;
|
// public void onFileSelected(File file, boolean checked) {
|
||||||
exportKeys(masterKeyId == null ? null : new long[] { masterKeyId }, exportSecret);
|
// mExportFile = file;
|
||||||
}
|
// exportKeys(masterKeyId == null ? null : new long[] { masterKeyId }, exportSecret);
|
||||||
}, mActivity.getSupportFragmentManager(), title, message, exportFile, null);
|
// }
|
||||||
|
// }, mActivity.getSupportFragmentManager(), title, message, exportFile, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: If ExportHelper requires pending data (see CryptoOPerationHelper), activities using
|
// TODO: If ExportHelper requires pending data (see CryptoOPerationHelper), activities using
|
||||||
|
|||||||
@@ -18,7 +18,6 @@
|
|||||||
package org.sufficientlysecure.keychain.util;
|
package org.sufficientlysecure.keychain.util;
|
||||||
|
|
||||||
import android.annotation.TargetApi;
|
import android.annotation.TargetApi;
|
||||||
import android.app.Activity;
|
|
||||||
import android.content.ActivityNotFoundException;
|
import android.content.ActivityNotFoundException;
|
||||||
import android.content.ContentResolver;
|
import android.content.ContentResolver;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
@@ -30,20 +29,13 @@ import android.net.Uri;
|
|||||||
import android.os.Build;
|
import android.os.Build;
|
||||||
import android.os.Build.VERSION_CODES;
|
import android.os.Build.VERSION_CODES;
|
||||||
import android.os.Environment;
|
import android.os.Environment;
|
||||||
import android.os.Handler;
|
|
||||||
import android.os.Message;
|
|
||||||
import android.os.Messenger;
|
|
||||||
import android.provider.DocumentsContract;
|
import android.provider.DocumentsContract;
|
||||||
import android.provider.OpenableColumns;
|
import android.provider.OpenableColumns;
|
||||||
import android.support.annotation.StringRes;
|
import android.support.annotation.StringRes;
|
||||||
import android.support.v4.app.Fragment;
|
import android.support.v4.app.Fragment;
|
||||||
import android.support.v4.app.FragmentManager;
|
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
import org.sufficientlysecure.keychain.Constants;
|
|
||||||
import org.sufficientlysecure.keychain.R;
|
import org.sufficientlysecure.keychain.R;
|
||||||
import org.sufficientlysecure.keychain.compatibility.DialogFragmentWorkaround;
|
|
||||||
import org.sufficientlysecure.keychain.ui.dialog.FileDialogFragment;
|
|
||||||
|
|
||||||
import java.io.BufferedInputStream;
|
import java.io.BufferedInputStream;
|
||||||
import java.io.BufferedOutputStream;
|
import java.io.BufferedOutputStream;
|
||||||
@@ -97,37 +89,12 @@ public class FileHelper {
|
|||||||
public static void saveDocument(Fragment fragment, String targetName, Uri inputUri, String mimeType,
|
public static void saveDocument(Fragment fragment, String targetName, Uri inputUri, String mimeType,
|
||||||
@StringRes int title, @StringRes int message, int requestCode) {
|
@StringRes int title, @StringRes int message, int requestCode) {
|
||||||
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) {
|
if (Build.VERSION.SDK_INT < Build.VERSION_CODES.KITKAT) {
|
||||||
saveDocumentDialog(fragment, targetName, inputUri, title, message, requestCode);
|
throw new RuntimeException("saveDocument does not support Android < 4.4!");
|
||||||
} else {
|
} else {
|
||||||
saveDocumentKitKat(fragment, mimeType, targetName, requestCode);
|
saveDocumentKitKat(fragment, mimeType, targetName, requestCode);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void saveDocumentDialog(final Fragment fragment, String targetName, Uri inputUri,
|
|
||||||
@StringRes int title, @StringRes int message, final int requestCode) {
|
|
||||||
|
|
||||||
saveDocumentDialog(fragment, targetName, inputUri, title, message, new FileDialogCallback() {
|
|
||||||
// is this a good idea? seems hacky...
|
|
||||||
@Override
|
|
||||||
public void onFileSelected(File file, boolean checked) {
|
|
||||||
Intent intent = new Intent();
|
|
||||||
intent.setData(Uri.fromFile(file));
|
|
||||||
fragment.onActivityResult(requestCode, Activity.RESULT_OK, intent);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void saveDocumentDialog(final Fragment fragment, String targetName, Uri inputUri,
|
|
||||||
@StringRes int title, @StringRes int message, FileDialogCallback callback) {
|
|
||||||
|
|
||||||
File file = inputUri == null ? null : new File(inputUri.getPath());
|
|
||||||
File parentDir = file != null && file.exists() ? file.getParentFile() : Constants.Path.APP_DIR;
|
|
||||||
File targetFile = new File(parentDir, targetName);
|
|
||||||
saveDocumentDialog(callback, fragment.getActivity().getSupportFragmentManager(),
|
|
||||||
fragment.getString(title), fragment.getString(message), targetFile, null);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Opens the preferred installed file manager on Android and shows a toast
|
/** Opens the preferred installed file manager on Android and shows a toast
|
||||||
* if no manager is installed. */
|
* if no manager is installed. */
|
||||||
private static void openDocumentPreKitKat(
|
private static void openDocumentPreKitKat(
|
||||||
@@ -172,36 +139,6 @@ public class FileHelper {
|
|||||||
fragment.startActivityForResult(intent, requestCode);
|
fragment.startActivityForResult(intent, requestCode);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void saveDocumentDialog(
|
|
||||||
final FileDialogCallback callback, final FragmentManager fragmentManager,
|
|
||||||
final String title, final String message, final File defaultFile,
|
|
||||||
final String checkMsg) {
|
|
||||||
// Message is received after file is selected
|
|
||||||
Handler returnHandler = new Handler() {
|
|
||||||
@Override
|
|
||||||
public void handleMessage(Message message) {
|
|
||||||
if (message.what == FileDialogFragment.MESSAGE_OKAY) {
|
|
||||||
callback.onFileSelected(
|
|
||||||
new File(message.getData().getString(FileDialogFragment.MESSAGE_DATA_FILE)),
|
|
||||||
message.getData().getBoolean(FileDialogFragment.MESSAGE_DATA_CHECKED));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
// Create a new Messenger for the communication back
|
|
||||||
final Messenger messenger = new Messenger(returnHandler);
|
|
||||||
|
|
||||||
DialogFragmentWorkaround.INTERFACE.runnableRunDelayed(new Runnable() {
|
|
||||||
@Override
|
|
||||||
public void run() {
|
|
||||||
FileDialogFragment fileDialog = FileDialogFragment.newInstance(messenger, title, message,
|
|
||||||
defaultFile, checkMsg);
|
|
||||||
|
|
||||||
fileDialog.show(fragmentManager, "fileDialog");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public static String getFilename(Context context, Uri uri) {
|
public static String getFilename(Context context, Uri uri) {
|
||||||
String filename = null;
|
String filename = null;
|
||||||
try {
|
try {
|
||||||
|
|||||||
19
OpenKeychain/src/main/res/menu-v19/decrypt_bottom_sheet.xml
Normal file
19
OpenKeychain/src/main/res/menu-v19/decrypt_bottom_sheet.xml
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<menu xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/decrypt_open"
|
||||||
|
android:icon="@drawable/ic_apps_black_24dp"
|
||||||
|
android:title="@string/btn_open_with" />
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/decrypt_share"
|
||||||
|
android:icon="@drawable/ic_share_black_24dp"
|
||||||
|
android:title="@string/btn_share_decrypted_text" />
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/decrypt_save"
|
||||||
|
android:icon="@drawable/ic_save_black_24dp"
|
||||||
|
android:title="@string/btn_save" />
|
||||||
|
|
||||||
|
</menu>
|
||||||
@@ -3,17 +3,12 @@
|
|||||||
|
|
||||||
<item
|
<item
|
||||||
android:id="@+id/decrypt_open"
|
android:id="@+id/decrypt_open"
|
||||||
android:title="Open with…"
|
android:icon="@drawable/ic_apps_black_24dp"
|
||||||
android:icon="@drawable/ic_apps_black_24dp" />
|
android:title="@string/btn_open_with" />
|
||||||
|
|
||||||
<item
|
<item
|
||||||
android:id="@+id/decrypt_share"
|
android:id="@+id/decrypt_share"
|
||||||
android:title="@string/btn_share_decrypted_text"
|
android:icon="@drawable/ic_share_black_24dp"
|
||||||
android:icon="@drawable/ic_share_black_24dp" />
|
android:title="@string/btn_share_decrypted_text" />
|
||||||
|
|
||||||
<item
|
</menu>
|
||||||
android:id="@+id/decrypt_save"
|
|
||||||
android:title="@string/btn_save"
|
|
||||||
android:icon="@drawable/ic_save_black_24dp" />
|
|
||||||
|
|
||||||
</menu>
|
|
||||||
@@ -91,6 +91,7 @@
|
|||||||
<string name="btn_create_key">"Create key"</string>
|
<string name="btn_create_key">"Create key"</string>
|
||||||
<string name="btn_add_files">"Add file(s)"</string>
|
<string name="btn_add_files">"Add file(s)"</string>
|
||||||
<string name="btn_share_decrypted_text">"Share"</string>
|
<string name="btn_share_decrypted_text">"Share"</string>
|
||||||
|
<string name="btn_open_with">"Open with…"</string>
|
||||||
<string name="btn_copy_decrypted_text">"Copy decrypted text"</string>
|
<string name="btn_copy_decrypted_text">"Copy decrypted text"</string>
|
||||||
<string name="btn_decrypt_clipboard">"Read from clipboard"</string>
|
<string name="btn_decrypt_clipboard">"Read from clipboard"</string>
|
||||||
<string name="btn_decrypt_files">"Select input file"</string>
|
<string name="btn_decrypt_files">"Select input file"</string>
|
||||||
|
|||||||
Reference in New Issue
Block a user