Converted Lyrics activity to fragment
This commit is contained in:
parent
73f246b60e
commit
4d6f75031a
5 changed files with 113 additions and 125 deletions
|
@ -111,7 +111,7 @@
|
||||||
<activity android:name=".activities.SettingsActivity" />
|
<activity android:name=".activities.SettingsActivity" />
|
||||||
<activity android:name=".activities.tageditor.AlbumTagEditorActivity" />
|
<activity android:name=".activities.tageditor.AlbumTagEditorActivity" />
|
||||||
<activity android:name=".activities.tageditor.SongTagEditorActivity" />
|
<activity android:name=".activities.tageditor.SongTagEditorActivity" />
|
||||||
<activity android:name=".activities.LyricsActivity" />
|
<activity android:name=".fragments.LyricsActivity" />
|
||||||
<activity android:name=".activities.SupportDevelopmentActivity" />
|
<activity android:name=".activities.SupportDevelopmentActivity" />
|
||||||
<activity android:name=".activities.LicenseActivity" />
|
<activity android:name=".activities.LicenseActivity" />
|
||||||
<activity android:name=".activities.PurchaseActivity" />
|
<activity android:name=".activities.PurchaseActivity" />
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
* See the GNU General Public License for more details.
|
* See the GNU General Public License for more details.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
package code.name.monkey.retromusic.activities
|
package code.name.monkey.retromusic.fragments
|
||||||
|
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.text.InputType
|
import android.text.InputType
|
||||||
|
@ -20,13 +20,13 @@ import android.view.*
|
||||||
import androidx.core.view.ViewCompat
|
import androidx.core.view.ViewCompat
|
||||||
import androidx.fragment.app.Fragment
|
import androidx.fragment.app.Fragment
|
||||||
import androidx.fragment.app.FragmentActivity
|
import androidx.fragment.app.FragmentActivity
|
||||||
|
import androidx.navigation.fragment.findNavController
|
||||||
import androidx.viewpager2.adapter.FragmentStateAdapter
|
import androidx.viewpager2.adapter.FragmentStateAdapter
|
||||||
import code.name.monkey.appthemehelper.ThemeStore
|
import code.name.monkey.appthemehelper.ThemeStore
|
||||||
import code.name.monkey.appthemehelper.util.ToolbarContentTintHelper
|
import code.name.monkey.appthemehelper.util.ToolbarContentTintHelper
|
||||||
import code.name.monkey.retromusic.R
|
import code.name.monkey.retromusic.R
|
||||||
import code.name.monkey.retromusic.activities.base.AbsMusicServiceActivity
|
|
||||||
import code.name.monkey.retromusic.activities.tageditor.WriteTagsAsyncTask
|
import code.name.monkey.retromusic.activities.tageditor.WriteTagsAsyncTask
|
||||||
import code.name.monkey.retromusic.databinding.ActivityLyricsBinding
|
import code.name.monkey.retromusic.databinding.FragmentLyricsBinding
|
||||||
import code.name.monkey.retromusic.databinding.FragmentNormalLyricsBinding
|
import code.name.monkey.retromusic.databinding.FragmentNormalLyricsBinding
|
||||||
import code.name.monkey.retromusic.databinding.FragmentSyncedLyricsBinding
|
import code.name.monkey.retromusic.databinding.FragmentSyncedLyricsBinding
|
||||||
import code.name.monkey.retromusic.extensions.accentColor
|
import code.name.monkey.retromusic.extensions.accentColor
|
||||||
|
@ -53,12 +53,13 @@ import org.jaudiotagger.tag.FieldKey
|
||||||
import java.io.File
|
import java.io.File
|
||||||
import java.util.*
|
import java.util.*
|
||||||
|
|
||||||
class LyricsActivity : AbsMusicServiceActivity() {
|
class LyricsFragment : AbsMusicServiceFragment(R.layout.fragment_lyrics) {
|
||||||
|
|
||||||
private lateinit var binding: ActivityLyricsBinding
|
private var _binding: FragmentLyricsBinding? = null
|
||||||
|
private val binding get() = _binding!!
|
||||||
private lateinit var song: Song
|
private lateinit var song: Song
|
||||||
|
|
||||||
private val lyricsSectionsAdapter = LyricsSectionsAdapter(this)
|
private lateinit var lyricsSectionsAdapter: LyricsSectionsAdapter
|
||||||
|
|
||||||
private val googleSearchLrcUrl: String
|
private val googleSearchLrcUrl: String
|
||||||
get() {
|
get() {
|
||||||
|
@ -80,20 +81,18 @@ class LyricsActivity : AbsMusicServiceActivity() {
|
||||||
private fun buildContainerTransform(): MaterialContainerTransform {
|
private fun buildContainerTransform(): MaterialContainerTransform {
|
||||||
val transform = MaterialContainerTransform()
|
val transform = MaterialContainerTransform()
|
||||||
transform.setAllContainerColors(
|
transform.setAllContainerColors(
|
||||||
MaterialColors.getColor(findViewById(R.id.container), R.attr.colorSurface)
|
MaterialColors.getColor(requireView().findViewById(R.id.container), R.attr.colorSurface)
|
||||||
)
|
)
|
||||||
transform.addTarget(R.id.container)
|
transform.addTarget(R.id.container)
|
||||||
transform.duration = 300
|
transform.duration = 300
|
||||||
return transform
|
return transform
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onViewCreated(view, savedInstanceState)
|
||||||
binding = ActivityLyricsBinding.inflate(layoutInflater)
|
lyricsSectionsAdapter = LyricsSectionsAdapter(requireActivity())
|
||||||
setContentView(binding.root)
|
_binding = FragmentLyricsBinding.bind(view)
|
||||||
ViewCompat.setTransitionName(binding.container, "lyrics")
|
ViewCompat.setTransitionName(binding.container, "lyrics")
|
||||||
setStatusbarColorAuto()
|
|
||||||
setTaskDescriptionColorAuto()
|
|
||||||
|
|
||||||
setupWakelock()
|
setupWakelock()
|
||||||
|
|
||||||
|
@ -101,12 +100,10 @@ class LyricsActivity : AbsMusicServiceActivity() {
|
||||||
binding.tabLyrics.setBackgroundColor(surfaceColor())
|
binding.tabLyrics.setBackgroundColor(surfaceColor())
|
||||||
binding.container.setBackgroundColor(surfaceColor())
|
binding.container.setBackgroundColor(surfaceColor())
|
||||||
ToolbarContentTintHelper.colorBackButton(binding.toolbar)
|
ToolbarContentTintHelper.colorBackButton(binding.toolbar)
|
||||||
setSupportActionBar(binding.toolbar)
|
|
||||||
setupViews()
|
setupViews()
|
||||||
|
updateTitleSong()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private fun setupViews() {
|
private fun setupViews() {
|
||||||
binding.lyricsPager.adapter = lyricsSectionsAdapter
|
binding.lyricsPager.adapter = lyricsSectionsAdapter
|
||||||
TabLayoutMediator(binding.tabLyrics, binding.lyricsPager) { tab, position ->
|
TabLayoutMediator(binding.tabLyrics, binding.lyricsPager) { tab, position ->
|
||||||
|
@ -118,7 +115,7 @@ class LyricsActivity : AbsMusicServiceActivity() {
|
||||||
}.attach()
|
}.attach()
|
||||||
// lyricsPager.isUserInputEnabled = false
|
// lyricsPager.isUserInputEnabled = false
|
||||||
|
|
||||||
binding.tabLyrics.setSelectedTabIndicatorColor(ThemeStore.accentColor(this))
|
binding.tabLyrics.setSelectedTabIndicatorColor(ThemeStore.accentColor(requireContext()))
|
||||||
binding.tabLyrics.setTabTextColors(textColorSecondary(), accentColor())
|
binding.tabLyrics.setTabTextColors(textColorSecondary(), accentColor())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,22 +137,22 @@ class LyricsActivity : AbsMusicServiceActivity() {
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun setupWakelock() {
|
private fun setupWakelock() {
|
||||||
window.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON)
|
requireActivity().window.addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onCreateOptionsMenu(menu: Menu?): Boolean {
|
override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) {
|
||||||
menuInflater.inflate(R.menu.menu_search, menu)
|
inflater.inflate(R.menu.menu_search, menu)
|
||||||
return super.onCreateOptionsMenu(menu)
|
return super.onCreateOptionsMenu(menu, inflater)
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
||||||
if (item.itemId == android.R.id.home) {
|
if (item.itemId == android.R.id.home) {
|
||||||
finish()
|
findNavController().navigateUp()
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
if (item.itemId == R.id.action_search) {
|
if (item.itemId == R.id.action_search) {
|
||||||
RetroUtil.openUrl(
|
RetroUtil.openUrl(
|
||||||
this, when (binding.lyricsPager.currentItem) {
|
requireActivity(), when (binding.lyricsPager.currentItem) {
|
||||||
0 -> syairSearchLrcUrl
|
0 -> syairSearchLrcUrl
|
||||||
1 -> googleSearchLrcUrl
|
1 -> googleSearchLrcUrl
|
||||||
else -> googleSearchLrcUrl
|
else -> googleSearchLrcUrl
|
||||||
|
@ -184,7 +181,7 @@ class LyricsActivity : AbsMusicServiceActivity() {
|
||||||
e.printStackTrace()
|
e.printStackTrace()
|
||||||
}
|
}
|
||||||
|
|
||||||
MaterialDialog(this, BottomSheet(LayoutMode.WRAP_CONTENT)).show {
|
MaterialDialog(requireContext(), BottomSheet(LayoutMode.WRAP_CONTENT)).show {
|
||||||
title(res = R.string.edit_normal_lyrics)
|
title(res = R.string.edit_normal_lyrics)
|
||||||
input(
|
input(
|
||||||
hintRes = R.string.paste_lyrics_here,
|
hintRes = R.string.paste_lyrics_here,
|
||||||
|
@ -193,7 +190,7 @@ class LyricsActivity : AbsMusicServiceActivity() {
|
||||||
) { _, input ->
|
) { _, input ->
|
||||||
val fieldKeyValueMap = EnumMap<FieldKey, String>(FieldKey::class.java)
|
val fieldKeyValueMap = EnumMap<FieldKey, String>(FieldKey::class.java)
|
||||||
fieldKeyValueMap[FieldKey.LYRICS] = input.toString()
|
fieldKeyValueMap[FieldKey.LYRICS] = input.toString()
|
||||||
WriteTagsAsyncTask(this@LyricsActivity).execute(
|
WriteTagsAsyncTask(requireActivity()).execute(
|
||||||
LoadingInfo(
|
LoadingInfo(
|
||||||
listOf(song.data), fieldKeyValueMap, null
|
listOf(song.data), fieldKeyValueMap, null
|
||||||
)
|
)
|
||||||
|
@ -216,7 +213,7 @@ class LyricsActivity : AbsMusicServiceActivity() {
|
||||||
}
|
}
|
||||||
val content: String = LyricUtil.getStringFromLrc(lrcFile)
|
val content: String = LyricUtil.getStringFromLrc(lrcFile)
|
||||||
|
|
||||||
MaterialDialog(this, BottomSheet(LayoutMode.WRAP_CONTENT)).show {
|
MaterialDialog(requireContext(), BottomSheet(LayoutMode.WRAP_CONTENT)).show {
|
||||||
title(res = R.string.edit_synced_lyrics)
|
title(res = R.string.edit_synced_lyrics)
|
||||||
input(
|
input(
|
||||||
hintRes = R.string.paste_timeframe_lyrics_here,
|
hintRes = R.string.paste_timeframe_lyrics_here,
|
|
@ -11,100 +11,88 @@
|
||||||
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
* See the GNU General Public License for more details.
|
* See the GNU General Public License for more details.
|
||||||
*/
|
*/
|
||||||
|
package code.name.monkey.retromusic.util
|
||||||
|
|
||||||
package code.name.monkey.retromusic.util;
|
import android.app.Activity
|
||||||
|
import android.content.ActivityNotFoundException
|
||||||
|
import android.content.Context
|
||||||
|
import android.content.Intent
|
||||||
|
import android.media.audiofx.AudioEffect
|
||||||
|
import android.widget.Toast
|
||||||
|
import androidx.core.app.ActivityCompat
|
||||||
|
import androidx.navigation.findNavController
|
||||||
|
import code.name.monkey.retromusic.R
|
||||||
|
import code.name.monkey.retromusic.activities.*
|
||||||
|
import code.name.monkey.retromusic.activities.bugreport.BugReportActivity
|
||||||
|
import code.name.monkey.retromusic.helper.MusicPlayerRemote.audioSessionId
|
||||||
|
|
||||||
import android.app.Activity;
|
object NavigationUtil {
|
||||||
import android.app.ActivityOptions;
|
fun bugReport(activity: Activity) {
|
||||||
import android.content.ActivityNotFoundException;
|
ActivityCompat.startActivity(
|
||||||
import android.content.Context;
|
activity,
|
||||||
import android.content.Intent;
|
Intent(activity, BugReportActivity::class.java),
|
||||||
import android.media.audiofx.AudioEffect;
|
null
|
||||||
import android.widget.Toast;
|
)
|
||||||
|
}
|
||||||
import androidx.annotation.NonNull;
|
|
||||||
import androidx.core.app.ActivityCompat;
|
fun goToOpenSource(activity: Activity) {
|
||||||
|
ActivityCompat.startActivity(activity, Intent(activity, LicenseActivity::class.java), null)
|
||||||
import org.jetbrains.annotations.NotNull;
|
}
|
||||||
|
|
||||||
import code.name.monkey.retromusic.R;
|
fun goToLyrics(activity: Activity) {
|
||||||
import code.name.monkey.retromusic.activities.DriveModeActivity;
|
if (activity is MainActivity) {
|
||||||
import code.name.monkey.retromusic.activities.LicenseActivity;
|
activity.collapsePanel()
|
||||||
import code.name.monkey.retromusic.activities.LyricsActivity;
|
}
|
||||||
import code.name.monkey.retromusic.activities.PlayingQueueActivity;
|
activity.findNavController(R.id.fragment_container).navigate(R.id.lyrics_fragment)
|
||||||
import code.name.monkey.retromusic.activities.PurchaseActivity;
|
}
|
||||||
import code.name.monkey.retromusic.activities.SupportDevelopmentActivity;
|
|
||||||
import code.name.monkey.retromusic.activities.WhatsNewActivity;
|
fun goToProVersion(context: Context) {
|
||||||
import code.name.monkey.retromusic.activities.bugreport.BugReportActivity;
|
ActivityCompat.startActivity(context, Intent(context, PurchaseActivity::class.java), null)
|
||||||
import code.name.monkey.retromusic.fragments.UserInfoFragment;
|
}
|
||||||
import code.name.monkey.retromusic.helper.MusicPlayerRemote;
|
|
||||||
|
fun goToSupportDevelopment(activity: Activity) {
|
||||||
public class NavigationUtil {
|
ActivityCompat.startActivity(
|
||||||
|
activity, Intent(activity, SupportDevelopmentActivity::class.java), null
|
||||||
public static void bugReport(@NonNull Activity activity) {
|
)
|
||||||
ActivityCompat.startActivity(activity, new Intent(activity, BugReportActivity.class), null);
|
}
|
||||||
}
|
|
||||||
|
fun gotoDriveMode(activity: Activity) {
|
||||||
public static void goToLyrics(@NonNull Activity activity) {
|
ActivityCompat.startActivity(
|
||||||
Intent intent = new Intent(activity, LyricsActivity.class);
|
activity,
|
||||||
ActivityCompat.startActivity(activity, intent, null);
|
Intent(activity, DriveModeActivity::class.java),
|
||||||
}
|
null
|
||||||
|
)
|
||||||
public static void goToOpenSource(@NonNull Activity activity) {
|
}
|
||||||
ActivityCompat.startActivity(activity, new Intent(activity, LicenseActivity.class), null);
|
|
||||||
}
|
fun gotoWhatNews(activity: Activity) {
|
||||||
|
ActivityCompat.startActivity(activity, Intent(activity, WhatsNewActivity::class.java), null)
|
||||||
public static void goToPlayingQueue(@NonNull Activity activity) {
|
}
|
||||||
Intent intent = new Intent(activity, PlayingQueueActivity.class);
|
|
||||||
ActivityCompat.startActivity(activity, intent, null);
|
fun openEqualizer(activity: Activity) {
|
||||||
}
|
stockEqalizer(activity)
|
||||||
|
}
|
||||||
public static void goToProVersion(@NonNull Context context) {
|
|
||||||
ActivityCompat.startActivity(context, new Intent(context, PurchaseActivity.class), null);
|
private fun stockEqalizer(activity: Activity) {
|
||||||
}
|
val sessionId = audioSessionId
|
||||||
|
if (sessionId == AudioEffect.ERROR_BAD_VALUE) {
|
||||||
public static void goToSupportDevelopment(@NonNull Activity activity) {
|
Toast.makeText(
|
||||||
ActivityCompat.startActivity(
|
activity, activity.resources.getString(R.string.no_audio_ID), Toast.LENGTH_LONG
|
||||||
activity, new Intent(activity, SupportDevelopmentActivity.class), null);
|
)
|
||||||
}
|
.show()
|
||||||
|
} else {
|
||||||
public static void goToUserInfo(
|
try {
|
||||||
@NonNull Activity activity, @NonNull ActivityOptions activityOptions) {
|
val effects = Intent(AudioEffect.ACTION_DISPLAY_AUDIO_EFFECT_CONTROL_PANEL)
|
||||||
ActivityCompat.startActivity(
|
effects.putExtra(AudioEffect.EXTRA_AUDIO_SESSION, sessionId)
|
||||||
activity, new Intent(activity, UserInfoFragment.class), activityOptions.toBundle());
|
effects.putExtra(AudioEffect.EXTRA_CONTENT_TYPE, AudioEffect.CONTENT_TYPE_MUSIC)
|
||||||
}
|
activity.startActivityForResult(effects, 0)
|
||||||
|
} catch (notFound: ActivityNotFoundException) {
|
||||||
public static void gotoDriveMode(@NotNull final Activity activity) {
|
Toast.makeText(
|
||||||
ActivityCompat.startActivity(activity, new Intent(activity, DriveModeActivity.class), null);
|
activity,
|
||||||
}
|
activity.resources.getString(R.string.no_equalizer),
|
||||||
|
Toast.LENGTH_SHORT
|
||||||
public static void gotoWhatNews(@NonNull Activity activity) {
|
)
|
||||||
ActivityCompat.startActivity(activity, new Intent(activity, WhatsNewActivity.class), null);
|
.show()
|
||||||
}
|
}
|
||||||
|
}
|
||||||
public static void openEqualizer(@NonNull final Activity activity) {
|
|
||||||
stockEqalizer(activity);
|
|
||||||
}
|
|
||||||
|
|
||||||
private static void stockEqalizer(@NonNull Activity activity) {
|
|
||||||
final int sessionId = MusicPlayerRemote.INSTANCE.getAudioSessionId();
|
|
||||||
if (sessionId == AudioEffect.ERROR_BAD_VALUE) {
|
|
||||||
Toast.makeText(
|
|
||||||
activity, activity.getResources().getString(R.string.no_audio_ID), Toast.LENGTH_LONG)
|
|
||||||
.show();
|
|
||||||
} else {
|
|
||||||
try {
|
|
||||||
final Intent effects = new Intent(AudioEffect.ACTION_DISPLAY_AUDIO_EFFECT_CONTROL_PANEL);
|
|
||||||
effects.putExtra(AudioEffect.EXTRA_AUDIO_SESSION, sessionId);
|
|
||||||
effects.putExtra(AudioEffect.EXTRA_CONTENT_TYPE, AudioEffect.CONTENT_TYPE_MUSIC);
|
|
||||||
activity.startActivityForResult(effects, 0);
|
|
||||||
} catch (@NonNull final ActivityNotFoundException notFound) {
|
|
||||||
Toast.makeText(
|
|
||||||
activity,
|
|
||||||
activity.getResources().getString(R.string.no_equalizer),
|
|
||||||
Toast.LENGTH_SHORT)
|
|
||||||
.show();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
|
@ -7,11 +7,10 @@
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:fitsSystemWindows="true">
|
android:fitsSystemWindows="true">
|
||||||
|
|
||||||
<com.google.android.material.bottomappbar.BottomAppBar
|
<com.google.android.material.appbar.AppBarLayout
|
||||||
android:id="@+id/appBarLayout"
|
android:id="@+id/appBarLayout"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_gravity="bottom"
|
|
||||||
android:padding="0dp"
|
android:padding="0dp"
|
||||||
app:contentInsetLeft="0dp"
|
app:contentInsetLeft="0dp"
|
||||||
app:contentInsetStart="0dp"
|
app:contentInsetStart="0dp"
|
||||||
|
@ -39,13 +38,13 @@
|
||||||
tools:subtitle="@tools:sample/full_names"
|
tools:subtitle="@tools:sample/full_names"
|
||||||
tools:title="@tools:sample/full_names" />
|
tools:title="@tools:sample/full_names" />
|
||||||
|
|
||||||
</com.google.android.material.bottomappbar.BottomAppBar>
|
</com.google.android.material.appbar.AppBarLayout>
|
||||||
|
|
||||||
|
|
||||||
<androidx.constraintlayout.widget.ConstraintLayout
|
<androidx.constraintlayout.widget.ConstraintLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:layout_marginBottom="?attr/actionBarSize">
|
android:layout_marginTop="?attr/actionBarSize">
|
||||||
|
|
||||||
<androidx.viewpager2.widget.ViewPager2
|
<androidx.viewpager2.widget.ViewPager2
|
||||||
android:id="@+id/lyricsPager"
|
android:id="@+id/lyricsPager"
|
|
@ -129,4 +129,8 @@
|
||||||
<fragment
|
<fragment
|
||||||
android:id="@+id/playing_queue_fragment"
|
android:id="@+id/playing_queue_fragment"
|
||||||
android:name="code.name.monkey.retromusic.fragments.queue.PlayingQueueFragment" />
|
android:name="code.name.monkey.retromusic.fragments.queue.PlayingQueueFragment" />
|
||||||
|
|
||||||
|
<fragment
|
||||||
|
android:id="@+id/lyrics_fragment"
|
||||||
|
android:name="code.name.monkey.retromusic.fragments.LyricsFragment" />
|
||||||
</navigation>
|
</navigation>
|
Loading…
Reference in a new issue