# Netdata agent web GUI ## Generating dashboard.js The monolithic `dashboards.js` file is automatically generated by concatenating the source files located in the `web/gui/src/dashboard.js/` directory by running the build script: ```sh cd web/gui make ``` After every change in the `src` directory, the `dashboard.js` file should be regenerated and commited to the repository. ## Custom Dashboards For information on creating custom dashboards, see **[Custom Dashboards](custom/)** and **[Atlassian Confluence Dashboards](confluence/)** ## Supported chart libraries - Dygraph - jQuery Sparkline - Peity - Google Charts - Morris - EasyPieChart - Gauge.js - D3 - C3 ### Dygraph #### Settings [Example settings here](https://github.com/netdata/netdata/blob/e91f00d99f4965e985981b93fa46ef33f94dd726/web/dashboard.js#L3793) #### Value Range You can set the min and max values of the y-axis using `data-dygraph-valuerange="[MIN, MAX]"` ### EasyPieChart #### Settings TBD #### Value Range You can set the max value of the chart using the following snippet: ```html <div data-netdata="unique.id" data-chart-library="easypiechart" data-easypiechart-max-value="40" ></div> ``` Be aware that values that exceed the max value will get expanded (e.g. "41" is still 100%). Similar for the minimum: ```html <div data-netdata="unique.id" data-chart-library="easypiechart" data-easypiechart-min-value="20" ></div> ``` If you specify both minimum and maximum, the rendering behavior changes. Instead of displaying the `value` based from zero, it is now based on the range that is provided by the snippet: ```html <div data-netdata="unique.id" data-chart-library="easypiechart" data-easypiechart-min-value="20" data-easypiechart-max-value="40" ></div> ``` In the first example, a value of `30`, without specifying the minimum, fills the chart bar to `75%` (100% / 40 * 30). However, in this example the range is now `20` (40 - 20 = 20). The value `30` will fill the chart to **`50%`**, since it's in the middle between 20 and 40. This szenario is useful if you have metrics that change only within a specific range, e.g. temperatures that are very unlikely to fall out of range. In these cases it is more useful to have the chart render the values between the given min and max, to better highlight the changes within them. #### Negative Values EasyPieCharts can render negative values with the following flag: ```html <div data-netdata="unique.id" data-chart-library="easypiechart" data-override-options="signed" ></div> ``` Negative values are rendered counter-clockwise. #### Full example This is a chart that displays the hotwater temperature in the given range of 40 to 50. ```html <div data-netdata="stiebeleltron_system.hotwater.hotwatertemp" data-title="Hot Water Temperature" data-decimal-digits="1" data-chart-library="easypiechart" data-colors="#FE3912" data-width="55%" data-height="50%" data-points="1200" data-after="-1200" data-dimensions="actual" data-units="°C" data-easypiechart-max-value="50" data-easypiechart-min-value="40" data-common-max="netdata-hotwater-max" data-common-min="netdata-hotwater-min" ></div> ``` ![hot water chart](https://user-images.githubusercontent.com/12159026/28666665-a7d68ad2-72c8-11e7-9a96-f6bf9691b471.png) [![analytics](https://www.google-analytics.com/collect?v=1&aip=1&t=pageview&_s=1&ds=github&dr=https%3A%2F%2Fgithub.com%2Fnetdata%2Fnetdata&dl=https%3A%2F%2Fmy-netdata.io%2Fgithub%2Fweb%2Fgui%2FREADME&_u=MAC~&cid=5792dfd7-8dc4-476b-af31-da2fdb9f93d2&tid=UA-64295674-3)]()