From 09801df74f56b93b54d4bc51dacc1bae6bf523ac Mon Sep 17 00:00:00 2001 From: William Hilton Date: Wed, 28 Nov 2018 14:42:20 -0500 Subject: [PATCH] chore(code-editor): add more specific typings --- src/CodeEditor.tsx | 34 ++++++++++++++++++++++------------ 1 file changed, 22 insertions(+), 12 deletions(-) diff --git a/src/CodeEditor.tsx b/src/CodeEditor.tsx index 00769030..350533be 100644 --- a/src/CodeEditor.tsx +++ b/src/CodeEditor.tsx @@ -2,7 +2,7 @@ import noop = require('lodash/noop'); import 'prismjs/components/'; import * as React from 'react'; import { useCallback } from 'react'; -import Editor from 'react-simple-code-editor'; +import ReactSimpleCodeEditor from 'react-simple-code-editor'; import styled from 'styled-components'; import { themeGet } from './utils'; import { highlightCode } from './utils/highlightCode'; @@ -49,17 +49,27 @@ export const supportedLanguages = { ...optionalSupport, }; -const CodeEditorView = React.forwardRef((props: ICodeEditorProps & { className: string }, ref: any) => { - const { className, language, onChange = noop, value } = props; - - const highlightCodeCallback = useCallback(() => highlightCode(value, language), [value, language]); - - return ( -
- -
- ); -}); +export type ReactSimpleCodeEditorRef = ReactSimpleCodeEditor; + +const CodeEditorView = React.forwardRef( + (props, ref) => { + const { className, language, onChange = noop, value } = props; + + const highlightCodeCallback = useCallback(() => highlightCode(value, language), [value, language]); + + return ( +
+ +
+ ); + } +); // @ts-ignore export const CodeEditor = styled(CodeEditorView as any)`