Build Modular, Scalable, CMS-driven Flutter Apps
Packages |
---|
Sanity Integration |
Vyuh |
Developer Tools |
NPM |
Vyuh is a framework to build CMS-driven Flutter Apps at scale. It gives the no-code flexibility to the Business teams (via the CMS), and the full-code power to the Engineering teams. This puts the right control at the right place without any compromise.
Note
CMS is one of the many extensible integrations inside Vyuh. All integrations are managed as Plugins, which are standardized interfaces to extend the capabilities of the framework.
A common problem when building large scale apps is the need to stay modular as you keep growing the feature set. You also want different teams to work in parallel without stepping on each other. The typical approach of creating a single project and building all the functionality in it does not scale very well over time. You could break up the app into several packages but that still does not give you the clarity of who owns what. It does not tell you how to combine these packages to create the final app.
Additionally, Apps today are very content-oriented and need to be dynamic. This means your journeys, page content, themes, etc. should be remotely controllable. In other words, making your app Server-driven.
Combining all these capabilities requires a holistic approach, which is only possible when you build a cohesive framework.
Vyuh is that framework.
It allows you to create the perfect balance of simple, modular components on the
CMS
, with powerfulFlutter
counterparts that take care of all the complexity.
The teams (Business teams) managing the content and experience don't have to worry about UI Design, pixel precision or performance and focus more on building the screen journeys and page content instead. The Flutter engineering teams handle the complexity of the components along with its performance.
This clear separation allows a phenomenal flexibility in building simple to large scale apps. It also gives the right tools to the right teams and makes them more productive.
Business teams assemble page-content and journeys, whereas the Engineering teams focus on the developing the design, performance and scalability of those content-blocks. This results in a gallery of blocks which the Business teams use to create the content of the App.
The Vyuh framework has some powerful built-in capabilities such as:
- Building features atomically and in a modular fashion.
- Features as transferable and reusable units of functionality that can be moved between Apps.
- Remote configuration of content, enabling Server-Driven UI.
- Extensible Plugin-based approach to add new third-party integrations.
- Team Independence.
- Decentralised development.
- Creating a family of apps with reusable features.
- A growing set of integrations (aka building blocks) to make app development faster.
The core building blocks that enable all of this include:
- Features: build user-facing functionality in a modular, reusable, atomic manner. Features can be composed together to create the entire app or a family of apps. Features can also be transferred between apps easily.
- Plugins: All third party integrations are handled in a cross-cutting manner using Plugins. Authentication, Networking, CMS, Storage, Permissions, Ads, etc. are all plugins that are available to all features.
- CMS-Driven UI: Also known as Server-Driven UI, the entire app experience
can be driven from a CMS. This includes the screen journeys, page content,
themes, etc. The CMS itself is a standard plugin with custom Providers. Bring
your own CMS as a
ContentProvider
!
Note
The default CMS we use is Sanity.io.
- Community packages: leverages the best community packages like
mobx
,go_router
,get_it
,hive
,firebase
, etc. This means you don't have to learn anything proprietary to use Vyuh.
It is plain old Flutter with a fresh approach to building scalable apps.
- Start with the documentation on the Docs Website.
- There are several examples to give you a taste of the Framework. Check them out in the examples directory. Some direct links to the examples are listed below.
- To run the Vyuh Demo, there is some setup needed. This includes API Keys for Unsplash and TMDB. All these details are in the Vyuh Demo README.
Counter The classic counter example from Flutter, as a Vyuh Feature. |
Conference A Conference App feature with a list of sessions and speakers. |
Wonderous The Wonderous App as a feature. |
Movies A Movies feature using the TMDB API. |
Unsplash Explore the photos from Unsplash |
Miscellaneous Explore the various framework capabilities in this miscellaneous feature. |
Food A fast-food menu feature |
Puzzle A fun little puzzle game, as a feature. |
Follow us, stay up to date or reach out on:
Pavan Podila 💻 📖 |
Vishal Kumar 💻 |
Ajay Kumar 💻 |
Stephen Richter 💻 📖 |
The framework is FSL Licensed.