1 /* ownCloud Android client application
2 * Copyright (C) 2011 Bartek Przybylski
3 * Copyright (C) 2012-2013 ownCloud Inc.
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2,
7 * as published by the Free Software Foundation.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 package com
.owncloud
.android
.ui
.dialog
;
21 import android
.app
.AlertDialog
;
22 import android
.app
.Dialog
;
23 import android
.content
.DialogInterface
;
24 import android
.os
.Bundle
;
25 import android
.view
.LayoutInflater
;
26 import android
.view
.View
;
27 import android
.view
.WindowManager
.LayoutParams
;
28 import android
.widget
.EditText
;
29 import android
.widget
.TextView
;
31 import com
.actionbarsherlock
.app
.SherlockDialogFragment
;
32 import com
.owncloud
.android
.R
;
37 * Dialog to request the user to input a name, optionally initialized with a former name.
39 * @author Bartek Przybylski
40 * @author David A. Velasco
42 public class EditNameDialog
extends SherlockDialogFragment
implements DialogInterface
.OnClickListener
{
44 public static final String TAG
= EditNameDialog
.class.getSimpleName();
46 protected static final String ARG_TITLE
= "TITLE";
47 protected static final String ARG_NAME
= "NAME";
48 protected static final String ARG_SELECTION_START
= "SELECTION_START";
49 protected static final String ARG_SELECTION_END
= "SELECTION_END";
51 private String mNewFilename
;
52 private boolean mResult
;
53 private EditNameDialogListener mListener
;
56 * Public factory method to get dialog instances.
58 * @param title Text to show as title in the dialog.
59 * @param name Optional text to include in the text input field when the dialog is shown.
60 * @param listener Instance to notify when the dialog is dismissed.
61 * @param selectionStart Index to the first character to be selected in the input field; negative value for none
62 * @param selectionEnd Index to the last character to be selected in the input field; negative value for none
63 * @return New dialog instance, ready to show.
65 static public EditNameDialog
newInstance(String title
, String name
, int selectionStart
, int selectionEnd
, EditNameDialogListener listener
) {
66 EditNameDialog f
= new EditNameDialog();
67 Bundle args
= new Bundle();
68 args
.putString(ARG_TITLE
, title
);
69 args
.putString(ARG_NAME
, name
);
70 args
.putInt(ARG_SELECTION_START
, selectionStart
);
71 args
.putInt(ARG_SELECTION_END
, selectionEnd
);
73 f
.setOnDismissListener(listener
);
82 public Dialog
onCreateDialog(Bundle savedInstanceState
) {
83 String currentName
= getArguments().getString(ARG_NAME
);
84 if (currentName
== null
)
86 String title
= getArguments().getString(ARG_TITLE
);
88 // Inflate the layout for the dialog
89 LayoutInflater inflater
= getSherlockActivity().getLayoutInflater();
90 View v
= inflater
.inflate(R
.layout
.edit_box_dialog
, null
); // null parent view because it will go in the dialog layout
91 EditText inputText
= ((EditText
)v
.findViewById(R
.id
.user_input
));
92 inputText
.setText(currentName
);
94 // Set it to the dialog
95 AlertDialog
.Builder builder
= new AlertDialog
.Builder(getSherlockActivity());
97 .setPositiveButton(R
.string
.common_ok
, this)
98 .setNegativeButton(R
.string
.common_cancel
, this);
101 builder
.setTitle(title
);
106 Dialog d
= builder
.create();
108 inputText
.requestFocus();
109 int selectionStart
= getArguments().getInt(ARG_SELECTION_START
, -1);
110 int selectionEnd
= getArguments().getInt(ARG_SELECTION_END
, -1);
111 if (selectionStart
>= 0 && selectionEnd
>= 0) {
112 inputText
.setSelection(Math
.min(selectionStart
, selectionEnd
), Math
.max(selectionStart
, selectionEnd
));
114 d
.getWindow().setSoftInputMode(LayoutParams
.SOFT_INPUT_STATE_VISIBLE
);
120 * Performs the corresponding action when a dialog button is clicked.
122 * Saves the text in the input field to be accessed through {@link #getNewFilename()} when the positive
125 * Notify the current listener in any case.
128 public void onClick(DialogInterface dialog
, int which
) {
130 case AlertDialog
.BUTTON_POSITIVE
: {
131 mNewFilename
= ((TextView
)(getDialog().findViewById(R
.id
.user_input
))).getText().toString();
134 case AlertDialog
.BUTTON_NEGATIVE
: { // fall through
136 if (mListener
!= null
)
137 mListener
.onDismiss(this);
142 protected void setOnDismissListener(EditNameDialogListener listener
) {
143 mListener
= listener
;
147 * Returns the text in the input field after the user clicked the positive button.
149 * @return Text in the input field.
151 public String
getNewFilename() {
157 * @return True when the user clicked the positive button.
159 public boolean getResult() {
165 * Interface to receive a notification when any button in the dialog is clicked.
167 public interface EditNameDialogListener
{
168 public void onDismiss(EditNameDialog dialog
);