From b437d68ee6fdbe905e4b3c6270e742cb89a9a0c3 Mon Sep 17 00:00:00 2001 From: Beka Westberg Date: Fri, 5 Apr 2024 16:34:00 +0000 Subject: [PATCH] feat: add toFlyoutData method for compatibility with backpack --- core/block_svg.ts | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) diff --git a/core/block_svg.ts b/core/block_svg.ts index c41bf38841a..8590cd71332 100644 --- a/core/block_svg.ts +++ b/core/block_svg.ts @@ -62,6 +62,7 @@ import {IconType} from './icons/icon_types.js'; import {BlockCopyData, BlockPaster} from './clipboard/block_paster.js'; import {BlockDragStrategy} from './dragging/block_drag_strategy.js'; import {IDeletable} from './blockly.js'; +import {FlyoutItemInfo} from './utils/toolbox.js'; /** * Class for a block's SVG representation. @@ -1622,4 +1623,30 @@ export class BlockSvg revertDrag(): void { this.dragStrategy.revertDrag(); } + + /** + * Returns a representation of this block that can be displayed in a flyout. + */ + toFlyoutData(): FlyoutItemInfo[] { + const json: FlyoutItemInfo = { + kind: 'BLOCK', + ...blocks.save(this), + }; + + const toRemove = new Set(['id', 'height', 'width', 'pinned', 'enabled']); + + // Traverse the JSON recursively. + const traverseJson = function (json: {[key: string]: unknown}) { + for (const key in json) { + if (toRemove.has(key)) { + delete json[key]; + } else if (typeof json[key] === 'object') { + traverseJson(json[key] as {[key: string]: unknown}); + } + } + }; + + traverseJson(json as unknown as {[key: string]: unknown}); + return [json]; + } }