Skip to content

kevinhermawan/ViewState

Repository files navigation

ViewState

An extension that provides essential state modifiers to SwiftUI views.

Overview

ViewState is a SwiftUI extension that introduces state modifiers to manage common view states. ViewState simplifies the process of displaying loaders, representing empty states and showcasing errors.

Installation

You can add ViewState as a dependency to your project using Swift Package Manager by adding it to the dependencies value of your Package.swift.

dependencies: [
    .package(url: "https://github.com/kevinhermawan/ViewState.git", .upToNextMajor(from: "1.2.2"))
]

Alternatively, in Xcode:

  1. Open your project in Xcode.
  2. Click on File -> Swift Packages -> Add Package Dependency...
  3. Enter the repository URL: https://github.com/kevinhermawan/ViewState.git
  4. Choose the version you want to add. You probably want to add the latest version.
  5. Click Add Package.

Usage

import SwiftUI
import ViewState

struct Example: View {
    @State private var viewState: ViewState? = .loading

    var body: some View {
        VStack {
            Text("This is the main content.")
        }
        .when(viewState, is: .loading) {
            ProgressView()
                .progressViewStyle(.circular)
        }
        .when(viewState, is: .empty) {
            ContentUnavailableView {
                Text("There is no data to display.")
            }
        }
        .whenError(viewState) { message in
            ContentUnavailableView {
                Text(message)
            }
        }
    }
}

License

MIT License

About

An extension that provides essential state modifiers to SwiftUI views

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages