|
|
@ -4,7 +4,6 @@
|
|
|
|
|
|
|
|
|
|
|
|
package org.mozilla.fenix.settings.creditcards.controller
|
|
|
|
package org.mozilla.fenix.settings.creditcards.controller
|
|
|
|
|
|
|
|
|
|
|
|
import android.content.Context
|
|
|
|
|
|
|
|
import androidx.navigation.NavController
|
|
|
|
import androidx.navigation.NavController
|
|
|
|
import kotlinx.coroutines.CoroutineDispatcher
|
|
|
|
import kotlinx.coroutines.CoroutineDispatcher
|
|
|
|
import kotlinx.coroutines.CoroutineScope
|
|
|
|
import kotlinx.coroutines.CoroutineScope
|
|
|
@ -13,10 +12,8 @@ import kotlinx.coroutines.launch
|
|
|
|
import mozilla.components.concept.storage.NewCreditCardFields
|
|
|
|
import mozilla.components.concept.storage.NewCreditCardFields
|
|
|
|
import mozilla.components.concept.storage.UpdatableCreditCardFields
|
|
|
|
import mozilla.components.concept.storage.UpdatableCreditCardFields
|
|
|
|
import mozilla.components.service.sync.autofill.AutofillCreditCardsAddressesStorage
|
|
|
|
import mozilla.components.service.sync.autofill.AutofillCreditCardsAddressesStorage
|
|
|
|
import org.mozilla.fenix.components.metrics.Event
|
|
|
|
|
|
|
|
import org.mozilla.fenix.settings.creditcards.CreditCardEditorFragment
|
|
|
|
import org.mozilla.fenix.settings.creditcards.CreditCardEditorFragment
|
|
|
|
import org.mozilla.fenix.settings.creditcards.interactor.CreditCardEditorInteractor
|
|
|
|
import org.mozilla.fenix.settings.creditcards.interactor.CreditCardEditorInteractor
|
|
|
|
import org.mozilla.fenix.ext.components
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
/**
|
|
|
|
* [CreditCardEditorFragment] controller. An interface that handles the view manipulation of the
|
|
|
|
* [CreditCardEditorFragment] controller. An interface that handles the view manipulation of the
|
|
|
@ -55,15 +52,12 @@ interface CreditCardEditorController {
|
|
|
|
* @param ioDispatcher [CoroutineDispatcher] used for executing async tasks. Defaults to [Dispatchers.IO].
|
|
|
|
* @param ioDispatcher [CoroutineDispatcher] used for executing async tasks. Defaults to [Dispatchers.IO].
|
|
|
|
*/
|
|
|
|
*/
|
|
|
|
class DefaultCreditCardEditorController(
|
|
|
|
class DefaultCreditCardEditorController(
|
|
|
|
context: Context,
|
|
|
|
|
|
|
|
private val storage: AutofillCreditCardsAddressesStorage,
|
|
|
|
private val storage: AutofillCreditCardsAddressesStorage,
|
|
|
|
private val lifecycleScope: CoroutineScope,
|
|
|
|
private val lifecycleScope: CoroutineScope,
|
|
|
|
private val navController: NavController,
|
|
|
|
private val navController: NavController,
|
|
|
|
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO
|
|
|
|
private val ioDispatcher: CoroutineDispatcher = Dispatchers.IO
|
|
|
|
) : CreditCardEditorController {
|
|
|
|
) : CreditCardEditorController {
|
|
|
|
|
|
|
|
|
|
|
|
private val metrics = context.components.analytics.metrics
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
override fun handleCancelButtonClicked() {
|
|
|
|
override fun handleCancelButtonClicked() {
|
|
|
|
navController.popBackStack()
|
|
|
|
navController.popBackStack()
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -71,7 +65,6 @@ class DefaultCreditCardEditorController(
|
|
|
|
override fun handleDeleteCreditCard(guid: String) {
|
|
|
|
override fun handleDeleteCreditCard(guid: String) {
|
|
|
|
lifecycleScope.launch(ioDispatcher) {
|
|
|
|
lifecycleScope.launch(ioDispatcher) {
|
|
|
|
storage.deleteCreditCard(guid)
|
|
|
|
storage.deleteCreditCard(guid)
|
|
|
|
metrics.track(Event.CreditCardDelete)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lifecycleScope.launch(Dispatchers.Main) {
|
|
|
|
lifecycleScope.launch(Dispatchers.Main) {
|
|
|
|
navController.popBackStack()
|
|
|
|
navController.popBackStack()
|
|
|
@ -82,7 +75,6 @@ class DefaultCreditCardEditorController(
|
|
|
|
override fun handleSaveCreditCard(creditCardFields: NewCreditCardFields) {
|
|
|
|
override fun handleSaveCreditCard(creditCardFields: NewCreditCardFields) {
|
|
|
|
lifecycleScope.launch(ioDispatcher) {
|
|
|
|
lifecycleScope.launch(ioDispatcher) {
|
|
|
|
storage.addCreditCard(creditCardFields)
|
|
|
|
storage.addCreditCard(creditCardFields)
|
|
|
|
metrics.track(Event.CreditCardManualSave)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
lifecycleScope.launch(Dispatchers.Main) {
|
|
|
|
lifecycleScope.launch(Dispatchers.Main) {
|
|
|
|
navController.popBackStack()
|
|
|
|
navController.popBackStack()
|
|
|
|