Skip to content

Commit

Permalink
Add the possibility to make button load
Browse files Browse the repository at this point in the history
  • Loading branch information
LunarX committed Oct 17, 2024
1 parent 88ab73f commit d413a13
Showing 1 changed file with 101 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,12 @@ import androidx.annotation.StringRes
import androidx.compose.foundation.layout.*
import androidx.compose.material3.*
import androidx.compose.runtime.Composable
import androidx.compose.runtime.derivedStateOf
import androidx.compose.runtime.getValue
import androidx.compose.runtime.remember
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.alpha
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.graphics.vector.ImageVector
import androidx.compose.ui.res.stringResource
Expand All @@ -37,28 +42,60 @@ import com.infomaniak.swisstransfer.ui.theme.Dimens
import com.infomaniak.swisstransfer.ui.theme.Margin
import com.infomaniak.swisstransfer.ui.theme.SwissTransferTheme


/**
* Specifying a progress has the priority over specifying showIndeterminateProgress
*/
@Composable
fun LargeButton(
@StringRes titleRes: Int,
modifier: Modifier = Modifier,
style: ButtonType = ButtonType.PRIMARY,
enabled: () -> Boolean = { true },
showIndeterminateProgress: () -> Boolean = { false },
determinateProgress: (() -> Float)? = null,
onClick: () -> Unit,
imageVector: ImageVector? = null,
) {
CoreButton(titleRes, modifier, ButtonSize.LARGE, style, enabled, onClick, imageVector)
CoreButton(
titleRes,
modifier,
ButtonSize.LARGE,
style,
enabled,
showIndeterminateProgress,
determinateProgress,
onClick,
imageVector,
)
}


/**
* Specifying a progress has the priority over specifying showIndeterminateProgress
*/
@Composable
fun SmallButton(
@StringRes titleRes: Int,
modifier: Modifier = Modifier,
style: ButtonType = ButtonType.PRIMARY,
enabled: () -> Boolean = { true },
showIndeterminateProgress: () -> Boolean = { false },
determinateProgress: (() -> Float)? = null,
onClick: () -> Unit,
imageVector: ImageVector? = null,
) {
CoreButton(titleRes, modifier, ButtonSize.SMALL, style, enabled, onClick, imageVector)
CoreButton(
titleRes,
modifier,
ButtonSize.SMALL,
style,
enabled,
showIndeterminateProgress,
determinateProgress,
onClick,
imageVector,
)
}

@Composable
Expand All @@ -68,16 +105,46 @@ private fun CoreButton(
buttonSize: ButtonSize,
style: ButtonType,
enabled: () -> Boolean,
showIndeterminateProgress: () -> Boolean,
progress: (() -> Float)?,
onClick: () -> Unit,
imageVector: ImageVector?,
) {
val isEnabled by remember { derivedStateOf { enabled() || showIndeterminateProgress() } }
val buttonColors = style.buttonColors()

Button(
modifier = modifier.height(buttonSize.height),
colors = style.buttonColors(),
colors = buttonColors,
shape = CustomShapes.medium,
enabled = enabled(),
enabled = isEnabled,
onClick = onClick,
) {
when {
progress != null -> {
val (progressColor, progressModifier) = getProgressSpecs(buttonColors)
Box(contentAlignment = Alignment.Center) {
ButtonTextContent(imageVector, titleRes, Modifier.alpha(0f))
CircularProgressIndicator(modifier = progressModifier, color = progressColor, progress = progress)
}
}
showIndeterminateProgress() -> {
val (progressColor, progressModifier) = getProgressSpecs(buttonColors)
Box(contentAlignment = Alignment.Center) {
ButtonTextContent(imageVector, titleRes, Modifier.alpha(0f))
CircularProgressIndicator(modifier = progressModifier, color = progressColor)
}
}
else -> {
ButtonTextContent(imageVector, titleRes)
}
}
}
}

@Composable
private fun ButtonTextContent(imageVector: ImageVector?, titleRes: Int, modifier: Modifier = Modifier) {
Row(modifier = modifier) {
imageVector?.let {
Icon(modifier = Modifier.size(Margin.Medium), imageVector = it, contentDescription = null)
Spacer(modifier = Modifier.width(Margin.Small))
Expand All @@ -86,6 +153,15 @@ private fun CoreButton(
}
}

@Composable
private fun getProgressSpecs(buttonColors: ButtonColors): Pair<Color, Modifier> {
val progressColor = buttonColors.contentColor
val progressModifier = Modifier
.fillMaxHeight(0.8f)
.aspectRatio(1f)
return Pair(progressColor, progressModifier)
}

enum class ButtonType(val buttonColors: @Composable () -> ButtonColors) {
PRIMARY({
ButtonDefaults.buttonColors(
Expand Down Expand Up @@ -118,18 +194,36 @@ private enum class ButtonSize(val height: Dp) {
SMALL(40.dp),
}

@Preview(name = "Light")
@Preview(name = "Dark", uiMode = Configuration.UI_MODE_NIGHT_YES or Configuration.UI_MODE_TYPE_NORMAL)
@Preview(name = "Light", widthDp = 800)
@Preview(name = "Dark", widthDp = 800, uiMode = Configuration.UI_MODE_NIGHT_YES or Configuration.UI_MODE_TYPE_NORMAL)
@Composable
private fun LargeButtonPreview() {
SwissTransferTheme {
Surface {
Column {
ButtonType.entries.forEach {
Row {
LargeButton(titleRes = R.string.appName, style = it, imageVector = AppIcons.Add, onClick = {})
LargeButton(titleRes = R.string.appName, style = it, onClick = {}, imageVector = AppIcons.Add)
Spacer(modifier = Modifier.width(Margin.Small))
LargeButton(
titleRes = R.string.appName,
style = it,
determinateProgress = { 0.3f },
onClick = {},
imageVector = AppIcons.Add
)

Spacer(modifier = Modifier.width(Margin.Small))

SmallButton(titleRes = R.string.appName, style = it, imageVector = AppIcons.Add, onClick = {})
Spacer(modifier = Modifier.width(Margin.Small))
SmallButton(
titleRes = R.string.appName,
style = it,
determinateProgress = { 0.3f },
imageVector = AppIcons.Add,
onClick = {}
)
}
Spacer(modifier = Modifier.height(Margin.Medium))
}
Expand Down

0 comments on commit d413a13

Please sign in to comment.