The fglrichtext web component
The fglrichtext
built-in web component implements an HTML text
editor.
The fglrichtext
built-in web component uses the gICAPI web component framework.
HTML content in the fglrichtext
web component
The fglrichtext web component generates standard HTML, without any "flavour" based on external library or CSS. Therefore, depending HTML rendering engine, the visual result might be slightly different.
For example, when using the fglrichtext web component to create a blog post, you want the blog theme to be used to display this post, and not something completely out of the theme.
Thus, fglrichtext generates as "abstract" HTML as possible (without any decoration), to apply different CSS styles afterwards.
Using images in rich text content
The fglrichtext web component allows insertion of image resources into the text. This can be done
with the image
option of the toolbar, by copy/paste, or drag&drop
operations.
When inserting an image resource from the local platform (for example, with the
image
option of the toolbar), the complete image content will be inserted as a
base64 encoded object in the text.
Inserting huge base64 encoded image data can lead to performance issues.
When inserting an image resource from a copy/paste from a web resource (like an HTML page), only the URL of the image resource is inserted in the text. If this URL is no longer available, the image will disappear from the text.
Defining the fglrichtext
web component in the form file
In your .per form definition file, define the HTML text editor as a WEBCOMPONENT
form
item with the COMPONENTTYPE
attribute set to the "fglrichtext"
value.
The fglrichtext
web component provides its own built-in scrollbars. Therefore,
the SCROLLBARS
attribute
can be set to NONE
.
Use SIZEPOLICY=FIXED
and
STRETCH=BOTH
, to get a text
editor that is resized with the parent window.
For example:
LAYOUT
GRID
{
[rt ]
[ ]
[ ]
...
ATTRIBUTES
WEBCOMPONENT rt = FORMONLY.richtext,
COMPONENTTYPE = "fglrichtext",
PROPERTIES = (
toolbar = "bold|italic|underline|undo|redo"
),
SCROLLBARS = NONE,
SIZEPOLICY = FIXED,
STRETCH = BOTH;
...
Properties of the fglrichtext
PROPERTIES
:
toolbar
: Defines the toolbar elements layout.autoflush
/autoflush_interval
: Defines an action and timer for auto flushing the value.spellcheck
: Defines the spell checking in the fglrichtext.noteditable
: Defines id the fglrichtext is read-only.- Properties to define the default font:
font_family
: Defines the default font family.font_size
: Defines the default font size.
- Properties to localize fglrichtext labels:
labels_toolbar_tooltips
: Defines the texts to be displayed for toolbar tooltips.labels_toolbar_link
: Defines the labels to be displayed for the link popup dialog.labels_toolbar_linespacing
: Defines the texts for line spacing options.labels_toolbar_formatselect
: Defines the texts to be format options.
Configuring the toolbar
Define the controls to be used in the editor toolbar with the toolbar
property
in the PROPERTIES
attribute.
WEBCOMPONENT rt = FORMONLY.richtext,
...
PROPERTIES = (
toolbar = "bold|italic|underline|undo|redo|emoji"
),
...
The fglrichtext web component supports the following toolbar
items:
Option name | Description |
---|---|
aligncenter |
Centers the current block or image. |
alignjustify |
Justifies the current block or image. |
alignleft |
Left aligns the current block or image. |
alignnone |
Removes the alignment of the current block or image and left aligns it. |
alignright |
Right aligns the current block or image. |
bold |
Applies the bold format to the current selection. |
bullist |
Formats the current selection as a bullet list. |
color |
Applies text color to selection. This opens a color picker pop-up, allowing you to choose text and/or background color. |
emoji |
Opens a picker for selecting an emoji to insert into the field. Important: Emoji are not simple images, they are Unicode characters. They may look different depending on the display device, and may not be supported on some systems. If your device does not handle emoji, you may need to install fonts that handle emoji characters. |
fontselect |
Dropdown list with font families to apply to selection. |
fontsizeselect |
Dropdown list with font sizes to apply to selection. |
formatselect |
Dropdown list with block formats to apply to selection. |
indent |
Indents the current list item or block element. |
image |
Inserts an image resource found on the local platform. |
insert |
Create and delete links. |
italic |
Applies the italic format to the current selection. |
linespacing |
Defines the line spacing of a selected text. |
numlist |
Formats the current selection as a numbered list. |
outdent |
Outdents the current list item or block element. |
redo |
Redoes the last undo operation. |
removeformat |
Removes the formatting from the current selection. |
strikethrough |
Applies strike though format to the current selection. |
underline |
Applies the underline format to the current selection. |
undo |
Undoes the last operation. |
Using the spell checker
fglrichtext
web component can be configured for spell checking with the
spellcheck
property of the PROPERTIES
attribute:WEBCOMPONENT rt = FORMONLY.richtext,
...
PROPERTIES = (
spellcheck = "browser"
),
...
spellcheck
property can be set to the following values:
"browser"
(default): This will enable the intrinsic spell checking of the browser."none"
: No spell checking is required for this rich text field.
Auto-flushing the rich text content
By default, the text value of an fglrichtext
field is only flushed to the
runtime system, when focus leaves the field or when firing an action.
autoflush
property of the PROPERTIES
attribute allows you to define a user action to be fired every
autoflush_interval
seconds, when the text is changed. The default for
autoflush_interval
is 10 seconds.When the user enters text, the
autoflush
action will be fired every autoflush_interval
seconds.
After the autoflush
action is sent, if the user does not modify the text, no action
will be fired until the user starts again to type text. This way, the network traffic is
optimized.
WEBCOMPONENT rt = FORMONLY.richtext,
...
PROPERTIES = (
autoflush = "save_text",
autoflush_interval = 5 -- Flush every 5 seconds
),
...
In the program code, implement an ON ACTION
handler using the action name that
matches the autoflush
property of the WEBCOMPONENT
field. When the
action is fired, the rich text will be available in the WEBCOMPONENT
field value.
Use the UNBUFFERED
dialog
mode to have the text automatically copied into the program variable bound to the form field:
INPUT BY NAME rec.richtext, -- Variable bound to the WEBCOMPONENT form field
...
ATTRIBUTES(UNBUFFERED) -- To get the input buffer copied into the variable
...
ON ACTION save_text ATTRIBUTES(DEFAULTVIEW = NO)
UPDATE ord_info SET oi_comment = rec.richtext
WHERE oi_pkey = curr_pkey
...
Auto-flush can for example be used to implement automatic backup of the text content.
Defining the rich text field as read-only
TEXTEDIT
NOTEDITABLE
attribute, it is possible to make the
fglrichtext
web component read-only, by defining the noteditable
property:WEBCOMPONENT rt = FORMONLY.richtext,
...
PROPERTIES = (
noteditable = true
),
...
Specifying the default font
fglrichtext
web component by
using the following properties:
Property name | Values |
---|---|
font_family |
Monospace, Sans serif, Serif, Roboto |
font_size |
nnnpx |
WEBCOMPONENT rt = FORMONLY.richtext,
...
PROPERTIES = (
font_family = "Monospace",
font_size = "25px"
),
...
The font_size
defines the px
unit, otherwise, the property will
be ignored.
If the toolbar items fontselect
/ fontsizeselect
are used, they
will display the font family and font size defined by the properties, when the
fglrichtext
initializes.
If the user moves the edit cursor to a text element that uses a different font to the one specified with these attributes, the richtext will reset the current font settings to match that text element.
Localizing rich text component strings
The toolbar button tooltips, combobox items, and popup dialog labels of the fglrichtext
web component can be localized with dedicated properties.
Consider using localized strings to define the texts in external string ressource files.
label-localization-property = '{ "item-name" : "item-label" [
,...]
}'
Property name | Items/Keys |
---|---|
labels_toolbar_tooltips |
"aligncenter", "alignjustify", "alignleft", "alignnone", "alignright", "bold",
"bullist", "color", "backgroundcolor", "emoji", "fontselect", "fontsizeselect", "formatselect",
"title", "image", "indent", "insert", "numlist", "outdent", "redo", "removeformat",
"strikethrough", "underline", "undo", "linespacing" |
labels_toolbar_link |
"save", "label", "edit", "visit", "remove" |
labels_toolbar_linespacing |
"small", "normal", "large", "huge" |
labels_toolbar_formatselect |
"heading", "normal" |
For combobox items like with labels_toolbar_linespacing
, the item/key
names must be specified in lowercase ( "small":"Petit"
, not
"Small":"Petit"
)
For example (not using localized strings):
WEBCOMPONENT rt = FORMONLY.richtext,
...
PROPERTIES = (
labels_toolbar_tooltips = '{ "aligncenter":"Centré", "alignjustify":"Justifié" }',
labels_toolbar_link = '{"save":"OK","label":"Entrez un lien:"}',
labels_toolbar_linespacing = '{"small":"Petit","normal":"Normal","large":"Grand" }',
labels_toolbar_formatselect = '{"heading":"Titre","normal":"Normal"}'
),
...
labels_toolbar_tooltips = %"rtlabels.toolbar.tooltips"
rtlabels.toolbar.tooltips = '{ "aligncenter":"Centré", "alignjustify":"Justifié" }'