Skip to content

Commit

Permalink
feat: add content editable ref
Browse files Browse the repository at this point in the history
  • Loading branch information
dks333 authored and petyosi committed Nov 12, 2024
1 parent 483b196 commit 083080a
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 6 deletions.
20 changes: 14 additions & 6 deletions src/MDXEditor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@ import {
setMarkdown$,
topAreaChildren$,
useTranslation,
viewMode$
viewMode$,
contentEditableRef$
} from './plugins/core'

import { ContentEditable } from '@lexical/react/LexicalContentEditable.js'
Expand Down Expand Up @@ -45,6 +46,11 @@ const LexicalProvider: React.FC<{

const RichTextEditor: React.FC = () => {
const t = useTranslation()
const setContentEditableRef = usePublisher(contentEditableRef$)
const onRef = (_contentEditableRef: HTMLDivElement) => {
setContentEditableRef({ current: _contentEditableRef })
}

const [contentEditableClassName, spellCheck, composerChildren, topAreaChildren, editorWrappers, placeholder] = useCellValues(
contentEditableClassName$,
spellCheck$,
Expand All @@ -62,11 +68,13 @@ const RichTextEditor: React.FC = () => {
<div className={classNames(styles.rootContentEditableWrapper, 'mdxeditor-root-contenteditable')}>
<RichTextPlugin
contentEditable={
<ContentEditable
className={classNames(styles.contentEditable, contentEditableClassName)}
ariaLabel={t('contentArea.editableMarkdown', 'editable markdown')}
spellCheck={spellCheck}
/>
<div ref={onRef}>
<ContentEditable
className={classNames(styles.contentEditable, contentEditableClassName)}
ariaLabel={t('contentArea.editableMarkdown', 'editable markdown')}
spellCheck={spellCheck}
/>
</div>
}
placeholder={
<div className={classNames(styles.contentEditable, styles.placeholder, contentEditableClassName)}>
Expand Down
6 changes: 6 additions & 0 deletions src/plugins/core/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -293,6 +293,12 @@ export const codeBlockEditorDescriptors$ = Cell<CodeBlockEditorDescriptor[]>([])
*/
export const editorRootElementRef$ = Cell<React.RefObject<HTMLDivElement> | null>(null)

/**
* A reference to the content editable element.
* @group Core
*/
export const contentEditableRef$ = Cell<React.RefObject<HTMLDivElement> | null>(null)

/**
* Registers a lexical node to be used in the editor.
* @group Core
Expand Down

0 comments on commit 083080a

Please sign in to comment.