2014-10-10 15:54:07 +01:00
|
|
|
// # Plural Helper
|
2018-01-09 14:50:57 +01:00
|
|
|
// Usage example: `{{plural ../pagination.total empty='No posts' singular='1 post' plural='% posts'}}`
|
|
|
|
// or for translatable themes, with (t) translation helper's subexpressions:
|
|
|
|
// `{{plural ../pagination.total empty=(t "No posts") singular=(t "1 post") plural=(t "% posts")}}`
|
2014-10-10 15:54:07 +01:00
|
|
|
//
|
2018-01-09 14:50:57 +01:00
|
|
|
// Pluralises strings depending on item count
|
2014-10-10 15:54:07 +01:00
|
|
|
//
|
|
|
|
// The 1st argument is the numeric variable which the helper operates on
|
|
|
|
// The 2nd argument is the string that will be output if the variable's value is 0
|
|
|
|
// The 3rd argument is the string that will be output if the variable's value is 1
|
|
|
|
// The 4th argument is the string that will be output if the variable's value is 2+
|
2022-04-05 17:38:46 +01:00
|
|
|
const {SafeString} = require('../services/handlebars');
|
2014-10-10 15:54:07 +01:00
|
|
|
|
2021-09-26 21:01:13 +01:00
|
|
|
const errors = require('@tryghost/errors');
|
|
|
|
const tpl = require('@tryghost/tpl');
|
2020-03-30 21:23:02 +01:00
|
|
|
const isUndefined = require('lodash/isUndefined');
|
2014-10-10 15:54:07 +01:00
|
|
|
|
2021-09-23 20:46:22 +01:00
|
|
|
const messages = {
|
|
|
|
valuesMustBeDefined: 'All values must be defined for empty, singular and plural'
|
|
|
|
};
|
|
|
|
|
2017-04-04 17:07:35 +01:00
|
|
|
module.exports = function plural(number, options) {
|
2020-03-30 21:23:02 +01:00
|
|
|
if (isUndefined(options.hash) || isUndefined(options.hash.empty) ||
|
|
|
|
isUndefined(options.hash.singular) || isUndefined(options.hash.plural)) {
|
2016-10-06 14:27:35 +02:00
|
|
|
throw new errors.IncorrectUsageError({
|
2021-09-23 20:46:22 +01:00
|
|
|
message: tpl(messages.valuesMustBeDefined)
|
2016-10-06 14:27:35 +02:00
|
|
|
});
|
2014-10-10 15:54:07 +01:00
|
|
|
}
|
|
|
|
|
2016-02-21 18:48:44 +00:00
|
|
|
if (number === 0) {
|
2017-04-04 17:07:35 +01:00
|
|
|
return new SafeString(options.hash.empty.replace('%', number));
|
2016-02-21 18:48:44 +00:00
|
|
|
} else if (number === 1) {
|
2017-04-04 17:07:35 +01:00
|
|
|
return new SafeString(options.hash.singular.replace('%', number));
|
2016-02-21 18:48:44 +00:00
|
|
|
} else if (number >= 2) {
|
2017-04-04 17:07:35 +01:00
|
|
|
return new SafeString(options.hash.plural.replace('%', number));
|
2014-10-10 15:54:07 +01:00
|
|
|
}
|
|
|
|
};
|