Skip to content
This repository has been archived by the owner on Sep 5, 2024. It is now read-only.

Widget to allow display and control of devices and groups of devices. Developed by Global Presales.

License

Notifications You must be signed in to change notification settings

Cumulocity-IoT/cumulocity-device-control-widget

Repository files navigation

Device control and status widget

This widget allows display and control of devices and groups of devices.

⚠️ This project is no longer under development. Please use cumulocity-device-control-plugin for Application Builder >=2.x.x and Cumulocity >=1016.x.x⚠️

Preview

Features

  • The user can select groups and individual devices.
  • The user can use images (including vector graphics) to represent the devices.
  • Select operations and define tooltips, and payload for each.
  • Filter and display at risk devices
  • Toggling of flags on the managed object supported.
    • N.B. referred to as toggles below.
  • Supports group template dashboard
  • Realtime update of the managed objects

Installation

Runtime Widget Deployment?

  • This widget supports runtime deployment. Download the Runtime Binary and follow runtime deployment instructions from here.

User guide

This guide will teach you how to add the widget in your existing or new dashboard.

NOTE: This guide assumes that you have followed the installation instructions

  1. Open the Application Builder application from the app switcher (Next to your username in the top right)
  2. Add a new dashboard or navigate to an existing dashboard
  3. Click Add Widget
  4. Search for Device Control
  5. See below for the configuration options

addwidget

The widget configuration page contains a number of configuration attributes.

addwidget

  • Title : Enter the title which will display at the top of your widget

Device Options

  • Select device : Choose a group of devices and/or individual devices to display on the widget. As you choose the Preview section will update to reflect your choices.

addwidget

  • Device icon : click on the icon to change the displayed image for each device.

  • Icon height : use the slider to change the image display size.

  • Columns : use the slider to change how many devices will display side by side before wrapping.

addwidget

  • Show Availability : check to show the current status of the device - based on the fragment c8y_Availability.

  • Show alarms : Check this option to display a pill containing the number of alarms for this device.

  • Show operations : Check this option to display the buttons to allow operations and toggles to be invoked.

  • Show at risk only : Check this option to default the widget to display only those devices that are offline, in maintenance or have alarms.

addwidget

Select operations or add toggles

N.B. (reminder) "toggles" are a name for a mechanism the widget provides to flip a boolean fragment on the Managed Object that represents the device. It is intended to be a generic mechanism to help demos, but may well have utility in other areas.

  • Select operations : if the selected devices have the c8y_SupportedOperations fragment then the list will be displayed here. The list will be a composite of the c8y_SupportedOperations fragments from all selected devices with duplicates removed.

After selecting an operation a column of options for the operation will appear.

  • Display Name : This is a tool tip which will be displayed when you mouse over the operation on the widget.

  • Button icon : select an icon from the font awsome 4 list of icons to represent the selected operation.

  • payload : this is an arbitrary payload (json) that will be sent in the operation. Typically the payload can be anything but is the value of a fragment of the operation object that will be sent. a code representation is shown below but the contents of the field will depend wholly on what operation the user selects and what it expects. See Cumulocity create section for more details

    //this is an example for supplorted operation 'myOperation'
    //deviceId is supplied by the widget
    let operation: IOperation = {
        deviceId: xxxxxx,
        myOperation: <payload field contents>
    }
  • Add toggle : Clicking this will add a column, similar to the one added by selecting a command above. However the fields are slightly different.

addwidget

The following shows the widget responding to the change in managed object flag state. because it has the c8y_Availability when the fragment sag_IsShutDown is toggled to true (and its status is available) the device shows as being in standby.

addwidget

Group template

You can use this widget with a group template dashboard:

addwidget

for example the Laboratory group in my examples above:

addwidget

Now each page can have a widget that displays the device linked to the route selected.

addwidget

Additionally you can set up a link from the individual devices on the widget to the individuals group page:

addwidget

Widget display

Once configured the widget displays the selected devices, or all devices in a selected group. You can configure the widget to only display "at risk" devices by default also.

Additionally by checking/unchecking the "Only ay risk" option you can change what is seen.

Lastly there is a search facility allowing you to select a subset of devices based off their name.

filters

as shown above in the configuration, if the group dashboard link is set then clicking on the icon will take you to that devices page in the group template dashboard.

The devices will update when the managed objects change.


These tools are provided as-is and without warranty or support. They do not constitute part of the Software AG product suite. Users are free to use, fork and modify them, subject to the license agreement. While Software AG welcomes contributions, we cannot guarantee to include every contribution in the master project.


For more information you can Ask a Question in the Tech Community Forums.

You can find additional information in the Software AG Tech Community.