aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--app.js4
-rw-r--r--controllers/system.js84
-rw-r--r--models/Access.js42
-rw-r--r--models/Project.js67
-rw-r--r--models/User.js (renamed from models/user.js)23
-rw-r--r--models/project.js39
-rw-r--r--package.json2
-rw-r--r--public/css/shame.less12
-rw-r--r--public/css/use.less61
-rw-r--r--public/img/androidA.pngbin5288 -> 9055 bytes
-rw-r--r--public/img/androidA@2x.pngbin5059 -> 22383 bytes
-rw-r--r--public/img/dashboard.pngbin127906 -> 128952 bytes
-rw-r--r--public/img/dashboard@2x.pngbin339575 -> 342282 bytes
-rw-r--r--public/img/dennis.jpgbin0 -> 28716 bytes
-rw-r--r--public/img/erling.jpgbin0 -> 30651 bytes
-rw-r--r--public/img/iphoneA.pngbin4283 -> 9785 bytes
-rw-r--r--public/img/iphoneA@2x.pngbin5906 -> 27306 bytes
-rw-r--r--public/img/par.pngbin6545 -> 3453 bytes
-rw-r--r--public/img/par@2x.pngbin5110 -> 3900 bytes
-rw-r--r--public/img/robert.jpgbin0 -> 29892 bytes
-rw-r--r--public/img/stian.jpgbin0 -> 23693 bytes
-rw-r--r--public/img/winA.pngbin5296 -> 6468 bytes
-rw-r--r--public/img/winA@2x.pngbin4678 -> 16853 bytes
-rw-r--r--routes.js (renamed from router.js)10
-rw-r--r--views/contact.ejs73
-rw-r--r--views/dashboard.ejs32
-rw-r--r--views/home.ejs26
-rw-r--r--views/navbar.ejs11
-rw-r--r--views/newproject.ejs2
-rw-r--r--views/project.ejs2
-rw-r--r--views/projectParticipants.ejs55
31 files changed, 409 insertions, 136 deletions
diff --git a/app.js b/app.js
index f9aa1b9..a0f7ae1 100644
--- a/app.js
+++ b/app.js
@@ -20,7 +20,7 @@ mongoose.connect(config.db);
var db = mongoose.connection;
db.on('error', console.error.bind(console, 'connection error:'));
db.once('open', function callback(){
- console.log('Connected to MongoDB');
+ console.log('Connected to ' + config.db);
});
// Bootstrap models
@@ -44,7 +44,7 @@ require('./config/express')(app, config, passport);
/**
* Routes
*/
-require('./router')(app, passport, auth);
+require('./routes')(app, passport, auth);
/**
diff --git a/controllers/system.js b/controllers/system.js
index e3a55bd..a5e8f46 100644
--- a/controllers/system.js
+++ b/controllers/system.js
@@ -3,9 +3,9 @@
* Module dependencies
*/
var mongoose = require('mongoose')
- , Project = mongoose.model('Project');
-
-
+ , Project = mongoose.model('Project')
+ , Access = mongoose.model('Access')
+ , User = mongoose.model('User');
/**
@@ -53,12 +53,47 @@ exports.faq = function(req, res) {
exports.dashboard = function(req, res) {
- console.log('/dashboard - ' + req.user);
- res.render('dashboard', {
- title: 'kanin',
- loggedin: true
+ console.log('/dashboard - ' + req.user._id);
+
+/*
+ Access.find({ user: req.user._id }, function(err, accesses) {
+ if (err) return res.render('500');
+ console.log('accesses ' + accesses);
+ accesses.forEach(function(access) {
+ Project.load(access.project, function(err, project) {
+ if (err) return res.render('500');
+ projectList.push(project);
+ console.log(project.user.username);
+ });
+ });
});
-};
+*/
+ Access.loadUser(req.user._id, function(err, projects) {
+ if (err) return res.render('500');
+ Project.populate(projects, { path: 'project.user', model: User }, function(err, projects) {
+
+ console.log('accesses: ' + projects);
+
+ res.render('dashboard', {
+ title: 'Dashboard',
+ loggedin: true,
+ projects: projects
+ });
+
+ });
+
+ })
+
+/*
+ Project.find(function(err, projects) {
+ if (err) return res.render('500');
+ res.render('dashboard', {
+ title: 'Dashboad',
+ loggedin: true,
+ projects: projects
+ });
+ });*/
+}
@@ -66,15 +101,44 @@ exports.project = function(req, res) {
res.render('project', { title: 'Harepus', loggedin: true });
}
+exports.projectParticipants = function(req, res) {
+
+ res.render('projectParticipants', { title: 'Prosjektdeltakere', loggedin: true });
+
+}
+
+exports.postProjectParticipants = function(req, res) {
+
+
+
+}
+
+
exports.newProject = function(req, res) {
res.render('newproject', { title: 'Nytt prosjekt', loggedin: true });
}
exports.postNewProject = function(req, res) {
var project = new Project(req.body);
+ project.user = req.user._id;
project.save(function(err) {
- if (err) return res.render('newproject', { title: 'Nytt prosjekt - en feil oppstod', loggedin: true, errors: err.errors, project: project });
- return res.redirect('/dashboard');
+ if (err) {
+ console.log(err.errors);
+ return res.render('newproject', { title: 'Nytt prosjekt - en feil oppstod', loggedin: true, errors: err.errors, project: project });
+ }
});
+
+ var access = new Access();
+ access.user = req.user._id;
+ access.creator = req.user._id;
+ access.project = project._id;
+ access.permissions = 1;
+ access.save(function(err) {
+ if (err) {
+ console.log(err.errors);
+ return res.render('newproject', { title: 'Nytt prosjekt - en feil oppstod', loggedin: true });
+ }
+ return res.redirect('/dashboard');
+ })
}
diff --git a/models/Access.js b/models/Access.js
new file mode 100644
index 0000000..ce75f8c
--- /dev/null
+++ b/models/Access.js
@@ -0,0 +1,42 @@
+
+/**
+ * Module dependencies
+ */
+
+var mongoose = require('mongoose')
+ , Schema = mongoose.Schema;
+
+var AccessSchema = new Schema({
+ user: { type: Schema.ObjectId, ref: 'User' },
+ creator: { type: Schema.ObjectId, ref: 'User' },
+ project: { type: Schema.ObjectId, ref: 'Project' },
+ permissions: { type: Number, default: '3' },
+ created: { type: Date, default: Date.now },
+ updated: { type: Date, default: Date.now }
+});
+
+// the four validations below only apply if you are signing up traditionally
+
+AccessSchema.statics = {
+
+ log: function() {
+ console.log('wat. wat logged this');
+ },
+
+ /**
+ * Load ALL accesses for a single user
+ *
+ * @param {ObjectId} id
+ * @param {Function} callback
+ * @api private
+ */
+
+ loadUser: function(id, callback) {
+ this.find({ user: id })
+ .populate('project')
+ .sort({ 'created': -1 }) // sort by date
+ .exec(callback);
+ }
+}
+
+mongoose.model('Access', AccessSchema);
diff --git a/models/Project.js b/models/Project.js
new file mode 100644
index 0000000..f29c7f8
--- /dev/null
+++ b/models/Project.js
@@ -0,0 +1,67 @@
+
+/**
+ * Module dependencies
+ */
+
+var mongoose = require('mongoose')
+ , Schema = mongoose.Schema;
+
+var ProjectSchema = new Schema({
+ user: { type: Schema.ObjectId, ref: 'User' },
+ name: { type: String, default: '', trim: true },
+ description: {type: String, default: '', trim: true },
+ currency: { type: String, default: 'kr', trim: true },
+ public: { type: String, default: 'invite-only' },
+ created: { type: Date, default: Date.now },
+ updated: { type: Date, default: Date.now },
+ shortURL: { type: String, unique: true }
+});
+
+// the four validations below only apply if you are signing up traditionally
+
+ProjectSchema.path('name').validate(function(name) {
+ // if you're authenticated by any of the oauth strategies (facebook, twitter), don't validate
+ return name.length;
+}, 'Project name cannot be blank');
+
+
+ProjectSchema.pre('save', function(next) {
+ if (this.shortURL !== undefined) return next();
+ var chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";
+ this.shortURL = '';
+ for (var i = 0; i < 6; i++) {
+ var x = Math.floor(Math.random() * chars.length);
+ this.shortURL += chars.charAt(x);
+ }
+ console.log('SHORT: ' + this.shortURL);
+ next();
+});
+
+
+
+ProjectSchema.statics = {
+
+ log: function() {
+ console.log('wat. wat logged this');
+ },
+
+
+
+ /**
+ * Find project by id
+ *
+ * @param {ObjectId} id
+ * @param {Function} callback
+ * @api private
+ */
+
+ load: function(id, callback) {
+ this.findOne({ _id: id })
+ .populate('user')
+ .exec(callback);
+ }
+
+
+}
+
+mongoose.model('Project', ProjectSchema);
diff --git a/models/user.js b/models/User.js
index b61f7c9..4d32941 100644
--- a/models/user.js
+++ b/models/User.js
@@ -5,7 +5,7 @@
var mongoose = require('mongoose')
, Schema = mongoose.Schema
- , crypto =require('crypto')
+ , crypto = require('crypto')
, authTypes = ['facebook', 'twitter'];
@@ -20,6 +20,7 @@ var UserSchema = new Schema({
provider: String,
hashed_password: String,
salt: String,
+ accessToken: String,
facebook: {},
twitter: {}
});
@@ -98,6 +99,7 @@ UserSchema.methods = {
return this.encryptPassword(plainText) === this.hashed_password;
},
+
/**
* Make salt
*
@@ -109,6 +111,7 @@ UserSchema.methods = {
return Math.round((new Date().valueOf() * Math.random())) + '';
},
+
/**
* Encrypt password
*
@@ -120,6 +123,24 @@ UserSchema.methods = {
encryptPassword: function(password) {
if (!password) return '';
return crypto.createHmac('sha1', this.salt).update(password).digest('hex');
+ },
+
+
+ /**
+ * Generate random access token for Remember Me function
+ *
+ * @return {String}
+ * @api public
+ */
+
+ generateRandomToken: function() {
+ var chars = "_!abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"
+ , token = new Date().getTime() + '_';
+ for (var i = 0; i < 16; i++) {
+ var x = Math.floor(Math.random() * 62);
+ token += chars.charAt(x);
+ }
+ return token;
}
}
diff --git a/models/project.js b/models/project.js
deleted file mode 100644
index 2424694..0000000
--- a/models/project.js
+++ /dev/null
@@ -1,39 +0,0 @@
-
-/**
- * Module dependencies
- */
-
-var mongoose = require('mongoose')
- , Schema = mongoose.Schema;
-
-
-
-
-
-var ProjectSchema = new Schema({
- user: { type: String, ref: 'User' },
- name: { type: String, default: '', trim: true },
- description: {type: String, default: '', trim: true },
- currency: { type: String, default: 'kr', trim: true },
- public: { type: String, default: 'invite-only' },
- created: { type: Date, default: Date.now },
- updated: { type: Date, default: Date.now }
-});
-
-
-// the four validations below only apply if you are signing up traditionally
-
-ProjectSchema.path('name').validate(function(name) {
- // if you're authenticated by any of the oauth strategies (facebook, twitter), don't validate
- return name.length;
-}, 'Project name cannot be blank');
-
-ProjectSchema.methods = {
-
- log: function() {
- console.log('wat. wat logged this');
- }
-
-}
-
-mongoose.model('Project', ProjectSchema);
diff --git a/package.json b/package.json
index c2ca75b..4aabf64 100644
--- a/package.json
+++ b/package.json
@@ -1,7 +1,7 @@
{
"name": "Divid"
, "description": "A bachelorproject ending in a webapplication for social accounting"
- , "version": "0.0.2"
+ , "version": "0.0.3"
, "private": true
, "engines": {
"node": "0.10.x"
diff --git a/public/css/shame.less b/public/css/shame.less
index 04e4aa6..997409b 100644
--- a/public/css/shame.less
+++ b/public/css/shame.less
@@ -239,5 +239,15 @@ div.lastactivity .activity .details {
}
}
+#vertical(@startColor: #555, @endColor: #333) {
+ background-color: mix(@startColor, @endColor, 60%);
+ background-image: -moz-linear-gradient(top, @startColor, @endColor); // FF 3.6+
+ background-image: -webkit-gradient(linear, 0 0, 0 100%, from(@startColor), to(@endColor)); // Safari 4+, Chrome 2+
+ background-image: -webkit-linear-gradient(top, @startColor, @endColor); // Safari 5.1+, Chrome 10+
+ background-image: -o-linear-gradient(top, @startColor, @endColor); // Opera 11.10
+ background-image: linear-gradient(to bottom, @startColor, @endColor); // Standard, IE10
+ background-repeat: repeat-x;
+ filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)",argb(@startColor),argb(@endColor))); // IE9 and down
+}
+
-/*@import "use.less";*/
diff --git a/public/css/use.less b/public/css/use.less
index 7788aa2..740818f 100644
--- a/public/css/use.less
+++ b/public/css/use.less
@@ -1,22 +1,10 @@
/*#wrapper {
width:100%;
background-position: center 40%;
-}*/
-
-#vertical(@startColor: #555, @endColor: #333) {
- background-color: mix(@startColor, @endColor, 60%);
- background-image: -moz-linear-gradient(top, @startColor, @endColor); // FF 3.6+
- background-image: -webkit-gradient(linear, 0 0, 0 100%, from(@startColor), to(@endColor)); // Safari 4+, Chrome 2+
- background-image: -webkit-linear-gradient(top, @startColor, @endColor); // Safari 5.1+, Chrome 10+
- background-image: -o-linear-gradient(top, @startColor, @endColor); // Opera 11.10
- background-image: linear-gradient(to bottom, @startColor, @endColor); // Standard, IE10
- background-repeat: repeat-x;
- filter: e(%("progid:DXImageTransform.Microsoft.gradient(startColorstr='%d', endColorstr='%d', GradientType=0)",argb(@startColor),argb(@endColor))); // IE9 and down
}
-
.content {
margin-left: 0px;
-}
+}*/
.pitch {
position: relative;
margin-left: 10px;
@@ -37,18 +25,17 @@
float: left;
margin-top: 20px;
margin-left: 10px;
- margin-right: 0px;
+ margin-right: 20px;
}
.sectionright {
float: right;
- margin-top: 20px;
- margin-right: 10px;
- margin-left: 0px;
+ margin: 20px;
}
.tutorial {
padding: 5px;
}
.infobox {
+ display: inline-block;
text-align: center;
/*background-color: @grayLighter;*/
@@ -88,7 +75,7 @@
margin-top:45px;
}
.showcase {
- height: 460px;
+ /*height: 460px;*/
margin-top: 40px;
margin-bottom: 20px;
margin-left: 0px;
@@ -116,6 +103,7 @@ margin-top:45px;
.scenario {
margin:60px;
+text-align: center;
}
/*
@@ -123,22 +111,23 @@ margin:60px;
background-color:@grayLighter;
}*/
#hva {
- height:460px;
+ /*height: 460px;*/
+ /*margin: 0 auto;*/
margin-top: 25px;
/*border-top: 2px solid #9fd5df;*/
-
- color: #000000;
- background-color: #eeeeee;
box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.2);
-moz-box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
-webkit-box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
- margin: 0 auto;
+
font-size: 18px;
line-height: 26px;
display: block;
}
+
+#dildo
+{}
#hvor {
- height:460px;
+ /*height:460px;*/
margin-top: 25px;
/*border-top: 2px solid #9fd5df;*/
@@ -147,13 +136,13 @@ margin:60px;
box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.2);
-moz-box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
-webkit-box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
- margin: 0 auto;
+ /*margin: 0 auto;*/
font-size: 18px;
line-height: 26px;
display: block;
}
#hvordan {
- height:460px;
+ /*height:460px;*/
margin-top: 25px;
/*border-top: 2px solid #9fd5df;*/
@@ -162,26 +151,12 @@ margin:60px;
box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.2);
-moz-box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
-webkit-box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
- margin: 0 auto;
+ /*margin: 0 auto;*/
font-size: 18px;
line-height: 26px;
display: block;
}
-#android:hover {
-background-image: url('/img/androidA');
-}
-img.apple {
-background-image: url('/img/iphone');
-z-index:2;
-}
-img.apple:hover {
-background-image: url('/img/iphoneA');
-z-index:1;
-}
-#windows:hover {
-background-image: url('/img/winA');
-}
/*
#register {
height:460px;
@@ -193,7 +168,7 @@ background-image: url('/img/winA');
box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.2);
-moz-box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
-webkit-box-shadow: 0 -2px 5px rgba(0, 0, 0, 0.2);
- margin: 0 auto;
+ /*margin: 0 auto;*/
font-size: 18px;
line-height: 26px;
display: block;
@@ -202,4 +177,4 @@ background-image: url('/img/winA');
background-color: #0D56A6;
width:1170px;
height:100px;
-}*/ \ No newline at end of file
+}*/
diff --git a/public/img/androidA.png b/public/img/androidA.png
index 75736f3..afb53f9 100644
--- a/public/img/androidA.png
+++ b/public/img/androidA.png
Binary files differ
diff --git a/public/img/androidA@2x.png b/public/img/androidA@2x.png
index 5b80fd9..204c8d0 100644
--- a/public/img/androidA@2x.png
+++ b/public/img/androidA@2x.png
Binary files differ
diff --git a/public/img/dashboard.png b/public/img/dashboard.png
index 1b82ffc..0fdbc1f 100644
--- a/public/img/dashboard.png
+++ b/public/img/dashboard.png
Binary files differ
diff --git a/public/img/dashboard@2x.png b/public/img/dashboard@2x.png
index 4f582b8..b154265 100644
--- a/public/img/dashboard@2x.png
+++ b/public/img/dashboard@2x.png
Binary files differ
diff --git a/public/img/dennis.jpg b/public/img/dennis.jpg
new file mode 100644
index 0000000..9e86a1c
--- /dev/null
+++ b/public/img/dennis.jpg
Binary files differ
diff --git a/public/img/erling.jpg b/public/img/erling.jpg
new file mode 100644
index 0000000..97e499e
--- /dev/null
+++ b/public/img/erling.jpg
Binary files differ
diff --git a/public/img/iphoneA.png b/public/img/iphoneA.png
index 3d35eaf..0e0399a 100644
--- a/public/img/iphoneA.png
+++ b/public/img/iphoneA.png
Binary files differ
diff --git a/public/img/iphoneA@2x.png b/public/img/iphoneA@2x.png
index a341671..e519291 100644
--- a/public/img/iphoneA@2x.png
+++ b/public/img/iphoneA@2x.png
Binary files differ
diff --git a/public/img/par.png b/public/img/par.png
index 5b9beb2..3637a8e 100644
--- a/public/img/par.png
+++ b/public/img/par.png
Binary files differ
diff --git a/public/img/par@2x.png b/public/img/par@2x.png
index 1797663..6c15675 100644
--- a/public/img/par@2x.png
+++ b/public/img/par@2x.png
Binary files differ
diff --git a/public/img/robert.jpg b/public/img/robert.jpg
new file mode 100644
index 0000000..f4c0a69
--- /dev/null
+++ b/public/img/robert.jpg
Binary files differ
diff --git a/public/img/stian.jpg b/public/img/stian.jpg
new file mode 100644
index 0000000..2b6ce31
--- /dev/null
+++ b/public/img/stian.jpg
Binary files differ
diff --git a/public/img/winA.png b/public/img/winA.png
index b19d985..62bdb33 100644
--- a/public/img/winA.png
+++ b/public/img/winA.png
Binary files differ
diff --git a/public/img/winA@2x.png b/public/img/winA@2x.png
index 638145e..cdb2313 100644
--- a/public/img/winA@2x.png
+++ b/public/img/winA@2x.png
Binary files differ
diff --git a/router.js b/routes.js
index b67f03a..d597ae8 100644
--- a/router.js
+++ b/routes.js
@@ -50,12 +50,18 @@ module.exports = function(app, passport, auth) {
*/
- app.get('/dashboard', system.dashboard);
+ app.get('/dashboard', auth.requiresLogin, system.dashboard);
app.get('/project', auth.requiresLogin, system.project);
app.get('/project/new', auth.requiresLogin, system.newProject);
- app.post('/project/new', auth.requiresLogin, system.postNewProject)
+ app.post('/project/new', auth.requiresLogin, system.postNewProject);
+
+ app.get('/project/:short', auth.requiresLogin, system.project);
+
+ app.get('/project/:short/participants', auth.requiresLogin, system.projectParticipants);
+
+ app.post('/project/:short/participants', auth.requiresLogin, system.postProjectParticipants);
};
diff --git a/views/contact.ejs b/views/contact.ejs
new file mode 100644
index 0000000..bf43f1c
--- /dev/null
+++ b/views/contact.ejs
@@ -0,0 +1,73 @@
+<% include header %>
+<link rel="stylesheet" href="/css/divanim.css">
+<link rel="stylesheet" href="/css/need.css">
+</head>
+<body>
+
+ <% include navbar %>
+
+ <!-- Wrapper
+ ================================================== -->
+<div class="container" id="wrapper">
+ <div class="row">
+ <!-- content
+ ================================================== -->
+ <div class="span12 content">
+ <div class="container">
+ <div class="contact">
+ <h1>Kontakt oss</h1>
+ <h3>Support</h3>
+ <p>Se gjerne igjennom vår <a href="https://divid.no/faq">faq</a> - ofte stilte spørsmål - før dere sender mail på support(a)divid.no . </a>
+ <h3>Business</h3>
+ <p>Ønsker du å kontakte oss for kjøp av annonseplass, forretninger og lignende ta kontakt på pr(a)divid.no.</p>
+ </div>
+ <div class="about">
+ <h1>Om teamet DERS</h1>
+ <div class="member">
+ <h3>Dennis Eriksen<h3>
+ <img src="/img/dennis.jpg">
+ <p>Alder:</p>
+ <p>Ifra:Skien</p>
+ <p>Mobil:</p>
+ <p>Fokus:</p>
+ <p>Favoritt ting:Unicorns</p>
+ </div>
+ <div class="member">
+ <h3>Erling Aaby<h3>
+ <img src="/img/erling.jpg">
+ <p>Alder:</p>
+ <p>Ifra:Oslo</p>
+ <p>Mobil:</p>
+ <p>Fokus:</p>
+ <p>Favoritt ting:trening</p>
+ </div>
+ <div class="member">
+ <h3>Robert Joramo<h3>
+ <img src="/img/robert.jpg">
+ <p>Alder:</p>
+ <p>Ifra:Årnes</p>
+ <p>Mobil:</p>
+ <p>Fokus:</p>
+ <p>Favoritt ting:Fopal</p>
+ </div>
+ <div class="member">
+ <h3>Stian Olsen<h3>
+ <img src="/img/stian.jpeg">
+ <p>Alder:</p>
+ <p>Ifra:Trondheim</p>
+ <p>Mobil:</p>
+ <p>Fokus:</p>
+ <p>Favoritt ting:Korboi <3 </p>
+ </div>
+ </div>
+ </div>
+ </div>
+ </div><!-- /div.row -->
+</div><!-- /div#wrapper -->
+ <!--<div id="footer">
+ <div class="container">
+ </div>
+ </div>-->
+<% include footer %>
+</body>
+</html> \ No newline at end of file
diff --git a/views/dashboard.ejs b/views/dashboard.ejs
index 5eca9f1..dfd76f6 100644
--- a/views/dashboard.ejs
+++ b/views/dashboard.ejs
@@ -12,24 +12,26 @@
<div class="smallfullwidth span5">
<h1>Prosjekter</h1>
<section class="projects">
- <section class="project">
- <div class="row-fluid">
- <div class="span11">
- <h1><a href="/project">dennisse/<strong>hytteturskogentilfrank</strong></a></h1>
- <div class="row-fluid">
- <div class="span8">
- <small>Meg, Robert, Turid-Laila, Kurt, Stian, Aleksander, Frank, Olav, Heidi, Anette, Kristine</small>
- </div>
- <div class="span4">
- <small>Oppgjør: <span class="text-error">-200 kr</span></small>
+ <% projects.forEach(function(projects) { %>
+ <section class="project">
+ <div class="row-fluid">
+ <div class="span11">
+ <h1><a href="/project/<%= projects.project.shortURL %>"><%= projects.project.user.username %>/<strong><%= projects.project.name %></strong></a></h1>
+ <div class="row-fluid">
+ <div class="span8">
+ <small>Meg, Robert, Turid-Laila, Kurt, Stian, Aleksander, Frank, Olav, Heidi, Anette, Kristine</small>
+ </div>
+ <div class="span4">
+ <small>Oppgjør: <span class="text-error">-200 kr</span></small>
+ </div>
</div>
</div>
+ <div class="span1">
+ <p>+</p>
+ </div>
</div>
- <div class="span1">
- <p>+</p>
- </div>
- </div>
- </section>
+ </section>
+ <% }); %>
<section class="project">
<div class="row-fluid">
<div class="span11">
diff --git a/views/home.ejs b/views/home.ejs
index 4718199..c99c6fb 100644
--- a/views/home.ejs
+++ b/views/home.ejs
@@ -78,7 +78,6 @@
<img src="/img/flytting.png">
<h4>Parforhold</h4>
<p>I etableringsfasen som ønsker å ha ordnet økonomi fra starten av</p>
- <p>Hindrer snylting</p>
</div>
<div class="span2 scenario">
<img src="/img/omsorg.png">
@@ -88,11 +87,6 @@
<p>Hvem betaler hva for hans, hennes og deres barn?</p>
<!--<p>klær, mat, reiser, aktiviteter, sport, skolebøker, tannlege, medisiner</p>--!>
</div>
- <!--<div class="span2 scenario">
- <img src="/img/overwatch.png">
- <h4>Person som vil ha oversikt over tingene sine.</h4>
- <p>Ta et bilde med Divid: av gressklippern han lånte bort til naboen, tennisrackettene kompisen hans lånte, eller klær hun har lånt bort til venninner</p>
- </div>--!>
</div>
</div>
</div>
@@ -109,12 +103,19 @@
<iframe src="http://player.vimeo.com/video/41974181" width="500" height="281" frameborder="0" webkitAllowFullScreen mozallowfullscreen allowFullScreen></iframe>
</div>
</div>
+<<<<<<< HEAD
<div class="span5 sectionright">
<a href="https://itunes.apple.com/us/genre/ios-finance/id6015?mt=8" title="Appstore">
<div id="app" class="apple"> <img src="/img/iph.png" class="apple">
</a>
<a href="https://play.google.com/store"><img src="/img/android.png" id="android" class="infoimg"></a>
<a href="http://www.windowsphone.com/nb-no/store"><img src="/img/win.png" id="windows" class="infoimg"></a>
+=======
+ <div class="span5 sectionright">
+ <a href="https://itunes.apple.com/us/genre/ios-finance/id6015?mt=8"><img src="/img/iph.png" onmouseover="this.src='/img/iphoneA.png'" onmouseout="this.src='/img/iph.png'"></a>
+ <a href="https://play.google.com/store"><img src="/img/android.png" onmouseover="this.src='/img/androidA.png'" onmouseout="this.src='/img/android.png'"></a>
+ <a href="http://www.windowsphone.com/nb-no/store"><img src="/img/win.png" onmouseover="this.src='/img/winA.png'" onmouseout="this.src='/img/win.png'"></a>
+>>>>>>> a935f29043c48063839c5f139dbbde6817b213f6
</div>
</div>
</div>
@@ -124,20 +125,15 @@
<h1>Registrering</h1>
<p>"Her skal registreringsformen inn"</p>
</div>
-
<div class="span6 sectionright">
<h1>Divid er enkelt!</h1> <!-- Vi viser deg hvor enkelt det er å bruke Divid.--!>
<ul>
- <h4><i class="icon-chevron-right icon-white"></i> Vi tar bryet og løser delingen rettferdig</h4>
- </br>
- <h4><i class="icon-chevron-right icon-white"></i> Divid hjelper deg med å holde oversikt over dine utgifter, utlegg og lån</h4> <!--Ikke la uvissheten om at du glemmer eller manglende tillit til folk hindre deg i dele eller låne.--!>
- </br>
- <h4><i class="icon-chevron-right icon-white"></i> Hold venner og bekjente oppdatert eller purr de med hva de skylder deg og vice versa</h4>
- </br>
- <h4><i class="icon-chevron-right icon-white"></i> Ta bilde av kvitteringene eller en utlånt gjenstand med Divid bildebank for senere gjennomsyn</h4><!--Du slipper kvitteringer - ta bilde av de og kast de i søpla. Bildene lastes opp til Divids servere så har du de senere hvis det er bruk for de.--!>
+ <h3><i class="icon-chevron-right icon-white"></i> Divid tar bryet ut av delingen og løser det rettferdig</h3>
+ <h3><i class="icon-chevron-right icon-white"></i> Divid hjelper deg med å holde oversikt over dine utgifter, utlegg og lån</h3> <!--Ikke la uvissheten om at du glemmer eller manglende tillit til folk hindre deg i dele eller låne.--!>
+ <h3><i class="icon-chevron-right icon-white"></i> Hold venner og bekjente oppdatert med hva de skylder deg og vice versa</h3>
+ <h3><i class="icon-chevron-right icon-white"></i> Ta bilde av kvitteringene eller en utlånt gjenstand så er de tilgjengelig i Divids bildebank for senere gjennomsyn</h3><!--Du slipper kvitteringer - ta bilde av de og kast de i søpla. Bildene lastes opp til Divids servere så har du de senere hvis det er bruk for de.--!>
</ul>
</div>
-
</div>
</div>
</div>
diff --git a/views/navbar.ejs b/views/navbar.ejs
index 6bc2bbe..9f02e9f 100644
--- a/views/navbar.ejs
+++ b/views/navbar.ejs
@@ -6,10 +6,10 @@
<div class="container">
<% if (!loggedin) { %>
<div class="row-fluid collapse login-collapse">
- <div class="span7">
+ <div class="span6">
<!--<img src="/img/logo_white.png">-->
</div>
- <div class="span5">
+ <div class="span6">
<form action="/login" method="post" id="login-form" class="form-horizontal">
<div class="control-group">
<div class="input-prepend">
@@ -31,15 +31,16 @@
</div>
<div class="span5">
<button type="submit" class="btn btn-inverse btn-small">Logg inn</button>
- <a href="/auth/facebook">f</a>
- <a href="/auth/twitter">t</a>
</div>
</div>
+ <div class="row-fluid">
+ Eller logg inn med <a href="/auth/facebook">facebook</a> / <a href="/auth/twitter">twitter</a>
+ </div>
</form>
</div>
</div>
<% } %>
- <div class="row">
+ <div class="row-fluid">
<img class="logo" src="/img/dividlogo.png" href="#">
<!--<a class="brand" href="#">Divid</a>--!>
<div class="pull-right">
diff --git a/views/newproject.ejs b/views/newproject.ejs
index e83673f..5559a9c 100644
--- a/views/newproject.ejs
+++ b/views/newproject.ejs
@@ -20,7 +20,7 @@
<div class="controls">
<div class="input-prepend">
<span class="add-on">u/fb.dennis.se/</span>
- <input id="projectname" name="projectname" placeholder="" class="span12" type="text" required="">
+ <input id="projectname" name="name" placeholder="" class="span12" type="text" required="">
</div>
<p class="help-block">Navnet på prosjektet du vil lage</p>
</div>
diff --git a/views/project.ejs b/views/project.ejs
index 4bee9fd..e9978d5 100644
--- a/views/project.ejs
+++ b/views/project.ejs
@@ -35,7 +35,7 @@
Robert Joramo<br />
Dennis Eriksen<br />
Helene Apelort<br />
- <small><a href="/ppl">Legg til flere deltakere</a></small>
+ <small><a href="/project/fEyMe3/participants">Legg til flere deltakere</a></small>
</div>
</div>
<div class="row-fluid">
diff --git a/views/projectParticipants.ejs b/views/projectParticipants.ejs
new file mode 100644
index 0000000..3af9c10
--- /dev/null
+++ b/views/projectParticipants.ejs
@@ -0,0 +1,55 @@
+<% include header %>
+
+</head>
+<body>
+ <% include navbar %>
+
+ <!-- Wrapper
+ ================================================== -->
+ <div class="container" id="wrapper">
+ <div class="row-fluid">
+
+
+ <form class="form-horizontal" method="post">
+ <fieldset>
+
+ <h1><legend><%= title %></legend></h1>
+ <p>Her kan du invitere venner til å delta i prosjektet ditt. Skriv inn eposadressene deres, en på hver linje, i tekstboksen under.</p>
+ <div class="control-group">
+ <label class="control-label">Epostadresser</label>
+ <div class="controls">
+ <textarea id="emails" name="emails" class="span6"></textarea>
+ </div>
+ </div>
+
+ <div class="control-group">
+ <label class="control-label">Beskrivelse</label>
+ <div class="controls">
+ <textarea id="description" name="description" class="span6">Hei! Jeg har oppdaget et nytt og kult program... Bla bla bla. Stian og Erling fixes.</textarea>
+ </div>
+ </div>
+
+ <div class="control-group">
+ <label class="control-label"></label>
+ <div class="controls">
+ <button type="submit" id="button1id" name="button1id" class="btn btn-primary">Inviter</button>
+ <button type="reset" id="button2id" name="button2id" class="btn">Nullstill</button>
+ </div>
+ </div>
+
+ </fieldset>
+ </form>
+
+
+
+
+
+
+
+ </div><!-- /div.row -->
+ </div><!-- /div.#wrapper -->
+
+
+<% include footer %>
+</body>
+</html>