Scripts Module (How-to Guide) walks you through configuring the Scripts module for custom automation and business logic. You'll create reusable classes, automated tasks, simple expressions, and integrate external libraries using C#, VB.NET, or Python.
ScriptClasses are libraries of reusable methods available throughout your solution.
| Class | Purpose | Domain |
|---|---|---|
| ServerMain | Methods for all server tasks | Server |
| ClientMain | Methods for all client displays | Client |
<ac:structured-macro ac:name="warning"> ac:rich-text-body Important: ScriptClasses with Methods type contain only method definitions - NO class declaration wrapper </ac:rich-text-body> </ac:structured-macro>
csharp
// CORRECT - Methods directly, no class wrapper
public double CalculateEfficiency(double input, double output)
{
if (input == 0) return 0;
return (output / input) * 100;
}
public void LogEvent(string message)
{
@Alarm.AuditTrail.AddCustomMessage(message);
}
public string GetStatus(double value, double limit)
{
return value > limit ? "High" : "Normal";
}ScriptTasks execute code based on triggers or schedules.
| Task | Trigger | Purpose |
|---|---|---|
| ServerStartup | Solution starts | Initialize server resources |
| ServerShutdown | Solution stops | Cleanup operations |
| ClientStartup | Client connects | Setup client environment |
| ClientShutdown | Client disconnects | Client cleanup |
| Trigger Type | Example | Use Case |
|---|---|---|
| Tag Change | @Tag.Temperature | React to value changes |
| Period | 60000 (ms) | Run every minute |
| Condition | @Tag.Level > 100 | Monitor thresholds |
| Startup | Built-in | One-time initialization |
<ac:structured-macro ac:name="warning"> ac:rich-text-body Important: ScriptTasks contain only the method body - NO function declarations or wrappers </ac:rich-text-body> </ac:structured-macro>
csharp
// CORRECT - Code directly, no method wrapper
// Task: MonitorProduction
// Trigger: @Tag.ProductionRun
if (@Tag.ProductionRun == 1)
{
@Tag.StartTime = DateTime.Now;
@Tag.BatchNumber = @Tag.BatchNumber + 1;
// Call class method
@Script.Class.ServerMain.LogEvent("Production Started");
}
else
{
@Tag.EndTime = DateTime.Now;
TimeSpan duration = @Tag.EndTime - @Tag.StartTime;
@Tag.BatchDuration = duration.TotalMinutes;
}Expressions are single-line VB.NET statements for simple operations.
| Property | Description | Example |
|---|---|---|
| Object | Target tag to receive result | Tag.Result |
| Expression | VB.NET calculation/action | Tag.Input1 + Tag.Input2 |
| Execution | When to run | OnChange |
| Domain | Server or Client | Server |
| Trigger | Optional trigger tag | Tag.Calculate |
Expressions Syntax
Expressions use VB.NET / C# syntax and don't require @ symbol for tags, as there is no local .NET. variables declared in the same context.
IIF Method (all parameters evaluated):
vbnet
Tag.Status = IIF(Tag.Value > 100, "High", "Normal")
' Both "High" and "Normal" are evaluatedTIF Method (conditional evaluation - recommended):
vbnet
Tag.Result = TIF(Tag.Mode = 1, Script.Class.ServerMain.Method1(), Script.Class.ServerMain.Method2())
' Only executes Method1() OR Method2(), not bothvbnet
' Mathematical
Tag.Average = (Tag.Value1 + Tag.Value2) / 2
' Conditional
Tag.Alarm = Tag.Temperature > Tag.Setpoint
' Method call
Tag.Efficiency = Script.Class.ServerMain.CalculateEfficiency(Tag.Input, Tag.Output)
' String manipulation
Tag.FullName = Tag.FirstName + " " + Tag.LastName
' Using TIF for conditional execution
Tag.Status = TIF(Tag.Running, "Active", "Stopped")Go to Scripts → References
| Location | Macro | Use For |
|---|---|---|
| ThirdParty folder | _ThirdParty_ | Server-side DLLs |
| WpfControls folder | _WpfControls_ | Client-side controls |
| Solution folder | _SolutionPath_ | Solution-specific DLLs |
csharp
System.Data
System.Linq
MyCustomLibrary
Never add using/import statements directly in code - always use Namespace Declarations dialog
Check script performance:
csharp
// Access in expressions or displays
@Script.Task.MyTask.ExecutionCount // Number of executions
@Script.Task.MyTask.LastCPUTime // Last execution time
@Script.Task.MyTask.State // Running or Idle@ to see all namespaces. after objects for properties| Tool | Action | Purpose |
|---|---|---|
| Format Document | Toolbar button | Auto-format code |
| Comment Out | Toolbar button | Comment selection |
| Uncomment | Toolbar button | Uncomment selection |
| Compile | Save or toolbar | Check for errors |
Common operations via TK namespace:
csharp
// Type conversion
double value = TK.ConvertTo<double>("123.45");
// Tag to DataTable
DataTable dt = TK.TagsToDataTable("Tag.*");
// Dynamic property access
object val = TK.GetObjectValue("Tag.MyTag");Script Not Executing
Compilation Errors
DLL Not Found
Performance Issue
→ Modules / Business Operations / Scripts Module → Tutorials / Business Operations / Scripts Module Tutorial → How-to Guides / I Business Operations / Scripts Module How-to Guide → Technical Reference / Business Operations / Scripts Module ReferenceScripts Module Links
Explanation - to understand concepts
Tutorials - to learn by doing
How-to Guides - to accomplish specific tasks
Reference - technical details