@hotnipi/node-red-dashboard-2-ui-gauge-linear 0.1.10

A linear style gauge node for @flowfuse/node-red-dashboard

npm install @hotnipi/node-red-dashboard-2-ui-gauge-linear

A linear type of gauge node for node-red dashboard 2.0

A linear type of gauge node for the flowfuse Node-RED Dashboard 2.0

hotnipi-gauge-linear

Install

The usual method of installing is to use Manage Palette in the node red editor and search for @hotnipi/node-red-dashboard-2-ui-gauge-linear and install it.

Using npm directly, cd into your node red user directory (usually .node-red in your home folder) and from there run

npm install @hotnipi/node-red-dashboard-2-ui-gauge-linear

Inputs

Pass the value in configured property or as default msg.payload. This may be a Number or a string that represents a number.

Certain configuration values can be overridden dynamically be passing in an object in msg.ui_update. See Dynamic Properties below.

Configuration

  • Name - The name of the node.

  • Group - The display group in which to show the gauge.

  • Size - The size of the gauge on the dashboard.

  • Label - A text label that is shown above the gauge's bar.

  • Input - Configured input property should carry single numeric value.

  • Limits Min and Max - These specify the range of the gauge. Values are mandatory. Optionally you can configure labels for limits. If configured, the label is shown instead of value.

  • Ticks - This defines intermediate values under the gauge bar. Each row defines the value of the tick and as for limits, optionally the label for tick can be configured.

  • Bar - The bar appearance. Bar can be segmented (led-like dots) or solid. For solid bar the bar colored sectors are defined by the ticks.

    • Select Mode - Select the mode of the bar beahvior. Select the mode first and the configure the colors and maybe count of the cells. You can always change the mode but whenever you have selected a mode which makes same color for all cells, you'll need configure the colors again. "Default" - basic mode. "Full Bar Color" - all bar cells change the color based on value. "Cross Zero" - The left end of the bar is zero. The right end is even positive or negative limit. The bar switches color based of value being positive or negative. If Min and Max are configured equally far from zero, it is possible to configure intermediate ticks. Otherwise ticks are not available for this mode.

    • Pick Color - Use color picker to select the color and then drag over the bar to apply the selected color to the desired cells. Repeat this step to apply different colors for different bar regions. Note that for "Cross Zero" mode it takes to configure different colors for positive and negative occurence.

    • Add cell - Adds a cell to the bar end. (if there is less than 60)

    • Remove cell - Removes a cell from the bar end. (until there is only 2)

  • Decimals - The value is rounded down to configured decimals. Keep zeros keeps the trailing zeros.

  • Icon - An icon that is shown in front of the gauge's bar. Gauge supports Material design icons.

  • Unit - The unit string to show in the gauge.

  • Dim - The value for how much non-active cells will dim down. Number in range 0 - 0.9

  • Class - A CSS Class that will be applied to the gauge to allow override of display element style.

Dynamic Properties

Certain properties can be overridden by passing an object in msg.ui_update. The name of the item in msg.ui_update is generally the name of the propety being overridden. For example, the Ticks definitions may be changed by passing in array in msg.ui_update.ticks.

  • Colors - If msg.ui_update.colors contains an array then that will be used to override all cells. The array must contain a list of colors:
    ["green","green","green","red"] or an array of objects [{ "color": "green" },{ "color": "green" },{ "color": "green" },{ "color": "red" }] Define color for each cell.

  • Min - If msg.ui_update.min is present and contains an object {value:10} or {value:10,label:"Ten"} then min limit of the gauge will be changed.

  • Max - If msg.ui_update.max is present and contains an object {value:10} or {value:10,label:"Ten"} then max limit of the gauge will be changed.

  • Label - If msg.ui_update.label is present and contains a string then that string will be displayed in the label field in the gauge.

  • Unit - If msg.ui_update.unit is present and contains a string then that string will be displayed in the units field in the gauge.

  • Ticks - If msg.ui_update.ticks contains an array then that will be used to override all ticks. The format of the tick in the array is same as for min and max. [{value:10},{value:30}] or [{value:10,label:"Ten"}]

  • ZeroCrossColors - If msg.ui_update.zeroCrossColors contains an array then that will be used to override colros when gauge mode is Cross Zero. Two colors must be defined in array representing colors for negative and positive ["red","green"]

  • Icon - If msg.ui_update.icon is present and contains a icon name as string then gauge changes the icon. Note that you can not change the icon if you didn't configure the gauge to have icon.

  • NB! Updating ticks for the solid bar is tricky.

Ticks can not be changed alone, it takes also to change the colors. Every color must be defined with the size property and the value for that must be calculated:

Math.floor(((tv - mi) / (ma - mi)) * 100)

where:

tv = tick value, mi = min value, ma = max value

The colors in array must be objects in shape { "size": 60, "color": "green" }

CSS overrides

The label, value and limits can be hidden by adding pre-built modifier class names to the Class field:

  • To hide label add hide-label
  • To hide value add hide-value
  • To hide limits and ticks add hide-limits

For more specific modifications of display elements override styles in the normal way using a ui-template node. In particular:

The color of the value

.myclass .hotnipi-gauge-linear-value{
    color: red;
}

Other notes

  • Count of cells - The optimal count of the cells is about 20. Cell count is limited: min 2, max 60 .You are free to configure any amout of cells in this range but pay attention for 2 key things.
    • Too many elements may affect the performance of the dashboard.
    • The node is made responsive. If you are using it with small screen and there is not enough space to render elements, the gauge tries to hold important elements visible by removing less important elements. Every second cell is removed to keep other cells size reasonable. This also means that if you configure single cell with one color, it may be removed if conditions met.

Buy Me A Coffee

Node Info

Version: 0.1.10
Updated 7 months ago
License: Apache-2.0
Rating: 4.8 4

Categories

Actions

Rate:

Downloads

220 in the last week

Nodes

  • ui-gauge-linear

Keywords

  • node-red
  • node-red-dashboard-2
  • gauge
  • lineargauge

Maintainers