diff --git a/briar-android/src/main/java/org/briarproject/briar/android/conversation/ConversationSettingsDialog.java b/briar-android/src/main/java/org/briarproject/briar/android/conversation/ConversationSettingsDialog.java
index 0f38d964e..0b2efcaa8 100644
--- a/briar-android/src/main/java/org/briarproject/briar/android/conversation/ConversationSettingsDialog.java
+++ b/briar-android/src/main/java/org/briarproject/briar/android/conversation/ConversationSettingsDialog.java
@@ -13,6 +13,7 @@ import org.briarproject.bramble.api.nullsafety.ParametersNotNullByDefault;
import org.briarproject.briar.R;
import org.briarproject.briar.android.activity.ActivityComponent;
import org.briarproject.briar.android.fragment.BaseFragment;
+import org.briarproject.briar.android.widget.OnboardingFullDialogFragment;
import java.util.logging.Logger;
@@ -113,10 +114,10 @@ public class ConversationSettingsDialog extends DialogFragment {
}
private void showLearnMoreDialog() {
- ConversationSettingsLearnMoreDialog
- dialog = new ConversationSettingsLearnMoreDialog();
- dialog.show(getChildFragmentManager(),
- ConversationSettingsLearnMoreDialog.TAG);
+ OnboardingFullDialogFragment.newInstance(
+ R.string.disappearing_messages_title,
+ R.string.disappearing_messages_explanation_long
+ ).show(getChildFragmentManager(), OnboardingFullDialogFragment.TAG);
}
}
diff --git a/briar-android/src/main/java/org/briarproject/briar/android/conversation/ConversationSettingsLearnMoreDialog.java b/briar-android/src/main/java/org/briarproject/briar/android/conversation/ConversationSettingsLearnMoreDialog.java
deleted file mode 100644
index 5f5b960fd..000000000
--- a/briar-android/src/main/java/org/briarproject/briar/android/conversation/ConversationSettingsLearnMoreDialog.java
+++ /dev/null
@@ -1,43 +0,0 @@
-package org.briarproject.briar.android.conversation;
-
-import android.app.Dialog;
-import android.os.Bundle;
-import android.view.LayoutInflater;
-import android.view.View;
-
-import org.briarproject.bramble.api.nullsafety.MethodsNotNullByDefault;
-import org.briarproject.bramble.api.nullsafety.ParametersNotNullByDefault;
-import org.briarproject.briar.R;
-
-import androidx.annotation.Nullable;
-import androidx.appcompat.app.AlertDialog;
-import androidx.fragment.app.DialogFragment;
-import androidx.fragment.app.FragmentActivity;
-
-@MethodsNotNullByDefault
-@ParametersNotNullByDefault
-public class ConversationSettingsLearnMoreDialog extends DialogFragment {
-
- final static String TAG =
- ConversationSettingsLearnMoreDialog.class.getName();
-
- @Override
- public Dialog onCreateDialog(@Nullable Bundle savedInstanceState) {
- FragmentActivity activity = requireActivity();
-
- AlertDialog.Builder builder = new AlertDialog.Builder(activity,
- R.style.OnboardingDialogTheme);
-
- LayoutInflater inflater = LayoutInflater.from(builder.getContext());
- View view = inflater.inflate(
- R.layout.fragment_conversation_settings_learn_more, null);
- builder.setView(view);
-
- builder.setTitle(R.string.disappearing_messages_title);
- builder.setPositiveButton(R.string.ok, null);
-
- return builder.create();
- }
-
-
-}
diff --git a/briar-android/src/main/java/org/briarproject/briar/android/widget/OnboardingFullDialogFragment.java b/briar-android/src/main/java/org/briarproject/briar/android/widget/OnboardingFullDialogFragment.java
new file mode 100644
index 000000000..cf2fd2d72
--- /dev/null
+++ b/briar-android/src/main/java/org/briarproject/briar/android/widget/OnboardingFullDialogFragment.java
@@ -0,0 +1,66 @@
+package org.briarproject.briar.android.widget;
+
+import android.os.Bundle;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.TextView;
+
+import org.briarproject.bramble.api.nullsafety.NotNullByDefault;
+import org.briarproject.briar.R;
+
+import androidx.annotation.NonNull;
+import androidx.annotation.Nullable;
+import androidx.annotation.StringRes;
+import androidx.appcompat.widget.Toolbar;
+import androidx.fragment.app.DialogFragment;
+
+@NotNullByDefault
+public class OnboardingFullDialogFragment extends DialogFragment {
+
+ public final static String TAG =
+ OnboardingFullDialogFragment.class.getName();
+
+ private final static String RES_TITLE = "resTitle";
+ private final static String RES_CONTENT = "resContent";
+
+ public static OnboardingFullDialogFragment newInstance(@StringRes int title,
+ @StringRes int content) {
+ Bundle args = new Bundle();
+ args.putInt(RES_TITLE, title);
+ args.putInt(RES_CONTENT, content);
+ OnboardingFullDialogFragment f = new OnboardingFullDialogFragment();
+ f.setArguments(args);
+ return f;
+ }
+
+ @Override
+ public void onCreate(@Nullable Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setStyle(DialogFragment.STYLE_NORMAL,
+ R.style.BriarFullScreenDialogTheme);
+ }
+
+ @Nullable
+ @Override
+ public View onCreateView(@NonNull LayoutInflater inflater,
+ @Nullable ViewGroup container,
+ @Nullable Bundle savedInstanceState) {
+ View view = inflater.inflate(R.layout.fragment_onboarding_full,
+ container, false);
+
+ Bundle args = requireArguments();
+
+ Toolbar toolbar = view.findViewById(R.id.toolbar);
+ toolbar.setNavigationOnClickListener(v -> dismiss());
+ toolbar.setTitle(args.getInt(RES_TITLE));
+
+ TextView contentView = view.findViewById(R.id.contentView);
+ contentView.setText(args.getInt(RES_CONTENT));
+
+ view.findViewById(R.id.button).setOnClickListener(v -> dismiss());
+
+ return view;
+ }
+
+}
diff --git a/briar-android/src/main/res/layout/fragment_conversation_settings_learn_more.xml b/briar-android/src/main/res/layout/fragment_conversation_settings_learn_more.xml
deleted file mode 100644
index 3e3c6260d..000000000
--- a/briar-android/src/main/res/layout/fragment_conversation_settings_learn_more.xml
+++ /dev/null
@@ -1,19 +0,0 @@
-
-
-
-
-
-
\ No newline at end of file
diff --git a/briar-android/src/main/res/layout/fragment_onboarding_full.xml b/briar-android/src/main/res/layout/fragment_onboarding_full.xml
new file mode 100644
index 000000000..235df95b7
--- /dev/null
+++ b/briar-android/src/main/res/layout/fragment_onboarding_full.xml
@@ -0,0 +1,69 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+