mirror of
https://github.com/microsoft/frontend-bootcamp.git
synced 2026-01-26 14:56:42 +08:00
get rid of the keypress charcode 13 stuff
This commit is contained in:
@@ -11,5 +11,6 @@
|
|||||||
<a href="/step1-09/">Step 9</a>
|
<a href="/step1-09/">Step 9</a>
|
||||||
<h2>Day 2</h2>
|
<h2>Day 2</h2>
|
||||||
<a href="/step2-01/">Step 1</a>
|
<a href="/step2-01/">Step 1</a>
|
||||||
|
<a href="/step2-02/">Step 2</a>
|
||||||
<a href="/playground/">Playground</a>
|
<a href="/playground/">Playground</a>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,8 +1,9 @@
|
|||||||
# Step 2.1
|
# Step 2.2
|
||||||
|
|
||||||
Typescript
|
Integrates Fabric
|
||||||
|
|
||||||
- modules
|
Learn about Basic Components
|
||||||
- a look at types
|
|
||||||
- defining interfaces
|
- Stack
|
||||||
-
|
- Text
|
||||||
|
- Show case some components
|
||||||
|
|||||||
@@ -19,7 +19,30 @@ export class TodoHeader extends React.Component<TodoHeaderProps, TodoHeaderState
|
|||||||
this.state = { labelInput: undefined };
|
this.state = { labelInput: undefined };
|
||||||
}
|
}
|
||||||
|
|
||||||
private onAdd = (evt: React.MouseEvent<any>) => {
|
render() {
|
||||||
|
return (
|
||||||
|
<Stack>
|
||||||
|
<Stack horizontal horizontalAlign="center">
|
||||||
|
<Text variant="xxLarge">todos</Text>
|
||||||
|
</Stack>
|
||||||
|
|
||||||
|
<Stack horizontal>
|
||||||
|
<Stack.Item grow>
|
||||||
|
<TextField placeholder="What needs to be done?" value={this.state.labelInput} onChange={this.onChange} />
|
||||||
|
</Stack.Item>
|
||||||
|
<DefaultButton onClick={this.onAdd}>Add</DefaultButton>
|
||||||
|
</Stack>
|
||||||
|
|
||||||
|
<Pivot onLinkClick={this.onFilter}>
|
||||||
|
<PivotItem headerText="all" />
|
||||||
|
<PivotItem headerText="active" />
|
||||||
|
<PivotItem headerText="completed" />
|
||||||
|
</Pivot>
|
||||||
|
</Stack>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
private onAdd = () => {
|
||||||
this.props.addTodo(this.state.labelInput);
|
this.props.addTodo(this.state.labelInput);
|
||||||
this.setState({ labelInput: undefined });
|
this.setState({ labelInput: undefined });
|
||||||
};
|
};
|
||||||
@@ -31,27 +54,4 @@ export class TodoHeader extends React.Component<TodoHeaderProps, TodoHeaderState
|
|||||||
private onFilter = (item: PivotItem) => {
|
private onFilter = (item: PivotItem) => {
|
||||||
this.props.setFilter(item.props.headerText as FilterTypes);
|
this.props.setFilter(item.props.headerText as FilterTypes);
|
||||||
};
|
};
|
||||||
|
|
||||||
render() {
|
|
||||||
return (
|
|
||||||
<Stack>
|
|
||||||
<Stack horizontal horizontalAlign="center">
|
|
||||||
<Text variant="xxLarge">todos</Text>
|
|
||||||
</Stack>
|
|
||||||
|
|
||||||
<Stack as="form" horizontal>
|
|
||||||
<TextField placeholder="What needs to be done?" value={this.state.labelInput} onChange={this.onChange} />
|
|
||||||
<DefaultButton type="submit" onClick={this.onAdd}>
|
|
||||||
Add
|
|
||||||
</DefaultButton>
|
|
||||||
</Stack>
|
|
||||||
|
|
||||||
<Pivot onLinkClick={this.onFilter}>
|
|
||||||
<PivotItem headerText="all" />
|
|
||||||
<PivotItem headerText="active" />
|
|
||||||
<PivotItem headerText="completed" />
|
|
||||||
</Pivot>
|
|
||||||
</Stack>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { Stack } from '@uifabric/experiments';
|
import { Stack } from '@uifabric/experiments';
|
||||||
import { Checkbox, IconButton, TextField } from 'office-ui-fabric-react';
|
import { Checkbox, IconButton, TextField, DefaultButton } from 'office-ui-fabric-react';
|
||||||
import { mergeStyles } from '@uifabric/styling';
|
import { mergeStyles } from '@uifabric/styling';
|
||||||
import { Store } from '../store';
|
import { Store } from '../store';
|
||||||
|
|
||||||
@@ -37,34 +37,6 @@ export class TodoListItem extends React.Component<TodoListItemProps, TodoListIte
|
|||||||
this.state = { editing: false, editLabel: undefined };
|
this.state = { editing: false, editLabel: undefined };
|
||||||
}
|
}
|
||||||
|
|
||||||
onEdit = () => {
|
|
||||||
const { todos, id } = this.props;
|
|
||||||
const { label } = todos[id];
|
|
||||||
|
|
||||||
this.setState(prevState => ({
|
|
||||||
editing: true,
|
|
||||||
editLabel: prevState.editLabel || label
|
|
||||||
}));
|
|
||||||
};
|
|
||||||
|
|
||||||
onDoneEdit = () => {
|
|
||||||
this.props.edit(this.props.id, this.state.editLabel);
|
|
||||||
this.setState(prevState => ({
|
|
||||||
editing: false,
|
|
||||||
editLabel: undefined
|
|
||||||
}));
|
|
||||||
};
|
|
||||||
|
|
||||||
onKeyDown = (evt: React.KeyboardEvent) => {
|
|
||||||
if (evt.which === 13) {
|
|
||||||
this.onDoneEdit();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
onChange = (evt: React.FormEvent<HTMLInputElement>, newValue: string) => {
|
|
||||||
this.setState({ editLabel: newValue });
|
|
||||||
};
|
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { todos, id, complete, remove } = this.props;
|
const { todos, id, complete, remove } = this.props;
|
||||||
const item = todos[id];
|
const item = todos[id];
|
||||||
@@ -81,8 +53,39 @@ export class TodoListItem extends React.Component<TodoListItemProps, TodoListIte
|
|||||||
</>
|
</>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{this.state.editing && <TextField value={this.state.editLabel} onChange={this.onChange} onKeyPress={this.onKeyDown} />}
|
{this.state.editing && (
|
||||||
|
<Stack.Item fillHorizontal>
|
||||||
|
<Stack horizontal>
|
||||||
|
<Stack.Item grow>
|
||||||
|
<TextField value={this.state.editLabel} onChange={this.onChange} />
|
||||||
|
</Stack.Item>
|
||||||
|
<DefaultButton onClick={this.onDoneEdit}>Save</DefaultButton>
|
||||||
|
</Stack>
|
||||||
|
</Stack.Item>
|
||||||
|
)}
|
||||||
</Stack>
|
</Stack>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private onEdit = () => {
|
||||||
|
const { todos, id } = this.props;
|
||||||
|
const { label } = todos[id];
|
||||||
|
|
||||||
|
this.setState({
|
||||||
|
editing: true,
|
||||||
|
editLabel: this.state.editLabel || label
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
private onDoneEdit = () => {
|
||||||
|
this.props.edit(this.props.id, this.state.editLabel);
|
||||||
|
this.setState({
|
||||||
|
editing: false,
|
||||||
|
editLabel: undefined
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
private onChange = (evt: React.FormEvent<HTMLInputElement>, newValue: string) => {
|
||||||
|
this.setState({ editLabel: newValue });
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user