Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add API to standalone to easily create an SvgLoader #139

Merged
merged 1 commit into from
Sep 29, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 0 additions & 16 deletions core/src/main/kotlin/org/jetbrains/jewel/Icon.kt
Original file line number Diff line number Diff line change
Expand Up @@ -90,22 +90,6 @@ fun Icon(
)
}

@Composable
fun Icon(
fscarponi marked this conversation as resolved.
Show resolved Hide resolved
resource: String,
contentDescription: String?,
modifier: Modifier = Modifier,
resourceLoader: ResourceLoader = LocalResourceLoader.current,
tint: Color = Color.Unspecified,
) {
Icon(
painter = painterResource(resource, resourceLoader),
contentDescription = contentDescription,
modifier = modifier,
tint = tint,
)
}

/**
* Icon component that draws a [painter] using [tint], defaulting to
* [Color.Unspecified]
Expand Down
21 changes: 21 additions & 0 deletions core/src/main/kotlin/org/jetbrains/jewel/NoIndication.kt
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
package org.jetbrains.jewel

import androidx.compose.foundation.Indication
import androidx.compose.foundation.IndicationInstance
import androidx.compose.foundation.interaction.InteractionSource
import androidx.compose.runtime.Composable
import androidx.compose.ui.graphics.drawscope.ContentDrawScope

object NoIndication : Indication {
fscarponi marked this conversation as resolved.
Show resolved Hide resolved

private object NoIndicationInstance : IndicationInstance {

override fun ContentDrawScope.drawIndication() {
drawContent()
}
}

@Composable
override fun rememberUpdatedInstance(interactionSource: InteractionSource): IndicationInstance =
NoIndicationInstance
}
19 changes: 0 additions & 19 deletions core/src/main/kotlin/org/jetbrains/jewel/Tabs.kt
Original file line number Diff line number Diff line change
@@ -1,13 +1,10 @@
package org.jetbrains.jewel

import androidx.compose.foundation.Image
import androidx.compose.foundation.Indication
import androidx.compose.foundation.IndicationInstance
import androidx.compose.foundation.LocalIndication
import androidx.compose.foundation.background
import androidx.compose.foundation.clickable
import androidx.compose.foundation.interaction.HoverInteraction
import androidx.compose.foundation.interaction.InteractionSource
import androidx.compose.foundation.interaction.MutableInteractionSource
import androidx.compose.foundation.interaction.PressInteraction
import androidx.compose.foundation.layout.Arrangement
Expand All @@ -33,7 +30,6 @@ import androidx.compose.ui.draw.drawBehind
import androidx.compose.ui.geometry.Offset
import androidx.compose.ui.graphics.SolidColor
import androidx.compose.ui.graphics.StrokeCap
import androidx.compose.ui.graphics.drawscope.ContentDrawScope
import androidx.compose.ui.input.pointer.PointerEventType
import androidx.compose.ui.input.pointer.isTertiary
import androidx.compose.ui.input.pointer.onPointerEvent
Expand Down Expand Up @@ -165,21 +161,6 @@ internal fun TabImpl(
}
}

private object NoIndication : Indication {
fscarponi marked this conversation as resolved.
Show resolved Hide resolved
private object NoIndicationInstance : IndicationInstance {

override fun ContentDrawScope.drawIndication() {
drawContent()
}
}

@Suppress("ExpressionBodySyntax")
@Composable
override fun rememberUpdatedInstance(interactionSource: InteractionSource): IndicationInstance {
return NoIndicationInstance
}
}

@Immutable
@JvmInline
value class TabState(val state: ULong) : SelectableComponentState {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,15 +1,11 @@
package org.jetbrains.jewel.intui.core

import androidx.compose.foundation.Indication
import androidx.compose.foundation.IndicationInstance
import androidx.compose.foundation.LocalContextMenuRepresentation
import androidx.compose.foundation.LocalIndication
import androidx.compose.foundation.interaction.InteractionSource
import androidx.compose.runtime.Composable
import androidx.compose.runtime.CompositionLocalProvider
import androidx.compose.runtime.ReadOnlyComposable
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.graphics.drawscope.ContentDrawScope
import androidx.compose.ui.text.TextStyle
import org.jetbrains.jewel.GlobalColors
import org.jetbrains.jewel.GlobalMetrics
Expand All @@ -19,6 +15,7 @@ import org.jetbrains.jewel.IntelliJTheme
import org.jetbrains.jewel.IntelliJThemeIconData
import org.jetbrains.jewel.LocalColorPalette
import org.jetbrains.jewel.LocalIconData
import org.jetbrains.jewel.NoIndication
import org.jetbrains.jewel.styling.ButtonStyle
import org.jetbrains.jewel.styling.CheckboxStyle
import org.jetbrains.jewel.styling.ChipStyle
Expand Down Expand Up @@ -225,17 +222,3 @@ fun BaseIntUiTheme(
IntelliJTheme(theme, swingCompatMode, content)
}
}

private object NoIndication : Indication {

private object NoIndicationInstance : IndicationInstance {

override fun ContentDrawScope.drawIndication() {
drawContent()
}
}

@Composable
override fun rememberUpdatedInstance(interactionSource: InteractionSource): IndicationInstance =
NoIndicationInstance
}
Original file line number Diff line number Diff line change
Expand Up @@ -197,21 +197,40 @@ fun IntUiTheme(
swingCompatMode: Boolean = false,
content: @Composable () -> Unit,
) {
val svgLoader by remember(themeDefinition.isDark, themeDefinition.iconData, themeDefinition.colorPalette) {
val svgLoader by rememberSvgLoader(
isDark = themeDefinition.isDark,
iconData = themeDefinition.iconData,
colorPalette = themeDefinition.colorPalette,
fscarponi marked this conversation as resolved.
Show resolved Hide resolved
)

val componentStyling = defaultComponentStyling(themeDefinition, svgLoader)
IntUiTheme(themeDefinition, componentStyling, swingCompatMode, content)
}

/**
* Create and remember an instance of [SvgLoader].
*
* Note that since [SvgLoader] may cache the loaded images, and
* that creating it may be somewhat expensive, you should only
* create it once at the top level, and pass it around.
*/
@Composable
fun rememberSvgLoader(
fscarponi marked this conversation as resolved.
Show resolved Hide resolved
isDark: Boolean = IntUiTheme.isDark,
iconData: IntelliJThemeIconData = IntUiTheme.iconData,
colorPalette: IntUiThemeColorPalette = IntUiTheme.colorPalette,
) =
remember(isDark, iconData, colorPalette) {
val paletteMapper =
StandalonePaletteMapperFactory.create(
themeDefinition.isDark,
themeDefinition.iconData,
themeDefinition.colorPalette,
isDark,
iconData,
colorPalette,
)
val svgPatcher = IntelliJSvgPatcher(paletteMapper)
mutableStateOf(JewelSvgLoader(svgPatcher))
}

val componentStyling = defaultComponentStyling(themeDefinition, svgLoader)
IntUiTheme(themeDefinition, componentStyling, swingCompatMode, content)
}

@Composable
fun IntUiTheme(
theme: IntUiThemeDefinition,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -29,14 +29,17 @@ import androidx.compose.ui.unit.dp
import androidx.compose.ui.window.singleWindowApplication
import org.jetbrains.jewel.CheckboxRow
import org.jetbrains.jewel.Divider
import org.jetbrains.jewel.JewelSvgLoader
import org.jetbrains.jewel.LocalResourceLoader
import org.jetbrains.jewel.VerticalScrollbar
import org.jetbrains.jewel.intui.standalone.IntUiTheme
import org.jetbrains.jewel.intui.standalone.rememberSvgLoader
import org.jetbrains.jewel.samples.standalone.components.Borders
import org.jetbrains.jewel.samples.standalone.components.Buttons
import org.jetbrains.jewel.samples.standalone.components.Checkboxes
import org.jetbrains.jewel.samples.standalone.components.ChipsAndTree
import org.jetbrains.jewel.samples.standalone.components.Dropdowns
import org.jetbrains.jewel.samples.standalone.components.Icons
import org.jetbrains.jewel.samples.standalone.components.Links
import org.jetbrains.jewel.samples.standalone.components.ProgressBar
import org.jetbrains.jewel.samples.standalone.components.RadioButtons
Expand All @@ -57,6 +60,7 @@ fun main() {

IntUiTheme(theme, swingCompat) {
val resourceLoader = LocalResourceLoader.current
val svgLoader by rememberSvgLoader()

val windowBackground = if (isDark) {
IntUiTheme.colorPalette.grey(1)
Expand All @@ -76,14 +80,14 @@ fun main() {

Divider(Modifier.fillMaxWidth())

ComponentShowcase()
ComponentShowcase(svgLoader, resourceLoader)
}
}
}
}

@Composable
private fun ComponentShowcase() {
private fun ComponentShowcase(svgLoader: JewelSvgLoader, resourceLoader: ResourceLoader) {
val verticalScrollState = rememberScrollState()

Box(Modifier.fillMaxSize()) {
Expand All @@ -104,7 +108,8 @@ private fun ComponentShowcase() {
TextAreas()
ProgressBar()
ChipsAndTree()
Tabs()
Tabs(svgLoader, resourceLoader)
Icons(svgLoader, resourceLoader)
}

VerticalScrollbar(
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
package org.jetbrains.jewel.samples.standalone.components

import androidx.compose.foundation.layout.Arrangement
import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.fillMaxWidth
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.size
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.remember
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.BlendMode
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.graphics.ColorFilter
import androidx.compose.ui.res.ResourceLoader
import androidx.compose.ui.unit.dp
import org.jetbrains.jewel.GroupHeader
import org.jetbrains.jewel.Icon
import org.jetbrains.jewel.SvgLoader
import org.jetbrains.jewel.styling.ResourcePainterProvider

@Composable
internal fun Icons(svgLoader: SvgLoader, resourceLoader: ResourceLoader) {
GroupHeader("Icons")

Row(
modifier = Modifier.fillMaxWidth().padding(horizontal = 16.dp),
horizontalArrangement = Arrangement.spacedBy(16.dp),
) {
val jewelLogoProvider = remember { ResourcePainterProvider.stateless("icons/jewel-logo.svg", svgLoader) }
val jewelLogo by jewelLogoProvider.getPainter(resourceLoader)

Icon(jewelLogo, "Jewel Logo", Modifier.size(16.dp))
Icon(jewelLogo, "Jewel Logo", Modifier.size(32.dp))
Icon(jewelLogo, "Jewel Logo", Modifier.size(64.dp))
Icon(jewelLogo, "Jewel Logo", Modifier.size(128.dp))
Icon(jewelLogo, "Jewel Logo", ColorFilter.tint(Color.Magenta, BlendMode.Multiply), Modifier.size(128.dp))
}
}
Loading