From f5eb1a2636b5c59626603d122976d54b4d62cb5b Mon Sep 17 00:00:00 2001 From: Manuel Calavera Date: Sun, 13 Oct 2019 18:17:20 -0700 Subject: [PATCH] feat: tables refactoring --- .../components/Applications/Table/index.jsx | 47 ++++---------- src/v2/components/Blocks/Table/index.jsx | 57 +++++----------- src/v2/components/Blocks/Table/styles.js | 40 ------------ src/v2/components/TourDeSol/Table/index.jsx | 65 ++++++++++--------- src/v2/components/TourDeSol/Table/styles.js | 40 ------------ .../components/Transactions/Table/index.jsx | 62 ++++++------------ .../components/Transactions/Table/styles.js | 22 ------- src/v2/components/UI/Table/index.jsx | 11 ++-- src/v2/components/UI/Table/styles.js | 5 ++ src/v2/components/Validators/Table/index.jsx | 7 +- src/v2/components/Validators/Table/styles.js | 4 +- 11 files changed, 102 insertions(+), 258 deletions(-) diff --git a/src/v2/components/Applications/Table/index.jsx b/src/v2/components/Applications/Table/index.jsx index e039f7cb..969fc947 100644 --- a/src/v2/components/Applications/Table/index.jsx +++ b/src/v2/components/Applications/Table/index.jsx @@ -1,37 +1,35 @@ // @flow import React from 'react'; -import { - Table, - TableBody, - TableCell, - TableHead, - TableRow, -} from '@material-ui/core'; +import {TableCell, TableRow} from '@material-ui/core'; import cn from 'classnames'; import useMediaQuery from '@material-ui/core/useMediaQuery'; import {useTheme} from '@material-ui/core/styles'; import {observer} from 'mobx-react-lite'; import {Link} from 'react-router-dom'; import {map} from 'lodash/fp'; -import HelpLink from 'v2/components/HelpLink'; import TypeLabel from 'v2/components/UI/TypeLabel'; +import Table from 'v2/components/UI/Table'; import type {TableHeadProps} from 'v2/@types/table'; import formatDistanceToNow from 'date-fns/formatDistanceToNow'; + import useStyles from './styles'; -const tHeads: TableHeadProps[] = [ +const fields: TableHeadProps[] = [ { + label: 'Application Id', name: 'Application Id', text: '', term: '', }, { + label: 'Type', name: 'type', text: '', term: '', }, { + label: 'Time', name: 'time', text: '', term: '', @@ -56,16 +54,15 @@ const ApplicationsTable = ({ const renderRow = application => { return ( - - + + {application.programId} - TODO +
+ +
{asTime(application.timestamp)} @@ -99,28 +96,10 @@ const ApplicationsTable = ({ ); }; - const renderTH = ({name, width, ...rest}: TableHeadProps) => ( - - {name} - - - ); - return (
{showTable ? ( - - - {map(renderTH)(tHeads)} - - - {map(renderRow)(applications)} - -
+ ) : (
{map(renderCard)(applications)} diff --git a/src/v2/components/Blocks/Table/index.jsx b/src/v2/components/Blocks/Table/index.jsx index ca5edfd3..a5645ca5 100644 --- a/src/v2/components/Blocks/Table/index.jsx +++ b/src/v2/components/Blocks/Table/index.jsx @@ -1,59 +1,56 @@ // @flow import React from 'react'; -import { - Table, - TableBody, - TableCell, - TableHead, - TableRow, -} from '@material-ui/core'; +import {TableCell, TableRow} from '@material-ui/core'; import cn from 'classnames'; +import formatDistanceToNow from 'date-fns/formatDistanceToNow'; import useMediaQuery from '@material-ui/core/useMediaQuery'; import {useTheme} from '@material-ui/core/styles'; import {observer} from 'mobx-react-lite'; import {Link} from 'react-router-dom'; import {map} from 'lodash/fp'; - +import Table from 'v2/components/UI/Table'; import type {TableHeadProps} from 'v2/@types/table'; -import formatDistanceToNow from 'date-fns/formatDistanceToNow'; -import HelpLink from 'v2/components/HelpLink'; import ValidatorName from 'v2/components/UI/ValidatorName'; + import useStyles from './styles'; -const tHeads: TableHeadProps[] = [ +const fields: TableHeadProps[] = [ { + label: 'Blocks', name: 'blocks', text: '', term: '', }, { + label: 'slot', name: 'slot', text: '', term: '', }, { + label: 'time', name: 'time', text: '', term: '', }, { + label: 'transactions', name: 'transactions', text: '', term: '', - width: 190, }, { + label: 'confidence', name: 'confidence', text: '', term: '', - width: 165, }, { + label: 'leader', name: 'leader', text: '', term: '', - width: 240, }, ]; @@ -76,14 +73,12 @@ const BlocksTable = ({ return ( - -
{block.id}
- + {block.id}
- {block.slot} - {asTime(block.timestamp)} - TODO - TODO + {block.slot} + {asTime(block.timestamp)} + TODO + TODO @@ -128,28 +123,10 @@ const BlocksTable = ({ ); }; - const renderTH = ({name, width, ...rest}: TableHeadProps) => ( - - {name} - - - ); - return (
{showTable ? ( -
- - {map(renderTH)(tHeads)} - - - {map(renderRow)(blocks)} - -
+ ) : (
{map(renderCard)(blocks)} diff --git a/src/v2/components/Blocks/Table/styles.js b/src/v2/components/Blocks/Table/styles.js index 8cff6763..94176fd9 100644 --- a/src/v2/components/Blocks/Table/styles.js +++ b/src/v2/components/Blocks/Table/styles.js @@ -10,35 +10,6 @@ export default makeStyles(theme => ({ marginBottom: 50, }, }, - head: { - border: '1px solid #979797', - '& th': { - textTransform: 'uppercase', - fontSize: 15, - letterSpacing: 2, - fontWeight: 'bold', - borderBottom: 'none', - paddingRight: 16, - '&:first-child': { - paddingLeft: 40, - }, - }, - }, - body: { - '& td': { - fontSize: 15, - paddingTop: 18, - paddingBottom: 18, - maxWidth: 0, - whiteSpace: 'nowrap', - textOverflow: 'ellipsis', - overflow: 'hidden', - paddingRight: 16, - '&:first-child': { - paddingLeft: 40, - }, - }, - }, list: { width: '100%', }, @@ -83,15 +54,4 @@ export default makeStyles(theme => ({ letterSpacing: 2, fontWeight: 'bold', }, - leader: { - display: 'flex', - alignItems: 'center', - color: getColor('main')(theme), - '& div': { - marginLeft: 5, - whiteSpace: 'nowrap', - textOverflow: 'ellipsis', - overflow: 'hidden', - }, - }, })); diff --git a/src/v2/components/TourDeSol/Table/index.jsx b/src/v2/components/TourDeSol/Table/index.jsx index 0c21ce45..7159252e 100644 --- a/src/v2/components/TourDeSol/Table/index.jsx +++ b/src/v2/components/TourDeSol/Table/index.jsx @@ -1,26 +1,45 @@ // @flow import React from 'react'; -import { - Typography, - Table, - TableBody, - TableCell, - TableHead, - TableRow, - Grid, -} from '@material-ui/core'; +import {Typography, TableCell, TableRow, Grid} from '@material-ui/core'; import cn from 'classnames'; import useMediaQuery from '@material-ui/core/useMediaQuery'; import {useTheme} from '@material-ui/core/styles'; import {observer} from 'mobx-react-lite'; import {Link} from 'react-router-dom'; import {map} from 'lodash/fp'; +import Table from 'v2/components/UI/Table'; +import HelpLink from 'v2/components/HelpLink'; import ValidatorName from 'v2/components/UI/ValidatorName'; - -import HelpLink from '../../HelpLink'; import useStyles from './styles'; +const fields = [ + { + label: 'ranking', + name: 'ranking', + text: '', + term: '', + }, + { + label: 'name', + name: 'name', + text: '', + term: '', + }, + { + label: 'Staked sol', + name: 'staked_sol', + text: '', + term: '', + }, + { + label: 'Uptime', + name: 'uptime', + text: '', + term: '', + }, +]; + const ValidatorsTable = ({ activeValidators, separate, @@ -36,12 +55,12 @@ const ValidatorsTable = ({ const {name, pubkey, avatarUrl, activatedStake, uptimePercent, rank} = row; return ( - {rank} + {rank} - {activatedStake.toFixed(8)} - {uptimePercent}% + {activatedStake.toFixed(8)} + {uptimePercent}% ); }; @@ -84,23 +103,7 @@ const ValidatorsTable = ({ )}
{showTable ? ( -
- - - Ranking - Name - Staked SOL - Uptime - - - - {map(renderRow)(activeValidators)} - -
+ ) : (
{map(renderCard)(activeValidators)} diff --git a/src/v2/components/TourDeSol/Table/styles.js b/src/v2/components/TourDeSol/Table/styles.js index c52545ea..d04ad3ab 100644 --- a/src/v2/components/TourDeSol/Table/styles.js +++ b/src/v2/components/TourDeSol/Table/styles.js @@ -13,29 +13,6 @@ export default makeStyles(theme => ({ marginBottom: 50, }, }, - head: { - border: '1px solid #979797', - '& th': { - textTransform: 'uppercase', - fontSize: 15, - letterSpacing: 2, - paddingRight: 5, - fontWeight: 'bold', - borderBottom: 'none', - }, - }, - body: { - '& td': { - fontSize: 15, - paddingTop: 18, - paddingBottom: 18, - paddingRight: 5, - maxWidth: 0, - whiteSpace: 'nowrap', - textOverflow: 'ellipsis', - overflow: 'hidden', - }, - }, header: { display: 'flex', alignItems: 'baseline', @@ -56,23 +33,6 @@ export default makeStyles(theme => ({ fontSize: 15, textDecoration: 'none', }, - name: { - display: 'flex', - alignItems: 'center', - color: getColor('main')(theme), - textDecoration: 'none', - '& div': { - '&:first-child': { - marginRight: 22, - }, - whiteSpace: 'nowrap', - textOverflow: 'ellipsis', - overflow: 'hidden', - }, - [theme.breakpoints.down('sm')]: { - marginBottom: 22, - }, - }, list: { display: 'flex', width: '100%', diff --git a/src/v2/components/Transactions/Table/index.jsx b/src/v2/components/Transactions/Table/index.jsx index 384f4187..292e54ad 100644 --- a/src/v2/components/Transactions/Table/index.jsx +++ b/src/v2/components/Transactions/Table/index.jsx @@ -1,53 +1,53 @@ // @flow import React from 'react'; -import { - Table, - TableBody, - TableCell, - TableHead, - TableRow, -} from '@material-ui/core'; +import {TableCell, TableRow} from '@material-ui/core'; import cn from 'classnames'; import useMediaQuery from '@material-ui/core/useMediaQuery'; import {useTheme} from '@material-ui/core/styles'; import {observer} from 'mobx-react-lite'; import {Link} from 'react-router-dom'; import {map} from 'lodash/fp'; -import HelpLink from 'v2/components/HelpLink'; import TypeLabel from 'v2/components/UI/TypeLabel'; +import Table from 'v2/components/UI/Table'; import type {TableHeadProps} from 'v2/@types/table'; import formatDistanceToNow from 'date-fns/formatDistanceToNow'; import useStyles from './styles'; -const tHeads: TableHeadProps[] = [ +const fields: TableHeadProps[] = [ { - name: 'hash', + id: 'hash', + label: 'hash', text: '', term: '', }, { + label: 'block', name: 'block', text: '', term: '', }, { + label: 'time', name: 'time', text: '', term: '', }, { + label: 'application id', name: 'application id', text: '', term: '', }, { + label: 'type', name: 'type', text: '', term: '', }, { + label: 'confirmations', name: 'confirmations', text: '', term: '', @@ -72,20 +72,16 @@ const TransactionsTable = ({ const renderRow = transaction => { return ( - - - {transaction.id} - + + {transaction.id} - + {transaction.blockId} - - {asTime(transaction.timestamp)} - - + {asTime(transaction.timestamp)} + - - TODO + +
+ +
- TODO + TODO
); }; @@ -151,28 +149,10 @@ const TransactionsTable = ({ ); }; - const renderTH = ({name, ...rest}: TableHeadProps) => ( - - {name} - - - ); - return (
{showTable ? ( -
- - {map(renderTH)(tHeads)} - - - {map(renderRow)(transactions)} - -
+ ) : (
{map(renderCard)(transactions)} diff --git a/src/v2/components/Transactions/Table/styles.js b/src/v2/components/Transactions/Table/styles.js index a895378b..8fc66346 100644 --- a/src/v2/components/Transactions/Table/styles.js +++ b/src/v2/components/Transactions/Table/styles.js @@ -10,28 +10,6 @@ export default makeStyles(theme => ({ marginBottom: 50, }, }, - head: { - border: '1px solid #979797', - '& th': { - textTransform: 'uppercase', - fontSize: 15, - letterSpacing: 2, - fontWeight: 'bold', - borderBottom: 'none', - whiteSpace: 'nowrap', - }, - }, - body: { - '& td': { - fontSize: 15, - paddingTop: 18, - paddingBottom: 18, - maxWidth: 0, - whiteSpace: 'nowrap', - textOverflow: 'ellipsis', - overflow: 'hidden', - }, - }, name: { display: 'flex', alignItems: 'center', diff --git a/src/v2/components/UI/Table/index.jsx b/src/v2/components/UI/Table/index.jsx index cf69f534..1c281556 100644 --- a/src/v2/components/UI/Table/index.jsx +++ b/src/v2/components/UI/Table/index.jsx @@ -42,9 +42,10 @@ function getSorting(order, orderBy) { const EnhancedTableHead = props => { const classes = useStyles(); - const {fields, order, orderBy, onRequestSort, text, term} = props; + const {fields, order, orderBy, onRequestSort, sortable} = props; const createSortHandler = property => event => { + if (!sortable) return; onRequestSort(event, property); }; @@ -60,12 +61,13 @@ const EnhancedTableHead = props => { sortDirection={orderBy === headCell.id ? order : false} > {headCell.label} - + ), @@ -78,7 +80,7 @@ const EnhancedTableHead = props => { const EnhancedTable = props => { const classes = useStyles(); - const {data = [], fields, renderRow, initialSort = 'name'} = props; + const {data = [], fields, renderRow, initialSort = ''} = props; const [order, setOrder] = useState('asc'); const [orderBy, setOrderBy] = React.useState(initialSort); const handleRequestSort = (event, property) => { @@ -90,6 +92,7 @@ const EnhancedTable = props => { return (
{ ); }; -EnhancedTable.propTypes = {}; - export default EnhancedTable; diff --git a/src/v2/components/UI/Table/styles.js b/src/v2/components/UI/Table/styles.js index 4ff30c05..3c634146 100644 --- a/src/v2/components/UI/Table/styles.js +++ b/src/v2/components/UI/Table/styles.js @@ -16,6 +16,11 @@ export default makeStyles(() => ({ maxWidth: 1, overflow: 'hidden', textOverflow: 'ellipsis', + '& > *': { + overflow: 'hidden', + textOverflow: 'ellipsis', + display: 'block', + }, }, }, })); diff --git a/src/v2/components/Validators/Table/index.jsx b/src/v2/components/Validators/Table/index.jsx index 44f15298..e1419ab2 100644 --- a/src/v2/components/Validators/Table/index.jsx +++ b/src/v2/components/Validators/Table/index.jsx @@ -14,6 +14,8 @@ import Table from 'v2/components/UI/Table'; import {LAMPORT_SOL_RATIO} from 'v2/constants'; import Socket from 'v2/stores/socket'; import Loader from 'v2/components/UI/Loader'; +import HelpLink from 'v2/components/HelpLink'; + import ValidatorName from 'v2/components/UI/ValidatorName'; import useStyles from './styles'; @@ -122,9 +124,8 @@ const ValidatorsTable = ({separate}: {separate: boolean}) => { {!separate && (
Validators - - {activeValidators.length + inactiveValidators.length} - + + {allValidators.length} See all > diff --git a/src/v2/components/Validators/Table/styles.js b/src/v2/components/Validators/Table/styles.js index b6ea6c7a..6712426e 100644 --- a/src/v2/components/Validators/Table/styles.js +++ b/src/v2/components/Validators/Table/styles.js @@ -32,9 +32,9 @@ export default makeStyles(theme => ({ }, header: { display: 'flex', - alignItems: 'baseline', + alignItems: 'center', flexWrap: 'wrap', - '& *:first-child': { + '& *:nth-child(2)': { marginRight: 35, }, marginBottom: 23,