app/assets/htmls/gs-element-blockly.html in gobstones-blockly-0.11.2 vs app/assets/htmls/gs-element-blockly.html in gobstones-blockly-0.12.0
- old
+ new
@@ -85,10 +85,12 @@
</category>
<category name="Definiciones">
<category name="Programas">
<block type="Program"></block>
<block type="InteractiveProgram"></block>
+ </category>
+ <category name="Asociaciones">
<block type="InteractiveLetterBinding"></block>
<block type="InteractiveNumberBinding"></block>
<block type="InteractiveKeyBinding"></block>
</category>
<category name="Procedimientos">
@@ -3308,11 +3310,11 @@
*/
FUNCTION_TYPES: ['procedures_defnoreturn', 'procedures_defreturn']
};</script>
<script>var PLUS = "";
var MINUS = "";
-var WAND = "";
+var HAND = "";
window.initProcedsBlockly = function(customStatementType) {
Blockly.Msg.PROCEDURES_DEFNORETURN_COMMENT = 'Describe el procedimiento...';
Blockly.Msg.PROCEDURES_DEFNORETURN_PROCEDURE = "Hacer algo";
Blockly.Msg.PROCEDURES_DEFNORETURN_TITLE = "Definir";
@@ -3442,11 +3444,11 @@
block.updateShape_();
}
}
var createCallButton = new Blockly.FieldImage(
- WAND,
+ HAND,
16,
16,
Blockly.Msg.VARIABLES_SET_CREATE_GET.replace('%1', name),
function() {
createParameterCaller(self, self.arguments_[i])();
@@ -3585,28 +3587,31 @@
this.statementConnection_ = null;
// if (!withParametersMutator) this.updateParams_();
// [!] adding create call button
- // TODO: Hacer esto
- // var xmlMutation = goog.dom.createDom('mutation');
- // xmlMutation.setAttribute('name', name);
- // for (var i = 0; i < self.arguments_.length; i++) {
- // var xmlArg = goog.dom.createDom('arg');
- // xmlArg.setAttribute('name', self.arguments_[i]);
- // xmlMutation.appendChild(xmlArg);
- // }
- // var xmlBlock = goog.dom.createDom('block', null, xmlMutation);
- // xmlBlock.setAttribute('type', self.callType_);
- // var createCallButton = new Blockly.FieldImage(
- // WAND,
- // 16,
- // 16,
- // "",
- // Blockly.ContextMenu.callbackFactory(self, xmlBlock)
- // );
- // input.appendField(createCallButton);
+ var createCallButton = new Blockly.FieldImage(
+ HAND,
+ 16,
+ 16,
+ "",
+ function() {
+ var name = self.getFieldValue('NAME');
+ var xmlMutation = goog.dom.createDom('mutation');
+ xmlMutation.setAttribute('name', name);
+ for (var i = 0; i < self.arguments_.length; i++) {
+ var xmlArg = goog.dom.createDom('arg');
+ xmlArg.setAttribute('name', self.arguments_[i]);
+ xmlMutation.appendChild(xmlArg);
+ }
+ var xmlBlock = goog.dom.createDom('block', null, xmlMutation);
+ xmlBlock.setAttribute('type', self.callType_);
+
+ Blockly.ContextMenu.callbackFactory(self, xmlBlock)();
+ }
+ );
+ input.appendField(createCallButton);
};
};
// -----------------------
// [!] Custom context menu
@@ -4028,12 +4033,14 @@
};
}
</script>
<script>initProcedsBlockly("Statement");</script>
- <script>var MINUS = "";
+ <script>var PLUS = "";
+var MINUS = "";
var HAND = "";
+var CLEAN = "";
/* global Blockly */
Blockly.CUSTOM_COLORS = {
globalHsvSaturation: Blockly.HSV_SATURATION,
@@ -4231,11 +4238,11 @@
[ 'SHIFT', 'SHIFT' ],
[ 'CTRL', 'CTRL' ],
[ 'ALT', 'ALT' ]
];
-const getModifiersInput = (block) => block.inputList[0];
+const getModifiersInput = (block) => block.inputList[1];
const getModifierFields = (block) => getModifiersInput(block).fieldRow.slice(2);
const getModifierDropdownFields = (block) => getModifierFields(block).filter(it => it.constructor === Blockly.FieldDropdown);
const getModifierValues = (block) => getModifierDropdownFields(block).map(it => it.getValue());
const getAvailableModifiers = (block) => {
const currentModifiers = getModifierValues(block);
@@ -4259,30 +4266,59 @@
createInteractiveBinding = (name, keys) => {
return {
init: function () {
this.jsonInit({
- message0: "%1 %2",
+ message0: "%1 %2 %3 %4",
type: "InteractiveBinding",
previousStatement: "InteractiveBinding",
nextStatement: "InteractiveBinding",
args0: [
{
"type": "field_label",
"text": "Al apretar " + name
},
+ { "type": "input_dummy" },
+ {
+ "type": "field_label",
+ "text": "➣"
+ },
{
type: "field_dropdown",
name: "InteractiveBindingDropdownKey",
options: keys.map(it => [it.name, it.code]),
}
],
colour: Blockly.CUSTOM_COLORS.InteractiveBinding || Blockly.CUSTOM_COLORS.interactiveBinding,
tooltip: "Escoger una entrada",
});
- this.appendStatementInput('block').setCheck(["Statement"]);
+ this.appendStatementInput('block').setCheck(["Statement"]);
+
+ const self = this;
+ const input = this.inputList[0];
+ input.appendField(new Blockly.FieldImage(
+ PLUS,
+ 16,
+ 16,
+ "Agregar modificador",
+ function() {
+ const modifiersCount = getModifierFields(self).length / 2;
+ if (modifiersCount >= modifiers.length) return;
+
+ self._addModifier();
+ }
+ ));
+ input.appendField(new Blockly.FieldImage(
+ CLEAN,
+ 16,
+ 16,
+ "Limpiar modificadores",
+ function() {
+ self._cleanModifiers();
+ }
+ ));
},
customContextMenu: function(options) {
const modifiersCount = getModifierFields(this).length / 2;
@@ -5276,16 +5312,16 @@
if (Blockly.GobstonesLanguage.variableDB_) {
Blockly.GobstonesLanguage.variableDB_.reset();
} else {
Blockly.GobstonesLanguage.variableDB_ =
new Blockly.Names(Blockly.GobstonesLanguage.RESERVED_WORDS_);
-
+
// Gobstones lets ñáéíóú, so Blockly's safeName should be rewritten.
// In the process, makes everything CamelCase which is Gobstones' default.
Blockly.GobstonesLanguage.variableDB_.safeName_ = function(name) {
if (!name) return 'unnamed';
-
+
//Get rid of unwanted chars
var safe = name.replace(/[^\wáéíóúÁÉÍÓÚñÑ ]/g, '')
//Escape initial numbers
if ('0123456789'.indexOf(safe[0]) != -1) safe = 'my ' + safe;
@@ -5293,11 +5329,11 @@
// Join spaces capitalizing in the process: ¡Gobstones is CamelCase!
// Leave first char as user wanted, for now...
safe = safe.split(' ').map((word, i) =>
!word | i == 0 ? word : word[0].toUpperCase() + word.slice(1)
).join('');
-
+
return safe;
};
}
};
@@ -5388,11 +5424,11 @@
return codigo;
};
Blockly.GobstonesLanguage.InteractiveProgram = function (block) {
let program = Blockly.GobstonesLanguage.statementToCode(block, 'interactiveprogram');
-
+
let init = '';
if (block.$init)
init = ` INIT -> {\n${Blockly.GobstonesLanguage.statementToCode(block, 'init')} }\n`;
let timeout = '';
@@ -5405,11 +5441,11 @@
Blockly.GobstonesLanguage.InteractiveLetterBinding = function (block) {
let key = block.getFieldValue('InteractiveBindingDropdownKey');
const order = ["CTRL", "ALT", "SHIFT"];
- const modifier = block.inputList[0]
+ const modifier = block.inputList[1]
.fieldRow
.slice(2)
.filter(it => it.constructor === Blockly.FieldDropdown)
.map(it => order.indexOf(it.getValue()))
.sort()
@@ -5488,11 +5524,11 @@
};
var makeParameterList = function (block) {
return block.arguments_
.map(arg => formatCallName(arg, false, Blockly.VARIABLE_CATEGORY_NAME))
- .join(', ');
+ .join(', ');
};
Blockly.GobstonesLanguage.procedures_defnoreturn = function (block) {
var name = formatCallName(block.getFieldValue('NAME'),true);
var body = Blockly.GobstonesLanguage.statementToCode(block, 'STACK');
@@ -5551,11 +5587,11 @@
return [code, Blockly.GobstonesLanguage.ORDER_ATOMIC];
};
Blockly.GobstonesLanguage.Asignacion = function(block) {
var varValue = Blockly.GobstonesLanguage.valueToCode(block, 'varValue', Blockly.GobstonesLanguage.ORDER_ASSIGNMENT);
- var code = formatCallName(block.getFieldValue('varName'),false,Blockly.VARIABLE_CATEGORY_NAME) +
+ var code = formatCallName(block.getFieldValue('varName'),false,Blockly.VARIABLE_CATEGORY_NAME) +
' := ' + varValue + '\n';
return code;
};
</script>
<script>Blockly.GobstonesLanguage.blockIDAliases = {
@@ -5734,11 +5770,11 @@
'.blocklyPreconditionError>.blocklyPath {',
'stroke: #f88;',
'stroke-width: 3px;',
'}',
];</script>
-
+
<script>
const BLOCKLY_PRIMITIVE_PROCEDURES = "Procedimientos primitivos";
const BLOCKLY_PRIMITIVE_FUNCTIONS = "Funciones primitivas";
Polymer({
@@ -6110,11 +6146,11 @@
// Bloque
Blockly.Blocks[name] = {
init: function () {
let argsIndex = 1;
this.setColour(Blockly.CUSTOM_COLORS.primitiveProcedure);
-
+
if (icon) {
this.appendDummyInput().appendField(new Blockly.FieldImage(
icon,
16,
16,
@@ -6268,11 +6304,11 @@
const interactiveProgram = interactiveProgramXmls[0] && block(interactiveProgramXmls[0]);
if (program && interactiveProgram) {
program.setDeletable(true);
interactiveProgram.setDeletable(true);
-
+
const important = program.$timestamp > interactiveProgram.$timestamp ? program : interactiveProgram;
const unimportant = program.$timestamp > interactiveProgram.$timestamp ? interactiveProgram : program;
const twoActivePrograms = !program.disabled && !interactiveProgram.disabled;
const twoDisabledPrograms = program.disabled && interactiveProgram.disabled;
@@ -6294,11 +6330,11 @@
const blocks = this.workspace.getAllBlocks();
for (block of blocks) {
if (block.type === "variables_get" && block.$parent) {
const parentBlock = this.workspace.getBlockById(block.$parent);
const varField = block.getField("VAR");
-
+
if (
parentBlock &&
(
!parentBlock.type.startsWith("procedures") ||
parentBlock.arguments_.some(it => it === varField.getValue())
@@ -6513,11 +6549,11 @@
// Element Behavior
/**
* Generate gobstones code from the blocks in the workspace.
* It removes all highlighting and errors if already present.
- *
+ *
* There is an additional option which if provided adds pragma BEGIN/END REGION
* to the output.
* * `element.generateCode( {withRegions: true, clearErrors: false} );`
* @return {string} The code.
*/
@@ -6545,16 +6581,16 @@
this.workspace.highlightBlock(blockId)
},
/**
* Highlight a given block, telling the user it has an error
- *
+ *
* `blockId` is the block ID where the error should appear
- *
+ *
* `errorKind` is either a string with the description or an object with a kind of error.
* Next are examples with the existent error kinds.
- *
+ *
* Examples:
* * `element.showBlockError('a1s2', 'Hey, here is an error')`
* * `element.showBlockError('a1s2', { kind: 'INCOMPLETE_ERROR'} )`
* * `element.showBlockError('a1s2', { kind: 'TYPE_ERROR', expectedType:'string', actualType: 'boolean' })`
* * `element.showBlockError('a1s2', { kind: 'PRECONDITION_ERROR', description: "Susan can't move right" })`
@@ -6563,13 +6599,13 @@
this.workspace.showBlockError(blockId, errorKind);
},
testColors(colors) {
Blockly.CUSTOM_COLORS = colors;
- Blockly.HSV_SATURATION = colors.globalHsvSaturation;
+ Blockly.HSV_SATURATION = colors.globalHsvSaturation;
Blockly.HSV_VALUE = colors.globalHsvValue;
Blockly.Blocks.procedures.HUE = colors.procedure;
-
+
var xmlDom = Blockly.Xml.workspaceToDom(this.workspace);
const xml = Blockly.Xml.domToText(xmlDom);
this.resetWorkspace();
setTimeout(() => {
\ No newline at end of file