actions: do not show labels in low-res landscape mode
This commit is contained in:
parent
c86edb94fd
commit
6f22c5122f
7 changed files with 29 additions and 45 deletions
|
@ -1,9 +1,7 @@
|
||||||
package info.nightscout.plugins.general.actions
|
package info.nightscout.plugins.general.actions
|
||||||
|
|
||||||
import android.content.Context
|
|
||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
import android.util.DisplayMetrics
|
|
||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
|
@ -59,7 +57,6 @@ class ActionsFragment : DaggerFragment() {
|
||||||
@Inject lateinit var sp: SP
|
@Inject lateinit var sp: SP
|
||||||
@Inject lateinit var dateUtil: DateUtil
|
@Inject lateinit var dateUtil: DateUtil
|
||||||
@Inject lateinit var profileFunction: ProfileFunction
|
@Inject lateinit var profileFunction: ProfileFunction
|
||||||
@Inject lateinit var ctx: Context
|
|
||||||
@Inject lateinit var rh: ResourceHelper
|
@Inject lateinit var rh: ResourceHelper
|
||||||
@Inject lateinit var statusLightHandler: StatusLightHandler
|
@Inject lateinit var statusLightHandler: StatusLightHandler
|
||||||
@Inject lateinit var fabricPrivacy: FabricPrivacy
|
@Inject lateinit var fabricPrivacy: FabricPrivacy
|
||||||
|
@ -78,31 +75,22 @@ class ActionsFragment : DaggerFragment() {
|
||||||
|
|
||||||
private val pumpCustomActions = HashMap<String, CustomAction>()
|
private val pumpCustomActions = HashMap<String, CustomAction>()
|
||||||
private val pumpCustomButtons = ArrayList<SingleClickButton>()
|
private val pumpCustomButtons = ArrayList<SingleClickButton>()
|
||||||
private lateinit var dm: DisplayMetrics
|
|
||||||
|
|
||||||
private var _binding: ActionsFragmentBinding? = null
|
private var _binding: ActionsFragmentBinding? = null
|
||||||
|
|
||||||
// This property is only valid between onCreateView and onDestroyView.
|
// This property is only valid between onCreateView and onDestroyView.
|
||||||
private val binding get() = _binding!!
|
private val binding get() = _binding!!
|
||||||
|
|
||||||
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View {
|
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View =
|
||||||
//check screen width
|
ActionsFragmentBinding.inflate(inflater, container, false).also { _binding = it }.root
|
||||||
dm = DisplayMetrics()
|
|
||||||
if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.R) {
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
activity?.display?.getRealMetrics(dm)
|
|
||||||
} else {
|
|
||||||
@Suppress("DEPRECATION")
|
|
||||||
activity?.windowManager?.defaultDisplay?.getMetrics(dm)
|
|
||||||
}
|
|
||||||
_binding = ActionsFragmentBinding.inflate(inflater, container, false)
|
|
||||||
return binding.root
|
|
||||||
}
|
|
||||||
|
|
||||||
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
|
||||||
super.onViewCreated(view, savedInstanceState)
|
super.onViewCreated(view, savedInstanceState)
|
||||||
|
|
||||||
skinProvider.activeSkin().preProcessLandscapeActionsLayout(dm, binding)
|
val screenWidth = activity?.window?.decorView?.width ?: 0
|
||||||
|
val screenHeight = activity?.window?.decorView?.height ?: 0
|
||||||
|
val isLandscape = screenHeight < screenWidth
|
||||||
|
skinProvider.activeSkin().preProcessLandscapeActionsLayout(isLandscape, binding)
|
||||||
|
|
||||||
binding.profileSwitch.setOnClickListener {
|
binding.profileSwitch.setOnClickListener {
|
||||||
activity?.let { activity ->
|
activity?.let { activity ->
|
||||||
|
@ -285,7 +273,7 @@ class ActionsFragment : DaggerFragment() {
|
||||||
binding.tddStats.visibility = pump.pumpDescription.supportsTDDs.toVisibility()
|
binding.tddStats.visibility = pump.pumpDescription.supportsTDDs.toVisibility()
|
||||||
val isPatchPump = pump.pumpDescription.isPatchPump
|
val isPatchPump = pump.pumpDescription.isPatchPump
|
||||||
binding.status.apply {
|
binding.status.apply {
|
||||||
cannulaOrPatch.text = if (isPatchPump) rh.gs(R.string.patch_pump) else rh.gs(R.string.cannula)
|
cannulaOrPatch.text = if (cannulaOrPatch.text.isEmpty()) "" else if (isPatchPump) rh.gs(R.string.patch_pump) else rh.gs(R.string.cannula)
|
||||||
val imageResource = if (isPatchPump) info.nightscout.core.main.R.drawable.ic_patch_pump_outline else R.drawable.ic_cp_age_cannula
|
val imageResource = if (isPatchPump) info.nightscout.core.main.R.drawable.ic_patch_pump_outline else R.drawable.ic_cp_age_cannula
|
||||||
cannulaOrPatch.setCompoundDrawablesWithIntrinsicBounds(imageResource, 0, 0, 0)
|
cannulaOrPatch.setCompoundDrawablesWithIntrinsicBounds(imageResource, 0, 0, 0)
|
||||||
batteryLayout.visibility = (!isPatchPump || pump.pumpDescription.useHardwareLink).toVisibility()
|
batteryLayout.visibility = (!isPatchPump || pump.pumpDescription.useHardwareLink).toVisibility()
|
||||||
|
@ -293,7 +281,11 @@ class ActionsFragment : DaggerFragment() {
|
||||||
cannulaUsage.visibility = isPatchPump.not().toVisibility()
|
cannulaUsage.visibility = isPatchPump.not().toVisibility()
|
||||||
|
|
||||||
if (!config.NSCLIENT) {
|
if (!config.NSCLIENT) {
|
||||||
statusLightHandler.updateStatusLights(cannulaAge, cannulaUsage, insulinAge, reservoirLevel, sensorAge, sensorLevel, pbAge, batteryLevel)
|
statusLightHandler.updateStatusLights(
|
||||||
|
cannulaAge, cannulaUsage, insulinAge,
|
||||||
|
reservoirLevel, sensorAge, sensorLevel,
|
||||||
|
pbAge, pbLevel
|
||||||
|
)
|
||||||
sensorLevelLabel.text = if (activeBgSource.sensorBatteryLevel == -1) "" else rh.gs(R.string.level_label)
|
sensorLevelLabel.text = if (activeBgSource.sensorBatteryLevel == -1) "" else rh.gs(R.string.level_label)
|
||||||
} else {
|
} else {
|
||||||
statusLightHandler.updateStatusLights(cannulaAge, cannulaUsage, insulinAge, null, sensorAge, null, pbAge, null)
|
statusLightHandler.updateStatusLights(cannulaAge, cannulaUsage, insulinAge, null, sensorAge, null, pbAge, null)
|
||||||
|
|
|
@ -188,7 +188,7 @@ class OverviewFragment : DaggerFragment(), View.OnClickListener, OnLongClickList
|
||||||
smallHeight = screenHeight <= Constants.SMALL_HEIGHT
|
smallHeight = screenHeight <= Constants.SMALL_HEIGHT
|
||||||
val landscape = screenHeight < screenWidth
|
val landscape = screenHeight < screenWidth
|
||||||
|
|
||||||
skinProvider.activeSkin().preProcessLandscapeOverviewLayout(dm, binding, landscape, rh.gb(info.nightscout.shared.R.bool.isTablet), smallHeight)
|
skinProvider.activeSkin().preProcessLandscapeOverviewLayout(binding, landscape, rh.gb(info.nightscout.shared.R.bool.isTablet), smallHeight)
|
||||||
binding.nsclientCard.visibility = config.NSCLIENT.toVisibility()
|
binding.nsclientCard.visibility = config.NSCLIENT.toVisibility()
|
||||||
|
|
||||||
binding.notifications.setHasFixedSize(false)
|
binding.notifications.setHasFixedSize(false)
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package info.nightscout.plugins.skins
|
package info.nightscout.plugins.skins
|
||||||
|
|
||||||
import android.util.DisplayMetrics
|
|
||||||
import info.nightscout.interfaces.Config
|
import info.nightscout.interfaces.Config
|
||||||
import info.nightscout.plugins.R
|
import info.nightscout.plugins.R
|
||||||
import info.nightscout.plugins.databinding.OverviewFragmentBinding
|
import info.nightscout.plugins.databinding.OverviewFragmentBinding
|
||||||
|
@ -14,8 +13,8 @@ class SkinClassic @Inject constructor(private val config: Config) : SkinInterfac
|
||||||
override val mainGraphHeight: Int get() = 200
|
override val mainGraphHeight: Int get() = 200
|
||||||
override val secondaryGraphHeight: Int get() = 100
|
override val secondaryGraphHeight: Int get() = 100
|
||||||
|
|
||||||
override fun preProcessLandscapeOverviewLayout(dm: DisplayMetrics, binding: OverviewFragmentBinding, isLandscape: Boolean, isTablet: Boolean, isSmallHeight: Boolean) {
|
override fun preProcessLandscapeOverviewLayout(binding: OverviewFragmentBinding, isLandscape: Boolean, isTablet: Boolean, isSmallHeight: Boolean) {
|
||||||
super.preProcessLandscapeOverviewLayout(dm, binding, isLandscape, isTablet, isSmallHeight)
|
super.preProcessLandscapeOverviewLayout(binding, isLandscape, isTablet, isSmallHeight)
|
||||||
if (!config.NSCLIENT && (isSmallHeight || isLandscape)) moveButtonsLayout(binding.root)
|
if (!config.NSCLIENT && (isSmallHeight || isLandscape)) moveButtonsLayout(binding.root)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package info.nightscout.plugins.skins
|
package info.nightscout.plugins.skins
|
||||||
|
|
||||||
import android.util.DisplayMetrics
|
|
||||||
import android.util.TypedValue.COMPLEX_UNIT_PX
|
import android.util.TypedValue.COMPLEX_UNIT_PX
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.widget.LinearLayout
|
import android.widget.LinearLayout
|
||||||
|
@ -18,16 +17,11 @@ interface SkinInterface {
|
||||||
val secondaryGraphHeight: Int // in dp
|
val secondaryGraphHeight: Int // in dp
|
||||||
|
|
||||||
// no pre processing by default
|
// no pre processing by default
|
||||||
fun preProcessLandscapeActionsLayout(dm: DisplayMetrics, binding: ActionsFragmentBinding) {
|
fun preProcessLandscapeActionsLayout(isLandscape: Boolean, binding: ActionsFragmentBinding) {
|
||||||
}
|
}
|
||||||
|
|
||||||
fun preProcessLandscapeOverviewLayout(dm: DisplayMetrics, binding: OverviewFragmentBinding, isLandscape: Boolean, isTablet: Boolean, isSmallHeight: Boolean) {
|
fun preProcessLandscapeOverviewLayout(binding: OverviewFragmentBinding, isLandscape: Boolean, isTablet: Boolean, isSmallHeight: Boolean) {
|
||||||
// pre-process landscape mode
|
if (isLandscape) {
|
||||||
val screenWidth = dm.widthPixels
|
|
||||||
val screenHeight = dm.heightPixels
|
|
||||||
val landscape = screenHeight < screenWidth
|
|
||||||
|
|
||||||
if (landscape) {
|
|
||||||
val iobLayout = binding.infoLayout.iobLayout
|
val iobLayout = binding.infoLayout.iobLayout
|
||||||
val iobLayoutParams = iobLayout.layoutParams as ConstraintLayout.LayoutParams
|
val iobLayoutParams = iobLayout.layoutParams as ConstraintLayout.LayoutParams
|
||||||
val timeLayout = binding.infoLayout.timeLayout
|
val timeLayout = binding.infoLayout.timeLayout
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package info.nightscout.plugins.skins
|
package info.nightscout.plugins.skins
|
||||||
|
|
||||||
import android.util.DisplayMetrics
|
|
||||||
import info.nightscout.interfaces.Config
|
import info.nightscout.interfaces.Config
|
||||||
import info.nightscout.plugins.R
|
import info.nightscout.plugins.R
|
||||||
import info.nightscout.plugins.databinding.OverviewFragmentBinding
|
import info.nightscout.plugins.databinding.OverviewFragmentBinding
|
||||||
|
@ -14,8 +13,8 @@ class SkinLargeDisplay @Inject constructor(private val config: Config) : SkinInt
|
||||||
override val mainGraphHeight: Int get() = 400
|
override val mainGraphHeight: Int get() = 400
|
||||||
override val secondaryGraphHeight: Int get() = 150
|
override val secondaryGraphHeight: Int get() = 150
|
||||||
|
|
||||||
override fun preProcessLandscapeOverviewLayout(dm: DisplayMetrics, binding: OverviewFragmentBinding, isLandscape: Boolean, isTablet: Boolean, isSmallHeight: Boolean) {
|
override fun preProcessLandscapeOverviewLayout(binding: OverviewFragmentBinding, isLandscape: Boolean, isTablet: Boolean, isSmallHeight: Boolean) {
|
||||||
super.preProcessLandscapeOverviewLayout(dm, binding, isLandscape, isTablet, isSmallHeight)
|
super.preProcessLandscapeOverviewLayout(binding, isLandscape, isTablet, isSmallHeight)
|
||||||
if (!config.NSCLIENT && (isSmallHeight || isLandscape)) moveButtonsLayout(binding.root)
|
if (!config.NSCLIENT && (isSmallHeight || isLandscape)) moveButtonsLayout(binding.root)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package info.nightscout.plugins.skins
|
package info.nightscout.plugins.skins
|
||||||
|
|
||||||
import android.util.DisplayMetrics
|
|
||||||
import android.view.View.GONE
|
import android.view.View.GONE
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import info.nightscout.interfaces.Config
|
import info.nightscout.interfaces.Config
|
||||||
|
@ -17,27 +16,26 @@ class SkinLowRes @Inject constructor(private val config: Config) : SkinInterface
|
||||||
override val mainGraphHeight: Int get() = 200
|
override val mainGraphHeight: Int get() = 200
|
||||||
override val secondaryGraphHeight: Int get() = 100
|
override val secondaryGraphHeight: Int get() = 100
|
||||||
|
|
||||||
override fun preProcessLandscapeActionsLayout(dm: DisplayMetrics, binding: ActionsFragmentBinding) {
|
override fun preProcessLandscapeActionsLayout(isLandscape: Boolean, binding: ActionsFragmentBinding) {
|
||||||
val screenWidth = dm.widthPixels
|
|
||||||
val screenHeight = dm.heightPixels
|
|
||||||
val isLandscape = screenHeight < screenWidth
|
|
||||||
|
|
||||||
if (!isLandscape) {
|
if (!isLandscape) {
|
||||||
binding.status.apply {
|
binding.status.apply {
|
||||||
sensorAgeLabel.visibility = GONE
|
sensorLabel.text = ""
|
||||||
sensorAgeLabel.visibility = GONE
|
sensorAgeLabel.visibility = GONE
|
||||||
sensorLevelLabel.visibility = GONE
|
sensorLevelLabel.visibility = GONE
|
||||||
insulinAgeLabel.visibility = GONE
|
insulinAgeLabel.visibility = GONE
|
||||||
|
insulinLabel.text = ""
|
||||||
insulinLevelLabel.visibility = GONE
|
insulinLevelLabel.visibility = GONE
|
||||||
|
cannulaOrPatch.text = ""
|
||||||
cannulaAgeLabel.visibility = GONE
|
cannulaAgeLabel.visibility = GONE
|
||||||
cannulaUsageLabel.visibility = GONE
|
cannulaUsageLabel.visibility = GONE
|
||||||
|
pbLabel.text = ""
|
||||||
pbAgeLabel.visibility = GONE
|
pbAgeLabel.visibility = GONE
|
||||||
pbLevelLabel.visibility = GONE
|
pbLevelLabel.visibility = GONE
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun preProcessLandscapeOverviewLayout(dm: DisplayMetrics, binding: OverviewFragmentBinding, isLandscape: Boolean, isTablet: Boolean, isSmallHeight: Boolean) {
|
override fun preProcessLandscapeOverviewLayout(binding: OverviewFragmentBinding, isLandscape: Boolean, isTablet: Boolean, isSmallHeight: Boolean) {
|
||||||
if (!config.NSCLIENT && isLandscape) moveButtonsLayout(binding.root)
|
if (!config.NSCLIENT && isLandscape) moveButtonsLayout(binding.root)
|
||||||
|
|
||||||
binding.apply {
|
binding.apply {
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
android:focusable="true">
|
android:focusable="true">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
|
android:id="@+id/sensor_label"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="25dp"
|
android:layout_height="25dp"
|
||||||
android:gravity="center_vertical"
|
android:gravity="center_vertical"
|
||||||
|
@ -84,6 +85,7 @@
|
||||||
android:focusable="true">
|
android:focusable="true">
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
|
android:id="@+id/insulin_label"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="25dp"
|
android:layout_height="25dp"
|
||||||
android:gravity="center_vertical"
|
android:gravity="center_vertical"
|
||||||
|
@ -272,7 +274,7 @@
|
||||||
android:textSize="14sp" />
|
android:textSize="14sp" />
|
||||||
|
|
||||||
<TextView
|
<TextView
|
||||||
android:id="@+id/battery_level"
|
android:id="@+id/pb_level"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_marginEnd="20dp"
|
android:layout_marginEnd="20dp"
|
||||||
|
|
Loading…
Add table
Reference in a new issue