Plugin Shortcuts
Learn how to configure and use keyboard shortcuts in Plate plugins.
This guide covers the configuration and usage of keyboard shortcuts in Plate plugins, allowing you to create custom hotkeys for various editor actions.
Plugin Shortcuts
Plate provides a set of default shortcuts for common actions.
Text Formatting
-
BoldPlugin
toggleBold
:Mod+B
-
ItalicPlugin
toggleItalic
:Mod+I
-
UnderlinePlugin
toggleUnderline
:Mod+U
-
StrikethroughPlugin
toggleStrikethrough
:Mod+Shift+X
-
CodePlugin
toggleCode
:Mod+E
-
SubscriptPlugin
toggleSubscript
:Mod+,
-
SuperscriptPlugin
toggleSuperscript
:Mod+.
-
HighlightPlugin
toggleHighlight
:Mod+Shift+H
Block Formatting
-
ParagraphPlugin
toggleParagraph
:Mod+Alt+0
orMod+Shift+0
-
BlockquotePlugin
toggleBlockquote
:Mod+Shift+.
-
HeadingPlugin
toggleHeading1
:Mod+Alt+1
orMod+Shift+1
toggleHeading2
:Mod+Alt+2
orMod+Shift+2
toggleHeading3
:Mod+Alt+3
orMod+Shift+3
-
CodeBlockPlugin
toggleCodeBlock
:Mod+Alt+8
Lists
-
ListPlugin
toggleBulletedList
:Mod+Alt+5
toggleNumberedList
:Mod+Alt+6
-
TodoListPlugin
toggleTodoList
:Mod+Alt+4
orMod+Shift+4
Comments
- CommentsPlugin
toggleComment
:Mod+Shift+M
Notes
Mod
representsCmd
on macOS andCtrl
on Windows/Linux.- Shortcuts can be customized or extended as needed in your Plate configuration.
Adding Shortcuts to Plugins
You can add shortcuts to your plugins using the shortcuts
option. Each shortcut is defined with a unique key and an object containing the handler, keys, and other optional properties.
Here's a basic example:
const ParagraphPlugin = createPlatePlugin({
key: 'p',
shortcuts: {
toggleParagraph: {
handler: ({ editor }) => {
editor.toggleBlock({ type: 'p' });
},
keys: ['mod+opt+0', 'mod+shift+0'],
},
},
});
In this example, pressing Cmd+Option+0
or Cmd+Shift+0
(on Mac) or Ctrl+Alt+0
or Ctrl+Shift+0
(on Windows/Linux) will toggle the paragraph block.
Shortcut Properties
Each shortcut can have the following properties:
handler
: A function that is called when the shortcut is triggered.keys
: A string or array of strings representing the key combination(s).priority
: (Optional) A number indicating the priority of the shortcut.preventDefault
: (Optional) A boolean to prevent the default browser action.
Multiple Shortcuts
You can define multiple shortcuts for a single plugin:
const FormattingPlugin = createPlatePlugin({
key: 'formatting',
shortcuts: {
toggleBold: {
handler: ({ editor }) => {
editor.tf.toggleMark('bold');
},
keys: 'mod+b',
},
toggleItalic: {
handler: ({ editor }) => {
editor.tf.toggleMark('italic');
},
keys: 'mod+i',
},
},
});
Shortcut Priority
When multiple plugins define shortcuts with the same key combination, you can use the priority
property to determine which one takes precedence:
const HighPriorityPlugin = createPlatePlugin({
key: 'highPriority',
shortcuts: {
myShortcut: {
handler: () => console.info('High priority'),
keys: 'mod+k',
priority: 100,
},
},
});
const LowPriorityPlugin = createPlatePlugin({
key: 'lowPriority',
shortcuts: {
myShortcut: {
handler: () => console.info('Low priority'),
keys: 'mod+k',
priority: 50,
},
},
});
In this case, the HighPriorityPlugin
shortcut will be triggered when Cmd+K
(Mac) or Ctrl+K
(Windows/Linux) is pressed.
Disabling Shortcuts
You can disable a specific shortcut by setting its value to null
:
const MyPlugin = ParagraphPlugin.configure({
shortcuts: {
myShortcut: null,
},
});
Extending Shortcuts
You can extend or override shortcuts using the extend
method:
const ExtendedPlugin = BasePlugin.extend({
shortcuts: {
newShortcut: {
handler: () => console.info('New shortcut'),
keys: 'mod+shift+n',
},
},
});
Root Plugin Shortcuts
You can also define shortcuts at the root level when creating the editor:
const editor = createPlateEditor({
plugins: [/* your plugins */],
shortcuts: {
globalShortcut: {
handler: () => console.info('Global shortcut triggered'),
keys: 'mod+g',
},
},
});
Root-level shortcuts have the highest priority by default.
Best Practices
- Consider using the
preventDefault
option for shortcuts that might conflict with browser defaults. - Be mindful of existing shortcuts in your application to avoid conflicts.
- Use the
priority
property when you need fine-grained control over which shortcut is triggered.