37 lines
1.1 KiB
TypeScript
37 lines
1.1 KiB
TypeScript
/** Convert HTML to a plaintext representation, preserving whitespace. */
|
|
// NB: This function can still return unsafe HTML
|
|
export const unescapeHTML = (html: string = ''): string => {
|
|
const wrapper = document.createElement('div');
|
|
wrapper.innerHTML = html.replace(/<br\s*\/?>/g, '\n').replace(/<\/p><[^>]*>/g, '\n\n').replace(/<[^>]*>/g, '');
|
|
return wrapper.textContent || '';
|
|
};
|
|
|
|
/** Remove compatibility markup for features Soapbox supports. */
|
|
export const stripCompatibilityFeatures = (html: string): string => {
|
|
const node = document.createElement('div');
|
|
node.innerHTML = html;
|
|
|
|
const selectors = [
|
|
// Quote posting
|
|
'.quote-inline',
|
|
// Explicit mentions
|
|
'.recipients-inline',
|
|
];
|
|
|
|
// Remove all instances of all selectors
|
|
selectors.forEach(selector => {
|
|
node.querySelectorAll(selector).forEach(elem => {
|
|
elem.remove();
|
|
});
|
|
});
|
|
|
|
return node.innerHTML;
|
|
};
|
|
|
|
/** Convert HTML to plaintext. */
|
|
// https://stackoverflow.com/a/822486
|
|
export const stripHTML = (html: string) => {
|
|
const div = document.createElement('div');
|
|
div.innerHTML = html;
|
|
return div.textContent || div.innerText || '';
|
|
};
|