A declarative, expressive and efficient way to lay out your views.
Summary | |
---|---|
Declarative | Tell the framework what the layout of your views should be and let the framework intelligently add/modify/remove constraints and views for you. |
Expressive | Let your code visually express the hierarchy of your views. |
Flexible | Write the same constraints you already do, using whatever autolayout constraint DSL you prefer. |
Small | Small and readable Swift 5 codebase. |
Usage | Updating to a new layout | Installation | Requirements | Building on top of DeclarativeLayout | License
Import Declarative Layout at the top of the file you would like to layout your views in
import DeclarativeLayout
You will define and update your layout through the ViewLayout
object, so your first step should be creating one and storing it in a property.
Make sure that it is being initialized after your view has loaded. A place like viewDidLoad
would work, or consider intializing the property lazily.
viewLayout = ViewLayout(view: view)
Tell your ViewLayout
you would like to update it
viewLayout.updateLayoutTo { (com) in
...
}
Use the layout components to define new views that should be in the hierarchy,
as well as the constraints that should be active (Note: All constraints passed
to .constraints(_:)
method should not be active).
Here is an example:
viewLayout.updateLayoutTo { (com) in
com.stackView(self.stackView) { (com) in
com.constraints(
com.ownedView.leadingAnchor.constraint(equalTo: com.superview.leadingAnchor),
com.ownedView.trailingAnchor.constraint(equalTo: com.superview.trailingAnchor),
com.ownedView.topAnchor.constraint(equalTo: com.superview.safeAreaLayoutGuide.topAnchor,
constant: 35)
)
com.ownedView.axis = .vertical
com.arrangedView(self.redView) { (com) in
com.constraints(
com.ownedView.heightAnchor.constraint(equalToConstant: 50)
)
}
com.space(20)
com.arrangedView(self.orangeView) { (com) in
com.constraints(
com.ownedView.heightAnchor.constraint(equalToConstant: 50)
)
}
com.space(20)
com.arrangedView(self.yellowView) { (com) in
com.constraints(
com.ownedView.heightAnchor.constraint(equalToConstant: 50)
)
}
com.space(20)
com.arrangedView(self.greenView) { (com) in
com.constraints(
com.ownedView.heightAnchor.constraint(equalToConstant: 50)
)
}
com.space(20)
com.arrangedView(self.blueView) { (com) in
com.constraints(
com.ownedView.heightAnchor.constraint(equalToConstant: 50)
)
}
com.space(20)
com.arrangedView(self.purpleView) { (com) in
com.constraints(
com.ownedView.heightAnchor.constraint(equalToConstant: 50)
)
}
}
}
That will give you a view looking like this:
If you want to update to a new layout, just call the updateLayoutTo
method
again, defining what your layout should be. The framework will take care of
adding, removing and moving views as well as activating, deactivating and
modifying constraints.
As an example, let's randomly order these views, the spacing inbetween them and their height, re-updating the layout in this way every few seconds. The result will look something like this:
let views = [redView,
orangeView,
yellowView,
greenView,
blueView,
purpleView]
viewLayout.updateLayoutTo { (com) in
com.stackView(self.stackView) { (com) in
com.constraints(
com.ownedView.leadingAnchor.constraint(equalTo: com.superview.leadingAnchor),
com.ownedView.trailingAnchor.constraint(equalTo: com.superview.trailingAnchor),
com.ownedView.topAnchor.constraint(equalTo: com.superview.safeAreaLayoutGuide.topAnchor,
constant: 35),
)
com.ownedView.axis = .vertical
for view in views.shuffled() {
com.arrangedView(view) { (com) in
let random = CGFloat(Int.random(in: 20..<100))
com.constraints(
com.ownedView.heightAnchor.constraint(equalToConstant: random)
)
}
com.space(CGFloat(Int.random(in: 0..<50)))
}
}
}
DeclarativeLayout is available through CocoaPods. To install it, simply add the following line to your Podfile:
pod "DeclarativeLayout"
- iOS 9.0 or later
- Supports Swift 5
Every method that adds a new layout component (ex: view(:)
) will also return a
layout component. Using the component passed into the optional closure is
optional. This is done to make it easy for more opinionated layout frameworks to
be built on top of DeclarativeLayout and take advantage of its constraint and
view hierarchy diffing.
DeclarativeLayout is available under the MIT license. See the LICENSE file for more info.