|
1 | 1 | import { |
2 | | - Spin, |
3 | | - Input, |
4 | 2 | Image, |
5 | | - Toast, |
| 3 | + Input, |
6 | 4 | Modal as SemiUIModal, |
| 5 | + Spin, |
| 6 | + Toast, |
7 | 7 | } from "@douyinfe/semi-ui"; |
8 | | -import { DB, MODAL, STATUS, State } from "../../../data/constants"; |
| 8 | +import { saveAs } from "file-saver"; |
| 9 | +import { Parser } from "node-sql-parser"; |
| 10 | +import { Parser as OracleParser } from "oracle-sql-parser"; |
9 | 11 | import { useState } from "react"; |
| 12 | +import { useTranslation } from "react-i18next"; |
| 13 | +import { DB, MODAL, STATUS, State } from "../../../data/constants"; |
| 14 | +import { databases } from "../../../data/databases"; |
10 | 15 | import { db } from "../../../data/db"; |
11 | 16 | import { |
12 | 17 | useAreas, |
| 18 | + useDiagram, |
13 | 19 | useEnums, |
14 | 20 | useNotes, |
15 | | - useDiagram, |
| 21 | + useSaveState, |
| 22 | + useTasks, |
16 | 23 | useTransform, |
17 | 24 | useTypes, |
18 | 25 | useUndoRedo, |
19 | | - useTasks, |
20 | | - useSaveState, |
21 | 26 | } from "../../../hooks"; |
22 | | -import { saveAs } from "file-saver"; |
23 | | -import { Parser } from "node-sql-parser"; |
24 | | -import { Parser as OracleParser } from "oracle-sql-parser"; |
| 27 | +import { isRtl } from "../../../i18n/utils/rtl"; |
| 28 | +import { importSQL } from "../../../utils/importSQL"; |
25 | 29 | import { |
26 | 30 | getModalTitle, |
27 | 31 | getModalWidth, |
28 | 32 | getOkText, |
29 | 33 | } from "../../../utils/modalData"; |
30 | | -import Rename from "./Rename"; |
31 | | -import Open from "./Open"; |
32 | | -import New from "./New"; |
| 34 | +import CodeEditor from "../../CodeEditor"; |
33 | 35 | import ImportDiagram from "./ImportDiagram"; |
34 | 36 | import ImportSource from "./ImportSource"; |
35 | | -import SetTableWidth from "./SetTableWidth"; |
36 | 37 | import Language from "./Language"; |
| 38 | +import New from "./New"; |
| 39 | +import Open from "./Open"; |
| 40 | +import Rename from "./Rename"; |
| 41 | +import SetTableWidth from "./SetTableWidth"; |
37 | 42 | import Share from "./Share"; |
38 | | -import CodeEditor from "../../CodeEditor"; |
39 | | -import { useTranslation } from "react-i18next"; |
40 | | -import { importSQL } from "../../../utils/importSQL"; |
41 | | -import { databases } from "../../../data/databases"; |
42 | | -import { isRtl } from "../../../i18n/utils/rtl"; |
43 | 43 |
|
44 | 44 | const extensionToLanguage = { |
45 | 45 | md: "markdown", |
@@ -70,6 +70,9 @@ export default function Modal({ |
70 | 70 | const { setUndoStack, setRedoStack } = useUndoRedo(); |
71 | 71 | const { setSaveState } = useSaveState(); |
72 | 72 | const [uncontrolledTitle, setUncontrolledTitle] = useState(title); |
| 73 | + const [uncontrolledLanguage, setUncontrolledLanguage] = useState( |
| 74 | + i18n.language, |
| 75 | + ); |
73 | 76 | const [importSource, setImportSource] = useState({ |
74 | 77 | src: "", |
75 | 78 | overwrite: false, |
@@ -254,8 +257,12 @@ export default function Modal({ |
254 | 257 | setModal(MODAL.NONE); |
255 | 258 | return; |
256 | 259 | case MODAL.NEW: |
257 | | - setModal(MODAL.NONE); |
258 | 260 | createNewDiagram(selectedTemplateId); |
| 261 | + setModal(MODAL.NONE); |
| 262 | + return; |
| 263 | + case MODAL.LANGUAGE: |
| 264 | + i18n.changeLanguage(uncontrolledLanguage); |
| 265 | + setModal(MODAL.NONE); |
259 | 266 | return; |
260 | 267 | default: |
261 | 268 | setModal(MODAL.NONE); |
@@ -347,7 +354,12 @@ export default function Modal({ |
347 | 354 | case MODAL.TABLE_WIDTH: |
348 | 355 | return <SetTableWidth />; |
349 | 356 | case MODAL.LANGUAGE: |
350 | | - return <Language />; |
| 357 | + return ( |
| 358 | + <Language |
| 359 | + language={uncontrolledLanguage} |
| 360 | + setLanguage={setUncontrolledLanguage} |
| 361 | + /> |
| 362 | + ); |
351 | 363 | case MODAL.SHARE: |
352 | 364 | return <Share title={title} setModal={setModal} />; |
353 | 365 | default: |
@@ -379,6 +391,7 @@ export default function Modal({ |
379 | 391 | }} |
380 | 392 | onCancel={() => { |
381 | 393 | if (modal === MODAL.RENAME) setUncontrolledTitle(title); |
| 394 | + if (modal === MODAL.LANGUAGE) setUncontrolledLanguage(i18n.language); |
382 | 395 | setModal(MODAL.NONE); |
383 | 396 | }} |
384 | 397 | centered |
|
0 commit comments