Skip to content

Commit

Permalink
add props diagram
Browse files Browse the repository at this point in the history
  • Loading branch information
Manu Ramirez committed Aug 25, 2020
1 parent a5f5061 commit 5364c53
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 14 deletions.
23 changes: 9 additions & 14 deletions packages/cascara/src/ui/Table/TechnicalDesign.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -63,9 +63,9 @@ Given the nature of our actual tables and the operations we need to perform on t

It is true that CRUD operations are needed in less scenarios, so the CRUD feature must be easily enabled and must not interfere with the regular table logic.

## API
## Props

The API has been divided into
![Table props](assets/props.svg)

### Events

Expand All @@ -74,16 +74,16 @@ In order to support CRUD operations, we must define a mechanism to communicate t
- onCreate
- onUpdate
- onDelete
- onCustomAction
- onTrigger

Please note that the names could have been something like `onItemCreate` for semantics, but let's remember that in the future we plan to support selection and custom actions on multiple items. Our proposal is to keep these as abstract as possible.

| Event | Signature | Description |
| -------------- | ---------------------------------------------------------- | --------------------------------------------------------------- |
| onCreate | `(Object: newItem) => {}` | Fired when the User saves a new item |
| onUpdate | `(Array[Object]: updatedItems) => {}` | Fired when one or more rows have been updated by the User |
| onDelete | `(Array[String]: selectedItems) => {}` | Fired when one or more rows have been deleted by the User |
| onCustomAction | `(String: actionType, Array[String]: selectedItems) => {}` | Fired when a custom action has been applied to one or more rows |
| Event | Signature | Description |
| --------- | ------------------------------------------------- | --------------------------------------------------------------- |
| onCreate | `(Object: newItem) => {}` | Fired when the User saves a new item |
| onUpdate | `(Array[Object]: updatedItems) => {}` | Fired when one or more rows have been updated by the User |
| onDelete | `(Array[String]: selectedItems) => {}` | Fired when one or more rows have been deleted by the User |
| onTrigger | `(String: actionType, Array[String]: data) => {}` | Fired when a custom action has been applied to one or more rows |

### Config

Expand Down Expand Up @@ -124,11 +124,8 @@ The definition of columns depends on the data, we must make sure we have a well-
| Attribute | Type | default | Description |
| ---------- | ---------------------------------------------------------------------- | ---------- | -------------------------------------------------------- |
| attribute | String | `null` | The name of the entity attribute that maps to the column |
| context | Object | `{}` | the context to be passed down to the custom component |
| isEditable | Boolean | `FALSE` | Specifies if the cells are editable |
| label | String | `''` | Label text to display with this attribute |
| render | JSX | `null` | A custom component to render |
| style | Object | `{}` | Custom style for the rendered component |
| type | Enum[`boolean`, `date`, `image`, `link`, `number`, `string`, `render`] | `'string'` | Specifies the type of data for the column |

### Data types
Expand All @@ -143,8 +140,6 @@ For mutation purposes, the implementation will support `select`, `input`, `boole

All the internal logic will be hosted in a Context. The definition is WIP.

![Table API]()

## The complete JSX picture

```
Expand Down
Loading

0 comments on commit 5364c53

Please sign in to comment.