mirror of
https://github.com/whyorean/AuroraStore.git
synced 2026-06-12 01:38:35 -04:00
Fix force close issue when network connectivity changes
This commit is contained in:
@@ -70,6 +70,18 @@ class MainActivity : BaseActivity() {
|
||||
|
||||
private var lastBackPressed = 0L
|
||||
|
||||
override fun onConnected() {
|
||||
hideNetworkConnectivitySheet()
|
||||
}
|
||||
|
||||
override fun onDisconnected() {
|
||||
showNetworkConnectivitySheet()
|
||||
}
|
||||
|
||||
override fun onReconnected() {
|
||||
|
||||
}
|
||||
|
||||
companion object {
|
||||
@JvmStatic
|
||||
private fun matchDestination(
|
||||
@@ -220,18 +232,6 @@ class MainActivity : BaseActivity() {
|
||||
}
|
||||
}
|
||||
|
||||
override fun onConnected() {
|
||||
hideNetworkConnectivitySheet()
|
||||
}
|
||||
|
||||
override fun onDisconnected() {
|
||||
showNetworkConnectivitySheet()
|
||||
}
|
||||
|
||||
override fun onReconnected() {
|
||||
|
||||
}
|
||||
|
||||
private fun pickExternalFileDir() {
|
||||
val getContentIntent = Intent(Intent.ACTION_GET_CONTENT)
|
||||
getContentIntent.type = "*/*"
|
||||
|
||||
@@ -24,7 +24,6 @@ import android.content.Intent
|
||||
import android.os.Build
|
||||
import android.os.Bundle
|
||||
import androidx.appcompat.app.AppCompatActivity
|
||||
import androidx.fragment.app.Fragment
|
||||
import com.aurora.Constants
|
||||
import com.aurora.extensions.applyTheme
|
||||
import com.aurora.extensions.getEmptyActivityBundle
|
||||
@@ -138,24 +137,25 @@ abstract class BaseActivity : AppCompatActivity(), NetworkProvider.NetworkListen
|
||||
}
|
||||
|
||||
fun showNetworkConnectivitySheet() {
|
||||
supportFragmentManager.beginTransaction()
|
||||
.add(NetworkDialogSheet.newInstance(0), "NDS")
|
||||
.commitAllowingStateLoss()
|
||||
runOnUiThread {
|
||||
supportFragmentManager.beginTransaction()
|
||||
.add(NetworkDialogSheet.newInstance(), NetworkDialogSheet.TAG)
|
||||
.commitAllowingStateLoss()
|
||||
}
|
||||
}
|
||||
|
||||
fun hideNetworkConnectivitySheet() {
|
||||
val fragment: Fragment? = supportFragmentManager.findFragmentByTag("NDS")
|
||||
if (fragment != null) {
|
||||
supportFragmentManager.beginTransaction()
|
||||
.remove(fragment)
|
||||
.commitAllowingStateLoss()
|
||||
runOnUiThread {
|
||||
val fragment = supportFragmentManager.findFragmentByTag(NetworkDialogSheet.TAG)
|
||||
fragment?.let {
|
||||
supportFragmentManager.beginTransaction().remove(fragment).commitAllowingStateLoss()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
override fun onStart() {
|
||||
super.onStart()
|
||||
NetworkProvider.addListener(this)
|
||||
|
||||
}
|
||||
|
||||
override fun onStop() {
|
||||
|
||||
@@ -23,22 +23,20 @@ import android.os.Bundle
|
||||
import android.view.LayoutInflater
|
||||
import android.view.View
|
||||
import android.view.ViewGroup
|
||||
import com.aurora.Constants
|
||||
import com.aurora.store.databinding.SheetNetworkBinding
|
||||
|
||||
class NetworkDialogSheet : BaseBottomSheet() {
|
||||
|
||||
lateinit var B: SheetNetworkBinding
|
||||
|
||||
private var type = 0
|
||||
|
||||
companion object {
|
||||
|
||||
const val TAG = "NetworkDialogSheet"
|
||||
|
||||
@JvmStatic
|
||||
fun newInstance(type: Int): NetworkDialogSheet {
|
||||
fun newInstance(): NetworkDialogSheet {
|
||||
return NetworkDialogSheet().apply {
|
||||
arguments = Bundle().apply {
|
||||
putInt(Constants.INT_EXTRA, type)
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -47,18 +45,14 @@ class NetworkDialogSheet : BaseBottomSheet() {
|
||||
inflater: LayoutInflater,
|
||||
container: ViewGroup,
|
||||
savedInstanceState: Bundle?
|
||||
): View? {
|
||||
): View {
|
||||
B = SheetNetworkBinding.inflate(inflater, container, false)
|
||||
|
||||
val bundle = arguments
|
||||
if (bundle != null) {
|
||||
type = bundle.getInt(Constants.INT_EXTRA, 0)
|
||||
}
|
||||
|
||||
return B.root
|
||||
}
|
||||
|
||||
override fun onContentViewCreated(view: View, savedInstanceState: Bundle?) {
|
||||
|
||||
B.btnAction.setOnClickListener {
|
||||
dismissAllowingStateLoss()
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -24,20 +24,10 @@
|
||||
android:orientation="vertical"
|
||||
android:padding="@dimen/padding_small">
|
||||
|
||||
|
||||
<androidx.appcompat.widget.AppCompatTextView
|
||||
android:id="@+id/title"
|
||||
style="@style/AuroraTextStyle.Title"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_centerHorizontal="true"
|
||||
android:text="Network" />
|
||||
|
||||
<androidx.appcompat.widget.AppCompatImageView
|
||||
android:id="@+id/animationView"
|
||||
android:layout_width="176dp"
|
||||
android:layout_height="176dp"
|
||||
android:layout_below="@id/title"
|
||||
android:id="@+id/img"
|
||||
android:layout_width="@dimen/icon_size_avatar"
|
||||
android:layout_height="@dimen/icon_size_avatar"
|
||||
android:layout_centerHorizontal="true"
|
||||
android:layout_marginTop="@dimen/margin_normal"
|
||||
android:layout_marginBottom="@dimen/margin_normal"
|
||||
@@ -45,19 +35,20 @@
|
||||
|
||||
<androidx.appcompat.widget.AppCompatTextView
|
||||
android:id="@+id/txt_warning"
|
||||
style="@style/AuroraTextStyle.Line1"
|
||||
style="@style/AuroraTextStyle.Subtitle"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_below="@id/animationView"
|
||||
android:text="No network!"
|
||||
android:layout_below="@id/img"
|
||||
android:text="@string/title_no_network"
|
||||
android:textAlignment="center" />
|
||||
|
||||
<com.google.android.material.button.MaterialButton
|
||||
style="@style/Widget.MaterialComponents.Button.UnelevatedButton"
|
||||
android:id="@+id/btn_action"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:layout_below="@+id/txt_warning"
|
||||
android:layout_centerHorizontal="true"
|
||||
android:layout_marginTop="@dimen/margin_normal"
|
||||
android:text="Try Later" />
|
||||
android:text="@string/action_try_later" />
|
||||
</RelativeLayout>
|
||||
@@ -115,6 +115,7 @@
|
||||
<string name="action_skip">"Skip"</string>
|
||||
<string name="action_spoofed">"Spoof"</string>
|
||||
<string name="action_submit">"Submit"</string>
|
||||
<string name="action_try_later">"Try later"</string>
|
||||
<string name="action_uninstall">"Uninstall"</string>
|
||||
<string name="action_info">"App Info"</string>
|
||||
<string name="action_update">"Update"</string>
|
||||
@@ -310,6 +311,7 @@
|
||||
<string name="title_installer">"App Installer"</string>
|
||||
<string name="title_language">"Language"</string>
|
||||
<string name="title_library">"Library"</string>
|
||||
<string name="title_no_network">"No network"</string>
|
||||
<string name="title_purchase_history">"Purchase history"</string>
|
||||
<string name="title_settings">"Settings"</string>
|
||||
<string name="title_spoof_manager">"Spoof manager"</string>
|
||||
|
||||
Reference in New Issue
Block a user