aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authoreug-vs <eug-vs@keemail.me>2020-04-09 16:21:43 +0300
committereug-vs <eug-vs@keemail.me>2020-04-09 16:21:43 +0300
commit4734e2b50ba130cd697dcf58575e9a8477fc49cf (patch)
tree581c332b135d09964ddf28b072e77714e6ac2007 /src
parent3e42b2b555d8cdbee72151b535a47b1b253751d4 (diff)
downloadreact-benzin-4734e2b50ba130cd697dcf58575e9a8477fc49cf.tar.gz
feat: add live preview page
Diffstat (limited to 'src')
-rw-r--r--src/index.tsx79
1 files changed, 64 insertions, 15 deletions
diff --git a/src/index.tsx b/src/index.tsx
index be76722..e440746 100644
--- a/src/index.tsx
+++ b/src/index.tsx
@@ -38,6 +38,7 @@ const headerContents = {
'spacevim': null,
'material-ui': null,
'custom': null,
+ 'live preview': null,
};
const pageMap: Record<string, string> = {
@@ -64,8 +65,11 @@ const CustomPage: React.FC = () => {
</p>
<p>
<TextField
+ fullWidth
inputRef={inputEl}
- variant="outlined" color="secondary" label="Markdown url"
+ variant="outlined"
+ color="secondary"
+ label="Markdown url"
/>
</p>
<Button variant="contained" color="secondary" onClick={handleParseUrl} >
@@ -77,18 +81,53 @@ const CustomPage: React.FC = () => {
);
}
+interface LivePropTypes {
+ setLivePreviewData: (livePreviewData: string) => void;
+}
+
+const LivePreviewPage: React.FC<LivePropTypes> = ({ setLivePreviewData }) => {
+ const classes = useStyles();
+ const inputEl = useRef<HTMLInputElement>(null);
+
+ const handleRender = (): void => {
+ setLivePreviewData(inputEl.current?.value || '');
+ }
+
+ return (
+ <>
+ <ContentSection sectionName="Markdown live preview" level={2} >
+ <p>
+ Start typing and see your text rendered on the left window! We recommend starting with # Header.
+ </p>
+ <p>
+ <TextField
+ fullWidth
+ multiline
+ inputRef={inputEl}
+ variant="outlined"
+ color="primary"
+ label="Markdown"
+ onChange={handleRender}
+ />
+ </p>
+ </ContentSection>
+ </>
+ )
+}
+
const App: React.FC = () => {
const classes = useStyles();
const [page, setPage] = useState<string>('home');
+ const [livePreviewData, setLivePreviewData] = useState<string>('');
- const handleGoCustom = (): void => {
- setPage('custom');
+ const handleGoLivePreview = (): void => {
+ setPage('live preview');
}
const url = pageMap[page];
const fileName = url?.slice(url.lastIndexOf('/') + 1);
- const metadata = [
+ const info = [
`## Markdown\n [Markdown file](${url}) *(...${fileName})* that you can see on the left was parsed and rendered by **BENZIN**! :rocket:`,
'Switch between tabs on the header to explore other markdown templates. :recycle: ',
'Currently **only core features** of markdown function.',
@@ -118,23 +157,33 @@ const App: React.FC = () => {
(page === 'custom') ?
<CustomPage />
:
+ (page === 'live preview') ?
+ <Markdown data={livePreviewData || '# Start typing in the right window!'} />
+ :
<Markdown url={url} />
}
</div>
</Window>
<Window type="secondary" name="Feature preview">
<div className={classes.window}>
- <Markdown data={metadata} />
- <p className={classes.promoButton}>
- <Button
- variant="contained"
- color="primary"
- size="large"
- onClick={handleGoCustom}
- >
- Render custom document
- </Button>
- </p>
+ {
+ (page === 'live preview') ?
+ <LivePreviewPage setLivePreviewData={setLivePreviewData} />
+ :
+ <>
+ <Markdown data={info} />
+ <p className={classes.promoButton}>
+ <Button
+ variant="contained"
+ color="primary"
+ size="large"
+ onClick={handleGoLivePreview}
+ >
+ Try it yourself!
+ </Button>
+ </p>
+ </>
+ }
</div>
</Window>
</Benzin>