Adding test blocks into the playground (#1629)
The new toolbox option includes a number of test blocks largely pulled from the android project, testing various configurations and edge cases.
BIN
media/test_200px.png
Normal file
|
After Width: | Height: | Size: 2.1 KiB |
BIN
media/test_30px.png
Normal file
|
After Width: | Height: | Size: 1.1 KiB |
BIN
media/test_50px.png
Normal file
|
After Width: | Height: | Size: 1.6 KiB |
BIN
media/test_a.png
Normal file
|
After Width: | Height: | Size: 778 B |
BIN
media/test_b.png
Normal file
|
After Width: | Height: | Size: 769 B |
BIN
media/test_c.png
Normal file
|
After Width: | Height: | Size: 856 B |
BIN
media/test_d.png
Normal file
|
After Width: | Height: | Size: 738 B |
BIN
media/test_e.png
Normal file
|
After Width: | Height: | Size: 393 B |
BIN
media/test_f.png
Normal file
|
After Width: | Height: | Size: 343 B |
BIN
media/test_g.png
Normal file
|
After Width: | Height: | Size: 1.1 KiB |
BIN
media/test_h.png
Normal file
|
After Width: | Height: | Size: 313 B |
BIN
media/test_i.png
Normal file
|
After Width: | Height: | Size: 200 B |
BIN
media/test_j.png
Normal file
|
After Width: | Height: | Size: 453 B |
BIN
media/test_k.png
Normal file
|
After Width: | Height: | Size: 612 B |
BIN
media/test_l.png
Normal file
|
After Width: | Height: | Size: 254 B |
BIN
media/test_m.png
Normal file
|
After Width: | Height: | Size: 1.0 KiB |
493
tests/blocks/test_blocks.js
Normal file
@@ -0,0 +1,493 @@
|
|||||||
|
/**
|
||||||
|
* @license
|
||||||
|
* Blockly Tests
|
||||||
|
*
|
||||||
|
* Copyright 2017 Google Inc.
|
||||||
|
* https://developers.google.com/blockly/
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
Blockly.defineBlocksWithJsonArray([ // BEGIN JSON EXTRACT
|
||||||
|
{
|
||||||
|
"type": "empty_block",
|
||||||
|
"message0": "",
|
||||||
|
"args0": []
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "example_dropdown_long",
|
||||||
|
"message0": "long: %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_dropdown",
|
||||||
|
"name": "FIELDNAME",
|
||||||
|
"options": [
|
||||||
|
[ "first item", "ITEM1" ],
|
||||||
|
[ "second item", "ITEM2" ],
|
||||||
|
[ "third item", "ITEM3" ],
|
||||||
|
[ "fourth item", "ITEM4" ],
|
||||||
|
[ "fifth item", "ITEM5" ],
|
||||||
|
[ "sixth item", "ITEM6" ],
|
||||||
|
[ "seventh item", "ITEM7" ],
|
||||||
|
[ "eighth item", "ITEM8" ],
|
||||||
|
[ "ninth item", "ITEM9" ],
|
||||||
|
[ "tenth item", "ITEM10" ],
|
||||||
|
[ "eleventh item", "ITEM11" ],
|
||||||
|
[ "twelfth item", "ITEM12" ],
|
||||||
|
[ "thirteenth item", "ITEM13" ],
|
||||||
|
[ "fourteenth item", "ITEM14" ],
|
||||||
|
[ "fifteenth item", "ITEM15" ],
|
||||||
|
[ "sixteenth item", "ITEM16" ],
|
||||||
|
[ "seventeenth item", "ITEM17" ],
|
||||||
|
[ "eighteenth item", "ITEM18" ],
|
||||||
|
[ "nineteenth item", "ITEM19" ],
|
||||||
|
[ "twentieth item", "ITEM20" ],
|
||||||
|
[ "twenty-first item", "ITEM21" ],
|
||||||
|
[ "twenty-second item", "ITEM22" ],
|
||||||
|
[ "twenty-third item", "ITEM23" ],
|
||||||
|
[ "twenty-fourth item", "ITEM24" ],
|
||||||
|
[ "twenty-fifth item", "ITEM25" ],
|
||||||
|
[ "twenty-sixth item", "ITEM26" ],
|
||||||
|
[ "twenty-seventh item", "ITEM27" ],
|
||||||
|
[ "twenty-eighth item", "ITEM28" ],
|
||||||
|
[ "twenty-ninth item", "ITEM29" ],
|
||||||
|
[ "thirtieth item", "ITEM30" ],
|
||||||
|
[ "thirty-first item", "ITEM31" ],
|
||||||
|
[ "thirty-second item", "ITEM32" ]
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "example_dropdown_images",
|
||||||
|
"message0": "%1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_dropdown",
|
||||||
|
"name": "FIELDNAME",
|
||||||
|
"options": [
|
||||||
|
[{"src": "../media/test_a.png", "width": 32, "height": 32, "alt": "A"}, "A"],
|
||||||
|
[{"src": "../media/test_b.png", "width": 32, "height": 32, "alt": "B"}, "B"],
|
||||||
|
[{"src": "../media/test_c.png", "width": 32, "height": 32, "alt": "C"}, "C"],
|
||||||
|
[{"src": "../media/test_d.png", "width": 32, "height": 32, "alt": "D"}, "D"],
|
||||||
|
[{"src": "../media/test_e.png", "width": 32, "height": 32, "alt": "E"}, "E"],
|
||||||
|
[{"src": "../media/test_f.png", "width": 32, "height": 32, "alt": "F"}, "F"],
|
||||||
|
[{"src": "../media/test_g.png", "width": 32, "height": 32, "alt": "G"}, "G"],
|
||||||
|
[{"src": "../media/test_h.png", "width": 32, "height": 32, "alt": "H"}, "H"],
|
||||||
|
[{"src": "../media/test_i.png", "width": 32, "height": 32, "alt": "I"}, "I"],
|
||||||
|
[{"src": "../media/test_j.png", "width": 32, "height": 32, "alt": "J"}, "J"],
|
||||||
|
[{"src": "../media/test_k.png", "width": 32, "height": 32, "alt": "K"}, "K"],
|
||||||
|
[{"src": "../media/test_l.png", "width": 32, "height": 32, "alt": "L"}, "L"],
|
||||||
|
[{"src": "../media/test_m.png", "width": 32, "height": 32, "alt": "M"}, "M"]
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "example_angle",
|
||||||
|
"message0": "angle: %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_angle",
|
||||||
|
"name": "FIELDNAME",
|
||||||
|
"angle": "90",
|
||||||
|
"alt":
|
||||||
|
{
|
||||||
|
"type": "field_label",
|
||||||
|
"text": "NO ANGLE FIELD"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "example_date",
|
||||||
|
"message0": "date: %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_date",
|
||||||
|
"name": "FIELDNAME",
|
||||||
|
"date": "2020-02-20",
|
||||||
|
"alt":
|
||||||
|
{
|
||||||
|
"type": "field_label",
|
||||||
|
"text": "NO DATE FIELD"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "test_number",
|
||||||
|
"message0": "float %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_number",
|
||||||
|
"name": "NUM",
|
||||||
|
"text": "0"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 230,
|
||||||
|
"output": "Number",
|
||||||
|
"tooltip": "A number."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "test_integer",
|
||||||
|
"message0": "integer %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_number",
|
||||||
|
"name": "NUM",
|
||||||
|
"precision": 1,
|
||||||
|
"text": "0"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 230,
|
||||||
|
"output": "Number",
|
||||||
|
"tooltip": "An integer."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "test_number_hundredths",
|
||||||
|
"message0": "$ %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_number",
|
||||||
|
"name": "NUM",
|
||||||
|
"precision": 0.01,
|
||||||
|
"text": "0"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 230,
|
||||||
|
"output": "Number",
|
||||||
|
"tooltip": "A dollar amount."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "test_integer_bounded",
|
||||||
|
"message0": "midi note %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_number",
|
||||||
|
"name": "NOTE",
|
||||||
|
"precision": 1,
|
||||||
|
"min": 1,
|
||||||
|
"max": 127,
|
||||||
|
"text": "0"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 230,
|
||||||
|
"output": "Note",
|
||||||
|
"tooltip": "A midi note."
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "image_datauri",
|
||||||
|
"message0": "Image data: URI %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "",
|
||||||
|
"width": 50,
|
||||||
|
"height": 50,
|
||||||
|
"alt": "*"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 160
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "image_small",
|
||||||
|
"message0": "Image too small %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "../media/test_30px.png",
|
||||||
|
"width": 50,
|
||||||
|
"height": 50,
|
||||||
|
"alt": "*"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 160
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "image_large",
|
||||||
|
"message0": "Image too large %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "../media/test_200px.png",
|
||||||
|
"width": 50,
|
||||||
|
"height": 50,
|
||||||
|
"alt": "*"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 160
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "image_missing",
|
||||||
|
"message0": "Image missing %1",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "missing.png",
|
||||||
|
"width": 50,
|
||||||
|
"height": 50,
|
||||||
|
"alt": "*"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 160
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "test_with_lots_of_network_icons",
|
||||||
|
"message0": "Lots of network icons: %1 %2 %3 %4 %5 %6 %7 %8 %9 %10 %11 %12 %13 %14 %15 %16 %17 %18",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "input_dummy"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_a.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "A"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_b.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "B"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_c.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "C"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_d.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "D"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_e.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "E"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_f.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "F"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_g.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "G"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_h.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "H"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "input_dummy"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_a.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "A"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_b.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "B"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_c.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "C"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_d.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "D"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_e.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "E"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_f.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "F"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_g.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "G"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_image",
|
||||||
|
"src": "https://blockly-demo.appspot.com/static/media/test_h.png",
|
||||||
|
"width": 32,
|
||||||
|
"height": 32,
|
||||||
|
"alt": "H"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"colour": 160
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "styled_event_cap",
|
||||||
|
"message0": "Hat block (event)",
|
||||||
|
"nextStatement": null,
|
||||||
|
"colour": 330,
|
||||||
|
"style": {
|
||||||
|
"hat": "cap"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "block_colour_hex1",
|
||||||
|
"message0": "Block color: Bright purple %1 %2 %3 %4",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_input",
|
||||||
|
"name": "TEXT",
|
||||||
|
"text": "#992aff"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_dropdown",
|
||||||
|
"name": "DROPDOWN",
|
||||||
|
"options": [
|
||||||
|
[ "option", "ONE" ],
|
||||||
|
[ "option", "TWO" ]
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_checkbox",
|
||||||
|
"name": "NAME",
|
||||||
|
"checked": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "NAME"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"previousStatement": null,
|
||||||
|
"nextStatement": null,
|
||||||
|
"colour": "#992aff"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "block_colour_hex2",
|
||||||
|
"message0": "Block color: White %1 %2 %3 %4",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_input",
|
||||||
|
"name": "TEXT",
|
||||||
|
"text": "#fefefe"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_dropdown",
|
||||||
|
"name": "DROPDOWN",
|
||||||
|
"options": [
|
||||||
|
[ "option", "ONE" ],
|
||||||
|
[ "option", "TWO" ]
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_checkbox",
|
||||||
|
"name": "NAME",
|
||||||
|
"checked": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "NAME"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"previousStatement": null,
|
||||||
|
"nextStatement": null,
|
||||||
|
"colour": "#fefefe"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "block_colour_hex3",
|
||||||
|
"message0": "Block color: Black %1 %2 %3 %4",
|
||||||
|
"args0": [
|
||||||
|
{
|
||||||
|
"type": "field_input",
|
||||||
|
"name": "TEXT",
|
||||||
|
"text": "#010101"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_dropdown",
|
||||||
|
"name": "DROPDOWN",
|
||||||
|
"options": [
|
||||||
|
[ "option", "ONE" ],
|
||||||
|
[ "option", "TWO" ]
|
||||||
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "field_checkbox",
|
||||||
|
"name": "NAME",
|
||||||
|
"checked": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "input_value",
|
||||||
|
"name": "NAME"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"previousStatement": null,
|
||||||
|
"nextStatement": null,
|
||||||
|
"colour": "#010101"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "block_no_colour",
|
||||||
|
"message0": "Block color: unset"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "block_colour_hex4",
|
||||||
|
"message0": "Block color: #RRGGBBAA (invalid)",
|
||||||
|
"colour": "#992aff99"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "block_colour_hex5",
|
||||||
|
"message0": "Block color: #RRGGBB (invalid)",
|
||||||
|
"colour": "#NotHex"
|
||||||
|
}
|
||||||
|
]); // END JSON EXTRACT (Do not delete this comment.)
|
||||||
|
|
||||||
|
Blockly.Blocks['empty_block_with_mutator'] = {
|
||||||
|
init: function() {
|
||||||
|
this.setMutator(new Blockly.Mutator(['math_number']));
|
||||||
|
}
|
||||||
|
};
|
||||||
@@ -64,6 +64,7 @@
|
|||||||
<script src="../blocks/variables.js"></script>
|
<script src="../blocks/variables.js"></script>
|
||||||
<script src="../blocks/variables_dynamic.js"></script>
|
<script src="../blocks/variables_dynamic.js"></script>
|
||||||
<script src="../blocks/procedures.js"></script>
|
<script src="../blocks/procedures.js"></script>
|
||||||
|
<script src="blocks/test_blocks.js"></script>
|
||||||
<script>
|
<script>
|
||||||
'use strict';
|
'use strict';
|
||||||
var workspace = null;
|
var workspace = null;
|
||||||
@@ -326,6 +327,7 @@ h1 {
|
|||||||
<option value="categories">Categories (untyped variables)</option>
|
<option value="categories">Categories (untyped variables)</option>
|
||||||
<option value="categories-typed-variables">Categories (typed variables)</option>
|
<option value="categories-typed-variables">Categories (typed variables)</option>
|
||||||
<option value="simple">Simple</option>
|
<option value="simple">Simple</option>
|
||||||
|
<option value="test-blocks">Test Blocks</option>
|
||||||
</select>
|
</select>
|
||||||
<select name="side" onchange="document.forms.options.submit()">
|
<select name="side" onchange="document.forms.options.submit()">
|
||||||
<option value="start">Start</option>
|
<option value="start">Start</option>
|
||||||
@@ -1048,5 +1050,47 @@ h1 {
|
|||||||
<category name="Variables" colour="310" custom="VARIABLE_DYNAMIC"></category>
|
<category name="Variables" colour="310" custom="VARIABLE_DYNAMIC"></category>
|
||||||
<category name="Functions" colour="290" custom="PROCEDURE"></category>
|
<category name="Functions" colour="290" custom="PROCEDURE"></category>
|
||||||
</xml>
|
</xml>
|
||||||
|
|
||||||
|
<!-- toolbox-test-blocks has a category menu and an auto-closing flyout.
|
||||||
|
The blocks in this toolbox reflect block configurations not used by
|
||||||
|
the standard predefined blocks, and so test alernative block rendering
|
||||||
|
code paths. -->
|
||||||
|
<xml id="toolbox-test-blocks" style="display: none">
|
||||||
|
<category name="Basic">
|
||||||
|
<block type="empty_block"></block>
|
||||||
|
<block type="empty_block_with_mutator"></block>
|
||||||
|
</category>
|
||||||
|
<category name="Fields">
|
||||||
|
<label text="Numbers"></label>
|
||||||
|
<block type="test_number"></block>
|
||||||
|
<block type="test_integer"></block>
|
||||||
|
<block type="test_number_hundredths"></block>
|
||||||
|
<block type="test_integer_bounded"></block>
|
||||||
|
<label text="Drop-downs"></label>
|
||||||
|
<block type="example_dropdown_long"></block>
|
||||||
|
<block type="example_dropdown_images"></block>
|
||||||
|
<label text="Others"></label>
|
||||||
|
<block type="example_angle"></block>
|
||||||
|
<block type="example_date"></block>
|
||||||
|
</category>
|
||||||
|
<category name="Style">
|
||||||
|
<label text="Hats"></label>
|
||||||
|
<block type="styled_event_cap"></block>
|
||||||
|
<label text="Colour"></label>
|
||||||
|
<block type="block_colour_hex1"></block>
|
||||||
|
<block type="block_colour_hex2"></block>
|
||||||
|
<block type="block_colour_hex3"></block>
|
||||||
|
<block type="block_no_colour"></block>
|
||||||
|
<block type="block_colour_hex4"></block>
|
||||||
|
<block type="block_colour_hex5"></block>
|
||||||
|
</category>
|
||||||
|
<category name="Images">
|
||||||
|
<block type="image_datauri"></block>
|
||||||
|
<block type="image_small"></block>
|
||||||
|
<block type="image_large"></block>
|
||||||
|
<block type="image_missing"></block>
|
||||||
|
<block type="test_with_lots_of_network_icons"></block>
|
||||||
|
</category>
|
||||||
|
</xml>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||