Action Workflow Elements
Convert documents (action/convert
)
Options
Name | Type | Description |
---|---|---|
value | ContextExpression, String | Raw Data to be converted. |
file | boolean: false | If the returned file should be saved as a file |
parse | boolean: false | Fix LateX variables if converting to LateX |
from | String | The initial format of the Data |
to | String | The Format to which the Data will be converted |
filters | (String) Array (table, heading_to_toc) | Names of the LateX filters to apply when converting directly to Latex |
assets | ContextExpression, (Asset Object) Array | Assets to download and serve to the conversion process |
Asset Object Structure
You can serve Assets either with an (unprotected) URL or Base64 encoded.
Name | Type | Description |
---|---|---|
name | String | Filename |
url | String | Public Url that serves the file. Either http or https |
data | Base64 String | Raw Data of the asset in Base64 format |
Setting values in the client (action/set
)
Tells the client via a Webhook response to set some internal values. Usually, the object being set on the client side are fields in a resource create or edit view. Useful for dynamically filling fields based on other fields or based on data that is only available in backend.
Inputs
Port | Type | Description |
---|---|---|
default | Resource|Resource[] | The resource to use for base variables. |
Outputs
Port | Type | Description |
---|---|---|
default | Forward | Same output as input. Data is not changed. |
Options
Name | Type | Description |
---|---|---|
values | Dict[ContextExpression, String] | Mapping from a JSONPath-selector to a recipe. Variables available in the recipe are context and input resource. |
hidden | Dict[ContextExpression, String] | Mapping from a JSONPath-selector to a (boolean) recipe. Variables available in the recipe are context and input resource. |
options | ContextExpression | Selector of the (multi)select fields whose available options should change. The default port is used for the new options. Example: positions[*].warehouse to indicate all warehouse select fields in the positions list. |
Response
Webhook-JSON of type set
.
Example (1)
client_street
and client_discount
are fields present in the default-input resource. The keys are JSONPath selectors. shipping_street
refers to the key with the same name in the client’s object that is to be set. positions[*].discount
is a JSONPath selecting all discount
fields of all entries in the positions
array.
Example (2) – Full Workflow
Graph view
Note that the on_change
-Event gives three inputs into the workflow. default
/prototype
(the current values of the resource frontend at time of the event), original
(resource in edit mode, empty in create mode), and selector
(the JSONPath of the parent of the field that fired the event). In this case, if the event was fired at the top-most level, the selector would be ”$” and hence change the root “email” field of the resource. If the event was fired in a list field, the selector could look like “$.mylist[2]”, and the email field of this list item would be changed instead.
In this case, we expect the selector to describe a list item, so we first select only the list item with the op/selector
element. In the “Set”-element, we would then set the field $.mylist[2].email
to the email of the user field in the previously selected list item. This example therefore shows
- how we can select sub-fields based on the event emitter (in
op/selector
) - how we can tell the client what fields we want to set with which values.
Adding an event emitter to a field
We have to set the “events” option, and in there set the “on_change” value to a list of event identifiers.
action/buildSite
The action/buildSite
element builds static sites using different strategies, depending on the site builder driver used.
Options
Driver (driver
) [string
]
Currently, page-depot
is the only supported driver for building static sites.
Template (template
) [Entity
]
Entity with the capability SiteBuilderTemplate
.
Pages Module (pages_module
) [string
] (optional)
Module identifier to request the pages. Used by the PageDepot driver.
Sections Module (sections_module
) [string
] (optional)
Module identifier to request available sections. Used by the PageDepot driver.
Pages Filter (pages_filter
) [array
] (optional)
Brezel filter array for the request to page entities. Used by the PageDepot driver.
Drivers
The default driver is page-depot
.
PageDepot (page-depot
)
The PageDepot driver communicates with the external PageDepot service.
Capabilities
SiteBuilderTemplate
Defines a basic template for the site builder.
Field | Type | Description |
---|---|---|
name | Text | A unique identifier for the template. |
views | Multiselect | View entities with code. |
PageDepotTemplate
Defines a template for web pages specific to the PageDepot service. This capability is a part of the implementation logic behind the scenes.
Field | Type | Description |
---|---|---|
name | Text | A unique identifier for the template. |
base | Text | A reference to the base layout for the template. |
PageDepotLayout
Defines the general layout of a web page. This includes how sections, slots, and scripts should be arranged.
Field | Type | Description |
---|---|---|
name | Text | A unique identifier for the layout. |
base | Text | A reference to the base layout. |
scripts | Code | Code snippets written in JavaScript to enhance the page functionality. |
slots | List | A list of slots that are sub-parts of a layout. |
The ‘slots’ field holds a list of slot objects. Each ‘slot’ defines a specific area on the page where sections can be inserted. Within a layout, different slots can be defined to include different sections of the page.
Each slot object contains the following sub-fields:
Field | Type | Description |
---|---|---|
slot | Text | A unique identifier for the slot. |
sections | List | A list of sections that are inserted into this slot. |
Under a section, following sub-fields are present:
Field | Type | Description |
---|---|---|
section | Select | The name of the section that is added to the slot. It selects from the available ‘sections’. |
params | Map | A map of parameters used within the section. |
subslots | Json | A JSON object denoting any subsections within the main section. |
provide_slot | Text | The name of the slot that this section provides for nesting additional sections. |
By arranging and configuring different slots and sections within each slot, you can create complex yet easily manageable page layouts. The actual contents of the sections and their respective parameters can be customized as per needs and are not defined in the PageDepotLayoutCapability. They would fall within other capabilities, such as PageDepotSectionCapability.
PageDepotPage
Defines a structure for a single webpage. It gives details about how the title, description, layout, script, etc. should be formed.
Field | Type | Description |
---|---|---|
name | Text | A unique identifier for the page. |
title | Text | The name shown on the tab of the browser. |
dynamic_title | Code | A dynamic title that changes according to some conditions. |
layout | Select | The layout type in which the page should be presented. |
description | Textarea | A brief description of the page. |
scripts | Code | Code snippets written in JavaScript to enhance the page functionality. |
slots | List | A list of slots that are sub-parts of the page. |
PageDepotSection
Defines a section - a subset of the layout. Its purpose is to bring in variants in the layout.
Field | Type | Description |
---|---|---|
name | Text | A unique identifier for the section. |
type | Select | The type of the section. It can either be Astro or Vue. |
vars | Map | A map related to the functioning of the section. |
code | Code | Code that defines the functionalities of the section. |
action/deploySite
The action/deploySite
element deploys static sites built by action/buildSite
.
Inputs
- Default (
default
): a stored site, output byaction/buildSite
Options
Deployer (deployer
) [string
]
Currently, page-depot
is the only supported driver for deploying static sites.
Hostnames (hostnames
) [array<string>
]
List of hostnames the site should be available under. Used by the PageDepot driver.
Deployers
The default driver is page-depot
.
PageDepot (page-depot
)
The PageDepot driver communicates with the external PageDepot service.
Running another workflow (action/run
)
Runs another Workflow. This can be either sync or async.
If New Scope
is set to false the context will not change. This means all Variables will be accessible.
If New Scope
is set to true a new context will be created for the action/run. Variables kann be passed to the new Context. These are set on the context not passed via the Workflowflow. This means that they are normally accessible. The output will be the output of the last Element of the executed Workflow.
The old context will automatically be restored one the action/run
is done.
Notify (action/notify
)
Sends a notification to the notification center and over Web push, if available.
Options
Below are the available options for creating notifications:
-
recipients
: Specifies the recipient of the notification, which can be a user, a list of users, a role slug, or a list of role slugs. If this field is omitted, the notification will be sent to the current user. If set tonull
in recipe mode, the notification will not be sent to anyone. -
title
: Specify the title of the notification. -
message
: The message of the notification. -
entity
: Append an entity, such as aFile
entity, to the notification using this field. -
type
: The type of notification, which can be one ofinfo
,warning
, orerror
. -
icon
: The icon to be displayed in the notification. You can provide an absolute URL or a virtual path pointing to a Brezel file (e.g.,/static/icon.png
). If you use a virtual path, a permanent public absolute URL to the file will be generated, containing a share token. If you are in recipe mode, you can also use a file entity, with the same sharing behavior as the virtual path. -
image
: The image to be displayed in the notification. You can provide an absolute URL, a virtual path, or a file entity. -
actions
: Provide a list of action buttons to display in the notification. You can provide a tokenized list of action names (e.g., “Accept
,Deny
”), an array of action identifiers (in recipe mode), or an array of action dictionaries (in recipe mode), where each dictionary specifies the action button properties.
Outputs
action
: fired when the user clicks on an action, with the selected action identifier as the data.