blob: 70f06e506c365637d645eb8a7f6e3c835ff8520c (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
import { CdTableSelection } from './cd-table-selection';
export class CdTableAction {
// It's possible to assign a string
// or a function that returns the link if it has to be dynamic
// or none if it's not needed
routerLink?: string | Function;
preserveFragment? = false;
// This is the function that will be triggered on a click event if defined
click?: Function;
permission: 'create' | 'update' | 'delete' | 'read';
// The name of the action
name: string;
// The font awesome icon that will be used
icon: string;
/**
* You can define the condition to disable the action.
* By default all 'update' and 'delete' actions will only be enabled
* if one selection is made and no task is running on the selected item.`
*
* In some cases you might want to give the user a hint why a button is
* disabled. This is achieved by returning a string.
* */
disable?: (_: CdTableSelection) => boolean | string;
/**
* Defines if the button can become 'primary' (displayed as button and not
* 'hidden' in the menu). Only one button can be primary at a time. By
* default all 'create' actions can be the action button if no or multiple
* items are selected. Also, all 'update' and 'delete' actions can be the
* action button by default, provided only one item is selected.
*/
canBePrimary?: (_: CdTableSelection) => boolean;
// In some rare cases you want to hide a action that can be used by the user for example
// if one action can lock the item and another action unlocks it
visible?: (_: CdTableSelection) => boolean;
}
|