2013-12-06 09:13:15 -05:00
|
|
|
// Holds all theme configuration information
|
|
|
|
// that as mostly used by templates and handlebar helpers.
|
|
|
|
|
2013-12-28 11:01:08 -05:00
|
|
|
var when = require('when'),
|
2013-12-06 09:13:15 -05:00
|
|
|
|
|
|
|
// Variables
|
2013-12-26 07:15:10 -05:00
|
|
|
themeConfig = {};
|
2013-12-06 09:13:15 -05:00
|
|
|
|
|
|
|
|
|
|
|
function theme() {
|
|
|
|
return themeConfig;
|
|
|
|
}
|
|
|
|
|
2013-12-09 23:41:58 -05:00
|
|
|
// We must pass the api.settings object
|
2013-12-06 09:13:15 -05:00
|
|
|
// into this method due to circular dependencies.
|
|
|
|
// If we were to require the api module here
|
|
|
|
// there would be a race condition where the ./models/base
|
|
|
|
// tries to access the config() object before it is created.
|
2013-12-26 07:15:10 -05:00
|
|
|
function update(settings, configUrl) {
|
2014-05-06 19:49:25 -05:00
|
|
|
// TODO: Pass the context into this method instead of hard coding internal: true?
|
2013-12-06 09:13:15 -05:00
|
|
|
return when.all([
|
2014-05-06 19:49:25 -05:00
|
|
|
settings.read.call({ internal: true }, 'title'),
|
|
|
|
settings.read.call({ internal: true }, 'description'),
|
|
|
|
settings.read.call({ internal: true }, 'logo'),
|
|
|
|
settings.read.call({ internal: true }, 'cover')
|
2013-12-06 09:13:15 -05:00
|
|
|
]).then(function (globals) {
|
2013-12-28 11:01:08 -05:00
|
|
|
// normalise the URL by removing any trailing slash
|
|
|
|
themeConfig.url = configUrl.replace(/\/$/, '');
|
2014-04-27 18:28:50 -05:00
|
|
|
themeConfig.title = globals[0].settings[0].value;
|
|
|
|
themeConfig.description = globals[1].settings[0].value;
|
|
|
|
themeConfig.logo = globals[2].settings[0] ? globals[2].settings[0].value : '';
|
|
|
|
themeConfig.cover = globals[3].settings[0] ? globals[3].settings[0].value : '';
|
2013-12-06 09:13:15 -05:00
|
|
|
return;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = theme;
|
|
|
|
module.exports.update = update;
|