diff --git a/.gitignore b/.gitignore
index cf709889..600e365e 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1 +1 @@
-**/node_modules
+**/node_modules
\ No newline at end of file
diff --git a/.idea/express-personal-api.iml b/.idea/express-personal-api.iml
new file mode 100644
index 00000000..c3cd732c
--- /dev/null
+++ b/.idea/express-personal-api.iml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/misc.xml b/.idea/misc.xml
new file mode 100644
index 00000000..319f9a80
--- /dev/null
+++ b/.idea/misc.xml
@@ -0,0 +1,7 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/modules.xml b/.idea/modules.xml
new file mode 100644
index 00000000..3f28dff8
--- /dev/null
+++ b/.idea/modules.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
new file mode 100644
index 00000000..94a25f7f
--- /dev/null
+++ b/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/.idea/workspace.xml b/.idea/workspace.xml
new file mode 100644
index 00000000..c90baaf6
--- /dev/null
+++ b/.idea/workspace.xml
@@ -0,0 +1,582 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ todo
+ this
+ delete-bu
+ data-movie
+ closest
+ find(
+ "get"
+ -icon
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ true
+
+ false
+ true
+ true
+
+
+ true
+ DEFINITION_ORDER
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 1504303087591
+
+
+ 1504303087591
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/controllers/index.js b/controllers/index.js
new file mode 100644
index 00000000..23ed5af3
--- /dev/null
+++ b/controllers/index.js
@@ -0,0 +1,14 @@
+// // GET /api/albums
+// function index(req, res) {
+// // send back all albums as JSON
+// db.Album.find({}, function(err, allAlbums) {
+// res.json(allAlbums);
+// });
+// }
+
+
+//need to connect index function to display data from seed, start with ajax in app.js
+
+module.exports = {
+ movies: require('./moviesController'),
+}
diff --git a/controllers/moviesController.js b/controllers/moviesController.js
new file mode 100644
index 00000000..135d7fe3
--- /dev/null
+++ b/controllers/moviesController.js
@@ -0,0 +1,58 @@
+/************
+ * DATABASE *
+ ************/
+//change everything here into movies
+var db = require('../models');
+
+// GET /api/albums
+function index(req, res) {
+ // send back all albums as JSON
+ db.Movie.find({}, function(err, allMovies) {
+ res.json(allMovies);
+ // console.log(allMovies);
+ });
+}
+
+// POST /api/albums
+function create(req, res) {
+ // create an album based on request body and send it back as JSON
+ console.log('body', req.body);
+ db.Movie.create(req.body)
+ // if (err) { console.log('error', err); }
+ console.log("hello");
+ res.json(req.body);
+}
+
+function show(req, res) {
+ // send back all albums as JSON
+ db.Movie.findById({_id: req.params.movieid}, function(err, allMovies) {
+ res.json(allMovies);
+ // console.log(allMovies);
+ });
+}
+
+function destroy(req, res) {
+ db.Movie.findOneAndRemove({_id: req.params.movieid}, function(err, remainingMovies) {
+ })
+}
+
+function update(req, res) {
+ console.log(req.body);
+ db.Movie.findByIdAndUpdate(req.params.movieid, {new: true}, (err, movie) => {
+ movie.title = req.body.title;
+ movie.director= req.body.director;
+ movie.year= req.body.year;
+ movie.image = req.body.image
+ movie.save();
+ })
+ console.log('testing');
+}
+
+// export public methods here
+module.exports = {
+ index: index,
+ create: create,
+ show: show,
+ destroy: destroy,
+ update: update
+};
\ No newline at end of file
diff --git a/models/hobbies.js b/models/hobbies.js
new file mode 100644
index 00000000..bd8e520e
--- /dev/null
+++ b/models/hobbies.js
@@ -0,0 +1,11 @@
+var mongoose = require("mongoose");
+var Schema = mongoose.Schema;
+
+var HobbySchema = new Schema({
+ name: String,
+ yearsPlaying: Number
+});
+
+var Hobby = mongoose.model('Hobby', HobbySchema);
+
+module.exports = Hobby;
\ No newline at end of file
diff --git a/models/index.js b/models/index.js
index 66997fe0..119d1aef 100644
--- a/models/index.js
+++ b/models/index.js
@@ -2,4 +2,6 @@ var mongoose = require("mongoose");
mongoose.connect( process.env.MONGODB_URI || "mongodb://localhost/personal-api", {useMongoClient: true});
mongoose.Promise = global.Promise; // use native Promise
-// module.exports.Campsite = require("./campsite.js.example");
+module.exports.Personal = require("./personal_data");
+module.exports.Hobby = require("./hobbies");
+module.exports.Movie = require("./movies");
diff --git a/models/movies.js b/models/movies.js
new file mode 100644
index 00000000..31164648
--- /dev/null
+++ b/models/movies.js
@@ -0,0 +1,12 @@
+var mongoose = require("mongoose");
+var Schema = mongoose.Schema;
+
+var MovieSchema = new Schema({
+ title: String,
+ year: Number,
+ director: String,
+ image: String,
+});
+
+var Movie = mongoose.model('Movie', MovieSchema);
+module.exports = Movie;
\ No newline at end of file
diff --git a/models/personal_data.js b/models/personal_data.js
new file mode 100644
index 00000000..f4843ce0
--- /dev/null
+++ b/models/personal_data.js
@@ -0,0 +1,19 @@
+var mongoose = require("mongoose");
+var Schema = mongoose.Schema;
+
+var Hobby = require('./hobbies');
+
+
+var PersonalSchema = new Schema({
+ name: String,
+ githubUsername: String,
+ githubLink: String,
+ githubProfileImage: String,
+ personalSiteLink: String,
+ currentCity: String,
+ hobbies: [Hobby.schema]
+});
+
+var Personal = mongoose.model('Personal', PersonalSchema);
+
+module.exports = Personal;
diff --git a/package-lock.json b/package-lock.json
new file mode 100644
index 00000000..6596d516
--- /dev/null
+++ b/package-lock.json
@@ -0,0 +1,547 @@
+{
+ "name": "express-personal-api",
+ "version": "1.0.0",
+ "lockfileVersion": 1,
+ "requires": true,
+ "dependencies": {
+ "accepts": {
+ "version": "1.3.4",
+ "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.4.tgz",
+ "integrity": "sha1-hiRnWMfdbSGmR0/whKR0DsBesh8=",
+ "requires": {
+ "mime-types": "2.1.16",
+ "negotiator": "0.6.1"
+ }
+ },
+ "array-flatten": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz",
+ "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI="
+ },
+ "async": {
+ "version": "2.1.4",
+ "resolved": "https://registry.npmjs.org/async/-/async-2.1.4.tgz",
+ "integrity": "sha1-LSFgx3iAMuTdbL4lAvH5osj2zeQ=",
+ "requires": {
+ "lodash": "4.17.4"
+ }
+ },
+ "bluebird": {
+ "version": "2.10.2",
+ "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-2.10.2.tgz",
+ "integrity": "sha1-AkpVFylTCIV/FPkfEQb8O1VfRGs="
+ },
+ "body-parser": {
+ "version": "1.17.2",
+ "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.17.2.tgz",
+ "integrity": "sha1-+IkqvI+eYn1Crtr7yma/WrmRBO4=",
+ "requires": {
+ "bytes": "2.4.0",
+ "content-type": "1.0.2",
+ "debug": "2.6.7",
+ "depd": "1.1.1",
+ "http-errors": "1.6.2",
+ "iconv-lite": "0.4.15",
+ "on-finished": "2.3.0",
+ "qs": "6.4.0",
+ "raw-body": "2.2.0",
+ "type-is": "1.6.15"
+ },
+ "dependencies": {
+ "debug": {
+ "version": "2.6.7",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.7.tgz",
+ "integrity": "sha1-krrR9tBbu2u6Isyoi80OyJTChh4=",
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "qs": {
+ "version": "6.4.0",
+ "resolved": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz",
+ "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM="
+ }
+ }
+ },
+ "bson": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/bson/-/bson-1.0.4.tgz",
+ "integrity": "sha1-k8ENOeqltYQVy8QFLz5T5WKwtyw="
+ },
+ "buffer-shims": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/buffer-shims/-/buffer-shims-1.0.0.tgz",
+ "integrity": "sha1-mXjOMXOIxkmth5MCjDR37wRKi1E="
+ },
+ "bytes": {
+ "version": "2.4.0",
+ "resolved": "https://registry.npmjs.org/bytes/-/bytes-2.4.0.tgz",
+ "integrity": "sha1-fZcZb51br39pNeJZhVSe3SpsIzk="
+ },
+ "content-disposition": {
+ "version": "0.5.2",
+ "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.2.tgz",
+ "integrity": "sha1-DPaLud318r55YcOoUXjLhdunjLQ="
+ },
+ "content-type": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.2.tgz",
+ "integrity": "sha1-t9ETrueo3Se9IRM8TcJSnfFyHu0="
+ },
+ "cookie": {
+ "version": "0.3.1",
+ "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.3.1.tgz",
+ "integrity": "sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s="
+ },
+ "cookie-signature": {
+ "version": "1.0.6",
+ "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz",
+ "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw="
+ },
+ "core-util-is": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz",
+ "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac="
+ },
+ "debug": {
+ "version": "2.6.8",
+ "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz",
+ "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=",
+ "requires": {
+ "ms": "2.0.0"
+ }
+ },
+ "depd": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.1.tgz",
+ "integrity": "sha1-V4O04cRZ8G+lyif5kfPQbnoxA1k="
+ },
+ "destroy": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz",
+ "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA="
+ },
+ "ee-first": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz",
+ "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0="
+ },
+ "encodeurl": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.1.tgz",
+ "integrity": "sha1-eePVhlU0aQn+bw9Fpd5oEDspTSA="
+ },
+ "es6-promise": {
+ "version": "3.2.1",
+ "resolved": "https://registry.npmjs.org/es6-promise/-/es6-promise-3.2.1.tgz",
+ "integrity": "sha1-7FYjOGgDKQkgcXDDlEjiREndH8Q="
+ },
+ "escape-html": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz",
+ "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg="
+ },
+ "etag": {
+ "version": "1.8.0",
+ "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.0.tgz",
+ "integrity": "sha1-b2Ma7zNtbEY2K1F2QETOIWvjwFE="
+ },
+ "express": {
+ "version": "4.15.4",
+ "resolved": "https://registry.npmjs.org/express/-/express-4.15.4.tgz",
+ "integrity": "sha1-Ay4iU0ic+PzgJma+yj0R7XotrtE=",
+ "requires": {
+ "accepts": "1.3.4",
+ "array-flatten": "1.1.1",
+ "content-disposition": "0.5.2",
+ "content-type": "1.0.2",
+ "cookie": "0.3.1",
+ "cookie-signature": "1.0.6",
+ "debug": "2.6.8",
+ "depd": "1.1.1",
+ "encodeurl": "1.0.1",
+ "escape-html": "1.0.3",
+ "etag": "1.8.0",
+ "finalhandler": "1.0.4",
+ "fresh": "0.5.0",
+ "merge-descriptors": "1.0.1",
+ "methods": "1.1.2",
+ "on-finished": "2.3.0",
+ "parseurl": "1.3.1",
+ "path-to-regexp": "0.1.7",
+ "proxy-addr": "1.1.5",
+ "qs": "6.5.0",
+ "range-parser": "1.2.0",
+ "send": "0.15.4",
+ "serve-static": "1.12.4",
+ "setprototypeof": "1.0.3",
+ "statuses": "1.3.1",
+ "type-is": "1.6.15",
+ "utils-merge": "1.0.0",
+ "vary": "1.1.1"
+ }
+ },
+ "finalhandler": {
+ "version": "1.0.4",
+ "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.0.4.tgz",
+ "integrity": "sha512-16l/r8RgzlXKmFOhZpHBztvye+lAhC5SU7hXavnerC9UfZqZxxXl3BzL8MhffPT3kF61lj9Oav2LKEzh0ei7tg==",
+ "requires": {
+ "debug": "2.6.8",
+ "encodeurl": "1.0.1",
+ "escape-html": "1.0.3",
+ "on-finished": "2.3.0",
+ "parseurl": "1.3.1",
+ "statuses": "1.3.1",
+ "unpipe": "1.0.0"
+ }
+ },
+ "forwarded": {
+ "version": "0.1.0",
+ "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.0.tgz",
+ "integrity": "sha1-Ge+YdMSuHCl7zweP3mOgm2aoQ2M="
+ },
+ "fresh": {
+ "version": "0.5.0",
+ "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.0.tgz",
+ "integrity": "sha1-9HTKXmqSRtb9jglTz6m5yAWvp44="
+ },
+ "hooks-fixed": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/hooks-fixed/-/hooks-fixed-2.0.0.tgz",
+ "integrity": "sha1-oB2JTVKsf2WZu7H2PfycQR33DLo="
+ },
+ "http-errors": {
+ "version": "1.6.2",
+ "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.2.tgz",
+ "integrity": "sha1-CgAsyFcHGSp+eUbO7cERVfYOxzY=",
+ "requires": {
+ "depd": "1.1.1",
+ "inherits": "2.0.3",
+ "setprototypeof": "1.0.3",
+ "statuses": "1.3.1"
+ }
+ },
+ "iconv-lite": {
+ "version": "0.4.15",
+ "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.15.tgz",
+ "integrity": "sha1-/iZaIYrGpXz+hUkn6dBMGYJe3es="
+ },
+ "inherits": {
+ "version": "2.0.3",
+ "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz",
+ "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4="
+ },
+ "ipaddr.js": {
+ "version": "1.4.0",
+ "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.4.0.tgz",
+ "integrity": "sha1-KWrKh4qCGBbluF0KKFqZvP9FgvA="
+ },
+ "isarray": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz",
+ "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE="
+ },
+ "kareem": {
+ "version": "1.5.0",
+ "resolved": "https://registry.npmjs.org/kareem/-/kareem-1.5.0.tgz",
+ "integrity": "sha1-4+QQHZ3P3imXadr0tNtk2JXRdEg="
+ },
+ "lodash": {
+ "version": "4.17.4",
+ "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.4.tgz",
+ "integrity": "sha1-eCA6TRwyiuHYbcpkYONptX9AVa4="
+ },
+ "media-typer": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz",
+ "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g="
+ },
+ "merge-descriptors": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz",
+ "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E="
+ },
+ "methods": {
+ "version": "1.1.2",
+ "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz",
+ "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4="
+ },
+ "mime": {
+ "version": "1.3.4",
+ "resolved": "https://registry.npmjs.org/mime/-/mime-1.3.4.tgz",
+ "integrity": "sha1-EV+eO2s9rylZmDyzjxSaLUDrXVM="
+ },
+ "mime-db": {
+ "version": "1.29.0",
+ "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.29.0.tgz",
+ "integrity": "sha1-SNJtI1WJZRcErFkWygYAGRQmaHg="
+ },
+ "mime-types": {
+ "version": "2.1.16",
+ "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.16.tgz",
+ "integrity": "sha1-K4WKUuXs1RbbiXrCvodIeDBpjiM=",
+ "requires": {
+ "mime-db": "1.29.0"
+ }
+ },
+ "mongodb": {
+ "version": "2.2.31",
+ "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-2.2.31.tgz",
+ "integrity": "sha1-GUBEXGYeGSF7s7+CRdmFSq71SNs=",
+ "requires": {
+ "es6-promise": "3.2.1",
+ "mongodb-core": "2.1.15",
+ "readable-stream": "2.2.7"
+ }
+ },
+ "mongodb-core": {
+ "version": "2.1.15",
+ "resolved": "https://registry.npmjs.org/mongodb-core/-/mongodb-core-2.1.15.tgz",
+ "integrity": "sha1-hB9TuH//9MdFgYnDXIroJ+EWl2Q=",
+ "requires": {
+ "bson": "1.0.4",
+ "require_optional": "1.0.1"
+ }
+ },
+ "mongoose": {
+ "version": "4.11.9",
+ "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-4.11.9.tgz",
+ "integrity": "sha512-4WTZOex1yGVv5lwjEtIQ4DEP9UaYL8wLhhrxrSBC8meU8l/D+r/cBeNfHMmIptWNonIp9gpgvKu3Vk3IkuXDTw==",
+ "requires": {
+ "async": "2.1.4",
+ "bson": "1.0.4",
+ "hooks-fixed": "2.0.0",
+ "kareem": "1.5.0",
+ "mongodb": "2.2.31",
+ "mpath": "0.3.0",
+ "mpromise": "0.5.5",
+ "mquery": "2.3.1",
+ "ms": "2.0.0",
+ "muri": "1.2.2",
+ "regexp-clone": "0.0.1",
+ "sliced": "1.0.1"
+ }
+ },
+ "mpath": {
+ "version": "0.3.0",
+ "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.3.0.tgz",
+ "integrity": "sha1-elj3iem1/TyUUgY0FXlg8mvV70Q="
+ },
+ "mpromise": {
+ "version": "0.5.5",
+ "resolved": "https://registry.npmjs.org/mpromise/-/mpromise-0.5.5.tgz",
+ "integrity": "sha1-9bJCWddjrMIlewoMjG2Gb9UXMuY="
+ },
+ "mquery": {
+ "version": "2.3.1",
+ "resolved": "https://registry.npmjs.org/mquery/-/mquery-2.3.1.tgz",
+ "integrity": "sha1-mrNnSXFIAP8LtTpoHOS8TV8HyHs=",
+ "requires": {
+ "bluebird": "2.10.2",
+ "debug": "2.6.8",
+ "regexp-clone": "0.0.1",
+ "sliced": "0.0.5"
+ },
+ "dependencies": {
+ "sliced": {
+ "version": "0.0.5",
+ "resolved": "https://registry.npmjs.org/sliced/-/sliced-0.0.5.tgz",
+ "integrity": "sha1-XtwETKTrb3gW1Qui/GPiXY/kcH8="
+ }
+ }
+ },
+ "ms": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz",
+ "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g="
+ },
+ "muri": {
+ "version": "1.2.2",
+ "resolved": "https://registry.npmjs.org/muri/-/muri-1.2.2.tgz",
+ "integrity": "sha1-YxmBMmUNsIoEzHnM0A3Tia/SYxw="
+ },
+ "negotiator": {
+ "version": "0.6.1",
+ "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.1.tgz",
+ "integrity": "sha1-KzJxhOiZIQEXeyhWP7XnECrNDKk="
+ },
+ "on-finished": {
+ "version": "2.3.0",
+ "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz",
+ "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=",
+ "requires": {
+ "ee-first": "1.1.1"
+ }
+ },
+ "parseurl": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.1.tgz",
+ "integrity": "sha1-yKuMkiO6NIiKpkopeyiFO+wY2lY="
+ },
+ "path-to-regexp": {
+ "version": "0.1.7",
+ "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz",
+ "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w="
+ },
+ "process-nextick-args": {
+ "version": "1.0.7",
+ "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-1.0.7.tgz",
+ "integrity": "sha1-FQ4gt1ZZCtP5EJPyWk8q2L/zC6M="
+ },
+ "proxy-addr": {
+ "version": "1.1.5",
+ "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-1.1.5.tgz",
+ "integrity": "sha1-ccDuOxAt4/IC87ZPYI0XP8uhqRg=",
+ "requires": {
+ "forwarded": "0.1.0",
+ "ipaddr.js": "1.4.0"
+ }
+ },
+ "qs": {
+ "version": "6.5.0",
+ "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.0.tgz",
+ "integrity": "sha512-fjVFjW9yhqMhVGwRExCXLhJKrLlkYSaxNWdyc9rmHlrVZbk35YHH312dFd7191uQeXkI3mKLZTIbSvIeFwFemg=="
+ },
+ "range-parser": {
+ "version": "1.2.0",
+ "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.0.tgz",
+ "integrity": "sha1-9JvmtIeJTdxA3MlKMi9hEJLgDV4="
+ },
+ "raw-body": {
+ "version": "2.2.0",
+ "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.2.0.tgz",
+ "integrity": "sha1-mUl2z2pQlqQRYoQEkvC9xdbn+5Y=",
+ "requires": {
+ "bytes": "2.4.0",
+ "iconv-lite": "0.4.15",
+ "unpipe": "1.0.0"
+ }
+ },
+ "readable-stream": {
+ "version": "2.2.7",
+ "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.2.7.tgz",
+ "integrity": "sha1-BwV6y+JGeyIELTb5jFrVBwVOlbE=",
+ "requires": {
+ "buffer-shims": "1.0.0",
+ "core-util-is": "1.0.2",
+ "inherits": "2.0.3",
+ "isarray": "1.0.0",
+ "process-nextick-args": "1.0.7",
+ "string_decoder": "1.0.3",
+ "util-deprecate": "1.0.2"
+ }
+ },
+ "regexp-clone": {
+ "version": "0.0.1",
+ "resolved": "https://registry.npmjs.org/regexp-clone/-/regexp-clone-0.0.1.tgz",
+ "integrity": "sha1-p8LgmJH9vzj7sQ03b7cwA+aKxYk="
+ },
+ "require_optional": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/require_optional/-/require_optional-1.0.1.tgz",
+ "integrity": "sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g==",
+ "requires": {
+ "resolve-from": "2.0.0",
+ "semver": "5.4.1"
+ }
+ },
+ "resolve-from": {
+ "version": "2.0.0",
+ "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-2.0.0.tgz",
+ "integrity": "sha1-lICrIOlP+h2egKgEx+oUdhGWa1c="
+ },
+ "safe-buffer": {
+ "version": "5.1.1",
+ "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.1.tgz",
+ "integrity": "sha512-kKvNJn6Mm93gAczWVJg7wH+wGYWNrDHdWvpUmHyEsgCtIwwo3bqPtV4tR5tuPaUhTOo/kvhVwd8XwwOllGYkbg=="
+ },
+ "semver": {
+ "version": "5.4.1",
+ "resolved": "https://registry.npmjs.org/semver/-/semver-5.4.1.tgz",
+ "integrity": "sha512-WfG/X9+oATh81XtllIo/I8gOiY9EXRdv1cQdyykeXK17YcUW3EXUAi2To4pcH6nZtJPr7ZOpM5OMyWJZm+8Rsg=="
+ },
+ "send": {
+ "version": "0.15.4",
+ "resolved": "https://registry.npmjs.org/send/-/send-0.15.4.tgz",
+ "integrity": "sha1-mF+qPihLAnPHkzZKNcZze9k5Bbk=",
+ "requires": {
+ "debug": "2.6.8",
+ "depd": "1.1.1",
+ "destroy": "1.0.4",
+ "encodeurl": "1.0.1",
+ "escape-html": "1.0.3",
+ "etag": "1.8.0",
+ "fresh": "0.5.0",
+ "http-errors": "1.6.2",
+ "mime": "1.3.4",
+ "ms": "2.0.0",
+ "on-finished": "2.3.0",
+ "range-parser": "1.2.0",
+ "statuses": "1.3.1"
+ }
+ },
+ "serve-static": {
+ "version": "1.12.4",
+ "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.12.4.tgz",
+ "integrity": "sha1-m2qpjutyU8Tu3Ewfb9vKYJkBqWE=",
+ "requires": {
+ "encodeurl": "1.0.1",
+ "escape-html": "1.0.3",
+ "parseurl": "1.3.1",
+ "send": "0.15.4"
+ }
+ },
+ "setprototypeof": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.0.3.tgz",
+ "integrity": "sha1-ZlZ+NwQ+608E2RvWWMDL77VbjgQ="
+ },
+ "sliced": {
+ "version": "1.0.1",
+ "resolved": "https://registry.npmjs.org/sliced/-/sliced-1.0.1.tgz",
+ "integrity": "sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E="
+ },
+ "statuses": {
+ "version": "1.3.1",
+ "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.3.1.tgz",
+ "integrity": "sha1-+vUbnrdKrvOzrPStX2Gr8ky3uT4="
+ },
+ "string_decoder": {
+ "version": "1.0.3",
+ "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.0.3.tgz",
+ "integrity": "sha512-4AH6Z5fzNNBcH+6XDMfA/BTt87skxqJlO0lAh3Dker5zThcAxG6mKz+iGu308UKoPPQ8Dcqx/4JhujzltRa+hQ==",
+ "requires": {
+ "safe-buffer": "5.1.1"
+ }
+ },
+ "type-is": {
+ "version": "1.6.15",
+ "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.15.tgz",
+ "integrity": "sha1-yrEPtJCeRByChC6v4a1kbIGARBA=",
+ "requires": {
+ "media-typer": "0.3.0",
+ "mime-types": "2.1.16"
+ }
+ },
+ "unpipe": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz",
+ "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw="
+ },
+ "util-deprecate": {
+ "version": "1.0.2",
+ "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz",
+ "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8="
+ },
+ "utils-merge": {
+ "version": "1.0.0",
+ "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.0.tgz",
+ "integrity": "sha1-ApT7kiu5N1FTVBxPcJYjHyh8ivg="
+ },
+ "vary": {
+ "version": "1.1.1",
+ "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.1.tgz",
+ "integrity": "sha1-Z1Neu2lMHVIldFeYRmUyP1h+jTc="
+ }
+ }
+}
diff --git a/package.json b/package.json
index 22718d9e..03c0b9dd 100644
--- a/package.json
+++ b/package.json
@@ -18,7 +18,7 @@
"homepage": "https://github.com/SF-WDI-LABS/express-personal-api",
"dependencies": {
"body-parser": "^1.15.0",
- "express": "^4.13.4",
- "mongoose": "^4.4.10"
+ "express": "^4.15.4",
+ "mongoose": "^4.11.9"
}
}
diff --git a/public/images/background.jpg b/public/images/background.jpg
new file mode 100644
index 00000000..93bd5d7a
Binary files /dev/null and b/public/images/background.jpg differ
diff --git a/public/images/github-image.png b/public/images/github-image.png
new file mode 100644
index 00000000..228b09ac
Binary files /dev/null and b/public/images/github-image.png differ
diff --git a/public/images/movie-icon.png b/public/images/movie-icon.png
new file mode 100644
index 00000000..299d9ade
Binary files /dev/null and b/public/images/movie-icon.png differ
diff --git a/public/images/project-icon.png b/public/images/project-icon.png
new file mode 100644
index 00000000..b20399a6
Binary files /dev/null and b/public/images/project-icon.png differ
diff --git a/public/images/show-icon.png b/public/images/show-icon.png
new file mode 100644
index 00000000..53bea822
Binary files /dev/null and b/public/images/show-icon.png differ
diff --git a/public/scripts/app.js b/public/scripts/app.js
index 00988cd4..bfb49751 100644
--- a/public/scripts/app.js
+++ b/public/scripts/app.js
@@ -1,7 +1,137 @@
console.log("Sanity Check: JS is working!");
$(document).ready(function(){
+ $.ajax({
+ method: "GET",
+ url: "api/movies/:id",
+ });
-// your code
+ $(document).on("click", '.add-movie-button', function(event) {
+ event.preventDefault();
+ // console.log($('.title-input').val());
+ $.ajax({
+ method: "POST",
+ url: "/api/movies/",
+ data: {
+ title: $('.title-input').val(),
+ year: $('.year-input').val(),
+ director: $('.director-input').val(),
+ image: $('.image-input').val(),
+ }
+ });
+ $.ajax({
+ method: "GET",
+ url: "api/movies",
+ success: renderMovies,
+ });
+ });
+ $(document).on("click", '.save-movies', function(event) {
+ event.preventDefault();
+ let movieId = $(this).closest('.save-movies').data('movie-id');
+ let movies = $(this).closest('.list-container')
+ console.log(movies.find('.title-edit').val())
+ console.log(movies.find('.release-edit').val());
+ console.log(movies.find('.director-edit').val())
+ $.ajax({
+ method: "PUT",
+ url: "/api/movies/" + movieId,
+ data: {
+ title: movies.find('.title-edit').val(),
+ year: movies.find('.release-edit').val(),
+ director: movies.find('.director-edit').val(),
+ // image: $('.image-input').val(),
+ }
+ });
+ $.ajax({
+ method: "GET",
+ url: "api/movies",
+ success: renderMovies,
+ });
+ });
+
+ $(document).on("click", '.edit-movies', function(event) {
+ event.preventDefault();
+ let movieId = $(this).closest('.edit-movies').data('movie-id');
+ let movies = $(this).closest('.list-container');
+ console.log(movieId);
+ movies.find('.list-display').data('movie-id', movieId).toggle()
+ movies.find('.list-edit').data('movie-id', movieId).toggle();
+
+ });
+
+ $('.movie-icon').on("click", function() {
+ $.ajax({
+ method: "GET",
+ url: "api/movies",
+ success: renderMovies,
+ });
+ });
+
+ $(document).on("click", '.delete-movies', function(event) {
+ event.preventDefault();
+ let movieId = $(this).closest('.delete-movies').data('movie-id');
+ $.ajax({
+ method:"DELETE",
+ url: "api/movies/" + movieId,
+ })
+ $.ajax({
+ method: "GET",
+ url: "api/movies",
+ success: renderMovies,
+ });
+ });
});
+
+ function renderMovies(movieData) {
+ console.log(movieData)
+ console.log('hello')
+ event.preventDefault();
+ let listing = "";
+ $('.form-row').empty();
+ $('.all-listing').empty();
+ $('.form-row').append(`
+
+
Add some movies in the form below
+
+
+ `);
+ movieData.forEach(function(lists) {
+ listing += `
+
+
+

+
Title: ${lists.title}
+
Release: ${lists.year}
+
Director: ${lists.director}
+
+
+
+
+
+
+

+
+
+
`
+ })
+ $('.all-listing').append(listing);
+ };
diff --git a/public/styles/styles.css b/public/styles/styles.css
index 57b4da0e..5f6fee9a 100644
--- a/public/styles/styles.css
+++ b/public/styles/styles.css
@@ -1,10 +1,81 @@
+
+
body {
color: #333;
font-family: Helvetica, Arial, sans-serif;
- background-color: skyblue; /* Sanity Check! */
}
h1 {
margin-top: 100px;
text-align: center;
}
+
+.nav-styles {
+ padding: 10px 0;
+ opacity: 0.5;
+}
+
+.nav-list-styles {
+ font-size: 35px;
+ margin: 0 50px;
+}
+
+img {
+ height: 100px;
+ width: 100px;
+}
+
+.movie-image {
+ height: 350px;
+ width: 100%;
+ margin: 50px 25px 15px 25px;
+}
+
+.list-text {
+ font-family: Arial, Helvetica, sans-serif;;
+ text-align: left;
+ font-size: 25px;
+ margin: 0 0 0 25px;
+}
+
+.edit-movies {
+ width: 30%;
+ margin: 0 0 0 25px;
+}
+
+.save-movies {
+ width: 30%;
+ margin: 0 0 0 25px;
+}
+
+.delete-movies {
+ width: 30%;
+ margin: 0 0 0 25px;
+}
+
+.list-display {
+ display: inline;
+}
+
+.list-edit {
+ display: none;
+}
+
+.list-input {
+ width: 50%;
+ margin: 5px 0;
+}
+
+body {
+ background-image: url('/images/background.jpg');
+ background-size: cover;
+ background-repeat: no-repeat;
+}
+
+.all-listing {
+ margin: 0 0 25px 0;
+}
+
+div h1 {
+ margin-top: 0;
+}
\ No newline at end of file
diff --git a/seed.js b/seed.js
index 896dead0..8c08384a 100644
--- a/seed.js
+++ b/seed.js
@@ -1,15 +1,36 @@
// This file allows us to seed our application with data
// simply run: `node seed.js` from the root of this project folder.
+//app will talk to server which will talk to seed.js
+var db = require('./models');
+var personalData = [];
-// var db = require('./models');
+personalData.push({name: 'David Jue'});
+personalData.push({githubUsername: 'Congocash'});
+personalData.push({githubLink: 'https://github.com/CongoCash'});
+personalData.push({githubProfileImage: '../public/images/github-image.png'});
+personalData.push({personalSiteLink: 'https://peaceful-chamber-97994.herokuapp.com/'});
+personalData.push({currentCity: 'San Francisco'});
+personalData.push({
+ hobbies: [
+ {
+ name: 'Basketball',
+ yearsPlaying: 13,
+ },
+ {
+ name: 'Tetris',
+ yearsPlaying: 5
+ },
+ ]
+})
-// var new_campsite = {description: "Sharp rocks. Middle of nowhere."}
-// db.Campsite.create(new_campsite, function(err, campsite){
-// if (err){
-// return console.log("Error:", err);
-// }
-// console.log("Created new campsite", campsite._id)
-// process.exit(); // we're all done! Exit the program.
-// })
+
+db.Personal.create(personalData, function(err, data){
+ if (err){
+ return console.log("Error:", err);
+ }
+
+ console.log("Created new campsite", data)
+ process.exit(); // we're all done! Exit the program.
+})
diff --git a/server.js b/server.js
index fd366289..fd9046c1 100644
--- a/server.js
+++ b/server.js
@@ -1,6 +1,6 @@
// require express and other modules
-var express = require('express'),
- app = express();
+var express = require('express');
+var app = express();
// parse incoming urlencoded form data
// and populate the req.body object
@@ -15,6 +15,8 @@ app.use(function(req, res, next) {
next();
});
+var controllers = require('./controllers');
+
/************
* DATABASE *
************/
@@ -59,6 +61,30 @@ app.get('/api', function apiIndex(req, res) {
})
});
+app.get('/api/profile', function apiProfile(req, res) {
+ res.json({
+ name: 'David Jue',
+ githubUsername: 'Congocash',
+ githubLink: 'https://github.com/CongoCash',
+ githubProfileImage: '../public/images/github-image.png',
+ personalSiteLink: 'https://peaceful-chamber-97994.herokuapp.com/',
+ currentCity: 'San Francisco',
+ hobbies: [{
+ name: 'Basketball',
+ yearsPlaying: 14
+ },
+ {
+ name: 'Tetris',
+ yearsPlaying: 6
+ }]
+ });
+});
+
+app.post('/api/movies', controllers.movies.create);
+app.get('/api/movies', controllers.movies.index);
+app.get('/api/movies/:movieid', controllers.movies.show);
+app.delete('/api/movies/:movieid', controllers.movies.destroy);
+app.put('/api/movies/:movieid', controllers.movies.update);
/**********
* SERVER *
**********/
diff --git a/views/index.html b/views/index.html
index 48e39ae6..40a923e1 100644
--- a/views/index.html
+++ b/views/index.html
@@ -19,11 +19,36 @@
-
-
Under Construction
-
+
+
Click on an icon below
+
+
+
+
+
+
+
+
+
+
+
+
+
+