mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-03 04:27:53 +00:00
* chore: Use markdown-it instead of marked * Adds styling for markdown rendered content * fixes codeclimate issue * Fixes blockquote styles for widget in darkmode * fix: issue block quote color issue in light mode * fix: issue block quote color issue in light mode * Fixes blockquote color in dark mode * Remove usage of dark mode mixin in user bubble * chore: code clean up --------- Co-authored-by: Nithin David Thomas <1277421+nithindavid@users.noreply.github.com> Co-authored-by: Sivin Varghese <64252451+iamsivin@users.noreply.github.com> Co-authored-by: iamsivin <iamsivin@gmail.com>
100 lines
3.9 KiB
JavaScript
100 lines
3.9 KiB
JavaScript
import MessageFormatter from '../MessageFormatter';
|
|
|
|
describe('#MessageFormatter', () => {
|
|
describe('content with links', () => {
|
|
it('should format correctly', () => {
|
|
const message =
|
|
'Chatwoot is an opensource tool. [Chatwoot](https://www.chatwoot.com)';
|
|
expect(new MessageFormatter(message).formattedMessage).toMatch(
|
|
'<p>Chatwoot is an opensource tool. <a href="https://www.chatwoot.com" class="link" rel="noreferrer noopener nofollow" target="_blank">Chatwoot</a></p>'
|
|
);
|
|
});
|
|
it('should format correctly', () => {
|
|
const message =
|
|
'Chatwoot is an opensource tool. https://www.chatwoot.com';
|
|
expect(new MessageFormatter(message).formattedMessage).toMatch(
|
|
'<p>Chatwoot is an opensource tool. <a href="https://www.chatwoot.com" class="link" rel="noreferrer noopener nofollow" target="_blank">https://www.chatwoot.com</a></p>'
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('parses heading to strong', () => {
|
|
it('should format correctly', () => {
|
|
const message = '### opensource \n ## tool';
|
|
expect(new MessageFormatter(message).formattedMessage).toMatch(
|
|
`<h3>opensource</h3>
|
|
<h2>tool</h2>`
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('tweets', () => {
|
|
it('should return the same string if not tags or @mentions', () => {
|
|
const message = 'Chatwoot is an opensource tool';
|
|
expect(new MessageFormatter(message).formattedMessage).toMatch(message);
|
|
});
|
|
|
|
it('should add links to @mentions', () => {
|
|
const message =
|
|
'@chatwootapp is an opensource tool thanks @longnonexistenttwitterusername';
|
|
expect(
|
|
new MessageFormatter(message, true, false).formattedMessage
|
|
).toMatch(
|
|
'<p><a href="http://twitter.com/chatwootapp" class="link" rel="noreferrer noopener nofollow" target="_blank">@chatwootapp</a> is an opensource tool thanks @longnonexistenttwitterusername</p>'
|
|
);
|
|
});
|
|
|
|
it('should add links to #tags', () => {
|
|
const message = '#chatwootapp is an opensource tool';
|
|
expect(
|
|
new MessageFormatter(message, true, false).formattedMessage
|
|
).toMatch(
|
|
'<p><a href="https://twitter.com/hashtag/chatwootapp" class="link" rel="noreferrer noopener nofollow" target="_blank">#chatwootapp</a> is an opensource tool</p>'
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('private notes', () => {
|
|
it('should return the same string if not tags or @mentions', () => {
|
|
const message = 'Chatwoot is an opensource tool';
|
|
expect(new MessageFormatter(message).formattedMessage).toMatch(message);
|
|
});
|
|
|
|
it('should add links to @mentions', () => {
|
|
const message =
|
|
'@chatwootapp is an opensource tool thanks @longnonexistenttwitterusername';
|
|
expect(
|
|
new MessageFormatter(message, false, true).formattedMessage
|
|
).toMatch(message);
|
|
});
|
|
|
|
it('should add links to #tags', () => {
|
|
const message = '#chatwootapp is an opensource tool';
|
|
expect(
|
|
new MessageFormatter(message, false, true).formattedMessage
|
|
).toMatch(message);
|
|
});
|
|
});
|
|
|
|
describe('plain text content', () => {
|
|
it('returns the plain text without HTML', () => {
|
|
const message =
|
|
'<b>Chatwoot is an opensource tool. https://www.chatwoot.com</b>';
|
|
expect(new MessageFormatter(message).plainText).toMatch(
|
|
'Chatwoot is an opensource tool. https://www.chatwoot.com'
|
|
);
|
|
});
|
|
});
|
|
|
|
describe('#sanitize', () => {
|
|
it('sanitizes markup and removes all unnecessary elements', () => {
|
|
const message =
|
|
'[xssLink](javascript:alert(document.cookie))\n[normalLink](https://google.com)**I am a bold text paragraph**';
|
|
expect(new MessageFormatter(message).formattedMessage).toMatch(
|
|
`<p>[xssLink](javascript:alert(document.cookie))<br />
|
|
<a href="https://google.com" class="link" rel="noreferrer noopener nofollow" target="_blank">normalLink</a><strong>I am a bold text paragraph</strong></p>`
|
|
);
|
|
});
|
|
});
|
|
});
|