add subscription info to settings fragment
* update androidx.navigation: 2.3.4 -> 2.3.5
This commit is contained in:
		@ -40,6 +40,7 @@ object AoDParser {
 | 
			
		||||
    private const val baseUrl = "https://www.anime-on-demand.de"
 | 
			
		||||
    private const val loginPath = "/users/sign_in"
 | 
			
		||||
    private const val libraryPath = "/animes"
 | 
			
		||||
    private const val subscriptionPath = "/mypools"
 | 
			
		||||
 | 
			
		||||
    private const val userAgent = "Mozilla/5.0 (X11; Linux x86_64; rv:84.0) Gecko/20100101 Firefox/84.0"
 | 
			
		||||
 | 
			
		||||
@ -117,6 +118,25 @@ object AoDParser {
 | 
			
		||||
        return media
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * get subscription info from aod website, remove "Anime-Abo" Prefix and trim
 | 
			
		||||
     */
 | 
			
		||||
    fun getSubscriptionInfoAsync(): Deferred<String> {
 | 
			
		||||
        return GlobalScope.async(Dispatchers.IO) {
 | 
			
		||||
            // get the subscription page
 | 
			
		||||
            val res = Jsoup.connect(baseUrl + subscriptionPath)
 | 
			
		||||
                .cookies(sessionCookies)
 | 
			
		||||
                .get()
 | 
			
		||||
 | 
			
		||||
            return@async res.select("a:contains(Anime-Abo)").text()
 | 
			
		||||
                .removePrefix("Anime-Abo").trim()
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    fun getSubscriptionUrl(): String {
 | 
			
		||||
        return baseUrl + subscriptionPath
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    fun markAsWatched(mediaId: Int, episodeId: Int) = GlobalScope.launch {
 | 
			
		||||
        val episode = getMediaById(mediaId).getEpisodeById(episodeId)
 | 
			
		||||
        episode.watched = true
 | 
			
		||||
@ -261,6 +281,8 @@ object AoDParser {
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * TODO rework the media loading process, don't modify media object
 | 
			
		||||
     * TODO catch SocketTimeoutException from loading to show a waring dialog
 | 
			
		||||
     * load streams for the media path, movies have one episode
 | 
			
		||||
     * @param media is used as call ba reference
 | 
			
		||||
     */
 | 
			
		||||
 | 
			
		||||
@ -1,5 +1,7 @@
 | 
			
		||||
package org.mosad.teapod.ui.activity.main.fragments
 | 
			
		||||
 | 
			
		||||
import android.content.Intent
 | 
			
		||||
import android.net.Uri
 | 
			
		||||
import android.os.Bundle
 | 
			
		||||
import android.util.Log
 | 
			
		||||
import android.view.LayoutInflater
 | 
			
		||||
@ -8,6 +10,8 @@ import android.view.ViewGroup
 | 
			
		||||
import androidx.fragment.app.Fragment
 | 
			
		||||
import com.afollestad.materialdialogs.MaterialDialog
 | 
			
		||||
import com.afollestad.materialdialogs.list.listItemsSingleChoice
 | 
			
		||||
import kotlinx.coroutines.GlobalScope
 | 
			
		||||
import kotlinx.coroutines.launch
 | 
			
		||||
import org.mosad.teapod.BuildConfig
 | 
			
		||||
import org.mosad.teapod.ui.activity.main.MainActivity
 | 
			
		||||
import org.mosad.teapod.R
 | 
			
		||||
@ -31,6 +35,15 @@ class AccountFragment : Fragment() {
 | 
			
		||||
    override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
 | 
			
		||||
        super.onViewCreated(view, savedInstanceState)
 | 
			
		||||
 | 
			
		||||
        // load subscription (async) info before anything else
 | 
			
		||||
        binding.textAccountSubscription.text = getString(R.string.account_subscription, getString(R.string.loading))
 | 
			
		||||
        GlobalScope.launch {
 | 
			
		||||
            binding.textAccountSubscription.text = getString(
 | 
			
		||||
                R.string.account_subscription,
 | 
			
		||||
                AoDParser.getSubscriptionInfoAsync().await()
 | 
			
		||||
            )
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        binding.textAccountLogin.text = EncryptedPreferences.login
 | 
			
		||||
        binding.textInfoAboutDesc.text = getString(R.string.info_about_desc, BuildConfig.VERSION_NAME, getString(R.string.build_time))
 | 
			
		||||
        binding.textThemeSelected.text = when (Preferences.theme) {
 | 
			
		||||
@ -49,6 +62,10 @@ class AccountFragment : Fragment() {
 | 
			
		||||
            showLoginDialog(true)
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        binding.linearAccountSubscription.setOnClickListener {
 | 
			
		||||
            startActivity(Intent(Intent.ACTION_VIEW, Uri.parse(AoDParser.getSubscriptionUrl())))
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        binding.linearTheme.setOnClickListener {
 | 
			
		||||
            showThemeDialog()
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user