Modifier
Skip support for custom View Modifiers on Android. Consult the SkipUI module for a complete list of supported SwiftUI.
The following example screens and source code is from SkipUI’s
Showcase sample app
ModifierPlayground.swift
data:image/s3,"s3://crabby-images/3fb4b/3fb4b49a030c7e672ea1f7bb230c820bd26af017" alt="Android screenshot for Modifier component (light mode)"
data:image/s3,"s3://crabby-images/55090/55090958a54dd65a69986d3bdc09f8ed9a845d53" alt="iPhone screenshot for Modifier component (light mode)"
data:image/s3,"s3://crabby-images/0eac9/0eac96c3d0536a07a30bf0644272039a233c2f12" alt="iPhone screenshot for Modifier component (dark mode)"
data:image/s3,"s3://crabby-images/91df1/91df1985786d0daa3242f265eac008533f635bd8" alt="Android screenshot for Modifier component (dark mode)"
import SwiftUI
struct ModifierPlayground: View {
var body: some View {
Text("This text uses a custom modifier that adds a Dismiss button to the navigation bar above")
.padding()
.dismissable()
.toolbar {
PlaygroundSourceLink(file: "ModifierPlayground.swift")
}
}
}
extension View {
public func dismissable() -> some View {
modifier(DismissModifier())
}
}
struct DismissModifier: ViewModifier {
@State var isConfirmationPresented = false
@Environment(\.dismiss) var dismiss
func body(content: Content) -> some View {
content
.toolbar {
Button(action: { isConfirmationPresented = true }) {
Label("Dismiss", systemImage: "trash")
}
}
.confirmationDialog("Dismiss", isPresented: $isConfirmationPresented) {
Button("Dismiss", role: .destructive, action: { dismiss() })
}
}
}