Actions
    • 04 Jan 2022
    • 17 Minutes to read
    • PDF

    Actions

    • PDF

    Article summary

    Actions are triggered when the event for which they were configured is triggered. Available actions are:

    Write tag

    Write tag allows a value to be written to the selected tag. It has two configurable fields:

    • Tag: Tag to write value to.
    • Value: Value to write to tag.

    Figure 94: Write tag options


    Write tag popup

    Write tag popup allows a list of comma separated tags to be set. When the event is triggered, a popup will open that allows users to write values to selected tags.

    Figure 95: Write tag popup options


    Write popup

    Write popup is a popup that presents information about the selected tags in a table and also allows values to be written to the tags. The table includes the following columns:

    • Tag: Tag path.
    • Type: Data type of the concrete tag.
    • Current value: Current tag value.
    • New value: New value that we want to write to the tag. If the tag is a number type, a popup will appear with a helper to translate between numerical bases. This popup can open a new value dropdown option.

    Figure 96: New value


    • Select field: Allows tags to be selected. Only new values for selected tags will be written.
    • Result: Result of writing operation.

    Figure 97: Write popup after writing tag values: /ReadWriteBoolean shows a writing error because 19 is not a Boolean.


    Write tag popup static

    This action is very similar to Write tag popup, although here the tag properties are static and use action options instead of the Write tag popup (where they are read from the tag dynamically). Write tag popup static allows multiple elements to be added to represent static tag definitions. Each tag definition has the following properties:         

    • Label: Label shown in Write popup instead of showing the tag path.
    • Tag: Tag path.
    • Value type: Permitted value type for writing to tags.
    • Allow manual input: Allows a personalized value to be written to a tag or simply values inside the value list.
    • Validation:
      • Min value: Only if value type is a number. Minimum value accepted to write.
      • Max value: Only if value type is a number. Maximum value accepted to write.
      • Custom: Optional expression that allows tag values to be filtered based on an expression. Within the expression, the value to be written can be accessed using the "value" variable. If a message is returned, this message will be shown as an error message instead of allowing it to be written.

    Figure 98: Custom


    • Users can define a predefined values list, which will be shown in the write popup as options in the new value dropdown.

    Figure 99: Static tag definition


    Write popup static

    Write popup static is a popup that permits values to be written to tags with much more control over the values the operator can choose from. Each tag offers the following possibilities:

    • Label: The text used to describe the tag.
    • Type: Type of value (Boolean, number, or string).
    • New value: New value can have a static values list defined during action creation. Input on this field can also be disabled.
    • Result: Result will show the writing results and action validation values (Custom and min/max).

    Figure 100: Write popup fail for previously defined Custom validation


    Reload historical DataSet

    Using this action, a historical DataSet will reload its values independently of whether its needed or not. It allows users to input a list of comma separated historical DataSets.

    Set property

    Allows a value to be set to the selected instance property. There are 3 properties:

    • Instance: Instance proprietary for the property to be set.
    • Property: Property to set.
    • Value: Value to set to the property.

    Figure 101: Set property action properties


    User interface

    Allows user interface actions to be triggered: Logout and change timezone.

    Figure 102: User interface action properties


    Wait for completion

    Wait for completion forces all actions before it to be completed before continuing with the next action. It can be applied to any property, depending on the completion of actions. For example, the following image shows a wait for completion example that forces the writepopupstatic action to wait until the end before executing the specified action.

    Figure 103: User


    Wait for timeout

    Wait for timeout forces a wait time of a predefined number of milliseconds before executing the next action.

    Break execution

    Break execution allows the actions chain to be stopped for the selected event using a Boolean condition. This condition can be a simple true or false value but it can also be a reference to another property or expression.

    Figure 104: Break execution event that will stop the execution of the actions chain when an element value is larger than 30


    Ack alarm

    Ack alarm allows a comma separated alarms list to be added. When the event is triggered and the action executed, a popup will open showing info for the selected alarms and allowing them to be acked with a message.

    Figure 105: Ack alarm action configuration


    Figure 106: Ack popup


    Figure 107: Post Ack result, as seen in the alarms table


    Open URL

    Open URL allows a url to be added that will be opened as a new tab when the action is executed.

    Figure 108: Open URL configuration


    Print

    Print allows preview windows to be opened or a navigator to be built in print preview dialogs to show and print selected instances. Overflow (content area inside the element that overflows the element size. For example, rows hidden in a table and only reachable using scroll) will be shown when printing.

    Figure 109: Print action configuration


    Figure 110: Element to print in Webvision


    Figure 111: Element printed version (if width is larger than the selected page width, it will overflow)


    Open historical

    Open historical opens a popup for visualizing historical data. This popup allows different tags to be selected and their data with different parameters to be shown. Action configuration properties can be preselected when opening the popup and changed by the end user in runtime. The following properties can be configured with default values:

    • Tags: Comma separated list of tags to be displayed.
    • Autoreload: Manages historical data autoreload.
      • Enabled: Boolean value for activating/deactivating autoreload.
      • Interval: Reload interval, in seconds.
    • View: Configuration of view to be opened by default.
      • View: Config or Content.
      • Tabs: Only on Content view, Chart, or Report.
    • Config: Configurable parameters inside Config view.
      • Date mode: Allows different ways of specifying the start and end dates for displayed data.
        • Relative: Allows users to select the start and end date according to the current date.
        • Absolute: Allows users to select a start and end date as absolute dates.
        • Current: Allows users to select an interval between the current moment and a previous moment defined by the offset.
      • Date: Configuration for the different Date modes:
        • Relative: Start and end dates are configured using an offset in days or weeks and a time offset in milliseconds
          • Offset: Offset relative to current moment.
          • Time: Absolute offset over the relative offset.
        • Absolute: Allows dates to be specified as absolute values.
          • Start: Absolute start date.
          • End: Absolute end date.
            • Current: Allows the date to be specified between a selected negative offset and the current moment.
              • Offset: Negative offset from current date.
              • Units: Offset units (seconds, minutes or hours).

    • Mode: Configuration of data representations.
      • Aggregated: Allows users to aggregate data using different methods.
      • Raw: Presents data as per it is stored in the historical database.
      • Delta: Only presents values when they have changed more than the deadband value. Includes all values after the change.
      • Filter: Only presents values when they have changed more than the deadband value. Includes all values before and after the change.
    • Mode configuration: Configuration properties for the different modes.
      • Aggregated:
        • Aggregation method: Type of aggregation applied to data. Choose between:
          • Tag configuration: Value configured within the tag.
          • Avg: Weighted-time average for the selected aggregation interval.
          • Min: Minimum value for the selected aggregation interval.
          • Max: Maximum value for the selected aggregation interval.
          • First: First value for the selected aggregation interval.
          • Last: Last value for the selected aggregation interval.
        • Aggregation interval: Interval for the aggregated data:
          • Value: Interval value.
          • Units: Value units.
      • Raw: No special configuration, raw values.
      • Delta and Filter:
        • Deadband: Defines the data change threshold.

    Figure 112: Open historical action configuration options


    Historical popup

    Historical popup allows users to configure the historical data displayed and view it either as a graph or a data table. The following popup viewing options are available:

    • Config: This view enables users to configure the data visualization. It’s similar to setting the config in action configuration but offers a less compressed layout.

    Figure 113: Config view


    • Content: Content view allows historical data to be displayed. There are two key areas offered:
      • General: Enables multiple options:
        • Return to config view.
        • Reload selected tags.
        • Configure autoreload.
        • Download data as csv.
        • Toggle between different data visualizations.
      • Data visualization: Can be one of two types: a graph or a table with date/value representation.

    Figure 114: Content view chart


    Figure 115: Content view table


    Load report pdf

    The Load report pdf action allows reports in PDF to be loaded from the backend. It does exactly the same as the load button inside the Report pdf viewer

    Figure 116: Load report pdf action configuration properties


    Download report pdf

    The Download report pdf action allows users to download a PDF report from the backend. It does exactly the same as the download button inside the Report pdf viewer. If the report hasn’t been loaded prior to the event, it will be loaded before downloading.

    Figure 117: Load report pdf action configuration properties


    Open instance

    Open instance allows users to select a template and create an instance for it, which can then be opened inside a region or as a new popup window. There are two different possible behaviors, depending on the Open target (Region or popup):

    • Region: When action is executed, an instance will be added to the Region children and the displaying child will be set as the new instance. If the uid is specified, it will share the same instance name as the Region child. If not, an automatic name will be assigned. If the child displayed in Region is changed manually, the instance will be removed from the region children instance list.
    • Popup: When action is executed, an instance will be created and opened in a new popup window.

    This action offers the following configuration properties:

    • Open on: Instance open target. Region or Popup.
    • Region: Region for inserting the instance. Disabled if “Open on” is a popup.
    • Template: Template to instantiate.
    • Instance UID: Unique identifier for the instance. Unless left null, when executing an action for the first time the UID will be added to Region or opened in a new popup. For all executions thereafter, the same instance will be refused and instead, only existing custom properties will be applied.
    • Custom properties: Instance elements list. If named the same as any of the custom properties inside the selected template, the value inside the value property field will be set as the instance custom property value.

    Figure 118: Open instance inside Region


    Figure 119: Open instance in new popup window


    Expressions

    JavaScript expressions can be used on each custom property or data entry to calculate the value. They allow for dynamic configuration by creating custom properties within templates and using different values for each instance in the template. Custom properties can also be changed dynamically using events, or by linking them to other tags and properties. Moreover, WebVision has added an extra set of functions, which can be used in Expressions to augment its capabilities.

    Syntax

    When using an expression, instead of writing a static value to a field, the field must start with ‘=’. JavaScript code can then be used and the expression return value will be used as the value for the field. As expressions are evaluated as JavaScript code, all strings must be enclosed in either single or double quotes. The following examples show a number of different valid and invalid expressions, as well as their values when evaluated:

    = 5 -> 5
    = “This is a string” -> This is a string
    = The value is 5 -> INVALID, the string needs to be enclosed in quotes
    = “The value is” 5 -> INVALID, 5 needs to be concatenated to the string
    = “The value is ” + 5 -> The value is 5
    
    


    Expressions can also use custom properties, which is done by using the property, self or parent functions, depending on the custom property origin. This will be substituted by the value of the custom property when resolving the expression. This can be seen in the following example:

    //Assuming a basePath custom property with the value /Group1/Inverter1/
    
    = self(“custom.basePath”) -> /Group1/Inverter1/
    = “self(“custom.basePath”)” -> self(“custom.basePath”)
    = self(“custom.basePath”) + Power -> INVALID, power needs to be enclosed in quotes
    = self(“custom.basePath”) + “Power” -> /Group1/Inverter1/Power
    
    


    Since expressions are JavaScript code, they can resolve conditionals. This allows the color of a component to be changed based on the value of a tag or a custom property:

    //Assuming there is a “valid” boolean custom property set to true
    
    = if(valid === true) “green”; else “red” -> green
    //Valid changes to false -> red
    


    Besides conditionals, other JavaScript features such as JavaScript functions, can also be used in expressions. This includes Date, Math, or String functions.

    //StringCustomProperty is a string with a value of “2”
    =parseInt(self(“custom.stringCustomProperty”))*2 -> 4
    
    =Date.now()+3600*1000 -> Date one hour from now, in Epoch
    
    //fullTagPath is a string with a value of “/Group1/Inverter1/Power
    = self(“custom.stringCustomProperty”).split(‘/’).slice(-1)[0] -> Power
    


    Tag function

    WebVision adds the tag() function to expressions. This function is used to obtain information about a tag from N3uron, which can be the value, quality, engineering units, etc…

    The syntax for this function is tag(“tagPath.propertyPath”). If the propertyPath is left blank, the tag value will be returned. Otherwise, the property value will be returned (if it exists) or alternatively, it will be left as null if no such value exists. See below for examples of this function, which assumes the following tag is being used:

    Tag:{
    	fullPath: “/Group1/Inverter1/Power”,
    	config:{
    		engUnits: “kW”
    	},
    	data:{
    		value:150,
    		quality:192,
    		ts: “2018-09-25T14:56:52.460Z”,
    	}
    }
    
    //tag is a custom property with value “/Group1/Inverter1/Power”
    = tag(self(“custom.tag”)) -> 150
    
    = tag(“Group1/Inverter1/Power.engUnits”) -> null (engUnits path is config.engUnits)
    
    = tag(“Group1/Inverter1/Power.config.engUnits”) -> kW
    
    = tag(self(“custom.tag”).data.quality) -> INVALID, .data.quality needs to be a string
    
    = tag(self(“custom.tag”)+”.data.quality”) -> 192
    


    Alias function

    The Alias function adds alias functionality to tag path transformations for any property. For example, for the following alias structure:

    Figure 120: Alias function


    the testTag path will be: @testGroup/testTag. Using the alias function allows it to be translated to the original target path.

    // Generic function definition
    =alias(“<alias path>”)
    // Example
    =alias(“@testGroup/testTag”) => /ReadOnlyNumber
    


    Property function

    Just like the tag function, the property() function has been added by WebVision to augment the functionality of expressions. This function is used to obtain the value of a property for a different element to the one that has this expression. For instance, it can be used to change an element width based on the width of another element. This function is implicitly called when linking a property to a different property in another component.

    The syntax of this function is property(PathToElement.pathToProperty). The pathToElement must be a relative path from this element, using ‘..’ to refer to the parent element and separated by backslashes. The pathToProperty uses the internal name of the property, which may be different than the label used in the configuration window. In order to find the internal path, the link property helper can be used.

    The following example creates a rectangle that occupies 10% of the parent container and a label component centered inside the rectangle. It uses the following components (properties are simplified for this example, this is not the real internal structure of the properties):

    Container:{
    	width:1920,
    	height:1080,
    	components: {
    		Rectangle:{
    			x:500,
    			y:450,
    			width:Expression 1,
    			height:100
    		}
    		Label{
    			x:Expression 2,
    			y:Expression 3,
    			width: Expression 4,
    			height: Expression 5
    }
    


    With this structure, the following expressions are used (these are valid expressions using the correct internal name of the properties):

    //Expression 1: Width of the rectangle is 10% of the parent container
    =property(../.width)/10 -> 192
    //Expression 2: Width of the label is the same as rectangle
    = property(“../Rectangle.width”) -> 200
    //Expression 2: Height of the label is the same as rectangle
    = property(“../Rectangle.height”) -> 100
    //Expression 3: X position of the label is the same as the rectangle
    = property(“../Rectangle.container.left”) -> 500
    //Expression 4: Y position of the label is the same as the rectangle
    = property(“../Rectangle.container.top”) -> 450
    


    Self function

    The Self() function has the same functionality as the property() function, except it is used in a component to refer to itself. As such, it can be used as an alias of property(“./.property”). The syntax for this function is self(“property”).

    This function can be used in events to obtain the value of this component, especially in input, toggle, or dropdown components.

    See below example. Assuming the following component is used:

    Dropdown:{
    	width:200,
    	height:100,
    	dropdown:{
    		options: Power, Temperature, Speed
    		selectedValue: Temperature	
    }
    }
    


    A custom property is set whenever the dropdown value changes. This means that an action is attached to the value change event, with the following expression as the value that the event sets:

    //Using property
    =property(“./.value”) -> Temperature
    //Using self
    =self(“value”) -> Temperature
    


    Parent function

    The Parent() function has the same functionality as the property() function, except it is used in a component to refer to its parent. As such, it can be used as an alias of property(“../.property”). The syntax for this function is parent(“property”). This function can be used in events to obtain the value of this component.

    See below example. Assuming the following component is used:

    Container:{
    	width:1920,
    	height:1080,
    	components: {
    		Rectangle:{
    			x:Expression 1,
    			y:Expression 2,
    			width:100,
    			height:100
    		}
    
    


    in order to set the rectangle position in the middle of the parent container; x/y values must be set to half of the parent width/height, minus half of the self width/height.

    //Expression 1
    =parent(“width”)/2 – self(“width”)/2
    //Expression 2
    =parent(“height”)/2 – self(“height”)/2
    
    


    Dataset function

    Just like the tag function, the dataset() function has been added by WebVision to augment the functionality of expressions. This function is used to obtain the value of a DataSet element instance, or a manual dataset [[key1,value1],[key2,value2],…,[keyN,valueN]]. For instance, it can be used to populate a Chart series.

    For inputs such as the DataSet input in the Chart series, the input will automatically obtain and use the dataset value. However, for normal inputs such as the example of a Label input in the Label component, a <dataset> placeholder will be displayed. This placeholder represents the dataset object, which has a very similar functionality to a javascript array. It also has a loading property, which allows users to see if the dataset has been loaded or not.

    DataSets can be operated using standard javascript arithmetical, logical, and bitwise operators.

    // Generic function definition
    =dataset(“<dataset path | manual dataset>”)
    // Basic example (using manual dataset syntax for example simplicity)
    = dataset(“[[1,2],[3,4],[5,6]]”) => <dataset> (if used in a dataset property the values will be automatically loaded and used)
    // Join example
    =dataset(“[[1,2],[3,4],[5,6]]”).join(“, ”) => 1,2, 3,4, 5,6
    // plus operation example
    =(dataset([[1,2],[3,4],[5,6]]) + dataset([[1,2],[3,4],[5,6]])).join(“, ”) => 1,4, 3,8, 5,12
    // Zero fill right shift bitwise operator
    =(dataset([[1,2],[3,4],[5,6]]) >>> 2).join(", ") => 1,0, 3,1, 5,1
    


    Func function

    The Func() function allows users to reference a function defined in the Function system folder anywhere in the project. The syntax is the function name and a comma separated list of parameters, which will be passed on to function as an array called argv.

    • For example, if a function is used to multiply every number inside an array by another number, as defined in the following image.

    Figure 121: Func function


    This function is expecting the first parameter inside argv to be the array and the second parameter to be the number. This function can be used by any property in the project:

    // Generic function definition
    =func(“<function name>”, parameter1, parameter2, …parameter)
    //Example, multiply array by number and return multiplied array
    =func(“multiplyArray”, [1,2,3,4], 5) -> [5, 10, 15, 20]
    


    Ui function

    The Ui() function adds an additional functionality for accessing multiple system functionalities and values in expressions, for example data manipulation and user information. See below for example possibilities:

    // Generic function definition
    =ui(“<functionality>”)
    // Current timestamp in milliseconds
    =ui(“time”) => 1604664222188
    // Current date with “<Year-month-day hour:minute:second format>”
    =ui(“timestr”) => 2020-11-06 12:04:04
    // Offset from GMT in millisenconds
    =ui(“timeoffset”) => 25200000
    // Offset from GMT in text format
    =ui(“timeoffsetstr”) => GMT-07:00
    // Currently selected timezone in text format
    =ui(“timezone”) => America/Phoenix
    // WebVision viewport width
    =ui(“width”) => 1920
    // WebVision viewport height
    =ui(“height”) => 1080
    // User name
    =ui(“user.name”) => admin
    // Returns true of false depending if the user has writing permission
    =ui(“user.writePermission”) => true
    


    Sprintf function

    Allows values to be formatted using formatters, as specified in the Sprintf format specification appendix. This function accepts a format string and a value as parameters and returns the formatted value.

    // Generic function definition
    =sprintf(“<format string”, <Value1>, <Value2>, …, <ValueN>) => <Formatted value>
    // float decimals specification
    =sprint(“%.1f”, 50.522) => 50.5
    // Modify parameters order
    =sprintf(“%2$s %3$s a %1$s”, “cracker”, “Polly”, “wants”) => Polly wants a cracker
    // Add positive/negative sign
    =sprintf(“%+.1f”, -54.4) => -54.4
    =sprintf(“%+.1f”, 54.4) => +54.4
    // Add padding character
    =sprintf(“%'.09d”, 54) => .......54
    // Exponential formatting
    =sprintf(“%.3e”, 54000000) => 5.400e+7
    

    Moment function

    The Moment function enables direct access to moment.js, allowing for advanced date manipulation and adding multiple additional helpers for date manipulation. More information about the Moment functionality can be found on the moment.js docs page. The Moment date format specification can be found in the Timestamp formatting appendix.

    // Generic function definition
    =moment(<optional date>)
    // Initialize moment with custom Date object
    =moment(new Date()) => Fri Nov 06 2020 13:19:56 GMT+0100
    // Initialize moment with custom timestamp
    =moment(Date.now()) => Fri Nov 06 2020 13:19:56 GMT+0100
    // Initialize moment with date string
    =moment(“2019-Feb-01 00:00:00”) => Fri Feb 01 2019 00:00:00 GMT+0100
    // Date formatting as readable string
    =moment(Date.now()).format(“YYYY-MM”) => 2020-11
    



    Was this article helpful?

    What's Next