UNPKG

voca

Version:

The ultimate JavaScript string library

36 lines (31 loc) 1.25 kB
'use strict'; require('./internal/is_nil.js'); require('./is_string.js'); var coerce_to_string = require('./internal/coerce_to_string.js'); var _const = require('./internal/const.js'); var nil_default = require('./internal/nil_default.js'); /** * Splits `subject` into an array of graphemes taking care of * <a href="https://rainsoft.io/what-every-javascript-developer-should-know-about-unicode/#24surrogatepairs">surrogate pairs</a> and * <a href="https://rainsoft.io/what-every-javascript-developer-should-know-about-unicode/#25combiningmarks">combining marks</a>. * * @function graphemes * @static * @since 1.0.0 * @memberOf Split * @param {string} [subject=''] The string to split into characters. * @return {Array} Returns the array of graphemes. * @example * v.graphemes('\uD835\uDC00\uD835\uDC01'); // or '𝐀𝐁' * // => ['\uD835\uDC00', '\uD835\uDC01'], or * // ['𝐀', '𝐁'] * * v.graphemes('cafe\u0301'); // or 'café' * // => ['c', 'a', 'f', 'e\u0301'], or * // ['c', 'a', 'f', 'é'] */ function graphemes(subject) { var subjectString = coerce_to_string.coerceToString(subject); return nil_default.nilDefault(subjectString.match(_const.REGEXP_UNICODE_CHARACTER), []); } module.exports = graphemes;