Font
Provide extended formatting options for document content.
'use client';
import React from 'react';
import { Plate } from '@udecode/plate-common/react';
import { editorPlugins } from '@/components/editor/plugins/editor-plugins';
import { useCreateEditor } from '@/components/editor/use-create-editor';
import { Editor, EditorContainer } from '@/components/plate-ui/editor';
import { DEMO_VALUES } from './values/demo-values';
export default function Demo({ id }: { id: string }) {
const editor = useCreateEditor({
plugins: [...editorPlugins],
value: DEMO_VALUES[id],
});
return (
<Plate editor={editor}>
<EditorContainer variant="demo">
<Editor />
</EditorContainer>
</Plate>
);
}
Features
- Font size, family, color, background color, and weight.
Plugins:
FontFamilyPlugin
: Change font family using inline elements with afont-family
in the style attribute.FontSizePlugin
: Control font size with inline elements having a CSS class or afont-size
in the style attribute.FontColorPlugin
: Control font color with inline elements having acolor
in the style attribute.FontBackgroundColorPlugin
: Control font background color with inline elements having abackground-color
in the style attribute.FontWeightPlugin
: Control font weight with inline elements having afont-weight
in the style attribute.
Installation
npm install @udecode/plate-font
Usage
import {
FontBackgroundColorPlugin,
FontColorPlugin,
FontSizePlugin,
} from '@udecode/plate-font/react';
const plugins = [
// ...otherPlugins,
FontColorPlugin,
FontBackgroundColorPlugin,
FontSizePlugin,
];
Plugins
FontBackgroundColorPlugin
FontColorPlugin
FontFamilyPlugin
FontSizePlugin
API
editor.api.fontSize.setMark
Set the font size mark.
Parameters
The font size value to set.
Utils
toUnitLess
Convert a font size value to a unitless value.
Parameters
The font size value to convert.
Returns
The font size value without units.
FontWeightPlugin
API Components
useColorDropdownMenu
A behavior hook for the color dropdown menu component.
State
A boolean indicating whether the dropdown menu is open.
A callback function to toggle the open state of the dropdown menu.
Returns
The props to be spread on the menu component.
The props to be spread on the button component.
useColorInput
A behavior hook for the color input component.
Returns
A ref object that should be assigned to the color input element.
The props to be spread on the child component that triggers the color picker.
useColorsCustom
A behavior hook for custom colors in a color picker.
State
The callback function to update the custom color.
The current value of the color input.
The callback function to update the value of the color input.
Returns
The props to be spread on the color input element.
The props to be spread on the menu item elements in the color picker.