f671f9d2c9
refs #5345, refs #3801 - Blog localisation - default is `en` (English) - you can change the language code in the admin panel, see https://github.com/TryGhost/Ghost-Admin/pull/703 - blog behaviour changes depending on the language e.g. date helper format - theme translation get's loaded if available depending on the language setting - falls back to english if not available - Theme translation - complete automatic translation of Ghost's frontend for site visitors (themes, etc.), to quickly deploy a site in a non-English language - added {{t}} and {{lang}} helper - no backend or admin panel translations (!) - easily readable translation keys - very simple translation - server restart required when adding new language files or changing existing files in the theme - no language code validation for now (will be added soon) - a full theme translation requires to translate Ghost core templates (e.g. subscriber form) - when activating a different theme, theme translations are auto re-loaded - when switching language of blog, theme translations are auto re-loaded - Bump gscan to version 1.3.0 to support more known helpers **Documentation can be found at https://themes.ghost.org/v1.20.0/docs/i18n.**
48 lines
1.6 KiB
JavaScript
48 lines
1.6 KiB
JavaScript
// # Date Helper
|
|
// Usage: `{{date format="DD MM, YYYY"}}`, `{{date updated_at format="DD MM, YYYY"}}`
|
|
//
|
|
// Formats a date using moment-timezone.js. Formats published_at by default but will also take a date as a parameter
|
|
|
|
var proxy = require('./proxy'),
|
|
moment = require('moment-timezone'),
|
|
SafeString = proxy.SafeString,
|
|
i18n = proxy.i18n;
|
|
|
|
module.exports = function (date, options) {
|
|
var timezone, format, timeago, timeNow, dateMoment;
|
|
|
|
if (!options && date.hasOwnProperty('hash')) {
|
|
options = date;
|
|
date = undefined;
|
|
timezone = options.data.blog.timezone;
|
|
|
|
// set to published_at by default, if it's available
|
|
// otherwise, this will print the current date
|
|
if (this.published_at) {
|
|
date = moment(this.published_at).tz(timezone).format();
|
|
}
|
|
}
|
|
|
|
// ensure that context is undefined, not null, as that can cause errors
|
|
date = date === null ? undefined : date;
|
|
|
|
format = options.hash.format || 'MMM DD, YYYY';
|
|
timeago = options.hash.timeago;
|
|
timezone = options.data.blog.timezone;
|
|
timeNow = moment().tz(timezone);
|
|
|
|
// i18n: Making dates, including month names, translatable to any language.
|
|
// Documentation: http://momentjs.com/docs/#/i18n/
|
|
// Locales: https://github.com/moment/moment/tree/develop/locale
|
|
dateMoment = moment(date);
|
|
dateMoment.locale(i18n.locale());
|
|
|
|
if (timeago) {
|
|
date = timezone ? dateMoment.tz(timezone).from(timeNow) : dateMoment.fromNow();
|
|
} else {
|
|
date = timezone ? dateMoment.tz(timezone).format(format) : dateMoment.format(format);
|
|
}
|
|
|
|
return new SafeString(date);
|
|
};
|