From 9e04408efa32d2b533dba337de747d999259d987 Mon Sep 17 00:00:00 2001 From: Hemanth S Date: Wed, 8 May 2019 14:11:23 +0530 Subject: [PATCH 1/5] Added material dialog --- app/build.gradle | 14 +++++----- .../mainactivity/folders/FoldersFragment.java | 28 +++++++++++-------- app/src/main/res/values/strings.xml | 1 + 3 files changed, 24 insertions(+), 19 deletions(-) diff --git a/app/build.gradle b/app/build.gradle index 99b289d1..db59a87e 100644 --- a/app/build.gradle +++ b/app/build.gradle @@ -120,14 +120,14 @@ static def getDate() { dependencies { implementation fileTree(include: ['*.jar'], dir: 'libs') implementation 'androidx.multidex:multidex:2.0.1' - implementation 'androidx.fragment:fragment:1.1.0-alpha06' - implementation 'androidx.appcompat:appcompat:1.1.0-alpha04' + implementation 'androidx.fragment:fragment:1.1.0-alpha08' + implementation 'androidx.appcompat:appcompat:1.1.0-alpha05' implementation 'androidx.recyclerview:recyclerview:1.1.0-alpha04' implementation "androidx.gridlayout:gridlayout:1.0.0" implementation "androidx.cardview:cardview:1.0.0" implementation "androidx.palette:palette:1.0.0" implementation 'androidx.annotation:annotation:1.1.0-beta01' - implementation 'androidx.preference:preference:1.1.0-alpha04' + implementation 'androidx.preference:preference:1.1.0-alpha05' implementation "androidx.legacy:legacy-support-v13:1.0.0" implementation "androidx.legacy:legacy-preference-v14:1.0.0" implementation 'com.google.android.material:material:1.1.0-alpha05' @@ -135,10 +135,10 @@ dependencies { implementation 'com.squareup.retrofit2:retrofit:2.5.0' implementation 'com.squareup.retrofit2:converter-gson:2.5.0' implementation 'com.squareup.retrofit2:adapter-rxjava2:2.5.0' - implementation "com.afollestad.material-dialogs:core:$materialDialog" - implementation "com.afollestad.material-dialogs:core:$materialDialog" - implementation 'com.afollestad.material-dialogs:input:2.0.0' - implementation 'com.afollestad.material-dialogs:color:2.0.0' + implementation 'com.afollestad.material-dialogs:core:3.0.0-alpha1' + implementation 'com.afollestad.material-dialogs:input:3.0.0-alpha1' + implementation 'com.afollestad.material-dialogs:color:3.0.0-alpha1' + implementation 'com.afollestad.material-dialogs:bottomsheets:3.0.0-alpha1' implementation 'com.afollestad:material-cab:0.1.12' implementation 'com.github.bumptech.glide:glide:4.8.0' kapt 'com.github.bumptech.glide:compiler:4.8.0' diff --git a/app/src/main/java/code/name/monkey/retromusic/fragments/mainactivity/folders/FoldersFragment.java b/app/src/main/java/code/name/monkey/retromusic/fragments/mainactivity/folders/FoldersFragment.java index b2ec3874..6c6d72bb 100644 --- a/app/src/main/java/code/name/monkey/retromusic/fragments/mainactivity/folders/FoldersFragment.java +++ b/app/src/main/java/code/name/monkey/retromusic/fragments/mainactivity/folders/FoldersFragment.java @@ -20,6 +20,7 @@ import android.widget.Toast; import com.afollestad.materialcab.MaterialCab; import com.afollestad.materialdialogs.MaterialDialog; +import com.afollestad.materialdialogs.bottomsheets.BottomSheet; import com.google.android.material.appbar.AppBarLayout; import com.google.android.material.snackbar.Snackbar; import com.simplecityapps.recyclerview_fastscroll.views.FastScrollRecyclerView; @@ -48,8 +49,9 @@ import code.name.monkey.appthemehelper.util.ATHUtil; import code.name.monkey.appthemehelper.util.ColorUtil; import code.name.monkey.appthemehelper.util.TintHelper; import code.name.monkey.appthemehelper.util.ToolbarContentTintHelper; - import code.name.monkey.retromusic.R; +import code.name.monkey.retromusic.adapter.SongFileAdapter; +import code.name.monkey.retromusic.fragments.base.AbsMainActivityFragment; import code.name.monkey.retromusic.helper.MusicPlayerRemote; import code.name.monkey.retromusic.helper.menu.SongMenuHelper; import code.name.monkey.retromusic.helper.menu.SongsMenuHelper; @@ -60,8 +62,6 @@ import code.name.monkey.retromusic.misc.DialogAsyncTask; import code.name.monkey.retromusic.misc.UpdateToastMediaScannerCompletionListener; import code.name.monkey.retromusic.misc.WrappedAsyncTaskLoader; import code.name.monkey.retromusic.model.Song; -import code.name.monkey.retromusic.adapter.SongFileAdapter; -import code.name.monkey.retromusic.fragments.base.AbsMainActivityFragment; import code.name.monkey.retromusic.util.FileUtil; import code.name.monkey.retromusic.util.PreferenceUtil; import code.name.monkey.retromusic.util.RetroColorUtil; @@ -245,7 +245,8 @@ public class FoldersFragment extends AbsMainActivityFragment implements }); breadCrumbs.setActivatedContentColor(ToolbarContentTintHelper.toolbarTitleColor(getActivity(), ColorUtil.INSTANCE.darkenColor(primaryColor))); - breadCrumbs.setDeactivatedContentColor(ToolbarContentTintHelper.toolbarSubtitleColor(getActivity(), ColorUtil.INSTANCE.darkenColor(primaryColor))); + breadCrumbs.setDeactivatedContentColor(ToolbarContentTintHelper.toolbarSubtitleColor(getActivity(), + ColorUtil.INSTANCE.darkenColor(primaryColor))); appBarLayout.addOnOffsetChangedListener((appBarLayout, verticalOffset) -> getMainActivity().setLightStatusbar(!ATHUtil.INSTANCE.isWindowBackgroundDark(getContext()))); } @@ -347,7 +348,8 @@ public class FoldersFragment extends AbsMainActivityFragment implements BreadCrumbLayout.Crumb crumb = getActiveCrumb(); if (crumb != null) { //noinspection Convert2MethodRef - new ListPathsAsyncTask(getActivity(), paths -> scanPaths(paths)).execute(new ListPathsAsyncTask.LoadingInfo(crumb.getFile(), AUDIO_FILE_FILTER)); + new ListPathsAsyncTask(getActivity(), paths -> scanPaths(paths)).execute(new ListPathsAsyncTask.LoadingInfo(crumb.getFile(), + AUDIO_FILE_FILTER)); } return true; } @@ -454,7 +456,9 @@ public class FoldersFragment extends AbsMainActivityFragment implements case R.id.action_details: case R.id.action_set_as_ringtone: case R.id.action_delete_from_device: - new ListSongsAsyncTask(getActivity(), null, (songs, extra) -> SongMenuHelper.INSTANCE.handleMenuClick(getActivity(), songs.get(0), itemId)).execute(new ListSongsAsyncTask.LoadingInfo(toList(file), AUDIO_FILE_FILTER, getFileComparator())); + new ListSongsAsyncTask(getActivity(), null, (songs, extra) -> SongMenuHelper.INSTANCE.handleMenuClick(getActivity(), + songs.get(0), itemId)).execute(new ListSongsAsyncTask.LoadingInfo(toList(file), AUDIO_FILE_FILTER, + getFileComparator())); return true; case R.id.action_scan: new ListPathsAsyncTask(getActivity(), this::scanPaths).execute(new ListPathsAsyncTask.LoadingInfo(file, AUDIO_FILE_FILTER)); @@ -739,13 +743,13 @@ public class FoldersFragment extends AbsMainActivityFragment implements @Override protected Dialog createDialog(@NonNull Context context) { - View view= LayoutInflater.from(context).inflate(R.layout.progress_bar,null); - ProgressBar progressBar= view.findViewById(R.id.progressBar); - ViewUtil.INSTANCE.setProgressDrawable(progressBar,ThemeStore.Companion.accentColor(context)); + View view = LayoutInflater.from(context).inflate(R.layout.progress_bar, null); + ProgressBar progressBar = view.findViewById(R.id.progressBar); + ViewUtil.INSTANCE.setProgressDrawable(progressBar, ThemeStore.Companion.accentColor(context)); - MaterialDialog materialDialog= new MaterialDialog(context); - materialDialog.setContentView(R.layout.progress_bar); - materialDialog.title(R.string.listing_files,""); + MaterialDialog materialDialog = new MaterialDialog(context, new BottomSheet()); + materialDialog.setContentView(view); + materialDialog.title(R.string.listing_files, ""); return materialDialog; } diff --git a/app/src/main/res/values/strings.xml b/app/src/main/res/values/strings.xml index 3d7def9c..8d76c670 100644 --- a/app/src/main/res/values/strings.xml +++ b/app/src/main/res/values/strings.xml @@ -614,5 +614,6 @@ On Select preset Upgrade to premium + New playlist From b37b1681f5885a1a15eda1769c80fda228c994bd Mon Sep 17 00:00:00 2001 From: Hemanth S Date: Wed, 8 May 2019 14:12:44 +0530 Subject: [PATCH 2/5] Added material dialog --- .../retromusic/activities/tageditor/WriteTagsAsyncTask.java | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/app/src/main/java/code/name/monkey/retromusic/activities/tageditor/WriteTagsAsyncTask.java b/app/src/main/java/code/name/monkey/retromusic/activities/tageditor/WriteTagsAsyncTask.java index 9648fdd6..8ead2b76 100644 --- a/app/src/main/java/code/name/monkey/retromusic/activities/tageditor/WriteTagsAsyncTask.java +++ b/app/src/main/java/code/name/monkey/retromusic/activities/tageditor/WriteTagsAsyncTask.java @@ -7,6 +7,7 @@ import android.graphics.Bitmap; import android.media.MediaScannerConnection; import com.afollestad.materialdialogs.MaterialDialog; +import com.afollestad.materialdialogs.bottomsheets.BottomSheet; import org.jaudiotagger.audio.AudioFile; import org.jaudiotagger.audio.AudioFileIO; @@ -134,7 +135,7 @@ public class WriteTagsAsyncTask extends @Override protected Dialog createDialog(@NonNull Context context) { - return new MaterialDialog(context) + return new MaterialDialog(context, new BottomSheet()) .title(R.string.saving_changes, "") .cancelable(false); } From 0ffab0c9fb5c1453040ac1451191c23007e8d655 Mon Sep 17 00:00:00 2001 From: h4h13 Date: Wed, 8 May 2019 14:40:40 +0530 Subject: [PATCH 3/5] Fix crash when device lock --- .../service/MediaButtonIntentReceiver.kt | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/app/src/main/java/code/name/monkey/retromusic/service/MediaButtonIntentReceiver.kt b/app/src/main/java/code/name/monkey/retromusic/service/MediaButtonIntentReceiver.kt index ef99d3da..b48f34dc 100644 --- a/app/src/main/java/code/name/monkey/retromusic/service/MediaButtonIntentReceiver.kt +++ b/app/src/main/java/code/name/monkey/retromusic/service/MediaButtonIntentReceiver.kt @@ -19,14 +19,13 @@ import android.annotation.SuppressLint import android.content.BroadcastReceiver import android.content.Context import android.content.Intent -import android.os.Build import android.os.Handler import android.os.Message import android.os.PowerManager import android.os.PowerManager.WakeLock import android.util.Log import android.view.KeyEvent - +import androidx.core.content.ContextCompat import code.name.monkey.retromusic.BuildConfig import code.name.monkey.retromusic.Constants.ACTION_PAUSE import code.name.monkey.retromusic.Constants.ACTION_PLAY @@ -35,6 +34,7 @@ import code.name.monkey.retromusic.Constants.ACTION_SKIP import code.name.monkey.retromusic.Constants.ACTION_STOP import code.name.monkey.retromusic.Constants.ACTION_TOGGLE_PAUSE + /** * Used to control headset playback. * Single press: pause/resume @@ -152,10 +152,16 @@ class MediaButtonIntentReceiver : BroadcastReceiver() { private fun startService(context: Context, command: String?) { val intent = Intent(context, MusicService::class.java) intent.action = command - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { - context.startForegroundService(intent) - } else { + try { + // IMPORTANT NOTE: (kind of a hack) + // on Android O and above the following crashes when the app is not running + // there is no good way to check whether the app is running so we catch the exception + // we do not always want to use startForegroundService() because then one gets an ANR + // if no notification is displayed via startForeground() + // according to Play analytics this happens a lot, I suppose for example if command = PAUSE context.startService(intent) + } catch (ignored: IllegalStateException) { + ContextCompat.startForegroundService(context, intent) } } From 5a36491ad27c675a082570a4b093661419c81ab7 Mon Sep 17 00:00:00 2001 From: h4h13 Date: Wed, 8 May 2019 14:42:31 +0530 Subject: [PATCH 4/5] Fix crashing when empty strings --- .../monkey/retromusic/util/MusicUtil.java | 28 +++++++------------ 1 file changed, 10 insertions(+), 18 deletions(-) diff --git a/app/src/main/java/code/name/monkey/retromusic/util/MusicUtil.java b/app/src/main/java/code/name/monkey/retromusic/util/MusicUtil.java index 90c89202..1864b593 100644 --- a/app/src/main/java/code/name/monkey/retromusic/util/MusicUtil.java +++ b/app/src/main/java/code/name/monkey/retromusic/util/MusicUtil.java @@ -29,10 +29,6 @@ import android.text.TextUtils; import android.util.Log; import android.widget.Toast; -import androidx.annotation.NonNull; -import androidx.annotation.Nullable; -import androidx.core.content.FileProvider; - import org.jaudiotagger.audio.AudioFileIO; import org.jaudiotagger.tag.FieldKey; @@ -43,6 +39,9 @@ import java.util.List; import java.util.Locale; import java.util.regex.Pattern; +import androidx.annotation.NonNull; +import androidx.annotation.Nullable; +import androidx.core.content.FileProvider; import code.name.monkey.retromusic.R; import code.name.monkey.retromusic.helper.MusicPlayerRemote; import code.name.monkey.retromusic.loaders.PlaylistLoader; @@ -99,22 +98,15 @@ public class MusicUtil { * Ex: for a given album --> buildInfoString(album.artist, album.songCount) */ public static String buildInfoString(@NonNull final String string1, @NonNull final String string2) { - // Skip empty strings - if (string1.isEmpty()) { - return string2; + if (TextUtils.isEmpty(string1)) { + //noinspection ConstantConditions + return TextUtils.isEmpty(string2) ? "" : string2; } - if (string2.isEmpty()) { - return string1; + if (TextUtils.isEmpty(string2)) { + //noinspection ConstantConditions + return TextUtils.isEmpty(string1) ? "" : string1; } - - final String separator = " • "; - - final StringBuilder builder = new StringBuilder(); - builder.append(string1); - builder.append(separator); - builder.append(string2); - - return builder.toString(); + return string1 + " • " + string2; } @NonNull From 0950e988c997c7657e43b114bdf97808f27e1e63 Mon Sep 17 00:00:00 2001 From: h4h13 Date: Wed, 8 May 2019 15:27:39 +0530 Subject: [PATCH 5/5] Added classic theme --- .../base/AbsSlidingMusicPanelActivity.kt | 4 +++- .../adapter/album/AlbumCoverPagerAdapter.kt | 12 ++++++++---- .../retromusic/fragments/NowPlayingScreen.kt | 1 + .../ClassicPlayerPlaybackControlsFragment.kt | 17 ++++++++--------- 4 files changed, 20 insertions(+), 14 deletions(-) diff --git a/app/src/main/java/code/name/monkey/retromusic/activities/base/AbsSlidingMusicPanelActivity.kt b/app/src/main/java/code/name/monkey/retromusic/activities/base/AbsSlidingMusicPanelActivity.kt index 669e8fa8..ca4aa7f0 100644 --- a/app/src/main/java/code/name/monkey/retromusic/activities/base/AbsSlidingMusicPanelActivity.kt +++ b/app/src/main/java/code/name/monkey/retromusic/activities/base/AbsSlidingMusicPanelActivity.kt @@ -20,6 +20,7 @@ import code.name.monkey.retromusic.fragments.player.adaptive.AdaptiveFragment import code.name.monkey.retromusic.fragments.player.blur.BlurPlayerFragment import code.name.monkey.retromusic.fragments.player.card.CardFragment import code.name.monkey.retromusic.fragments.player.cardblur.CardBlurFragment +import code.name.monkey.retromusic.fragments.player.classic.ClassicPlayerFragment import code.name.monkey.retromusic.fragments.player.color.ColorFragment import code.name.monkey.retromusic.fragments.player.fit.FitFragment import code.name.monkey.retromusic.fragments.player.flat.FlatPlayerFragment @@ -28,6 +29,7 @@ import code.name.monkey.retromusic.fragments.player.material.MaterialFragment import code.name.monkey.retromusic.fragments.player.normal.PlayerFragment import code.name.monkey.retromusic.fragments.player.plain.PlainPlayerFragment import code.name.monkey.retromusic.fragments.player.simple.SimplePlayerFragment +import code.name.monkey.retromusic.fragments.player.slide.SlidePlayerFragment import code.name.monkey.retromusic.fragments.player.tiny.TinyPlayerFragment import code.name.monkey.retromusic.util.PreferenceUtil import code.name.monkey.retromusic.views.BottomNavigationBarTinted @@ -194,7 +196,7 @@ abstract class AbsSlidingMusicPanelActivity : AbsMusicServiceActivity(), Sliding MATERIAL -> MaterialFragment() COLOR -> ColorFragment() TINY -> TinyPlayerFragment() - //SLIDE -> SlidePlayerFragment() + CLASSIC -> ClassicPlayerFragment() else -> PlayerFragment() } // must implement AbsPlayerFragment supportFragmentManager.beginTransaction().replace(R.id.playerFragmentContainer, fragment).commit() diff --git a/app/src/main/java/code/name/monkey/retromusic/adapter/album/AlbumCoverPagerAdapter.kt b/app/src/main/java/code/name/monkey/retromusic/adapter/album/AlbumCoverPagerAdapter.kt index 5015db01..c28fcdb9 100644 --- a/app/src/main/java/code/name/monkey/retromusic/adapter/album/AlbumCoverPagerAdapter.kt +++ b/app/src/main/java/code/name/monkey/retromusic/adapter/album/AlbumCoverPagerAdapter.kt @@ -10,13 +10,14 @@ import android.widget.ImageView import androidx.fragment.app.Fragment import androidx.fragment.app.FragmentManager import code.name.monkey.retromusic.R +import code.name.monkey.retromusic.activities.LyricsActivity +import code.name.monkey.retromusic.fragments.AlbumCoverStyle +import code.name.monkey.retromusic.fragments.NowPlayingScreen import code.name.monkey.retromusic.glide.GlideApp import code.name.monkey.retromusic.glide.RetroGlideExtension import code.name.monkey.retromusic.glide.RetroMusicColoredTarget import code.name.monkey.retromusic.misc.CustomFragmentStatePagerAdapter import code.name.monkey.retromusic.model.Song -import code.name.monkey.retromusic.activities.LyricsActivity -import code.name.monkey.retromusic.fragments.AlbumCoverStyle import code.name.monkey.retromusic.util.PreferenceUtil import java.util.* @@ -90,8 +91,11 @@ class AlbumCoverPagerAdapter(fm: FragmentManager, private val dataSet: ArrayList } override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? { - val layout = layout - val view = inflater.inflate(layout, container, false) + var finalLayout = layout + if (PreferenceUtil.getInstance().nowPlayingScreen == NowPlayingScreen.CLASSIC) { + finalLayout = R.layout.fragment_album_full_cover + } + val view = inflater.inflate(finalLayout, container, false) albumCover = view.findViewById(R.id.player_image) albumCover.setOnClickListener { startActivity(Intent(context, LyricsActivity::class.java)) } return view diff --git a/app/src/main/java/code/name/monkey/retromusic/fragments/NowPlayingScreen.kt b/app/src/main/java/code/name/monkey/retromusic/fragments/NowPlayingScreen.kt index e3a61c7e..228ddb58 100644 --- a/app/src/main/java/code/name/monkey/retromusic/fragments/NowPlayingScreen.kt +++ b/app/src/main/java/code/name/monkey/retromusic/fragments/NowPlayingScreen.kt @@ -22,6 +22,7 @@ enum class NowPlayingScreen constructor(@param:StringRes @field:StringRes PLAIN(R.string.plain, R.drawable.np_plain, 3), TINY(R.string.tiny, R.drawable.np_tiny, 7), SIMPLE(R.string.simple, R.drawable.np_simple, 8), + CLASSIC(R.string.classic, R.drawable.np_normal, 13); //SLIDE(R.string.slide, R.drawable.np_slide, 13) } diff --git a/app/src/main/java/code/name/monkey/retromusic/fragments/player/classic/ClassicPlayerPlaybackControlsFragment.kt b/app/src/main/java/code/name/monkey/retromusic/fragments/player/classic/ClassicPlayerPlaybackControlsFragment.kt index bddaa282..e2aff8c9 100644 --- a/app/src/main/java/code/name/monkey/retromusic/fragments/player/classic/ClassicPlayerPlaybackControlsFragment.kt +++ b/app/src/main/java/code/name/monkey/retromusic/fragments/player/classic/ClassicPlayerPlaybackControlsFragment.kt @@ -30,7 +30,6 @@ class ClassicPlayerPlaybackControlsFragment : AbsPlayerControlsFragment() { playerPlayPauseFab.animate() .scaleX(1f) .scaleY(1f) - .rotation(360f) .setInterpolator(DecelerateInterpolator()) .start() } @@ -50,19 +49,19 @@ class ClassicPlayerPlaybackControlsFragment : AbsPlayerControlsFragment() { fun setDark(dark: Boolean) { if (dark) { - lastPlaybackControlsColor = MaterialValueHelper.getSecondaryTextColor(getActivity(), true); - lastDisabledPlaybackControlsColor = MaterialValueHelper.getSecondaryDisabledTextColor(getActivity(), true); + lastPlaybackControlsColor = MaterialValueHelper.getSecondaryTextColor(activity, true) + lastDisabledPlaybackControlsColor = MaterialValueHelper.getSecondaryDisabledTextColor(activity, true) } else { - lastPlaybackControlsColor = MaterialValueHelper.getPrimaryTextColor(getActivity(), false); - lastDisabledPlaybackControlsColor = MaterialValueHelper.getPrimaryDisabledTextColor(getActivity(), false); + lastPlaybackControlsColor = MaterialValueHelper.getPrimaryTextColor(activity, false) + lastDisabledPlaybackControlsColor = MaterialValueHelper.getPrimaryDisabledTextColor(activity, false) } //volumeFragment?.setTintableColor(lastPlaybackControlsColor) - updateRepeatState(); - updateShuffleState(); - updatePrevNextColor(); - updateProgressTextColor(); + updateRepeatState() + updateShuffleState() + updatePrevNextColor() + updateProgressTextColor() } private var playerFabPlayPauseDrawable: PlayPauseDrawable? = null