2013-12-06 18:13:15 +04:00
|
|
|
// Holds all theme configuration information
|
|
|
|
// that as mostly used by templates and handlebar helpers.
|
|
|
|
|
|
|
|
var when = require('when'),
|
|
|
|
|
|
|
|
// Variables
|
2013-12-26 16:15:10 +04:00
|
|
|
themeConfig = {};
|
2013-12-06 18:13:15 +04:00
|
|
|
|
|
|
|
|
|
|
|
function theme() {
|
|
|
|
return themeConfig;
|
|
|
|
}
|
|
|
|
|
2013-12-10 08:41:58 +04:00
|
|
|
// We must pass the api.settings object
|
2013-12-06 18:13:15 +04: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 16:15:10 +04:00
|
|
|
function update(settings, configUrl) {
|
2013-12-06 18:13:15 +04:00
|
|
|
return when.all([
|
2013-12-10 08:41:58 +04:00
|
|
|
settings.read('title'),
|
|
|
|
settings.read('description'),
|
|
|
|
settings.read('logo'),
|
|
|
|
settings.read('cover')
|
2013-12-06 18:13:15 +04:00
|
|
|
]).then(function (globals) {
|
|
|
|
|
2013-12-26 16:15:10 +04:00
|
|
|
themeConfig.url = configUrl;
|
2013-12-06 18:13:15 +04:00
|
|
|
themeConfig.title = globals[0].value;
|
|
|
|
themeConfig.description = globals[1].value;
|
|
|
|
themeConfig.logo = globals[2] ? globals[2].value : '';
|
|
|
|
themeConfig.cover = globals[3] ? globals[3].value : '';
|
|
|
|
return;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = theme;
|
|
|
|
module.exports.update = update;
|