KeyboardKit lets you create amazing custom keyboard extensions with a few lines of code, using Swift & SwiftUI.
KeyboardKit extends Apple's limited keyboard APIs with more capabilities. KeyboardKit Pro extends further by unlocking localized keyboards, autocomplete, an emoji keyboard, AI support, themes, and much more.
KeyboardKit Pro can be installed with the Swift Package Manager:
https://github.com/KeyboardKit/KeyboardKitPro.git
KeyboardKit Pro requires a license to be used. You can sign up on the KeyboardKit website or the Gumroad store.
Important
Unlike KeyboardKit, KeyboardKit Pro is a binary target and must only be linked to the app target.
The easiest way to set up KeyboardKit is to first create a KeyboardApp
value for your app:
extension KeyboardApp {
static var keyboardKitDemo: KeyboardApp {
.init(
name: "KeyboardKit",
licenseKey: "your-key-here", // Required by KeyboardKit Pro!
appGroupId: "group.com.keyboardkit.demo", // Sets up App Group data sync
locales: .keyboardKitSupported, // Sets up the enabled locales
autocomplete: .init( // Sets up custom autocomplete
nextWordPredictionRequest: .claude(...) // Sets up AI-based prediction
),
deepLinks: .init(app: "kkdemo://", ...) // Defines how to open the app
)
}
}
Next, let your KeyboardController
inherit KeyboardInputViewController
instead of UIInputViewController
:
class KeyboardController: KeyboardInputViewController {}
This unlocks additional functions and capabilities, and adds services
and observable state
to the controller.
Next, override viewDidLoad()
and call setup(for:)
to set up the keyboard extension for your app:
class KeyboardViewController: KeyboardInputViewController {
override func viewDidLoad() {
super.viewDidLoad()
setup(for: .keyboardKitDemo) { result in
// If the result is `.success`, the setup succeeded.
// This is where you can setup custom services, etc.
}
}
}
This will make keyboard settings sync data between the main app and its keyboard if the KeyboardApp
defines an appGroupId
, set up KeyboardKit Pro if it defines a licenseKey
, set up dictation and deep links, etc.
To replace or customize the default KeyboardView
that will otherwise be used as the standard keyboard view, just override viewWillSetupKeyboardView()
and call setupKeyboardView(_:)
with the view that you want to use:
class KeyboardViewController: KeyboardInputViewController {
override func viewWillSetupKeyboardView() {
setupKeyboardView { [weak self] controller in // <-- Use weak or unknowned self!
KeyboardView(
state: controller.state,
services: controller.services,
buttonContent: { $0.view },
buttonView: { $0.view },
collapsedView: { $0.view },
emojiKeyboard: { $0.view },
toolbar: { $0.view }
)
}
}
}
To set up your main app with the same keyboard configuration, just wrap the content view in a KeyboardAppView
:
@main
struct MyApp: App {
var body: some Scene {
WindowGroup {
KeyboardAppView(for: .keyboardKitDemo) {
ContentView()
}
}
}
}
For more information, see the getting started guide and essentials articles.
KeyboardKit supports 71 keyboard-specific locales:
🇺🇸 🇦🇱 🇦🇪 🇦🇲 🇧🇾 🇧🇬 🇦🇩 🏳️ 🏳️ 🇭🇷
🇨🇿 🇩🇰 🇳🇱 🇧🇪 🇦🇺 🇨🇦 🇬🇧 🇺🇸 🇪🇪 🇫🇴
🇵🇭 🇫🇮 🇫🇷 🇨🇦 🇧🇪 🇨🇭 🇬🇪 🇩🇪 🇦🇹 🇨🇭
🇬🇷 🇺🇸 🇮🇱 🇭🇺 🇮🇸 🏳️ 🇮🇩 🇮🇪 🇮🇹 🇰🇿
🇹🇯 🇹🇯 🇹🇯 🇱🇻 🇱🇹 🇲🇰 🇲🇾 🇲🇹 🇲🇳 🏳️
🇳🇴 🇳🇴 🇮🇷 🇵🇱 🇵🇹 🇧🇷 🇷🇴 🇷🇺 🇷🇸 🇷🇸
🇸🇰 🇸🇮 🇪🇸 🇦🇷 🇲🇽 🇸🇪 🇰🇪 🇹🇷 🇺🇦 🇺🇿
🏴
KeyboardKit only includes localized strings, while KeyboardKit Pro unlocks localized keyboards, layouts, callouts and behaviors for all supported locales.
KeyboardKit provides a free, open-source keyboard engine. KeyboardKit Pro unlocks more powerful pro features.
- 🌱 Essentials - Essential keyboard utilities, models, services & views.
- ⌨️ Essentials-KeyboardView - A native-looking, customizable keyboard.
- 💥 Actions - Trigger & handle keyboard-related actions.
- 📱 App - Set up your app, keyboard, sync settings, etc.
- 🗯 Callouts - Show input & secondary action callouts.
- 🖥️ Device - Identify device type, device capabilities, etc.
- 😀 Emojis - Emojis, categories, versions, skin tones, etc.
- 🔉 Feedback - Trigger audio & haptic feedback.
- 👆 Gestures - Handle a rich set of gestures on any key.
- 🔣 Layout - Define and customize dynamic keyboard layouts.
- 🌐 Localization - Localize your keyboard in 71 locales.
- 🗺️ Navigation - Open urls and other apps from the keyboard.
- 👁 Previews - Extensive SwiftUI preview support.
- 📄 Proxy - Extend the text document proxy with more capabilities.
- ⚙️ Settings - Provide keyboard settings & link to System Settings.
- 🩺 Status - Detect if a keyboard is enabled, has full access, etc.
- 🎨 Styling - Style your keyboard to great extent.
- 🌱 Essentials - More essential tools, previews, toolbars, etc.
- ⌨️ Essentials-KeyboardView - Make the keyboard view do a lot more.
- 🤖 AI - Features that are needed for AI.
- 📱 App - App-specific screens & views.
- 💡 Autocomplete - Local & remote autocomplete, next word prediction, etc.
- 🗯 Callouts - Localized callout actions for all supported locales.
- 🎤 Dictation - Dictate text from the keyboard.
- 😀 Emojis - A powerful emoji keyboard, search, etc.
- ⌨️ External - Auto-detect if an external keyboard is connected.
- 🏠 Host - Identify and open specific host applications.
- 🔣 Layout - More input sets and layouts for all supported locales.
- 🌐 Localization - Services & views for all supported locales.
- 👁 Previews - Keyboard & theme previews for in-app use.
- 📄 Proxy - Allow
UITextDocumentProxy
to read the full document. - 📝 Text - Allow users to type within the keyboard.
- 🍭 Themes - A theme engine with many pre-defined themes.
The online documentation has a thorough getting-started guide, a detailed article for each feature, code samples, etc. You can also build it from the source code to get better formatting.
The main repository has a demo app that shows how to set up the main keyboard app, show keyboard status, provide in-app settings, link to system settings, apply custom styles, etc.
The app has two keyboards - a Keyboard
that uses KeyboardKit and a KeyboardPro
that uses KeyboardKit Pro.
Important
The demo isn't code signed and can therefore not use an App Group to sync settings between the app and its keyboards. As such, the KeyboardPro
keyboard has keyboard settings in the keyboard as well.
If you want to try KeyboardKit without having to write any code or build the demo app from Xcode, the KeyboardKit app lets you try out many features by just downloading it from the App Store.
Feel free to reach out if you have questions or if you want to contribute in any way:
- Website: keyboardkit.com
- E-mail: info@keyboardkit.com
- Bluesky: @keyboardkit.bsky.social
- Mastodon: @keyboardkit@techhub.social
KeyboardKit Pro requires a license to be used. You can sign up on the KeyboardKit website or the Gumroad store.