diff options
Diffstat (limited to 'frontend/src/components/PasteInfo.js')
| -rw-r--r-- | frontend/src/components/PasteInfo.js | 40 |
1 files changed, 22 insertions, 18 deletions
diff --git a/frontend/src/components/PasteInfo.js b/frontend/src/components/PasteInfo.js index 6ab5b19..1ef69cc 100644 --- a/frontend/src/components/PasteInfo.js +++ b/frontend/src/components/PasteInfo.js @@ -1,8 +1,9 @@ import React from 'react'; import styled from 'styled-components' -import { useHistory } from 'react-router-dom'; import { Theme } from './Inputs' import {Button} from "./Common/Button"; +import {useRouter} from "next/router"; +import {ErrMsg} from "./Err"; const Bold = styled.span` font-weight: 700 @@ -27,21 +28,21 @@ const Flex = styled.div` flex-direction: row; ` -const PasteInfo = (props) => { - const history = useHistory(); +const PasteInfo = ({hash, lang, theme, expiry, toggleRenderCallback, isRenderMode, onChange, err}) => { + const router = useRouter() const redirRaw = () => { - const redirUrl = `/raw/${props.hash}` - history.push(redirUrl); + const redirUrl = `/raw/${hash}` + router.push(redirUrl); } const renderable = () => { - const buttonTxt = props.isRenderMode ? 'text' : 'render' - if (props.lang === 'latex' || props.lang === 'markdown') { + const buttonTxt = isRenderMode ? 'text' : 'render' + if (lang === 'latex' || lang === 'markdown') { return ( <ShiftedButton secondary type="button" - onClick={props.toggleRenderCallback}> + onClick={toggleRenderCallback}> {buttonTxt} </ShiftedButton> ); @@ -59,20 +60,23 @@ const PasteInfo = (props) => { </ShiftedButton> {renderable()} <Theme - value={props.theme} - onChange={props.onChange} + value={theme} + onChange={onChange} id="themeInput" /> </Flex> <StyledDiv> - <SpacedText> - <Bold>language: </Bold>{props.lang} - </SpacedText> - <SpacedText> - <Bold>expires: </Bold>{props.expiry} - </SpacedText> + {err ? + <ErrMsg active> {err} </ErrMsg> : + <> + <SpacedText> + <Bold>language: </Bold>{lang} + </SpacedText> + <SpacedText> + <Bold>expires: </Bold>{expiry} + </SpacedText> + </> + } </StyledDiv> - <br /> - {props.err} </div> ); } |