Converse converse.js

Source: headless/utils/parse-helpers.js

  1. /**
  2. * @copyright 2022, the Converse.js contributors
  3. * @license Mozilla Public License (MPLv2)
  4. * @description Pure functions to help functionally parse messages.
  5. * @todo Other parsing helpers can be made more abstract and placed here.
  6. */
  7. const helpers = {};
  8. const escapeRegexChars = (string, char) => string.replace(RegExp('\\' + char, 'ig'), '\\' + char);
  9. helpers.escapeCharacters = characters => string =>
  10. characters.split('').reduce(escapeRegexChars, string);
  11. helpers.escapeRegexString = helpers.escapeCharacters('[\\^$.?*+(){}|');
  12. // `for` is ~25% faster than using `Array.find()`
  13. helpers.findFirstMatchInArray = array => text => {
  14. for (let i = 0; i < array.length; i++) {
  15. if (text.localeCompare(array[i], undefined, {sensitivity: 'base'}) === 0) {
  16. return array[i];
  17. }
  18. }
  19. return null;
  20. };
  21. const reduceReferences = ([text, refs], ref, index) => {
  22. let updated_text = text;
  23. let { begin, end } = ref;
  24. const { value } = ref;
  25. begin = begin - index;
  26. end = end - index - 1; // -1 to compensate for the removed @
  27. updated_text = `${updated_text.slice(0, begin)}${value}${updated_text.slice(end + 1)}`;
  28. return [updated_text, [...refs, { ...ref, begin, end }]]
  29. }
  30. helpers.reduceTextFromReferences = (text, refs) => refs.reduce(reduceReferences, [text, []]);
  31. export default helpers;