Write JavaScript
Last updated
Last updated
This action executes javascript code on a website.
getRef()
and setRef()
Use a reference from a variable or a table:
Save a value to a variable or a table:
ref_id
and where to find it?ref_id
corresponds to the table id or variables id. In ZeroWork, tables and variables are considered data groups. Each data group has its own id (which is ref_id
), so ref_id
corresponds to the whole table id or to all variables. The individual columns and individual variables are uniquely identified by name.
Table ids can be found on the left sidebar:
Variables id (ref_id) can be found in the variables dialog:
Before moving on to examples, beware that getting table content adheres to ZeroWork dynamic loop behavior, as described below: #saving-or-getting-data-within-loops.
Using browser in-built functions:
Making a fetch request, which returns an array and saving a value from the first item to a variable:
getRef()
and setRef()
Both getRef()
and setRef()
are executed asynchronously. Make sure to wait for response, for example, by using await
. Otherwise the code will continue executing without waiting for response.
❌ Won't work
✅ Works
Variable and column names are case-sensitive. For example, if the column in your table is named "Profile Name" and you reference to it in lower case, you will get an error.
❌ Won't work
✅ Works
Ensure to use correct data types. ref_id
is expected to be number or string; name
and value
are expected to be strings.
❌ Won't work
✅ Works
✅ Also works
setRef()
Whenever you use setRef()
, the value is stringified when it's saved. If the value is, for example, array or object and you need to access it later when calling getRef()
, you need to parse it first to json. See example below.
Assume you need to access the first item's object from the array saved to the variable "animals":
❌ Won't work
✅ Works
getRef()
and setRef()
getRef()
and setRef()
adhere to ZeroWork in-built loop logic. For example, in order to access value from a table, you need to place Start Repeat building block with dynamic loop type before the Write JavaScript building block.
If you want to append data to a table, you need to place Start Repeat building block with standard loop type before the Write JavaScript building block.
You can append rows within a custom loop in your code block by providing an argument for appendIndex
.
Beware:
appendIndex
refers to the row number that should be appended. appendIndex: 0
means the first row to be appended. If there are already 3 rows in the table, it will be appended as 4th.
When using appendIndex
, avoid placing Write JavaScript building block inside any ZeroWork in-built loop (by this, Start Repeat building block is meant) - whether nested or not! Otherwise the row indices might get mixed up between ZeroWork in-built loop logic and your custom loop logic, and you might end up with mismatched data.
With that in mind, here is an example of how you can make this scenario work:
And here is the end result:
Copy and try yourself:
Custom looping through existing rows of a table within your code block in order to update data (as opposed to append) is currently not supported. However, in most use cases, adding dynamic loop with Start Repeat is enough to enable this use case. Please let us know if you want this feature to be implemented in our Discord server (#ideas-features-suggestions) while providing an example what you would need it for.
log()
You can define your own log messages by using the function log
.
Will be shown in your logs like so:
You can include status
parameter, which is optional and accepts "success"
or "fail".
The default is "success". Must be either "fail"
or "success"
.
Will be shown in your logs highlighted in red:
You can include tag
argument, which is optional and makes your log message appear with a labeled tag in your logs. Must be string.
Will be shown in your logs with a tag on the right:
ZeroWork in-built error handling behavior will not always apply to your custom code. For example, if you use building block Click Web Element and the selector is not found, normally you will get an error that selector could not be found (after the corresponding timeout) in your logs and the TaskBot run will be interrupted. However, because browser console treats not found selectors differently (by simply returning null
), your TaskBot will continue its run despite the error.
❌ Not recommended
✅ Better
You can use custom error handling including custom try-catch logic and define custom behavior on error as well as your own custom error messages. Your custom error messages will be reflected in the logs and error reports. Consider the example below:
This is how your custom error message in the logs and error reports will appear:
Here is another example with your own custom try-catch logic:
delay()
The custom delay()
method allows you to pause the execution of JavaScript code for a specified duration.
How It Works:
min
: The minimum duration for the delay in milliseconds (required). Must be number.
max
: The maximum duration for the delay in milliseconds (optional). Must be number. If provided, the actual delay duration will be randomized between min
and max
.
If max
is not specified, the delay will last exactly min
milliseconds.
If max
is less than min
, the delay will default to min
milliseconds.
This option allows the JavaScript code to execute directly in the ZeroWork agent application, bypassing the browser. By running locally, you gain access to additional system features and tools that are not available in the browser environment.
Access to Playwright
pw
: Full access to the Playwright library.
Example:
Access to node.js file system
fs
: Node.js file system operations.
Example:
Access to axios
axios
: HTTP requests using the Axios library.
Example:
Access to the active page
activePage
: Access the current active browser page.
This refers to the page your TaskBot is using during its run.
It is designed to combine no-code and code actions. For example, you might initiate a new page with the Open Link building block, perform some actions with some other building blocks, and then use custom Playwright code for advanced actions.
Notes:
The activePage
is a Playwright Page
object. Any methods described in the Playwright Page class documentation are applicable.
If no page exists (e.g., because it was not initiated with Open Link or was closed with the Switch or Close Tab building block), activePage
will be null
.
Examples:
Performing actions not available in ZeroWork:
Adding event listeners:
Access to the active context
taskbotContext
: Access the current active browser context.
This allows integration of code and no-code actions at the context level. A context is one level above a page.
Notes:
The taskbotContext
is a Playwright BrowserContext
object. Any methods described in the Playwright BrowserContext class documentation are applicable.
If no browser exists (e.g., because it was not initiated with Open Link or was closed with the Switch or Close Tab building block), taskbotContext
will be null
.
Examples:
Getting all pages:
Programmatically adding cookies:
Output from console.log()
will not appear in the browser console since the code runs directly in the ZeroWork application. Tip: Use await log({ message })
to log messages in the TaskBot Run Reports and running logs.
getRef()
You might be used to inserting references directly from the dialog options. By this, we are referring to these options:
You can continue using these options. However, there are two caveats:
The values are replaced before the code is executed. If you need dynamic getting and setting behavior within your code, you need to use getRef()
and setRef()
.
Beware to not change the way references are pasted when using these options - for example, when using these in-built options, the name is not a string. This is intended and not to be confused with the arguments used in getRef()
.