forked from PeterCxy/OpenEUICC
Compare commits
2 commits
c82cace7fa
...
fe4903605c
Author | SHA1 | Date | |
---|---|---|---|
fe4903605c | |||
d259b034ab |
2 changed files with 27 additions and 24 deletions
|
@ -88,15 +88,12 @@ class ProfileDeleteFragment : DialogFragment(), EuiccChannelFragmentMarker {
|
||||||
requireParentFragment().lifecycleScope.launch {
|
requireParentFragment().lifecycleScope.launch {
|
||||||
ensureEuiccChannelManager()
|
ensureEuiccChannelManager()
|
||||||
euiccChannelManagerService.waitForForegroundTask()
|
euiccChannelManagerService.waitForForegroundTask()
|
||||||
euiccChannelManagerService.launchProfileDeleteTask(slotId, portId, iccid).onStart {
|
euiccChannelManagerService.launchProfileDeleteTask(slotId, portId, iccid)
|
||||||
|
.onStart {
|
||||||
parentFragment?.notifyEuiccProfilesChanged()
|
parentFragment?.notifyEuiccProfilesChanged()
|
||||||
|
runCatching(::dismiss)
|
||||||
try {
|
|
||||||
dismiss()
|
|
||||||
} catch (e: IllegalStateException) {
|
|
||||||
// Ignored
|
|
||||||
}
|
}
|
||||||
}.waitDone()
|
.waitDone()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -7,6 +7,7 @@ import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import android.widget.ProgressBar
|
import android.widget.ProgressBar
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
|
import androidx.annotation.StringRes
|
||||||
import androidx.appcompat.widget.Toolbar
|
import androidx.appcompat.widget.Toolbar
|
||||||
import androidx.lifecycle.lifecycleScope
|
import androidx.lifecycle.lifecycleScope
|
||||||
import com.google.android.material.textfield.TextInputLayout
|
import com.google.android.material.textfield.TextInputLayout
|
||||||
|
@ -18,12 +19,15 @@ import net.typeblog.lpac_jni.LocalProfileAssistant
|
||||||
|
|
||||||
class ProfileRenameFragment : BaseMaterialDialogFragment(), EuiccChannelFragmentMarker {
|
class ProfileRenameFragment : BaseMaterialDialogFragment(), EuiccChannelFragmentMarker {
|
||||||
companion object {
|
companion object {
|
||||||
|
private const val FIELD_ICCID = "iccid"
|
||||||
|
private const val FIELD_CURRENT_NAME = "currentName"
|
||||||
|
|
||||||
const val TAG = "ProfileRenameFragment"
|
const val TAG = "ProfileRenameFragment"
|
||||||
|
|
||||||
fun newInstance(slotId: Int, portId: Int, iccid: String, currentName: String) =
|
fun newInstance(slotId: Int, portId: Int, iccid: String, currentName: String) =
|
||||||
newInstanceEuicc(ProfileRenameFragment::class.java, slotId, portId) {
|
newInstanceEuicc(ProfileRenameFragment::class.java, slotId, portId) {
|
||||||
putString("iccid", iccid)
|
putString(FIELD_ICCID, iccid)
|
||||||
putString("currentName", currentName)
|
putString(FIELD_CURRENT_NAME, currentName)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -33,6 +37,14 @@ class ProfileRenameFragment : BaseMaterialDialogFragment(), EuiccChannelFragment
|
||||||
|
|
||||||
private var renaming = false
|
private var renaming = false
|
||||||
|
|
||||||
|
private val iccid: String by lazy {
|
||||||
|
requireArguments().getString(FIELD_ICCID)!!
|
||||||
|
}
|
||||||
|
|
||||||
|
private val currentName: String by lazy {
|
||||||
|
requireArguments().getString(FIELD_CURRENT_NAME)!!
|
||||||
|
}
|
||||||
|
|
||||||
override fun onCreateView(
|
override fun onCreateView(
|
||||||
inflater: LayoutInflater,
|
inflater: LayoutInflater,
|
||||||
container: ViewGroup?,
|
container: ViewGroup?,
|
||||||
|
@ -51,7 +63,7 @@ class ProfileRenameFragment : BaseMaterialDialogFragment(), EuiccChannelFragment
|
||||||
|
|
||||||
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
||||||
super.onViewCreated(view, savedInstanceState)
|
super.onViewCreated(view, savedInstanceState)
|
||||||
profileRenameNewName.editText!!.setText(requireArguments().getString("currentName"))
|
profileRenameNewName.editText!!.setText(currentName)
|
||||||
toolbar.apply {
|
toolbar.apply {
|
||||||
setTitle(R.string.rename)
|
setTitle(R.string.rename)
|
||||||
setNavigationOnClickListener {
|
setNavigationOnClickListener {
|
||||||
|
@ -75,12 +87,8 @@ class ProfileRenameFragment : BaseMaterialDialogFragment(), EuiccChannelFragment
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun showErrorAndCancel(errorStrRes: Int) {
|
private fun showErrorAndCancel(@StringRes resId: Int) {
|
||||||
Toast.makeText(
|
Toast.makeText(requireContext(), resId, Toast.LENGTH_LONG).show()
|
||||||
requireContext(),
|
|
||||||
errorStrRes,
|
|
||||||
Toast.LENGTH_LONG
|
|
||||||
).show()
|
|
||||||
|
|
||||||
renaming = false
|
renaming = false
|
||||||
progress.visibility = View.GONE
|
progress.visibility = View.GONE
|
||||||
|
@ -91,17 +99,15 @@ class ProfileRenameFragment : BaseMaterialDialogFragment(), EuiccChannelFragment
|
||||||
progress.isIndeterminate = true
|
progress.isIndeterminate = true
|
||||||
progress.visibility = View.VISIBLE
|
progress.visibility = View.VISIBLE
|
||||||
|
|
||||||
|
val newName = profileRenameNewName.editText!!.text.toString().trim()
|
||||||
|
|
||||||
lifecycleScope.launch {
|
lifecycleScope.launch {
|
||||||
ensureEuiccChannelManager()
|
ensureEuiccChannelManager()
|
||||||
euiccChannelManagerService.waitForForegroundTask()
|
euiccChannelManagerService.waitForForegroundTask()
|
||||||
val res = euiccChannelManagerService.launchProfileRenameTask(
|
val response = euiccChannelManagerService
|
||||||
slotId,
|
.launchProfileRenameTask(slotId, portId, iccid, newName).waitDone()
|
||||||
portId,
|
|
||||||
requireArguments().getString("iccid")!!,
|
|
||||||
profileRenameNewName.editText!!.text.toString().trim()
|
|
||||||
).waitDone()
|
|
||||||
|
|
||||||
when (res) {
|
when (response) {
|
||||||
is LocalProfileAssistant.ProfileNameTooLongException -> {
|
is LocalProfileAssistant.ProfileNameTooLongException -> {
|
||||||
showErrorAndCancel(R.string.profile_rename_too_long)
|
showErrorAndCancel(R.string.profile_rename_too_long)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue