You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
93 lines
3.3 KiB
Kotlin
93 lines
3.3 KiB
Kotlin
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
package org.mozilla.fenix.settings.address
|
|
|
|
import android.os.Bundle
|
|
import android.view.LayoutInflater
|
|
import android.view.View
|
|
import android.view.ViewGroup
|
|
import androidx.compose.ui.platform.ComposeView
|
|
import androidx.fragment.app.Fragment
|
|
import androidx.lifecycle.lifecycleScope
|
|
import androidx.navigation.fragment.findNavController
|
|
import kotlinx.coroutines.Dispatchers
|
|
import kotlinx.coroutines.launch
|
|
import mozilla.components.lib.state.ext.consumeFrom
|
|
import mozilla.components.lib.state.ext.observeAsComposableState
|
|
import org.mozilla.fenix.components.StoreProvider
|
|
import org.mozilla.fenix.ext.components
|
|
import org.mozilla.fenix.settings.address.controller.DefaultAddressManagementController
|
|
import org.mozilla.fenix.settings.address.interactor.AddressManagementInteractor
|
|
import org.mozilla.fenix.settings.address.interactor.DefaultAddressManagementInteractor
|
|
import org.mozilla.fenix.settings.address.view.AddressList
|
|
import org.mozilla.fenix.settings.autofill.AutofillAction
|
|
import org.mozilla.fenix.settings.autofill.AutofillFragmentState
|
|
import org.mozilla.fenix.settings.autofill.AutofillFragmentStore
|
|
import org.mozilla.fenix.theme.FirefoxTheme
|
|
|
|
/**
|
|
* Displays a list of saved addresses.
|
|
*/
|
|
class AddressManagementFragment : Fragment() {
|
|
|
|
private lateinit var store: AutofillFragmentStore
|
|
private lateinit var interactor: AddressManagementInteractor
|
|
|
|
override fun onCreateView(
|
|
inflater: LayoutInflater,
|
|
container: ViewGroup?,
|
|
savedInstanceState: Bundle?
|
|
): View {
|
|
store = StoreProvider.get(this) {
|
|
AutofillFragmentStore(AutofillFragmentState())
|
|
}
|
|
|
|
interactor = DefaultAddressManagementInteractor(
|
|
controller = DefaultAddressManagementController(
|
|
navController = findNavController()
|
|
)
|
|
)
|
|
|
|
loadAddresses()
|
|
|
|
return ComposeView(requireContext()).apply {
|
|
setContent {
|
|
FirefoxTheme {
|
|
val addresses = store.observeAsComposableState { state -> state.addresses }
|
|
|
|
AddressList(
|
|
addresses = addresses.value ?: emptyList(),
|
|
onAddressClick = interactor::onSelectAddress,
|
|
onAddAddressButtonClick = interactor::onAddAddressButtonClick
|
|
)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
|
consumeFrom(store) { state ->
|
|
if (!state.isLoading && state.addresses.isEmpty()) {
|
|
findNavController().popBackStack()
|
|
return@consumeFrom
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Fetches all the addresses from the autofill storage and updates the
|
|
* [AutofillFragmentStore] with the list of addresses.
|
|
*/
|
|
private fun loadAddresses() {
|
|
lifecycleScope.launch {
|
|
val addresses = requireContext().components.core.autofillStorage.getAllAddresses()
|
|
|
|
lifecycleScope.launch(Dispatchers.Main) {
|
|
store.dispatch(AutofillAction.UpdateAddresses(addresses))
|
|
}
|
|
}
|
|
}
|
|
}
|