1 /* <lambda>null2 * Copyright (C) 2023 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 * 16 * 17 */ 18 19 package com.android.healthconnect.controller.data 20 21 import android.os.Bundle 22 import androidx.activity.viewModels 23 import androidx.navigation.findNavController 24 import com.android.healthconnect.controller.R 25 import com.android.healthconnect.controller.migration.MigrationActivity 26 import com.android.healthconnect.controller.migration.MigrationActivity.Companion.maybeRedirectToMigrationActivity 27 import com.android.healthconnect.controller.migration.MigrationActivity.Companion.maybeShowWhatsNewDialog 28 import com.android.healthconnect.controller.migration.MigrationViewModel 29 import com.android.healthconnect.controller.migration.api.MigrationState 30 import com.android.healthconnect.controller.navigation.DestinationChangedListener 31 import com.android.healthconnect.controller.onboarding.OnboardingActivity.Companion.maybeRedirectToOnboardingActivity 32 import com.android.healthconnect.controller.utils.activity.EmbeddingUtils.maybeRedirectIntoTwoPaneSettings 33 import com.android.settingslib.collapsingtoolbar.CollapsingToolbarBaseActivity 34 import dagger.hilt.android.AndroidEntryPoint 35 import kotlinx.coroutines.runBlocking 36 37 /** Entry point activity for Health Connect Data Management controllers. */ 38 @AndroidEntryPoint(CollapsingToolbarBaseActivity::class) 39 class DataManagementActivity : Hilt_DataManagementActivity() { 40 private val migrationViewModel: MigrationViewModel by viewModels() 41 42 override fun onCreate(savedInstanceState: Bundle?) { 43 super.onCreate(savedInstanceState) 44 setContentView(R.layout.activity_data_management) 45 46 if (maybeRedirectIntoTwoPaneSettings(this)) { 47 return 48 } 49 50 if (maybeRedirectToOnboardingActivity(this, intent)) { 51 return 52 } 53 54 val currentMigrationState = runBlocking { migrationViewModel.getCurrentMigrationUiState() } 55 56 if (maybeRedirectToMigrationActivity(this, currentMigrationState)) { 57 return 58 } 59 60 migrationViewModel.migrationState.observe(this) { migrationState -> 61 when (migrationState) { 62 is MigrationViewModel.MigrationFragmentState.WithData -> { 63 if (migrationState.migrationState == MigrationState.COMPLETE) { 64 maybeShowWhatsNewDialog(this) 65 } 66 } 67 else -> { 68 // do nothing 69 } 70 } 71 } 72 } 73 74 override fun onStart() { 75 super.onStart() 76 findNavController(R.id.nav_host_fragment) 77 .addOnDestinationChangedListener(DestinationChangedListener(this)) 78 } 79 80 override fun onResume() { 81 super.onResume() 82 val currentMigrationState = runBlocking { migrationViewModel.getCurrentMigrationUiState() } 83 84 if (MigrationActivity.maybeRedirectToMigrationActivity(this, currentMigrationState)) { 85 return 86 } 87 } 88 89 override fun onBackPressed() { 90 val navController = findNavController(R.id.nav_host_fragment) 91 if (!navController.popBackStack()) { 92 finish() 93 } 94 } 95 96 override fun onNavigateUp(): Boolean { 97 val navController = findNavController(R.id.nav_host_fragment) 98 if (!navController.popBackStack()) { 99 finish() 100 } 101 return true 102 } 103 } 104