fix(v2): remove auto wrap for code blocks (#2048)

This commit is contained in:
Alexey Pyltsyn 2019-11-25 21:24:52 +03:00 committed by Yangshun Tay
parent 91ef5c67cf
commit 10cd99b3e4
5 changed files with 107 additions and 88 deletions

View file

@ -63,16 +63,26 @@ export default ({children, className: languageClassName, metastring}) => {
}; };
return ( return (
<div className={styles.codeBlockWrapper}>
<button
ref={button}
type="button"
aria-label="Copy code to clipboard"
className={styles.copyButton}
onClick={handleCopyCode}>
{showCopied ? 'Copied' : 'Copy'}
</button>
<Highlight <Highlight
{...defaultProps} {...defaultProps}
theme={prism.theme || defaultTheme} theme={prism.theme || defaultTheme}
code={children.trim()} code={children.trim()}
language={language}> language={language}>
{({className, style, tokens, getLineProps, getTokenProps}) => ( {({className, style, tokens, getLineProps, getTokenProps}) => (
<div className={styles.codeBlockWrapper}> <pre className={classnames(className, styles.codeBlock)}>
<pre <code
ref={target} ref={target}
className={classnames(className, styles.codeBlock)} className={classnames(className, styles.codeBlockLines)}
style={style}> style={style}>
{tokens.map((line, i) => { {tokens.map((line, i) => {
const lineProps = getLineProps({line, key: i}); const lineProps = getLineProps({line, key: i});
@ -89,17 +99,10 @@ export default ({children, className: languageClassName, metastring}) => {
</div> </div>
); );
})} })}
</code>
</pre> </pre>
<button
ref={button}
type="button"
aria-label="Copy code to clipboard"
className={styles.copyButton}
onClick={handleCopyCode}>
{showCopied ? 'Copied' : 'Copy'}
</button>
</div>
)} )}
</Highlight> </Highlight>
</div>
); );
}; };

View file

@ -1,11 +1,3 @@
.codeBlock {
border-radius: 0;
margin-bottom: 0;
overflow: hidden;
overflow-wrap: break-word;
white-space: pre-wrap;
}
.codeBlockWrapper { .codeBlockWrapper {
position: relative; position: relative;
} }
@ -32,3 +24,18 @@
transition: opacity 200ms ease-in-out, visibility 200ms ease-in-out, transition: opacity 200ms ease-in-out, visibility 200ms ease-in-out,
bottom 200ms ease-in-out; bottom 200ms ease-in-out;
} }
.codeBlock {
overflow: auto;
display: block;
padding: 0;
font-size: inherit;
}
.codeBlockLines {
border-radius: 0;
margin-bottom: 0;
float: left;
min-width: 100%;
padding: var(--ifm-pre-padding);
}

View file

@ -94,7 +94,7 @@ function DocItem(props) {
<div className="padding-vert--lg"> <div className="padding-vert--lg">
<div className="container"> <div className="container">
<div className="row"> <div className="row">
<div className="col"> <div className="col col--9">
<div className={styles.docItemContainer}> <div className={styles.docItemContainer}>
<article> <article>
{version && ( {version && (

View file

@ -81,16 +81,26 @@ export default ({
}; };
return ( return (
<div className={styles.codeBlockWrapper}>
<button
ref={button}
type="button"
aria-label="Copy code to clipboard"
className={styles.copyButton}
onClick={handleCopyCode}>
{showCopied ? 'Copied' : 'Copy'}
</button>
<Highlight <Highlight
{...defaultProps} {...defaultProps}
theme={prism.theme || defaultTheme} theme={prism.theme || defaultTheme}
code={children.trim()} code={children.trim()}
language={language}> language={language}>
{({className, style, tokens, getLineProps, getTokenProps}) => ( {({className, style, tokens, getLineProps, getTokenProps}) => (
<div className={styles.codeBlockWrapper}> <pre className={classnames(className, styles.codeBlock)}>
<pre <code
ref={target} ref={target}
className={classnames(className, styles.codeBlock)} className={classnames(className, styles.codeBlockLines)}
style={style}> style={style}>
{tokens.map((line, i) => { {tokens.map((line, i) => {
const lineProps = getLineProps({line, key: i}); const lineProps = getLineProps({line, key: i});
@ -107,17 +117,10 @@ export default ({
</div> </div>
); );
})} })}
</code>
</pre> </pre>
<button
ref={button}
type="button"
aria-label="Copy code to clipboard"
className={styles.copyButton}
onClick={handleCopyCode}>
{showCopied ? 'Copied' : 'Copy'}
</button>
</div>
)} )}
</Highlight> </Highlight>
</div>
); );
}; };

View file

@ -1,12 +1,3 @@
.codeBlock {
border-radius: 0;
font-size: inherit;
margin-bottom: 0;
overflow: hidden;
overflow-wrap: break-word;
white-space: pre-wrap;
}
.codeBlockWrapper { .codeBlockWrapper {
position: relative; position: relative;
} }
@ -33,3 +24,18 @@
transition: opacity 200ms ease-in-out, visibility 200ms ease-in-out, transition: opacity 200ms ease-in-out, visibility 200ms ease-in-out,
bottom 200ms ease-in-out; bottom 200ms ease-in-out;
} }
.codeBlock {
overflow: auto;
display: block;
padding: 0;
font-size: inherit;
}
.codeBlockLines {
border-radius: 0;
margin-bottom: 0;
float: left;
min-width: 100%;
padding: var(--ifm-pre-padding);
}