Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/freshos/keyboardlayoutguide
⌨️ KeyboardLayoutGuide, back from when it didn't exist.
https://github.com/freshos/keyboardlayoutguide
autolayout ios keyboard keyboard-layout layout layoutguide swift
Last synced: 6 days ago
JSON representation
⌨️ KeyboardLayoutGuide, back from when it didn't exist.
- Host: GitHub
- URL: https://github.com/freshos/keyboardlayoutguide
- Owner: freshOS
- License: mit
- Created: 2017-11-14T13:16:15.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-09-20T07:48:41.000Z (5 months ago)
- Last Synced: 2025-02-13T20:05:27.594Z (6 days ago)
- Topics: autolayout, ios, keyboard, keyboard-layout, layout, layoutguide, swift
- Language: Swift
- Homepage:
- Size: 5.79 MB
- Stars: 1,200
- Watchers: 14
- Forks: 59
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# ⌨️ KeyboardLayoutGuide
*Apple's missing KeyboardLayoutGuide*[data:image/s3,"s3://crabby-images/d15e5/d15e55ab7369f7a17c8be41b9ecefe2529f65a62" alt="Language: Swift 5"](https://developer.apple.com/swift)
data:image/s3,"s3://crabby-images/c440d/c440d74888118cef9ed083424f8c54ee1b5f3a5e" alt="Platform: iOS 9+"
[data:image/s3,"s3://crabby-images/0b708/0b7084ebffa9e88bc4957c45487b9be84772d22c" alt="SPM compatible"](https://swift.org/package-manager/)
[data:image/s3,"s3://crabby-images/b6c9c/b6c9ce77d5520d6708cb86f16e9c583bf4ab7e91" alt="Build Status"](https://app.bitrise.io/app/37eb1367c9a89767)
[data:image/s3,"s3://crabby-images/72800/72800bf4f517e20ce33958f0b33d287f1df2f96a" alt="codebeat badge"](https://codebeat.co/projects/github-com-freshos-keyboardlayoutguide-master)
[data:image/s3,"s3://crabby-images/36d9c/36d9c5538b61edbe982bfb78116eb309d9057a74" alt="License: MIT"](https://github.com/s4cha/Stevia/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/0ae14/0ae147d06964e87c6139775bab7e764c51d68d48" alt="GitHub tag"](https://github.com/freshOS/KeyboardLayoutGuide/releases)- [x] No Subclassing / Protocol inheritance / obscure overrides
- [x] No more keyboard notification handling
- [x] `UIKit` Friendly
- [x] Takes `safeArea` into account
- [x] Only animates if view is fully on screen
## How to use it
Simply constrain your views to the KeyboardLayoutGuide's top anchor the way you would do natively:
```swift
override func viewDidLoad() {
super.viewDidLoad()// Pin your button to the keyboard
button.bottomAnchor.constraint(equalTo: view.keyboardLayoutGuide.topAnchor).isActive = true
}
```**Bonus**: if you're using [Stevia](https://github.com/freshOS/Stevia), this gets even more concise \o/
```swift
button.Bottom == view.keyboardLayoutGuide.Top
```If you add your view in Interface Builder, don't forget to enable the "**Remove at build time**" checkbox for the bottom constraint:
## Safe Area
By default, KeyboardLayoutGuide will align your item with the bottom safe area.
This is a behaviour that can be opt out by using `keyboardLayoutGuideNoSafeArea` instead of `keyboardLayoutGuide`.## Installation
The Swift Package Manager (SPM) is now the official way to install `KeyboardLayoutGuide`. The other package managers are now deprecated as of `1.7.0` and won't be supported in future versions.
#### Swift Package Manager
`Xcode` > `File` > `Swift Packages` > `Add Package Dependency...` > `Paste` `https://github.com/freshOS/KeyboardLayoutGuide`
### CocoaPods - Deprecated
To install `KeyboardLayoutGuide` via [CocoaPods](http://cocoapods.org), add the following line to your Podfile:
```
target 'MyAppName' do
pod 'Keyboard+LayoutGuide'
use_frameworks!
end
```### Carthage - Deprecated
To install `KeyboardLayoutGuide` via [Carthage](https://github.com/Carthage/Carthage#if-youre-building-for-ios-tvos-or-watchos), add the following line to your Cartfile:
```
github "freshos/KeyboardLayoutGuide"
```### Manually
Just add `Keyboard+LayoutGuide.swift` to your Xcode project.## License
`KeyboardLayoutGuide` is available under the MIT license. See the [LICENSE](LICENSE) file for more info.