PlayerAndroid/app/src/main/java/code/name/monkey/retromusic/dialogs/CreatePlaylistDialog.kt

75 lines
3.2 KiB
Kotlin
Raw Normal View History

package code.name.monkey.retromusic.dialogs
2019-05-15 20:55:57 +00:00
import android.app.Dialog
import android.os.Bundle
2020-05-23 21:47:23 +00:00
import android.text.TextUtils
import android.view.LayoutInflater
2020-09-05 18:24:05 +00:00
import android.widget.Toast
import androidx.core.os.bundleOf
2019-05-15 20:55:57 +00:00
import androidx.fragment.app.DialogFragment
2020-09-05 18:24:05 +00:00
import androidx.lifecycle.lifecycleScope
2020-05-23 22:26:45 +00:00
import code.name.monkey.retromusic.EXTRA_SONG
import code.name.monkey.retromusic.R
2020-09-05 18:24:05 +00:00
import code.name.monkey.retromusic.db.PlaylistEntity
2020-09-18 11:01:55 +00:00
import code.name.monkey.retromusic.db.toSongEntity
2020-07-19 11:21:15 +00:00
import code.name.monkey.retromusic.extensions.colorButtons
2020-09-05 19:11:48 +00:00
import code.name.monkey.retromusic.extensions.extra
2020-07-19 14:39:04 +00:00
import code.name.monkey.retromusic.extensions.materialDialog
2020-09-05 18:24:05 +00:00
import code.name.monkey.retromusic.fragments.LibraryViewModel
import code.name.monkey.retromusic.fragments.ReloadType.Playlists
import code.name.monkey.retromusic.model.Song
2019-05-15 20:55:57 +00:00
import com.google.android.material.textfield.TextInputEditText
import com.google.android.material.textfield.TextInputLayout
2020-05-23 22:26:45 +00:00
import kotlinx.android.synthetic.main.dialog_playlist.view.*
2020-09-05 18:24:05 +00:00
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch
import org.koin.androidx.viewmodel.ext.android.sharedViewModel
2019-05-15 20:55:57 +00:00
class CreatePlaylistDialog : DialogFragment() {
2020-09-05 18:24:05 +00:00
private val libraryViewModel by sharedViewModel<LibraryViewModel>()
companion object {
fun create(song: Song): CreatePlaylistDialog {
val list = mutableListOf<Song>()
list.add(song)
return create(list)
}
fun create(songs: List<Song>): CreatePlaylistDialog {
return CreatePlaylistDialog().apply {
arguments = bundleOf(EXTRA_SONG to songs)
}
}
}
2019-05-15 20:55:57 +00:00
2020-09-05 18:24:05 +00:00
override fun onCreateDialog(savedInstanceState: Bundle?): Dialog {
2020-05-23 21:47:23 +00:00
val view = LayoutInflater.from(requireActivity()).inflate(R.layout.dialog_playlist, null)
2020-09-05 19:11:48 +00:00
val songs: List<Song> = extra<List<Song>>(EXTRA_SONG).value ?: emptyList()
2020-05-23 22:26:45 +00:00
val playlistView: TextInputEditText = view.actionNewPlaylist
val playlistContainer: TextInputLayout = view.actionNewPlaylistContainer
2020-07-19 14:39:04 +00:00
return materialDialog(R.string.new_playlist_title)
2020-05-23 21:47:23 +00:00
.setView(view)
.setPositiveButton(
R.string.create_action
) { _, _ ->
val playlistName = playlistView.text.toString()
if (!TextUtils.isEmpty(playlistName)) {
2020-09-05 18:24:05 +00:00
lifecycleScope.launch(Dispatchers.IO) {
2020-09-05 20:13:45 +00:00
if (libraryViewModel.checkPlaylistExists(playlistName).isEmpty()) {
val playlistId: Long =
libraryViewModel.createPlaylist(PlaylistEntity(playlistName = playlistName))
libraryViewModel.insertSongs(songs.map { it.toSongEntity(playlistId) })
2020-09-05 18:24:05 +00:00
libraryViewModel.forceReload(Playlists)
} else {
Toast.makeText(requireContext(), "Playlist exists", Toast.LENGTH_SHORT)
.show()
}
2019-05-15 20:55:57 +00:00
}
2020-09-05 18:24:05 +00:00
} else {
playlistContainer.error = "Playlist is can't be empty"
2019-05-15 20:55:57 +00:00
}
2020-02-19 07:08:12 +00:00
}
2020-05-23 21:47:23 +00:00
.create()
2020-07-19 11:21:15 +00:00
.colorButtons()
2020-05-23 21:47:23 +00:00
}
}