mirror of
https://github.com/terribleplan/next.js.git
synced 2024-01-19 02:48:18 +00:00
Merge branch 'master' of https://github.com/zeit/next.js
This commit is contained in:
commit
7dfc298859
28
Readme.md
28
Readme.md
|
@ -40,21 +40,24 @@ That means pages never load unneccessary code!
|
|||
|
||||
### CSS
|
||||
|
||||
We use [Aphrodite](https://github.com/Khan/aphrodite) to provide a great built-in solution for CSS modularization
|
||||
We use [glamor](https://github.com/threepointone/glamor) to provide a great built-in solution for CSS isolation and modularization without trading off any CSS features
|
||||
|
||||
```jsx
|
||||
import React from 'react'
|
||||
import { css, StyleSheet } from 'next/css'
|
||||
import { style } from 'next/css'
|
||||
|
||||
export default () => (
|
||||
<div className={ css(styles.main) }>
|
||||
<div className={style}>
|
||||
Hello world
|
||||
</div>
|
||||
)
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
const style = style({
|
||||
main: {
|
||||
background: 'red',
|
||||
':hover': {
|
||||
background: 'gray'
|
||||
}
|
||||
'@media (max-width: 600px)': {
|
||||
background: 'blue'
|
||||
}
|
||||
|
@ -80,9 +83,9 @@ export default () => (
|
|||
)
|
||||
```
|
||||
|
||||
### Stateful components
|
||||
### Lifecycle components
|
||||
|
||||
When state, lifecycle hooks or initial data population you can export a `React.Component`:
|
||||
When you need state, lifecycle hooks or **initial data population** you can export a `React.Component`:
|
||||
|
||||
```jsx
|
||||
import React from 'react'
|
||||
|
@ -92,7 +95,6 @@ export default class extends React.Component {
|
|||
? { userAgent: req.headers.userAgent }
|
||||
: { userAgent: navigator.userAgent }
|
||||
}
|
||||
|
||||
render () {
|
||||
return <div>
|
||||
Hello World {this.props.userAgent}
|
||||
|
@ -160,16 +162,16 @@ export default class Error extends React.Component {
|
|||
}
|
||||
```
|
||||
|
||||
### Production deployment
|
||||
## Production deployment
|
||||
|
||||
To deploy, run:
|
||||
To deploy, instead of running `next`, you probably want to build ahead of time. Therefore, building and starting are separate commands:
|
||||
|
||||
```bash
|
||||
next build
|
||||
next start
|
||||
```
|
||||
|
||||
For example, to deploy with `now` a `package.json` like follows is recommended:
|
||||
For example, to deploy with [`now`](https://zeit.co/now) a `package.json` like follows is recommended:
|
||||
|
||||
```json
|
||||
{
|
||||
|
@ -185,7 +187,11 @@ For example, to deploy with `now` a `package.json` like follows is recommended:
|
|||
}
|
||||
```
|
||||
|
||||
### In progress
|
||||
Then run `now` and enjoy!
|
||||
|
||||
Note: we recommend putting `.next` in `.npmignore` or `.gitigore`. Otherwise, use `files` or `now.files` to opt-into a whitelist of files you want to deploy (and obviously exclude `.next`)
|
||||
|
||||
## FAQ
|
||||
|
||||
The following tasks are planned and part of our roadmap
|
||||
|
||||
|
|
|
@ -1,11 +1,11 @@
|
|||
import React, { Component } from 'react'
|
||||
import { StyleSheet, css } from 'next/css'
|
||||
import { style } from 'next/css'
|
||||
|
||||
export default class CrazyCSS extends Component {
|
||||
spans () {
|
||||
const out = []
|
||||
for (let i = 0; i < 1000; i++) {
|
||||
out.push(<span key={i} class={css(styles[`padding-${i}`])}>This is ${i}</span>)
|
||||
out.push(<span key={i} class={spanStyles[`padding-${i}`]}>This is ${i}</span>)
|
||||
}
|
||||
return out
|
||||
}
|
||||
|
@ -17,7 +17,5 @@ export default class CrazyCSS extends Component {
|
|||
|
||||
const spanStyles = {}
|
||||
for (let i = 0; i < 1000; i++) {
|
||||
spanStyles[`padding-${i}`] = { padding: i }
|
||||
spanStyles[`padding-${i}`] = style({ padding: i })
|
||||
}
|
||||
|
||||
const styles = StyleSheet.create(spanStyles)
|
||||
|
|
|
@ -1,13 +1,13 @@
|
|||
import { createElement } from 'react'
|
||||
import { render } from 'react-dom'
|
||||
import HeadManager from './head-manager'
|
||||
import { StyleSheet } from '../lib/css'
|
||||
import { rehydrate } from '../lib/css'
|
||||
import Router from '../lib/router'
|
||||
import DefaultApp from '../lib/app'
|
||||
import evalScript from '../lib/eval-script'
|
||||
|
||||
const {
|
||||
__NEXT_DATA__: { app, component, props, classNames, err }
|
||||
__NEXT_DATA__: { app, component, props, ids, err }
|
||||
} = window
|
||||
|
||||
const App = app ? evalScript(app).default : DefaultApp
|
||||
|
@ -19,5 +19,5 @@ const headManager = new HeadManager()
|
|||
const container = document.getElementById('__next')
|
||||
const appProps = { Component, props, router, headManager }
|
||||
|
||||
StyleSheet.rehydrate(classNames)
|
||||
rehydrate(ids)
|
||||
render(createElement(App, appProps), container)
|
||||
|
|
|
@ -1,14 +1,13 @@
|
|||
import React from 'react'
|
||||
import { css, StyleSheet } from 'next/css'
|
||||
import { style } from 'next/css'
|
||||
|
||||
export default () => (
|
||||
<div className={css(styles.main)}>
|
||||
<div className={styles}>
|
||||
<p>Hello World</p>
|
||||
</div>
|
||||
)
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
main: {
|
||||
const styles = style({
|
||||
font: '15px Helvetica, Arial, sans-serif',
|
||||
background: '#eee',
|
||||
padding: '100px',
|
||||
|
@ -17,5 +16,4 @@ const styles = StyleSheet.create({
|
|||
':hover': {
|
||||
background: '#ccc'
|
||||
}
|
||||
}
|
||||
})
|
||||
|
|
|
@ -1,13 +1,11 @@
|
|||
import React from 'react'
|
||||
import { css, StyleSheet } from 'next/css'
|
||||
import { style } from 'next/css'
|
||||
|
||||
export default ({ children }) => (
|
||||
<p className={css(styles.main)}>{children}</p>
|
||||
<p className={styles}>{children}</p>
|
||||
)
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
main: {
|
||||
const styles = style({
|
||||
font: '13px Helvetica, Arial',
|
||||
margin: '10px 0'
|
||||
}
|
||||
})
|
||||
|
|
|
@ -1,23 +1,21 @@
|
|||
import React from 'react'
|
||||
import { css, StyleSheet } from 'next/css'
|
||||
import { style } from 'next/css'
|
||||
|
||||
export default ({ title, children }) => (
|
||||
<div className={css(styles.main)}>
|
||||
<h1 className={css(styles.title)}>{ title }</h1>
|
||||
<div className={mainStyle}>
|
||||
<h1 className={titleStyle}>{ title }</h1>
|
||||
{ children }
|
||||
</div>
|
||||
)
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
main: {
|
||||
const mainStyle = style({
|
||||
font: '15px Helvetica, Arial',
|
||||
border: '1px solid #eee',
|
||||
padding: '0 10px'
|
||||
},
|
||||
})
|
||||
|
||||
title: {
|
||||
const titleStyle = style({
|
||||
fontSize: '16px',
|
||||
fontWeight: 'bold',
|
||||
margin: '10px 0'
|
||||
}
|
||||
})
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
import React from 'react'
|
||||
import P from '../components/paragraph'
|
||||
import Post from '../components/post'
|
||||
import { css, StyleSheet } from 'next/css'
|
||||
import { style } from 'next/css'
|
||||
|
||||
export default () => (
|
||||
<div className={css(styles.main)}>
|
||||
<div className={styles.main}>
|
||||
<Post title='My first blog post'>
|
||||
<P>Hello there</P>
|
||||
<P>This is an example of a componentized blog post</P>
|
||||
|
@ -26,23 +26,23 @@ export default () => (
|
|||
</div>
|
||||
)
|
||||
|
||||
const Hr = () => <hr className={css(styles.hr)} />
|
||||
const Hr = () => <hr className={styles.hr} />
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
main: {
|
||||
const styles = {
|
||||
main: style({
|
||||
margin: 'auto',
|
||||
maxWidth: '420px',
|
||||
padding: '10px'
|
||||
},
|
||||
}),
|
||||
|
||||
hr: {
|
||||
hr: style({
|
||||
width: '100px',
|
||||
borderWidth: 0,
|
||||
margin: '20px auto',
|
||||
textAlign: 'center',
|
||||
':before': {
|
||||
'::before': {
|
||||
content: '"***"',
|
||||
color: '#ccc'
|
||||
}
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
|
|
|
@ -1 +1 @@
|
|||
module.exports = require('aphrodite')
|
||||
module.exports = require('glamor')
|
||||
|
|
|
@ -5,7 +5,7 @@ export default ({ head, css, html, data, dev, staticMarkup }) => {
|
|||
return <html>
|
||||
<head>
|
||||
{(head || []).map((h, i) => React.cloneElement(h, { key: i }))}
|
||||
<style data-aphrodite='' dangerouslySetInnerHTML={{ __html: css.content }} />
|
||||
<style dangerouslySetInnerHTML={{ __html: css }} />
|
||||
</head>
|
||||
<body>
|
||||
<div id='__next' dangerouslySetInnerHTML={{ __html: html }} />
|
||||
|
|
|
@ -2,7 +2,7 @@ import React from 'react'
|
|||
import ReactDOM from 'react-dom'
|
||||
import App from '../lib/app'
|
||||
import Link from '../lib/link'
|
||||
import Css from '../lib/css'
|
||||
import * as Css from '../lib/css'
|
||||
import Head from '../lib/head'
|
||||
|
||||
const modules = new Map([
|
||||
|
|
|
@ -17,7 +17,6 @@
|
|||
"precommit": "npm run lint"
|
||||
},
|
||||
"dependencies": {
|
||||
"aphrodite": "0.5.0",
|
||||
"babel-core": "6.17.0",
|
||||
"babel-generator": "6.17.0",
|
||||
"babel-loader": "6.2.5",
|
||||
|
@ -31,6 +30,7 @@
|
|||
"babel-runtime": "6.11.6",
|
||||
"cross-spawn": "4.0.2",
|
||||
"del": "2.2.2",
|
||||
"glamor": "2.17.10",
|
||||
"glob-promise": "1.0.6",
|
||||
"htmlescape": "1.1.1",
|
||||
"loader-utils": "0.2.16",
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
import React from 'react'
|
||||
import stripAnsi from 'strip-ansi'
|
||||
import Head from 'next/head'
|
||||
import { css, StyleSheet } from 'next/css'
|
||||
import { style } from 'next/css'
|
||||
|
||||
export default class ErrorDebug extends React.Component {
|
||||
static getInitialProps ({ err }) {
|
||||
|
@ -12,7 +12,7 @@ export default class ErrorDebug extends React.Component {
|
|||
render () {
|
||||
const { message, path } = this.props
|
||||
|
||||
return <div className={css(styles.errorDebug)}>
|
||||
return <div className={styles.errorDebug}>
|
||||
<Head>
|
||||
<style dangerouslySetInnerHTML={{ __html: `
|
||||
body {
|
||||
|
@ -21,48 +21,36 @@ export default class ErrorDebug extends React.Component {
|
|||
}
|
||||
`}} />
|
||||
</Head>
|
||||
<div className={css(styles.heading)}>Error in {path}</div>
|
||||
<pre className={css(styles.message)}>{stripAnsi(message)}</pre>
|
||||
<div className={styles.heading}>Error in {path}</div>
|
||||
<pre className={styles.message}>{stripAnsi(message)}</pre>
|
||||
</div>
|
||||
}
|
||||
}
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
body: {
|
||||
const styles = {
|
||||
body: style({
|
||||
background: '#dc0067',
|
||||
margin: 0
|
||||
},
|
||||
}),
|
||||
|
||||
errorDebug: {
|
||||
errorDebug: style({
|
||||
height: '100%',
|
||||
padding: '16px',
|
||||
boxSizing: 'border-box'
|
||||
},
|
||||
}),
|
||||
|
||||
message: {
|
||||
message: style({
|
||||
fontFamily: 'menlo-regular',
|
||||
fontSize: '10px',
|
||||
color: '#fff',
|
||||
margin: 0
|
||||
},
|
||||
}),
|
||||
|
||||
heading: {
|
||||
heading: style({
|
||||
fontFamily: 'sans-serif',
|
||||
fontSize: '13px',
|
||||
fontWeight: 'bold',
|
||||
color: '#ff90c6',
|
||||
marginBottom: '20px'
|
||||
},
|
||||
|
||||
token: {
|
||||
backgroundColor: '#000'
|
||||
},
|
||||
|
||||
marker: {
|
||||
color: '#000'
|
||||
},
|
||||
|
||||
dim: {
|
||||
color: '#e85b9b'
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
import React from 'react'
|
||||
import { css, StyleSheet } from 'next/css'
|
||||
import { style, merge } from 'next/css'
|
||||
|
||||
export default class Error extends React.Component {
|
||||
static getInitialProps ({ res, xhr }) {
|
||||
|
@ -11,19 +11,19 @@ export default class Error extends React.Component {
|
|||
const { statusCode } = this.props
|
||||
const title = statusCode === 404 ? 'This page could not be found' : 'Internal Server Error'
|
||||
|
||||
return <div className={css(styles.error, styles['error_' + statusCode])}>
|
||||
<div className={css(styles.text)}>
|
||||
<h1 className={css(styles.h1)}>{statusCode}</h1>
|
||||
<div className={css(styles.desc)}>
|
||||
<h2 className={css(styles.h2)}>{title}.</h2>
|
||||
return <div className={merge(styles.error, styles['error_' + statusCode])}>
|
||||
<div className={styles.text}>
|
||||
<h1 className={styles.h1}>{statusCode}</h1>
|
||||
<div className={styles.desc}>
|
||||
<h2 className={styles.h2}>{title}.</h2>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
}
|
||||
}
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
error: {
|
||||
const styles = {
|
||||
error: style({
|
||||
color: '#000',
|
||||
background: '#fff',
|
||||
top: 0,
|
||||
|
@ -34,17 +34,17 @@ const styles = StyleSheet.create({
|
|||
fontFamily: '"SF UI Text", "Helvetica Neue", "Lucida Grande"',
|
||||
textAlign: 'center',
|
||||
paddingTop: '20%'
|
||||
},
|
||||
}),
|
||||
|
||||
desc: {
|
||||
desc: style({
|
||||
display: 'inline-block',
|
||||
textAlign: 'left',
|
||||
lineHeight: '49px',
|
||||
height: '49px',
|
||||
verticalAlign: 'middle'
|
||||
},
|
||||
}),
|
||||
|
||||
h1: {
|
||||
h1: style({
|
||||
display: 'inline-block',
|
||||
borderRight: '1px solid rgba(0, 0, 0,.3)',
|
||||
margin: 0,
|
||||
|
@ -53,12 +53,12 @@ const styles = StyleSheet.create({
|
|||
fontSize: '24px',
|
||||
fontWeight: 500,
|
||||
verticalAlign: 'top'
|
||||
},
|
||||
}),
|
||||
|
||||
h2: {
|
||||
h2: style({
|
||||
fontSize: '14px',
|
||||
fontWeight: 'normal',
|
||||
margin: 0,
|
||||
padding: 0
|
||||
}
|
||||
})
|
||||
})
|
||||
}
|
||||
|
|
|
@ -8,7 +8,7 @@ import Router from '../lib/router'
|
|||
import Document from '../lib/document'
|
||||
import Head from '../lib/head'
|
||||
import App from '../lib/app'
|
||||
import { StyleSheetServer } from '../lib/css'
|
||||
import { renderStatic } from 'glamor/server'
|
||||
|
||||
export async function render (url, ctx = {}, {
|
||||
dir = process.cwd(),
|
||||
|
@ -22,7 +22,7 @@ export async function render (url, ctx = {}, {
|
|||
const props = await (Component.getInitialProps ? Component.getInitialProps(ctx) : {})
|
||||
const component = await read(join(dir, '.next', 'bundles', 'pages', path))
|
||||
|
||||
const { html, css } = StyleSheetServer.renderStatic(() => {
|
||||
const { html, css, ids } = renderStatic(() => {
|
||||
const app = createElement(App, {
|
||||
Component,
|
||||
props,
|
||||
|
@ -41,7 +41,7 @@ export async function render (url, ctx = {}, {
|
|||
data: {
|
||||
component,
|
||||
props,
|
||||
classNames: css.renderedClassNames,
|
||||
ids: ids,
|
||||
err: ctx.err ? errorToJSON(ctx.err) : null
|
||||
},
|
||||
hotReload: false,
|
||||
|
|
8
test/fixtures/basic/pages/css.js
vendored
8
test/fixtures/basic/pages/css.js
vendored
|
@ -1,8 +1,6 @@
|
|||
import React from 'react'
|
||||
import { StyleSheet, css } from 'next/css'
|
||||
import { style } from 'next/css'
|
||||
|
||||
export default () => <div className={css(styles.red)}>This is red</div>
|
||||
export default () => <div className={styles}>This is red</div>
|
||||
|
||||
const styles = StyleSheet.create({
|
||||
red: { color: 'red' }
|
||||
})
|
||||
const styles = style({ color: 'red' })
|
||||
|
|
|
@ -14,8 +14,8 @@ test(async t => {
|
|||
|
||||
test(async t => {
|
||||
const html = await render('/css')
|
||||
t.true(html.includes('<style data-aphrodite="">.red_im3wl1{color:red !important;}</style>'))
|
||||
t.true(html.includes('<div class="red_im3wl1">This is red</div>'))
|
||||
t.true(html.includes('.css-im3wl1'))
|
||||
t.true(html.includes('<div class="css-im3wl1">This is red</div>'))
|
||||
})
|
||||
|
||||
test(async t => {
|
||||
|
|
Loading…
Reference in a new issue