Skip to content

React Dashboard helps you to generate dashboard prototypes very quickly with "configuration over code".

License

Notifications You must be signed in to change notification settings

sparcv9/dashboard-prototyper

 
 

Repository files navigation

React-Dashboard (RDB)

This project is at an early stage of development!

RDB helps you to generate dashboard prototypes very quickly with "configuration over code". You just need to specify the boards and the belonging widgets in the RDB config file file and you are ready to build your dashboard. It's also easy to extend RDB by writing your own widgets.

RDB is based on our react starterkit.

Get Started

Clone RDB

$ git clone https://github.com/wbkd/react-dashboard.git && cd react-dashboard

Installation

Install all dependencies.

$ npm install

Development

Builds the application and starts a webserver with livereload. By default the webserver starts at port 1337. You can define a port with $ gulp --port 3333.

$ gulp

Build

Builds a minified version of the application in the dist folder.

$ gulp build --type production

Documentation

RDB config file

You can find the config file in the root folder. It has three attributes (name, style and boards). The name is displayed at the top of the sidebar as the title of the dashboard. Style indicates stuff like the font, colors etc and under boards (the important part) you configure the different boards and their related widgets. If you do not specify a property we use the default one, you can find in the default config.

Properties:

  • name String that defines the dashboard title. Default: 'RDB Dashboard'.
  • style Object with style properties
  • boards Array with boards

Example config file:

module.exports = {
  name: 'Awesome dashboard',
  style: {
    font : 'Roboto',
    titlebg : '#fff',
    titlecol : 'red'
  },
  boards: [
    {
      name: 'Site A',
      widgets: [
        {type : 'map', properties: { center : [52.25, 13.4] }}, 
        {type : 'line', properties: { data : jsonObjA }}
      ]
    },
    {
      name: 'Site B',
      widgets: [
        {type : 'map', properties: { center : [52.25, 13.4] }}, 
        {type : 'bar', properties: {  data : jsonObjB }}
      ]
    }
  ]
};

Style

For now it's only possible to tweak some colors and change the font type. You can find the available fonts and the font loading logic in the Font Loader. The styles are applied in the Styler Module.

Available fonts are:

  • Droid Sans
  • Lato
  • PT Sans
  • Roboto
  • Open Sans

Properties:

  • font Font type. Default: 'PT Sans'
  • titlebg Background color of the title. Default: '#eeeeee'.
  • titlecol Font color of title. Default: '#222222'
  • sidebarbg Background color of the sidebar. Default: '#303030'
  • sidebarcol Font color of the sidebar. Default: '#f4f4f4'
  • boardbg Background color of the boards. Default: '#f4f4f4'
  • boardcol Font color of the boards. Default: '#222222'
  • widgetbg Background color of the widgets. Default: '#ffffff'
  • widgetcol Font color of the widgets. Default: '#222222'

Example style:

  style: {
    font : 'PT Sans',
    titlebg : '#eeeeee',
    titlecol : '#222222',
    sidebarbg : '#303030',
    sidebarcol : '#f4f4f4',
    boardbg : '#f4f4f4',
    boardcol : '#222222'
  }
  

Boards

The boards property is an array with board objects. A board object has a name and and several widgets. When you build the dashboard, the several boards are dynamically generated in Routes with the help of the Board Factory. The Board Component then displays the title and loads its widgets.

Example Board:

{
  name: 'Site A',
  widgets: [
    {type : 'map', properties: { center : [52.25, 13.4] }}, 
    {type : 'linechart', properties: { data : jsonObj }}
  ]
}
    

Widgets

The widgets are defined in the board objects. A widget object has a type and properties. The type specifies the widget type and the properties define all data that get passed to the widget. Widgets are created in the Board Component with the help of Widget Factory.

For now there are these widgets available:

Map Widget

The map widget is based on Leaflet. It displays a map with a certain center and markers with tooltips.

Properties:

  • title String that defines the widget title. Default: No Title.
  • center Array with Coordinates. Default: [0,0]
  • zoom Integer with the starting zoom level. Default: 13.
  • wmsTileLayerUrl String that declares the WMS tile layer. Default: https://tile.stamen.com/toner/{z}/{x}/{y}.png.
  • marker Array with marker objects. Default : No marker.
    • latlng Array with Coordinates.
    • text String with tooltip content. Default: No content.

Example Map Widget Configuration:

{ type: 'map',
  properties: {
    title: 'map title',
    center: [52.52, 13.4],
    zoom : 10,
    marker: [
      { latlng: [52.52, 13.4], text : 'This is a marker.'},
      {latlng: [52.55, 13.35]}
    ]
  }
}

Source: Map Widget

Bar Chart Widget

The bar chart widget is based on c3.

Properties:

  • title String that defines the widget title. Default: No Title.
  • data Array with JSON data. Default: [{ alpha: 100, beta : 120, gamma: 110 },{ alpha: 120, beta : 110, gamma: 90 },{ alpha: 75, beta : 100,gamma: 80 }]
  • keys Array with keys you want to display. Default: Every key found in the passed data.

Example Bar Chart Widget Configuration:

{
  type: 'barchart',
  properties: {
    title : 'A Bar Chart \o/',
    data: [{ alpha: 100, beta : 120, gamma: 110 },{ alpha: 120, beta : 110, gamma: 90 },{ alpha: 75, beta : 100,gamma: 80 }],
    keys : ['alpha', 'gamma']
  }
}

Source: Bar Chart Widget

Line Chart Widget

Almost the same configuration as the bar chart widget but type is equal linechart in this case.

{
  type: 'linechart',
  properties: {
    title : 'A Line Chart \o/',
    data: [{ alpha: 100, beta : 120, gamma: 110 },{ alpha: 120, beta : 110, gamma: 90 },{ alpha: 75, beta : 100,gamma: 80 }],
    keys : ['beta']
  }
}

Source: Line Chart Widget

IFrame Widget

Displays a certain webpage.

Properties:

  • title String that defines the widget title. Default: No Title.
  • src String that defines the url you want to display. Default: 'https://news.ycombinator.com'.

Example IFrame Widget Configuration:

{
  type: 'iframe',
  properties: {
    title : 'True Reddit',
    src: 'https://www.reddit.com/r/TrueReddit/'
  }
}

Source: IFrame Widget

Extend RDB

Widgets

Every widgets ships its own dependencies. You can use the css-loader to load CSS dependencies. The map widget for example loads leaflet.js and the related CSS file:

var L = require('leaflet');
require('../../../../node_modules/leaflet/dist/leaflet.css');

If we want to check out a widget we don't want to specify any properties. We just want to see the widget. Because of that it's important that the widget has at least some default properties, so that something get rendered if we add the widget to a board.

Writing your own Widgets

Todo

About

React Dashboard helps you to generate dashboard prototypes very quickly with "configuration over code".

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 91.6%
  • CSS 6.9%
  • HTML 1.5%