mirror of
https://github.com/JetBrains/intellij-platform-plugin-template.git
synced 2025-12-05 06:11:52 +00:00
Add simple WeatherAppSample implementation
This commit is contained in:
parent
aeef1e7811
commit
2c94191e82
@ -1,22 +1,137 @@
|
|||||||
package org.jetbrains.plugins.template.weatherApp.ui
|
package org.jetbrains.plugins.template.weatherApp.ui
|
||||||
|
|
||||||
|
import androidx.compose.foundation.background
|
||||||
import androidx.compose.foundation.layout.*
|
import androidx.compose.foundation.layout.*
|
||||||
import androidx.compose.runtime.*
|
import androidx.compose.runtime.Composable
|
||||||
|
import androidx.compose.runtime.collectAsState
|
||||||
|
import androidx.compose.ui.Alignment
|
||||||
import androidx.compose.ui.Modifier
|
import androidx.compose.ui.Modifier
|
||||||
|
import androidx.compose.ui.graphics.Color.Companion.Transparent
|
||||||
|
import androidx.compose.ui.text.style.TextOverflow
|
||||||
import androidx.compose.ui.unit.dp
|
import androidx.compose.ui.unit.dp
|
||||||
|
import com.intellij.openapi.components.service
|
||||||
|
import org.jetbrains.jewel.bridge.retrieveColorOrUnspecified
|
||||||
|
import org.jetbrains.jewel.foundation.lazy.SelectableLazyColumn
|
||||||
|
import org.jetbrains.jewel.foundation.lazy.SelectionMode
|
||||||
|
import org.jetbrains.jewel.foundation.lazy.items
|
||||||
|
import org.jetbrains.jewel.foundation.lazy.rememberSelectableLazyListState
|
||||||
import org.jetbrains.jewel.foundation.theme.JewelTheme
|
import org.jetbrains.jewel.foundation.theme.JewelTheme
|
||||||
import org.jetbrains.jewel.ui.component.Text
|
import org.jetbrains.jewel.ui.component.*
|
||||||
|
import org.jetbrains.plugins.template.weatherApp.model.Location
|
||||||
|
import org.jetbrains.plugins.template.weatherApp.model.WeatherForecastData
|
||||||
|
import org.jetbrains.plugins.template.weatherApp.services.*
|
||||||
|
import org.jetbrains.plugins.template.weatherApp.ui.components.SearchToolbarMenu
|
||||||
|
import org.jetbrains.plugins.template.weatherApp.ui.components.WeatherDetailsCard
|
||||||
|
|
||||||
@Composable
|
@Composable
|
||||||
fun WeatherAppSample() {
|
internal fun WeatherAppSample() {
|
||||||
Column(Modifier
|
val viewModel: MyLocationsViewModel = service<MyLocationsViewModel>()
|
||||||
.fillMaxWidth()
|
val searchAutoCompletionItemProvided = service<LocationsProvider>()
|
||||||
.heightIn(20.dp)
|
|
||||||
.padding(16.dp)) {
|
HorizontalSplitLayout(
|
||||||
Text(
|
first = { LeftColumn(viewModel, modifier = Modifier.fillMaxSize()) },
|
||||||
"Not yet implemented",
|
second = {
|
||||||
style = JewelTheme.defaultTextStyle
|
RightColumn(
|
||||||
|
viewModel,
|
||||||
|
viewModel,
|
||||||
|
searchAutoCompletionItemProvided,
|
||||||
|
modifier = Modifier.fillMaxSize()
|
||||||
|
)
|
||||||
|
},
|
||||||
|
modifier = Modifier.fillMaxSize(),
|
||||||
|
firstPaneMinWidth = 100.dp,
|
||||||
|
secondPaneMinWidth = 300.dp,
|
||||||
|
state = rememberSplitLayoutState(.2f)
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
private fun LeftColumn(
|
||||||
|
myLocationsViewModelApi: MyLocationsViewModelApi,
|
||||||
|
modifier: Modifier = Modifier,
|
||||||
|
) {
|
||||||
|
val myLocations = myLocationsViewModelApi.myLocationsFlow.collectAsState(emptyList()).value
|
||||||
|
|
||||||
|
// TODO Set selected item on initial showing
|
||||||
|
|
||||||
|
Column(modifier.fillMaxSize().padding(8.dp)) {
|
||||||
|
GroupHeader("My Locations", modifier = Modifier.padding(bottom = 8.dp))
|
||||||
|
|
||||||
|
Spacer(modifier = Modifier.height(4.dp))
|
||||||
|
|
||||||
|
val listState = rememberSelectableLazyListState()
|
||||||
|
|
||||||
|
SelectableLazyColumn(
|
||||||
|
modifier = modifier.fillMaxSize(),
|
||||||
|
selectionMode = SelectionMode.Single,
|
||||||
|
state = listState,
|
||||||
|
onSelectedIndexesChange = { indices ->
|
||||||
|
val selectedLocationIndex = indices.firstOrNull() ?: return@SelectableLazyColumn
|
||||||
|
myLocationsViewModelApi.onLocationSelected(selectedLocationIndex)
|
||||||
|
},
|
||||||
|
) {
|
||||||
|
items(
|
||||||
|
items = myLocations,
|
||||||
|
key = { item -> item },
|
||||||
|
contentType = { item -> item.location },
|
||||||
|
) { item ->
|
||||||
|
|
||||||
|
ContentItemRow(
|
||||||
|
item = item.location, isSelected = item.isSelected, isActive = isActive
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
private fun ContentItemRow(item: Location, isSelected: Boolean, isActive: Boolean) {
|
||||||
|
val color = when {
|
||||||
|
isSelected && isActive -> retrieveColorOrUnspecified("List.selectionBackground")
|
||||||
|
isSelected && !isActive -> retrieveColorOrUnspecified("List.selectionInactiveBackground")
|
||||||
|
else -> Transparent
|
||||||
|
}
|
||||||
|
Row(
|
||||||
|
modifier = Modifier
|
||||||
|
.height(JewelTheme.globalMetrics.rowHeight)
|
||||||
|
.background(color)
|
||||||
|
.padding(horizontal = 4.dp)
|
||||||
|
.padding(end = scrollbarContentSafePadding()),
|
||||||
|
verticalAlignment = Alignment.CenterVertically,
|
||||||
|
horizontalArrangement = Arrangement.spacedBy(4.dp),
|
||||||
|
) {
|
||||||
|
Text(text = item.id, modifier = Modifier.weight(1f), overflow = TextOverflow.Ellipsis, maxLines = 1)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Composable
|
||||||
|
private fun RightColumn(
|
||||||
|
myLocationViewModel: MyLocationsViewModelApi,
|
||||||
|
weatherViewModelApi: WeatherViewModelApi,
|
||||||
|
searchAutoCompletionItemProvider: SearchAutoCompletionItemProvider<Location>,
|
||||||
|
modifier: Modifier = Modifier,
|
||||||
|
) {
|
||||||
|
val weatherForecastData = weatherViewModelApi.weatherForecast.collectAsState(WeatherForecastData.EMPTY).value
|
||||||
|
|
||||||
|
Column(modifier.fillMaxWidth().padding(8.dp)) {
|
||||||
|
SearchToolbarMenu(
|
||||||
|
searchAutoCompletionItemProvider = searchAutoCompletionItemProvider,
|
||||||
|
confirmButtonText = "Add",
|
||||||
|
onSearchPerformed = { place ->
|
||||||
|
weatherViewModelApi.onLoadWeatherForecast(place)
|
||||||
|
},
|
||||||
|
onSearchConfirmed = { place ->
|
||||||
|
myLocationViewModel.onAddLocation(place)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
WeatherDetailsCard(
|
||||||
|
modifier = Modifier
|
||||||
|
.fillMaxWidth()
|
||||||
|
.align(Alignment.CenterHorizontally), // optional for positioning
|
||||||
|
weatherForecastData
|
||||||
|
) {
|
||||||
|
weatherViewModelApi.onReloadWeatherForecast()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user