Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/emirhanemmez/MultiStepsProgressBar

A customizable onboarding progressbar component
https://github.com/emirhanemmez/MultiStepsProgressBar

android android-library compose compose-library jetpack-compose kotlin onboarding onboarding-screen progressbar

Last synced: 3 months ago
JSON representation

A customizable onboarding progressbar component

Awesome Lists containing this project

README

        

# MultiStepsProgressBar

A customizable progressbar component can be used in onboarding screens for Jetpack Compose.

![MultiStepsProgressBar](https://github.com/emirhanemmez/MultiStepsProgressBar/blob/main/screenshot/animation.gif)

## Implementation

Add jitpack.io maven to **settings.gradle.kts**

```gradle
pluginManagement {
repositories {
google {
content {
includeGroupByRegex("com\\.android.*")
includeGroupByRegex("com\\.google.*")
includeGroupByRegex("androidx.*")
}
}
mavenCentral()
mavenLocal()
maven(url = "https://jitpack.io")
gradlePluginPortal()
}
}
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
google()
mavenLocal()
maven(url = "https://jitpack.io")
mavenCentral()
}
}
```

Add library dependency to your **build.gradle.kts**

```gradle
implementation("com.github.emirhanemmez:MultiStepsProgressBar:version")
```

## Usage

Define your **stepList** as **SnapShotStateList** in your ViewModel. For example:

```kt
class MainViewModel : ViewModel() {

private val _stepList = mutableStateListOf().apply {
addAll(
listOf(
StepData(
stepId = Id.FirstStep,
stepName = "Step1",
progress = ProgressProperties.PROGRESS_FULL
),
StepData(
stepId = Id.SecondStep,
stepName = "Step2",
progress = ProgressProperties.PROGRESS_NONE,
),
StepData(
stepId = Id.ThirdStep,
stepName = "Step3",
progress = ProgressProperties.PROGRESS_HALF
)
)
)
}
val stepList: List = _stepList

fun updateProgressesWithRandomValues() {
_stepList.updateStepProgress(Id.FirstStep, Random.nextFloat())
_stepList.updateStepProgress(Id.SecondStep, Random.nextFloat())
_stepList.updateStepProgress(Id.ThirdStep, Random.nextFloat())
}

sealed class Id(id: Int) : StepId(id) {
data object FirstStep : Id(0)
data object SecondStep : Id(1)
data object ThirdStep : Id(2)
}
}
```

Observe **stepList** in your composable function:

```kt
class MainActivity : ComponentActivity() {

private lateinit var mainViewModel: MainViewModel

override fun onCreate(savedInstanceState: Bundle?) {

mainViewModel = ViewModelProvider(this)[MainViewModel::class.java]

super.onCreate(savedInstanceState)
setContent {
MyTheme {
// A surface container using the 'background' color from the theme
Surface(
modifier = Modifier.fillMaxSize(),
color = MaterialTheme.colorScheme.background
) {
Column(
horizontalAlignment = Alignment.CenterHorizontally
) {
Spacer(modifier = Modifier.height(56.dp))

MultipleStepsProgressBar(
stepDataList = mainViewModel.stepList
)

Spacer(modifier = Modifier.height(56.dp))

Button(onClick = {
mainViewModel.updateProgressesWithRandomValues()
}) {
Text(text = "Click for random progresses")
}
}
}
}
}
}
}
```

And update progress with this extension function:

```kt
fun SnapshotStateList.updateStepProgress(stepId: StepId, progress: Float) {
val index = stepId.index
val step = this[index]
this[index] = step.copy(progress = progress)
}
```

For UI customization please check [StepProperties.kt](https://github.com/emirhanemmez/MultiStepsProgressBar/blob/main/multistepsprogressbar/src/main/java/com/emirhanemmez/multistepsprogressbar/model/StepProperties.kt)