upgrade appcompat, fix nightmode (#1455)
* upgrade appcompat, fix language switching & nightmode * cleanup ThemeUtils * upgrade dependencies * change active boost icon (#1513) * upgrade jetifier and android gradle plugin * fix FilterTest
This commit is contained in:
parent
9e4c19a47e
commit
2dad358c96
18 changed files with 52 additions and 71 deletions
|
@ -95,15 +95,15 @@ dependencies {
|
||||||
implementation('com.mikepenz:materialdrawer:6.1.2@aar') {
|
implementation('com.mikepenz:materialdrawer:6.1.2@aar') {
|
||||||
transitive = true
|
transitive = true
|
||||||
}
|
}
|
||||||
implementation 'androidx.core:core:1.0.2'
|
implementation 'androidx.core:core:1.1.0'
|
||||||
implementation 'androidx.appcompat:appcompat:1.0.2'
|
implementation 'androidx.appcompat:appcompat:1.1.0'
|
||||||
implementation 'androidx.browser:browser:1.0.0'
|
implementation 'androidx.browser:browser:1.0.0'
|
||||||
implementation 'androidx.recyclerview:recyclerview:1.0.0'
|
implementation 'androidx.recyclerview:recyclerview:1.0.0'
|
||||||
implementation 'androidx.legacy:legacy-support-v13:1.0.0'
|
implementation 'androidx.legacy:legacy-support-v13:1.0.0'
|
||||||
implementation 'com.google.android.material:material:1.1.0-alpha10'
|
implementation 'com.google.android.material:material:1.1.0-alpha10'
|
||||||
implementation 'androidx.exifinterface:exifinterface:1.0.0'
|
implementation 'androidx.exifinterface:exifinterface:1.0.0'
|
||||||
implementation 'androidx.cardview:cardview:1.0.0'
|
implementation 'androidx.cardview:cardview:1.0.0'
|
||||||
implementation 'androidx.preference:preference:1.1.0-alpha04'
|
implementation 'androidx.preference:preference:1.1.0'
|
||||||
implementation "com.squareup.retrofit2:retrofit:$retrofitVersion"
|
implementation "com.squareup.retrofit2:retrofit:$retrofitVersion"
|
||||||
implementation "com.squareup.retrofit2:converter-gson:$retrofitVersion"
|
implementation "com.squareup.retrofit2:converter-gson:$retrofitVersion"
|
||||||
implementation "com.squareup.retrofit2:adapter-rxjava2:$retrofitVersion"
|
implementation "com.squareup.retrofit2:adapter-rxjava2:$retrofitVersion"
|
||||||
|
@ -123,7 +123,7 @@ dependencies {
|
||||||
implementation 'androidx.emoji:emoji-appcompat:1.0.0'
|
implementation 'androidx.emoji:emoji-appcompat:1.0.0'
|
||||||
implementation 'de.c1710:filemojicompat:1.0.17'
|
implementation 'de.c1710:filemojicompat:1.0.17'
|
||||||
// architecture components
|
// architecture components
|
||||||
implementation 'androidx.lifecycle:lifecycle-extensions:2.0.0'
|
implementation 'androidx.lifecycle:lifecycle-extensions:2.1.0'
|
||||||
//room
|
//room
|
||||||
implementation 'androidx.room:room-runtime:2.1.0'
|
implementation 'androidx.room:room-runtime:2.1.0'
|
||||||
implementation 'androidx.legacy:legacy-support-v4:1.0.0'
|
implementation 'androidx.legacy:legacy-support-v4:1.0.0'
|
||||||
|
@ -157,5 +157,5 @@ dependencies {
|
||||||
implementation 'com.github.bumptech.glide:okhttp3-integration:4.10.0'
|
implementation 'com.github.bumptech.glide:okhttp3-integration:4.10.0'
|
||||||
|
|
||||||
//Add some useful extensions
|
//Add some useful extensions
|
||||||
implementation 'androidx.core:core-ktx:1.2.0-alpha01'
|
implementation 'androidx.core:core-ktx:1.2.0-alpha04'
|
||||||
}
|
}
|
||||||
|
|
|
@ -52,8 +52,6 @@ import javax.inject.Inject;
|
||||||
|
|
||||||
public abstract class BaseActivity extends AppCompatActivity implements Injectable {
|
public abstract class BaseActivity extends AppCompatActivity implements Injectable {
|
||||||
|
|
||||||
@Inject
|
|
||||||
public ThemeUtils themeUtils;
|
|
||||||
@Inject
|
@Inject
|
||||||
public AccountManager accountManager;
|
public AccountManager accountManager;
|
||||||
|
|
||||||
|
@ -75,8 +73,6 @@ public abstract class BaseActivity extends AppCompatActivity implements Injectab
|
||||||
setTheme(R.style.TuskyBlackTheme);
|
setTheme(R.style.TuskyBlackTheme);
|
||||||
}
|
}
|
||||||
|
|
||||||
themeUtils.setAppNightMode(theme, this);
|
|
||||||
|
|
||||||
/* set the taskdescription programmatically, the theme would turn it blue */
|
/* set the taskdescription programmatically, the theme would turn it blue */
|
||||||
String appName = getString(R.string.app_name);
|
String appName = getString(R.string.app_name);
|
||||||
Bitmap appIcon = BitmapFactory.decodeResource(getResources(), R.mipmap.ic_launcher);
|
Bitmap appIcon = BitmapFactory.decodeResource(getResources(), R.mipmap.ic_launcher);
|
||||||
|
|
|
@ -32,7 +32,6 @@ import dagger.android.DispatchingAndroidInjector
|
||||||
import kotlinx.android.synthetic.main.toolbar_basic.*
|
import kotlinx.android.synthetic.main.toolbar_basic.*
|
||||||
import java.lang.IllegalArgumentException
|
import java.lang.IllegalArgumentException
|
||||||
import javax.inject.Inject
|
import javax.inject.Inject
|
||||||
import androidx.appcompat.app.AppCompatDelegate
|
|
||||||
import dagger.android.HasAndroidInjector
|
import dagger.android.HasAndroidInjector
|
||||||
|
|
||||||
class PreferencesActivity : BaseActivity(), SharedPreferences.OnSharedPreferenceChangeListener,
|
class PreferencesActivity : BaseActivity(), SharedPreferences.OnSharedPreferenceChangeListener,
|
||||||
|
@ -124,18 +123,11 @@ class PreferencesActivity : BaseActivity(), SharedPreferences.OnSharedPreference
|
||||||
"appTheme" -> {
|
"appTheme" -> {
|
||||||
val theme = sharedPreferences.getNonNullString("appTheme", ThemeUtils.APP_THEME_DEFAULT)
|
val theme = sharedPreferences.getNonNullString("appTheme", ThemeUtils.APP_THEME_DEFAULT)
|
||||||
Log.d("activeTheme", theme)
|
Log.d("activeTheme", theme)
|
||||||
themeUtils.setAppNightMode(theme, this)
|
ThemeUtils.setAppNightMode(theme)
|
||||||
|
|
||||||
restartActivitiesOnExit = true
|
restartActivitiesOnExit = true
|
||||||
this.restartCurrentActivity()
|
this.restartCurrentActivity()
|
||||||
|
|
||||||
// MODE_NIGHT_FOLLOW_SYSTEM workaround part 2 :/
|
|
||||||
when(theme){
|
|
||||||
ThemeUtils.THEME_SYSTEM -> {
|
|
||||||
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_FOLLOW_SYSTEM)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//workaround end
|
|
||||||
}
|
}
|
||||||
"statusTextSize", "absoluteTimeView", "showBotOverlay", "animateGifAvatars" -> {
|
"statusTextSize", "absoluteTimeView", "showBotOverlay", "animateGifAvatars" -> {
|
||||||
restartActivitiesOnExit = true
|
restartActivitiesOnExit = true
|
||||||
|
|
|
@ -17,6 +17,7 @@ package com.keylesspalace.tusky;
|
||||||
|
|
||||||
import android.app.Application;
|
import android.app.Application;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.SharedPreferences;
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.preference.PreferenceManager;
|
import android.preference.PreferenceManager;
|
||||||
|
|
||||||
|
@ -30,6 +31,7 @@ import com.keylesspalace.tusky.di.AppInjector;
|
||||||
import com.keylesspalace.tusky.util.EmojiCompatFont;
|
import com.keylesspalace.tusky.util.EmojiCompatFont;
|
||||||
import com.keylesspalace.tusky.util.LocaleManager;
|
import com.keylesspalace.tusky.util.LocaleManager;
|
||||||
import com.keylesspalace.tusky.util.NotificationPullJobCreator;
|
import com.keylesspalace.tusky.util.NotificationPullJobCreator;
|
||||||
|
import com.keylesspalace.tusky.util.ThemeUtils;
|
||||||
import com.uber.autodispose.AutoDisposePlugins;
|
import com.uber.autodispose.AutoDisposePlugins;
|
||||||
|
|
||||||
import org.conscrypt.Conscrypt;
|
import org.conscrypt.Conscrypt;
|
||||||
|
@ -91,6 +93,7 @@ public class TuskyApplication extends Application implements HasAndroidInjector
|
||||||
|
|
||||||
initAppInjector();
|
initAppInjector();
|
||||||
initEmojiCompat();
|
initEmojiCompat();
|
||||||
|
initNightMode();
|
||||||
|
|
||||||
JobManager.create(this).addJobCreator(notificationPullJobCreator);
|
JobManager.create(this).addJobCreator(notificationPullJobCreator);
|
||||||
|
|
||||||
|
@ -133,6 +136,12 @@ public class TuskyApplication extends Application implements HasAndroidInjector
|
||||||
AppInjector.INSTANCE.init(this);
|
AppInjector.INSTANCE.init(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void initNightMode() {
|
||||||
|
SharedPreferences preferences = PreferenceManager.getDefaultSharedPreferences(this);
|
||||||
|
String theme = preferences.getString("appTheme", ThemeUtils.APP_THEME_DEFAULT);
|
||||||
|
ThemeUtils.setAppNightMode(theme);
|
||||||
|
}
|
||||||
|
|
||||||
public ServiceLocator getServiceLocator() {
|
public ServiceLocator getServiceLocator() {
|
||||||
return serviceLocator;
|
return serviceLocator;
|
||||||
}
|
}
|
||||||
|
|
|
@ -324,7 +324,7 @@ public abstract class StatusBaseViewHolder extends RecyclerView.ViewHolder {
|
||||||
} else {
|
} else {
|
||||||
inactiveId = ThemeUtils.getDrawableId(reblogButton.getContext(),
|
inactiveId = ThemeUtils.getDrawableId(reblogButton.getContext(),
|
||||||
R.attr.status_reblog_inactive_drawable, R.drawable.reblog_inactive_dark);
|
R.attr.status_reblog_inactive_drawable, R.drawable.reblog_inactive_dark);
|
||||||
activeId = R.drawable.reblog_active;
|
activeId = R.drawable.ic_reblog_active_24dp;
|
||||||
}
|
}
|
||||||
reblogButton.setInactiveImage(inactiveId);
|
reblogButton.setInactiveImage(inactiveId);
|
||||||
reblogButton.setActiveImage(activeId);
|
reblogButton.setActiveImage(activeId);
|
||||||
|
|
|
@ -26,29 +26,21 @@ import androidx.annotation.DrawableRes;
|
||||||
import androidx.annotation.NonNull;
|
import androidx.annotation.NonNull;
|
||||||
import androidx.annotation.Nullable;
|
import androidx.annotation.Nullable;
|
||||||
import androidx.appcompat.app.AppCompatDelegate;
|
import androidx.appcompat.app.AppCompatDelegate;
|
||||||
import android.provider.Settings;
|
|
||||||
import android.util.TypedValue;
|
import android.util.TypedValue;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
|
||||||
import javax.inject.Singleton;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides runtime compatibility to obtain theme information and re-theme views, especially where
|
* Provides runtime compatibility to obtain theme information and re-theme views, especially where
|
||||||
* the ability to do so is not supported in resource files.
|
* the ability to do so is not supported in resource files.
|
||||||
*/
|
*/
|
||||||
@Singleton
|
|
||||||
public class ThemeUtils {
|
public class ThemeUtils {
|
||||||
|
|
||||||
@Inject
|
|
||||||
public ThemeUtils(){}
|
|
||||||
|
|
||||||
public static final String APP_THEME_DEFAULT = ThemeUtils.THEME_NIGHT;
|
public static final String APP_THEME_DEFAULT = ThemeUtils.THEME_NIGHT;
|
||||||
|
|
||||||
private static final String THEME_NIGHT = "night";
|
private static final String THEME_NIGHT = "night";
|
||||||
private static final String THEME_DAY = "day";
|
private static final String THEME_DAY = "day";
|
||||||
private static final String THEME_BLACK = "black";
|
private static final String THEME_BLACK = "black";
|
||||||
private static final String THEME_AUTO = "auto";
|
private static final String THEME_AUTO = "auto";
|
||||||
public static final String THEME_SYSTEM = "auto_system";
|
private static final String THEME_SYSTEM = "auto_system";
|
||||||
|
|
||||||
public static Drawable getDrawable(@NonNull Context context, @AttrRes int attribute,
|
public static Drawable getDrawable(@NonNull Context context, @AttrRes int attribute,
|
||||||
@DrawableRes int fallbackDrawable) {
|
@DrawableRes int fallbackDrawable) {
|
||||||
|
@ -62,7 +54,8 @@ public class ThemeUtils {
|
||||||
return context.getDrawable(resourceId);
|
return context.getDrawable(resourceId);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static @DrawableRes int getDrawableId(@NonNull Context context, @AttrRes int attribute,
|
@DrawableRes
|
||||||
|
public static int getDrawableId(@NonNull Context context, @AttrRes int attribute,
|
||||||
@DrawableRes int fallbackDrawableId) {
|
@DrawableRes int fallbackDrawableId) {
|
||||||
TypedValue value = new TypedValue();
|
TypedValue value = new TypedValue();
|
||||||
if (context.getTheme().resolveAttribute(attribute, value, true)) {
|
if (context.getTheme().resolveAttribute(attribute, value, true)) {
|
||||||
|
@ -72,7 +65,8 @@ public class ThemeUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static @ColorInt int getColor(@NonNull Context context, @AttrRes int attribute) {
|
@ColorInt
|
||||||
|
public static int getColor(@NonNull Context context, @AttrRes int attribute) {
|
||||||
TypedValue value = new TypedValue();
|
TypedValue value = new TypedValue();
|
||||||
if (context.getTheme().resolveAttribute(attribute, value, true)) {
|
if (context.getTheme().resolveAttribute(attribute, value, true)) {
|
||||||
return value.data;
|
return value.data;
|
||||||
|
@ -81,14 +75,16 @@ public class ThemeUtils {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static @ColorRes int getColorId(@NonNull Context context, @AttrRes int attribute) {
|
@ColorRes
|
||||||
|
public static int getColorId(@NonNull Context context, @AttrRes int attribute) {
|
||||||
TypedValue value = new TypedValue();
|
TypedValue value = new TypedValue();
|
||||||
context.getTheme().resolveAttribute(attribute, value, true);
|
context.getTheme().resolveAttribute(attribute, value, true);
|
||||||
return value.resourceId;
|
return value.resourceId;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** this can be replaced with drawableTint in xml once minSdkVersion >= 23 */
|
/** this can be replaced with drawableTint in xml once minSdkVersion >= 23 */
|
||||||
public static @Nullable Drawable getTintedDrawable(@NonNull Context context, @DrawableRes int drawableId, @AttrRes int colorAttr) {
|
@Nullable
|
||||||
|
public static Drawable getTintedDrawable(@NonNull Context context, @DrawableRes int drawableId, @AttrRes int colorAttr) {
|
||||||
Drawable drawable = context.getDrawable(drawableId);
|
Drawable drawable = context.getDrawable(drawableId);
|
||||||
if(drawable == null) {
|
if(drawable == null) {
|
||||||
return null;
|
return null;
|
||||||
|
@ -101,30 +97,21 @@ public class ThemeUtils {
|
||||||
drawable.setColorFilter(getColor(context, attribute), PorterDuff.Mode.SRC_IN);
|
drawable.setColorFilter(getColor(context, attribute), PorterDuff.Mode.SRC_IN);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setAppNightMode(String flavor, Context context) {
|
public static void setAppNightMode(String flavor) {
|
||||||
switch (flavor) {
|
switch (flavor) {
|
||||||
default:
|
default:
|
||||||
case THEME_NIGHT:
|
case THEME_NIGHT:
|
||||||
|
case THEME_BLACK:
|
||||||
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_YES);
|
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_YES);
|
||||||
break;
|
break;
|
||||||
case THEME_DAY:
|
case THEME_DAY:
|
||||||
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_NO);
|
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_NO);
|
||||||
break;
|
break;
|
||||||
case THEME_BLACK:
|
|
||||||
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_YES);
|
|
||||||
break;
|
|
||||||
case THEME_AUTO:
|
case THEME_AUTO:
|
||||||
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_AUTO);
|
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_AUTO_TIME);
|
||||||
break;
|
break;
|
||||||
case THEME_SYSTEM:
|
case THEME_SYSTEM:
|
||||||
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_FOLLOW_SYSTEM);
|
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_FOLLOW_SYSTEM);
|
||||||
|
|
||||||
//stupid workaround to make MODE_NIGHT_FOLLOW_SYSTEM work :(
|
|
||||||
if((Settings.System.getInt(context.getContentResolver(), "display_night_theme", 0) == 1)) {
|
|
||||||
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_YES);
|
|
||||||
} else if ((Settings.System.getInt(context.getContentResolver(), "display_night_theme", 0) == 0)) {
|
|
||||||
AppCompatDelegate.setDefaultNightMode(AppCompatDelegate.MODE_NIGHT_NO);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
9
app/src/main/res/drawable/ic_reblog_active_24dp.xml
Normal file
9
app/src/main/res/drawable/ic_reblog_active_24dp.xml
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:width="24dp"
|
||||||
|
android:height="24dp"
|
||||||
|
android:viewportWidth="24"
|
||||||
|
android:viewportHeight="24">
|
||||||
|
<path
|
||||||
|
android:fillColor="@color/tusky_blue"
|
||||||
|
android:pathData="M17,2L17,5L5,5L5,11L7,11L7,7L17,7L17,10L21,6L17,2zM9.75,9.75L9.75,14.25L14.25,14.25L14.25,9.75L9.75,9.75zM17,13L17,17L7,17L7,14L3,18L7,22L7,19L19,19L19,13L17,13z"/>
|
||||||
|
</vector>
|
|
@ -1,9 +0,0 @@
|
||||||
<vector xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:width="24dp"
|
|
||||||
android:height="24dp"
|
|
||||||
android:viewportWidth="24.0"
|
|
||||||
android:viewportHeight="24.0">
|
|
||||||
<path
|
|
||||||
android:fillColor="@color/tusky_blue"
|
|
||||||
android:pathData="M7,7h10v3l4,-4 -4,-4v3L5,5v6h2L7,7zM17,17L7,17v-3l-4,4 4,4v-3h12v-6h-2v4z"/>
|
|
||||||
</vector>
|
|
|
@ -435,7 +435,7 @@
|
||||||
app:layout_constraintEnd_toStartOf="@id/status_favourite"
|
app:layout_constraintEnd_toStartOf="@id/status_favourite"
|
||||||
app:layout_constraintStart_toEndOf="@id/status_reply"
|
app:layout_constraintStart_toEndOf="@id/status_reply"
|
||||||
app:layout_constraintTop_toTopOf="@id/status_reply"
|
app:layout_constraintTop_toTopOf="@id/status_reply"
|
||||||
sparkbutton:activeImage="@drawable/reblog_active"
|
sparkbutton:activeImage="@drawable/ic_reblog_active_24dp"
|
||||||
sparkbutton:iconSize="28dp"
|
sparkbutton:iconSize="28dp"
|
||||||
sparkbutton:inactiveImage="?attr/status_reblog_inactive_drawable"
|
sparkbutton:inactiveImage="?attr/status_reblog_inactive_drawable"
|
||||||
sparkbutton:primaryColor="@color/tusky_blue"
|
sparkbutton:primaryColor="@color/tusky_blue"
|
||||||
|
|
|
@ -525,7 +525,7 @@
|
||||||
app:layout_constraintEnd_toStartOf="@id/status_favourite"
|
app:layout_constraintEnd_toStartOf="@id/status_favourite"
|
||||||
app:layout_constraintStart_toEndOf="@id/status_reply"
|
app:layout_constraintStart_toEndOf="@id/status_reply"
|
||||||
app:layout_constraintTop_toTopOf="@id/status_reply"
|
app:layout_constraintTop_toTopOf="@id/status_reply"
|
||||||
sparkbutton:activeImage="@drawable/reblog_active"
|
sparkbutton:activeImage="@drawable/ic_reblog_active_24dp"
|
||||||
sparkbutton:iconSize="28dp"
|
sparkbutton:iconSize="28dp"
|
||||||
sparkbutton:inactiveImage="?attr/status_reblog_inactive_drawable"
|
sparkbutton:inactiveImage="?attr/status_reblog_inactive_drawable"
|
||||||
sparkbutton:primaryColor="@color/tusky_blue"
|
sparkbutton:primaryColor="@color/tusky_blue"
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
<item name="toolbar_background_color">@color/toolbar_background_dark</item>
|
<item name="toolbar_background_color">@color/toolbar_background_dark</item>
|
||||||
<item name="toolbar_icon_tint">@color/toolbar_icon_dark</item>
|
<item name="toolbar_icon_tint">@color/toolbar_icon_dark</item>
|
||||||
<item name="image_button_style">@style/TuskyImageButton.Dark</item>
|
<item name="image_button_style">@style/TuskyImageButton.Dark</item>
|
||||||
<item name="status_reblog_small_drawable">@drawable/ic_reblog_dark_18dp</item>
|
<item name="status_reblog_small_drawable">@drawable/ic_reblog_dark_24dp</item>
|
||||||
<item name="status_reblog_inactive_drawable">@drawable/reblog_inactive_dark</item>
|
<item name="status_reblog_inactive_drawable">@drawable/reblog_inactive_dark</item>
|
||||||
<item name="status_reblog_disabled_drawable">@drawable/reblog_private_dark</item>
|
<item name="status_reblog_disabled_drawable">@drawable/reblog_private_dark</item>
|
||||||
<item name="status_reblog_direct_drawable">@drawable/reblog_direct_dark</item>
|
<item name="status_reblog_direct_drawable">@drawable/reblog_direct_dark</item>
|
||||||
|
|
|
@ -80,7 +80,7 @@
|
||||||
<item name="toolbar_background_color">@color/toolbar_background_light</item>
|
<item name="toolbar_background_color">@color/toolbar_background_light</item>
|
||||||
<item name="toolbar_icon_tint">@color/toolbar_icon_light</item>
|
<item name="toolbar_icon_tint">@color/toolbar_icon_light</item>
|
||||||
<item name="image_button_style">@style/TuskyImageButton.Light</item>
|
<item name="image_button_style">@style/TuskyImageButton.Light</item>
|
||||||
<item name="status_reblog_small_drawable">@drawable/ic_reblog_light_18dp</item>
|
<item name="status_reblog_small_drawable">@drawable/ic_reblog_light_24dp</item>
|
||||||
<item name="status_reblog_inactive_drawable">@drawable/reblog_inactive_light</item>
|
<item name="status_reblog_inactive_drawable">@drawable/reblog_inactive_light</item>
|
||||||
<item name="status_reblog_disabled_drawable">@drawable/reblog_private_light</item>
|
<item name="status_reblog_disabled_drawable">@drawable/reblog_private_light</item>
|
||||||
<item name="status_reblog_direct_drawable">@drawable/reblog_direct_light</item>
|
<item name="status_reblog_direct_drawable">@drawable/reblog_direct_light</item>
|
||||||
|
|
|
@ -26,14 +26,12 @@ import com.keylesspalace.tusky.entity.Account
|
||||||
import com.keylesspalace.tusky.entity.Emoji
|
import com.keylesspalace.tusky.entity.Emoji
|
||||||
import com.keylesspalace.tusky.entity.Instance
|
import com.keylesspalace.tusky.entity.Instance
|
||||||
import com.keylesspalace.tusky.network.MastodonApi
|
import com.keylesspalace.tusky.network.MastodonApi
|
||||||
import com.keylesspalace.tusky.util.ThemeUtils
|
|
||||||
import okhttp3.Request
|
import okhttp3.Request
|
||||||
import org.junit.Assert
|
import org.junit.Assert
|
||||||
import org.junit.Assert.*
|
import org.junit.Assert.*
|
||||||
import org.junit.Before
|
import org.junit.Before
|
||||||
import org.junit.Test
|
import org.junit.Test
|
||||||
import org.junit.runner.RunWith
|
import org.junit.runner.RunWith
|
||||||
import org.mockito.Mockito
|
|
||||||
import org.mockito.Mockito.`when`
|
import org.mockito.Mockito.`when`
|
||||||
import org.mockito.Mockito.mock
|
import org.mockito.Mockito.mock
|
||||||
import org.robolectric.Robolectric
|
import org.robolectric.Robolectric
|
||||||
|
@ -58,7 +56,6 @@ class ComposeActivityTest {
|
||||||
private lateinit var activity: ComposeActivity
|
private lateinit var activity: ComposeActivity
|
||||||
private lateinit var accountManagerMock: AccountManager
|
private lateinit var accountManagerMock: AccountManager
|
||||||
private lateinit var apiMock: MastodonApi
|
private lateinit var apiMock: MastodonApi
|
||||||
private lateinit var themeUtilsMock: ThemeUtils
|
|
||||||
|
|
||||||
private val account = AccountEntity(
|
private val account = AccountEntity(
|
||||||
id = 1,
|
id = 1,
|
||||||
|
@ -85,9 +82,9 @@ class ComposeActivityTest {
|
||||||
val controller = Robolectric.buildActivity(ComposeActivity::class.java)
|
val controller = Robolectric.buildActivity(ComposeActivity::class.java)
|
||||||
activity = controller.get()
|
activity = controller.get()
|
||||||
|
|
||||||
accountManagerMock = Mockito.mock(AccountManager::class.java)
|
accountManagerMock = mock(AccountManager::class.java)
|
||||||
|
|
||||||
apiMock = Mockito.mock(MastodonApi::class.java)
|
apiMock = mock(MastodonApi::class.java)
|
||||||
`when`(apiMock.getCustomEmojis()).thenReturn(object: Call<List<Emoji>> {
|
`when`(apiMock.getCustomEmojis()).thenReturn(object: Call<List<Emoji>> {
|
||||||
override fun isExecuted(): Boolean {
|
override fun isExecuted(): Boolean {
|
||||||
return false
|
return false
|
||||||
|
@ -125,12 +122,9 @@ class ComposeActivityTest {
|
||||||
val dbMock = mock(AppDatabase::class.java)
|
val dbMock = mock(AppDatabase::class.java)
|
||||||
`when`(dbMock.instanceDao()).thenReturn(instanceDaoMock)
|
`when`(dbMock.instanceDao()).thenReturn(instanceDaoMock)
|
||||||
|
|
||||||
themeUtilsMock = Mockito.mock(ThemeUtils::class.java)
|
|
||||||
|
|
||||||
activity.mastodonApi = apiMock
|
activity.mastodonApi = apiMock
|
||||||
activity.accountManager = accountManagerMock
|
activity.accountManager = accountManagerMock
|
||||||
activity.database = dbMock
|
activity.database = dbMock
|
||||||
activity.themeUtils = themeUtilsMock
|
|
||||||
|
|
||||||
`when`(accountManagerMock.activeAccount).thenReturn(account)
|
`when`(accountManagerMock.activeAccount).thenReturn(account)
|
||||||
|
|
||||||
|
@ -185,7 +179,7 @@ class ComposeActivityTest {
|
||||||
fun whenTextContainsNoUrl_everyCharacterIsCounted() {
|
fun whenTextContainsNoUrl_everyCharacterIsCounted() {
|
||||||
val content = "This is test content please ignore thx "
|
val content = "This is test content please ignore thx "
|
||||||
insertSomeTextInContent(content)
|
insertSomeTextInContent(content)
|
||||||
Assert.assertEquals(activity.calculateTextLength(), content.length)
|
assertEquals(activity.calculateTextLength(), content.length)
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -193,7 +187,7 @@ class ComposeActivityTest {
|
||||||
val url = "https://www.google.dk/search?biw=1920&bih=990&tbm=isch&sa=1&ei=bmDrWuOoKMv6kwWOkIaoDQ&q=indiana+jones+i+hate+snakes+animated&oq=indiana+jones+i+hate+snakes+animated&gs_l=psy-ab.3...54174.55443.0.55553.9.7.0.0.0.0.255.333.1j0j1.2.0....0...1c.1.64.psy-ab..7.0.0....0.40G-kcDkC6A#imgdii=PSp15hQjN1JqvM:&imgrc=H0hyE2JW5wrpBM:"
|
val url = "https://www.google.dk/search?biw=1920&bih=990&tbm=isch&sa=1&ei=bmDrWuOoKMv6kwWOkIaoDQ&q=indiana+jones+i+hate+snakes+animated&oq=indiana+jones+i+hate+snakes+animated&gs_l=psy-ab.3...54174.55443.0.55553.9.7.0.0.0.0.255.333.1j0j1.2.0....0...1c.1.64.psy-ab..7.0.0....0.40G-kcDkC6A#imgdii=PSp15hQjN1JqvM:&imgrc=H0hyE2JW5wrpBM:"
|
||||||
val additionalContent = "Check out this @image #search result: "
|
val additionalContent = "Check out this @image #search result: "
|
||||||
insertSomeTextInContent(additionalContent + url)
|
insertSomeTextInContent(additionalContent + url)
|
||||||
Assert.assertEquals(activity.calculateTextLength(), additionalContent.length + ComposeActivity.MAXIMUM_URL_LENGTH)
|
assertEquals(activity.calculateTextLength(), additionalContent.length + ComposeActivity.MAXIMUM_URL_LENGTH)
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
|
|
@ -16,6 +16,10 @@ class FakeTuskyApplication : TuskyApplication() {
|
||||||
// No-op
|
// No-op
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun initNightMode() {
|
||||||
|
// No-op
|
||||||
|
}
|
||||||
|
|
||||||
override fun getServiceLocator(): ServiceLocator {
|
override fun getServiceLocator(): ServiceLocator {
|
||||||
return locator
|
return locator
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,7 +37,6 @@ class FilterTest {
|
||||||
val activity = controller.get()
|
val activity = controller.get()
|
||||||
|
|
||||||
activity.accountManager = mock()
|
activity.accountManager = mock()
|
||||||
activity.themeUtils = mock()
|
|
||||||
val apiMock = Mockito.mock(MastodonApi::class.java)
|
val apiMock = Mockito.mock(MastodonApi::class.java)
|
||||||
Mockito.`when`(apiMock.getFilters()).thenReturn(object: Call<List<Filter>> {
|
Mockito.`when`(apiMock.getFilters()).thenReturn(object: Call<List<Filter>> {
|
||||||
override fun isExecuted(): Boolean {
|
override fun isExecuted(): Boolean {
|
||||||
|
|
|
@ -7,8 +7,8 @@ buildscript {
|
||||||
google()
|
google()
|
||||||
}
|
}
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath 'com.android.tools.build.jetifier:jetifier-processor:1.0.0-beta06'
|
classpath 'com.android.tools.build.jetifier:jetifier-processor:1.0.0-beta07'
|
||||||
classpath 'com.android.tools.build:gradle:3.5.0'
|
classpath 'com.android.tools.build:gradle:3.5.1'
|
||||||
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue