diff --git a/.DS_Store b/.DS_Store new file mode 100644 index 00000000..e1fb9f75 Binary files /dev/null and b/.DS_Store differ diff --git a/.gitignore b/.gitignore index cf709889..e2125946 100644 --- a/.gitignore +++ b/.gitignore @@ -1 +1,2 @@ -**/node_modules + +node_modules diff --git a/controllers/apiController.js b/controllers/apiController.js new file mode 100644 index 00000000..d934a5b5 --- /dev/null +++ b/controllers/apiController.js @@ -0,0 +1,16 @@ +function index(req, res) { + res.json({ + message: "Welcome to my personal API!", + documentation_url: "https://github.com/jcheng305/express-personal-api", + base_url: "localhost:3000", + endpoints: [ + { + method: "GET", path: "/api", description: "Describes available endpoints" + } + ] + }); +} + +module.exports = { + index: index +} diff --git a/controllers/index.js b/controllers/index.js new file mode 100644 index 00000000..160e96a3 --- /dev/null +++ b/controllers/index.js @@ -0,0 +1,4 @@ +module.exports = { + api: require('./apiController'), + motorcycleList: require('./motorcycleList') +} diff --git a/controllers/motorcycleList.js b/controllers/motorcycleList.js new file mode 100644 index 00000000..2fb51815 --- /dev/null +++ b/controllers/motorcycleList.js @@ -0,0 +1,91 @@ +/*********** +* DATABASE * +************/ +var db = require('../models'); + +/* hard-coded data */ +var motorcycleLists = []; + +motorcycleLists.push({ + _id: 132, + make: 'BMW', + model: 'S1000RR', + image: '/images/s1000rr.jpg', + releaseDate: '2009 to current', + weight: '403 lbs', + maxPower: '199 hp at 13,500 rpm', + maxTorque: '83 lb.-ft. at 10,500 rpm', + engineDisplacement: '999 cc' +}); +motorcycleLists.push({ + _id: 133, + make: 'Honda', + model: 'CBR1000RR', + image: '/images/cbr1000rr.jpg', + releaseDate: '2008 to current', + weight: '439 lbs', + maxPower: '153.4 hp at 10,700 rpm', + maxTorque: '78.74 lb.-ft. at 9,400 rpm', + engineDisplacement: '999 cc' +}); +motorcycleLists.push({ + _id: 134, + make: 'Triumph', + model: 'Daytona 675R', + image: '/images/675r.jpg', + releaseDate: '2006 to current', + weight: '363 lbs', + maxPower: '104 hp at 13,500 rpm', + maxTorque: '53 lb.-ft. at 10,500 rpm', + engineDisplacement: '674 cc' +}) +motorcycleLists.push({ + _id: 135, + make: 'Suzuki', + model: 'GSX-R 750', + image: '/images/gsxr750.jpg', + releaseDate: '2011 to current', + weight: '418 lbs', + maxPower: '148 hp at 12,800 rpm', + maxTorque: '64 lb.-ft. at 11,200 rpm', + engineDisplacement: '749 cc' +}); + +// GET /api/albums +function index(req, res) { + // send back all albums as JSON + + res.json(motorcycleLists); + +} + +// POST /api/albums +function create(req, res) { + // create an album based on request body and send it back as JSON +} + +// GET /api/albums/:albumId +function show(req, res) { + // find one album by id and send it back as JSON +} + +// DELETE /api/albums/:albumId +function destroy(req, res) { + // find one album by id, delete it, and send it back as JSON +} + +// PUT or PATCH /api/albums/:albumId +function update(req, res) { + // find one album by id, update it based on request body, + // and send it back as JSON +} + + +// export public methods here +module.exports = { + index: index, + create: create, + show: show, + destroy: destroy, + update: update +}; diff --git a/models/.DS_Store b/models/.DS_Store new file mode 100644 index 00000000..aeb5f2fd Binary files /dev/null and b/models/.DS_Store differ diff --git a/models/campsite.js.example b/models/campsite.js.example deleted file mode 100644 index cb9e8ee6..00000000 --- a/models/campsite.js.example +++ /dev/null @@ -1,10 +0,0 @@ -// var mongoose = require('mongoose'), -// Schema = mongoose.Schema; - -// var CampsiteSchema = new Schema({ -// description: String -// }); - -// var Campsite = mongoose.model('Campsite', CampsiteSchema); - -// module.exports = Campsite; diff --git a/models/index.js b/models/index.js index 66997fe0..d9448628 100644 --- a/models/index.js +++ b/models/index.js @@ -3,3 +3,9 @@ mongoose.connect( process.env.MONGODB_URI || "mongodb://localhost/personal-api", mongoose.Promise = global.Promise; // use native Promise // module.exports.Campsite = require("./campsite.js.example"); + + +const Profile = require('./profile'); + + +module.exports.Profile = require("./profile.js"); diff --git a/models/profile.js b/models/profile.js new file mode 100644 index 00000000..7ba93231 --- /dev/null +++ b/models/profile.js @@ -0,0 +1,28 @@ +// var mongoose = require('mongoose'), +// const Schema = mongoose.Schema; + +// var CampsiteSchema = new Schema({ +// description: String +// }); + +// var Campsite = mongoose.model('Campsite', CampsiteSchema); + +// module.exports = Campsite; + +var mongoose = require('mongoose'), +Schema = mongoose.Schema; + +const ProfileSchema = new Schema ({ + make: String, + model: String, + image: String, + releaseDate: String, + weight: String, + maxPower: String, + maxTorque: String, + engineDisplacement: String +}); + +const Profile = mongoose.model('Profile', ProfileSchema); + +module.exports = Profile; diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 00000000..a704cdd6 --- /dev/null +++ b/package-lock.json @@ -0,0 +1,575 @@ +{ + "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" + } + }, + "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.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.7.tgz", + "integrity": "sha1-krrR9tBbu2u6Isyoi80OyJTChh4=", + "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" + }, + "dependencies": { + "debug": { + "version": "2.6.8", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", + "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", + "requires": { + "ms": "2.0.0" + } + }, + "qs": { + "version": "6.5.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.0.tgz", + "integrity": "sha512-fjVFjW9yhqMhVGwRExCXLhJKrLlkYSaxNWdyc9rmHlrVZbk35YHH312dFd7191uQeXkI3mKLZTIbSvIeFwFemg==" + } + } + }, + "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" + }, + "dependencies": { + "debug": { + "version": "2.6.8", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", + "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", + "requires": { + "ms": "2.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": { + "debug": { + "version": "2.6.8", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", + "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", + "requires": { + "ms": "2.0.0" + } + }, + "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.4.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.4.0.tgz", + "integrity": "sha1-E+JtKK1rD/qpExLNO/cI7TUecjM=" + }, + "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" + }, + "dependencies": { + "debug": { + "version": "2.6.8", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.8.tgz", + "integrity": "sha1-5zFTHKLt4n0YgiJCfaF4IdaP9Pw=", + "requires": { + "ms": "2.0.0" + } + } + } + }, + "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/public/.DS_Store b/public/.DS_Store new file mode 100644 index 00000000..df02a58c 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 00000000..4cbf5a01 Binary files /dev/null and b/public/images/.DS_Store differ diff --git a/public/images/675r.jpg b/public/images/675r.jpg new file mode 100644 index 00000000..8f141b6c Binary files /dev/null and b/public/images/675r.jpg differ diff --git a/public/images/bmwhp4.jpg b/public/images/bmwhp4.jpg new file mode 100644 index 00000000..682abe3c Binary files /dev/null and b/public/images/bmwhp4.jpg differ diff --git a/public/images/cbr1000rr.jpg b/public/images/cbr1000rr.jpg new file mode 100644 index 00000000..af626022 Binary files /dev/null and b/public/images/cbr1000rr.jpg differ diff --git a/public/images/gsxr750.jpg b/public/images/gsxr750.jpg new file mode 100644 index 00000000..41f351b2 Binary files /dev/null and b/public/images/gsxr750.jpg differ diff --git a/public/images/s1000rr.jpg b/public/images/s1000rr.jpg new file mode 100644 index 00000000..4c70c2a8 Binary files /dev/null and b/public/images/s1000rr.jpg differ diff --git a/public/scripts/app.js b/public/scripts/app.js index 00988cd4..7ebb5b3b 100644 --- a/public/scripts/app.js +++ b/public/scripts/app.js @@ -1,7 +1,79 @@ console.log("Sanity Check: JS is working!"); $(document).ready(function(){ + console.log('app.js is loaded!'); + $.ajax({ + method: 'GET', + url: '/api/motorcycleList', + success: renderMultipleMotorcycles + }); +}); -// your code +function renderMultipleMotorcycles(motorcycleList) { + motorcycleList.forEach(function(motorcycle) { + renderList(motorcycle); + }); +} -}); +// this function takes a single album and renders it to the page +function renderList(motorcycle) { + console.log('rendering motorcycles', motorcycle); + var motorcycleHtml = (` +
+ +
+
+
+ + + +
+
+ Motorcycle Image +
+
+
    +
  • +

    Make:

    + ${motorcycle.make} +
  • +
  • +

    Model:

    + ${motorcycle.model} +
  • +
  • +

    Weight:

    + ${motorcycle.weight} +
  • +
  • +

    maxPower:

    + ${motorcycle.maxPower} +
  • +
  • +

    maxTorque:

    + ${motorcycle.maxTorque} +
  • +
  • +

    Engine Displacement:

    + ${motorcycle.engineDisplacement} +
  • +
+
+
+ + +
+
+
+
+ + `); + $('#motorcycleList').prepend(motorcycleHtml); +} + + +//this function takes a single motorcycle and renders it to the page +function renderMotorcycle(list) { + console.log('rendering list', list); +} diff --git a/public/styles/styles.css b/public/styles/styles.css index 57b4da0e..08ab18f6 100644 --- a/public/styles/styles.css +++ b/public/styles/styles.css @@ -1,10 +1,43 @@ body { - color: #333; font-family: Helvetica, Arial, sans-serif; - background-color: skyblue; /* Sanity Check! */ + background-color: black; /* Sanity Check! */ } h1 { - margin-top: 100px; + color: white; + margin-top: -80px; text-align: center; } +legend { + color: white; +} +div { + +} +.jumbotron { + background-image: url(/images/bmwhp4.jpg); + background-size: cover; + background-repeat: no-repeat; + background-position: center; + color: #2D59AD; + padding-top: 30px; + padding-bottom: 30px; + margin-bottom: 30px; + padding-top: 82px; +} +.jumbotron .container { + height: 600px; +} +.jumbotron p { + text-align: center; + font-size: 25px; + +} +.inline-header { + display: inline-block; + vertical-align: baseline; + margin-right: 12px; +} +legend { + color: white; +} diff --git a/seed.js b/seed.js index 896dead0..a8704bef 100644 --- a/seed.js +++ b/seed.js @@ -13,3 +13,63 @@ // console.log("Created new campsite", campsite._id) // process.exit(); // we're all done! Exit the program. // }) + +var db = require("./models"); + +var motorcycleList = []; + +motorcycleList.push({ + make: 'BMW', + model: 'S1000RR', + image: '/images/s1000rr.jpg', + releaseDate: '2009 to current', + weight: '403 lbs', + maxPower: '199 hp at 13,500 rpm', + maxTorque: '83 lb.-ft. at 10,500 rpm', + engineDisplacement: '999 cc' +}); +motorcycleList.push({ + make: 'Honda', + model: 'CBR1000RR', + image: '/images/cbr1000rr.jpg', + releaseDate: '2008 to current', + weight: '439 lbs', + maxPower: '153.4 hp at 10,700 rpm', + maxTorque: '78.74 lb.-ft. at 9,400 rpm', + engineDisplacement: '999 cc' +}); +motorcycleList.push({ + make: 'Triumph', + model: 'Daytona 675R', + image: '/images/675r.jpg', + releaseDate: '2006 to current', + weight: '363 lbs', + maxPower: '104 hp at 13,500 rpm', + maxTorque: '53 lb.-ft. at 10,500 rpm', + engineDisplacement: '674 cc' +}) +motorcycleList.push({ + make: 'Suzuki', + model: 'GSX-R 750', + image: '/images/gsxr750.jpg', + releaseDate: '2011 to current', + weight: '418 lbs', + maxPower: '148 hp at 12,800 rpm', + maxTorque: '64 lb.-ft. at 11,200 rpm', + engineDisplacement: '749 cc' +}); + +//Need to resolve this issue here, when I run node seed.js +//I'm getting an error that .remove() is undefined +db.List.remove({}, function(err, lists){ + + db.List.create(motorcycleList, function(err, lists) { + if (err) { + return console.log('ERROR', err); + } + console.log("Motorcycle list generated", lists.length, lists); + console.log("All motorcycle data displayed", lists); + process.exit(); + }); + +}); diff --git a/server.js b/server.js index fd366289..74544356 100644 --- a/server.js +++ b/server.js @@ -1,6 +1,6 @@ // require express and other modules var express = require('express'), - app = express(); +app = express(); // parse incoming urlencoded form data // and populate the req.body object @@ -18,7 +18,7 @@ app.use(function(req, res, next) { /************ * DATABASE * ************/ - +var controllers = require('./controllers'); // var db = require('./models'); /********** @@ -47,18 +47,32 @@ app.get('/api', function apiIndex(req, res) { // It would be seriously overkill to save any of this to your database. // But you should change almost every line of this response. res.json({ - woopsIForgotToDocumentAllMyEndpoints: true, // CHANGE ME ;) message: "Welcome to my personal api! Here's what you need to know!", - documentationUrl: "https://github.com/example-username/express-personal-api/README.md", // CHANGE ME - baseUrl: "http://YOUR-APP-NAME.herokuapp.com", // CHANGE ME + documentationUrl: "https://github.com/jcheng305/express-personal-api/blob/master/README.md", // CHANGE ME + baseUrl: "https://stark-coast-86694.herokuapp.com/", // CHANGE ME endpoints: [ {method: "GET", path: "/api", description: "Describes all available endpoints"}, {method: "GET", path: "/api/profile", description: "Data about me"}, // CHANGE ME - {method: "POST", path: "/api/campsites", description: "E.g. Create a new campsite"} // CHANGE ME ] }) }); +app.get('/api/profile', function apiIndex(req, res) { + res.json({ + "About Me": [{ + // method: "GET", + // path: "/api/profile", + name: "Jimmy Cheng", + githubUsername: "jcheng305", + githubLink: "https://github.com/jcheng305/express-personal-api", + githubProfileImage: "https://avatars2.githubusercontent.com/u/29786912?v=4&s=400", + personalSiteLink: "https://jcheng305.github.io/index.html", + currentCity: "Millbrae, CA", + hobbies: "Adrenaline junky, hanging out with friends, trying new food places." + }] + }) +}); +app.get('/api/motorcycleList', controllers.motorcycleList.index); /********** * SERVER * **********/ diff --git a/views/index.html b/views/index.html index 48e39ae6..2654488a 100644 --- a/views/index.html +++ b/views/index.html @@ -1,29 +1,129 @@ - - - + + + - Blank + 2017 Supersport Shootout - - - + + + - - + + + - - - - + + + + +
+

Welcome to Supersport Shootout!

+

Your one stop domain for the top motorcycles of 2017!

+
+
+ + +
+ + + +
-
-

Under Construction

-

Read My API Documentation

+
+ +
+
+ + + Add New Motorcycle + + +
+ +
+ + +
+
+ + +
+ +
+ + +
+
+ + +
+ +
+ + +
+
+ + +
+ +
+ +
+
+ + +
+ +
+ +
+
+ + +
+ +
+ +
+
+ + +
+ +
+ +
+
+ + +
+ +
+ +
+
+ + + +
+ +
+ +
+
+
+
- +
+ + +

Read My API Documentation

+ +