mirror of
https://github.com/ClaytonWWilson/CS307-Team24.git
synced 2025-12-16 02:08:47 +00:00
Merge branch 'master' into finalfix
This commit is contained in:
commit
aad9dc0273
@ -56,7 +56,7 @@ exports.getallPostsforUser = (req, res) => {
|
|||||||
.catch(function(err) {
|
.catch(function(err) {
|
||||||
return res
|
return res
|
||||||
.status(500)
|
.status(500)
|
||||||
.json("Failed to retrieve user's posts from database.", err);
|
.json({message: "Failed to retrieve user's posts from database.", error: err});
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@ -8,6 +8,7 @@ import TextField from '@material-ui/core/TextField';
|
|||||||
// import Typography from '@material-ui/core/Typography';
|
// import Typography from '@material-ui/core/Typography';
|
||||||
import Button from '@material-ui/core/Button';
|
import Button from '@material-ui/core/Button';
|
||||||
import withStyles from "@material-ui/styles/withStyles";
|
import withStyles from "@material-ui/styles/withStyles";
|
||||||
|
import CircularProgress from "@material-ui/core/CircularProgress";
|
||||||
|
|
||||||
const styles = {
|
const styles = {
|
||||||
container: {
|
container: {
|
||||||
@ -21,6 +22,13 @@ const styles = {
|
|||||||
},
|
},
|
||||||
textField: {
|
textField: {
|
||||||
marginBottom: 15
|
marginBottom: 15
|
||||||
|
},
|
||||||
|
progress: {
|
||||||
|
position: "absolute"
|
||||||
|
},
|
||||||
|
button: {
|
||||||
|
positon: "relative",
|
||||||
|
marginBottom: 30
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -31,7 +39,8 @@ class Writing_Microblogs extends Component {
|
|||||||
value: "",
|
value: "",
|
||||||
title: "",
|
title: "",
|
||||||
topics: "",
|
topics: "",
|
||||||
characterCount: 250
|
characterCount: 250,
|
||||||
|
loading: false
|
||||||
};
|
};
|
||||||
|
|
||||||
this.handleChange = this.handleChange.bind(this);
|
this.handleChange = this.handleChange.bind(this);
|
||||||
@ -56,11 +65,15 @@ class Writing_Microblogs extends Component {
|
|||||||
microBlogTitle: this.state.title,
|
microBlogTitle: this.state.title,
|
||||||
microBlogTopics: this.state.topics.split(", ")
|
microBlogTopics: this.state.topics.split(", ")
|
||||||
};
|
};
|
||||||
|
|
||||||
|
this.setState({
|
||||||
|
loading: true
|
||||||
|
})
|
||||||
const headers = {
|
const headers = {
|
||||||
headers: { "Content-Type": "application/json" }
|
headers: { "Content-Type": "application/json" }
|
||||||
};
|
};
|
||||||
|
|
||||||
axios
|
let postPromise = axios
|
||||||
.post("/putPost", postData, headers) // TODO: add topics
|
.post("/putPost", postData, headers) // TODO: add topics
|
||||||
.then(res => {
|
.then(res => {
|
||||||
// alert("Post was shared successfully!");
|
// alert("Post was shared successfully!");
|
||||||
@ -71,8 +84,9 @@ class Writing_Microblogs extends Component {
|
|||||||
console.error(err);
|
console.error(err);
|
||||||
});
|
});
|
||||||
console.log(postData.microBlogTopics);
|
console.log(postData.microBlogTopics);
|
||||||
|
let topicPromises = [];
|
||||||
postData.microBlogTopics.forEach(topic => {
|
postData.microBlogTopics.forEach(topic => {
|
||||||
axios
|
topicPromises.push(axios
|
||||||
.post("/putTopic", {
|
.post("/putTopic", {
|
||||||
following: topic
|
following: topic
|
||||||
})
|
})
|
||||||
@ -81,10 +95,24 @@ class Writing_Microblogs extends Component {
|
|||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
console.error(err);
|
console.error(err);
|
||||||
});
|
})
|
||||||
|
)
|
||||||
});
|
});
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
this.setState({ value: "", title: "", characterCount: 250, topics: "" });
|
topicPromises.push(postPromise);
|
||||||
|
Promise.all(topicPromises)
|
||||||
|
.then(() => {
|
||||||
|
this.setState({
|
||||||
|
value: "",
|
||||||
|
title: "",
|
||||||
|
characterCount: 250,
|
||||||
|
topics: "",
|
||||||
|
loading: false
|
||||||
|
});
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
console.log(error);
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
handleChangeforPost(event) {
|
handleChangeforPost(event) {
|
||||||
@ -149,12 +177,14 @@ class Writing_Microblogs extends Component {
|
|||||||
autoComplete='off'
|
autoComplete='off'
|
||||||
/>
|
/>
|
||||||
<Button
|
<Button
|
||||||
|
className={classes.button}
|
||||||
onClick={this.handleSubmit}
|
onClick={this.handleSubmit}
|
||||||
// disabled={loading}
|
disabled={this.state.loading}
|
||||||
variant="outlined"
|
variant="outlined"
|
||||||
color="primary"
|
color="primary"
|
||||||
>
|
>
|
||||||
Share Post
|
Share Post
|
||||||
|
{this.state.loading && <CircularProgress size={30} className={classes.progress} />}
|
||||||
</Button>
|
</Button>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@ -35,12 +35,14 @@ const styles = {
|
|||||||
class Home extends Component {
|
class Home extends Component {
|
||||||
state = {
|
state = {
|
||||||
likes: [],
|
likes: [],
|
||||||
|
loading: false,
|
||||||
following: null,
|
following: null,
|
||||||
topics: null
|
topics: null
|
||||||
};
|
};
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
axios
|
this.setState({loading: true});
|
||||||
|
let userPromise = axios
|
||||||
.get("/user")
|
.get("/user")
|
||||||
.then(res => {
|
.then(res => {
|
||||||
this.setState({
|
this.setState({
|
||||||
@ -50,7 +52,7 @@ class Home extends Component {
|
|||||||
})
|
})
|
||||||
.catch(err => console.log(err));
|
.catch(err => console.log(err));
|
||||||
|
|
||||||
axios
|
let postPromise = axios
|
||||||
.get("/getallPosts")
|
.get("/getallPosts")
|
||||||
.then(res => {
|
.then(res => {
|
||||||
// console.log(res.data);
|
// console.log(res.data);
|
||||||
@ -60,6 +62,16 @@ class Home extends Component {
|
|||||||
})
|
})
|
||||||
.catch(err => console.log(err));
|
.catch(err => console.log(err));
|
||||||
|
|
||||||
|
Promise.all([userPromise, postPromise])
|
||||||
|
.then(() => {
|
||||||
|
this.setState({
|
||||||
|
loading: false
|
||||||
|
})
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
console.log(error);
|
||||||
|
})
|
||||||
|
|
||||||
this.props.getLikes();
|
this.props.getLikes();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -175,7 +187,9 @@ class Home extends Component {
|
|||||||
<p>Loading post...</p>
|
<p>Loading post...</p>
|
||||||
);
|
);
|
||||||
|
|
||||||
return authenticated ? (
|
return (
|
||||||
|
authenticated ? (
|
||||||
|
this.state.loading ? (<CircularProgress size={60} style={{marginTop: "300px"}}></CircularProgress>) :
|
||||||
<Grid container>
|
<Grid container>
|
||||||
<Grid item sm={4} xs={8}>
|
<Grid item sm={4} xs={8}>
|
||||||
<Writing_Microblogs />
|
<Writing_Microblogs />
|
||||||
@ -184,20 +198,16 @@ class Home extends Component {
|
|||||||
{postMarkup}
|
{postMarkup}
|
||||||
</Grid>
|
</Grid>
|
||||||
</Grid>
|
</Grid>
|
||||||
) : loading ? (
|
) : loading ?
|
||||||
<CircularProgress
|
(<CircularProgress size={60} style={{marginTop: "300px"}}></CircularProgress>)
|
||||||
size={60}
|
:
|
||||||
style={{ marginTop: "300px" }}
|
(
|
||||||
></CircularProgress>
|
|
||||||
) : (
|
|
||||||
<div>
|
<div>
|
||||||
<div>
|
<div>
|
||||||
<img src={logo} className="app-logo" alt="logo" />
|
<img src={logo} className="app-logo" alt="logo" />
|
||||||
<br />
|
<br/><br/>
|
||||||
<br />
|
|
||||||
<b>Welcome to Twistter!</b>
|
<b>Welcome to Twistter!</b>
|
||||||
<br />
|
<br/><br/>
|
||||||
<br />
|
|
||||||
<b>See the most interesting topics people are following right now.</b>
|
<b>See the most interesting topics people are following right now.</b>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -219,6 +229,7 @@ class Home extends Component {
|
|||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -548,8 +548,8 @@ export class directMessages extends Component {
|
|||||||
>
|
>
|
||||||
Create
|
Create
|
||||||
{creatingDirectMessage &&
|
{creatingDirectMessage &&
|
||||||
<CircularProgress size={30} style={{position: "absolute"}}/>
|
|
||||||
// Won't accept classes style for some reason
|
// Won't accept classes style for some reason
|
||||||
|
<CircularProgress size={30} style={{position: "absolute"}}/>
|
||||||
}
|
}
|
||||||
</Button>
|
</Button>
|
||||||
</Grid>
|
</Grid>
|
||||||
|
|||||||
@ -22,6 +22,7 @@ import AddCircle from "@material-ui/icons/AddCircle";
|
|||||||
import TextField from "@material-ui/core/TextField";
|
import TextField from "@material-ui/core/TextField";
|
||||||
import VerifiedIcon from "@material-ui/icons/CheckSharp";
|
import VerifiedIcon from "@material-ui/icons/CheckSharp";
|
||||||
import DoneIcon from "@material-ui/icons/Done";
|
import DoneIcon from "@material-ui/icons/Done";
|
||||||
|
import CircularProgress from "@material-ui/core/CircularProgress";
|
||||||
|
|
||||||
// component
|
// component
|
||||||
import "../App.css";
|
import "../App.css";
|
||||||
@ -79,6 +80,7 @@ class user extends Component {
|
|||||||
posts: null,
|
posts: null,
|
||||||
myTopics: null,
|
myTopics: null,
|
||||||
followingList: null
|
followingList: null
|
||||||
|
loading: false
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,7 +135,8 @@ class user extends Component {
|
|||||||
};
|
};
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
axios
|
this.setState({loading: true});
|
||||||
|
let otherUserPromise = axios
|
||||||
.post("/getUserDetails", {
|
.post("/getUserDetails", {
|
||||||
handle: this.state.profile
|
handle: this.state.profile
|
||||||
})
|
})
|
||||||
@ -145,7 +148,7 @@ class user extends Component {
|
|||||||
})
|
})
|
||||||
.catch(err => console.log(err));
|
.catch(err => console.log(err));
|
||||||
|
|
||||||
axios
|
let userPromise = axios
|
||||||
.get("/user")
|
.get("/user")
|
||||||
.then(res => {
|
.then(res => {
|
||||||
// console.log(res.data.credentials.following);
|
// console.log(res.data.credentials.following);
|
||||||
@ -165,7 +168,7 @@ class user extends Component {
|
|||||||
})
|
})
|
||||||
.catch(err => console.log(err));
|
.catch(err => console.log(err));
|
||||||
|
|
||||||
axios
|
let posts = axios
|
||||||
.post("/getOtherUsersPosts", {
|
.post("/getOtherUsersPosts", {
|
||||||
handle: this.state.profile
|
handle: this.state.profile
|
||||||
})
|
})
|
||||||
@ -193,6 +196,14 @@ class user extends Component {
|
|||||||
.catch(function(err) {
|
.catch(function(err) {
|
||||||
console.log(err);
|
console.log(err);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
Promise.all([otherUserPromise, userPromise, posts])
|
||||||
|
.then(() => {
|
||||||
|
this.setState({loading: false});
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
console.log(error);
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
@ -300,6 +311,7 @@ class user extends Component {
|
|||||||
);
|
);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
this.state.loading ? <CircularProgress size={60} style={{marginTop: "300px"}}></CircularProgress> :
|
||||||
<Grid container spacing={24}>
|
<Grid container spacing={24}>
|
||||||
<Grid item sm={4} xs={8}>
|
<Grid item sm={4} xs={8}>
|
||||||
{imageMarkup}
|
{imageMarkup}
|
||||||
|
|||||||
@ -13,6 +13,7 @@ import CardMedia from "@material-ui/core/CardMedia";
|
|||||||
import CardContent from "@material-ui/core/CardContent";
|
import CardContent from "@material-ui/core/CardContent";
|
||||||
import Button from "@material-ui/core/Button";
|
import Button from "@material-ui/core/Button";
|
||||||
import Grid from "@material-ui/core/Grid";
|
import Grid from "@material-ui/core/Grid";
|
||||||
|
import CircularProgress from "@material-ui/core/CircularProgress";
|
||||||
|
|
||||||
import Chip from "@material-ui/core/Chip";
|
import Chip from "@material-ui/core/Chip";
|
||||||
import Typography from "@material-ui/core/Typography";
|
import Typography from "@material-ui/core/Typography";
|
||||||
@ -76,7 +77,8 @@ class user extends Component {
|
|||||||
profile: null,
|
profile: null,
|
||||||
imageUrl: null,
|
imageUrl: null,
|
||||||
topics: null,
|
topics: null,
|
||||||
newTopic: ""
|
newTopic: "",
|
||||||
|
loading: false
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,7 +129,8 @@ class user extends Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
axios
|
this.setState({loading: true})
|
||||||
|
let userPromise = axios
|
||||||
.get("/user")
|
.get("/user")
|
||||||
.then(res => {
|
.then(res => {
|
||||||
this.setState({
|
this.setState({
|
||||||
@ -141,7 +144,7 @@ class user extends Component {
|
|||||||
})
|
})
|
||||||
.catch(err => console.log(err));
|
.catch(err => console.log(err));
|
||||||
|
|
||||||
axios
|
let postsPromise = axios
|
||||||
.get("/getallPostsforUser")
|
.get("/getallPostsforUser")
|
||||||
.then(res => {
|
.then(res => {
|
||||||
// console.log(res.data);
|
// console.log(res.data);
|
||||||
@ -150,6 +153,14 @@ class user extends Component {
|
|||||||
});
|
});
|
||||||
})
|
})
|
||||||
.catch(err => console.log(err));
|
.catch(err => console.log(err));
|
||||||
|
|
||||||
|
Promise.all([userPromise, postsPromise])
|
||||||
|
.then(() => {
|
||||||
|
this.setState({loading: false});
|
||||||
|
})
|
||||||
|
.catch((error) => {
|
||||||
|
console.log(error)
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
formatDate(dateString) {
|
formatDate(dateString) {
|
||||||
@ -259,6 +270,7 @@ class user extends Component {
|
|||||||
) : null;
|
) : null;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
this.state.loading ? <CircularProgress size={60} style={{marginTop: "300px"}}></CircularProgress> :
|
||||||
<div>
|
<div>
|
||||||
{/* <Paper className={classes.paper}> */}
|
{/* <Paper className={classes.paper}> */}
|
||||||
<Grid container direction="column">
|
<Grid container direction="column">
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user