Skip to content

Commit

Permalink
Adding scrollbars to tree and packages list, added minimum details pa…
Browse files Browse the repository at this point in the history
  • Loading branch information
fscarponi authored and lamba92 committed Dec 4, 2023
1 parent 2ee98fe commit ab90ce9
Show file tree
Hide file tree
Showing 10 changed files with 135 additions and 51 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -7,21 +7,24 @@ import com.intellij.openapi.wm.ToolWindow
import com.intellij.openapi.wm.ToolWindowFactory
import com.jetbrains.packagesearch.plugin.ui.LocalComponentManager
import com.jetbrains.packagesearch.plugin.ui.PackageSearchToolwindow
import com.jetbrains.packagesearch.plugin.ui.panels.packages.packageSearchGlobalColors
import com.jetbrains.packagesearch.plugin.ui.panels.packages.packageSearchTabStyle
import com.jetbrains.packagesearch.plugin.ui.panels.packages.PackageSearchTabStyle
import com.jetbrains.packagesearch.plugin.ui.panels.packages.PackageSearchTreeStyle
import com.jetbrains.packagesearch.plugin.ui.panels.packages.PackageSearchGlobalColors
import com.jetbrains.packagesearch.plugin.utils.installActions
import org.jetbrains.jewel.bridge.addComposeTab
import org.jetbrains.jewel.foundation.LocalGlobalColors
import org.jetbrains.jewel.ui.component.styling.LocalDefaultTabStyle
import org.jetbrains.jewel.ui.component.styling.LocalLazyTreeStyle

class PackageSearchToolWindowFactory : ToolWindowFactory, DumbAware {
override fun createToolWindowContent(project: Project, toolWindow: ToolWindow) {
toolWindow.installActions(project)
toolWindow.addComposeTab(PackageSearchBundle.message("packagesearch.title.tab")) {
CompositionLocalProvider(
LocalComponentManager provides project,
LocalGlobalColors provides packageSearchGlobalColors(),
LocalDefaultTabStyle provides packageSearchTabStyle()
LocalGlobalColors provides PackageSearchGlobalColors(),
LocalDefaultTabStyle provides PackageSearchTabStyle(),
LocalLazyTreeStyle provides PackageSearchTreeStyle()
) {
PackageSearchToolwindow()
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,24 @@
package com.jetbrains.packagesearch.plugin.ui

import androidx.compose.foundation.layout.PaddingValues
import androidx.compose.foundation.layout.calculateEndPadding
import androidx.compose.runtime.Composable
import androidx.compose.ui.platform.LocalLayoutDirection
import androidx.compose.ui.unit.Dp
import androidx.compose.ui.unit.dp
import org.jetbrains.jewel.foundation.theme.JewelTheme
import org.jetbrains.jewel.ui.theme.scrollbarStyle

object PackageSearchMetrics {

val scrollbarWidth: Dp
@Composable
get() {
val metrics = JewelTheme.scrollbarStyle.metrics
return metrics.thumbThickness +
metrics.trackPadding.calculateEndPadding(LocalLayoutDirection.current)
}

object Popups {

val minWidth: Dp = 50.dp
Expand All @@ -14,17 +28,17 @@ object PackageSearchMetrics {
val maxHeight: Dp = 250.dp
}

object PackageList{
object Item{
val height= 24.dp
object PackageList {
object Item {
val height = 24.dp
val padding = 8.dp
}
}

val searchBarHeight = 36.dp
val treeActionsHeight = searchBarHeight

object Dropdown{
object Dropdown {
val maxHeight = 100.dp
}

Expand Down
Original file line number Diff line number Diff line change
@@ -1,36 +1,34 @@
package com.jetbrains.packagesearch.plugin.ui

import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import androidx.compose.ui.unit.dp
import com.jetbrains.packagesearch.plugin.core.data.PackageSearchModule
import com.jetbrains.packagesearch.plugin.ui.model.packageslist.PackageListItem
import com.jetbrains.packagesearch.plugin.ui.model.packageslist.PackageListItemEvent
import com.jetbrains.packagesearch.plugin.ui.panels.packages.PackageSearchCentralPanel
import com.jetbrains.packagesearch.plugin.ui.panels.side.PackageSearchInfoPanel
import com.jetbrains.packagesearch.plugin.ui.panels.tree.PackageSearchModulesTree
import org.jetbrains.jewel.foundation.lazy.SelectableLazyListState
import org.jetbrains.jewel.ui.component.HorizontalSplitLayout

@Composable
fun PackageSearchPackagePanel(
onSelectionModulesSelectionChanged: (Set<PackageSearchModule.Identity>) -> Unit,
isInfoPanelOpen: Boolean,
onLinkClick: (String) -> Unit,
onPackageEvent:(PackageListItemEvent) -> Unit,
onPackageEvent: (PackageListItemEvent) -> Unit,
) {
HorizontalSplitLayout(
first = { PackageSearchModulesTree(it, onSelectionModulesSelectionChanged) },
second = {
if (isInfoPanelOpen) {
HorizontalSplitLayout(
modifier = it,
initialDividerPosition = 700.dp,
initialDividerPosition = 900.dp,
first = { PackageSearchCentralPanel(it, onLinkClick) },
second = { PackageSearchInfoPanel(it, onLinkClick, onPackageEvent) }
second = { PackageSearchInfoPanel(it, onLinkClick, onPackageEvent) },
maxRatio = 0.8f
)
} else PackageSearchCentralPanel(it, onLinkClick)
}
},
minRatio = 0.1f,
)
}

Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,8 @@ internal class TreeViewModel(project: Project) : Disposable {
}
.stateIn(viewModelScope, SharingStarted.Lazily, emptyTree())

val treeState = TreeState(SelectableLazyListState(LazyListState()))
internal val lazyListState = LazyListState()
internal val treeState = TreeState(SelectableLazyListState(lazyListState))

val isOnline
get() = IntelliJApplication.PackageSearchApplicationCachesService
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,20 @@ package com.jetbrains.packagesearch.plugin.ui.panels.packages

import androidx.compose.foundation.layout.Box
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.fillMaxHeight
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.rememberScrollbarAdapter
import androidx.compose.runtime.Composable
import androidx.compose.runtime.collectAsState
import androidx.compose.runtime.getValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import com.jetbrains.packagesearch.plugin.ui.model.packageslist.PackageListViewModel
import com.jetbrains.packagesearch.plugin.ui.viewModel
import org.jetbrains.jewel.ui.Orientation
import org.jetbrains.jewel.ui.component.Divider
import org.jetbrains.jewel.ui.component.IndeterminateHorizontalProgressBar
import org.jetbrains.jewel.ui.component.VerticalScrollbar

@Composable
fun PackageSearchCentralPanel(
Expand Down Expand Up @@ -39,6 +43,10 @@ fun PackageSearchCentralPanel(
selectableLazyListState = viewModel.selectableLazyListState,
onPackageEvent = viewModel::onPackageListItemEvent,
)
VerticalScrollbar(
adapter = rememberScrollbarAdapter(scrollState = viewModel.selectableLazyListState.lazyListState),
modifier = Modifier.fillMaxHeight().align(Alignment.CenterEnd),
)
}
}
val isLoading by viewModel.isLoadingFlow.collectAsState()
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,7 @@ import com.jetbrains.packagesearch.plugin.ui.model.packageslist.PackageListItemE
import com.jetbrains.packagesearch.plugin.ui.model.packageslist.PackageListItemEvent.OnPackageAction.GoToSource
import com.jetbrains.packagesearch.plugin.ui.model.packageslist.PackageListItemEvent.OnPackageAction.Install
import com.jetbrains.packagesearch.plugin.ui.model.packageslist.PackageListItemEvent.OnPackageAction.Remove
import com.jetbrains.packagesearch.plugin.ui.panels.packages.items.PackageListItem
import com.jetbrains.packagesearch.plugin.ui.panels.packages.items.PackageListHeader
import org.jetbrains.jewel.foundation.lazy.SelectableLazyColumn
import org.jetbrains.jewel.foundation.lazy.SelectableLazyItemScope
import org.jetbrains.jewel.foundation.lazy.SelectableLazyListState
Expand All @@ -60,13 +60,15 @@ import org.jetbrains.jewel.ui.component.styling.LocalLazyTreeStyle

@Composable
fun PackageSearchPackageList(
modifier: Modifier = Modifier,
packagesList: List<PackageListItem>,
isCompact: Boolean,
selectableLazyListState: SelectableLazyListState,
onPackageEvent: (PackageListItemEvent) -> Unit,
) {
var openPopupId by remember { mutableStateOf<PackageListItem.Package.Id?>(null) }
SelectableLazyColumn(
modifier = modifier,
selectionMode = SelectionMode.Single,
state = selectableLazyListState,
onSelectedIndexesChanged = {
Expand All @@ -80,12 +82,17 @@ fun PackageSearchPackageList(
) {
packagesList.forEachIndexed { index, item ->
when (item) {
is PackageListItem.Header -> stickyHeader(item.id, "header") {
PackageListItem(item, onPackageEvent)
is PackageListItem.Header -> stickyHeader(key = item.id, contentType = "header") {
PackageListHeader(
additionalContentModifier = Modifier.padding(end = PackageSearchMetrics.scrollbarWidth),
content = item,
onEvent = onPackageEvent
)
}

is PackageListItem.Package -> item(item.id, contentType = item.contentType()) {
is PackageListItem.Package -> item(key = item.id, contentType = item.contentType()) {
PackageListItem(
modifier = Modifier.padding(end = PackageSearchMetrics.scrollbarWidth),
content = item,
packagesList = packagesList,
index = index,
Expand All @@ -103,6 +110,7 @@ fun PackageSearchPackageList(

@Composable
private fun SelectableLazyItemScope.PackageListItem(
modifier: Modifier = Modifier,
content: PackageListItem.Package,
packagesList: List<PackageListItem>,
index: Int,
Expand All @@ -117,7 +125,7 @@ private fun SelectableLazyItemScope.PackageListItem(
isLastItem = packagesList.getOrNull(index + 1) !is PackageListItem.Package
)
Box(
modifier = Modifier
modifier = modifier
.padding(itemPaddings)
.onClick(
interactionSource = remember { MutableInteractionSource() },
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
package com.jetbrains.packagesearch.plugin.ui.panels.packages

import androidx.compose.animation.Crossfade
import androidx.compose.foundation.layout.PaddingValues
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.calculateStartPadding
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.height
import androidx.compose.foundation.layout.padding
Expand All @@ -10,6 +12,7 @@ import androidx.compose.runtime.remember
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.platform.LocalLayoutDirection
import androidx.compose.ui.unit.dp
import com.intellij.icons.AllIcons
import com.jetbrains.packagesearch.plugin.PackageSearchBundle.message
Expand All @@ -21,7 +24,10 @@ import org.jetbrains.jewel.ui.component.Icon
import org.jetbrains.jewel.ui.component.IconButton
import org.jetbrains.jewel.ui.component.Text
import org.jetbrains.jewel.ui.component.TextField
import org.jetbrains.jewel.ui.component.styling.LazyTreeMetrics
import org.jetbrains.jewel.ui.component.styling.LazyTreeStyle
import org.jetbrains.jewel.ui.component.styling.LocalDefaultTabStyle
import org.jetbrains.jewel.ui.component.styling.LocalLazyTreeStyle
import org.jetbrains.jewel.ui.component.styling.LocalTextFieldStyle
import org.jetbrains.jewel.ui.component.styling.TabMetrics
import org.jetbrains.jewel.ui.component.styling.TabStyle
Expand Down Expand Up @@ -82,7 +88,7 @@ fun PackageSearchSearchBar(
}

@Composable
internal fun packageSearchTabStyle(): TabStyle {
internal fun PackageSearchTabStyle(): TabStyle {
val current = LocalDefaultTabStyle.current
return TabStyle(
colors = current.colors,
Expand All @@ -99,7 +105,7 @@ internal fun packageSearchTabStyle(): TabStyle {


@Composable
fun packageSearchGlobalColors(): GlobalColors {
fun PackageSearchGlobalColors(): GlobalColors {
val colors = LocalGlobalColors.current

return remember(colors) {
Expand All @@ -118,3 +124,28 @@ fun packageSearchGlobalColors(): GlobalColors {
}
}


@Composable
internal fun PackageSearchTreeStyle(): LazyTreeStyle {
val currentStyle = LocalLazyTreeStyle.current
val paddings = currentStyle.metrics.elementPadding
return LazyTreeStyle(
currentStyle.colors,
metrics = LazyTreeMetrics(
indentSize = currentStyle.metrics.indentSize,
elementPadding = PaddingValues(
top = paddings.calculateTopPadding(),
bottom = paddings.calculateBottomPadding(),
start = paddings.calculateStartPadding(LocalLayoutDirection.current),
end = 0.dp
),
elementContentPadding = currentStyle.metrics.elementContentPadding,
elementMinHeight = currentStyle.metrics.elementMinHeight,
chevronContentGap = currentStyle.metrics.chevronContentGap,
elementBackgroundCornerSize = currentStyle.metrics.elementBackgroundCornerSize,
),
currentStyle.icons,
)
}


Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,8 @@ import org.jetbrains.jewel.ui.component.Link
import org.jetbrains.jewel.ui.component.Text

@Composable
fun PackageListItem(
fun PackageListHeader(
additionalContentModifier: Modifier = Modifier,
content: PackageListItem.Header,
onEvent: (PackageListItemEvent) -> Unit,
) {
Expand Down Expand Up @@ -107,17 +108,22 @@ fun PackageListItem(
}
}
if (content.additionalContent != null) {
when (content.additionalContent) {
is PackageListItem.Header.AdditionalContent.VariantsText ->
LabelInfo(
text = content.additionalContent.text,
maxLines = 1
)
Box(
modifier = additionalContentModifier,
) {

when (content.additionalContent) {
is PackageListItem.Header.AdditionalContent.VariantsText ->
LabelInfo(
text = content.additionalContent.text,
maxLines = 1
)

is PackageListItem.Header.AdditionalContent.UpdatesAvailableCount ->
UpdateAllLink(content.additionalContent, content, onEvent)
is PackageListItem.Header.AdditionalContent.UpdatesAvailableCount ->
UpdateAllLink(content.additionalContent, content, onEvent)

PackageListItem.Header.AdditionalContent.Loading -> CircularProgressIndicator()
PackageListItem.Header.AdditionalContent.Loading -> CircularProgressIndicator()
}
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@ import androidx.compose.ui.Modifier
import androidx.compose.ui.text.style.TextAlign
import androidx.compose.ui.unit.dp
import com.jetbrains.packagesearch.plugin.PackageSearchBundle
import com.jetbrains.packagesearch.plugin.ui.PackageSearchMetrics
import com.jetbrains.packagesearch.plugin.ui.bridge.LabelInfo
import com.jetbrains.packagesearch.plugin.ui.model.infopanel.InfoPanelContent
import com.jetbrains.packagesearch.plugin.ui.model.infopanel.InfoPanelViewModel
Expand Down Expand Up @@ -56,7 +57,7 @@ fun PackageSearchInfoPanel(
Box(modifier = Modifier.fillMaxWidth()) {
Column(
modifier = Modifier
.padding(start = 4.dp, top = 4.dp, end = 16.dp, bottom = 12.dp)
.padding(start = 4.dp, end = PackageSearchMetrics.scrollbarWidth)
.verticalScroll(viewModel.scrollState)
) {
val tab = activeTab
Expand All @@ -83,7 +84,10 @@ private fun NoTabsAvailable() {
Modifier.fillMaxSize(),
contentAlignment = Alignment.Center,
) {
LabelInfo(PackageSearchBundle.message("packagesearch.ui.toolwindow.packages.details.noItemSelected"), textAlign = TextAlign.Center)
LabelInfo(
PackageSearchBundle.message("packagesearch.ui.toolwindow.packages.details.noItemSelected"),
textAlign = TextAlign.Center
)
}
}

Loading

0 comments on commit ab90ce9

Please sign in to comment.