Remove mongoose style lookup from fieldguide.js. Update user model.
This commit is contained in:
@ -126,9 +126,8 @@
|
||||
"type": "string"
|
||||
},
|
||||
"sentSlackInvite": {
|
||||
"type": {
|
||||
"type": false
|
||||
}
|
||||
"type": "boolean",
|
||||
"default": false
|
||||
},
|
||||
"resetPasswordExpires": {
|
||||
"type": "string"
|
||||
@ -145,10 +144,12 @@
|
||||
"completedDate": "string",
|
||||
"solution": "string"
|
||||
}
|
||||
]
|
||||
],
|
||||
"default": []
|
||||
},
|
||||
"uncompletedCoursewares": {
|
||||
"type": "array"
|
||||
"type": "array",
|
||||
"default": []
|
||||
},
|
||||
"completedCoursewares": {
|
||||
"type": [
|
||||
@ -164,7 +165,8 @@
|
||||
"githubLink": "string",
|
||||
"verified": "boolean"
|
||||
}
|
||||
]
|
||||
],
|
||||
"default": []
|
||||
},
|
||||
"completedFieldGuides": {
|
||||
"type": []
|
||||
@ -217,7 +219,8 @@
|
||||
"default": []
|
||||
},
|
||||
"uncompletedChallenges": {
|
||||
"type": "array"
|
||||
"type": "array",
|
||||
"default": []
|
||||
}
|
||||
},
|
||||
"validations": [],
|
||||
|
@ -1,7 +1,7 @@
|
||||
var R = require('ramda'),
|
||||
// Rx = require('rx'),
|
||||
// debug = require('debug')('freecc:fieldguides'),
|
||||
utils = require('../utils');
|
||||
// Rx = require('rx'),
|
||||
// debug = require('debug')('freecc:fieldguides'),
|
||||
utils = require('../utils');
|
||||
|
||||
module.exports = function(app) {
|
||||
var router = app.loopback.Router();
|
||||
@ -48,7 +48,7 @@ module.exports = function(app) {
|
||||
}
|
||||
|
||||
var fieldGuide = R.head(fieldGuideFromMongo);
|
||||
fieldGuide.name.toLowerCase().replace(/\s/g, '-').replace(/\?/g, '');
|
||||
fieldGuide.name.toLowerCase().replace(/\s/g, '-').replace(/\?/g, '');
|
||||
|
||||
// if (fieldGuide.dashedName !== dashedNameFromQuery) {
|
||||
// return res.redirect('../field-guide/' + fieldGuide.dashedName);
|
||||
@ -80,45 +80,44 @@ module.exports = function(app) {
|
||||
return res.redirect('/field-guide/how-do-i-use-this-guide');
|
||||
}
|
||||
|
||||
var displayedFieldGuides =
|
||||
FieldGuide.find({'id': req.user.uncompletedFieldGuides[0]});
|
||||
FieldGuide.find({'id': req.user.uncompletedFieldGuides[0]},
|
||||
function(err, fieldGuide) {
|
||||
|
||||
displayedFieldGuides.exec(function(err, fieldGuide) {
|
||||
if (err) { return next(err); }
|
||||
fieldGuide = fieldGuide.pop();
|
||||
if (err) { return next(err); }
|
||||
fieldGuide = fieldGuide.pop();
|
||||
|
||||
if (typeof fieldGuide === 'undefined') {
|
||||
if (req.user.completedFieldGuides.length > 0) {
|
||||
req.flash('success', {
|
||||
msg: [
|
||||
"You've read all our current Field Guide entries. If you have ",
|
||||
'ideas for other Field Guide articles, please let us know on ',
|
||||
"<a href='https://github.com/freecodecamp/freecodecamp/issues/new?&body=Please describe your idea for a Field Guide article and include links if possible.'>GitHub</a>."
|
||||
].join('')
|
||||
});
|
||||
if (typeof fieldGuide === 'undefined') {
|
||||
if (req.user.completedFieldGuides.length > 0) {
|
||||
req.flash('success', {
|
||||
msg: [
|
||||
"You've read all our current Field Guide entries. If you have ",
|
||||
'ideas for other Field Guide articles, please let us know on ',
|
||||
"<a href='https://github.com/freecodecamp/freecodecamp/issues/new?&body=Please describe your idea for a Field Guide article and include links if possible.'>GitHub</a>."
|
||||
].join('')
|
||||
});
|
||||
}
|
||||
return res.redirect('../field-guide/how-do-i-use-this-guide');
|
||||
}
|
||||
return res.redirect('../field-guide/how-do-i-use-this-guide');
|
||||
}
|
||||
return res.redirect('../field-guide/' + fieldGuide.dashedName);
|
||||
});
|
||||
}
|
||||
|
||||
function completedFieldGuide(req, res, next) {
|
||||
var fieldGuideId = req.body.fieldGuideInfo.fieldGuideId;
|
||||
|
||||
req.user.completedFieldGuides.push(fieldGuideId);
|
||||
|
||||
var index = req.user.uncompletedFieldGuides.indexOf(fieldGuideId);
|
||||
if (index > -1) {
|
||||
req.user.progressTimestamps.push(Date.now());
|
||||
req.user.uncompletedFieldGuides.splice(index, 1);
|
||||
}
|
||||
|
||||
req.user.save(function (err) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
res.send(true);
|
||||
});
|
||||
return res.redirect('../field-guide/' + fieldGuide.dashedName);
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
function completedFieldGuide(req, res, next) {
|
||||
var fieldGuideId = req.body.fieldGuideInfo.fieldGuideId;
|
||||
|
||||
req.user.completedFieldGuides.push(fieldGuideId);
|
||||
|
||||
var index = req.user.uncompletedFieldGuides.indexOf(fieldGuideId);
|
||||
if (index > -1) {
|
||||
req.user.progressTimestamps.push(Date.now());
|
||||
req.user.uncompletedFieldGuides.splice(index, 1);
|
||||
}
|
||||
|
||||
req.user.save(function (err) {
|
||||
if (err) {
|
||||
return next(err);
|
||||
}
|
||||
res.send(true);
|
||||
});
|
||||
}
|
||||
|
Reference in New Issue
Block a user