mirror of
https://github.com/muerwre/vault-frontend.git
synced 2025-04-25 04:46:40 +07:00
added markdown formatter
This commit is contained in:
parent
8f9c61e1f6
commit
0666237586
7 changed files with 111 additions and 126 deletions
71
src/utils/formatText.ts
Normal file
71
src/utils/formatText.ts
Normal file
|
@ -0,0 +1,71 @@
|
|||
import marked from 'marked';
|
||||
|
||||
/**
|
||||
* Cleans youtube urls
|
||||
*/
|
||||
export const formatTextSanitizeYoutube = (text: string): string =>
|
||||
text.replace(
|
||||
/(https?:\/\/(www\.)?(youtube\.com|youtu\.be)\/(watch)?(\?v=)?[\w\-\&\=]+)/gim,
|
||||
'\n$1\n'
|
||||
);
|
||||
|
||||
/**
|
||||
* Removes HTML tags
|
||||
*/
|
||||
export const formatTextSanitizeTags = (text: string): string =>
|
||||
text.replace(/</g, '<').replace(/>/g, '>');
|
||||
|
||||
/**
|
||||
* Returns clickable usernames
|
||||
*/
|
||||
export const formatTextClickableUsernames = (text: string): string =>
|
||||
text.replace(
|
||||
/~([\wа-яА-Я-]+)/giu,
|
||||
'<span class="username" onClick="window.postMessage({ type: \'username\', username: \'$1\'});">~$1</span>'
|
||||
);
|
||||
|
||||
/**
|
||||
* Makes gray comments
|
||||
*/
|
||||
export const formatTextComments = (text: string): string =>
|
||||
text
|
||||
.replace(/:\/\//gim, ':|--|')
|
||||
.replace(/(\/\/[^\n]+)/gim, '<span class="grey">$1</span>')
|
||||
.replace(/(\/\*[\s\S]*?\*\/)/gim, '<span class="grey">$1</span>')
|
||||
.replace(/:\|--\|/gim, '://');
|
||||
|
||||
/**
|
||||
* Highlights todos
|
||||
*/
|
||||
export const formatTextTodos = (text: string): string =>
|
||||
text
|
||||
.replace(/\/\/\s*(todo|туду):?\s*([^\n]+)/gim, '// <span class="todo">$1</span> $2')
|
||||
.replace(
|
||||
/\/\/\s*(done|сделано|сделал|готово|fixed|пофикшено|фиксед):?\s*([^\n]+)/gim,
|
||||
'// <span class="done">$1</span> $2'
|
||||
);
|
||||
|
||||
/**
|
||||
* Formats !!exclamation messages with green color
|
||||
*/
|
||||
export const formatExclamations = (text: string): string =>
|
||||
text.replace(/(\!\![\s\S]*?(\!\!|\n|$))/gim, '<span class="green">$1</span>');
|
||||
|
||||
/**
|
||||
* Formats links
|
||||
*/
|
||||
export const formatLinks = (text: string): string =>
|
||||
text.replace(
|
||||
/(\b(https?|ftp|file):\/\/([-A-Z0-9+&@#%?=~_|!:,.;]*)([-A-Z0-9+&@#%?\/=~_|!:,.;]*)[-A-Z0-9+&@#\/%=~_|])/gi,
|
||||
'<a href="$1" target="blank" rel="nofollow">$1</a>'
|
||||
);
|
||||
|
||||
/**
|
||||
* Replaces -- with dash
|
||||
*/
|
||||
export const formatDash = (text: string): string => text.replace(' -- ', ' — ');
|
||||
|
||||
/**
|
||||
* Formats with markdown
|
||||
*/
|
||||
export const formatMarkdown = (text: string): string => marked(text);
|
Loading…
Add table
Add a link
Reference in a new issue