- Xcode 11+
- SwiftUI
- iOS 14+
File ➜ Swift Packages ➜ Add Package Dependancy..
CMLoadingButton(action: { }, isLoading: <Binding>Bool, style: CMButtonStyle) {
// View on the button
// style is optional parameter
}
action
: Actions to do when button clickedisLoading
:<Binding>Bool
type. you can control loading status with this.style
(Optional) : Custom style withCMButtonStyle
CMButtonStyle(width: CGFloat,
height: CGFloat,
cornerRadius: CGFloat,
backgroundColor: Color,
loadingColor: Color,
strokeWidth: CGFloat,
strokeColor: Color)
// All of the parameter is optional
width
(Optional) : Width of buttonheight
(Optional) : Height of buttoncornerRadius
(Optional) : Corner radius of buttonbackgroundColor
(Optional) : Background color of buttonloadingColor
(Optional) : Background color of button whenLoading
, default is 50% opacity ofbackgroundColor
strokeWidth
(Optional) : Circle loading indicator stroke widthstrokeColor
(Optional) : Circle loading indicator stroke Color(default: gray)
import SwiftUI
import CMLoadingButton
struct ContentView: View {
@State var isLoading: Bool = false
var body: some View {
CMLoadingButton(action: {
// Your Action here
}, isLoading: $isLoading) {
Text("CMLoadingButton").foregroundColor(Color.white)
}
}
}
import SwiftUI
import CMLoadingButton
struct ContentView: View {
@State var isLoading: Bool = false
var style = CMButtonStyle(width: 312,
height: 54,
cornerRadius: 27,
backgroundColor: .orange,
loadingColor: Color.orange.opacity(0.5),
strokeWidth: 5,
strokeColor: .gray)
var body: some View {
CMLoadingButton(action: {
// Your Action here
}, isLoading: $isLoading, style: style) {
Text("Styled CMLoadingButton").foregroundColor(Color.white)
}
}
}
import SwiftUI
import CMLoadingButton
struct ContentView: View {
@State var isLoading: Bool = false
var body: some View {
CMLoadingButton(action: {
// Your Action here
}, isLoading: $isLoading, style: CMButtonStyle(cornerRadius: 27, backgroundColor: .orange)) {
Text("Styled CMLoadingButton").foregroundColor(Color.white)
}
}
}
- End animation(normal, shake(when fail), expand)
- Support gradient background color
Byun Kyung Min ➜ [email protected]
CMLoadingButton is available under the MIT license. See the LICENSE
file for more info.