Skip to content

Commit

Permalink
fix: setup editor mode post editor mount (#89)
Browse files Browse the repository at this point in the history
  • Loading branch information
rahulyadav-57 authored Aug 20, 2024
1 parent 096dc11 commit a869dc2
Showing 1 changed file with 23 additions and 14 deletions.
37 changes: 23 additions & 14 deletions src/components/workspace/Editor/Editor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ const Editor: FC<Props> = ({ file, projectId, className = '' }) => {

const editorRef = useRef<monaco.editor.IStandaloneCodeEditor | null>(null);
const monacoRef = useRef<Monaco | null>(null);
const vimStatusBarRef = useRef(null);
const vimStatusBarRef = useRef<HTMLElement | null>(null);
const vimModeRef = useRef<{
dispose: () => void;
} | null>(null);
Expand Down Expand Up @@ -162,20 +162,28 @@ const Editor: FC<Props> = ({ file, projectId, className = '' }) => {
updateOpenFile(file.id, { isDirty: true }, projectId);
};

const initializeEditorMode = async () => {
if (!editorRef.current || !vimStatusBarRef.current) return;

if (editorMode === 'vim') {
const { initVimMode } = await import('monaco-vim');
vimModeRef.current = initVimMode(
editorRef.current,
vimStatusBarRef.current as unknown as HTMLElement,
);
} else {
vimModeRef.current?.dispose();
}
};

useEffect(() => {
(async () => {
if (!editorRef.current) return;
if (editorMode === 'vim') {
const { initVimMode } = await import('monaco-vim');
vimModeRef.current = initVimMode(
editorRef.current,
vimStatusBarRef.current as unknown as HTMLElement,
);
} else {
vimModeRef.current?.dispose();
}
})().catch(() => {});
}, [editorRef, editorMode]);
if (editorRef.current) {
initializeEditorMode().catch(() => {});
}
return () => {
vimModeRef.current?.dispose();
};
}, [editorMode]);

useEffect(() => {
if (!isEditorInitialized) {
Expand Down Expand Up @@ -244,6 +252,7 @@ const Editor: FC<Props> = ({ file, projectId, className = '' }) => {

setIsEditorInitialized(true);
await editorOnMount(editor, monaco);
await initializeEditorMode();
editor.onDidChangeCursorPosition(() => {
const position = editor.getPosition();
if (position) {
Expand Down

0 comments on commit a869dc2

Please sign in to comment.