parse tables

This commit is contained in:
1ilit 2023-09-19 15:50:39 +03:00
parent 38da28ac99
commit 348363acbb
4 changed files with 87 additions and 13 deletions

24
package-lock.json generated
View File

@ -8,6 +8,7 @@
"name": "frontend", "name": "frontend",
"version": "0.1.0", "version": "0.1.0",
"dependencies": { "dependencies": {
"@dbml/core": "^2.5.4",
"@douyinfe/semi-ui": "^2.36.0", "@douyinfe/semi-ui": "^2.36.0",
"@monaco-editor/react": "^4.5.1", "@monaco-editor/react": "^4.5.1",
"@testing-library/jest-dom": "^5.16.5", "@testing-library/jest-dom": "^5.16.5",
@ -2392,6 +2393,16 @@
"postcss-selector-parser": "^6.0.10" "postcss-selector-parser": "^6.0.10"
} }
}, },
"node_modules/@dbml/core": {
"version": "2.5.4",
"resolved": "https://registry.npmjs.org/@dbml/core/-/core-2.5.4.tgz",
"integrity": "sha512-bfLb59z6pExD64eFUZTiRQfVW853v+vsfQd1bOKAZm4fHozGYVyQnM5WI4AahkAy+Jwm9NKr/b0wmrT/Hyft1w==",
"dependencies": {
"lodash": "^4.17.15",
"parsimmon": "^1.13.0",
"pluralize": "^8.0.0"
}
},
"node_modules/@douyinfe/semi-animation": { "node_modules/@douyinfe/semi-animation": {
"version": "2.37.0", "version": "2.37.0",
"resolved": "https://registry.npmjs.org/@douyinfe/semi-animation/-/semi-animation-2.37.0.tgz", "resolved": "https://registry.npmjs.org/@douyinfe/semi-animation/-/semi-animation-2.37.0.tgz",
@ -13210,6 +13221,11 @@
"node": ">= 0.8" "node": ">= 0.8"
} }
}, },
"node_modules/parsimmon": {
"version": "1.18.1",
"resolved": "https://registry.npmjs.org/parsimmon/-/parsimmon-1.18.1.tgz",
"integrity": "sha512-u7p959wLfGAhJpSDJVYXoyMCXWYwHia78HhRBWqk7AIbxdmlrfdp5wX0l3xv/iTSH5HvhN9K7o26hwwpgS5Nmw=="
},
"node_modules/pascal-case": { "node_modules/pascal-case": {
"version": "3.1.2", "version": "3.1.2",
"resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.2.tgz", "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.2.tgz",
@ -13424,6 +13440,14 @@
"node": ">=4" "node": ">=4"
} }
}, },
"node_modules/pluralize": {
"version": "8.0.0",
"resolved": "https://registry.npmjs.org/pluralize/-/pluralize-8.0.0.tgz",
"integrity": "sha512-Nc3IT5yHzflTfbjgqWcCPpo7DaKy4FnpB0l/zCAW0Tc7jxAiuqSxHasntB3D7887LSrA93kDJ9IXovxJYxyLCA==",
"engines": {
"node": ">=4"
}
},
"node_modules/postcss": { "node_modules/postcss": {
"version": "8.4.24", "version": "8.4.24",
"resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.24.tgz", "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.24.tgz",

View File

@ -35,6 +35,7 @@ import {
exitFullscreen, exitFullscreen,
ddbDiagramIsValid, ddbDiagramIsValid,
dataURItoBlob, dataURItoBlob,
jsonToSQL,
} from "../utils"; } from "../utils";
import { import {
AreaContext, AreaContext,
@ -53,6 +54,7 @@ import { useHotkeys } from "react-hotkeys-hook";
import { Validator } from "jsonschema"; import { Validator } from "jsonschema";
import { areaSchema, noteSchema, tableSchema } from "../schemas"; import { areaSchema, noteSchema, tableSchema } from "../schemas";
import { Editor } from "@monaco-editor/react"; import { Editor } from "@monaco-editor/react";
// import { Parser } from "node-sql-parser";
export default function ControlPanel(props) { export default function ControlPanel(props) {
const MODAL = { const MODAL = {
@ -69,7 +71,7 @@ export default function ControlPanel(props) {
}; };
const [visible, setVisible] = useState(MODAL.NONE); const [visible, setVisible] = useState(MODAL.NONE);
const [exportData, setExportData] = useState({ const [exportData, setExportData] = useState({
data: "", data: null,
filename: `diagram_${new Date().toISOString()}`, filename: `diagram_${new Date().toISOString()}`,
extension: "", extension: "",
}); });
@ -726,7 +728,29 @@ export default function ControlPanel(props) {
}, },
"Export source": { "Export source": {
children: [ children: [
{ MySQL: () => {} }, {
MySQL: () => {
setVisible(MODAL.CODE);
const src = jsonToSQL({
tables: tables,
references: relationships,
});
// try{
// const parser = new Parser();
// const ast = parser.astify(src);
// console.log(ast);
// const sql = parser.sqlify(ast);
// console.log(sql);
// } catch(e){
// console.log(e)
// }
setExportData((prev) => ({
...prev,
data: src,
extension: "sql",
}));
},
},
{ PostgreSQL: () => {} }, { PostgreSQL: () => {} },
{ DBML: () => {} }, { DBML: () => {} },
], ],
@ -863,7 +887,10 @@ export default function ControlPanel(props) {
"Tweet us": { "Tweet us": {
function: () => {}, function: () => {},
}, },
"Found a bug": { "Report a bug": {
function: () => {},
},
"Suggest a feature": {
function: () => {}, function: () => {},
}, },
}, },
@ -1193,7 +1220,7 @@ export default function ControlPanel(props) {
<Editor <Editor
height="360px" height="360px"
value={exportData.data} value={exportData.data}
language="json" language={exportData.extension}
options={{ readOnly: true }} options={{ readOnly: true }}
/> />
)} )}

View File

@ -80,7 +80,7 @@ export default function Editor(props) {
fields: [ fields: [
{ {
name: "id", name: "id",
type: "UUID", type: "INT",
default: "", default: "",
check: "", check: "",
primary: true, primary: true,

View File

@ -1,7 +1,7 @@
import { Validator } from "jsonschema"; import { Validator } from "jsonschema";
import { ddbSchema, jsonSchema } from "../schemas"; import { ddbSchema, jsonSchema } from "../schemas";
const enterFullscreen = () => { function enterFullscreen() {
const element = document.documentElement; const element = document.documentElement;
if (element.requestFullscreen) { if (element.requestFullscreen) {
element.requestFullscreen(); element.requestFullscreen();
@ -12,9 +12,9 @@ const enterFullscreen = () => {
} else if (element.msRequestFullscreen) { } else if (element.msRequestFullscreen) {
element.msRequestFullscreen(); element.msRequestFullscreen();
} }
}; }
const exitFullscreen = () => { function exitFullscreen() {
if (document.exitFullscreen) { if (document.exitFullscreen) {
document.exitFullscreen(); document.exitFullscreen();
} else if (document.mozCancelFullScreen) { } else if (document.mozCancelFullScreen) {
@ -24,15 +24,15 @@ const exitFullscreen = () => {
} else if (document.msExitFullscreen) { } else if (document.msExitFullscreen) {
document.msExitFullscreen(); document.msExitFullscreen();
} }
}; }
const jsonDiagramIsValid = (obj) => { function jsonDiagramIsValid(obj) {
return new Validator().validate(obj, jsonSchema).valid; return new Validator().validate(obj, jsonSchema).valid;
}; }
const ddbDiagramIsValid = (obj) => { function ddbDiagramIsValid(obj) {
return new Validator().validate(obj, ddbSchema).valid; return new Validator().validate(obj, ddbSchema).valid;
}; }
function dataURItoBlob(dataUrl) { function dataURItoBlob(dataUrl) {
const byteString = atob(dataUrl.split(",")[1]); const byteString = atob(dataUrl.split(",")[1]);
@ -47,10 +47,33 @@ function dataURItoBlob(dataUrl) {
return new Blob([intArray], { type: mimeString }); return new Blob([intArray], { type: mimeString });
} }
function jsonToSQL(obj) {
return obj.tables
.map(
(table) =>
`${
table.comment === "" ? "" : `/* ${table.comment} */\n`
}CREATE TABLE \`${table.name}\` (\n${table.fields
.map(
(field) =>
`${field.comment === "" ? "" : `\t-- ${field.comment}\n`}\t\`${
field.name
}\` ${field.type} ${field.notNull ? "NOT NULL" : ""} ${
field.increment ? "AUTO_INCREMENT" : ""
} ${field.unique ? "UNIQUE" : ""},`
)
.join("\n")}\n\tPRIMARY KEY(${table.fields.map((f) =>
f.primary ? `${f.name}` : ""
)})\n);`
)
.join("\n");
}
export { export {
enterFullscreen, enterFullscreen,
exitFullscreen, exitFullscreen,
jsonDiagramIsValid, jsonDiagramIsValid,
ddbDiagramIsValid, ddbDiagramIsValid,
dataURItoBlob, dataURItoBlob,
jsonToSQL,
}; };