Compare commits

..

3 Commits

Author SHA1 Message Date
yuyl
e1dd2d7497 veloria three 6.25 commit 2025-06-25 09:42:04 +08:00
yuyl
28b91d8412 veloria three 6.17 commit 2025-06-17 14:41:03 +08:00
yuyl
a004e34e05 veloria three 6.16 commit 2025-06-16 17:33:44 +08:00
124 changed files with 6801 additions and 2675 deletions

View File

@ -4,6 +4,9 @@ import java.util.Date
plugins { plugins {
alias(libs.plugins.android.application) alias(libs.plugins.android.application)
alias(libs.plugins.kotlin.android) alias(libs.plugins.kotlin.android)
id("com.google.gms.google-services")
id("com.google.firebase.crashlytics")
id("com.google.firebase.firebase-perf")
} }
android { android {
@ -14,8 +17,8 @@ android {
applicationId = "com.veloria.now.shortapp" applicationId = "com.veloria.now.shortapp"
minSdk = 24 minSdk = 24
targetSdk = 34 targetSdk = 34
versionCode = 5 versionCode = 8
versionName = "1.0.4" versionName = "1.0.6"
testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
} }
@ -98,9 +101,11 @@ dependencies {
implementation(libs.kotlinx.coroutines.android) implementation(libs.kotlinx.coroutines.android)
implementation(libs.baserecyclerviewadapterhelper4) implementation(libs.baserecyclerviewadapterhelper4)
// banner // banner
implementation(libs.banner) implementation(libs.banner)
implementation(libs.glide) implementation(libs.glide)
implementation(libs.bannerviewpager)
//utils //utils
implementation(libs.greenrobot.eventbus) implementation(libs.greenrobot.eventbus)
@ -134,4 +139,13 @@ dependencies {
//billing //billing
implementation(libs.billing) implementation(libs.billing)
//google
implementation(platform("com.google.firebase:firebase-bom:32.3.1"))
implementation(libs.firebase.messaging.ktx)
implementation(libs.androidx.work.runtime.ktx)
implementation(libs.firebase.analytics.ktx)
implementation(libs.firebase.crashlytics)
implementation(libs.firebase.perf)
implementation(libs.flexbox)
} }

View File

@ -284,3 +284,40 @@
-keep class com.android.billingclient.api.** { *; } -keep class com.android.billingclient.api.** { *; }
-keep class com.gytv.app.ui.data.**{ *; } -keep class com.gytv.app.ui.data.**{ *; }
-keep class com.adjust.sdk.** { *; }
-keep class com.google.android.gms.common.ConnectionResult {
int SUCCESS;
}
-keep class com.google.android.gms.ads.identifier.AdvertisingIdClient {
com.google.android.gms.ads.identifier.AdvertisingIdClient$Info getAdvertisingIdInfo(android.content.Context);
}
-keep class com.google.android.gms.ads.identifier.AdvertisingIdClient$Info {
java.lang.String getId();
boolean isLimitAdTrackingEnabled();
}
-keep public class com.android.installreferrer.** { *; }
-keep class com.wang.avi.** { *; }
-keep class com.wang.avi.indicators.** { *; }
-keep class com.bytedance.sdk.** { *; }
-keep public class com.google.android.gms.** { public protected *; }
-keepattributes SourceFile,LineNumberTable # Keep file names and line numbers.
-keep public class * extends java.lang.Exception # Optional: Keep custom exceptions.
-keep class android.support.v8.renderscript.** { *; }
-keep class androidx.renderscript.** { *; }
#unity
-keep class com.google.android.gms.ads.** {public *;}
-keep class com.google.android.gms.appset.** { *; }
-keep class com.google.android.gms.tasks.** { *; }
-keep class androidx.recyclerview.widget.**{*;}
-keep class androidx.viewpager2.widget.**{*;}

View File

@ -9,7 +9,6 @@
<uses-permission android:name="android.permission.READ_MEDIA_IMAGES" /> <uses-permission android:name="android.permission.READ_MEDIA_IMAGES" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<application <application
android:name=".newsletter.XNBackground" android:name=".newsletter.XNBackground"
android:allowBackup="true" android:allowBackup="true"
@ -89,6 +88,23 @@
</intent-filter> </intent-filter>
</activity> </activity>
<meta-data
android:name="com.google.firebase.messaging.default_notification_icon"
android:resource="@mipmap/ic_launcher" />
<meta-data
android:name="com.google.firebase.messaging.default_notification_color"
android:resource="@color/black" />
<meta-data
android:name="com.google.firebase.messaging.default_notification_channel_id"
android:value="@string/default_notification_channel_id" />
<service
android:name="com.veloria.now.shortapp.other.MyFirebaseMessagingService"
android:exported="false">
<intent-filter>
<action android:name="com.google.firebase.MESSAGING_EVENT" />
</intent-filter>
</service>
</application> </application>
</manifest> </manifest>

View File

@ -77,7 +77,7 @@ object JActivityAdapter {
const val FEEDBACK_URL_INDEX: String = "https://campaign.qjwl168.com/pages/leave/index" const val FEEDBACK_URL_INDEX: String = "https://campaign.qjwl168.com/pages/leave/index"
const val FEEDBACK_URL_LIST: String = "https://campaign.qjwl168.com/pages/leave/list" const val FEEDBACK_URL_LIST: String = "https://campaign.qjwl168.com/pages/leave/list"
const val FEEDBACK_URL_DETAIL: String = "https://campaign.qjwl168.com/pages/leave/detail" const val FEEDBACK_URL_DETAIL: String = "https://campaign.qjwl168.com/pages/leave/detail"
const val REWARDS_URL_DETAIL: String = "https://campaign.qjwl168.com/pages/luckydraw/index" const val REWARDS_URL_DETAIL: String = "https://campaign.qjwl168.com/pages/reward/theme4"
const val FEEDBACK_REQUEST_PERMISSIONS_PHOTO = "FEEDBACK_REQUEST_PERMISSIONS_PHOTO" const val FEEDBACK_REQUEST_PERMISSIONS_PHOTO = "FEEDBACK_REQUEST_PERMISSIONS_PHOTO"
const val FEEDBACK_REQUEST_PERMISSIONS_PHOTO_DETAIL = "FEEDBACK_REQUEST_PERMISSIONS_PHOTO_DETAIL" const val FEEDBACK_REQUEST_PERMISSIONS_PHOTO_DETAIL = "FEEDBACK_REQUEST_PERMISSIONS_PHOTO_DETAIL"
@ -93,6 +93,7 @@ object JActivityAdapter {
const val HOME_USER_REFRESH = "HOME_USER_REFRESH" const val HOME_USER_REFRESH = "HOME_USER_REFRESH"
const val HOME_REFRESH_ME = "HOME_REFRESH_ME" const val HOME_REFRESH_ME = "HOME_REFRESH_ME"
const val HOME_LOGIN = "HOME_LOGIN" const val HOME_LOGIN = "HOME_LOGIN"
const val REWARD_LOGIN = "REWARD_LOGIN"
const val HOME_LEAVE_APP = "HOME_LEAVE_APP" const val HOME_LEAVE_APP = "HOME_LEAVE_APP"
const val HOME_ON_LINE = "HOME_ON_LINE" const val HOME_ON_LINE = "HOME_ON_LINE"
const val HOME_DDL_URL = "HOME_DDL_URL" const val HOME_DDL_URL = "HOME_DDL_URL"
@ -101,9 +102,23 @@ object JActivityAdapter {
const val HOME_TYPE_MORE_STATE = "HOME_TYPE_MORE_STATE" const val HOME_TYPE_MORE_STATE = "HOME_TYPE_MORE_STATE"
const val HOME_TYPE_MORE_DATA = "HOME_TYPE_MORE_DATA" const val HOME_TYPE_MORE_DATA = "HOME_TYPE_MORE_DATA"
var IS_HOME_SET_NOTIFICATIONS: Boolean = false
const val LANGUAGE_TRANSLATES_STRING = "LANGUAGE_TRANSLATES_STRING" const val LANGUAGE_TRANSLATES_STRING = "LANGUAGE_TRANSLATES_STRING"
const val PAY_ORDER_PAY_BEAN = "PAY_ORDER_PAY_BEAN" const val PAY_ORDER_PAY_BEAN = "PAY_ORDER_PAY_BEAN"
const val ACCOUNT_DIALOG_TIME_VIP_SPLASH = "ACCOUNT_DIALOG_TIME_VIP_SPLASH"
const val ONE_DAY_IN_MILLIS_VIP = 60 * 60 * 1000L
const val ACCOUNT_VERSION_CONTROL_TIME =
"ACCOUNT_VERSION_CONTROL_TIME"
const val ACCOUNT_DIALOG_TIME_NOTIFICATIONS =
"ACCOUNT_DIALOG_TIME_NOTIFICATIONS"
const val ONE_DAY_IN_MILLIS_DAY = 24 * 60 * 60 * 1000L
const val ACCOUNT_FIREBASE_TOKEN_REFRESH = "ACCOUNT_FIREBASE_TOKEN_REFRESH"
const val ACCOUNT_WEB_NOTIFICATION = "ACCOUNT_WEB_NOTIFICATION"
} }

View File

@ -6,6 +6,7 @@ import android.os.Handler
import android.os.Looper import android.os.Looper
import android.widget.Toast import android.widget.Toast
import androidx.annotation.RequiresApi import androidx.annotation.RequiresApi
import com.veloria.now.shortapp.civil.JActivityAdapter.ONE_DAY_IN_MILLIS_DAY
import com.veloria.now.shortapp.newsletter.XNBackground import com.veloria.now.shortapp.newsletter.XNBackground
import java.text.SimpleDateFormat import java.text.SimpleDateFormat
import java.time.Duration import java.time.Duration
@ -620,3 +621,27 @@ fun formatNumber(num: Int): String {
else -> num.toString() else -> num.toString()
} }
} }
fun setShowVIPSlash(): Boolean {
val lastTime =
RYAction.getMMKV().getLong(JActivityAdapter.ACCOUNT_DIALOG_TIME_VIP_SPLASH, 0)
val currentTime = System.currentTimeMillis()
return currentTime - lastTime > JActivityAdapter.ONE_DAY_IN_MILLIS_VIP
}
fun setShowNotifications(): Boolean {
val lastTime =
RYAction.getMMKV().getLong(JActivityAdapter.ACCOUNT_DIALOG_TIME_NOTIFICATIONS, 0)
val currentTime = System.currentTimeMillis()
return currentTime - lastTime > JActivityAdapter.ONE_DAY_IN_MILLIS_DAY
}
fun shouldVersionControl(): Boolean {
val lastPopupTime = RYAction.getMMKV().getLong(JActivityAdapter.ACCOUNT_VERSION_CONTROL_TIME, 0)
val currentTime = System.currentTimeMillis()
return currentTime - lastPopupTime > ONE_DAY_IN_MILLIS_DAY
}

View File

@ -474,19 +474,12 @@ object RYAction {
fun saveOrder(payReq: VePayBean) { fun saveOrder(payReq: VePayBean) {
val list = getOrder() val list = getOrder()
if (!list.contains(payReq)) { if (!list.contains(payReq) && payReq.order_code.isNotEmpty()) {
list.add(payReq) list.add(payReq)
} }
val toJson = Gson().toJson(list) val toJson = Gson().toJson(list)
getMMKV().putString(JActivityAdapter.PAY_ORDER_PAY_BEAN, toJson) getMMKV().putString(JActivityAdapter.PAY_ORDER_PAY_BEAN, toJson)
} }
fun removeOrder(payReq: VePayBean?) {
val updatedList = getOrder().filterNot { it == payReq }
getMMKV().putString(
JActivityAdapter.PAY_ORDER_PAY_BEAN,
Gson().toJson(updatedList)
)
}
fun removeOrderString(order: String) { fun removeOrderString(order: String) {
val updatedList = getOrder().filterNot { it.order_code == order } val updatedList = getOrder().filterNot { it.order_code == order }

View File

@ -21,7 +21,6 @@ object TranslationHelper {
return Gson().fromJson(string, VeTranslationBean.Translation::class.java) return Gson().fromJson(string, VeTranslationBean.Translation::class.java)
} }
fun replaces(string: String, new1: String, new2: String): String { fun replaces(string: String, new1: String, new2: String): String {
val replace = string.replace("##", new1) val replace = string.replace("##", new1)
return replace.replace("#1#", new2) return replace.replace("#1#", new2)

View File

@ -0,0 +1,41 @@
package com.veloria.now.shortapp.civil
import android.app.Activity
import android.app.NotificationManager
import android.content.Context
import android.content.Intent
import android.net.Uri
import android.os.Build
object VeNotificationHelper {
const val VE_NOTIFICATION_REQUEST_CODE: Int = 4001
fun isNotification(context: Context): Boolean {
val manager =
context.getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
return if (Build.VERSION.SDK_INT < Build.VERSION_CODES.N) {
true
} else {
manager.areNotificationsEnabled()
}
}
fun setNotification(context: Activity) {
val intent = Intent()
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
intent.action = "android.settings.APP_NOTIFICATION_SETTINGS"
intent.putExtra(
"android.provider.extra.APP_PACKAGE",
YFHome.getPackageName()
)
context.startActivityForResult(intent, VE_NOTIFICATION_REQUEST_CODE)
} else {
intent.action = "android.settings.APPLICATION_DETAILS_SETTINGS"
intent.data =
Uri.fromParts("package", YFHome.getPackageName(), null)
context.startActivityForResult(intent, VE_NOTIFICATION_REQUEST_CODE)
}
}
}

File diff suppressed because it is too large Load Diff

View File

@ -22,10 +22,15 @@ import com.veloria.now.shortapp.texturedAsink.VeCustomerOrderBean
import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean
import com.veloria.now.shortapp.texturedAsink.VeNoticeNumBean import com.veloria.now.shortapp.texturedAsink.VeNoticeNumBean
import com.veloria.now.shortapp.texturedAsink.VePayBean import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePayResBean
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
import com.veloria.now.shortapp.texturedAsink.VeRevolutionsBean
import com.veloria.now.shortapp.texturedAsink.VeRewardCoinsBean import com.veloria.now.shortapp.texturedAsink.VeRewardCoinsBean
import com.veloria.now.shortapp.texturedAsink.VeTranslationBean import com.veloria.now.shortapp.texturedAsink.VeTranslationBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationDataBean
import com.veloria.now.shortapp.texturedAsink.VeW2aSelfAttributionBean import com.veloria.now.shortapp.texturedAsink.VeW2aSelfAttributionBean
import com.veloria.now.shortapp.texturedAsink.VersionControlBean
import com.veloria.now.shortapp.texturedAsink.XAboutBean import com.veloria.now.shortapp.texturedAsink.XAboutBean
import retrofit2.Call import retrofit2.Call
import retrofit2.http.Body import retrofit2.http.Body
@ -108,7 +113,6 @@ interface BIFBase {
@GET("customer/info") @GET("customer/info")
fun getUserInfo(): Call<TStore<KFAFavoritesInterceptorBean>> fun getUserInfo(): Call<TStore<KFAFavoritesInterceptorBean>>
@POST("uploadHistorySeconds") @POST("uploadHistorySeconds")
fun getUploadHistorySeconds( fun getUploadHistorySeconds(
@Body uploadVideoHistoryBean: PURLockBean @Body uploadVideoHistoryBean: PURLockBean
@ -222,7 +226,35 @@ interface BIFBase {
): Call<TStore<VeCreatePayOrderBean>> ): Call<TStore<VeCreatePayOrderBean>>
@POST("googlePaid") @POST("googlePaid")
fun setGooglePaid(@Body vePayBean: VePayBean?): Call<TStore<VePayBean>> fun setGooglePaid(@Body vePayBean: VePayBean?): Call<TStore<VePayResBean>>
@GET("getRevolutions")
fun getRevolutions(
): Call<TStore<VeRevolutionsBean>>
@POST("customer/uploadNoticeStatus")
fun setUploadNoticeStatus(
@Body veUploadNotificationBean: VeUploadNotificationBean
): Call<TStore<VeUploadNotificationDataBean>>
@FormUrlEncoded
@POST("customer/firebaseToken")
fun setFirebaseToken(
@Field("fcm_token") fcm_token: String
): Call<TStore<Any>>
@POST("openNotify")
fun setOpenNotify(
): Call<TStore<Any>>
@FormUrlEncoded
@POST("message/sendReport")
fun setSendReport(
@Field("message_id") message_id: String,
@Field("title") title: String
): Call<TStore<Any>>
@GET("customer/versionControl")
fun getVersionControl(): Call<TStore<VersionControlBean>>
} }

View File

@ -1,17 +1,12 @@
package com.veloria.now.shortapp.highbits package com.veloria.now.shortapp.highbits
import android.os.Build
import android.util.Log import android.util.Log
import androidx.lifecycle.LiveData import androidx.lifecycle.LiveData
import androidx.lifecycle.liveData import androidx.lifecycle.liveData
import com.veloria.now.shortapp.newsletter.XNBackground.Companion.instance import com.tencent.mmkv.BuildConfig
import com.veloria.now.shortapp.newsletter.TStore
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.JActivityAdapter.BASE_URL import com.veloria.now.shortapp.civil.JActivityAdapter.BASE_URL
import com.veloria.now.shortapp.civil.YFHome import com.veloria.now.shortapp.newsletter.TStore
import com.tencent.mmkv.BuildConfig
import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.getCurrentTimeZone
import kotlinx.coroutines.DelicateCoroutinesApi import kotlinx.coroutines.DelicateCoroutinesApi
import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.GlobalScope import kotlinx.coroutines.GlobalScope
@ -25,24 +20,24 @@ import retrofit2.Callback
import retrofit2.Response import retrofit2.Response
import retrofit2.Retrofit import retrofit2.Retrofit
import retrofit2.converter.gson.GsonConverterFactory import retrofit2.converter.gson.GsonConverterFactory
import java.nio.charset.StandardCharsets
import java.util.concurrent.TimeUnit import java.util.concurrent.TimeUnit
import java.util.regex.Pattern
import kotlin.coroutines.resume import kotlin.coroutines.resume
import kotlin.coroutines.resumeWithException import kotlin.coroutines.resumeWithException
import kotlin.coroutines.suspendCoroutine import kotlin.coroutines.suspendCoroutine
import java.nio.charset.StandardCharsets
import java.util.regex.Pattern
import kotlin.math.min
import kotlin.math.max
@Volatile @Volatile
private var pagerLogoAndroid_mark: Int = 3503 private var pagerLogoAndroid_mark: Int = 3503
@Volatile @Volatile
var listenerFree_sum: Long = 8777L var listenerFree_sum: Long = 8777L
@Volatile @Volatile
private var seekAnimatingList: MutableList<Double> = mutableListOf<Double>() private var seekAnimatingList: MutableList<Double> = mutableListOf<Double>()
@Volatile @Volatile
var vipTransparentExpanded_str: String = "printout" var vipTransparentExpanded_str: String = "printout"
internal object RGJCollectionSurfaceAfterRecent { internal object RGJCollectionSurfaceAfterRecent {
@ -73,33 +68,36 @@ internal object RGJCollectionSurfaceAfterRecent {
} }
object QGift { object QGift {
@Volatile @Volatile
var durationBuy_Array: MutableList<Boolean> = mutableListOf<Boolean>() var durationBuy_Array: MutableList<Boolean> = mutableListOf<Boolean>()
@Volatile
@Volatile
var visibleImgWorkStr: String = "yuvplane" var visibleImgWorkStr: String = "yuvplane"
@Volatile
@Volatile
var requestLeft_mark: Int = 5228 var requestLeft_mark: Int = 5228
private val client by lazy { private val client by lazy {
var started6:Double = 8100.0 var started6: Double = 8100.0
if (started6 == 170.0) {} if (started6 == 170.0) {
}
OkHttpClient.Builder() OkHttpClient.Builder()
.connectTimeout(30, TimeUnit.SECONDS) .connectTimeout(30, TimeUnit.SECONDS)
.readTimeout(30, TimeUnit.SECONDS) .readTimeout(30, TimeUnit.SECONDS)
.writeTimeout(30, TimeUnit.SECONDS) .writeTimeout(30, TimeUnit.SECONDS)
.addInterceptor(DExtraction())
.addInterceptor(clearBlack) .addInterceptor(clearBlack)
.addInterceptor(XGradleCategories()) .addInterceptor(XGradleCategories())
.addInterceptor(DExtraction())
.addInterceptor(HttpLoggingInterceptor().apply { .addInterceptor(HttpLoggingInterceptor().apply {
var userL:MutableList<String> = mutableListOf<String>() var userL: MutableList<String> = mutableListOf<String>()
userL.add("reel") userL.add("reel")
userL.add("convert") userL.add("convert")
while (userL.size > 44) { break } while (userL.size > 44) {
break
}
level = if (BuildConfig.DEBUG) level = if (BuildConfig.DEBUG)
@ -112,8 +110,10 @@ object QGift {
} }
val apiService: BIFBase by lazy { val apiService: BIFBase by lazy {
var l_heightF:Int = 4538 var l_heightF: Int = 4538
while (l_heightF < 88) { break } while (l_heightF < 88) {
break
}
Retrofit.Builder() Retrofit.Builder()
@ -126,33 +126,37 @@ object QGift {
private val interceptorCheckbox: Retrofit private val interceptorCheckbox: Retrofit
public fun verticalPriceDimensionHistory(seriesRemove: Int, lightModule: Long, stayCut: Double) :Int { public fun verticalPriceDimensionHistory(
var playfairSize_7:Boolean = true seriesRemove: Int,
lightModule: Long,
stayCut: Double
): Int {
var playfairSize_7: Boolean = true
var blackArrangement = 2123.0f var blackArrangement = 2123.0f
var trendMax_9 = 3883.0 var trendMax_9 = 3883.0
var integerifyQuerySubmodels:Int = 9924 var integerifyQuerySubmodels: Int = 9924
playfairSize_7 = true playfairSize_7 = true
integerifyQuerySubmodels *= if(playfairSize_7) 38 else 16 integerifyQuerySubmodels *= if (playfairSize_7) 38 else 16
blackArrangement += 9356.0f blackArrangement += 9356.0f
trendMax_9 = 6295.0 trendMax_9 = 6295.0
return integerifyQuerySubmodels return integerifyQuerySubmodels
} }
fun <T> handleData(apiCall: suspend () -> TStore<T>): LiveData<Result<TStore<T>>> { fun <T> handleData(apiCall: suspend () -> TStore<T>): LiveData<Result<TStore<T>>> {
var strtollBitizen:Int = this.verticalPriceDimensionHistory(2818,772L,1390.0) var strtollBitizen: Int = this.verticalPriceDimensionHistory(2818, 772L, 1390.0)
if (strtollBitizen >= 66) { if (strtollBitizen >= 66) {
println(strtollBitizen) println(strtollBitizen)
} }
println(strtollBitizen) println(strtollBitizen)
var systeml:MutableMap<String,Long> = mutableMapOf<String,Long>() var systeml: MutableMap<String, Long> = mutableMapOf<String, Long>()
systeml.put("swapper", 705L) systeml.put("swapper", 705L)
systeml.put("cbrt", 676L) systeml.put("cbrt", 676L)
systeml.put("affinity", 224L) systeml.put("affinity", 224L)
@ -161,7 +165,7 @@ println(strtollBitizen)
systeml.put("decbn", 361L) systeml.put("decbn", 361L)
this.durationBuy_Array = mutableListOf<Boolean>() this.durationBuy_Array = mutableListOf<Boolean>()
this.visibleImgWorkStr = "subsamp" this.visibleImgWorkStr = "subsamp"
@ -169,44 +173,54 @@ this.durationBuy_Array = mutableListOf<Boolean>()
return liveData(Dispatchers.IO) { return liveData(Dispatchers.IO) {
var gradlewY:String = "cuvid" var gradlewY: String = "cuvid"
if (gradlewY.length > 73) {} if (gradlewY.length > 73) {
}
println(gradlewY) println(gradlewY)
val result = try { val result = try {
var playfairr:Boolean = true var playfairr: Boolean = true
if (!playfairr) {} if (!playfairr) {
}
println(playfairr) println(playfairr)
var applicationc:String = "growing" var applicationc: String = "growing"
while (applicationc.length > 123) { break } while (applicationc.length > 123) {
break
}
println(applicationc) println(applicationc)
val offsetd = apiCall.invoke() val offsetd = apiCall.invoke()
var activej:Int = 9413 var activej: Int = 9413
while (activej <= 84) { break } while (activej <= 84) {
break
}
println(activej) println(activej)
if (offsetd.code == 200) { if (offsetd.code == 200) {
var cloudc:Boolean = false var cloudc: Boolean = false
Result.success(offsetd) Result.success(offsetd)
} else { } else {
var colorsq:Float = 9972.0f var colorsq: Float = 9972.0f
while (colorsq == 76.0f) { break } while (colorsq == 76.0f) {
break
}
println(colorsq) println(colorsq)
Result.failure(RuntimeException("Result failure")) Result.failure(RuntimeException("Result failure"))
} }
} catch (e: Exception) { } catch (e: Exception) {
var lifecyclev:Int = 6918 var lifecyclev: Int = 6918
while (lifecyclev > 162) { break } while (lifecyclev > 162) {
break
}
Result.failure(e) Result.failure(e)
@ -214,6 +228,7 @@ this.durationBuy_Array = mutableListOf<Boolean>()
emit(result) emit(result)
} }
} }
private val clearBlack = HttpLoggingInterceptor() private val clearBlack = HttpLoggingInterceptor()
private const val while_7Scheme = 2000L private const val while_7Scheme = 2000L
private var type__kService: Long = 0L private var type__kService: Long = 0L
@ -221,19 +236,22 @@ this.durationBuy_Array = mutableListOf<Boolean>()
private val activeColor = Any() private val activeColor = Any()
init { init {
var buttonS:MutableMap<String,Double> = mutableMapOf<String,Double>() var buttonS: MutableMap<String, Double> = mutableMapOf<String, Double>()
buttonS.put("radfg", 308.0) buttonS.put("radfg", 308.0)
buttonS.put("origins", 531.0) buttonS.put("origins", 531.0)
buttonS.put("albums", 618.0) buttonS.put("albums", 618.0)
buttonS.put("temp", 939.0) buttonS.put("temp", 939.0)
buttonS.put("hypotheses", 893.0) buttonS.put("hypotheses", 893.0)
buttonS.put("memorybarrier", 290.0) buttonS.put("memorybarrier", 290.0)
while (buttonS.size > 26) { break } while (buttonS.size > 26) {
break
}
clearBlack.level = HttpLoggingInterceptor.Level.BODY clearBlack.level = HttpLoggingInterceptor.Level.BODY
var deletes1:Long = 9049L var deletes1: Long = 9049L
if (deletes1 == 128L) {} if (deletes1 == 128L) {
}
val okHttpClient = OkHttpClient.Builder().connectTimeout(30, TimeUnit.SECONDS) val okHttpClient = OkHttpClient.Builder().connectTimeout(30, TimeUnit.SECONDS)
@ -242,8 +260,10 @@ this.durationBuy_Array = mutableListOf<Boolean>()
.addInterceptor(XGradleCategories()) .addInterceptor(XGradleCategories())
.addInterceptor(DExtraction()) .addInterceptor(DExtraction())
.build() .build()
var navigatey:Long = 6330L var navigatey: Long = 6330L
while (navigatey < 83L) { break } while (navigatey < 83L) {
break
}
println(navigatey) println(navigatey)
@ -269,47 +289,66 @@ this.durationBuy_Array = mutableListOf<Boolean>()
} }
public fun layoutListenerLoadFavoriteResponseProgress() :Long { public fun layoutListenerLoadFavoriteResponseProgress(): Long {
var paddingForeground:Int = 6984 var paddingForeground: Int = 6984
var playerResource = 3187.0 var playerResource = 3187.0
var playAgreement:MutableList<Boolean> = mutableListOf<Boolean>() var playAgreement: MutableList<Boolean> = mutableListOf<Boolean>()
var activityGradle:MutableMap<String,String> = mutableMapOf<String,String>() var activityGradle: MutableMap<String, String> = mutableMapOf<String, String>()
var unrefcountHeavyLoudspeaker:Long = 6413L var unrefcountHeavyLoudspeaker: Long = 6413L
paddingForeground += 5851 paddingForeground += 5851
playerResource -= 1555.0 playerResource -= 1555.0
return unrefcountHeavyLoudspeaker return unrefcountHeavyLoudspeaker
} }
fun getUserAgent(): String { fun getUserAgent(): String {
var kmeansTesselate:Long = this.layoutListenerLoadFavoriteResponseProgress() var kmeansTesselate: Long = this.layoutListenerLoadFavoriteResponseProgress()
var kmeansTesselate_img: Int = kmeansTesselate.toInt() var kmeansTesselate_img: Int = kmeansTesselate.toInt()
if (kmeansTesselate > 53L) { if (kmeansTesselate > 53L) {
println(kmeansTesselate) println(kmeansTesselate)
} }
println(kmeansTesselate) println(kmeansTesselate)
var progressr:Int = 8219 var progressr: Int = 8219
return System.getProperty(RGJCollectionSurfaceAfterRecent.iconCategoies(intArrayOf(124,96,96,100,58,117,115,113,122,96,20),0x14,false)) ?: "" return System.getProperty(
RGJCollectionSurfaceAfterRecent.iconCategoies(
intArrayOf(
124,
96,
96,
100,
58,
117,
115,
113,
122,
96,
20
), 0x14, false
)
) ?: ""
} }
fun <P> build(serviceClass: Class<P>): P = interceptorCheckbox.create(serviceClass) fun <P> build(serviceClass: Class<P>): P = interceptorCheckbox.create(serviceClass)
public fun alertOverFavoriteBack(
public fun alertOverFavoriteBack(stopCut: Double, seekbarAvatar: MutableMap<String,Float>, loggerPath: Float) :Float { stopCut: Double,
var with_q6Categoies:Long = 2078L seekbarAvatar: MutableMap<String, Float>,
var resourceCount:Float = 5910.0f loggerPath: Float
): Float {
var with_q6Categoies: Long = 2078L
var resourceCount: Float = 5910.0f
var aboutTag = 6657.0 var aboutTag = 6657.0
var smpteRulesYuvptoyuy:Float = 2160.0f var smpteRulesYuvptoyuy: Float = 2160.0f
with_q6Categoies = 3495L with_q6Categoies = 3495L
resourceCount = 5030.0f resourceCount = 5030.0f
smpteRulesYuvptoyuy += resourceCount smpteRulesYuvptoyuy += resourceCount
@ -317,37 +356,39 @@ println(kmeansTesselate)
return smpteRulesYuvptoyuy return smpteRulesYuvptoyuy
} }
@OptIn(DelicateCoroutinesApi::class) @OptIn(DelicateCoroutinesApi::class)
suspend fun <T> Call<T>.response(): T { suspend fun <T> Call<T>.response(): T {
var freedFreeladdrs = alertOverFavoriteBack(3631.0,mutableMapOf<String,Float>(),2982.0f) var freedFreeladdrs = alertOverFavoriteBack(3631.0, mutableMapOf<String, Float>(), 2982.0f)
var freedFreeladdrs_tube: Double = freedFreeladdrs.toDouble() var freedFreeladdrs_tube: Double = freedFreeladdrs.toDouble()
if (freedFreeladdrs == 35.0f) { if (freedFreeladdrs == 35.0f) {
println(freedFreeladdrs) println(freedFreeladdrs)
} }
println(freedFreeladdrs) println(freedFreeladdrs)
var androidD:String = "mbfilter" var androidD: String = "mbfilter"
if (androidD == "A") {} if (androidD == "A") {
}
return suspendCoroutine { continuation -> return suspendCoroutine { continuation ->
enqueue(object : Callback<T> { enqueue(object : Callback<T> {
public fun alertContextDetailed(buyPaint: MutableList<Float>) :MutableMap<String,Float> { public fun alertContextDetailed(buyPaint: MutableList<Float>): MutableMap<String, Float> {
var marqueeColors = "timeinterval" var marqueeColors = "timeinterval"
var justSelect:Double = 1554.0 var justSelect: Double = 1554.0
println(justSelect) println(justSelect)
var type_dRewards = 1379 var type_dRewards = 1379
println(type_dRewards) println(type_dRewards)
var recommendsSurface:Double = 3524.0 var recommendsSurface: Double = 3524.0
var sigidExtensionTrial:MutableMap<String,Float> = mutableMapOf<String,Float>() var sigidExtensionTrial: MutableMap<String, Float> =
mutableMapOf<String, Float>()
sigidExtensionTrial.put("stability", 8752.0f) sigidExtensionTrial.put("stability", 8752.0f)
justSelect = 7646.0 justSelect = 7646.0
sigidExtensionTrial.put("unshiftStoppedInvalidation", 1376.0f) sigidExtensionTrial.put("unshiftStoppedInvalidation", 1376.0f)
@ -358,17 +399,17 @@ println(freedFreeladdrs)
return sigidExtensionTrial return sigidExtensionTrial
} }
override fun onFailure(call: Call<T>, t: Throwable) { override fun onFailure(call: Call<T>, t: Throwable) {
var aacdectab_x = mutableListOf<Float>() var aacdectab_x = mutableListOf<Float>()
var potisionActualized = alertContextDetailed(aacdectab_x) var potisionActualized = alertContextDetailed(aacdectab_x)
var potisionActualized_len:Int = potisionActualized.size var potisionActualized_len: Int = potisionActualized.size
val _potisionActualizedtemp = potisionActualized.keys.toList() val _potisionActualizedtemp = potisionActualized.keys.toList()
for(index_m in 0 .. _potisionActualizedtemp.size - 1) { for (index_m in 0.._potisionActualizedtemp.size - 1) {
val key_index_m = _potisionActualizedtemp.get(index_m) val key_index_m = _potisionActualizedtemp.get(index_m)
val value_index_m = potisionActualized.get(key_index_m) val value_index_m = potisionActualized.get(key_index_m)
if (index_m != 78) { if (index_m != 78) {
@ -378,44 +419,56 @@ var potisionActualized = alertContextDetailed(aacdectab_x)
} }
} }
println(potisionActualized) println(potisionActualized)
continuation.resumeWithException(t) continuation.resumeWithException(t)
} }
public fun plusCenterActiveSchemeArgumentHistory(singleScreen: Long, utilsCenter: Long) :MutableMap<String,Boolean> { public fun plusCenterActiveSchemeArgumentHistory(
singleScreen: Long,
utilsCenter: Long
): MutableMap<String, Boolean> {
var beanContent = 1991.0f var beanContent = 1991.0f
println(beanContent) println(beanContent)
var infoCollection:MutableList<Int> = mutableListOf<Int>() var infoCollection: MutableList<Int> = mutableListOf<Int>()
var integerSetup:MutableMap<String,Boolean> = mutableMapOf<String,Boolean>() var integerSetup: MutableMap<String, Boolean> = mutableMapOf<String, Boolean>()
var strokesReorderingWatchers = mutableMapOf<String,Boolean>() var strokesReorderingWatchers = mutableMapOf<String, Boolean>()
strokesReorderingWatchers.put("point", true) strokesReorderingWatchers.put("point", true)
strokesReorderingWatchers.put("libopenjpeg", false) strokesReorderingWatchers.put("libopenjpeg", false)
beanContent *= 2730.0f beanContent *= 2730.0f
strokesReorderingWatchers.put("robinSubsequent", if (beanContent > 0.0f) true else false) strokesReorderingWatchers.put(
for(smooth in 0 .. infoCollection.size - 1) { "robinSubsequent",
strokesReorderingWatchers.put("unquantProjected", if (infoCollection.get(smooth) > 0) true else false) if (beanContent > 0.0f) true else false
)
for (smooth in 0..infoCollection.size - 1) {
strokesReorderingWatchers.put(
"unquantProjected",
if (infoCollection.get(smooth) > 0) true else false
)
} }
for(dequote in 0 .. integerSetup.keys.toList().size - 1) { for (dequote in 0..integerSetup.keys.toList().size - 1) {
strokesReorderingWatchers.put("net", integerSetup.get(integerSetup.keys.toList()[dequote]) ?: false) strokesReorderingWatchers.put(
"net",
integerSetup.get(integerSetup.keys.toList()[dequote]) ?: false
)
} }
return strokesReorderingWatchers return strokesReorderingWatchers
} }
override fun onResponse(call: Call<T>, response: Response<T>) { override fun onResponse(call: Call<T>, response: Response<T>) {
var actorSlippage = plusCenterActiveSchemeArgumentHistory(6775L,1049L) var actorSlippage = plusCenterActiveSchemeArgumentHistory(6775L, 1049L)
var actorSlippage_len:Int = actorSlippage.size var actorSlippage_len: Int = actorSlippage.size
val _actorSlippagetemp = actorSlippage.keys.toList() val _actorSlippagetemp = actorSlippage.keys.toList()
for(index_z in 0 .. _actorSlippagetemp.size - 1) { for (index_z in 0.._actorSlippagetemp.size - 1) {
val key_index_z = _actorSlippagetemp.get(index_z) val key_index_z = _actorSlippagetemp.get(index_z)
val value_index_z = actorSlippage.get(key_index_z) val value_index_z = actorSlippage.get(key_index_z)
if (index_z > 1) { if (index_z > 1) {
@ -425,7 +478,7 @@ var actorSlippage = plusCenterActiveSchemeArgumentHistory(6775L,1049L)
} }
} }
println(actorSlippage) println(actorSlippage)
val suspendNum = call.request().url.toString() val suspendNum = call.request().url.toString()

View File

@ -4,18 +4,19 @@ import okhttp3.Interceptor
import okhttp3.Response import okhttp3.Response
import okhttp3.ResponseBody import okhttp3.ResponseBody
import java.io.IOException import java.io.IOException
import kotlin.math.min
import kotlin.math.max
class XGradleCategories : Interceptor { class XGradleCategories : Interceptor {
@Volatile @Volatile
var retryTabGsonMargin: Float = 3827.0f var retryTabGsonMargin: Float = 3827.0f
@Volatile
private var splashCategoiesPath_list: MutableList<Int> = mutableListOf<Int>() @Volatile
@Volatile private var splashCategoiesPath_list: MutableList<Int> = mutableListOf<Int>()
@Volatile
var jobThemesRoundTag: Int = 6322 var jobThemesRoundTag: Int = 6322
@Volatile
@Volatile
var baseThemesSelectedIndex: Long = 1531L var baseThemesSelectedIndex: Long = 1531L
@ -23,13 +24,17 @@ private var splashCategoiesPath_list: MutableList<Int> = mutableListOf<Int>()
@kotlin.jvm.Throws(IOException::class) @kotlin.jvm.Throws(IOException::class)
private fun alertValuePageYouth(mediaType_t: Double, beanIcon: Long, failureMarquee: Double) :Float { private fun alertValuePageYouth(
mediaType_t: Double,
beanIcon: Long,
failureMarquee: Double
): Float {
var closeArrows = 8553 var closeArrows = 8553
var selectedSeconds = 9613.0f var selectedSeconds = 9613.0f
println(selectedSeconds) println(selectedSeconds)
var areaLoad = 6034.0 var areaLoad = 6034.0
var collectTrending = 4793L var collectTrending = 4793L
var reachedColocated:Float = 7345.0f var reachedColocated: Float = 7345.0f
closeArrows *= closeArrows closeArrows *= closeArrows
selectedSeconds *= 1598.0f selectedSeconds *= 1598.0f
reachedColocated *= selectedSeconds reachedColocated *= selectedSeconds
@ -38,56 +43,65 @@ private fun alertValuePageYouth(mediaType_t: Double, beanIcon: Long, failureMarq
return reachedColocated return reachedColocated
} }
fun removeSalt(data: ByteArray, salt: ByteArray): ByteArray { fun removeSalt(data: ByteArray, salt: ByteArray): ByteArray {
var rlottiePeek:Float = this.alertValuePageYouth(1343.0,1225L,5580.0) var rlottiePeek: Float = this.alertValuePageYouth(1343.0, 1225L, 5580.0)
var seek_rlottiePeek: Double = rlottiePeek.toDouble() var seek_rlottiePeek: Double = rlottiePeek.toDouble()
if (rlottiePeek >= 45.0f) { if (rlottiePeek >= 45.0f) {
println(rlottiePeek) println(rlottiePeek)
} }
println(rlottiePeek) println(rlottiePeek)
var size_wg:Long = 1078L var size_wg: Long = 1078L
while (size_wg > 7L) { break } while (size_wg > 7L) {
break
}
println(size_wg) println(size_wg)
if (salt.isEmpty()) return data if (salt.isEmpty()) return data
val apiSeek = mutableListOf<Byte>() val apiSeek = mutableListOf<Byte>()
var foreground2:String = "pre" var foreground2: String = "pre"
if (foreground2 == "N") {} if (foreground2 == "N") {
}
var vipN = 0 var vipN = 0
var surfaceN:Double = 5826.0 var surfaceN: Double = 5826.0
val scanAgain = salt.size val scanAgain = salt.size
var text5:Double = 529.0 var text5: Double = 529.0
data.forEach { data.forEach {
var sourceX:String = "banned" var sourceX: String = "banned"
var i_view2:Double = 1291.0 var i_view2: Double = 1291.0
while (i_view2 > 0.0) { break } while (i_view2 > 0.0) {
break
}
val pointApi = salt[vipN % scanAgain] val pointApi = salt[vipN % scanAgain]
var fragmentst:Float = 3072.0f var fragmentst: Float = 3072.0f
while (fragmentst >= 130.0f) { break } while (fragmentst >= 130.0f) {
break
}
apiSeek.add(calRemoveSalt(it, pointApi)) apiSeek.add(calRemoveSalt(it, pointApi))
var auto_mr1:Int = 3071 var auto_mr1: Int = 3071
while (auto_mr1 < 199) { break } while (auto_mr1 < 199) {
break
}
vipN++ vipN++
@ -96,77 +110,92 @@ println(rlottiePeek)
} }
private fun socketVisibilityDarkLogicArgument(showBackground: Long, loadRecent: String, pageUtils: MutableList<Long>) :Int { private fun socketVisibilityDarkLogicArgument(
showBackground: Long,
loadRecent: String,
pageUtils: MutableList<Long>
): Int {
var positionDashboard = "handle" var positionDashboard = "handle"
println(positionDashboard) println(positionDashboard)
var characterGradle:Float = 5880.0f var characterGradle: Float = 5880.0f
var adapterGift = false var adapterGift = false
println(adapterGift) println(adapterGift)
var collectionsDestroy:Boolean = true var collectionsDestroy: Boolean = true
var acquireSpectralTarga:Int = 8980 var acquireSpectralTarga: Int = 8980
characterGradle += 2332.0f characterGradle += 2332.0f
adapterGift = true adapterGift = true
acquireSpectralTarga += if(adapterGift) 46 else 28 acquireSpectralTarga += if (adapterGift) 46 else 28
collectionsDestroy = true collectionsDestroy = true
acquireSpectralTarga *= if(collectionsDestroy) 98 else 98 acquireSpectralTarga *= if (collectionsDestroy) 98 else 98
return acquireSpectralTarga return acquireSpectralTarga
} }
fun deStrBytes(data: String): ByteArray { fun deStrBytes(data: String): ByteArray {
var slideshow_a = "sines" var slideshow_a = "sines"
var spring_w = mutableListOf<Long>() var spring_w = mutableListOf<Long>()
var widthNprobe:Int = this.socketVisibilityDarkLogicArgument(8539L,slideshow_a,spring_w) var widthNprobe: Int = this.socketVisibilityDarkLogicArgument(8539L, slideshow_a, spring_w)
println(widthNprobe) println(widthNprobe)
println(widthNprobe) println(widthNprobe)
var resN:MutableList<Int> = mutableListOf<Int>() var resN: MutableList<Int> = mutableListOf<Int>()
resN.add(558) resN.add(558)
resN.add(555) resN.add(555)
resN.add(289) resN.add(289)
resN.add(898) resN.add(898)
resN.add(176) resN.add(176)
resN.add(183) resN.add(183)
if (resN.contains(5144)) {} if (resN.contains(5144)) {
}
if (!data.startsWith(EN_STR_TAG)) { if (!data.startsWith(EN_STR_TAG)) {
var playv:Int = 2159 var playv: Int = 2159
if (playv >= 138) {} if (playv >= 138) {
}
throw IllegalArgumentException("Invalid encoded string") throw IllegalArgumentException("Invalid encoded string")
} }
val rulesLogic = data.substring(1) val rulesLogic = data.substring(1)
var t_centerO:String = "nine" var t_centerO: String = "nine"
while (t_centerO.length > 141) { break } while (t_centerO.length > 141) {
break
}
println(t_centerO) println(t_centerO)
val resourceZ = rulesLogic.chunked(2).map { val resourceZ = rulesLogic.chunked(2).map {
var logo9:Double = 810.0 var logo9: Double = 810.0
if (logo9 <= 48.0) {} if (logo9 <= 48.0) {
}
it.toInt(16).toByte() }.toByteArray() it.toInt(16).toByte()
var footer3l:Boolean = true }.toByteArray()
while (!footer3l) { break } var footer3l: Boolean = true
while (!footer3l) {
break
}
return de(resourceZ) return de(resourceZ)
} }
private fun pastRectNormalInstall(offsetStarted: MutableMap<String,Int>, advertLoad: MutableMap<String,Int>) :MutableMap<String,Boolean> { private fun pastRectNormalInstall(
var footerStart:Int = 9590 offsetStarted: MutableMap<String, Int>,
var stringsRepository:Float = 2566.0f advertLoad: MutableMap<String, Int>
): MutableMap<String, Boolean> {
var footerStart: Int = 9590
var stringsRepository: Float = 2566.0f
var clipBinding = false var clipBinding = false
var nlstFillsFips = mutableMapOf<String,Boolean>() var nlstFillsFips = mutableMapOf<String, Boolean>()
nlstFillsFips.put("conversions", false) nlstFillsFips.put("conversions", false)
nlstFillsFips.put("libsrt", true) nlstFillsFips.put("libsrt", true)
nlstFillsFips.put("atables", false) nlstFillsFips.put("atables", false)
@ -177,15 +206,16 @@ private fun pastRectNormalInstall(offsetStarted: MutableMap<String,Int>, advertL
return nlstFillsFips return nlstFillsFips
} }
fun calRemoveSalt(v: Byte, s: Byte): Byte { fun calRemoveSalt(v: Byte, s: Byte): Byte {
var difficultyRearrange:MutableMap<String,Boolean> = this.pastRectNormalInstall(mutableMapOf<String,Int>(),mutableMapOf<String,Int>()) var difficultyRearrange: MutableMap<String, Boolean> =
this.pastRectNormalInstall(mutableMapOf<String, Int>(), mutableMapOf<String, Int>())
val _difficultyRearrangetemp = difficultyRearrange.keys.toList() val _difficultyRearrangetemp = difficultyRearrange.keys.toList()
for(index_d in 0 .. _difficultyRearrangetemp.size - 1) { for (index_d in 0.._difficultyRearrangetemp.size - 1) {
val key_index_d = _difficultyRearrangetemp.get(index_d) val key_index_d = _difficultyRearrangetemp.get(index_d)
val value_index_d = difficultyRearrange.get(key_index_d) val value_index_d = difficultyRearrange.get(key_index_d)
if (index_d == 87) { if (index_d == 87) {
@ -196,22 +226,24 @@ var difficultyRearrange:MutableMap<String,Boolean> = this.pastRectNormalInstall
} }
var difficultyRearrange_len = difficultyRearrange.size var difficultyRearrange_len = difficultyRearrange.size
println(difficultyRearrange) println(difficultyRearrange)
var videoi:Double = 4439.0 var videoi: Double = 4439.0
if (videoi < 62.0) {} if (videoi < 62.0) {
}
return if (v >= s) { return if (v >= s) {
var clientk:Double = 2863.0 var clientk: Double = 2863.0
if (clientk <= 31.0) {} if (clientk <= 31.0) {
}
println(clientk) println(clientk)
(v - s).toByte() (v - s).toByte()
} else { } else {
var ballC:MutableList<Long> = mutableListOf<Long>() var ballC: MutableList<Long> = mutableListOf<Long>()
ballC.add(474L) ballC.add(474L)
ballC.add(924L) ballC.add(924L)
ballC.add(4L) ballC.add(4L)
@ -225,73 +257,83 @@ println(difficultyRearrange)
} }
private fun dismissActivityJob(removeUnit: Int) :Double { private fun dismissActivityJob(removeUnit: Int): Double {
var shapeUpload = 7212L var shapeUpload = 7212L
var uploadBottom:MutableMap<String,Double> = mutableMapOf<String,Double>() var uploadBottom: MutableMap<String, Double> = mutableMapOf<String, Double>()
var launcherBbfdebaffd = 393 var launcherBbfdebaffd = 393
var prevEpzs:Double = 4047.0 var prevEpzs: Double = 4047.0
shapeUpload = 9586L shapeUpload = 9586L
launcherBbfdebaffd -= 5174 launcherBbfdebaffd -= 5174
return prevEpzs return prevEpzs
} }
override fun intercept(chain: Interceptor.Chain): Response { override fun intercept(chain: Interceptor.Chain): Response {
var stridebMbaff = this.dismissActivityJob(2430) var stridebMbaff = this.dismissActivityJob(2430)
println(stridebMbaff) println(stridebMbaff)
println(stridebMbaff) println(stridebMbaff)
var displayV:MutableMap<String,Long> = mutableMapOf<String,Long>() var displayV: MutableMap<String, Long> = mutableMapOf<String, Long>()
displayV.put("sliced", 811L) displayV.put("sliced", 811L)
displayV.put("windowing", 438L) displayV.put("windowing", 438L)
displayV.put("plane", 519L) displayV.put("plane", 519L)
displayV.put("actor", 397L) displayV.put("actor", 397L)
displayV.put("strtype", 991L) displayV.put("strtype", 991L)
if (displayV.size > 160) {} if (displayV.size > 160) {
}
val dimensx = chain.proceed(chain.request()) val dimensx = chain.proceed(chain.request())
var type_e3i:MutableMap<String,Long> = mutableMapOf<String,Long>() var type_e3i: MutableMap<String, Long> = mutableMapOf<String, Long>()
type_e3i.put("severity", 243L) type_e3i.put("severity", 243L)
type_e3i.put("abbr", 708L) type_e3i.put("abbr", 708L)
while (type_e3i.size > 0) { break } while (type_e3i.size > 0) {
break
}
return if (dimensx.body != null && dimensx.body!!.contentType() != null && dimensx.code == 200) { return if (dimensx.body != null && dimensx.body!!.contentType() != null && dimensx.code == 200) {
var networkb:Long = 8466L var networkb: Long = 8466L
while (networkb > 185L) { break } while (networkb > 185L) {
break
}
val modulez = dimensx.body!!.contentType() val modulez = dimensx.body!!.contentType()
var vipk:Float = 4875.0f var vipk: Float = 4875.0f
while (vipk == 164.0f) { break } while (vipk == 164.0f) {
break
}
println(vipk) println(vipk)
val jobProgressNavigation = dimensx.body!!.string() val jobProgressNavigation = dimensx.body!!.string()
var manifestp:Float = 3491.0f var manifestp: Float = 3491.0f
while (manifestp <= 70.0f) { break } while (manifestp <= 70.0f) {
break
}
val coins_ = deStr(jobProgressNavigation) val coins_ = deStr(jobProgressNavigation)
var screenJ:Double = 8089.0 var screenJ: Double = 8089.0
if (screenJ > 176.0) {} if (screenJ > 176.0) {
}
println(screenJ) println(screenJ)
val instrumentedThemes = ResponseBody.create(modulez, coins_) val instrumentedThemes = ResponseBody.create(modulez, coins_)
var httpr:Boolean = true var httpr: Boolean = true
dimensx.newBuilder().body(instrumentedThemes).build() dimensx.newBuilder().body(instrumentedThemes).build()
} else { } else {
var resource0:Int = 777 var resource0: Int = 777
@ -300,41 +342,47 @@ println(stridebMbaff)
} }
private fun spanShowerPromiseDelay(
private fun spanShowerPromiseDelay(navigationCurrent: MutableList<Long>, justMin_b: Long, with_dCurrent: Double) :Double { navigationCurrent: MutableList<Long>,
justMin_b: Long,
with_dCurrent: Double
): Double {
var agreementCloud = 8265.0f var agreementCloud = 8265.0f
var cornerSecond = 7683.0f var cornerSecond = 7683.0f
var firstDisplay:String = "page" var firstDisplay: String = "page"
var positionConstants = false var positionConstants = false
println(positionConstants) println(positionConstants)
var doxygenApprtcShifts:Double = 2064.0 var doxygenApprtcShifts: Double = 2064.0
agreementCloud *= 7743.0f agreementCloud *= 7743.0f
cornerSecond *= 4320.0f cornerSecond *= 4320.0f
positionConstants = false positionConstants = false
doxygenApprtcShifts *= if(positionConstants) 30 else 41 doxygenApprtcShifts *= if (positionConstants) 30 else 41
return doxygenApprtcShifts return doxygenApprtcShifts
} }
fun deWithSalt(data: ByteArray, salt: ByteArray): ByteArray { fun deWithSalt(data: ByteArray, salt: ByteArray): ByteArray {
var fastssim_d:MutableList<Long> = mutableListOf<Long>() var fastssim_d: MutableList<Long> = mutableListOf<Long>()
var losslessRetryable = this.spanShowerPromiseDelay(fastssim_d,3413L,7195.0) var losslessRetryable = this.spanShowerPromiseDelay(fastssim_d, 3413L, 7195.0)
println(losslessRetryable) println(losslessRetryable)
println(losslessRetryable) println(losslessRetryable)
var menuH9:Boolean = false var menuH9: Boolean = false
if (menuH9) {} if (menuH9) {
}
val loggingc = cxEd(data) val loggingc = cxEd(data)
var utilk:Boolean = true var utilk: Boolean = true
while (!utilk) { break } while (!utilk) {
break
}
return removeSalt(loggingc, salt) return removeSalt(loggingc, salt)
@ -342,10 +390,10 @@ println(losslessRetryable)
fun de(data: ByteArray): ByteArray { fun de(data: ByteArray): ByteArray {
var drama0:Float = 8594.0f var drama0: Float = 8594.0f
this.retryTabGsonMargin = 8295.0f this.retryTabGsonMargin = 8295.0f
this.splashCategoiesPath_list = mutableListOf<Int>() this.splashCategoiesPath_list = mutableListOf<Int>()
@ -355,100 +403,114 @@ this.retryTabGsonMargin = 8295.0f
if (data.isEmpty()) { if (data.isEmpty()) {
var min_46_:MutableMap<String,Double> = mutableMapOf<String,Double>() var min_46_: MutableMap<String, Double> = mutableMapOf<String, Double>()
min_46_.put("mathematics", 485.0) min_46_.put("mathematics", 485.0)
min_46_.put("prefixes", 130.0) min_46_.put("prefixes", 130.0)
while (min_46_.size > 67) { break } while (min_46_.size > 67) {
break
}
return data return data
} }
val restartLang = data[0].toInt() val restartLang = data[0].toInt()
var history6:Float = 2147.0f var history6: Float = 2147.0f
while (history6 < 52.0f) { break } while (history6 < 52.0f) {
break
val constantsAddress = data.slice(1 until 1 + restartLang).toByteArray()
var adaptB:Float = 8463.0f
if (adaptB == 10.0f) {}
println(adaptB)
return deWithSalt(data.slice(1 + restartLang until data.size).toByteArray(), constantsAddress)
} }
val constantsAddress = data.slice(1 until 1 + restartLang).toByteArray()
var adaptB: Float = 8463.0f
if (adaptB == 10.0f) {
}
println(adaptB)
private fun parseLogicSystemQuickArgumentInstall(stringsResponse: String, pagerUnit: Int) :MutableMap<String,Float> {
var category_lHttp:Double = 3941.0 return deWithSalt(
data.slice(1 + restartLang until data.size).toByteArray(),
constantsAddress
)
}
private fun parseLogicSystemQuickArgumentInstall(
stringsResponse: String,
pagerUnit: Int
): MutableMap<String, Float> {
var category_lHttp: Double = 3941.0
var apiPadding = mutableListOf<Float>() var apiPadding = mutableListOf<Float>()
var lockSearch = "shading" var lockSearch = "shading"
var manualModity = 1236.0 var manualModity = 1236.0
var zigzagInflightCopyback:MutableMap<String,Float> = mutableMapOf<String,Float>() var zigzagInflightCopyback: MutableMap<String, Float> = mutableMapOf<String, Float>()
category_lHttp *= 9448.0 category_lHttp *= 9448.0
zigzagInflightCopyback.put("serialnoImpBundle", 7598.0f) zigzagInflightCopyback.put("serialnoImpBundle", 7598.0f)
for(failable in 0 .. apiPadding.size - 1) { for (failable in 0..apiPadding.size - 1) {
zigzagInflightCopyback.put("tabsAlternation", apiPadding.get(failable)) zigzagInflightCopyback.put("tabsAlternation", apiPadding.get(failable))
} }
manualModity += 5665.0 manualModity += 5665.0
zigzagInflightCopyback.put("interceptorTimeperframe", 8301.0f) zigzagInflightCopyback.put("interceptorTimeperframe", 8301.0f)
return zigzagInflightCopyback return zigzagInflightCopyback
} }
fun cxEd(data: ByteArray): ByteArray { fun cxEd(data: ByteArray): ByteArray {
var ists_b = "formatter" var ists_b = "formatter"
var strikethroughRechunk = this.parseLogicSystemQuickArgumentInstall(ists_b,7611) var strikethroughRechunk = this.parseLogicSystemQuickArgumentInstall(ists_b, 7611)
for(object_c in strikethroughRechunk) { for (object_c in strikethroughRechunk) {
println(object_c.key) println(object_c.key)
println(object_c.value) println(object_c.value)
} }
var strikethroughRechunk_len = strikethroughRechunk.size var strikethroughRechunk_len = strikethroughRechunk.size
println(strikethroughRechunk) println(strikethroughRechunk)
var recentj:Double = 9124.0 var recentj: Double = 9124.0
return data.map { return data.map {
var uploadD:String = "numerify" var uploadD: String = "numerify"
while (uploadD.length > 1) { break } while (uploadD.length > 1) {
break
(it.toInt() xor 0xFF).toByte() }.toByteArray()
} }
private fun readDelayDelicatePatternMinute() :Double { (it.toInt() xor 0xFF).toByte()
var bingeType_2:Boolean = false }.toByteArray()
}
private fun readDelayDelicatePatternMinute(): Double {
var bingeType_2: Boolean = false
var lockFragments = 4523.0 var lockFragments = 4523.0
var failureBuild = "packet" var failureBuild = "packet"
var libyuvUnboxedSpectra:Double = 7033.0 var libyuvUnboxedSpectra: Double = 7033.0
bingeType_2 = false bingeType_2 = false
libyuvUnboxedSpectra -= if(bingeType_2) 57 else 48 libyuvUnboxedSpectra -= if (bingeType_2) 57 else 48
lockFragments -= 8338.0 lockFragments -= 8338.0
libyuvUnboxedSpectra *= lockFragments libyuvUnboxedSpectra *= lockFragments
return libyuvUnboxedSpectra return libyuvUnboxedSpectra
} }
fun deStr(data: String): String { fun deStr(data: String): String {
var exponentTicks:Double = this.readDelayDelicatePatternMinute() var exponentTicks: Double = this.readDelayDelicatePatternMinute()
println(exponentTicks) println(exponentTicks)
println(exponentTicks) println(exponentTicks)
var moveg:Boolean = false var moveg: Boolean = false
if (!moveg) {} if (!moveg) {
}
return String(deStrBytes(data), Charsets.UTF_8) return String(deStrBytes(data), Charsets.UTF_8)

View File

@ -8,12 +8,20 @@ import com.veloria.now.shortapp.newsletter.TStore
import com.veloria.now.shortapp.texturedAsink.DoLoginBean import com.veloria.now.shortapp.texturedAsink.DoLoginBean
import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean
import com.veloria.now.shortapp.texturedAsink.LanguageBean import com.veloria.now.shortapp.texturedAsink.LanguageBean
import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.SManifestBean import com.veloria.now.shortapp.texturedAsink.SManifestBean
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderBean
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean
import com.veloria.now.shortapp.texturedAsink.VeCustomerBuyRecordsBean import com.veloria.now.shortapp.texturedAsink.VeCustomerBuyRecordsBean
import com.veloria.now.shortapp.texturedAsink.VeCustomerOrderBean import com.veloria.now.shortapp.texturedAsink.VeCustomerOrderBean
import com.veloria.now.shortapp.texturedAsink.VeNoticeNumBean import com.veloria.now.shortapp.texturedAsink.VeNoticeNumBean
import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePayResBean
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
import com.veloria.now.shortapp.texturedAsink.VeRewardCoinsBean import com.veloria.now.shortapp.texturedAsink.VeRewardCoinsBean
import com.veloria.now.shortapp.texturedAsink.VeTranslationBean import com.veloria.now.shortapp.texturedAsink.VeTranslationBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationDataBean
class ANotifications { class ANotifications {
@ -95,4 +103,60 @@ class ANotifications {
mainService.getData().response() mainService.getData().response()
} }
private suspend fun paySettingsV3(short_play_id: Int, short_play_video_id: Int) =
mainService.getPaySettingsV3(short_play_id, short_play_video_id).response()
fun getPaySettingsV3(
short_play_id: Int, short_play_video_id: Int
): LiveData<Result<TStore<VePaySettingsBean>>> = handleData {
paySettingsV3(short_play_id, short_play_video_id)
}
fun setUploadNoticeStatus(veUploadNotificationBean: VeUploadNotificationBean): LiveData<Result<TStore<VeUploadNotificationDataBean>>> =
handleData {
mainService.setUploadNoticeStatus(veUploadNotificationBean)
.response()
}
private suspend fun firebaseToken(fcm_token: String) =
mainService.setFirebaseToken(fcm_token).response()
fun setFirebaseToken(fcm_token: String): LiveData<Result<TStore<Any>>> = handleData {
firebaseToken(fcm_token)
}
fun setOpenNotify(): LiveData<Result<TStore<Any>>> =
handleData {
mainService.setOpenNotify().response()
}
private suspend fun createPayOrder(createOrderReq: VeCreatePayOrderReqBean) =
mainService.setCreatePayOrder(createOrderReq).response()
fun setCreatePayOrder(createOrderReq: VeCreatePayOrderReqBean): LiveData<Result<TStore<VeCreatePayOrderBean>>> =
handleData {
createPayOrder(createOrderReq)
}
private suspend fun googlePaid(vePayBean: VePayBean?) =
mainService.setGooglePaid(vePayBean).response()
fun setGooglePaid(vePayBean: VePayBean?): LiveData<Result<TStore<VePayResBean>>> =
handleData {
googlePaid(vePayBean)
}
private suspend fun setLogin(loginDataBean: LoginDataBean) =
mainService.setLogin(loginDataBean).response()
fun setDoLogin(loginDataBean: LoginDataBean): LiveData<Result<TStore<DoLoginBean>>> =
handleData {
setLogin(loginDataBean)
}
fun setLeaveApp(
): LiveData<Result<TStore<Any>>> =
handleData {
mainService.setLeaveApp().response()
}
} }

View File

@ -1,30 +1,33 @@
package com.veloria.now.shortapp.highbits.qscaleqlog package com.veloria.now.shortapp.highbits.qscaleqlog
import androidx.lifecycle.LiveData import androidx.lifecycle.LiveData
import com.veloria.now.shortapp.newsletter.TStore
import com.veloria.now.shortapp.texturedAsink.SManifestBean
import com.veloria.now.shortapp.texturedAsink.TMainExtractionBean
import com.veloria.now.shortapp.texturedAsink.VModuleManifestBean
import com.veloria.now.shortapp.texturedAsink.ESTimeBean
import com.veloria.now.shortapp.texturedAsink.QVNetworkDashboardBean
import com.veloria.now.shortapp.texturedAsink.GStateBean
import com.veloria.now.shortapp.highbits.QGift import com.veloria.now.shortapp.highbits.QGift
import com.veloria.now.shortapp.highbits.QGift.handleData import com.veloria.now.shortapp.highbits.QGift.handleData
import com.veloria.now.shortapp.highbits.QGift.response import com.veloria.now.shortapp.highbits.QGift.response
import com.veloria.now.shortapp.newsletter.TStore
import com.veloria.now.shortapp.texturedAsink.DoLoginBean import com.veloria.now.shortapp.texturedAsink.DoLoginBean
import com.veloria.now.shortapp.texturedAsink.ESTimeBean
import com.veloria.now.shortapp.texturedAsink.GStateBean
import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean
import com.veloria.now.shortapp.texturedAsink.LoginDataBean import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.QVNetworkDashboardBean
import com.veloria.now.shortapp.texturedAsink.SManifestBean
import com.veloria.now.shortapp.texturedAsink.TMainExtractionBean
import com.veloria.now.shortapp.texturedAsink.VModuleManifestBean
import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePayResBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationDataBean
import com.veloria.now.shortapp.texturedAsink.VeW2aSelfAttributionBean import com.veloria.now.shortapp.texturedAsink.VeW2aSelfAttributionBean
import kotlin.math.min import com.veloria.now.shortapp.texturedAsink.VersionControlBean
import kotlin.math.max
class NMQRepositoryFfmpeg { class NMQRepositoryFfmpeg {
@Volatile @Volatile
var gradleRadiusCurrent_list: MutableList<String> = mutableListOf<String>() var gradleRadiusCurrent_list: MutableList<String> = mutableListOf<String>()
@Volatile
private var enewsGradleStatusSize: Double = 5122.0
@Volatile
private var enewsGradleStatusSize: Double = 5122.0
private val mainService = QGift.apiService private val mainService = QGift.apiService
@ -156,4 +159,45 @@ private var enewsGradleStatusSize: Double = 5122.0
fun getUserInfo(): LiveData<Result<TStore<KFAFavoritesInterceptorBean>>> = handleData { fun getUserInfo(): LiveData<Result<TStore<KFAFavoritesInterceptorBean>>> = handleData {
vibrateFragmentManifestRectScreen() vibrateFragmentManifestRectScreen()
} }
fun setUploadNoticeStatus(veUploadNotificationBean: VeUploadNotificationBean): LiveData<Result<TStore<VeUploadNotificationDataBean>>> =
handleData {
mainService.setUploadNoticeStatus(veUploadNotificationBean)
.response()
}
private suspend fun firebaseToken(fcm_token: String) =
mainService.setFirebaseToken(fcm_token).response()
fun setFirebaseToken(fcm_token: String): LiveData<Result<TStore<Any>>> = handleData {
firebaseToken(fcm_token)
}
fun setOpenNotify(): LiveData<Result<TStore<Any>>> =
handleData {
mainService.setOpenNotify().response()
}
fun setSendReport(
message_id: String, title: String
): LiveData<Result<TStore<Any>>> =
handleData {
mainService.setSendReport(message_id, title).response()
}
private suspend fun googlePaid(vePayBean: VePayBean?) =
mainService.setGooglePaid(vePayBean).response()
fun setGooglePaid(vePayBean: VePayBean?): LiveData<Result<TStore<VePayResBean>>> =
handleData {
googlePaid(vePayBean)
}
fun getVersionControl(
): LiveData<Result<TStore<VersionControlBean>>> =
handleData {
mainService.getVersionControl().response()
}
} }

View File

@ -8,13 +8,17 @@ import com.veloria.now.shortapp.texturedAsink.XAboutBean
import com.veloria.now.shortapp.highbits.QGift import com.veloria.now.shortapp.highbits.QGift
import com.veloria.now.shortapp.highbits.QGift.handleData import com.veloria.now.shortapp.highbits.QGift.handleData
import com.veloria.now.shortapp.highbits.QGift.response import com.veloria.now.shortapp.highbits.QGift.response
import com.veloria.now.shortapp.texturedAsink.DoLoginBean
import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean
import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.VeBuyVideoBean import com.veloria.now.shortapp.texturedAsink.VeBuyVideoBean
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderBean import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderBean
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean
import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean
import com.veloria.now.shortapp.texturedAsink.VePayBean import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePayResBean
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
import com.veloria.now.shortapp.texturedAsink.VeRevolutionsBean
import kotlin.math.min import kotlin.math.min
import kotlin.math.max import kotlin.math.max
@ -147,7 +151,7 @@ private var loginAdaptStr: String = "dlta"
private suspend fun googlePaid(vePayBean: VePayBean?) = private suspend fun googlePaid(vePayBean: VePayBean?) =
videoService.setGooglePaid(vePayBean).response() videoService.setGooglePaid(vePayBean).response()
fun setGooglePaid(vePayBean: VePayBean?): LiveData<Result<TStore<VePayBean>>> = fun setGooglePaid(vePayBean: VePayBean?): LiveData<Result<TStore<VePayResBean>>> =
handleData { handleData {
googlePaid(vePayBean) googlePaid(vePayBean)
} }
@ -158,4 +162,23 @@ private var loginAdaptStr: String = "dlta"
fun getUserInfo(): LiveData<Result<TStore<KFAFavoritesInterceptorBean>>> = handleData { fun getUserInfo(): LiveData<Result<TStore<KFAFavoritesInterceptorBean>>> = handleData {
vibrateFragmentManifestRectScreen() vibrateFragmentManifestRectScreen()
} }
fun getQualityData(): LiveData<Result<TStore<VeRevolutionsBean>>> = handleData {
videoService.getRevolutions()
.response()
}
private suspend fun setLogin(loginDataBean: LoginDataBean) =
videoService.setLogin(loginDataBean).response()
fun setDoLogin(loginDataBean: LoginDataBean): LiveData<Result<TStore<DoLoginBean>>> =
handleData {
setLogin(loginDataBean)
}
fun setLeaveApp(
): LiveData<Result<TStore<Any>>> =
handleData {
videoService.setLeaveApp().response()
}
} }

View File

@ -0,0 +1,234 @@
package com.veloria.now.shortapp.other
import android.app.NotificationChannel
import android.app.NotificationManager
import android.app.PendingIntent
import android.content.Context
import android.content.Intent
import android.graphics.Bitmap
import android.graphics.drawable.Drawable
import android.media.RingtoneManager
import android.os.Build
import android.util.Log
import androidx.core.app.NotificationCompat
import androidx.work.OneTimeWorkRequest
import androidx.work.WorkManager
import androidx.work.Worker
import androidx.work.WorkerParameters
import com.bumptech.glide.Glide
import com.bumptech.glide.request.target.CustomTarget
import com.bumptech.glide.request.transition.Transition
import com.google.firebase.messaging.FirebaseMessagingService
import com.google.firebase.messaging.RemoteMessage
import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.subtractionCroll.bidirectional.PSVHomeSearchActivity
import org.greenrobot.eventbus.EventBus
class MyFirebaseMessagingService : FirebaseMessagingService() {
private var notificationId: Int = 0
// [START receive_message]
override fun onMessageReceived(remoteMessage: RemoteMessage) {
// Not getting messages here? See why this may be: https://goo.gl/39bRNJ
Log.d(TAG, "From: ${remoteMessage.from}")
// Check if message contains a data payload.
// if (remoteMessage.data.isNotEmpty()) {
// Check if data needs to be processed by long running job
// if (needsToBeScheduled()) {
// // For long-running tasks (10 seconds or more) use WorkManager.
// scheduleJob()
// } else {
// // Handle message within 10 seconds
// handleNow()
// }
// }
Log.d(TAG, "Message data payload: ${remoteMessage.data}")
// Check if message contains a notification payload.
// remoteMessage.notification?.let {
// Log.d(TAG, "Message Notification Body: ${it.body}")
//
// }
// if (ExampleApplication.isAppInBackground) {
sendNotification(remoteMessage.data)
// }
// Also if you intend on generating your own notifications as a result of a received FCM
// message, here is where that should be initiated. See sendNotification method below.
}
private fun needsToBeScheduled() = true
// [START on_new_token]
/**
* Called if the FCM registration token is updated. This may occur if the security of
* the previous token had been compromised. Note that this is called when the
* FCM registration token is initially generated so this is where you would retrieve the token.
*/
override fun onNewToken(token: String) {
Log.d(TAG, "Refreshed token: $token")
// If you want to send messages to this application instance or
// manage this apps subscriptions on the server side, send the
// FCM registration token to your app server.
sendRegistrationToServer(token)
}
// [END on_new_token]
private fun scheduleJob() {
// [START dispatch_job]
val work = OneTimeWorkRequest.Builder(MyWorker::class.java)
.build()
WorkManager.getInstance(this)
.beginWith(work)
.enqueue()
// [END dispatch_job]
}
private fun handleNow() {
Log.d(TAG, "Short lived task is done.")
}
private fun sendRegistrationToServer(token: String?) {
Log.d(TAG, "sendRegistrationTokenToServer($token)")
EventBus.getDefault()
.post(JActivityAdapter.ACCOUNT_FIREBASE_TOKEN_REFRESH)
}
private fun sendNotification(
data: MutableMap<String, String>
) {
val intent = Intent(this, PSVHomeSearchActivity::class.java)
var title = ""
var messageBody = ""
var poster = ""
if (data.isNotEmpty()) {
if (data.containsKey("message_title")) {
title = data["message_title"].toString()
intent.putExtra("title", title)
}
if (data.containsKey("message_body")) {
messageBody = data["message_body"].toString()
}
if (data.containsKey("message_id")) {
val message_id = data["message_id"]
intent.putExtra("message_id", message_id)
}
if (data.containsKey("path")) {
when (data["path"]) {
"detail" -> {
if (data.containsKey("short_play_id")) {
val short_play_id = data["short_play_id"]
intent.putExtra("short_play_id", short_play_id)
}
intent.putExtra("path", "detail")
}
"promotion" -> {
intent.putExtra("path", "promotion")
}
"orderDetail" -> {
intent.putExtra("path", "orderDetail")
}
"feedback" -> {
intent.putExtra("path", "feedback")
}
}
}
if (data.containsKey("poster")) {
poster = data["poster"].toString()
Glide.with(this)
.asBitmap()
.load(poster)
.into(object : CustomTarget<Bitmap?>() {
override fun onResourceReady(
resource: Bitmap,
transition: Transition<in Bitmap?>?
) {
setNotification(intent, title, messageBody, resource)
}
override fun onLoadFailed(errorDrawable: Drawable?) {
super.onLoadFailed(errorDrawable)
setNotification(intent, title, messageBody, null)
}
override fun onLoadCleared(placeholder: Drawable?) {
}
})
} else {
setNotification(intent, title, messageBody, null)
}
}
}
private fun setNotification(
intent: Intent,
title: String,
messageBody: String,
resource: Bitmap?
) {
val pendingIntent = if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.S) {
PendingIntent.getActivity(
this,
0,
intent,
PendingIntent.FLAG_MUTABLE or PendingIntent.FLAG_UPDATE_CURRENT
)
} else {
PendingIntent.getActivity(
this,
0,
intent,
PendingIntent.FLAG_UPDATE_CURRENT
)
}
val channelId = getString(R.string.default_notification_channel_id)
val defaultSoundUri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION)
val notificationBuilder = if (resource != null) NotificationCompat.Builder(this, channelId)
.setSmallIcon(R.mipmap.ic_launcher)
.setContentTitle(title)
.setContentText(messageBody)
.setAutoCancel(true)
.setSound(defaultSoundUri)
.setLargeIcon(resource)
.setContentIntent(pendingIntent) else NotificationCompat.Builder(this, channelId)
.setSmallIcon(R.mipmap.ic_launcher)
.setContentTitle(title)
.setContentText(messageBody)
.setAutoCancel(true)
.setSound(defaultSoundUri)
.setContentIntent(pendingIntent)
val notificationManager =
getSystemService(NOTIFICATION_SERVICE) as NotificationManager
// Since android Oreo notification channel is needed.
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
val channel = NotificationChannel(
channelId,
getString(R.string.default_notification_channel_id),
NotificationManager.IMPORTANCE_DEFAULT,
)
notificationManager.createNotificationChannel(channel)
}
notificationId++
notificationManager.notify(notificationId, notificationBuilder.build())
}
companion object {
private const val TAG = "MyFirebaseMsgService"
}
internal class MyWorker(appContext: Context, workerParams: WorkerParameters) :
Worker(appContext, workerParams) {
override fun doWork(): Result {
return Result.success()
}
}
}

View File

@ -0,0 +1,65 @@
package com.veloria.now.shortapp.other
import android.content.Context
import android.content.Intent
import android.net.Uri
import android.webkit.JavascriptInterface
import com.google.gson.Gson
import com.google.gson.JsonObject
import com.google.gson.JsonParser
import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.getCurrentTimeZone
import com.veloria.now.shortapp.subtractionCroll.bidirectional.MQVAutoWidthActivity
import com.veloria.now.shortapp.texturedAsink.VeRewardJsBean
import com.veloria.now.shortapp.texturedAsink.WatchVideoJsonBean
import org.greenrobot.eventbus.EventBus
class VeRewardJsBridge(private val context: Context) {
@JavascriptInterface
fun getUserInfo(): String {
val jsInfo = VeRewardJsBean(
RYAction.getMMKV()
.getString(JActivityAdapter.ACCOUNT_TOKEN, "")
.toString(),
getCurrentTimeZone(),
RYAction.getMMKV().getString(JActivityAdapter.ACCOUNT_LANG_KEY, "en")
.toString(),
"android"
)
return Gson().toJson(jsInfo)
}
@JavascriptInterface
fun js2app(string: String) {
val parser = JsonParser()
val rootJson = parser.parse(string) as JsonObject
when (rootJson.get("type").asString) {
"login" -> {
EventBus.getDefault().post(JActivityAdapter.REWARD_LOGIN)
}
"open_notify" -> {
EventBus.getDefault().post(JActivityAdapter.ACCOUNT_WEB_NOTIFICATION)
}
"watch_video" -> {
val fromJson = Gson().fromJson(string, WatchVideoJsonBean::class.java)
context.startActivity(
Intent(
context,
MQVAutoWidthActivity::class.java
).apply {
putExtra(
JActivityAdapter.VIDEO_SHORT_PLAY_ID,
fromJson.data?.short_play_id
)
putExtra(
JActivityAdapter.VIDEO_ACTIVITY_ID,
fromJson.data?.activity_id
)
})
}
}
}
}

View File

@ -0,0 +1,134 @@
package com.veloria.now.shortapp.rewards
import android.annotation.SuppressLint
import android.content.Context
import android.net.Uri
import android.util.AttributeSet
import android.view.LayoutInflater
import android.view.View
import android.widget.FrameLayout
import androidx.appcompat.widget.AppCompatImageView
import androidx.media3.common.MediaItem
import androidx.media3.common.PlaybackException
import androidx.media3.common.Player
import androidx.media3.datasource.DataSource
import androidx.media3.datasource.DefaultDataSourceFactory
import androidx.media3.exoplayer.DefaultRenderersFactory
import androidx.media3.exoplayer.ExoPlayer
import androidx.media3.exoplayer.hls.HlsMediaSource
import androidx.media3.exoplayer.source.MediaSource
import androidx.media3.exoplayer.source.ProgressiveMediaSource
import com.bumptech.glide.Glide
import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.BImage
import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.toast
import com.veloria.now.shortapp.databinding.LayoutBannerPlayerBinding
import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean
import kotlinx.coroutines.cancel
class BannerPlayerView(context: Context, attrs: AttributeSet?) :
FrameLayout(context, attrs) {
@SuppressLint("UnsafeOptInUsageError")
private var builder = ExoPlayer.Builder(context, BImage(context))
.setRenderersFactory(DefaultRenderersFactory(context).setEnableDecoderFallback(true))
private var player: ExoPlayer? = builder.build()
private var isDragging = false
private var ivCover: AppCompatImageView? = null
init {
val inflate =
LayoutInflater.from(context)
.inflate(R.layout.layout_banner_player, this, true)
val explorePlayerViewBinding = LayoutBannerPlayerBinding.bind(inflate)
explorePlayerViewBinding.playerView.player = player
ivCover = explorePlayerViewBinding.playerView.findViewById(R.id.iv_cover_recommend_detail)
player?.addListener(object : Player.Listener {
override fun onPlaybackStateChanged(playbackState: Int) {
super.onPlaybackStateChanged(playbackState)
when (playbackState) {
Player.STATE_BUFFERING -> {
}
Player.STATE_READY -> {
player?.play()
ivCover?.visibility = View.INVISIBLE
}
Player.STATE_ENDED -> {
ivCover?.visibility = View.VISIBLE
}
Player.STATE_IDLE -> {
}
}
}
override fun onPlayerError(error: PlaybackException) {
super.onPlayerError(error)
ivCover?.visibility = View.VISIBLE
}
})
}
fun play() {
if (player != null){
player?.play()
}
}
fun pause() {
if (player != null){
player?.pause()
}
}
fun stop() {
if (player != null){
player?.stop()
}
}
fun release() {
if (player != null){
player?.release()
player = null
}
}
@SuppressLint("UnsafeOptInUsageError")
fun setPlayInfo(dataRes: VeDetailsRecommendBean.ItemDaraBean?) {
if (dataRes != null) {
ivCover?.let {
Glide.with(context).load(dataRes.image_url)
.into(it)
}
ivCover?.visibility = View.VISIBLE
player?.setMediaSource(buildMediaSource(dataRes.video_url))
player?.prepare()
} else {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_video_source_error.toString())
} else {
toast("There is a problem with the video source")
}
}
}
@SuppressLint("UnsafeOptInUsageError")
private fun buildMediaSource(videoPath: String): MediaSource {
val dataSourceFactory: DataSource.Factory = DefaultDataSourceFactory(context, "veloriatv")
return if (videoPath.endsWith(".m3u8")) {
HlsMediaSource.Factory(dataSourceFactory)
.createMediaSource(MediaItem.fromUri(Uri.parse(videoPath)))
} else {
ProgressiveMediaSource.Factory(dataSourceFactory)
.createMediaSource(MediaItem.fromUri(Uri.parse(videoPath)))
}
}
}

View File

@ -580,8 +580,7 @@ class PUtilsView(context: Context, attrs: AttributeSet?) :
tvSeriesPlayer?.text =
"EP.".plus(dataRes.video_info.episode)
var fragment4t: Long = 8643L var fragment4t: Long = 8643L
if (fragment4t < 77L) { if (fragment4t < 77L) {
} }
@ -593,10 +592,14 @@ class PUtilsView(context: Context, attrs: AttributeSet?) :
TranslationHelper.getTranslation()?.veloria_all_episodes.toString(), TranslationHelper.getTranslation()?.veloria_all_episodes.toString(),
dataRes.episode_total.toString() dataRes.episode_total.toString()
) )
tvSeriesPlayer?.text = TranslationHelper.replace(TranslationHelper.getTranslation()?.mireo_EP.toString(),dataRes.video_info.episode.toString())
} else { } else {
tvSeriesPlayerAll?.text = tvSeriesPlayerAll?.text =
"All ".plus(dataRes.episode_total).plus(" Episodes") "All ".plus(dataRes.episode_total).plus(" Episodes")
tvSeriesPlayer?.text =
"EP.".plus(dataRes.video_info.episode)
} }
var stringD: String = "blocksize" var stringD: String = "blocksize"
while (stringD.length > 148) { while (stringD.length > 148) {

View File

@ -28,6 +28,7 @@ import com.veloria.now.shortapp.civil.BImage
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.JActivityAdapter.PLAYER_IS_SEEK import com.veloria.now.shortapp.civil.JActivityAdapter.PLAYER_IS_SEEK
import com.veloria.now.shortapp.civil.JActivityAdapter.PLAYER_LOCK import com.veloria.now.shortapp.civil.JActivityAdapter.PLAYER_LOCK
import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.formatNumber import com.veloria.now.shortapp.civil.formatNumber
import com.veloria.now.shortapp.civil.formatTimestamp import com.veloria.now.shortapp.civil.formatTimestamp
@ -66,16 +67,17 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
private val viewLifecycleScope = MainScope() private val viewLifecycleScope = MainScope()
private var isDragging = false private var isDragging = false
private var seekbarPlayerController: AppCompatSeekBar? = null private var seekbarPlayerController: AppCompatSeekBar? = null
private var exampleProgressJob: Job? = null private var progressJob: Job? = null
private var ivPlayPlayerController: AppCompatImageView? = null private var ivPlayPlayerController: AppCompatImageView? = null
private var ivCollectionController: AppCompatImageView? = null private var ivCollectionController: AppCompatImageView? = null
private var ivBackController: AppCompatImageView? = null private var ivBackController: AppCompatImageView? = null
private var ivCover: AppCompatImageView? = null private var ivCover: AppCompatImageView? = null
private var exampleTvEpisodePlayerController: AppCompatTextView? = null private var tvCollectionNumController: AppCompatTextView? = null
private var ivEpisodePlayerController: AppCompatTextView? = null private var ivEpisodePlayerController: AppCompatTextView? = null
private var llEpisode: LinearLayout? = null private var llEpisode: LinearLayout? = null
private var exampleTvCollectionNumController: AppCompatTextView? = null private var ivCollectionNumController: AppCompatTextView? = null
private var exampleTvTitlePlayerController: AppCompatTextView? = null private var tvTitlePlayerController: AppCompatTextView? = null
private var tvQuality: AppCompatTextView? = null
private var tv_player_seek_time: AppCompatTextView? = null private var tv_player_seek_time: AppCompatTextView? = null
private var loadingLine: UVPlayer? = null private var loadingLine: UVPlayer? = null
private var example_iv_share: AppCompatImageView? = null private var example_iv_share: AppCompatImageView? = null
@ -151,7 +153,7 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
} }
exampleTvEpisodePlayerController = tvCollectionNumController =
exampleDetailPlayerViewBinding.playerView.findViewById(R.id.tv_episode_player) exampleDetailPlayerViewBinding.playerView.findViewById(R.id.tv_episode_player)
var p_managerB: Boolean = true var p_managerB: Boolean = true
println(p_managerB) println(p_managerB)
@ -177,13 +179,13 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
println(listsa) println(listsa)
exampleTvCollectionNumController = ivCollectionNumController =
exampleDetailPlayerViewBinding.playerView.findViewById(R.id.tv_collection_num) exampleDetailPlayerViewBinding.playerView.findViewById(R.id.tv_collection_num)
var top6: Float = 827.0f var top6: Float = 827.0f
println(top6) println(top6)
exampleTvTitlePlayerController = tvTitlePlayerController =
exampleDetailPlayerViewBinding.playerView.findViewById(R.id.tv_player_title) exampleDetailPlayerViewBinding.playerView.findViewById(R.id.tv_player_title)
var logicN: MutableList<String> = mutableListOf<String>() var logicN: MutableList<String> = mutableListOf<String>()
logicN.add("indefinitely") logicN.add("indefinitely")
@ -212,6 +214,8 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
example_iv_share = example_iv_share =
exampleDetailPlayerViewBinding.playerView.findViewById(R.id.iv_share_controller) exampleDetailPlayerViewBinding.playerView.findViewById(R.id.iv_share_controller)
tvQuality =
exampleDetailPlayerViewBinding.playerView.findViewById(R.id.tv_quality)
var interceptv: Long = 6461L var interceptv: Long = 6461L
if (interceptv == 23L) { if (interceptv == 23L) {
} }
@ -526,7 +530,7 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
} }
exampleProgressJob?.cancel() progressJob?.cancel()
var numE: Long = 5987L var numE: Long = 5987L
if (numE <= 157L) { if (numE <= 157L) {
} }
@ -561,7 +565,7 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
} }
exampleProgressJob = viewLifecycleScope.launch { progressJob = viewLifecycleScope.launch {
var arrangementO: String = "audiogen" var arrangementO: String = "audiogen"
if (arrangementO.length > 136) { if (arrangementO.length > 136) {
} }
@ -779,14 +783,14 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
} }
exampleProgressJob?.cancel() progressJob?.cancel()
var unitb: Int = 3323 var unitb: Int = 3323
while (unitb > 110) { while (unitb > 110) {
break break
} }
exampleProgressJob = null progressJob = null
var additionX: Long = 3766L var additionX: Long = 3766L
if (additionX > 11L) { if (additionX > 11L) {
} }
@ -1165,39 +1169,43 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
} }
exampleTvTitlePlayerController?.text = shortVideo.name tvTitlePlayerController?.text = shortVideo.name
var repositoryN: Long = 9371L var repositoryN: Long = 9371L
if (repositoryN == 190L) { if (repositoryN == 190L) {
} }
exampleTvEpisodePlayerController?.text =
"EP.".plus(episode.episode)
var y_widthv: Float = 508.0f var y_widthv: Float = 508.0f
if (y_widthv == 30.0f) { if (y_widthv == 30.0f) {
} }
println(y_widthv) println(y_widthv)
val revolution =
RYAction.getMMKV().getInt(JActivityAdapter.CONSTANTS_QUALITY, 540).toString()
tvQuality?.text = revolution.plus("P")
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
ivEpisodePlayerController?.text = ivEpisodePlayerController?.text =
TranslationHelper.replace( TranslationHelper.replace(
TranslationHelper.getTranslation()?.veloria_all_episodes.toString(), TranslationHelper.getTranslation()?.veloria_all_episodes.toString(),
shortVideo.episode_total.toString() shortVideo.episode_total.toString()
) )
tvCollectionNumController?.text = TranslationHelper.replace(TranslationHelper.getTranslation()?.mireo_EP.toString(),episode.episode.toString())
} else { } else {
ivEpisodePlayerController?.text = ivEpisodePlayerController?.text =
"All ".plus(shortVideo.episode_total).plus(" Episodes") "All ".plus(shortVideo.episode_total).plus(" Episodes")
tvCollectionNumController?.text =
"EP.".plus(episode.episode)
} }
var splashB: MutableMap<String, Float> = mutableMapOf<String, Float>() var splashB: MutableMap<String, Float> = mutableMapOf<String, Float>()
splashB.put("dividor", 509.0f) splashB.put("dividor", 509.0f)
splashB.put("tagavr", 760.0f) splashB.put("tagavr", 760.0f)
exampleTvCollectionNumController?.text = formatNumber(shortVideo.collect_total) ivCollectionNumController?.text = formatNumber(shortVideo.collect_total)
var freej: Long = 4100L var freej: Long = 4100L
exampleTvCollectionNumController?.setTextColor( ivCollectionNumController?.setTextColor(
if (shortVideo.is_collect) resources.getColor( if (shortVideo.is_collect) resources.getColor(
R.color.listLineActivity R.color.listLineActivity
) else resources.getColor(R.color.white) ) else resources.getColor(R.color.white)
@ -1279,6 +1287,10 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
EventBus.getDefault() EventBus.getDefault()
.post(JActivityAdapter.DetailPlayerVieww_CLOSE) .post(JActivityAdapter.DetailPlayerVieww_CLOSE)
} }
tvQuality?.setOnClickListener {
EventBus.getDefault()
.post(JActivityAdapter.CONSTANTS_QUALITY)
}
} else { } else {
var additionJ: Double = 725.0 var additionJ: Double = 725.0
@ -1332,6 +1344,6 @@ class TOYPlayfairAutoView(context: Context, attrs: AttributeSet?) :
println(cagetoryU) println(cagetoryU)
exampleProgressJob?.cancel() progressJob?.cancel()
} }
} }

View File

@ -13,8 +13,8 @@ import androidx.annotation.RawRes
import androidx.annotation.StringRes import androidx.annotation.StringRes
import androidx.core.content.ContextCompat import androidx.core.content.ContextCompat
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.TranslationHelper
import kotlin.math.min import kotlin.math.min
import kotlin.math.max
class VSNotificationsDefault @JvmOverloads constructor( class VSNotificationsDefault @JvmOverloads constructor(
@ -22,15 +22,17 @@ class VSNotificationsDefault @JvmOverloads constructor(
defStyleAttr: Int = 0, defStyleRes: Int = 0 defStyleAttr: Int = 0, defStyleRes: Int = 0
) : ) :
FrameLayout(context, attrs, defStyleAttr, defStyleRes) { FrameLayout(context, attrs, defStyleAttr, defStyleRes) {
@Volatile @Volatile
var traceTestPadding: Float = 9408.0f var traceTestPadding: Float = 9408.0f
@Volatile
private var movePlayfairMeasureArray: MutableList<Float> = mutableListOf<Float>()
@Volatile
var rewardsRightDelete_p0Index: Long = 2995L
@Volatile
var scannerBingeListener_idx: Long = 8377L
@Volatile
private var movePlayfairMeasureArray: MutableList<Float> = mutableListOf<Float>()
@Volatile
var rewardsRightDelete_p0Index: Long = 2995L
@Volatile
var scannerBingeListener_idx: Long = 8377L
private var mainLayout: ViewGroup? = null private var mainLayout: ViewGroup? = null
@ -45,77 +47,97 @@ private var movePlayfairMeasureArray: MutableList<Float> = mutableListOf<Float>
private var listener: OnRetryListener? = null private var listener: OnRetryListener? = null
private fun cloudyDramaCancelFormatSink(smartNotifications: Long, imgFirst: Float, setupKeyboard: MutableList<Int>) :Long { private fun cloudyDramaCancelFormatSink(
smartNotifications: Long,
imgFirst: Float,
setupKeyboard: MutableList<Int>
): Long {
var resJust = 4399L var resJust = 4399L
var priceRetrofit:Int = 5523 var priceRetrofit: Int = 5523
println(priceRetrofit) println(priceRetrofit)
var tabRenderers:MutableList<Float> = mutableListOf<Float>() var tabRenderers: MutableList<Float> = mutableListOf<Float>()
var xnasmSchnorr:Long = 5218L var xnasmSchnorr: Long = 5218L
resJust -= 9248L resJust -= 9248L
xnasmSchnorr *= resJust xnasmSchnorr *= resJust
priceRetrofit -= 1846 priceRetrofit -= 1846
return xnasmSchnorr return xnasmSchnorr
} }
private fun surfaceHeightProgressiveBrowseCoreMain() { private fun surfaceHeightProgressiveBrowseCoreMain() {
var hexcharint_z:MutableList<Int> = mutableListOf<Int>() var hexcharint_z: MutableList<Int> = mutableListOf<Int>()
var likeInformation:Long = this.cloudyDramaCancelFormatSink(8186L,9572.0f,hexcharint_z) var likeInformation: Long = this.cloudyDramaCancelFormatSink(8186L, 9572.0f, hexcharint_z)
if (likeInformation == 51L) { if (likeInformation == 51L) {
println(likeInformation) println(likeInformation)
} }
var job_likeInformation: Int = likeInformation.toInt() var job_likeInformation: Int = likeInformation.toInt()
println(likeInformation) println(likeInformation)
var collect6:Long = 4445L var collect6: Long = 4445L
if (collect6 >= 9L) {} if (collect6 >= 9L) {
}
println(collect6) println(collect6)
mainLayout = LayoutInflater.from(context) mainLayout = LayoutInflater.from(context)
.inflate(R.layout.u_resource, this, false) as ViewGroup .inflate(R.layout.u_resource, this, false) as ViewGroup
var with_aK:Boolean = false var with_aK: Boolean = false
while (!with_aK) { break } while (!with_aK) {
break
}
imageView = mainLayout!!.findViewById(R.id.iv_icon) imageView = mainLayout!!.findViewById(R.id.iv_icon)
var networki:MutableList<Double> = mutableListOf<Double>() var networki: MutableList<Double> = mutableListOf<Double>()
networki.add(816.0) networki.add(816.0)
networki.add(936.0) networki.add(936.0)
networki.add(330.0) networki.add(330.0)
networki.add(918.0) networki.add(918.0)
networki.add(406.0) networki.add(406.0)
if (networki.contains(8136.0)) {} if (networki.contains(8136.0)) {
}
println(networki) println(networki)
tvContent = mainLayout!!.findViewById(R.id.tvEmptyTitle) tvContent = mainLayout!!.findViewById(R.id.tvEmptyTitle)
var handleru:Boolean = true var handleru: Boolean = true
while (handleru) { break } while (handleru) {
break
}
tvMessage = mainLayout!!.findViewById(R.id.tvEmptyMessage) tvMessage = mainLayout!!.findViewById(R.id.tvEmptyMessage)
var place1:Long = 4101L var place1: Long = 4101L
while (place1 > 147L) { break } while (place1 > 147L) {
break
}
retryView = mainLayout!!.findViewById(R.id.btnRetry) retryView = mainLayout!!.findViewById(R.id.btnRetry)
var cloudj:Double = 9036.0 var cloudj: Double = 9036.0
while (cloudj < 171.0) { break } while (cloudj < 171.0) {
break
}
if (TranslationHelper.getTranslation() != null) {
tvContent?.text = TranslationHelper.getTranslation()?.veloria_no_data
tvMessage?.text = TranslationHelper.getTranslation()?.veloria_no_data_add
retryView?.text = TranslationHelper.getTranslation()?.veloria_try_again
}
retryView!!.setOnClickListener { retryView!!.setOnClickListener {
var free6:Boolean = true var free6: Boolean = true
var statey:Int = 4980 var statey: Int = 4980
if (statey < 131) {} if (statey < 131) {
}
println(statey) println(statey)
@ -125,44 +147,46 @@ println(likeInformation)
} }
private fun needForeverIllegalViewScreen() :String { private fun needForeverIllegalViewScreen(): String {
var needCorrect:MutableMap<String,String> = mutableMapOf<String,String>() var needCorrect: MutableMap<String, String> = mutableMapOf<String, String>()
var userHeight:String = "sendv" var userHeight: String = "sendv"
var visibleFddebcdbeeffcebdf = mutableMapOf<String,Long>() var visibleFddebcdbeeffcebdf = mutableMapOf<String, Long>()
println(visibleFddebcdbeeffcebdf) println(visibleFddebcdbeeffcebdf)
var footerSeconds:Float = 727.0f var footerSeconds: Float = 727.0f
println(footerSeconds) println(footerSeconds)
var n_77Hwdownload:String = "headphone" var n_77Hwdownload: String = "headphone"
if (userHeight == "smart") { if (userHeight == "smart") {
println("userHeight" + userHeight) println("userHeight" + userHeight)
} }
if (null != userHeight) { if (null != userHeight) {
var resource_z:Int = min(1, kotlin.random.Random.nextInt(64)) % userHeight.length var resource_z: Int = min(1, kotlin.random.Random.nextInt(64)) % userHeight.length
var upload_x:Int = min(1, kotlin.random.Random.nextInt(81)) % n_77Hwdownload.length var upload_x: Int = min(1, kotlin.random.Random.nextInt(81)) % n_77Hwdownload.length
n_77Hwdownload += userHeight.get(resource_z) n_77Hwdownload += userHeight.get(resource_z)
} }
if (footerSeconds >= -128 && footerSeconds <= 128){ if (footerSeconds >= -128 && footerSeconds <= 128) {
var salt_o = min(1, kotlin.random.Random.nextInt(17)) % n_77Hwdownload.length var salt_o = min(1, kotlin.random.Random.nextInt(17)) % n_77Hwdownload.length
n_77Hwdownload += footerSeconds.toString() n_77Hwdownload += footerSeconds.toString()
} }
return n_77Hwdownload return n_77Hwdownload
} }
fun setTitle(text: CharSequence?) { fun setTitle(text: CharSequence?) {
var handshakeEach:String = this.needForeverIllegalViewScreen() var handshakeEach: String = this.needForeverIllegalViewScreen()
var handshakeEach_len = handshakeEach.length var handshakeEach_len = handshakeEach.length
println(handshakeEach) println(handshakeEach)
println(handshakeEach) println(handshakeEach)
var draggingb:Double = 154.0 var draggingb: Double = 154.0
while (draggingb > 96.0) { break } while (draggingb > 96.0) {
break
}
println(draggingb) println(draggingb)
@ -170,38 +194,40 @@ println(handshakeEach)
} }
private fun prepareFollowCellInnerOff() :Double { private fun prepareFollowCellInnerOff(): Double {
var handlerTrends = "recv" var handlerTrends = "recv"
println(handlerTrends) println(handlerTrends)
var bindingModel:Boolean = false var bindingModel: Boolean = false
println(bindingModel) println(bindingModel)
var videoCorrect:Float = 7731.0f var videoCorrect: Float = 7731.0f
var bootstrapBinkdata:Double = 5230.0 var bootstrapBinkdata: Double = 5230.0
bindingModel = false bindingModel = false
bootstrapBinkdata *= if(bindingModel) 53 else 35 bootstrapBinkdata *= if (bindingModel) 53 else 35
videoCorrect *= videoCorrect videoCorrect *= videoCorrect
return bootstrapBinkdata return bootstrapBinkdata
} }
fun hide() { fun hide() {
var transcodeMrz:Double = this.prepareFollowCellInnerOff() var transcodeMrz: Double = this.prepareFollowCellInnerOff()
println(transcodeMrz) println(transcodeMrz)
println(transcodeMrz) println(transcodeMrz)
var stylesG:Boolean = false var stylesG: Boolean = false
if (!stylesG) {} if (!stylesG) {
}
if (mainLayout == null || !isShow()) { if (mainLayout == null || !isShow()) {
var schemeP:String = "terminate" var schemeP: String = "terminate"
if (schemeP.length > 0) {} if (schemeP.length > 0) {
}
return return
@ -210,41 +236,41 @@ println(transcodeMrz)
} }
private fun bindCorrectPriceCapability(historyModule: Double) :MutableMap<String,Float> { private fun bindCorrectPriceCapability(historyModule: Double): MutableMap<String, Float> {
var manualItem = mutableListOf<Int>() var manualItem = mutableListOf<Int>()
var agentView:MutableMap<String,Boolean> = mutableMapOf<String,Boolean>() var agentView: MutableMap<String, Boolean> = mutableMapOf<String, Boolean>()
println(agentView) println(agentView)
var trendCover:Float = 9605.0f var trendCover: Float = 9605.0f
println(trendCover) println(trendCover)
var manifestVariable:String = "vmafmotiondsp" var manifestVariable: String = "vmafmotiondsp"
println(manifestVariable) println(manifestVariable)
var failableLatitudeVmhd:MutableMap<String,Float> = mutableMapOf<String,Float>() var failableLatitudeVmhd: MutableMap<String, Float> = mutableMapOf<String, Float>()
failableLatitudeVmhd.put("ffmpeg", 500.0f) failableLatitudeVmhd.put("ffmpeg", 500.0f)
failableLatitudeVmhd.put("mipsfpu", 763.0f) failableLatitudeVmhd.put("mipsfpu", 763.0f)
failableLatitudeVmhd.put("avstring", 716.0f) failableLatitudeVmhd.put("avstring", 716.0f)
for(guessed in manualItem) { for (guessed in manualItem) {
failableLatitudeVmhd.put("impulseEnumvalueComb", guessed.toFloat()) failableLatitudeVmhd.put("impulseEnumvalueComb", guessed.toFloat())
} }
for(should in 0 .. agentView.keys.toList().size - 1) { for (should in 0..agentView.keys.toList().size - 1) {
failableLatitudeVmhd.put("webpages", 0.0f) failableLatitudeVmhd.put("webpages", 0.0f)
} }
trendCover -= 1253.0f trendCover -= 1253.0f
failableLatitudeVmhd.put("crossfadingRngSegwit", trendCover) failableLatitudeVmhd.put("crossfadingRngSegwit", trendCover)
failableLatitudeVmhd.put("cascaded", 973.0f) failableLatitudeVmhd.put("cascaded", 973.0f)
return failableLatitudeVmhd return failableLatitudeVmhd
} }
fun setIcon(@DrawableRes id: Int) { fun setIcon(@DrawableRes id: Int) {
var alsasymboltableAdjectives = this.bindCorrectPriceCapability(5459.0) var alsasymboltableAdjectives = this.bindCorrectPriceCapability(5459.0)
val _alsasymboltableAdjectivestemp = alsasymboltableAdjectives.keys.toList() val _alsasymboltableAdjectivestemp = alsasymboltableAdjectives.keys.toList()
for(index_j in 0 .. _alsasymboltableAdjectivestemp.size - 1) { for (index_j in 0.._alsasymboltableAdjectivestemp.size - 1) {
val key_index_j = _alsasymboltableAdjectivestemp.get(index_j) val key_index_j = _alsasymboltableAdjectivestemp.get(index_j)
val value_index_j = alsasymboltableAdjectives.get(key_index_j) val value_index_j = alsasymboltableAdjectives.get(key_index_j)
if (index_j == 99) { if (index_j == 99) {
@ -253,25 +279,27 @@ var alsasymboltableAdjectives = this.bindCorrectPriceCapability(5459.0)
break break
} }
} }
var alsasymboltableAdjectives_len:Int = alsasymboltableAdjectives.size var alsasymboltableAdjectives_len: Int = alsasymboltableAdjectives.size
println(alsasymboltableAdjectives) println(alsasymboltableAdjectives)
var edit4:Double = 3986.0 var edit4: Double = 3986.0
while (edit4 < 76.0) { break } while (edit4 < 76.0) {
break
}
setIcon(ContextCompat.getDrawable(context, id)) setIcon(ContextCompat.getDrawable(context, id))
} }
private fun beginPortArePlatform() :Boolean { private fun beginPortArePlatform(): Boolean {
var downPager = "clli" var downPager = "clli"
var cutPath:Int = 210 var cutPath: Int = 210
var time_hRetry:Boolean = false var time_hRetry: Boolean = false
var headerDefault_60 = "cronos" var headerDefault_60 = "cronos"
var prodMbufsHints:Boolean = false var prodMbufsHints: Boolean = false
cutPath -= 7075 cutPath -= 7075
prodMbufsHints = cutPath > 4 prodMbufsHints = cutPath > 4
time_hRetry = true time_hRetry = true
@ -279,68 +307,75 @@ private fun beginPortArePlatform() :Boolean {
return prodMbufsHints return prodMbufsHints
} }
fun isShow(): Boolean { fun isShow(): Boolean {
var rlottiecommonAwait = this.beginPortArePlatform() var rlottiecommonAwait = this.beginPortArePlatform()
if (!rlottiecommonAwait) { if (!rlottiecommonAwait) {
println("keyword") println("keyword")
} }
println(rlottiecommonAwait) println(rlottiecommonAwait)
var transparentc:String = "movepage" var transparentc: String = "movepage"
while (transparentc.length > 194) { break } while (transparentc.length > 194) {
break
}
return mainLayout != null && mainLayout?.visibility == VISIBLE return mainLayout != null && mainLayout?.visibility == VISIBLE
} }
private fun hailTopDispatchZoomAlsoLaunch(cloudDisplay: MutableMap<String,Boolean>) :MutableMap<String,Int> { private fun hailTopDispatchZoomAlsoLaunch(cloudDisplay: MutableMap<String, Boolean>): MutableMap<String, Int> {
var managerHeader:String = "max" var managerHeader: String = "max"
println(managerHeader) println(managerHeader)
var seekIndex = 640.0f var seekIndex = 640.0f
println(seekIndex) println(seekIndex)
var androidCharacter:MutableMap<String,String> = mutableMapOf<String,String>() var androidCharacter: MutableMap<String, String> = mutableMapOf<String, String>()
var requestVideo = mutableListOf<Long>() var requestVideo = mutableListOf<Long>()
var ffprobeOwnersCreating = mutableMapOf<String,Int>() var ffprobeOwnersCreating = mutableMapOf<String, Int>()
ffprobeOwnersCreating.put("overlay", managerHeader.length) ffprobeOwnersCreating.put("overlay", managerHeader.length)
seekIndex = 840.0f seekIndex = 840.0f
ffprobeOwnersCreating.put("cacheNcomingAaaa", 4562) ffprobeOwnersCreating.put("cacheNcomingAaaa", 4562)
for(pixfmts in androidCharacter) { for (pixfmts in androidCharacter) {
ffprobeOwnersCreating.put("mafq", if (pixfmts.value.matches(Regex("(-)?(^[0-9]+$)"))) pixfmts.value.toInt() else 27) ffprobeOwnersCreating.put(
"mafq",
if (pixfmts.value.matches(Regex("(-)?(^[0-9]+$)"))) pixfmts.value.toInt() else 27
)
} }
for(cert in 0 .. requestVideo.size - 1) { for (cert in 0..requestVideo.size - 1) {
ffprobeOwnersCreating.put("actuallyVmslGsmdec", requestVideo.get(cert).toInt()) ffprobeOwnersCreating.put("actuallyVmslGsmdec", requestVideo.get(cert).toInt())
} }
return ffprobeOwnersCreating return ffprobeOwnersCreating
} }
fun setAnimResource(@RawRes id: Int) { fun setAnimResource(@RawRes id: Int) {
var handleBadge:MutableMap<String,Int> = this.hailTopDispatchZoomAlsoLaunch(mutableMapOf<String,Boolean>()) var handleBadge: MutableMap<String, Int> =
this.hailTopDispatchZoomAlsoLaunch(mutableMapOf<String, Boolean>())
var handleBadge_len:Int = handleBadge.size var handleBadge_len: Int = handleBadge.size
for(obj_u in handleBadge) { for (obj_u in handleBadge) {
println(obj_u.key) println(obj_u.key)
println(obj_u.value) println(obj_u.value)
} }
println(handleBadge) println(handleBadge)
var postY:Double = 547.0 var postY: Double = 547.0
if (postY < 93.0) {} if (postY < 93.0) {
}
imageView?.apply { imageView?.apply {
@ -348,160 +383,171 @@ println(handleBadge)
} }
private fun queryAccessLight(placeBuy: Int, againDashboard: Boolean) :Float { private fun queryAccessLight(placeBuy: Int, againDashboard: Boolean): Float {
var deteleAttrs = 9391L var deteleAttrs = 9391L
var bingeBanner = 2600 var bingeBanner = 2600
println(bingeBanner) println(bingeBanner)
var emptyAvailable:Boolean = true var emptyAvailable: Boolean = true
var launcherCheckbox = 7949L var launcherCheckbox = 7949L
var visualizationEdia:Float = 9168.0f var visualizationEdia: Float = 9168.0f
deteleAttrs += 5878L deteleAttrs += 5878L
bingeBanner -= 7264 bingeBanner -= 7264
emptyAvailable = false emptyAvailable = false
visualizationEdia += if(emptyAvailable) 7 else 10 visualizationEdia += if (emptyAvailable) 7 else 10
launcherCheckbox -= deteleAttrs launcherCheckbox -= deteleAttrs
launcherCheckbox += launcherCheckbox launcherCheckbox += launcherCheckbox
return visualizationEdia return visualizationEdia
} }
fun show() { fun show() {
var exportIfaddrs:Float = this.queryAccessLight(2332,false) var exportIfaddrs: Float = this.queryAccessLight(2332, false)
println(exportIfaddrs) println(exportIfaddrs)
var exportIfaddrs_collections: Double = exportIfaddrs.toDouble() var exportIfaddrs_collections: Double = exportIfaddrs.toDouble()
println(exportIfaddrs) println(exportIfaddrs)
var min_l_:Double = 630.0 var min_l_: Double = 630.0
if (min_l_ >= 94.0) {} if (min_l_ >= 94.0) {
}
if (mainLayout == null) { if (mainLayout == null) {
var closel:Float = 3076.0f var closel: Float = 3076.0f
while (closel >= 36.0f) { break } while (closel >= 36.0f) {
break
}
surfaceHeightProgressiveBrowseCoreMain() surfaceHeightProgressiveBrowseCoreMain()
} }
if (isShow()) { if (isShow()) {
var roundy:Float = 6748.0f var roundy: Float = 6748.0f
if (roundy < 100.0f) {} if (roundy < 100.0f) {
}
return return
} }
retryView!!.visibility = INVISIBLE retryView!!.visibility = INVISIBLE
var cut2:Int = 4701 var cut2: Int = 4701
if (cut2 <= 68) {} if (cut2 <= 68) {
}
mainLayout!!.visibility = VISIBLE mainLayout!!.visibility = VISIBLE
} }
private fun takeCollectBannerLevel() :String { private fun takeCollectBannerLevel(): String {
var launchMove:Boolean = true var launchMove: Boolean = true
var standName = 1785.0 var standName = 1785.0
println(standName) println(standName)
var playingHeight:Float = 9620.0f var playingHeight: Float = 9620.0f
var surfaceTrends:Double = 6023.0 var surfaceTrends: Double = 6023.0
var sbcdecMixinOptable:String = "realtime" var sbcdecMixinOptable: String = "realtime"
if (false == launchMove){ if (false == launchMove) {
println("click") println("click")
} }
if (standName >= -128 && standName <= 128){ if (standName >= -128 && standName <= 128) {
var current_w = min(1, kotlin.random.Random.nextInt(11)) % sbcdecMixinOptable.length var current_w = min(1, kotlin.random.Random.nextInt(11)) % sbcdecMixinOptable.length
sbcdecMixinOptable += standName.toString() sbcdecMixinOptable += standName.toString()
} }
if (playingHeight <= 128 && playingHeight >= -128){ if (playingHeight <= 128 && playingHeight >= -128) {
var format_i:Int = min(1, kotlin.random.Random.nextInt(79)) % sbcdecMixinOptable.length var format_i: Int = min(1, kotlin.random.Random.nextInt(79)) % sbcdecMixinOptable.length
sbcdecMixinOptable += playingHeight.toString() sbcdecMixinOptable += playingHeight.toString()
} }
if (surfaceTrends <= 128 && surfaceTrends >= -128){ if (surfaceTrends <= 128 && surfaceTrends >= -128) {
var keyword_n = min(1, kotlin.random.Random.nextInt(100)) % sbcdecMixinOptable.length var keyword_n = min(1, kotlin.random.Random.nextInt(100)) % sbcdecMixinOptable.length
sbcdecMixinOptable += surfaceTrends.toString() sbcdecMixinOptable += surfaceTrends.toString()
} }
return sbcdecMixinOptable return sbcdecMixinOptable
} }
fun setHint(text: CharSequence?) { fun setHint(text: CharSequence?) {
var stormbirdWidefelem:String = this.takeCollectBannerLevel() var stormbirdWidefelem: String = this.takeCollectBannerLevel()
if (stormbirdWidefelem == "user") { if (stormbirdWidefelem == "user") {
println(stormbirdWidefelem) println(stormbirdWidefelem)
} }
var stormbirdWidefelem_len:Int = stormbirdWidefelem.length var stormbirdWidefelem_len: Int = stormbirdWidefelem.length
println(stormbirdWidefelem) println(stormbirdWidefelem)
var watchingX:Boolean = false var watchingX: Boolean = false
tvMessage?.text = text ?: "" tvMessage?.text = text ?: ""
} }
private fun showHistoryAgo() :String { private fun showHistoryAgo(): String {
var builderRewards = true var builderRewards = true
var cameraBinge:MutableList<Boolean> = mutableListOf<Boolean>() var cameraBinge: MutableList<Boolean> = mutableListOf<Boolean>()
println(cameraBinge) println(cameraBinge)
var closeType_tk:Boolean = false var closeType_tk: Boolean = false
var default_gxVisit = 1581L var default_gxVisit = 1581L
var capsHevmask = "user" var capsHevmask = "user"
if (builderRewards == false){ if (builderRewards == false) {
println("remove") println("remove")
} }
if (closeType_tk){ if (closeType_tk) {
println("banner") println("banner")
} }
if (default_gxVisit >= -128 && default_gxVisit <= 128){ if (default_gxVisit >= -128 && default_gxVisit <= 128) {
var again_u = min(1, kotlin.random.Random.nextInt(75)) % capsHevmask.length var again_u = min(1, kotlin.random.Random.nextInt(75)) % capsHevmask.length
capsHevmask += default_gxVisit.toString() capsHevmask += default_gxVisit.toString()
} }
return capsHevmask return capsHevmask
} }
fun setOnRetryListener(listener: OnRetryListener?) { fun setOnRetryListener(listener: OnRetryListener?) {
var allpassSerialize = this.showHistoryAgo() var allpassSerialize = this.showHistoryAgo()
println(allpassSerialize) println(allpassSerialize)
var allpassSerialize_len = allpassSerialize.length var allpassSerialize_len = allpassSerialize.length
println(allpassSerialize) println(allpassSerialize)
var utilsb:MutableList<Boolean> = mutableListOf<Boolean>() var utilsb: MutableList<Boolean> = mutableListOf<Boolean>()
utilsb.add(false) utilsb.add(false)
utilsb.add(false) utilsb.add(false)
utilsb.add(true) utilsb.add(true)
utilsb.add(false) utilsb.add(false)
utilsb.add(true) utilsb.add(true)
while (utilsb.size > 199) { break } while (utilsb.size > 199) {
break
}
println(utilsb) println(utilsb)
this.listener = listener this.listener = listener
var explorem:Int = 6157 var explorem: Int = 6157
while (explorem > 200) { break } while (explorem > 200) {
break
}
if (isShow()) { if (isShow()) {
var clipG:Double = 7440.0 var clipG: Double = 7440.0
while (clipG > 58.0) { break } while (clipG > 58.0) {
break
}
retryView!!.visibility = if (this.listener == null) INVISIBLE else VISIBLE retryView!!.visibility = if (this.listener == null) INVISIBLE else VISIBLE
@ -509,13 +555,13 @@ println(allpassSerialize)
} }
private fun requireMathAgentBody(animatorKeyword: Boolean) :Long { private fun requireMathAgentBody(animatorKeyword: Boolean): Long {
var handlerFooter:MutableMap<String,Float> = mutableMapOf<String,Float>() var handlerFooter: MutableMap<String, Float> = mutableMapOf<String, Float>()
var collectAnimator:Double = 1861.0 var collectAnimator: Double = 1861.0
var logoName = 7849L var logoName = 7849L
println(logoName) println(logoName)
var paintModel:Long = 5558L var paintModel: Long = 5558L
var devpollAutocapitalization:Long = 7487L var devpollAutocapitalization: Long = 7487L
collectAnimator -= collectAnimator collectAnimator -= collectAnimator
logoName = logoName * paintModel logoName = logoName * paintModel
devpollAutocapitalization *= logoName devpollAutocapitalization *= logoName
@ -524,33 +570,36 @@ private fun requireMathAgentBody(animatorKeyword: Boolean) :Long {
return devpollAutocapitalization return devpollAutocapitalization
} }
fun setIcon(drawable: Drawable?) { fun setIcon(drawable: Drawable?) {
var modmContaining = this.requireMathAgentBody(false) var modmContaining = this.requireMathAgentBody(false)
var local_d6_modmContaining: Int = modmContaining.toInt() var local_d6_modmContaining: Int = modmContaining.toInt()
println(modmContaining) println(modmContaining)
println(modmContaining) println(modmContaining)
var adapterX:MutableMap<String,Boolean> = mutableMapOf<String,Boolean>() var adapterX: MutableMap<String, Boolean> = mutableMapOf<String, Boolean>()
adapterX.put("sea", false) adapterX.put("sea", false)
adapterX.put("srp", false) adapterX.put("srp", false)
adapterX.put("jobq", true) adapterX.put("jobq", true)
if (adapterX.get("g") != null) {} if (adapterX.get("g") != null) {
}
println(adapterX) println(adapterX)
imageView?.apply { imageView?.apply {
var window_o7:MutableList<Long> = mutableListOf<Long>() var window_o7: MutableList<Long> = mutableListOf<Long>()
window_o7.add(919L) window_o7.add(919L)
window_o7.add(651L) window_o7.add(651L)
window_o7.add(874L) window_o7.add(874L)
while (window_o7.size > 67) { break } while (window_o7.size > 67) {
break
}
setImageDrawable(drawable) setImageDrawable(drawable)
@ -558,44 +607,53 @@ println(modmContaining)
} }
private fun commitDriverBottom(bindingProfile: MutableMap<String,Long>, userHelp: Int, handlerBottom: MutableMap<String,Long>) :String { private fun commitDriverBottom(
bindingProfile: MutableMap<String, Long>,
userHelp: Int,
handlerBottom: MutableMap<String, Long>
): String {
var latestDisplay = 4878L var latestDisplay = 4878L
var uploadHome = 1707.0f var uploadHome = 1707.0f
println(uploadHome) println(uploadHome)
var giftBackground = true var giftBackground = true
var navigationbarHqdspIntle:String = "twopoint" var navigationbarHqdspIntle: String = "twopoint"
if (latestDisplay >= -128 && latestDisplay <= 128){ if (latestDisplay >= -128 && latestDisplay <= 128) {
var active_i:Int = min(1, kotlin.random.Random.nextInt(41)) % navigationbarHqdspIntle.length var active_i: Int =
min(1, kotlin.random.Random.nextInt(41)) % navigationbarHqdspIntle.length
navigationbarHqdspIntle += latestDisplay.toString() navigationbarHqdspIntle += latestDisplay.toString()
} }
if (uploadHome >= -128 && uploadHome <= 128){ if (uploadHome >= -128 && uploadHome <= 128) {
var point_s:Int = min(1, kotlin.random.Random.nextInt(57)) % navigationbarHqdspIntle.length var point_s: Int =
min(1, kotlin.random.Random.nextInt(57)) % navigationbarHqdspIntle.length
navigationbarHqdspIntle += uploadHome.toString() navigationbarHqdspIntle += uploadHome.toString()
} }
if (giftBackground){ if (giftBackground) {
println("binge") println("binge")
} }
return navigationbarHqdspIntle return navigationbarHqdspIntle
} }
fun netWorkShow() { fun netWorkShow() {
var contextRingtone = this.commitDriverBottom(mutableMapOf<String,Long>(),834,mutableMapOf<String,Long>()) var contextRingtone =
this.commitDriverBottom(mutableMapOf<String, Long>(), 834, mutableMapOf<String, Long>())
var contextRingtone_len:Int = contextRingtone.length var contextRingtone_len: Int = contextRingtone.length
println(contextRingtone) println(contextRingtone)
println(contextRingtone) println(contextRingtone)
var renderersP:String = "tweaks" var renderersP: String = "tweaks"
while (renderersP.length > 166) { break } while (renderersP.length > 166) {
break
}
this.traceTestPadding = 640.0f this.traceTestPadding = 640.0f
this.movePlayfairMeasureArray = mutableListOf<Float>() this.movePlayfairMeasureArray = mutableListOf<Float>()
@ -605,27 +663,33 @@ this.traceTestPadding = 640.0f
if (mainLayout == null) { if (mainLayout == null) {
var c_managerf:Float = 5448.0f var c_managerf: Float = 5448.0f
while (c_managerf == 116.0f) { break } while (c_managerf == 116.0f) {
break
}
surfaceHeightProgressiveBrowseCoreMain() surfaceHeightProgressiveBrowseCoreMain()
} }
if (isShow()) { if (isShow()) {
var closeS:Int = 9872 var closeS: Int = 9872
while (closeS <= 115) { break } while (closeS <= 115) {
break
}
return return
} }
setIcon(R.mipmap.button_banner) setIcon(R.mipmap.button_banner)
var giftA:Double = 7976.0 var giftA: Double = 7976.0
if (giftA > 120.0) {} if (giftA > 120.0) {
}
setHint("Network anomaly") setHint("Network anomaly")
var saltE:Boolean = true var saltE: Boolean = true
if (saltE) {} if (saltE) {
}
retryView!!.visibility = if (listener == null) INVISIBLE else VISIBLE retryView!!.visibility = if (listener == null) INVISIBLE else VISIBLE
@ -633,9 +697,9 @@ this.traceTestPadding = 640.0f
} }
private fun seekClickSetupCheckNothing() :String { private fun seekClickSetupCheckNothing(): String {
var bodyloadLoading:String = "steps" var bodyloadLoading: String = "steps"
var coinsRecord:Long = 4784L var coinsRecord: Long = 4784L
println(coinsRecord) println(coinsRecord)
var eventFfmpeg = 596.0 var eventFfmpeg = 596.0
println(eventFfmpeg) println(eventFfmpeg)
@ -644,40 +708,43 @@ private fun seekClickSetupCheckNothing() :String {
if (bodyloadLoading == "price") { if (bodyloadLoading == "price") {
println("bodyloadLoading" + bodyloadLoading) println("bodyloadLoading" + bodyloadLoading)
} }
if(bodyloadLoading.length > 0 && mismatchesSerializableLookup.length > 0) { if (bodyloadLoading.length > 0 && mismatchesSerializableLookup.length > 0) {
mismatchesSerializableLookup += bodyloadLoading.get(0) mismatchesSerializableLookup += bodyloadLoading.get(0)
} }
if (coinsRecord <= 128 && coinsRecord >= -128){ if (coinsRecord <= 128 && coinsRecord >= -128) {
var free_w = min(1, kotlin.random.Random.nextInt(52)) % mismatchesSerializableLookup.length var free_w =
min(1, kotlin.random.Random.nextInt(52)) % mismatchesSerializableLookup.length
mismatchesSerializableLookup += coinsRecord.toString() mismatchesSerializableLookup += coinsRecord.toString()
} }
if (eventFfmpeg >= -128 && eventFfmpeg <= 128){ if (eventFfmpeg >= -128 && eventFfmpeg <= 128) {
var select_r:Int = min(1, kotlin.random.Random.nextInt(60)) % mismatchesSerializableLookup.length var select_r: Int =
min(1, kotlin.random.Random.nextInt(60)) % mismatchesSerializableLookup.length
mismatchesSerializableLookup += eventFfmpeg.toString() mismatchesSerializableLookup += eventFfmpeg.toString()
} }
if (profileCamera >= -128 && profileCamera <= 128){ if (profileCamera >= -128 && profileCamera <= 128) {
var ffmpeg_q = min(1, kotlin.random.Random.nextInt(18)) % mismatchesSerializableLookup.length var ffmpeg_q =
min(1, kotlin.random.Random.nextInt(18)) % mismatchesSerializableLookup.length
mismatchesSerializableLookup += profileCamera.toString() mismatchesSerializableLookup += profileCamera.toString()
} }
return mismatchesSerializableLookup return mismatchesSerializableLookup
} }
fun setHint(@StringRes id: Int) { fun setHint(@StringRes id: Int) {
var accuratePolls:String = this.seekClickSetupCheckNothing() var accuratePolls: String = this.seekClickSetupCheckNothing()
if (accuratePolls == "num") { if (accuratePolls == "num") {
println(accuratePolls) println(accuratePolls)
} }
var accuratePolls_len:Int = accuratePolls.length var accuratePolls_len: Int = accuratePolls.length
println(accuratePolls) println(accuratePolls)
var recommendsk:Long = 7632L var recommendsk: Long = 7632L
setHint(resources.getString(id)) setHint(resources.getString(id))

View File

@ -15,6 +15,7 @@ import com.scwang.smart.refresh.layout.api.RefreshLayout
import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.JActivityAdapter.CONSTANTS_QUALITY_REFRESH
import com.veloria.now.shortapp.civil.NOFfmpeg import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
@ -324,8 +325,9 @@ class GColorsFragment : JItemServiceFragment<VpnInterceptorBinding, PWidthClient
isQualityRefresh = true isQualityRefresh = true
}
restoreRightKeyboardFirstProfileActivity()
}
} }
@ -371,6 +373,17 @@ class GColorsFragment : JItemServiceFragment<VpnInterceptorBinding, PWidthClient
showComplete() showComplete()
binding.viewPagerRecommend.visibility = View.VISIBLE binding.viewPagerRecommend.visibility = View.VISIBLE
// if (revolution == "1080" && !RYAction.isVipTo()) {
// if (RYAction.isTouristTo()){
// RYAction.getMMKV()
// .putInt(JActivityAdapter.CONSTANTS_QUALITY, 540)
// }else {
// RYAction.getMMKV()
// .putInt(JActivityAdapter.CONSTANTS_QUALITY, 720)
// }
// revolution = RYAction.getMMKV().getInt(JActivityAdapter.CONSTANTS_QUALITY, 540).toString()
// }
viewModel.getExploreRecommends(currentPage, revolution) viewModel.getExploreRecommends(currentPage, revolution)
} else { } else {
var listv: MutableMap<String, String> = mutableMapOf<String, String>() var listv: MutableMap<String, String> = mutableMapOf<String, String>()

View File

@ -18,6 +18,7 @@ import com.scwang.smart.refresh.layout.api.RefreshLayout
import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.JActivityAdapter.CONSTANTS_QUALITY_REFRESH
import com.veloria.now.shortapp.civil.JActivityAdapter.VIDEO_SHORT_PLAY_ID import com.veloria.now.shortapp.civil.JActivityAdapter.VIDEO_SHORT_PLAY_ID
import com.veloria.now.shortapp.civil.NOFfmpeg import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
@ -526,7 +527,7 @@ class NOEditRegisterFragment : JItemServiceFragment<QfAutoBinding, VDLRenderers>
this.buttonMeasureStandArr = mutableListOf<Boolean>() this.buttonMeasureStandArr = mutableListOf<Boolean>()
StatusBarUtil.addStatusBarPadding(binding.textHome) // StatusBarUtil.addStatusBarPadding(binding.textHome)
var coverP: String = "member" var coverP: String = "member"
if (coverP.length > 87) { if (coverP.length > 87) {
} }
@ -544,7 +545,7 @@ class NOEditRegisterFragment : JItemServiceFragment<QfAutoBinding, VDLRenderers>
} }
binding.constraint.visibility = View.GONE binding.clRoot.visibility = View.GONE
var bolda: Int = 5532 var bolda: Int = 5532
if (bolda == 91) { if (bolda == 91) {
} }
@ -586,6 +587,7 @@ class NOEditRegisterFragment : JItemServiceFragment<QfAutoBinding, VDLRenderers>
}) })
return return
} }
showComplete()
EventBus.getDefault().register(this) EventBus.getDefault().register(this)
var bbfdebaffdk: Boolean = true var bbfdebaffdk: Boolean = true
if (!bbfdebaffdk) { if (!bbfdebaffdk) {
@ -594,17 +596,19 @@ class NOEditRegisterFragment : JItemServiceFragment<QfAutoBinding, VDLRenderers>
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
binding.textHome.text = binding.textHome.text =
TranslationHelper.getTranslation()?.veloria_addictive_short_await TranslationHelper.getTranslation()?.veloria_addictive_short_await
binding.tvMenuBinge.text = TranslationHelper.getTranslation()?.veloria_worthy_picks
binding.tvMenuDrama.text = TranslationHelper.getTranslation()?.veloria_drama_champions binding.tvMenuDrama.text = TranslationHelper.getTranslation()?.veloria_drama_champions
binding.tvMenuCategories.text = binding.tvMenuCategories.text =
TranslationHelper.getTranslation()?.veloria_select_categories TranslationHelper.getTranslation()?.veloria_select_categories
binding.tvMenuCategories1.text = binding.tvMenuCategories1.text =
TranslationHelper.getTranslation()?.veloria_select_categories TranslationHelper.getTranslation()?.veloria_select_categories
binding.tvSearch.text = TranslationHelper.getTranslation()?.veloria_search_dramas binding.tvSearch.text = TranslationHelper.getTranslation()?.veloria_search_dramas
binding.tvMoreBinge.text = TranslationHelper.getTranslation()?.veloria_more
binding.tvMoreDrama.text = TranslationHelper.getTranslation()?.veloria_more
binding.tvMoreFree.text = TranslationHelper.getTranslation()?.veloria_more
binding.tvMoreJust.text = TranslationHelper.getTranslation()?.veloria_more
} else { } else {
binding.textHome.text = getString(R.string.home_addictive_shorts_await) binding.textHome.text = getString(R.string.home_addictive_shorts_await)
binding.tvMenuBinge.text = getString(R.string.binge_worthy_picks)
binding.tvMenuDrama.text = getString(R.string.drama_champions) binding.tvMenuDrama.text = getString(R.string.drama_champions)
binding.tvMenuCategories.text = getString(R.string.select_categories) binding.tvMenuCategories.text = getString(R.string.select_categories)
binding.tvMenuCategories1.text = getString(R.string.select_categories) binding.tvMenuCategories1.text = getString(R.string.select_categories)
@ -623,7 +627,7 @@ class NOEditRegisterFragment : JItemServiceFragment<QfAutoBinding, VDLRenderers>
println(message6) println(message6)
binding.constraint.visibility = View.VISIBLE binding.clRoot.visibility = View.VISIBLE
var viewsL: Long = 2629L var viewsL: Long = 2629L
while (viewsL > 95L) { while (viewsL > 95L) {
break break
@ -1238,6 +1242,17 @@ class NOEditRegisterFragment : JItemServiceFragment<QfAutoBinding, VDLRenderers>
viewModel.userInfo.observe(this){ viewModel.userInfo.observe(this){
if (it?.data != null) { if (it?.data != null) {
RYAction.saveUserInfoBean(it.data) RYAction.saveUserInfoBean(it.data)
if (!RYAction.isVipTo()) {
if (RYAction.isTouristTo()){
RYAction.getMMKV()
.putInt(JActivityAdapter.CONSTANTS_QUALITY, 540)
}else {
RYAction.getMMKV()
.putInt(JActivityAdapter.CONSTANTS_QUALITY, 720)
}
EventBus.getDefault().post(CONSTANTS_QUALITY_REFRESH)
}
} }
} }
@ -1473,7 +1488,7 @@ class NOEditRegisterFragment : JItemServiceFragment<QfAutoBinding, VDLRenderers>
} }
println(infoO) println(infoO)
binding.tvMenuBinge.text = homeTotal.title
homeBingeAdapter?.submitList(homeTotal.list) homeBingeAdapter?.submitList(homeTotal.list)
} else { } else {
var register__9: Double = 7713.0 var register__9: Double = 7713.0
@ -1652,12 +1667,10 @@ class NOEditRegisterFragment : JItemServiceFragment<QfAutoBinding, VDLRenderers>
while (helpqb >= 138) { while (helpqb >= 138) {
break break
} }
val maxSize = appearanceBase.size - (appearanceBase.size % 3) val maxSize = appearanceBase.size - (appearanceBase.size % 3)
val dramaList = appearanceBase.take(maxSize)
val dramaArrayList = appearanceBase.take(maxSize) homeDramaAdapter?.submitList(dramaList)
homeDramaAdapter?.submitList(dramaArrayList)
} else { } else {
var loginm: String = "downmix" var loginm: String = "downmix"
while (loginm.length > 104) { while (loginm.length > 104) {

View File

@ -7,6 +7,17 @@ import android.view.View
import android.view.ViewGroup import android.view.ViewGroup
import androidx.fragment.app.activityViewModels import androidx.fragment.app.activityViewModels
import androidx.lifecycle.ViewModelProvider import androidx.lifecycle.ViewModelProvider
import androidx.lifecycle.lifecycleScope
import com.android.billingclient.api.AcknowledgePurchaseParams
import com.android.billingclient.api.BillingClient
import com.android.billingclient.api.BillingClientStateListener
import com.android.billingclient.api.BillingFlowParams
import com.android.billingclient.api.BillingResult
import com.android.billingclient.api.ProductDetails
import com.android.billingclient.api.ProductDetailsResponseListener
import com.android.billingclient.api.Purchase
import com.android.billingclient.api.PurchasesUpdatedListener
import com.android.billingclient.api.QueryProductDetailsParams
import com.bumptech.glide.Glide import com.bumptech.glide.Glide
import com.bumptech.glide.load.engine.DiskCacheStrategy import com.bumptech.glide.load.engine.DiskCacheStrategy
import com.bumptech.glide.load.resource.bitmap.CircleCrop import com.bumptech.glide.load.resource.bitmap.CircleCrop
@ -16,25 +27,32 @@ import com.scwang.smart.refresh.layout.api.RefreshLayout
import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.JActivityAdapter.CONSTANTS_QUALITY_REFRESH
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.YFHome
import com.veloria.now.shortapp.civil.setShowVIPSlash
import com.veloria.now.shortapp.civil.singleOnClick import com.veloria.now.shortapp.civil.singleOnClick
import com.veloria.now.shortapp.civil.timeToString import com.veloria.now.shortapp.civil.timeToString
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
import com.veloria.now.shortapp.databinding.EvBodyloadHomeBinding import com.veloria.now.shortapp.databinding.EvBodyloadHomeBinding
import com.veloria.now.shortapp.newsletter.JItemServiceFragment import com.veloria.now.shortapp.newsletter.JItemServiceFragment
import com.veloria.now.shortapp.subtractionCroll.adminSourceid.coordinate.OMNormalInstrumented import com.veloria.now.shortapp.subtractionCroll.adminSourceid.coordinate.OMNormalInstrumented
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.LoginDialog
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.LogoutDialog import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.LogoutDialog
import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeLanguageActivity import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.VipSplashDialog
import com.veloria.now.shortapp.subtractionCroll.bidirectional.RBZLatestDeteleActivity import com.veloria.now.shortapp.subtractionCroll.bidirectional.RBZLatestDeteleActivity
import com.veloria.now.shortapp.subtractionCroll.bidirectional.RCheckActivity import com.veloria.now.shortapp.subtractionCroll.bidirectional.RCheckActivity
import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeAccountDeletionActivity import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeAccountDeletionActivity
import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeFeedbackActivity import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeFeedbackActivity
import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeLanguageActivity
import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeMyWalletActivity import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeMyWalletActivity
import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeRewardsActivity import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeRewardsActivity
import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeStoreActivity import com.veloria.now.shortapp.subtractionCroll.bidirectional.VeStoreActivity
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.JService import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.JService
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean
import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
import kotlinx.coroutines.launch
import org.greenrobot.eventbus.EventBus import org.greenrobot.eventbus.EventBus
import org.greenrobot.eventbus.Subscribe import org.greenrobot.eventbus.Subscribe
import org.greenrobot.eventbus.ThreadMode import org.greenrobot.eventbus.ThreadMode
@ -188,11 +206,14 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
if (radiusz.size > 101) { if (radiusz.size > 101) {
} }
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null) {
binding.tvCheckIn.text = TranslationHelper.getTranslation()?.veloria_check_in binding.tvCheckIn.text = TranslationHelper.getTranslation()?.veloria_check_in
binding.tvVipContent1.text = TranslationHelper.getTranslation()?.veloria_ad_free_streaming binding.tvVipContent1.text =
binding.tvVipContent2.text = TranslationHelper.getTranslation()?.veloria_exclusive_episodes TranslationHelper.getTranslation()?.veloria_ad_free_streaming
binding.tvVipContent3.text = TranslationHelper.getTranslation()?.veloria_daily_free_coins binding.tvVipContent2.text =
TranslationHelper.getTranslation()?.veloria_exclusive_episodes
binding.tvVipContent3.text =
TranslationHelper.getTranslation()?.veloria_daily_free_coins
binding.tvCoinsText.text = TranslationHelper.getTranslation()?.veloria_coins binding.tvCoinsText.text = TranslationHelper.getTranslation()?.veloria_coins
binding.tvDonateText.text = TranslationHelper.getTranslation()?.veloria_bonus binding.tvDonateText.text = TranslationHelper.getTranslation()?.veloria_bonus
binding.tvWallet.text = TranslationHelper.getTranslation()?.veloria_wallet binding.tvWallet.text = TranslationHelper.getTranslation()?.veloria_wallet
@ -200,39 +221,45 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
binding.tvRewards.text = TranslationHelper.getTranslation()?.veloria_rewards binding.tvRewards.text = TranslationHelper.getTranslation()?.veloria_rewards
binding.tvRecord.text = TranslationHelper.getTranslation()?.veloria_order_record binding.tvRecord.text = TranslationHelper.getTranslation()?.veloria_order_record
binding.tvLanguage.text = TranslationHelper.getTranslation()?.veloria_language binding.tvLanguage.text = TranslationHelper.getTranslation()?.veloria_language
binding.tvDeleteAccount.text = TranslationHelper.getTranslation()?.veloria_delete_account binding.tvDeleteAccount.text =
TranslationHelper.getTranslation()?.veloria_delete_account
binding.tvPrivacyPolicy.text = TranslationHelper.getTranslation()?.veloria_my_privacy binding.tvPrivacyPolicy.text = TranslationHelper.getTranslation()?.veloria_my_privacy
binding.tvUserAgreement.text = TranslationHelper.getTranslation()?.veloria_my_agreement binding.tvUserAgreement.text = TranslationHelper.getTranslation()?.veloria_my_agreement
binding.tvVisit.text = TranslationHelper.getTranslation()?.veloria_visit_website binding.tvVisit.text = TranslationHelper.getTranslation()?.veloria_visit_website
binding.tvHelpCenter.text = TranslationHelper.getTranslation()?.veloria_my_feedback binding.tvHelpCenter.text = TranslationHelper.getTranslation()?.veloria_my_feedback
binding.tvAboutUs.text = TranslationHelper.getTranslation()?.veloria_me_about binding.tvAboutUs.text = TranslationHelper.getTranslation()?.veloria_me_about
binding.tvFavorites.text = TranslationHelper.getTranslation()?.veloria_favorites
} }
setPushUI() setPushUI()
setShowVipSlashDialog()
} }
private fun setPushUI(){ private fun setPushUI() {
if (RYAction.isTouristTo()) { if (RYAction.isTouristTo()) {
if (TranslationHelper.getTranslation()!= null){ if (TranslationHelper.getTranslation() != null) {
binding.tvName.text = TranslationHelper.getTranslation()?.veloria_visitor binding.tvName.text = TranslationHelper.getTranslation()?.veloria_visitor
binding.tvLogin.text = TranslationHelper.getTranslation()?.veloria_login binding.tvLogin.text = TranslationHelper.getTranslation()?.veloria_login
}else { } else {
binding.tvName.text = "Visitor" binding.tvName.text = "Visitor"
binding.tvLogin.text = "Log in" binding.tvLogin.text = "Log in"
} }
binding.ivAvatar.setImageResource(R.mipmap.binge_banner) // binding.ivAvatar.setImageResource(R.mipmap.binge_banner)
binding.ivAvatar.let {
Glide.with(this).load(R.mipmap.binge_banner).into(it)
}
binding.tvDeleteAccount.visibility = View.GONE binding.tvDeleteAccount.visibility = View.GONE
} else { } else {
binding.tvName.text = binding.tvName.text =
RYAction.getUserInfoBean()?.family_name.plus(RYAction.getUserInfoBean()?.giving_name) RYAction.getUserInfoBean()?.family_name
binding.tvLogin.text = TranslationHelper.getTranslation()?.let { TranslationHelper.getTranslation()?.veloria_log_out } ?: "Log out" binding.tvLogin.text = TranslationHelper.getTranslation()
?.let { TranslationHelper.getTranslation()?.veloria_log_out } ?: "Log out"
binding.ivAvatar.let { binding.ivAvatar.let {
Glide.with(this).load(RYAction.getUserInfoBean()?.avator).skipMemoryCache(true) Glide.with(this).load(RYAction.getUserInfoBean()?.avator).skipMemoryCache(true)
@ -254,7 +281,7 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
RYAction.getUserInfoBean()?.send_coin_left_total.toString() RYAction.getUserInfoBean()?.send_coin_left_total.toString()
if (RYAction.isVipTo()) { if (RYAction.isVipTo()) {
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null) {
// binding.tvDes.text = TranslationHelper.getTranslation()?.veloria_welcome_back // binding.tvDes.text = TranslationHelper.getTranslation()?.veloria_welcome_back
binding.tvVipName.text = TranslationHelper.getTranslation()?.veloria_vip_active binding.tvVipName.text = TranslationHelper.getTranslation()?.veloria_vip_active
binding.tvVipDes.text = binding.tvVipDes.text =
@ -263,7 +290,7 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
it.toLong() it.toLong()
) )
}) })
}else { } else {
// binding.tvDes.text = "Welcome back, Member!" // binding.tvDes.text = "Welcome back, Member!"
binding.tvVipName.text = "VIP Active" binding.tvVipName.text = "VIP Active"
binding.tvVipDes.text = binding.tvVipDes.text =
@ -275,15 +302,16 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
} }
} else { } else {
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null) {
// binding.tvDes.text = TranslationHelper.getTranslation()?.veloria_is_vip_tips // binding.tvDes.text = TranslationHelper.getTranslation()?.veloria_is_vip_tips
binding.tvVipName.text = TranslationHelper.getTranslation()?.veloria_vip_join binding.tvVipName.text = TranslationHelper.getTranslation()?.veloria_vip_join
binding.tvVipDes.text = TranslationHelper.getTranslation()?.veloria_unlock_exclusive binding.tvVipDes.text = TranslationHelper.getTranslation()?.veloria_unlock_exclusive
}else { } else {
// binding.tvDes.text = getString(R.string.collectIcon) // binding.tvDes.text = getString(R.string.collectIcon)
binding.tvVipName.text = "Join VIP" binding.tvVipName.text = "Join VIP"
binding.tvVipDes.text = getString(R.string.pagerCategoies) binding.tvVipDes.text = getString(R.string.pagerCategoies)
} }
} }
} }
@ -391,11 +419,22 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
setPushUI() setPushUI()
if (!RYAction.isVipTo()) {
if (RYAction.isTouristTo()) {
RYAction.getMMKV()
.putInt(JActivityAdapter.CONSTANTS_QUALITY, 540)
} else {
RYAction.getMMKV()
.putInt(JActivityAdapter.CONSTANTS_QUALITY, 720)
}
EventBus.getDefault().post(CONSTANTS_QUALITY_REFRESH)
}
} }
hideLoading() hideLoading()
} }
viewModel.logoutLiveData.observe(this){ viewModel.logoutLiveData.observe(this) {
if (it?.data != null) { if (it?.data != null) {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_succeed.toString()) toast(TranslationHelper.getTranslation()?.veloria_succeed.toString())
@ -405,19 +444,63 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
LoginManager.getInstance().logOut() LoginManager.getInstance().logOut()
RYAction.getMMKV() RYAction.getMMKV()
.putString(JActivityAdapter.ACCOUNT_TOKEN, it.data.token) .putString(JActivityAdapter.ACCOUNT_TOKEN, it.data.token)
EventBus.getDefault()
.post(JActivityAdapter.HOME_LEAVE_APP)
EventBus.getDefault() EventBus.getDefault()
.post(JActivityAdapter.HOME_ENTER_THE_APP) .post(JActivityAdapter.HOME_ENTER_THE_APP)
EventBus.getDefault() EventBus.getDefault()
.post(JActivityAdapter.HOME_USER_REFRESH) .post(JActivityAdapter.HOME_USER_REFRESH)
// RYAction.getMMKV()
// .putInt(JActivityAdapter.CONSTANTS_QUALITY, 540)
EventBus.getDefault()
.post(JActivityAdapter.CONSTANTS_QUALITY_REFRESH)
EventBus.getDefault() EventBus.getDefault()
.post(JActivityAdapter.HOME_NAVIGATE_TO_HOME) .post(JActivityAdapter.HOME_NAVIGATE_TO_HOME)
EventBus.getDefault()
.post(JActivityAdapter.HOME_ON_LINE)
} }
} }
viewModel.PaySettingsV3.observe(this) {
if (it?.data != null) {
if (it.data.list_sub_vip.isNotEmpty()) {
setVipSlashDialog(it.data.list_sub_vip)
it.data.list_sub_vip.let { it1 -> querySubVipProductDetails(it1) }
}
}
}
viewModel.createPayOrderData.observe(this) {
if (it?.data != null) {
order_code = it.data.order_code.toString()
vipData?.android_template_id?.let { it1 -> getProduct(it1) }
} else {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else {
toast(getString(R.string.shapeSelected))
}
hideLoading()
}
}
viewModel.googlePaidData.observe(this) {
if (it?.data != null) {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_success.toString())
} else {
toast(getString(R.string.ve_google_pay_success))
}
viewModel.getUserInfo()
vipSplashDialog?.dismiss()
} else {
payBeanReq?.let { it1 -> RYAction.saveOrder(it1) }
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else {
toast(getString(R.string.shapeSelected))
}
hideLoading()
}
}
binding.tvUserAgreement.setOnClickListener { binding.tvUserAgreement.setOnClickListener {
var fragmentsP: Long = 2747L var fragmentsP: Long = 2747L
if (fragmentsP == 197L) { if (fragmentsP == 197L) {
@ -526,6 +609,16 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
} }
} }
binding.tvStore.setOnClickListener { binding.tvStore.setOnClickListener {
singleOnClick {
startActivity(
Intent(
requireContext(),
VeStoreActivity::class.java
)
)
}
}
binding.clVip.setOnClickListener {
singleOnClick { singleOnClick {
var loggingY: MutableMap<String, String> = mutableMapOf<String, String>() var loggingY: MutableMap<String, String> = mutableMapOf<String, String>()
loggingY.put("trellis", "retried") loggingY.put("trellis", "retried")
@ -631,8 +724,10 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
fun setLogoutDialog() { fun setLogoutDialog() {
val dialog = LogoutDialog(requireContext()).apply { val dialog = LogoutDialog(requireContext()).apply {
setOnLogoutClickListener(object : LogoutDialog.LogoutOnClick{ setOnLogoutClickListener(object : LogoutDialog.LogoutOnClick {
override fun onLogoutAction() { override fun onLogoutAction() {
EventBus.getDefault()
.post(JActivityAdapter.HOME_LEAVE_APP)
viewModel.setLogout() viewModel.setLogout()
} }
}) })
@ -735,9 +830,95 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
showLoading() showLoading()
viewModel.getUserInfo() viewModel.getUserInfo()
setShowVipSlashDialog()
} }
} }
private var isVipSplash = false
fun setShowVipSlashDialog() {
// Fragment 可见
binding.root.postDelayed({
// if (!RYAction.isVipTo() && !isVipSplash) {
if (setShowVIPSlash() && !RYAction.isVipTo() && !isVipSplash) {
initPayData()
viewModel.getPaySettingsV3(0, 0)
}
}, 1000)
}
var vipSplashDialog: VipSplashDialog? = null
fun isFragmentVisible(): Boolean {
return isAdded &&
isResumed &&
!isHidden &&
view?.visibility == View.VISIBLE
}
private fun setVipSlashDialog(vipBeans: List<VePaySettingsBean.VipBean>) {
if (!isFragmentVisible()) {
return
}
vipSplashDialog = VipSplashDialog(requireContext(), vipBeans).apply {
setOnVipSplashOnClickListener(object :
VipSplashDialog.SetVipSplashOnClick {
override fun onVipSplash() {
startActivity(
Intent(
requireContext(),
VeStoreActivity::class.java
)
)
}
override fun onVipOnAdapterBuy(vipBean: VePaySettingsBean.VipBean) {
if (!isConnect) {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else {
toast(getString(R.string.ve_google_pay_error))
}
return
}
vipData = vipBean
showLoading()
viewModel.setCreatePayOrder(
VeCreatePayOrderReqBean(
vipData?.id.toString(),
"google",
0,
0
)
)
}
})
}
vipSplashDialog?.setOnDismissListener {
RYAction.getMMKV().putLong(
JActivityAdapter.ACCOUNT_DIALOG_TIME_VIP_SPLASH,
System.currentTimeMillis()
)
isVipSplash = false
billingClientMe?.endConnection()
billingClientMe = null
System.gc()
}
vipSplashDialog?.show()
vipSplashDialog?.setVipSplashOnClick
isVipSplash = true
}
override fun onDestroy() {
super.onDestroy()
payBeanReq = null
if (billingClientMe != null) {
billingClientMe?.endConnection()
billingClientMe = null
}
System.gc()
}
@Subscribe(threadMode = ThreadMode.MAIN) @Subscribe(threadMode = ThreadMode.MAIN)
fun onEvent(event: String) { fun onEvent(event: String) {
if (JActivityAdapter.HOME_USER_REFRESH == event || JActivityAdapter.HOME_REFRESH_ME == event) { if (JActivityAdapter.HOME_USER_REFRESH == event || JActivityAdapter.HOME_REFRESH_ME == event) {
@ -746,4 +927,240 @@ class UColorsAvatarFragment : JItemServiceFragment<EvBodyloadHomeBinding, OMNorm
} }
} }
private var billingClientMe: BillingClient? = null
private var connectNum = 0
private var isConnect = false
private var vipData: VePaySettingsBean.VipBean? = null
private var order_code = ""
private var payBeanReq: VePayBean? = null
private fun initPayData() {
val purchasesUpdatedMeListener =
PurchasesUpdatedListener { billingResult, purchases ->
when (billingResult.responseCode) {
BillingClient.BillingResponseCode.OK -> {
for (purchase in purchases!!) {
if (purchase.purchaseState == Purchase.PurchaseState.PURCHASED) {
consumePurchaseSubMe(purchase)
}
}
}
BillingClient.BillingResponseCode.ITEM_ALREADY_OWNED -> {
queryAndConsumePurchases()
hideLoading()
}
BillingClient.BillingResponseCode.USER_CANCELED -> {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_canceled.toString())
} else {
toast(getString(R.string.ve_google_pay_canceled))
}
hideLoading()
}
else -> {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else {
toast(getString(R.string.ve_google_pay_error))
}
hideLoading()
}
}
}
billingClientMe = BillingClient.newBuilder(requireContext())
.setListener(purchasesUpdatedMeListener)
.enablePendingPurchases()
.build()
val stateMeListener: BillingClientStateListener = object : BillingClientStateListener {
override fun onBillingSetupFinished(billingResult: BillingResult) {
if (billingResult.responseCode == BillingClient.BillingResponseCode.OK) {
isConnect = true
}
}
override fun onBillingServiceDisconnected() {
if (connectNum < 5) {
connectNum++
isConnect = false
billingClientMe?.startConnection(this)
}
}
}
billingClientMe?.startConnection(stateMeListener)
}
private fun consumePurchaseSubMe(
purchase: Purchase
) {
if (billingClientMe?.isReady == true) {
if (!purchase.isAcknowledged) {
val acknowledgePurchaseParams =
AcknowledgePurchaseParams.newBuilder()
.setPurchaseToken(purchase.purchaseToken)
.build()
billingClientMe?.acknowledgePurchase(
acknowledgePurchaseParams
) {
val vePayBean = VePayBean(
order_code,
vipData?.id.toString(),
YFHome.getPackageName(),
vipData?.android_template_id.toString(),
purchase.purchaseToken,
purchase.orderId.toString(),
vipData?.price.toString()
)
payBeanReq = vePayBean
if (it.responseCode == BillingClient.BillingResponseCode.OK) {
lifecycleScope.launch {
viewModel.setGooglePaid(vePayBean)
}
} else {
RYAction.saveOrder(vePayBean)
lifecycleScope.launch {
toast(it.toString())
hideLoading()
}
}
}
} else {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else {
toast(getString(R.string.ve_google_pay_error))
}
hideLoading()
}
} else {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else {
toast(getString(R.string.ve_google_pay_error))
}
hideLoading()
}
}
private fun querySubVipProductDetails(listSubVip: List<VePaySettingsBean.VipBean>) {
val productDetailsResponseListener =
ProductDetailsResponseListener { billingResult, productDetailsList ->
if (billingResult.responseCode == BillingClient.BillingResponseCode.OK) {
val priceInfo = productDetailsList.mapNotNull { productDetails ->
productDetails.subscriptionOfferDetails?.get(0)?.pricingPhases?.pricingPhaseList?.get(
0
)?.let {
productDetails.productId to (it.formattedPrice to it.priceCurrencyCode)
}
}.toMap()
// 更新VIP列表的价格和货币代码
val updatedVipList = listSubVip.map { vip ->
priceInfo[vip.android_template_id]?.let { (price, currency) ->
vip.copy(price_google = price, currency_goolge = currency)
} ?: vip
}
binding.root.postDelayed({
vipSplashDialog?.setAdapterSubmitList(updatedVipList)
hideLoading()
}, 500)
} else {
hideLoading()
}
}
val productType: String = BillingClient.ProductType.SUBS
val inAppProductInfo = listSubVip.map {
QueryProductDetailsParams.Product.newBuilder()
.setProductId(it.android_template_id)
.setProductType(productType)
.build()
}
if (inAppProductInfo.isNotEmpty()) {
val productDetailsParams = QueryProductDetailsParams.newBuilder()
.setProductList(inAppProductInfo)
.build()
billingClientMe?.queryProductDetailsAsync(
productDetailsParams,
productDetailsResponseListener
)
} else {
hideLoading()
}
}
private fun getProduct(productId: String) {
val productDetailsResponseListener =
ProductDetailsResponseListener { billingResult, productDetailsList ->
if (productDetailsList.isNotEmpty()) {
setPay(productDetailsList[0])
} else {
lifecycleScope.launch {
toast(billingResult.toString())
hideLoading()
}
}
}
val productType: String =
BillingClient.ProductType.SUBS
val inAppProductInfo = ArrayList<QueryProductDetailsParams.Product>()
inAppProductInfo.add(
QueryProductDetailsParams.Product.newBuilder()
.setProductId(productId)
.setProductType(productType)
.build()
)
val productDetailsParams = QueryProductDetailsParams.newBuilder()
.setProductList(inAppProductInfo)
.build()
billingClientMe?.queryProductDetailsAsync(
productDetailsParams,
productDetailsResponseListener
)
}
private fun setPay(productDetailInfo: ProductDetails) {
if (productDetailInfo.subscriptionOfferDetails?.isNotEmpty() == true) {
val params = ArrayList<BillingFlowParams.ProductDetailsParams>()
productDetailInfo.subscriptionOfferDetails?.get(0)?.offerToken?.let {
BillingFlowParams.ProductDetailsParams.newBuilder()
.setProductDetails(productDetailInfo)
.setOfferToken(it)
.build()
}?.let {
params.add(
it
)
}
val billingFlowParams = BillingFlowParams.newBuilder()
.setObfuscatedProfileId(order_code)
.setObfuscatedAccountId(RYAction.getCustomId())
.setProductDetailsParamsList(params)
.build()
billingClientMe?.launchBillingFlow(requireActivity(), billingFlowParams)
}
}
private fun queryAndConsumePurchases() {
// 查询所有未消费的购买记录
billingClientMe?.queryPurchasesAsync(BillingClient.ProductType.INAPP) { billingResult, purchaseList ->
if (billingResult.responseCode == BillingClient.BillingResponseCode.OK) {
for (purchase in purchaseList) {
// consumePurchase(purchase)
}
}
}
}
} }

View File

@ -398,6 +398,7 @@ class ZEpisodeFragment : JItemServiceFragment<QHeaderBinding, NNAndroid>(), NOFf
}) })
return return
} }
showComplete()
EventBus.getDefault().register(this) EventBus.getDefault().register(this)
var s_heightN: String = "uplink" var s_heightN: String = "uplink"

View File

@ -6,6 +6,11 @@ import com.veloria.now.shortapp.newsletter.SStringsHelp
import com.veloria.now.shortapp.newsletter.TStore import com.veloria.now.shortapp.newsletter.TStore
import com.veloria.now.shortapp.texturedAsink.DoLoginBean import com.veloria.now.shortapp.texturedAsink.DoLoginBean
import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderBean
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean
import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePayResBean
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
class OMNormalInstrumented : SStringsHelp() { class OMNormalInstrumented : SStringsHelp() {
@ -35,4 +40,29 @@ class OMNormalInstrumented : SStringsHelp() {
repository.setLogout().observeForever { result -> repository.setLogout().observeForever { result ->
_logoutLiveData.value = result.getOrNull() _logoutLiveData.value = result.getOrNull()
} }
private val _paySettingsV3 = MutableLiveData<TStore<VePaySettingsBean>?>()
val PaySettingsV3: MutableLiveData<TStore<VePaySettingsBean>?> get() = _paySettingsV3
fun getPaySettingsV3(short_play_id: Int, short_play_video_id: Int) =
repository.getPaySettingsV3(short_play_id,short_play_video_id).observeForever { result ->
_paySettingsV3.value = result.getOrNull()
}
private val createPayOrderLiveData = MutableLiveData<TStore<VeCreatePayOrderBean>?>()
val createPayOrderData: MutableLiveData<TStore<VeCreatePayOrderBean>?> get() = createPayOrderLiveData
fun setCreatePayOrder(createOrderReq: VeCreatePayOrderReqBean) {
repository.setCreatePayOrder(createOrderReq).observeForever { result ->
createPayOrderLiveData.value = result.getOrNull()
}
}
private val googlePaidLiveData = MutableLiveData<TStore<VePayResBean>?>()
val googlePaidData: MutableLiveData<TStore<VePayResBean>?> get() = googlePaidLiveData
fun setGooglePaid(vePayBean: VePayBean?) {
repository.setGooglePaid(vePayBean).observeForever { result ->
googlePaidLiveData.value = result.getOrNull()
}
}
} }

View File

@ -0,0 +1,65 @@
package com.veloria.now.shortapp.subtractionCroll.avcintraRelock
import android.annotation.SuppressLint
import android.app.Dialog
import android.content.Context
import android.graphics.Color
import android.graphics.drawable.ColorDrawable
import android.view.Gravity
import android.view.Window
import android.view.WindowManager
import androidx.appcompat.widget.AppCompatImageView
import androidx.appcompat.widget.AppCompatTextView
import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.TranslationHelper
import org.greenrobot.eventbus.EventBus
@SuppressLint("MissingInflatedId")
class NotificationsDialog(context: Context) : Dialog(context) {
var setNotificationOnClick: SetNotificationOnClick? = null
interface SetNotificationOnClick {
fun notificationOnClick()
}
init {
requestWindowFeature(Window.FEATURE_NO_TITLE)
setContentView(R.layout.dialog_notifications)
window?.apply {
setBackgroundDrawable(ColorDrawable(Color.TRANSPARENT))
setLayout(
(context.resources.displayMetrics.widthPixels * 0.8).toInt(),
WindowManager.LayoutParams.WRAP_CONTENT
)
setGravity(Gravity.CENTER)
}
setCancelable(true)
val ivClose = findViewById<AppCompatImageView>(R.id.iv_close)
val tvGo = findViewById<AppCompatTextView>(R.id.tv_go)
val tvContent = findViewById<AppCompatTextView>(R.id.tv_content)
val tvTitle = findViewById<AppCompatTextView>(R.id.tv_title)
if (TranslationHelper.getTranslation() != null) {
tvTitle.text = TranslationHelper.getTranslation()?.veloria_open_notice_at_watch_video
tvContent.text = TranslationHelper.getTranslation()?.veloria_open_notice_alert_text
tvGo.text = TranslationHelper.getTranslation()?.veloria_allow
}
ivClose.setOnClickListener {
dismiss()
}
tvGo.setOnClickListener {
setNotificationOnClick?.notificationOnClick()
dismiss()
}
}
fun setOnNotificationClickListener(listener: SetNotificationOnClick) {
this.setNotificationOnClick = listener
}
}

View File

@ -94,6 +94,8 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
binding?.tvCoinsText?.text = TranslationHelper.getTranslation()?.veloria_your_coins binding?.tvCoinsText?.text = TranslationHelper.getTranslation()?.veloria_your_coins
binding?.tvCoinTitle?.text = TranslationHelper.getTranslation()?.veloria_coin_buy_title
binding?.tvUnlockText?.text = TranslationHelper.getTranslation()?.veloria_unlock
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
binding?.tvTips?.text = Html.fromHtml( binding?.tvTips?.text = Html.fromHtml(
TranslationHelper.getTranslation()?.veloria_store_tips TranslationHelper.getTranslation()?.veloria_store_tips
@ -111,6 +113,7 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
initLoading() initLoading()
binding?.tvCoins?.text = RYAction.getAllCoinTotal().toString() binding?.tvCoins?.text = RYAction.getAllCoinTotal().toString()
binding?.tvUnlock?.text = parcelable?.coins?.toString()
binding?.ivCloseDialog?.setOnClickListener { binding?.ivCloseDialog?.setOnClickListener {
dismiss() dismiss()
@ -218,6 +221,7 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
singleOnClick { singleOnClick {
if (!isConnect) { if (!isConnect) {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_error)) toast(getString(R.string.ve_google_pay_error))
} }
@ -317,6 +321,7 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
} }
} else { } else {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else { } else {
toast(getString(R.string.shapeSelected)) toast(getString(R.string.shapeSelected))
} }
@ -326,12 +331,10 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
viewModel.googlePaidData.observe(this) { viewModel.googlePaidData.observe(this) {
if (it?.data != null) { if (it?.data != null) {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_success.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_success)) toast(getString(R.string.ve_google_pay_success))
} }
if (null != payBeanReq) {
RYAction.removeOrder(payBeanReq)
}
EventBus.getDefault() EventBus.getDefault()
.post(JActivityAdapter.VIDEO_PAY_REFRESH) .post(JActivityAdapter.VIDEO_PAY_REFRESH)
dismiss() dismiss()
@ -339,6 +342,7 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
} else { } else {
payBeanReq?.let { it1 -> RYAction.saveOrder(it1) } payBeanReq?.let { it1 -> RYAction.saveOrder(it1) }
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else { } else {
toast(getString(R.string.shapeSelected)) toast(getString(R.string.shapeSelected))
} }
@ -364,8 +368,14 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
} }
} }
BillingClient.BillingResponseCode.ITEM_ALREADY_OWNED -> {
queryAndConsumePurchases()
hideLoading()
}
BillingClient.BillingResponseCode.USER_CANCELED -> { BillingClient.BillingResponseCode.USER_CANCELED -> {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_canceled.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_canceled)) toast(getString(R.string.ve_google_pay_canceled))
} }
@ -374,6 +384,7 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
else -> { else -> {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_error)) toast(getString(R.string.ve_google_pay_error))
} }
@ -655,7 +666,7 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
billingClientData?.consumeAsync(consumeParams, responseListener) billingClientData?.consumeAsync(consumeParams, responseListener)
} else { } else {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
// toast(TranslationHelper.getTranslation()?.mireo_g_pay_error.toString()) toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_error)) toast(getString(R.string.ve_google_pay_error))
} }
@ -663,6 +674,16 @@ class PlayerBuyDialogFragment : BottomSheetDialogFragment() {
} }
} }
private fun queryAndConsumePurchases() {
// 查询所有未消费的购买记录
billingClientData?.queryPurchasesAsync(BillingClient.ProductType.INAPP) { billingResult, purchaseList ->
if (billingResult.responseCode == BillingClient.BillingResponseCode.OK) {
for (purchase in purchaseList) {
consumePurchase(purchase)
}
}
}
}
override fun onDismiss(dialog: DialogInterface) { override fun onDismiss(dialog: DialogInterface) {
payBeanReq = null payBeanReq = null

View File

@ -0,0 +1,95 @@
package com.veloria.now.shortapp.subtractionCroll.avcintraRelock
import android.app.Dialog
import android.content.Context
import android.content.Intent
import android.graphics.Color
import android.graphics.drawable.ColorDrawable
import android.net.Uri
import android.os.Build
import android.text.Html
import android.view.Gravity
import android.view.Window
import android.view.WindowManager
import androidx.appcompat.widget.AppCompatImageView
import androidx.appcompat.widget.AppCompatTextView
import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.YFHome
import com.veloria.now.shortapp.texturedAsink.VersionControlBean
class VersionControlDialog(context: Context, versionControlBean: VersionControlBean) :
Dialog(context) {
init {
requestWindowFeature(Window.FEATURE_NO_TITLE)
setContentView(R.layout.dialog_version_control)
window?.apply {
setBackgroundDrawable(ColorDrawable(Color.TRANSPARENT))
setLayout(
(context.resources.displayMetrics.widthPixels * 0.8).toInt(),
WindowManager.LayoutParams.WRAP_CONTENT
)
setGravity(Gravity.CENTER)
}
setCancelable(false)
val ivClose = findViewById<AppCompatImageView>(R.id.iv_close)
val tvVersion = findViewById<AppCompatTextView>(R.id.tv_version)
val tvNow = findViewById<AppCompatTextView>(R.id.tv_now)
val tvContent = findViewById<AppCompatTextView>(R.id.tv_content)
val tvTitle = findViewById<AppCompatTextView>(R.id.tv_title)
tvVersion.text = "v".plus(versionControlBean.version_name)
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
tvContent?.text = Html.fromHtml(
versionControlBean.description, Html.FROM_HTML_MODE_COMPACT
)
} else {
tvContent?.text = Html.fromHtml(
versionControlBean.description
)
}
if (TranslationHelper.getTranslation() != null) {
tvTitle.text = TranslationHelper.getTranslation()?.veloria_update_title
tvNow.text = TranslationHelper.getTranslation()?.veloria_update_now
}
ivClose.setOnClickListener {
dismiss()
}
tvNow.setOnClickListener {
setOpenGooglePlayStore(YFHome.getPackageName())
dismiss()
}
this.setOnDismissListener {
RYAction.getMMKV().putLong(
JActivityAdapter.ACCOUNT_VERSION_CONTROL_TIME,
System.currentTimeMillis()
)
}
}
private fun setOpenGooglePlayStore(packageName: String) {
try {
val intent = Intent(Intent.ACTION_VIEW, Uri.parse("market://details?id=$packageName"))
intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK
context.startActivity(intent)
} catch (e: Exception) {
val intent = Intent(
Intent.ACTION_VIEW,
Uri.parse("https://play.google.com/store/apps/details?id=$packageName")
)
intent.flags = Intent.FLAG_ACTIVITY_NEW_TASK
context.startActivity(intent)
}
}
}

View File

@ -0,0 +1,64 @@
package com.veloria.now.shortapp.subtractionCroll.avcintraRelock
import android.annotation.SuppressLint
import android.app.Dialog
import android.content.Context
import android.graphics.Color
import android.graphics.drawable.ColorDrawable
import android.view.Gravity
import android.view.Window
import android.view.WindowManager
import androidx.appcompat.widget.AppCompatImageView
import androidx.appcompat.widget.AppCompatTextView
import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.TranslationHelper
import org.greenrobot.eventbus.EventBus
@SuppressLint("MissingInflatedId")
class VipActivateDialog(context: Context) : Dialog(context) {
init {
requestWindowFeature(Window.FEATURE_NO_TITLE)
setContentView(R.layout.dialog_vip_activate)
window?.apply {
setBackgroundDrawable(ColorDrawable(Color.TRANSPARENT))
setLayout(
(context.resources.displayMetrics.widthPixels * 0.8).toInt(),
WindowManager.LayoutParams.WRAP_CONTENT
)
setGravity(Gravity.CENTER)
}
setCancelable(true)
val ivClose = findViewById<AppCompatImageView>(R.id.iv_close)
val tvCancel = findViewById<AppCompatTextView>(R.id.tv_cancel)
val tvGo = findViewById<AppCompatTextView>(R.id.tv_go)
val tvContent = findViewById<AppCompatTextView>(R.id.tv_content)
val tvTitle = findViewById<AppCompatTextView>(R.id.tv_title)
if (TranslationHelper.getTranslation() != null) {
tvTitle.text = TranslationHelper.getTranslation()?.veloria_vip_activate_title
tvContent.text = TranslationHelper.getTranslation()?.veloria_vip_activate_content
tvCancel.text = TranslationHelper.getTranslation()?.veloria_later
tvGo.text = TranslationHelper.getTranslation()?.veloria_go
}
ivClose.setOnClickListener {
dismiss()
}
tvCancel.setOnClickListener {
EventBus.getDefault()
.post(JActivityAdapter.VIDEO_START_PLAY)
dismiss()
}
tvGo.setOnClickListener {
EventBus.getDefault()
.post(JActivityAdapter.VIDEO_STOP_PLAY)
dismiss()
}
}
}

View File

@ -0,0 +1,141 @@
package com.veloria.now.shortapp.subtractionCroll.avcintraRelock
import android.annotation.SuppressLint
import android.app.Dialog
import android.content.Context
import android.content.Intent
import android.graphics.Color
import android.graphics.drawable.ColorDrawable
import android.view.Gravity
import android.view.Window
import android.view.WindowManager
import androidx.appcompat.widget.AppCompatImageView
import androidx.appcompat.widget.AppCompatTextView
import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.subtractionCroll.bidirectional.PSVHomeSearchActivity
import com.veloria.now.shortapp.texturedAsink.VeRevolutionsBean
import org.greenrobot.eventbus.EventBus
@SuppressLint("MissingInflatedId")
class VipQualityDialog(context: Context, revolutionsBean: VeRevolutionsBean) : Dialog(context) {
var setQualityBackOnClick: SetQualityBackOnClick? = null
interface SetQualityBackOnClick {
fun qualityBackOnClick(quality: Int)
fun loginOnClick()
fun showActivateOnClick()
}
init {
requestWindowFeature(Window.FEATURE_NO_TITLE)
setContentView(R.layout.dialog_ve_quality)
window?.apply {
setBackgroundDrawable(ColorDrawable(Color.TRANSPARENT))
setLayout(
(context.resources.displayMetrics.widthPixels * 0.95).toInt(),
WindowManager.LayoutParams.WRAP_CONTENT
)
setGravity(Gravity.BOTTOM)
}
setCancelable(true)
val tvQuality480 = findViewById<AppCompatTextView>(R.id.tv_quality_480)
val tvQuality720 = findViewById<AppCompatTextView>(R.id.tv_quality_720)
val tvQuality1080 = findViewById<AppCompatTextView>(R.id.tv_quality_1080)
val tvLoginTag = findViewById<AppCompatTextView>(R.id.tv_login_tag)
val tvVipTag = findViewById<AppCompatTextView>(R.id.tv_vip_tag)
if (TranslationHelper.getTranslation() != null) {
tvLoginTag.text = TranslationHelper.getTranslation()?.veloria_login
} else {
tvLoginTag.text = "Login"
}
val size = revolutionsBean.list?.size ?: 0
val int = RYAction.getMMKV().getInt(JActivityAdapter.CONSTANTS_QUALITY, 0)
if (size > 0 && null != revolutionsBean?.list?.get(0)) {
val revolutionData = revolutionsBean.list[0]
tvQuality480.text = revolutionData.value.toString().plus("p")
if (revolutionData.can_check) {
if (int == revolutionData.value) {
tvQuality480.setBackgroundResource(R.mipmap.iv_quality_bg_on)
} else {
tvQuality480.setBackgroundResource(R.mipmap.iv_quality_bg_off)
}
tvQuality480.setTextColor(Color.parseColor("#FFFFFF"))
tvQuality480.setOnClickListener {
if (int != revolutionData.value) {
setQualityBackOnClick?.qualityBackOnClick(revolutionData.value)
dismiss()
}
}
} else {
tvQuality480.setTextColor(Color.parseColor("#8B8B8B"))
tvQuality480.setBackgroundResource(R.mipmap.iv_quality_bg_off)
}
}
if (size > 1 && null != revolutionsBean?.list?.get(1)) {
val revolutionData = revolutionsBean.list[1]
tvQuality720.text = revolutionData.value.toString().plus("p")
if (revolutionData.can_check) {
if (int == revolutionData.value) {
tvQuality720.setBackgroundResource(R.mipmap.iv_quality_bg_on)
} else {
tvQuality720.setBackgroundResource(R.mipmap.iv_quality_bg_off)
}
tvQuality720.setTextColor(Color.parseColor("#FFFFFF"))
tvQuality720.setOnClickListener {
if (int != revolutionData.value) {
setQualityBackOnClick?.qualityBackOnClick(revolutionData.value)
dismiss()
}
}
} else {
tvQuality720.setTextColor(Color.parseColor("#8B8B8B"))
tvQuality720.setBackgroundResource(R.mipmap.iv_quality_bg_off)
tvQuality720.setOnClickListener {
// EventBus.getDefault().post(JActivityAdapter.VIDEO_PAUSE_PLAY)
setQualityBackOnClick?.loginOnClick()
dismiss()
}
}
}
if (size > 2 && null != revolutionsBean?.list?.get(2)) {
val revolutionData = revolutionsBean.list[2]
tvQuality1080.text = revolutionData.value.toString().plus("p")
if (revolutionData.can_check) {
if (int == revolutionData.value) {
tvQuality1080.setBackgroundResource(R.mipmap.iv_quality_bg_on)
} else {
tvQuality1080.setBackgroundResource(R.mipmap.iv_quality_bg_off)
}
tvQuality1080.setTextColor(Color.parseColor("#FFFFFF"))
tvQuality1080.setOnClickListener {
if (int != revolutionData.value) {
setQualityBackOnClick?.qualityBackOnClick(revolutionData.value)
dismiss()
}
}
} else {
tvQuality1080.setTextColor(Color.parseColor("#8B8B8B"))
tvQuality1080.setBackgroundResource(R.mipmap.iv_quality_bg_off)
tvQuality1080.setOnClickListener {
EventBus.getDefault().post(JActivityAdapter.VIDEO_PAUSE_PLAY)
setQualityBackOnClick?.showActivateOnClick()
dismiss()
}
}
}
}
fun setOnQualityBackOnClickListener(listener: SetQualityBackOnClick) {
this.setQualityBackOnClick = listener
}
}

View File

@ -0,0 +1,99 @@
package com.veloria.now.shortapp.subtractionCroll.avcintraRelock
import android.annotation.SuppressLint
import android.app.Dialog
import android.content.Context
import android.graphics.Color
import android.graphics.drawable.ColorDrawable
import android.view.Gravity
import android.view.View
import android.view.Window
import android.view.WindowManager
import android.widget.TextView
import androidx.appcompat.widget.AppCompatImageView
import androidx.appcompat.widget.AppCompatTextView
import androidx.recyclerview.widget.LinearLayoutManager
import androidx.recyclerview.widget.RecyclerView
import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.singleOnClick
import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeStoreCoinAdapter
import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeVipSplashAdapter
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
@SuppressLint("MissingInflatedId")
class VipSplashDialog(context: Context,vipBeans: List<VePaySettingsBean.VipBean>) : Dialog(context) {
var setVipSplashOnClick: SetVipSplashOnClick? = null
private var vipAdapter: VeVipSplashAdapter? = null
interface SetVipSplashOnClick {
fun onVipSplash()
fun onVipOnAdapterBuy(vipBean: VePaySettingsBean.VipBean)
}
init {
requestWindowFeature(Window.FEATURE_NO_TITLE)
setContentView(R.layout.dialog_vip_splash)
window?.apply {
setBackgroundDrawable(ColorDrawable(Color.TRANSPARENT))
setLayout(
(context.resources.displayMetrics.widthPixels * 0.8).toInt(),
WindowManager.LayoutParams.WRAP_CONTENT
)
setGravity(Gravity.TOP or Gravity.CENTER_HORIZONTAL)
}
setCancelable(true)
val ivClose = findViewById<AppCompatImageView>(R.id.iv_close)
val tvContent = findViewById<AppCompatTextView>(R.id.tv_content)
val tvTitle = findViewById<AppCompatTextView>(R.id.tv_title)
val recyclerView = findViewById<RecyclerView>(R.id.recyclerView)
if (TranslationHelper.getTranslation() != null) {
tvTitle.text = TranslationHelper.getTranslation()?.veloria_vip_splash_title
tvContent.text = TranslationHelper.getTranslation()?.veloria_vip_splash_content
} else {
tvTitle.text = "Unlock VIP Privileges!"
tvContent.text = "Enjoy ad-free streaming, early access, and exclusive content!"
}
recyclerView.layoutManager = LinearLayoutManager(context)
vipAdapter = VeVipSplashAdapter()
recyclerView.adapter = vipAdapter
vipAdapter?.submitList(vipBeans)
ivClose.setOnClickListener {
singleOnClick {
dismiss()
}
}
vipAdapter?.setOnItemClickListener { adapter, view, position ->
singleOnClick {
val data = adapter.getItem(position)
vipAdapter?.currentPosition = position
vipAdapter?.notifyDataSetChanged()
if (data != null) {
setVipSplashOnClick?.onVipOnAdapterBuy(data)
}
}
}
}
fun setOnVipSplashOnClickListener(listener: SetVipSplashOnClick) {
this.setVipSplashOnClick = listener
}
fun setAdapterSubmitList(data: List<VePaySettingsBean.VipBean>){
vipAdapter?.submitList(data)
}
}

View File

@ -151,6 +151,26 @@ class HLanguageActivity : AIXTextActivity<MqInstrumentedBinding, YCFddebcdbeeffc
this.testDetails_list = mutableListOf<Float>() this.testDetails_list = mutableListOf<Float>()
binding.ivBack.setOnClickListener {
var complete9: Long = 6360L
if (complete9 == 49L) {
}
var system2: Float = 1503.0f
finish()
}
if (TranslationHelper.getTranslation() != null){
binding.etSearch.hint = TranslationHelper.getTranslation()?.veloria_recersal_of_fate
binding.tvTitleRecent.text = TranslationHelper.getTranslation()?.veloria_recent_searches
binding.tvTitleRecommended.text = TranslationHelper.getTranslation()?.veloria_recommended
binding.tvTrendingTop.text = TranslationHelper.getTranslation()?.veloria_trending_top
binding.tvLatestTrends.text = TranslationHelper.getTranslation()?.veloria_latest_trends
binding.tvResultTitle.text = TranslationHelper.getTranslation()?.veloria_search_results
}
if (!NetworkUtils.isConnected()) { if (!NetworkUtils.isConnected()) {
var langR: Float = 4492.0f var langR: Float = 4492.0f
@ -213,7 +233,7 @@ class HLanguageActivity : AIXTextActivity<MqInstrumentedBinding, YCFddebcdbeeffc
break break
} }
showComplete()
binding.clOne.visibility = View.VISIBLE binding.clOne.visibility = View.VISIBLE
var displaye: Double = 49.0 var displaye: Double = 49.0
if (displaye > 179.0) { if (displaye > 179.0) {
@ -223,15 +243,6 @@ class HLanguageActivity : AIXTextActivity<MqInstrumentedBinding, YCFddebcdbeeffc
binding.stateLayout.visibility = View.GONE binding.stateLayout.visibility = View.GONE
} }
if (TranslationHelper.getTranslation() != null){
binding.etSearch.hint = TranslationHelper.getTranslation()?.veloria_recersal_of_fate
binding.tvTitleRecent.text = TranslationHelper.getTranslation()?.veloria_recent_searches
binding.tvTitleRecommended.text = TranslationHelper.getTranslation()?.veloria_recommended
binding.tvTrendingTop.text = TranslationHelper.getTranslation()?.veloria_trending_top
binding.tvLatestTrends.text = TranslationHelper.getTranslation()?.veloria_latest_trends
}
searchTrendAdapter = VXAgreement() searchTrendAdapter = VXAgreement()
var buttonu: Int = 3389 var buttonu: Int = 3389
if (buttonu < 189) { if (buttonu < 189) {
@ -419,17 +430,6 @@ class HLanguageActivity : AIXTextActivity<MqInstrumentedBinding, YCFddebcdbeeffc
binding.ivBack.setOnClickListener {
var complete9: Long = 6360L
if (complete9 == 49L) {
}
var system2: Float = 1503.0f
finish()
}
binding.ivDelete.setOnClickListener { binding.ivDelete.setOnClickListener {
var selectZ: Float = 4767.0f var selectZ: Float = 4767.0f
while (selectZ < 108.0f) { while (selectZ < 108.0f) {

View File

@ -1,6 +1,7 @@
package com.veloria.now.shortapp.subtractionCroll.bidirectional package com.veloria.now.shortapp.subtractionCroll.bidirectional
import android.annotation.SuppressLint import android.annotation.SuppressLint
import android.content.Intent
import android.net.Uri import android.net.Uri
import android.os.Bundle import android.os.Bundle
import android.view.View import android.view.View
@ -10,14 +11,9 @@ import androidx.activity.viewModels
import androidx.appcompat.widget.AppCompatImageView import androidx.appcompat.widget.AppCompatImageView
import androidx.appcompat.widget.AppCompatTextView import androidx.appcompat.widget.AppCompatTextView
import androidx.fragment.app.DialogFragment.STYLE_NO_FRAME import androidx.fragment.app.DialogFragment.STYLE_NO_FRAME
import androidx.lifecycle.lifecycleScope
import androidx.media3.common.MediaItem import androidx.media3.common.MediaItem
import androidx.media3.common.PlaybackException
import androidx.media3.common.Player
import androidx.media3.datasource.DataSource import androidx.media3.datasource.DataSource
import androidx.media3.datasource.DefaultDataSourceFactory import androidx.media3.datasource.DefaultDataSourceFactory
import androidx.media3.exoplayer.DefaultRenderersFactory
import androidx.media3.exoplayer.ExoPlayer
import androidx.media3.exoplayer.hls.HlsMediaSource import androidx.media3.exoplayer.hls.HlsMediaSource
import androidx.media3.exoplayer.source.MediaSource import androidx.media3.exoplayer.source.MediaSource
import androidx.media3.exoplayer.source.ProgressiveMediaSource import androidx.media3.exoplayer.source.ProgressiveMediaSource
@ -25,10 +21,18 @@ import androidx.recyclerview.widget.RecyclerView
import androidx.viewpager2.widget.ViewPager2 import androidx.viewpager2.widget.ViewPager2
import com.blankj.utilcode.util.NetworkUtils import com.blankj.utilcode.util.NetworkUtils
import com.bumptech.glide.Glide import com.bumptech.glide.Glide
import com.facebook.AccessToken
import com.facebook.CallbackManager
import com.facebook.CallbackManager.Factory.create
import com.facebook.FacebookCallback
import com.facebook.FacebookException
import com.facebook.GraphRequest
import com.facebook.login.LoginManager
import com.facebook.login.LoginResult
import com.google.gson.Gson import com.google.gson.Gson
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.BImage
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.JActivityAdapter.CONSTANTS_QUALITY_REFRESH
import com.veloria.now.shortapp.civil.JActivityAdapter.PLAYER_DETAILS_CAN_PLAY import com.veloria.now.shortapp.civil.JActivityAdapter.PLAYER_DETAILS_CAN_PLAY
import com.veloria.now.shortapp.civil.JActivityAdapter.VIDEO_ACTIVITY_ID import com.veloria.now.shortapp.civil.JActivityAdapter.VIDEO_ACTIVITY_ID
import com.veloria.now.shortapp.civil.JActivityAdapter.VIDEO_SHORT_PLAY_ID import com.veloria.now.shortapp.civil.JActivityAdapter.VIDEO_SHORT_PLAY_ID
@ -40,25 +44,31 @@ import com.veloria.now.shortapp.civil.singleOnClick
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
import com.veloria.now.shortapp.databinding.JDetailsLayoutBinding import com.veloria.now.shortapp.databinding.JDetailsLayoutBinding
import com.veloria.now.shortapp.newsletter.AIXTextActivity import com.veloria.now.shortapp.newsletter.AIXTextActivity
import com.veloria.now.shortapp.newsletter.XNBackground
import com.veloria.now.shortapp.rewards.TOYPlayfairAutoView import com.veloria.now.shortapp.rewards.TOYPlayfairAutoView
import com.veloria.now.shortapp.rewards.VSNotificationsDefault import com.veloria.now.shortapp.rewards.VSNotificationsDefault
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.DSPUnitVideoFragment import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.DSPUnitVideoFragment
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.FYStatusAppveloria import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.FYStatusAppveloria
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.LoginDialog
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.PlayerBuyDialogFragment import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.PlayerBuyDialogFragment
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.VipActivateDialog
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.VipQualityDialog
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.UKBottomCollection import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.UKBottomCollection
import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.SUJustSmart import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.SUJustSmart
import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeBannerRecommendAdapter import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeBannerRecommendAdapter
import com.veloria.now.shortapp.texturedAsink.LServiceBean import com.veloria.now.shortapp.texturedAsink.LServiceBean
import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.NBECenterBean import com.veloria.now.shortapp.texturedAsink.NBECenterBean
import com.veloria.now.shortapp.texturedAsink.PURLockBean import com.veloria.now.shortapp.texturedAsink.PURLockBean
import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
import com.veloria.now.shortapp.texturedAsink.VeRevolutionsBean
import com.veloria.now.shortapp.texturedAsink.XAboutBean import com.veloria.now.shortapp.texturedAsink.XAboutBean
import com.youth.banner.listener.OnPageChangeListener import com.zhpan.bannerview.constants.PageStyle.MULTI_PAGE_OVERLAP
import kotlinx.coroutines.launch
import org.greenrobot.eventbus.EventBus import org.greenrobot.eventbus.EventBus
import org.greenrobot.eventbus.Subscribe import org.greenrobot.eventbus.Subscribe
import org.greenrobot.eventbus.ThreadMode import org.greenrobot.eventbus.ThreadMode
import org.json.JSONObject
import kotlin.math.max import kotlin.math.max
import kotlin.math.min import kotlin.math.min
@ -174,11 +184,6 @@ class MQVAutoWidthActivity :
private var revolution = private var revolution =
RYAction.getMMKV().getInt(JActivityAdapter.CONSTANTS_QUALITY, 540).toString() RYAction.getMMKV().getInt(JActivityAdapter.CONSTANTS_QUALITY, 540).toString()
@SuppressLint("UnsafeOptInUsageError")
private var builder: ExoPlayer.Builder? = null
private var player: ExoPlayer? = null
public fun illegalPositiveFinishAreaWorkAny(): Float { public fun illegalPositiveFinishAreaWorkAny(): Float {
var menuRecommends: String = "strideable" var menuRecommends: String = "strideable"
var againText: Double = 4231.0 var againText: Double = 4231.0
@ -243,6 +248,9 @@ class MQVAutoWidthActivity :
} }
manifestAnyBuildGravityView()?.pause() manifestAnyBuildGravityView()?.pause()
if (binding.layoutRecommend.root.visibility == View.VISIBLE) {
bannerAdapter?.getCurrentPlayerView()?.pause()
}
}, 300) }, 300)
} }
@ -453,6 +461,42 @@ class MQVAutoWidthActivity :
if (JActivityAdapter.VIDEO_PAY_REFRESH_DISMISS == event) { if (JActivityAdapter.VIDEO_PAY_REFRESH_DISMISS == event) {
isBuyShowDialog = false isBuyShowDialog = false
} }
if (JActivityAdapter.VIDEO_PAUSE_PLAY == event) {
binding.root.postDelayed({
manifestAnyBuildGravityView()?.pause()
}, 500)
}
if (JActivityAdapter.VIDEO_START_PLAY == event) {
binding.root.postDelayed({
manifestAnyBuildGravityView()?.play()
}, 500)
}
if (JActivityAdapter.VIDEO_STOP_PLAY == event) {
recommendAdapter?.items?.get(currentPosition)?.let {
setPlayerBuyDialog(it)
}
binding.root.postDelayed({
manifestAnyBuildGravityView()?.stop()
}, 500)
}
if (JActivityAdapter.CONSTANTS_QUALITY == event) {
if (episode?.is_lock == false) {
viewModel.getQualityData()
}
}
if (JActivityAdapter.HOME_USER_REFRESH == event) {
revolution = "720"
RYAction.getMMKV()
.putInt(JActivityAdapter.CONSTANTS_QUALITY, 720)
detailRefresh()
EventBus.getDefault().post(CONSTANTS_QUALITY_REFRESH)
}
if (JActivityAdapter.CONSTANTS_QUALITY_REFRESH == event) {
revolution =
RYAction.getMMKV().getInt(JActivityAdapter.CONSTANTS_QUALITY, 540)
.toString()
isQualityRefresh = true
}
} }
@ -488,8 +532,6 @@ class MQVAutoWidthActivity :
if (h_viewf < 96) { if (h_viewf < 96) {
} }
EventBus.getDefault().register(this)
var watchingB: Float = 8505.0f var watchingB: Float = 8505.0f
if (watchingB > 46.0f) { if (watchingB > 46.0f) {
} }
@ -519,12 +561,12 @@ class MQVAutoWidthActivity :
break break
} }
binding.ivBack.setOnClickListener { finish() }
if (!NetworkUtils.isConnected()) { if (!NetworkUtils.isConnected()) {
var lightf: Long = 4156L var lightf: Long = 4156L
binding.ivBack.visibility = View.VISIBLE
showErrorData(object : VSNotificationsDefault.OnRetryListener { showErrorData(object : VSNotificationsDefault.OnRetryListener {
public fun spanLoveWhatBinge(): Boolean { public fun spanLoveWhatBinge(): Boolean {
@ -556,6 +598,7 @@ class MQVAutoWidthActivity :
initView() initView()
} }
}) })
return return
} else { } else {
var playh: MutableList<Double> = mutableListOf<Double>() var playh: MutableList<Double> = mutableListOf<Double>()
@ -564,17 +607,29 @@ class MQVAutoWidthActivity :
playh.add(941.0) playh.add(941.0)
if (playh.size > 20) { if (playh.size > 20) {
} }
binding.ivBack.visibility = View.GONE
showComplete() showComplete()
var marqueeo: Float = 1740.0f var marqueeo: Float = 1740.0f
if (marqueeo < 162.0f) { if (marqueeo < 162.0f) {
} }
showLoading() // if (revolution == "1080" && !RYAction.isVipTo()) {
// if (RYAction.isTouristTo()) {
// RYAction.getMMKV()
// .putInt(JActivityAdapter.CONSTANTS_QUALITY, 540)
// } else {
// RYAction.getMMKV()
// .putInt(JActivityAdapter.CONSTANTS_QUALITY, 720)
// }
// EventBus.getDefault().post(CONSTANTS_QUALITY_REFRESH)
// revolution =
// RYAction.getMMKV().getInt(JActivityAdapter.CONSTANTS_QUALITY, 540).toString()
// }
viewModel.getVideoPlayDetails(shortPlayId, 0, activityId, revolution) viewModel.getVideoPlayDetails(shortPlayId, 0, activityId, revolution)
} }
EventBus.getDefault().register(this)
onBackPressedDispatcher.addCallback(this, object : OnBackPressedCallback(true) { onBackPressedDispatcher.addCallback(this, object : OnBackPressedCallback(true) {
override fun handleOnBackPressed() { override fun handleOnBackPressed() {
@ -583,47 +638,12 @@ class MQVAutoWidthActivity :
} }
} }
}) })
builder = ExoPlayer.Builder(this, BImage(this))
.setRenderersFactory(DefaultRenderersFactory(this).setEnableDecoderFallback(true))
player = builder?.build()
binding.layoutRecommend.recommendPlayerView.player = player
ivCoverRecommendDetail =
binding.layoutRecommend.recommendPlayerView.findViewById(R.id.iv_cover_recommend_detail)
player?.addListener(object : Player.Listener {
override fun onPlaybackStateChanged(playbackState: Int) {
super.onPlaybackStateChanged(playbackState)
when (playbackState) {
Player.STATE_BUFFERING -> {
}
Player.STATE_READY -> {
player?.play()
ivCoverRecommendDetail?.visibility = View.INVISIBLE
}
Player.STATE_ENDED -> {
ivCoverRecommendDetail?.visibility = View.VISIBLE
}
Player.STATE_IDLE -> {
}
}
}
override fun onPlayerError(error: PlaybackException) {
super.onPlayerError(error)
ivCoverRecommendDetail?.visibility = View.VISIBLE
}
})
binding.layoutRecommend.ivCloseDialog.setOnClickListener { binding.layoutRecommend.ivCloseDialog.setOnClickListener {
finish() finish()
} }
showLoading()
var appendK: MutableMap<String, Float> = mutableMapOf<String, Float>() var appendK: MutableMap<String, Float> = mutableMapOf<String, Float>()
appendK.put("decklink", 519.0f) appendK.put("decklink", 519.0f)
appendK.put("flattened", 285.0f) appendK.put("flattened", 285.0f)
@ -932,6 +952,10 @@ class MQVAutoWidthActivity :
manifestAnyBuildGravityView()?.play() manifestAnyBuildGravityView()?.play()
if (binding.layoutRecommend.root.visibility == View.VISIBLE) {
bannerAdapter?.getCurrentPlayerView()?.play()
}
} else { } else {
var listso: String = "agate" var listso: String = "agate"
@ -1363,10 +1387,6 @@ class MQVAutoWidthActivity :
while (cagetoryb >= 19.0) { while (cagetoryb >= 19.0) {
break break
} }
player?.stop()
player?.release()
player = null
manifestAnyBuildGravityView()?.stop() manifestAnyBuildGravityView()?.stop()
var circleA: Int = 8245 var circleA: Int = 8245
while (circleA >= 16) { while (circleA >= 16) {
@ -1375,6 +1395,11 @@ class MQVAutoWidthActivity :
manifestAnyBuildGravityView()?.release() manifestAnyBuildGravityView()?.release()
if (::bannerAdapter.isInitialized) {
bannerAdapter?.getCurrentPlayerView()?.stop()
bannerAdapter?.getCurrentPlayerView()?.release()
}
} }
recommendAdapter?.shortVideo = null recommendAdapter?.shortVideo = null
var mmkvi: Double = 540.0 var mmkvi: Double = 540.0
@ -1618,7 +1643,7 @@ class MQVAutoWidthActivity :
} }
println(startA) println(startA)
binding.ivBack.visibility = View.GONE
showComplete() showComplete()
var rights: Long = 9660L var rights: Long = 9660L
if (rights > 16L) { if (rights > 16L) {
@ -1670,7 +1695,7 @@ class MQVAutoWidthActivity :
break break
} }
binding.ivBack.visibility = View.VISIBLE
showEmptyData() showEmptyData()
} }
} }
@ -1903,26 +1928,33 @@ class MQVAutoWidthActivity :
} }
viewModel.detailsRecommendLiveData.observe(this) { viewModel.detailsRecommendLiveData.observe(this) {
hideLoading()
it?.data?.let { it?.data?.let {
setDetailsRecommendation(it) setDetailsRecommendation(it)
} ?: finish() } ?: finish()
hideLoading()
} }
viewModel.userInfo.observe(this) { viewModel.userInfo.observe(this) {
it?.data?.let { it?.data?.let {
RYAction.saveUserInfoBean(it) RYAction.saveUserInfoBean(it)
if (needRestart) { if (needRestart) {
if (TranslationHelper.getTranslation() != null) {
binding.layoutLock.tvBalance.text =
TranslationHelper.getTranslation()?.veloria_balance.plus(": ")
.plus(RYAction.getUserInfoBean()?.coin_left_total.toString())
.plus(TranslationHelper.getTranslation()?.veloria_coins)
.plus(" | ")
.plus(RYAction.getUserInfoBean()?.send_coin_left_total.toString())
.plus(" ")
.plus(TranslationHelper.getTranslation()?.veloria_bonus)
} else {
binding.layoutLock.tvBalance.text = binding.layoutLock.tvBalance.text =
"Balance: ".plus(RYAction.getUserInfoBean()?.coin_left_total.toString()) "Balance: ".plus(RYAction.getUserInfoBean()?.coin_left_total.toString())
.plus(" Coins | ") .plus(" Coins | ")
.plus(RYAction.getUserInfoBean()?.send_coin_left_total.toString()) .plus(RYAction.getUserInfoBean()?.send_coin_left_total.toString())
.plus(" Bonus") .plus(" Bonus")
if (RYAction.isVipTo()) {
revolution = "1080"
RYAction.getMMKV().putInt(JActivityAdapter.CONSTANTS_QUALITY, 1080)
} }
detailRefresh() detailRefresh()
} }
} }
@ -1967,6 +1999,102 @@ class MQVAutoWidthActivity :
} }
} }
} }
viewModel.qualityData.observe(this) {
it?.data?.let {
setQualityDialog(it)
} ?: run {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else {
toast(getString(R.string.shapeSelected))
}
}
}
callbackManager = create()
LoginManager.getInstance().registerCallback(callbackManager,
object : FacebookCallback<LoginResult> {
override fun onSuccess(loginResult: LoginResult) {
val enableButtons = AccessToken.getCurrentAccessToken() != null
if (enableButtons) {
val mGraphRequest = GraphRequest.newMeRequest(
loginResult.accessToken
) { jsonObject, response ->
if (response!!.error != null) {
if (TranslationHelper.getTranslation() != null) {
toast(
"Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_exception)
.plus(".${response.error?.exception.toString()}")
)
} else {
toast("Facebook Error")
}
} else {
val id = jsonObject?.optString("id")
val name = jsonObject?.optString("name")
val object_pic: JSONObject? = jsonObject!!.optJSONObject("picture")
val object_data = object_pic?.optJSONObject("data")
val photo = object_data?.optString("url")
viewModel.setLeaveApp()
viewModel.setDoLogin(
LoginDataBean(
photo.toString(),
"",
name.toString(),
"",
"facebook",
id.toString()
)
)
}
}
val parameters = Bundle()
parameters.putString("fields", "id,name,email,picture")
mGraphRequest.parameters = parameters
mGraphRequest.executeAsync()
}
}
override fun onCancel() {
if (TranslationHelper.getTranslation() != null) {
toast("Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_cancel))
} else {
toast("Facebook Cancel")
}
}
override fun onError(exception: FacebookException) {
if (TranslationHelper.getTranslation() != null) {
toast(
"Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_exception)
.plus("n.$exception")
)
} else {
toast("Facebook Error")
}
}
})
viewModel.loginLiveData.observe(this) {
if (it?.data != null) {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_succeed.toString())
}
RYAction.getMMKV()
.putString(JActivityAdapter.ACCOUNT_TOKEN, it.data.token)
EventBus.getDefault()
.post(JActivityAdapter.HOME_ENTER_THE_APP)
EventBus.getDefault()
.post(JActivityAdapter.HOME_ON_LINE)
EventBus.getDefault()
.post(JActivityAdapter.HOME_USER_REFRESH)
}
}
} }
@ -1996,6 +2124,14 @@ class MQVAutoWidthActivity :
} }
private fun showGoldShortageDialog(episode1: XAboutBean.Episode) { private fun showGoldShortageDialog(episode1: XAboutBean.Episode) {
if (!NetworkUtils.isConnected()) {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else {
toast(XNBackground.instance.getString(R.string.shapeSelected))
}
return
}
val allCoin = RYAction.getAllCoinTotal() val allCoin = RYAction.getAllCoinTotal()
if (allCoin >= episode1.coins) { if (allCoin >= episode1.coins) {
if (currentPosition > 0) { if (currentPosition > 0) {
@ -2073,21 +2209,34 @@ class MQVAutoWidthActivity :
return false return false
} }
private lateinit var bannerAdapter: VeBannerRecommendAdapter
@SuppressLint("UnsafeOptInUsageError") @SuppressLint("UnsafeOptInUsageError")
private fun setDetailsRecommendation(data: VeDetailsRecommendBean) { private fun setDetailsRecommendation(data: VeDetailsRecommendBean) {
if (data.list.isNotEmpty()) { if (data.list.isNotEmpty()) {
if (TranslationHelper.getTranslation() != null) {
binding.layoutRecommend.tvTitle.text =
TranslationHelper.getTranslation()?.veloria_detail_recommand_title
binding.layoutRecommend.tvWatchNow.text =
TranslationHelper.getTranslation()?.veloria_watch_now
}
PLAYER_DETAILS_CAN_PLAY = false PLAYER_DETAILS_CAN_PLAY = false
binding.layoutRecommend.root.visibility = View.VISIBLE binding.layoutRecommend.root.visibility = View.VISIBLE
val bannerAdapter = bannerAdapter =
VeBannerRecommendAdapter(data.list) VeBannerRecommendAdapter()
binding.layoutRecommend.bannerRecommend.setBannerGalleryMZ( binding.layoutRecommend.bannerRecommend.setAdapter(
resources.getDimension(R.dimen.dp_20).toInt() bannerAdapter
) )
binding.layoutRecommend.bannerRecommend.apply {
setLifecycleRegistry(lifecycle)
setRevealWidth(resources.getDimension(R.dimen.dp_50).toInt())
setPageStyle(MULTI_PAGE_OVERLAP)
}.create(data.list)
binding.layoutRecommend.bannerRecommend.addOnPageChangeListener( binding.layoutRecommend.bannerRecommend.registerOnPageChangeCallback(
object : object :
OnPageChangeListener { ViewPager2.OnPageChangeCallback() {
override fun onPageScrolled( override fun onPageScrolled(
position: Int, position: Int,
positionOffset: Float, positionOffset: Float,
@ -2100,56 +2249,34 @@ class MQVAutoWidthActivity :
bannerPosition = position bannerPosition = position
bannerAdapter.currentPlayingPosition = position bannerAdapter.currentPlayingPosition = position
bannerAdapter.notifyDataSetChanged() bannerAdapter.notifyDataSetChanged()
val data = bannerAdapter.getData(position)
ivCoverRecommendDetail?.let { it1 ->
Glide.with(this@MQVAutoWidthActivity)
.load(data?.image_url)
.into(it1)
}
binding.layoutRecommend.cardView.visibility = View.VISIBLE
ivCoverRecommendDetail?.visibility = View.VISIBLE
player?.stop()
player?.setMediaSource(buildMediaSource(data?.video_url.toString()))
player?.prepare()
} }
override fun onPageScrollStateChanged(state: Int) { override fun onPageScrollStateChanged(state: Int) {
if (1 == state) { // if (1 == state) {
player?.pause() // bannerAdapter.currentPlayingPosition = -1
binding.layoutRecommend.cardView.visibility = // bannerAdapter.notifyDataSetChanged()
View.INVISIBLE // } else {
bannerAdapter.currentPlayingPosition = -1 // if (2 == state) {
bannerAdapter.notifyDataSetChanged() // if (player?.isPlaying == false) {
} else { // bannerAdapter.currentPlayingPosition =
if (2 == state) { // bannerPosition
if (player?.isPlaying == false) { // bannerAdapter.notifyDataSetChanged()
player?.play() // }
binding.layoutRecommend.cardView.visibility = // }
View.VISIBLE // }
bannerAdapter.currentPlayingPosition =
bannerPosition
bannerAdapter.notifyDataSetChanged()
}
}
}
} }
}) })
binding.layoutRecommend.bannerRecommend.setAdapter(
bannerAdapter
)
binding.layoutRecommend.tvWatchNow.setOnClickListener { binding.layoutRecommend.tvWatchNow.setOnClickListener {
val data = bannerAdapter.getData(bannerPosition) val data =
binding.layoutRecommend.bannerRecommend.getData()[bannerPosition] as VeDetailsRecommendBean.ItemDaraBean
watchNow(data, data?.short_play_id) watchNow(data, data?.short_play_id)
} }
val data = bannerAdapter.getData(0) val data = data.list[0]
ivCoverRecommendDetail?.let { it1 -> ivCoverRecommendDetail?.let { it1 ->
Glide.with(this@MQVAutoWidthActivity).load(data?.image_url) Glide.with(this@MQVAutoWidthActivity).load(data?.image_url)
.into(it1) .into(it1)
} }
lifecycleScope.launch {
player?.setMediaSource(buildMediaSource(data?.video_url.toString()))
player?.prepare()
}
} else { } else {
finish() finish()
} }
@ -2174,7 +2301,8 @@ class MQVAutoWidthActivity :
) { ) {
binding.layoutRecommend.bannerRecommend.postDelayed({ binding.layoutRecommend.bannerRecommend.postDelayed({
if (data?.short_play_id != null) { if (data?.short_play_id != null) {
player?.stop() bannerAdapter.getCurrentPlayerView()?.stop()
bannerAdapter.getCurrentPlayerView()?.release()
if (short_play_id != null) { if (short_play_id != null) {
shortPlayId = short_play_id shortPlayId = short_play_id
} }
@ -2184,5 +2312,63 @@ class MQVAutoWidthActivity :
binding.layoutRecommend.root.visibility = View.INVISIBLE binding.layoutRecommend.root.visibility = View.INVISIBLE
} }
private fun setQualityDialog(revolutionData: VeRevolutionsBean) {
val dialog = VipQualityDialog(this, revolutionData).apply {
setOnQualityBackOnClickListener(object :
VipQualityDialog.SetQualityBackOnClick {
override fun qualityBackOnClick(quality: Int) {
RYAction.getMMKV()
.putInt(JActivityAdapter.CONSTANTS_QUALITY, quality)
EventBus.getDefault().post(CONSTANTS_QUALITY_REFRESH)
revolution = quality.toString()
detailRefresh()
}
override fun showActivateOnClick() {
setVipActivateDialog()
}
override fun loginOnClick() {
setLogin()
}
})
}
dialog.show()
dialog.setQualityBackOnClick
}
private fun setVipActivateDialog() {
val dialog = VipActivateDialog(this)
dialog.show()
}
private var callbackManager: CallbackManager? = null
fun setLogin() {
val dialog = LoginDialog(this).apply {
setOnLoginOnclickListener(object : LoginDialog.LoginOnClick {
override fun onLoginFacebook() {
onFacebook()
}
})
}
dialog.show()
dialog.loginOnclick
}
private fun onFacebook() {
singleOnClick {
LoginManager.getInstance()
.logInWithReadPermissions(this, arrayListOf("public_profile", "email"))
}
}
@Deprecated("Deprecated in Java")
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
callbackManager?.onActivityResult(requestCode, resultCode, data)
}
} }

View File

@ -1,15 +1,21 @@
package com.veloria.now.shortapp.subtractionCroll.bidirectional package com.veloria.now.shortapp.subtractionCroll.bidirectional
import android.Manifest
import android.app.Activity import android.app.Activity
import android.content.ClipData import android.content.ClipData
import android.content.ClipboardManager import android.content.ClipboardManager
import android.content.Context import android.content.Context
import android.content.Intent import android.content.Intent
import android.content.pm.PackageManager
import android.os.Build
import android.os.Bundle import android.os.Bundle
import android.text.TextUtils import android.text.TextUtils
import android.util.Log
import android.view.KeyEvent import android.view.KeyEvent
import android.view.View import android.view.View
import androidx.activity.result.contract.ActivityResultContracts
import androidx.activity.viewModels import androidx.activity.viewModels
import androidx.core.content.ContextCompat
import androidx.fragment.app.Fragment import androidx.fragment.app.Fragment
import androidx.lifecycle.lifecycleScope import androidx.lifecycle.lifecycleScope
import com.blankj.utilcode.util.NetworkUtils import com.blankj.utilcode.util.NetworkUtils
@ -22,12 +28,19 @@ import com.facebook.FacebookException
import com.facebook.GraphRequest import com.facebook.GraphRequest
import com.facebook.login.LoginManager import com.facebook.login.LoginManager
import com.facebook.login.LoginResult import com.facebook.login.LoginResult
import com.google.android.gms.common.GoogleApiAvailability
import com.google.android.gms.tasks.OnCompleteListener
import com.google.firebase.messaging.FirebaseMessaging
import com.google.gson.Gson import com.google.gson.Gson
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.JActivityAdapter.VIDEO_SHORT_PLAY_ID import com.veloria.now.shortapp.civil.JActivityAdapter.VIDEO_SHORT_PLAY_ID
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.VeNotificationHelper
import com.veloria.now.shortapp.civil.YFHome.getPackageVersionCode
import com.veloria.now.shortapp.civil.setShowNotifications
import com.veloria.now.shortapp.civil.shouldVersionControl
import com.veloria.now.shortapp.civil.singleOnClick import com.veloria.now.shortapp.civil.singleOnClick
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
import com.veloria.now.shortapp.databinding.JsDramaFragmentBinding import com.veloria.now.shortapp.databinding.JsDramaFragmentBinding
@ -38,9 +51,18 @@ import com.veloria.now.shortapp.subtractionCroll.adminSourceid.NOEditRegisterFra
import com.veloria.now.shortapp.subtractionCroll.adminSourceid.UColorsAvatarFragment import com.veloria.now.shortapp.subtractionCroll.adminSourceid.UColorsAvatarFragment
import com.veloria.now.shortapp.subtractionCroll.adminSourceid.YYLoginHistoryFragment import com.veloria.now.shortapp.subtractionCroll.adminSourceid.YYLoginHistoryFragment
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.LoginDialog import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.LoginDialog
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.NotificationsDialog
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.VersionControlDialog
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.JService import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.JService
import com.veloria.now.shortapp.texturedAsink.LoginDataBean import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.VeHomeWatchBean import com.veloria.now.shortapp.texturedAsink.VeHomeWatchBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationBean
import com.veloria.now.shortapp.texturedAsink.VersionControlBean
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.flow.debounce
import kotlinx.coroutines.flow.flow
import kotlinx.coroutines.flow.onEach
import kotlinx.coroutines.launch import kotlinx.coroutines.launch
import org.greenrobot.eventbus.EventBus import org.greenrobot.eventbus.EventBus
import org.greenrobot.eventbus.Subscribe import org.greenrobot.eventbus.Subscribe
@ -67,6 +89,7 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
val viewModel: JService by viewModels() val viewModel: JService by viewModels()
private var callbackManager: CallbackManager? = null private var callbackManager: CallbackManager? = null
private var scheduler: ScheduledExecutorService? = Executors.newSingleThreadScheduledExecutor() private var scheduler: ScheduledExecutorService? = Executors.newSingleThreadScheduledExecutor()
private val scope = CoroutineScope(Dispatchers.Main)
private fun rawEventShowPositionLatest(): MutableList<Boolean> { private fun rawEventShowPositionLatest(): MutableList<Boolean> {
var responseRemove = true var responseRemove = true
@ -198,7 +221,7 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
it.data?.token?.let { it1 -> it.data?.token?.let { it1 ->
RYAction.saveToken(it1) RYAction.saveToken(it1)
EventBus.getDefault().post(JActivityAdapter.REFRESH_HOME) EventBus.getDefault().post(JActivityAdapter.HOME_REFRESH_ME)
} }
} }
} }
@ -233,16 +256,37 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
} }
} }
viewModel.w2aSelfAttributionData.observe(this){ viewModel.w2aSelfAttributionData.observe(this) {
if (needSave) { if (needSave) {
setAdjustToDetail() setAdjustToDetail()
} }
} }
viewModel.restorePaidData.observe(this) {
viewModel.onLineLiveData.observe(this){ if (it != null) {
it.data?.order_code?.let { it1 -> RYAction.removeOrderString(it1) }
}
}
viewModel.onLineLiveData.observe(this) {
} }
viewModel.versionControlData.observe(this) {
if (it != null) {
if (it.data?.version_code?.isNotEmpty() == true) {
val toInt = it.data.version_code.toInt()
if (shouldVersionControl() && toInt > getPackageVersionCode(this)) {
setVersionControlDialog(it.data)
}
}
}
}
}
fun setVersionControlDialog(versionControlBean: VersionControlBean) {
val dialog = VersionControlDialog(this, versionControlBean)
dialog.show()
} }
private val items = listOf( private val items = listOf(
@ -376,7 +420,7 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
if (string?.isNotEmpty() == true && NetworkUtils.isConnected()) { if (string?.isNotEmpty() == true && NetworkUtils.isConnected()) {
val fromJson = Gson().fromJson(string, VeHomeWatchBean::class.java) val fromJson = Gson().fromJson(string, VeHomeWatchBean::class.java)
showHistoryDialog(fromJson) showHistoryDialog(fromJson)
}else { } else {
binding.dialogWatch.root.visibility = View.INVISIBLE binding.dialogWatch.root.visibility = View.INVISIBLE
} }
}, 500 }, 500
@ -454,7 +498,10 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
var episode0: Long = 1323L var episode0: Long = 1323L
if (episode0 > 52L) { if (episode0 > 52L) {
} }
path = intent?.getStringExtra("path").toString()
short_play_id = intent?.getStringExtra("short_play_id").toString()
message_id = intent?.getStringExtra("message_id").toString()
title = intent?.getStringExtra("title").toString()
manifestShapeSinkExclusive() manifestShapeSinkExclusive()
@ -487,12 +534,12 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
loginResult.accessToken loginResult.accessToken
) { jsonObject, response -> ) { jsonObject, response ->
if (response!!.error != null) { if (response!!.error != null) {
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null) {
toast( toast(
"Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_exception) "Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_exception)
.plus(".${response.error?.exception.toString()}") .plus(".${response.error?.exception.toString()}")
) )
}else { } else {
toast("Facebook Error") toast("Facebook Error")
} }
} else { } else {
@ -522,24 +569,57 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
} }
override fun onCancel() { override fun onCancel() {
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null) {
toast("Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_cancel)) toast("Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_cancel))
}else { } else {
toast("Facebook Cancel") toast("Facebook Cancel")
} }
} }
override fun onError(exception: FacebookException) { override fun onError(exception: FacebookException) {
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null) {
toast( toast(
"Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_exception) "Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_exception)
.plus("n.$exception") .plus("n.$exception")
) )
}else { } else {
toast("Facebook Error") toast("Facebook Error")
} }
} }
}) })
JActivityAdapter.IS_HOME_SET_NOTIFICATIONS = VeNotificationHelper.isNotification(this)
viewModel.setUploadNoticeStatus(
VeUploadNotificationBean(
if (JActivityAdapter.IS_HOME_SET_NOTIFICATIONS) "1" else "0"
)
)
GoogleApiAvailability.getInstance().makeGooglePlayServicesAvailable(this)
.addOnCompleteListener {
if (it.isSuccessful) {
askNotificationPermission()
}
}
binding.root.postDelayed({ setNotificationTo() }, 700)
//处理失败订单
binding.root.postDelayed({
if (RYAction.getOrder().isNotEmpty()) {
val string = RYAction.getOrder()
scope.launch {
flow {
for (item in string) {
emit(item)
}
}.onEach { item ->
viewModel.setGooglePaid(item)
}.debounce(1000).collect {}
}
}
}, 3000)
viewModel.getVersionControl()
} }
private fun stayPrimaryRecommendSearchToast( private fun stayPrimaryRecommendSearchToast(
@ -747,6 +827,18 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
binding.bottomNavBar.updateSelection(0) binding.bottomNavBar.updateSelection(0)
playWhatHeavyPlatformEach(0) playWhatHeavyPlatformEach(0)
} }
if (JActivityAdapter.ACCOUNT_FIREBASE_TOKEN_REFRESH == event) {
getFirebaseMessaging()
}
if (JActivityAdapter.ACCOUNT_OUT_LOGIN == event) {
viewModel.loadData()
if (TranslationHelper.getTranslation() != null) {
toast(
TranslationHelper.getTranslation()?.veloria_network_error_1
?: getString(R.string.veloria_network_error_1)
)
}
}
} }
private fun restartApplication(context: Context) { private fun restartApplication(context: Context) {
@ -780,8 +872,21 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
@Deprecated("Deprecated in Java") @Deprecated("Deprecated in Java")
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) { override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data) super.onActivityResult(requestCode, resultCode, data)
if (requestCode == VeNotificationHelper.VE_NOTIFICATION_REQUEST_CODE) {
JActivityAdapter.IS_HOME_SET_NOTIFICATIONS = VeNotificationHelper.isNotification(this)
if (JActivityAdapter.IS_HOME_SET_NOTIFICATIONS) {
getFirebaseMessaging()
viewModel.setOpenNotify()
}
viewModel.setUploadNoticeStatus(
VeUploadNotificationBean(
if (JActivityAdapter.IS_HOME_SET_NOTIFICATIONS) "1" else "0"
)
)
} else {
callbackManager?.onActivityResult(requestCode, resultCode, data) callbackManager?.onActivityResult(requestCode, resultCode, data)
} }
}
private fun showHistoryDialog(data: VeHomeWatchBean) { private fun showHistoryDialog(data: VeHomeWatchBean) {
@ -845,7 +950,8 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
) )
needSave = true needSave = true
w2aSelfAttribution(clipContent) w2aSelfAttribution(clipContent)
RYAction.getMMKV().putString(JActivityAdapter.HOME_DDL_URL, "") RYAction.getMMKV()
.putString(JActivityAdapter.HOME_DDL_URL, "")
} }
} }
} }
@ -891,7 +997,7 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
if (string?.isNotEmpty() == true && NetworkUtils.isConnected()) { if (string?.isNotEmpty() == true && NetworkUtils.isConnected()) {
val fromJson = Gson().fromJson(string, VeHomeWatchBean::class.java) val fromJson = Gson().fromJson(string, VeHomeWatchBean::class.java)
showHistoryDialog(fromJson) showHistoryDialog(fromJson)
}else { } else {
binding.dialogWatch.root.visibility = View.INVISIBLE binding.dialogWatch.root.visibility = View.INVISIBLE
} }
}, 500 }, 500
@ -982,4 +1088,173 @@ class PSVHomeSearchActivity : AIXTextActivity<JsDramaFragmentBinding, JService>(
} }
} }
private fun getFirebaseMessaging() {
FirebaseMessaging.getInstance().token.addOnCompleteListener(OnCompleteListener { task ->
if (!task.isSuccessful) {
return@OnCompleteListener
}
// Get new FCM registration token
val token = task.result
// Log and toast
Log.d("LOG_TAG", token)
viewModel.setFirebaseToken(token)
})
}
private fun askNotificationPermission() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
if (ContextCompat.checkSelfPermission(
this, Manifest.permission.POST_NOTIFICATIONS
) == PackageManager.PERMISSION_GRANTED
) {
getFirebaseMessaging()
viewModel.setOpenNotify()
viewModel.setUploadNoticeStatus(
VeUploadNotificationBean("1")
)
} else {
if (setShowNotifications()) {
setNotifications()
}
}
} else {
if (VeNotificationHelper.isNotification(this)) {
getFirebaseMessaging()
viewModel.setOpenNotify()
viewModel.setUploadNoticeStatus(
VeUploadNotificationBean("1")
)
} else {
if (setShowNotifications()) {
setNotifications()
}
}
}
}
private fun setNotifications() {
val dialog = NotificationsDialog(this).apply {
setOnNotificationClickListener(object :
NotificationsDialog.SetNotificationOnClick {
override fun notificationOnClick() {
setNotificationOnClick()
}
})
}
dialog.show()
dialog.setNotificationOnClick
dialog.setOnDismissListener {
RYAction.getMMKV().putLong(
JActivityAdapter.ACCOUNT_DIALOG_TIME_NOTIFICATIONS,
System.currentTimeMillis()
)
}
}
fun setNotificationOnClick() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
setRequestPermission.launch(Manifest.permission.POST_NOTIFICATIONS)
} else {
VeNotificationHelper.setNotification(this)
}
}
private val setRequestPermission = registerForActivityResult(
ActivityResultContracts.RequestPermission(),
) { isGranted: Boolean ->
JActivityAdapter.IS_HOME_SET_NOTIFICATIONS = isGranted
if (isGranted) {
getFirebaseMessaging()
viewModel.setOpenNotify()
viewModel.setUploadNoticeStatus(
VeUploadNotificationBean("1")
)
} else {
VeNotificationHelper.setNotification(this)
}
}
private fun setNotificationTo() {
if (message_id.isNotBlank() && !message_id.contentEquals("null")) {
if ("0" != message_id) {
viewModel.setSendReport(message_id, title)
}
}
when (path) {
"detail" -> {
if (short_play_id.isNotEmpty() && "null" != short_play_id) {
try {
val toInt = short_play_id.toInt()
binding.root.postDelayed({
startActivity(Intent(
this, MQVAutoWidthActivity::class.java
).apply {
putExtra(
VIDEO_SHORT_PLAY_ID, toInt
)
})
}, 700)
} catch (e: Exception) {
e.printStackTrace()
}
}
}
"promotion" -> {
binding.root.postDelayed({
startActivity(
Intent(
this, VeRewardsActivity::class.java
)
)
}, 700)
}
"orderDetail" -> {
binding.root.postDelayed({
startActivity(
Intent(
this, VeMyWalletActivity::class.java
)
)
}, 700)
}
"feedback" -> {
binding.root.postDelayed({
if (message_id.isNotBlank() && message_id != "null") {
RYAction.getMMKV()
.putString(JActivityAdapter.FEEDBACK_DETAIL_ID, message_id)
startActivity(
Intent(
this, VeFeedbackDetailActivity::class.java
)
)
} else {
startActivity(
Intent(
this, VeFeedbackListActivity::class.java
)
)
}
}, 700)
}
}
}
private var path = ""
private var short_play_id = ""
private var message_id = ""
private var title = ""
override fun onNewIntent(intent: Intent?) {
super.onNewIntent(intent)
path = intent?.getStringExtra("path").toString()
short_play_id = intent?.getStringExtra("short_play_id").toString()
message_id = intent?.getStringExtra("message_id").toString()
title = intent?.getStringExtra("title").toString()
setNotificationTo()
}
} }

View File

@ -2,24 +2,28 @@ package com.veloria.now.shortapp.subtractionCroll.bidirectional
import android.annotation.SuppressLint import android.annotation.SuppressLint
import android.graphics.Bitmap import android.graphics.Bitmap
import android.view.View
import android.webkit.WebChromeClient import android.webkit.WebChromeClient
import android.webkit.WebResourceError import android.webkit.WebResourceError
import android.webkit.WebResourceRequest import android.webkit.WebResourceRequest
import android.webkit.WebSettings import android.webkit.WebSettings
import android.webkit.WebView import android.webkit.WebView
import android.webkit.WebViewClient import android.webkit.WebViewClient
import com.blankj.utilcode.util.NetworkUtils
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
import com.veloria.now.shortapp.databinding.IPlaceBinding import com.veloria.now.shortapp.databinding.IPlaceBinding
import com.veloria.now.shortapp.newsletter.AIXTextActivity import com.veloria.now.shortapp.newsletter.AIXTextActivity
import com.veloria.now.shortapp.rewards.VSNotificationsDefault
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.LXMService import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.LXMService
import kotlin.math.max import kotlin.math.max
import kotlin.math.min import kotlin.math.min
class RBZLatestDeteleActivity : AIXTextActivity<IPlaceBinding, LXMService>() { class RBZLatestDeteleActivity : AIXTextActivity<IPlaceBinding, LXMService>(), NOFfmpeg {
@Volatile @Volatile
var centerTrendPaint_min: Double = 5869.0 var centerTrendPaint_min: Double = 5869.0
@ -168,7 +172,6 @@ class RBZLatestDeteleActivity : AIXTextActivity<IPlaceBinding, LXMService>() {
println(messageL) println(messageL)
when (urlString) { when (urlString) {
JActivityAdapter.WEB_VIEW_USER_AGREEMENT -> { JActivityAdapter.WEB_VIEW_USER_AGREEMENT -> {
var modelE: Float = 6376.0f var modelE: Float = 6376.0f
@ -206,6 +209,20 @@ class RBZLatestDeteleActivity : AIXTextActivity<IPlaceBinding, LXMService>() {
binding.tvTitle.text = "Veloria" binding.tvTitle.text = "Veloria"
} }
} }
if (!NetworkUtils.isConnected()) {
binding.webView.visibility = View.GONE
showErrorData(object : VSNotificationsDefault.OnRetryListener {
override fun onRetry(layout: VSNotificationsDefault) {
initView()
}
})
return
}
binding.webView.visibility = View.VISIBLE
showComplete()
showLoading() showLoading()
var helpF: MutableMap<String, Long> = mutableMapOf<String, Long>() var helpF: MutableMap<String, Long> = mutableMapOf<String, Long>()
helpF.put("texturedspenc", 528L) helpF.put("texturedspenc", 528L)
@ -502,4 +519,7 @@ class RBZLatestDeteleActivity : AIXTextActivity<IPlaceBinding, LXMService>() {
} }
override fun getViewBinding() = IPlaceBinding.inflate(layoutInflater) override fun getViewBinding() = IPlaceBinding.inflate(layoutInflater)
override fun getStatusLayout(): VSNotificationsDefault? {
return binding.stateLayout
}
} }

View File

@ -27,13 +27,14 @@ import androidx.lifecycle.lifecycleScope
import com.blankj.utilcode.util.PermissionUtils import com.blankj.utilcode.util.PermissionUtils
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.singleOnClick import com.veloria.now.shortapp.civil.singleOnClick
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
import com.veloria.now.shortapp.databinding.ActivityVeFeedbackBinding import com.veloria.now.shortapp.databinding.ActivityVeFeedbackBinding
import com.veloria.now.shortapp.newsletter.AIXTextActivity import com.veloria.now.shortapp.newsletter.AIXTextActivity
import com.veloria.now.shortapp.newsletter.XNBackground
import com.veloria.now.shortapp.other.FeedbackJsBridge import com.veloria.now.shortapp.other.FeedbackJsBridge
import com.veloria.now.shortapp.rewards.VSNotificationsDefault
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeFeedbackViewModel import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeFeedbackViewModel
import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch import kotlinx.coroutines.launch
@ -44,7 +45,8 @@ import org.greenrobot.eventbus.ThreadMode
import java.io.ByteArrayOutputStream import java.io.ByteArrayOutputStream
import java.io.InputStream import java.io.InputStream
class VeFeedbackActivity : AIXTextActivity<ActivityVeFeedbackBinding, VeFeedbackViewModel>() { class VeFeedbackActivity : AIXTextActivity<ActivityVeFeedbackBinding, VeFeedbackViewModel>(),
NOFfmpeg {
val viewModel: VeFeedbackViewModel by viewModels() val viewModel: VeFeedbackViewModel by viewModels()
@ -55,7 +57,7 @@ class VeFeedbackActivity : AIXTextActivity<ActivityVeFeedbackBinding, VeFeedback
override fun initView() { override fun initView() {
EventBus.getDefault().register(this) EventBus.getDefault().register(this)
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null) {
binding.tvTitle.text = TranslationHelper.getTranslation()?.veloria_my_feedback binding.tvTitle.text = TranslationHelper.getTranslation()?.veloria_my_feedback
} }
@ -138,7 +140,8 @@ class VeFeedbackActivity : AIXTextActivity<ActivityVeFeedbackBinding, VeFeedback
binding.webFeedback.webViewClient = object : WebViewClient() { binding.webFeedback.webViewClient = object : WebViewClient() {
override fun onPageStarted(view: WebView?, url: String?, favicon: Bitmap?) { override fun onPageStarted(view: WebView?, url: String?, favicon: Bitmap?) {
super.onPageStarted(view, url, favicon) super.onPageStarted(view, url, favicon)
showComplete()
binding.webFeedback.visibility = View.VISIBLE
} }
override fun onPageFinished(view: WebView?, url: String?) { override fun onPageFinished(view: WebView?, url: String?) {
@ -152,9 +155,17 @@ class VeFeedbackActivity : AIXTextActivity<ActivityVeFeedbackBinding, VeFeedback
error: WebResourceError? error: WebResourceError?
) { ) {
super.onReceivedError(view, request, error) super.onReceivedError(view, request, error)
if (TranslationHelper.getTranslation() != null){ showErrorData(object : VSNotificationsDefault.OnRetryListener {
override fun onRetry(layout: VSNotificationsDefault) {
showLoading()
loadPageUrl(JActivityAdapter.FEEDBACK_URL_INDEX)
}
})
binding.webFeedback.visibility = View.INVISIBLE
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString()) toast(TranslationHelper.getTranslation()?.veloria_network.toString())
}else { } else {
toast(getString(R.string.shapeSelected)) toast(getString(R.string.shapeSelected))
} }
hideLoading() hideLoading()
@ -303,4 +314,8 @@ class VeFeedbackActivity : AIXTextActivity<ActivityVeFeedbackBinding, VeFeedback
EventBus.getDefault().unregister(this) EventBus.getDefault().unregister(this)
} }
override fun getStatusLayout(): VSNotificationsDefault? {
return binding.stateLayout
}
} }

View File

@ -12,6 +12,7 @@ import android.net.Uri
import android.os.Build import android.os.Build
import android.util.Base64 import android.util.Base64
import android.util.Log import android.util.Log
import android.view.View
import android.webkit.JsPromptResult import android.webkit.JsPromptResult
import android.webkit.JsResult import android.webkit.JsResult
import android.webkit.WebChromeClient import android.webkit.WebChromeClient
@ -27,6 +28,7 @@ import androidx.lifecycle.lifecycleScope
import com.blankj.utilcode.util.PermissionUtils import com.blankj.utilcode.util.PermissionUtils
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
@ -38,6 +40,7 @@ import com.veloria.now.shortapp.newsletter.XNBackground
import com.veloria.now.shortapp.other.BaseEventBusBean import com.veloria.now.shortapp.other.BaseEventBusBean
import com.veloria.now.shortapp.other.FeedbackJsBridge import com.veloria.now.shortapp.other.FeedbackJsBridge
import com.veloria.now.shortapp.other.FeedbackJsBridgeDetail import com.veloria.now.shortapp.other.FeedbackJsBridgeDetail
import com.veloria.now.shortapp.rewards.VSNotificationsDefault
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeFeedbackViewModel import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeFeedbackViewModel
import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.launch import kotlinx.coroutines.launch
@ -48,7 +51,8 @@ import org.greenrobot.eventbus.ThreadMode
import java.io.ByteArrayOutputStream import java.io.ByteArrayOutputStream
import java.io.InputStream import java.io.InputStream
class VeFeedbackDetailActivity : AIXTextActivity<ActivityVeFeedbackDetailBinding, VeFeedbackViewModel>() { class VeFeedbackDetailActivity : AIXTextActivity<ActivityVeFeedbackDetailBinding, VeFeedbackViewModel>() ,
NOFfmpeg {
val viewModel: VeFeedbackViewModel by viewModels() val viewModel: VeFeedbackViewModel by viewModels()
@ -91,7 +95,8 @@ class VeFeedbackDetailActivity : AIXTextActivity<ActivityVeFeedbackDetailBinding
binding.webFeedbackDetail.webViewClient = object : WebViewClient() { binding.webFeedbackDetail.webViewClient = object : WebViewClient() {
override fun onPageStarted(view: WebView?, url: String?, favicon: Bitmap?) { override fun onPageStarted(view: WebView?, url: String?, favicon: Bitmap?) {
super.onPageStarted(view, url, favicon) super.onPageStarted(view, url, favicon)
showComplete()
binding.webFeedbackDetail.visibility = View.VISIBLE
} }
override fun onPageFinished(view: WebView?, url: String?) { override fun onPageFinished(view: WebView?, url: String?) {
@ -106,6 +111,14 @@ class VeFeedbackDetailActivity : AIXTextActivity<ActivityVeFeedbackDetailBinding
error: WebResourceError? error: WebResourceError?
) { ) {
super.onReceivedError(view, request, error) super.onReceivedError(view, request, error)
showErrorData(object : VSNotificationsDefault.OnRetryListener {
override fun onRetry(layout: VSNotificationsDefault) {
showLoading()
loadPageUrl(JActivityAdapter.FEEDBACK_URL_DETAIL)
}
})
binding.webFeedbackDetail.visibility = View.INVISIBLE
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null){
toast(TranslationHelper.getTranslation()?.veloria_network.toString()) toast(TranslationHelper.getTranslation()?.veloria_network.toString())
}else { }else {
@ -251,4 +264,8 @@ class VeFeedbackDetailActivity : AIXTextActivity<ActivityVeFeedbackDetailBinding
EventBus.getDefault().unregister(this) EventBus.getDefault().unregister(this)
} }
override fun getStatusLayout(): VSNotificationsDefault? {
return binding.stateLayout
}
} }

View File

@ -4,6 +4,7 @@ import android.annotation.SuppressLint
import android.content.Intent import android.content.Intent
import android.graphics.Bitmap import android.graphics.Bitmap
import android.graphics.Color import android.graphics.Color
import android.view.View
import android.webkit.WebChromeClient import android.webkit.WebChromeClient
import android.webkit.WebResourceError import android.webkit.WebResourceError
import android.webkit.WebResourceRequest import android.webkit.WebResourceRequest
@ -13,6 +14,7 @@ import android.webkit.WebViewClient
import androidx.activity.viewModels import androidx.activity.viewModels
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
@ -21,13 +23,14 @@ import com.veloria.now.shortapp.newsletter.AIXTextActivity
import com.veloria.now.shortapp.newsletter.XNBackground import com.veloria.now.shortapp.newsletter.XNBackground
import com.veloria.now.shortapp.other.BaseEventBusBean import com.veloria.now.shortapp.other.BaseEventBusBean
import com.veloria.now.shortapp.other.FeedbackJsBridge import com.veloria.now.shortapp.other.FeedbackJsBridge
import com.veloria.now.shortapp.rewards.VSNotificationsDefault
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeFeedbackViewModel import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeFeedbackViewModel
import org.greenrobot.eventbus.EventBus import org.greenrobot.eventbus.EventBus
import org.greenrobot.eventbus.Subscribe import org.greenrobot.eventbus.Subscribe
import org.greenrobot.eventbus.ThreadMode import org.greenrobot.eventbus.ThreadMode
class VeFeedbackListActivity : class VeFeedbackListActivity :
AIXTextActivity<ActivityVeFeedbackListBinding, VeFeedbackViewModel>() { AIXTextActivity<ActivityVeFeedbackListBinding, VeFeedbackViewModel>() , NOFfmpeg {
val viewModel: VeFeedbackViewModel by viewModels() val viewModel: VeFeedbackViewModel by viewModels()
@ -67,7 +70,8 @@ class VeFeedbackListActivity :
binding.webFeedbackList.webViewClient = object : WebViewClient() { binding.webFeedbackList.webViewClient = object : WebViewClient() {
override fun onPageStarted(view: WebView?, url: String?, favicon: Bitmap?) { override fun onPageStarted(view: WebView?, url: String?, favicon: Bitmap?) {
super.onPageStarted(view, url, favicon) super.onPageStarted(view, url, favicon)
showComplete()
binding.webFeedbackList.visibility = View.VISIBLE
} }
override fun onPageFinished(view: WebView?, url: String?) { override fun onPageFinished(view: WebView?, url: String?) {
@ -82,6 +86,14 @@ class VeFeedbackListActivity :
error: WebResourceError? error: WebResourceError?
) { ) {
super.onReceivedError(view, request, error) super.onReceivedError(view, request, error)
showErrorData(object : VSNotificationsDefault.OnRetryListener {
override fun onRetry(layout: VSNotificationsDefault) {
showLoading()
loadPageUrl(JActivityAdapter.FEEDBACK_URL_LIST)
}
})
binding.webFeedbackList.visibility = View.INVISIBLE
if (TranslationHelper.getTranslation() != null){ if (TranslationHelper.getTranslation() != null){
toast(TranslationHelper.getTranslation()?.veloria_network.toString()) toast(TranslationHelper.getTranslation()?.veloria_network.toString())
}else { }else {
@ -123,4 +135,8 @@ class VeFeedbackListActivity :
EventBus.getDefault().unregister(this) EventBus.getDefault().unregister(this)
} }
override fun getStatusLayout(): VSNotificationsDefault? {
return binding.stateLayout
}
} }

View File

@ -6,6 +6,7 @@ import androidx.appcompat.app.AppCompatDelegate
import androidx.core.os.LocaleListCompat import androidx.core.os.LocaleListCompat
import androidx.lifecycle.lifecycleScope import androidx.lifecycle.lifecycleScope
import androidx.recyclerview.widget.LinearLayoutManager import androidx.recyclerview.widget.LinearLayoutManager
import com.blankj.utilcode.util.NetworkUtils
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.NOFfmpeg import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
@ -33,16 +34,28 @@ class VeLanguageActivity : AIXTextActivity<ActivityVeLanguageBinding, LanguageVi
override fun getViewBinding() = ActivityVeLanguageBinding.inflate(layoutInflater) override fun getViewBinding() = ActivityVeLanguageBinding.inflate(layoutInflater)
override fun initView() { override fun initView() {
if (TranslationHelper.getTranslation() != null){
binding.tvTitle.text = TranslationHelper.getTranslation()?.veloria_language
}
binding.ivBack.setOnClickListener {
finish()
}
if (!NetworkUtils.isConnected()) {
showErrorData(object : VSNotificationsDefault.OnRetryListener {
override fun onRetry(layout: VSNotificationsDefault) {
initView()
}
})
return
}
showComplete()
val layoutManager = val layoutManager =
LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false) LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false)
binding.recyclerView.layoutManager = layoutManager binding.recyclerView.layoutManager = layoutManager
mAdapter = LanguageAdapter() mAdapter = LanguageAdapter()
binding.recyclerView.adapter = mAdapter binding.recyclerView.adapter = mAdapter
if (TranslationHelper.getTranslation() != null){
binding.tvTitle.text = TranslationHelper.getTranslation()?.veloria_language
}
showLoading() showLoading()
viewModel.getLanguages() viewModel.getLanguages()
@ -61,6 +74,7 @@ class VeLanguageActivity : AIXTextActivity<ActivityVeLanguageBinding, LanguageVi
viewModel.getTranslates(langKey) viewModel.getTranslates(langKey)
} }
} }
} }
override fun observeData() { override fun observeData() {
@ -85,8 +99,8 @@ class VeLanguageActivity : AIXTextActivity<ActivityVeLanguageBinding, LanguageVi
viewModel.translatesDataBean.observe(this) { viewModel.translatesDataBean.observe(this) {
if (it?.data != null) { if (it?.data != null) {
RYAction.getMMKV() // RYAction.getMMKV()
.putString(JActivityAdapter.HOME_MAIN_VIDEO_INFO, "") // .putString(JActivityAdapter.HOME_MAIN_VIDEO_INFO, "")
lifecycleScope.launch { lifecycleScope.launch {
withContext(Dispatchers.IO) { withContext(Dispatchers.IO) {
TranslationHelper.saveTranslation(it.data.translates) TranslationHelper.saveTranslation(it.data.translates)

View File

@ -7,21 +7,24 @@ import android.widget.TextView
import androidx.activity.viewModels import androidx.activity.viewModels
import androidx.core.content.ContextCompat import androidx.core.content.ContextCompat
import androidx.viewpager2.widget.ViewPager2 import androidx.viewpager2.widget.ViewPager2
import com.blankj.utilcode.util.NetworkUtils
import com.google.android.material.tabs.TabLayout import com.google.android.material.tabs.TabLayout
import com.google.android.material.tabs.TabLayoutMediator import com.google.android.material.tabs.TabLayoutMediator
import com.scwang.smart.refresh.layout.api.RefreshLayout import com.scwang.smart.refresh.layout.api.RefreshLayout
import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.databinding.ActivityVeMyWalletBinding import com.veloria.now.shortapp.databinding.ActivityVeMyWalletBinding
import com.veloria.now.shortapp.newsletter.AIXTextActivity import com.veloria.now.shortapp.newsletter.AIXTextActivity
import com.veloria.now.shortapp.other.NestedScrollHelper import com.veloria.now.shortapp.other.NestedScrollHelper
import com.veloria.now.shortapp.rewards.VSNotificationsDefault
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeMyWalletViewModel import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeMyWalletViewModel
import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeMyWalletViewPagerAdapter import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeMyWalletViewPagerAdapter
class VeMyWalletActivity : AIXTextActivity<ActivityVeMyWalletBinding, VeMyWalletViewModel>(), class VeMyWalletActivity : AIXTextActivity<ActivityVeMyWalletBinding, VeMyWalletViewModel>(),
OnRefreshLoadMoreListener { OnRefreshLoadMoreListener , NOFfmpeg {
val viewModel: VeMyWalletViewModel by viewModels() val viewModel: VeMyWalletViewModel by viewModels()
@ -41,9 +44,20 @@ class VeMyWalletActivity : AIXTextActivity<ActivityVeMyWalletBinding, VeMyWallet
binding.tvRechargeText.text = TranslationHelper.getTranslation()?.veloria_recharge binding.tvRechargeText.text = TranslationHelper.getTranslation()?.veloria_recharge
binding.tvDonateText.text = TranslationHelper.getTranslation()?.veloria_bonus binding.tvDonateText.text = TranslationHelper.getTranslation()?.veloria_bonus
} }
if (!NetworkUtils.isConnected()) {
binding.scrollView.visibility = View.GONE
showErrorData(object : VSNotificationsDefault.OnRetryListener {
override fun onRetry(layout: VSNotificationsDefault) {
initView()
}
})
return
}
showComplete()
binding.scrollView.visibility = View.VISIBLE
binding.tvTotal.text = binding.tvTotal.text =
RYAction.getAllCoinTotal().toString() RYAction.getAllCoinTotal().toString()
binding.tvRecharge.text = binding.tvRecharge.text =
@ -175,5 +189,9 @@ class VeMyWalletActivity : AIXTextActivity<ActivityVeMyWalletBinding, VeMyWallet
viewModel.setLoadMoreAction(binding.viewPager.currentItem) viewModel.setLoadMoreAction(binding.viewPager.currentItem)
} }
override fun getStatusLayout(): VSNotificationsDefault? {
return binding.stateLayout
}
} }

View File

@ -1,8 +1,15 @@
package com.veloria.now.shortapp.subtractionCroll.bidirectional package com.veloria.now.shortapp.subtractionCroll.bidirectional
import android.Manifest
import android.annotation.SuppressLint import android.annotation.SuppressLint
import android.content.Intent
import android.content.pm.PackageManager
import android.graphics.Bitmap import android.graphics.Bitmap
import android.graphics.Color import android.graphics.Color
import android.net.Uri
import android.os.Build
import android.os.Bundle
import android.util.Log
import android.view.View import android.view.View
import android.view.ViewGroup import android.view.ViewGroup
import android.webkit.WebChromeClient import android.webkit.WebChromeClient
@ -11,25 +18,50 @@ import android.webkit.WebResourceRequest
import android.webkit.WebSettings import android.webkit.WebSettings
import android.webkit.WebView import android.webkit.WebView
import android.webkit.WebViewClient import android.webkit.WebViewClient
import androidx.activity.result.contract.ActivityResultContracts
import androidx.activity.viewModels import androidx.activity.viewModels
import androidx.core.content.ContextCompat
import com.blankj.utilcode.util.NetworkUtils import com.blankj.utilcode.util.NetworkUtils
import com.blankj.utilcode.util.NotificationUtils
import com.facebook.AccessToken
import com.facebook.CallbackManager
import com.facebook.CallbackManager.Factory.create
import com.facebook.FacebookCallback
import com.facebook.FacebookException
import com.facebook.GraphRequest
import com.facebook.login.LoginManager
import com.facebook.login.LoginResult
import com.google.android.gms.tasks.OnCompleteListener
import com.google.firebase.messaging.FirebaseMessaging
import com.scwang.smart.refresh.layout.api.RefreshLayout import com.scwang.smart.refresh.layout.api.RefreshLayout
import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener import com.scwang.smart.refresh.layout.listener.OnRefreshLoadMoreListener
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.JActivityAdapter import com.veloria.now.shortapp.civil.JActivityAdapter
import com.veloria.now.shortapp.civil.NOFfmpeg import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.VeNotificationHelper
import com.veloria.now.shortapp.civil.YFHome
import com.veloria.now.shortapp.civil.singleOnClick import com.veloria.now.shortapp.civil.singleOnClick
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
import com.veloria.now.shortapp.databinding.ActivityVeRewardsBinding import com.veloria.now.shortapp.databinding.ActivityVeRewardsBinding
import com.veloria.now.shortapp.newsletter.AIXTextActivity import com.veloria.now.shortapp.newsletter.AIXTextActivity
import com.veloria.now.shortapp.newsletter.XNBackground import com.veloria.now.shortapp.newsletter.XNBackground
import com.veloria.now.shortapp.other.FeedbackJsBridge import com.veloria.now.shortapp.other.FeedbackJsBridge
import com.veloria.now.shortapp.other.VeRewardJsBridge
import com.veloria.now.shortapp.rewards.VSNotificationsDefault import com.veloria.now.shortapp.rewards.VSNotificationsDefault
import com.veloria.now.shortapp.subtractionCroll.avcintraRelock.LoginDialog
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeFeedbackViewModel import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeFeedbackViewModel
import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationBean
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import org.greenrobot.eventbus.EventBus import org.greenrobot.eventbus.EventBus
import org.greenrobot.eventbus.Subscribe import org.greenrobot.eventbus.Subscribe
import org.greenrobot.eventbus.ThreadMode import org.greenrobot.eventbus.ThreadMode
import org.json.JSONObject
import java.util.concurrent.Executors
import java.util.concurrent.ScheduledExecutorService
class VeRewardsActivity : AIXTextActivity<ActivityVeRewardsBinding, VeFeedbackViewModel>(), class VeRewardsActivity : AIXTextActivity<ActivityVeRewardsBinding, VeFeedbackViewModel>(),
OnRefreshLoadMoreListener, NOFfmpeg { OnRefreshLoadMoreListener, NOFfmpeg {
@ -41,20 +73,18 @@ class VeRewardsActivity : AIXTextActivity<ActivityVeRewardsBinding, VeFeedbackVi
override fun initView() { override fun initView() {
EventBus.getDefault().register(this) EventBus.getDefault().register(this)
if (TranslationHelper.getTranslation() != null){
binding.tvTitle.text = TranslationHelper.getTranslation()?.veloria_rewards
}
binding.ivBack.setOnClickListener { finish() } binding.ivBack.setOnClickListener { finish() }
binding.refresh.setOnRefreshLoadMoreListener(this) binding.refresh.setOnRefreshLoadMoreListener(this)
binding.refresh.setEnableLoadMore(false) binding.refresh.setEnableLoadMore(false)
binding.webRewards.setBackgroundColor(Color.TRANSPARENT) binding.webRewards.setBackgroundColor(Color.TRANSPARENT)
// ivLeft?.setOnClickListener {
// singleClick {
// DialogUtils.showStoreHint(requireContext())
// }
// }
setWebView() setWebView()
loadingData() loadingData()
initLogin()
} }
fun loadingData() { fun loadingData() {
@ -82,6 +112,31 @@ class VeRewardsActivity : AIXTextActivity<ActivityVeRewardsBinding, VeFeedbackVi
override fun observeData() { override fun observeData() {
viewModel.loginLiveData.observe(this) {
if (it?.data != null) {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_succeed.toString())
}else {
toast("Succeed")
}
RYAction.getMMKV()
.putString(JActivityAdapter.ACCOUNT_TOKEN, it.data.token)
EventBus.getDefault()
.post(JActivityAdapter.HOME_ENTER_THE_APP)
EventBus.getDefault()
.post(JActivityAdapter.HOME_ON_LINE)
EventBus.getDefault()
.post(JActivityAdapter.HOME_USER_REFRESH)
loadingData()
}
}
viewModel.openNotifyLiveData.observe(this){
if (it?.data != null) {
}
}
} }
@ -132,14 +187,22 @@ class VeRewardsActivity : AIXTextActivity<ActivityVeRewardsBinding, VeFeedbackVi
webSettings.builtInZoomControls = true webSettings.builtInZoomControls = true
webSettings.displayZoomControls = false webSettings.displayZoomControls = false
binding.webRewards.addJavascriptInterface( binding.webRewards.addJavascriptInterface(
FeedbackJsBridge(this), VeRewardJsBridge(this),
"AndroidInterface" "AndroidInterface"
) )
} }
@Subscribe(threadMode = ThreadMode.MAIN) @Subscribe(threadMode = ThreadMode.MAIN)
fun onEvent(event: String) { fun onEvent(event: String) {
if (JActivityAdapter.HOME_LOGIN == event) {
finish()
}
if (JActivityAdapter.ACCOUNT_WEB_NOTIFICATION == event) {
askNotificationPermission()
}
if (JActivityAdapter.REWARD_LOGIN == event) {
setLogin()
}
} }
override fun onDestroy() { override fun onDestroy() {
@ -161,4 +224,177 @@ class VeRewardsActivity : AIXTextActivity<ActivityVeRewardsBinding, VeFeedbackVi
return binding.stateLayout return binding.stateLayout
} }
private fun askNotificationPermission() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
if (ContextCompat.checkSelfPermission(
this, Manifest.permission.POST_NOTIFICATIONS
) == PackageManager.PERMISSION_GRANTED
) {
getFirebaseMessaging()
viewModel.setOpenNotify()
loadingData()
} else {
requestPermissionLauncher.launch(Manifest.permission.POST_NOTIFICATIONS)
}
} else {
if (VeNotificationHelper.isNotification(this)) {
getFirebaseMessaging()
viewModel.setOpenNotify()
loadingData()
} else {
VeNotificationHelper.setNotification(this)
}
}
}
override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {
super.onActivityResult(requestCode, resultCode, data)
if (requestCode == VeNotificationHelper.VE_NOTIFICATION_REQUEST_CODE) {
JActivityAdapter.IS_HOME_SET_NOTIFICATIONS = VeNotificationHelper.isNotification(this)
if (JActivityAdapter.IS_HOME_SET_NOTIFICATIONS) {
getFirebaseMessaging()
viewModel.setOpenNotify()
}
loadingData()
}else {
callbackManager?.onActivityResult(requestCode, resultCode, data)
}
}
private val requestPermissionLauncher = registerForActivityResult(
ActivityResultContracts.RequestPermission(),
) { isGranted: Boolean ->
JActivityAdapter.IS_HOME_SET_NOTIFICATIONS = isGranted
if (isGranted) {
getFirebaseMessaging()
viewModel.setOpenNotify()
loadingData()
} else {
openAppNotificationSettings()
}
}
private fun openAppNotificationSettings() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.TIRAMISU) {
val intent = Intent()
intent.action = "android.settings.APP_NOTIFICATION_SETTINGS"
intent.putExtra(
"android.provider.extra.APP_PACKAGE",
YFHome.getPackageName()
)
startActivity(intent)
} else {
val intent = Intent()
intent.action = "android.settings.APPLICATION_DETAILS_SETTINGS"
intent.data =
Uri.fromParts("package", YFHome.getPackageName(), null)
startActivity(intent)
}
}
private fun getFirebaseMessaging() {
FirebaseMessaging.getInstance().token.addOnCompleteListener(OnCompleteListener { task ->
if (!task.isSuccessful) {
return@OnCompleteListener
}
// Get new FCM registration token
val token = task.result
// Log and toast
Log.d("LOG_TAG", token)
viewModel.setFirebaseToken(token)
})
}
private var callbackManager: CallbackManager? = null
fun setLogin() {
val dialog = LoginDialog(this).apply {
setOnLoginOnclickListener(object : LoginDialog.LoginOnClick {
override fun onLoginFacebook() {
onFacebook()
}
})
}
dialog.show()
dialog.loginOnclick
}
private fun onFacebook() {
singleOnClick {
LoginManager.getInstance()
.logInWithReadPermissions(this, arrayListOf("public_profile", "email"))
}
}
fun initLogin(){
callbackManager = create()
LoginManager.getInstance().registerCallback(callbackManager,
object : FacebookCallback<LoginResult> {
override fun onSuccess(loginResult: LoginResult) {
val enableButtons = AccessToken.getCurrentAccessToken() != null
if (enableButtons) {
val mGraphRequest = GraphRequest.newMeRequest(
loginResult.accessToken
) { jsonObject, response ->
if (response!!.error != null) {
if (TranslationHelper.getTranslation() != null) {
toast(
"Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_exception)
.plus(".${response.error?.exception.toString()}")
)
} else {
toast("Facebook Error")
}
} else {
val id = jsonObject?.optString("id")
val name = jsonObject?.optString("name")
val object_pic: JSONObject? = jsonObject!!.optJSONObject("picture")
val object_data = object_pic?.optJSONObject("data")
val photo = object_data?.optString("url")
viewModel.setLeaveApp()
viewModel.setDoLogin(
LoginDataBean(
photo.toString(),
"",
name.toString(),
"",
"facebook",
id.toString()
)
)
}
}
val parameters = Bundle()
parameters.putString("fields", "id,name,email,picture")
mGraphRequest.parameters = parameters
mGraphRequest.executeAsync()
}
}
override fun onCancel() {
if (TranslationHelper.getTranslation() != null) {
toast("Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_cancel))
} else {
toast("Facebook Cancel")
}
}
override fun onError(exception: FacebookException) {
if (TranslationHelper.getTranslation() != null) {
toast(
"Facebook ".plus(TranslationHelper.getTranslation()?.veloria_login_exception)
.plus("n.$exception")
)
} else {
toast("Facebook Error")
}
}
})
}
} }

View File

@ -21,7 +21,9 @@ import com.android.billingclient.api.ProductDetailsResponseListener
import com.android.billingclient.api.Purchase import com.android.billingclient.api.Purchase
import com.android.billingclient.api.PurchasesUpdatedListener import com.android.billingclient.api.PurchasesUpdatedListener
import com.android.billingclient.api.QueryProductDetailsParams import com.android.billingclient.api.QueryProductDetailsParams
import com.blankj.utilcode.util.NetworkUtils
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.NOFfmpeg
import com.veloria.now.shortapp.civil.RYAction import com.veloria.now.shortapp.civil.RYAction
import com.veloria.now.shortapp.civil.TranslationHelper import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.YFHome import com.veloria.now.shortapp.civil.YFHome
@ -29,6 +31,7 @@ import com.veloria.now.shortapp.civil.singleOnClick
import com.veloria.now.shortapp.civil.toast import com.veloria.now.shortapp.civil.toast
import com.veloria.now.shortapp.databinding.ActivityVeStoreBinding import com.veloria.now.shortapp.databinding.ActivityVeStoreBinding
import com.veloria.now.shortapp.newsletter.AIXTextActivity import com.veloria.now.shortapp.newsletter.AIXTextActivity
import com.veloria.now.shortapp.rewards.VSNotificationsDefault
import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeStoreViewModel import com.veloria.now.shortapp.subtractionCroll.bidirectional.coordinate.VeStoreViewModel
import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeStoreCoinAdapter import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeStoreCoinAdapter
import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeStoreCoinBigAdapter import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeStoreCoinBigAdapter
@ -36,9 +39,14 @@ import com.veloria.now.shortapp.subtractionCroll.modificationsPretch.VeStoreVipA
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean
import com.veloria.now.shortapp.texturedAsink.VePayBean import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
import kotlinx.coroutines.CoroutineScope
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.flow.debounce
import kotlinx.coroutines.flow.flow
import kotlinx.coroutines.flow.onEach
import kotlinx.coroutines.launch import kotlinx.coroutines.launch
class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel>() { class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel>() , NOFfmpeg {
val viewModel: VeStoreViewModel by viewModels() val viewModel: VeStoreViewModel by viewModels()
@ -52,8 +60,6 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
private var vipData: VePaySettingsBean.VipBean? = null private var vipData: VePaySettingsBean.VipBean? = null
private var coinsData: VePaySettingsBean.CoinsBean? = null private var coinsData: VePaySettingsBean.CoinsBean? = null
private var coinsBigData: VePaySettingsBean.CoinsBean? = null private var coinsBigData: VePaySettingsBean.CoinsBean? = null
// private var bannerAdapter: VeBannerVipPayAdapter? = null
private var payBeanReq: VePayBean? = null private var payBeanReq: VePayBean? = null
private var billingClientData: BillingClient? = null private var billingClientData: BillingClient? = null
@ -62,10 +68,14 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
private var isBuy = false private var isBuy = false
private var purchaseData: Purchase? = null private var purchaseData: Purchase? = null
private val scope = CoroutineScope(Dispatchers.Main)
override fun initView() { override fun initView() {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
binding.tvTitle.text = TranslationHelper.getTranslation()?.veloria_store
binding.tvCoinTitle.text = TranslationHelper.getTranslation()?.veloria_coin_buy_title
binding.tvRestore.text = TranslationHelper.getTranslation()?.veloria_restore
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
binding.tvTips.text = Html.fromHtml( binding.tvTips.text = Html.fromHtml(
TranslationHelper.getTranslation()?.veloria_store_tips TranslationHelper.getTranslation()?.veloria_store_tips
@ -79,13 +89,23 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
) )
} }
} }
showLoading()
binding.ivBack.setOnClickListener { binding.ivBack.setOnClickListener {
finish() finish()
} }
if (!NetworkUtils.isConnected()) {
binding.scrollView.visibility = View.GONE
showErrorData(object : VSNotificationsDefault.OnRetryListener {
override fun onRetry(layout: VSNotificationsDefault) {
initView()
}
})
return
}
showComplete()
binding.scrollView.visibility = View.VISIBLE
showLoading()
vipAdapter = VeStoreVipAdapter() vipAdapter = VeStoreVipAdapter()
binding.recyclerVip.layoutManager = LinearLayoutManager(this) binding.recyclerVip.layoutManager = LinearLayoutManager(this)
@ -122,7 +142,6 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
} }
}) })
viewModel.getPaySettingsV3(0, 0) viewModel.getPaySettingsV3(0, 0)
vipAdapter?.setOnItemClickListener { adapter, view, position -> vipAdapter?.setOnItemClickListener { adapter, view, position ->
@ -164,15 +183,42 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
setOnPayNowClick() setOnPayNowClick()
} }
binding.tvRestore.setOnClickListener{
singleOnClick {
if (RYAction.getOrder().isNotEmpty()
) {
showLoading()
val string = RYAction.getOrder()
scope.launch {
flow {
for (item in string) {
emit(item)
}
}
.onEach { item ->
viewModel.setRestorePaid(item)
}
.debounce(500)
.collect {}
}
} else {
if (TranslationHelper.getTranslation() != null){
TranslationHelper.getTranslation()?.veloria_no_restore?.let { it1 -> toast(it1) }
}else {
toast("No orders to restore")
}
}
}
}
initPayData() initPayData()
} }
fun setOnPayNowClick() { fun setOnPayNowClick() {
singleOnClick { singleOnClick {
if (!isConnect) { if (!isConnect) {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_error)) toast(getString(R.string.ve_google_pay_error))
} }
@ -208,6 +254,7 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
} }
} }
override fun observeData() { override fun observeData() {
viewModel.PaySettingsV3.observe(this) { viewModel.PaySettingsV3.observe(this) {
if (it?.data != null) { if (it?.data != null) {
@ -248,7 +295,6 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
binding.tvCoinTitle.visibility = View.GONE binding.tvCoinTitle.visibility = View.GONE
} }
} }
hideLoading() hideLoading()
} }
viewModel.createPayOrderData.observe(this) { viewModel.createPayOrderData.observe(this) {
@ -263,6 +309,7 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
} }
} else { } else {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else { } else {
toast(getString(R.string.shapeSelected)) toast(getString(R.string.shapeSelected))
} }
@ -273,6 +320,7 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
viewModel.googlePaidData.observe(this) { viewModel.googlePaidData.observe(this) {
if (it?.data != null) { if (it?.data != null) {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_success.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_success)) toast(getString(R.string.ve_google_pay_success))
} }
@ -281,12 +329,12 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
} else { } else {
payBeanReq?.let { it1 -> RYAction.saveOrder(it1) } payBeanReq?.let { it1 -> RYAction.saveOrder(it1) }
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else { } else {
toast(getString(R.string.shapeSelected)) toast(getString(R.string.shapeSelected))
} }
hideLoading() hideLoading()
} }
} }
viewModel.userInfo.observe(this) { viewModel.userInfo.observe(this) {
if (it?.data != null) { if (it?.data != null) {
@ -294,7 +342,30 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
} }
hideLoading() hideLoading()
} }
viewModel.restorePaidData.observe(this){
if (it != null) {
it.data?.order_code?.let { it1 -> RYAction.removeOrderString(it1) }
if (RYAction.getOrder().size == 0) {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_success.toString())
} else {
toast(getString(R.string.ve_google_pay_success))
} }
viewModel.getUserInfo()
isBuy = true
}
}else {
if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_network.toString())
} else {
toast(getString(R.string.shapeSelected))
}
hideLoading()
}
}
}
private fun initPayData() { private fun initPayData() {
val purchasesUpdatedListener = val purchasesUpdatedListener =
@ -312,8 +383,14 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
} }
} }
BillingClient.BillingResponseCode.ITEM_ALREADY_OWNED -> {
queryAndConsumePurchases()
hideLoading()
}
BillingClient.BillingResponseCode.USER_CANCELED -> { BillingClient.BillingResponseCode.USER_CANCELED -> {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_canceled.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_canceled)) toast(getString(R.string.ve_google_pay_canceled))
} }
@ -322,6 +399,7 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
else -> { else -> {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_error)) toast(getString(R.string.ve_google_pay_error))
} }
@ -578,7 +656,7 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
billingClientData?.consumeAsync(consumeParams, responseListener) billingClientData?.consumeAsync(consumeParams, responseListener)
} else { } else {
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
// toast(TranslationHelper.getTranslation()?.mireo_g_pay_error.toString()) toast(TranslationHelper.getTranslation()?.veloria_google_pay_error.toString())
} else { } else {
toast(getString(R.string.ve_google_pay_error)) toast(getString(R.string.ve_google_pay_error))
} }
@ -611,6 +689,18 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
} }
} }
private fun queryAndConsumePurchases() {
// 查询所有未消费的购买记录
billingClientData?.queryPurchasesAsync(BillingClient.ProductType.INAPP) { billingResult, purchaseList ->
if (billingResult.responseCode == BillingClient.BillingResponseCode.OK) {
for (purchase in purchaseList) {
consumePurchase(purchase)
}
}
}
}
override fun onDestroy() { override fun onDestroy() {
super.onDestroy() super.onDestroy()
payBeanReq = null payBeanReq = null
@ -619,4 +709,8 @@ class VeStoreActivity : AIXTextActivity<ActivityVeStoreBinding, VeStoreViewModel
System.gc() System.gc()
} }
override fun getStatusLayout(): VSNotificationsDefault? {
return binding.stateLayout
}
} }

View File

@ -8,7 +8,12 @@ import com.veloria.now.shortapp.newsletter.TStore
import com.veloria.now.shortapp.texturedAsink.DoLoginBean import com.veloria.now.shortapp.texturedAsink.DoLoginBean
import com.veloria.now.shortapp.texturedAsink.LoginDataBean import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.SManifestBean import com.veloria.now.shortapp.texturedAsink.SManifestBean
import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePayResBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationDataBean
import com.veloria.now.shortapp.texturedAsink.VeW2aSelfAttributionBean import com.veloria.now.shortapp.texturedAsink.VeW2aSelfAttributionBean
import com.veloria.now.shortapp.texturedAsink.VersionControlBean
class JService : SStringsHelp() { class JService : SStringsHelp() {
@ -83,7 +88,7 @@ class JService : SStringsHelp() {
private val _onLineLiveData = MutableLiveData<TStore<Any>?>() private val _onLineLiveData = MutableLiveData<TStore<Any>?>()
val onLineLiveData: MutableLiveData<TStore<Any>?> get() = _onLineLiveData val onLineLiveData: MutableLiveData<TStore<Any>?> get() = _onLineLiveData
fun setOnLine() { fun setOnLine() {
repository.setOnLine().observeForever {result -> repository.setOnLine().observeForever { result ->
_onLineLiveData.value = result.getOrNull() _onLineLiveData.value = result.getOrNull()
} }
} }
@ -105,4 +110,51 @@ class JService : SStringsHelp() {
} }
} }
private val _notificationLiveData = MutableLiveData<TStore<VeUploadNotificationDataBean>?>()
val notificationLiveData: MutableLiveData<TStore<VeUploadNotificationDataBean>?> get() = _notificationLiveData
fun setUploadNoticeStatus(veUploadNotificationBean: VeUploadNotificationBean) {
repository.setUploadNoticeStatus(veUploadNotificationBean)
.observeForever { result ->
_notificationLiveData.value = result.getOrNull()
}
}
private val firebaseTokenLiveData = MutableLiveData<TStore<Any>?>()
fun setFirebaseToken(
fcm_token: String
) {
repository.setFirebaseToken(fcm_token).observeForever { result ->
firebaseTokenLiveData.value = result.getOrNull()
}
}
private val _openNotifyLiveData = MutableLiveData<TStore<Any>?>()
val openNotifyLiveData: MutableLiveData<TStore<Any>?> get() = _openNotifyLiveData
fun setOpenNotify() {
repository.setOpenNotify().observeForever { result ->
_openNotifyLiveData.value = result.getOrNull()
}
}
fun setSendReport(message_id: String, title: String) {
repository.setSendReport(message_id, title).observeForever {}
}
private val restorePaidLiveData = MutableLiveData<TStore<VePayResBean>?>()
val restorePaidData: MutableLiveData<TStore<VePayResBean>?> get() = restorePaidLiveData
fun setGooglePaid(vePayBean: VePayBean?) {
repository.setGooglePaid(vePayBean).observeForever { result ->
restorePaidLiveData.value = result.getOrNull()
}
}
private val _versionControlLiveData = MutableLiveData<TStore<VersionControlBean>?>()
val versionControlData: MutableLiveData<TStore<VersionControlBean>?> get() = _versionControlLiveData
fun getVersionControl() {
repository.getVersionControl().observeForever { result ->
_versionControlLiveData.value = result.getOrNull()
}
}
} }

View File

@ -6,9 +6,12 @@ import com.veloria.now.shortapp.newsletter.SStringsHelp
import com.veloria.now.shortapp.texturedAsink.PURLockBean import com.veloria.now.shortapp.texturedAsink.PURLockBean
import com.veloria.now.shortapp.texturedAsink.XAboutBean import com.veloria.now.shortapp.texturedAsink.XAboutBean
import com.veloria.now.shortapp.highbits.qscaleqlog.PDeteleResource import com.veloria.now.shortapp.highbits.qscaleqlog.PDeteleResource
import com.veloria.now.shortapp.texturedAsink.DoLoginBean
import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean
import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.VeBuyVideoBean import com.veloria.now.shortapp.texturedAsink.VeBuyVideoBean
import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean
import com.veloria.now.shortapp.texturedAsink.VeRevolutionsBean
import kotlin.math.min import kotlin.math.min
import kotlin.math.max import kotlin.math.max
@ -99,4 +102,25 @@ private var moreSecond_sum: Int = 6970
_userInfo.value = result.getOrNull() _userInfo.value = result.getOrNull()
} }
private val qualityLiveData = MutableLiveData<TStore<VeRevolutionsBean>?>()
val qualityData: MutableLiveData<TStore<VeRevolutionsBean>?> get() = qualityLiveData
fun getQualityData() {
repository.getQualityData()
.observeForever { result ->
qualityLiveData.value = result.getOrNull()
}
}
fun setLeaveApp() {
repository.setLeaveApp().observeForever {}
}
private val _loginLiveData = MutableLiveData<TStore<DoLoginBean>?>()
val loginLiveData: MutableLiveData<TStore<DoLoginBean>?> get() = _loginLiveData
fun setDoLogin(loginDataBean: LoginDataBean) {
repository.setDoLogin(loginDataBean).observeForever { result ->
_loginLiveData.value = result.getOrNull()
}
}
} }

View File

@ -4,7 +4,11 @@ import androidx.lifecycle.MutableLiveData
import com.veloria.now.shortapp.highbits.qscaleqlog.ANotifications import com.veloria.now.shortapp.highbits.qscaleqlog.ANotifications
import com.veloria.now.shortapp.newsletter.SStringsHelp import com.veloria.now.shortapp.newsletter.SStringsHelp
import com.veloria.now.shortapp.newsletter.TStore import com.veloria.now.shortapp.newsletter.TStore
import com.veloria.now.shortapp.texturedAsink.DoLoginBean
import com.veloria.now.shortapp.texturedAsink.LoginDataBean
import com.veloria.now.shortapp.texturedAsink.VeNoticeNumBean import com.veloria.now.shortapp.texturedAsink.VeNoticeNumBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationBean
import com.veloria.now.shortapp.texturedAsink.VeUploadNotificationDataBean
class VeFeedbackViewModel : SStringsHelp() { class VeFeedbackViewModel : SStringsHelp() {
@ -19,4 +23,42 @@ class VeFeedbackViewModel : SStringsHelp() {
_noticeNumLiveData.value = result.getOrNull() _noticeNumLiveData.value = result.getOrNull()
} }
} }
private val _notificationLiveData = MutableLiveData<TStore<VeUploadNotificationDataBean>?>()
val notificationLiveData: MutableLiveData<TStore<VeUploadNotificationDataBean>?> get() = _notificationLiveData
fun setUploadNoticeStatus(veUploadNotificationBean: VeUploadNotificationBean) {
repository.setUploadNoticeStatus(veUploadNotificationBean)
.observeForever { result ->
_notificationLiveData.value = result.getOrNull()
}
}
private val firebaseTokenLiveData = MutableLiveData<TStore<Any>?>()
fun setFirebaseToken(
fcm_token: String
) {
repository.setFirebaseToken(fcm_token).observeForever { result ->
firebaseTokenLiveData.value = result.getOrNull()
}
}
private val _openNotifyLiveData = MutableLiveData<TStore<Any>?>()
val openNotifyLiveData: MutableLiveData<TStore<Any>?> get() = _openNotifyLiveData
fun setOpenNotify() {
repository.setOpenNotify().observeForever { result ->
_openNotifyLiveData.value = result.getOrNull()
}
}
fun setLeaveApp() {
repository.setLeaveApp().observeForever {}
}
private val _loginLiveData = MutableLiveData<TStore<DoLoginBean>?>()
val loginLiveData: MutableLiveData<TStore<DoLoginBean>?> get() = _loginLiveData
fun setDoLogin(loginDataBean: LoginDataBean) {
repository.setDoLogin(loginDataBean).observeForever { result ->
_loginLiveData.value = result.getOrNull()
}
}
} }

View File

@ -8,6 +8,7 @@ import com.veloria.now.shortapp.texturedAsink.KFAFavoritesInterceptorBean
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderBean import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderBean
import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean import com.veloria.now.shortapp.texturedAsink.VeCreatePayOrderReqBean
import com.veloria.now.shortapp.texturedAsink.VePayBean import com.veloria.now.shortapp.texturedAsink.VePayBean
import com.veloria.now.shortapp.texturedAsink.VePayResBean
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
@ -48,8 +49,8 @@ class VeStoreViewModel : SStringsHelp() {
} }
} }
private val googlePaidLiveData = MutableLiveData<TStore<VePayBean>?>() private val googlePaidLiveData = MutableLiveData<TStore<VePayResBean>?>()
val googlePaidData: MutableLiveData<TStore<VePayBean>?> get() = googlePaidLiveData val googlePaidData: MutableLiveData<TStore<VePayResBean>?> get() = googlePaidLiveData
fun setGooglePaid(vePayBean: VePayBean?) { fun setGooglePaid(vePayBean: VePayBean?) {
repository.setGooglePaid(vePayBean).observeForever { result -> repository.setGooglePaid(vePayBean).observeForever { result ->
googlePaidLiveData.value = result.getOrNull() googlePaidLiveData.value = result.getOrNull()
@ -62,4 +63,13 @@ class VeStoreViewModel : SStringsHelp() {
repository.getUserInfo().observeForever { result -> repository.getUserInfo().observeForever { result ->
_userInfo.value = result.getOrNull() _userInfo.value = result.getOrNull()
} }
private val restorePaidLiveData = MutableLiveData<TStore<VePayResBean>?>()
val restorePaidData: MutableLiveData<TStore<VePayResBean>?> get() = restorePaidLiveData
fun setRestorePaid(vePayBean: VePayBean?) {
repository.setGooglePaid(vePayBean).observeForever { result ->
restorePaidLiveData.value = result.getOrNull()
}
}
} }

View File

@ -7,21 +7,20 @@ import androidx.recyclerview.widget.RecyclerView
import com.bumptech.glide.Glide import com.bumptech.glide.Glide
import com.chad.library.adapter4.BaseQuickAdapter import com.chad.library.adapter4.BaseQuickAdapter
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.civil.getTimeAgoDetailed
import com.veloria.now.shortapp.databinding.IDisplayTrendsBinding
import com.veloria.now.shortapp.newsletter.XNBackground import com.veloria.now.shortapp.newsletter.XNBackground
import com.veloria.now.shortapp.texturedAsink.TMainExtractionBean import com.veloria.now.shortapp.texturedAsink.TMainExtractionBean
import com.veloria.now.shortapp.databinding.IDisplayTrendsBinding
import com.veloria.now.shortapp.civil.getTimeAgoDetailed
import kotlin.math.min
import kotlin.math.max
class GFFavorites : class GFFavorites :
BaseQuickAdapter<TMainExtractionBean.DataListBean, GFFavorites.VH>() { BaseQuickAdapter<TMainExtractionBean.DataListBean, GFFavorites.VH>() {
@Volatile @Volatile
var default_0mTabBingeSum: Long = 3471L var default_0mTabBingeSum: Long = 3471L
@Volatile
var freeRetrofitMark: Int = 5934
@Volatile
var freeRetrofitMark: Int = 5934
var collectionOnClick: CollectionOnClick? = null var collectionOnClick: CollectionOnClick? = null
@ -39,38 +38,43 @@ class GFFavorites :
) : RecyclerView.ViewHolder(binding.root) ) : RecyclerView.ViewHolder(binding.root)
private fun playDramaAppendModeForeverTest(lifecycleHttp: MutableList<Long>, secondsStarted: MutableMap<String,Double>) :MutableMap<String,Float> { private fun playDramaAppendModeForeverTest(
var durationFailure:MutableList<Boolean> = mutableListOf<Boolean>() lifecycleHttp: MutableList<Long>,
var setupMin__6:MutableList<Long> = mutableListOf<Long>() secondsStarted: MutableMap<String, Double>
var toastCurrent:MutableMap<String,Boolean> = mutableMapOf<String,Boolean>() ): MutableMap<String, Float> {
var durationFailure: MutableList<Boolean> = mutableListOf<Boolean>()
var setupMin__6: MutableList<Long> = mutableListOf<Long>()
var toastCurrent: MutableMap<String, Boolean> = mutableMapOf<String, Boolean>()
println(toastCurrent) println(toastCurrent)
var correspondentsTableinit:MutableMap<String,Float> = mutableMapOf<String,Float>() var correspondentsTableinit: MutableMap<String, Float> = mutableMapOf<String, Float>()
for(clips in toastCurrent) { for (clips in toastCurrent) {
correspondentsTableinit.put("multiframe", 0.0f) correspondentsTableinit.put("multiframe", 0.0f)
} }
return correspondentsTableinit return correspondentsTableinit
} }
override fun onCreateViewHolder(context: Context, parent: ViewGroup, viewType: Int): VH { override fun onCreateViewHolder(context: Context, parent: ViewGroup, viewType: Int): VH {
var scheduling_r = mutableListOf<Long>() var scheduling_r = mutableListOf<Long>()
var elisionUnhighlight = this.playDramaAppendModeForeverTest(scheduling_r,mutableMapOf<String,Double>()) var elisionUnhighlight =
this.playDramaAppendModeForeverTest(scheduling_r, mutableMapOf<String, Double>())
var elisionUnhighlight_len:Int = elisionUnhighlight.size var elisionUnhighlight_len: Int = elisionUnhighlight.size
for(object_i in elisionUnhighlight) { for (object_i in elisionUnhighlight) {
println(object_i.key) println(object_i.key)
println(object_i.value) println(object_i.value)
} }
println(elisionUnhighlight) println(elisionUnhighlight)
var dashboardI:String = "rscc" var dashboardI: String = "rscc"
if (dashboardI.length > 171) {} if (dashboardI.length > 171) {
}
println(dashboardI) println(dashboardI)
@ -78,50 +82,51 @@ println(elisionUnhighlight)
} }
private fun liveOutputCallAnyEpisodeApplication(chooseSeries: Long) :Long { private fun liveOutputCallAnyEpisodeApplication(chooseSeries: Long): Long {
var responseSeekbar = mutableListOf<Float>() var responseSeekbar = mutableListOf<Float>()
println(responseSeekbar) println(responseSeekbar)
var eventFree:Double = 1094.0 var eventFree: Double = 1094.0
var seekbarHttp:String = "kanna" var seekbarHttp: String = "kanna"
println(seekbarHttp) println(seekbarHttp)
var iconSkewed:Int = 9958 var iconSkewed: Int = 9958
println(iconSkewed) println(iconSkewed)
var armthFreadSqrt:Long = 5210L var armthFreadSqrt: Long = 5210L
eventFree = eventFree eventFree = eventFree
iconSkewed -= iconSkewed iconSkewed -= iconSkewed
return armthFreadSqrt return armthFreadSqrt
} }
override fun onBindViewHolder( override fun onBindViewHolder(
holder: VH, holder: VH,
position: Int, position: Int,
item: TMainExtractionBean.DataListBean? item: TMainExtractionBean.DataListBean?
) { ) {
var splittingSigning:Long = this.liveOutputCallAnyEpisodeApplication(1455L) var splittingSigning: Long = this.liveOutputCallAnyEpisodeApplication(1455L)
var interpolator_splittingSigning: Int = splittingSigning.toInt() var interpolator_splittingSigning: Int = splittingSigning.toInt()
if (splittingSigning >= 2L) { if (splittingSigning >= 2L) {
println(splittingSigning) println(splittingSigning)
} }
println(splittingSigning) println(splittingSigning)
var loading6:Int = 1947 var loading6: Int = 1947
if (loading6 > 87) {} if (loading6 > 87) {
}
this.default_0mTabBingeSum = 9956L this.default_0mTabBingeSum = 9956L
this.freeRetrofitMark = 4850 this.freeRetrofitMark = 4850
if (null != item) { if (null != item) {
var transparent1:Boolean = true var transparent1: Boolean = true
Glide.with(XNBackground.instance) Glide.with(XNBackground.instance)
@ -129,53 +134,74 @@ this.default_0mTabBingeSum = 9956L
.placeholder(R.mipmap.collection_trending_recommend) .placeholder(R.mipmap.collection_trending_recommend)
.error(R.mipmap.collection_trending_recommend) .error(R.mipmap.collection_trending_recommend)
.into(holder.binding.ivImage2) .into(holder.binding.ivImage2)
var factoryu:Int = 4239 var factoryu: Int = 4239
if (factoryu > 62) {} if (factoryu > 62) {
}
holder.binding.tvName2.text = item.name holder.binding.tvName2.text = item.name
var progressJ:Long = 3354L var progressJ: Long = 3354L
while (progressJ >= 27L) { break } while (progressJ >= 27L) {
break
}
if (TranslationHelper.getTranslation() != null) {
holder.binding.tvSeries.text = TranslationHelper.replace(
TranslationHelper.getTranslation()?.mireo_EP.toString(),
item.current_episode
)
holder.binding.tvSeriesAll.text = "/".plus(
TranslationHelper.replace(
TranslationHelper.getTranslation()?.veloria_all_episodes.toString(),
item.episode_total.toString()
)
)
} else {
holder.binding.tvSeries.text = holder.binding.tvSeries.text =
"EP.".plus(item.current_episode) "EP.".plus(item.current_episode)
var uploadp:Int = 6616
while (uploadp >= 157) { break }
holder.binding.tvSeriesAll.text = "/EP.".plus(item.episode_total) holder.binding.tvSeriesAll.text = "/EP.".plus(item.episode_total)
var indexJ:Long = 6061L }
if (indexJ > 169L) {} var uploadp: Int = 6616
while (uploadp >= 157) {
break
}
var indexJ: Long = 6061L
if (indexJ > 169L) {
}
if (item.is_collect == 1) { if (item.is_collect == 1) {
var login_:Float = 4781.0f var login_: Float = 4781.0f
while (login_ >= 30.0f) { break } while (login_ >= 30.0f) {
break
}
holder.binding.ivCollection.setImageResource(R.mipmap.detele_rewards_episode) holder.binding.ivCollection.setImageResource(R.mipmap.detele_rewards_episode)
} else { } else {
var tabA:Float = 2603.0f var tabA: Float = 2603.0f
if (tabA <= 39.0f) {} if (tabA <= 39.0f) {
}
holder.binding.ivCollection.setImageResource(R.mipmap.episode_utils) holder.binding.ivCollection.setImageResource(R.mipmap.episode_utils)
} }
if (!item.updated_at.isNullOrEmpty()) { if (!item.updated_at.isNullOrEmpty()) {
var outV:Float = 6386.0f var outV: Float = 6386.0f
if (outV == 10.0f) {} if (outV == 10.0f) {
}
holder.binding.tvTime.text = getTimeAgoDetailed(item.updated_at) holder.binding.tvTime.text = item.updated_at
} }
holder.binding.ivCollection.setOnClickListener { holder.binding.ivCollection.setOnClickListener {
var processa:Boolean = false var processa: Boolean = false
println(processa) println(processa)

View File

@ -1,62 +1,53 @@
package com.veloria.now.shortapp.subtractionCroll.modificationsPretch package com.veloria.now.shortapp.subtractionCroll.modificationsPretch
import android.view.LayoutInflater
import android.view.View import android.view.View
import android.view.ViewGroup
import androidx.appcompat.widget.AppCompatImageView import androidx.appcompat.widget.AppCompatImageView
import androidx.appcompat.widget.AppCompatTextView import androidx.appcompat.widget.AppCompatTextView
import androidx.cardview.widget.CardView
import androidx.recyclerview.widget.RecyclerView
import com.bumptech.glide.Glide import com.bumptech.glide.Glide
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.newsletter.XNBackground
import com.veloria.now.shortapp.rewards.BannerPlayerView
import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean import com.veloria.now.shortapp.texturedAsink.VeDetailsRecommendBean
import com.youth.banner.adapter.BannerAdapter import com.zhpan.bannerview.BaseBannerAdapter
import com.zhpan.bannerview.BaseViewHolder
class VeBannerRecommendAdapter(items: List<VeDetailsRecommendBean.ItemDaraBean?>?) : class VeBannerRecommendAdapter :
BannerAdapter<VeDetailsRecommendBean.ItemDaraBean, VeBannerRecommendAdapter.BannerViewHolder>( BaseBannerAdapter<VeDetailsRecommendBean.ItemDaraBean>() {
items
) {
var currentPlayingPosition = 0 var currentPlayingPosition = 0
override fun onCreateHolder(parent: ViewGroup, viewType: Int): BannerViewHolder { private var currentBannerPlayerView: BannerPlayerView? = null
val view: View = LayoutInflater.from(parent.context)
.inflate(R.layout.item_ve_banner_recommend, parent, false) fun getCurrentPlayerView(): BannerPlayerView? {
view.layoutParams = ViewGroup.LayoutParams( return currentBannerPlayerView
ViewGroup.LayoutParams.MATCH_PARENT,
ViewGroup.LayoutParams.MATCH_PARENT
)
return BannerViewHolder(view)
} }
override fun onBindView( override fun bindData(
holder: BannerViewHolder?, holder: BaseViewHolder<VeDetailsRecommendBean.ItemDaraBean>?,
data: VeDetailsRecommendBean.ItemDaraBean?, data: VeDetailsRecommendBean.ItemDaraBean?,
position: Int, position: Int,
size: Int pageSize: Int
) { ) {
val imageView = val imageView =
holder?.view?.findViewById<AppCompatImageView>(R.id.ic_icon_banner) holder?.findViewById<AppCompatImageView>(R.id.ic_icon_banner)
if (imageView != null) { if (imageView != null) {
Glide.with(holder.view.context!!) Glide.with(XNBackground.instance)
.load(data?.image_url) .load(data?.image_url)
.placeholder(R.mipmap.collection_trending_recommend) .placeholder(R.mipmap.collection_trending_recommend)
.into(imageView) .into(imageView)
} }
val tvName = val tvName =
holder?.view?.findViewById<AppCompatTextView>(R.id.tv_name) holder?.findViewById<AppCompatTextView>(R.id.tv_name)
tvName?.text = data?.name
val cardView =
holder?.view?.findViewById<CardView>(R.id.cardView)
if (position == currentPlayingPosition) {
cardView?.visibility = View.INVISIBLE
} else {
cardView?.visibility = View.VISIBLE
}
val tvRevenge = val tvRevenge =
holder?.view?.findViewById<AppCompatTextView>(R.id.tv_revenge) holder?.findViewById<AppCompatTextView>(R.id.tv_revenge)
val tvRevenge1 = val tvRevenge1 =
holder?.view?.findViewById<AppCompatTextView>(R.id.tv_revenge_1) holder?.findViewById<AppCompatTextView>(R.id.tv_revenge_1)
tvName?.text = data?.name
val bannerPlayerView = holder?.findViewById<BannerPlayerView>(R.id.banner_player)
if (position == currentPlayingPosition) {
imageView?.visibility = View.INVISIBLE
bannerPlayerView?.setPlayInfo(data)
currentBannerPlayerView = bannerPlayerView
tvName?.visibility = View.VISIBLE
tvRevenge?.visibility = View.GONE tvRevenge?.visibility = View.GONE
tvRevenge1?.visibility = View.GONE tvRevenge1?.visibility = View.GONE
@ -68,10 +59,19 @@ class VeBannerRecommendAdapter(items: List<VeDetailsRecommendBean.ItemDaraBean?>
tvRevenge1?.visibility = View.VISIBLE tvRevenge1?.visibility = View.VISIBLE
} }
} }
} else {
imageView?.visibility = View.VISIBLE
bannerPlayerView?.stop()
tvName?.visibility = View.GONE
tvRevenge?.visibility = View.GONE
tvRevenge1?.visibility = View.GONE
} }
inner class BannerViewHolder(var view: View) : RecyclerView.ViewHolder(
view
)
}
override fun getLayoutId(viewType: Int): Int {
return R.layout.item_ve_banner_recommend;
}
} }

View File

@ -30,7 +30,11 @@ class VeCustomerBuyRecordAdapter :
item: VeCustomerBuyRecordsBean.DataBean? item: VeCustomerBuyRecordsBean.DataBean?
) { ) {
if (null != item) { if (null != item) {
if (TranslationHelper.getTranslation()!=null){
holder.binding.tvBalance.text = TranslationHelper.replace(TranslationHelper.getTranslation()?.mireo_EP.toString(),item.episode.toString()).plus(" ").plus(item.name)
}else{
holder.binding.tvBalance.text = "EP.".plus(item.episode).plus(" ").plus(item.name) holder.binding.tvBalance.text = "EP.".plus(item.episode).plus(" ").plus(item.name)
}
holder.binding.tvName.text = TranslationHelper.getTranslation() holder.binding.tvName.text = TranslationHelper.getTranslation()
?.let { TranslationHelper.getTranslation()?.veloria_purchase_single_episode } ?.let { TranslationHelper.getTranslation()?.veloria_purchase_single_episode }
?: "Purchase Single Episode" ?: "Purchase Single Episode"

View File

@ -7,6 +7,7 @@ import android.view.ViewGroup
import androidx.recyclerview.widget.RecyclerView import androidx.recyclerview.widget.RecyclerView
import com.chad.library.adapter4.BaseQuickAdapter import com.chad.library.adapter4.BaseQuickAdapter
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.databinding.ItemVeStoreCoinBinding import com.veloria.now.shortapp.databinding.ItemVeStoreCoinBinding
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
import kotlin.math.floor import kotlin.math.floor
@ -36,7 +37,15 @@ class VeStoreCoinAdapter :
holder.binding.tvCoins.text = "+".plus(item.coins.toString()) holder.binding.tvCoins.text = "+".plus(item.coins.toString())
holder.binding.tvPrice.text = item.price_google holder.binding.tvPrice.text = item.price_google
if (item.send_coins > 0) { if (item.send_coins > 0) {
if (TranslationHelper.getTranslation() != null) {
holder.binding.tvBonus.text = TranslationHelper.replace(
TranslationHelper.getTranslation()?.veloria_bonus_count_text.toString(),
item.send_coins.toString()
)
} else {
holder.binding.tvBonus.text = "+".plus(item.send_coins).plus(" Bonus") holder.binding.tvBonus.text = "+".plus(item.send_coins).plus(" Bonus")
}
} else { } else {
holder.binding.tvBonus.text = "" holder.binding.tvBonus.text = ""
} }

View File

@ -7,6 +7,7 @@ import android.view.ViewGroup
import androidx.recyclerview.widget.RecyclerView import androidx.recyclerview.widget.RecyclerView
import com.chad.library.adapter4.BaseQuickAdapter import com.chad.library.adapter4.BaseQuickAdapter
import com.veloria.now.shortapp.R import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.databinding.ItemVeStoreCoinBigBinding import com.veloria.now.shortapp.databinding.ItemVeStoreCoinBigBinding
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
import kotlin.math.floor import kotlin.math.floor
@ -36,7 +37,14 @@ class VeStoreCoinBigAdapter :
holder.binding.tvCoins.text = "+".plus(item.coins.toString()) holder.binding.tvCoins.text = "+".plus(item.coins.toString())
holder.binding.tvPrice.text = item.price_google holder.binding.tvPrice.text = item.price_google
if (item.send_coins > 0) { if (item.send_coins > 0) {
if (TranslationHelper.getTranslation() != null) {
holder.binding.tvBonus.text = TranslationHelper.replace(
TranslationHelper.getTranslation()?.veloria_bonus_count_text.toString(),
item.send_coins.toString()
)
} else {
holder.binding.tvBonus.text = "+".plus(item.send_coins).plus(" Bonus") holder.binding.tvBonus.text = "+".plus(item.send_coins).plus(" Bonus")
}
} else { } else {
holder.binding.tvBonus.text = "" holder.binding.tvBonus.text = ""
} }

View File

@ -36,9 +36,11 @@ class VeStoreVipAdapter :
if (null != item) { if (null != item) {
holder.binding.tvDay.text = item.brief holder.binding.tvDay.text = item.brief
holder.binding.tvMoney.text = item.price_google holder.binding.tvMoney.text = item.price_google
holder.binding.tvMoneyDay.text = "/".plus(item.vip_type_key) holder.binding.tvMoneyDay.text = "/".plus(item.short_type)
holder.binding.tvDescription.text = item.description holder.binding.tvDescription.text = item.description
holder.binding.tvInfo.text = item.auto_sub if (TranslationHelper.getTranslation() != null) {
holder.binding.tvInfo.text = TranslationHelper.getTranslation()?.veloria_store_auto_renew
}
if ((item.send_coins ?: 0) > 0) { if ((item.send_coins ?: 0) > 0) {
holder.binding.tvExtra.text = holder.binding.tvExtra.text =
"+".plus( "+".plus(
@ -48,7 +50,7 @@ class VeStoreVipAdapter :
if (TranslationHelper.getTranslation() != null) { if (TranslationHelper.getTranslation() != null) {
holder.binding.tvExpire.text = holder.binding.tvExpire.text =
TranslationHelper.getTranslation()?.veloria_donate_expire?.let { TranslationHelper.getTranslation()?.veloria_store_donate_coins_ios?.let {
TranslationHelper.replace( TranslationHelper.replace(
it, it,
item.send_coin_ttl.toString() item.send_coin_ttl.toString()
@ -66,6 +68,7 @@ class VeStoreVipAdapter :
holder.binding.tvExpire.visibility = View.GONE holder.binding.tvExpire.visibility = View.GONE
} }
if (currentPosition == position) { if (currentPosition == position) {
holder.binding.tvSelect.visibility = View.VISIBLE holder.binding.tvSelect.visibility = View.VISIBLE
} else { } else {

View File

@ -0,0 +1,100 @@
package com.veloria.now.shortapp.subtractionCroll.modificationsPretch
import android.content.Context
import android.graphics.Color
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.recyclerview.widget.RecyclerView
import com.chad.library.adapter4.BaseQuickAdapter
import com.veloria.now.shortapp.R
import com.veloria.now.shortapp.civil.TranslationHelper
import com.veloria.now.shortapp.databinding.ItemVeStoreVipBinding
import com.veloria.now.shortapp.databinding.ItemVeVipSplashBinding
import com.veloria.now.shortapp.texturedAsink.VePaySettingsBean
class VeVipSplashAdapter :
BaseQuickAdapter<VePaySettingsBean.VipBean, VeVipSplashAdapter.VH>() {
var currentPosition = -1
class VH(
parent: ViewGroup,
val binding: ItemVeVipSplashBinding = ItemVeVipSplashBinding.inflate(
LayoutInflater.from(parent.context), parent, false
),
) : RecyclerView.ViewHolder(binding.root)
override fun onCreateViewHolder(context: Context, parent: ViewGroup, viewType: Int): VH {
return VH(parent)
}
override fun onBindViewHolder(
holder: VH,
position: Int,
item: VePaySettingsBean.VipBean?
) {
if (null != item) {
holder.binding.tvMoney.text = item.price_google
holder.binding.tvMoneyDay.text = "/".plus(item.short_type)
if ((item.send_coins ?: 0) > 0) {
holder.binding.tvExtra.text =
"+".plus(
TranslationHelper.getTranslation()
?.let { TranslationHelper.getTranslation()?.veloria_extra } ?: "Extra")
.plus(" ").plus(item.send_coins)
holder.binding.tvExtra.visibility = View.VISIBLE
} else {
holder.binding.tvExtra.visibility = View.GONE
}
if (position == 0){
holder.binding.tvHot.visibility = View.VISIBLE
}else {
holder.binding.tvHot.visibility = View.GONE
}
if (currentPosition == position) {
holder.binding.tvSelect.visibility = View.VISIBLE
} else {
holder.binding.tvSelect.visibility = View.GONE
}
when (item.vip_type_key) {
"month" -> {
holder.binding.root.setBackgroundResource(R.mipmap.iv_dialog_vip_splash_vip_1)
holder.binding.tvMoney.setTextColor(Color.parseColor("#414867"))
holder.binding.tvMoneyDay.setTextColor(Color.parseColor("#414867"))
holder.binding.tvExtra.setTextColor(Color.parseColor("#303962"))
holder.binding.tvExtra.setBackgroundResource(R.drawable.bg_store_vip_text_1)
}
"week" -> {
holder.binding.root.setBackgroundResource(R.mipmap.iv_dialog_vip_splash_vip_2)
holder.binding.tvMoney.setTextColor(Color.parseColor("#416767"))
holder.binding.tvMoneyDay.setTextColor(Color.parseColor("#416767"))
holder.binding.tvExtra.setTextColor(Color.parseColor("#416767"))
holder.binding.tvExtra.setBackgroundResource(R.drawable.bg_store_vip_text_2)
}
"quarter" -> {
holder.binding.root.setBackgroundResource(R.mipmap.iv_dialog_vip_splash_vip_3)
holder.binding.tvMoney.setTextColor(Color.parseColor("#5F1EB9"))
holder.binding.tvMoneyDay.setTextColor(Color.parseColor("#5F1EB9"))
holder.binding.tvExtra.setTextColor(Color.parseColor("#5F1EB9"))
holder.binding.tvExtra.setBackgroundResource(R.drawable.bg_store_vip_text_3)
}
"year" -> {
holder.binding.root.setBackgroundResource(R.mipmap.iv_dialog_vip_splash_vip_4)
holder.binding.tvMoney.setTextColor(Color.parseColor("#573D31"))
holder.binding.tvMoneyDay.setTextColor(Color.parseColor("#573D31"))
holder.binding.tvExtra.setTextColor(Color.parseColor("#573D31"))
holder.binding.tvExtra.setBackgroundResource(R.drawable.bg_store_vip_text_4)
}
}
}
}
}

View File

@ -0,0 +1,8 @@
package com.veloria.now.shortapp.texturedAsink
class VePayResBean(
val is_backhaul: Int,//1可以上传
val money: String,//回传价格
val order_code: String,
val status: String
)

View File

@ -0,0 +1,11 @@
package com.veloria.now.shortapp.texturedAsink
class VeRevolutionsBean(
val list: List<RevolutionItemBean>
) {
data class RevolutionItemBean(
val can_check: Boolean,
val condition: Int,
val value: Int
)
}

View File

@ -0,0 +1,8 @@
package com.veloria.now.shortapp.texturedAsink
class VeRewardJsBean (
val token: String,
val time_zone: String,
val lang: String,
val type: String
)

View File

@ -16,7 +16,38 @@ class VeTranslationBean(
) )
data class Translation( data class Translation(
val veloria_update_title : String,
val veloria_update_now : String,
val veloria_no_restore : String,
val veloria_store_donate_coins_ios : String,
val veloria_coin_buy_title : String,
val mireo_EP : String,
val veloria_try_again : String,
val veloria_network_error_1 : String,
val veloria_search_results : String,
val veloria_watch_now : String,
val veloria_detail_recommand_title : String,
val veloria_bonus_count_text : String,
val veloria_donate_expire : String, val veloria_donate_expire : String,
val veloria_open_notice_at_watch_video : String,
val veloria_allow : String,
val veloria_open_notice_alert_text : String,
val veloria_favorites : String,
val veloria_more : String,
val veloria_week : String,
val veloria_month : String,
val veloria_quarter : String,
val veloria_year : String,
val veloria_go : String,
val veloria_later : String,
val veloria_vip_activate_content : String,
val veloria_vip_activate_title : String,
val veloria_vip_splash_onclick : String,
val veloria_vip_splash_content : String,
val veloria_vip_splash_title : String,
val veloria_google_pay_success : String,
val veloria_google_pay_canceled : String,
val veloria_google_pay_error : String,
val veloria_not_found_string : String, val veloria_not_found_string : String,
val veloria_not_found : String, val veloria_not_found : String,
val veloria_episode : String, val veloria_episode : String,
@ -62,6 +93,7 @@ class VeTranslationBean(
val veloria_recersal_of_fate : String, val veloria_recersal_of_fate : String,
val veloria_extra : String, val veloria_extra : String,
val veloria_store_tips : String, val veloria_store_tips : String,
val veloria_unlock : String,
val veloria_your_coins : String, val veloria_your_coins : String,
val veloria_get_more_coins : String, val veloria_get_more_coins : String,
val veloria_buy_now : String, val veloria_buy_now : String,
@ -97,6 +129,7 @@ class VeTranslationBean(
val veloria_order_record : String, val veloria_order_record : String,
val veloria_rewards : String, val veloria_rewards : String,
val veloria_store : String, val veloria_store : String,
val veloria_restore : String,
val veloria_wallet : String, val veloria_wallet : String,
val veloria_bonus : String, val veloria_bonus : String,
val veloria_coins : String, val veloria_coins : String,

View File

@ -0,0 +1,3 @@
package com.veloria.now.shortapp.texturedAsink
class VeUploadNotificationBean (val is_open_notice: String)

View File

@ -0,0 +1,3 @@
package com.veloria.now.shortapp.texturedAsink
class VeUploadNotificationDataBean (val coins: String)

View File

@ -0,0 +1,7 @@
package com.veloria.now.shortapp.texturedAsink
class VersionControlBean (
val description: String,
val version_code: String,
val version_name: String
)

View File

@ -0,0 +1,14 @@
package com.veloria.now.shortapp.texturedAsink
class WatchVideoJsonBean(
val data: Data?,
val is_complete: Boolean,
val is_show: Int,
val type: String
) {
data class Data(
val activity_id: Int,
val short_play_id: Int?
)
}

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="#BE0069" />
<corners android:topRightRadius="@dimen/dp_10" android:bottomLeftRadius="@dimen/dp_10" />
</shape>

View File

@ -0,0 +1,7 @@
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="#7C174F" />
<corners android:topLeftRadius="@dimen/dp_7"
android:topRightRadius="@dimen/dp_7"
android:bottomLeftRadius="@dimen/dp_7"/>
</shape>

View File

@ -0,0 +1,11 @@
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item>
<shape android:shape="rectangle">
<gradient android:endColor="#FCCB6D" android:startColor="#FDDDA2" android:type="linear" />
<corners android:topLeftRadius="@dimen/dp_7"
android:topRightRadius="@dimen/dp_7"
android:bottomLeftRadius="@dimen/dp_7" />
</shape>
</item>
</selector>

View File

@ -0,0 +1,5 @@
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="#A3F0DE" />
<corners android:radius="@dimen/dp_15"/>
</shape>

View File

@ -57,13 +57,23 @@
tools:text="1" /> tools:text="1" />
<WebView <com.veloria.now.shortapp.rewards.VSNotificationsDefault
android:id="@+id/web_feedback" android:id="@+id/stateLayout"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="0dp" android:layout_height="0dp"
app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/iv_back" /> app:layout_constraintTop_toBottomOf="@+id/iv_back"
>
<WebView
android:id="@+id/web_feedback"
android:layout_width="match_parent"
android:layout_height="match_parent"
/>
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -39,11 +39,18 @@
app:layout_constraintTop_toBottomOf="@+id/iv_back" app:layout_constraintTop_toBottomOf="@+id/iv_back"
app:srlEnablePreviewInEditMode="false"> app:srlEnablePreviewInEditMode="false">
<com.veloria.now.shortapp.rewards.VSNotificationsDefault
android:id="@+id/stateLayout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<WebView <WebView
android:id="@+id/web_feedback_detail" android:id="@+id/web_feedback_detail"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" /> android:layout_height="match_parent" />
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</com.scwang.smart.refresh.layout.SmartRefreshLayout> </com.scwang.smart.refresh.layout.SmartRefreshLayout>
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -39,10 +39,18 @@
app:layout_constraintTop_toBottomOf="@+id/iv_back" app:layout_constraintTop_toBottomOf="@+id/iv_back"
app:srlEnablePreviewInEditMode="false"> app:srlEnablePreviewInEditMode="false">
<com.veloria.now.shortapp.rewards.VSNotificationsDefault
android:id="@+id/stateLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<WebView <WebView
android:id="@+id/web_feedback_list" android:id="@+id/web_feedback_list"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" /> android:layout_height="match_parent" />
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</com.scwang.smart.refresh.layout.SmartRefreshLayout> </com.scwang.smart.refresh.layout.SmartRefreshLayout>

View File

@ -29,15 +29,21 @@
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@+id/iv_back" /> app:layout_constraintTop_toTopOf="@+id/iv_back" />
<com.scwang.smart.refresh.layout.SmartRefreshLayout <com.veloria.now.shortapp.rewards.VSNotificationsDefault
android:id="@+id/refresh" android:id="@+id/stateLayout"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="0dp" android:layout_height="0dp"
android:layout_marginBottom="@dimen/dp_10"
app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/iv_back"> app:layout_constraintTop_toBottomOf="@+id/iv_back">
<com.scwang.smart.refresh.layout.SmartRefreshLayout
android:id="@+id/refresh"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginBottom="@dimen/dp_10"
>
<androidx.core.widget.NestedScrollView <androidx.core.widget.NestedScrollView
android:id="@+id/scrollView" android:id="@+id/scrollView"
android:layout_width="match_parent" android:layout_width="match_parent"
@ -63,7 +69,7 @@
android:id="@+id/tv_total_text" android:id="@+id/tv_total_text"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_5" android:layout_marginStart="@dimen/dp_10"
android:layout_marginTop="@dimen/dp_5" android:layout_marginTop="@dimen/dp_5"
android:text="Total Coins" android:text="Total Coins"
android:textColor="@color/white" android:textColor="@color/white"
@ -75,7 +81,7 @@
android:id="@+id/tv_total" android:id="@+id/tv_total"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_5" android:layout_marginStart="@dimen/dp_10"
android:layout_marginTop="@dimen/dp_8" android:layout_marginTop="@dimen/dp_8"
android:drawableStart="@mipmap/iv_coins" android:drawableStart="@mipmap/iv_coins"
android:drawablePadding="@dimen/dp_5" android:drawablePadding="@dimen/dp_5"
@ -100,7 +106,7 @@
android:id="@+id/tv_recharge_text" android:id="@+id/tv_recharge_text"
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_5" android:layout_marginStart="@dimen/dp_10"
android:layout_marginTop="@dimen/dp_18" android:layout_marginTop="@dimen/dp_18"
android:text="Recharge" android:text="Recharge"
android:textColor="@color/white" android:textColor="@color/white"
@ -112,7 +118,7 @@
android:id="@+id/tv_recharge" android:id="@+id/tv_recharge"
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_5" android:layout_marginStart="@dimen/dp_10"
android:layout_marginTop="@dimen/dp_5" android:layout_marginTop="@dimen/dp_5"
android:layout_marginBottom="@dimen/dp_5" android:layout_marginBottom="@dimen/dp_5"
android:text="0" android:text="0"
@ -205,4 +211,7 @@
</androidx.core.widget.NestedScrollView> </androidx.core.widget.NestedScrollView>
</com.scwang.smart.refresh.layout.SmartRefreshLayout> </com.scwang.smart.refresh.layout.SmartRefreshLayout>
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -1,7 +1,6 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:background="@color/ve_080b16"> android:background="@color/ve_080b16">
@ -31,32 +30,6 @@
app:layout_constraintTop_toTopOf="@+id/iv_back" /> app:layout_constraintTop_toTopOf="@+id/iv_back" />
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_feedback_list"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="@dimen/dp_15"
android:src="@mipmap/iv_ve_feedback"
app:layout_constraintBottom_toBottomOf="@+id/iv_back"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="@+id/iv_back" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_feedback_num"
android:layout_width="@dimen/dp_16"
android:layout_height="@dimen/dp_16"
android:layout_marginTop="@dimen/dp_6"
android:layout_marginEnd="@dimen/dp_8"
android:background="@drawable/bg_feedback_mes_num"
android:gravity="center"
android:textColor="@color/white"
android:textSize="@dimen/sp_12"
android:visibility="gone"
app:layout_constraintEnd_toEndOf="@+id/iv_feedback_list"
app:layout_constraintTop_toTopOf="@+id/iv_feedback_list"
tools:text="1" />
<com.scwang.smart.refresh.layout.SmartRefreshLayout <com.scwang.smart.refresh.layout.SmartRefreshLayout
android:id="@+id/refresh" android:id="@+id/refresh"
android:layout_width="match_parent" android:layout_width="match_parent"

View File

@ -21,18 +21,37 @@
android:layout_alignTop="@+id/iv_back" android:layout_alignTop="@+id/iv_back"
android:layout_alignBottom="@+id/iv_back" android:layout_alignBottom="@+id/iv_back"
android:layout_centerHorizontal="true" android:layout_centerHorizontal="true"
android:gravity="center"
android:singleLine="true" android:singleLine="true"
android:text="Store" android:text="Store"
android:gravity="center"
android:textColor="@color/white" android:textColor="@color/white"
android:textSize="@dimen/sp_16" /> android:textSize="@dimen/sp_16" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_restore"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignTop="@+id/iv_back"
android:layout_alignBottom="@+id/iv_back"
android:layout_alignParentEnd="true"
android:layout_marginEnd="@dimen/dp_15"
android:gravity="center"
android:singleLine="true"
android:text="Restore"
android:textColor="@color/white"
android:textSize="@dimen/sp_14" />
<androidx.core.widget.NestedScrollView <com.veloria.now.shortapp.rewards.VSNotificationsDefault
android:id="@+id/stateLayout"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:layout_below="@+id/iv_back"> android:layout_below="@+id/iv_back">
<androidx.core.widget.NestedScrollView
android:id="@+id/scrollView"
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.appcompat.widget.LinearLayoutCompat <androidx.appcompat.widget.LinearLayoutCompat
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
@ -95,4 +114,6 @@
</androidx.core.widget.NestedScrollView> </androidx.core.widget.NestedScrollView>
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</RelativeLayout> </RelativeLayout>

View File

@ -33,15 +33,15 @@
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" app:layout_constraintTop_toTopOf="parent"
android:layout_marginStart="@dimen/dp_10" android:layout_marginStart="@dimen/dp_10"
android:layout_marginTop="@dimen/dp_25" android:layout_marginTop="@dimen/dp_30"
/> />
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_title" android:id="@+id/tv_title"
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_20" android:layout_marginStart="@dimen/dp_23"
android:layout_marginTop="@dimen/dp_30" android:layout_marginTop="@dimen/dp_36"
android:layout_marginEnd="@dimen/dp_115" android:layout_marginEnd="@dimen/dp_115"
android:fontFamily="sans-serif-medium" android:fontFamily="sans-serif-medium"
android:lineSpacingExtra="@dimen/dp_2" android:lineSpacingExtra="@dimen/dp_2"
@ -58,8 +58,8 @@
android:id="@+id/tv_content" android:id="@+id/tv_content"
android:layout_width="0dp" android:layout_width="0dp"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginHorizontal="@dimen/dp_20" android:layout_marginHorizontal="@dimen/dp_23"
android:layout_marginTop="@dimen/dp_15" android:layout_marginTop="@dimen/dp_25"
android:minLines="4" android:minLines="4"
android:text="when you sign out, your watch history will not be synced to your account." android:text="when you sign out, your watch history will not be synced to your account."
android:textColor="@color/avatarAdvert" android:textColor="@color/avatarAdvert"

View File

@ -0,0 +1,117 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:background="@mipmap/playfair_selected_gradle">
<View
android:layout_width="0dp"
android:layout_height="0dp"
android:background="@drawable/ppi_auto_renderers"
app:layout_constraintBottom_toBottomOf="@+id/cl_one"
app:layout_constraintEnd_toEndOf="@+id/cl_one"
app:layout_constraintStart_toStartOf="@+id/cl_one"
app:layout_constraintTop_toTopOf="@+id/cl_one" />
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/cl_one"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@mipmap/checkbox_layout"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<androidx.appcompat.widget.AppCompatImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_10"
android:layout_marginTop="@dimen/dp_30"
android:src="@mipmap/iv_dialog_text_top"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_title"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_23"
android:layout_marginTop="@dimen/dp_36"
android:layout_marginEnd="@dimen/dp_115"
android:fontFamily="sans-serif-medium"
android:lineSpacingExtra="@dimen/dp_2"
android:minLines="2"
android:text="Turn on Notifications?"
android:textColor="@color/avatarAdvert"
android:textSize="@dimen/sp_20"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_content"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginHorizontal="@dimen/dp_23"
android:layout_marginTop="@dimen/dp_30"
android:minLines="4"
android:text="Get alerts for new episodes and exclusive offers."
android:textColor="@color/avatarAdvert"
android:textSize="@dimen/sp_15"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@id/tv_title" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_go"
android:layout_width="match_parent"
android:layout_height="@dimen/dp_48"
android:layout_marginHorizontal="@dimen/dp_30"
android:layout_marginTop="@dimen/dp_20"
android:layout_marginBottom="@dimen/dp_30"
android:background="@drawable/mc_player"
android:gravity="center"
android:text="Allow"
android:textColor="@color/white"
android:textSize="@dimen/sp_14"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toBottomOf="@id/tv_content" />
</androidx.constraintlayout.widget.ConstraintLayout>
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="-45dp"
android:src="@mipmap/menu_unit"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="@+id/cl_one" />
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_image_1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="@dimen/dp_15"
android:src="@mipmap/iv_notifications_check"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toBottomOf="@+id/iv_image" />
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_close"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dp_10"
android:padding="@dimen/dp_10"
android:src="@mipmap/factory_icon"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/cl_one" />
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,110 @@
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:background="@color/window_bg_color">
<androidx.appcompat.widget.LinearLayoutCompat
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"
android:layout_marginBottom="@dimen/dp_80"
android:orientation="horizontal">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1">
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_quality_480"
android:layout_width="@dimen/dp_100"
android:layout_height="@dimen/dp_54"
android:background="@mipmap/iv_quality_bg_on"
android:gravity="center"
android:text="480p"
android:textColor="@color/white"
android:textSize="@dimen/sp_14"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1">
<com.hjq.shape.view.ShapeTextView
android:id="@+id/tv_quality_720"
android:layout_width="@dimen/dp_100"
android:layout_height="@dimen/dp_54"
android:background="@mipmap/iv_quality_bg_off"
android:gravity="center"
android:text="720p"
android:textColor="@color/white"
android:textSize="@dimen/sp_14"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_login_tag"
android:layout_width="wrap_content"
android:layout_height="@dimen/dp_14"
android:background="@drawable/bg_quality_login"
android:drawableStart="@mipmap/iv_quality_login_user"
android:drawablePadding="@dimen/dp_2"
android:gravity="center"
android:paddingHorizontal="@dimen/dp_5"
android:text="Login"
android:textColor="@color/white"
android:textSize="@dimen/sp_8"
app:layout_constraintEnd_toEndOf="@+id/tv_quality_720"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1">
<com.hjq.shape.view.ShapeTextView
android:id="@+id/tv_quality_1080"
android:layout_width="@dimen/dp_100"
android:layout_height="@dimen/dp_54"
android:background="@mipmap/iv_quality_bg_off"
android:gravity="center"
android:text="1080p"
android:textColor="@color/white"
android:textSize="@dimen/sp_14"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_vip_tag"
android:layout_width="wrap_content"
android:layout_height="@dimen/dp_14"
android:background="@drawable/bg_quality_vip"
android:drawableStart="@mipmap/iv_quality_login_vip"
android:drawablePadding="@dimen/dp_2"
android:gravity="center"
android:paddingHorizontal="@dimen/dp_5"
android:text="VIP"
android:textColor="#CF8E02"
android:textSize="@dimen/sp_8"
app:layout_constraintEnd_toEndOf="@+id/tv_quality_1080"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.appcompat.widget.LinearLayoutCompat>
</FrameLayout>

View File

@ -0,0 +1,125 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:background="@mipmap/playfair_selected_gradle">
<View
android:layout_width="0dp"
android:layout_height="0dp"
android:background="@drawable/ppi_auto_renderers"
app:layout_constraintBottom_toBottomOf="@+id/cl_one"
app:layout_constraintEnd_toEndOf="@+id/cl_one"
app:layout_constraintStart_toStartOf="@+id/cl_one"
app:layout_constraintTop_toTopOf="@+id/cl_one" />
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/cl_one"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@mipmap/checkbox_layout"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<androidx.appcompat.widget.AppCompatImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_10"
android:layout_marginTop="@dimen/dp_30"
android:src="@mipmap/iv_dialog_text_top"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_title"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_23"
android:layout_marginTop="@dimen/dp_36"
android:layout_marginEnd="@dimen/dp_135"
android:fontFamily="sans-serif-medium"
android:lineSpacingExtra="@dimen/dp_2"
android:maxLines="2"
android:ellipsize="end"
android:text="Discover a new version"
android:textColor="@color/avatarAdvert"
android:textSize="@dimen/sp_20"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_version"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_23"
android:layout_marginTop="@dimen/sp_12"
android:background="@drawable/bg_upload_version"
android:paddingHorizontal="@dimen/sp_8"
android:paddingVertical="@dimen/dp_3"
android:text="v2.0"
android:textColor="@color/black"
android:textSize="@dimen/sp_12"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/tv_title" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_content"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginHorizontal="@dimen/dp_23"
android:layout_marginTop="@dimen/dp_12"
android:minLines="4"
android:text="when you sign out, your watch history will not be synced to your account."
android:textColor="@color/avatarAdvert"
android:textSize="@dimen/sp_15"
app:layout_constraintBottom_toTopOf="@+id/tv_now"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@id/tv_version" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_now"
android:layout_width="match_parent"
android:layout_height="@dimen/dp_48"
android:layout_marginHorizontal="@dimen/dp_30"
android:layout_marginTop="@dimen/dp_15"
android:layout_marginBottom="@dimen/dp_30"
android:background="@drawable/mc_player"
android:gravity="center"
android:text="Update Now"
android:textColor="@color/white"
android:textSize="@dimen/sp_14"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/tv_content" />
</androidx.constraintlayout.widget.ConstraintLayout>
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="-45dp"
android:src="@mipmap/iv_version_control_top"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="@+id/cl_one" />
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_close"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dp_10"
android:padding="@dimen/dp_10"
android:src="@mipmap/factory_icon"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/cl_one" />
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,129 @@
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:background="@mipmap/playfair_selected_gradle">
<View
android:layout_width="0dp"
android:layout_height="0dp"
android:background="@drawable/ppi_auto_renderers"
app:layout_constraintBottom_toBottomOf="@+id/cl_one"
app:layout_constraintEnd_toEndOf="@+id/cl_one"
app:layout_constraintStart_toStartOf="@+id/cl_one"
app:layout_constraintTop_toTopOf="@+id/cl_one" />
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/cl_one"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@mipmap/checkbox_layout"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<androidx.appcompat.widget.AppCompatImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_10"
android:layout_marginTop="@dimen/dp_30"
android:src="@mipmap/iv_dialog_text_top"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_title"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_23"
android:layout_marginTop="@dimen/dp_36"
android:layout_marginEnd="@dimen/dp_115"
android:fontFamily="sans-serif-medium"
android:lineSpacingExtra="@dimen/dp_2"
android:minLines="2"
android:text="Unlock HD VIP Access!"
android:textColor="@color/avatarAdvert"
android:textSize="@dimen/sp_20"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_content"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginHorizontal="@dimen/dp_23"
android:layout_marginTop="@dimen/dp_25"
android:minLines="4"
android:text="Activate vip and enjoy HD video privileges."
android:textColor="@color/avatarAdvert"
android:textSize="@dimen/sp_15"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toBottomOf="@id/tv_title" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_cancel"
android:layout_width="0dp"
android:layout_height="@dimen/dp_48"
android:layout_marginStart="@dimen/dp_30"
android:layout_marginTop="@dimen/dp_20"
android:layout_marginEnd="@dimen/dp_5"
android:layout_marginBottom="@dimen/dp_30"
android:background="@drawable/bg_login"
android:gravity="center"
android:text="Later"
android:textColor="#B3B3B3"
android:textSize="@dimen/sp_14"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toStartOf="@+id/tv_go"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/tv_content" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_go"
android:layout_width="0dp"
android:layout_height="@dimen/dp_48"
android:layout_marginStart="@dimen/dp_5"
android:layout_marginTop="@dimen/dp_20"
android:layout_marginEnd="@dimen/dp_30"
android:layout_marginBottom="@dimen/dp_30"
android:background="@drawable/mc_player"
android:gravity="center"
android:text="Go"
android:textColor="@color/white"
android:textSize="@dimen/sp_14"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toEndOf="@+id/tv_cancel"
app:layout_constraintTop_toBottomOf="@id/tv_content" />
</androidx.constraintlayout.widget.ConstraintLayout>
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="-45dp"
android:src="@mipmap/iv_dialog_vip_activate_top"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toTopOf="@+id/cl_one" />
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_close"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dp_10"
android:padding="@dimen/dp_10"
android:src="@mipmap/factory_icon"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/cl_one" />
</androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -0,0 +1,83 @@
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<View
android:id="@+id/v_bg"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignTop="@+id/iv_top"
android:layout_alignBottom="@+id/v_line"
android:layout_marginTop="@dimen/dp_75"
android:background="@mipmap/iv_dialog_vip_splash_bg" />
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_top"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="@dimen/dp_15"
android:background="@mipmap/iv_dialog_vip_splash_top" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_title"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/iv_top"
android:layout_marginHorizontal="@dimen/dp_20"
android:layout_marginTop="@dimen/dp_30"
android:fontFamily="sans-serif-medium"
android:lineSpacingExtra="@dimen/dp_2"
android:textStyle="bold"
android:gravity="center"
android:text="Unlock VIP Privileges!"
android:textColor="@color/white"
android:textSize="@dimen/sp_16" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_content"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/tv_title"
android:layout_marginHorizontal="@dimen/dp_20"
android:layout_marginTop="@dimen/dp_15"
android:ellipsize="end"
android:gravity="center"
android:minLines="2"
android:text="Enjoy ad-free streaming, early access, and exclusive content!"
android:textColor="#C5C5C5"
android:textSize="@dimen/sp_14" />
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/recyclerView"
android:layout_width="@dimen/dp_240"
android:layout_height="wrap_content"
android:layout_below="@+id/tv_content"
android:layout_centerHorizontal="true"
android:layout_marginHorizontal="@dimen/dp_20"
android:layout_marginTop="@dimen/dp_15"
/>
<View
android:id="@+id/v_line"
android:layout_width="@dimen/dp_1"
android:layout_height="@dimen/dp_15"
android:layout_below="@+id/recyclerView"
/>
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_close"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/v_line"
android:layout_centerHorizontal="true"
android:padding="@dimen/dp_10"
android:src="@mipmap/factory_icon" />
</RelativeLayout>

View File

@ -261,6 +261,9 @@
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_10" android:layout_marginStart="@dimen/dp_10"
android:ellipsize="end"
android:maxWidth="@dimen/dp_60"
android:maxLines="2"
android:text="Donate" android:text="Donate"
android:textColor="@color/gradleLayout" android:textColor="@color/gradleLayout"
android:textSize="@dimen/sp_14" android:textSize="@dimen/sp_14"
@ -318,7 +321,7 @@
android:id="@+id/tv_store" android:id="@+id/tv_store"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginHorizontal="@dimen/dp_30" android:layout_marginHorizontal="@dimen/dp_20"
android:drawableTop="@mipmap/empty_image" android:drawableTop="@mipmap/empty_image"
android:gravity="center" android:gravity="center"
android:text="Store" android:text="Store"
@ -332,12 +335,12 @@
android:id="@+id/tv_rewards" android:id="@+id/tv_rewards"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginEnd="@dimen/dp_20"
android:drawableTop="@mipmap/bold_wight_fddebcdbeeffcebdf" android:drawableTop="@mipmap/bold_wight_fddebcdbeeffcebdf"
android:gravity="center" android:gravity="center"
android:text="Rewards" android:text="Rewards"
android:textColor="@color/white" android:textColor="@color/white"
android:textSize="@dimen/sp_12" android:textSize="@dimen/sp_12"
android:visibility="gone"
app:layout_constraintEnd_toStartOf="@+id/tv_favorites" app:layout_constraintEnd_toStartOf="@+id/tv_favorites"
app:layout_constraintStart_toEndOf="@+id/tv_store" app:layout_constraintStart_toEndOf="@+id/tv_store"
app:layout_constraintTop_toTopOf="parent" /> app:layout_constraintTop_toTopOf="parent" />
@ -392,10 +395,10 @@
android:drawablePadding="@dimen/dp_8" android:drawablePadding="@dimen/dp_8"
android:gravity="center_vertical" android:gravity="center_vertical"
android:paddingHorizontal="@dimen/dp_10" android:paddingHorizontal="@dimen/dp_10"
android:visibility="gone"
android:text="@string/dimensImage" android:text="@string/dimensImage"
android:textColor="@color/white" android:textColor="@color/white"
android:textSize="@dimen/sp_14" /> android:textSize="@dimen/sp_14"
android:visibility="visible" />
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_delete_account" android:id="@+id/tv_delete_account"

View File

@ -14,13 +14,13 @@
android:src="@mipmap/right_dimens" android:src="@mipmap/right_dimens"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" /> app:layout_constraintTop_toTopOf="parent" />
<ScrollView
android:orientation="vertical" <ScrollView
android:layout_height="0dp" android:layout_width="0dp"
android:visibility="invisible" android:layout_height="0dp"
android:layout_width="0dp" android:background="#58AE3A"
android:background="#58AE3A"> android:orientation="vertical"
</ScrollView> android:visibility="invisible"></ScrollView>
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_title" android:id="@+id/tv_title"
@ -33,23 +33,32 @@ android:background="#58AE3A">
app:layout_constraintEnd_toEndOf="parent" app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="@+id/iv_back" /> app:layout_constraintTop_toTopOf="@+id/iv_back" />
<LinearLayout
android:layout_height="210dp" <LinearLayout
android:padding="53dp" android:layout_width="wrap_content"
android:visibility="gone" android:layout_height="210dp"
android:background="#1AB1B1" android:background="#1AB1B1"
android:layout_width="wrap_content" android:orientation="vertical"
android:orientation="vertical"> android:padding="53dp"
</LinearLayout> android:visibility="gone"></LinearLayout>
<com.veloria.now.shortapp.rewards.VSNotificationsDefault
android:id="@+id/stateLayout"
android:layout_width="match_parent"
android:layout_height="0dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/iv_back">
<WebView <WebView
android:id="@+id/webView" android:id="@+id/webView"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="0dp" android:layout_height="match_parent"
android:layout_marginTop="@dimen/dp_5" android:layout_marginTop="@dimen/dp_5"
android:background="@color/transparent" android:background="@color/transparent"
app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintTop_toBottomOf="@+id/iv_back" /> app:layout_constraintTop_toBottomOf="@+id/iv_back" />
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>

View File

@ -14,14 +14,23 @@
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"> app:layout_constraintTop_toTopOf="parent">
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<com.veloria.now.shortapp.rewards.BannerPlayerView
android:id="@+id/banner_player"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<androidx.appcompat.widget.AppCompatImageView <androidx.appcompat.widget.AppCompatImageView
android:id="@+id/ic_icon_banner" android:id="@+id/ic_icon_banner"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:scaleType="centerCrop" android:scaleType="centerCrop" />
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent" </FrameLayout>
app:layout_constraintTop_toTopOf="parent" />
</androidx.cardview.widget.CardView> </androidx.cardview.widget.CardView>
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView

View File

@ -14,7 +14,7 @@
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_gravity="center_horizontal" android:layout_gravity="center_horizontal"
android:layout_marginStart="@dimen/dp_14" android:layout_marginStart="@dimen/dp_14"
android:layout_marginTop="@dimen/dp_20" android:layout_marginTop="@dimen/dp_18"
android:gravity="center_horizontal" android:gravity="center_horizontal"
android:text="Weekly VIP" android:text="Weekly VIP"
android:textColor="#647DA7" android:textColor="#647DA7"

View File

@ -0,0 +1,66 @@
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="@dimen/dp_55"
android:layout_marginBottom="@dimen/dp_10"
android:background="@mipmap/iv_dialog_vip_splash_vip_1">
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_money"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="@dimen/dp_16"
android:text="0"
android:textColor="#416767"
android:textSize="@dimen/sp_22"
android:textStyle="bold" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_money_day"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dp_8"
android:layout_toEndOf="@+id/tv_money"
android:text="/month"
android:textColor="#416767"
android:textSize="@dimen/sp_12" />
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_extra"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/tv_money"
android:layout_marginStart="@dimen/dp_16"
android:drawableEnd="@mipmap/iv_coins_small"
android:paddingVertical="@dimen/dp_3"
android:paddingHorizontal="@dimen/dp_6"
android:background="@drawable/bg_store_vip_text_1"
android:drawablePadding="@dimen/dp_5"
android:text="+Extra 0"
android:textColor="#416767"
android:textSize="@dimen/sp_10" />
<ImageView
android:id="@+id/tv_hot"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentEnd="true"
android:layout_marginTop="@dimen/dp_4"
android:visibility="gone"
android:layout_marginEnd="@dimen/dp_4"
android:background="@mipmap/iv_store_vip_big_hot" />
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/tv_select"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentEnd="true"
android:layout_alignParentBottom="true"
android:background="@drawable/bg_coin_left"
android:gravity="center"
android:paddingHorizontal="@dimen/dp_5"
android:src="@mipmap/iv_yes"
android:visibility="invisible" />
</RelativeLayout>

View File

@ -1,6 +1,5 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<com.veloria.now.shortapp.rewards.VSNotificationsDefault xmlns:android="http://schemas.android.com/apk/res/android" <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/stateLayout"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:background="@mipmap/playfair_selected_gradle"> android:background="@mipmap/playfair_selected_gradle">
@ -9,12 +8,17 @@
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent"> android:layout_height="match_parent">
<com.veloria.now.shortapp.rewards.VSNotificationsDefault
android:id="@+id/stateLayout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.viewpager2.widget.ViewPager2 <androidx.viewpager2.widget.ViewPager2
android:id="@+id/viewPager_detail" android:id="@+id/viewPager_detail"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:orientation="vertical" /> android:orientation="vertical" />
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
<androidx.appcompat.widget.AppCompatImageView <androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_cover" android:id="@+id/iv_cover"
@ -25,16 +29,24 @@
<include <include
android:id="@+id/layout_lock" android:id="@+id/layout_lock"
layout="@layout/layout_ve_lock_episode" layout="@layout/layout_ve_lock_episode" />
/>
<include <include
android:id="@+id/layout_recommend" android:id="@+id/layout_recommend"
layout="@layout/layout_player_recommend" layout="@layout/layout_player_recommend" />
/>
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>
<androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_back"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dp_35"
android:padding="@dimen/dp_15"
android:src="@mipmap/right_dimens"
android:visibility="gone"
/>
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</FrameLayout>

View File

@ -0,0 +1,13 @@
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.media3.ui.PlayerView
android:id="@+id/player_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:controller_layout_id="@layout/layout_player_recommend_controller"
app:resize_mode="zoom" />
</FrameLayout>

View File

@ -38,39 +38,16 @@
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent" /> app:layout_constraintTop_toTopOf="parent" />
<androidx.cardview.widget.CardView <com.zhpan.bannerview.BannerViewPager
android:id="@+id/cardView"
android:layout_width="@dimen/dp_190"
android:layout_height="@dimen/dp_260"
android:layout_marginTop="@dimen/dp_19"
android:background="@color/transparent"
app:cardCornerRadius="@dimen/dp_8"
app:cardElevation="0dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/tv_title">
<androidx.media3.ui.PlayerView
android:id="@+id/recommend_player_view"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:controller_layout_id="@layout/layout_player_recommend_controller"
app:resize_mode="zoom" />
</androidx.cardview.widget.CardView>
<com.youth.banner.Banner
android:id="@+id/banner_recommend" android:id="@+id/banner_recommend"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="@dimen/dp_340" android:layout_height="@dimen/dp_340"
android:layout_marginTop="@dimen/dp_19" android:layout_marginTop="@dimen/dp_19"
android:layout_marginHorizontal="@dimen/dp_23" android:layout_marginHorizontal="@dimen/dp_23"
android:clipChildren="false" app:bvp_round_corner="@dimen/dp_13"
android:clipToPadding="false" app:bvp_auto_play="false"
app:banner_auto_loop="false" app:bvp_can_loop="false"
app:bvp_indicator_radius="0dp"
app:layout_constraintLeft_toLeftOf="parent" app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintTop_toBottomOf="@id/tv_title" /> app:layout_constraintTop_toBottomOf="@id/tv_title" />

View File

@ -39,11 +39,42 @@
android:gravity="center_vertical" android:gravity="center_vertical"
android:text="" android:text=""
android:textColor="#05CEA0" android:textColor="#05CEA0"
app:drawableEndCompat="@mipmap/start_text"
app:layout_constraintBottom_toBottomOf="@+id/tv_coins_text" app:layout_constraintBottom_toBottomOf="@+id/tv_coins_text"
app:layout_constraintStart_toEndOf="@+id/tv_coins_text" app:layout_constraintStart_toEndOf="@+id/tv_coins_text"
app:layout_constraintTop_toTopOf="@+id/tv_coins_text" /> app:layout_constraintTop_toTopOf="@+id/tv_coins_text" />
<androidx.appcompat.widget.LinearLayoutCompat
android:layout_width="wrap_content"
android:layout_height="@dimen/dp_26"
android:layout_marginStart="@dimen/dp_15"
android:layout_marginTop="@dimen/dp_17"
android:layout_toRightOf="@+id/tv_coins"
android:background="@drawable/jru_categories_constants"
android:gravity="center"
android:orientation="horizontal"
android:paddingHorizontal="@dimen/dp_12">
<TextView
android:id="@+id/tv_unlock_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Unlock: "
android:textColor="@color/white" />
<TextView
android:id="@+id/tv_unlock"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:drawableEnd="@mipmap/iv_coins_small"
android:drawablePadding="@dimen/dp_3"
android:gravity="center"
android:text="0"
android:textColor="#05CEA0" />
</androidx.appcompat.widget.LinearLayoutCompat>
<androidx.core.widget.NestedScrollView <androidx.core.widget.NestedScrollView
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"

View File

@ -1,17 +1,24 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" <com.veloria.now.shortapp.rewards.VSNotificationsDefault xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools" xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:id="@+id/stateLayout"
android:background="@mipmap/playfair_selected_gradle"> android:background="@mipmap/playfair_selected_gradle">
<androidx.constraintlayout.widget.ConstraintLayout
android:id="@+id/cl_root"
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
android:id="@+id/text_home" android:id="@+id/text_home"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginStart="8dp" android:layout_marginStart="8dp"
android:layout_marginTop="@dimen/dp_20" android:layout_marginTop="@dimen/dp_60"
android:layout_marginEnd="8dp" android:layout_marginEnd="8dp"
android:text="@string/home_addictive_shorts_await" android:text="@string/home_addictive_shorts_await"
android:textAlignment="center" android:textAlignment="center"
@ -84,11 +91,6 @@
app:layout_constraintStart_toStartOf="parent" app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/fl_search"> app:layout_constraintTop_toBottomOf="@+id/fl_search">
<com.veloria.now.shortapp.rewards.VSNotificationsDefault
android:id="@+id/stateLayout"
android:layout_width="match_parent"
android:layout_height="match_parent">
<androidx.core.widget.NestedScrollView <androidx.core.widget.NestedScrollView
android:id="@+id/scrollView" android:id="@+id/scrollView"
android:layout_width="match_parent" android:layout_width="match_parent"
@ -365,7 +367,6 @@
</com.veloria.now.shortapp.rewards.VSNotificationsDefault> </com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>
</androidx.core.widget.NestedScrollView> </androidx.core.widget.NestedScrollView>
</com.veloria.now.shortapp.rewards.VSNotificationsDefault>
</com.scwang.smart.refresh.layout.SmartRefreshLayout> </com.scwang.smart.refresh.layout.SmartRefreshLayout>
<androidx.constraintlayout.widget.ConstraintLayout <androidx.constraintlayout.widget.ConstraintLayout
@ -411,5 +412,5 @@
</androidx.constraintlayout.widget.ConstraintLayout> </androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.constraintlayout.widget.ConstraintLayout> </com.veloria.now.shortapp.rewards.VSNotificationsDefault>

View File

@ -46,6 +46,8 @@ android:orientation="vertical">
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_below="@+id/tvEmptyTitle" android:layout_below="@+id/tvEmptyTitle"
android:layout_centerHorizontal="true" android:layout_centerHorizontal="true"
android:layout_marginHorizontal="@dimen/dp_15"
android:gravity="center"
android:layout_marginBottom="@dimen/dp_30" android:layout_marginBottom="@dimen/dp_30"
android:text="Start exploring and add something!" android:text="Start exploring and add something!"
android:textColor="@color/white" android:textColor="@color/white"

View File

@ -10,14 +10,14 @@
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"
android:scaleType="centerCrop" /> android:scaleType="centerCrop" />
<ScrollView
android:layout_width="0dp" <ScrollView
android:layout_height="0dp" android:layout_width="0dp"
android:visibility="invisible" android:layout_height="0dp"
android:orientation="horizontal" android:background="#999C19"
android:background="#999C19" android:orientation="horizontal"
android:paddingLeft="57dp"> android:paddingLeft="57dp"
</ScrollView> android:visibility="invisible"></ScrollView>
<androidx.appcompat.widget.AppCompatImageView <androidx.appcompat.widget.AppCompatImageView
android:id="@+id/iv_back_controller" android:id="@+id/iv_back_controller"
@ -27,21 +27,22 @@ android:paddingLeft="57dp">
android:layout_marginTop="@dimen/dp_40" android:layout_marginTop="@dimen/dp_40"
android:padding="@dimen/dp_10" android:padding="@dimen/dp_10"
android:src="@mipmap/right_dimens" /> android:src="@mipmap/right_dimens" />
<ScrollView
android:layout_height="0dp" <ScrollView
android:orientation="horizontal" android:layout_width="0dp"
android:paddingLeft="80dp" android:layout_height="0dp"
android:layout_width="0dp" android:background="#1C03E5"
android:background="#1C03E5"> android:orientation="horizontal"
<LinearLayout android:paddingLeft="80dp">
android:paddingBottom="37dp"
android:layout_width="0dp" <LinearLayout
android:layout_height="0dp" android:layout_width="0dp"
android:background="#D3A2CF" android:layout_height="0dp"
android:visibility="invisible" android:background="#D3A2CF"
android:orientation="horizontal"> android:orientation="horizontal"
</LinearLayout> android:paddingBottom="37dp"
</ScrollView> android:visibility="invisible"></LinearLayout>
</ScrollView>
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_player_title" android:id="@+id/tv_player_title"
@ -56,21 +57,23 @@ android:orientation="horizontal">
android:singleLine="true" android:singleLine="true"
android:textColor="@color/white" android:textColor="@color/white"
android:textSize="@dimen/sp_16" /> android:textSize="@dimen/sp_16" />
<EditText
android:text="enumeratedRtmpdh" <EditText
android:background="#094A0F" android:layout_width="0dp"
android:layout_width="0dp" android:layout_height="0dp"
android:layout_height="0dp" android:background="#094A0F"
android:paddingBottom="91dp" android:hint="knockoutCovariance"
android:visibility="visible" android:paddingBottom="91dp"
android:hint="knockoutCovariance" android:text="enumeratedRtmpdh"
android:textSize="17sp"/> android:textSize="17sp"
android:visibility="visible" />
<LinearLayout <LinearLayout
android:id="@+id/ll_episode" android:id="@+id/ll_episode"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_toLeftOf="@+id/tv_quality"
android:layout_alignParentBottom="true" android:layout_alignParentBottom="true"
android:layout_marginHorizontal="@dimen/dp_15" android:layout_marginHorizontal="@dimen/dp_15"
android:layout_marginBottom="@dimen/dp_15" android:layout_marginBottom="@dimen/dp_15"
@ -89,13 +92,13 @@ android:textSize="17sp"/>
android:paddingVertical="@dimen/dp_5" android:paddingVertical="@dimen/dp_5"
android:textColor="@color/white" android:textColor="@color/white"
android:textSize="@dimen/sp_13" /> android:textSize="@dimen/sp_13" />
<ScrollView
android:visibility="visible" <ScrollView
android:layout_height="0dp" android:layout_width="0dp"
android:paddingLeft="95dp" android:layout_height="0dp"
android:layout_width="0dp" android:orientation="vertical"
android:orientation="vertical"> android:paddingLeft="95dp"
</ScrollView> android:visibility="visible"></ScrollView>
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_episode_player_all" android:id="@+id/tv_episode_player_all"
@ -110,14 +113,29 @@ android:orientation="vertical">
android:text="All 58 Episodes" android:text="All 58 Episodes"
android:textColor="@color/utilsUtils" android:textColor="@color/utilsUtils"
android:textSize="@dimen/sp_13" /> android:textSize="@dimen/sp_13" />
<View
android:layout_width="0dp" <View
android:layout_height="0dp" android:layout_width="0dp"
android:visibility="visible" android:layout_height="0dp"
android:paddingTop="6dp"/> android:paddingTop="6dp"
android:visibility="visible" />
</LinearLayout> </LinearLayout>
<androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_quality"
android:layout_width="@dimen/dp_65"
android:layout_height="wrap_content"
android:layout_alignTop="@+id/ll_episode"
android:layout_alignBottom="@+id/ll_episode"
android:layout_alignParentEnd="true"
android:layout_marginEnd="@dimen/dp_15"
android:text="540P"
android:textColor="@color/white"
android:gravity="center"
android:background="@drawable/t_lock"
/>
<androidx.appcompat.widget.AppCompatTextView <androidx.appcompat.widget.AppCompatTextView
android:id="@+id/tv_player_seek_time" android:id="@+id/tv_player_seek_time"
android:layout_width="wrap_content" android:layout_width="wrap_content"
@ -130,21 +148,22 @@ android:paddingTop="6dp"/>
android:textSize="@dimen/sp_12" android:textSize="@dimen/sp_12"
android:visibility="invisible" android:visibility="invisible"
tools:text="00:00/02:24" /> tools:text="00:00/02:24" />
<ScrollView
android:paddingBottom="53dp" <ScrollView
android:background="#AF907C" android:layout_width="127dp"
android:layout_width="127dp" android:layout_height="7dp"
android:visibility="gone" android:background="#AF907C"
android:orientation="horizontal" android:orientation="horizontal"
android:layout_height="7dp"> android:paddingBottom="53dp"
<LinearLayout android:visibility="gone">
android:paddingLeft="37dp"
android:layout_height="wrap_content" <LinearLayout
android:orientation="vertical" android:layout_width="match_parent"
android:layout_width="match_parent" android:layout_height="wrap_content"
android:visibility="gone"> android:orientation="vertical"
</LinearLayout> android:paddingLeft="37dp"
</ScrollView> android:visibility="gone"></LinearLayout>
</ScrollView>
<androidx.appcompat.widget.LinearLayoutCompat <androidx.appcompat.widget.LinearLayoutCompat
android:id="@+id/ll_bottom_controller" android:id="@+id/ll_bottom_controller"

Binary file not shown.

Before

Width:  |  Height:  |  Size: 32 KiB

After

Width:  |  Height:  |  Size: 24 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 109 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 23 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 16 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 29 KiB

After

Width:  |  Height:  |  Size: 22 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 3.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 207 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.1 KiB

Some files were not shown because too many files have changed in this diff Show More