mirror of
https://github.com/ClaytonWWilson/CS307-Team24.git
synced 2025-12-16 10:18:48 +00:00
216 lines
5.7 KiB
JavaScript
216 lines
5.7 KiB
JavaScript
import React, { Component } from "react";
|
|
import axios from "axios";
|
|
import PropTypes from "prop-types";
|
|
// TODO: Fix font, so that it is roboto
|
|
// TODO: Add a read-only '@' in the left side of the handle input
|
|
// TODO: Add a cancel button, that takes the user back to their profile page
|
|
// TODO: Sort imports
|
|
// TODO: Add comments
|
|
|
|
// Material-UI stuff
|
|
import TextField from "@material-ui/core/TextField";
|
|
import Typography from "@material-ui/core/Typography";
|
|
import withStyles from "@material-ui/core/styles/withStyles";
|
|
import Grid from "@material-ui/core/Grid";
|
|
import Button from "@material-ui/core/Button";
|
|
import CircularProgress from '@material-ui/core/CircularProgress';
|
|
|
|
const styles = {
|
|
form: {
|
|
textAlign: "center"
|
|
},
|
|
textField: {
|
|
marginBottom: 40
|
|
},
|
|
pageTitle: {
|
|
marginTop: 40,
|
|
marginBottom: 40
|
|
},
|
|
button: {
|
|
positon: 'relative',
|
|
},
|
|
progress: {
|
|
position: 'absolute',
|
|
}
|
|
};
|
|
|
|
export class edit extends Component {
|
|
|
|
componentDidMount() {
|
|
axios
|
|
.get("/getProfileInfo")
|
|
.then((res) => {
|
|
this.setState({
|
|
firstName: res.data.firstName,
|
|
lastName: res.data.lastName,
|
|
email: res.data.email,
|
|
handle: res.data.handle,
|
|
bio: res.data.bio
|
|
});
|
|
})
|
|
.catch((err) => {
|
|
console.error(err);
|
|
});
|
|
}
|
|
|
|
constructor() {
|
|
super();
|
|
this.state = {
|
|
firstName: "",
|
|
lastName: "",
|
|
email: "",
|
|
handle: "",
|
|
bio: "",
|
|
loading: false,
|
|
errors: {}
|
|
};
|
|
}
|
|
|
|
handleSubmit = (event) => {
|
|
event.preventDefault();
|
|
this.setState({
|
|
loading: true
|
|
});
|
|
const newProfileData = {
|
|
firstName: this.state.firstName,
|
|
lastName: this.state.lastName,
|
|
email: this.state.email,
|
|
handle: this.state.handle,
|
|
bio: this.state.bio
|
|
};
|
|
axios
|
|
.post("/updateProfileInfo", newProfileData)
|
|
.then((res) => {
|
|
this.setState({
|
|
loading: false
|
|
});
|
|
// this.props.history.push('/');
|
|
// TODO: Need to redirect user to their profile page
|
|
})
|
|
.catch((err) => {
|
|
this.setState({
|
|
errors: err.response.data,
|
|
loading: false
|
|
});
|
|
});
|
|
};
|
|
|
|
handleChange = (event) => {
|
|
this.setState({
|
|
[event.target.name]: event.target.value,
|
|
errors: {
|
|
[event.target.name]: null,
|
|
}
|
|
});
|
|
};
|
|
|
|
render() {
|
|
const { classes } = this.props;
|
|
const { errors, loading } = this.state;
|
|
|
|
return (
|
|
<Grid container className={classes.form}>
|
|
<Grid item sm />
|
|
<Grid item sm>
|
|
<Typography variant="h2" className={classes.pageTitle}>
|
|
Edit Profile
|
|
</Typography>
|
|
<form noValidate onSubmit={this.handleSubmit}>
|
|
<Grid container className={classes.form} spacing={4}>
|
|
<Grid item sm>
|
|
<TextField
|
|
id="firstName"
|
|
name="firstName"
|
|
label="First Name"
|
|
className={classes.textField}
|
|
value={this.state.firstName}
|
|
helperText={errors.firstName}
|
|
error={errors.firstName ? true : false}
|
|
variant="outlined"
|
|
onChange={this.handleChange}
|
|
fullWidth
|
|
/>
|
|
</Grid>
|
|
<Grid item sm>
|
|
<TextField
|
|
id="lastName"
|
|
name="lastName"
|
|
label="Last Name"
|
|
className={classes.textField}
|
|
value={this.state.lastName}
|
|
helperText={errors.lastname}
|
|
error={errors.lastName ? true : false}
|
|
variant="outlined"
|
|
onChange={this.handleChange}
|
|
fullWidth
|
|
/>
|
|
</Grid>
|
|
</Grid>
|
|
<TextField
|
|
id="email"
|
|
name="email"
|
|
label="Email*"
|
|
className={classes.textField}
|
|
value={this.state.email}
|
|
disabled
|
|
helperText="(disabled)"
|
|
// helperText={errors.email}
|
|
// error={errors.email ? true : false}
|
|
variant="outlined"
|
|
onChange={this.handleChange}
|
|
fullWidth
|
|
/>
|
|
<TextField
|
|
id="handle"
|
|
name="handle"
|
|
label="Handle*"
|
|
className={classes.textField}
|
|
value={this.state.handle}
|
|
disabled
|
|
helperText="(disabled)"
|
|
// helperText={errors.handle}
|
|
// error={errors.handle ? true : false}
|
|
variant="outlined"
|
|
onChange={this.handleChange}
|
|
fullWidth
|
|
/>
|
|
<TextField
|
|
id="bio"
|
|
name="bio"
|
|
label="Bio"
|
|
className={classes.textField}
|
|
value={this.state.bio}
|
|
helperText={errors.bio}
|
|
error={errors.bio ? true : false}
|
|
multiline
|
|
rows="8"
|
|
variant="outlined"
|
|
onChange={this.handleChange}
|
|
fullWidth
|
|
/>
|
|
<Button
|
|
type="submit"
|
|
variant="contained"
|
|
color="primary"
|
|
className={classes.button}
|
|
disabled={loading}
|
|
>
|
|
Submit
|
|
{loading && (
|
|
<CircularProgress size={30} className={classes.progress}/>
|
|
)}
|
|
</Button>
|
|
</form>
|
|
</Grid>
|
|
<Grid item sm />
|
|
</Grid>
|
|
);
|
|
}
|
|
}
|
|
|
|
edit.propTypes = {
|
|
classes: PropTypes.object.isRequired
|
|
};
|
|
|
|
export default withStyles(styles)(edit);
|