Go to file
Zach Eriksen 62a3d1f34a
Update README.md
2021-06-22 20:13:00 -05:00
.swiftpm/xcode/package.xcworkspace/xcshareddata Initial Commit 2021-05-24 21:38:48 -05:00
Sources/ObjectUI Added ObjectView PreviewProvider 2021-06-22 18:55:47 -05:00
Tests/ObjectUITests 👊 commit 2021-05-24 21:48:14 -05:00
.gitignore Initial Commit 2021-05-24 21:38:48 -05:00
Package.resolved 👊 commit 2021-05-24 21:48:14 -05:00
Package.swift 👊 commit 2021-05-24 21:48:14 -05:00
README.md Update README.md 2021-06-22 20:13:00 -05:00

README.md

ObjectUI

Create SwiftUI Views with any data

Usage

import ObjectUI

Basic Example

struct ContentView: View {
    var body: some View {
        ObjectView { object in
            VStack {
                if let value = object.value(as: String.self) {
                    Text(value)
                        .font(.largeTitle)
                } else {
                    Text("Waiting...")
                }
                
                Button("Wave") {
                    DispatchQueue.main.async {
                        object.set(value: "👋")
                    }
                }
            }
        }
    }
}

JSON Example

struct ContentView: View {
    let json = """
        {
          "userId": 1,
          "id": 2,
          "title": "quis ut nam facilis et officia qui",
          "completed": false
        }
        """
        .data(using: .utf8)
    
    var body: some View {
        ObjectView(data: json) { object in
            VStack {
                object.userId.value(as: Int.self).map { userId in
                    Text("\(userId)")
                }
                
                object.id.value(as: Int.self).map { id in
                    Text("\(id)")
                }
                
                object.title.value(as: String.self).map { title in
                    Text(title)
                }
                
                object.completed.value(as: Bool.self).map { completed in
                    Text(completed.description)
                }
            }
        }
    }
}