Skip to content

Commit 7eb7b70

Browse files
committedOct 7, 2021
website: Update example.
1 parent 7405871 commit 7eb7b70

File tree

2 files changed

+45
-27
lines changed

2 files changed

+45
-27
lines changed
 

‎package.json

+1
Original file line numberDiff line numberDiff line change
@@ -89,6 +89,7 @@
8989
"@types/testing-library__jest-dom": "5.14.1",
9090
"@uiw/react-github-corners": "1.5.3",
9191
"@uiw/react-markdown-preview": "3.3.5",
92+
"@uiw/react-loader": "4.9.7",
9293
"code-example": "3.3.1",
9394
"compile-less-cli": "1.8.9",
9495
"husky": "7.0.2",

‎website/App.tsx

+44-27
Original file line numberDiff line numberDiff line change
@@ -2,38 +2,54 @@ import React, { useEffect, useState } from 'react';
22
import MarkdownPreview from '@uiw/react-markdown-preview';
33
import GitHubCorners from '@uiw/react-github-corners';
44
import rehypeAttr from 'rehype-attr';
5-
// @ts-ignore
5+
import Loader from '@uiw/react-loader';
66
import exts from 'code-example/ext.json';
77
import TextareaCodeEditor from '../';
88
import MDStr from '../README.md';
99
import './App.css';
1010

11-
const App: React.FC = () => {
12-
const [value, setValue] = useState('');
13-
const [language, setLanguage] = useState('jsx');
14-
const [lang, setLang] = useState('jsx');
11+
const useFetch = (language: string) => {
12+
const [code, setCode] = useState('');
13+
const [loading, setLoading] = useState(false);
14+
const [lang, setLang] = useState(language);
15+
const [error, setError] = useState<any>(null);
16+
1517
useEffect(() => {
16-
if (language) {
17-
import(`code-example/txt/sample.${language}.txt`)
18-
.then((code) => {
19-
setValue(code.default || '');
20-
let str = language;
21-
if (/^(mysql|pgsql)$/.test(language)) {
22-
str = 'sql';
23-
}
24-
if (/^(objective-c)$/.test(language)) {
25-
str = 'objc';
26-
}
27-
if (/^(vue)$/.test(language)) {
28-
str = 'html';
29-
}
30-
setLang(str);
31-
})
32-
.catch((err) => {
33-
setValue('');
34-
});
35-
}
18+
setLoading(true);
19+
const fetchData = async () => {
20+
try {
21+
const codeStr = await import(`code-example/txt/sample.${language}.txt`);
22+
setCode(codeStr.default);
23+
24+
let str = language;
25+
if (/^(mysql|pgsql)$/.test(language)) {
26+
str = 'sql';
27+
}
28+
if (/^(objective-c)$/.test(language)) {
29+
str = 'objc';
30+
}
31+
if (/^(vue)$/.test(language)) {
32+
str = 'html';
33+
}
34+
setLang(str);
35+
setLoading(false);
36+
} catch (error) {
37+
console.log(error);
38+
setLoading(false);
39+
setError(error);
40+
setCode('');
41+
}
42+
};
43+
fetchData();
44+
// eslint-disable-next-line react-hooks/exhaustive-deps
3645
}, [language]);
46+
47+
return { lang, loading, code, setCode, error };
48+
};
49+
50+
const App: React.FC = () => {
51+
const [language, setLanguage] = useState('jsx');
52+
const { lang, loading, code, setCode } = useFetch(language);
3753
// @ts-ignore
3854
const version = VERSION;
3955
return (
@@ -46,7 +62,7 @@ const App: React.FC = () => {
4662
<div className="App-editor">
4763
<TextareaCodeEditor
4864
autoFocus
49-
value={value}
65+
value={code}
5066
language={lang}
5167
minHeight={80}
5268
placeholder={`Please enter ${(language || '').toLocaleUpperCase()} code.`}
@@ -55,7 +71,7 @@ const App: React.FC = () => {
5571
fontSize: 14,
5672
fontFamily: 'ui-monospace,SFMono-Regular,SF Mono,Consolas,Liberation Mono,Menlo,monospace',
5773
}}
58-
onChange={(evn) => setValue(evn.target.value)}
74+
onChange={(evn) => setCode(evn.target.value)}
5975
/>
6076
</div>
6177
<div className="App-tools" style={{ marginTop: 5 }}>
@@ -69,6 +85,7 @@ const App: React.FC = () => {
6985
);
7086
})}
7187
</select>
88+
<Loader loading={loading} />
7289
</div>
7390
<MarkdownPreview source={MDStr} className="info" rehypePlugins={[[rehypeAttr, { properties: 'attr' }]]} />
7491
</div>

0 commit comments

Comments
 (0)
Please sign in to comment.