gobstones-blockly 0.18.1 → 0.19.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/app/assets/htmls/gs-element-blockly.html +139 -38
- data/lib/gobstones/blockly/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 22e54e57e3a61cd5f0694f56ec03ed2ec210d7d5c70fe698aee60565b58cfd03
|
4
|
+
data.tar.gz: c4d7409ce025087cc072521a1486554122a87d761142c9e7c5c3247958764d35
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 528d0a0d53dbe5bbd51d3c642377639bc0486332b5a568455e1e57c85a22307b03b46626ffb7a38ee575afe45f2107a620e4732712bde8ed8667c47bd8622988
|
7
|
+
data.tar.gz: 69388948401273c9e95739d6ad4178555f8bfdd3d4be79fde6ddf983c4e164e03f70e46ae801fb146794b8ec9261a2190f5e9da80cd846da0c07d30e92464e07
|
@@ -4035,14 +4035,17 @@ window.initProcedsBlockly = function(customStatementType) {
|
|
4035
4035
|
}
|
4036
4036
|
</script>
|
4037
4037
|
<script>initProcedsBlockly("Statement");</script>
|
4038
|
-
<script
|
4039
|
-
var MINUS = "";
|
4040
|
-
var HAND = "";
|
4041
|
-
var CLEAN = "";
|
4042
|
-
|
4043
|
-
/* global Blockly */
|
4038
|
+
<script>/* global Blockly */
|
4044
4039
|
|
4045
4040
|
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}};
|
4041
|
+
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"];
|
4042
|
+
|
4043
|
+
const getOptions = (block) => {
|
4044
|
+
const parentWorkspace = block.workspace.options.parentWorkspace;
|
4045
|
+
return parentWorkspace && parentWorkspace.options || block.workspace.options
|
4046
|
+
}
|
4047
|
+
const getLocalMediaUrl = (block, name) => getOptions(block).localMedia + name;
|
4048
|
+
const getLocalMediaSize = (name) => Blockly.AVAILABLE_ICONS.includes(name) ? 16 : 0;
|
4046
4049
|
|
4047
4050
|
/**
|
4048
4051
|
* Create the svg representation of a block and render
|
@@ -4169,10 +4172,11 @@ Blockly.Blocks.InteractiveProgram = {
|
|
4169
4172
|
_addInit() {
|
4170
4173
|
this.$init = true;
|
4171
4174
|
|
4175
|
+
const icon = "minnus.png";
|
4172
4176
|
var removeButton = new Blockly.FieldImage(
|
4173
|
-
|
4174
|
-
|
4175
|
-
|
4177
|
+
getLocalMediaUrl(this, icon),
|
4178
|
+
getLocalMediaSize(icon),
|
4179
|
+
getLocalMediaSize(icon),
|
4176
4180
|
"Eliminar",
|
4177
4181
|
function() {
|
4178
4182
|
this.$init = false;
|
@@ -4193,10 +4197,11 @@ Blockly.Blocks.InteractiveProgram = {
|
|
4193
4197
|
_addTimeout(timeout) {
|
4194
4198
|
this.$timeout = timeout;
|
4195
4199
|
|
4200
|
+
const icon = "minus.png";
|
4196
4201
|
var removeButton = new Blockly.FieldImage(
|
4197
|
-
|
4198
|
-
|
4199
|
-
|
4202
|
+
getLocalMediaUrl(this, icon),
|
4203
|
+
getLocalMediaSize(icon),
|
4204
|
+
getLocalMediaSize(icon),
|
4200
4205
|
"Eliminar",
|
4201
4206
|
function() {
|
4202
4207
|
this.$timeout = undefined;
|
@@ -4276,10 +4281,12 @@ createInteractiveBinding = (name, keys) => {
|
|
4276
4281
|
|
4277
4282
|
const self = this;
|
4278
4283
|
const input = this.inputList[0];
|
4284
|
+
const plusIcon = "plus.png";
|
4285
|
+
const cleanIcon = "clean.png";
|
4279
4286
|
input.appendField(new Blockly.FieldImage(
|
4280
|
-
|
4281
|
-
|
4282
|
-
|
4287
|
+
getLocalMediaUrl(this, plusIcon),
|
4288
|
+
getLocalMediaSize(plusIcon),
|
4289
|
+
getLocalMediaSize(plusIcon),
|
4283
4290
|
"Agregar modificador",
|
4284
4291
|
function() {
|
4285
4292
|
const modifiersCount = getModifierFields(self).length / 2;
|
@@ -4289,9 +4296,9 @@ createInteractiveBinding = (name, keys) => {
|
|
4289
4296
|
}
|
4290
4297
|
));
|
4291
4298
|
input.appendField(new Blockly.FieldImage(
|
4292
|
-
|
4293
|
-
|
4294
|
-
|
4299
|
+
getLocalMediaUrl(this, cleanIcon),
|
4300
|
+
getLocalMediaSize(cleanIcon),
|
4301
|
+
getLocalMediaSize(cleanIcon),
|
4295
4302
|
"Limpiar modificadores",
|
4296
4303
|
function() {
|
4297
4304
|
self._cleanModifiers();
|
@@ -4425,7 +4432,7 @@ Blockly.Blocks.AlternativaSimple = {
|
|
4425
4432
|
this.jsonInit({
|
4426
4433
|
type: "Statement",
|
4427
4434
|
previousStatement: "Statement",
|
4428
|
-
nextStatement: "Statement"
|
4435
|
+
nextStatement: "Statement"
|
4429
4436
|
});
|
4430
4437
|
|
4431
4438
|
this.setColour(Blockly.CUSTOM_COLORS.AlternativaSimple || Blockly.CUSTOM_COLORS.controlStructure);
|
@@ -4552,12 +4559,20 @@ Blockly.Blocks.AlternativaCompleta = {
|
|
4552
4559
|
|
4553
4560
|
Blockly.Blocks.Poner = {
|
4554
4561
|
init: function () {
|
4562
|
+
const icon = "putStone.png";
|
4563
|
+
|
4555
4564
|
this.jsonInit({
|
4556
|
-
message0: 'Poner %
|
4565
|
+
message0: '%1 Poner %2',
|
4557
4566
|
type: "Statement",
|
4558
4567
|
previousStatement: "Statement",
|
4559
4568
|
nextStatement: "Statement",
|
4560
4569
|
args0: [
|
4570
|
+
{
|
4571
|
+
"type": "field_image",
|
4572
|
+
"src": getLocalMediaUrl(this, icon),
|
4573
|
+
"width": getLocalMediaSize(icon),
|
4574
|
+
"height": getLocalMediaSize(icon)
|
4575
|
+
},
|
4561
4576
|
{
|
4562
4577
|
type: 'input_value',
|
4563
4578
|
name: 'COLOR'
|
@@ -4572,12 +4587,20 @@ Blockly.Blocks.Poner = {
|
|
4572
4587
|
|
4573
4588
|
Blockly.Blocks.Sacar = {
|
4574
4589
|
init: function () {
|
4590
|
+
const icon = "removeStone.png";
|
4591
|
+
|
4575
4592
|
this.jsonInit({
|
4576
4593
|
type: "Statement",
|
4577
4594
|
previousStatement: "Statement",
|
4578
4595
|
nextStatement: "Statement",
|
4579
|
-
message0: 'Sacar %
|
4596
|
+
message0: '%1 Sacar %2',
|
4580
4597
|
args0: [
|
4598
|
+
{
|
4599
|
+
"type": "field_image",
|
4600
|
+
"src": getLocalMediaUrl(this, icon),
|
4601
|
+
"width": getLocalMediaSize(icon),
|
4602
|
+
"height": getLocalMediaSize(icon)
|
4603
|
+
},
|
4581
4604
|
{
|
4582
4605
|
type: 'input_value',
|
4583
4606
|
name: 'COLOR'
|
@@ -4592,12 +4615,20 @@ Blockly.Blocks.Sacar = {
|
|
4592
4615
|
|
4593
4616
|
Blockly.Blocks.Mover = {
|
4594
4617
|
init: function () {
|
4618
|
+
const icon = "move.png";
|
4619
|
+
|
4595
4620
|
this.jsonInit({
|
4596
4621
|
type: "Statement",
|
4597
4622
|
previousStatement: "Statement",
|
4598
4623
|
nextStatement: "Statement",
|
4599
|
-
message0: 'Mover %
|
4624
|
+
message0: '%1 Mover %2',
|
4600
4625
|
args0: [
|
4626
|
+
{
|
4627
|
+
"type": "field_image",
|
4628
|
+
"src": getLocalMediaUrl(this, icon),
|
4629
|
+
"width": getLocalMediaSize(icon),
|
4630
|
+
"height": getLocalMediaSize(icon)
|
4631
|
+
},
|
4601
4632
|
{
|
4602
4633
|
type: 'input_value',
|
4603
4634
|
name: 'DIRECCION'
|
@@ -4612,12 +4643,20 @@ Blockly.Blocks.Mover = {
|
|
4612
4643
|
|
4613
4644
|
Blockly.Blocks.IrAlBorde = {
|
4614
4645
|
init: function () {
|
4646
|
+
const icon = "goToEdge.png";
|
4647
|
+
|
4615
4648
|
this.jsonInit({
|
4616
4649
|
type: "Statement",
|
4617
4650
|
previousStatement: "Statement",
|
4618
4651
|
nextStatement: "Statement",
|
4619
|
-
message0: 'Ir al borde %
|
4652
|
+
message0: '%1 Ir al borde %2',
|
4620
4653
|
args0: [
|
4654
|
+
{
|
4655
|
+
"type": "field_image",
|
4656
|
+
"src": getLocalMediaUrl(this, icon),
|
4657
|
+
"width": getLocalMediaSize(icon),
|
4658
|
+
"height": getLocalMediaSize(icon)
|
4659
|
+
},
|
4621
4660
|
{
|
4622
4661
|
type: 'input_value',
|
4623
4662
|
name: 'DIRECCION'
|
@@ -4632,11 +4671,21 @@ Blockly.Blocks.IrAlBorde = {
|
|
4632
4671
|
|
4633
4672
|
Blockly.Blocks.VaciarTablero = {
|
4634
4673
|
init: function () {
|
4674
|
+
const icon = "emptyBoard.png";
|
4675
|
+
|
4635
4676
|
this.jsonInit({
|
4636
4677
|
type: "Statement",
|
4637
4678
|
previousStatement: "Statement",
|
4638
4679
|
nextStatement: "Statement",
|
4639
|
-
message0: 'Vaciar tablero',
|
4680
|
+
message0: '%1 Vaciar tablero',
|
4681
|
+
args0: [
|
4682
|
+
{
|
4683
|
+
"type": "field_image",
|
4684
|
+
"src": getLocalMediaUrl(this, icon),
|
4685
|
+
"width": getLocalMediaSize(icon),
|
4686
|
+
"height": getLocalMediaSize(icon)
|
4687
|
+
},
|
4688
|
+
],
|
4640
4689
|
colour: Blockly.CUSTOM_COLORS.VaciarTablero || Blockly.CUSTOM_COLORS.primitiveCommand,
|
4641
4690
|
tooltip: 'Vaciar el tablero.',
|
4642
4691
|
inputsInline: true
|
@@ -4646,13 +4695,21 @@ Blockly.Blocks.VaciarTablero = {
|
|
4646
4695
|
|
4647
4696
|
Blockly.Blocks.BOOM = {
|
4648
4697
|
init: function () {
|
4698
|
+
const icon = "boom.png";
|
4699
|
+
|
4649
4700
|
this.jsonInit({
|
4650
4701
|
"type": "Statement",
|
4651
4702
|
"previousStatement": "Statement",
|
4652
4703
|
"nextStatement": "Statement",
|
4653
4704
|
"lastDummyAlign0": "RIGHT",
|
4654
|
-
"message0": "Hacer ¡BOOM! porque: %
|
4705
|
+
"message0": "%1 Hacer ¡BOOM! porque: %2 %3",
|
4655
4706
|
"args0": [
|
4707
|
+
{
|
4708
|
+
"type": "field_image",
|
4709
|
+
"src": getLocalMediaUrl(this, icon),
|
4710
|
+
"width": getLocalMediaSize(icon),
|
4711
|
+
"height": getLocalMediaSize(icon)
|
4712
|
+
},
|
4656
4713
|
{
|
4657
4714
|
"type": "input_dummy"
|
4658
4715
|
},
|
@@ -4725,6 +4782,14 @@ const oldMathNumber = Blockly.Blocks.math_number;
|
|
4725
4782
|
Blockly.Blocks.math_number = deepCopyObj(Blockly.Blocks.math_number);
|
4726
4783
|
Blockly.Blocks.math_number.init = function() {
|
4727
4784
|
oldMathNumber.init.call(this);
|
4785
|
+
|
4786
|
+
const icon = "number.png";
|
4787
|
+
var iconField = new Blockly.FieldImage(
|
4788
|
+
getLocalMediaUrl(this, icon),
|
4789
|
+
getLocalMediaSize(icon),
|
4790
|
+
getLocalMediaSize(icon)
|
4791
|
+
);
|
4792
|
+
this.inputList[0].insertFieldAt(0, iconField);
|
4728
4793
|
this.setColour(Blockly.CUSTOM_COLORS.math_number || Blockly.CUSTOM_COLORS.literalExpression);
|
4729
4794
|
}
|
4730
4795
|
|
@@ -4747,17 +4812,32 @@ function createLiteralSelectorBlock(type,values){
|
|
4747
4812
|
init: function () {
|
4748
4813
|
this.jsonInit({
|
4749
4814
|
type: type,
|
4750
|
-
message0: "%1",
|
4751
|
-
args0: [
|
4752
|
-
|
4753
|
-
|
4754
|
-
|
4755
|
-
|
4815
|
+
message0: "%1 %2",
|
4816
|
+
args0: [
|
4817
|
+
{
|
4818
|
+
"type": "field_image",
|
4819
|
+
"src": "",
|
4820
|
+
"width": 16,
|
4821
|
+
"height": 16
|
4822
|
+
},
|
4823
|
+
{
|
4824
|
+
type: "field_dropdown",
|
4825
|
+
name: type + "Dropdown",
|
4826
|
+
options: values.map(value => [value,value])
|
4827
|
+
}
|
4828
|
+
],
|
4756
4829
|
output: type,
|
4757
4830
|
colour: Blockly.CUSTOM_COLORS[`${type}Selector`] || Blockly.CUSTOM_COLORS.literalExpression,
|
4758
4831
|
tooltip: "Escoger " + type,
|
4759
4832
|
});
|
4760
|
-
}
|
4833
|
+
},
|
4834
|
+
|
4835
|
+
onchange: function(event) {
|
4836
|
+
const [image, dropdown] = this.inputList[0].fieldRow;
|
4837
|
+
const value = dropdown.getValue();
|
4838
|
+
|
4839
|
+
image.setValue(getLocalMediaUrl(this, `${type.toLowerCase()}-${value.toLowerCase()}.svg`));
|
4840
|
+
}
|
4761
4841
|
};
|
4762
4842
|
}
|
4763
4843
|
|
@@ -4881,10 +4961,18 @@ Blockly.Blocks.OperadorLogico = {
|
|
4881
4961
|
|
4882
4962
|
Blockly.Blocks.Asignacion = {
|
4883
4963
|
init: function () {
|
4964
|
+
const icon = "assignation.png";
|
4965
|
+
|
4884
4966
|
this.jsonInit({
|
4885
4967
|
"type": "asignacion",
|
4886
|
-
"message0": "Recordar que %
|
4968
|
+
"message0": "%1 Recordar que %2 %3 vale %4 %5",
|
4887
4969
|
"args0": [
|
4970
|
+
{
|
4971
|
+
"type": "field_image",
|
4972
|
+
"src": getLocalMediaUrl(this, icon),
|
4973
|
+
"width": getLocalMediaSize(icon),
|
4974
|
+
"height": getLocalMediaSize(icon)
|
4975
|
+
},
|
4888
4976
|
{
|
4889
4977
|
"type": "field_input",
|
4890
4978
|
"name": "varName",
|
@@ -4911,10 +4999,12 @@ Blockly.Blocks.Asignacion = {
|
|
4911
4999
|
});
|
4912
5000
|
|
4913
5001
|
var self = this;
|
5002
|
+
|
5003
|
+
const handIcon = "hand.png";
|
4914
5004
|
var createGetterButton = new Blockly.FieldImage(
|
4915
|
-
|
4916
|
-
|
4917
|
-
|
5005
|
+
getLocalMediaUrl(this, handIcon),
|
5006
|
+
getLocalMediaSize(handIcon),
|
5007
|
+
getLocalMediaSize(handIcon),
|
4918
5008
|
"Obtener variable",
|
4919
5009
|
function() {
|
4920
5010
|
var name = self.getFieldValue('varName');
|
@@ -5866,6 +5956,14 @@ Blockly.ErrorInforming.CssContent = [
|
|
5866
5956
|
value: "../bower_components/blockly-package/media/"
|
5867
5957
|
},
|
5868
5958
|
|
5959
|
+
/*
|
5960
|
+
* `media` path a media de gs-element-blockly.
|
5961
|
+
*/
|
5962
|
+
localMedia: {
|
5963
|
+
type: String,
|
5964
|
+
value: "../media/"
|
5965
|
+
},
|
5966
|
+
|
5869
5967
|
/*
|
5870
5968
|
* `readOnly` Use blockly in readOnly mode.
|
5871
5969
|
*/
|
@@ -6523,14 +6621,15 @@ Blockly.ErrorInforming.CssContent = [
|
|
6523
6621
|
attached: function() {
|
6524
6622
|
this._definePrimitiveProcedures();
|
6525
6623
|
this._definePrimitiveFunctions();
|
6526
|
-
|
6624
|
+
|
6625
|
+
// create workspace
|
6527
6626
|
var blocklyDiv = this.$$('#blocklyDiv');
|
6528
6627
|
this.blocklyDiv = blocklyDiv;
|
6529
6628
|
this._fixSize();
|
6530
6629
|
this._fixScroll();
|
6531
6630
|
this.workspace = Blockly.inject(blocklyDiv, {
|
6532
6631
|
toolbox: this._createToolbox(),
|
6533
|
-
media: this.
|
6632
|
+
media: this.media,
|
6534
6633
|
toolboxPosition: "start",
|
6535
6634
|
scrollbars: true,
|
6536
6635
|
horizontalLayout: false,
|
@@ -6542,6 +6641,8 @@ Blockly.ErrorInforming.CssContent = [
|
|
6542
6641
|
wheel: true
|
6543
6642
|
}
|
6544
6643
|
});
|
6644
|
+
this.workspace.options.localMedia = this.localMedia;
|
6645
|
+
|
6545
6646
|
var _this = this;
|
6546
6647
|
this.workspace.addChangeListener(function (a, b, c) {
|
6547
6648
|
Blockly.Events.disableOrphans(a, b, c);
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: gobstones-blockly
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.19.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Rodrigo Alfonso
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2018-08-
|
11
|
+
date: 2018-08-22 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|