diff --git a/app/src/main/java/com/stevesoltys/seedvault/restore/RestoreViewModel.kt b/app/src/main/java/com/stevesoltys/seedvault/restore/RestoreViewModel.kt index 0912fbe2..6a838828 100644 --- a/app/src/main/java/com/stevesoltys/seedvault/restore/RestoreViewModel.kt +++ b/app/src/main/java/com/stevesoltys/seedvault/restore/RestoreViewModel.kt @@ -46,6 +46,7 @@ import org.calyxos.backup.storage.api.SnapshotItem import org.calyxos.backup.storage.api.StorageBackup import org.calyxos.backup.storage.restore.RestoreService.Companion.EXTRA_TIMESTAMP_START import org.calyxos.backup.storage.restore.RestoreService.Companion.EXTRA_USER_ID +import org.calyxos.backup.storage.ui.restore.FileSelectionManager import org.calyxos.backup.storage.ui.restore.SnapshotViewModel import java.util.LinkedList @@ -98,6 +99,8 @@ internal class RestoreViewModel( get() = appDataRestoreManager.restoreBackupResult override val snapshots = storageBackup.getBackupSnapshots().asLiveData(ioDispatcher) + override val fileSelectionManager: FileSelectionManager + get() = TODO("Not yet implemented") internal fun loadRestoreSets() = viewModelScope.launch(ioDispatcher) { val backups = restoreCoordinator.getAvailableMetadata()?.mapNotNull { (token, metadata) -> diff --git a/storage/demo/src/main/java/de/grobox/storagebackuptester/MainViewModel.kt b/storage/demo/src/main/java/de/grobox/storagebackuptester/MainViewModel.kt index 18159b27..a0dd1728 100644 --- a/storage/demo/src/main/java/de/grobox/storagebackuptester/MainViewModel.kt +++ b/storage/demo/src/main/java/de/grobox/storagebackuptester/MainViewModel.kt @@ -28,6 +28,7 @@ import org.calyxos.backup.storage.backup.BackupJobService import org.calyxos.backup.storage.scanner.DocumentScanner import org.calyxos.backup.storage.scanner.MediaScanner import org.calyxos.backup.storage.ui.backup.BackupContentViewModel +import org.calyxos.backup.storage.ui.restore.FileSelectionManager import org.calyxos.backup.storage.ui.restore.SnapshotViewModel private val logEmptyState = """ @@ -47,6 +48,7 @@ class MainViewModel(application: Application) : BackupContentViewModel(applicati private val app: App = application as App private val settingsManager = app.settingsManager override val storageBackup: StorageBackup = app.storageBackup + override val fileSelectionManager = FileSelectionManager() private val _backupLog = MutableLiveData(BackupProgress(0, 0, logEmptyState)) val backupLog: LiveData = _backupLog @@ -124,6 +126,11 @@ class MainViewModel(application: Application) : BackupContentViewModel(applicati } fun onSnapshotClicked(item: SnapshotItem) { + val snapshot = item.snapshot ?: error("${item.storedSnapshot} had null snapshot") + fileSelectionManager.onSnapshotChosen(snapshot) + } + + fun onFilesSelected(item: SnapshotItem) { val snapshot = item.snapshot check(snapshot != null) diff --git a/storage/demo/src/main/java/de/grobox/storagebackuptester/restore/DemoFileSelectionFragment.kt b/storage/demo/src/main/java/de/grobox/storagebackuptester/restore/DemoFileSelectionFragment.kt new file mode 100644 index 00000000..35afa54c --- /dev/null +++ b/storage/demo/src/main/java/de/grobox/storagebackuptester/restore/DemoFileSelectionFragment.kt @@ -0,0 +1,36 @@ +/* + * SPDX-FileCopyrightText: 2021 The Calyx Institute + * SPDX-License-Identifier: Apache-2.0 + */ + +package de.grobox.storagebackuptester.restore + +import android.os.Bundle +import android.view.LayoutInflater +import android.view.View +import android.view.ViewGroup +import androidx.fragment.app.activityViewModels +import de.grobox.storagebackuptester.MainViewModel +import org.calyxos.backup.storage.ui.restore.FileSelectionFragment + +class DemoFileSelectionFragment : FileSelectionFragment() { + + override val viewModel: MainViewModel by activityViewModels() + + override fun onCreateView( + inflater: LayoutInflater, + container: ViewGroup?, + savedInstanceState: Bundle?, + ): View { + val v = super.onCreateView(inflater, container, savedInstanceState) + // val topStub: ViewStub = v.findViewById(R.id.topStub) + // topStub.layoutResource = R.layout.footer_snapshot + // val header = topStub.inflate() + // header.findViewById