voca
Version:
The ultimate JavaScript string library
36 lines (31 loc) • 1.25 kB
JavaScript
;
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;