aboutsummaryrefslogtreecommitdiffstats
path: root/packages/react-shared/src/components/markdown_code_block.tsx
diff options
context:
space:
mode:
authorFabio Berger <me@fabioberger.com>2018-03-14 22:18:16 +0800
committerGitHub <noreply@github.com>2018-03-14 22:18:16 +0800
commite16feb27f4ec1987259a87f360824a0158bd8b10 (patch)
treee94cb3bc89e215c4df38ab161379023ab8e0c4e9 /packages/react-shared/src/components/markdown_code_block.tsx
parent3f3e8be004818ddaa1921b3dff12bdd46052278b (diff)
parent83ae7ba08d55fa964bf7b7a985aea0fe1520c5c7 (diff)
downloaddexon-0x-contracts-e16feb27f4ec1987259a87f360824a0158bd8b10.tar
dexon-0x-contracts-e16feb27f4ec1987259a87f360824a0158bd8b10.tar.gz
dexon-0x-contracts-e16feb27f4ec1987259a87f360824a0158bd8b10.tar.bz2
dexon-0x-contracts-e16feb27f4ec1987259a87f360824a0158bd8b10.tar.lz
dexon-0x-contracts-e16feb27f4ec1987259a87f360824a0158bd8b10.tar.xz
dexon-0x-contracts-e16feb27f4ec1987259a87f360824a0158bd8b10.tar.zst
dexon-0x-contracts-e16feb27f4ec1987259a87f360824a0158bd8b10.zip
Merge pull request #450 from 0xProject/convertScriptsToTs
Convert Scripts to TS & Other Misc. Fixes
Diffstat (limited to 'packages/react-shared/src/components/markdown_code_block.tsx')
-rw-r--r--packages/react-shared/src/components/markdown_code_block.tsx25
1 files changed, 25 insertions, 0 deletions
diff --git a/packages/react-shared/src/components/markdown_code_block.tsx b/packages/react-shared/src/components/markdown_code_block.tsx
new file mode 100644
index 000000000..2070bb8e1
--- /dev/null
+++ b/packages/react-shared/src/components/markdown_code_block.tsx
@@ -0,0 +1,25 @@
+import * as _ from 'lodash';
+import * as React from 'react';
+import * as HighLight from 'react-highlight';
+
+export interface MarkdownCodeBlockProps {
+ value: string;
+ language: string;
+}
+
+export interface MarkdownCodeBlockState {}
+
+export class MarkdownCodeBlock extends React.Component<MarkdownCodeBlockProps, MarkdownCodeBlockState> {
+ // Re-rendering a codeblock causes any use selection to become de-selected. This is annoying when trying
+ // to copy-paste code examples. We therefore noop re-renders on this component if it's props haven't changed.
+ public shouldComponentUpdate(nextProps: MarkdownCodeBlockProps, nextState: MarkdownCodeBlockState) {
+ return nextProps.value !== this.props.value || nextProps.language !== this.props.language;
+ }
+ public render() {
+ return (
+ <span style={{ fontSize: 14 }}>
+ <HighLight className={this.props.language || 'javascript'}>{this.props.value}</HighLight>
+ </span>
+ );
+ }
+}