From 4eab11ffff21108f812dbee55ee176c91b36d033 Mon Sep 17 00:00:00 2001 From: merceyz Date: Fri, 31 May 2019 03:12:48 +0200 Subject: [PATCH 1/6] [docs] Migrate Grid demos to hooks --- docs/src/pages/components/grid/AutoGrid.js | 17 +- docs/src/pages/components/grid/AutoGrid.tsx | 50 ++++ .../pages/components/grid/AutoGridNoWrap.js | 17 +- .../pages/components/grid/AutoGridNoWrap.tsx | 65 +++++ docs/src/pages/components/grid/CSSGrid.js | 19 +- docs/src/pages/components/grid/CSSGrid.tsx | 84 +++++++ .../src/pages/components/grid/CenteredGrid.js | 17 +- .../pages/components/grid/CenteredGrid.tsx | 51 ++++ docs/src/pages/components/grid/ComplexGrid.js | 18 +- .../src/pages/components/grid/ComplexGrid.tsx | 72 ++++++ .../pages/components/grid/FullWidthGrid.js | 17 +- .../pages/components/grid/FullWidthGrid.tsx | 51 ++++ .../pages/components/grid/InteractiveGrid.js | 237 ++++++++---------- .../pages/components/grid/InteractiveGrid.tsx | 150 +++++++++++ docs/src/pages/components/grid/NestedGrid.js | 59 ++--- docs/src/pages/components/grid/NestedGrid.tsx | 55 ++++ docs/src/pages/components/grid/SpacingGrid.js | 103 ++++---- .../src/pages/components/grid/SpacingGrid.tsx | 70 ++++++ 18 files changed, 860 insertions(+), 292 deletions(-) create mode 100644 docs/src/pages/components/grid/AutoGrid.tsx create mode 100644 docs/src/pages/components/grid/AutoGridNoWrap.tsx create mode 100644 docs/src/pages/components/grid/CSSGrid.tsx create mode 100644 docs/src/pages/components/grid/CenteredGrid.tsx create mode 100644 docs/src/pages/components/grid/ComplexGrid.tsx create mode 100644 docs/src/pages/components/grid/FullWidthGrid.tsx create mode 100644 docs/src/pages/components/grid/InteractiveGrid.tsx create mode 100644 docs/src/pages/components/grid/NestedGrid.tsx create mode 100644 docs/src/pages/components/grid/SpacingGrid.tsx diff --git a/docs/src/pages/components/grid/AutoGrid.js b/docs/src/pages/components/grid/AutoGrid.js index 849947b73ad43b..1a1e3ce47342a7 100644 --- a/docs/src/pages/components/grid/AutoGrid.js +++ b/docs/src/pages/components/grid/AutoGrid.js @@ -1,10 +1,9 @@ import React from 'react'; -import PropTypes from 'prop-types'; -import { withStyles } from '@material-ui/core/styles'; +import { makeStyles } from '@material-ui/core/styles'; import Paper from '@material-ui/core/Paper'; import Grid from '@material-ui/core/Grid'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ root: { flexGrow: 1, }, @@ -13,10 +12,10 @@ const styles = theme => ({ textAlign: 'center', color: theme.palette.text.secondary, }, -}); +})); -function AutoGrid(props) { - const { classes } = props; +function AutoGrid() { + const classes = useStyles(); return (
@@ -46,8 +45,4 @@ function AutoGrid(props) { ); } -AutoGrid.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(AutoGrid); +export default AutoGrid; diff --git a/docs/src/pages/components/grid/AutoGrid.tsx b/docs/src/pages/components/grid/AutoGrid.tsx new file mode 100644 index 00000000000000..22324a40de26eb --- /dev/null +++ b/docs/src/pages/components/grid/AutoGrid.tsx @@ -0,0 +1,50 @@ +import React from 'react'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; +import Paper from '@material-ui/core/Paper'; +import Grid from '@material-ui/core/Grid'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + root: { + flexGrow: 1, + }, + paper: { + padding: theme.spacing(2), + textAlign: 'center', + color: theme.palette.text.secondary, + }, + }), +); + +function AutoGrid() { + const classes = useStyles(); + + return ( +
+ + + xs + + + xs + + + xs + + + + + xs + + + xs=6 + + + xs + + +
+ ); +} + +export default AutoGrid; diff --git a/docs/src/pages/components/grid/AutoGridNoWrap.js b/docs/src/pages/components/grid/AutoGridNoWrap.js index 9010f942a10d60..dcc1a6d48c16a2 100644 --- a/docs/src/pages/components/grid/AutoGridNoWrap.js +++ b/docs/src/pages/components/grid/AutoGridNoWrap.js @@ -1,12 +1,11 @@ import React from 'react'; -import PropTypes from 'prop-types'; import Paper from '@material-ui/core/Paper'; -import { withStyles } from '@material-ui/core/styles'; +import { makeStyles } from '@material-ui/core/styles'; import Grid from '@material-ui/core/Grid'; import Avatar from '@material-ui/core/Avatar'; import Typography from '@material-ui/core/Typography'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ root: { flexGrow: 1, overflow: 'hidden', @@ -17,13 +16,13 @@ const styles = theme => ({ margin: `${theme.spacing(1)}px auto`, padding: theme.spacing(2), }, -}); +})); const message = `Truncation should be conditionally applicable on this long line of text as this is a much longer line than what the container can support. `; -function AutoGridNoWrap(props) { - const { classes } = props; +function AutoGridNoWrap() { + const classes = useStyles(); return (
@@ -61,8 +60,4 @@ function AutoGridNoWrap(props) { ); } -AutoGridNoWrap.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(AutoGridNoWrap); +export default AutoGridNoWrap; diff --git a/docs/src/pages/components/grid/AutoGridNoWrap.tsx b/docs/src/pages/components/grid/AutoGridNoWrap.tsx new file mode 100644 index 00000000000000..084c3524fd8442 --- /dev/null +++ b/docs/src/pages/components/grid/AutoGridNoWrap.tsx @@ -0,0 +1,65 @@ +import React from 'react'; +import Paper from '@material-ui/core/Paper'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Avatar from '@material-ui/core/Avatar'; +import Typography from '@material-ui/core/Typography'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + root: { + flexGrow: 1, + overflow: 'hidden', + padding: theme.spacing(0, 3), + }, + paper: { + maxWidth: 400, + margin: `${theme.spacing(1)}px auto`, + padding: theme.spacing(2), + }, + }), +); + +const message = `Truncation should be conditionally applicable on this long line of text + as this is a much longer line than what the container can support. `; + +function AutoGridNoWrap() { + const classes = useStyles(); + + return ( +
+ + + + W + + + {message} + + + + + + + W + + + {message} + + + + + + + W + + + {message} + + + +
+ ); +} + +export default AutoGridNoWrap; diff --git a/docs/src/pages/components/grid/CSSGrid.js b/docs/src/pages/components/grid/CSSGrid.js index efbf3b672dd3e9..bd3eb355be0321 100644 --- a/docs/src/pages/components/grid/CSSGrid.js +++ b/docs/src/pages/components/grid/CSSGrid.js @@ -1,16 +1,15 @@ import React from 'react'; -import PropTypes from 'prop-types'; -import { withStyles } from '@material-ui/core/styles'; +import { makeStyles } from '@material-ui/core/styles'; import Typography from '@material-ui/core/Typography'; import Paper from '@material-ui/core/Paper'; import Divider from '@material-ui/core/Divider'; import Grid from '@material-ui/core/Grid'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ container: { display: 'grid', gridTemplateColumns: 'repeat(12, 1fr)', - gridGap: `${theme.spacing(3)}px`, + gridGap: theme.spacing(3), }, paper: { padding: theme.spacing(1), @@ -22,10 +21,10 @@ const styles = theme => ({ divider: { margin: theme.spacing(2, 0), }, -}); +})); -function CSSGrid(props) { - const { classes } = props; +function CSSGrid() { + const classes = useStyles(); return (
@@ -80,8 +79,4 @@ function CSSGrid(props) { ); } -CSSGrid.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(CSSGrid); +export default CSSGrid; diff --git a/docs/src/pages/components/grid/CSSGrid.tsx b/docs/src/pages/components/grid/CSSGrid.tsx new file mode 100644 index 00000000000000..ba5353677dfae5 --- /dev/null +++ b/docs/src/pages/components/grid/CSSGrid.tsx @@ -0,0 +1,84 @@ +import React from 'react'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; +import Typography from '@material-ui/core/Typography'; +import Paper from '@material-ui/core/Paper'; +import Divider from '@material-ui/core/Divider'; +import Grid from '@material-ui/core/Grid'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + container: { + display: 'grid', + gridTemplateColumns: 'repeat(12, 1fr)', + gridGap: theme.spacing(3), + }, + paper: { + padding: theme.spacing(1), + textAlign: 'center', + color: theme.palette.text.secondary, + whiteSpace: 'nowrap', + marginBottom: theme.spacing(1), + }, + divider: { + margin: theme.spacing(2, 0), + }, + }), +); + +function CSSGrid() { + const classes = useStyles(); + + return ( +
+ + Material-UI Grid: + + + + xs=3 + + + xs=3 + + + xs=3 + + + xs=3 + + + xs=8 + + + xs=4 + + + + + CSS Grid Layout: + +
+
+ xs=3 +
+
+ xs=3 +
+
+ xs=3 +
+
+ xs=3 +
+
+ xs=8 +
+
+ xs=4 +
+
+
+ ); +} + +export default CSSGrid; diff --git a/docs/src/pages/components/grid/CenteredGrid.js b/docs/src/pages/components/grid/CenteredGrid.js index a5cf198acc0e57..bfd11a47a4fc71 100644 --- a/docs/src/pages/components/grid/CenteredGrid.js +++ b/docs/src/pages/components/grid/CenteredGrid.js @@ -1,10 +1,9 @@ import React from 'react'; -import PropTypes from 'prop-types'; -import { withStyles } from '@material-ui/core/styles'; +import { makeStyles } from '@material-ui/core/styles'; import Paper from '@material-ui/core/Paper'; import Grid from '@material-ui/core/Grid'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ root: { flexGrow: 1, }, @@ -13,10 +12,10 @@ const styles = theme => ({ textAlign: 'center', color: theme.palette.text.secondary, }, -}); +})); -function CenteredGrid(props) { - const { classes } = props; +function CenteredGrid() { + const classes = useStyles(); return (
@@ -47,8 +46,4 @@ function CenteredGrid(props) { ); } -CenteredGrid.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(CenteredGrid); +export default CenteredGrid; diff --git a/docs/src/pages/components/grid/CenteredGrid.tsx b/docs/src/pages/components/grid/CenteredGrid.tsx new file mode 100644 index 00000000000000..25b3e77204b4f4 --- /dev/null +++ b/docs/src/pages/components/grid/CenteredGrid.tsx @@ -0,0 +1,51 @@ +import React from 'react'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; +import Paper from '@material-ui/core/Paper'; +import Grid from '@material-ui/core/Grid'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + root: { + flexGrow: 1, + }, + paper: { + padding: theme.spacing(2), + textAlign: 'center', + color: theme.palette.text.secondary, + }, + }), +); + +function CenteredGrid() { + const classes = useStyles(); + + return ( +
+ + + xs=12 + + + xs=6 + + + xs=6 + + + xs=3 + + + xs=3 + + + xs=3 + + + xs=3 + + +
+ ); +} + +export default CenteredGrid; diff --git a/docs/src/pages/components/grid/ComplexGrid.js b/docs/src/pages/components/grid/ComplexGrid.js index 3df1564aeec3b5..00821579c6919a 100644 --- a/docs/src/pages/components/grid/ComplexGrid.js +++ b/docs/src/pages/components/grid/ComplexGrid.js @@ -1,12 +1,11 @@ import React from 'react'; -import PropTypes from 'prop-types'; -import { withStyles } from '@material-ui/core/styles'; +import { makeStyles } from '@material-ui/core/styles'; import Grid from '@material-ui/core/Grid'; import Paper from '@material-ui/core/Paper'; import Typography from '@material-ui/core/Typography'; import ButtonBase from '@material-ui/core/ButtonBase'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ root: { flexGrow: 1, }, @@ -25,10 +24,11 @@ const styles = theme => ({ maxWidth: '100%', maxHeight: '100%', }, -}); +})); + +function ComplexGrid() { + const classes = useStyles(); -function ComplexGrid(props) { - const { classes } = props; return (
@@ -67,8 +67,4 @@ function ComplexGrid(props) { ); } -ComplexGrid.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(ComplexGrid); +export default ComplexGrid; diff --git a/docs/src/pages/components/grid/ComplexGrid.tsx b/docs/src/pages/components/grid/ComplexGrid.tsx new file mode 100644 index 00000000000000..5c8b64eb06f93a --- /dev/null +++ b/docs/src/pages/components/grid/ComplexGrid.tsx @@ -0,0 +1,72 @@ +import React from 'react'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; +import Grid from '@material-ui/core/Grid'; +import Paper from '@material-ui/core/Paper'; +import Typography from '@material-ui/core/Typography'; +import ButtonBase from '@material-ui/core/ButtonBase'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + root: { + flexGrow: 1, + }, + paper: { + padding: theme.spacing(2), + margin: 'auto', + maxWidth: 500, + }, + image: { + width: 128, + height: 128, + }, + img: { + margin: 'auto', + display: 'block', + maxWidth: '100%', + maxHeight: '100%', + }, + }), +); + +function ComplexGrid() { + const classes = useStyles(); + + return ( +
+ + + + + complex + + + + + + + Standard license + + + Full resolution 1920x1080 • JPEG + + + ID: 1030114 + + + + + Remove + + + + + $19.00 + + + + +
+ ); +} + +export default ComplexGrid; diff --git a/docs/src/pages/components/grid/FullWidthGrid.js b/docs/src/pages/components/grid/FullWidthGrid.js index 5664d56404d6b8..feb92a87e0316b 100644 --- a/docs/src/pages/components/grid/FullWidthGrid.js +++ b/docs/src/pages/components/grid/FullWidthGrid.js @@ -1,10 +1,9 @@ import React from 'react'; -import PropTypes from 'prop-types'; -import { withStyles } from '@material-ui/core/styles'; +import { makeStyles } from '@material-ui/core/styles'; import Paper from '@material-ui/core/Paper'; import Grid from '@material-ui/core/Grid'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ root: { flexGrow: 1, }, @@ -13,10 +12,10 @@ const styles = theme => ({ textAlign: 'center', color: theme.palette.text.secondary, }, -}); +})); -function FullWidthGrid(props) { - const { classes } = props; +function FullWidthGrid() { + const classes = useStyles(); return (
@@ -47,8 +46,4 @@ function FullWidthGrid(props) { ); } -FullWidthGrid.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(FullWidthGrid); +export default FullWidthGrid; diff --git a/docs/src/pages/components/grid/FullWidthGrid.tsx b/docs/src/pages/components/grid/FullWidthGrid.tsx new file mode 100644 index 00000000000000..cec133592850ed --- /dev/null +++ b/docs/src/pages/components/grid/FullWidthGrid.tsx @@ -0,0 +1,51 @@ +import React from 'react'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; +import Paper from '@material-ui/core/Paper'; +import Grid from '@material-ui/core/Grid'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + root: { + flexGrow: 1, + }, + paper: { + padding: theme.spacing(2), + textAlign: 'center', + color: theme.palette.text.secondary, + }, + }), +); + +function FullWidthGrid() { + const classes = useStyles(); + + return ( +
+ + + xs=12 + + + xs=12 sm=6 + + + xs=12 sm=6 + + + xs=6 sm=3 + + + xs=6 sm=3 + + + xs=6 sm=3 + + + xs=6 sm=3 + + +
+ ); +} + +export default FullWidthGrid; diff --git a/docs/src/pages/components/grid/InteractiveGrid.js b/docs/src/pages/components/grid/InteractiveGrid.js index 1bc27d01aac017..032f8f58a8cb7c 100644 --- a/docs/src/pages/components/grid/InteractiveGrid.js +++ b/docs/src/pages/components/grid/InteractiveGrid.js @@ -1,7 +1,4 @@ import React from 'react'; -import PropTypes from 'prop-types'; -import { withStyles } from '@material-ui/core/styles'; -import MarkdownElement from 'docs/src/modules/components/MarkdownElement'; import Grid from '@material-ui/core/Grid'; import FormControl from '@material-ui/core/FormControl'; import FormLabel from '@material-ui/core/FormLabel'; @@ -9,8 +6,14 @@ import FormControlLabel from '@material-ui/core/FormControlLabel'; import RadioGroup from '@material-ui/core/RadioGroup'; import Radio from '@material-ui/core/Radio'; import Paper from '@material-ui/core/Paper'; +import { makeStyles } from '@material-ui/core/styles'; + +// We don't have a typescript version of MarkdownElement +// tslint:disable-next-line: ban-ts-ignore +// @ts-ignore +import MarkdownElement from 'docs/src/modules/components/MarkdownElement'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ root: { flexGrow: 1, }, @@ -25,26 +28,15 @@ const styles = theme => ({ control: { padding: theme.spacing(2), }, -}); - -class InteractiveGrid extends React.Component { - state = { - direction: 'row', - justify: 'center', - alignItems: 'center', - }; - - handleChange = key => (event, value) => { - this.setState({ - [key]: value, - }); - }; +})); - render() { - const { classes } = this.props; - const { alignItems, direction, justify } = this.state; +function InteractiveGrid() { + const classes = useStyles(); + const [direction, setDirection] = React.useState('row'); + const [justify, setJustify] = React.useState('center'); + const [alignItems, setAlignItems] = React.useState('center'); - const code = ` + const code = ` \`\`\`jsx - - - {[0, 1, 2].map(value => ( - - - {`Cell ${value + 1}`} - - - ))} - - - - - - - - direction - - } label="row" /> - } label="row-reverse" /> - } label="column" /> - } - label="column-reverse" - /> - - - - - - justify - - } label="flex-start" /> - } label="center" /> - } label="flex-end" /> - } - label="space-between" - /> - } - label="space-around" - /> - } - label="space-evenly" - /> - - - - - - alignItems - - } label="flex-start" /> - } label="center" /> - } label="flex-end" /> - } label="stretch" /> - } label="baseline" /> - - - + return ( + + + + {[0, 1, 2].map(value => ( + + + {`Cell ${value + 1}`} + - - - - + ))} - ); - } + + + + + + direction + setDirection(value)} + > + } label="row" /> + } label="row-reverse" /> + } label="column" /> + } + label="column-reverse" + /> + + + + + + justify + setJustify(value)} + > + } label="flex-start" /> + } label="center" /> + } label="flex-end" /> + } + label="space-between" + /> + } label="space-around" /> + } label="space-evenly" /> + + + + + + alignItems + setAlignItems(value)} + > + } label="flex-start" /> + } label="center" /> + } label="flex-end" /> + } label="stretch" /> + } label="baseline" /> + + + + + + + + + + + ); } -InteractiveGrid.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(InteractiveGrid); +export default InteractiveGrid; diff --git a/docs/src/pages/components/grid/InteractiveGrid.tsx b/docs/src/pages/components/grid/InteractiveGrid.tsx new file mode 100644 index 00000000000000..52b2e90e55643f --- /dev/null +++ b/docs/src/pages/components/grid/InteractiveGrid.tsx @@ -0,0 +1,150 @@ +import React from 'react'; +import Grid, { GridItemsAlignment, GridJustification, GridDirection } from '@material-ui/core/Grid'; +import FormControl from '@material-ui/core/FormControl'; +import FormLabel from '@material-ui/core/FormLabel'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import RadioGroup from '@material-ui/core/RadioGroup'; +import Radio from '@material-ui/core/Radio'; +import Paper from '@material-ui/core/Paper'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; + +// We don't have a typescript version of MarkdownElement +// tslint:disable-next-line: ban-ts-ignore +// @ts-ignore +import MarkdownElement from 'docs/src/modules/components/MarkdownElement'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + root: { + flexGrow: 1, + }, + demo: { + height: 240, + }, + paper: { + padding: theme.spacing(2), + height: '100%', + color: theme.palette.text.secondary, + }, + control: { + padding: theme.spacing(2), + }, + }), +); + +function InteractiveGrid() { + const classes = useStyles(); + const [direction, setDirection] = React.useState('row'); + const [justify, setJustify] = React.useState('center'); + const [alignItems, setAlignItems] = React.useState('center'); + + const code = ` +\`\`\`jsx + +\`\`\` +`; + + return ( + + + + {[0, 1, 2].map(value => ( + + + {`Cell ${value + 1}`} + + + ))} + + + + + + + + direction + setDirection(value as GridDirection)} + > + } label="row" /> + } label="row-reverse" /> + } label="column" /> + } + label="column-reverse" + /> + + + + + + justify + setJustify(value as GridJustification)} + > + } label="flex-start" /> + } label="center" /> + } label="flex-end" /> + } + label="space-between" + /> + } label="space-around" /> + } label="space-evenly" /> + + + + + + alignItems + setAlignItems(value as GridItemsAlignment)} + > + } label="flex-start" /> + } label="center" /> + } label="flex-end" /> + } label="stretch" /> + } label="baseline" /> + + + + + + + + + + + ); +} + +export default InteractiveGrid; diff --git a/docs/src/pages/components/grid/NestedGrid.js b/docs/src/pages/components/grid/NestedGrid.js index 08b0747cec2e83..07a316efe546ea 100644 --- a/docs/src/pages/components/grid/NestedGrid.js +++ b/docs/src/pages/components/grid/NestedGrid.js @@ -1,10 +1,9 @@ import React from 'react'; -import PropTypes from 'prop-types'; -import { withStyles } from '@material-ui/core/styles'; +import { makeStyles } from '@material-ui/core/styles'; import Paper from '@material-ui/core/Paper'; import Grid from '@material-ui/core/Grid'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ root: { flexGrow: 1, }, @@ -13,52 +12,42 @@ const styles = theme => ({ textAlign: 'center', color: theme.palette.text.secondary, }, -}); +})); -function FormRow(props) { - const { classes } = props; +function NestedGrid() { + const classes = useStyles(); - return ( - - - item - - - item - - - item - - - ); -} - -FormRow.propTypes = { - classes: PropTypes.object.isRequired, -}; - -function NestedGrid(props) { - const { classes } = props; + function FormRow() { + return ( + + + item + + + item + + + item + + + ); + } return (
- + - + - +
); } -NestedGrid.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(NestedGrid); +export default NestedGrid; diff --git a/docs/src/pages/components/grid/NestedGrid.tsx b/docs/src/pages/components/grid/NestedGrid.tsx new file mode 100644 index 00000000000000..674bc984207afb --- /dev/null +++ b/docs/src/pages/components/grid/NestedGrid.tsx @@ -0,0 +1,55 @@ +import React from 'react'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; +import Paper from '@material-ui/core/Paper'; +import Grid from '@material-ui/core/Grid'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + root: { + flexGrow: 1, + }, + paper: { + padding: theme.spacing(1), + textAlign: 'center', + color: theme.palette.text.secondary, + }, + }), +); + +function NestedGrid() { + const classes = useStyles(); + + function FormRow() { + return ( + + + item + + + item + + + item + + + ); + } + + return ( +
+ + + + + + + + + + + +
+ ); +} + +export default NestedGrid; diff --git a/docs/src/pages/components/grid/SpacingGrid.js b/docs/src/pages/components/grid/SpacingGrid.js index 3c419995e4e1c6..8631c8df81b8b0 100644 --- a/docs/src/pages/components/grid/SpacingGrid.js +++ b/docs/src/pages/components/grid/SpacingGrid.js @@ -1,6 +1,5 @@ import React from 'react'; -import PropTypes from 'prop-types'; -import { withStyles } from '@material-ui/core/styles'; +import { makeStyles } from '@material-ui/core/styles'; import Grid from '@material-ui/core/Grid'; import FormLabel from '@material-ui/core/FormLabel'; import FormControlLabel from '@material-ui/core/FormControlLabel'; @@ -8,7 +7,7 @@ import RadioGroup from '@material-ui/core/RadioGroup'; import Radio from '@material-ui/core/Radio'; import Paper from '@material-ui/core/Paper'; -const styles = theme => ({ +const useStyles = makeStyles(theme => ({ root: { flexGrow: 1, }, @@ -19,69 +18,51 @@ const styles = theme => ({ control: { padding: theme.spacing(2), }, -}); +})); -class GuttersGrid extends React.Component { - state = { - spacing: '2', - }; +function GuttersGrid() { + const [spacing, setSpacing] = React.useState(2); + const classes = useStyles(); - handleChange = key => (event, value) => { - this.setState({ - [key]: value, - }); - }; - - render() { - const { classes } = this.props; - const { spacing } = this.state; + function handleChange(event, value) { + setSpacing(Number(value)); + } - return ( - - - - {[0, 1, 2].map(value => ( - - - - ))} - - - - - - - spacing - - } label="0" /> - } label="1" /> - } label="2" /> - } label="3" /> - } label="4" /> - } label="5" /> - } label="6" /> - } label="7" /> - } label="8" /> - } label="9" /> - } label="10" /> - - + return ( + + + + {[0, 1, 2].map(value => ( + + - + ))} - ); - } + + + + + spacing + + {Array(10) + .fill(0) + .map((value, index) => ( + } label={index} /> + ))} + + + + + +
+ ); } -GuttersGrid.propTypes = { - classes: PropTypes.object.isRequired, -}; - -export default withStyles(styles)(GuttersGrid); +export default GuttersGrid; diff --git a/docs/src/pages/components/grid/SpacingGrid.tsx b/docs/src/pages/components/grid/SpacingGrid.tsx new file mode 100644 index 00000000000000..287743184066d8 --- /dev/null +++ b/docs/src/pages/components/grid/SpacingGrid.tsx @@ -0,0 +1,70 @@ +import React from 'react'; +import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; +import Grid, { GridSpacing } from '@material-ui/core/Grid'; +import FormLabel from '@material-ui/core/FormLabel'; +import FormControlLabel from '@material-ui/core/FormControlLabel'; +import RadioGroup from '@material-ui/core/RadioGroup'; +import Radio from '@material-ui/core/Radio'; +import Paper from '@material-ui/core/Paper'; + +const useStyles = makeStyles((theme: Theme) => + createStyles({ + root: { + flexGrow: 1, + }, + paper: { + height: 140, + width: 100, + }, + control: { + padding: theme.spacing(2), + }, + }), +); + +function GuttersGrid() { + const [spacing, setSpacing] = React.useState(2); + const classes = useStyles(); + + function handleChange(event: any, value: string) { + setSpacing(Number(value) as GridSpacing); + } + + return ( + + + + {[0, 1, 2].map(value => ( + + + + ))} + + + + + + + spacing + + {Array(10) + .fill(0) + .map((value, index) => ( + } label={index} /> + ))} + + + + + + + ); +} + +export default GuttersGrid; From ba1a60b0375f0d50dd0a9d3df8838110c5b6b345 Mon Sep 17 00:00:00 2001 From: merceyz Date: Fri, 31 May 2019 03:37:16 +0200 Subject: [PATCH 2/6] [docs] Fix complaints --- docs/src/pages/components/grid/InteractiveGrid.js | 1 - docs/src/pages/components/grid/InteractiveGrid.tsx | 1 - docs/src/pages/components/grid/SpacingGrid.js | 8 +++----- docs/src/pages/components/grid/SpacingGrid.tsx | 8 +++----- 4 files changed, 6 insertions(+), 12 deletions(-) diff --git a/docs/src/pages/components/grid/InteractiveGrid.js b/docs/src/pages/components/grid/InteractiveGrid.js index 032f8f58a8cb7c..cf70ffe54d8b6a 100644 --- a/docs/src/pages/components/grid/InteractiveGrid.js +++ b/docs/src/pages/components/grid/InteractiveGrid.js @@ -7,7 +7,6 @@ import RadioGroup from '@material-ui/core/RadioGroup'; import Radio from '@material-ui/core/Radio'; import Paper from '@material-ui/core/Paper'; import { makeStyles } from '@material-ui/core/styles'; - // We don't have a typescript version of MarkdownElement // tslint:disable-next-line: ban-ts-ignore // @ts-ignore diff --git a/docs/src/pages/components/grid/InteractiveGrid.tsx b/docs/src/pages/components/grid/InteractiveGrid.tsx index 52b2e90e55643f..f9e4fe338aa4ed 100644 --- a/docs/src/pages/components/grid/InteractiveGrid.tsx +++ b/docs/src/pages/components/grid/InteractiveGrid.tsx @@ -7,7 +7,6 @@ import RadioGroup from '@material-ui/core/RadioGroup'; import Radio from '@material-ui/core/Radio'; import Paper from '@material-ui/core/Paper'; import { makeStyles, createStyles, Theme } from '@material-ui/core/styles'; - // We don't have a typescript version of MarkdownElement // tslint:disable-next-line: ban-ts-ignore // @ts-ignore diff --git a/docs/src/pages/components/grid/SpacingGrid.js b/docs/src/pages/components/grid/SpacingGrid.js index 8631c8df81b8b0..f5ece9cb857c0f 100644 --- a/docs/src/pages/components/grid/SpacingGrid.js +++ b/docs/src/pages/components/grid/SpacingGrid.js @@ -51,11 +51,9 @@ function GuttersGrid() { onChange={handleChange} row > - {Array(10) - .fill(0) - .map((value, index) => ( - } label={index} /> - ))} + {[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(value => ( + } label={value} /> + ))} diff --git a/docs/src/pages/components/grid/SpacingGrid.tsx b/docs/src/pages/components/grid/SpacingGrid.tsx index 287743184066d8..dd21f26b46563d 100644 --- a/docs/src/pages/components/grid/SpacingGrid.tsx +++ b/docs/src/pages/components/grid/SpacingGrid.tsx @@ -53,11 +53,9 @@ function GuttersGrid() { onChange={handleChange} row > - {Array(10) - .fill(0) - .map((value, index) => ( - } label={index} /> - ))} + {[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(value => ( + } label={value} /> + ))} From f00aa2dbcd377e2b742ed6f22db28e42894981f8 Mon Sep 17 00:00:00 2001 From: merceyz Date: Fri, 31 May 2019 04:01:32 +0200 Subject: [PATCH 3/6] [docs] number to string --- docs/src/pages/components/grid/SpacingGrid.js | 7 ++++++- docs/src/pages/components/grid/SpacingGrid.tsx | 7 ++++++- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/docs/src/pages/components/grid/SpacingGrid.js b/docs/src/pages/components/grid/SpacingGrid.js index f5ece9cb857c0f..d0f953711b2070 100644 --- a/docs/src/pages/components/grid/SpacingGrid.js +++ b/docs/src/pages/components/grid/SpacingGrid.js @@ -52,7 +52,12 @@ function GuttersGrid() { row > {[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(value => ( - } label={value} /> + } + label={value.toString()} + /> ))} diff --git a/docs/src/pages/components/grid/SpacingGrid.tsx b/docs/src/pages/components/grid/SpacingGrid.tsx index dd21f26b46563d..e199d2f8d7b93e 100644 --- a/docs/src/pages/components/grid/SpacingGrid.tsx +++ b/docs/src/pages/components/grid/SpacingGrid.tsx @@ -54,7 +54,12 @@ function GuttersGrid() { row > {[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10].map(value => ( - } label={value} /> + } + label={value.toString()} + /> ))} From 4e3f1cf61fe2f3ef945f16192598e86265764051 Mon Sep 17 00:00:00 2001 From: Kristoffer K Date: Fri, 31 May 2019 13:24:01 +0200 Subject: [PATCH 4/6] Update docs/src/pages/components/grid/SpacingGrid.tsx Co-Authored-By: Olivier Tassinari --- docs/src/pages/components/grid/SpacingGrid.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/src/pages/components/grid/SpacingGrid.tsx b/docs/src/pages/components/grid/SpacingGrid.tsx index e199d2f8d7b93e..c85193466b996b 100644 --- a/docs/src/pages/components/grid/SpacingGrid.tsx +++ b/docs/src/pages/components/grid/SpacingGrid.tsx @@ -70,4 +70,4 @@ function GuttersGrid() { ); } -export default GuttersGrid; +export default SpacingGrid; From 2a3b2d3ca04f2e0a5e50af8d6bdb97f6d05f2bba Mon Sep 17 00:00:00 2001 From: merceyz Date: Fri, 31 May 2019 14:13:40 +0200 Subject: [PATCH 5/6] docs:typescript:formatted --- docs/src/pages/components/grid/SpacingGrid.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/src/pages/components/grid/SpacingGrid.js b/docs/src/pages/components/grid/SpacingGrid.js index d0f953711b2070..8ddf9ee6a18e5d 100644 --- a/docs/src/pages/components/grid/SpacingGrid.js +++ b/docs/src/pages/components/grid/SpacingGrid.js @@ -68,4 +68,4 @@ function GuttersGrid() { ); } -export default GuttersGrid; +export default SpacingGrid; From 3b3b644a2512f8105cf0cf3e0fc74e7a94fb6688 Mon Sep 17 00:00:00 2001 From: merceyz Date: Fri, 31 May 2019 14:24:42 +0200 Subject: [PATCH 6/6] Fix name --- docs/src/pages/components/grid/SpacingGrid.js | 2 +- docs/src/pages/components/grid/SpacingGrid.tsx | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/src/pages/components/grid/SpacingGrid.js b/docs/src/pages/components/grid/SpacingGrid.js index 8ddf9ee6a18e5d..c2842de1f6b917 100644 --- a/docs/src/pages/components/grid/SpacingGrid.js +++ b/docs/src/pages/components/grid/SpacingGrid.js @@ -20,7 +20,7 @@ const useStyles = makeStyles(theme => ({ }, })); -function GuttersGrid() { +function SpacingGrid() { const [spacing, setSpacing] = React.useState(2); const classes = useStyles(); diff --git a/docs/src/pages/components/grid/SpacingGrid.tsx b/docs/src/pages/components/grid/SpacingGrid.tsx index c85193466b996b..62ad9d8375f7e2 100644 --- a/docs/src/pages/components/grid/SpacingGrid.tsx +++ b/docs/src/pages/components/grid/SpacingGrid.tsx @@ -22,7 +22,7 @@ const useStyles = makeStyles((theme: Theme) => }), ); -function GuttersGrid() { +function SpacingGrid() { const [spacing, setSpacing] = React.useState(2); const classes = useStyles();