cleanup.cjs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. 'use strict';
  2. const emoji_convert = require('./convert.cjs');
  3. const emoji_data = require('./data.cjs');
  4. function getEmojiSequenceFromString(value) {
  5. return value.trim().split(/[^0-9A-F]+/i).filter((item) => item.length > 0).map(emoji_convert.getEmojiCodePoint);
  6. }
  7. function getSequenceFromEmojiStringOrKeyword(value) {
  8. if (!value.match(/^[0-9a-fA-F-\s]+$/)) {
  9. const results = [];
  10. for (const codePoint of value) {
  11. const code = codePoint.codePointAt(0);
  12. if (code) {
  13. results.push(code);
  14. } else {
  15. return getEmojiSequenceFromString(value);
  16. }
  17. }
  18. return results;
  19. }
  20. return getEmojiSequenceFromString(value);
  21. }
  22. function splitEmojiSequences(sequence, separator = emoji_data.joinerEmoji) {
  23. const results = [];
  24. let queue = [];
  25. for (let i = 0; i < sequence.length; i++) {
  26. const code = sequence[i];
  27. if (code === separator) {
  28. results.push(queue);
  29. queue = [];
  30. } else {
  31. queue.push(code);
  32. }
  33. }
  34. results.push(queue);
  35. return results;
  36. }
  37. function joinEmojiSequences(sequences, separator = emoji_data.joinerEmoji) {
  38. let results = [];
  39. for (let i = 0; i < sequences.length; i++) {
  40. if (i > 0) {
  41. results.push(separator);
  42. }
  43. results = results.concat(sequences[i]);
  44. }
  45. return results;
  46. }
  47. function getUnqualifiedEmojiSequence(sequence) {
  48. return sequence.filter((num) => num !== emoji_data.vs16Emoji);
  49. }
  50. exports.getEmojiSequenceFromString = getEmojiSequenceFromString;
  51. exports.getSequenceFromEmojiStringOrKeyword = getSequenceFromEmojiStringOrKeyword;
  52. exports.getUnqualifiedEmojiSequence = getUnqualifiedEmojiSequence;
  53. exports.joinEmojiSequences = joinEmojiSequences;
  54. exports.splitEmojiSequences = splitEmojiSequences;