cloud-blocks
Version:
Cloud Blocks is a library for building scratch computing interfaces with Luxrobo MODI.
313 lines (299 loc) • 7.3 kB
JavaScript
/**
* @license
* Visual Blocks Editor
*
* Copyright 2016 Massachusetts Institute of Technology
* All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
'use strict';
goog.provide('Blockly.Blocks.extensions');
goog.require('Blockly.Blocks');
goog.require('Blockly.Colours');
goog.require('Blockly.constants');
goog.require('Blockly.ScratchBlocks.VerticalExtensions');
Blockly.Blocks['extension_pen_down'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1 %2 pen down',
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/pen-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
}
],
category: Blockly.Categories.more,
extensions: ['colours_more', 'shape_statement', 'scratch_extension']
});
}
};
Blockly.Blocks['extension_music_drum'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1 %2 play drum %3',
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/music-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
},
{
type: 'input_value',
name: 'NUMBER'
}
],
category: Blockly.Categories.more,
extensions: ['colours_more', 'shape_statement', 'scratch_extension']
});
}
};
Blockly.Blocks['extension_wedo_motor'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1 %2 turn a motor %3',
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/wedo2-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
},
{
type: 'field_image',
src: Blockly.mainWorkspace.options.pathToMedia + 'rotate-right.svg',
width: 24,
height: 24
}
],
category: Blockly.Categories.more,
extensions: ['colours_more', 'shape_statement', 'scratch_extension']
});
}
};
Blockly.Blocks['extension_wedo_hat'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1 %2 when I am wearing a hat',
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/wedo2-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
}
],
category: Blockly.Categories.more,
extensions: ['colours_more', 'shape_hat', 'scratch_extension']
});
}
};
Blockly.Blocks['extension_wedo_boolean'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1 %2 O RLY?',
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/wedo2-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
}
],
category: Blockly.Categories.more,
extensions: ['colours_more', 'output_boolean', 'scratch_extension']
});
}
};
Blockly.Blocks['extension_wedo_tilt_reporter'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1 %2 tilt angle %3',
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/wedo2-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
},
{
type: 'input_value',
name: 'TILT'
}
],
category: Blockly.Categories.more,
extensions: ['colours_more', 'output_number', 'scratch_extension']
});
}
};
Blockly.Blocks['extension_wedo_tilt_menu'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1',
args0: [
{
type: 'field_dropdown',
name: 'TILT',
options: [
['Any', 'Any'],
['Whirl', 'Whirl'],
['South', 'South'],
['Back in time', 'Back in time']
]
}
],
extensions: ['colours_more', 'output_string']
});
}
};
Blockly.Blocks['extension_music_reporter'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: "%1 %2 hey now, you're an all-star",
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/music-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
}
],
category: Blockly.Categories.more,
extensions: ['colours_more', 'output_number', 'scratch_extension']
});
}
};
Blockly.Blocks['extension_microbit_display'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1 %2 display %3',
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/microbit-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
},
{
type: 'input_value',
name: 'MATRIX'
}
],
category: Blockly.Categories.pen,
extensions: ['colours_pen', 'shape_statement', 'scratch_extension']
});
}
};
Blockly.Blocks['extension_music_play_note'] = {
/**
* @this Blockly.Block
*/
init: function () {
this.jsonInit({
message0: '%1 %2 play note %3 for %4 beats',
args0: [
{
type: 'field_image',
src:
Blockly.mainWorkspace.options.pathToMedia +
'extensions/music-block-icon.svg',
width: 40,
height: 40
},
{
type: 'field_vertical_separator'
},
{
type: 'input_value',
name: 'NOTE'
},
{
type: 'input_value',
name: 'BEATS'
}
],
category: Blockly.Categories.pen,
extensions: ['colours_pen', 'shape_statement', 'scratch_extension']
});
}
};