diff --git a/.changeset/modern-socks-retire.md b/.changeset/modern-socks-retire.md new file mode 100644 index 000000000..f78074f6b --- /dev/null +++ b/.changeset/modern-socks-retire.md @@ -0,0 +1,6 @@ +--- +'@craftjs/utils': patch +'@craftjs/core': patch +--- + +Allow customising dnd indicator style/classname diff --git a/packages/core/src/events/RenderEditorIndicator.tsx b/packages/core/src/events/RenderEditorIndicator.tsx index 910a41ba0..e2ab13d45 100644 --- a/packages/core/src/events/RenderEditorIndicator.tsx +++ b/packages/core/src/events/RenderEditorIndicator.tsx @@ -35,6 +35,7 @@ export const RenderEditorIndicator = () => { } return React.createElement(RenderIndicator, { + className: indicatorOptions.className, style: { ...movePlaceholder( indicator.placement, @@ -47,6 +48,7 @@ export const RenderEditorIndicator = () => { ? indicatorOptions.error : indicatorOptions.success, transition: indicatorOptions.transition || '0.2s ease-in', + ...(indicatorOptions.style ?? {}), }, parentDom: indicator.placement.parent.dom, }); diff --git a/packages/core/src/interfaces/editor.ts b/packages/core/src/interfaces/editor.ts index 114069c4e..742b792a4 100644 --- a/packages/core/src/interfaces/editor.ts +++ b/packages/core/src/interfaces/editor.ts @@ -23,6 +23,8 @@ export type Options = { error: string; transition: string; thickness: number; + className: string; + style: React.CSSProperties; }>; handlers: (store: EditorStore) => CoreEventHandlers; normalizeNodes: ( diff --git a/packages/utils/src/RenderIndicator.tsx b/packages/utils/src/RenderIndicator.tsx index 3199ea266..609dbba00 100644 --- a/packages/utils/src/RenderIndicator.tsx +++ b/packages/utils/src/RenderIndicator.tsx @@ -3,12 +3,18 @@ import ReactDOM from 'react-dom'; type RenderIndicatorProps = { style: React.CSSProperties; + className?: string; parentDom?: HTMLElement; }; -export const RenderIndicator = ({ style, parentDom }: RenderIndicatorProps) => { +export const RenderIndicator = ({ + style, + className, + parentDom, +}: RenderIndicatorProps) => { const indicator = (
{ ``` In the above example, every user element will now be wrapped in a black `div`. -### Specifying the Drop Indicator colour +### Customising the drag-and-drop indicator -You could change the colours of the drag and drop indicators like so: +You could also change the colours/style of the drag-and-drop indicator like so: ```jsx {6-9} import {Editor} from "@craftjs/core"; @@ -65,7 +65,11 @@ const App = () => {