Browse Source

Shift out examples content

main
Tay Yang Shun 7 years ago
parent
commit
57baeb1298
  1. 7
      content/examples/a-component-using-external-plugins.md
  2. 9
      content/examples/a-simple-component.md
  3. 7
      content/examples/a-stateful-component.md
  4. 7
      content/examples/an-application.md
  5. 156
      src/pages/index.js

7
content/examples/a-component-using-external-plugins.md

@ -0,0 +1,7 @@
---
title: A Component Using External Plugins
order: 3
example_name: markdownExample
---
React is flexible and provides hooks that allow you to interface with other libraries and frameworks. This example uses **remarkable**, an external Markdown library, to convert the `<textarea>`'s value in real time.

9
content/examples/a-simple-component.md

@ -0,0 +1,9 @@
---
title: A Simple Component
order: 0
example_name: helloExample
---
React components implement a `render()` method that takes input data and returns what to display. This example uses an XML-like syntax called JSX. Input data that is passed into the component can be accessed by `render()` via `this.props`.
**JSX is optional and not required to use React.** Try the [Babel REPL](http://babeljs.io/repl#?babili=false&browsers=&build=&builtIns=false&code_lz=MYGwhgzhAEASCmIQHsCy8pgOb2vAHgC7wB2AJjAErxjCEB0AwsgLYAOyJph0A3gFABIAE6ky8YQAoAlHyEj4hAK7CS0ADxkAlgDcAfAiTI-hABZaI9NsORtLJMC3gBfdQHpt-gNxDn_P_zUtIQAIgDyqPSi5BKS6oYo6Jg40A5OALwARCHwOlokmdBuegA00CzISiSEAHLI4tJeQA&debug=false&circleciRepo=&evaluate=false&lineWrap=false&presets=react&prettier=true&targets=&version=6.26.0) to see the raw JavaScript code produced by the JSX compilation step.

7
content/examples/a-stateful-component.md

@ -0,0 +1,7 @@
---
title: A Stateful Component
order: 1
example_name: timerExample
---
In addition to taking input data (accessed via `this.props`), a component can maintain internal state data (accessed via `this.state`). When a component's state data changes, the rendered markup will be updated by re-invoking `render()`.

7
content/examples/an-application.md

@ -0,0 +1,7 @@
---
title: An Application
order: 2
example_name: todoExample
---
Using `props` and `state`, we can put together a small Todo application. This example uses `state` to track the current list of items as well as the text that the user has entered. Although event handlers appear to be rendered inline, they will be collected and implemented using event delegation.

156
src/pages/index.js

@ -43,10 +43,15 @@ class Home extends Component {
render() { render() {
const {data} = this.props; const {data} = this.props;
const title = 'React - A JavaScript library for building user interfaces'; const title = 'React - A JavaScript library for building user interfaces';
const marketingColumns = data.allMarkdownRemark.edges.map(edge => ({ const marketingContent = data.marketing.edges.map(edge => ({
title: edge.node.frontmatter.title, title: edge.node.frontmatter.title,
content: edge.node.html, content: edge.node.html,
})); }));
const examplesContent = data.examples.edges.map(edge => ({
title: edge.node.frontmatter.title,
name: edge.node.frontmatter.example_name,
content: edge.node.html,
}));
return ( return (
<div css={{width: '100%'}}> <div css={{width: '100%'}}>
@ -142,7 +147,7 @@ class Home extends Component {
</header> </header>
<Container> <Container>
<div css={[sharedStyles.markdown, markdownStyles]}> <div css={sharedStyles.markdown}>
<section <section
css={[ css={[
sectionStyles, sectionStyles,
@ -169,7 +174,7 @@ class Home extends Component {
whiteSpace: 'nowrap', whiteSpace: 'nowrap',
}, },
}}> }}>
{marketingColumns.map((column, index) => ( {marketingContent.map((column, index) => (
<div <div
key={index} key={index}
css={{ css={{
@ -199,27 +204,25 @@ class Home extends Component {
marginTop: 0, marginTop: 0,
}, },
}, },
'& p': {
lineHeight: 1.7,
},
}}> }}>
<h3 <h3
css={{ css={[
'&&': { headingStyles,
// Make specificity higher than the site-wide h3 styles. {
color: colors.subtle, '&&': {
marginBottom: 20, // Make specificity higher than the site-wide h3 styles.
paddingTop: 0, color: colors.subtle,
fontWeight: 300, paddingTop: 0,
fontSize: 20, fontWeight: 300,
fontSize: 20,
[media.greaterThan('xlarge')]: {
fontSize: 24, [media.greaterThan('xlarge')]: {
fontWeight: 200, fontSize: 24,
fontWeight: 200,
},
}, },
}, },
}}> ]}>
{column.title} {column.title}
</h3> </h3>
<div dangerouslySetInnerHTML={{__html: column.content}} /> <div dangerouslySetInnerHTML={{__html: column.content}} />
@ -237,60 +240,25 @@ class Home extends Component {
/> />
<section css={sectionStyles}> <section css={sectionStyles}>
<div id="examples"> <div id="examples">
<div className="example"> {examplesContent.map((example, index) => (
<h3>A Simple Component</h3> <div
<p> key={index}
React components implement a `render()` method that takes css={{
input data and returns what to display. This example uses an marginTop: 40,
XML-like syntax called JSX. Input data that is passed into
the component can be accessed by `render()` via '&:first-child': {
`this.props`. marginTop: 0,
</p> },
<p>
<strong> [media.greaterThan('xlarge')]: {
JSX is optional and not required to use React. marginTop: 80,
</strong>{' '} },
Try the{' '} }}>
<a href="http://babeljs.io/repl#?babili=false&browsers=&build=&builtIns=false&code_lz=MYGwhgzhAEASCmIQHsCy8pgOb2vAHgC7wB2AJjAErxjCEB0AwsgLYAOyJph0A3gFABIAE6ky8YQAoAlHyEj4hAK7CS0ADxkAlgDcAfAiTI-hABZaI9NsORtLJMC3gBfdQHpt-gNxDn_P_zUtIQAIgDyqPSi5BKS6oYo6Jg40A5OALwARCHwOlokmdBuegA00CzISiSEAHLI4tJeQA&debug=false&circleciRepo=&evaluate=false&lineWrap=false&presets=react&prettier=true&targets=&version=6.26.0"> <h3 css={headingStyles}>{example.title}</h3>
Babel REPL <div dangerouslySetInnerHTML={{__html: example.content}} />
</a>{' '} <div id={example.name} />
to see the raw JavaScript code produced by the JSX </div>
compilation step. ))}
</p>
<div id="helloExample" />
</div>
<div className="example">
<h3>A Stateful Component</h3>
<p>
In addition to taking input data (accessed via
`this.props`), a component can maintain internal state data
(accessed via `this.state`). When a component's state data
changes, the rendered markup will be updated by re-invoking
`render()`.
</p>
<div id="timerExample" />
</div>
<div className="example">
<h3>An Application</h3>
<p>
Using `props` and `state`, we can put together a small Todo
application. This example uses `state` to track the current
list of items as well as the text that the user has entered.
Although event handlers appear to be rendered inline, they
will be collected and implemented using event delegation.
</p>
<div id="todoExample" />
</div>
<div className="example">
<h3>A Component Using External Plugins</h3>
<p>
React is flexible and provides hooks that allow you to
interface with other libraries and frameworks. This example
uses <strong>remarkable</strong>, an external Markdown
library, to convert the textarea's value in real time.
</p>
<div id="markdownExample" />
</div>
</div> </div>
</section> </section>
</div> </div>
@ -324,7 +292,10 @@ class Home extends Component {
} }
Home.propTypes = { Home.propTypes = {
data: PropTypes.object.isRequired, data: PropTypes.shape({
marketing: PropTypes.object.isRequired,
examples: PropTypes.object.isRequired,
}).isRequired,
location: PropTypes.object.isRequired, location: PropTypes.object.isRequired,
}; };
@ -368,15 +339,29 @@ const CtaItem = ({children, primary = false}) => (
// eslint-disable-next-line no-undef // eslint-disable-next-line no-undef
export const pageQuery = graphql` export const pageQuery = graphql`
query MarketingMarkdown { query IndexMarkdown {
allMarkdownRemark( marketing: allMarkdownRemark(
filter: {id: {regex: "/marketing/"}} filter: {id: {regex: "//marketing//"}}
sort: {fields: [frontmatter___order], order: ASC}
) {
edges {
node {
frontmatter {
title
}
html
}
}
}
examples: allMarkdownRemark(
filter: {id: {regex: "//examples//"}}
sort: {fields: [frontmatter___order], order: ASC} sort: {fields: [frontmatter___order], order: ASC}
) { ) {
edges { edges {
node { node {
frontmatter { frontmatter {
title title
example_name
} }
html html
} }
@ -397,18 +382,9 @@ const sectionStyles = {
}, },
}; };
// TODO This nasty CSS is required because 'docs/index.md' defines hard-coded class names. const headingStyles = {
const markdownStyles = { '&&': {
'& .example': { marginBottom: 20,
marginTop: 40,
'&:first-child': {
marginTop: 0,
},
[media.greaterThan('xlarge')]: {
marginTop: 80,
},
}, },
}; };

Loading…
Cancel
Save