Skip to main content
Version: Next

Table

The table widget can hold structured data in the form of an array. The input widget for table data is a table with variable rows and columns as shown below.

Table previewTable previewTable preview

The data is stored in an array, which needs to be flattened for storage in the database. For this purpose columns are separated with a "|" and rows are distinguished with line breaks. The database field for a table is a TEXT column. For example, the data shown in the screen above would be stored as:

one|two|three
four|five|six
seven|eight|nine

Table settingsTable settingsTable settings

The input widget can be preconfigured with default data or a fixed amount of rows and columns. The default amount of rows and columns, as well as the default data, can be changed later when the data is entered. It's possible to prevent adding/removing additional rows/columns by setting the "Rows fixed"/"Cols fixed" checkbox. If this is set to fixed the add and delete button for rows and columns will disappear.

In order to set table data programmatically, an array needs to be passed to the setter as shown in the code snippet below:

$object->setTable([
["one", "two", "three"],
["four", "five", "six"],
["seven", "eight", "nine"]
]);

Using copy and paste feature in an object using table data type

A copy and paste feature is available to be able to fill easily the table in an object from an Excel sheet for instance:

Copy and paste featureCopy and paste featureCopy and paste feature

It is possible to copy directly data in the OS clipboard from Excel:

Copy and paste featureCopy and paste featureCopy and paste feature

And after pasting data will be formatted keeping Excel structure:

Copy and paste featureCopy and paste featureCopy and paste feature

You can paste any data (from text files, etc.), separator must be tabulation.