app/assets/htmls/gs-element-blockly.html in gobstones-blockly-0.28.1 vs app/assets/htmls/gs-element-blockly.html in gobstones-blockly-0.29.0

- old
+ new

@@ -3312,11 +3312,11 @@ };</script> <script>var PLUS = ""; var MINUS = ""; var HAND = ""; -window.initProcedsBlockly = function(customStatementType) { +window.initProcedsBlockly = function(customStatementType, initialize = () => {}) { Blockly.Msg.PROCEDURES_DEFNORETURN_COMMENT = 'Describe el procedimiento...'; Blockly.Msg.PROCEDURES_DEFNORETURN_PROCEDURE = "Hacer algo"; Blockly.Msg.PROCEDURES_DEFNORETURN_TITLE = "Definir"; Blockly.Msg.PROCEDURES_DEFNORETURN_NOPARAMS = ""; Blockly.Msg.PROCEDURES_DEFRETURN_NOPARAMS = ""; @@ -3534,11 +3534,21 @@ addParameter(this, i, name); }.bind(this)); }; } - var makeProcedureInit = function(withReturn, withStatements = true, withParameters = false, defaultName, title, comment, tooltip, helpUrl) { + var makeProcedureInit = function( + withReturn, + withStatements = true, + withParameters = false, + defaultName, + title, + comment, + tooltip, + helpUrl, + returnMsg = Blockly.Msg.PROCEDURES_DEFRETURN_RETURN + ) { return function() { var defaultLegalName = Blockly.Procedures.findLegalName(defaultName, this); var nameField = new Blockly.FieldTextInput(defaultLegalName, Blockly.Procedures.rename); nameField.setSpellcheck(false); @@ -3562,11 +3572,11 @@ input.appendField(addParameterButton); if (withReturn) this.appendValueInput('RETURN') .setAlign(Blockly.ALIGN_RIGHT) - .appendField(Blockly.Msg.PROCEDURES_DEFRETURN_RETURN); + .appendField(returnMsg); // if (withParametersMutator) // this.setMutator(new Blockly.Mutator(['procedures_mutatorarg'])); if ((this.workspace.options.comments || @@ -3864,11 +3874,21 @@ onchange: Blockly.Blocks['procedures_callreturn'].onchange, customContextMenu: Blockly.Blocks['procedures_callreturn'].customContextMenu, defType_: 'procedures_defreturnsimple' }; - // ------------------------------------------------------------------- + // --------------------------------------------------------------- + // [!] Calling `initialize` to support another types of procedures + // --------------------------------------------------------------- + initialize( + makeProcedureInit, + makeUpdateParams, + makeProcedureDomToMutation, + makeProcedureCustomMenu + ); + + // ------------------------------------------------------------------- // [!] Adding two flyoutCategories: PROCEDURE_CALLS and FUNCTION_CALLS // ------------------------------------------------------------------- Blockly.Procedures.procedureCallFlyoutCategory = function(workspace) { var xmlList = []; @@ -4033,13 +4053,126 @@ this.workspace_.addChangeListener(this.reflowWrapper_); }; } </script> - <script>initProcedsBlockly("Statement");</script> <script>/* global Blockly */ +// Initialize proceds-blockly creating new custom functions +initProcedsBlockly("Statement", (makeProcedureInit, makeUpdateParams, makeProcedureDomToMutation, makeProcedureCustomMenu) => { + Blockly.Blocks['DefinicionDeFuncionDeclarativa'] = { + init: makeProcedureInit( + true, true, true, + "algo", + "Definir que", + Blockly.Msg.PROCEDURES_DEFRETURN_COMMENT, + Blockly.Msg.PROCEDURES_DEFRETURN_TOOLTIP, + Blockly.Msg.PROCEDURES_DEFRETURN_HELPURL, + "es igual a" + ), + setStatements_: Blockly.Blocks['procedures_defreturn'].setStatements_, + updateParams_: makeUpdateParams(), + mutationToDom: Blockly.Blocks['procedures_defreturn'].mutationToDom, + domToMutation: makeProcedureDomToMutation(), + decompose: Blockly.Blocks['procedures_defreturn'].decompose, + compose: Blockly.Blocks['procedures_defreturn'].compose, + getProcedureDef: Blockly.Blocks['procedures_defreturn'].getProcedureDef, + getVars: Blockly.Blocks['procedures_defreturn'].getVars, + renameVar: Blockly.Blocks['procedures_defreturn'].renameVar, + customContextMenu: makeProcedureCustomMenu(true), + callType_: 'procedures_callreturndeclarative' + }; + + Blockly.Blocks['procedures_callreturndeclarative'] = { + init: Blockly.Blocks['procedures_callreturn'].init, + getProcedureCall: Blockly.Blocks['procedures_callreturn'].getProcedureCall, + renameProcedure: Blockly.Blocks['procedures_callreturn'].renameProcedure, + setProcedureParameters_: Blockly.Blocks['procedures_callreturn'].setProcedureParameters_, + updateShape_: Blockly.Blocks['procedures_callreturn'].updateShape_, + mutationToDom: Blockly.Blocks['procedures_callreturn'].mutationToDom, + domToMutation: Blockly.Blocks['procedures_callreturn'].domToMutation, + renameVar: Blockly.Blocks['procedures_callreturn'].renameVar, + onchange: Blockly.Blocks['procedures_callreturn'].onchange, + customContextMenu: Blockly.Blocks['procedures_callreturn'].customContextMenu, + defType_: 'DefinicionDeFuncionDeclarativa' + }; + + Blockly.Blocks['DefinicionDeFuncionSimpleConParametrosDeclarativa'] = { + init: makeProcedureInit( + true, false, true, + "algo", + "Definir que", + Blockly.Msg.PROCEDURES_DEFRETURN_COMMENT, + Blockly.Msg.PROCEDURES_DEFRETURN_TOOLTIP, + Blockly.Msg.PROCEDURES_DEFRETURN_HELPURL, + "es igual a" + ), + setStatements_: Blockly.Blocks['procedures_defreturn'].setStatements_, + updateParams_: makeUpdateParams(), + mutationToDom: Blockly.Blocks['procedures_defreturn'].mutationToDom, + domToMutation: makeProcedureDomToMutation(), + decompose: Blockly.Blocks['procedures_defreturn'].decompose, + compose: Blockly.Blocks['procedures_defreturn'].compose, + getProcedureDef: Blockly.Blocks['procedures_defreturn'].getProcedureDef, + getVars: Blockly.Blocks['procedures_defreturn'].getVars, + renameVar: Blockly.Blocks['procedures_defreturn'].renameVar, + customContextMenu: makeProcedureCustomMenu(true), + callType_: 'procedures_callreturndeclarativesimplewithparams' + }; + + Blockly.Blocks['procedures_callreturndeclarativesimplewithparams'] = { + init: Blockly.Blocks['procedures_callreturn'].init, + getProcedureCall: Blockly.Blocks['procedures_callreturn'].getProcedureCall, + renameProcedure: Blockly.Blocks['procedures_callreturn'].renameProcedure, + setProcedureParameters_: Blockly.Blocks['procedures_callreturn'].setProcedureParameters_, + updateShape_: Blockly.Blocks['procedures_callreturn'].updateShape_, + mutationToDom: Blockly.Blocks['procedures_callreturn'].mutationToDom, + domToMutation: Blockly.Blocks['procedures_callreturn'].domToMutation, + renameVar: Blockly.Blocks['procedures_callreturn'].renameVar, + onchange: Blockly.Blocks['procedures_callreturn'].onchange, + customContextMenu: Blockly.Blocks['procedures_callreturn'].customContextMenu, + defType_: 'DefinicionDeFuncionSimpleConParametrosDeclarativa' + }; + + Blockly.Blocks['DefinicionDeFuncionSimpleDeclarativa'] = { + init: makeProcedureInit( + true, false, false, + "algo", + "Definir que", + Blockly.Msg.PROCEDURES_DEFRETURN_COMMENT, + Blockly.Msg.PROCEDURES_DEFRETURN_TOOLTIP, + Blockly.Msg.PROCEDURES_DEFRETURN_HELPURL, + "es igual a" + ), + setStatements_: Blockly.Blocks['procedures_defreturn'].setStatements_, + updateParams_: makeUpdateParams(), + mutationToDom: Blockly.Blocks['procedures_defreturn'].mutationToDom, + domToMutation: makeProcedureDomToMutation(), + decompose: Blockly.Blocks['procedures_defreturn'].decompose, + compose: Blockly.Blocks['procedures_defreturn'].compose, + getProcedureDef: Blockly.Blocks['procedures_defreturn'].getProcedureDef, + getVars: Blockly.Blocks['procedures_defreturn'].getVars, + renameVar: Blockly.Blocks['procedures_defreturn'].renameVar, + customContextMenu: makeProcedureCustomMenu(false), + callType_: 'procedures_callreturndeclarativesimple' + }; + + Blockly.Blocks['procedures_callreturndeclarativesimple'] = { + init: Blockly.Blocks['procedures_callreturn'].init, + getProcedureCall: Blockly.Blocks['procedures_callreturn'].getProcedureCall, + renameProcedure: Blockly.Blocks['procedures_callreturn'].renameProcedure, + setProcedureParameters_: Blockly.Blocks['procedures_callreturn'].setProcedureParameters_, + updateShape_: Blockly.Blocks['procedures_callreturn'].updateShape_, + mutationToDom: Blockly.Blocks['procedures_callreturn'].mutationToDom, + domToMutation: Blockly.Blocks['procedures_callreturn'].domToMutation, + renameVar: Blockly.Blocks['procedures_callreturn'].renameVar, + onchange: Blockly.Blocks['procedures_callreturn'].onchange, + customContextMenu: Blockly.Blocks['procedures_callreturn'].customContextMenu, + defType_: 'DefinicionDeFuncionSimpleDeclarativa' + }; +}); + 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 EMPTY_GIF = ""; const getOptions = (block) => { @@ -5896,10 +6029,13 @@ }; Blockly.GobstonesLanguage.procedures_defnoreturnnoparams = Blockly.GobstonesLanguage.procedures_defnoreturn; Blockly.GobstonesLanguage.procedures_defreturnsimplewithparams = Blockly.GobstonesLanguage.procedures_defreturn; Blockly.GobstonesLanguage.procedures_defreturnsimple = Blockly.GobstonesLanguage.procedures_defreturn; +Blockly.GobstonesLanguage.DefinicionDeFuncionDeclarativa = Blockly.GobstonesLanguage.procedures_defreturn; +Blockly.GobstonesLanguage.DefinicionDeFuncionSimpleConParametrosDeclarativa = Blockly.GobstonesLanguage.procedures_defreturn; +Blockly.GobstonesLanguage.DefinicionDeFuncionSimpleDeclarativa = Blockly.GobstonesLanguage.procedures_defreturn; var procedureCall = function(block, capitalizeFirst, newLine) { var procName = formatCallName(block.getFieldValue('NAME'),capitalizeFirst); var args = []; for (var i = 0; i < block.arguments_.length; i++) { @@ -5918,9 +6054,12 @@ }; Blockly.GobstonesLanguage.procedures_callnoreturnnoparams = Blockly.GobstonesLanguage.procedures_callnoreturn; Blockly.GobstonesLanguage.procedures_callreturnsimplewithparams = Blockly.GobstonesLanguage.procedures_callreturn; Blockly.GobstonesLanguage.procedures_callreturnsimple = Blockly.GobstonesLanguage.procedures_callreturn; +Blockly.GobstonesLanguage.procedures_callreturndeclarative = Blockly.GobstonesLanguage.procedures_callreturn; +Blockly.GobstonesLanguage.procedures_callreturndeclarativesimplewithparams = Blockly.GobstonesLanguage.procedures_callreturn; +Blockly.GobstonesLanguage.procedures_callreturndeclarativesimple = Blockly.GobstonesLanguage.procedures_callreturn; Blockly.GobstonesLanguage.variables_get = function (block) { var code = formatCallName(block.getFieldValue('VAR'),false,Blockly.VARIABLE_CATEGORY_NAME); return [code, Blockly.GobstonesLanguage.ORDER_ATOMIC]; }; \ No newline at end of file