Fix navigation bar color on dialog
This commit is contained in:
parent
183c6810fe
commit
ce918acb45
23 changed files with 411 additions and 387 deletions
|
@ -4,16 +4,16 @@ apply plugin: 'kotlin-android-extensions'
|
||||||
apply plugin: 'kotlin-kapt'
|
apply plugin: 'kotlin-kapt'
|
||||||
|
|
||||||
android {
|
android {
|
||||||
compileSdkVersion 28
|
compileSdkVersion 29
|
||||||
defaultConfig {
|
defaultConfig {
|
||||||
minSdkVersion 21
|
minSdkVersion 21
|
||||||
targetSdkVersion 28
|
targetSdkVersion 29
|
||||||
|
|
||||||
renderscriptTargetApi 28 //must match target sdk and build tools
|
renderscriptTargetApi 28 //must match target sdk and build tools
|
||||||
vectorDrawables.useSupportLibrary = true
|
vectorDrawables.useSupportLibrary = true
|
||||||
|
|
||||||
applicationId "code.name.monkey.retromusic"
|
applicationId "code.name.monkey.retromusic"
|
||||||
versionCode 392
|
versionCode 393
|
||||||
versionName '3.4.800'
|
versionName '3.4.800'
|
||||||
|
|
||||||
multiDexEnabled true
|
multiDexEnabled true
|
||||||
|
|
File diff suppressed because one or more lines are too long
|
@ -1,7 +1,6 @@
|
||||||
package code.name.monkey.retromusic.activities
|
package code.name.monkey.retromusic.activities
|
||||||
|
|
||||||
import android.app.Activity
|
import android.app.Activity
|
||||||
import android.content.ContentUris
|
|
||||||
import android.content.Context
|
import android.content.Context
|
||||||
import android.content.ContextWrapper
|
import android.content.ContextWrapper
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
|
@ -9,7 +8,6 @@ import android.content.res.ColorStateList
|
||||||
import android.graphics.Bitmap
|
import android.graphics.Bitmap
|
||||||
import android.net.Uri
|
import android.net.Uri
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.provider.DocumentsContract
|
|
||||||
import android.provider.MediaStore.Images.Media
|
import android.provider.MediaStore.Images.Media
|
||||||
import android.provider.MediaStore.Images.Media.getBitmap
|
import android.provider.MediaStore.Images.Media.getBitmap
|
||||||
import android.text.TextUtils
|
import android.text.TextUtils
|
||||||
|
@ -123,10 +121,7 @@ class UserInfoActivity : AbsBaseActivity() {
|
||||||
pickImageIntent.putExtra("aspectY", 9)
|
pickImageIntent.putExtra("aspectY", 9)
|
||||||
pickImageIntent.putExtra("scale", true)
|
pickImageIntent.putExtra("scale", true)
|
||||||
//intent.setAction(Intent.ACTION_GET_CONTENT);
|
//intent.setAction(Intent.ACTION_GET_CONTENT);
|
||||||
startActivityForResult(
|
startActivityForResult(Intent.createChooser(pickImageIntent, "Select Picture"), PICK_BANNER_REQUEST)
|
||||||
Intent.createChooser(pickImageIntent, "Select Picture"),
|
|
||||||
PICK_BANNER_REQUEST
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun pickNewPhoto() {
|
private fun pickNewPhoto() {
|
||||||
|
@ -138,10 +133,7 @@ class UserInfoActivity : AbsBaseActivity() {
|
||||||
pickImageIntent.putExtra("aspectX", 1)
|
pickImageIntent.putExtra("aspectX", 1)
|
||||||
pickImageIntent.putExtra("aspectY", 1)
|
pickImageIntent.putExtra("aspectY", 1)
|
||||||
pickImageIntent.putExtra("scale", true)
|
pickImageIntent.putExtra("scale", true)
|
||||||
startActivityForResult(
|
startActivityForResult(Intent.createChooser(pickImageIntent, "Select Picture"), PICK_IMAGE_REQUEST)
|
||||||
Intent.createChooser(pickImageIntent, "Select Picture"),
|
|
||||||
PICK_IMAGE_REQUEST
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
|
public override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
|
||||||
|
@ -180,32 +172,6 @@ class UserInfoActivity : AbsBaseActivity() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getImagePathFromUri(aUri: Uri?): String? {
|
|
||||||
var imagePath: String? = null
|
|
||||||
if (aUri == null) {
|
|
||||||
return imagePath
|
|
||||||
}
|
|
||||||
if (DocumentsContract.isDocumentUri(App.getContext(), aUri)) {
|
|
||||||
val documentId = DocumentsContract.getDocumentId(aUri)
|
|
||||||
if ("com.android.providers.media.documents" == aUri.authority) {
|
|
||||||
val id = documentId.split(":".toRegex()).dropLastWhile { it.isEmpty() }.toTypedArray()[1]
|
|
||||||
val selection = Media._ID + "=" + id
|
|
||||||
imagePath = getImagePath(Media.EXTERNAL_CONTENT_URI, selection)
|
|
||||||
} else if ("com.android.providers.downloads.documents" == aUri.authority) {
|
|
||||||
val contentUri = ContentUris.withAppendedId(
|
|
||||||
Uri.parse("content://downloads/public_downloads"),
|
|
||||||
java.lang.Long.valueOf(documentId)
|
|
||||||
)
|
|
||||||
imagePath = getImagePath(contentUri, null)
|
|
||||||
}
|
|
||||||
} else if ("content".equals(aUri.scheme!!, ignoreCase = true)) {
|
|
||||||
imagePath = getImagePath(aUri, null)
|
|
||||||
} else if ("file".equals(aUri.scheme!!, ignoreCase = true)) {
|
|
||||||
imagePath = aUri.path
|
|
||||||
}
|
|
||||||
return imagePath
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun getImagePath(aUri: Uri, aSelection: String?): String? {
|
private fun getImagePath(aUri: Uri, aSelection: String?): String? {
|
||||||
var path: String? = null
|
var path: String? = null
|
||||||
val cursor = App.getContext().contentResolver.query(aUri, null, aSelection, null, null)
|
val cursor = App.getContext().contentResolver.query(aUri, null, aSelection, null, null)
|
||||||
|
@ -219,27 +185,25 @@ class UserInfoActivity : AbsBaseActivity() {
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun loadBannerFromStorage(profileImagePath: String) {
|
private fun loadBannerFromStorage(profileImagePath: String) {
|
||||||
disposable.add(
|
disposable.add(Compressor(this).setQuality(100)
|
||||||
Compressor(this).setQuality(100).setCompressFormat(Bitmap.CompressFormat.WEBP).compressToBitmapAsFlowable(
|
.setCompressFormat(Bitmap.CompressFormat.WEBP)
|
||||||
File(profileImagePath, USER_BANNER)
|
.compressToBitmapAsFlowable(File(profileImagePath, USER_BANNER))
|
||||||
).subscribeOn(Schedulers.io()).observeOn(AndroidSchedulers.mainThread()).subscribe(
|
.subscribeOn(Schedulers.io())
|
||||||
{ bitmap -> bannerImage.setImageBitmap(bitmap) },
|
.observeOn(AndroidSchedulers.mainThread())
|
||||||
{ t -> println() })
|
.subscribe({ bitmap -> bannerImage.setImageBitmap(bitmap) }, { t -> println(t) })
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun loadImageFromStorage(path: String) {
|
private fun loadImageFromStorage(path: String) {
|
||||||
disposable.add(
|
disposable.add(Compressor(this)
|
||||||
Compressor(this).setMaxHeight(300).setMaxWidth(300).setQuality(75).setCompressFormat(
|
.setMaxHeight(300)
|
||||||
Bitmap.CompressFormat.WEBP
|
.setMaxWidth(300)
|
||||||
).compressToBitmapAsFlowable(
|
.setQuality(75)
|
||||||
File(
|
.setCompressFormat(Bitmap.CompressFormat.WEBP)
|
||||||
path,
|
.compressToBitmapAsFlowable(File(path, USER_PROFILE))
|
||||||
USER_PROFILE
|
.subscribeOn(Schedulers.io())
|
||||||
)
|
.observeOn(AndroidSchedulers.mainThread())
|
||||||
).subscribeOn(Schedulers.io()).observeOn(AndroidSchedulers.mainThread()).subscribe(
|
.subscribe({ bitmap -> userImage.setImageBitmap(bitmap) }, { t -> println(t) })
|
||||||
{ bitmap -> userImage!!.setImageBitmap(bitmap) },
|
|
||||||
{ t -> println() })
|
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -155,7 +155,7 @@ open class BugReportActivity : AbsThemeActivity() {
|
||||||
private fun copyDeviceInfoToClipBoard() {
|
private fun copyDeviceInfoToClipBoard() {
|
||||||
val clipboard = getSystemService(Context.CLIPBOARD_SERVICE) as ClipboardManager
|
val clipboard = getSystemService(Context.CLIPBOARD_SERVICE) as ClipboardManager
|
||||||
val clip = ClipData.newPlainText(getString(R.string.device_info), deviceInfo?.toMarkdown())
|
val clip = ClipData.newPlainText(getString(R.string.device_info), deviceInfo?.toMarkdown())
|
||||||
clipboard.primaryClip = clip
|
clipboard.setPrimaryClip(clip)
|
||||||
Toast.makeText(
|
Toast.makeText(
|
||||||
this@BugReportActivity,
|
this@BugReportActivity,
|
||||||
R.string.copied_device_info_to_clipboard,
|
R.string.copied_device_info_to_clipboard,
|
||||||
|
|
|
@ -86,7 +86,6 @@ class OptionsSheetDialogFragment : DialogFragment(), View.OnClickListener {
|
||||||
}
|
}
|
||||||
|
|
||||||
return super.onCreateView(inflater, container, savedInstanceState)
|
return super.onCreateView(inflater, container, savedInstanceState)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
companion object {
|
companion object {
|
||||||
|
|
|
@ -3,6 +3,7 @@ package code.name.monkey.retromusic.fragments.mainactivity.folders;
|
||||||
import android.app.ActivityOptions;
|
import android.app.ActivityOptions;
|
||||||
import android.app.Dialog;
|
import android.app.Dialog;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
|
import android.content.res.ColorStateList;
|
||||||
import android.media.MediaScannerConnection;
|
import android.media.MediaScannerConnection;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Environment;
|
import android.os.Environment;
|
||||||
|
@ -231,15 +232,14 @@ public class FoldersFragment extends AbsMainActivityFragment implements
|
||||||
private void setUpAppbarColor() {
|
private void setUpAppbarColor() {
|
||||||
int primaryColor = ATHUtil.INSTANCE.resolveColor(requireContext(), R.attr.colorSurface);
|
int primaryColor = ATHUtil.INSTANCE.resolveColor(requireContext(), R.attr.colorSurface);
|
||||||
getMainActivity().setSupportActionBar(toolbar);
|
getMainActivity().setSupportActionBar(toolbar);
|
||||||
toolbar.setBackgroundColor(RetroColorUtil.toolbarColor(getMainActivity()));
|
toolbar.setBackgroundTintList(ColorStateList.valueOf(ATHUtil.INSTANCE.resolveColor(requireContext(), R.attr.colorSurface)));
|
||||||
toolbar.setNavigationIcon(R.drawable.ic_menu_white_24dp);
|
toolbar.setNavigationIcon(R.drawable.ic_menu_white_24dp);
|
||||||
toolbar.setNavigationOnClickListener(v -> {
|
toolbar.setNavigationOnClickListener(v -> {
|
||||||
showMainMenu(OptionsSheetDialogFragment.FOLDER);
|
showMainMenu(OptionsSheetDialogFragment.FOLDER);
|
||||||
});
|
});
|
||||||
breadCrumbs.setActivatedContentColor(ToolbarContentTintHelper.toolbarTitleColor(requireActivity(), ColorUtil.INSTANCE.darkenColor(primaryColor)));
|
breadCrumbs.setActivatedContentColor(ToolbarContentTintHelper.toolbarTitleColor(requireActivity(), ColorUtil.INSTANCE.darkenColor(primaryColor)));
|
||||||
breadCrumbs.setDeactivatedContentColor(ToolbarContentTintHelper.toolbarSubtitleColor(requireActivity(),
|
breadCrumbs.setDeactivatedContentColor(ToolbarContentTintHelper.toolbarSubtitleColor(requireActivity(), ColorUtil.INSTANCE.darkenColor(primaryColor)));
|
||||||
ColorUtil.INSTANCE.darkenColor(primaryColor)));
|
appBarLayout.addOnOffsetChangedListener((appBarLayout, verticalOffset) -> getMainActivity().setLightStatusbar(!ATHUtil.INSTANCE.isWindowBackgroundDark(requireContext())));
|
||||||
appBarLayout.addOnOffsetChangedListener((appBarLayout, verticalOffset) -> getMainActivity().setLightStatusbar(!ATHUtil.INSTANCE.isWindowBackgroundDark(getContext())));
|
|
||||||
toolbar.setOnClickListener(v -> {
|
toolbar.setOnClickListener(v -> {
|
||||||
ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(getMainActivity(), toolbarContainer, getString(R.string.transition_toolbar));
|
ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(getMainActivity(), toolbarContainer, getString(R.string.transition_toolbar));
|
||||||
NavigationUtil.goToSearch(getMainActivity(), options);
|
NavigationUtil.goToSearch(getMainActivity(), options);
|
||||||
|
|
|
@ -48,16 +48,8 @@ class PlayingNotificationImpl24 : PlayingNotification() {
|
||||||
val song = service.currentSong
|
val song = service.currentSong
|
||||||
val isPlaying = service.isPlaying
|
val isPlaying = service.isPlaying
|
||||||
val isFavorite = MusicUtil.isFavorite(service, song)
|
val isFavorite = MusicUtil.isFavorite(service, song)
|
||||||
val playButtonResId = if (isPlaying)
|
val playButtonResId = if (isPlaying) R.drawable.ic_pause_white_48dp else R.drawable.ic_play_arrow_white_48dp
|
||||||
R.drawable.ic_pause_white_48dp
|
val favoriteResId = if (isFavorite) R.drawable.ic_favorite_white_24dp else R.drawable.ic_favorite_border_white_24dp
|
||||||
else
|
|
||||||
R.drawable.ic_play_arrow_white_48dp
|
|
||||||
|
|
||||||
val favoriteResId = if (isFavorite)
|
|
||||||
R.drawable.ic_favorite_white_24dp
|
|
||||||
else
|
|
||||||
R.drawable.ic_favorite_border_white_24dp
|
|
||||||
|
|
||||||
|
|
||||||
val action = Intent(service, MainActivity::class.java)
|
val action = Intent(service, MainActivity::class.java)
|
||||||
action.putExtra("expand", true)
|
action.putExtra("expand", true)
|
||||||
|
@ -99,30 +91,10 @@ class PlayingNotificationImpl24 : PlayingNotification() {
|
||||||
bitmapFinal = BitmapFactory.decodeResource(service.resources, R.drawable.default_album_art)
|
bitmapFinal = BitmapFactory.decodeResource(service.resources, R.drawable.default_album_art)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
val toggleFavorite = NotificationCompat.Action(favoriteResId, service.getString(R.string.action_toggle_favorite), retrievePlaybackAction(TOGGLE_FAVORITE))
|
||||||
val toggleFavorite = NotificationCompat.Action(favoriteResId,
|
val playPauseAction = NotificationCompat.Action(playButtonResId, service.getString(R.string.action_play_pause), retrievePlaybackAction(ACTION_TOGGLE_PAUSE))
|
||||||
service.getString(R.string.action_toggle_favorite),
|
val previousAction = NotificationCompat.Action(R.drawable.ic_skip_previous_round_white_32dp, service.getString(R.string.action_previous), retrievePlaybackAction(ACTION_REWIND))
|
||||||
retrievePlaybackAction(TOGGLE_FAVORITE))
|
val nextAction = NotificationCompat.Action(R.drawable.ic_skip_next_round_white_32dp, service.getString(R.string.action_next), retrievePlaybackAction(ACTION_SKIP))
|
||||||
|
|
||||||
val playPauseAction = NotificationCompat.Action(
|
|
||||||
playButtonResId,
|
|
||||||
service.getString(R.string.action_play_pause),
|
|
||||||
retrievePlaybackAction(ACTION_TOGGLE_PAUSE))
|
|
||||||
|
|
||||||
val closeAction = NotificationCompat.Action(
|
|
||||||
R.drawable.ic_close_white_24dp,
|
|
||||||
service.getString(R.string.close_notification),
|
|
||||||
retrievePlaybackAction(ACTION_QUIT))
|
|
||||||
|
|
||||||
val previousAction = NotificationCompat.Action(
|
|
||||||
R.drawable.ic_skip_previous_round_white_32dp,
|
|
||||||
service.getString(R.string.action_previous),
|
|
||||||
retrievePlaybackAction(ACTION_REWIND))
|
|
||||||
|
|
||||||
val nextAction = NotificationCompat.Action(
|
|
||||||
R.drawable.ic_skip_next_round_white_32dp,
|
|
||||||
service.getString(R.string.action_next),
|
|
||||||
retrievePlaybackAction(ACTION_SKIP))
|
|
||||||
|
|
||||||
val builder = NotificationCompat.Builder(service,
|
val builder = NotificationCompat.Builder(service,
|
||||||
NOTIFICATION_CHANNEL_ID)
|
NOTIFICATION_CHANNEL_ID)
|
||||||
|
@ -139,7 +111,6 @@ class PlayingNotificationImpl24 : PlayingNotification() {
|
||||||
.addAction(previousAction)
|
.addAction(previousAction)
|
||||||
.addAction(playPauseAction)
|
.addAction(playPauseAction)
|
||||||
.addAction(nextAction)
|
.addAction(nextAction)
|
||||||
.addAction(closeAction)
|
|
||||||
|
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
|
||||||
builder.setStyle(MediaStyle()
|
builder.setStyle(MediaStyle()
|
||||||
|
|
|
@ -114,7 +114,7 @@ class PlayingNotificationOreo : PlayingNotification() {
|
||||||
|
|
||||||
override fun onLoadFailed(e: Exception?, errorDrawable: Drawable?) {
|
override fun onLoadFailed(e: Exception?, errorDrawable: Drawable?) {
|
||||||
super.onLoadFailed(e, errorDrawable)
|
super.onLoadFailed(e, errorDrawable)
|
||||||
update(null, ATHUtil.resolveColor(service, R.attr.colorPrimary, Color.WHITE))
|
update(null, ATHUtil.resolveColor(service, R.attr.colorSurface, Color.WHITE))
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun update(bitmap: Bitmap?, bgColor: Int) {
|
private fun update(bitmap: Bitmap?, bgColor: Int) {
|
||||||
|
|
|
@ -657,9 +657,7 @@ public final class PreferenceUtil {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void saveProfileImage(String profileImagePath) {
|
public void saveProfileImage(String profileImagePath) {
|
||||||
mPreferences.edit().putString(PROFILE_IMAGE_PATH, profileImagePath)
|
mPreferences.edit().putString(PROFILE_IMAGE_PATH, profileImagePath).apply();
|
||||||
.apply();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getProfileImage() {
|
public String getProfileImage() {
|
||||||
|
|
|
@ -54,9 +54,6 @@ public class OptionMenuItemView extends FrameLayout {
|
||||||
public OptionMenuItemView(@NonNull Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
|
public OptionMenuItemView(@NonNull Context context, @Nullable AttributeSet attrs, int defStyleAttr, int defStyleRes) {
|
||||||
super(context, attrs, defStyleAttr, defStyleRes);
|
super(context, attrs, defStyleAttr, defStyleRes);
|
||||||
|
|
||||||
int accentColor = ThemeStore.Companion.accentColor(context);
|
|
||||||
int colorWithAlpha = ColorUtil.INSTANCE.adjustAlpha(accentColor, 0.22f);
|
|
||||||
|
|
||||||
setBackground(ContextCompat.getDrawable(context, R.drawable.option_menu_background));
|
setBackground(ContextCompat.getDrawable(context, R.drawable.option_menu_background));
|
||||||
|
|
||||||
setClickable(true);
|
setClickable(true);
|
||||||
|
|
|
@ -29,7 +29,6 @@
|
||||||
android:ellipsize="end"
|
android:ellipsize="end"
|
||||||
android:maxLines="1"
|
android:maxLines="1"
|
||||||
android:paddingStart="12dp"
|
android:paddingStart="12dp"
|
||||||
android:paddingTop="6dp"
|
|
||||||
android:paddingEnd="8dp"
|
android:paddingEnd="8dp"
|
||||||
android:paddingBottom="4dp"
|
android:paddingBottom="4dp"
|
||||||
android:textAppearance="@style/TextViewNormal"
|
android:textAppearance="@style/TextViewNormal"
|
||||||
|
|
|
@ -17,11 +17,12 @@
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:background="?attr/rectSelector"
|
android:background="?selectableItemBackground"
|
||||||
android:gravity="center_vertical"
|
android:gravity="center_vertical"
|
||||||
android:minHeight="72dp"
|
android:minHeight="64dp"
|
||||||
android:orientation="horizontal"
|
android:orientation="horizontal"
|
||||||
android:padding="12dp"
|
android:paddingStart="12dp"
|
||||||
|
android:paddingEnd="12dp"
|
||||||
tools:ignore="PrivateResource">
|
tools:ignore="PrivateResource">
|
||||||
|
|
||||||
<code.name.monkey.retromusic.views.CircularImageView
|
<code.name.monkey.retromusic.views.CircularImageView
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:background="?attr/rectSelector"
|
android:background="?selectableItemBackground"
|
||||||
android:gravity="center_horizontal"
|
android:gravity="center_horizontal"
|
||||||
android:minHeight="@dimen/md_listitem_height"
|
android:minHeight="@dimen/md_listitem_height"
|
||||||
android:orientation="vertical"
|
android:orientation="vertical"
|
||||||
|
|
|
@ -48,16 +48,18 @@
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
android:textAppearance="@style/TextViewSubtitle1"
|
android:textAppearance="@style/TextViewSubtitle1"
|
||||||
|
android:textColor="?android:attr/textColorPrimary"
|
||||||
android:textStyle="bold"
|
android:textStyle="bold"
|
||||||
tools:text="@string/bug_report_summary" />
|
tools:text="@tools:sample/lorem" />
|
||||||
|
|
||||||
<com.google.android.material.textview.MaterialTextView
|
<com.google.android.material.textview.MaterialTextView
|
||||||
android:id="@+id/text"
|
android:id="@+id/text"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:paddingTop="4dp"
|
android:paddingTop="2dp"
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
tools:text="@string/bug_report_summary" />
|
android:textColor="?android:attr/textColorSecondary"
|
||||||
|
tools:text="@tools:sample/lorem" />
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
</FrameLayout>
|
</FrameLayout>
|
||||||
|
|
|
@ -4,7 +4,10 @@
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_margin="4dp"
|
android:layout_marginStart="4dp"
|
||||||
|
android:layout_marginTop="2dp"
|
||||||
|
android:layout_marginEnd="4dp"
|
||||||
|
android:layout_marginBottom="2dp"
|
||||||
android:clickable="true"
|
android:clickable="true"
|
||||||
android:focusable="true"
|
android:focusable="true"
|
||||||
android:foreground="?rectSelector"
|
android:foreground="?rectSelector"
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_weight="0"
|
android:layout_weight="0"
|
||||||
android:padding="14dp"
|
android:padding="12dp"
|
||||||
app:tint="?attr/colorControlNormal"
|
app:tint="?attr/colorControlNormal"
|
||||||
tools:srcCompat="@drawable/ic_folder_white_24dp" />
|
tools:srcCompat="@drawable/ic_folder_white_24dp" />
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
android:id="@+id/largeIcon"
|
android:id="@+id/largeIcon"
|
||||||
android:layout_width="@dimen/notification_big_image_size"
|
android:layout_width="@dimen/notification_big_image_size"
|
||||||
android:layout_height="@dimen/notification_big_image_size"
|
android:layout_height="@dimen/notification_big_image_size"
|
||||||
|
android:forceDarkAllowed="false"
|
||||||
android:layout_alignParentEnd="true"
|
android:layout_alignParentEnd="true"
|
||||||
android:scaleType="centerCrop"
|
android:scaleType="centerCrop"
|
||||||
tools:src="@tools:sample/avatars" />
|
tools:src="@tools:sample/avatars" />
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
xmlns:tools="http://schemas.android.com/tools"
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:background="?attr/rectSelector"
|
android:background="?selectableItemBackground"
|
||||||
android:minHeight="72dp"
|
android:minHeight="72dp"
|
||||||
android:orientation="horizontal"
|
android:orientation="horizontal"
|
||||||
android:padding="16dp"
|
android:padding="16dp"
|
||||||
|
|
37
app/src/main/res/values-night-v27/styles.xml
Normal file
37
app/src/main/res/values-night-v27/styles.xml
Normal file
|
@ -0,0 +1,37 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright (c) 2019 Hemanth Savarala.
|
||||||
|
~
|
||||||
|
~ Licensed under the GNU General Public License v3
|
||||||
|
~
|
||||||
|
~ This is free software: you can redistribute it and/or modify it under
|
||||||
|
~ the terms of the GNU General Public License as published by
|
||||||
|
~ the Free Software Foundation either version 3 of the License, or (at your option) any later version.
|
||||||
|
~
|
||||||
|
~ This software is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
||||||
|
~ without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
|
~ See the GNU General Public License for more details.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<resources>
|
||||||
|
|
||||||
|
<style name="Theme.RetroMusic.Base.Adaptive" parent="Theme.MaterialComponents.DayNight.NoActionBar">
|
||||||
|
<item name="md_font_title">@font/circular</item>
|
||||||
|
<item name="md_font_body">@font/circular</item>
|
||||||
|
<item name="md_font_button">@font/circular</item>
|
||||||
|
<item name="md_background_color">?attr/colorSurface</item>
|
||||||
|
<item name="android:windowActionBarOverlay">true</item>
|
||||||
|
<item name="android:windowActivityTransitions">true</item>
|
||||||
|
<item name="android:fontFamily">@font/circular</item>
|
||||||
|
<item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Dark</item>
|
||||||
|
<item name="mcab_popup_theme">@style/ThemeOverlay.AppCompat.Dark</item>
|
||||||
|
<item name="windowActionBarOverlay">true</item>
|
||||||
|
<item name="preferenceTheme">@style/PreferenceThemeOverlay.v14.Material</item>
|
||||||
|
<item name="materialAlertDialogTheme">@style/MaterialAlertDialogTheme</item>
|
||||||
|
<item name="materialButtonStyle">@style/MaterialButtonTheme</item>
|
||||||
|
<item name="roundSelector">@drawable/round_selector</item>
|
||||||
|
<item name="rectSelector">@drawable/rect_selector</item>
|
||||||
|
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
||||||
|
<item name="android:windowLightNavigationBar">false</item>
|
||||||
|
</style>
|
||||||
|
</resources>
|
|
@ -31,5 +31,6 @@
|
||||||
<item name="roundSelector">@drawable/round_selector</item>
|
<item name="roundSelector">@drawable/round_selector</item>
|
||||||
<item name="rectSelector">@drawable/rect_selector</item>
|
<item name="rectSelector">@drawable/rect_selector</item>
|
||||||
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
||||||
|
<item name="android:windowLightNavigationBar">false</item>
|
||||||
</style>
|
</style>
|
||||||
</resources>
|
</resources>
|
79
app/src/main/res/values-v27/styles_parents.xml
Normal file
79
app/src/main/res/values-v27/styles_parents.xml
Normal file
|
@ -0,0 +1,79 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!--
|
||||||
|
~ Copyright (c) 2019 Hemanth Savarala.
|
||||||
|
~
|
||||||
|
~ Licensed under the GNU General Public License v3
|
||||||
|
~
|
||||||
|
~ This is free software: you can redistribute it and/or modify it under
|
||||||
|
~ the terms of the GNU General Public License as published by
|
||||||
|
~ the Free Software Foundation either version 3 of the License, or (at your option) any later version.
|
||||||
|
~
|
||||||
|
~ This software is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
||||||
|
~ without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
|
~ See the GNU General Public License for more details.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<resources>
|
||||||
|
|
||||||
|
<style name="Theme.RetroMusic.Base.Adaptive" parent="Theme.MaterialComponents.DayNight.NoActionBar">
|
||||||
|
<item name="md_font_title">@font/circular</item>
|
||||||
|
<item name="md_font_body">@font/circular</item>
|
||||||
|
<item name="md_font_button">@font/circular</item>
|
||||||
|
<item name="android:windowActionBarOverlay">true</item>
|
||||||
|
<item name="android:windowActivityTransitions">true</item>
|
||||||
|
<item name="windowActionBarOverlay">true</item>
|
||||||
|
<item name="android:fontFamily">@font/circular</item>
|
||||||
|
<item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Light</item>
|
||||||
|
<item name="mcab_popup_theme">@style/ThemeOverlay.AppCompat.Light</item>
|
||||||
|
<item name="preferenceTheme">@style/PreferenceThemeOverlay.v14.Material</item>
|
||||||
|
<item name="materialAlertDialogTheme">@style/MaterialAlertDialogTheme</item>
|
||||||
|
<item name="materialButtonStyle">@style/MaterialButtonTheme</item>
|
||||||
|
<item name="roundSelector">@drawable/round_selector</item>
|
||||||
|
<item name="rectSelector">@drawable/rect_selector</item>
|
||||||
|
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
||||||
|
<item name="android:windowLightNavigationBar">true</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<style name="Theme.RetroMusic.Base" parent="Theme.MaterialComponents.NoActionBar">
|
||||||
|
<item name="md_font_title">@font/circular</item>
|
||||||
|
<item name="md_font_body">@font/circular</item>
|
||||||
|
<item name="md_font_button">@font/circular</item>
|
||||||
|
<item name="md_color_button_text">@color/md_white_1000</item>
|
||||||
|
<item name="md_background_color">@color/darkColorPrimary</item>
|
||||||
|
<item name="android:windowActionBarOverlay">true</item>
|
||||||
|
<item name="android:windowActivityTransitions">true</item>
|
||||||
|
<item name="android:fontFamily">@font/circular</item>
|
||||||
|
<item name="windowActionBarOverlay">true</item>
|
||||||
|
<item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Dark</item>
|
||||||
|
<item name="mcab_popup_theme">@style/ThemeOverlay.AppCompat.Dark</item>
|
||||||
|
<item name="roundSelector">@drawable/round_selector_dark</item>
|
||||||
|
<item name="rectSelector">@drawable/rect_selector_dark</item>
|
||||||
|
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
||||||
|
<item name="preferenceTheme">@style/PreferenceThemeOverlay.v14.Material</item>
|
||||||
|
<item name="windowActionBar">false</item>
|
||||||
|
<item name="materialAlertDialogTheme">@style/MaterialAlertDialogTheme</item>
|
||||||
|
<item name="materialButtonStyle">@style/MaterialButtonTheme</item>
|
||||||
|
<item name="android:windowLightNavigationBar">false</item>
|
||||||
|
</style>
|
||||||
|
|
||||||
|
<style name="Theme.RetroMusic.Base.Light" parent="Theme.MaterialComponents.Light.NoActionBar">
|
||||||
|
<item name="md_font_title">@font/circular</item>
|
||||||
|
<item name="md_font_body">@font/circular</item>
|
||||||
|
<item name="md_font_button">@font/circular</item>
|
||||||
|
<item name="md_color_button_text">@color/md_black_1000</item>
|
||||||
|
<item name="android:windowActionBarOverlay">true</item>
|
||||||
|
<item name="windowActionBarOverlay">true</item>
|
||||||
|
<item name="roundSelector">@drawable/round_selector</item>
|
||||||
|
<item name="rectSelector">@drawable/rect_selector</item>
|
||||||
|
<item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Light</item>
|
||||||
|
<item name="android:windowBackground">@color/md_white_1000</item>
|
||||||
|
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
||||||
|
<item name="preferenceTheme">@style/PreferenceThemeOverlay.v14.Material</item>
|
||||||
|
<item name="android:windowActivityTransitions">true</item>
|
||||||
|
<item name="android:fontFamily">@font/circular</item>
|
||||||
|
<item name="windowActionBar">false</item>
|
||||||
|
<item name="materialAlertDialogTheme">@style/MaterialAlertDialogTheme</item>
|
||||||
|
<item name="materialButtonStyle">@style/MaterialButtonTheme</item>
|
||||||
|
<item name="android:windowLightNavigationBar">false</item>
|
||||||
|
</style>
|
||||||
|
</resources>
|
|
@ -29,15 +29,16 @@
|
||||||
<item name="android:windowActivityTransitions">true</item>
|
<item name="android:windowActivityTransitions">true</item>
|
||||||
<item name="android:fontFamily">@font/circular</item>
|
<item name="android:fontFamily">@font/circular</item>
|
||||||
<item name="windowActionBarOverlay">true</item>
|
<item name="windowActionBarOverlay">true</item>
|
||||||
|
<item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Dark</item>
|
||||||
<item name="mcab_popup_theme">@style/ThemeOverlay.AppCompat.Dark</item>
|
<item name="mcab_popup_theme">@style/ThemeOverlay.AppCompat.Dark</item>
|
||||||
<item name="roundSelector">@drawable/round_selector_dark</item>
|
<item name="roundSelector">@drawable/round_selector_dark</item>
|
||||||
<item name="rectSelector">@drawable/rect_selector_dark</item>
|
<item name="rectSelector">@drawable/rect_selector_dark</item>
|
||||||
<item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat</item>
|
|
||||||
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
||||||
<item name="preferenceTheme">@style/PreferenceThemeOverlay.v14.Material</item>
|
<item name="preferenceTheme">@style/PreferenceThemeOverlay.v14.Material</item>
|
||||||
<item name="windowActionBar">false</item>
|
<item name="windowActionBar">false</item>
|
||||||
<item name="materialAlertDialogTheme">@style/MaterialAlertDialogTheme</item>
|
<item name="materialAlertDialogTheme">@style/MaterialAlertDialogTheme</item>
|
||||||
<item name="materialButtonStyle">@style/MaterialButtonTheme</item>
|
<item name="materialButtonStyle">@style/MaterialButtonTheme</item>
|
||||||
|
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Theme.RetroMusic.Base.Black" parent="Theme.MaterialComponents.NoActionBar">
|
<style name="Theme.RetroMusic.Base.Black" parent="Theme.MaterialComponents.NoActionBar">
|
||||||
|
@ -59,58 +60,23 @@
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
<style name="Theme.RetroMusic.Base.Light" parent="Theme.MaterialComponents.Light.NoActionBar">
|
<style name="Theme.RetroMusic.Base.Light" parent="Theme.MaterialComponents.Light.NoActionBar">
|
||||||
|
|
||||||
<item name="md_font_title">@font/circular</item>
|
<item name="md_font_title">@font/circular</item>
|
||||||
<item name="md_font_body">@font/circular</item>
|
<item name="md_font_body">@font/circular</item>
|
||||||
<item name="md_font_button">@font/circular</item>
|
<item name="md_font_button">@font/circular</item>
|
||||||
<item name="md_color_button_text">@color/md_black_1000</item>
|
<item name="md_color_button_text">@color/md_black_1000</item>
|
||||||
|
|
||||||
<item name="android:windowActionBarOverlay">true</item>
|
<item name="android:windowActionBarOverlay">true</item>
|
||||||
<item name="windowActionBarOverlay">true</item>
|
<item name="windowActionBarOverlay">true</item>
|
||||||
|
|
||||||
<item name="roundSelector">@drawable/round_selector</item>
|
<item name="roundSelector">@drawable/round_selector</item>
|
||||||
<item name="rectSelector">@drawable/rect_selector</item>
|
<item name="rectSelector">@drawable/rect_selector</item>
|
||||||
|
|
||||||
<item name="cardBackgroundColor">@color/md_white_1000</item>
|
|
||||||
|
|
||||||
<item name="defaultFooterColor">@color/md_grey_500</item>
|
|
||||||
|
|
||||||
<item name="dividerColor">@color/md_grey_200</item>
|
|
||||||
<item name="iconColor">@color/ate_secondary_text_light</item>
|
|
||||||
|
|
||||||
<item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Light</item>
|
<item name="toolbarPopupTheme">@style/ThemeOverlay.AppCompat.Light</item>
|
||||||
|
|
||||||
<!-- just in case-->
|
|
||||||
<item name="android:windowBackground">@color/md_white_1000</item>
|
<item name="android:windowBackground">@color/md_white_1000</item>
|
||||||
|
|
||||||
<!-- necessary to find the overflow button later in the layout-->
|
|
||||||
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
<item name="android:actionOverflowButtonStyle">@style/Widget.ActionButton.Overflow</item>
|
||||||
|
|
||||||
<item name="preferenceTheme">@style/PreferenceThemeOverlay.v14.Material</item>
|
<item name="preferenceTheme">@style/PreferenceThemeOverlay.v14.Material</item>
|
||||||
|
|
||||||
<item name="android:windowActivityTransitions">true</item>
|
<item name="android:windowActivityTransitions">true</item>
|
||||||
<item name="android:fontFamily">@font/circular</item>
|
<item name="android:fontFamily">@font/circular</item>
|
||||||
|
|
||||||
<item name="windowActionBar">false</item>
|
<item name="windowActionBar">false</item>
|
||||||
|
|
||||||
<item name="materialAlertDialogTheme">@style/MaterialAlertDialogTheme</item>
|
<item name="materialAlertDialogTheme">@style/MaterialAlertDialogTheme</item>
|
||||||
<item name="materialButtonStyle">@style/MaterialButtonTheme</item>
|
<item name="materialButtonStyle">@style/MaterialButtonTheme</item>
|
||||||
|
|
||||||
<item name="colorPrimary">@color/lightColorPrimary</item>
|
|
||||||
<item name="colorSecondary">@color/lightColorSecondary</item>
|
|
||||||
<item name="colorPrimaryVariant">@color/md_red_400</item>
|
|
||||||
|
|
||||||
<item name="colorOnPrimary">@color/lightColorOnPrimary</item>
|
|
||||||
<item name="colorAccent">@color/md_deep_purple_A200</item>
|
|
||||||
<item name="colorOnSecondary">@color/mi_text_color_secondary_light</item>
|
|
||||||
<item name="colorSecondaryVariant">@color/md_green_A700</item>
|
|
||||||
|
|
||||||
|
|
||||||
<item name="android:colorBackground">@color/lightColorBackground</item>
|
|
||||||
<item name="colorSurface">@color/lightColorSurface</item>
|
|
||||||
<item name="colorOnSurface">@color/mi_text_color_secondary_light</item>
|
|
||||||
<item name="colorOnBackground">@color/mi_text_color_secondary_light</item>
|
|
||||||
<item name="colorControlNormal">@color/mi_text_color_secondary_light</item>
|
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -199,18 +199,24 @@ public final class ToolbarContentTintHelper {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void setToolbarContentColorBasedOnToolbarColor(@NonNull Context context,
|
public static void setToolbarContentColorBasedOnToolbarColor(@NonNull Context context,
|
||||||
Toolbar toolbar, int toolbarColor) {
|
Toolbar toolbar,
|
||||||
|
int toolbarColor) {
|
||||||
setToolbarContentColorBasedOnToolbarColor(context, toolbar, null, toolbarColor);
|
setToolbarContentColorBasedOnToolbarColor(context, toolbar, null, toolbarColor);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void setToolbarContentColorBasedOnToolbarColor(@NonNull Context context,
|
public static void setToolbarContentColorBasedOnToolbarColor(@NonNull Context context,
|
||||||
Toolbar toolbar, @Nullable Menu menu, int toolbarColor) {
|
Toolbar toolbar,
|
||||||
|
@Nullable Menu menu,
|
||||||
|
int toolbarColor) {
|
||||||
setToolbarContentColorBasedOnToolbarColor(context, toolbar, menu, toolbarColor,
|
setToolbarContentColorBasedOnToolbarColor(context, toolbar, menu, toolbarColor,
|
||||||
ThemeStore.Companion.accentColor(context));
|
ThemeStore.Companion.accentColor(context));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void setToolbarContentColorBasedOnToolbarColor(@NonNull Context context,
|
public static void setToolbarContentColorBasedOnToolbarColor(@NonNull Context context,
|
||||||
Toolbar toolbar, @Nullable Menu menu, int toolbarColor, final @ColorInt int menuWidgetColor) {
|
Toolbar toolbar,
|
||||||
|
@Nullable Menu menu,
|
||||||
|
int toolbarColor,
|
||||||
|
final @ColorInt int menuWidgetColor) {
|
||||||
setToolbarContentColor(context, toolbar, menu, toolbarContentColor(context, toolbarColor),
|
setToolbarContentColor(context, toolbar, menu, toolbarContentColor(context, toolbarColor),
|
||||||
toolbarTitleColor(context, toolbarColor), toolbarSubtitleColor(context, toolbarColor),
|
toolbarTitleColor(context, toolbarColor), toolbarSubtitleColor(context, toolbarColor),
|
||||||
menuWidgetColor);
|
menuWidgetColor);
|
||||||
|
|
Loading…
Reference in a new issue