Flexbox-Compose
A Jetpack Compose layout that places its children in a way that CSS Flexible Box Layout Module does.
Installation
Flexbox-Compose is available in the mavenCentral()
, so you just need to add it as a dependency (Module gradle)
implementation("io.github.aghajari:Flexbox-Compose:1.0.0")
Usage
Flexbox Row
Flexbox(
flexDirection = FlexDirection.Row,
horizontalArrangement = Arrangement.spacedBy(16.dp),
verticalArrangement = Arrangement.spacedBy(16.dp),
) {
// Add items
items(list) {
RemovableItem(it)
}
item {
AddIcon()
}
}
Flexbox Column
Flexbox(
flexDirection = FlexDirection.Column,
horizontalArrangement = Arrangement.spacedBy(16.dp),
verticalArrangement = Arrangement.spacedBy(16.dp),
) {
// Add items
}
Arrangements
You can customize the arrangement of both axis in Flexbox.
Row
: horizontalArrangement defines the arrangement of Placeables on the line and verticalArrangement defines the arrangement of lines.Column
: verticalArrangement defines the arrangement of Placeables on the line and horizontalArrangement defines the arrangement of lines.
Examples:
- SpaceEvenly
Flexbox(
flexDirection = FlexDirection.Row,
horizontalArrangement = Arrangement.SpaceEvenly,
verticalArrangement = Arrangement.spacedBy(16.dp),
) {
// Add items
}
- Center
Flexbox(
flexDirection = FlexDirection.Row,
horizontalArrangement =
Arrangement.spacedBy(16.dp, Alignment.CenterHorizontally),
verticalArrangement = Arrangement.spacedBy(16.dp),
) {
// Add items
}
- End
Flexbox(
flexDirection = FlexDirection.Row,
horizontalArrangement =
Arrangement.spacedBy(16.dp, Alignment.End),
verticalArrangement = Arrangement.spacedBy(16.dp),
) {
// Add items
}
MaxLines
You can set an optional maximum number of lines.
- SingleLine
Flexbox(
flexDirection = FlexDirection.Row,
maxLines = 1,
...
) {
// Add items
}
Item Inline Alignment
You can set the default alignment of Placeables inside a FlexboxLine.
- Center
Flexbox(
flexDirection = FlexDirection.Row,
maxLines = 1,
itemInlineAlignment = Alignment.Center,
) {
// Add items
}
- Top
Flexbox(
flexDirection = FlexDirection.Row,
maxLines = 1,
itemInlineAlignment = Alignment.TopCenter,
) {
// Add items
}
Flexbox Animation
Customize the animation of item movements. A spring spec will be used for the animation by default.
You can pass null
to disable the animation.
val myAnimation = object : FlexboxAnimation {
override val visibilityThreshold = 0.01f
override val animationSpec = tween<Float>(
durationMillis = 600,
easing = FastOutSlowInEasing
)
}
Flexbox(
flexDirection = FlexDirection.Row,
animation = myAnimation,
) {
// Add items
}
Key Identifier
You can set a factory of stable and unique keys representing the item. Using the same key for multiple items in the list is not allowed.
If you have fixed amount you can use enums as keys, or if you have a list of items maybe an index in the list or some other unique key can work.
If null
is passed the position in the list will represent the key.
Flexbox(...) {
items(
list,
key = { list[it].key }
) {
Content(it)
}
item(MY_KEY) {
SingleItem()
}
}
Author
Amir Hossein Aghajari
License
Copyright 2023 Amir Hossein Aghajari
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.