[]
TableSheet provides special columns on the row header to show status and perform row operations from the UI.
The following built-in row actions from the BuiltInRowActions class can be enabled using the TableSheet.rowActionOptions method -
Name | Description |
---|---|
| Pin a row. |
| Show the data changes in a row. |
| Show warning information in a row. |
| Remove a row. |
| Save the data changes in a row. |
| Reset the data changes in a row. |
The following code sample shows how to enable row actions in a TableSheet.
//init a tablesheet
var sheet = spread.addSheetTab(0, "TableSheet1", GC.Spread.Sheets.SheetType.tableSheet);
// Initialize and row actions
var rowActions = GC.Spread.Sheets.TableSheet.BuiltInRowActions;
let options = sheet.rowActionOptions();
options.push(
rowActions.removeRow,
rowActions.saveRow,
rowActions.resetRow,
);
sheet.rowActionOptions(options);
You can customize row actions by passing self-defined options in the rowActionsOptions method. For example, the following GIF illustrates custom row actions such as a checkbox and a comment popup.
The following properties are available and can be used to customize row actions.
Property | Description |
---|---|
name string | The name of the option. |
icons (string | GC.Spread.Sheets.ButtonImageType) | A series of icons indicate the different statuses. |
iconSelector (item: any, index: number) => number | boolean | Select an icon according to a different status. |
tooltip String | The tooltip for the row action. |
command string | The name of the command when clicking the row action. |
shortcutKey GC.Spread.Sheets.TableSheet.IShortcutKey | The shortcut key of the command for the row action. |
The following code sample shows how to create a custom row action in tablesheet.
function addCustomActions(sheet){
var options = sheet.rowActionOptions();
//add a action of check/uncheck
options.push({
name: 'check',
icons: ["", ""],
tooltip: "Check/Uncheck",
iconSelector: function (item) {
return !!checkMap[item.id];
},
command: CheckRow
});
//show the comment flag if the data has a comment
options.push({
name: 'comment',
icons: [""],
tooltip: "Show the comment",
iconSelector: function (item) {
return item.notes ? item.notes.length > 0 : false;
},
shortcutKey: { key: 65 /* A */, ctrl: true, alt: true },
command: ShowComment
});
//show the attachment flag if the data has a attachment
options.push({
name: 'attachment',
icons: [""],
tooltip: "Attachment",
iconSelector: function (item) {
return item.photoUrl ? item.photoUrl.length > 0 : false;
}
});
sheet.rowActionOptions(options);
}