Text formatting framework written on Swift 5.0.
Features | |
---|---|
🎭 | Convert string into formatted string and vice versa |
🚴 | Formatting text during typing |
#️⃣ | Set format using '#' characters like '### ##-###' |
😛 | Supporting emojis |
💲 | Formatting money amount |
Formatting with placeholders | |
🌱 | UITextField and UITextView support |
🔨 | SwiftUI compatible |
To run the example project, clone the repo and run pod install
from the Example directory first.
- iOS 8.0+
- Swift 4.0+
- Xcode 9.0+
- AnyFormatKit 0.2.0 MigrationGuide
- AnyFormatKit 1.0.0 MigrationGuide
- AnyFormatKit 2.3.0 MigrationGuide
AnyFormatKit is available through CocoaPods. To install it, simply add the following line to your Podfile:
pod 'AnyFormatKit', '~> 2.3.0'
Then, run the following command:
$ pod install
AnyFormatKit is available with Swift Package Manager.
Once you have your Swift package set up, than simply add AnyFormatKit to the dependencies
value of your Package.swift
dependencies: [
.package(url: "https://github.com/luximetr/AnyFormatKit.git", .upToNextMajor(from: "2.3.0"))
]
import AnyFormatKit
let phoneFormatter = DefaultTextInputFormatter(textPattern: "### (###) ###-##-##")
let phoneInputController = TextFieldInputController()
textField.delegate = phoneInputController
phoneInputController.formatter = phoneFormatter
phoneNumberFormatter.unformat("+51 (013) 442-55-11") // +51013442551
let phoneFormatter = DefaultTextInputFormatter(textPattern: "### (###) ###-##-##")
// inside of UITextFieldDelegate shouldChangeTextIn method
let result = formatter.formatInput(currentText: textField.text ?? "", range: range, replacementString: string)
textField.text = result.formattedText
textField.setCursorLocation(result.caretBeginOffset)
You can find example of
setCursorLocation
here
DefaultTextInputFormatter
- formatting symbol by symbolSumTextInputFormatter
- formatting like a money formatPlaceholderTextInputFormatter
- formatting with all textPattern as placeholder
AnyFormatKit is compatible with SwiftUI.
import SwiftUI
import AnyFormatKit
struct ContentView: View {
@State var text = ""
var body: some View {
FormatTextField(unformattedText: $text, textPattern: "## (###)-###-####")
}
}
FormatTextField
- formatting withDefaultTextInputFormatter
under the hood, or you can pass your own implementation in init methodFormatStartTextField
- formatting with correcting caret after begin editin, good to use withPlaceholderTextInputFormatter
FormatSumTextField
- formatting withSumTextInputFormatter
under the hood, or you can pass your own implementation in init method
luximetr, [email protected]
AnyFormatKit is available under the MIT license. See the LICENSE file for more info.