aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorChristian Schneppe <christian@pix-art.de>2018-04-08 19:57:41 +0200
committerChristian Schneppe <christian@pix-art.de>2018-04-08 19:57:41 +0200
commiteb773489d6c08ca336095688a8deda039c09c080 (patch)
tree798ba7237a021e942e3c532c1a835bb81f33a8fd /src
parented43ac7915317c06d3e9ae3fd717b69645759b6e (diff)
place enter jid dialog in dialog fragment
Diffstat (limited to 'src')
-rw-r--r--src/main/java/de/pixart/messenger/ui/BlocklistActivity.java8
-rw-r--r--src/main/java/de/pixart/messenger/ui/ChooseContactActivity.java5
-rw-r--r--src/main/java/de/pixart/messenger/ui/EnterJidDialog.java123
-rw-r--r--src/main/java/de/pixart/messenger/ui/StartConversationActivity.java6
4 files changed, 90 insertions, 52 deletions
diff --git a/src/main/java/de/pixart/messenger/ui/BlocklistActivity.java b/src/main/java/de/pixart/messenger/ui/BlocklistActivity.java
index 26faf003e..422803487 100644
--- a/src/main/java/de/pixart/messenger/ui/BlocklistActivity.java
+++ b/src/main/java/de/pixart/messenger/ui/BlocklistActivity.java
@@ -25,7 +25,7 @@ public class BlocklistActivity extends AbstractSearchableListItemActivity implem
BlockContactDialog.show(BlocklistActivity.this, (Contact) getListItems().get(position));
return true;
});
- this.binding.fab.setOnClickListener((v)->showEnterJidDialog());
+ this.binding.fab.setOnClickListener((v) -> showEnterJidDialog());
}
@Override
@@ -56,8 +56,8 @@ public class BlocklistActivity extends AbstractSearchableListItemActivity implem
}
protected void showEnterJidDialog() {
- EnterJidDialog dialog = new EnterJidDialog(
- this, mKnownHosts, null,
+ EnterJidDialog dialog = EnterJidDialog.newInstance(
+ mKnownHosts, null,
getString(R.string.block_jabber_id), getString(R.string.block),
null, account.getJid().asBareJid().toString(), true, xmppConnectionService.multipleAccounts()
);
@@ -69,7 +69,7 @@ public class BlocklistActivity extends AbstractSearchableListItemActivity implem
}
return true;
});
- dialog.show();
+ dialog.show(getSupportFragmentManager(), "block_contact_dialog");
}
protected void refreshUiReal() {
diff --git a/src/main/java/de/pixart/messenger/ui/ChooseContactActivity.java b/src/main/java/de/pixart/messenger/ui/ChooseContactActivity.java
index 1f991e8a0..ae836ee2a 100644
--- a/src/main/java/de/pixart/messenger/ui/ChooseContactActivity.java
+++ b/src/main/java/de/pixart/messenger/ui/ChooseContactActivity.java
@@ -232,8 +232,7 @@ public class ChooseContactActivity extends AbstractSearchableListItemActivity {
protected void showEnterJidDialog(XmppUri uri) {
Jid jid = uri == null ? null : uri.getJid();
- EnterJidDialog dialog = new EnterJidDialog(
- this,
+ EnterJidDialog dialog = EnterJidDialog.newInstance(
mKnownHosts,
mActivatedAccounts,
getString(R.string.enter_contact),
@@ -259,7 +258,7 @@ public class ChooseContactActivity extends AbstractSearchableListItemActivity {
return true;
});
- dialog.show();
+ dialog.show(getSupportFragmentManager(), "enter_contact_dialog");
}
@Override
diff --git a/src/main/java/de/pixart/messenger/ui/EnterJidDialog.java b/src/main/java/de/pixart/messenger/ui/EnterJidDialog.java
index ef1745fd9..604bfc8d2 100644
--- a/src/main/java/de/pixart/messenger/ui/EnterJidDialog.java
+++ b/src/main/java/de/pixart/messenger/ui/EnterJidDialog.java
@@ -1,16 +1,19 @@
package de.pixart.messenger.ui;
import android.app.Dialog;
-import android.content.Context;
+import android.os.Bundle;
+import android.support.annotation.NonNull;
+import android.support.v4.app.DialogFragment;
import android.support.v7.app.AlertDialog;
-import android.view.LayoutInflater;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
import android.widget.Spinner;
import android.widget.TextView;
+import java.util.ArrayList;
import java.util.Collection;
+import java.util.HashSet;
import java.util.List;
import de.pixart.messenger.Config;
@@ -19,42 +22,56 @@ import de.pixart.messenger.ui.adapter.KnownHostsAdapter;
import de.pixart.messenger.ui.util.DelayedHintHelper;
import rocks.xmpp.addr.Jid;
-public class EnterJidDialog {
- public interface OnEnterJidDialogPositiveListener {
- boolean onEnterJidDialogPositive(Jid account, Jid contact) throws EnterJidDialog.JidError;
- }
-
- public static class JidError extends Exception {
- final String msg;
+public class EnterJidDialog extends DialogFragment {
- public JidError(final String msg) {
- this.msg = msg;
- }
+ private OnEnterJidDialogPositiveListener mListener = null;
+ private static final String TITLE_KEY = "title";
+ private static final String POSITIVE_BUTTON_KEY = "positive_button";
+ private static final String PREFILLED_JID_KEY = "prefilled_jid";
+ private static final String ACCOUNT_KEY = "account";
+ private static final String ALLOW_EDIT_JID_KEY = "allow_edit_jid";
+ private static final String MULTIPLE_ACCOUNTS = "multiple_accounts_enabled";
+ private static final String ACCOUNTS_LIST_KEY = "activated_accounts_list";
+ private static final String CONFERENCE_HOSTS_KEY = "known_conference_hosts";
- public String toString() {
- return msg;
- }
+ public static EnterJidDialog newInstance(
+ Collection<String> knownHosts, final List<String> activatedAccounts,
+ final String title, final String positiveButton,
+ final String prefilledJid, final String account, boolean allowEditJid, boolean multipleAccounts) {
+ EnterJidDialog dialog = new EnterJidDialog();
+ Bundle bundle = new Bundle();
+ bundle.putString(TITLE_KEY, title);
+ bundle.putString(POSITIVE_BUTTON_KEY, positiveButton);
+ bundle.putString(PREFILLED_JID_KEY, prefilledJid);
+ bundle.putString(ACCOUNT_KEY, account);
+ bundle.putBoolean(ALLOW_EDIT_JID_KEY, allowEditJid);
+ bundle.putBoolean(MULTIPLE_ACCOUNTS, multipleAccounts);
+ bundle.putStringArrayList(ACCOUNTS_LIST_KEY, (ArrayList<String>) activatedAccounts);
+ bundle.putSerializable(CONFERENCE_HOSTS_KEY, (HashSet) knownHosts);
+ dialog.setArguments(bundle);
+ return dialog;
}
- protected final AlertDialog dialog;
- protected View.OnClickListener dialogOnClick;
- protected OnEnterJidDialogPositiveListener listener = null;
+ @Override
+ public void onActivityCreated(Bundle savedInstanceState) {
+ super.onActivityCreated(savedInstanceState);
+ setRetainInstance(true);
+ }
- public EnterJidDialog(
- final Context context, Collection<String> knownHosts, final List<String> activatedAccounts,
- final String title, final String positiveButton,
- final String prefilledJid, final String account, boolean allowEditJid, boolean multipleAccounts
- ) {
- final AlertDialog.Builder builder = new AlertDialog.Builder(context);
- builder.setTitle(title);
- final View dialogView = LayoutInflater.from(context).inflate(R.layout.enter_jid_dialog, null);
+ @NonNull
+ @Override
+ public Dialog onCreateDialog(Bundle savedInstanceState) {
+ final AlertDialog.Builder builder = new AlertDialog.Builder(getActivity());
+ builder.setTitle(getArguments().getString(TITLE_KEY));
+ View dialogView = getActivity().getLayoutInflater().inflate(R.layout.enter_jid_dialog, null);
final TextView yourAccount = dialogView.findViewById(R.id.your_account);
final Spinner spinner = dialogView.findViewById(R.id.account);
final AutoCompleteTextView jid = dialogView.findViewById(R.id.jid);
- jid.setAdapter(new KnownHostsAdapter(context, R.layout.simple_list_item, knownHosts));
+ jid.setAdapter(new KnownHostsAdapter(getActivity(), R.layout.simple_list_item, (Collection<String>) getArguments().getSerializable(CONFERENCE_HOSTS_KEY)));
+ String prefilledJid = getArguments().getString(PREFILLED_JID_KEY);
if (prefilledJid != null) {
jid.append(prefilledJid);
- if (!allowEditJid) {
+ if (!getArguments().getBoolean(ALLOW_EDIT_JID_KEY)) {
jid.setFocusable(false);
jid.setFocusableInTouchMode(false);
jid.setClickable(false);
@@ -64,7 +81,9 @@ public class EnterJidDialog {
DelayedHintHelper.setHint(R.string.account_settings_example_jabber_id, jid);
- if (multipleAccounts) {
+ String account = getArguments().getString(ACCOUNT_KEY);
+
+ if (getArguments().getBoolean(MULTIPLE_ACCOUNTS)) {
yourAccount.setVisibility(View.VISIBLE);
spinner.setVisibility(View.VISIBLE);
} else {
@@ -73,9 +92,9 @@ public class EnterJidDialog {
}
if (account == null) {
- StartConversationActivity.populateAccountSpinner(context, activatedAccounts, spinner);
+ StartConversationActivity.populateAccountSpinner(getActivity(), getArguments().getStringArrayList(ACCOUNTS_LIST_KEY), spinner);
} else {
- ArrayAdapter<String> adapter = new ArrayAdapter<>(context,
+ ArrayAdapter<String> adapter = new ArrayAdapter<>(getActivity(),
R.layout.simple_list_item,
new String[]{account});
spinner.setEnabled(false);
@@ -85,10 +104,10 @@ public class EnterJidDialog {
builder.setView(dialogView);
builder.setNegativeButton(R.string.cancel, null);
- builder.setPositiveButton(positiveButton, null);
- this.dialog = builder.create();
+ builder.setPositiveButton(getArguments().getString(POSITIVE_BUTTON_KEY), null);
+ AlertDialog dialog = builder.create();
- this.dialogOnClick = v -> {
+ View.OnClickListener dialogOnClick = v -> {
final Jid accountJid;
if (!spinner.isEnabled() && account == null) {
return;
@@ -106,13 +125,13 @@ public class EnterJidDialog {
try {
contactJid = Jid.of(jid.getText().toString());
} catch (final IllegalArgumentException e) {
- jid.setError(context.getString(R.string.invalid_jid));
+ jid.setError(getActivity().getString(R.string.invalid_jid));
return;
}
- if(listener != null) {
+ if(mListener != null) {
try {
- if(listener.onEnterJidDialogPositive(accountJid, contactJid)) {
+ if(mListener.onEnterJidDialogPositive(accountJid, contactJid)) {
dialog.dismiss();
}
} catch(JidError error) {
@@ -120,17 +139,37 @@ public class EnterJidDialog {
}
}
};
+ dialog.show();
+ dialog.getButton(AlertDialog.BUTTON_POSITIVE).setOnClickListener(dialogOnClick);
+ return dialog;
}
public void setOnEnterJidDialogPositiveListener(OnEnterJidDialogPositiveListener listener) {
- this.listener = listener;
+ this.mListener = listener;
}
- public Dialog show() {
- this.dialog.show();
- this.dialog.getButton(AlertDialog.BUTTON_POSITIVE).setOnClickListener(this.dialogOnClick);
- return this.dialog;
+ public interface OnEnterJidDialogPositiveListener {
+ boolean onEnterJidDialogPositive(Jid account, Jid contact) throws EnterJidDialog.JidError;
}
+ public static class JidError extends Exception {
+ final String msg;
+
+ public JidError(final String msg) {
+ this.msg = msg;
+ }
+ public String toString() {
+ return msg;
+ }
+ }
+
+ @Override
+ public void onDestroyView() {
+ Dialog dialog = getDialog();
+ if (dialog != null && getRetainInstance()) {
+ dialog.setDismissMessage(null);
+ }
+ super.onDestroyView();
+ }
}
diff --git a/src/main/java/de/pixart/messenger/ui/StartConversationActivity.java b/src/main/java/de/pixart/messenger/ui/StartConversationActivity.java
index 0de147361..d3d6d2d2a 100644
--- a/src/main/java/de/pixart/messenger/ui/StartConversationActivity.java
+++ b/src/main/java/de/pixart/messenger/ui/StartConversationActivity.java
@@ -432,8 +432,8 @@ public class StartConversationActivity extends XmppActivity implements OnRosterU
@SuppressLint("InflateParams")
protected void showCreateContactDialog(final String prefilledJid, final Invite invite) {
- EnterJidDialog dialog = new EnterJidDialog(
- this, mKnownHosts, mActivatedAccounts,
+ EnterJidDialog dialog = EnterJidDialog.newInstance(
+ mKnownHosts, mActivatedAccounts,
getString(R.string.create_contact), getString(R.string.create),
prefilledJid, null, invite == null || !invite.hasFingerprints(), xmppConnectionService.multipleAccounts()
);
@@ -467,7 +467,7 @@ public class StartConversationActivity extends XmppActivity implements OnRosterU
}
});
- dialog.show();
+ dialog.show(getSupportFragmentManager(), "create_contact_dialog");
}
@SuppressLint("InflateParams")