diff --git a/src/blocks/scratch3_pen.js b/src/blocks/scratch3_pen.js index 407215120..37609952f 100644 --- a/src/blocks/scratch3_pen.js +++ b/src/blocks/scratch3_pen.js @@ -7,6 +7,13 @@ const MathUtil = require('../util/math-util'); const RenderedTarget = require('../sprites/rendered-target'); const log = require('../util/log'); +/** + * Icon svg to be displayed at the left edge of each extension block, encoded as a data URI. + * @type {string} + */ +// eslint-disable-next-line max-len +const iconURI = ''; + /** * Enum for pen color parameters. * @readonly @@ -235,6 +242,7 @@ class Scratch3PenBlocks { return { id: 'pen', name: 'Pen', + iconURI: iconURI, blocks: [ { opcode: 'clear', diff --git a/src/engine/runtime.js b/src/engine/runtime.js index c86516bf7..56fceadfc 100644 --- a/src/engine/runtime.js +++ b/src/engine/runtime.js @@ -421,6 +421,7 @@ class Runtime extends EventEmitter { const categoryInfo = { id: extensionInfo.id, name: extensionInfo.name, + iconURI: extensionInfo.iconURI, color1: '#FF6680', color2: '#FF4D6A', color3: '#FF3355', @@ -524,8 +525,21 @@ class Runtime extends EventEmitter { // but each `[ARG]` will need to be replaced with the number in this map instead of `args0.length`. const argsMap = {}; - blockJSON.message0 = blockInfo.text.replace(/\[(.+?)]/g, (match, placeholder) => { + blockJSON.message0 = ''; + // If an icon for the extension exists, prepend it to each block + if (categoryInfo.iconURI) { + blockJSON.message0 = '%1'; + const iconJSON = { + type: 'field_image', + src: categoryInfo.iconURI, + width: 40, + height: 40 + }; + blockJSON.args0.push(iconJSON); + } + + blockJSON.message0 += blockInfo.text.replace(/\[(.+?)]/g, (match, placeholder) => { // Sanitize the placeholder to ensure valid XML placeholder = placeholder.replace(/[<"&]/, '_');