mirror of
https://github.com/libre-tube/LibreTube.git
synced 2024-12-16 07:10:29 +05:30
79 lines
3.2 KiB
Kotlin
79 lines
3.2 KiB
Kotlin
package com.github.libretube.dialogs
|
|
|
|
import android.app.Dialog
|
|
import android.content.Context
|
|
import android.os.Bundle
|
|
import android.widget.ArrayAdapter
|
|
import android.widget.Toast
|
|
import androidx.fragment.app.DialogFragment
|
|
import com.github.libretube.R
|
|
import com.github.libretube.preferences.PreferenceHelper
|
|
import com.github.libretube.util.BackgroundMode
|
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
|
|
|
/**
|
|
* Dialog with different options for a selected video.
|
|
*
|
|
* Needs the [videoId] to load the content from the right video.
|
|
*/
|
|
class VideoOptionsDialog(private val videoId: String, context: Context) : DialogFragment() {
|
|
/**
|
|
* List that stores the different menu options. In the future could be add more options here.
|
|
*/
|
|
private val optionsList = listOf(
|
|
context.getString(R.string.playOnBackground),
|
|
context.getString(R.string.addToPlaylist),
|
|
context.getString(R.string.share)
|
|
)
|
|
|
|
/**
|
|
* Dialog that returns a [MaterialAlertDialogBuilder] showing a menu of options.
|
|
*/
|
|
override fun onCreateDialog(savedInstanceState: Bundle?): Dialog {
|
|
return MaterialAlertDialogBuilder(requireContext())
|
|
.setNegativeButton(R.string.cancel) { dialog, _ ->
|
|
dialog.dismiss()
|
|
}
|
|
.setAdapter(
|
|
ArrayAdapter(
|
|
requireContext(),
|
|
R.layout.video_options_dialog_item,
|
|
optionsList
|
|
)
|
|
) { _, which ->
|
|
// For now, this checks the position of the option with the position that is in the
|
|
// list. I don't like it, but we will do like this for now.
|
|
when (optionsList[which]) {
|
|
// This for example will be the "Background mode" option
|
|
context?.getString(R.string.playOnBackground) -> {
|
|
BackgroundMode.getInstance()
|
|
.playOnBackgroundMode(requireContext(), videoId)
|
|
}
|
|
// Add Video to Playlist Dialog
|
|
context?.getString(R.string.addToPlaylist) -> {
|
|
val token = PreferenceHelper.getToken(requireContext())
|
|
if (token != "") {
|
|
val newFragment = AddtoPlaylistDialog()
|
|
val bundle = Bundle()
|
|
bundle.putString("videoId", videoId)
|
|
newFragment.arguments = bundle
|
|
newFragment.show(parentFragmentManager, "AddToPlaylist")
|
|
} else {
|
|
Toast.makeText(context, R.string.login_first, Toast.LENGTH_SHORT).show()
|
|
}
|
|
}
|
|
context?.getString(R.string.share) -> {
|
|
val shareDialog = ShareDialog(videoId, false)
|
|
// using parentFragmentManager is important here
|
|
shareDialog.show(parentFragmentManager, "ShareDialog")
|
|
}
|
|
}
|
|
}
|
|
.show()
|
|
}
|
|
|
|
companion object {
|
|
const val TAG = "VideoOptionsDialog"
|
|
}
|
|
}
|