app/assets/htmls/gs-element-blockly.html in gobstones-blockly-0.11.1 vs app/assets/htmls/gs-element-blockly.html in gobstones-blockly-0.11.2
- old
+ new
@@ -3571,18 +3571,42 @@
this.workspace.options.parentWorkspace.options.comments)) &&
comment) {
this.setCommentText(comment);
}
this.setCommentText(null);
- this.setColour(Blockly.Blocks.procedures.HUE);
+ this.setColour((
+ Blockly.CUSTOM_COLORS && (
+ Blockly.CUSTOM_COLORS[this.type] ||
+ Blockly.CUSTOM_COLORS[withReturn ? "function" : "procedure"]
+ )) || Blockly.Blocks.procedures.HUE);
this.setTooltip(tooltip);
this.setHelpUrl(helpUrl);
this.arguments_ = [];
this.setStatements_(withStatements);
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);
};
};
// -----------------------
// [!] Custom context menu
@@ -3646,26 +3670,48 @@
options.pop(); // [!] Remove help
};
};
- // ----------------------------------------------------
- // [!] Setting custom statement type to procedure calls
- // ----------------------------------------------------
+ // ---------------------------------------------------------------------
+ // [!] Setting custom statement type to procedure calls and adding color
+ // ---------------------------------------------------------------------
var oldProceduresCallNoReturnInit = Blockly.Blocks['procedures_callnoreturn'].init;
Blockly.Blocks['procedures_callnoreturn'].init = function() {
oldProceduresCallNoReturnInit.call(this);
+
if (customStatementType) {
this.jsonInit({
type: customStatementType,
previousStatement: customStatementType,
nextStatement: customStatementType
});
}
+
+ this.setColour((
+ Blockly.CUSTOM_COLORS && (
+ Blockly.CUSTOM_COLORS[this.type] ||
+ Blockly.CUSTOM_COLORS.procedure_call
+ )) || Blockly.Blocks.procedures.HUE);
};
+ // ----------------------------------
+ // [!] Adding color to function calls
+ // ----------------------------------
+
+ var oldProceduresCallReturnInit = Blockly.Blocks['procedures_callreturn'].init;
+ Blockly.Blocks['procedures_callreturn'].init = function() {
+ oldProceduresCallReturnInit.call(this);
+
+ this.setColour((
+ Blockly.CUSTOM_COLORS && (
+ Blockly.CUSTOM_COLORS[this.type] || // TODO: Usar this.type en todos los cosos de colors
+ Blockly.CUSTOM_COLORS.function_call
+ )) || Blockly.Blocks.procedures.HUE);
+ };
+
// -------------------------------
// [!] Patching default procedures
// -------------------------------
var makeUpdateParams = function() { return function() { }; };
@@ -3983,14 +4029,15 @@
}
</script>
<script>initProcedsBlockly("Statement");</script>
<script>var MINUS = "";
+var HAND = "";
/* global Blockly */
-Blockly.GOBSTONES_COLORS = {
+Blockly.CUSTOM_COLORS = {
globalHsvSaturation: Blockly.HSV_SATURATION,
globalHsvValue: Blockly.HSV_VALUE,
primitiveCommand: "#8DA65B",
assignation: "#5B68A6",
controlStructure: "#A6A65B",
@@ -3998,10 +4045,17 @@
expression: "#745BA6",
program: "#74A65B",
interactiveProgram: "#A6805B",
interactiveBinding: "#A6995B",
procedure: "#995BA6",
+ function: "#774A77",
+ primitiveProcedure: "#CACACA",
+ primitiveFunction: "#BABABA",
+ procedure_call: "#661CF6",
+ function_call: "#330610",
+ variable: "#FF0000",
+ parameter: "#0000FF",
complete: "#A65C5B",
};
/**
* Create the svg representation of a block and render
@@ -4034,11 +4088,11 @@
"name": "program",
"check": ["Statement"]
}
]
})
- this.setColour(Blockly.GOBSTONES_COLORS.program);
+ this.setColour(Blockly.CUSTOM_COLORS.Program || Blockly.CUSTOM_COLORS.program);
this.setDeletable(true);
this.setEditable(true);
this.setMovable(true);
},
@@ -4078,11 +4132,11 @@
"name": "interactiveprogram",
"check": ["InteractiveBinding"]
}
]
});
- this.setColour(Blockly.GOBSTONES_COLORS.interactiveProgram);
+ this.setColour(Blockly.CUSTOM_COLORS.InteractiveProgram || Blockly.CUSTOM_COLORS.interactiveProgram);
this.setDeletable(true);
this.setEditable(true);
this.setMovable(true);
},
@@ -4220,11 +4274,11 @@
type: "field_dropdown",
name: "InteractiveBindingDropdownKey",
options: keys.map(it => [it.name, it.code]),
}
],
- colour: Blockly.GOBSTONES_COLORS.interactiveBinding,
+ colour: Blockly.CUSTOM_COLORS.InteractiveBinding || Blockly.CUSTOM_COLORS.interactiveBinding,
tooltip: "Escoger una entrada",
});
this.appendStatementInput('block').setCheck(["Statement"]);
},
@@ -4321,11 +4375,11 @@
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
});
- this.setColour(Blockly.GOBSTONES_COLORS.controlStructure);
+ this.setColour(Blockly.CUSTOM_COLORS.RepeticionSimple || Blockly.CUSTOM_COLORS.controlStructure);
this.appendValueInput('count')
.appendField('repetir');
this.appendDummyInput()
.appendField('veces');
this.appendStatementInput('block').setCheck(["Statement"]);
@@ -4339,11 +4393,11 @@
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
});
- this.setColour(Blockly.GOBSTONES_COLORS.controlStructure);
+ this.setColour(Blockly.CUSTOM_COLORS.RepeticionCondicional || Blockly.CUSTOM_COLORS.controlStructure);
this.appendValueInput('condicion')
.setCheck('Bool')
.appendField('repetir hasta que');
this.appendStatementInput('block').setCheck(["Statement"]);
this.setInputsInline(true);
@@ -4356,11 +4410,11 @@
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
});
- this.setColour(Blockly.GOBSTONES_COLORS.controlStructure);
+ this.setColour(Blockly.CUSTOM_COLORS.AlternativaSimple || Blockly.CUSTOM_COLORS.controlStructure);
this.appendValueInput('condicion')
.appendField(Blockly.Msg["CONTROLS_IF_MSG_IF"]);
this.appendStatementInput('block').setCheck(["Statement"]);
this.setInputsInline(true);
}
@@ -4428,11 +4482,11 @@
"helpUrl": "%{BKY_CONTROLS_IF_HELPURL}",
"mutator": "controls_if_mutator_without_ui",
"extensions": ["controls_if_tooltip"]
});
- this.setColour(Blockly.GOBSTONES_COLORS.controlStructure);
+ this.setColour(Blockly.CUSTOM_COLORS.AlternativaCompleta || Blockly.CUSTOM_COLORS.controlStructure);
this.setInputsInline(true);
this.elseCount_++;
this.updateShape_();
},
@@ -4491,11 +4545,11 @@
{
type: 'input_value',
name: 'COLOR'
}
],
- colour: Blockly.GOBSTONES_COLORS.primitiveCommand,
+ colour: Blockly.CUSTOM_COLORS.Poner || Blockly.CUSTOM_COLORS.primitiveCommand,
tooltip: 'Poner color en casillero.',
inputsInline: true
});
}
};
@@ -4511,11 +4565,11 @@
{
type: 'input_value',
name: 'COLOR'
}
],
- colour: Blockly.GOBSTONES_COLORS.primitiveCommand,
+ colour: Blockly.CUSTOM_COLORS.Sacar || Blockly.CUSTOM_COLORS.primitiveCommand,
tooltip: 'Sacar color de casillero.',
inputsInline: true
});
}
};
@@ -4531,11 +4585,11 @@
{
type: 'input_value',
name: 'DIRECCION'
}
],
- colour: Blockly.GOBSTONES_COLORS.primitiveCommand,
+ colour: Blockly.CUSTOM_COLORS.Mover || Blockly.CUSTOM_COLORS.primitiveCommand,
tooltip: 'Mover en una dirección.',
inputsInline: true
});
}
};
@@ -4551,11 +4605,11 @@
{
type: 'input_value',
name: 'DIRECCION'
}
],
- colour: Blockly.GOBSTONES_COLORS.primitiveCommand,
+ colour: Blockly.CUSTOM_COLORS.IrAlBorde || Blockly.CUSTOM_COLORS.primitiveCommand,
tooltip: 'Ir al borde del tablero.',
inputsInline: true
});
}
};
@@ -4565,11 +4619,11 @@
this.jsonInit({
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
message0: 'Vaciar tablero',
- colour: Blockly.GOBSTONES_COLORS.primitiveCommand,
+ colour: Blockly.CUSTOM_COLORS.VaciarTablero || Blockly.CUSTOM_COLORS.primitiveCommand,
tooltip: 'Vaciar el tablero.',
inputsInline: true
});
}
};
@@ -4591,11 +4645,11 @@
"name": "boomDescription",
"text": "Ingresar motivo..."
}
],
"inputsInline": false,
- "colour": Blockly.GOBSTONES_COLORS.primitiveCommand,
+ "colour": Blockly.CUSTOM_COLORS.BOOM || Blockly.CUSTOM_COLORS.primitiveCommand,
"tooltip": "Este comando hace que estalle todo."
});
}
};
@@ -4611,11 +4665,11 @@
"type": "Statement",
"previousStatement": "Statement",
"nextStatement": "Statement",
"lastDummyAlign0": "RIGHT",
"message0": "COMPLETAR",
- "colour": Blockly.GOBSTONES_COLORS.complete,
+ "colour": Blockly.CUSTOM_COLORS.ComandoCompletar || Blockly.CUSTOM_COLORS.complete,
"tooltip": "Tenés que reemplazar este bloque por tu solución"
});
},
onchange: Blockly.Blocks.makeShadowEventListener
@@ -4627,11 +4681,11 @@
"type": "InteractiveBinding",
"previousStatement": "InteractiveBinding",
"nextStatement": "InteractiveBinding",
"lastDummyAlign0": "RIGHT",
"message0": "COMPLETAR",
- "colour": Blockly.GOBSTONES_COLORS.complete,
+ "colour": Blockly.CUSTOM_COLORS.AsociacionDeTeclaCompletar || Blockly.CUSTOM_COLORS.complete,
"tooltip": "Tenés que reemplazar este bloque por tu solución"
});
},
onchange: Blockly.Blocks.makeShadowEventListener
@@ -4639,17 +4693,34 @@
// ------------------------------------------------------
// Expresiones:
// ------------------------------------------------------
+function deepCopyObj(aObject) {
+ var bObject, v, k;
+ bObject = Array.isArray(aObject) ? [] : {};
+ for (k in aObject) {
+ v = aObject[k];
+ bObject[k] = (typeof v === "object") ? deepCopyObj(v) : v;
+ }
+ return bObject;
+}
+
+const oldMathNumber = Blockly.Blocks.math_number;
+Blockly.Blocks.math_number = deepCopyObj(Blockly.Blocks.math_number);
+Blockly.Blocks.math_number.init = function() {
+ oldMathNumber.init.call(this);
+ this.setColour(Blockly.CUSTOM_COLORS.math_number || Blockly.CUSTOM_COLORS.literalExpression);
+}
+
Blockly.Blocks.ExpresionCompletar = {
init: function () {
this.jsonInit({
"type": "completar_expression",
"message0": "COMPLETAR",
"output": "any",
- "colour": Blockly.GOBSTONES_COLORS.complete,
+ "colour": Blockly.CUSTOM_COLORS.ExpresionCompletar || Blockly.CUSTOM_COLORS.complete,
"tooltip": "Tenés que reemplazar este bloque por tu solución"
});
},
onchange: Blockly.Blocks.makeShadowEventListener
@@ -4665,11 +4736,11 @@
type: "field_dropdown",
name: type + "Dropdown",
options: values.map(value => [value,value]),
}],
output: type,
- colour: Blockly.GOBSTONES_COLORS.literalExpression,
+ colour: Blockly.CUSTOM_COLORS[`${type}Selector`] || Blockly.CUSTOM_COLORS.literalExpression,
tooltip: "Escoger " + type,
});
}
};
}
@@ -4687,11 +4758,11 @@
{
type: 'input_value',
name: 'VALUE'
}
],
- colour: Blockly.GOBSTONES_COLORS.expression,
+ colour: Blockly.CUSTOM_COLORS[this.type] || Blockly.CUSTOM_COLORS.expression,
inputsInline: true,
output: returnType
})
}
};
@@ -4725,11 +4796,11 @@
{
type: 'input_value',
name: 'arg2'
}
],
- colour: Blockly.GOBSTONES_COLORS.expression,
+ colour: Blockly.CUSTOM_COLORS.OperadorDeComparacion || Blockly.CUSTOM_COLORS.expression,
inputsInline: false,
output: 'Bool'
});
}
};
@@ -4754,11 +4825,11 @@
{
type: 'input_value',
name: 'arg2'
}
],
- colour: Blockly.GOBSTONES_COLORS.expression,
+ colour: Blockly.CUSTOM_COLORS.OperadorNumerico || Blockly.CUSTOM_COLORS.expression,
inputsInline: false,
output: 'Number'
});
}
};
@@ -4773,37 +4844,37 @@
name: 'arg1'
},
{
type: 'field_dropdown',
name: 'OPERATOR',
- options: [['y también', '&&'], ['o bien', '||']]
+ options: [['y también', 'AND'], ['o bien', '||']]
},
{
type: 'input_dummy'
},
{
type: 'input_value',
name: 'arg2'
}
],
- colour: Blockly.GOBSTONES_COLORS.expression,
+ colour: Blockly.CUSTOM_COLORS.OperadorLogico || Blockly.CUSTOM_COLORS.expression,
inputsInline: false,
output: 'Bool'
});
}
};
Blockly.Blocks.Asignacion = {
init: function () {
this.jsonInit({
"type": "asignacion",
- "message0": "%1 %2 := %3 %4",
+ "message0": "Recordar que %1 %2 vale %3 %4",
"args0": [
{
"type": "field_input",
"name": "varName",
- "text": "nombre de variable",
+ "text": "una variable",
"class": Blockly.Procedures.rename
},
{
"type": "input_dummy"
},
@@ -4816,15 +4887,28 @@
}
],
"inputsInline": true,
"previousStatement": null,
"nextStatement": null,
- "colour": Blockly.GOBSTONES_COLORS.assignation,
+ "colour": Blockly.CUSTOM_COLORS.Asignacion || Blockly.CUSTOM_COLORS.assignation,
"tooltip": "",
"helpUrl": ""
});
- this.getters = [];
+
+ var self = this;
+ var createGetterButton = new Blockly.FieldImage(
+ HAND,
+ 16,
+ 16,
+ "Obtener variable",
+ function() {
+ var name = self.getFieldValue('varName');
+ self.createVariableBlock(name);
+ }
+ );
+
+ this.appendDummyInput().appendField(createGetterButton);
},
customContextMenu: function(options) {
var name = this.getFieldValue('varName');
@@ -4835,24 +4919,11 @@
createVariableBlock: function(name) {
return Blockly.createBlockSvg(this.workspace, 'variables_get', b => {
b.setFieldValue(name, 'VAR');
b.moveBy(10,5);
- b.parentAssignmentBlock = this;
- this.getters.push(b);
});
- },
-
- removeGetter: function(block){
- this.getters.splice(this.getters.indexOf(block),1);
- },
-
- onchange: function(event){
- if(event.blockId == this.id && event.type == Blockly.Events.BLOCK_CHANGE &&
- event.element == 'field'){
- this.getters.forEach(block => block.setFieldValue(event.newValue,'VAR'));
- };
}
};
Blockly.Blocks.variables_get = {
@@ -4860,17 +4931,17 @@
this.jsonInit({
"type": "variables_get",
"message0": "%1",
"args0": [
{
- "type": "field_label",
+ "type": "field_input",
"name": "VAR",
"text": "nombre de variable"
}
],
"output": null,
- "colour": 230,
+ "colour": Blockly.CUSTOM_COLORS.variable,
"tooltip": "",
"helpUrl": "",
});
},
mutationToDom: function() {
@@ -4884,13 +4955,20 @@
this.setFieldValue(var_name, 'VAR');
this.$parent = xmlElement.getAttribute("parent") || null;
},
onchange: function(event){
- if(event.blockId == this.id && event.type == Blockly.Events.BLOCK_DELETE){
- this.parentAssignmentBlock.removeGetter(this);
+ if (this.$parent) {
+ this.getField("VAR").EDITABLE = false;
+ this.setColour(Blockly.CUSTOM_COLORS.parameter);
+ } else {
+ this.setColour(Blockly.CUSTOM_COLORS.variable);
}
+
+ if (event.blockId == this.id && event.type == Blockly.Events.BLOCK_DELETE) {
+ // do something with parent
+ }
}
};
Blockly.Blocks.not = createSingleParameterExpressionBlock('no','Bool');
Blockly.Blocks.siguiente = createSingleParameterExpressionBlock('siguiente','*');
@@ -5267,10 +5345,11 @@
};
Blockly.GobstonesLanguage.OperadorLogico = function(block) {
// Operations 'and', 'or'.
var operator = block.getFieldValue('OPERATOR');
+ if (operator === "AND") operator = "&&";
var order = (operator == '&&') ? Blockly.GobstonesLanguage.ORDER_LOGICAL_AND : Blockly.GobstonesLanguage.ORDER_LOGICAL_OR;
var argument0 = Blockly.GobstonesLanguage.valueToCode(block, 'arg1', order) || '()';
var argument1 = Blockly.GobstonesLanguage.valueToCode(block, 'arg2', order) || '()';
/* Este código lo comento porque creo que prefiero que estalle gobstones web
if (!argument0 && !argument1) {
@@ -5952,11 +6031,11 @@
const addCustomActionsChilds = (ttree) => {
for (var item of ttree) {
if (item.type !== "category") continue;
- if (item.name === BLOCKLY_PRIMITIVE_PROCEDURES)
+ if (item.name === categoryName)
item.child = customTree;
else
addCustomActionsChilds(item.child);
}
};
@@ -6002,13 +6081,13 @@
xml.push('</xml>');
}
return xml.join('\n');
},
- _getPartsByConvention(name) {
+ _getPartsByConvention(isProcedure, name) {
let parts = name.replace(/([A-Z])/g, " $1").toLowerCase();
- parts = parts[1].toUpperCase() + parts.substring(2);
+ if (isProcedure) parts = parts[1].toUpperCase() + parts.substring(2);
parts = this._getParts(parts);
return parts;
},
@@ -6023,18 +6102,18 @@
const name = this._getPrimitiveName(definition);
const customName = definition.attributes && definition.attributes.block_name;
const icon = definition.attributes && definition.attributes.block_icon;
const finalName = customName || name;
- const parts = (customName ? this._getParts : this._getPartsByConvention)
+ const parts = (customName ? this._getParts : this._getPartsByConvention.bind(this, true))
.bind(this)(finalName);
// Bloque
Blockly.Blocks[name] = {
init: function () {
let argsIndex = 1;
- this.setColour(Blockly.GOBSTONES_COLORS.primitiveCommand);
+ this.setColour(Blockly.CUSTOM_COLORS.primitiveProcedure);
if (icon) {
this.appendDummyInput().appendField(new Blockly.FieldImage(
icon,
16,
@@ -6083,18 +6162,18 @@
const name = this._getPrimitiveName(definition);
const customName = definition.attributes && definition.attributes.block_name;
const icon = definition.attributes && definition.attributes.block_icon;
const finalName = customName || name;
- const parts = (customName ? this._getParts : this._getPartsByConvention)
+ const parts = (customName ? this._getParts : this._getPartsByConvention.bind(this, false))
.bind(this)(finalName);
// Bloque
Blockly.Blocks[name] = {
init: function () {
let argsIndex = 1;
- this.setColour(Blockly.GOBSTONES_COLORS.primitiveCommand);
+ this.setColour(Blockly.CUSTOM_COLORS.primitiveFunction);
if (icon) {
this.appendDummyInput().appendField(new Blockly.FieldImage(
icon,
16,
@@ -6237,11 +6316,14 @@
}
}
},
_onWorkspaceUpdate: function () {
- if(this.workspaceXml != this._blocklyWorkspaceXML) {
+ const hasReloadedXml = this._runWorkspaceXmlRetrocompatibilityFixes();
+ if (hasReloadedXml) return;
+
+ if (this.workspaceXml != this._blocklyWorkspaceXML) {
this.workspace.clear();
let dom = Blockly.Xml.textToDom(this.workspaceXml);
try {
Blockly.Xml.domToWorkspace(dom, this.workspace);
} catch (e) {
@@ -6256,10 +6338,20 @@
}
}
}
},
+ _runWorkspaceXmlRetrocompatibilityFixes: function() {
+ const oldAndOperator = `<field name="OPERATOR">&&</field>`;
+ const newAndOperator = `<field name="OPERATOR">AND</field>`;
+
+ if (this.workspaceXml.includes(oldAndOperator)) {
+ this.workspaceXml = this.workspaceXml.replace(new RegExp(oldAndOperator, "g"), newAndOperator);
+ return true;
+ }
+ },
+
/**
* Reinicializa el workspace, dejando solo el bloque programa
*/
resetWorkspace: function() {
let xmlInicial = '<xml xmlns="http://www.w3.org/1999/xhtml"><block type="Program" x="30" y="30"></block></xml>';
@@ -6470,19 +6562,21 @@
showBlockError: function(blockId, errorKind) {
this.workspace.showBlockError(blockId, errorKind);
},
testColors(colors) {
- Blockly.GOBSTONES_COLORS = colors;
+ Blockly.CUSTOM_COLORS = colors;
Blockly.HSV_SATURATION = colors.globalHsvSaturation;
Blockly.HSV_VALUE = colors.globalHsvValue;
- Blockly.Constants.Math.HUE = colors.literalExpression;
- Blockly.Msg.MATH_HUE = colors.literalExpression.toString();
Blockly.Blocks.procedures.HUE = colors.procedure;
- var xml = Blockly.Xml.workspaceToDom(this.workspace);
+ var xmlDom = Blockly.Xml.workspaceToDom(this.workspace);
+ const xml = Blockly.Xml.domToText(xmlDom);
this.resetWorkspace();
- Blockly.Xml.domToWorkspace(xml, this.workspace);
+
+ setTimeout(() => {
+ this.workspaceXml = xml;
+ }, 0);
}
});
</script>
</dom-module>
</body></html>
\ No newline at end of file