Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/CodandoTV/CraftD
A Server Driven UI library
https://github.com/CodandoTV/CraftD
android flutter jetpack-compose server-driven-ui swift swiftui
Last synced: 3 months ago
JSON representation
A Server Driven UI library
- Host: GitHub
- URL: https://github.com/CodandoTV/CraftD
- Owner: CodandoTV
- License: mit
- Created: 2024-04-19T12:28:00.000Z (10 months ago)
- Default Branch: main
- Last Pushed: 2024-09-24T20:34:12.000Z (5 months ago)
- Last Synced: 2024-10-01T01:44:16.097Z (5 months ago)
- Topics: android, flutter, jetpack-compose, server-driven-ui, swift, swiftui
- Language: Kotlin
- Homepage: https://codandotv.gitbook.io/craftd
- Size: 720 KB
- Stars: 20
- Watchers: 5
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
- awesome-list - CodandoTV/CraftD - A Server Driven UI library (Kotlin)
README
[data:image/s3,"s3://crabby-images/3c0d8/3c0d8f7a6d007c1b29583491b176d86412c97ab1" alt="Android API"](https://android-arsenal.com/api?level=21)
[data:image/s3,"s3://crabby-images/75c2b/75c2bd0dab87c450b7e5292fb51b4ab4ebac28bd" alt="kotlin"](https://kotlinlang.org/)
[data:image/s3,"s3://crabby-images/048fa/048fa6d5e4413567fc669c1aa158e4050daf51ea" alt="License MIT"](https://opensource.org/licenses/MIT)
![]()
CraftD: A framework to implement Server-Driven UI quickly and easily to Android / iOS / Flutter / Kmp### Documentation
See the [project website](https://codandotv.gitbook.io/craftd) for documentation.Take a look at [CraftD: Server Driven UI for All Platforms](https://medium.com/codandotv/craftd-server-driven-ui-for-all-platforms-b2624d2c2a7b)
## Features
### 🔗 Compatibility| Tech | Support |
|---------------------------------|:--------------------:|
| View System - Android | ✅ **Supported** |
| Jetpack Compose - Android | ✅ **Supported** |
| Widget - Flutter | ✅ **Supported** |
| SwiftUi - iOS | ✅ **Supported** |
| Jetpack Compose - Multiplatform | ⚒️ **In Progress** |### Components that already exist in the library
| Component | Compose | View System | Widget | SwiftUI |
|-----------|----------|----------|----------|----------|
| Button | X | X | X | X |
| Text | X | X | X | X |
| CheckBox | X | - | - | X |### Create your custom component( android compose example )
```kotlin
@JsonIgnoreProperties(ignoreUnknown = true)
@Immutable
@Stable
data class CheckBoxProperties(
@JsonProperty("text") val text: String? = null,
... rest of your properties
)```
#### Add your Component json object in Dymanic.json
```json
{
"key": "CraftDCheckBox",
"value": {
... place your properties
}
}```
#### Create your Component
```kotlin
@Composable
fun CraftDCheckBox(
checkboxProperties: CheckBoxProperties,
modifier: Modifier = Modifier,
onChecked: (Boolean) -> Unit
) {
... place your code
}
```#### Create your Component Builder
```kotlin
class CraftDCheckBoxBuilder(
override val key: String = CraftDComponentKey.CHECK_BOX_COMPONENT.key
) :
CraftDBuilder {
@Composable
override fun craft(model: SimpleProperties, listener: CraftDViewListener) {
val checkBoxProperties = model.value.convertToVO()
CraftDCheckBox(checkBoxProperties) {
checkBoxProperties.actionProperties?.let { listener.invoke(it) }
}
}
}
```More details check our [documentation](https://codandotv.gitbook.io/craftd)
### Samples
| [Android Compose](https://github.com/CodandoTV/CraftD/tree/main/android_kmp/app-sample/src/main/java/com/github/codandotv/craftd/app_sample/presentation/compose) | [Android View System](https://github.com/CodandoTV/CraftD/tree/main/android_kmp/app-sample/src/main/java/com/github/codandotv/craftd/app_sample/presentation/xml) | [iOS SwiftUI](https://github.com/CodandoTV/CraftD/tree/main/ios/sample/CraftDSample) | [Flutter](https://github.com/CodandoTV/CraftD/tree/main/flutter/sample/lib) |
|----------|----------|----------|----------|
||
|
|
|
### Credits
> A Server Driven UI library for Android.
Inspired by the [DynamicView](https://github.com/rviannaoliveira/DynamicView/).
This project exists thanks to all the people who contribute.
![]()