refactor rxify fieldguides

This commit is contained in:
Berkeley Martinez
2015-06-23 16:22:07 -07:00
parent 71223de101
commit fb04a022ae
2 changed files with 98 additions and 83 deletions

View File

@ -1,11 +1,16 @@
var R = require('ramda'), var Rx = require('rx');
// Rx = require('rx'), var debug = require('debug')('freecc:fieldguides');
debug = require('debug')('freecc:fieldguides'), var observeMethod = require('../utils/rx').observeMethod;
utils = require('../utils'); var saveUser = require('../utils/rx').saveUser;
var utils = require('../utils');
var allFieldGuideNamesAndIds = utils.allFieldGuideNamesAndIds();
module.exports = function(app) { module.exports = function(app) {
var router = app.loopback.Router(); var router = app.loopback.Router();
var FieldGuide = app.models.FieldGuide; var FieldGuide = app.models.FieldGuide;
var findFieldGuideById = observeMethod(FieldGuide, 'findById');
var findOneFieldGuide = observeMethod(FieldGuide, 'findOne');
router.get('/field-guide/all-articles', showAllFieldGuides); router.get('/field-guide/all-articles', showAllFieldGuides);
router.get('/field-guide/:fieldGuideName', returnIndividualFieldGuide); router.get('/field-guide/:fieldGuideName', returnIndividualFieldGuide);
@ -15,60 +20,66 @@ module.exports = function(app) {
app.use(router); app.use(router);
function returnIndividualFieldGuide(req, res, next) { function returnIndividualFieldGuide(req, res, next) {
var dashedNameFromQuery = req.params.fieldGuideName; var dashedName = req.params.fieldGuideName;
if (req.user) { var userSave = Rx.Observable.just(req.user)
var completed = req.user.completedFieldGuides; .filter(function(user) {
return !!user;
})
.map(function(user) {
var completed = user.completedFieldGuides;
var uncompletedFieldGuides = utils.allFieldGuideIds() var uncompletedFieldGuides = utils.allFieldGuideIds()
.filter(function (elem) { .filter(function(id) {
if (completed.indexOf(elem) === -1) { if (completed.indexOf(id) === -1) {
return elem; return id;
} }
});
req.user.uncompletedFieldGuides = uncompletedFieldGuides;
// TODO(berks): handle callback properly
req.user.save(function(err) {
if (err) { return next(err); }
});
}
FieldGuide.find({ where: {'dashedName': dashedNameFromQuery}},
function(err, fieldGuideFromMongo) {
if (err) {
return next(err);
}
if (fieldGuideFromMongo.length < 1) {
req.flash('errors', {
msg: '404: We couldn\'t find a field guide entry with that name. ' +
'Please double check the name.'
}); });
user.uncompletedFieldGuides = uncompletedFieldGuides;
return user;
})
.flatMap(function(user) {
return saveUser(user);
});
return res.redirect('/'); var query = { where: { dashedName: { like: dashedName, options: 'i' } } };
}
var fieldGuide = R.head(fieldGuideFromMongo); debug('find fieldGuide', query);
fieldGuide.name.toLowerCase().replace(/\s/g, '-').replace(/\?/g, ''); Rx.Observable.combineLatest(
// find that field guide
findOneFieldGuide(query),
userSave,
Rx.helpers.identity
)
.subscribe(
// don't care about return from userSave
function(fieldGuide) {
if (!fieldGuide) {
req.flash('errors', {
msg: '404: We couldn\'t find a field guide entry with ' +
'that name. Please double check the name.'
});
return res.redirect('/field-guide/all-articles');
}
// if (fieldGuide.dashedName !== dashedNameFromQuery) { if (fieldGuide.dashedName !== dashedName) {
// return res.redirect('../field-guide/' + fieldGuide.dashedName); return res.redirect('../field-guide/' + fieldGuide.dashedName);
// } }
res.render('field-guide/show', { res.render('field-guide/show', {
title: fieldGuide.name, title: fieldGuide.name,
fieldGuideId: fieldGuide.id, fieldGuideId: fieldGuide.id,
description: fieldGuide.description.join('') description: fieldGuide.description.join('')
}); });
} },
next
); );
} }
function showAllFieldGuides(req, res) { function showAllFieldGuides(req, res) {
var allFieldGuideNamesAndIds = utils.allFieldGuideNamesAndIds();
var completedFieldGuides = []; var completedFieldGuides = [];
if (req.user && req.user.completedFieldGuides) { if (req.user && req.user.completedFieldGuides) {
completedFieldGuides = req.user.completedFieldGuides; completedFieldGuides = req.user.completedFieldGuides;
} }
res.render('field-guide/all-articles', { res.render('field-guide/all-articles', {
allFieldGuideNamesAndIds: allFieldGuideNamesAndIds, allFieldGuideNamesAndIds: allFieldGuideNamesAndIds,
completedFieldGuides: completedFieldGuides completedFieldGuides: completedFieldGuides
@ -76,16 +87,19 @@ module.exports = function(app) {
} }
function showCompletedFieldGuideFunction(req, res) { function showCompletedFieldGuideFunction(req, res) {
req.flash('success', { req.flash(
msg: [ 'success',
'You\'ve read all our current Field Guide entries. ' + {
'If you have ideas for other Field Guide articles, ' + msg: [
'please let us know on ', 'You\'ve read all our current Field Guide entries. ' +
'<a href=\'https://github.com/freecodecamp/freecodecamp/' + 'If you have ideas for other Field Guide articles, ' +
'issues/new?&body=Please describe your idea for a Field Guide' + 'please let us know on ',
' article and include links if possible.\'>GitHub</a>.' '<a href=\'https://github.com/freecodecamp/freecodecamp/' +
].join('') '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');
} }
@ -95,38 +109,40 @@ module.exports = function(app) {
} }
if (!req.user.uncompletedFieldGuides.length) { if (!req.user.uncompletedFieldGuides.length) {
return showCompletedFieldGuideFunction(req, res, next); return showCompletedFieldGuideFunction(req, res);
} }
FieldGuide.findById(req.user.uncompletedFieldGuides[0], findFieldGuideById(req.user.uncompletedFieldGuides[0]).subscribe(
function(err, fieldGuide) { function(fieldGuide) {
if (err) { return next(err); }
if (!fieldGuide) { if (!fieldGuide) {
debug('bad juju in field guide %s', debug(
req.user.uncompletedFieldGuides[0]); 'field guide %s not found',
req.user.uncompletedFieldGuides[0]
);
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); return res.redirect('../field-guide/' + fieldGuide.dashedName);
}); },
next
);
}
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);
}
saveUser(req.user).subscribe(
function() {
res.send(true);
},
next
);
} }
}; };
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);
});
}

View File

@ -1,6 +1,5 @@
var Rx = require('rx'); var Rx = require('rx');
var debug = require('debug')('freecc:rxUtils'); var debug = require('debug')('freecc:rxUtils');
var slice = Array.prototype.slice;
exports.saveUser = function saveUser(user) { exports.saveUser = function saveUser(user) {
return new Rx.Observable.create(function(observer) { return new Rx.Observable.create(function(observer) {