# KeyboardKit
**Repository Path**: ArtfulCoder/KeyboardKit
## Basic Information
- **Project Name**: KeyboardKit
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2026-03-14
- **Last Updated**: 2026-03-14
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# KeyboardKit
KeyboardKit lets you create amazing [custom keyboard extensions][About] with a few lines of code, using Swift & SwiftUI.
KeyboardKit extends Apple's limited keyboard APIs with more capabilities. It can be extended with [KeyboardKit Pro][Pro], which unlocks localized keyboards, autocomplete, an emoji keyboard, AI support, themes, and much more.
## Installation
KeyboardKit can be installed with the Swift Package Manager:
```
https://github.com/KeyboardKit/KeyboardKit.git
```
Since KeyboardKit is a binary framework, it must only linked to the main app target. All other targets will be able to use it without linking.
## Getting Started
The easiest way to set up KeyboardKit is to first create a `KeyboardApp` value for your app:
```swift
import KeyboardKit
extension KeyboardApp {
static var keyboardKitDemo: KeyboardApp {
.init(
name: "KeyboardKit",
licenseKey: "your-key-here", // Needed for 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`:
```swift
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:
```swift
class KeyboardViewController: KeyboardInputViewControllerย {
override func viewDidLoad() {
super.viewDidLoad()
// Set up the keyboard with the app we created above
setup(for: .keyboardKitDemo) { result in
// If `result` is `.success`, the setup did succeed.
// 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 standard ``KeyboardView``, just override `viewWillSetupKeyboardView()` and let it call `setupKeyboardView(_:)` with the view that you want to use:
```swift
class KeyboardViewController: KeyboardInputViewControllerย {
override func viewWillSetupKeyboardView() {
setupKeyboardView { [weak self] controller in // <-- Use weak or unknowned self!
KeyboardView(
state: controller.state,
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`:
```swift
@main
struct MyApp: App {
var body: some Scene {
WindowGroup {
// Here we use the keyboard app we created above
KeyboardAppView(for: .keyboardKitDemo) {
ContentView()
}
}
}
}
```
For more information, see the [getting started guide][Getting-Started] and [essentials][Essentials] articles.
## Localization
KeyboardKit supports [75 locales][Localization]:
๐บ๐ธ ๐ฆ๐ฑ ๐ฆ๐ช ๐ฆ๐ฒ ๐ฆ๐ฟ ๐ง๐พ ๐ง๐ฉ ๐ง๐ฌ ๐ฆ๐ฉ ๐ณ๏ธ
๐ณ๏ธ ๐ญ๐ท ๐จ๐ฟ ๐ฉ๐ฐ ๐ณ๐ฑ ๐ง๐ช ๐ฆ๐บ ๐จ๐ฆ ๐ฌ๐ง ๐บ๐ธ
๐ช๐ช ๐ซ๐ด ๐ต๐ญ ๐ซ๐ฎ ๐ซ๐ท ๐จ๐ฆ ๐ง๐ช ๐จ๐ญ ๐ฌ๐ช ๐ฉ๐ช
๐ฆ๐น ๐จ๐ญ ๐ฌ๐ท ๐บ๐ธ ๐ฎ๐ฑ ๐ญ๐บ ๐ฎ๐ธ ๐ณ๏ธ ๐ฎ๐ฉ ๐ฎ๐ช
๐ฎ๐น ๐ฐ๐ฟ ๐น๐ฏ ๐น๐ฏ ๐น๐ฏ ๐ฑ๐ป ๐ฑ๐น ๐ฒ๐ฐ ๐ฒ๐พ ๐ฒ๐น
๐ฒ๐ณ ๐ณ๏ธ ๐ณ๐ด ๐ณ๐ด ๐ฎ๐ท ๐ต๐ฑ ๐ต๐น ๐ง๐ท ๐ท๐ด ๐ท๐บ
๐ท๐ธ ๐ท๐ธ ๐น๐ฏ ๐ธ๐ฐ ๐ธ๐ฎ ๐ช๐ธ ๐ฆ๐ท ๐ฒ๐ฝ ๐ธ๐ช ๐ฐ๐ช
๐น๐ท ๐บ๐ฆ ๐บ๐ฟ ๐ป๐ณ ๐ด๓ ง๓ ข๓ ท๓ ฌ๓ ณ๓ ฟ
[KeyboardKit Pro][Pro] unlocks localized keyboards, layouts, callouts and behaviors for all supported locales.
## Features
KeyboardKit provides a free, open-source keyboard engine. [KeyboardKit Pro][Pro] unlocks more powerful pro features.
* ๐ฑ [Essentials][Essentials] - Essential utilities, models, services & views.
* โจ๏ธ [Essentials - KeyboardView][Essentials-KeyboardView] - Render a native-looking, fully customizable keyboard.
* ๐ฅ [Actions][Actions] - Trigger & handle keyboard-related actions.
* ๐ค [AI][AI] - Features that are needed by AI-based keyboards.
* ๐ฑ [App][App] - App-specific utilities, settings, screens, etc.
* ๐ก [Autocomplete][Autocomplete] - Autocomplete and autocorrect as the user types.
* ๐ฏ [Callouts][Callouts] - Show input & secondary action callouts.
* ๐ [Clipboard][Clipboard] - Create custom clips and integrate with the system clipboard.
* ๐ค [Dictation][Dictation] - Trigger dictation from the keyboard.
* ๐ [Emojis][Emojis] - Emoji models, an emoji keyboard, etc.
* โจ๏ธ [External][External] - Detect if an external keyboard is connected.
* ๐ [Feedback][Feedback] - Trigger audio & haptic feedback with ease.
* ๐ [Fonts][Fonts] - Type with other fonts than the standard system font.
* ๐ [Gestures][Gestures] - Handle a rich set of gestures on any key.
* ๐ [Host][Host] - Identify and open the host application.
* ๐ [Input][Input] - Keyboard input fields, Vietnamese support, etc.
* ๐ฃ [Layout][Layout] - A dynamic, customizable keyboard layout engine.
* ๐ [Localization][Localization] - Locale-specific utilities for all supported locales.
* ๐บ๏ธ [Navigation][Navigation] - Open urls and other apps from the keyboard.
* ๐ [Previews][Previews] - Keyboard & theme previews for in-app use.
* ๐ [Proxy][Proxy] - Extend the text document proxy with more capabilities.
* โ๏ธ [Settings][Settings] - Provide keyboard settings & link to System Settings.
* ๐ฉบ [Status][Status] - Detect if a keyboard is enabled, has full access, etc.
* ๐จ [Styling][Styling] - Style your keyboard to great extent.
* ๐ญ [Themes][Themes] - A theme engine with many pre-defined themes.
## Documentation
The [online documentation][Documentation] has a [getting started guide][Getting-Started], [feature articles][Feature-Articles], code samples, [developer guides][Developer-Guides], etc.
## Demo App
The `Demo` folder has a demo app that shows how to set up a main app and its keyboard extension, show keyboard status, provide in-app settings, link to system settings, apply custom styles, etc.
> [!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.
## KeyboardKit App
The [KeyboardKit app][KeyboardKit-App] on the App Store lets you download and try KeyboardKit without having to write any code.
## Support This Project
KeyboardKit is free to use, but you can support us by becoming a [GitHub Sponsor][Sponsors], upgrading to [KeyboardKit Pro][Pro] or [get in touch][Email] for freelance work, paid support etc.
## Contact
Feel free to reach out if you have questions or if you want to contribute in any way:
* Website: [keyboardkit.com][Website]
* E-mail: [info@keyboardkit.com][Email]
* Bluesky: [@keyboardkit.bsky.social][Bluesky]
* Mastodon: [@keyboardkit@techhub.social][Mastodon]
## License
KeyboardKit is closed-source. See the [LICENSE][License] file for more info.
[Email]: mailto:info@keyboardkit.com
[Website]: https://keyboardkit.com
[Bluesky]: https://bsky.app/profile/keyboardkit.bsky.social
[Mastodon]: https://techhub.social/@keyboardkit
[Sponsors]: https://github.com/sponsors/danielsaidi
[About]: https://keyboardkit.com/about
[KeyboardKit-App]: https://keyboardkit.com/app
[Pro]: https://keyboardkit.com/pro
[Documentation]: https://docs.keyboardkit.com
[License]: https://github.com/KeyboardKit/KeyboardKit/blob/master/LICENSE
[Getting-Started]: https://docs.keyboardkit.com/documentation/keyboardkit/getting-started-article
[Essentials]: https://docs.keyboardkit.com/documentation/keyboardkit/essentials-article
[Essentials-KeyboardView]: https://docs.keyboardkit.com/documentation/keyboardkit/essentials-keyboardview
[Developer-Guides]: https://docs.keyboardkit.com/documentation/keyboardkit/developer-articles
[Feature-Articles]: https://docs.keyboardkit.com/documentation/keyboardkit/features-articles
[Actions]: https://docs.keyboardkit.com/documentation/keyboardkit/actions-article
[AI]: https://docs.keyboardkit.com/documentation/keyboardkit/ai-article
[App]: https://docs.keyboardkit.com/documentation/keyboardkit/app-article
[Autocomplete]: https://docs.keyboardkit.com/documentation/keyboardkit/autocomplete-article
[Buttons]: https://docs.keyboardkit.com/documentation/keyboardkit/buttons-article
[Callouts]: https://docs.keyboardkit.com/documentation/keyboardkit/callouts-article
[Clipboard]: https://docs.keyboardkit.com/documentation/keyboardkit/clipboard-article
[Dictation]: https://docs.keyboardkit.com/documentation/keyboardkit/dictation-article
[Emojis]: https://docs.keyboardkit.com/documentation/keyboardkit/emojis-article
[External]: https://docs.keyboardkit.com/documentation/keyboardkit/external-keyboards-article
[Feedback]: https://docs.keyboardkit.com/documentation/keyboardkit/feedback-article
[Fonts]: https://docs.keyboardkit.com/documentation/keyboardkit/fonts-article
[Gestures]: https://docs.keyboardkit.com/documentation/keyboardkit/gestures-article
[Host]: https://docs.keyboardkit.com/documentation/keyboardkit/host-article
[Input]: https://docs.keyboardkit.com/documentation/keyboardkit/input-article
[Layout]: https://docs.keyboardkit.com/documentation/keyboardkit/layout-article
[Localization]: https://docs.keyboardkit.com/documentation/keyboardkit/localization-article
[Navigation]: https://docs.keyboardkit.com/documentation/keyboardkit/navigation-article
[Previews]: https://docs.keyboardkit.com/documentation/keyboardkit/previews-article
[Proxy]: https://docs.keyboardkit.com/documentation/keyboardkit/proxy-article
[Settings]: https://docs.keyboardkit.com/documentation/keyboardkit/settings-article
[Status]: https://docs.keyboardkit.com/documentation/keyboardkit/status-article
[Styling]: https://docs.keyboardkit.com/documentation/keyboardkit/styling-article
[Themes]: https://docs.keyboardkit.com/documentation/keyboardkit/themes-article