update logic and text blocks
This commit is contained in:
parent
f709b4b757
commit
aaeaf7a5aa
@ -1,5 +1,7 @@
|
|||||||
import Blockly from 'blockly/core';
|
import Blockly from 'blockly/core';
|
||||||
import { getColour } from '../helpers/colour';
|
import { getColour } from '../helpers/colour';
|
||||||
|
import * as Types from '../helpers/types';
|
||||||
|
import { getCompatibleTypes } from '../helpers/types';
|
||||||
|
|
||||||
|
|
||||||
Blockly.defineBlocksWithJsonArray([ // BEGIN JSON EXTRACT
|
Blockly.defineBlocksWithJsonArray([ // BEGIN JSON EXTRACT
|
||||||
@ -230,6 +232,73 @@ Blockly.defineBlocksWithJsonArray([ // Mutator blocks. Do not extract.
|
|||||||
}
|
}
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
Blockly.Blocks['logic_compare'] = {
|
||||||
|
/**
|
||||||
|
* Block for comparison operator.
|
||||||
|
* @this Blockly.Block
|
||||||
|
*/
|
||||||
|
init: function () {
|
||||||
|
var OPERATORS = this.RTL ? [
|
||||||
|
['=', 'EQ'],
|
||||||
|
['\u2260', 'NEQ'],
|
||||||
|
['>', 'LT'],
|
||||||
|
['\u2265', 'LTE'],
|
||||||
|
['<', 'GT'],
|
||||||
|
['\u2264', 'GTE']
|
||||||
|
] : [
|
||||||
|
['=', 'EQ'],
|
||||||
|
['\u2260', 'NEQ'],
|
||||||
|
['<', 'LT'],
|
||||||
|
['\u2264', 'LTE'],
|
||||||
|
['>', 'GT'],
|
||||||
|
['\u2265', 'GTE']
|
||||||
|
];
|
||||||
|
this.setHelpUrl(Blockly.Msg.LOGIC_COMPARE_HELPURL);
|
||||||
|
this.setColour(getColour().logic);
|
||||||
|
this.setOutput(true, Types.BOOLEAN.typeName);
|
||||||
|
this.appendValueInput('A');
|
||||||
|
this.appendValueInput('B')
|
||||||
|
.appendField(new Blockly.FieldDropdown(OPERATORS), 'OP');
|
||||||
|
this.setInputsInline(true);
|
||||||
|
// Assign 'this' to a variable for use in the tooltip closure below.
|
||||||
|
var thisBlock = this;
|
||||||
|
this.setTooltip(function () {
|
||||||
|
var op = thisBlock.getFieldValue('OP');
|
||||||
|
var TOOLTIPS = {
|
||||||
|
'EQ': Blockly.Msg.LOGIC_COMPARE_TOOLTIP_EQ,
|
||||||
|
'NEQ': Blockly.Msg.LOGIC_COMPARE_TOOLTIP_NEQ,
|
||||||
|
'LT': Blockly.Msg.LOGIC_COMPARE_TOOLTIP_LT,
|
||||||
|
'LTE': Blockly.Msg.LOGIC_COMPARE_TOOLTIP_LTE,
|
||||||
|
'GT': Blockly.Msg.LOGIC_COMPARE_TOOLTIP_GT,
|
||||||
|
'GTE': Blockly.Msg.LOGIC_COMPARE_TOOLTIP_GTE
|
||||||
|
};
|
||||||
|
return TOOLTIPS[op];
|
||||||
|
});
|
||||||
|
},
|
||||||
|
/**
|
||||||
|
* Called whenever anything on the workspace changes.
|
||||||
|
* Prevent mismatched types from being compared.
|
||||||
|
* @param {!Blockly.Events.Abstract} e Change event.
|
||||||
|
* @this Blockly.Block
|
||||||
|
*/
|
||||||
|
onchange: function (e) {
|
||||||
|
var blockA = this.getInputTargetBlock('A');
|
||||||
|
var blockB = this.getInputTargetBlock('B');
|
||||||
|
if (blockA === null && blockB === null) {
|
||||||
|
this.getInput('A').setCheck(null);
|
||||||
|
this.getInput('B').setCheck(null);
|
||||||
|
}
|
||||||
|
if (blockA !== null && blockB === null) {
|
||||||
|
this.getInput('A').setCheck(getCompatibleTypes(blockA.outputConnection.check_[0]));
|
||||||
|
this.getInput('B').setCheck(getCompatibleTypes(blockA.outputConnection.check_[0]));
|
||||||
|
}
|
||||||
|
if (blockB !== null && blockA === null) {
|
||||||
|
this.getInput('B').setCheck(getCompatibleTypes(blockB.outputConnection.check_[0]));
|
||||||
|
this.getInput('A').setCheck(getCompatibleTypes(blockB.outputConnection.check_[0]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
Blockly.Blocks['switch_case'] = {
|
Blockly.Blocks['switch_case'] = {
|
||||||
init: function () {
|
init: function () {
|
||||||
|
@ -1 +1,202 @@
|
|||||||
|
import Blockly from 'blockly/core';
|
||||||
|
import { getColour } from '../helpers/colour';
|
||||||
|
import * as Types from '../helpers/types';
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Blockly.defineBlocksWithJsonArray([ // BEGIN JSON EXTRACT
|
||||||
|
// Block for text value
|
||||||
|
{
|
||||||
|
"type": "text",
|
||||||
|
"message0": "%1",
|
||||||
|
"args0": [{
|
||||||
|
"type": "field_input",
|
||||||
|
"name": "TEXT",
|
||||||
|
"text": ""
|
||||||
|
}],
|
||||||
|
"output": Types.TEXT.typeName,
|
||||||
|
"style": "text_blocks",
|
||||||
|
"helpUrl": "%{BKY_TEXT_TEXT_HELPURL}",
|
||||||
|
"tooltip": "%{BKY_TEXT_TEXT_TOOLTIP}",
|
||||||
|
"extensions": [
|
||||||
|
"text_quotes",
|
||||||
|
"parent_tooltip_when_inline"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_multiline",
|
||||||
|
"message0": "%1 %2",
|
||||||
|
"args0": [{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": '' +
|
||||||
|
'U2iAAAABGdBTUEAALGPC/xhBQAAAAlwSFlzAAAdhgAAHYYBXaITgQAAABh0RVh0' +
|
||||||
|
'U29mdHdhcmUAcGFpbnQubmV0IDQuMS42/U4J6AAAAP1JREFUOE+Vks0KQUEYhjm' +
|
||||||
|
'RIja4ABtZ2dm5A3t3Ia6AUm7CylYuQRaUhZSlLZJiQbFAyRnPN33y01HOW08z88' +
|
||||||
|
'73zpwzM4F3GWOCruvGIE4/rLaV+Nq1hVGMBqzhqlxgCys4wJA65xnogMHsQ5luj' +
|
||||||
|
'nYHTejBBCK2mE4abjCgMGhNxHgDFWjDSG07kdfVa2pZMf4ZyMAdWmpZMfYOsLiD' +
|
||||||
|
'MYMjlMB+K613QISRhTnITnsYg5yUd0DETmEoMlkFOeIT/A58iyK5E18BuTBfgYX' +
|
||||||
|
'fwNJv4P9/oEBerLylOnRhygmGdPpTTBZAPkde61lbQe4moWUvYUZYLfUNftIY4z' +
|
||||||
|
'wA5X2Z9AYnQrEAAAAASUVORK5CYII=',
|
||||||
|
"width": 12,
|
||||||
|
"height": 17,
|
||||||
|
"alt": '\u00B6'
|
||||||
|
}, {
|
||||||
|
"type": "field_multilinetext",
|
||||||
|
"name": "TEXT",
|
||||||
|
"text": ""
|
||||||
|
}],
|
||||||
|
"output": Types.TEXT.typeName,
|
||||||
|
"style": "text_blocks",
|
||||||
|
"helpUrl": "%{BKY_TEXT_TEXT_HELPURL}",
|
||||||
|
"tooltip": "%{BKY_TEXT_TEXT_TOOLTIP}",
|
||||||
|
"extensions": [
|
||||||
|
"parent_tooltip_when_inline"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_join",
|
||||||
|
"message0": "",
|
||||||
|
"output": Types.TEXT.typeName,
|
||||||
|
"style": "text_blocks",
|
||||||
|
"helpUrl": "%{BKY_TEXT_JOIN_HELPURL}",
|
||||||
|
"tooltip": "%{BKY_TEXT_JOIN_TOOLTIP}",
|
||||||
|
"mutator": "text_join_mutator"
|
||||||
|
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_create_join_container",
|
||||||
|
"message0": "%{BKY_TEXT_CREATE_JOIN_TITLE_JOIN} %1 %2",
|
||||||
|
"args0": [{
|
||||||
|
"type": "input_dummy"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "input_statement",
|
||||||
|
"name": "STACK"
|
||||||
|
}],
|
||||||
|
"style": "text_blocks",
|
||||||
|
"tooltip": "%{BKY_TEXT_CREATE_JOIN_TOOLTIP}",
|
||||||
|
"enableContextMenu": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_create_join_item",
|
||||||
|
"message0": "%{BKY_TEXT_CREATE_JOIN_ITEM_TITLE_ITEM}",
|
||||||
|
"previousStatement": null,
|
||||||
|
"nextStatement": null,
|
||||||
|
"style": getColour().text,
|
||||||
|
"tooltip": "%{BKY_TEXT_CREATE_JOIN_ITEM_TOOLTIP}",
|
||||||
|
"enableContextMenu": false
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_append",
|
||||||
|
"message0": "%{BKY_TEXT_APPEND_TITLE}",
|
||||||
|
"args0": [{
|
||||||
|
"type": "field_variable",
|
||||||
|
"name": "VAR",
|
||||||
|
"variable": "%{BKY_TEXT_APPEND_VARIABLE}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "TEXT"
|
||||||
|
}],
|
||||||
|
"previousStatement": null,
|
||||||
|
"nextStatement": null,
|
||||||
|
"style": "text_blocks",
|
||||||
|
"extensions": [
|
||||||
|
"text_append_tooltip"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_length",
|
||||||
|
"message0": "%{BKY_TEXT_LENGTH_TITLE}",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "VALUE",
|
||||||
|
"check": ['String', 'Array']
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"output": Types.NUMBER.typeName,
|
||||||
|
"style": "text_blocks",
|
||||||
|
"tooltip": "%{BKY_TEXT_LENGTH_TOOLTIP}",
|
||||||
|
"helpUrl": "%{BKY_TEXT_LENGTH_HELPURL}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_isEmpty",
|
||||||
|
"message0": "%{BKY_TEXT_ISEMPTY_TITLE}",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "VALUE",
|
||||||
|
"check": ['String', 'Array']
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"output": Types.BOOLEAN.typeName,
|
||||||
|
"style": "text_blocks",
|
||||||
|
"tooltip": "%{BKY_TEXT_ISEMPTY_TOOLTIP}",
|
||||||
|
"helpUrl": "%{BKY_TEXT_ISEMPTY_HELPURL}"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_indexOf",
|
||||||
|
"message0": "%{BKY_TEXT_INDEXOF_TITLE}",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "VALUE",
|
||||||
|
"check": "String"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_dropdown",
|
||||||
|
"name": "END",
|
||||||
|
"options": [
|
||||||
|
[
|
||||||
|
"%{BKY_TEXT_INDEXOF_OPERATOR_FIRST}",
|
||||||
|
"FIRST"
|
||||||
|
],
|
||||||
|
[
|
||||||
|
"%{BKY_TEXT_INDEXOF_OPERATOR_LAST}",
|
||||||
|
"LAST"
|
||||||
|
]
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "FIND",
|
||||||
|
"check": "String"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"output": Types.NUMBER.typeName,
|
||||||
|
"style": "text_blocks",
|
||||||
|
"helpUrl": "%{BKY_TEXT_INDEXOF_HELPURL}",
|
||||||
|
"inputsInline": true,
|
||||||
|
"extensions": [
|
||||||
|
"text_indexOf_tooltip"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "text_charAt",
|
||||||
|
"message0": "%{BKY_TEXT_CHARAT_TITLE}", // "in text %1 %2"
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "VALUE",
|
||||||
|
"check": "String"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_dropdown",
|
||||||
|
"name": "WHERE",
|
||||||
|
"options": [
|
||||||
|
["%{BKY_TEXT_CHARAT_FROM_START}", "FROM_START"],
|
||||||
|
["%{BKY_TEXT_CHARAT_FROM_END}", "FROM_END"],
|
||||||
|
["%{BKY_TEXT_CHARAT_FIRST}", "FIRST"],
|
||||||
|
["%{BKY_TEXT_CHARAT_LAST}", "LAST"],
|
||||||
|
["%{BKY_TEXT_CHARAT_RANDOM}", "RANDOM"]
|
||||||
|
]
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"output": Types.TEXT.typeName,
|
||||||
|
"style": "text_blocks",
|
||||||
|
"helpUrl": "%{BKY_TEXT_CHARAT_HELPURL}",
|
||||||
|
"inputsInline": true,
|
||||||
|
"mutator": "text_charAt_mutator"
|
||||||
|
}
|
||||||
|
]); // END JSON EXTRACT (Do not delete this comment.)
|
Loading…
x
Reference in New Issue
Block a user