Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/banjun/NorthLayout
The fast path to autolayout views in code
https://github.com/banjun/NorthLayout
autolayout vfl visual-format-language visualformatlanguage
Last synced: 4 months ago
JSON representation
The fast path to autolayout views in code
- Host: GitHub
- URL: https://github.com/banjun/NorthLayout
- Owner: banjun
- License: mit
- Created: 2015-05-09T15:48:33.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2023-03-17T06:09:42.000Z (almost 2 years ago)
- Last Synced: 2024-09-27T00:45:56.754Z (5 months ago)
- Topics: autolayout, vfl, visual-format-language, visualformatlanguage
- Language: Swift
- Homepage:
- Size: 1.35 MB
- Stars: 41
- Watchers: 4
- Forks: 3
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- fucking-awesome-swift - NorthLayout - Fast path to layout using Visual Format Language (VFL) with extended syntax. (Libs / Layout)
- awesome-swift - NorthLayout - Fast path to layout using Visual Format Language (VFL) with extended syntax. (Libs / Layout)
- awesome-swift - NorthLayout - The fast path to autolayout views in code ` 📝 a month ago` (Layout [🔝](#readme))
- awesome-swift - NorthLayout - Fast path to layout using Visual Format Language (VFL) with extended syntax. (Libs / Layout)
README
# NorthLayout
[data:image/s3,"s3://crabby-images/9c231/9c2314785412984c7f6af9d89804b287f393292b" alt="Build Status"](https://app.bitrise.io/app/099ef6919e27d42e)
data:image/s3,"s3://crabby-images/ee10a/ee10a84a507928982a606ee25763f413f0334fe2" alt="CI"
[data:image/s3,"s3://crabby-images/2b08b/2b08b36085912ee49194435a934d927352b26101" alt="Version"](http://cocoapods.org/pods/NorthLayout)
[data:image/s3,"s3://crabby-images/0e076/0e076223c060b18513a7f843d5871fe0d8614e9f" alt="License"](http://cocoapods.org/pods/NorthLayout)
[data:image/s3,"s3://crabby-images/23ee4/23ee4b95a63839a931245a2206e3f23ac7a2b2aa" alt="Platform"](http://cocoapods.org/pods/NorthLayout)The fast path to autolayout views in code
## Talks
at AltConf19
## Simple Usage
```swift
let iconView = UIImageView() // and customize...
let nameLabel = UILabel() // and customize...override func loadView() {
super.loadView()
title = "Simple Example"
view.backgroundColor = .white
let autolayout = northLayoutFormat(["p": 8], [
"icon": iconView,
"name": nameLabel])
autolayout("H:||[icon(==64)]") // 64pt width icon on left side with default margin
autolayout("H:||[name]||") // full width label with default margin
autolayout("V:||-p-[icon(==64)]-p-[name]") // stack them vertically
}
```data:image/s3,"s3://crabby-images/0e436/0e4367e66bceb6a5a5241ab5265974d21b8f6b4b" alt=""
See also `Example` project.
## View Level Safe Area Example
```swift
override init(frame: CGRect) {
super.init(frame: frame)
// autolayout respecting safe area without reference to container view controller
let autolayout = northLayoutFormat([:], [
"icon": iconView,
"name": nameLabel])
autolayout("H:||-(>=0)-[icon(==64)]-(>=0)-||") // 64pt fitting width icon with default margin
autolayout("H:||[name]||") // fitting width label with default margin
autolayout("V:||[icon(==64)]-[name]||") // stack them vertically
// constrain iconView horizontal ambiguity to safe area center
layoutMarginsGuide.centerXAnchor.constraint(equalTo: iconView.centerXAnchor).isActive = true
}
```data:image/s3,"s3://crabby-images/fdc05/fdc05c0f2d4a51c8d5c882bc556014e454bab197" alt=""
See also `Example` project.
## Advanced Example
data:image/s3,"s3://crabby-images/812d8/812d8247ec0a7398953b9a50e16c6711849b6451" alt=""
See `Example` project.
## Features
### 📜 No Storyboards Required
Let's autolayout in code. boilerplates such as `translatesAutoresizingMaskIntoConstraints = false` and adding as subview are coded in `northLayoutFormat()`.
### ↔️ Visual Format Language
Use Visual Format Language (VFL) for layout.
[Auto Layout Guide: Visual Format Language](https://developer.apple.com/library/content/documentation/UserExperience/Conceptual/AutolayoutPG/VisualFormatLanguage.html)
### ⏸ Extended Visual Format for Layout Margins & Safe Area
In addition to Apple VFL above, NorthLayout introduces `||` syntax for layout margin bounds.
```swift
// stick to side edges (i.e. screen edges for view of view controller)
autolayout("H:|[icon1]|")// stick to side layout margins (avoids non safe areas)
autolayout("H:||[icon2]||")
```### 📚 View Controller level & View level layout
In autolayout, there is some differences in view of view controller and independent view. `northLayoutFormat` is available for view controller and view.
You can use `|` as topLayoutGuide or bottomLayoutGuide (mainly for before iOS 11) and avoid conflicting scroll adjustments on view controllers.
You can also code layout simply without a view controller on views.### 📱🖥 iOS & macOS
Available for UIView & NSView
## Migration to NorthLayout 5
NorthLayout 4 has supported Safe Area by translating `|` bounds as safe area layout guides by default.
NorthLayout 5 adds breaking changes that introduces `||` layout margin guides and thus `|` no longer respects Safe Area.
Choose `|` to stick to edges, or `||` to inset in layout margins or safe area.## Installation
NorthLayout is available through [CocoaPods](http://cocoapods.org). To install
it, simply add the following line to your Podfile:```ruby
pod "NorthLayout"
```## Code Snippets
Code snippets help writing VFL activated in string literal scope.
```bash
cd (NorthLayout directory)
cp CodeSnippets/*.codesnippet ~/Library/Developer/Xcode/UserData/CodeSnippets/
```data:image/s3,"s3://crabby-images/cefc8/cefc8568b1af566cb7f7507a15c11b01501798f6" alt=""
data:image/s3,"s3://crabby-images/b6ea0/b6ea0f2a6436c07c8a533d95e619f6eb2ac7c5da" alt=""
## The Name
NorthLayout is named after where it was cocoapodized, [Lake Toya](http://en.wikipedia.org/wiki/Lake_Tōya) in the North prefecture of Japan, the setting of [Celestial Method](http://en.wikipedia.org/wiki/Celestial_Method).
## License
NorthLayout is available under the MIT license. See the LICENSE file for more info.