message-text.js 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. import { __ } from 'i18n/index.js';
  2. import { getOOBURLMarkup } from 'utils/html.js';
  3. import { html } from 'lit';
  4. const tpl_edited_icon = (el) => {
  5. const i18n_edited = __('This message has been edited');
  6. return html`<converse-icon title="${ i18n_edited }" class="fa fa-edit chat-msg__edit-modal" @click=${el.showMessageVersionsModal} size="1em"></converse-icon>`;
  7. }
  8. export default (el) => {
  9. const i18n_show = __('Show more');
  10. const is_groupchat_message = (el.model.get('type') === 'groupchat');
  11. const i18n_show_less = __('Show less');
  12. const tpl_spoiler_hint = html`
  13. <div class="chat-msg__spoiler-hint">
  14. <span class="spoiler-hint">${el.model.get('spoiler_hint')}</span>
  15. <a class="badge badge-info spoiler-toggle" href="#" @click=${el.toggleSpoilerMessage}>
  16. <converse-icon size="1em" color="var(--background)" class="fa ${el.model.get('is_spoiler_visible') ? 'fa-eye-slash' : 'fa-eye'}"></converse-icon>
  17. ${ el.model.get('is_spoiler_visible') ? i18n_show_less : i18n_show }
  18. </a>
  19. </div>
  20. `;
  21. const spoiler_classes = el.model.get('is_spoiler') ? `spoiler ${el.model.get('is_spoiler_visible') ? '' : 'hidden'}` : '';
  22. const text = el.model.getMessageText();
  23. const show_oob = el.model.get('oob_url') && text !== el.model.get('oob_url');
  24. return html`
  25. ${ el.model.get('is_spoiler') ? tpl_spoiler_hint : '' }
  26. ${ el.model.get('subject') ? html`<div class="chat-msg__subject">${el.model.get('subject')}</div>` : '' }
  27. <span>
  28. <converse-chat-message-body
  29. class="chat-msg__text ${el.model.get('is_only_emojis') ? 'chat-msg__text--larger' : ''} ${spoiler_classes}"
  30. .model="${el.model}"
  31. hide_url_previews=${el.model.get('hide_url_previews')}
  32. ?is_me_message=${el.model.isMeCommand()}
  33. text="${text}"></converse-chat-message-body>
  34. ${ (el.model.get('received') && !el.model.isMeCommand() && !is_groupchat_message) ? html`<span class="fa fa-check chat-msg__receipt"></span>` : '' }
  35. ${ (el.model.get('edited')) ? tpl_edited_icon(el) : '' }
  36. </span>
  37. ${ show_oob ? html`<div class="chat-msg__media">${getOOBURLMarkup(el.model.get('oob_url'))}</div>` : '' }
  38. <div class="chat-msg__error">${ el.model.get('error_text') || el.model.get('error') }</div>
  39. `;
  40. }