Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix issue of duplicated blocks upon pasting an image into the Slate E… #5818

Merged
merged 9 commits into from
Jun 19, 2024
1 change: 1 addition & 0 deletions packages/volto-slate/news/5818.bugfix
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
When pasting an image into a Slate block, now only an image block is created, instead of both a Slate block and an image block. @aryan7081
Original file line number Diff line number Diff line change
Expand Up @@ -46,10 +46,7 @@ export const onImageLoad = (editor, reader) => () => {
},
};

uploadContent(url, content, block).then((data) => {
const dlUrl = data.image.download;
insertImage(editor, dlUrl);
});
uploadContent(url, content, block);
};

export const withDeserializers = (editor) => {
Expand Down
15 changes: 13 additions & 2 deletions packages/volto-slate/src/utils/volto-blocks.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
import {
addBlock,
changeBlock,
insertBlock,
blockHasValue,
getBlocksFieldname,
getBlocksLayoutFieldname,
} from '@plone/volto/helpers';
Expand Down Expand Up @@ -53,6 +55,7 @@
let endPoint;

Transforms.insertNodes(editor, { text: '' }, { at: end });

Check failure on line 58 in packages/volto-slate/src/utils/volto-blocks.js

View workflow job for this annotation

GitHub Actions / ESlint

Delete `····⏎`

end = Editor.end(editor, [0]);

Expand Down Expand Up @@ -121,8 +124,16 @@
const blocksFieldname = getBlocksFieldname(properties);
const blocksLayoutFieldname = getBlocksLayoutFieldname(properties);

const [id, formData] = addBlock(properties, 'image', index + 1);
const newFormData = changeBlock(formData, id, { '@type': 'image', url });
const currBlockId = properties.blocks_layout.items[index];
const currBlockHasValue = blockHasValue(properties.blocks[currBlockId]);
let id, newFormData;

if (currBlockHasValue) {
[id, newFormData] = addBlock(properties, 'image', index + 1);
newFormData = changeBlock(newFormData, id, { '@type': 'image', url });
} else {
[id, newFormData] = insertBlock(properties, currBlockId, { '@type': 'image', url });

Check failure on line 135 in packages/volto-slate/src/utils/volto-blocks.js

View workflow job for this annotation

GitHub Actions / ESlint

Replace `·'@type':·'image',·url` with `⏎······'@type':·'image',⏎······url,⏎···`
}

ReactDOM.unstable_batchedUpdates(() => {
onChangeField(blocksFieldname, newFormData[blocksFieldname]);
Expand Down
Loading