Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dogo/sketchkit
A lightweight auto-layout DSL library for iOS, tvOS & macOS.
https://github.com/dogo/sketchkit
auto-layout autolayout carthage cocoapods dsl ios ios-swift keyboardlayoutguide macos nslayoutconstraint nslayoutconstraints nslayoutguide spm swift swift-package-manager uilayoutguide
Last synced: about 1 month ago
JSON representation
A lightweight auto-layout DSL library for iOS, tvOS & macOS.
- Host: GitHub
- URL: https://github.com/dogo/sketchkit
- Owner: dogo
- License: mit
- Created: 2019-10-04T18:14:07.000Z (over 5 years ago)
- Default Branch: develop
- Last Pushed: 2024-09-22T22:35:42.000Z (5 months ago)
- Last Synced: 2025-01-10T04:11:27.901Z (about 1 month ago)
- Topics: auto-layout, autolayout, carthage, cocoapods, dsl, ios, ios-swift, keyboardlayoutguide, macos, nslayoutconstraint, nslayoutconstraints, nslayoutguide, spm, swift, swift-package-manager, uilayoutguide
- Language: Swift
- Homepage:
- Size: 1.11 MB
- Stars: 46
- Watchers: 7
- Forks: 10
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README

[](https://codecov.io/gh/dogo/SketchKit)
[](https://cocoapods.org/?q=SketchKit)
[](https://swift.org/package-manager)
[](https://github.com/Carthage/Carthage)
[](https://github.com/dogo/SketchKit/blob/develop/LICENSE)SketchKit is a lightweight, powerful and pure-Swift auto layout library, you can set up your constraints with a simple and intuitive code without any stringly typing.
In short, it allows you to replace this:
```Swift
newView.translatesAutoresizingMaskIntoConstraints = falseaddConstraint(NSLayoutConstraint(
item: newView,
attribute: NSLayoutConstraint.Attribute.centerX,
relatedBy: NSLayoutConstraint.Relation.equal,
toItem: view,
attribute: NSLayoutConstraint.Attribute.centerX,
multiplier: 1,
constant: 0))
```or
```Swift
newView.centerXAnchor.constraint(equalTo: view.centerXAnchor).isActive = true
```with this
```Swift
// It's NOT necessary: newView.translatesAutoresizingMaskIntoConstraints = false
newView.layout.applyConstraint { view in
view.centerXAnchor(equalTo: self.view.centerXAnchor)
view.centerYAnchor(equalTo: self.view.centerYAnchor)
}
```## Requirements
- iOS 9.0+ / tvOS 9.0+ / macOS 10.11+
- Swift 3.2+## Installation
### [CocoaPods](https://cocoapods.org)
To integrate SketchKit into your Xcode project using CocoaPods, specify it in your `Podfile`:
```ruby
target '' do
pod 'SketchKit'
end
```Then, run the following command:
```bash
$ pod install
```### [Swift Package Manager (SPM)](https://swift.org/package-manager)
To add `SketchKit` as a dependency, you have to add it to the `dependencies` of your `Package.swift` file and refer to that dependency in your `target`.
```swift
import PackageDescription
let package = Package(
name: "",
dependencies: [
.package(url: "https://github.com/dogo/SketchKit", .upToNextMajor(from: "1.0.0"))
],
targets: [
.target(
name: "",
dependencies: ["SketchKit"]),
]
)
```After adding the dependency, you can fetch the library with:
```bash
$ swift package resolve
```### [Carthage](https://github.com/Carthage/Carthage)
```
github "dogo/SketchKit"
```## Usage
### Quick Start
```swift
import SketchKitfinal class MyViewController: UIViewController {
let myView: UIView = {
let view = UIView(frame: .zero)
view.color = .red
return view
}()override func viewDidLoad() {
super.viewDidLoad()self.view.addSubview(myView)
myView.layout.applyConstraint { view in
view.topAnchor(equalTo: self.view.topAnchor)
view.leadingAnchor(equalTo: self.view.leadingAnchor)
view.bottomAnchor(equalTo: self.view.bottomAnchor)
view.trailingAnchor(equalTo: self.view.trailingAnchor)
}
}
}
```## Documentation
The project documentation can be found ([here](https://dogo.github.io/SketchKit/index.html))## Credits
- Nicholas Babo ([@NickBabo](https://github.com/NickBabo)) thank you for the SketchKit logo,
## License
SketchKit is released under the MIT license. See LICENSE for details.