Я создаю пример приложения в реагирующем js, в котором я извлекаю данные из хранилища и устанавливаю их в списке, после чего использую фильтр, чтобы получить искомый результат из хранилища. Я могу получить этот результат, но я не знаю, как установить этот результат в редуксе.
Хотя я использую избыточность для списка, я не уверен, нужно ли мне использовать избыточность для фильтра, может кто-нибудь, пожалуйста, помогите мне, как это сделать.
Страница сотрудника с сокращением:
class Employee extends Component {
constructor(props) {
super(props);
this.state = {};
}
static propTypes = {
employees: PropTypes.arrayOf(PropTypes.object),
history: PropTypes.object,
onSetEmployees: PropTypes.func
};
componentDidMount() {
const { onSetEmployees } = this.props;
let employeeData = [];
db.getEmployees().then((snapshot) => {
snapshot.docs.forEach((doc) => {
employeeData.push(doc);
});
onSetEmployees(employeeData);
});
}
addEmployee = () => {
this.props.history.push('/employee/new');
};
render() {
const employees = this.props.employees;
return (
<div className="animated fadeIn">
{employees.length > 0 ? (
<EmployeeList employees={employees} />
) : (
<h2> No Employees Available, Click + to add new Employees</h2>
)}
<Fab className="fab" onClick={this.addEmployee}>
<MaterialIcon icon="add" color="#FFFFFF" />
</Fab>
</div>
);
}
}
const authCondition = (authUser) => !!authUser;
function mapStateToProps(state) {
return {
employees: state.employeeState.employees
};
}
const mapDispatchToProps = (dispatch) => ({
onSetEmployees: (employees) => dispatch({ type: 'EMPLOYEES_SET', employees })
});
export default compose(
withAuthorization(authCondition),
connect(mapStateToProps, mapDispatchToProps)
)(Employee);
Страница списка сотрудников:
class EmployeeList extends Component {
constructor(props) {
super(props);
this.state = { mobileno: '' };
}
handleChange(event, key) {
this.setState({
[key]: event.target.value
});
}
onSubmit = (event) => {
const { mobileno } = this.state;
let employeeData = [];
db.filterEmployees(mobileno).then((snapshot) => {
snapshot.docs.forEach((doc) => {
employeeData.push(doc);
});
});
event.preventDefault();
}
static propTypes = {
employees: PropTypes.arrayOf(PropTypes.object),
};
render() {
const employees = this.props.employees;
const { mobileno } = this.state;
return (
<div className="animated fadeIn">
<Row>
<Col>
<Row>
<Col>
<Form className="form-horizontal" onSubmit={this.onSubmit}>
<FormGroup row>
<Col md="12">
<InputGroup>
<InputGroupAddon addonType="prepend">
<InputGroupText>
<i className="fa fa-search" />
</InputGroupText>
</InputGroupAddon>
<Input
type="text"
value={mobileno}
name="mobileno"
placeholder="Mobile No"
maxLength={10}
onChange={(event) => this.handleChange(event, 'mobileno')}
/>
<InputGroupAddon addonType="append">
<Button type="submit" color="primary">
Submit
</Button>
</InputGroupAddon>
</InputGroup>
</Col>
</FormGroup>
</Form>
</Col>
<Col>
<nav>
<Pagination>
<PaginationItem>
<PaginationLink previous tag="button">
Prev
</PaginationLink>
</PaginationItem>
<PaginationItem active>
<PaginationLink tag="button">1</PaginationLink>
</PaginationItem>
<PaginationItem>
<PaginationLink tag="button">2</PaginationLink>
</PaginationItem>
<PaginationItem>
<PaginationLink tag="button">3</PaginationLink>
</PaginationItem>
<PaginationItem>
<PaginationLink tag="button">4</PaginationLink>
</PaginationItem>
<PaginationItem>
<PaginationLink tag="button">5</PaginationLink>
</PaginationItem>
<PaginationItem>
<PaginationLink next tag="button">
Next
</PaginationLink>
</PaginationItem>
</Pagination>
</nav>
</Col>
</Row>
</Col>
</Row>
<Row>
<Col>
<Card>
<CardHeader>Employee List</CardHeader>
<CardBody>
<Table hover bordered striped responsive size="lg">
<thead>
<tr>
<th>S.No</th>
<th>Name</th>
<th>Mobile no</th>
<th>Role</th>
<th>Options</th>
</tr>
</thead>
<tbody>
{employees.map((employee, index) => {
return (
<tr key={employee.id}>
<td>{index + 1}</td>
<td>{employee.data().name}</td>
<td>{employee.data().mobileno}</td>
<td>{employee.data().role}</td>
<td>
<Link to={`/employees/${employee.id}`}>
<Button color="success" className="btn-pill">
<i className="fa fa-eye" />
View
</Button>
</Link>
<Button color="warning" className="btn-pill">
<i className="fa fa-pencil" />
Edit
</Button>
<Button color="danger" className="btn-pill">
<i className="fa fa-trash-o" />
Delete
</Button>
</td>
</tr>
);
})}
</tbody>
</Table>
</CardBody>
</Card>
</Col>
</Row>
</div>
);
}
}
export default EmployeeList;
Разбавление:
const INITIAL_STATE = {
employees: []
};
function employeeReducer(state = INITIAL_STATE, action) {
switch (action.type) {
case 'EMPLOYEES_SET': {
return { ...state, employees: action.employees };
}
default:
return state;
}
}
export default employeeReducer;