Skip to content

Commit

Permalink
feat(docs): split table docs (#232)
Browse files Browse the repository at this point in the history
  • Loading branch information
deini authored Nov 4, 2019
1 parent 1318bfd commit 823022a
Showing 1 changed file with 72 additions and 49 deletions.
121 changes: 72 additions & 49 deletions packages/docs/pages/Table/TablePage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,16 +23,10 @@ const data: Item[] = [
{ sku: 'DPB', name: '[Sample] Dustpan & Brush', stock: 34 },
{ sku: 'OCG', name: '[Sample] Oak Cheese Grater', stock: 34 },
{ sku: 'OFSUC', name: '[Sample] Utility Caddy', stock: 45 },
{ sku: 'OTL', name: '[Sample] Orbit Terrarium - Large', stock: 109 },
{ sku: 'OTS', name: '[Sample] Orbit Terrarium - Small', stock: 89 },
{ sku: 'SLCTBS', name: '[Sample] Fog Linen Chambray Towel - Beige Stripe with some fondu of some sort', stock: 49 },
{ sku: 'SLLPJ', name: '[Sample] 1 L Le Parfait Jar', stock: 7 },
{ sku: 'SM13', name: '[Sample] Smith Journal 13', stock: 25 },
{ sku: 'TWB', name: '[Sample] Tiered Wire Basket', stock: 119 },
];

const columns = [
{ header: 'Sku', hash: 'sku', render: ({ sku }) => sku, isSortable: true },
{ header: 'Sku', hash: 'sku', render: ({ sku }) => sku },
{ header: 'Name', hash: 'name', render: ({ name }) => name },
{ header: 'Stock', hash: 'stocck', render: ({ stock }) => stock },
];
Expand Down Expand Up @@ -75,73 +69,102 @@ export default () => {
<TableSelectablePropTable id="table-selectable-prop-table" />
<TableSortablePropTable id="table-sortable-prop-table" />

<H1>Using pagination and selectable</H1>
<H1>Usage with selectable</H1>

<CodePreview scope={{ data, columns, sort }}>
<CodePreview scope={{ data, columns }}>
{/* jsx-to-string:start */}
{function Example() {
const [items, setItems] = React.useState(data);
const [selectedItems, setSelectedItems] = React.useState([]);

// Pagination
const [ranges] = React.useState([10, 20, 30]);
const [range, setRange] = React.useState(ranges[0]);
const [page, setPage] = React.useState(1);
const [currentItems, setCurrentItems] = React.useState([]);
return (
<Table
keyField="sku"
columns={columns}
items={data}
itemName="Products"
// @ts-ignore
selectable={{
selectedItems,
onSelectionChange: setSelectedItems,
}}
/>
);
}}
{/* jsx-to-string:end */}
</CodePreview>

// Selectable
const [selectedItems, setSelectedItems] = React.useState([]);
<H1>Usage with pagination</H1>

// Sortable
const [sortDirection, setSortDirection] = React.useState('ASC');
<CodePreview scope={{ data, columns }}>
{/* jsx-to-string:start */}
{function Example() {
const [currentPage, setCurrentPage] = React.useState(1);
const [itemsPerPageOptions] = React.useState([5, 10, 20, 30]);
const [itemsPerPage, setItemsPerPage] = React.useState(5);
const [currentItems, setCurrentItems] = React.useState([]);

const onItemsPerPageChange = newRange => {
setPage(1);
setRange(newRange);
};

const onPageChange = newPage => {
setSelectedItems([]);
setPage(newPage);
setCurrentPage(1);
setItemsPerPage(newRange);
};

React.useEffect(() => {
const maxItems = page * range;
const lastItem = Math.min(maxItems, items.length);
const firstItem = Math.max(0, maxItems - range);
const maxItems = currentPage * itemsPerPage;
const lastItem = Math.min(maxItems, data.length);
const firstItem = Math.max(0, maxItems - itemsPerPage);

// @ts-ignore
setCurrentItems(items.slice(firstItem, lastItem));
}, [page, items, range]);

const onSort = (columnHash, direction) => {
const sortedItems = sort(items, columnHash, direction);
setSortDirection(direction);
setItems(sortedItems);
};
setCurrentItems(data.slice(firstItem, lastItem));
}, [currentPage, data, itemsPerPage]);

return (
<Table
stickyHeader
keyField="sku"
columns={columns}
items={currentItems}
itemName="Products"
selectable={{
onSelectionChange: setSelectedItems,
selectedItems,
}}
pagination={{
currentPage: page,
totalItems: items.length,
onPageChange,
itemsPerPageOptions: ranges,
currentPage,
totalItems: data.length,
onPageChange: setCurrentPage,
itemsPerPageOptions,
onItemsPerPageChange,
itemsPerPage: range,
itemsPerPage,
}}
/>
);
}}
{/* jsx-to-string:end */}
</CodePreview>
<H1>Usage with sortable</H1>

<CodePreview scope={{ data, columns, sort }}>
{/* jsx-to-string:start */}
{function Example() {
const [items, setItems] = React.useState(data);
const [columnHash, setColumnHash] = React.useState('');
const [direction, setDirection] = React.useState('ASC');

const onSort = (newColumnHash, newDirection) => {
setColumnHash(newColumnHash);
setDirection(newDirection);
setItems(currentItems => sort(currentItems, newColumnHash, newDirection));
};

return (
<Table
keyField="sku"
columns={[
{ header: 'Sku', hash: 'sku', render: ({ sku }) => sku, isSortable: true },
{ header: 'Name', hash: 'name', render: ({ name }) => name, isSortable: true },
{ header: 'Stock', hash: 'stocck', render: ({ stock }) => stock, isSortable: true },
]}
items={items}
itemName="Products"
// @ts-ignore
sortable={{
columnHash: 'sku',
direction: sortDirection,
columnHash,
direction,
onSort,
}}
/>
Expand Down

0 comments on commit 823022a

Please sign in to comment.