mirror of
https://github.com/ClaytonWWilson/CS307-Team24.git
synced 2025-12-16 10:18:48 +00:00
225 lines
6.2 KiB
JavaScript
225 lines
6.2 KiB
JavaScript
import React, { Component } from "react";
|
|
import axios from "axios";
|
|
import PropTypes from "prop-types";
|
|
// 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
|
|
|
|
// Material-UI stuff
|
|
import Button from "@material-ui/core/Button";
|
|
import CircularProgress from "@material-ui/core/CircularProgress";
|
|
import Grid from "@material-ui/core/Grid";
|
|
import TextField from "@material-ui/core/TextField";
|
|
import Typography from "@material-ui/core/Typography";
|
|
import withStyles from "@material-ui/core/styles/withStyles";
|
|
|
|
const styles = {
|
|
form: {
|
|
textAlign: "center"
|
|
},
|
|
textField: {
|
|
marginBottom: 30
|
|
},
|
|
pageTitle: {
|
|
// marginTop: 20,
|
|
marginBottom: 40
|
|
},
|
|
button: {
|
|
positon: "relative",
|
|
marginBottom: 30
|
|
},
|
|
progress: {
|
|
position: "absolute"
|
|
}
|
|
};
|
|
|
|
export class edit extends Component {
|
|
// Runs as soon as the page loads.
|
|
// Sets the default values of all the textboxes to the data
|
|
// that is stored in the database for the user.
|
|
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 for the state
|
|
constructor() {
|
|
super();
|
|
this.state = {
|
|
firstName: "",
|
|
lastName: "",
|
|
email: "",
|
|
handle: "",
|
|
bio: "",
|
|
loading: false,
|
|
errors: {}
|
|
};
|
|
}
|
|
|
|
// Runs whenever the submit button is clicked.
|
|
// Updates the database entry of the signed in user with the
|
|
// data stored in the state.
|
|
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
|
|
});
|
|
});
|
|
};
|
|
|
|
// Updates the state whenever one of the textboxes changes.
|
|
// The key is the name of the textbox and the value is the
|
|
// value in the text box.
|
|
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)"
|
|
// INFO: These will be uncommented if changing emails is allowed
|
|
// 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)"
|
|
// INFO: These will be uncommented if changing usernames is allowed
|
|
// 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);
|