- Introduction
- Installation
- Usage: bzBond web project manager
- Usage: bzBondRelay script
bzBond-claris is the part of the bzBond toolset that handles web code integration, storage, deployment and debugging. It contains
- The
bzBondRelay
script for managing communication between web viewers/JavaScript and Claris/FileMaker scripts. - The bzBond Web Project Manager for storing, deploying, configuring, and debugging web code for use in Claris/FileMaker web viewers.
- Download or clone the bzBond repo
- Unzip the repo if it was downloaded rather than cloned
- Copy the contents of the bzBond-addOn folder to the FileMaker Add-on folder:
- macOS:
~/Library/Application Support/FileMaker/Extensions/AddonModules
- Windows:
Users\<YOUR_USERNAME>\AppData\Local\FileMaker\Extensions\AddonModules
- In your target Claris/FileMaker file go into layout mode on any layout
- In the left panel click the
Add-ons
tab - Click the + icon and select bzBond-claris. It will be under the
Web
heading.
-
Download the bzBond-claris.fmp12 source file.
-
Copy the
WEB_PROJECT
table into the target file -
Create a layout in the target file to contain the web project manager with the following spec:
- LayoutName:
bzBond Web Project Manager
Width: 800px
Height: 610px
- Minimalist theme
- Body part only
- Show records from: WEB_PROJECT
- Create a layout in the target file to contain the default bzBond web viewer with the following spec:
- LayoutName:
bzBond Default Web Viewer
Width: 320px
Height: 460px
- Minimalist theme
- Body part only
- Show records from: WEB_PROJECT
-
Import or copy the
bzBond
script folder into the target file -
Copy the objects from the
bzBond Web Project Manager
layout into thebzBond Web Project Manager
layout created in step 3 -
Copy the objects from the
bzBond Default Web Viewer
layout into thebzBond Default Web Viewer
layout created in step 4
The bzBond web project manager is used for storing, deploying, configuring, and debugging web code for use in Claris/FileMaker web viewers.
The bzBond web project manager is opinionated in that it supports integrating web technologies in a specific way. Below are the key design choices and the reasoning behind them.
- Web code is stored as data in a Claris/FileMaker table. Code stored in this table is called a "web project". Storing web projects in a table has the following advantages:
- It keeps them organized and increases their visibility in a solution.
- It allows them to be updated via scripts or the Data API, meaning they can be part of a build chain or continuous delivery approach.
- It enables the debugging features that support "live development" for web projects.
- Web projects are stored in a single html file. This allows them to be deployed in web viewers as data urls.
- Web projects are deployed in web viewers using Claris/FileMaker scripts. This allows close control over how and when web viewers are populated and helps avoid timing issues.
- Web viewer "config" is used to determine which web project is deployed in a web viewer. Config can also be used to store useful supporting data such as value lists or script names. Leveraging config allows web projects to contain fewer hard-coded and context specific references, meaning they are more likely to be reusable within and between solutions.
- Config is defined in the web viewer calculation dialog. This allows web viewers to be added to layouts and configured without leaving the Manage Layout UI.
bzBond web projects are self-contained single html files, sometimes called "inline" files because all of the CSS, JavaScript and HTML code is contained "inline" in the file rather than split into separate files.
While it is possible to manually craft single-file web projects it is usually not the best approach when external code libraries are required. Instead, web projects are authored as multi-file projects and then "complied" into single files as part of an automated build process.
The bzBond toolset includes a bootstrapping command for quickly creating new bzBond web projects that include a build process. Providing git and node/npm are installed it can be directly invoked from Terminal or PowerShell with the following command:
npx -y @beezwax/create-bzbond-app <your_web_project_name_here> --web-only
e.g.
npx -y @beezwax/create-bzbond-app my-web-project --web-only
For more details see the create-bzbond-app documentation.
The simplest way to store a web project in the web project manager is copy-and-paste:
- Run the build process for your web project
- Copy the resulting html file contents to the clipboard
- In Claris/FileMaker Pro go to the solution's
bzBond Web Project Manager
layout - Press the "Add Web Project" button in the bottom right of the screen (or use the
New Record
command) - Enter the name of the web project in
Web Project Name
field - Paste the html file contents into the
Source Code
field
Another method is to populate source code via a local or remote url:
- Enter a url that uses the
http
,https
, orfile
protocol in theURL
field - To update the web project source code from the url, click the download button on the right of the field.
To link a web viewer to a web project:
- Enter the following calculation in the web viewer calculation dialog.
Let (
$$_BZBOND__WEB_VIEWER_CONFIG =
JSONSetElement (
$$_BZBOND__WEB_VIEWER_CONFIG;
Get ( LayoutName )
& "."
& "<web_viewer_name>";
JSONSetElement (
"{}";
[
"webProject";
"<web_project_name>"
JSONString
]
);
JSONObject
);
""
)
- Replace the "<web_viewer_name>" placeholder with the name of the web viewer
- Replace the "<web_project_name>" placeholder with the name of the web project to deploy in the web viewer. Make sure it matches the name in the web project manager.
- To deploy the web project in the web viewer call the the script
bzBond Load Web Viewer
with the webViewer parameter set to the web viewer name:{ "webViewer": "<web_viewer_name>"}
webViewer
- Type: string
- Value: the name of the web viewer to load
- Notes:
- Required
waitForLoad
- Type: boolean
- Value: if
true
the script stack does not continue until thebzBond
object is availale in the web viewer - Notes:
- Default:
false
- Setting this parameter to true solves timing issues that can occur due to web viewers running on a separate thread to the Claris/FileMaker script engine. In particular, if a script stack starts on a different layout to the one containing the web viewer then setting the
waitForLoad
parameter totrue
is recommended.
- Default:
waitForConfig
- Type: boolean
- Value: if true the script stack does not continue until the
$config
variable has been set. - Notes:
- Default:
false
- Setting this parameter to true solves timing issues that can occur due to web viewers running on a separate thread to the Cl;Claris/FileMaker script engine. In particular, if a script stack starts on a different layout to the one containing the web viewer then setting the
waitForConfig
parameter totrue
is recommended.
- Default:
clearCache
- Type: boolean
- Value: if
true
the cached code of the web project is reset to value in the web project manager. - Notes:
- Default: false
- This is to handle cases where a web project or web viewer has been loaded and then the web project code has subsequently been modified.
noCache
- Type: boolean
- Value: if
true
the cached code of the web project is ignored and the web project code is retrieved from the web project manager. - Notes:
- Default:
false
- This is mostly used in development where the web project is being frequently updated in the web project manager and the latest latest version is always required.
- Default:
goToWebViewer
- Type: boolean
- Value: if
true
the web viewer will be made the active object after it is loaded. This is useful for layout where focus should be immediately on the web viewer, for example in a data entry form. - Notes:
- Default:
true
- This is mostly used in development where the web project is being frequently updated in the web project manager and the latest latest version is always required.
- Default:
To load all web viewers on a layout rather than specifying them by name:
- Go to the layout containing the web viewers
- Run the script
bzBond Load Web Viewers On Current Layout
Note that you can specify the same parameters as for bzBond Load Web Viewer
with the exception of webViewer
. The specified parameters will be applied to all web viewers on the layout.
It is possible to use script triggers to load web viewers as soon as layouts are loaded. The recommended script triggers are
OnLayoutEnter
(Enable for Browse mode only)OnModeEnter
(Enable for Browse mode only)
"Live development" –where code changes can be observed in real time in an application's UI– is in FileMaker's DNA, and it's also a popular approach in web development. bzBond web projects support live development through debug mode, which can be applied at the web project or web viewer level.
- Go to the bzBond Web Project Manager layout and navigate to the target web project
- Click the "Manage Debugging" button in the top right corner
- Click the "Turn on Debugging For This Project" button and enter the url of your dev server, for example
http://localhost:8080
, then press OK.
- Go to the bzBond Web Project Manager layout
- Click the "Manage Debugging" button in the top right corner
- Click the "Debug Web Viewer..." button
- Enter the name of the web viewer and the url of your dev server, for example
http://localhost:8080
, then press OK
All web viewer configuration objects are stored in a global variable named $$_BZBOND__WEB_VIEWER_CONFIG
. The structure is as follows
{
"<layout_name>": {
"<web_viewer_name>": {
// web project name in WEB_PROJECT table
"webProject": "<web_project_name>"
// Other properties:
...
}
}
}
As well as defining the web project to deploy in a web viewer, config can also contain additional information useful to the web project, such as the layout context, script names, and supporting data such as value lists. The config object can be easily accessed from the web project. See the bzBond-js documentation for details.
Below is an example of a web viewer calculation with additional config:
Let (
$$_BZBOND__WEB_VIEWER_CONFIG =
JSONSetElement (
$$_BZBOND__WEB_VIEWER_CONFIG;
Get ( LayoutName )
& "."
& "<web_viewer_name>";
JSONSetElement (
"{}";
[
"webProject";
"<web_project_name>"
JSONString
];
[
"tableContext";
Get ( LayoutTableName )
JSONString
];
[
"valueList";
List (
"value1";
"value2";
"value3"
)
JSONString
]
);
JSONObject
);
""
)
The bzBondRelay
script manages Claris/FileMaker interactions with web code. These interactions are between Claris/FileMaker scripts and web viewers, or Claris/FileMaker scripts and the bzBond-server app.
The majority of these functions are called from bzBond-js and are documented there. The exception is the Perform JavaScript feature, which enables JavaScript functions to be integrated into a regular Claris/FileMaker script flow.
The recommended way to leverage JavaScript functions in Claris/FileMaker scripts is using the "PERFORM_JAVASCRIPT"
mode of the bzBondRelay
script. It allows you to call the bzBondRelay
script with specific parameters and get a result back via Get ( ScriptResult )
, which is a familar pattern. It also works server-side server if you have either the bBox plug-in v0.99+ or bzBond-server microservice framework installed on the server.
The script pattern is
Perform Script [ bzBondRelay; <parameters> ]
Set Variable[ $javaScriptResult; Get ( ScriptResult ) ]
The format of the result is the same as FileMaker Data API:
{
"response": {
"result": <result in correct JSON format>,
"messages": [{
code: "<0 or error code>",
message: "<Ok or error message>"
}]
}
}
The response.result
prop will be appropriately formatted (eg: as a number for numbers, string for strings, object for objects, etc...).
mode
- Type: string
- Value: Always
"PERFORM_JAVASCRIPT"
webViewerName
- Type: string
- Value: the name of the web viewer that will run the JavaScript. The web viewer needs to have bzBond-js installed
- Notes:
- Not required when running on server
- If blank on client, an attempt will be made to run the script on the currently selected object.
function
- Type: string
- Value:
- when running on the client or on server where the
route
parameter is"function"
- a function in the global (window) JavaScript context of the web viewer OR
- a JavaScript function (arrow or classic) defined as a string OR
- when running on server where the
route
parameter is"code"
- JavaScript code to execute
- when running on the client or on server where the
- Notes:
- Use the
Insert Text
script step to define functions or code without having to worry about escaping quotes.
- Use the
parameters
- Type: array
- Value: an array of parameters to pass to the function.
- Passing functions as parameters is supported. Prefix a parameter with the 'ƒ' symbol (⌥ + f on macs) to indicate that it is a function. For example:
[ 40, 2, ƒ(c) => c * 2 ]
- Notes:
- Optional (some JS functions do not need parameters)
- Not required when
route
is"code"
route
- Type: string
- Value:
"function"
or"code"
.- When
"function"
the function defined in thefunction
parameter is executed with the parameters provided in theparameters
parameter - When
"code"
the result of the last statement in thefunction
parameter will be returned
- When
- Notes:
- Not required on client (only functions are supported)
- Defaults to
"function"
on server
useBbox
- Type: boolean
- Value: if bBox plug-in v0.99+ is installed on Claris/FileMaker Server and this parameter is true then the JavaScript code will run using the
bBox_JavaScriptNode
function. - Notes:
- Not applicable on client
- Optional on server.
- Defaults to
false
Simple example
{
"mode": "PERFORM_JAVASCRIPT",
"webViewerName": "JS_Runner",
"function": "(a, b) => a + b",
"parameters": [40, 2]
}
// Result
{
"response": {
"result": 42,
"messages": [{
code: "0",
message: "Ok"
}]
}
}
Function parameter example
{
"mode": "PERFORM_JAVASCRIPT",
"webViewerName": "JS_Runner",
"function": "(a, b, c) => c(a + b)",
"parameters": [40, 2, ƒ(n) => a * 2]
}
// Result
{
"response": {
"result": 84,
"messages": [{
code: "0",
message: "Ok"
}]
}
}
code
route example
{
"mode": "PERFORM_JAVASCRIPT",
"function": "(40 + 2) * 2",
"route": "code"
}
// Result
{
"response": {
"result": 84,
"messages": [{
code: "0",
message: "Ok"
}]
}
}