Customizing your application using widgets
The Genero Browser Client (GBC) comes with built-in widgets that define the user interface. If a built-in widget does not meet your needs, you can extend the widget.
You usually start with an existing widget (such as the EditWidget
or
ButtonWidget
) and extend its functionality. For example, you might want to include
a custom color picker. You could start with the ButtonWidget
and add code to
display a color wheel that allows user selection.
To create or extend GBC widgets, you require some knowledge of JavaScript.
Required files
- A JavaScript (.js) file managing the widget creation, behavior, and listeners.
- A template HTML (.tpl.html) file containing the HTML
code structure of the widget. The template file determines whether your
widget is:
- A simple widget, which defines elements that implement basic
functions; for example, an
EditWidget
orLabelWidget
. - A container widget, which provides a placeholder for child widgets;
for example, a
MenuWidget
.
- A simple widget, which defines elements that implement basic
functions; for example, an
- A sass (.scss) file that serves as the widget's style sheet.
Some widgets require a library. The library must be in the customization directory under resources/lib/, and must be referenced by the config.json file.
Be careful when adding libraries to the GBC. If the library has access to GBC context, it might behave in an unexpected way. If the library is not optimized, it might cause performances issues.
Resources, such as images, may also be included with the widget.
Source files
You can explore the source files to familiarize yourself with how the front-end is implemented. The source files for the built-in widgets of the default GBC are found in the gbc-project-dir/src directory.
Do not modify the original source widget files.