5.6.3 • Published 3 months ago

ra-input-rich-text v5.6.3

Weekly downloads
5,731
License
MIT
Repository
github
Last release
3 months ago

ra-input-rich-text

A rich text editor for React Admin, based on TipTap.

Installation

npm install ra-input-rich-text
# or
yarn add ra-input-rich-text

Usage

Use it as you would any react-admin input:

import { Edit, SimpleForm, TextInput } from 'react-admin';
import { RichTextInput } from 'ra-input-rich-text';

export const PostEdit = () => (
  <Edit>
    <SimpleForm>
      <TextInput source="title" />
      <RichTextInput source="body" />
    </SimpleForm>
  </Edit>
);

Customizing the Toolbar

The <RichTextInput> component has a toolbar prop that accepts a ReactNode.

You can leverage this to change the buttons size:

import { Edit, SimpleForm, TextInput } from 'react-admin';
import { RichTextInput, RichTextInputToolbar } from 'ra-input-rich-text';

export const PostEdit = () => (
  <Edit>
    <SimpleForm>
      <TextInput source="title" />
      <RichTextInput source="body" toolbar={<RichTextInputToolbar size="large" />} />
    </SimpleForm>
  </Edit>
);

Or to remove some prebuilt components like the <AlignmentButtons>:

import {
  RichTextInput,
  RichTextInputToolbar,
  LevelSelect,
  FormatButtons,
  ListButtons,
  LinkButtons,
  QuoteButtons,
  ClearButtons,
} from 'ra-input-rich-text';

const MyRichTextInput = ({ size, ...props }) => (
  <RichTextInput
    toolbar={
      <RichTextInputToolbar>
        <LevelSelect size={size} />
        <FormatButtons size={size} />
        <ListButtons size={size} />
        <LinkButtons size={size} />
        <QuoteButtons size={size} />
        <ClearButtons size={size} />
      </RichTextInputToolbar>
    }
    label="Body"
    source="body"
    {...props}
  />
);

Customizing the editor

You might want to add more TipTap extensions. The <RichTextInput> component accepts an editorOptions prop, which is the object passed to the TipTap Editor.

If you just want to add extensions, don't forget to include those needed by default for our implementation. Here's an example to add the HorizontalRule node:

import {
  DefaultEditorOptions,
  RichTextInput,
  RichTextInputToolbar,
  LevelSelect,
  FormatButtons,
  AlignmentButtons,
  ListButtons,
  LinkButtons,
  QuoteButtons,
  ClearButtons,
} from 'ra-input-rich-text';
import HorizontalRule from '@tiptap/extension-horizontal-rule';
import Remove from '@mui/icons-material/Remove';

const MyRichTextInput = ({ size, ...props }) => (
  <RichTextInput
    editorOptions={MyEditorOptions}
    toolbar={
      <RichTextInputToolbar>
        <LevelSelect size={size} />
        <FormatButtons size={size} />
        <AlignmentButtons {size} />
        <ListButtons size={size} />
        <LinkButtons size={size} />
        <QuoteButtons size={size} />
        <ClearButtons size={size} />
        <ToggleButton
          aria-label="Add an horizontal rule"
          title="Add an horizontal rule"
          onClick={() => editor.chain().focus().setHorizontalRule().run()}
          selected={editor && editor.isActive('horizontalRule')}
        >
          <Remove fontSize="inherit" />
      </ToggleButton>
      </RichTextInputToolbar>
    }
    label="Body"
    source="body"
    {...props}
  />
);

export const MyEditorOptions = {
  ...DefaultEditorOptions,
  extensions: [
    ...DefaultEditorOptions.extensions,
        HorizontalRule,
  ],
};

License

This data provider is licensed under the MIT License, and sponsored by Marmelab.

5.3.4

7 months ago

5.3.3

7 months ago

5.4.4

5 months ago

5.4.3

6 months ago

5.4.2

6 months ago

5.4.1

7 months ago

5.4.0

7 months ago

5.5.4

4 months ago

5.5.3

4 months ago

5.5.2

5 months ago

5.5.1

5 months ago

5.5.0

5 months ago

5.6.3

3 months ago

5.6.2

4 months ago

5.6.1

4 months ago

5.6.0

4 months ago

5.3.2

8 months ago

5.3.1

8 months ago

5.1.5

9 months ago

5.1.4

9 months ago

5.1.3

10 months ago

5.2.3

8 months ago

5.2.2

9 months ago

5.2.1

9 months ago

5.2.0

9 months ago

5.3.0

8 months ago

5.0.0-beta.2

1 year ago

5.0.0-rc.0

12 months ago

5.0.0-beta.3

1 year ago

5.0.0-rc.1

12 months ago

5.0.0-beta.1

1 year ago

5.0.5

11 months ago

5.0.4

11 months ago

5.0.3

12 months ago

5.0.2

12 months ago

5.0.1

12 months ago

5.0.0

12 months ago

5.1.2

10 months ago

5.1.1

11 months ago

5.1.0

11 months ago

4.16.20

11 months ago

4.16.19

12 months ago

4.16.18

1 year ago

5.0.0-beta.0

1 year ago

4.16.17

1 year ago

4.16.16

1 year ago

4.16.15

1 year ago

4.16.14

1 year ago

5.0.0-alpha.1

1 year ago

5.0.0-alpha.0

1 year ago

4.16.13

1 year ago

4.16.12

1 year ago

4.16.11

1 year ago

4.16.10

1 year ago

4.16.9

1 year ago

4.16.8

1 year ago

4.16.7

1 year ago

4.16.6

1 year ago

4.16.5

1 year ago

4.16.4

1 year ago

4.16.3

2 years ago

4.14.5

2 years ago

4.14.6

2 years ago

4.16.0

2 years ago

4.16.1

2 years ago

4.16.2

2 years ago

4.15.4

2 years ago

4.15.5

2 years ago

4.15.0

2 years ago

4.15.1

2 years ago

4.15.2

2 years ago

4.15.3

2 years ago

4.14.1

2 years ago

4.14.2

2 years ago

4.14.3

2 years ago

4.14.4

2 years ago

4.10.5

2 years ago

4.10.6

2 years ago

4.14.0

2 years ago

4.10.4

2 years ago

4.13.2

2 years ago

4.13.3

2 years ago

4.13.4

2 years ago

4.13.0

2 years ago

4.13.1

2 years ago

4.12.3

2 years ago

4.12.4

2 years ago

4.12.0

2 years ago

4.12.1

2 years ago

4.12.2

2 years ago

4.11.4

2 years ago

4.11.0

2 years ago

4.11.1

2 years ago

4.11.2

2 years ago

4.11.3

2 years ago

4.9.4

2 years ago

4.9.3

2 years ago

4.9.2

2 years ago

4.10.1

2 years ago

4.10.2

2 years ago

4.10.3

2 years ago

4.9.0

2 years ago

4.9.1

2 years ago

4.8.4

2 years ago

4.8.1

2 years ago

4.8.0

2 years ago

4.8.3

2 years ago

4.8.2

2 years ago

4.7.6

2 years ago

4.7.5

2 years ago

4.7.2

2 years ago

4.7.1

2 years ago

4.7.4

2 years ago

4.7.3

2 years ago

3.19.12

2 years ago

4.5.4

3 years ago

4.5.3

3 years ago

4.4.1

3 years ago

4.4.3

3 years ago

4.4.2

3 years ago

4.4.4

3 years ago

4.7.0

2 years ago

4.6.1

3 years ago

4.6.0

3 years ago

4.6.3

2 years ago

4.6.2

2 years ago

4.5.0

3 years ago

4.5.2

3 years ago

4.5.1

3 years ago

4.4.0

3 years ago

4.3.2

3 years ago

4.3.1

3 years ago

4.3.4

3 years ago

4.3.3

3 years ago

4.3.0

3 years ago

4.2.8

3 years ago

4.0.5

3 years ago

4.0.4

3 years ago

4.2.3

3 years ago

4.2.2

3 years ago

4.2.5

3 years ago

4.2.4

3 years ago

4.2.1

3 years ago

4.2.0

3 years ago

4.2.7

3 years ago

4.2.6

3 years ago

4.1.4

3 years ago

4.1.3

3 years ago

4.1.6

3 years ago

4.1.5

3 years ago

4.1.0

3 years ago

4.1.2

3 years ago

4.1.1

3 years ago

4.0.3

3 years ago

4.0.2

3 years ago

4.0.0-RC.0

3 years ago

4.0.0-RC.1

3 years ago

4.0.0-rc.1

3 years ago

4.0.0-rc.0

3 years ago

4.0.1

3 years ago

4.0.0

3 years ago

4.0.0-beta.3

3 years ago

4.0.0-beta.2

3 years ago

3.19.11

3 years ago

3.19.4

4 years ago

3.19.3

4 years ago

3.19.6

3 years ago

3.19.5

3 years ago

3.19.8

3 years ago

3.19.7

3 years ago

3.19.9

3 years ago

4.0.0-alpha.1

3 years ago

4.0.0-alpha.2

3 years ago

4.0.0-beta.1.0

3 years ago

3.19.10

3 years ago

3.19.2

4 years ago

3.19.1

4 years ago

3.19.0

4 years ago

4.0.0-alpha.0

4 years ago

3.18.3

4 years ago

3.18.2

4 years ago

3.18.1

4 years ago

3.18.0

4 years ago

3.17.0

4 years ago

3.16.5

4 years ago

3.14.0

4 years ago

3.12.0

4 years ago

3.10.1

5 years ago

3.9.1

5 years ago

3.9.0

5 years ago

3.9.0-beta.3

5 years ago

3.9.0-beta.2

5 years ago

3.9.0-beta.1

5 years ago

3.8.3

5 years ago

3.7.2

5 years ago

3.7.1

5 years ago

3.5.5

5 years ago

3.3.1

5 years ago

3.3.0

5 years ago

3.2.2

5 years ago

3.2.1

5 years ago

3.2.0

5 years ago

3.1.0

5 years ago

3.0.1

6 years ago

3.0.0

6 years ago

3.0.0-beta.6

6 years ago

3.0.0-beta.4

6 years ago

3.0.0-beta.2

6 years ago

3.0.0-beta.1

6 years ago

3.0.0-beta.0

6 years ago

3.0.0-alpha.4

6 years ago

3.0.0-alpha.3

6 years ago

3.0.0-alpha.1

6 years ago

3.0.0-alpha.0

6 years ago

2.9.3

6 years ago

2.9.2

6 years ago

2.8.6

6 years ago

2.8.3

6 years ago

2.7.3

6 years ago

2.7.1

6 years ago

2.6.4

6 years ago

2.6.2

6 years ago

2.6.0

6 years ago

2.4.2

7 years ago

2.4.0

7 years ago

2.4.0-0

7 years ago

2.3.2

7 years ago

2.3.0

7 years ago

2.2.1

7 years ago

2.2.0

7 years ago

2.1.3

7 years ago

2.1.0

7 years ago

2.0.2

7 years ago

2.0.0

7 years ago

2.0.0-RC4

7 years ago

2.0.0-RC3

7 years ago

2.0.0-RC2

7 years ago

2.0.0-RC1

7 years ago

2.0.0-beta4

7 years ago

2.0.0-beta3

7 years ago

2.0.0-beta2

7 years ago

2.0.0-beta1

7 years ago

2.0.0-alpha3

8 years ago

2.0.0-alpha2

8 years ago

2.0.0-alpha1

8 years ago