mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-24 11:22:19 +03:00
22e13acd65
- All var declarations are now const or let as per ES6 - All comma-separated lists / chained declarations are now one declaration per line - This is for clarity/readability but also made running the var-to-const/let switch smoother - ESLint rules updated to match How this was done: - npm install -g jscodeshift - git clone https://github.com/cpojer/js-codemod.git - git clone git@github.com:TryGhost/Ghost.git shallow-ghost - cd shallow-ghost - jscodeshift -t ../js-codemod/transforms/unchain-variables.js . -v=2 - jscodeshift -t ../js-codemod/transforms/no-vars.js . -v=2 - yarn - yarn test - yarn lint / fix various lint errors (almost all indent) by opening files and saving in vscode - grunt test-regression - sorted!
43 lines
1.6 KiB
JavaScript
43 lines
1.6 KiB
JavaScript
const settingsCache = require('../../server/services/settings/cache');
|
|
const _ = require('lodash');
|
|
|
|
function getContextObject(data, context) {
|
|
/**
|
|
* If the data object does not contain the requested context, we return the fallback object.
|
|
*/
|
|
const blog = {
|
|
cover_image: settingsCache.get('cover_image'),
|
|
twitter: settingsCache.get('twitter'),
|
|
facebook: settingsCache.get('facebook')
|
|
};
|
|
|
|
let chosenContext;
|
|
|
|
// @TODO: meta layer is very broken, it's really hard to understand what it's doing
|
|
// The problem is that handlebars root object is structured differently. Sometimes the object is flat on data
|
|
// and sometimes the object is part of a key e.g. data.post. This needs to be prepared at the very first stage and not in each helper.
|
|
if ((_.includes(context, 'page') || _.includes(context, 'amp')) && data.post) {
|
|
chosenContext = data.post;
|
|
} else if (_.includes(context, 'post') && data.post) {
|
|
chosenContext = data.post;
|
|
} else if (_.includes(context, 'page') && data.page) {
|
|
chosenContext = data.page;
|
|
} else if (_.includes(context, 'tag') && data.tag) {
|
|
chosenContext = data.tag;
|
|
} else if (_.includes(context, 'author') && data.author) {
|
|
chosenContext = data.author;
|
|
} else if (data[context]) {
|
|
// @NOTE: This is confusing as hell. It tries to get data[['author']], which works, but coincidence?
|
|
chosenContext = data[context];
|
|
}
|
|
|
|
// Super fallback.
|
|
if (!chosenContext) {
|
|
chosenContext = blog;
|
|
}
|
|
|
|
return chosenContext;
|
|
}
|
|
|
|
module.exports = getContextObject;
|