Cube is visualization-agnostic, so you can build any user interface for your application.

You can directly query Cube Backend using JSON Query Format via HTTP API or WebSockets and visualize analytical data with tools of your choice. However, it's much easier to use the Cube JavaScript client and bindings for popular frameworks such as React, Angular, and Vue.

The client has methods to communicate with Cube API Gateway and retrieve and process data. It is designed to work with existing charting libraries including Chart.js, D3.js, and more.

Cube JavaScript Client

The client provides methods to solve common tasks:

Abstract from the transport and query data. You can fetch data from Cube Backend or subscribe to real-time updates regardless of the protocol, be it HTTP or WebSockets.

Transform data for visualization. You can pivot the result set to display as a chart or as a table, split into series or table columns.

Simplify work with complex query types. You can build Drill Down queries and decompose the results of compare date range queries or Data Blending queries.

Learn more in the documentation for the @cubejs-client/core package.

Cube Vue Package

The package provides convenient tools to work with Cube in Vue:

Components. You can use QueryBuilder and QueryRenderer components to abstract state management and API calls from your rendering code.

Example Usage

Here are the typical steps to query and visualize analytical data in Vue:

  • Import @cubejs-client/core and @cubejs-client/vue packages. These packages provide all the necessary methods and convenient Vue tools.
  • Create an instance of Cube JavaScript Client. The client is initialized with Cube API URL. In development mode, the default URL is http://localhost:4000/cubejs-api/v1 (opens in a new tab). The client is also initialized with an API token, but it takes effect only in production.
  • Query data from Cube Backend. Use QueryBuilder or QueryRenderer and their props to execute a query and transform the result set. See Query Format for details.
  • Transform data for visualization. Use QueryBuilder and QueryRenderer slots props to transform the result set. Furthermore, the result set has convenient methods, such as series and chartPivot, to prepare data for charting.
  • Visualize the data. Use tools of your choice to draw charts and create visualizations.

See an example of using Cube with Vue and Chart.js library. Note that you can always use a different charting library that suits your needs:

Getting Started

You can install Cube JavaScript Client and the Vue package with npm or Yarn:

# npm
npm install --save @cubejs-client/core @cubejs-client/vue3

# Yarn
yarn add @cubejs-client/core @cubejs-client/vue3

Note. If you're using Vue 2, please use @cubejs-client/vue.

Now you can build your application from scratch or connect to one of our supported data visualization tools. You can also explore example applications (opens in a new tab) built with Cube.