app/assets/htmls/gs-element-blockly.html in gobstones-blockly-0.18.1 vs app/assets/htmls/gs-element-blockly.html in gobstones-blockly-0.19.0
- old
+ new
@@ -4033,19 +4033,22 @@
};
}
</script>
<script>initProcedsBlockly("Statement");</script>
- <script>var PLUS = "";
-var MINUS = "";
-var HAND = "";
-var CLEAN = "";
+ <script>/* global Blockly */
-/* global Blockly */
-
Blockly.CUSTOM_COLORS = {"globalHsvSaturation":0.45,"globalHsvValue":0.65,"primitiveCommand":"#1d3c99","assignation":"#051d66","controlStructure":"#0f2b80","literalExpression":"#1d992c","primitiveExpression":"#1d992c","operator":"#0f801c","program":"#8d1bb3","interactiveProgram":"#6e158c","interactiveBinding":"#a11fcc","procedure":"#935ba6","function":"#745380","primitiveProcedure":"#2e4fb3","primitiveFunction":"#2eb33e","procedure_call":"#355bcc","function_call":"#35cc47","variable":"#056610","parameter":"#056610","complete":"#ff0000","H":{"commands":225,"expressions":127,"definitions":285},"S":{"assignation":95,"variable":95,"parameter":95,"primitiveCommand":81,"literalExpression":81,"primitiveExpression":81,"controlStructure":88,"operator":88,"procedure_call":74,"function_call":74,"primitiveProcedure":74,"primitiveFunction":74,"program":85,"interactiveProgram":85,"interactiveBinding":85,"procedure":45,"function":35,"complete":99},"V":{"assignation":40,"variable":40,"parameter":40,"primitiveCommand":60,"literalExpression":60,"primitiveExpression":60,"controlStructure":50,"operator":50,"procedure_call":80,"function_call":80,"primitiveProcedure":70,"primitiveFunction":70,"program":70,"interactiveProgram":55,"interactiveBinding":80,"procedure":65,"function":50,"complete":99}};
+Blockly.AVAILABLE_ICONS = ["bool-false.svg","bool-true.svg","clean.png","color-azul.svg","color-negro.svg","color-rojo.svg","color-verde.svg","direccion-este.svg","direccion-norte.svg","direccion-oeste.svg","direccion-sur.svg","hand.png","minus.png","plus.png"];
+const getOptions = (block) => {
+ const parentWorkspace = block.workspace.options.parentWorkspace;
+ return parentWorkspace && parentWorkspace.options || block.workspace.options
+}
+const getLocalMediaUrl = (block, name) => getOptions(block).localMedia + name;
+const getLocalMediaSize = (name) => Blockly.AVAILABLE_ICONS.includes(name) ? 16 : 0;
+
/**
* Create the svg representation of a block and render
* @name {!string} name of the parameter.
* @this Blockly.Block
*/
@@ -4167,14 +4170,15 @@
},
_addInit() {
this.$init = true;
+ const icon = "minnus.png";
var removeButton = new Blockly.FieldImage(
- MINUS,
- 16,
- 16,
+ getLocalMediaUrl(this, icon),
+ getLocalMediaSize(icon),
+ getLocalMediaSize(icon),
"Eliminar",
function() {
this.$init = false;
this.removeInput("initlabel");
this.removeInput("init");
@@ -4191,14 +4195,15 @@
},
_addTimeout(timeout) {
this.$timeout = timeout;
+ const icon = "minus.png";
var removeButton = new Blockly.FieldImage(
- MINUS,
- 16,
- 16,
+ getLocalMediaUrl(this, icon),
+ getLocalMediaSize(icon),
+ getLocalMediaSize(icon),
"Eliminar",
function() {
this.$timeout = undefined;
this.removeInput("timeoutlabel");
this.removeInput("timeout");
@@ -4274,26 +4279,28 @@
this.appendStatementInput('block').setCheck(["Statement"]);
const self = this;
const input = this.inputList[0];
+ const plusIcon = "plus.png";
+ const cleanIcon = "clean.png";
input.appendField(new Blockly.FieldImage(
- PLUS,
- 16,
- 16,
+ getLocalMediaUrl(this, plusIcon),
+ getLocalMediaSize(plusIcon),
+ getLocalMediaSize(plusIcon),
"Agregar modificador",
function() {
const modifiersCount = getModifierFields(self).length / 2;
if (modifiersCount >= modifiers.length) return;
self._addModifier();
}
));
input.appendField(new Blockly.FieldImage(
- CLEAN,
- 16,
- 16,
+ getLocalMediaUrl(this, cleanIcon),
+ getLocalMediaSize(cleanIcon),
+ getLocalMediaSize(cleanIcon),
"Limpiar modificadores",
function() {
self._cleanModifiers();
}
));
@@ -4423,11 +4430,11 @@
Blockly.Blocks.AlternativaSimple = {
init: function () {
this.jsonInit({
type: "Statement",
previousStatement: "Statement",
- nextStatement: "Statement",
+ nextStatement: "Statement"
});
this.setColour(Blockly.CUSTOM_COLORS.AlternativaSimple || Blockly.CUSTOM_COLORS.controlStructure);
this.appendValueInput('condicion')
.appendField(Blockly.Msg["CONTROLS_IF_MSG_IF"]);
@@ -4550,16 +4557,24 @@
// Comandos:
// ------------------------------------------------------
Blockly.Blocks.Poner = {
init: function () {
+ const icon = "putStone.png";
+
this.jsonInit({
- message0: 'Poner %1',
+ message0: '%1 Poner %2',
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
args0: [
+ {
+ "type": "field_image",
+ "src": getLocalMediaUrl(this, icon),
+ "width": getLocalMediaSize(icon),
+ "height": getLocalMediaSize(icon)
+ },
{
type: 'input_value',
name: 'COLOR'
}
],
@@ -4570,16 +4585,24 @@
}
};
Blockly.Blocks.Sacar = {
init: function () {
+ const icon = "removeStone.png";
+
this.jsonInit({
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
- message0: 'Sacar %1',
+ message0: '%1 Sacar %2',
args0: [
+ {
+ "type": "field_image",
+ "src": getLocalMediaUrl(this, icon),
+ "width": getLocalMediaSize(icon),
+ "height": getLocalMediaSize(icon)
+ },
{
type: 'input_value',
name: 'COLOR'
}
],
@@ -4590,16 +4613,24 @@
}
};
Blockly.Blocks.Mover = {
init: function () {
+ const icon = "move.png";
+
this.jsonInit({
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
- message0: 'Mover %1',
+ message0: '%1 Mover %2',
args0: [
+ {
+ "type": "field_image",
+ "src": getLocalMediaUrl(this, icon),
+ "width": getLocalMediaSize(icon),
+ "height": getLocalMediaSize(icon)
+ },
{
type: 'input_value',
name: 'DIRECCION'
}
],
@@ -4610,16 +4641,24 @@
}
};
Blockly.Blocks.IrAlBorde = {
init: function () {
+ const icon = "goToEdge.png";
+
this.jsonInit({
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
- message0: 'Ir al borde %1',
+ message0: '%1 Ir al borde %2',
args0: [
+ {
+ "type": "field_image",
+ "src": getLocalMediaUrl(this, icon),
+ "width": getLocalMediaSize(icon),
+ "height": getLocalMediaSize(icon)
+ },
{
type: 'input_value',
name: 'DIRECCION'
}
],
@@ -4630,31 +4669,49 @@
}
};
Blockly.Blocks.VaciarTablero = {
init: function () {
+ const icon = "emptyBoard.png";
+
this.jsonInit({
type: "Statement",
previousStatement: "Statement",
nextStatement: "Statement",
- message0: 'Vaciar tablero',
+ message0: '%1 Vaciar tablero',
+ args0: [
+ {
+ "type": "field_image",
+ "src": getLocalMediaUrl(this, icon),
+ "width": getLocalMediaSize(icon),
+ "height": getLocalMediaSize(icon)
+ },
+ ],
colour: Blockly.CUSTOM_COLORS.VaciarTablero || Blockly.CUSTOM_COLORS.primitiveCommand,
tooltip: 'Vaciar el tablero.',
inputsInline: true
});
}
};
Blockly.Blocks.BOOM = {
init: function () {
+ const icon = "boom.png";
+
this.jsonInit({
"type": "Statement",
"previousStatement": "Statement",
"nextStatement": "Statement",
"lastDummyAlign0": "RIGHT",
- "message0": "Hacer ¡BOOM! porque: %1 %2",
+ "message0": "%1 Hacer ¡BOOM! porque: %2 %3",
"args0": [
+ {
+ "type": "field_image",
+ "src": getLocalMediaUrl(this, icon),
+ "width": getLocalMediaSize(icon),
+ "height": getLocalMediaSize(icon)
+ },
{
"type": "input_dummy"
},
{
"type": "field_input",
@@ -4723,10 +4780,18 @@
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);
+
+ const icon = "number.png";
+ var iconField = new Blockly.FieldImage(
+ getLocalMediaUrl(this, icon),
+ getLocalMediaSize(icon),
+ getLocalMediaSize(icon)
+ );
+ this.inputList[0].insertFieldAt(0, iconField);
this.setColour(Blockly.CUSTOM_COLORS.math_number || Blockly.CUSTOM_COLORS.literalExpression);
}
Blockly.Blocks.ExpresionCompletar = {
init: function () {
@@ -4745,21 +4810,36 @@
function createLiteralSelectorBlock(type,values){
return {
init: function () {
this.jsonInit({
type: type,
- message0: "%1",
- args0: [{
- type: "field_dropdown",
- name: type + "Dropdown",
- options: values.map(value => [value,value]),
- }],
+ message0: "%1 %2",
+ args0: [
+ {
+ "type": "field_image",
+ "src": "",
+ "width": 16,
+ "height": 16
+ },
+ {
+ type: "field_dropdown",
+ name: type + "Dropdown",
+ options: values.map(value => [value,value])
+ }
+ ],
output: type,
colour: Blockly.CUSTOM_COLORS[`${type}Selector`] || Blockly.CUSTOM_COLORS.literalExpression,
tooltip: "Escoger " + type,
});
- }
+ },
+
+ onchange: function(event) {
+ const [image, dropdown] = this.inputList[0].fieldRow;
+ const value = dropdown.getValue();
+
+ image.setValue(getLocalMediaUrl(this, `${type.toLowerCase()}-${value.toLowerCase()}.svg`));
+ }
};
}
Blockly.Blocks.ColorSelector = createLiteralSelectorBlock('Color',['Rojo','Verde','Negro','Azul']);
Blockly.Blocks.DireccionSelector = createLiteralSelectorBlock('Direccion',['Este','Oeste','Norte','Sur']);
@@ -4879,14 +4959,22 @@
}
};
Blockly.Blocks.Asignacion = {
init: function () {
+ const icon = "assignation.png";
+
this.jsonInit({
"type": "asignacion",
- "message0": "Recordar que %1 %2 vale %3 %4",
+ "message0": "%1 Recordar que %2 %3 vale %4 %5",
"args0": [
+ {
+ "type": "field_image",
+ "src": getLocalMediaUrl(this, icon),
+ "width": getLocalMediaSize(icon),
+ "height": getLocalMediaSize(icon)
+ },
{
"type": "field_input",
"name": "varName",
"text": "una variable",
"class": Blockly.Procedures.rename
@@ -4909,14 +4997,16 @@
"tooltip": "",
"helpUrl": ""
});
var self = this;
+
+ const handIcon = "hand.png";
var createGetterButton = new Blockly.FieldImage(
- HAND,
- 16,
- 16,
+ getLocalMediaUrl(this, handIcon),
+ getLocalMediaSize(handIcon),
+ getLocalMediaSize(handIcon),
"Obtener variable",
function() {
var name = self.getFieldValue('varName');
self.createVariableBlock(name);
}
@@ -5865,10 +5955,18 @@
type: String,
value: "../bower_components/blockly-package/media/"
},
/*
+ * `media` path a media de gs-element-blockly.
+ */
+ localMedia: {
+ type: String,
+ value: "../media/"
+ },
+
+ /*
* `readOnly` Use blockly in readOnly mode.
*/
readOnly: {
type: Boolean,
value: false
@@ -6521,18 +6619,19 @@
},
attached: function() {
this._definePrimitiveProcedures();
this._definePrimitiveFunctions();
- // create workspace
+
+ // create workspace
var blocklyDiv = this.$$('#blocklyDiv');
this.blocklyDiv = blocklyDiv;
this._fixSize();
this._fixScroll();
this.workspace = Blockly.inject(blocklyDiv, {
toolbox: this._createToolbox(),
- media: this.get("media"),
+ media: this.media,
toolboxPosition: "start",
scrollbars: true,
horizontalLayout: false,
collapse: true,
css: true,
@@ -6540,9 +6639,11 @@
zoom: {
controls: true,
wheel: true
}
});
+ this.workspace.options.localMedia = this.localMedia;
+
var _this = this;
this.workspace.addChangeListener(function (a, b, c) {
Blockly.Events.disableOrphans(a, b, c);
_this._onBlocklyWorkspaceUpdate();
});
\ No newline at end of file