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