diff --git a/.DS_Store b/.DS_Store new file mode 100644 index 000000000..b86bd0570 Binary files /dev/null and b/.DS_Store differ diff --git a/README.md b/README.md index eee74593d..7c4f86ce6 100644 --- a/README.md +++ b/README.md @@ -14,7 +14,7 @@ It uses: ## Card wall -REPLACE THIS TEXT WITH A LINK TO YOUR CARD WALL +(https://trello.com/b/9wjGVeJU/kittens) ## Quickstart diff --git a/app.js b/app.js index bb2057955..ab4b56f5d 100644 --- a/app.js +++ b/app.js @@ -10,6 +10,7 @@ const homeRouter = require("./routes/home"); const postsRouter = require("./routes/posts"); const sessionsRouter = require("./routes/sessions"); const usersRouter = require("./routes/users"); +const friendsRouter = require("./routes/friends"); const app = express(); @@ -56,8 +57,14 @@ const sessionChecker = (req, res, next) => { // route setup app.use("/", homeRouter); app.use("/posts", sessionChecker, postsRouter); +app.use("posts/explore", sessionChecker, postsRouter); //do we need this for it to work? app.use("/sessions", sessionsRouter); app.use("/users", usersRouter); +app.use("/friends", sessionChecker, friendsRouter) //added SC to check user is logged in + +//posts router to listen to a post request to the id/act +app.use("/posts/:id/act", postsRouter) +//app.use("/users/:id/befriend", postsRouter) // catch 404 and forward to error handler app.use((req, res, next) => { diff --git a/car.txt b/car.txt new file mode 100644 index 000000000..e69de29bb diff --git a/controllers/friends.js b/controllers/friends.js new file mode 100644 index 000000000..2d55b3003 --- /dev/null +++ b/controllers/friends.js @@ -0,0 +1,19 @@ +const User = require("../models/user"); + + +const FriendsController = { + Index: (req, res) => { + const user = req.session.user.username + User.find({username: user}, { friends: 1 }, (err, friendsArray) => { + if (err) { + throw err + + } + //console.log(friendsArray[0].friends) - the find returns a list of objects which includes ids as well + //list of friends to be sent as an argument - this needs usercontroller and a method to list it + res.render("friends/index", { title: "Furrends", shownavbar:true, friendslist:friendsArray[0], user:user }); + }) + } +} + + module.exports = FriendsController; \ No newline at end of file diff --git a/controllers/home.js b/controllers/home.js index 667b4decc..ccd5bbe52 100644 --- a/controllers/home.js +++ b/controllers/home.js @@ -1,6 +1,6 @@ const HomeController = { Index: (req, res) => { - res.render("home/index", { title: "Acebook" }); + res.render("home/index", { title: "Acebook", shownavbar:false }); }, }; diff --git a/controllers/posts.js b/controllers/posts.js index 4b521304d..277b5d0fe 100644 --- a/controllers/posts.js +++ b/controllers/posts.js @@ -1,28 +1,149 @@ const Post = require("../models/post"); +const User = require("../models/user"); const PostsController = { Index: (req, res) => { + //do we only see posts from users that are friends? yes + const postIds = req.params.id + console.log(postIds) + // const postauthor = Post.findOne({ _id: }) + const user = req.session.user + const friendsList = user.friends + friendsList.push(user.username) + Post.find({author: {$in: friendsList}},(err, posts) => { + + if (err) { + throw err; + } + posts = posts.sort((a,b) => b.date-a.date ) //sorts the posts by date order before rendering + res.render("posts/index", { posts: posts, shownavbar:true, user: user}); + }); + }, + Explore: (req, res) => { + //page to see all posts make it happen + const user = req.session.user Post.find((err, posts) => { if (err) { throw err; } - - res.render("posts/index", { posts: posts }); - }); + posts = posts.sort((a,b) => b.date-a.date ) //sorts the posts by date order before rendering + res.render("posts/explore", { posts: posts, shownavbar:true, user: user}); + }); }, + New: (req, res) => { - res.render("posts/new", {}); + res.render("posts/new", {shownavbar:true}); }, + Create: (req, res) => { - const post = new Post(req.body); + const post = new Post({message:req.body.message,author:req.session.user.username,image:req.body.photoURL.trim()}); post.save((err) => { if (err) { throw err; } - res.status(201).redirect("/posts"); }); }, + //added a like object that has an anonymous f(x) for the PostController 'class' + //this should send a post request to update the db using the postID retrieved from the + Like: (req, res) => { + const postId = req.params.id; + const action = req.body.action; + if (action === 'Like') { + Post.updateOne({ _id: postId }, { $inc: { likes: 1 } }, function (error) { + if (error) { + res.send(error); + console.log(error) + } else { + console.log('like updated') + res.send('Like added'); + } + }); + } else if (action === 'Unlike') { + Post.updateOne({ _id: postId }, { $inc: { likes: -1 } }, function (error) { + if (error) { + res.send(error); + } else { + res.send('Unlike added'); + } + }); + } + }, + + Love: (req, res) => { + const postId = req.params.id; + const action = req.body.action; + if (action === 'Love') { + Post.updateOne({ _id: postId }, { $inc: { loves: 1 } }, function (error) { + if (error) { + res.send(error); + console.log(error) + } else { + console.log('love updated') + res.send('Love added'); + } + }); + } else if (action === 'Hate') { + Post.updateOne({ _id: postId }, { $inc: { loves: -1 } }, function (error) { + if (error) { + res.send(error); + } else { + res.send('Hate added'); + } + }); + } + }, + //added a follow object THIS IS ACTUALLY A MESS ATM + Follow: (req,res) => { + //const postId = req.params.id; + const usersname = req.body.main //gets the main user (user who's friend list is created) + // console.log(req.param.id) + // console.log(req.body.friend) + // console.log(req.body.action) + // console.log(req.body.main) + const friend = req.body.friend; //get friend to add from the post req body + const action = req.body.action; //get action + if (action === 'Follow') { + //use addToSet because want unique values to be added only + User.updateOne({ username: usersname }, {$addToSet:{ friends: friend}}, function (error) { + if (error) { + res.send(error); + console.log(error) + } else { + console.log('Followed'); + } + }); + } else if (action === 'Unfollow') { + User.updateOne({ username: usersname }, { $pull: { friends: friend } }, function (error) { + if (error) { + res.send(error); + } else { + console.log('Unfollowed'); + } + }); + } + +}, + Comment: (req, res) => { + + // const usersname = req.body.main //gets the main user (user who's friend list is created) + // const friend = req.body.friend; //get friend to add from the post req body + // const action = req.body.action; //get action + const postId = req.params.id + const comment = req.body.comment + const commenter = req.session.user.username + const commentObject = {comment:comment, user:commenter} + Post.updateOne({ _id: postId }, {$push: {comments:commentObject}}, {new:true}, function + (error) { + if (error) { + res.send(error); + console.log(error) + } + + }); + res.status(201).redirect("/posts"); + } }; + module.exports = PostsController; diff --git a/controllers/sessions.js b/controllers/sessions.js index 917e2e14c..cd6635d57 100644 --- a/controllers/sessions.js +++ b/controllers/sessions.js @@ -2,7 +2,7 @@ const User = require("../models/user"); const SessionsController = { New: (req, res) => { - res.render("sessions/new", {}); + res.render("sessions/new", {shownavbar:false}); }, Create: (req, res) => { @@ -11,10 +11,14 @@ const SessionsController = { const password = req.body.password; User.findOne({ email: email }).then((user) => { + //if user doesn't exist in the db, redirects to /new which creates a new account if (!user) { - res.redirect("/sessions/new"); + var wronguser = true; + res.render("home/index", {wronguser}); + //if the userpassword doesn't match it redirects } else if (user.password != password) { - res.redirect("/sessions/new"); + var wrongpass = true; + res.render("home/index",{wrongpass}); } else { req.session.user = user; res.redirect("/posts"); diff --git a/controllers/users.js b/controllers/users.js index bdc2ea8f3..96c207956 100644 --- a/controllers/users.js +++ b/controllers/users.js @@ -2,18 +2,41 @@ const User = require("../models/user"); const UsersController = { New: (req, res) => { - res.render("users/new", {}); + res.render("users/new", {shownavbar:true}); }, - Create: (req, res) => { - const user = new User(req.body); - user.save((err) => { + const newuser = new User(req.body); + const email = req.body.email + const username = req.body.username + User.findOne({ email: email }).then((user) => { + //if user doesn't exist in the db, redirects to /new which creates a new account + if (!user) { + User.findOne({ username: username }).then((name) => { + if (!name) { + newuser.save((err) => { if (err) { throw err; } - res.status(201).redirect("/posts"); - }); - }, -}; + var accountCreated = true; + res.render("home/index", {accountCreated}) + })} + else + { + console.log('User already exists!') + var usernameExists = true; + res.render("home/index", {usernameExists}) + } + })} + //if user email and name doesn't exist, save it + else + { + console.log('User already exists!') + var emailExists = true; + res.render("home/index", {emailExists}) + } + }) + } + } + -module.exports = UsersController; +module.exports = UsersController; \ No newline at end of file diff --git a/models/post.js b/models/post.js index 3ef06ae2d..b7b6fafe7 100644 --- a/models/post.js +++ b/models/post.js @@ -1,10 +1,22 @@ const mongoose = require("mongoose"); + const PostSchema = new mongoose.Schema({ - message: String, - likes: { type: Number, default: 0 } + message: {type:String, required:true}, + author: {type:String, required:true}, //required true means it is needed when a post is created, we can then pass an objecrt including user info to the new post initialisation. + likes: { type: Number, default: 0 }, + loves: { type: Number, default: 0 }, + date: { type: Date, default:Date.now }, + image: {type:String}, + comments: [{ + date: { type: Date, default: Date.now }, + comment: {type: String}, + user: {type:String} +}] + }); + const Post = mongoose.model("Post", PostSchema); module.exports = Post; diff --git a/models/user.js b/models/user.js index 27406b498..321d54a2c 100644 --- a/models/user.js +++ b/models/user.js @@ -1,10 +1,22 @@ const mongoose = require("mongoose"); const UserSchema = new mongoose.Schema({ - email: String, + username: {type: String, unique: true}, + email: {type: String, unique: true}, password: String, + profilepic: {type:String}, + friends: {type: [String], default: []} }); const User = mongoose.model("User", UserSchema); +//const friend = new User({username: "Kitten", email: "kitten@kitten.com", password: "password "}) +//friend.friends.push("Steve") -module.exports = User; +//friend.save() +// User.findOneAndUpdate( +// { _id: "63bc4bc14dbd82782c7cc65c" }, +// { $push: { +// friends : "Steve" +// } +// }) +module.exports = User; \ No newline at end of file diff --git a/public/.DS_Store b/public/.DS_Store new file mode 100644 index 000000000..52846d7f3 Binary files /dev/null and b/public/.DS_Store differ diff --git a/public/images/.DS_Store b/public/images/.DS_Store new file mode 100644 index 000000000..9aba217bd Binary files /dev/null and b/public/images/.DS_Store differ diff --git a/public/images/Catbook.gif b/public/images/Catbook.gif new file mode 100644 index 000000000..8cb5c9370 Binary files /dev/null and b/public/images/Catbook.gif differ diff --git a/public/images/favicon.ico b/public/images/favicon.ico new file mode 100644 index 000000000..9159cba1a Binary files /dev/null and b/public/images/favicon.ico differ diff --git a/public/images/paw.jpg b/public/images/paw.jpg new file mode 100644 index 000000000..9159cba1a Binary files /dev/null and b/public/images/paw.jpg differ diff --git a/public/stylesheets/style.css b/public/stylesheets/style.css index 9453385b9..4119dbcc9 100644 --- a/public/stylesheets/style.css +++ b/public/stylesheets/style.css @@ -4,5 +4,176 @@ body { } a { - color: #00B7FF; + color: #911758; } + +.like-button{ + width:15px; + height:15px; +} + +.row{ + width:15px; + height:15px; +} +body{ + padding: 0; + margin: 0; + background-color: #a205; +} +.container{ + height: 500px; + width: 350px; + position: absolute; + margin: auto; + top: 0; + bottom: 0; + left: 1000; + right: 0; + z-index: -1; +} +.cat{ + position: relative; + top: 150px; + left: 50px; +} +.face{ + background-color: #33292b; + height: 100px; + width: 150px; + border-radius: 30px; +} +.ear-1,.ear-r{ + width: 0; + height: 0; + border-bottom: 50px solid #33292b; + border-left: 20px solid transparent; + border-right: 20px solid transparent; + position: relative; + z-index: -1; +} +.ear-1{ + bottom: 35px; + transform: rotate(-30deg); +} +.ear-r{ + bottom: 85px; + left: 110px; + transform: rotate(30deg); +} +.inner-1{ + width: 0; + height: 0; + border-bottom: 50px solid #d36149; + border-left: 25px solid transparent; + right: 25px; + position: relative; +} +.inner-2{ + width: 0; + height: 0; + border-bottom: 50px solid #d36149; + border-right: 25px solid transparent; + position: relative; +} +.eye-1,.eye-r{ + background-color: #d2873b; + height: 30px; + width: 30px; + border-radius: 50%; + position: relative; +} +.eye-1{ + bottom: 75px; + left: 30px; +} +.eye-r{ + bottom: 105px; + left: 90px; +} +.eyeball{ + background-color: #262626; + height: 24px; + width: 24px; + border-radius: 50%; + position: relative; + top: 3px; + left: 3px; +} +.nose{ + height: 0; + width: 0; + border-top: 8px solid #d36149; + border-left: 7px solid transparent; + border-right: 7px solid transparent; + position: relative; + bottom: 110px; + left: 68px; +} +.l1,.l2{ + background-color: #d36149; + height: 8px; + width: 1px; + position: relative; +} +.l1{ + transform: rotate(45deg); + right: 4px; + bottom: 1.5px; +} +.l2{ + transform: rotate(-45deg); + bottom: 10px; + left: 3px; +} +.body{ + background-color: #33292b; + height: 120px; + width: 150px; + position: relative; + left: 30px; + border: 5px; + border-radius: 0 65px 0 0; +} +.paw-1,.paw-2{ + background-color: #33292b; + height: 10px; + width: 22px; + position: relative; + border-radius: 0 0 10px 10px; +} +.paw-1{ + top: 120px; +} +.paw-2{ + top: 110px; + left: 50px; +} +.tail{ + background-color: #33292b; + width: 100px; + height: 20px; + position: relative; + top: 80px; + left: 100px; + border-radius: 0 20px 20px 0; +} +.shadow{ + background-color: rgba(8,8,8,0.05); + height: 30px; + width: 150px; + border-radius: 50%; + position: relative; + bottom: 15px; + left: 20px; + z-index: -1; +} + +.box { + border: 1px solid black; + padding: 20px; +} + +.box:hover { + box-shadow: 4px 4px 4px grey; +} \ No newline at end of file diff --git a/routes/friends.js b/routes/friends.js new file mode 100644 index 000000000..b480b4aa7 --- /dev/null +++ b/routes/friends.js @@ -0,0 +1,8 @@ +const express = require("express"); +const router = express.Router(); + +const FriendsController = require("../controllers/friends"); + +router.get("/", FriendsController.Index); + +module.exports = router; \ No newline at end of file diff --git a/routes/posts.js b/routes/posts.js index d4ec2d937..f4d8311a1 100644 --- a/routes/posts.js +++ b/routes/posts.js @@ -6,5 +6,14 @@ const PostsController = require("../controllers/posts"); router.get("/", PostsController.Index); router.post("/", PostsController.Create); router.get("/new", PostsController.New); +router.get("/explore", PostsController.Explore); //is this weird? + +router.post('/:id/act', PostsController.Like); +router.post('/:id/love', PostsController.Love); + +//add a friend to follow +router.post('/:id/befriend', PostsController.Follow); +// submit is a comment +router.post('/:id/comment', PostsController.Comment); module.exports = router; diff --git a/spec/models/post.spec.js b/spec/models/post.spec.js index 3acfd48ce..038097628 100644 --- a/spec/models/post.spec.js +++ b/spec/models/post.spec.js @@ -9,10 +9,15 @@ describe("Post model", () => { done(); }); }); - +//this has been changed due to the fact it now saves a post with an author + // it("has a message", () => { + // var post = new Post({ message: "some message" }); + // expect(post.message).toEqual("some message"); + // }); it("has a message", () => { - var post = new Post({ message: "some message" }); + var post = new Post({ message: "some message", author:'Andy Pandy'}); expect(post.message).toEqual("some message"); + expect(post.author).toEqual("Andy Pandy") }); it("can list all posts", (done) => { @@ -36,5 +41,11 @@ describe("Post model", () => { done(); }); }); + xit("can like a post and increase the likes by 1", () => { + //we need to change it so it can only be liked and then freeze the button forevermore? + }); + xit("can love a post and increase the loves by 1", () => { + + }) }); }); diff --git a/views/friends/index.hbs b/views/friends/index.hbs new file mode 100644 index 000000000..12298f007 --- /dev/null +++ b/views/friends/index.hbs @@ -0,0 +1,43 @@ + + + + +

Furrends

+

{{user.username}}

+ + + + + +{{!-- loop through the friends list array and print each one to the screen --}} +{{#each friendslist.friends }} +
+

{{this}}

+ +
+
+ +{{/each}} + + + + + + + + diff --git a/views/home/index.hbs b/views/home/index.hbs index 7ad30d847..892e606c2 100644 --- a/views/home/index.hbs +++ b/views/home/index.hbs @@ -1,2 +1,52 @@ -

{{title}}

-

Welcome to {{title}}

+ + + + + + + +
+

Please log in or sign up

+
+ +
+
+
+ + +
+ +

+ {{#if accountCreated}} + Account created! Please sign in. + {{/if}} + {{#if emailExists}} + Email already exists!
+ Please try to log in, or try to sign up with a different email. + {{/if}} + {{#if usernameExists}} + Username already exists!
+ Please try to log in, or try to sign up with a different username. + {{/if}} + {{#if wronguser}} + User does not exist, please sign up! + {{/if}} + {{#if wrongpass}} + Password is incorrect, please try again. + {{/if}} +
+ {{!-- password and user prompts for incorrect --}} +
+
+

+
+ +

+{{!-- currently doesn't work needs to have a new route added with a form --}} +
+ +

+
+
+ + \ No newline at end of file diff --git a/views/layout.hbs b/views/layout.hbs index 17645b71e..1a6064b1a 100644 --- a/views/layout.hbs +++ b/views/layout.hbs @@ -1,13 +1,171 @@ + - - {{title}} - - - -
- -
- {{{body}}} - + + + + Catbook + + + + + + +
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ + + + + + + + + + +
+
+ + + {{/if}} +
+ {{{body}}} + + + +
+ + + diff --git a/views/posts/explore.hbs b/views/posts/explore.hbs new file mode 100644 index 000000000..dffe53b4e --- /dev/null +++ b/views/posts/explore.hbs @@ -0,0 +1,249 @@ + + + + + + + + + + + + + +
+
+ {{#if user.profilepic }} + + {{else}} + User + {{/if}} + +

{{user.username}}

+

Welcome {{user.username}} +

+
+ +
+ +
+ {{!-- for each of the posts array, the message and date is posted and a button + rendered - the button has a onclick method that runs a method from the script, + each button has a data-post-id attached in which the posts.id is attached to. + the item with likes count is given an idea which is also associated with posts.id --}} + {{#each posts }} +
+
+
+ {{ this.message }}
+
+ + {{#if this.image }} + image not found! + {{else}} +

+ {{/if}} + +
+ +

{{ this.author }}

+ {{!-- {{#if }} + image not found! + {{else}} +

+ {{/if}} --}} +
+
+
+ {{ this.date }} +
+ {{!-- adds a little meow with the like counter, associated with this.id and showing this.likes_count --}} +
+ +
+ 😻 + {{ this.likes }} + + 🐾 + {{ this.loves }} + +
+ {{!-- set the data-post-id as posts.id onto this button --}} + +
+ + +
+
+
+ {{!-- adds a little meow with the like counter, associated with this.id and showing this.likes_count --}} + {{!-- set the data-post-id as posts.id onto this button --}} +
+
+
Comments:
+ {{#each this.comments}} +
+ "{{this.comment}}" - {{this.user}}, {{this.date}}
+ + {{/each}} +
+
+
+
+ + + +
+ +
+ + + +
+ {{/each}} +
+ +
+ + + + + \ No newline at end of file diff --git a/views/posts/index.hbs b/views/posts/index.hbs index 4a4bca1d8..b054461b1 100644 --- a/views/posts/index.hbs +++ b/views/posts/index.hbs @@ -1,9 +1,250 @@ -

Timeline

- + + +
+ +
+ New post
+ -New post + \ No newline at end of file diff --git a/views/posts/new.hbs b/views/posts/new.hbs index a80541cdf..5a05a5e96 100644 --- a/views/posts/new.hbs +++ b/views/posts/new.hbs @@ -1,5 +1,18 @@ + + + + + +
+ + +
+ + + + diff --git a/views/sessions/new.hbs b/views/sessions/new.hbs index 86de20b62..892e606c2 100644 --- a/views/sessions/new.hbs +++ b/views/sessions/new.hbs @@ -1,7 +1,52 @@ + + + + + + + +
+

Please log in or sign up

+
+ +
+
- - - - - -
+ + +
+ +

+ {{#if accountCreated}} + Account created! Please sign in. + {{/if}} + {{#if emailExists}} + Email already exists!
+ Please try to log in, or try to sign up with a different email. + {{/if}} + {{#if usernameExists}} + Username already exists!
+ Please try to log in, or try to sign up with a different username. + {{/if}} + {{#if wronguser}} + User does not exist, please sign up! + {{/if}} + {{#if wrongpass}} + Password is incorrect, please try again. + {{/if}} +
+ {{!-- password and user prompts for incorrect --}} +
+
+
+
+ +

+{{!-- currently doesn't work needs to have a new route added with a form --}} +
+ +

+
+
+ + \ No newline at end of file diff --git a/views/test.hbs b/views/test.hbs new file mode 100644 index 000000000..17645b71e --- /dev/null +++ b/views/test.hbs @@ -0,0 +1,13 @@ + + + + {{title}} + + + +
+ +
+ {{{body}}} + + diff --git a/views/users/new.hbs b/views/users/new.hbs index 13e3b4fc1..325887948 100644 --- a/views/users/new.hbs +++ b/views/users/new.hbs @@ -1,7 +1,18 @@ + + + + +
- - +
+ +
+
+ +
+ + \ No newline at end of file