From 825035f503e1a3cbee3b4da68c45fdb906ed8aa0 Mon Sep 17 00:00:00 2001 From: Eric Rosenbaum Date: Thu, 16 Aug 2018 14:24:19 -0400 Subject: [PATCH] Fix importing WeDo 2.0 blocks from SB2 (#1487) * Fix wedo2 import from sb2 * Hide wedo play note block --- src/extensions/scratch3_wedo2/index.js | 65 +++++++++++++------------- src/serialization/sb2_specmap.js | 52 ++++++++++----------- 2 files changed, 59 insertions(+), 58 deletions(-) diff --git a/src/extensions/scratch3_wedo2/index.js b/src/extensions/scratch3_wedo2/index.js index 896ce29a9..8ff0578bb 100644 --- a/src/extensions/scratch3_wedo2/index.js +++ b/src/extensions/scratch3_wedo2/index.js @@ -746,7 +746,7 @@ class Scratch3WeDo2Blocks { arguments: { MOTOR_ID: { type: ArgumentType.STRING, - menu: 'motorID', + menu: 'MOTOR_ID', defaultValue: MotorID.DEFAULT }, DURATION: { @@ -766,7 +766,7 @@ class Scratch3WeDo2Blocks { arguments: { MOTOR_ID: { type: ArgumentType.STRING, - menu: 'motorID', + menu: 'MOTOR_ID', defaultValue: MotorID.DEFAULT } } @@ -782,7 +782,7 @@ class Scratch3WeDo2Blocks { arguments: { MOTOR_ID: { type: ArgumentType.STRING, - menu: 'motorID', + menu: 'MOTOR_ID', defaultValue: MotorID.DEFAULT } } @@ -798,7 +798,7 @@ class Scratch3WeDo2Blocks { arguments: { MOTOR_ID: { type: ArgumentType.STRING, - menu: 'motorID', + menu: 'MOTOR_ID', defaultValue: MotorID.DEFAULT }, POWER: { @@ -811,19 +811,19 @@ class Scratch3WeDo2Blocks { opcode: 'setMotorDirection', text: formatMessage({ id: 'wedo2.setMotorDirection', - default: 'set [MOTOR_ID] direction to [DIRECTION]', + default: 'set [MOTOR_ID] direction to [MOTOR_DIRECTION]', description: 'set the motor\'s turn direction' }), blockType: BlockType.COMMAND, arguments: { MOTOR_ID: { type: ArgumentType.STRING, - menu: 'motorID', + menu: 'MOTOR_ID', defaultValue: MotorID.DEFAULT }, - DIRECTION: { + MOTOR_DIRECTION: { type: ArgumentType.STRING, - menu: 'motorDirection', + menu: 'MOTOR_DIRECTION', defaultValue: MotorDirection.FORWARD } } @@ -860,7 +860,8 @@ class Scratch3WeDo2Blocks { type: ArgumentType.NUMBER, defaultValue: 0.5 } - } + }, + hideFromPalette: true }, { opcode: 'whenDistance', @@ -873,7 +874,7 @@ class Scratch3WeDo2Blocks { arguments: { OP: { type: ArgumentType.STRING, - menu: 'lessMore', + menu: 'OP', defaultValue: '<' }, REFERENCE: { @@ -886,15 +887,15 @@ class Scratch3WeDo2Blocks { opcode: 'whenTilted', text: formatMessage({ id: 'wedo2.whenTilted', - default: 'when tilted [DIRECTION]', + default: 'when tilted [TILT_DIRECTION_ANY]', description: 'check when tilted in a certain direction' }), func: 'isTilted', blockType: BlockType.HAT, arguments: { - DIRECTION: { + TILT_DIRECTION_ANY: { type: ArgumentType.STRING, - menu: 'tiltDirectionAny', + menu: 'TILT_DIRECTION_ANY', defaultValue: TiltDirection.ANY } } @@ -912,14 +913,14 @@ class Scratch3WeDo2Blocks { opcode: 'isTilted', text: formatMessage({ id: 'wedo2.isTilted', - default: 'tilted [DIRECTION]?', + default: 'tilted [TILT_DIRECTION_ANY]?', description: 'whether the tilt sensor is tilted' }), blockType: BlockType.BOOLEAN, arguments: { - DIRECTION: { + TILT_DIRECTION_ANY: { type: ArgumentType.STRING, - menu: 'tiltDirectionAny', + menu: 'TILT_DIRECTION_ANY', defaultValue: TiltDirection.ANY } } @@ -928,26 +929,26 @@ class Scratch3WeDo2Blocks { opcode: 'getTiltAngle', text: formatMessage({ id: 'wedo2.getTiltAngle', - default: 'tilt angle [DIRECTION]', + default: 'tilt angle [TILT_DIRECTION]', description: 'the angle returned by the tilt sensor' }), blockType: BlockType.REPORTER, arguments: { - DIRECTION: { + TILT_DIRECTION: { type: ArgumentType.STRING, - menu: 'tiltDirection', + menu: 'TILT_DIRECTION', defaultValue: TiltDirection.UP } } } ], menus: { - motorID: [MotorID.DEFAULT, MotorID.A, MotorID.B, MotorID.ALL], - motorDirection: [MotorDirection.FORWARD, MotorDirection.BACKWARD, MotorDirection.REVERSE], - tiltDirection: [TiltDirection.UP, TiltDirection.DOWN, TiltDirection.LEFT, TiltDirection.RIGHT], - tiltDirectionAny: + MOTOR_ID: [MotorID.DEFAULT, MotorID.A, MotorID.B, MotorID.ALL], + MOTOR_DIRECTION: [MotorDirection.FORWARD, MotorDirection.BACKWARD, MotorDirection.REVERSE], + TILT_DIRECTION: [TiltDirection.UP, TiltDirection.DOWN, TiltDirection.LEFT, TiltDirection.RIGHT], + TILT_DIRECTION_ANY: [TiltDirection.UP, TiltDirection.DOWN, TiltDirection.LEFT, TiltDirection.RIGHT, TiltDirection.ANY], - lessMore: ['<', '>'] + OP: ['<', '>'] } }; } @@ -1024,13 +1025,13 @@ class Scratch3WeDo2Blocks { * If the direction is 'reverse' the motor(s) will be reversed individually. * @param {object} args - the block's arguments. * @property {MotorID} MOTOR_ID - the motor(s) to be affected. - * @property {MotorDirection} DIRECTION - the new direction for the motor(s). + * @property {MotorDirection} MOTOR_DIRECTION - the new direction for the motor(s). */ setMotorDirection (args) { this._forEachMotor(args.MOTOR_ID, motorIndex => { const motor = this._device.motor(motorIndex); if (motor) { - switch (args.DIRECTION) { + switch (args.MOTOR_DIRECTION) { case MotorDirection.FORWARD: motor.direction = 1; break; @@ -1118,11 +1119,11 @@ class Scratch3WeDo2Blocks { /** * Test whether the tilt sensor is currently tilted. * @param {object} args - the block's arguments. - * @property {TiltDirection} DIRECTION - the tilt direction to test (up, down, left, right, or any). + * @property {TiltDirection} TILT_DIRECTION_ANY - the tilt direction to test (up, down, left, right, or any). * @return {boolean} - true if the tilt sensor is tilted past a threshold in the specified direction. */ whenTilted (args) { - return this._isTilted(args.DIRECTION); + return this._isTilted(args.TILT_DIRECTION_ANY); } /** @@ -1135,21 +1136,21 @@ class Scratch3WeDo2Blocks { /** * Test whether the tilt sensor is currently tilted. * @param {object} args - the block's arguments. - * @property {TiltDirection} DIRECTION - the tilt direction to test (up, down, left, right, or any). + * @property {TiltDirection} TILT_DIRECTION_ANY - the tilt direction to test (up, down, left, right, or any). * @return {boolean} - true if the tilt sensor is tilted past a threshold in the specified direction. */ isTilted (args) { - return this._isTilted(args.DIRECTION); + return this._isTilted(args.TILT_DIRECTION_ANY); } /** * @param {object} args - the block's arguments. - * @property {TiltDirection} DIRECTION - the direction (up, down, left, right) to check. + * @property {TiltDirection} TILT_DIRECTION - the direction (up, down, left, right) to check. * @return {number} - the tilt sensor's angle in the specified direction. * Note that getTiltAngle(up) = -getTiltAngle(down) and getTiltAngle(left) = -getTiltAngle(right). */ getTiltAngle (args) { - return this._getTiltAngle(args.DIRECTION); + return this._getTiltAngle(args.TILT_DIRECTION); } /** diff --git a/src/serialization/sb2_specmap.js b/src/serialization/sb2_specmap.js index 80112a894..c05cde2bd 100644 --- a/src/serialization/sb2_specmap.js +++ b/src/serialization/sb2_specmap.js @@ -1621,11 +1621,11 @@ const addExtensionOp = function (sb2Extension, sb2Opcode, blockInfo) { const weDo2 = 'LEGO WeDo 2.0'; addExtensionOp(weDo2, 'motorOnFor', { - opcode: 'wedo2.motorOnFor', + opcode: 'wedo2_motorOnFor', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.motorID', + inputOp: 'wedo2_menu_MOTOR_ID', inputName: 'MOTOR_ID' }, { @@ -1637,33 +1637,33 @@ addExtensionOp(weDo2, 'motorOnFor', { }); addExtensionOp(weDo2, 'motorOn', { - opcode: 'wedo2.motorOn', + opcode: 'wedo2_motorOn', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.motorID', + inputOp: 'wedo2_menu_MOTOR_ID', inputName: 'MOTOR_ID' } ] }); addExtensionOp(weDo2, 'motorOff', { - opcode: 'wedo2.motorOff', + opcode: 'wedo2_motorOff', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.motorID', + inputOp: 'wedo2_menu_MOTOR_ID', inputName: 'MOTOR_ID' } ] }); addExtensionOp(weDo2, 'startMotorPower', { - opcode: 'wedo2.startMotorPower', + opcode: 'wedo2_startMotorPower', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.motorID', + inputOp: 'wedo2_menu_MOTOR_ID', inputName: 'MOTOR_ID' }, { @@ -1675,23 +1675,23 @@ addExtensionOp(weDo2, 'startMotorPower', { }); addExtensionOp(weDo2, 'setMotorDirection', { - opcode: 'wedo2.setMotorDirection', + opcode: 'wedo2_setMotorDirection', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.motorID', + inputOp: 'wedo2_menu_MOTOR_ID', inputName: 'MOTOR_ID' }, { type: 'input', - inputOp: 'wedo2.menu.motorDirection', - inputName: 'DIRECTION' + inputOp: 'wedo2_menu_MOTOR_DIRECTION', + inputName: 'MOTOR_DIRECTION' } ] }); addExtensionOp(weDo2, 'setLED', { - opcode: 'wedo2.setLightHue', + opcode: 'wedo2_setLightHue', argMap: [ { type: 'input', @@ -1702,7 +1702,7 @@ addExtensionOp(weDo2, 'setLED', { }); addExtensionOp(weDo2, 'playNote', { - opcode: 'wedo2.playNoteFor', + opcode: 'wedo2_playNoteFor', argMap: [ { type: 'input', @@ -1718,11 +1718,11 @@ addExtensionOp(weDo2, 'playNote', { }); addExtensionOp(weDo2, 'whenDistance', { - opcode: 'wedo2.whenDistance', + opcode: 'wedo2_whenDistance', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.lessMore', + inputOp: 'wedo2_menu_OP', inputName: 'OP' }, { @@ -1734,39 +1734,39 @@ addExtensionOp(weDo2, 'whenDistance', { }); addExtensionOp(weDo2, 'whenTilted', { - opcode: 'wedo2.whenTilted', + opcode: 'wedo2_whenTilted', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.tiltDirectionAny', - inputName: 'DIRECTION' + inputOp: 'wedo2_menu_TILT_DIRECTION_ANY', + inputName: 'TILT_DIRECTION_ANY' } ] }); addExtensionOp(weDo2, 'getDistance', { - opcode: 'wedo2.getDistance', + opcode: 'wedo2_getDistance', argMap: [] }); addExtensionOp(weDo2, 'isTilted', { - opcode: 'wedo2.isTilted', + opcode: 'wedo2_isTilted', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.tiltDirectionAny', - inputName: 'DIRECTION' + inputOp: 'wedo2_menu_TILT_DIRECTION_ANY', + inputName: 'TILT_DIRECTION_ANY' } ] }); addExtensionOp(weDo2, 'getTilt', { - opcode: 'wedo2.getTiltAngle', + opcode: 'wedo2_getTiltAngle', argMap: [ { type: 'input', - inputOp: 'wedo2.menu.tiltDirection', - inputName: 'DIRECTION' + inputOp: 'wedo2_menu_TILT_DIRECTION', + inputName: 'TILT_DIRECTION' } ] });