Find Replace
Find and replace functionality in text.
components/find-replace-demo.tsx
'use client';
import React from 'react';
import { Plate, useEditorPlugin } from '@udecode/plate/react';
import { FindReplacePlugin } from '@udecode/plate-find-replace';
import { editorPlugins } from '@/components/editor/plugins/editor-plugins';
import { useCreateEditor } from '@/components/editor/use-create-editor';
import { findReplaceValue } from '@/components/values/find-replace-value';
import { Editor, EditorContainer } from '@/components/plate-ui/editor';
import { FixedToolbar } from '@/components/plate-ui/fixed-toolbar';
import { Input } from '@/components/plate-ui/input';
import { SearchHighlightLeaf } from '@/components/plate-ui/search-highlight-leaf';
export function FindToolbar() {
const { editor, setOption, useOption } = useEditorPlugin(FindReplacePlugin);
const search = useOption('search');
return (
<FixedToolbar className="border-none py-3">
<Input
data-testid="ToolbarSearchHighlightInput"
className="mx-2"
value={search}
onChange={(e) => {
setOption('search', e.target.value);
editor.api.redecorate();
}}
placeholder="Search the text..."
type="search"
/>
</FixedToolbar>
);
}
export default function FindReplaceDemo() {
const editor = useCreateEditor(
{
components: {
[FindReplacePlugin.key]: SearchHighlightLeaf,
},
plugins: [
...editorPlugins,
FindReplacePlugin.configure({ options: { search: 'text' } }),
],
value: findReplaceValue,
},
[]
);
return (
<Plate editor={editor}>
<FindToolbar />
<EditorContainer variant="demo" className="border-t">
<Editor />
</EditorContainer>
</Plate>
);
}