package info.nightscout.androidaps.setupwizard import android.content.Intent import android.os.Bundle import android.view.View import android.widget.TextView import dagger.android.HasAndroidInjector import info.nightscout.androidaps.MainActivity import info.nightscout.androidaps.R import info.nightscout.androidaps.activities.NoSplashAppCompatActivity import info.nightscout.androidaps.databinding.ActivitySetupwizardBinding import info.nightscout.androidaps.events.EventProfileSwitchChanged import info.nightscout.androidaps.events.EventProfileStoreChanged import info.nightscout.androidaps.events.EventPumpStatusChanged import info.nightscout.androidaps.logging.UserEntryLogger import info.nightscout.androidaps.plugins.bus.RxBus import info.nightscout.androidaps.plugins.general.nsclient.events.EventNSClientStatus import info.nightscout.androidaps.plugins.profile.local.LocalProfilePlugin import info.nightscout.androidaps.plugins.pump.common.events.EventRileyLinkDeviceStatusChange import info.nightscout.androidaps.setupwizard.elements.SWItem import info.nightscout.androidaps.setupwizard.events.EventSWUpdate import info.nightscout.androidaps.utils.FabricPrivacy import info.nightscout.androidaps.utils.alertDialogs.OKDialog import info.nightscout.androidaps.utils.locale.LocaleHelper.update import info.nightscout.androidaps.utils.rx.AapsSchedulers import info.nightscout.shared.sharedPreferences.SP import io.reactivex.rxjava3.disposables.CompositeDisposable import javax.inject.Inject import kotlin.math.max import kotlin.math.min class SetupWizardActivity : NoSplashAppCompatActivity() { @Inject lateinit var injector: HasAndroidInjector @Inject lateinit var localProfilePlugin: LocalProfilePlugin @Inject lateinit var swDefinition: SWDefinition @Inject lateinit var sp: SP @Inject lateinit var fabricPrivacy: FabricPrivacy @Inject lateinit var aapsSchedulers: AapsSchedulers @Inject lateinit var uel: UserEntryLogger private val disposable = CompositeDisposable() private lateinit var screens: List private var currentWizardPage = 0 private val intentMessage = "WIZZARDPAGE" private lateinit var binding: ActivitySetupwizardBinding override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) update(applicationContext) binding = ActivitySetupwizardBinding.inflate(layoutInflater) setContentView(binding.root) screens = swDefinition.getScreens() val intent = intent currentWizardPage = intent.getIntExtra(intentMessage, 0) if (screens.isNotEmpty() && currentWizardPage < screens.size) { val currentScreen = screens[currentWizardPage] //Set screen name val screenName = findViewById(R.id.sw_content) screenName.text = currentScreen.getHeader() swDefinition.activity = this //Generate layout first generateLayout() updateButtons() } } override fun onPause() { super.onPause() disposable.clear() } override fun onResume() { super.onResume() swDefinition.activity = this disposable.add(rxBus .toObservable(EventPumpStatusChanged::class.java) .observeOn(aapsSchedulers.main) .subscribe({ updateButtons() }, fabricPrivacy::logException) ) disposable.add(rxBus .toObservable(EventRileyLinkDeviceStatusChange::class.java) .observeOn(aapsSchedulers.main) .subscribe({ updateButtons() }, fabricPrivacy::logException) ) disposable.add(rxBus .toObservable(EventNSClientStatus::class.java) .observeOn(aapsSchedulers.main) .subscribe({ updateButtons() }, fabricPrivacy::logException) ) disposable.add(rxBus .toObservable(EventProfileSwitchChanged::class.java) .observeOn(aapsSchedulers.main) .subscribe({ updateButtons() }, fabricPrivacy::logException) ) disposable.add(rxBus .toObservable(EventProfileStoreChanged::class.java) .observeOn(aapsSchedulers.main) .subscribe({ updateButtons() }, fabricPrivacy::logException) ) disposable.add(rxBus .toObservable(EventSWUpdate::class.java) .observeOn(aapsSchedulers.main) .subscribe({ event: EventSWUpdate -> if (event.redraw) generateLayout() updateButtons() }, fabricPrivacy::logException) ) updateButtons() } private fun generateLayout() { val currentScreen = screens[currentWizardPage] val layout = SWItem(injector, SWItem.Type.NONE).generateLayout(findViewById(R.id.sw_content_fields)) for (i in currentScreen.items.indices) { val currentItem = currentScreen.items[i] currentItem.generateDialog(layout) } binding.swScrollview.smoothScrollTo(0, 0) } override fun updateButtons() { runOnUiThread { val currentScreen = screens[currentWizardPage] if (currentScreen.validator == null || currentScreen.validator?.isValid == true || currentScreen.skippable) { if (currentWizardPage == nextPage(null)) { findViewById(R.id.finish_button).visibility = View.VISIBLE findViewById(R.id.next_button).visibility = View.GONE } else { findViewById(R.id.finish_button).visibility = View.GONE findViewById(R.id.next_button).visibility = View.VISIBLE } } else { findViewById(R.id.finish_button).visibility = View.GONE findViewById(R.id.next_button).visibility = View.GONE } if (currentWizardPage == 0) findViewById(R.id.previous_button).visibility = View.GONE else findViewById(R.id.previous_button).visibility = View.VISIBLE currentScreen.processVisibility() } } override fun onBackPressed() { if (currentWizardPage == 0) OKDialog.showConfirmation(this, rh.gs(R.string.exitwizard)) { finish() } else showPreviousPage(null) } @Suppress("UNUSED_PARAMETER") fun exitPressed(view: View?) { sp.putBoolean(R.string.key_setupwizard_processed, true) OKDialog.showConfirmation(this, rh.gs(R.string.exitwizard)) { finish() } } @Suppress("UNUSED_PARAMETER") fun showNextPage(view: View?) { finish() val intent = Intent(this, SetupWizardActivity::class.java) intent.putExtra(intentMessage, nextPage(null)) startActivity(intent) } @Suppress("UNUSED_PARAMETER") fun showPreviousPage(view: View?) { finish() val intent = Intent(this, SetupWizardActivity::class.java) intent.putExtra(intentMessage, previousPage(null)) startActivity(intent) } // Go back to overview @Suppress("UNUSED_PARAMETER") fun finishSetupWizard(view: View?) { sp.putBoolean(R.string.key_setupwizard_processed, true) val intent = Intent(this, MainActivity::class.java) intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP) startActivity(intent) finish() } @Suppress("UNUSED_PARAMETER", "SameParameterValue") private fun nextPage(view: View?): Int { var page = currentWizardPage + 1 while (page < screens.size) { if (screens[page].visibility == null || screens[page].visibility?.isValid == true) return page page++ } return min(currentWizardPage, screens.size - 1) } @Suppress("UNUSED_PARAMETER", "SameParameterValue") private fun previousPage(view: View?): Int { var page = currentWizardPage - 1 while (page >= 0) { if (screens[page].visibility == null || screens[page].visibility?.isValid == true) return page page-- } return max(currentWizardPage, 0) } }