SwiftUI-Custom-TextField
SwiftUI-Custom-TextField copied to clipboard
Custom TextField component SwiftUI. It is built upon programmatic UI and fully customizable.
SwiftUI Custom TextField
This repository developed with only swiftUI, there is no UIViewRepresentable.
Requirements
- iOS 13.0+
- Xcode 13+
- Swift 5+
Swift Package Manager
CustomTextfield is available through Swift Package Manager. Add CustomTextField as a dependency to your Package.swift
:
.package(url: "https://github.com/esatgozcu/SwiftUI-Custom-TextField", from: "main")
Customize config
You can set your config properties in @main so you don't need to set every time.
@main
struct ExampleApp: App {
init() {
let shared = EGTextFieldConfig.shared
shared.defaultTextColor = .black
shared.darkModeTextColor = .white
shared.defaultTitleColor = .black
shared.darkModeTitleColor = .white
shared.titleFont = .body
shared.borderType = .line
...
}
var body: some Scene {
WindowGroup {
ContentView()
}
}
}
Dark Mode
Dark mode ability is available. You don't need to consider this issue. If you want to change default color you can set in config file.
Default initialize
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setTitleText("Title")
Light
data:image/s3,"s3://crabby-images/ffa07/ffa07175154f9e26767bfa02d107064a3883f2aa" alt="Light Mode"
Dark
data:image/s3,"s3://crabby-images/f4d14/f4d143c60d5199d3c39490f4ee86f64fde514470" alt="Dark Mode"
Examples
Default
@State var text = "Esat Gozcu"
EGTextField(text: $text)
data:image/s3,"s3://crabby-images/62a95/62a9502bb48d6e2859e62423b83130c4afec8c7b" alt="Default"
Line Border
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setBorderType(.line)
data:image/s3,"s3://crabby-images/149c6/149c675868e228c57e6b6ab897fe9f7c9d2797bc" alt="Line Border"
Title
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setTitleText("Name")
.setTitleColor(.blue)
.setTitleFont(.body)
data:image/s3,"s3://crabby-images/a35c2/a35c2b47153e66650b19b913e60dc11183e8026c" alt="Title"
PlaceHolder
@State var text = ""
EGTextField(text: $text)
.setPlaceHolderText("Enter a name")
data:image/s3,"s3://crabby-images/aaa0a/aaa0ab8fecddde2e3a15ed8cb7411e67b0345d10" alt="PlaceHolder"
Also if you want you can change placeholder color
@State var text = ""
EGTextField(text: $text)
.setPlaceHolderText("Enter a name")
.setPlaceHolderTextColor(Color.gray)
Disable
@State var text = "Esat Gozcu"
@State var disable = true
EGTextField(text: $text)
.setDisable($disable)
.setDisableColor(Color.gray.opacity(0.2))
data:image/s3,"s3://crabby-images/48a23/48a238a640007a4dcd375fcc0674b7a7a616d778" alt="Disable"
Bottom Error
@State var text = "Esat Gozcu"
@State var error = true
@State var errorText = "Your name is not matched"
EGTextField(text: $text)
.setError(errorText: $errorText, error: $error)
data:image/s3,"s3://crabby-images/0b29d/0b29d5190e924215073b93eccea94b9cef5acd8f" alt="Bottom Error"
Trailing Image
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setTrailingImage(Image(systemName: "qrcode"), click: {
print("qr image tapped")
})
data:image/s3,"s3://crabby-images/ec0c6/ec0c699004b80bc97f3903a417673cc10ac04b03" alt="Trailing Image"
You can also set image foreground color.
EGTextField(text: $text)
.setTrailingImageForegroundColor(.black)
.setDarkModeTrailingImageForegroundColor(.white)
⚠️ Warning: If you do not use system image. When you add your image, you have to set your 'Render as -> Template Image'. Otherwise you can not use this foreground color feature.
Secure Text
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setSecureText(true)
data:image/s3,"s3://crabby-images/b1f3c/b1f3c9a598736f67eba474500be97e4b47ad389f" alt="Secure Text Close"
data:image/s3,"s3://crabby-images/ae0ce/ae0ce865640bc5c87825fe2e89df4661834734b4" alt="Secure Text Open"
Secure text images can be changed
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setSecureText(true)
.setSecureTextImages(open : Image(systemName: "eye.fill"),
close: Image(systemName: "eye.slash.fill"))
Max Count
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setMaxCount(8)
data:image/s3,"s3://crabby-images/a8108/a8108bcc53b4e33d7ef627011ec7f6285da3cf01" alt="Max Count"
Truncation Mode
@State var text = "esat1feyk23mqjyefycrfk862x78cyk2sy9l0t8rt6c"
EGTextField(text: $text)
.setTruncateMode(.middle)
data:image/s3,"s3://crabby-images/847ed/847ed0c93fa8b46fc89f7c2ab8311d39907311bb" alt="Truncation Mode"
Border Color and Width
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setBorderColor(.orange)
.setBorderWidth(1.0)
data:image/s3,"s3://crabby-images/5eae2/5eae2129fc6f53d53e51b265f023a587ce3d0d47" alt="Border Color"
Text Color
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setTextColor(.blue)
data:image/s3,"s3://crabby-images/2d600/2d6005a5085c87fccedb060191c66df866cfc316" alt="Text Color"
Background Color
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setBackgroundColor(Color.black)
.setTextColor(Color.white)
data:image/s3,"s3://crabby-images/0375e/0375e3b2d375eb1446ff4e366d333aec185a5871" alt="Background Color"
Corner Radius
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setCornerRadius(20.0)
data:image/s3,"s3://crabby-images/27c94/27c94c74dc6e5f747ac89d0a4da5f9cdbf97434c" alt="Corner Radius"
Disable Auto Correction
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setDisableAutoCorrection(true)
Set Height
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setTextFieldHeight(45)
Focused Border Color
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setFocusedBorderColorEnable(true)
data:image/s3,"s3://crabby-images/5f688/5f68859541c416ed27523eec7bad964bf0ea2905" alt="Normal"
data:image/s3,"s3://crabby-images/72b29/72b2985039aa9c7fe683f25cad703f839e8dd1db" alt="Focused"
If you want you can change colors.
@State var text = "Esat Gozcu"
EGTextField(text: $text)
.setFocusedBorderColorEnable(true)
.setFocusedBorderColor(.black)
.setDarkModeFocusedBorderColor(.white)
⚠️ Warning: This feauture is not working on secureField.