Merge pull request #754 from ericrosenbaum/feature/pen-block-icon

Extension block icons (including pen icon)
This commit is contained in:
Eric Rosenbaum 2017-11-06 10:02:23 -05:00 committed by GitHub
commit 0540640684
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 23 additions and 1 deletions

View file

@ -7,6 +7,13 @@ const MathUtil = require('../util/math-util');
const RenderedTarget = require('../sprites/rendered-target'); const RenderedTarget = require('../sprites/rendered-target');
const log = require('../util/log'); 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. * Enum for pen color parameters.
* @readonly * @readonly
@ -235,6 +242,7 @@ class Scratch3PenBlocks {
return { return {
id: 'pen', id: 'pen',
name: 'Pen', name: 'Pen',
iconURI: iconURI,
blocks: [ blocks: [
{ {
opcode: 'clear', opcode: 'clear',

View file

@ -421,6 +421,7 @@ class Runtime extends EventEmitter {
const categoryInfo = { const categoryInfo = {
id: extensionInfo.id, id: extensionInfo.id,
name: extensionInfo.name, name: extensionInfo.name,
iconURI: extensionInfo.iconURI,
color1: '#FF6680', color1: '#FF6680',
color2: '#FF4D6A', color2: '#FF4D6A',
color3: '#FF3355', 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`. // but each `[ARG]` will need to be replaced with the number in this map instead of `args0.length`.
const argsMap = {}; 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 // Sanitize the placeholder to ensure valid XML
placeholder = placeholder.replace(/[<"&]/, '_'); placeholder = placeholder.replace(/[<"&]/, '_');