ptcs-grid¶
Overview¶
The ptcs-grid
component displays data in tabular format. Each data item is represented by a grid row that contains one or more cells. You can customize the content of each cell. In a typical configuration, the data item is a JavaScript object and each cell corresponds to a field in that object. Additional objects types are also supported.
The grid component can manage large data sets that contain 100,000 data items. Larger data sets with up to one million data items were tested and are manageable, with some operations such as sorting taking more time.
Data Manager¶
The grid component reads its data from a data manager, which is used to perform all operations on the data, such as:
- filtering,
- sorting,
- selections,
- grouping,
- hierarchical items (tree grid),
- creating, updating, deleting,
- exporting,
- lazy loading,
and more.
The data manager must provide information about the number of items it contains, and return any item when a request is sent.
If the data manager has dynamic content or dynamic views, it must send updates about any changes using change events. For example, the data manager must send a change event when data is filtered, sorted, or grouped.
View Configurator¶
The grid displays each item using configurations from a view configurator.
The view configurator provides two types of view configurations:
- The column header, which defines the grid layout.
- Row configurations, which defines a row configuration for a specific data item. The row configuration defines the user interface controls that should be used for the various cells in the data row.
Usage Examples¶
Basic Usage¶
<ptcs-grid data="[[dataMgr]]" view="[[viewCfg]]"></ptcs-grid>
Component API¶
Properties¶
Property | Type | Description |
---|---|---|
data | Data Manager | Specifies the data manager. Refer to the detailed section about the data manager below. |
disabled | Boolean | Disables the grid |
disableRow | Function or String | A function that specifies if a row should be disabled. The function is called as disableRow(item, baseIndex, dataManager) . If the function returns true , the row that corresponds to the item is disabled. As syntactic sugar, disableRow can also be supplied as a string. In that case the grid creates the following function: item => item[disableRow] . That is, if disableRow is a string it specifies a field in the row object that in turn specifies if the item is disabled or not. |
filterHintText | String | The hint text to display in the quick filter box |
filterString | String | The string for the filter query |
showFilter | Boolean | Shows or hides the grid filter (a.k.a. simple / quick filter) |
filterWidth | Number | Sets a specific width in pixels for the quick filter box, although actual width may be limited by CSS min-width on part filter-field |
quickFilterMinWidth | Number | Read-only property returning the quick filter's min-width, if any |
hideHeader | Boolean | Enables you to hide the grid header |
items | Array | A simpler interface for specifying data: if items is assigned, the array is forwarded to data - if data is an instance of the default data manager. If data is unassigned, the grid instantiates a default data manager and assign items to it. |
label | String | Enables you to specify the grid title |
labelVariant | String | Specifies the variant of the grid title |
labelAlignment | String | Enables you to set the title alignment to the "left", "center", or "right". |
filterLabel | String | Enables you to specify a title for the grid filter |
clearFilteredSelection | Boolean | Clears the selected rows when filtering the grid data. |
selectedIndexes | Array | Array of selected items indexes. The indexes are base indexes, not row indexes. This property can be used both for selecting items and for checking which items are selected. It is automatically updated when the user selects or unselects rows. Note that selectedIndexes is an array even if selectMethod is 'single' . |
selectedItemText | String | The text to display next to the filter label when a single item is selected (default value: 'Selected Item'). |
selectedItemsText | String | The text to display next to the filter label when two or more items are selected (default value: 'Selected Items'). |
hideMessage | Boolean | Hide the grid message? (Ignore bindDataText, noDataToDisplayText, noResultsText, noMatchesText?) |
bindDataText | String | Prompt to bind data to the grid, shown in the message area (default value: 'Bind data to the grid') |
noDataToDisplayText | String | Alternative text shown in the message area when there is no data binding (default value: 'There is no data to display.') |
noResultsText | String | Text shown in the message area when there is bound data but no rows to show (default value: 'No Results.') |
noMatchesText | String | Text shown in the message area when data filtering causes all rows to be filtered out (default value: 'No matches found.') |
selectMethod | String | Sets the selection method of data . |
selectRow | Boolean | Allow users to select grid rows using the mouse or the keyboard. |
view | View Configurator | Sets the View Configurator. Refer to the detailed section about the view configurator below. |
cacheRuntimeChanges | Boolean | Should we store user interactions in browser local storage? (effective only when gridId is defined) |
preserveRowExpansion | Boolean | Should we store expanded rows in browser local storage? (effective only when gridId is defined and cacheRuntimeChanges is true) |
gridId | String | Associated unique ID for saving the grid's client configurations (sort, order, widths, visibility, expanded) in browser local storage. |
dataLoading | Boolean | Set to true to show the "data loading" indicator when starting to load data, and to false to hide the indicator |
loadingIndicatorSize | Number | Container size in pixels (same height / width) for the data loading indicator (default: 200) |
loadingIndicatorDelay | Number | Delay before displaying the loading indicator, in ms (default: 1000) |
loadingIndicatorImage | String | The url of a custom loading indicator image, that replaces the default indeterminate progress bar load indicator. If the image load fails, the default loading indicator is used as fallback. |
showResetButton | Boolean | Shows a button that resets the grid back to its default configuration when changes are made at run time. |
resizeColumns | Boolean | Enables to adjust the width of grid columns by dragging the divider lines. |
reorderColumns | Boolean | Allows the user to reorder columns in runtime using drag and drop. |
rowEditFormTitle | String | Title for the Row Edit form when it edits an existing row.. |
rowEditFormAddTitle | String | Title for the Row Edit form when it adds a new row. |
updateButtonText | String | Label for Save button in Row Edit Form when it edits an existing row. |
addButtonText | String | Label for Save button in Row Edit Form when it adds a new row. |
applyButtonText | String | Label for Apply button in Column Reorder Form. |
cancelButtonText | String | Label for Cancel button in Column Reorder Form and Row Edit Form. |
isEditable | Boolean | Specifies the editing mode. If true , then any editable cells can be edited. Otherwise the grid is read-only. If showEditButton is true , the default value for isEditable is false and it will not become true until the Edit button is clicked. |
edit | String | Specifies inline editing mode: 'cell' for cell editing or 'row' for row editing. All changes will be submitted as soon as they are valid. If edit has the value grid , the grid uses cell editing, but doesn't submit the changes until the user presses the Save button or the method commitUpdates is called. |
showEditButton | Boolean | When this property is true , buttons are displayed on the grid toolbar that enable you to turn editing mode on or off. Initially, only the Edit button is displayed. When the edit level is set to grid and Edit is clicked, the edit-started event is triggered and the Edit button is replaced by Save and Cancel buttons. When the Save button is clicked, the edit-completed event is triggered and the editing mode is stopped. When the Cancel button is clicked, the edit-cancelled event is triggered and the editing mode is stopped. The save and cancel buttons are only available when editing on a grid level. Grid-level editing enables you to save all modifications to grid cells at the same time. Cell level and row level editing will immediately save the edits to a cell or a row. When the edit mode is stopped, the Save and Cancel buttons are hidden and the Edit button is displayed again. |
editButtonText | String | Label for the Edit toolbar button (only visible if showEditButton is on). Default: 'Edit' . |
saveEditButtonText | String | Label for the Save toolbar button (only visible if showEditButton is on). Default: 'Save' . |
cancelEditButtonText | String | Label for the Cancel toolbar button (only visible if showEditButton is on). Default: 'Cancel' . |
editControlVisibility | String | Specifies how to show the edit control in 'cell' edit mode: 'hover' (default), 'always' , or 'never' . Note that the 'never' option effectively disables editing, unless inlineEditing is true . |
inlineEditing | Boolean | Enable inline editing? Ignored unless edit is 'cell' or 'grid' and editControlVisibility is 'never' . |
showDeleteRowButton | Boolean | Show a Delete Row button in the grid toolbar that allows the user to delete the selected rows? |
deleteRowButtonText | String | Label for the Delete Row toolbar button. Default: 'Delete' |
showAddRowButton | Boolean | Show an Add Row button in the grid toolbar that allows the user to add new rows? |
addRowButtonText | String | Label for Add Row toolbar button. Default: 'Add' . |
editControl | String | Specifies the edit control. The edit controls the edit activator, that the user can click on to edit a cell or row. Supported values: 'icon' (default), 'link' , or 'none' (= disable editing) |
editControlLabel | String | Specifies the label for the 'link' edit control. |
editControlIcon | String | Specifies the icon for the 'icon' edit control. |
highlightDrafts | Boolean | Highlight cells that contains a value that has been changed by grid inline editing. |
highlightNewRows | Boolean | Highlight newly added rows with a "change badge" marker. |
columnsMenuOptions | String | Enables user to show and hide specific columns using a check box, and change the order of the columns by dragging. |
columnsMenuVisibleItems | Number | Sets the number of items to display initially when the columns configuration menu is opened. |
columnsMenuReorderTooltip | String | Tooltip for the reorder icon in the columns configuration menu. |
columnsMenuVisibilityTooltip | String | Tooltip for the column visibility checkbox in the columns configuration menu. |
navigation | String | Specifies the focus navigation method. Possible values: 'row-first' (default), cell-first , cell-only |
preventFocusRowWrap | Boolean | Prevents the left and right arrow keys from navigating to next or previous row. Default: false |
selectFollowsFocus | Boolean | In single selection mode, automatically selects the focused row. Default: false |
autoScroll | Boolean | Keeps selected rows visible by scrolling automatically when the grid is updated or resized. |
footerData | Array | A JS object that contains data for the grid footer. Refer to the detailed section about the grid footer. |
showFooter | Boolean | Adds a footer area to the grid. |
showHeaderRowInFooter | Boolean | Shows the header row within the grid footer. |
deleteRowsConfirmation | Boolean | Prevents the deleteSelectedRows method from being executed after pressing the delete button. It can be used together with the delete-row-clicked event to add a custom confirmation step before calling the deleteSelectedRows manually. |
customActions | Action[] | Actions to display on the grid toolbar. |
customActionsPosition | String | Position of the toolbar actions relative to the edit, add, and delete buttons on the grid. Possible values: 'after' (default), 'before' , 'none' . |
preventDoubleClickedEvent | Boolean | Prevents text selection on double click. |
shiftKeySelection | Boolean | Prevents text selection on double click. |
Additional properties for the Tree Grid¶
Property | Type | Description |
---|---|---|
subItems | String | For tree grids: specifies a field name in the data item that contains sub-items |
alwaysExpanded | Boolean | If true, then all sub-items will always be visible and the tree toggle icons are automatically hidden. |
showExpandAll | Boolean | If true, the grid displays a button in the toolbar that allows the user to expand or collsapse all sub-items. |
expandAllText | String | The label of the showExpandAll button when it expands all sub-nodes. Default: 'Expand All' |
collapseAllText | String | The label of the showExpandAll button when it collapses all sub-nodes. Default: 'Collapse All' |
disableChildRows | Boolean | Works together with disableRow . If disableChildRows is true, items will be disabled if any ancestor item is disabled. |
Using the Data Manager Interface¶
To use a data manager with the grid, it should have the following methods and properties:
data.observe(cbObj)
The method registers cbOoj
as an observer to state changes in the data manager.
Each change event corresponds to a function name. If the object cbObj
has a corresponding function, the event is sent to that function.
In ThingWorx, 9.2, the grid component monitors the following events:
-
dmView()
- Triggered when the data view is updated through sorting, filtering, or grouping. -
dmItem(index)
- Triggered when data item with indexindex
is updated. -
dmInserted([[index, count], ...])
- Triggered whencount
items are inserted, starting at theindex
. Note that several segments can be inserted at the same time. -
dmRemoved([[index, count], ...])
- Triggered whencount
items are removed, starting atindex
. Note that several segments can be removed at the same time. -
dmSelected(baseIndex, selected)
- Triggered when an item with the base indexbaseIndex
is selected (selected
istrue
) or unselected (selected
isfalse
).
The baseIndex
persists to a specific data item, including when the data is sorted, filtered, grouped, and more. However, some operations such as adding or removing items can affect the baseIndex
persistence.
data.unobserve(cbObj);
Use the unobserve() method to stop the cbObj
observer from listening to the data manager events.
data.length
Returns the number of data items in the data manager.
data.item(index)
Returns the data item that corresponds at a specific index number.
The index
is a zero-based index with a value between 0
and data.length - 1
.
Note: The item is used as an input for methods in the view configurator and it is not interpreted by the grid.
data.isSelected(index)
Returns true
if a data item at a specific index number is selected, and false
in any other case. The grid uses the returned value to set or unset the selected
attribute on the corresponding row element.
data.selectMethod
The property (or get
function) specifies the data selection mode using one of the following options:
none
- disable selectionsingle
- select one item at a timemultiple
- select multiple items at the same time
data.baseIndex(index)
Converts the current index
into a persistent base index that is not affected by changes to the view. When index
does not correspond to an item, such as a virtual grouping item, the method returns -1
.
The base indexes are used to maintain the selection when the data view is changed by sorting, filtering, or any additional changes to the data projection.
data.setSelected(selected, directSelection)
Set the selected items. The directSelection
argument indicates whether the unselection was direct or non-direct.
data.select(baseIndex, selected, directSelection)
Controls the selection of the item using the index number and based on the value of the selected
variable. The item is selected when selected
is True unselected when False. When selected
is set to undefined
, the method toggles the selected state of the item. The directSelection
argument indicates whether the unselection was direct or non-direct.
data.selectAllItems(directSelection)
Selects all items. The directSelection
argument indicates whether the selection was direct or non-direct.
data.unselectAllItems(directSelection)
Unselects all items. The directSelection
argument indicates whether the unselection was direct or non-direct.
data.directSelection
Returns true
if the row or rows selection was direct, and undefined
or false
if triggered from other data service. A direct selection is when a user selects grid rows using the mouse or the keyboard.
View Configurator interface¶
The grid expects that the view configurator has the following methods or properties:
view.singleLineHeader
Displays each column label on the grid header as a single line of text.
view.maxHeightHeader
Sets the maximum height of the grid header when it is displayed across multiple lines.
view.singleLineRows
Use this property to display the grid rows on a single line.
view.maxHeightRow
Sets the maximum height of the grid rows when each row is displayed across multiple lines.
view.minHeightRow
Sets the grid minimum height of each row on the grid.
view.sortSelectionColumn
Adds a sort button to the row selection column.
view.externalSort
Controls whether an internal sort function is applied or an external sort is used when you click to sort a column.
view.getSortExpression()
Gets the current sort expression based on column names and sort orders.
view.setSortExpression(expr, dataManager, opt)
Applies a sort expression to the grid. Set opt.noOrder
to true
to reset only the sort icons. Set opt.reset
to true
to reset current sort order.
view.getOrderExpression()
Get the current columns order.
view.getWidthsExpression()
Get the current widths expression based on column names and widths.
view.getVisibilityExpression()
Get the current visibility expression based on column names and its hidden property.
view.observe(cbObj);
Registers cbOoj
as an observer to any state changes in the view configurator.
Each change event corresponds to a function name. If the object cbObj
has a corresponding function, the event is sent to that function.
In ThingWorx, 9.2, the grid component observes one event:
dvChanged()
- Triggers when the view configuration changes, which allows the grid to refresh the current view.
view.unobserve(cbObj);
Stops the cbObj
observer from observing the view configurator events.
view.columns
The columns
property (or get
function) contains an array that defines the grid columns. Each array item is an object that contains the following fields:
col.name¶
Specifies the identifier of the column. Optional. Required only if you want to show a footer data for this column.
In order to not interfere with the internal view expression syntax (used to capture e.g. column widths, order, or visibility), ASCII colon or comma appearing in column names will internally be replaced by other strings within such expressions.
col.label¶
Specifies the title in the column header. It is either a string or a function. If it is a string it will be displayed using a ptcs-label
component. If it is a function, it returns a single element which may contain sub-elements, that is used as the column header.
col.width¶
Sets the column width. For variable widths, set the value using fractions or percentage (fr
) units.
col.minWidth¶
Sets the minimum column width, width when the col.width
property contains is a variable width.
col.maxWidth¶
Sets the maximum column width, width when the col.width
property contains is a variable width.
col.headerHAlign¶
Sets the horizontal alignment of the column header label to one of the following options:
'left'
'center'
'right'
col.headerVAlign¶
Sets the vertical alignment of the column header label to one of the following options:
'top'
'center'
'bottom'
col.halign¶
Sets the horizontal alignment of content within the column cells to one of the following options:
'left'
'center'
'right'
col.valign¶
Sets the vertical alignment of content within the column cells to one of the following options:
'top'
'center'
'bottom'
col.resizable¶
Returns a True value when column can be resized by the user using mouse or keyboard interaction (not implemented yet).
col.hidden¶
Returns a True value if the column is hidden.
view.getRowDef(item);
Returns the row configuration of an item. The row configuration is an array, where each array item defines a specific cell. It is an object with these fields:
row.create¶
row.create
is a function that creates the cell content. It is called with a single parameter: the cell element where the result is placed. This allows the create function to mark the cell with extra styling or attributes, giving it control over the whole cell area.
Note that the returned element is not yet bound to a data item. The element may be reused for many items, which can improve performance.
row.select¶
Retrieves the cell data from a data item. The function is called with two parameters:
row.select(item, index);
item
- the data item from the data managerindex
- the index number of the item
The returned value is assigned as a value
property to the cell element, which makes the cell available for state formatting, and also sent to row.assign()
.
row.assign¶
Binds an element that is created by the row.create()
function to a data item. The function is executed with four parameters:
row.assign(element, value, index, dataManager);
element
- the element created by therow.create()
value
- the value selected byrow.select()
index
- the index of the corresponding data itemdataManager
- the data manager that contains the data item
The two latter arguments is mainly intended for inline cell editing, which allows the editor to send any changes to the data manager.
row.halign¶
row.halign
sets the horizontal alignment of the cell to one of the following options:
'left'
'center'
'right'
row.valign¶
row.valign
specifies the vertical alignment of the cell to one of the following options:
'top'
'center'
'bottom'
Grid Footer¶
See the example of the grid footer object. When you create your own footer data you should ensure same field names in the footer data as are used in the actual grid data.
grid.footerData = [
{
avatar: 'Footer Area',
title: '#cspan',
name: 'Total Count: {#stat_count}, text-align:right;',
department: '#cspan',
linkedin: '#cspan',
born: 'Average Age:, text-align:right;',
age: '{#stat_average}',
desc: '#cspan'
}
];
{#stat_count}
- Counts the number of rows.
{#stat_max}
- Calculates the maximum client-side value for the values in the column. Limited for numbers and dates only.
{#stat_min}
- Calculates the minimum client-side value for the values in the column. Limited for numbers and dates only.
{#stat_average}
- Calculates the average client-side value for the values in the column. Limited for numbers only.
{#stat_total}
- Calculates the total client-side value for the values in the column. Limited to numbers only.
{#cspan}
- Span columns.
You can align data in the footer using #cspan and text alignment settings text-align:left or text-align:right. Use HTML escape characters for comma in text, and the text following the comma is the alignment setting in the configuration, which is by default text-align:left.
Events¶
Name | Event.detail | Description |
---|---|---|
edit-started | Generated when the user clicks on the Edit button. |
|
edit-completed | Generated when the user clicks on the Save button. |
|
edit-cancelled | Generated when the user clicks on the Cancel button. |
|
add-row | Generated when the user clicks on the Add Row button. |
|
edit-item-started | {item, field, baseIndex} | Generated when the user begins inline editing: item is the edited item. field is the edited field, if edit mode is 'cell' (otherwise field is undefined). baseIndex is the base index of the edited item. If a new item is being created, only baseIndex is present, with the value -1 . |
edit-item-cancelled | {baseIndex, field, item} | Generated when the user stops inline editing without making any changes. |
edit-item-completed | {baseIndex, field, item, update, validation} | Generated when the user has completed an inline change. item contains the updated item and update contains the actual changes. validation contains any validation errors for the changes. |
reset-to-default | Generated when the user clicks on the Reset button. |
|
row-click | { value: row index } | Generated when the user clicks on a row. |
row-double-click | { value: row index } | Generated when the user double clicks on a row. |
delete-row-clicked | {rowsIndex: rows indexes} | Generated when the user clicks on the Delete button (row deletion). |
custom-actions-activated | { action, value } | Event generated from the toolbar custom actions. It's triggered when the user clicks on a button or link . |
custom-actions-value-changed | { action, value } | Event generated from the toolbar custom actions. It's triggered when the value of a toggle or dropdown changes. |
NOTE: The data manager and view configurator also generates various events.
Methods¶
Name | Argument | Type | Description |
---|---|---|---|
isIndexSelected | index | Number | Returns true if the item with the base index index is selected. |
isRowSelected | index | Number | Returns true if the item on the row at index index is selected. |
selectIndex | index | Number | Base index for item |
select | Boolean | false : unselect item. true : select item. undefined : toggle item selection state. |
|
selectRowIndex | index | Number | Row index for item (dependent on filtering, sorting, ...) |
select | Boolean | false : unselect item. true : select item. undefined : toggle item selection state. |
|
scrollTo | index | Number | Scrolls the item with the specified index number into the current view. |
getSortExpression | Returns the value of getSortExpression() from the view configurator | ||
setSortExpression | sortExpression, opt | Forwards the call to setSortExpression() in the view configurator | |
getOrderExpression | Returns the value of getSortExpression() from the view configurator | ||
getWidthsExpression | Returns the value of getSortExpression() from the view configurator | ||
getVisibilityExpression | Returns the value of getSortExpression() from the view configurator | ||
rollbackUpdates | Rollback all unsubmitted changes made by the grid inline editing | ||
commitUpdates | Submit all changes made by the grid inline editing - including invalid changes. | ||
deleteSelectedRows | Removes the selected rows from the grid. | ||
modifyCustomAction | actionId, value, updateType | String, |
Modifies the toolbar according to the updateType ('value' /'disabled' /'visible' ) |
Styling¶
Parts¶
Part | Description |
---|---|
body-cell | A data cell |
header-cell | A header cell |
header | The grid header row |
header-label | The column label in header cell |
row | A data row |
cell-link | A link in a cell |
States¶
Attribute | Description | Part |
---|---|---|
disabled | Indicates whether the grid is disabled | :host |
Subcomponents¶
The grid has subcomponent ptcs-quick-filter
with following parts:
Part | Description |
---|---|
label | The filter label |
filter-field | The filter textfield |
filter-label | Displays the number of selected rows when the grid selection mode is multiple |
The grid has subcomponent ptcs-data-load-bar
with following parts:
Part | Description |
---|---|
bar-container | The container for the indeterminate progress bar or custom image |
track | The default progress bar (a horizontal track with a moving slider) |
slider | The moving part within the track |
image | The custom image that replaces the default progress bar |
TODO¶
- rows spanning multiple columns
- resize columns with mouse interaction
- drag and drop reordering of columns
- drag and drop reordering of rows (or?)
- pinned rows and columns (the row / column stays in place regardless of scrolling)
- allow runtime user to dynamically show / hide columns
- keyboard interaction for resizing columns
- keyboard interaction for moving columns
- keyboard interaction for moving rows (or?)
- pagination
- tile / card layout
- ARIA attributes