diff options
| author | Shubham Basu <basushubham@google.com> | 2021-03-04 11:12:59 -0800 |
|---|---|---|
| committer | Shubham Basu <basushubham@google.com> | 2021-03-10 17:26:14 -0800 |
| commit | f40ab06f378b886ab4da12e657a992aaa0250661 (patch) | |
| tree | 865c7749690c3bd6012eb8e230adcd80a059c26f /src | |
| parent | da76c5f47d590be54082a5ed6cfdb865a7d7d869 (diff) | |
| download | platform_packages_apps_DocumentsUI-f40ab06f378b886ab4da12e657a992aaa0250661.tar.gz platform_packages_apps_DocumentsUI-f40ab06f378b886ab4da12e657a992aaa0250661.tar.bz2 platform_packages_apps_DocumentsUI-f40ab06f378b886ab4da12e657a992aaa0250661.zip | |
Check empty string on create and rename folder
Fix: 175717294
Test: atest DocumentsUIGoogleTests, Manual
Change-Id: I98ddb3e750260a5364891b12a27beca9388ad932
Diffstat (limited to 'src')
| -rw-r--r-- | src/com/android/documentsui/CreateDirectoryFragment.java | 58 | ||||
| -rw-r--r-- | src/com/android/documentsui/dirlist/RenameDocumentFragment.java | 20 |
2 files changed, 36 insertions, 42 deletions
diff --git a/src/com/android/documentsui/CreateDirectoryFragment.java b/src/com/android/documentsui/CreateDirectoryFragment.java index 9ef58839b..4b066edb6 100644 --- a/src/com/android/documentsui/CreateDirectoryFragment.java +++ b/src/com/android/documentsui/CreateDirectoryFragment.java @@ -25,7 +25,6 @@ import android.content.ContentProviderClient; import android.content.ContentResolver; import android.content.Context; import android.content.DialogInterface; -import android.content.DialogInterface.OnClickListener; import android.net.Uri; import android.os.AsyncTask; import android.os.Bundle; @@ -37,6 +36,7 @@ import android.view.KeyEvent; import android.view.LayoutInflater; import android.view.View; import android.view.inputmethod.EditorInfo; +import android.widget.Button; import android.widget.EditText; import android.widget.TextView; import android.widget.TextView.OnEditorActionListener; @@ -59,6 +59,9 @@ import com.google.android.material.textfield.TextInputLayout; */ public class CreateDirectoryFragment extends DialogFragment { private static final String TAG_CREATE_DIRECTORY = "create_directory"; + private @Nullable DialogInterface mDialog; + private EditText mEditText; + private TextInputLayout mInputWrapper; public static void show(FragmentManager fm) { if (fm.isStateSaved()) { @@ -78,30 +81,20 @@ public class CreateDirectoryFragment extends DialogFragment { final LayoutInflater dialogInflater = LayoutInflater.from(builder.getContext()); final View view = dialogInflater.inflate(R.layout.dialog_file_name, null, false); - final EditText editText = (EditText) view.findViewById(android.R.id.text1); + mEditText = (EditText) view.findViewById(android.R.id.text1); - final TextInputLayout inputWrapper = view.findViewById(R.id.input_wrapper); - inputWrapper.setHint(getString(R.string.input_hint_new_folder)); + mInputWrapper = view.findViewById(R.id.input_wrapper); + mInputWrapper.setHint(getString(R.string.input_hint_new_folder)); builder.setTitle(R.string.menu_create_dir); builder.setView(view); - - builder.setPositiveButton( - android.R.string.ok, - new OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int which) { - createDirectory(editText.getText().toString()); - } - }); - + builder.setPositiveButton(android.R.string.ok, null); builder.setNegativeButton(android.R.string.cancel, null); final AlertDialog dialog = builder.create(); - + dialog.setOnShowListener(this::onShowDialog); // Workaround for the problem - virtual keyboard doesn't show on the phone. Shared.ensureKeyboardPresent(context, dialog); - - editText.setOnEditorActionListener( + mEditText.setOnEditorActionListener( new OnEditorActionListener() { @Override public boolean onEditorAction( @@ -109,24 +102,39 @@ public class CreateDirectoryFragment extends DialogFragment { if ((actionId == EditorInfo.IME_ACTION_DONE) || (event != null && event.getKeyCode() == KeyEvent.KEYCODE_ENTER && event.hasNoModifiers())) { - createDirectory(editText.getText().toString()); - dialog.dismiss(); + createDirectory(mEditText.getText().toString()); return true; } return false; } }); - editText.requestFocus(); + mEditText.requestFocus(); return dialog; } - private void createDirectory(String name) { - final BaseActivity activity = (BaseActivity) getActivity(); - final DocumentInfo cwd = activity.getCurrentDirectory(); + private void onShowDialog(DialogInterface dialog) { + mDialog = dialog; + Button button = ((AlertDialog) dialog).getButton(AlertDialog.BUTTON_POSITIVE); + button.setOnClickListener(this::onClickDialog); + } + + private void onClickDialog(View view) { + createDirectory(mEditText.getText().toString()); + } - new CreateDirectoryTask(activity, cwd, name).executeOnExecutor( - ProviderExecutor.forAuthority(cwd.authority)); + private void createDirectory(String name) { + if (name.isEmpty()) { + mInputWrapper.setError(getContext().getString( + R.string.add_folder_name_error)); + } else { + final BaseActivity activity = (BaseActivity) getActivity(); + final DocumentInfo cwd = activity.getCurrentDirectory(); + + new CreateDirectoryTask(activity, cwd, name).executeOnExecutor( + ProviderExecutor.forAuthority(cwd.authority)); + mDialog.dismiss(); + } } private class CreateDirectoryTask extends AsyncTask<Void, Void, DocumentInfo> { diff --git a/src/com/android/documentsui/dirlist/RenameDocumentFragment.java b/src/com/android/documentsui/dirlist/RenameDocumentFragment.java index f46c4e54f..12873a218 100644 --- a/src/com/android/documentsui/dirlist/RenameDocumentFragment.java +++ b/src/com/android/documentsui/dirlist/RenameDocumentFragment.java @@ -158,16 +158,6 @@ public class RenameDocumentFragment extends DialogFragment { } /** - * Validates if string is a proper document name. - * Checks if string is not empty. More rules might be added later. - * @param docName string representing document name - * @returns true if string is a valid name. - **/ - private boolean isValidDocumentName(String docName) { - return !docName.isEmpty(); - } - - /** * Fills text field with the file name and selects the name without extension. * * @param editText text field to be filled @@ -193,17 +183,13 @@ public class RenameDocumentFragment extends DialogFragment { if (newDisplayName.equals(mDocument.displayName)) { mDialog.dismiss(); - } else if (!isValidDocumentName(newDisplayName)) { - Log.w(TAG, "Failed to rename file - invalid name:" + newDisplayName); - mRenameInputWrapper.setError(getContext().getString(R.string.rename_error)); - Metrics.logRenameFileError(); - } else if (activity.getInjector().getModel().hasFileWithName(newDisplayName)){ + } else if (newDisplayName.isEmpty()) { + mRenameInputWrapper.setError(getContext().getString(R.string.missing_rename_error)); + } else if (activity.getInjector().getModel().hasFileWithName(newDisplayName)) { mRenameInputWrapper.setError(getContext().getString(R.string.name_conflict)); selectFileName(mEditText); - Metrics.logRenameFileError(); } else { new RenameDocumentsTask(activity, newDisplayName).execute(mDocument); - if (mDialog != null) { mDialog.dismiss(); } |
