Quasar Framework is a high-performance Vue.js framework that enables developers to build different types of applications with a single codebase.
With Quasar, you can have a single codebase for:
Single Page Apps (SPA)
Server-Side Rendered Apps (SSR)
iOS/Android Mobile Apps
Desktop Apps
PWAs
Hybrid Apps
In simple terms, Quasar allows you to build cross-platform applications.
Although it is powered by Vue.js, it comes with its own set of built-in web components that can be imported to construct user interfaces.
Hasura with Quasar
Hasura is an open-source GraphQL engine that gives you real-time GraphQL APIs on new or existing Postgres databases. It comes with built-in support for stitching custom GraphQL APIs, and it allows you to trigger webhooks on database changes.
Hasura GraphQL fits in this workflow of building cross-platform apps neatly. All the clients (mobile app/electron app) use the same set of APIs controlled by the same set of permissions and auth. That means it can leverage the power of Postgres. Quasar gives endless possibilities with one codebase, and a standard GraphQL API from Hasura adds to the easier development workflow.
In the next step, you will learn how to configure the Apollo Client with Quasar and perform GraphQL Queries.
Quasar App Extensions
Quasar enables developers to extend the application’s functionalities with extensions. An example of an extension would be @quasar/apollo, which allows you to use GraphQL and the Apollo Client in your Quasar app.
In Quasar, you can install extensions as follows:
quasar ext add @quasar/apollo@next
The above command installs the extension and creates two additional files:
src/apollo/index.js - you need to add your Hasura app endpoint in this file
src/boot/apollo.js - you can leave this untouched
The next step is to register the extension in the quasar.config.js file. Open the file and add "apollo.js" in the boot array. See the part of the config file where you need to make the changes:
The above code loops over an array of authors, and it also uses a method named fetchArticles. That means you need to retrieve the authors from the database and define the method for fetching articles.
You use the Apollo Client to query the database and retrieve the authors. You also define the fetchArticle method, which routes users to the right page when clicking on the author’s name.
The code is still the same kind of code you would have written in a Vue.js app to make a GraphQL query with vue-apollo. The difference is the <template> part where Quasar uses native-like components to build hybrid apps.
Fetch Articles
Each author can have one or more articles, so you need to build the "Articles" page to list those articles. You can use the Quasar CLI to create a new page:
quasar new page Articles
The command creates a .vue file in the src/pages folder. Now you need to reference it in the routes file so that the users can access it.
use the Apollo Client to retrieve the articles from the database
pass the authorId parameter, so it fetches the articles for that specific author
re-fetch the articles when the author id (from the URL) changes
Thus, when you visit a URL like https://your-app.com/author/1, the page displays the articles of the author whose ID is "1".
Build Targets
Quasar requires you to specify the mode of the app spa|ssr|pwa|cordova|electron and the target cordova|electron - in case it's a hybrid app. You can also specify themes like material and ios, which will appropriately apply each component’s styles.
There is a boilerplate and a short tutorial to help you get started quickly! Check it out on Github.
Take it for a spin and let us know what you think. If you have any questions or run into any trouble, feel free to reach out to us on Twitter, Github, or our Discord server.
This post was originally published on March 20, 2019 and updated on April 14, 2022.