Dynamic Markdown, Tables & Notebooks with Dashboard 2.0

A dive into the new features available in 0.4.0 - The "Notebook" Layout and new dynamic Markdown & Table widgets.

Back to Blog Posts
Image representing null

Whilst we're still busy backporting through the existing Dashboard 1.0 features, we did want to highlight some new features we've built in Dashboard 2.0 released this week.

In our v0.4.0 release, we've introduced a new "Notebook" layout, alongside a new Table widget.

The Notebook layout is designed to allow users to create Dashboards structured like a Notebook (most often seen with the likes of Jupyter Notebooks or ObservableHQ).

Here we will deepdive into the Notebook layout, and show how, alongside our new Markdown Node (docs), Table Node (docs) and others, it's becoming easier to create dynamic and interactive Dashboards.

Note: If you're not familiar with Markdown, it's a simple markup language that allows you to format text. You can learn more about it here.

Dashboard Hierarchy

As a quick introductory note ahead of our below guide, each Dashboard is structured accordingly:

  • Widget: An individual functional block, e.g. button, chart, slider
  • Group: A collection of widgets that render together
  • Page: A single page/tab in your Dashboard. Each page can have it's own Layout, in this case we'll use "Notebook"
  • UI: Contains a collection of pages, deployed from Node-RED, provides the basic side navigation to switch between Pages.

Building a Notebook

Example Notebook created in Dashboard

To get started, drop your first widget (in this case, we'll add a ui-markdown) onto the Node-RED canvas. This in turn will prompt us to create our first Group/Page/Dashboard which we can name and configure accordingly.

Let's add the following Markdown to our first widget:

# Markdown Content

Here we can render dynamic Markdown content that is
easily _styled_.


We can inject `msg.payload`. For example, here is a
timestamp updating every second: {{ msg.payload }}

The joy of ui-markdown in Dashboard 2.0 is dynamic content, i.e. content that can be updated by passing messages to the ui-markdown node. We can wire an inject node, set it up to repeat every second, and connect it to ui-markdown. Now, our Markdown content will automatically update show this value.

Screenshot to show how an inject node can drive content of a ui-markdown node

Resulting in:

Dynamic markdown with an updating timestamp every 1 second

Adding More Widgets

Because the Notebook is just a layout, we can still wire together any of the available widgets and existing nodes and display them accordingly.

Let's wire a ui-button, HTTP Request, and ui-table node. When we click the button, it will perform the HTTP request, and then render the response in the table.

For this, we're going to use the Random Jokes API, and in particular, a call to https://official-joke-api.appspot.com/jokes/ten which will return 10 random jokes.

Screenshot showing a simple Button > HTTP Request > Table flow

We can also re-order the widgets on the page using the Dashboard 2.0 sidebar (as you could in Dashboard 1.0).

Screenshot to show how an inject node can drive content of a ui-markdown node

The above effort results in the following output in our Notebook:

Screenshot to show how an inject node can drive content of a ui-markdown node

What else is new in 0.4.0?

The above demonstrates just a few of the new features in the 0.4.0 Release, but we've also added other fixes and improvements. In particular, I want to call out Steve's great work on implementing custom class injection, the first of our new "Dynamic Properties", of which there will be more (e.g. visibility, disabled, etc.) to come.

As always, thanks for reading and your interested in Dashboard 2.0. If you have any feature requests, bugs/complaints or general feedback, please do reach out, and raise issues on our relevant GitHub repository.

Written By:

Head of UX & Design

Published on:

Related Articles:

Sign up for updates