Skip to content

Commit

Permalink
Show sensor state in secondary label in Wear OS sensor UI (#3959)
Browse files Browse the repository at this point in the history
* Show sensor state in secondary label in Wear OS sensor UI

* Review comments

* Remove runBlocking in previews and invert label check to match phone
  • Loading branch information
dshokouhi authored Oct 20, 2023
1 parent cda2547 commit e10ec79
Showing 1 changed file with 45 additions and 5 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ import io.homeassistant.companion.android.database.sensor.Sensor
import io.homeassistant.companion.android.theme.getToggleButtonColors
import io.homeassistant.companion.android.util.ToggleSwitch
import io.homeassistant.companion.android.util.batterySensorManager
import io.homeassistant.companion.android.views.ThemeLazyColumn
import kotlinx.coroutines.runBlocking

@SuppressLint("InlinedApi")
Expand Down Expand Up @@ -85,6 +86,13 @@ fun SensorUi(
overflow = TextOverflow.Ellipsis
)
},
secondaryLabel = {
if (sensor?.enabled == true) {
sensor.state.let {
Text(if (basicSensor.unitOfMeasurement.isNullOrBlank() || sensor.state.toDoubleOrNull() == null) it else "$it ${sensor.unitOfMeasurement}")
}
}
},
selectionControl = { ToggleSwitch(isChecked) },
colors = getToggleButtonColors()
)
Expand All @@ -94,11 +102,43 @@ fun SensorUi(
@Composable
private fun PreviewSensorUI() {
val context = LocalContext.current
val batterySensors = runBlocking { batterySensorManager.getAvailableSensors(context) }
CompositionLocalProvider {
SensorUi(
sensor = null,
manager = batterySensorManager,
basicSensor = runBlocking { batterySensorManager.getAvailableSensors(context).first() }
) { _, _ -> }
ThemeLazyColumn {
item {
SensorUi(
sensor = Sensor(
"battery_level",
0,
true,
state = "80",
unitOfMeasurement = "%"
),
manager = batterySensorManager,
basicSensor = batterySensors.first { it.id == "battery_level" }
) { _, _ -> }
}

item {
SensorUi(
sensor = Sensor(
"is_charging",
0,
true,
state = "true"
),
manager = batterySensorManager,
basicSensor = batterySensors.first { it.id == "is_charging" }
) { _, _ -> }
}

item {
SensorUi(
sensor = null,
manager = batterySensorManager,
basicSensor = batterySensors.first { it.id == "battery_power" }
) { _, _ -> }
}
}
}
}

0 comments on commit e10ec79

Please sign in to comment.