DocsAPI ReferenceComponents<DropZone>

<DropZone>

Place droppable regions (zones) inside other components to enable nested components.

import { DropZone } from "@measured/puck";
 
const config = {
  components: {
    Example: {
      render: () => {
        return (
          <div>
            <DropZone zone="my-content" />
          </div>
        );
      },
    },
  },
};

Props

ParamExampleTypeStatus
zonezone: "my-zone"StringRequired
allowallow: ["HeadingBlock"]Array-
classNameclassName: "MyClass"String-
collisionAxiscollisionAxis: "x"String-
disallowdisallow: ["HeadingBlock"]Array-
minEmptyHeightminEmptyHeight: 256Number-
refref: refRef-
stylestyle: {display: "flex"}CSSProperties-

Required props

zone

Set the zone identifier for the given DropZone.

Must be unique within this component, but two different components can both define DropZones with the same zone value.

const config = {
  components: {
    Example: {
      render: () => {
        return (
          <div>
            <DropZone zone="my-content" />
          </div>
        );
      },
    },
  },
};

Optional props

allow

Only allow specific components to be dragged into the DropZone:

const config = {
  components: {
    Example: {
      render: () => {
        return (
          <div>
            <DropZone zone="my-content" allow={["HeadingBlock"]} />
          </div>
        );
      },
    },
  },
};

className

Provide a className to the DropZone component. The default DropZone styles will still be applied.

const config = {
  components: {
    Example: {
      render: () => {
        return (
          <div>
            <DropZone zone="my-content" className="MyComponent" />
          </div>
        );
      },
    },
  },
};

collisionAxis

Configure which axis Puck will use for overlap collision detection.

Options:

  • x - detect collisions based their x-axis overlap
  • y - detect collisions based their y-axis overlap
  • dynamic - automatically choose an axis based on the direction of travel

The defaults are set based on the CSS layout of the parent:

  • grid: dynamic
  • flex (row): x
  • inline/inline-block: x
  • Everything else: y
const config = {
  components: {
    Example: {
      render: () => {
        return (
          <div>
            <DropZone zone="my-content" collisionAxis="dynamic" />
          </div>
        );
      },
    },
  },
};

disallow

Allow all but specific components to be dragged into the DropZone. Any items in allow will override disallow.

const config = {
  components: {
    Example: {
      render: () => {
        return (
          <div>
            <DropZone zone="my-content" disallow={["HeadingBlock"]} />
          </div>
        );
      },
    },
  },
};

minEmptyHeight

The minimum height of the DropZone when empty, in pixels. Defaults to 128.

const config = {
  components: {
    Example: {
      render: () => {
        return (
          <div>
            <DropZone zone="my-content" minEmptyHeight={256} />
          </div>
        );
      },
    },
  },
};

ref

A React ref, assigned to the root node of the DropZone.

const config = {
  components: {
    Example: {
      render: () => {
        const ref = useRef();
 
        return (
          <div>
            <DropZone zone="my-content" ref={ref} />
          </div>
        );
      },
    },
  },
};

style

Provide a style attribute to the DropZone. The default DropZone styles will still be applied.

const config = {
  components: {
    Example: {
      render: () => {
        return (
          <div>
            <DropZone zone="my-content" style={{ display: "flex" }} />
          </div>
        );
      },
    },
  },
};

Restrictions

You can’t drag between DropZones that don’t share a parent component.

React server components

By default, DropZones don’t work with React server components as they rely on context.

Instead, you can use the renderDropZone method passed to your component render function.