mirror of
https://github.com/supabase/supabase.git
synced 2026-06-22 15:24:24 +08:00
101 lines
2.4 KiB
TypeScript
101 lines
2.4 KiB
TypeScript
import { FC, useEffect, useRef } from 'react'
|
|
import Editor, { EditorProps } from '@monaco-editor/react'
|
|
|
|
import { timeout } from 'lib/helpers'
|
|
import Connecting from '../Loading'
|
|
import { alignEditor } from './CodeEditor.utils'
|
|
import { merge } from 'lodash'
|
|
|
|
interface Props {
|
|
id: string
|
|
language: 'pgsql' | 'json' | 'html'
|
|
defaultValue?: string
|
|
isReadOnly?: boolean
|
|
onInputChange: (value?: string) => void
|
|
onInputRun?: (value: string) => void
|
|
hideLineNumbers?: boolean
|
|
className?: string
|
|
loading?: boolean
|
|
options?: EditorProps['options']
|
|
value?: string
|
|
}
|
|
|
|
const CodeEditor: FC<Props> = ({
|
|
id,
|
|
language,
|
|
defaultValue,
|
|
isReadOnly = false,
|
|
hideLineNumbers = false,
|
|
onInputChange = () => {},
|
|
onInputRun = () => {},
|
|
className,
|
|
loading,
|
|
options,
|
|
value,
|
|
}) => {
|
|
const editorRef = useRef()
|
|
|
|
useEffect(() => {
|
|
if (editorRef.current) {
|
|
// alignEditor(editorRef.current)
|
|
}
|
|
}, [id])
|
|
|
|
const onMount = async (editor: any, monaco: any) => {
|
|
alignEditor(editor)
|
|
editor.addAction({
|
|
id: 'supabase',
|
|
label: 'Run Query',
|
|
keybindings: [monaco.KeyMod.CtrlCmd + monaco.KeyCode.Enter],
|
|
contextMenuGroupId: 'operation',
|
|
contextMenuOrder: 0,
|
|
run: async () => {
|
|
const selectedValue = (editorRef?.current as any)
|
|
.getModel()
|
|
.getValueInRange((editorRef?.current as any)?.getSelection())
|
|
onInputRun(selectedValue || (editorRef?.current as any)?.getValue())
|
|
},
|
|
})
|
|
|
|
await timeout(500)
|
|
editor?.focus()
|
|
editorRef.current = editor
|
|
}
|
|
|
|
const optionsMerged = merge(
|
|
{
|
|
tabSize: 2,
|
|
fontSize: 13,
|
|
readOnly: isReadOnly,
|
|
minimap: { enabled: false },
|
|
wordWrap: 'on',
|
|
fixedOverflowWidgets: true,
|
|
contextmenu: true,
|
|
lineNumbers: hideLineNumbers ? 'off' : undefined,
|
|
glyphMargin: hideLineNumbers ? false : undefined,
|
|
lineNumbersMinChars: hideLineNumbers ? 0 : undefined,
|
|
folding: hideLineNumbers ? false : undefined,
|
|
},
|
|
options
|
|
)
|
|
|
|
merge({ cpp: '12' }, { java: '23' }, { python: '35' })
|
|
|
|
return (
|
|
<Editor
|
|
value={value ?? undefined}
|
|
path={id}
|
|
theme="supabase"
|
|
className={`monaco-editor ${className}`}
|
|
defaultLanguage={language}
|
|
defaultValue={defaultValue ?? undefined}
|
|
loading={loading || <Connecting />}
|
|
options={optionsMerged}
|
|
onMount={onMount}
|
|
onChange={onInputChange}
|
|
/>
|
|
)
|
|
}
|
|
|
|
export default CodeEditor
|