From dd95303dac23536c50e49edcae719ca4ec289401 Mon Sep 17 00:00:00 2001 From: Ahmed Hosny Date: Thu, 8 Feb 2024 00:39:13 +0200 Subject: [PATCH 1/4] Support Rtl in SplitPane --- .../compose/splitpane/SplitPaneDSL.kt | 21 +++++++++++++------ .../compose/splitpane/DesktopSplitPane.kt | 14 ++++++------- .../compose/splitpane/DesktopSplitter.kt | 19 +++++++++++------ 3 files changed, 35 insertions(+), 19 deletions(-) diff --git a/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt b/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt index 0a730931d42..6f0e2535289 100644 --- a/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt +++ b/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt @@ -5,7 +5,9 @@ import androidx.compose.runtime.Composable import androidx.compose.runtime.remember import androidx.compose.ui.Modifier import androidx.compose.ui.input.pointer.pointerInput +import androidx.compose.ui.platform.LocalLayoutDirection import androidx.compose.ui.unit.Dp +import androidx.compose.ui.unit.LayoutDirection import androidx.compose.ui.unit.dp /** Receiver scope which is used by [HorizontalSplitPane] and [VerticalSplitPane] */ @@ -46,6 +48,7 @@ interface SplitPaneScope { @ExperimentalSplitPaneApi interface HandleScope { /** allow mark composable as movable handle */ + @Composable fun Modifier.markAsHandle(): Modifier } @@ -83,12 +86,18 @@ interface SplitterScope { internal class HandleScopeImpl( private val containerScope: SplitPaneScopeImpl ) : HandleScope { - override fun Modifier.markAsHandle(): Modifier = this.pointerInput(containerScope.splitPaneState) { - detectDragGestures { change, _ -> - change.consume() - containerScope.splitPaneState.dispatchRawMovement( - if (containerScope.isHorizontal) change.position.x else change.position.y - ) + @Composable + override fun Modifier.markAsHandle(): Modifier = this.run { + val layoutDirection = LocalLayoutDirection.current + pointerInput(containerScope.splitPaneState) { + detectDragGestures { change, _ -> + change.consume() + containerScope.splitPaneState.dispatchRawMovement( + if (containerScope.isHorizontal) + if (layoutDirection == LayoutDirection.Ltr) change.position.x else -change.position.x + else change.position.y + ) + } } } } diff --git a/components/SplitPane/library/src/desktopMain/kotlin/org/jetbrains/compose/splitpane/DesktopSplitPane.kt b/components/SplitPane/library/src/desktopMain/kotlin/org/jetbrains/compose/splitpane/DesktopSplitPane.kt index cf978e2ae8e..a8c1f00d22a 100644 --- a/components/SplitPane/library/src/desktopMain/kotlin/org/jetbrains/compose/splitpane/DesktopSplitPane.kt +++ b/components/SplitPane/library/src/desktopMain/kotlin/org/jetbrains/compose/splitpane/DesktopSplitPane.kt @@ -121,18 +121,18 @@ internal actual fun SplitPane( } layout(constraints.maxWidth, constraints.maxHeight) { - firstPlaceable.place(0, 0) + firstPlaceable.placeRelative(0, 0) if (isHorizontal) { - secondPlaceable.place(secondPlaceablePosition, 0) - splitterPlaceable.place(position, 0) + secondPlaceable.placeRelative(secondPlaceablePosition, 0) + splitterPlaceable.placeRelative(position, 0) if (moveEnabled) { - handlePlaceable.place(handlePosition, 0) + handlePlaceable.placeRelative(handlePosition, 0) } } else { - secondPlaceable.place(0, secondPlaceablePosition) - splitterPlaceable.place(0, position) + secondPlaceable.placeRelative(0, secondPlaceablePosition) + splitterPlaceable.placeRelative(0, position) if (moveEnabled) { - handlePlaceable.place(0, handlePosition) + handlePlaceable.placeRelative(0, handlePosition) } } } diff --git a/components/SplitPane/library/src/desktopMain/kotlin/org/jetbrains/compose/splitpane/DesktopSplitter.kt b/components/SplitPane/library/src/desktopMain/kotlin/org/jetbrains/compose/splitpane/DesktopSplitter.kt index 15e5c6cccb1..92ad6749e87 100644 --- a/components/SplitPane/library/src/desktopMain/kotlin/org/jetbrains/compose/splitpane/DesktopSplitter.kt +++ b/components/SplitPane/library/src/desktopMain/kotlin/org/jetbrains/compose/splitpane/DesktopSplitter.kt @@ -6,6 +6,8 @@ import androidx.compose.runtime.Composable import androidx.compose.ui.ExperimentalComposeUiApi import androidx.compose.ui.Modifier import androidx.compose.ui.input.pointer.* +import androidx.compose.ui.platform.LocalLayoutDirection +import androidx.compose.ui.unit.LayoutDirection import androidx.compose.ui.unit.dp import java.awt.Cursor @@ -20,12 +22,17 @@ private fun DesktopHandle( splitPaneState: SplitPaneState ) = Box( Modifier - .pointerInput(splitPaneState) { - detectDragGestures { change, _ -> - change.consumeAllChanges() - splitPaneState.dispatchRawMovement( - if (isHorizontal) change.position.x else change.position.y - ) + .run { + val layoutDirection = LocalLayoutDirection.current + pointerInput(splitPaneState) { + detectDragGestures { change, _ -> + change.consume() + splitPaneState.dispatchRawMovement( + if (isHorizontal) + if (layoutDirection == LayoutDirection.Ltr) change.position.x else -change.position.x + else change.position.y + ) + } } } .cursorForHorizontalResize(isHorizontal) From 68675760ffa2e7d8f423489384f37d3f5c9acbb9 Mon Sep 17 00:00:00 2001 From: Ahmed Hosny Date: Thu, 8 Feb 2024 15:16:24 +0200 Subject: [PATCH 2/4] Update components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt Co-authored-by: Igor Demin --- .../kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt | 1 - 1 file changed, 1 deletion(-) diff --git a/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt b/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt index 6f0e2535289..97d87e43669 100644 --- a/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt +++ b/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt @@ -48,7 +48,6 @@ interface SplitPaneScope { @ExperimentalSplitPaneApi interface HandleScope { /** allow mark composable as movable handle */ - @Composable fun Modifier.markAsHandle(): Modifier } From 100f56690be19a8bb5e740eb8cf47c4d53e4dad1 Mon Sep 17 00:00:00 2001 From: Ahmed Hosny Date: Thu, 8 Feb 2024 15:16:37 +0200 Subject: [PATCH 3/4] Update components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt Co-authored-by: Igor Demin --- .../kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt b/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt index 97d87e43669..665aa51de72 100644 --- a/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt +++ b/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt @@ -86,7 +86,7 @@ internal class HandleScopeImpl( private val containerScope: SplitPaneScopeImpl ) : HandleScope { @Composable - override fun Modifier.markAsHandle(): Modifier = this.run { + override fun Modifier.markAsHandle(): Modifier = composed { val layoutDirection = LocalLayoutDirection.current pointerInput(containerScope.splitPaneState) { detectDragGestures { change, _ -> From b24eadefa283d3fbed62921c6439e605b2035ed4 Mon Sep 17 00:00:00 2001 From: Ahmed Hosny Date: Thu, 8 Feb 2024 15:24:34 +0200 Subject: [PATCH 4/4] Update components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt --- .../kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt b/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt index 665aa51de72..4c533431524 100644 --- a/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt +++ b/components/SplitPane/library/src/commonMain/kotlin/org/jetbrains/compose/splitpane/SplitPaneDSL.kt @@ -4,6 +4,7 @@ import androidx.compose.foundation.gestures.detectDragGestures import androidx.compose.runtime.Composable import androidx.compose.runtime.remember import androidx.compose.ui.Modifier +import androidx.compose.ui.composed import androidx.compose.ui.input.pointer.pointerInput import androidx.compose.ui.platform.LocalLayoutDirection import androidx.compose.ui.unit.Dp @@ -85,7 +86,6 @@ interface SplitterScope { internal class HandleScopeImpl( private val containerScope: SplitPaneScopeImpl ) : HandleScope { - @Composable override fun Modifier.markAsHandle(): Modifier = composed { val layoutDirection = LocalLayoutDirection.current pointerInput(containerScope.splitPaneState) {