Keyboard
Skip support for SwiftUI.View.keyboardType 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
KeyboardPlayground.swift
data:image/s3,"s3://crabby-images/ac00a/ac00a7de4147d54291bba6274f7a45bfd87a62f3" alt="Android screenshot for Keyboard component (light mode)"
data:image/s3,"s3://crabby-images/31993/319933cfc86201592fc23f96a90060106578e70d" alt="iPhone screenshot for Keyboard component (light mode)"
data:image/s3,"s3://crabby-images/45838/45838e91c728d4576deb5f09470b9e7ec7a1a0a4" alt="iPhone screenshot for Keyboard component (dark mode)"
data:image/s3,"s3://crabby-images/9c318/9c3185a9ab015e97f5a179983d60bfe14686ca36" alt="Android screenshot for Keyboard component (dark mode)"
import SwiftUI
struct KeyboardPlayground: View {
@State var text = ""
var body: some View {
ScrollView {
VStack(spacing: 16.0) {
TextField("Default", text: $text)
TextField(".autocorrectionDisabled()", text: $text)
.autocorrectionDisabled()
#if os(macOS)
#else
ForEach(keyboardTypes, id: \.0) {
TextField(".keyboardType(.\($0.0))", text: $text)
.keyboardType($0.1)
}
#endif
ForEach(submitLabels, id: \.0) {
TextField(".submitLabel(.\($0.0))", text: $text)
.submitLabel($0.1)
}
#if os(macOS)
#else
ForEach(textInputAutocapitalizations, id: \.0) {
TextField(".textInputAutocapitalization(.\($0.0))", text: $text)
.textInputAutocapitalization($0.1)
}
TextField("Combination", text: $text)
.submitLabel(.next)
.autocorrectionDisabled()
.textInputAutocapitalization(.words)
#endif
}
.textFieldStyle(.roundedBorder)
.padding()
}
.toolbar {
PlaygroundSourceLink(file: "KeyboardPlayground.swift")
}
}
#if os(macOS)
#else
private var keyboardTypes: [(String, UIKeyboardType)] {
return [
("default", UIKeyboardType.default),
("asciiCapable", UIKeyboardType.asciiCapable),
("numbersAndPunctuation", UIKeyboardType.numbersAndPunctuation),
("URL", UIKeyboardType.URL),
("numberPad", UIKeyboardType.numberPad),
("phonePad", UIKeyboardType.phonePad),
("namePhonePad", UIKeyboardType.namePhonePad),
("emailAddress", UIKeyboardType.emailAddress),
("decimalPad", UIKeyboardType.decimalPad),
("twitter", UIKeyboardType.twitter),
("webSearch", UIKeyboardType.webSearch),
("asciiCapableNumberPad", UIKeyboardType.asciiCapableNumberPad),
("alphabet", UIKeyboardType.alphabet)
]
}
#endif
private var submitLabels: [(String, SubmitLabel)] {
return [
("done", SubmitLabel.done),
("go", SubmitLabel.done),
("send", SubmitLabel.send),
("join", SubmitLabel.join),
("route", SubmitLabel.route),
("search", SubmitLabel.search),
("return", SubmitLabel.return),
("next", SubmitLabel.next),
("continue", SubmitLabel.continue)
]
}
#if os(macOS)
#else
private var textInputAutocapitalizations: [(String, TextInputAutocapitalization)] {
return [
("never", TextInputAutocapitalization.never),
("words", TextInputAutocapitalization.words),
("sentences", TextInputAutocapitalization.sentences),
("characters", TextInputAutocapitalization.characters)
]
}
#endif
}