mirror of
https://github.com/terribleplan/next.js.git
synced 2024-01-19 02:48:18 +00:00
add new nextjs typings with samples (#6102)
The current `examples/with-typescript` is not using the latest type definitions currently available on DefinitelyTyped project for next. Added new list page examples that demonstrate how to use the new Types for both stateless functional components and classes. Also modified examples for list to demonstrate typings for `getInitialProps`.
This commit is contained in:
parent
c5d5148bad
commit
d6ec10a4bf
|
@ -3,7 +3,7 @@ import Link from 'next/link'
|
||||||
import Head from 'next/head'
|
import Head from 'next/head'
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
title?: string
|
title?: string,
|
||||||
}
|
}
|
||||||
|
|
||||||
const Layout: React.FunctionComponent<Props> = ({ children, title = 'This is the default title' }) => (
|
const Layout: React.FunctionComponent<Props> = ({ children, title = 'This is the default title' }) => (
|
||||||
|
@ -16,16 +16,17 @@ const Layout: React.FunctionComponent<Props> = ({ children, title = 'This is the
|
||||||
<header>
|
<header>
|
||||||
<nav>
|
<nav>
|
||||||
<Link href='/'><a>Home</a></Link> | {' '}
|
<Link href='/'><a>Home</a></Link> | {' '}
|
||||||
<Link href='/list'><a>List</a></Link> | {' '}
|
<Link href='/list-fc'><a>List as Functional Component</a></Link> | {' '}
|
||||||
|
<Link href='/list-class'><a>List As Class</a></Link> | {' '}
|
||||||
<Link href='/about'><a>About</a></Link> | {' '}
|
<Link href='/about'><a>About</a></Link> | {' '}
|
||||||
</nav>
|
</nav>
|
||||||
</header>
|
</header>
|
||||||
{children}
|
{children}
|
||||||
<footer>
|
<footer>
|
||||||
<hr/>
|
<hr />
|
||||||
<span>I'm here to stay (Footer)</span>
|
<span>I'm here to stay (Footer)</span>
|
||||||
</footer>
|
</footer>
|
||||||
</div>
|
</div>
|
||||||
)
|
)
|
||||||
|
|
||||||
export default Layout
|
export default Layout
|
||||||
|
|
|
@ -1,23 +1,19 @@
|
||||||
import * as React from "react"
|
import * as React from "react"
|
||||||
import ListItem from './ListItem'
|
import ListItem from './ListItem'
|
||||||
|
import IDataObject from '../interfaces'
|
||||||
|
|
||||||
export interface DataObject {
|
type Props = {
|
||||||
id: number,
|
items: IDataObject[],
|
||||||
name: string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const List : React.FunctionComponent = () => {
|
const List: React.FunctionComponent<Props> = ({ items }) => (
|
||||||
const dataArray : DataObject[] =
|
<ul>
|
||||||
[{id: 101, name: 'larry'}, {id: 102, name: 'sam'}, {id: 103, name: 'jill'}]
|
{items.map((item) => (
|
||||||
return (
|
<li key={item.id}>
|
||||||
<ul>
|
<ListItem data={item} />
|
||||||
{dataArray.map(item => (
|
</li>
|
||||||
<li key={item.id}>
|
))}
|
||||||
<ListItem data={item}/>
|
</ul>
|
||||||
</li>
|
)
|
||||||
))}
|
|
||||||
</ul>
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
export default List;
|
export default List
|
||||||
|
|
|
@ -1,12 +1,12 @@
|
||||||
import * as React from 'react'
|
import * as React from 'react'
|
||||||
import {DataObject} from "./List";
|
import IDataObject from '../interfaces'
|
||||||
|
|
||||||
export interface Props {
|
type Props = {
|
||||||
data: DataObject
|
data: IDataObject,
|
||||||
}
|
}
|
||||||
|
|
||||||
const ListItem: React.FunctionComponent<Props> = ({ data }) => (
|
const ListItem: React.FunctionComponent<Props> = ({ data }) => (
|
||||||
<React.Fragment>{data.id}:{data.name}</React.Fragment>
|
<React.Fragment>{data.id}:{data.name}</React.Fragment>
|
||||||
);
|
);
|
||||||
|
|
||||||
export default ListItem;
|
export default ListItem
|
||||||
|
|
4
examples/with-typescript/interfaces/index.tsx
Normal file
4
examples/with-typescript/interfaces/index.tsx
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
export default interface IDataObject {
|
||||||
|
id: number,
|
||||||
|
name: string
|
||||||
|
}
|
|
@ -15,7 +15,7 @@
|
||||||
"react-dom": "^16.7.0"
|
"react-dom": "^16.7.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/next": "^7.0.2",
|
"@types/next": "^7.0.6",
|
||||||
"@types/react": "^16.4.16",
|
"@types/react": "^16.4.16",
|
||||||
"@types/react-dom": "16.0.8",
|
"@types/react-dom": "16.0.8",
|
||||||
"eslint": "^5.12.0",
|
"eslint": "^5.12.0",
|
||||||
|
|
|
@ -2,13 +2,13 @@ import * as React from "react"
|
||||||
import Link from 'next/link'
|
import Link from 'next/link'
|
||||||
import Layout from '../components/Layout'
|
import Layout from '../components/Layout'
|
||||||
|
|
||||||
const index : React.FunctionComponent = () => {
|
const index: React.FunctionComponent = () => {
|
||||||
return (
|
return (
|
||||||
<Layout title="Home | Next.js + TypeScript Example">
|
<Layout title="Home | Next.js + TypeScript Example">
|
||||||
<h1>Hello Next.js 👋</h1>
|
<h1>Hello Next.js 👋</h1>
|
||||||
<p><Link href='/about'><a>About</a></Link></p>
|
<p><Link href='/about'><a>About</a></Link></p>
|
||||||
</Layout>
|
</Layout>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
export default index;
|
export default index;
|
||||||
|
|
29
examples/with-typescript/pages/list-class.tsx
Normal file
29
examples/with-typescript/pages/list-class.tsx
Normal file
|
@ -0,0 +1,29 @@
|
||||||
|
import React from 'react'
|
||||||
|
import { NextContext } from 'next'
|
||||||
|
|
||||||
|
import Layout from '../components/Layout'
|
||||||
|
import List from '../components/List'
|
||||||
|
import IDataObject from '../interfaces'
|
||||||
|
|
||||||
|
type Props = {
|
||||||
|
items: IDataObject[],
|
||||||
|
}
|
||||||
|
|
||||||
|
class ListClass extends React.Component<Props> {
|
||||||
|
static async getInitialProps({ pathname }: NextContext) {
|
||||||
|
const dataArray: IDataObject[] =
|
||||||
|
[{ id: 101, name: 'larry' }, { id: 102, name: 'sam' }, { id: 103, name: 'jill' }, { id: 104, name: pathname }]
|
||||||
|
|
||||||
|
return { items: dataArray }
|
||||||
|
}
|
||||||
|
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<Layout title="About | Next.js + TypeScript Example">
|
||||||
|
<List items={this.props.items} />
|
||||||
|
</Layout>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ListClass
|
23
examples/with-typescript/pages/list-fc.tsx
Normal file
23
examples/with-typescript/pages/list-fc.tsx
Normal file
|
@ -0,0 +1,23 @@
|
||||||
|
import { NextFunctionComponent, NextContext } from 'next'
|
||||||
|
import Layout from '../components/Layout'
|
||||||
|
import List from '../components/List'
|
||||||
|
import IDataObject from '../interfaces'
|
||||||
|
|
||||||
|
type Props = {
|
||||||
|
items: IDataObject[],
|
||||||
|
}
|
||||||
|
|
||||||
|
const list: NextFunctionComponent<Props> = ({ items }) => (
|
||||||
|
<Layout title="About | Next.js + TypeScript Example">
|
||||||
|
<List items={items} />
|
||||||
|
</Layout>
|
||||||
|
)
|
||||||
|
|
||||||
|
list.getInitialProps = async ({ pathname }: NextContext) => {
|
||||||
|
const dataArray: IDataObject[] =
|
||||||
|
[{ id: 101, name: 'larry' }, { id: 102, name: 'sam' }, { id: 103, name: 'jill' }, { id: 104, name: pathname }]
|
||||||
|
|
||||||
|
return { items: dataArray }
|
||||||
|
}
|
||||||
|
|
||||||
|
export default list
|
|
@ -1,11 +0,0 @@
|
||||||
import * as React from "react"
|
|
||||||
import Layout from '../components/Layout'
|
|
||||||
import List from '../components/List'
|
|
||||||
|
|
||||||
const list : React.FunctionComponent = () => (
|
|
||||||
<Layout title="About | Next.js + TypeScript Example">
|
|
||||||
<List/>
|
|
||||||
</Layout>
|
|
||||||
)
|
|
||||||
|
|
||||||
export default list;
|
|
Loading…
Reference in a new issue