Just been working on some small polish things. Like real small things—make sure the buttons have the right color. So I over-engineered it! I always forget how to make custom ButtonStyle
, so putting this here for reference. I have a view modifier for the shared stuff between multiple button styles that can simply be used like .buttonBase
. Than to style a button, .buttonStyle(.primaryButton)
. Easy! Definitely worth the effort for the 2 buttons I have. But did do some Swift generics stuff which is always exciting...
struct ButtonBase<S: ShapeStyle>: ViewModifier {
let background: S
let isPressed: Bool
func body(content: Content) -> some View {
content
.padding(.horizontal, 20)
.padding(.vertical, 6)
.background(background)
.opacity(isPressed ? 0.5 : 1)
}
}
extension View {
func buttonBase<S: ShapeStyle>(background: S, isPressed: Bool) -> some View {
modifier(ButtonBase(background: background, isPressed: isPressed))
}
}
struct PrimaryButton: ButtonStyle {
@Environment(\.colorScheme) private var colorScheme
func makeBody(configuration: Configuration) -> some View {
configuration.label
.buttonBase(background: Color.primary, isPressed: configuration.isPressed)
}
}
extension ButtonStyle where Self == PrimaryButton {
static var primary: Self {
return .init()
}
}