Implementing, maintaining, documenting and evolving a shared set of UI components is not an easy thing in a large-scale application. Web developers have created a powerful solution for this process - Storybook.js. But what about native iOS development? Can we achieve a somewhat similar experience?
What if we combine a catalog app, snapshot tests, and HTML-based documentation generation into a single system?
Imagine writing a code snippet just once, and then being able to do the following:
- Display a view produced from a snippet in a native catalog app
- Embed a view into SwiftUI previews
- Run a snapshot test for a snippet
- Display this code snippet and the resulting snapshot in a generated HTML-based documentation
This repo is a proof of the concept for such a system!
Check my article about NativeBook for more details: https://hackernoon.com/nativebook-unifying-the-native-ios-development-experience-with-storybookjs
class UIButtonStories: DynamicComponentStories {
@objc static func story_ImageTitleButton() -> UIView {
let button = UIButton()
var config = UIButton.Configuration.plain()
config.title = "Image + Title"
config.image = UIImage(systemName: "bell")
config.imagePlacement = .top
config.titlePadding = 10
button.configuration = config
return button
}
...
}
data:image/s3,"s3://crabby-images/ec665/ec6651e229e78350dc503a576c52cd6dd17dc914" alt=""
data:image/s3,"s3://crabby-images/dab41/dab413cee9c7fa071e7b194d28a83160cc0f3b36" alt=""
data:image/s3,"s3://crabby-images/08b35/08b359df4ef211c5bfb7f8e0316f35e3cb05ec5c" alt=""
Site: https://psharanda.github.io/NativeBook
data:image/s3,"s3://crabby-images/e74d0/e74d0572b5f21690b5723085edfdb3d1a188bfca" alt=""