You are reading the documentation for an outdated Corteza release. 2023.9 is the latest stable Corteza release.

Low Code configuration

Corteza provides a powerful Low-Code development platform allowing you to setup your application with ease. Corteza Low Code allows you to extend Corteza and support your business needs.

With Corteza Low Code we define the logical data structure, how the data is displayed, and how it should be visualized. The second part is the automation process, which allows you to implement custom business logic and automate tasks.

If you wish to learn more about a specific topic, refer to the subsections under Low-Code Platform Developer Guide  Low Code configuration.

App configuration

Create a new namespace

A namespace is a container for the configuration and the data specific to an application, such as a CRM. A namespace uses modules to define the data structure, pages to define how the data is displayed, and charts to visualize the data.

A namespace can not directly access data from another namespace. If this is needed, consider implementing this using automation to programmatically define the interaction.

To create a new namespace, navigate to your Corteza instance (for example http://latest.cortezaproject.org/) and click on the Low Code application.

Annotated image

A new screen with a list of all namespaces will appear.

ns create
From there you can:
  • create a new namespace by clicking on the Create new namespace button,

  • edit existing namespaces by clicking on the Edit icon next to the namespace,

  • manage global permissions by clicking on the Permissions button

Click on the Create new namespace button, insert the required parameters, and click on the Save or the Save and close button in the bottom right corner.

ns edit
Table 1. Available namespace parameters:

Name

The namespace name is the human-friendly label that is shown when identifying the namespace. The name should be short and descriptive.

Short name

The short name (slug) is a unique human-friendly system identifier for the namespace that can be used instead of the namespace ID when referencing the namespace.

The short name is usually a variation of the full name that must conform to the following constraints:
  1. start with a character,

  2. contain at most 64 characters,

  3. contain only characters, numbers, _ (underscore), - (dash) or . (dot),

  4. end with a character or a number.

Enable on namespace list

The enabled flag controls if the namespace is enabled and can be accessed. When disabled, the namespace is still visible, but can not be accessed.

Enable on application list

The enabled application flag controls if the namespace should be immediately treated as an application and shown on the app selector.

The namespace logo input allows you to upload a custom logo for the specific namespace. The default logo is the one defined in the theme.

Icon

The namespace icon input allows you to upload a custom icon to use alongside the namespace.

Subtitle

The subtitle is the subtitle of the namespace

Description

The description allows you to provide a more verbose description of the namespace, what it is for, and what kind of data does it contain.

After you’ve created the namespace, you can access it by clicking on the Visit namespace button. At this point, your namespace is empty and doesn’t have any modules, charts, or pages.

ns access ns empty

Creating a new module

A module defines the shape of a record and provides a container for the records, such as an account or a contact. A module uses a series for module fields to define the records' structure and a record page to define how the record is presented to the user.

When configuring a new namespace, you are presented with an onboarding screen from where you can click on the Create Module button to create your first module.

If you wish to add additional modules, or are configuring an already existing namespace, navigate to Admin panel  Modules, and click on the New Module button.

module create
From the module editor screen you can:
  • Edit the module metadata,

  • edit module fields for the given module,

  • edit DAL connection parameters and privacy settings for the given module,

  • configure duplicate detection for the given module,

  • configure record revisions for the given module,

  • manage permissions for the given module by clicking on the Permissions button,

  • manage module field permissions for the given module by clicking on the Field permissions button.

Table 2. Available module parameters:

Name

The module name is a user-friendly label that is shown when identifying the module. The name should be short and descriptive.

Handle

The short name (handle) is a unique user-friendly system identifier that can be used instead of the module ID when referencing the module.

The handle is usually a variation of the full name and therefore must conform to the following constraints:
  1. start with a character,

  2. contain at most 64 characters,

  3. contain only characters, numbers, _ (underscore), - (dash) or . (dot),

  4. end with a character or a number.

Generate synthetic data for a module

Corteza provides a tool to generate synthetic data for a module. You can use it to generate a large amount of data for a module to test the application’s performance or to demonstrate the implementation.

The tool is currently only available in the command line interface (CLI) and supports synthetic data generation for Low Code records (compose records synthetic) and users (users synthetic).

Generated records are flagged with synthetic:true in the record’s meta field, and users will have their handles prefixed with synthetic_ and email domain synthetic.tld.

Usage

Show help for synthetic Low Code record generator:
corteza-server compose records synthetic --help
Generate 10 leads in the crm namespace:
corteza-server compose records synthetic generate --namespace crm --module lead --total 10
Remove all synthetic records in leads module in the crm namespace:
corteza-server compose records synthetic rm --namespace crm --module lead

Creating record pages

A record page defines how the data is presented to the user when viewing, creating and editing records for that module. A record page consists of a series of page blocks that are defined with the page builder.

In case your module does not define a record page, you are not able to create or update its records through the user interface.

You are still able to view its records, create the records using inline record lists, the API, or an automation.

A record page is tied to the specified module, and to the record it is pointing to. This allows you to configure the page blocks to react to the currently viewed record for dynamic resource filtering.

You can utilize page layouts for even more flexibility on how users interact with the data.

The record page can be created directly from the module edit screen by clicking on the Create record page button.

Annotated image

Alternatively, you can create missing record pages from the list of modules by clicking on the Create record page button next to a module.

Annotated image

Creating charts

A chart defines how a specific modules' records are visualized. A chart is bound to your module and allows you to aggregate and transform the data which is then visualized on a chart.

One chart can only show records of one module.

If you’re configuring a new namespace, you are presented with an onboarding screen from where you can click on the Create Chart button to create your first chart.

If you wish to add additional charts or are configuring an already configured namespace, navigate to Admin panel  Charts, then click on the New Chart button.

chart create
Corteza defines three chart categories:

Refer to the chart specific sub-sections for more details

From the chart editor screen you can:
  • Edit the chart metadata,

  • edit the charts' report configuration,

  • edit the charts' visual representation.

Creating list pages

A list page defines how the application is presented to the user when interacting with it. A list page consists of a series of page blocks that are defined with the page builder.

In contrast to record pages, list pages are broader and only bound to the namespace they are on. They are general purpose and used to provide access to different record pages via record lists, dashboards, and other layouts.

When configuring a new namespace, you are presented with an onboarding screen. From there you click on the Build Page button in order to create your first page.

You can utilize page layouts for even more flexibility on how users interact with the data.

If you wish to add additional pages or you are configuring an already configured namespace, navigate to Admin panel  Pages, and click on the New Page button. From there you can click on the Page builder button to enter the page builder

Table 3. Available page parameters:

Page title

The page title is a label that is shown when viewing the page and when displaying the page navigation. The page title should be short and descriptive.

Handle

The short name (handle) is a unique, user-friendly system identifier for the module. It can be used instead of the page ID when referencing the page.

The handle is usually a variation of the title and therefore must conform to the following constraints:
  1. start with a character,

  2. contain at most 64 characters,

  3. contain only characters, numbers, _ (underscore), - (dash) or . (dot),

  4. end with a character or a number.

Structuring the navigation

The page navigation of your application is generated based on your list pages and their position in the page tree. Navigate to the Admin panel  Pages to see your current pages and how they are structured.

To change the order of pages, drag and drop the page to the desired position.

page tree base page tree reorder page tree reorder view

To create a dropdown menu (a sub-page or a nested page), drag and drop the page into another page.

page tree base page tree nest page tree nest view

To always have sub-pages expanded, enable the checkbox under the Other options sub-section.

Annotated image

After enabling the option, sub-pages will be expanded in the public view of Corteza.

Annotated image

Module fields

A module field defines the shape of the modules' records (what parameters will we store), what data type specific parameters are, and additional settings to control how the field should behave. Each module can have multiple module fields.

To edit module fields, navigate to Admin panel  Modules and click on the module you wish to edit. The module fields are listed in the "manage module fields" section, below the module metadata.

Table 4. A detailed breakdown of module fields:

Name

A field name defines how the value is stored internally and what key is used when accessing the value from an automation.

Once a module is populated with at least one record, the name can not be changed.

A field name should be short and descriptive. There is a limit of 64 characters imposed.

A name field must conform tho the following constraints:
  1. start with a character,

  2. contain at most 64 characters,

  3. contain only characters, numbers, _ (underscore), - (dash) or . (dot),

  4. end with a character or a number.

Title

A field title defines what label is used when presenting the field and the value to the user.

The field name should be short, descriptive, and modeled after the field title. If you omit the title, the name is used instead.

Type

A field type defines what type of data the field stores. For example, if we wish to store email addresses of our users, the field type will be Email.

Refer to the Field Type Reference section for more details regarding field types.

Base field settings

Base field settings control the general behavior of the module field. Base field settings are accessible directly under the "Attributes" column of the module field list.

When exporting multi-value fields into the CSV format, only the first value is exported.

Type specific field settings

Type-specific field settings control the behavior of the module field based on the field type.

To access type-specific settings, click on the settings icon next to the field type and navigate to the second tab (the one with the same name as the field type).

Refer to module field type reference for details.

Field expressions

Field expressions allow you to define a formula (calculated) field. When a field defines an expression, the value is updated by the system when the result of the expression changes.

The value of a formula field can not be manually changed.

Click on the settings icon next to the field type and navigate to the "General" tab. Check the "field value expression" checkbox and insert the formula into the new input box.

Refer to the field expressions for more details.

field value expr

Field validation

Value sanitizers allow you to implement custom value sanitization (value transformation) before the value is stored. Value validators allow you to implement custom value validation before it is stored.

Click on the settings icon next to the field type and navigate to the "Validation" tab.

  • Custom sanitizers are run before the built-in sanitizers.

  • Built-in sanitizers can not be disabled.

Refer to the field expressions for more details.

field validation

Chart configuration

Generic chart configuration

Generic charts include:
  • bar charts

  • line charts

  • pie charts

  • doughnut charts

Module

The module specifies the data source (what records to use) for the chart. The chart can only show records of the same namespace that the chart was created in.

Filter

The filter allows you to define what records you wish to show in the chart. For example, you wish to aggregate the leads that you created in the last month.

The dropdown menu provides you with a selection of the most common filters. Click on the "customize filter checkbox" if you wish to modify the selected filter or to write your own. Refer to the QL reference for details regarding filter definition.

Y-axis

The y-axis section allows you to configure the position of the axis (left or right), the label, and minimum, as well as maximum, values.

Dimensions

The dimensions section allows you to specify what field is to be used to plot the dimension; the x-axis.

The current implementation only permits one dimension per chart.

You may only use simple, single-value fields as dimension fields:
  • DateTime

  • Select

  • Number

  • Bool

  • String with rich-text editor disabled.

Field of the DateTime type also allows you to define the grouping function.

Metrics

The metric section allows you to specify what field is to be used to determine each dimension’s value and how it is to be plotted.

You may only use numeric fields as dimension fields. A special count field returns the number of records that match the configuration parameters.

There is a post-processing function input set up; it allows you to transform the generated values by the reporting system. They are written as simple JavaScript expressions that return a single number based on two variables.

  • m: the value of the previous dimension entry (the value is undefined for the first entry)

  • n: the value of the current dimension entry

An example that creates an aggregated chart:
m ? m + n : n

Funnel chart configuration

A funnel chart is constructed from a series of reports where each report may define its dimension and metric. This allows you to piece together reports from different modules, which allows you to visualize the data between multiple modules.

Module

The module specifies the data source (which records to use) for the chart. The chart can only show records of the same namespace that the chart was created in.

Filter

The filter allows you to define what records you wish to show in the chart. For example, you wish to aggregate the leads that you created in the last month.

The dropdown menu provides you with a selection of the most common filters. Click on the "customize filter checkbox" if you wish to modify the selected filter or write your own. Refer to the QL reference for details regarding filter definition.

Dimensions

The dimensions section allows you to specify what field is to be used to plot the dimension.

Only fields of type Select may be used as the dimension field. After you select a field, all of the field options are presented to you. Select which values you wish to show and their order.

Metrics

The metric section allows you to specify what field is to be used to determine each dimension’s value.

You may only use numeric fields as dimension fields. The count field returns the number of records that match the configuration parameters.

Gauge chart configuration

Module

The module specifies the data source (what records to use) for the chart. The chart can only show records of the same namespace that the chart was created in.

Filter

The filter allows you to define what records you wish to show in the chart. For example, you wish to aggregate the leads that you created in the last month.

The dropdown menu provides you with a selection of the most common filters. Click on the "customize filter checkbox" if you wish to modify the selected filter or write your own. Refer to the QL reference for details regarding filter definition.

Dimensions

The dimensions section allows you to specify what field is to be represented on the gauge. Only fields of type Select may be used as the dimension field.

Each dimension has a series of steps that can be added by clicking on the + Add button. Each step defines a label and the maximum value for the step. The colours are defined based on the set colour scheme.

Metrics

The metric section allows you to specify how the value of the gauge is calculated.

You may only use numeric fields as dimension fields. The count field returns the number of records that match the configuration parameters.

There is a special post-processing function input set up; it allows you to transform the generated values by the reporting system. They are written as simple JavaScript expressions that return a single number based on the two variables.

  • m: the value of the previous dimension entry (the value is undefined for the first entry)

  • n: the value of the current dimension entry

An example of a chart that converts the price to be in thousands:
n / 1000

Page builder

If all page blocks are on the same y-axis (one single row), the page will stretch the blocks to fill the entire page. This is useful when creating record or list pages with a single page block that should span the entire page.

page resize config page resize view

The page builder is used to define the pages' structure using page blocks and a drag-and-drop interface. Each page has a grid of 12 columns and is not limited vertically.

page builder empty

Click on the + Add block button to open the page block picker where you can configure and add a new page block. The entire page block reference is available here.

page builder block picker

When you configure and save a page block it is added to the page.

page builder block base

To reposition the page block, simply drag-and-drop it to the desired position.

The page block may be placed anywhere on the x-axis, but its y-axis must connect with another page block or with the top of the page. If the position is not valid, or it overlays with another page block, the page builder may automatically adjust the surrounding page blocks to conform to the constraints.

page builder block base
page builder block repos

To resize the page block, simply grab the arrow in the bottom-right corner and resize to your needs. The page block may not exceed the maximum width of 12 columns. The height is not limited.

page builder block base
page builder block resize

By placing a few extra blocks and changing their layout, you can create interesting home pages and dashboards like the CRM’s.

page builder example

Copying list pages

The option to save a list page as copy allows us to create a new page that contains the same page blocks as another list page. This is very useful because instead of re-adding the same page blocks from another page, they can be copied simply by pressing a button.

Only page lists can be copied. Record pages cannot be saved as copies.

To copy the contents of another list page, navigate to the page itself and click on the Save as copy.

Annotated image

A new page with the same contents will be added to the list of pages. The structure of the new page’s name will be Copy of <name of the page it was copied from> (<number of copies>). For example, if the page that was copied from is called Leads, then the newly created page will be Copy of Leads (1).

Annotated image

Configuring Page Icons

Page icons can be set to list or record pages. This gives us the ability to further customize a page and easily distinguish it from other pages.

To set the page icon, inside your namespace, navigate to the admin panel  pages, and edit the page you wish to set the icon for. Find the page icon section under the page description and click on the edit button.

Annotated image

A modal will open with two sub-sections: Upload icon and Or add link to icon.

Annotated image

The currently supported icon format is .icon. Svg image format isn’t supported yet.

In the Upload icon sub-section you can drag and drop or click on the button and choose an icon. The uploaded icon can be previewed in the list of icons.

Annotated image

In the or add link to icon sub-section you can add a link to an icon and preview it.

Annotated image

After uploading an icon, all of the available icons are shown at the bottom of the modal window. Select one (if not already selected) and click on the save button.

The page icon will be shown in the page edit screen and the sidebar navigation next to the page name.

Annotated image

Field expressions

Value expressions

Value expressions calculate the fields' value based on the provided expression. A value expression is a simple expression that results in a single value. If your field is a multi-value field, you need to return an array of items.

Refer to the Expressions for details on writing expressions.

Currently, you can only use values of the current record. References are not yet supported. If you need to reference data across multiple records, resort to using an automation instead.

Table 5. Available variables in the evaluation context:

old

The old variable refers to the original record. Only set when the field is being updated.

new

The new variable refers to the current record.

<field-name>

A string or an array of strings with current field values. If the field name collides with any of the system-defined variables, access the value via the new["field_name_here"].

Example expression that calculates the price with tax:
price * 1.25
Example expression that generates a full name:
trim(firstName + " " + lastName)
Example expression of a multi-value expression evaluation:
["foo", "bar", "baz"]

Sanitizers

Sanitizers modify the field value to cleanup (sanitize) the data before it is saved. A sanitizer is a simple expression that results in a single value.

Sanitizers are ran multiple times, once before data is sent to event bus (corredor and workflows) and the second is right before the record is sent to the API.

Refer to the Expressions for details on writing expressions.

By their nature, sanitizers should not result in an error. If an error occurs, it is logged in the action log, and the operation continues.

If you define multiple sanitizers, they are run in the specified order.

Example sanitizer that limits the text length:
length(value) > 5 ? substr(value, 0, 5) + "..." : value
Table 6. Available variables in the evaluation context:

value

The value variable refers to the current value.

Validators

Validators validate the field value by raising errors when the value is not valid. A validator is a simple expression that results in a single value, either true or false. The value validation is considered invalid when the expression results in true.

Validators can not change the field’s value.

Built-in field validators can be disabled; required and unique-multi-value validators can not be disabled.

If you define multiple validators, they are run in the specified order.

The field validator stops when the first error occurs. For example, if we define validators A, B, and C, and the validator A raises an error, validators B and C are not evaluated.

Validation expressions are not executed when:
  • the value is not changed,

  • the value is missing.

Use the required flag to check for required values.

Table 7. Available variables in the evaluation context:

value

The value variable refers to the current value.

oldValue

The oldValue variable refers to the original value. Only set when the field is being updated.

values

The values variable refers to all record values (values.<field-name>). You can use this to create context-aware validators.

Example validator to check the text length:
length(title) < 5

Page Block Magnification

Page blocks have a magnification option that allows the user to inspect the details of the block in distraction-free mode. By default, block magnification is disabled. When set, blocks that have this configuration will have a zoom-in icon in the top right corner of the block, allowing the user to magnify the block upon clicking on the icon.

Annotated image

Configuring Page Block Magnification

To display the magnification icon and enable block magnification, navigate to the page builder, choose a block, and go to its general tab. There you will find the block magnification options as a select dropdown.

Annotated image

Pick any of the two magnification options. Now, the magnification icon will be visible and users will be able to zoom in the specific block.

Table 8. Page Block Magnification Options:

Modal

The block magnification is in the form of a modal.

magnification modal

Fullscreen

The block magnification is in the form of a full-width and full-height modal.

magnification fullscreen

Page Block Refresh

Page blocks have a refresh option to automatically renew their data without having to reload the entire page, this is useful for page blocks that display data that changes frequently, such as a list of new leads, an update to a chart, or a list of recent comments.

Automation, file, content, nylas, navigation, and geometry blocks do not have the refresh option.

Enabling Auto-Refresh

When enabled, page blocks that have this configuration will automatically refresh based on an interval. To enable auto-refresh, navigate to the page builder, choose a block that supports refresh, and go to its general tab. There you will find the refresh option.

Page block general tab.
Figure 1. Page block general tab.

You’ll want to enter a value expressed in seconds into the input above the Show refresh button toggle, click save and close, save the page and you should see the block start to refresh when your interval elapses.

The lowest interval allowed is 5 seconds. To turn auto-refresh off on a block, you need to set its value to 0.

Enabling Manual Refresh

To enable manual refresh, navigate to the page builder, choose a block that supports refresh, and go to its general tab. There you will find a toggle as highlighted below. Switch it on.

Page block general tab.
Figure 2. Page block general tab.

When enabled, page blocks that have this configuration will have a refresh button in the top right corner of the page block, allowing the user to manually refresh the page block.

Refresh icon on page blocks with manual refresh.
Figure 3. Refresh icon on page blocks with manual refresh.