mirror of
https://github.com/libre-tube/LibreTube.git
synced 2025-01-06 01:20:29 +05:30
commit
c4fdeeb03a
@ -9,15 +9,20 @@ import android.os.Bundle
|
|||||||
import android.os.Environment
|
import android.os.Environment
|
||||||
import android.util.Log
|
import android.util.Log
|
||||||
import android.widget.ArrayAdapter
|
import android.widget.ArrayAdapter
|
||||||
|
import android.widget.Toast
|
||||||
import androidx.core.app.ActivityCompat
|
import androidx.core.app.ActivityCompat
|
||||||
import androidx.fragment.app.DialogFragment
|
import androidx.fragment.app.DialogFragment
|
||||||
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.github.libretube.R
|
import com.github.libretube.R
|
||||||
import com.github.libretube.activities.MainActivity
|
import com.github.libretube.activities.MainActivity
|
||||||
import com.github.libretube.databinding.DialogDownloadBinding
|
import com.github.libretube.databinding.DialogDownloadBinding
|
||||||
import com.github.libretube.obj.Streams
|
import com.github.libretube.obj.Streams
|
||||||
import com.github.libretube.services.DownloadService
|
import com.github.libretube.services.DownloadService
|
||||||
|
import com.github.libretube.util.RetrofitInstance
|
||||||
import com.github.libretube.util.ThemeHelper
|
import com.github.libretube.util.ThemeHelper
|
||||||
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
import com.google.android.material.dialog.MaterialAlertDialogBuilder
|
||||||
|
import retrofit2.HttpException
|
||||||
|
import java.io.IOException
|
||||||
|
|
||||||
class DownloadDialog : DialogFragment() {
|
class DownloadDialog : DialogFragment() {
|
||||||
private val TAG = "DownloadDialog"
|
private val TAG = "DownloadDialog"
|
||||||
@ -29,13 +34,14 @@ class DownloadDialog : DialogFragment() {
|
|||||||
|
|
||||||
override fun onCreateDialog(savedInstanceState: Bundle?): Dialog {
|
override fun onCreateDialog(savedInstanceState: Bundle?): Dialog {
|
||||||
return activity?.let {
|
return activity?.let {
|
||||||
streams = arguments?.getParcelable("streams")!!
|
|
||||||
videoId = arguments?.getString("video_id")!!
|
videoId = arguments?.getString("video_id")!!
|
||||||
|
|
||||||
val mainActivity = activity as MainActivity
|
val mainActivity = activity as MainActivity
|
||||||
val builder = MaterialAlertDialogBuilder(it)
|
val builder = MaterialAlertDialogBuilder(it)
|
||||||
binding = DialogDownloadBinding.inflate(layoutInflater)
|
binding = DialogDownloadBinding.inflate(layoutInflater)
|
||||||
|
|
||||||
|
fetchStreams()
|
||||||
|
|
||||||
// request storage permissions if not granted yet
|
// request storage permissions if not granted yet
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) {
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.R) {
|
||||||
Log.d("myz", "" + Build.VERSION.SDK_INT)
|
Log.d("myz", "" + Build.VERSION.SDK_INT)
|
||||||
@ -70,69 +76,89 @@ class DownloadDialog : DialogFragment() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var vidName = arrayListOf<String>()
|
|
||||||
var vidUrl = arrayListOf<String>()
|
|
||||||
|
|
||||||
// add empty selection
|
|
||||||
vidName.add(getString(R.string.no_video))
|
|
||||||
vidUrl.add("")
|
|
||||||
|
|
||||||
// add all available video streams
|
|
||||||
for (vid in streams.videoStreams!!) {
|
|
||||||
val name = vid.quality + " " + vid.format
|
|
||||||
vidName.add(name)
|
|
||||||
vidUrl.add(vid.url!!)
|
|
||||||
}
|
|
||||||
|
|
||||||
var audioName = arrayListOf<String>()
|
|
||||||
var audioUrl = arrayListOf<String>()
|
|
||||||
|
|
||||||
// add empty selection
|
|
||||||
audioName.add(getString(R.string.no_audio))
|
|
||||||
audioUrl.add("")
|
|
||||||
|
|
||||||
// add all available audio streams
|
|
||||||
for (audio in streams.audioStreams!!) {
|
|
||||||
val name = audio.quality + " " + audio.format
|
|
||||||
audioName.add(name)
|
|
||||||
audioUrl.add(audio.url!!)
|
|
||||||
}
|
|
||||||
|
|
||||||
val videoArrayAdapter = ArrayAdapter(
|
|
||||||
requireContext(),
|
|
||||||
android.R.layout.simple_spinner_item,
|
|
||||||
vidName
|
|
||||||
)
|
|
||||||
videoArrayAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)
|
|
||||||
binding.videoSpinner.adapter = videoArrayAdapter
|
|
||||||
binding.videoSpinner.setSelection(1)
|
|
||||||
|
|
||||||
val audioArrayAdapter = ArrayAdapter(
|
|
||||||
requireContext(),
|
|
||||||
android.R.layout.simple_spinner_item,
|
|
||||||
audioName
|
|
||||||
)
|
|
||||||
audioArrayAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)
|
|
||||||
binding.audioSpinner.adapter = audioArrayAdapter
|
|
||||||
binding.audioSpinner.setSelection(1)
|
|
||||||
|
|
||||||
binding.download.setOnClickListener {
|
|
||||||
val selectedAudioUrl = audioUrl[binding.audioSpinner.selectedItemPosition]
|
|
||||||
val selectedVideoUrl = vidUrl[binding.videoSpinner.selectedItemPosition]
|
|
||||||
|
|
||||||
val intent = Intent(context, DownloadService::class.java)
|
|
||||||
intent.putExtra("videoId", videoId)
|
|
||||||
intent.putExtra("videoUrl", selectedVideoUrl)
|
|
||||||
intent.putExtra("audioUrl", selectedAudioUrl)
|
|
||||||
intent.putExtra("duration", duration)
|
|
||||||
context?.startService(intent)
|
|
||||||
dismiss()
|
|
||||||
}
|
|
||||||
|
|
||||||
binding.title.text = ThemeHelper.getStyledAppName(requireContext())
|
binding.title.text = ThemeHelper.getStyledAppName(requireContext())
|
||||||
|
|
||||||
builder.setView(binding.root)
|
builder.setView(binding.root)
|
||||||
builder.create()
|
builder.create()
|
||||||
} ?: throw IllegalStateException("Activity cannot be null")
|
} ?: throw IllegalStateException("Activity cannot be null")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private fun fetchStreams() {
|
||||||
|
lifecycleScope.launchWhenCreated {
|
||||||
|
val response = try {
|
||||||
|
RetrofitInstance.api.getStreams(videoId!!)
|
||||||
|
} catch (e: IOException) {
|
||||||
|
println(e)
|
||||||
|
Log.e(TAG, "IOException, you might not have internet connection")
|
||||||
|
Toast.makeText(context, R.string.unknown_error, Toast.LENGTH_SHORT).show()
|
||||||
|
return@launchWhenCreated
|
||||||
|
} catch (e: HttpException) {
|
||||||
|
Log.e(TAG, "HttpException, unexpected response")
|
||||||
|
Toast.makeText(context, R.string.server_error, Toast.LENGTH_SHORT).show()
|
||||||
|
return@launchWhenCreated
|
||||||
|
}
|
||||||
|
initDownloadOptions(response)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun initDownloadOptions(streams: Streams) {
|
||||||
|
var vidName = arrayListOf<String>()
|
||||||
|
var vidUrl = arrayListOf<String>()
|
||||||
|
|
||||||
|
// add empty selection
|
||||||
|
vidName.add(getString(R.string.no_video))
|
||||||
|
vidUrl.add("")
|
||||||
|
|
||||||
|
// add all available video streams
|
||||||
|
for (vid in streams.videoStreams!!) {
|
||||||
|
val name = vid.quality + " " + vid.format
|
||||||
|
vidName.add(name)
|
||||||
|
vidUrl.add(vid.url!!)
|
||||||
|
}
|
||||||
|
|
||||||
|
var audioName = arrayListOf<String>()
|
||||||
|
var audioUrl = arrayListOf<String>()
|
||||||
|
|
||||||
|
// add empty selection
|
||||||
|
audioName.add(getString(R.string.no_audio))
|
||||||
|
audioUrl.add("")
|
||||||
|
|
||||||
|
// add all available audio streams
|
||||||
|
for (audio in streams.audioStreams!!) {
|
||||||
|
val name = audio.quality + " " + audio.format
|
||||||
|
audioName.add(name)
|
||||||
|
audioUrl.add(audio.url!!)
|
||||||
|
}
|
||||||
|
|
||||||
|
val videoArrayAdapter = ArrayAdapter(
|
||||||
|
requireContext(),
|
||||||
|
android.R.layout.simple_spinner_item,
|
||||||
|
vidName
|
||||||
|
)
|
||||||
|
videoArrayAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)
|
||||||
|
binding.videoSpinner.adapter = videoArrayAdapter
|
||||||
|
binding.videoSpinner.setSelection(1)
|
||||||
|
|
||||||
|
val audioArrayAdapter = ArrayAdapter(
|
||||||
|
requireContext(),
|
||||||
|
android.R.layout.simple_spinner_item,
|
||||||
|
audioName
|
||||||
|
)
|
||||||
|
audioArrayAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item)
|
||||||
|
binding.audioSpinner.adapter = audioArrayAdapter
|
||||||
|
binding.audioSpinner.setSelection(1)
|
||||||
|
|
||||||
|
binding.download.setOnClickListener {
|
||||||
|
val selectedAudioUrl = audioUrl[binding.audioSpinner.selectedItemPosition]
|
||||||
|
val selectedVideoUrl = vidUrl[binding.videoSpinner.selectedItemPosition]
|
||||||
|
|
||||||
|
val intent = Intent(context, DownloadService::class.java)
|
||||||
|
intent.putExtra("videoId", videoId)
|
||||||
|
intent.putExtra("videoUrl", selectedVideoUrl)
|
||||||
|
intent.putExtra("audioUrl", selectedAudioUrl)
|
||||||
|
intent.putExtra("duration", duration)
|
||||||
|
context?.startService(intent)
|
||||||
|
dismiss()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -774,9 +774,8 @@ class PlayerFragment : Fragment() {
|
|||||||
val newFragment = DownloadDialog()
|
val newFragment = DownloadDialog()
|
||||||
val bundle = Bundle()
|
val bundle = Bundle()
|
||||||
bundle.putString("video_id", videoId)
|
bundle.putString("video_id", videoId)
|
||||||
bundle.putParcelable("streams", response)
|
|
||||||
newFragment.arguments = bundle
|
newFragment.arguments = bundle
|
||||||
newFragment.show(childFragmentManager, "Download")
|
newFragment.show(childFragmentManager, "DownloadDialog")
|
||||||
} else {
|
} else {
|
||||||
Toast.makeText(context, R.string.dlisinprogress, Toast.LENGTH_SHORT)
|
Toast.makeText(context, R.string.dlisinprogress, Toast.LENGTH_SHORT)
|
||||||
.show()
|
.show()
|
||||||
|
@ -1,9 +1,5 @@
|
|||||||
package com.github.libretube.obj
|
package com.github.libretube.obj
|
||||||
|
|
||||||
import android.os.Parcel
|
|
||||||
import android.os.Parcelable
|
|
||||||
import com.fasterxml.jackson.annotation.JsonIgnoreProperties
|
import com.fasterxml.jackson.annotation.JsonIgnoreProperties
|
||||||
|
|
||||||
@JsonIgnoreProperties(ignoreUnknown = true)
|
@JsonIgnoreProperties(ignoreUnknown = true)
|
||||||
data class Streams(
|
data class Streams(
|
||||||
val title: String?,
|
val title: String?,
|
||||||
@ -28,68 +24,9 @@ data class Streams(
|
|||||||
val livestream: Boolean?,
|
val livestream: Boolean?,
|
||||||
val proxyUrl: String?,
|
val proxyUrl: String?,
|
||||||
val chapters: List<ChapterSegment>?
|
val chapters: List<ChapterSegment>?
|
||||||
) : Parcelable {
|
) {
|
||||||
constructor(parcel: Parcel) : this(
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readString(),
|
|
||||||
parcel.readValue(Boolean::class.java.classLoader) as? Boolean,
|
|
||||||
parcel.readValue(Int::class.java.classLoader) as? Int,
|
|
||||||
parcel.readValue(Long::class.java.classLoader) as? Long,
|
|
||||||
parcel.readValue(Long::class.java.classLoader) as? Long,
|
|
||||||
parcel.readValue(Int::class.java.classLoader) as? Long,
|
|
||||||
TODO("audioStreams"),
|
|
||||||
TODO("videoStreams"),
|
|
||||||
TODO("relatedStreams"),
|
|
||||||
TODO("subtitles"),
|
|
||||||
parcel.readValue(Boolean::class.java.classLoader) as? Boolean,
|
|
||||||
parcel.readString(),
|
|
||||||
TODO("chapters")
|
|
||||||
)
|
|
||||||
|
|
||||||
constructor() : this(
|
constructor() : this(
|
||||||
"", "", "", "", "", "", "", "", "", "", null, -1, -1, -1, -1, emptyList(), emptyList(),
|
"", "", "", "", "", "", "", "", "", "", null, -1, -1, -1, -1, emptyList(), emptyList(),
|
||||||
emptyList(), emptyList(), null, "", emptyList()
|
emptyList(), emptyList(), null, "", emptyList()
|
||||||
)
|
)
|
||||||
|
|
||||||
override fun writeToParcel(parcel: Parcel, flags: Int) {
|
|
||||||
parcel.writeString(title)
|
|
||||||
parcel.writeString(description)
|
|
||||||
parcel.writeString(uploadDate)
|
|
||||||
parcel.writeString(uploader)
|
|
||||||
parcel.writeString(uploaderUrl)
|
|
||||||
parcel.writeString(uploaderAvatar)
|
|
||||||
parcel.writeString(thumbnailUrl)
|
|
||||||
parcel.writeString(hls)
|
|
||||||
parcel.writeString(dash)
|
|
||||||
parcel.writeString(lbryId)
|
|
||||||
parcel.writeValue(uploaderVerified)
|
|
||||||
parcel.writeValue(duration)
|
|
||||||
parcel.writeValue(views)
|
|
||||||
parcel.writeValue(likes)
|
|
||||||
parcel.writeValue(dislikes)
|
|
||||||
parcel.writeValue(livestream)
|
|
||||||
parcel.writeString(proxyUrl)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun describeContents(): Int {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
companion object CREATOR : Parcelable.Creator<Streams> {
|
|
||||||
override fun createFromParcel(parcel: Parcel): Streams {
|
|
||||||
return Streams(parcel)
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun newArray(size: Int): Array<Streams?> {
|
|
||||||
return arrayOfNulls(size)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user