Find Replace

Find and replace functionality in text.

Loading...
Files
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>
  );
}