summaryrefslogtreecommitdiffstats
path: root/app/src/main/java/app/fedilab/android
diff options
context:
space:
mode:
Diffstat (limited to 'app/src/main/java/app/fedilab/android')
-rw-r--r--app/src/main/java/app/fedilab/android/MainApplication.java11
-rw-r--r--app/src/main/java/app/fedilab/android/client/entities/api/Status.java1
-rw-r--r--app/src/main/java/app/fedilab/android/helper/Helper.java2
-rw-r--r--app/src/main/java/app/fedilab/android/ui/drawer/StatusAdapter.java22
4 files changed, 26 insertions, 10 deletions
diff --git a/app/src/main/java/app/fedilab/android/MainApplication.java b/app/src/main/java/app/fedilab/android/MainApplication.java
index e598fe6ed..a8841037d 100644
--- a/app/src/main/java/app/fedilab/android/MainApplication.java
+++ b/app/src/main/java/app/fedilab/android/MainApplication.java
@@ -41,7 +41,7 @@ public class MainApplication extends MultiDexApplication {
private static MainApplication app;
-
+ private WebView webView;
public static MainApplication getApp() {
return app;
}
@@ -52,10 +52,9 @@ public class MainApplication extends MultiDexApplication {
app = this;
SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(MainApplication.this);
try {
- new WebView(this);
+ webView = new WebView(this);
} catch (Exception ignored) {
}
-
boolean dynamicColor = sharedpreferences.getBoolean(getString(R.string.SET_DYNAMICCOLOR), false);
if (dynamicColor) {
DynamicColors.applyToActivitiesIfAvailable(this);
@@ -63,6 +62,12 @@ public class MainApplication extends MultiDexApplication {
StrictMode.VmPolicy.Builder builder = new StrictMode.VmPolicy.Builder();
StrictMode.setVmPolicy(builder.build());
Toasty.Config.getInstance().apply();
+ if (webView != null) {
+ try {
+ webView.destroy();
+ } catch (Exception ignored) {
+ }
+ }
}
diff --git a/app/src/main/java/app/fedilab/android/client/entities/api/Status.java b/app/src/main/java/app/fedilab/android/client/entities/api/Status.java
index 7bbc3ba6c..b94cfbdcf 100644
--- a/app/src/main/java/app/fedilab/android/client/entities/api/Status.java
+++ b/app/src/main/java/app/fedilab/android/client/entities/api/Status.java
@@ -117,6 +117,7 @@ public class Status implements Serializable, Cloneable {
public boolean isChecked = false;
public String translationContent;
public boolean translationShown;
+ public boolean mathsShown = false;
public boolean canLoadMedia = false;
public transient boolean isFocused = false;
public transient boolean setCursorToEnd = false;
diff --git a/app/src/main/java/app/fedilab/android/helper/Helper.java b/app/src/main/java/app/fedilab/android/helper/Helper.java
index 7a0881ed2..f6c35ba65 100644
--- a/app/src/main/java/app/fedilab/android/helper/Helper.java
+++ b/app/src/main/java/app/fedilab/android/helper/Helper.java
@@ -327,7 +327,7 @@ public class Helper {
public static final Pattern groupPattern = Pattern.compile("(![\\w_]+)");
public static final Pattern mentionPattern = Pattern.compile("(@[\\w_.-]?[\\w]+)");
public static final Pattern mentionLongPattern = Pattern.compile("(@[\\w_.-]+@[a-zA-Z0-9][a-zA-Z0-9.-]{1,61}[a-zA-Z0-9](?:\\.[a-zA-Z]{2,})+)");
- public static final Pattern mathsPattern = Pattern.compile("\\\\\\(");
+ public static final Pattern mathsPattern = Pattern.compile("\\\\\\(|\\\\\\{|\\\\\\[");
public static final Pattern twitterPattern = Pattern.compile("((@[\\w]+)@twitter\\.com)");
public static final Pattern youtubePattern = Pattern.compile("(www\\.|m\\.)?(youtube\\.com|youtu\\.be|youtube-nocookie\\.com)/(((?!([\"'<])).)*)");
public static final Pattern nitterPattern = Pattern.compile("(mobile\\.|www\\.)?twitter.com([\\w-/]+)");
diff --git a/app/src/main/java/app/fedilab/android/ui/drawer/StatusAdapter.java b/app/src/main/java/app/fedilab/android/ui/drawer/StatusAdapter.java
index 632752ed2..af9c1ddfc 100644
--- a/app/src/main/java/app/fedilab/android/ui/drawer/StatusAdapter.java
+++ b/app/src/main/java/app/fedilab/android/ui/drawer/StatusAdapter.java
@@ -644,6 +644,7 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
if (status.isMaths == null) {
if (Helper.mathsPattern.matcher(status.content).find()) {
holder.binding.actionButtonMaths.setVisibility(View.VISIBLE);
+ status.isMaths = true;
} else {
holder.binding.actionButtonMaths.setVisibility(View.GONE);
}
@@ -654,10 +655,17 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
holder.binding.actionButtonMaths.setVisibility(View.GONE);
}
}
+ if (status.mathsShown) {
+ holder.binding.statusContentMaths.setVisibility(View.VISIBLE);
+ holder.binding.statusContent.setVisibility(View.GONE);
+ } else {
+ holder.binding.statusContentMaths.setVisibility(View.GONE);
+ holder.binding.statusContent.setVisibility(View.VISIBLE);
+ }
holder.binding.actionButtonMaths.setOnClickListener(v -> {
- if (holder.binding.statusContentMaths.getVisibility() == View.VISIBLE) {
- holder.binding.statusContentMaths.setVisibility(View.GONE);
- holder.binding.statusContent.setVisibility(View.VISIBLE);
+
+ if (status.mathsShown) {
+ status.mathsShown = false;
} else {
holder.binding.statusContentMaths.removeAllViews();
MathJaxConfig mathJaxConfig = new MathJaxConfig();
@@ -669,12 +677,12 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
mathJaxConfig.setTextColor("dark");
break;
}
+ status.mathsShown = true;
MathJaxView mathview = new MathJaxView(context, mathJaxConfig);
holder.binding.statusContentMaths.addView(mathview);
mathview.setInputText(status.contentSpan.toString());
- holder.binding.statusContentMaths.setVisibility(View.VISIBLE);
- holder.binding.statusContent.setVisibility(View.GONE);
}
+ adapter.notifyItemChanged(holder.getBindingAdapterPosition());
});
holder.binding.actionButtonFavorite.setActiveImage(R.drawable.ic_round_star_24);
holder.binding.actionButtonFavorite.setInactiveImage(R.drawable.ic_round_star_border_24);
@@ -1305,7 +1313,9 @@ public class StatusAdapter extends RecyclerView.Adapter<RecyclerView.ViewHolder>
if (statusToDeal.content.trim().length() == 0) {
holder.binding.mediaContainer.setVisibility(View.GONE);
} else {
- holder.binding.statusContent.setVisibility(View.VISIBLE);
+ if (!status.mathsShown) {
+ holder.binding.statusContent.setVisibility(View.VISIBLE);
+ }
if (statusToDeal.card != null && statusToDeal.quote_id == null && (display_card || statusToDeal.isFocused)) {
holder.binding.card.setVisibility(View.VISIBLE);
} else {