mirror of
https://github.com/microsoft/frontend-bootcamp.git
synced 2026-01-26 14:56:42 +08:00
adding types to 7
This commit is contained in:
10
step1-07/src/TodoApp.types.ts
Normal file
10
step1-07/src/TodoApp.types.ts
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
export type FilterTypes = 'all' | 'active' | 'completed';
|
||||||
|
|
||||||
|
export interface TodoItem {
|
||||||
|
label: string;
|
||||||
|
completed: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface Todos {
|
||||||
|
[id: string]: TodoItem;
|
||||||
|
}
|
||||||
@@ -1,6 +1,11 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
import { Todos } from '../TodoApp.types';
|
||||||
|
interface TodoFooterProps {
|
||||||
|
clear: () => void;
|
||||||
|
todos: Todos;
|
||||||
|
}
|
||||||
|
|
||||||
export const TodoFooter = (props: any) => {
|
export const TodoFooter = (props: TodoFooterProps) => {
|
||||||
const itemCount = Object.keys(props.todos).filter(id => !props.todos[id].completed).length;
|
const itemCount = Object.keys(props.todos).filter(id => !props.todos[id].completed).length;
|
||||||
return (
|
return (
|
||||||
<footer>
|
<footer>
|
||||||
|
|||||||
@@ -1,13 +1,20 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
import { FilterTypes } from '../TodoApp.types';
|
||||||
|
|
||||||
export class TodoHeader extends React.Component<any, any> {
|
interface TodoHeaderProps {
|
||||||
|
addTodo: (label: string) => void;
|
||||||
|
setFilter: (filter: FilterTypes) => void;
|
||||||
|
filter: FilterTypes;
|
||||||
|
}
|
||||||
|
|
||||||
|
export class TodoHeader extends React.Component<TodoHeaderProps, any> {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
this.state = { labelInput: '' };
|
this.state = { labelInput: '' };
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { filter } = this.props;
|
const { filter, setFilter } = this.props;
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<h1>todos</h1>
|
<h1>todos</h1>
|
||||||
@@ -16,13 +23,13 @@ export class TodoHeader extends React.Component<any, any> {
|
|||||||
Add
|
Add
|
||||||
</button>
|
</button>
|
||||||
<div className="filter">
|
<div className="filter">
|
||||||
<button onClick={() => this._onFilter('all')} className={filter == 'all' ? 'active' : ''}>
|
<button onClick={() => setFilter('all')} className={filter == 'all' ? 'active' : ''}>
|
||||||
all
|
all
|
||||||
</button>
|
</button>
|
||||||
<button onClick={() => this._onFilter('active')} className={filter == 'active' ? 'active' : ''}>
|
<button onClick={() => setFilter('active')} className={filter == 'active' ? 'active' : ''}>
|
||||||
active
|
active
|
||||||
</button>
|
</button>
|
||||||
<button onClick={() => this._onFilter('completed')} className={filter == 'completed' ? 'active' : ''}>
|
<button onClick={() => setFilter('completed')} className={filter == 'completed' ? 'active' : ''}>
|
||||||
completed
|
completed
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
@@ -30,10 +37,6 @@ export class TodoHeader extends React.Component<any, any> {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
_onFilter = filter => {
|
|
||||||
this.props.setFilter(filter);
|
|
||||||
};
|
|
||||||
|
|
||||||
_onChange = evt => {
|
_onChange = evt => {
|
||||||
this.setState({ labelInput: evt.target.value });
|
this.setState({ labelInput: evt.target.value });
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,7 +1,14 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { TodoListItem } from './TodoListItem';
|
import { TodoListItem } from './TodoListItem';
|
||||||
|
import { FilterTypes, Todos } from '../TodoApp.types';
|
||||||
|
|
||||||
export class TodoList extends React.Component<any, any> {
|
interface TodoListProps {
|
||||||
|
complete: (id: string) => void;
|
||||||
|
todos: Todos;
|
||||||
|
filter: FilterTypes;
|
||||||
|
}
|
||||||
|
|
||||||
|
export class TodoList extends React.Component<TodoListProps, any> {
|
||||||
render() {
|
render() {
|
||||||
const { filter, todos, complete } = this.props;
|
const { filter, todos, complete } = this.props;
|
||||||
|
|
||||||
@@ -12,7 +19,7 @@ export class TodoList extends React.Component<any, any> {
|
|||||||
return (
|
return (
|
||||||
<ul className="todos">
|
<ul className="todos">
|
||||||
{filteredTodos.map(id => (
|
{filteredTodos.map(id => (
|
||||||
<TodoListItem key={id} id={id} {...todos[id]} complete={complete} />
|
<TodoListItem key={id} id={id} complete={complete} {...todos[id]} />
|
||||||
))}
|
))}
|
||||||
</ul>
|
</ul>
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,6 +1,12 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
|
import { TodoItem } from '../TodoApp.types';
|
||||||
|
|
||||||
export class TodoListItem extends React.Component<any, any> {
|
interface TodoListItemProps extends TodoItem {
|
||||||
|
id: string;
|
||||||
|
complete: (id: string) => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
export class TodoListItem extends React.Component<TodoListItemProps, any> {
|
||||||
render() {
|
render() {
|
||||||
const { label, completed, complete, id } = this.props;
|
const { label, completed, complete, id } = this.props;
|
||||||
|
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ import { FilterTypes } from '../store';
|
|||||||
interface TodoHeaderProps {
|
interface TodoHeaderProps {
|
||||||
addTodo: (label: string) => void;
|
addTodo: (label: string) => void;
|
||||||
setFilter: (filter: FilterTypes) => void;
|
setFilter: (filter: FilterTypes) => void;
|
||||||
filter: string;
|
filter: FilterTypes;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface TodoHeaderState {
|
interface TodoHeaderState {
|
||||||
|
|||||||
Reference in New Issue
Block a user