forked from Ivasoft/mattermost-mobile
210 lines
5.1 KiB
TypeScript
210 lines
5.1 KiB
TypeScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import {Platform, StyleSheet} from 'react-native';
|
|
|
|
import {changeOpacity, makeStyleSheetFromTheme} from '@utils/theme';
|
|
|
|
export function getCodeFont() {
|
|
return Platform.OS === 'ios' ? 'Menlo' : 'monospace';
|
|
}
|
|
|
|
export const getMarkdownTextStyles = makeStyleSheetFromTheme((theme: Theme) => {
|
|
const codeFont = getCodeFont();
|
|
|
|
return {
|
|
emph: {
|
|
fontStyle: 'italic',
|
|
},
|
|
strong: {
|
|
fontWeight: 'bold',
|
|
},
|
|
del: {
|
|
textDecorationLine: 'line-through',
|
|
},
|
|
link: {
|
|
color: theme.linkColor,
|
|
},
|
|
heading1: {
|
|
fontSize: 22,
|
|
fontWeight: '700',
|
|
lineHeight: 25,
|
|
},
|
|
heading1Text: {
|
|
paddingBottom: 8,
|
|
},
|
|
heading2: {
|
|
fontSize: 20,
|
|
fontWeight: '700',
|
|
lineHeight: 25,
|
|
},
|
|
heading2Text: {
|
|
paddingBottom: 8,
|
|
},
|
|
heading3: {
|
|
fontSize: 19,
|
|
fontWeight: '700',
|
|
lineHeight: 25,
|
|
},
|
|
heading3Text: {
|
|
paddingBottom: 8,
|
|
},
|
|
heading4: {
|
|
fontSize: 18,
|
|
fontWeight: '700',
|
|
lineHeight: 25,
|
|
},
|
|
heading4Text: {
|
|
paddingBottom: 8,
|
|
},
|
|
heading5: {
|
|
fontSize: 17,
|
|
fontWeight: '700',
|
|
lineHeight: 25,
|
|
},
|
|
heading5Text: {
|
|
paddingBottom: 8,
|
|
},
|
|
heading6: {
|
|
fontSize: 16,
|
|
fontWeight: '700',
|
|
lineHeight: 25,
|
|
},
|
|
heading6Text: {
|
|
paddingBottom: 8,
|
|
},
|
|
code: {
|
|
alignSelf: 'center',
|
|
backgroundColor: changeOpacity(theme.centerChannelColor, 0.07),
|
|
fontFamily: codeFont,
|
|
},
|
|
codeBlock: {
|
|
fontFamily: codeFont,
|
|
},
|
|
mention: {
|
|
color: theme.linkColor,
|
|
},
|
|
error: {
|
|
color: theme.errorTextColor,
|
|
},
|
|
table_header_row: {
|
|
fontWeight: '700',
|
|
},
|
|
mention_highlight: {
|
|
backgroundColor: theme.mentionHighlightBg,
|
|
color: theme.mentionHighlightLink,
|
|
},
|
|
};
|
|
});
|
|
|
|
export const getMarkdownBlockStyles = makeStyleSheetFromTheme((theme: Theme) => {
|
|
return {
|
|
adjacentParagraph: {
|
|
marginTop: 6,
|
|
},
|
|
horizontalRule: {
|
|
backgroundColor: theme.centerChannelColor,
|
|
height: StyleSheet.hairlineWidth,
|
|
marginVertical: 10,
|
|
},
|
|
quoteBlockIcon: {
|
|
color: changeOpacity(theme.centerChannelColor, 0.5),
|
|
},
|
|
};
|
|
});
|
|
|
|
const languages: Record<string, string> = {
|
|
actionscript: 'ActionScript',
|
|
applescript: 'AppleScript',
|
|
bash: 'Bash',
|
|
clojure: 'Clojure',
|
|
coffeescript: 'CoffeeScript',
|
|
cpp: 'C++',
|
|
cs: 'C#',
|
|
css: 'CSS',
|
|
d: 'D',
|
|
dart: 'Dart',
|
|
delphi: 'Delphi',
|
|
diff: 'Diff',
|
|
django: 'Django',
|
|
dockerfile: 'Dockerfile',
|
|
elixir: 'Elixir',
|
|
erlang: 'Erlang',
|
|
fortran: 'Fortran',
|
|
fsharp: 'F#',
|
|
gcode: 'G-code',
|
|
go: 'Go',
|
|
groovy: 'Groovy',
|
|
handlebars: 'Handlebars',
|
|
haskell: 'Haskell',
|
|
haxe: 'Haxe',
|
|
html: 'HTML',
|
|
java: 'Java',
|
|
javascript: 'JavaScript',
|
|
js: 'JavaScript',
|
|
json: 'JSON',
|
|
julia: 'Julia',
|
|
kotlin: 'Kotlin',
|
|
latex: 'LaTeX',
|
|
less: 'Less',
|
|
lisp: 'Lisp',
|
|
lua: 'Lua',
|
|
makefile: 'Makefile',
|
|
markdown: 'Markdown',
|
|
matlab: 'Matlab',
|
|
objectivec: 'Objective-C',
|
|
ocaml: 'OCaml',
|
|
perl: 'Perl',
|
|
php: 'PHP',
|
|
powershell: 'PowerShell',
|
|
puppet: 'Puppet',
|
|
python: 'Python',
|
|
r: 'R',
|
|
ruby: 'Ruby',
|
|
rust: 'Rust',
|
|
scala: 'Scala',
|
|
scheme: 'Scheme',
|
|
scss: 'SCSS',
|
|
smalltalk: 'Smalltalk',
|
|
sql: 'SQL',
|
|
swift: 'Swift',
|
|
tex: 'TeX',
|
|
vbnet: 'VB.NET',
|
|
vbscript: 'VBScript',
|
|
verilog: 'Verilog',
|
|
xml: 'XML',
|
|
yaml: 'YAML',
|
|
};
|
|
|
|
export function getDisplayNameForLanguage(language: string) {
|
|
return languages[language.toLowerCase()] || '';
|
|
}
|
|
|
|
export function escapeRegex(text: string) {
|
|
return text.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&');
|
|
}
|
|
|
|
export function switchKeyboardForCodeBlocks(value: string, cursorPosition: number) {
|
|
if (Platform.OS === 'ios' && parseInt(Platform.Version, 10) >= 12) {
|
|
const regexForCodeBlock = /^```$(.*?)^```$|^```$(.*)/gms;
|
|
|
|
const matches = [];
|
|
let nextMatch;
|
|
while ((nextMatch = regexForCodeBlock.exec(value)) !== null) {
|
|
matches.push({
|
|
startOfMatch: regexForCodeBlock.lastIndex - nextMatch[0].length,
|
|
endOfMatch: regexForCodeBlock.lastIndex + 1,
|
|
});
|
|
}
|
|
|
|
const cursorIsInsideCodeBlock = matches.some((match) => cursorPosition >= match.startOfMatch && cursorPosition <= match.endOfMatch);
|
|
|
|
// 'email-address' keyboardType prevents iOS emdash autocorrect
|
|
if (cursorIsInsideCodeBlock) {
|
|
return 'email-address';
|
|
}
|
|
}
|
|
|
|
return 'default';
|
|
}
|