From 8802ebd5172ec4bc412a59d136c82b77ab452281 Mon Sep 17 00:00:00 2001 From: aleksandar-stefanovic Date: Sun, 15 Jan 2017 10:45:56 +0100 Subject: Moved About dialog to DialogFragment MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This makes the dialog more modular, and it takes no parameters instead of two. This is in the preparation of making the classes more independent on each-other's states, which is very important. Also, this follows the Android way of workflow better, since there is no "wrapper" class around the dialog, but instead the dialog is called directly. Change-Id: I7571480a040efaf202fae3929cfe76d65c19653e Reviewed-on: https://gerrit.libreoffice.org/33086 Tested-by: Jenkins Reviewed-by: Aleksandar Stefanović --- .../java/org/libreoffice/AboutDialogFragment.java | 108 ++++++++++++++++++++ .../source/src/java/org/libreoffice/LOAbout.java | 113 --------------------- .../org/libreoffice/LibreOfficeMainActivity.java | 8 +- .../org/libreoffice/ui/LibreOfficeUIActivity.java | 13 +-- 4 files changed, 115 insertions(+), 127 deletions(-) create mode 100644 android/source/src/java/org/libreoffice/AboutDialogFragment.java delete mode 100644 android/source/src/java/org/libreoffice/LOAbout.java diff --git a/android/source/src/java/org/libreoffice/AboutDialogFragment.java b/android/source/src/java/org/libreoffice/AboutDialogFragment.java new file mode 100644 index 000000000000..1f4e7438d2ce --- /dev/null +++ b/android/source/src/java/org/libreoffice/AboutDialogFragment.java @@ -0,0 +1,108 @@ +/* + * + * * This file is part of the LibreOffice project. + * * This Source Code Form is subject to the terms of the Mozilla Public + * * License, v. 2.0. If a copy of the MPL was not distributed with this + * * file, You can obtain one at http://mozilla.org/MPL/2.0/. + * + */ + +package org.libreoffice; + +import android.annotation.SuppressLint; +import android.app.AlertDialog; +import android.app.Dialog; +import android.content.ComponentName; +import android.content.DialogInterface; +import android.content.Intent; +import android.content.pm.PackageManager; +import android.net.Uri; +import android.os.Bundle; +import android.support.annotation.NonNull; +import android.support.v4.app.DialogFragment; +import android.view.View; +import android.widget.TextView; + +import java.io.File; + +public class AboutDialogFragment extends DialogFragment { + + private static final String DEFAULT_DOC_PATH = "/assets/example.odt"; + + + @NonNull @Override + public Dialog onCreateDialog(Bundle savedInstanceState) { + + @SuppressLint("InflateParams") //suppressed because the view will be placed in a dialog + View messageView = getActivity().getLayoutInflater().inflate(R.layout.about, null, false); + + // When linking text, force to always use default color. This works + // around a pressed color state bug. + TextView textView = (TextView) messageView.findViewById(R.id.about_credits); + int defaultColor = textView.getTextColors().getDefaultColor(); + textView.setTextColor(defaultColor); + + // Take care of placeholders in the version and vendor text views. + TextView versionView = (TextView)messageView.findViewById(R.id.about_version); + TextView vendorView = (TextView)messageView.findViewById(R.id.about_vendor); + try + { + String versionName = getActivity().getPackageManager() + .getPackageInfo(getActivity().getPackageName(), 0).versionName; + String[] tokens = versionName.split("/"); + if (tokens.length == 3) + { + String version = versionView.getText().toString(); + String vendor = vendorView.getText().toString(); + version = version.replace("$VERSION", tokens[0]); + version = version.replace("$BUILDID", tokens[1]); + vendor = vendor.replace("$VENDOR", tokens[2]); + versionView.setText(version); + vendorView.setText(vendor); + } + else + throw new PackageManager.NameNotFoundException(); + } + catch (PackageManager.NameNotFoundException e) + { + versionView.setText(""); + vendorView.setText(""); + } + + AlertDialog.Builder builder = new AlertDialog.Builder(getActivity()); + builder .setIcon(R.drawable.lo_icon) + .setTitle(R.string.app_name) + .setView(messageView) + .setNegativeButton(R.string.about_license, new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, int id) { + loadFromAbout("/assets/license.txt"); + dialog.dismiss(); + } + }) + .setPositiveButton(R.string.about_notice, new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, int id) { + loadFromAbout("/assets/notice.txt"); + dialog.dismiss(); + } + }) + .setNeutralButton(R.string.about_moreinfo, new DialogInterface.OnClickListener() { + @Override + public void onClick(DialogInterface dialog, int id) { + loadFromAbout(DEFAULT_DOC_PATH); + dialog.dismiss(); + } + }); + + return builder.create(); + } + + private void loadFromAbout(String input) { + Intent i = new Intent(Intent.ACTION_VIEW, Uri.fromFile(new File(input))); + String packageName = getActivity().getApplicationContext().getPackageName(); + ComponentName componentName = new ComponentName(packageName, LibreOfficeMainActivity.class.getName()); + i.setComponent(componentName); + getActivity().startActivity(i); + } +} diff --git a/android/source/src/java/org/libreoffice/LOAbout.java b/android/source/src/java/org/libreoffice/LOAbout.java deleted file mode 100644 index 111ad109669d..000000000000 --- a/android/source/src/java/org/libreoffice/LOAbout.java +++ /dev/null @@ -1,113 +0,0 @@ -package org.libreoffice; - -import android.app.Activity; -import android.app.AlertDialog; -import android.content.ComponentName; -import android.content.DialogInterface; -import android.content.Intent; -import android.content.pm.PackageManager.NameNotFoundException; -import android.net.Uri; -import android.view.View; -import android.widget.TextView; - -import java.io.File; - -/** - * The about dialog. - */ -public class LOAbout { - - private static final String DEFAULT_DOC_PATH = "/assets/example.odt"; - private final Activity mActivity; - - private boolean mNewActivity; - - public LOAbout(Activity activity, boolean newActivity) { - mActivity = activity; - mNewActivity = newActivity; - } - - private void loadFromAbout(String input) { - if (mNewActivity) { - Intent i = new Intent(Intent.ACTION_VIEW, Uri.fromFile(new File(input))); - String packageName = mActivity.getApplicationContext().getPackageName(); - ComponentName componentName = new ComponentName(packageName, LibreOfficeMainActivity.class.getName()); - i.setComponent(componentName); - mActivity.startActivity(i); - } else { - LOKitShell.sendCloseEvent(); - LOKitShell.sendLoadEvent(input); - } - } - - public void showAbout() { - // Inflate the about message contents - View messageView = mActivity.getLayoutInflater().inflate(R.layout.about, null, false); - - // When linking text, force to always use default color. This works - // around a pressed color state bug. - TextView textView = (TextView) messageView.findViewById(R.id.about_credits); - int defaultColor = textView.getTextColors().getDefaultColor(); - textView.setTextColor(defaultColor); - - // Take care of placeholders in the version and vendor text views. - TextView versionView = (TextView)messageView.findViewById(R.id.about_version); - TextView vendorView = (TextView)messageView.findViewById(R.id.about_vendor); - try - { - String versionName = mActivity.getPackageManager().getPackageInfo(mActivity.getPackageName(), 0).versionName; - String[] tokens = versionName.split("/"); - if (tokens.length == 3) - { - String version = versionView.getText().toString(); - String vendor = vendorView.getText().toString(); - version = version.replace("$VERSION", tokens[0]); - version = version.replace("$BUILDID", tokens[1]); - vendor = vendor.replace("$VENDOR", tokens[2]); - versionView.setText(version); - vendorView.setText(vendor); - } - else - throw new NameNotFoundException(); - } - catch (NameNotFoundException e) - { - versionView.setText(""); - vendorView.setText(""); - } - - AlertDialog.Builder builder = new AlertDialog.Builder(mActivity); - builder.setIcon(R.drawable.lo_icon); - builder.setTitle(R.string.app_name); - builder.setView(messageView); - - builder.setNegativeButton(R.string.about_license, new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int id) { - loadFromAbout("/assets/license.txt"); - dialog.dismiss(); - } - }); - - builder.setPositiveButton(R.string.about_notice, new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int id) { - loadFromAbout("/assets/notice.txt"); - dialog.dismiss(); - } - }); - - builder.setNeutralButton(R.string.about_moreinfo, new DialogInterface.OnClickListener() { - @Override - public void onClick(DialogInterface dialog, int id) { - loadFromAbout(DEFAULT_DOC_PATH); - dialog.dismiss(); - } - }); - - AlertDialog dialog = builder.create(); - dialog.show(); - } -} - -/* vim:set shiftwidth=4 softtabstop=4 expandtab: */ diff --git a/android/source/src/java/org/libreoffice/LibreOfficeMainActivity.java b/android/source/src/java/org/libreoffice/LibreOfficeMainActivity.java index 93e041c14349..b84f78bc94e6 100755 --- a/android/source/src/java/org/libreoffice/LibreOfficeMainActivity.java +++ b/android/source/src/java/org/libreoffice/LibreOfficeMainActivity.java @@ -64,7 +64,6 @@ public class LibreOfficeMainActivity extends AppCompatActivity { private URI documentUri; private DrawerLayout mDrawerLayout; - private LOAbout mAbout; private ListView mDrawerList; private List mDocumentPartView = new ArrayList(); @@ -79,10 +78,6 @@ public class LibreOfficeMainActivity extends AppCompatActivity { private FontController mFontController; private SearchController mSearchController; - public LibreOfficeMainActivity() { - mAbout = new LOAbout(this, false); - } - public GeckoLayerClient getLayerClient() { return mLayerClient; } @@ -599,7 +594,8 @@ public class LibreOfficeMainActivity extends AppCompatActivity { } public void showAbout() { - mAbout.showAbout(); + AboutDialogFragment aboutDialogFragment = new AboutDialogFragment(); + aboutDialogFragment.show(getSupportFragmentManager(), "AboutDialogFragment"); } public void showSettings() { diff --git a/android/source/src/java/org/libreoffice/ui/LibreOfficeUIActivity.java b/android/source/src/java/org/libreoffice/ui/LibreOfficeUIActivity.java index 67a848086353..efec500e4c57 100644 --- a/android/source/src/java/org/libreoffice/ui/LibreOfficeUIActivity.java +++ b/android/source/src/java/org/libreoffice/ui/LibreOfficeUIActivity.java @@ -48,7 +48,7 @@ import android.widget.TextView; import android.widget.Toast; import android.support.design.widget.NavigationView; -import org.libreoffice.LOAbout; +import org.libreoffice.AboutDialogFragment; import org.libreoffice.LibreOfficeMainActivity; import org.libreoffice.R; import org.libreoffice.SettingsActivity; @@ -99,13 +99,8 @@ public class LibreOfficeUIActivity extends AppCompatActivity { private ActionBarDrawerToggle drawerToggle; RecyclerView fileRecyclerView; - private final LOAbout mAbout; private boolean canQuit = false; - public LibreOfficeUIActivity() { - mAbout = new LOAbout(this, true); - } - @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); @@ -554,8 +549,10 @@ public class LibreOfficeUIActivity extends AppCompatActivity { case R.id.menu_sort_modified: sortFiles(item); break; - case R.id.action_about: - mAbout.showAbout(); + case R.id.action_about: { + AboutDialogFragment aboutDialogFragment = new AboutDialogFragment(); + aboutDialogFragment.show(getSupportFragmentManager(), "AboutDialogFragment"); + } return true; case R.id.action_settings: startActivity(new Intent(getApplicationContext(), SettingsActivity.class)); -- cgit