Skip to content

Commit

Permalink
refactor: refactor index page and extract common logic
Browse files Browse the repository at this point in the history
  • Loading branch information
alswl committed May 13, 2024
1 parent 2c7fdfc commit 2765809
Show file tree
Hide file tree
Showing 7 changed files with 63 additions and 56 deletions.
14 changes: 9 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,18 @@

![build-status](https://github.com/alswl/dbml-editor/actions/workflows/ci.yaml/badge.svg)

Online editor for [DBML](https://dbml.dbdiagram.io/home/) files.
Free online editor [DBML](https://dbml.dbdiagram.io/home/) editor.

## Online Editor

[dbml-editor](https://dbml-editor.alswl.com/)

## Features

- Syntax highlighting
- DBML syntax highlighting
- Live preview
- Import from SQL
- Export to SQL

## Alternatives

Expand All @@ -22,6 +24,8 @@ Online editor for [DBML](https://dbml.dbdiagram.io/home/) files.

## Roadmap

- Full support for DBML feature
- Export to SQL
- Import from SQL
- Better syntax highlighting
- Editor inline error hint
- hidden foreign key
- better style based on note
- ER positions save and restore
2 changes: 1 addition & 1 deletion src/components/viewer/viewer.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import parseDatabaseToER from '@/parser/parser';
import parseDatabaseToER from '@/services/er';
import { DagreLayout } from '@antv/layout';
import { Graph, Model } from '@antv/x6';
import { Snapline } from '@antv/x6-plugin-snapline';
Expand Down
2 changes: 1 addition & 1 deletion src/global.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import registerSyntax from '@/editor/syntax';
import registerER from '@/nodes/er';
import registerSyntax from '@/services/editor/syntax';

registerER();
registerSyntax();
75 changes: 26 additions & 49 deletions src/pages/Home/index.tsx
Original file line number Diff line number Diff line change
@@ -1,26 +1,19 @@
import { CompilerDiagnostic, exporter, importer, Parser } from '@dbml/core';
import { exporter, importer, Parser } from '@dbml/core';
import { Col, FloatButton, message, Modal, Row, Select, Space } from 'antd';
import { debounce } from 'lodash-es';
import { useEffect, useState } from 'react';
import MonacoEditor from 'react-monaco-editor';

import { InitCode } from '@/components/editor';
import Viewer from '@/components/viewer/viewer';
import ErrorFmt, { ExportFormat, ImportFormat } from '@/services/dbml';
import { ExportOutlined, ImportOutlined } from '@ant-design/icons';
import { PageContainer } from '@ant-design/pro-components';
import { CompilerError } from '@dbml/core/types/parse/error';
import TextArea from 'antd/es/input/TextArea';
import './index.less';

type ImportFormat =
| 'dbml'
| 'mysql'
| 'postgres'
| 'json'
| 'mssql'
| 'postgresLegacy';

type ExportFormat = 'dbml' | 'mysql' | 'postgres' | 'json' | 'mssql' | 'oracle';
const defaultBuildDelay = 2000;

export default () => {
const [messageApi, contextHolder] = message.useMessage();
Expand All @@ -39,54 +32,26 @@ export default () => {
const [exportText, setExportText] = useState('');
const [regen, setRegen] = useState(0);

// editorDidMount
// editor init
const editorDidMount = () => {
setDatabase(initialDatabase);
};

// code change
useEffect(() => {
try {
const newDB = parser.parse(code, 'dbmlv2');
setDatabase(newDB);
} catch (e) {
if (e as CompilerError) {
const diags = (e as CompilerError).diags
.map((d: CompilerDiagnostic) => {
return `${d.location.start.line}:${d.location.start.column} ${d.message}`;
})
.join('\n');

messageApi.error(diags);
// TODO hl to editor
} else if (e instanceof Error) {
messageApi.error(`${e.message}`);
} else {
throw e;
}
}
}, [code]);

// editor change
const editorOnChange = (newValue: any) => {
setCode(newValue);
};
const debouncedOnChange = debounce(editorOnChange, 500);
const debouncedOnChange = debounce(editorOnChange, defaultBuildDelay);

// handle import
const handleImport = () => {
try {
const s = importer.import(importText, importFormat);
setCode(s);
setIsImportModalOpen(false);
} catch (e) {
if (e as CompilerError) {
const diags = (e as CompilerError).diags
.map((d: CompilerDiagnostic) => {
return `${d.location.start.line}:${d.location.start.column} ${d.message}`;
})
.join('\n');

messageApi.error(diags);
messageApi.error(ErrorFmt(e as CompilerError));
} else if (e instanceof Error) {
messageApi.error(`${e.message}`);
return;
Expand All @@ -96,6 +61,24 @@ export default () => {
}
};

// code change regen database
useEffect(() => {
try {
const newDB = parser.parse(code, 'dbmlv2');
setDatabase(newDB);
} catch (e) {
if (e as CompilerError) {
messageApi.error(ErrorFmt(e as CompilerError));
// TODO hl to editor
} else if (e instanceof Error) {
messageApi.error(`${e.message}`);
} else {
throw e;
}
}
}, [code]);

// export regen
useEffect(() => {
if (!isExportModalOpen) return;

Expand All @@ -104,13 +87,7 @@ export default () => {
setExportText(s);
} catch (e) {
if (e as CompilerError) {
const diags = (e as CompilerError).diags
.map((d: CompilerDiagnostic) => {
return `${d.location.start.line}:${d.location.start.column} ${d.message}`;
})
.join('\n');

messageApi.error(diags);
messageApi.error(ErrorFmt(e as CompilerError));
} else if (e instanceof Error) {
messageApi.error(`${e.message}`);
} else {
Expand Down
22 changes: 22 additions & 0 deletions src/services/dbml/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
import { CompilerDiagnostic } from '@dbml/core';
import { CompilerError } from '@dbml/core/types/parse/error';

type ImportFormat =
| 'dbml'
| 'mysql'
| 'postgres'
| 'json'
| 'mssql'
| 'postgresLegacy';
type ExportFormat = 'dbml' | 'mysql' | 'postgres' | 'json' | 'mssql' | 'oracle';

export default function ErrorFmt(e: CompilerError): string {
const diags = e.diags
.map((d: CompilerDiagnostic) => {
return `${d.location.start.line}:${d.location.start.column} ${d.message}`;
})
.join('\n');
return diags;
}

export type { ExportFormat, ImportFormat };
4 changes: 4 additions & 0 deletions src/editor/syntax.ts → src/services/editor/syntax.ts
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,7 @@ function registerSyntax() {
{ include: '@whitespace' },

// delimiters and operators
// eslint-disable-next-line no-useless-escape
[/[\[\]{}().,;]/, '@brackets'],
[
/@symbols/,
Expand All @@ -150,6 +151,7 @@ function registerSyntax() {
],

// numbers
// eslint-disable-next-line no-useless-escape
[/\d*\.\d+([eE][\-+]?\d+)?/, 'number.float'],
[/0[xX][0-9a-fA-F]+/, 'number.hex'],
[/\d+/, 'number'],
Expand All @@ -165,8 +167,10 @@ function registerSyntax() {
],

comment: [
// eslint-disable-next-line no-useless-escape
[/[^\/*]+/, 'comment'],
[/\*\//, 'comment', '@pop'],
// eslint-disable-next-line no-useless-escape
[/[\/*]/, 'comment'],
],

Expand Down
File renamed without changes.

0 comments on commit 2765809

Please sign in to comment.