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](data:image/png;base64,<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="661px" height="461px" viewBox="-0.5 -0.5 661 461"><defs/><g><rect x="540" y="170" width="80" height="20" fill="none" stroke="none" pointer-events="all"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe flex-start; width: 78px; height: 1px; padding-top: 180px; margin-left: 542px;"><div style="box-sizing: border-box; font-size: 0; text-align: left; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">onCreate</div></div></div></foreignObject><text x="542" y="184" fill="#000000" font-family="Helvetica" font-size="12px" font-weight="bold">onCreate</text></switch></g><rect x="540" y="210" width="80" height="20" fill="none" stroke="none" pointer-events="all"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe flex-start; width: 78px; height: 1px; padding-top: 220px; margin-left: 542px;"><div style="box-sizing: border-box; font-size: 0; text-align: left; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">onDelete</div></div></div></foreignObject><text x="542" y="224" fill="#000000" font-family="Helvetica" font-size="12px" font-weight="bold">onDelete</text></switch></g><rect x="540" y="250" width="80" height="20" fill="none" stroke="none" pointer-events="all"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe flex-start; width: 78px; height: 1px; padding-top: 260px; margin-left: 542px;"><div style="box-sizing: border-box; font-size: 0; text-align: left; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">onUpdate</div></div></div></foreignObject><text x="542" y="264" fill="#000000" font-family="Helvetica" font-size="12px" font-weight="bold">onUpdate</text></switch></g><rect x="540" y="290" width="120" height="20" fill="none" stroke="none" pointer-events="all"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe flex-start; width: 118px; height: 1px; padding-top: 300px; margin-left: 542px;"><div style="box-sizing: border-box; font-size: 0; text-align: left; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">onCustomAction</div></div></div></foreignObject><text x="542" y="304" fill="#000000" font-family="Helvetica" font-size="12px" font-weight="bold">onCustomAction</text></switch></g><path d="M 315 190 L 360 211.61 L 360 268.39 L 315 290 L 270 268.39 L 270 211.61 Z" fill="#ffffff" stroke="#000000" stroke-miterlimit="10" pointer-events="all"/><path d="M 270 211.61 L 315 233.21 L 360 211.61 M 315 233.21 L 315 290" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe center; width: 88px; height: 1px; padding-top: 204px; margin-left: 271px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Props</div></div></div></foreignObject><text x="315" y="216" fill="#000000" font-family="Helvetica" font-size="12px" text-anchor="middle" font-weight="bold">Props</text></switch></g><path d="M 540 160 L 524.39 160 Q 514.39 160 514.39 170 L 514.39 230 Q 514.39 240 504.39 240 L 497.2 240 Q 490 240 500 240 L 507.2 240 Q 514.39 240 514.39 250 L 514.39 310 Q 514.39 320 524.39 320 L 540 320" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all"/><path d="M 360 240 L 495 240" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 240px; margin-left: 428px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; background-color: #ffffff; white-space: nowrap; "> events </div></div></div></foreignObject><text x="428" y="244" fill="#000000" font-family="Helvetica" font-size="12px" text-anchor="middle" font-weight="bold"> events </text></switch></g><path d="M 130 160 L 114.39 160 Q 104.39 160 104.39 170 L 104.39 230 Q 104.39 240 94.39 240 L 87.2 240 Q 80 240 90 240 L 97.2 240 Q 104.39 240 104.39 250 L 104.39 310 Q 104.39 320 114.39 320 L 130 320" fill="none" stroke="#000000" stroke-miterlimit="10" transform="rotate(180,105,240)" pointer-events="all"/><path d="M 270 240 L 125 240" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 240px; margin-left: 197px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; background-color: #ffffff; white-space: nowrap; "> config </div></div></div></foreignObject><text x="197" y="244" fill="#000000" font-family="Helvetica" font-size="12px" text-anchor="middle" font-weight="bold"> config </text></switch></g><rect x="0" y="170" width="100" height="140" fill="none" stroke="none" pointer-events="all"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe flex-start; justify-content: unsafe flex-start; width: 98px; height: 1px; padding-top: 177px; margin-left: 2px;"><div style="box-sizing: border-box; font-size: 0; text-align: left; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; white-space: normal; word-wrap: normal; ">Bulk<br /><br />Columns<br /><br />Create<br /><br />Delete<br /><br />Update</div></div></div></foreignObject><text x="2" y="189" fill="#000000" font-family="Helvetica" font-size="12px" font-weight="bold">Bulk...</text></switch></g><path d="M 315 190 L 315 83.04" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 137px; margin-left: 315px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; background-color: #ffffff; white-space: nowrap; "> data </div></div></div></foreignObject><text x="315" y="141" fill="#000000" font-family="Helvetica" font-size="12px" text-anchor="middle" font-weight="bold"> data </text></switch></g><path d="M 285 15 C 285 6.72 298.43 0 315 0 C 322.96 0 330.59 1.58 336.21 4.39 C 341.84 7.21 345 11.02 345 15 L 345 65 C 345 73.28 331.57 80 315 80 C 298.43 80 285 73.28 285 65 Z" fill="#ffffff" stroke="#000000" stroke-miterlimit="10" pointer-events="all"/><path d="M 345 15 C 345 23.28 331.57 30 315 30 C 298.43 30 285 23.28 285 15" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="all"/><path d="M 315 290 L 315 400" fill="none" stroke="#000000" stroke-miterlimit="10" pointer-events="stroke"/><g transform="translate(-0.5 -0.5)"><switch><foreignObject style="overflow: visible; text-align: left;" pointer-events="none" width="100%" height="100%" requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"><div xmlns="http://www.w3.org/1999/xhtml" style="display: flex; align-items: unsafe center; justify-content: unsafe center; width: 1px; height: 1px; padding-top: 345px; margin-left: 315px;"><div style="box-sizing: border-box; font-size: 0; text-align: center; "><div style="display: inline-block; font-size: 12px; font-family: Helvetica; color: #000000; line-height: 1.2; pointer-events: all; font-weight: bold; background-color: #ffffff; white-space: nowrap; ">triggers</div></div></div></foreignObject><text x="315" y="349" fill="#000000" font-family="Helvetica" font-size="12px" text-anchor="middle" font-weight="bold">triggers</text></switch></g><path d="M 280 410 L 370 410 L 370 460 L 280 460 Z" fill="#ffffff" stroke="#000000" stroke-miterlimit="10" pointer-events="all"/><path d="M 275 405 L 365 405 L 365 455 L 275 455 Z" fill="#ffffff" stroke="#000000" stroke-miterlimit="10" pointer-events="all"/><path d="M 270 400 L 360 400 L 360 450 L 270 450 Z" fill="#ffffff" stroke="#000000" stroke-miterlimit="10" pointer-events="all"/></g><switch><g requiredFeatures="http://www.w3.org/TR/SVG11/feature#Extensibility"/><a transform="translate(0,-5)" xlink:href="https://desk.draw.io/support/solutions/articles/16000042487" target="_blank"><text text-anchor="middle" font-size="10px" x="50%" y="100%">Viewer does not support full SVG 1.1</text></a></switch></svg>)

## The complete JSX picture

```
Expand Down
Loading

0 comments on commit 5364c53

Please sign in to comment.