mirror of
https://gitflic.ru/project/openide/openide.git
synced 2026-01-08 15:09:39 +07:00
Only apply workaround to CMP-5856 in toolwindows (#516)
This workaround should not be applied to _all_ JewelComposePanels, since it breaks auto-sizing for the panels based on their contents. This change creates a separate JewelToolWindowComposePanel that can be used for ToolWindows only, and removes the workaround from all other panels. GitOrigin-RevId: 1b51ea7092a12d5116d69e3ac8719be9979290d9
This commit is contained in:
committed by
intellij-monorepo-bot
parent
dd756abd01
commit
34791ce8da
@@ -65,6 +65,7 @@ public final class org/jetbrains/jewel/bridge/JewelBridgeException$KeysNotFoundE
|
||||
|
||||
public final class org/jetbrains/jewel/bridge/JewelComposePanelKt {
|
||||
public static final fun JewelComposePanel (Lkotlin/jvm/functions/Function2;)Ljavax/swing/JComponent;
|
||||
public static final fun JewelToolWindowComposePanel (Lkotlin/jvm/functions/Function2;)Ljavax/swing/JComponent;
|
||||
public static final fun getLocalComponent ()Landroidx/compose/runtime/ProvidableCompositionLocal;
|
||||
}
|
||||
|
||||
|
||||
@@ -14,10 +14,24 @@ import androidx.compose.ui.unit.toSize
|
||||
import org.jetbrains.jewel.bridge.actionSystem.ComponentDataProviderBridge
|
||||
import org.jetbrains.jewel.bridge.theme.SwingBridgeTheme
|
||||
import org.jetbrains.jewel.foundation.ExperimentalJewelApi
|
||||
import org.jetbrains.jewel.foundation.InternalJewelApi
|
||||
import javax.swing.JComponent
|
||||
|
||||
@Suppress("ktlint:standard:function-naming", "FunctionName") // Swing to Compose bridge API
|
||||
public fun JewelComposePanel(content: @Composable () -> Unit): JComponent =
|
||||
ComposePanel().apply {
|
||||
setContent {
|
||||
SwingBridgeTheme {
|
||||
CompositionLocalProvider(LocalComponent provides this@apply) {
|
||||
ComponentDataProviderBridge(this@apply, content = content)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@InternalJewelApi
|
||||
@Suppress("ktlint:standard:function-naming", "FunctionName") // Swing to Compose bridge API
|
||||
public fun JewelToolWindowComposePanel(content: @Composable () -> Unit): JComponent =
|
||||
ComposePanel().apply {
|
||||
setContent {
|
||||
Compose17IJSizeBugWorkaround {
|
||||
@@ -37,9 +51,9 @@ public val LocalComponent: ProvidableCompositionLocal<JComponent> =
|
||||
}
|
||||
|
||||
/**
|
||||
* Workaround until the issue with Compose 1.7 + fillMax__ + IntelliJ Panels is fixed:
|
||||
* https://github.com/JetBrains/jewel/issues/504
|
||||
* https://youtrack.jetbrains.com/issue/CMP-5856
|
||||
* Workaround until the issue with Compose 1.7 + fillMax__ + IntelliJ
|
||||
* Panels is fixed: https://github.com/JetBrains/jewel/issues/504
|
||||
* https://youtrack.jetbrains.com/issue/CMP-5856.
|
||||
*/
|
||||
@Composable
|
||||
private fun Compose17IJSizeBugWorkaround(content: @Composable () -> Unit) {
|
||||
|
||||
@@ -17,7 +17,7 @@ public fun ToolWindow.addComposeTab(
|
||||
|
||||
val tabContent =
|
||||
contentManager.factory.createContent(
|
||||
JewelComposePanel {
|
||||
JewelToolWindowComposePanel {
|
||||
val scope =
|
||||
object : ToolWindowScope {
|
||||
override val toolWindow: ToolWindow
|
||||
|
||||
Reference in New Issue
Block a user