UNPKG

handlebars-helpers-v2

Version:

Essential Handlebars helpers in TypeScript. A modernized collection of 8 core helper categories with TypeScript support and ESM compatibility.

215 lines 6.55 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); Object.defineProperty(exports, "__esModule", { value: true }); // Remove import as we use our own isNumber function from utils const util = __importStar(require("handlebars-utils")); const utils = __importStar(require("./utils")); const helpers = {}; /** * Format a number to it's equivalent in bytes. If a string is passed, * it's length will be formatted and returned. * * **Examples:** * * - `'foo' => 3 B` * - `13661855 => 13.66 MB` * - `825399 => 825.39 kB` * - `1396 => 1.4 kB` * * @param {Number|String} `number` * @return {String} * @api public */ helpers.bytes = function (number, precision, options) { if (number == null) return '0 B'; if (!utils.isNumber(number)) { number = number.length; if (!number) return '0 B'; } if (!utils.isNumber(precision)) { precision = 2; } var abbr = ['B', 'kB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']; precision = Math.pow(10, precision); number = Number(number); var len = abbr.length - 1; while (len-- >= 0) { var size = Math.pow(10, len * 3); if (size <= (number + 1)) { number = Math.round(number * precision / size) / precision; number += ' ' + abbr[len]; break; } } return number; }; /** * Add commas to numbers * * @param {Number} `num` * @return {Number} * @api public */ helpers.addCommas = function (num) { return num.toString().replace(/(\d)(?=(\d\d\d)+(?!\d))/g, '$1,'); }; /** * Convert a string or number to a formatted phone number. * * @param {Number|String} `num` The phone number to format, e.g. `8005551212` * @return {Number} Formatted phone number: `(800) 555-1212` * @source http://bit.ly/QlPmPr * @api public */ helpers.phoneNumber = function (num) { num = num.toString(); return '(' + num.substr(0, 3) + ') ' + num.substr(3, 3) + '-' + num.substr(6, 4); }; /** * Abbreviate numbers to the given number of `precision`. This is for * general numbers, not size in bytes. * * @param {Number} `number` * @param {Number} `precision` * @return {String} * @api public */ helpers.toAbbr = function (number, precision) { if (!utils.isNumber(number)) { number = 0; } if (util.isUndefined(precision)) { precision = 2; } number = Number(number); // 2 decimal places => 100, 3 => 1000, etc. precision = Math.pow(10, precision); var abbr = ['k', 'm', 'b', 't', 'q']; var len = abbr.length - 1; while (len >= 0) { var size = Math.pow(10, (len + 1) * 3); if (size <= (number + 1)) { number = Math.round(number * precision / size) / precision; number += abbr[len]; break; } len--; } return number; }; /** * Returns a string representing the given number in exponential notation. * * ```handlebars * {{toExponential number digits}}; * ``` * @param {Number} `number` * @param {Number} `fractionDigits` Optional. An integer specifying the number of digits to use after the decimal point. Defaults to as many digits as necessary to specify the number. * @return {Number} * @api public */ helpers.toExponential = function (number, digits) { if (!utils.isNumber(number)) { number = 0; } if (util.isUndefined(digits)) { digits = 0; } return Number(number).toExponential(digits); }; /** * Formats the given number using fixed-point notation. * * ```handlebars * {{toFixed "1.1234" 2}} * //=> '1.12' * ``` * @param {Number} `number` * @param {Number} `digits` (Optional) The number of digits to appear after the decimal point; this may be a value between 0 and 20. If this argument is omitted, it is treated as 0. * @return {String} A string representing the given number using fixed-point notation. * @api public */ helpers.toFixed = function (number, digits) { if (!utils.isNumber(number)) { number = 0; } if (!utils.isNumber(digits)) { digits = 0; } return Number(number).toFixed(digits); }; /** * @param {Number} `number` * @return {Number} * @api public */ helpers.toFloat = function (number) { return parseFloat(number); }; /** * @param {Number} `number` * @return {Number} * @api public */ helpers.toInt = function (number) { return parseInt(number, 10); }; /** * Returns a string representing the `Number` object to the specified precision. * * ```handlebars * {{toPrecision "1.1234" 2}} * //=> '1.1' * ``` * @param {Number} `number` * @param {Number} `precision` (Optional) An integer specifying the number of significant digits. If precison is not between 1 and 100 (inclusive), it will be coerced to `0`. * @return {String} A string representing a Number object in fixed-point or exponential notation rounded to precision significant digits. * @api public */ helpers.toPrecision = function (number, precision) { if (!utils.isNumber(number)) { number = 0; } if (!utils.isNumber(precision)) { precision = 1; } return Number(number).toPrecision(precision); }; exports.default = helpers; //# sourceMappingURL=number.js.map