Widget Structure
A widget is made up of these files:
File | Required | Description |
---|---|---|
widget.js |
Yes | Holds the widget definition |
widget.png |
Yes | The preview image of the widget in the widgets catalog |
backend.js |
No | A widget backend that allows widget frontend code to use backend services |
widget.css |
No | The CSS file that the widget uses |
widget.html |
No | A widget template file that is relevant only when you write a widget in plain JavaScript with an HTML template |
widget.js.gz |
No | Gzipped version of widget.js |
README.md |
No | A widget help ReadMe file in Markdown format |
Let’s say you want to create a widget my-widget
. You should put your widget.js
file (and optionally backend.js
file) into the src
directory along with any other required files.
In the widget.js
file, you can use import
to include any additional files. You can split the widget into a number of files.
The widget directory structure will look as follows:
-
Development package (only for development)
with source code not bundled
/widgets
/my-widget
/src
widget.js
backend.js // Optional
widget.html // Optional
widget.png
widget.css // Optional
README.md // Optional
-
Output package (zipped can be installed in Conductor Management Console application)
with source code bundled to single file and backend code copied to main folder
/widgets
/my-widget
widget.js
backend.js // Optional
widget.js.gz // Optional
widget.html // Optional
widget.png
widget.css // Optional
README.md // Optional
In the output package (created archive after building), src
directory and its content don’t have to be included.
my-widget/widget.js
is a single JS bundle file created from my-widget/src/widget.js
and contains all the code imported by my-widget/widget.js
.
For real examples of widgets, see cloudify-stage/widgets.
For details about files content check Widget Definition page.
- Documentation
During widget’s development process, each time some widget is created or changed, developers must include above steps (in the same ticket that introduced that new changes) in order to keep both Conductor’s Official Documentation and Stage
up to date.
Note: Widget’s thumbnail image must be inserted/updated directly on Stage
repo.