Simplify Compose, Accelerate Development 🚀
- Query - A seamless data fetching and caching. written more declaratively, leading to more readable code.
- Form - A extensible validation control and form state management. minimizes the impact of re-composition.
- Space - A flexible scoped state management. collaborating with the navigation library to create new scopes.
The following example demonstrates the basic usage of a Query to fetch the number of GitHub stars for the Soil GitHub project itself.
private val swrClient = SwrCache(
policy = SwrCachePolicy(coroutineScope = SwrCacheScope()) {
httpClient = /* createKtorHttpClient() */
}
)
@Composable
fun App() {
SwrClientProvider(client = swrClient) {
Box {
when (val query = rememberQuery(key = HelloQueryKey())) {
is QuerySuccessObject -> Text("✨ ${query.data.stargazersCount}")
is QueryLoadingObject -> Text("Loading...")
is QueryLoadingErrorObject,
is QueryRefreshErrorObject -> Text("Error :(")
}
}
}
}
@Immutable
class HelloQueryKey : KeyEquals(), QueryKey<Repo> by buildKtorQueryKey(
id = QueryId("demo/hello-query"),
fetch = { // HttpClient.() -> Repo
get("https://api.github.com/repos/soil-kt/soil").body()
}
)
@Serializable
data class Repo(
@SerialName("stargazers_count")
val stargazersCount: Int
)
The Soil library for Kotlin Multiplatform now includes experimental support for Kotlin Wasm. If your browser supports WasmGC, you can run the sample app directly in the browser.
Source code: https://github.com/soil-kt/soil/tree/main/sample/
Note
Currently, the only browsers that support WasmGC are Chrome and Firefox. For the latest compatibility information, please visit https://webassembly.org/features/.
Soil is available on mavenCentral()
.
dependencies {
val soil = "1.0.0-alpha09"
// Query
implementation("com.soil-kt.soil:query-core:$soil")
// Query for Compose
implementation("com.soil-kt.soil:query-compose:$soil")
// optional - experimental helpers for Compose
implementation("com.soil-kt.soil:query-compose-runtime:$soil")
// optional - receivers for Ktor (3.x)
implementation("com.soil-kt.soil:query-receivers-ktor:$soil")
// optional - Test helpers
testImplementation("com.soil-kt.soil:query-test:$soil")
// Form
implementation("com.soil-kt.soil:form:$soil")
// Space
implementation("com.soil-kt.soil:space:$soil")
}
Compose Multiplatform compatibility
Supported targets:
- Android
- iOS
- Desktop (JVM)
- Web (Wasm)
Please visit docs.soil-kt.com for Quick Start, guides of features and more.
Thank you for featuring our library in the following sources:
Copyright 2024 Soil Contributors
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
https://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.