Syntax
Information about PSBlazor syntax.
PSBlazor is a custom syntax based on Blazor and Razor pages. It is similar to XML or XAML and provides a mechanism to declaratively define a user interface.
Components
Each component is defined with an XML node, such as <Button>
or <Text>
. Each component has its own set of attributes that customize the behavior and look and feel of the widget. Some components support child content and can include nested components.
Defining a Component
To define a component, you will use the PSBlazor code editor to add the component's XML tags. For example, to create a button, you would do the following.
The result is page with a button defined.
Setting Attributes
Every component has attributes available. Within the code editor for the PSBlazor page, attributes will automatically be listed for the current component you are editing.
Setting attributes is the same as setting any XML attribute. This example changes the button to the danger state.
Once you save the tool, it will update the display. With the button in danger state, you'll see it is now red.
Child Content
Some components provide the ability to define child content. You can use the <ChildContent>
node to specify this is the case.
If no other nodes are specified within the child of the component, then it is assumed to be child content. The above can be simplified to this.
Some components provide template attributes that can be set by specifying multiple child content nodes with the appropriate node names. For example, the table can have child content that consists of columns and a title template that defines how the title is displayed. When multiple child nodes are defined, <ChildContent>
is required.
PowerShell
Each PSBlazor tool or component has an associated PSM1 file that contains interactive logic. This logic can interact with modules, invoke scripts in PSU, or update the interface based on data processed by the script.
Event Callbacks
Event callbacks occur when the user interacts with a PSBlazor component. This can include mouse clicks, form submissions or keyboard input. Event callbacks are just PowerShell functions. The following could be used for when a user clicks a button.
Arguments
Most event callbacks provide an object that contains information about the event. For example, mouse events include information like the coordinates of the click. You can access them by providing an $EventArgs
parameter.
Context
Some components are contextual. For example, a table row or a form item. Context values are passed into the event callback with a $Context
parameter.
Variables
Variables can be used to update the PSBlazor components with data from PowerShell. Use the $Variables
dictionary to get and set variables.
Within the PSBlazor syntax, you can reference variables similar to how you would in PowerShell.
You can also use variables in attributes.
Variables can also be complex objects such as PSCustomObject
or Hashtable
. If they have properties, you can reference those in the PSBlazor syntax as well.
Data Binding
Data binding provides a mechanism to update variables without having to call PowerShell script. To define a binding between an attribute on a PSBlazor component, use the bind-{attribute}
syntax.
For example, you could bind to a $test
variable for an input box like this.
In your PowerShell module, you could then access the variable from the $Variables
object.
Life Cycle
Variables are cleared when a user refreshes the page. They are not cached beyond this scope. Each user and tool page will have a different set of variables.
Last updated