Skip to content

Latest commit

 

History

History
139 lines (107 loc) · 2.57 KB

README.md

File metadata and controls

139 lines (107 loc) · 2.57 KB

SwiftUI extensions

A collection of SwiftUI convenient extensions and reusable custom views.

Basic alert

Convenient alert view modifier using an identifiable error type and displaying the localized error message.

struct ContentView: View {
  @State private var error: SomeError?
  
  var body: some View {
    ScrollView {
      //...
    }
    .basicAlert(error: $error)
  }
}

Loading button

SwiftUI button that handles async work and cancellation.

LoadingButton("Upload", systemImage: "arrow.up") {
  /// Tap to perform async work 
  /// or tap again to cancel the task.
}

Open link URL in-app

Solution proposed by Antoine van der Lee

VStack {
  Link("Apple", destination: URL(string: "https://www.apple.com")!)
  Text("Markdown link [website](https://www.apple.com)")
}
.openURLInApp()

Flow stack

FlowStack is similar to VStack and HStack layouts, but wrapping the content vertically when there is no space left horizontally.

ScrollView {
  FlowStack {
    ForEach(items, id: \.self) { item in
      TagView(item)
    }
  }
  .padding()
}

Screenshot

Share sheet

SwiftUI sheet based on UIKit UIActivityViewController.

struct SomeView: View {
  @State private var isSheetPresented = false
  
  var body: some View {
    ScrollView {
      //...
    }
    .shareSheet(isPresented: $isSheetPresented, items: [product.url])
  }
}

Toggle style: checkmark

Toggle("Show more options", isOn: $showMore)
  .toggleStyle(.checkCircle)

Stretching header

StretchingHeader {
  Image(.landscape)
    .resizable()
    .scaledToFill()
  Text("Photo credits: Marcus Lee")
    .font(.caption)
}

Lorem Ipsum text generator

guard let lipsum = String.loremIpsum(words: 20) else { return }
let words = lipsum.uniqueStrings()

Navigation stack

SettingsView()
  .navigationStack()
  .navigationBar(
    backgroundColor: .systemTeal,
    foregroundColor: .white,
    backSystemImage: "arrow.left",
    hideSeparator: true
  )

Fill & stroke combined shape modifier

Circle().fill(.red, stroke: .yellow, lineWidth: 4)

View size overlay

VStack {
  Rectangle().fill(.mint)
  Rectangle().fill(.brown)
  Rectangle().fill(.red)
  Rectangle().fill(.orange)
  Rectangle().fill(.yellow)
  Rectangle().fill(.cyan).overlaySize()
  Rectangle().fill(.teal)
  Rectangle().fill(.blue)
}

Screenshot