More WIP on new Omnipod wizard
This commit is contained in:
parent
8563817bae
commit
bc817d10f9
22 changed files with 207 additions and 99 deletions
|
@ -266,6 +266,8 @@ dependencies {
|
||||||
implementation "androidx.activity:activity-ktx:${activityVersion}"
|
implementation "androidx.activity:activity-ktx:${activityVersion}"
|
||||||
implementation "androidx.fragment:fragment:${fragmentVersion}"
|
implementation "androidx.fragment:fragment:${fragmentVersion}"
|
||||||
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
|
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
|
||||||
|
implementation "androidx.navigation:navigation-fragment-ktx:$nav_version"
|
||||||
|
implementation "androidx.navigation:navigation-ui-ktx:$nav_version"
|
||||||
implementation 'com.google.android.material:material:1.1.0'
|
implementation 'com.google.android.material:material:1.1.0'
|
||||||
|
|
||||||
implementation "io.reactivex.rxjava2:rxandroid:${rxandroid_version}"
|
implementation "io.reactivex.rxjava2:rxandroid:${rxandroid_version}"
|
||||||
|
|
|
@ -76,6 +76,7 @@ dependencies {
|
||||||
implementation "androidx.preference:preference-ktx:1.1.1"
|
implementation "androidx.preference:preference-ktx:1.1.1"
|
||||||
implementation "androidx.activity:activity-ktx:${activityVersion}"
|
implementation "androidx.activity:activity-ktx:${activityVersion}"
|
||||||
implementation "androidx.fragment:fragment:${fragmentVersion}"
|
implementation "androidx.fragment:fragment:${fragmentVersion}"
|
||||||
|
implementation 'androidx.constraintlayout:constraintlayout:2.0.1'
|
||||||
implementation 'com.google.android.material:material:1.1.0'
|
implementation 'com.google.android.material:material:1.1.0'
|
||||||
|
|
||||||
implementation 'com.google.firebase:firebase-analytics-ktx:17.4.3'
|
implementation 'com.google.firebase:firebase-analytics-ktx:17.4.3'
|
||||||
|
@ -103,6 +104,8 @@ dependencies {
|
||||||
implementation "androidx.navigation:navigation-fragment-ktx:$nav_version"
|
implementation "androidx.navigation:navigation-fragment-ktx:$nav_version"
|
||||||
implementation "androidx.navigation:navigation-ui-ktx:$nav_version"
|
implementation "androidx.navigation:navigation-ui-ktx:$nav_version"
|
||||||
|
|
||||||
|
implementation 'com.google.android.material:material:1.1.0'
|
||||||
|
|
||||||
testImplementation 'junit:junit:4.13'
|
testImplementation 'junit:junit:4.13'
|
||||||
testImplementation "org.mockito:mockito-core:2.8.47"
|
testImplementation "org.mockito:mockito-core:2.8.47"
|
||||||
testImplementation "org.powermock:powermock-api-mockito2:$powermockVersion"
|
testImplementation "org.powermock:powermock-api-mockito2:$powermockVersion"
|
||||||
|
|
|
@ -1,7 +1,9 @@
|
||||||
package info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2
|
package info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2
|
||||||
|
|
||||||
|
import android.app.AlertDialog
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.os.PersistableBundle
|
import androidx.annotation.IdRes
|
||||||
|
import androidx.navigation.NavController
|
||||||
import androidx.navigation.fragment.NavHostFragment
|
import androidx.navigation.fragment.NavHostFragment
|
||||||
import info.nightscout.androidaps.activities.NoSplashAppCompatActivity
|
import info.nightscout.androidaps.activities.NoSplashAppCompatActivity
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
||||||
|
@ -17,37 +19,67 @@ class ReplacePodWizardActivity : NoSplashAppCompatActivity() {
|
||||||
@Inject
|
@Inject
|
||||||
lateinit var podStateManager: PodStateManager
|
lateinit var podStateManager: PodStateManager
|
||||||
|
|
||||||
var startDestination: Int = R.id.deactivatePodInfoFragment
|
@IdRes
|
||||||
get() = field
|
private var startDestination: Int = R.id.deactivatePodInfoFragment
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
|
|
||||||
if (savedInstanceState == null) {
|
startDestination = savedInstanceState?.getInt(KEY_START_DESTINATION, R.id.deactivatePodInfoFragment)
|
||||||
|
?: if (!podStateManager.isPodActivationCompleted) {
|
||||||
|
if (!podStateManager.isPodInitialized || podStateManager.podProgressStatus.isBefore(PodProgressStatus.PRIMING_COMPLETED)) {
|
||||||
|
R.id.fillPodInfoFragment
|
||||||
|
} else {
|
||||||
|
R.id.attachPodInfoFragment
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
R.id.deactivatePodInfoFragment
|
||||||
|
}
|
||||||
|
|
||||||
setContentView(R.layout.omnipod_replace_pod_wizard_activity)
|
setContentView(R.layout.omnipod_replace_pod_wizard_activity)
|
||||||
|
|
||||||
val navHostFragment = supportFragmentManager.findFragmentById(R.id.nav_host_fragment) as NavHostFragment
|
val navController = getNavController()
|
||||||
val navController = navHostFragment.navController
|
|
||||||
|
if (savedInstanceState == null) {
|
||||||
val navInflater = navController.navInflater
|
val navInflater = navController.navInflater
|
||||||
val graph = navInflater.inflate(R.navigation.omnipod_replace_pod_wizard_navigation_graph)
|
val graph = navInflater.inflate(R.navigation.omnipod_replace_pod_wizard_navigation_graph)
|
||||||
|
|
||||||
if (!podStateManager.isPodActivationCompleted) {
|
graph.startDestination = startDestination
|
||||||
if (!podStateManager.isPodInitialized || podStateManager.podProgressStatus.isBefore(PodProgressStatus.PRIMING_COMPLETED)) {
|
|
||||||
startDestination = R.id.fillPodInfoFragment
|
|
||||||
} else {
|
|
||||||
startDestination = R.id.attachPodInfoFragment
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
graph.startDestination = startDestination;
|
|
||||||
navController.graph = graph
|
navController.graph = graph
|
||||||
} else {
|
}
|
||||||
startDestination = savedInstanceState.getInt(KEY_START_DESTINATION, R.id.deactivatePodInfoFragment)
|
|
||||||
|
navController.addOnDestinationChangedListener { controller, destination, _ ->
|
||||||
|
if (destination.id == R.id.deactivatePodInfoFragment) {
|
||||||
|
startDestination = R.id.deactivatePodInfoFragment
|
||||||
|
controller.graph.startDestination = R.id.deactivatePodInfoFragment
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun onSaveInstanceState(outState: Bundle?, outPersistentState: PersistableBundle?) {
|
override fun onSaveInstanceState(outState: Bundle) {
|
||||||
super.onSaveInstanceState(outState, outPersistentState)
|
super.onSaveInstanceState(outState)
|
||||||
outState?.putInt(KEY_START_DESTINATION, startDestination)
|
outState.putInt(KEY_START_DESTINATION, startDestination)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
override fun onBackPressed() {
|
||||||
|
exitActivityAfterConfirmation()
|
||||||
|
}
|
||||||
|
|
||||||
|
fun exitActivityAfterConfirmation() {
|
||||||
|
if (getNavController().previousBackStackEntry == null) {
|
||||||
|
finish()
|
||||||
|
} else {
|
||||||
|
AlertDialog.Builder(this)
|
||||||
|
.setIcon(android.R.drawable.ic_dialog_alert)
|
||||||
|
.setTitle(getString(R.string.omnipod_replace_pod_wizard_replace_pod))
|
||||||
|
.setMessage(getString(R.string.omnipod_replace_pod_wizard_exit_confirmation))
|
||||||
|
.setPositiveButton(getString(R.string.omnipod_yes)) { _, _ -> finish() }
|
||||||
|
.setNegativeButton(getString(R.string.omnipod_no), null)
|
||||||
|
.show()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getNavController(): NavController =
|
||||||
|
(supportFragmentManager.findFragmentById(R.id.nav_host_fragment) as NavHostFragment).navController
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,53 +1,67 @@
|
||||||
package info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.fragment
|
package info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.fragment
|
||||||
|
|
||||||
|
import android.content.res.ColorStateList
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import android.widget.Button
|
import android.view.ViewStub
|
||||||
import android.widget.TextView
|
|
||||||
import androidx.annotation.IdRes
|
import androidx.annotation.IdRes
|
||||||
import androidx.annotation.LayoutRes
|
import androidx.annotation.LayoutRes
|
||||||
import androidx.navigation.fragment.findNavController
|
import androidx.navigation.fragment.findNavController
|
||||||
import dagger.android.support.DaggerFragment
|
import dagger.android.support.DaggerFragment
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.ReplacePodWizardActivity
|
import info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.ReplacePodWizardActivity
|
||||||
|
import kotlinx.android.synthetic.main.omnipod_replace_pod_wizard_base_fragment.*
|
||||||
|
import kotlinx.android.synthetic.main.omnipod_replace_pod_wizard_nav_buttons.*
|
||||||
|
import kotlinx.android.synthetic.main.omnipod_replace_pod_wizard_progress_indication.*
|
||||||
|
import kotlin.math.roundToInt
|
||||||
|
|
||||||
abstract class FragmentBase : DaggerFragment() {
|
abstract class FragmentBase : DaggerFragment() {
|
||||||
override fun onCreateView(
|
override fun onCreateView(
|
||||||
inflater: LayoutInflater,
|
inflater: LayoutInflater,
|
||||||
container: ViewGroup?,
|
container: ViewGroup?,
|
||||||
savedInstanceState: Bundle?
|
savedInstanceState: Bundle?
|
||||||
): View? = inflater.inflate(getLayout(), container, false)
|
): View {
|
||||||
|
val baseView = inflater.inflate(R.layout.omnipod_replace_pod_wizard_base_fragment, container, false)
|
||||||
|
val contentView = baseView.findViewById<ViewStub>(R.id.omnipod_wizard_base_fragment_content)
|
||||||
|
contentView?.let {
|
||||||
|
it.layoutResource = getLayoutId()
|
||||||
|
it.inflate()
|
||||||
|
}
|
||||||
|
return baseView
|
||||||
|
}
|
||||||
|
|
||||||
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
||||||
super.onViewCreated(view, savedInstanceState)
|
super.onViewCreated(view, savedInstanceState)
|
||||||
|
|
||||||
view.findViewById<Button>(R.id.omnipod_replace_pod_wizard_button_cancel)?.setOnClickListener {
|
omnipod_wizard_base_fragment_title.text = getTitle()
|
||||||
activity?.finish()
|
|
||||||
}
|
|
||||||
|
|
||||||
val nextButton = view.findViewById<Button>(R.id.omnipod_replace_pod_wizard_button_next)
|
|
||||||
nextButton?.let {
|
|
||||||
val nextPage = getNextPageActionId()
|
val nextPage = getNextPageActionId()
|
||||||
|
|
||||||
it.text = if (nextPage == null) {
|
if (nextPage == null) {
|
||||||
getString(R.string.omnipod_replace_pod_wizard_button_finish)
|
omnipod_replace_pod_wizard_button_next.text = getString(R.string.omnipod_replace_pod_wizard_button_finish)
|
||||||
} else {
|
omnipod_replace_pod_wizard_button_next.backgroundTintList = ColorStateList.valueOf(resources.getColor(R.color.review_green, context?.theme))
|
||||||
getString(R.string.omnipod_replace_pod_wizard_button_next)
|
|
||||||
}
|
}
|
||||||
it.setOnClickListener {
|
|
||||||
|
updateProgressIndication()
|
||||||
|
|
||||||
|
omnipod_replace_pod_wizard_button_next.setOnClickListener {
|
||||||
if (nextPage == null) {
|
if (nextPage == null) {
|
||||||
activity?.finish()
|
activity?.finish()
|
||||||
} else {
|
} else {
|
||||||
findNavController().navigate(nextPage)
|
findNavController().navigate(nextPage)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
omnipod_replace_pod_wizard_button_cancel.setOnClickListener {
|
||||||
|
(activity as? ReplacePodWizardActivity)?.exitActivityAfterConfirmation()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
val startDestination = (activity as ReplacePodWizardActivity).startDestination
|
private fun updateProgressIndication() {
|
||||||
val total =
|
val totalFragments =
|
||||||
when (startDestination) {
|
when (findNavController().graph.startDestination) {
|
||||||
R.id.fillPodInfoFragment -> {
|
R.id.fillPodInfoFragment -> {
|
||||||
8 - 3
|
8 - 3
|
||||||
}
|
}
|
||||||
|
@ -61,13 +75,19 @@ abstract class FragmentBase : DaggerFragment() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO
|
val currentFragment = getIndex() - (8 - totalFragments)
|
||||||
view.findViewById<TextView>(R.id.omnipod_replace_pod_wizard_progress_indication)?.text = "X/$total"
|
val progressPercentage = (currentFragment / totalFragments.toDouble() * 100).roundToInt()
|
||||||
|
|
||||||
|
omnipod_replace_pod_wizard_progress_indication.progress = progressPercentage
|
||||||
}
|
}
|
||||||
|
|
||||||
@LayoutRes
|
@LayoutRes
|
||||||
abstract fun getLayout(): Int
|
abstract fun getLayoutId(): Int
|
||||||
|
|
||||||
@IdRes
|
@IdRes
|
||||||
abstract fun getNextPageActionId(): Int?
|
abstract fun getNextPageActionId(): Int?
|
||||||
|
|
||||||
|
abstract fun getTitle(): String
|
||||||
|
|
||||||
|
abstract fun getIndex(): Int
|
||||||
}
|
}
|
|
@ -15,7 +15,7 @@ abstract class ActionFragmentBase : FragmentBase() {
|
||||||
|
|
||||||
abstract fun getText(): String
|
abstract fun getText(): String
|
||||||
|
|
||||||
override fun getLayout(): Int {
|
override fun getLayoutId(): Int {
|
||||||
return R.layout.omnipod_replace_pod_wizard_action_page_fragment
|
return R.layout.omnipod_replace_pod_wizard_action_page_fragment
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -6,4 +6,8 @@ class DeactivatePodActionFragment : ActionFragmentBase() {
|
||||||
override fun getText(): String = "[deactivate Pod]"
|
override fun getText(): String = "[deactivate Pod]"
|
||||||
|
|
||||||
override fun getNextPageActionId(): Int = R.id.action_deactivatePodActionFragment_to_podDeactivatedInfoFragment
|
override fun getNextPageActionId(): Int = R.id.action_deactivatePodActionFragment_to_podDeactivatedInfoFragment
|
||||||
|
|
||||||
|
override fun getTitle(): String = "Deactivate Pod"
|
||||||
|
|
||||||
|
override fun getIndex(): Int = 2
|
||||||
}
|
}
|
|
@ -6,4 +6,8 @@ class InsertCannulaActionFragment : ActionFragmentBase() {
|
||||||
override fun getText(): String = "[insert cannula]"
|
override fun getText(): String = "[insert cannula]"
|
||||||
|
|
||||||
override fun getNextPageActionId(): Int = R.id.action_insertCannulaActionFragment_to_podReplacedInfoFragment
|
override fun getNextPageActionId(): Int = R.id.action_insertCannulaActionFragment_to_podReplacedInfoFragment
|
||||||
|
|
||||||
|
override fun getTitle(): String = "Insert cannula"
|
||||||
|
|
||||||
|
override fun getIndex(): Int = 7
|
||||||
}
|
}
|
|
@ -6,4 +6,8 @@ class PairAndPrimePodActionFragment : ActionFragmentBase() {
|
||||||
override fun getText(): String = "[pair and prime Pod]"
|
override fun getText(): String = "[pair and prime Pod]"
|
||||||
|
|
||||||
override fun getNextPageActionId(): Int = R.id.action_pairAndPrimePodActionFragment_to_attachPodInfoFragment
|
override fun getNextPageActionId(): Int = R.id.action_pairAndPrimePodActionFragment_to_attachPodInfoFragment
|
||||||
|
|
||||||
|
override fun getTitle(): String = "Pair and prime Pod"
|
||||||
|
|
||||||
|
override fun getIndex(): Int = 5
|
||||||
}
|
}
|
|
@ -6,4 +6,8 @@ class AttachPodInfoFragment : InfoFragmentBase() {
|
||||||
override fun getText(): String = "Attach the Pod"
|
override fun getText(): String = "Attach the Pod"
|
||||||
|
|
||||||
override fun getNextPageActionId(): Int = R.id.action_attachPodInfoFragment_to_insertCannulaActionFragment
|
override fun getNextPageActionId(): Int = R.id.action_attachPodInfoFragment_to_insertCannulaActionFragment
|
||||||
|
|
||||||
|
override fun getTitle(): String = "Attach Pod"
|
||||||
|
|
||||||
|
override fun getIndex(): Int = 6
|
||||||
}
|
}
|
|
@ -6,4 +6,8 @@ class DeactivatePodInfoFragment : InfoFragmentBase() {
|
||||||
override fun getText(): String = "Deactivate the Pod"
|
override fun getText(): String = "Deactivate the Pod"
|
||||||
|
|
||||||
override fun getNextPageActionId(): Int = R.id.action_deactivatePodInfoFragment_to_deactivatePodActionFragment
|
override fun getNextPageActionId(): Int = R.id.action_deactivatePodInfoFragment_to_deactivatePodActionFragment
|
||||||
|
|
||||||
|
override fun getTitle(): String = "Deactivate Pod"
|
||||||
|
|
||||||
|
override fun getIndex(): Int = 1
|
||||||
}
|
}
|
|
@ -6,4 +6,8 @@ class FillPodInfoFragment : InfoFragmentBase() {
|
||||||
override fun getText(): String = "Fill the Pod"
|
override fun getText(): String = "Fill the Pod"
|
||||||
|
|
||||||
override fun getNextPageActionId(): Int = R.id.action_fillPodInfoFragment_to_pairAndPrimePodActionFragment
|
override fun getNextPageActionId(): Int = R.id.action_fillPodInfoFragment_to_pairAndPrimePodActionFragment
|
||||||
|
|
||||||
|
override fun getTitle(): String = "Fill new Pod"
|
||||||
|
|
||||||
|
override fun getIndex(): Int = 4
|
||||||
}
|
}
|
|
@ -2,20 +2,21 @@ package info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.fragment.info
|
||||||
|
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.widget.TextView
|
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.fragment.FragmentBase
|
import info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.fragment.FragmentBase
|
||||||
|
import kotlinx.android.synthetic.main.omnipod_replace_pod_wizard_info_page_fragment.*
|
||||||
|
|
||||||
abstract class InfoFragmentBase : FragmentBase() {
|
abstract class InfoFragmentBase : FragmentBase() {
|
||||||
|
|
||||||
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
||||||
super.onViewCreated(view, savedInstanceState)
|
super.onViewCreated(view, savedInstanceState)
|
||||||
view.findViewById<TextView>(R.id.omnipod_wizard_info_page_text)?.text = getText();
|
|
||||||
|
omnipod_wizard_info_page_text.text = getText()
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract fun getText(): String
|
abstract fun getText(): String
|
||||||
|
|
||||||
override fun getLayout(): Int {
|
override fun getLayoutId(): Int {
|
||||||
return R.layout.omnipod_replace_pod_wizard_info_page_fragment
|
return R.layout.omnipod_replace_pod_wizard_info_page_fragment
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,11 @@ package info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.fragment.info
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
||||||
|
|
||||||
class PodDeactivatedInfoFragment : InfoFragmentBase() {
|
class PodDeactivatedInfoFragment : InfoFragmentBase() {
|
||||||
override fun getText(): String = "Pod has been deactivated"
|
override fun getText(): String = "Please remove the Pod from your body"
|
||||||
|
|
||||||
override fun getNextPageActionId(): Int = R.id.action_podDeactivatedInfoFragment_to_fillPodInfoFragment
|
override fun getNextPageActionId(): Int = R.id.action_podDeactivatedInfoFragment_to_fillPodInfoFragment
|
||||||
|
|
||||||
|
override fun getTitle(): String = "Remove Pod"
|
||||||
|
|
||||||
|
override fun getIndex(): Int = 3
|
||||||
}
|
}
|
|
@ -1,9 +1,11 @@
|
||||||
package info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.fragment.info
|
package info.nightscout.androidaps.plugins.pump.omnipod.ui.wizard2.fragment.info
|
||||||
|
|
||||||
import info.nightscout.androidaps.plugins.pump.omnipod.R
|
|
||||||
|
|
||||||
class PodReplacedInfoFragment : InfoFragmentBase() {
|
class PodReplacedInfoFragment : InfoFragmentBase() {
|
||||||
override fun getText(): String = "the Pod has been replaced"
|
override fun getText(): String = "the Pod has been replaced"
|
||||||
|
|
||||||
override fun getNextPageActionId(): Int? = null
|
override fun getNextPageActionId(): Int? = null
|
||||||
|
|
||||||
|
override fun getTitle(): String = "Pod replaced"
|
||||||
|
|
||||||
|
override fun getIndex(): Int = 8
|
||||||
}
|
}
|
|
@ -2,24 +2,10 @@
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:orientation="vertical"
|
android:orientation="vertical">
|
||||||
android:padding="10dp">
|
|
||||||
|
|
||||||
<include layout="@layout/omnipod_replace_pod_wizard_progress_indication" />
|
|
||||||
|
|
||||||
<ScrollView
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="0dp"
|
|
||||||
android:layout_weight="1"
|
|
||||||
android:paddingTop="20dp"
|
|
||||||
android:paddingBottom="20dp">
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/omnipod_wizard_action_page_text"
|
android:id="@+id/omnipod_wizard_action_page_text"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content" />
|
android:layout_height="wrap_content" />
|
||||||
</ScrollView>
|
|
||||||
|
|
||||||
<include layout="@layout/omnipod_replace_pod_wizard_nav_buttons" />
|
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
|
@ -1,15 +1,14 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:orientation="vertical">
|
android:padding="10dp">
|
||||||
|
|
||||||
<androidx.fragment.app.FragmentContainerView
|
<androidx.fragment.app.FragmentContainerView
|
||||||
android:id="@+id/nav_host_fragment"
|
android:id="@+id/nav_host_fragment"
|
||||||
android:name="androidx.navigation.fragment.NavHostFragment"
|
android:name="androidx.navigation.fragment.NavHostFragment"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
app:defaultNavHost="true"
|
|
||||||
app:navGraph="@navigation/omnipod_replace_pod_wizard_navigation_graph" />
|
app:navGraph="@navigation/omnipod_replace_pod_wizard_navigation_graph" />
|
||||||
</FrameLayout>
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
|
@ -0,0 +1,30 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="vertical">
|
||||||
|
|
||||||
|
<include layout="@layout/omnipod_replace_pod_wizard_progress_indication" />
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/omnipod_wizard_base_fragment_title"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:textAppearance="@style/WizardPageTitle" />
|
||||||
|
|
||||||
|
<ScrollView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="0dp"
|
||||||
|
android:layout_weight="1"
|
||||||
|
android:paddingTop="20dp"
|
||||||
|
android:paddingBottom="20dp">
|
||||||
|
|
||||||
|
<ViewStub
|
||||||
|
android:id="@+id/omnipod_wizard_base_fragment_content"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content" />
|
||||||
|
</ScrollView>
|
||||||
|
|
||||||
|
<include layout="@layout/omnipod_replace_pod_wizard_nav_buttons" />
|
||||||
|
</LinearLayout>
|
|
@ -2,24 +2,10 @@
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
android:orientation="vertical"
|
android:orientation="vertical">
|
||||||
android:padding="10dp">
|
|
||||||
|
|
||||||
<include layout="@layout/omnipod_replace_pod_wizard_progress_indication" />
|
|
||||||
|
|
||||||
<ScrollView
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="0dp"
|
|
||||||
android:layout_weight="1"
|
|
||||||
android:paddingTop="20dp"
|
|
||||||
android:paddingBottom="20dp">
|
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/omnipod_wizard_info_page_text"
|
android:id="@+id/omnipod_wizard_info_page_text"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content" />
|
android:layout_height="wrap_content" />
|
||||||
</ScrollView>
|
|
||||||
|
|
||||||
<include layout="@layout/omnipod_replace_pod_wizard_nav_buttons" />
|
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
|
@ -2,11 +2,15 @@
|
||||||
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:orientation="vertical">
|
android:orientation="horizontal">
|
||||||
|
|
||||||
<TextView
|
<ProgressBar
|
||||||
android:id="@+id/omnipod_replace_pod_wizard_progress_indication"
|
android:id="@+id/omnipod_replace_pod_wizard_progress_indication"
|
||||||
android:layout_width="wrap_content"
|
style="@android:style/Widget.ProgressBar.Horizontal"
|
||||||
android:layout_height="wrap_content" />
|
android:layout_width="200dp"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:indeterminate="false"
|
||||||
|
android:progress="0"
|
||||||
|
android:progressTint="@color/replacePodWizardProgressBar"
|
||||||
|
android:scaleY=".5" />
|
||||||
</LinearLayout>
|
</LinearLayout>
|
|
@ -2,4 +2,5 @@
|
||||||
<resources>
|
<resources>
|
||||||
<color name="black_overlay">#66000000</color>
|
<color name="black_overlay">#66000000</color>
|
||||||
<color name="ribbonWarning">#f4d700</color>
|
<color name="ribbonWarning">#f4d700</color>
|
||||||
|
<color name="replacePodWizardProgressBar">#0099CC</color>
|
||||||
</resources>
|
</resources>
|
|
@ -233,6 +233,10 @@
|
||||||
<string name="omnipod_wizard_button_cancel">Cancel</string>
|
<string name="omnipod_wizard_button_cancel">Cancel</string>
|
||||||
<string name="omnipod_replace_pod_wizard_button_finish">Finish</string>
|
<string name="omnipod_replace_pod_wizard_button_finish">Finish</string>
|
||||||
<string name="omnipod_replace_pod_wizard_button_next">Next</string>
|
<string name="omnipod_replace_pod_wizard_button_next">Next</string>
|
||||||
|
<string name="omnipod_replace_pod_wizard_exit_confirmation">You haven\'t finished replacing your pod yet. Are you sure you want to exit?</string>
|
||||||
|
<string name="omnipod_replace_pod_wizard_replace_pod">Replace Pod</string>
|
||||||
|
<string name="omnipod_yes">Yes</string>
|
||||||
|
<string name="omnipod_no">No</string>
|
||||||
<plurals name="omnipod_minutes">
|
<plurals name="omnipod_minutes">
|
||||||
<item quantity="one">%1$d minute</item>
|
<item quantity="one">%1$d minute</item>
|
||||||
<item quantity="other">%1$d minutes</item>
|
<item quantity="other">%1$d minutes</item>
|
||||||
|
|
|
@ -28,4 +28,14 @@
|
||||||
<item name="android:divider">@android:color/black</item>
|
<item name="android:divider">@android:color/black</item>
|
||||||
<item name="android:dividerHeight">1dp</item>
|
<item name="android:dividerHeight">1dp</item>
|
||||||
</style>
|
</style>
|
||||||
|
|
||||||
|
<style name="WizardPageTitle">
|
||||||
|
<item name="android:id">@android:id/title</item>
|
||||||
|
<item name="android:layout_width">match_parent</item>
|
||||||
|
<item name="android:layout_height">wrap_content</item>
|
||||||
|
<item name="android:layout_marginBottom">8dp</item>
|
||||||
|
<item name="android:paddingLeft">@dimen/list_item_padding_left</item>
|
||||||
|
<item name="android:textSize">36sp</item>
|
||||||
|
<item name="android:textColor">#0099CC</item>
|
||||||
|
</style>
|
||||||
</resources>
|
</resources>
|
Loading…
Reference in a new issue