Examples
UI Components
Experimental Mobile Formatting Toolbar

Experimental Mobile Formatting Toolbar

This example shows how to use the experimental mobile formatting toolbar, which uses Visual Viewport API (opens in a new tab) to position the toolbar right above the virtual keyboard on mobile devices.

Controller is currently marked experimental due to the flickering issue with positioning (caused by delays of the Visual Viewport API)

Relevant Docs:

import "@blocknote/core/fonts/inter.css";
import {
  ExperimentalMobileFormattingToolbarController,
  useCreateBlockNote,
} from "@blocknote/react";
import { BlockNoteView } from "@blocknote/mantine";
import "@blocknote/mantine/style.css";
 
import "./style.css";
 
export default function App() {
  // Creates a new editor instance.
  const editor = useCreateBlockNote({
    initialContent: [
      {
        type: "paragraph",
        content: "Welcome to this demo!",
      },
      {
        type: "paragraph",
        content:
          "Check out the experimental mobile formatting toolbar by selecting some text (best experienced on a mobile device).",
      },
      {
        type: "paragraph",
      },
    ],
  });
 
  // Renders the editor instance using a React component.
  return (
    // Disables the default formatting toolbar and re-adds it without the
    // `FormattingToolbarController` component. You may have seen
    // `FormattingToolbarController` used in other examples, but we omit it here
    // as we want to control the position and visibility ourselves. BlockNote
    // also uses the `FormattingToolbarController` when displaying the
    // Formatting Toolbar by default.
    <BlockNoteView editor={editor} formattingToolbar={false}>
      <ExperimentalMobileFormattingToolbarController />
    </BlockNoteView>
  );
}