YASAN
02/06/2022, 11:05 AMYASAN
02/06/2022, 11:06 AMDominaezzz
02/06/2022, 11:51 AMYASAN
02/06/2022, 11:51 AMYASAN
02/06/2022, 11:52 AMfun ActiveStationItem(
    stationNullable: Station?,
    isPlaying: Boolean,
    playState: Int?,
    onTogglePlay: () -> Unit
) {
}YASAN
02/06/2022, 11:52 AMDominaezzz
02/06/2022, 11:52 AMYASAN
02/06/2022, 11:52 AMYASAN
02/06/2022, 11:53 AMDominaezzz
02/06/2022, 11:54 AMYASAN
02/06/2022, 11:55 AMYASAN
02/06/2022, 11:55 AMYASAN
02/06/2022, 11:55 AMDominaezzz
02/06/2022, 11:57 AMAdam Powell
02/06/2022, 2:18 PMState<T>MutableState<T>() -> TAdam Powell
02/06/2022, 2:20 PM[Mutable]State<T>YASAN
02/06/2022, 3:06 PMmattinger
02/06/2022, 4:23 PMAdam Powell
02/06/2022, 4:32 PMclass Foo {
  var someValue by mutableStateOf(...)
  // ...
}
class Bar(
  private val foo: Foo
) {
  val computedValue: Int
    get() = foo.someValue * 2
}Adam Powell
02/06/2022, 4:36 PMbar.computedValue@Composable
fun BazOne(
  value: () -> Int
)
@Composable
fun BazTwo(
  value: State<Int>
)BazOne({ bar.computedValue })BazTwo(
  object : State<Int> {
    override val value: Int
      get() = bar.computedValue
  }
)Adam Powell
02/06/2022, 4:43 PMAdam Powell
02/06/2022, 4:44 PMStylianos Gakis
03/02/2023, 11:37 AMI keep meaning to add it to the compose API guidelines doc and make sure we get a lint check;Has this ever made it anywhere in the official docs so far?andState<T>generally shouldn’t appear in parameter lists. If you really find yourself in a place where you need more granular invalidations from performing a snapshot read more locally, use aMutableState<T>instead() -> T