scratch-blocks 2.0.0-beta.1 → 2.0.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1064) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/package.json +1 -1
  3. package/blockly-rc/.eslintignore +0 -28
  4. package/blockly-rc/.eslintrc.js +0 -187
  5. package/blockly-rc/.gitattributes +0 -1
  6. package/blockly-rc/.github/CODEOWNERS +0 -1
  7. package/blockly-rc/.github/CONTRIBUTING.md +0 -46
  8. package/blockly-rc/.github/ISSUE_TEMPLATE/bug_report.yaml +0 -58
  9. package/blockly-rc/.github/ISSUE_TEMPLATE/config.yml +0 -7
  10. package/blockly-rc/.github/ISSUE_TEMPLATE/documentation.yaml +0 -38
  11. package/blockly-rc/.github/ISSUE_TEMPLATE/feature_request.yaml +0 -39
  12. package/blockly-rc/.github/PULL_REQUEST_TEMPLATE.md +0 -42
  13. package/blockly-rc/.github/dependabot.yml +0 -27
  14. package/blockly-rc/.github/release.yml +0 -32
  15. package/blockly-rc/.github/workflows/appengine_deploy.yml +0 -54
  16. package/blockly-rc/.github/workflows/assign_reviewers.yml +0 -41
  17. package/blockly-rc/.github/workflows/browser_test.yml +0 -55
  18. package/blockly-rc/.github/workflows/build.yml +0 -86
  19. package/blockly-rc/.github/workflows/conventional-label.yml +0 -17
  20. package/blockly-rc/.github/workflows/develop_freeze.yml +0 -26
  21. package/blockly-rc/.github/workflows/tag_module_cleanup.yml +0 -37
  22. package/blockly-rc/.github/workflows/welcome_new_contributors.yml +0 -36
  23. package/blockly-rc/.prettierignore +0 -30
  24. package/blockly-rc/.prettierrc.js +0 -13
  25. package/blockly-rc/CHANGELOG.md +0 -77
  26. package/blockly-rc/LICENSE +0 -202
  27. package/blockly-rc/README.md +0 -80
  28. package/blockly-rc/_config.yml +0 -1
  29. package/blockly-rc/api-extractor.json +0 -385
  30. package/blockly-rc/appengine/.gcloudignore +0 -20
  31. package/blockly-rc/appengine/README.txt +0 -42
  32. package/blockly-rc/appengine/add_timestamps.py +0 -69
  33. package/blockly-rc/appengine/app.yaml +0 -104
  34. package/blockly-rc/appengine/apple-touch-icon.png +0 -0
  35. package/blockly-rc/appengine/blockly_compressed.js +0 -11
  36. package/blockly-rc/appengine/expiration.py +0 -52
  37. package/blockly-rc/appengine/favicon.ico +0 -0
  38. package/blockly-rc/appengine/index.yaml +0 -11
  39. package/blockly-rc/appengine/main.py +0 -39
  40. package/blockly-rc/appengine/redirect.html +0 -107
  41. package/blockly-rc/appengine/requirements.txt +0 -1
  42. package/blockly-rc/appengine/robots.txt +0 -2
  43. package/blockly-rc/appengine/storage.js +0 -190
  44. package/blockly-rc/appengine/storage.py +0 -125
  45. package/blockly-rc/blocks/blocks.ts +0 -44
  46. package/blockly-rc/blocks/lists.ts +0 -1085
  47. package/blockly-rc/blocks/logic.ts +0 -712
  48. package/blockly-rc/blocks/loops.ts +0 -408
  49. package/blockly-rc/blocks/math.ts +0 -591
  50. package/blockly-rc/blocks/procedures.ts +0 -1364
  51. package/blockly-rc/blocks/text.ts +0 -1007
  52. package/blockly-rc/blocks/variables.ts +0 -183
  53. package/blockly-rc/blocks/variables_dynamic.ts +0 -194
  54. package/blockly-rc/core/any_aliases.ts +0 -8
  55. package/blockly-rc/core/block.ts +0 -2523
  56. package/blockly-rc/core/block_animations.ts +0 -225
  57. package/blockly-rc/core/block_flyout_inflater.ts +0 -262
  58. package/blockly-rc/core/block_svg.ts +0 -1768
  59. package/blockly-rc/core/blockly.ts +0 -605
  60. package/blockly-rc/core/blockly_options.ts +0 -71
  61. package/blockly-rc/core/blocks.ts +0 -18
  62. package/blockly-rc/core/browser_events.ts +0 -244
  63. package/blockly-rc/core/bubbles/bubble.ts +0 -658
  64. package/blockly-rc/core/bubbles/mini_workspace_bubble.ts +0 -280
  65. package/blockly-rc/core/bubbles/text_bubble.ts +0 -103
  66. package/blockly-rc/core/bubbles/textinput_bubble.ts +0 -344
  67. package/blockly-rc/core/bubbles.ts +0 -12
  68. package/blockly-rc/core/bump_objects.ts +0 -192
  69. package/blockly-rc/core/button_flyout_inflater.ts +0 -63
  70. package/blockly-rc/core/clipboard/block_paster.ts +0 -142
  71. package/blockly-rc/core/clipboard/registry.ts +0 -31
  72. package/blockly-rc/core/clipboard/workspace_comment_paster.ts +0 -94
  73. package/blockly-rc/core/clipboard.ts +0 -113
  74. package/blockly-rc/core/comments/comment_view.ts +0 -899
  75. package/blockly-rc/core/comments/rendered_workspace_comment.ts +0 -297
  76. package/blockly-rc/core/comments/workspace_comment.ts +0 -237
  77. package/blockly-rc/core/comments.ts +0 -9
  78. package/blockly-rc/core/common.ts +0 -305
  79. package/blockly-rc/core/component_manager.ts +0 -235
  80. package/blockly-rc/core/config.ts +0 -65
  81. package/blockly-rc/core/connection.ts +0 -793
  82. package/blockly-rc/core/connection_checker.ts +0 -348
  83. package/blockly-rc/core/connection_db.ts +0 -297
  84. package/blockly-rc/core/connection_type.ts +0 -21
  85. package/blockly-rc/core/constants.ts +0 -23
  86. package/blockly-rc/core/contextmenu.ts +0 -268
  87. package/blockly-rc/core/contextmenu_items.ts +0 -700
  88. package/blockly-rc/core/contextmenu_registry.ts +0 -194
  89. package/blockly-rc/core/css.ts +0 -481
  90. package/blockly-rc/core/delete_area.ts +0 -77
  91. package/blockly-rc/core/dialog.ts +0 -121
  92. package/blockly-rc/core/drag_target.ts +0 -97
  93. package/blockly-rc/core/dragging/block_drag_strategy.ts +0 -454
  94. package/blockly-rc/core/dragging/bubble_drag_strategy.ts +0 -52
  95. package/blockly-rc/core/dragging/comment_drag_strategy.ts +0 -91
  96. package/blockly-rc/core/dragging/dragger.ts +0 -163
  97. package/blockly-rc/core/dragging.ts +0 -12
  98. package/blockly-rc/core/dropdowndiv.ts +0 -768
  99. package/blockly-rc/core/events/events.ts +0 -163
  100. package/blockly-rc/core/events/events_abstract.ts +0 -130
  101. package/blockly-rc/core/events/events_block_base.ts +0 -88
  102. package/blockly-rc/core/events/events_block_change.ts +0 -259
  103. package/blockly-rc/core/events/events_block_create.ts +0 -185
  104. package/blockly-rc/core/events/events_block_delete.ts +0 -182
  105. package/blockly-rc/core/events/events_block_drag.ts +0 -116
  106. package/blockly-rc/core/events/events_block_field_intermediate_change.ts +0 -167
  107. package/blockly-rc/core/events/events_block_move.ts +0 -307
  108. package/blockly-rc/core/events/events_bubble_open.ts +0 -120
  109. package/blockly-rc/core/events/events_click.ts +0 -110
  110. package/blockly-rc/core/events/events_comment_base.ts +0 -126
  111. package/blockly-rc/core/events/events_comment_change.ts +0 -161
  112. package/blockly-rc/core/events/events_comment_collapse.ts +0 -103
  113. package/blockly-rc/core/events/events_comment_create.ts +0 -118
  114. package/blockly-rc/core/events/events_comment_delete.ts +0 -117
  115. package/blockly-rc/core/events/events_comment_drag.ts +0 -99
  116. package/blockly-rc/core/events/events_comment_move.ts +0 -207
  117. package/blockly-rc/core/events/events_comment_resize.ts +0 -174
  118. package/blockly-rc/core/events/events_marker_move.ts +0 -134
  119. package/blockly-rc/core/events/events_selected.ts +0 -98
  120. package/blockly-rc/core/events/events_theme_change.ts +0 -84
  121. package/blockly-rc/core/events/events_toolbox_item_select.ts +0 -96
  122. package/blockly-rc/core/events/events_trashcan_open.ts +0 -88
  123. package/blockly-rc/core/events/events_ui_base.ts +0 -47
  124. package/blockly-rc/core/events/events_var_base.ts +0 -89
  125. package/blockly-rc/core/events/events_var_create.ts +0 -129
  126. package/blockly-rc/core/events/events_var_delete.ts +0 -124
  127. package/blockly-rc/core/events/events_var_rename.ts +0 -133
  128. package/blockly-rc/core/events/events_var_type_change.ts +0 -122
  129. package/blockly-rc/core/events/events_viewport.ts +0 -149
  130. package/blockly-rc/core/events/utils.ts +0 -595
  131. package/blockly-rc/core/events/workspace_events.ts +0 -46
  132. package/blockly-rc/core/extensions.ts +0 -491
  133. package/blockly-rc/core/field.ts +0 -1471
  134. package/blockly-rc/core/field_checkbox.ts +0 -271
  135. package/blockly-rc/core/field_dropdown.ts +0 -857
  136. package/blockly-rc/core/field_image.ts +0 -297
  137. package/blockly-rc/core/field_input.ts +0 -755
  138. package/blockly-rc/core/field_label.ts +0 -150
  139. package/blockly-rc/core/field_label_serializable.ts +0 -73
  140. package/blockly-rc/core/field_number.ts +0 -381
  141. package/blockly-rc/core/field_registry.ts +0 -115
  142. package/blockly-rc/core/field_textinput.ts +0 -117
  143. package/blockly-rc/core/field_variable.ts +0 -651
  144. package/blockly-rc/core/flyout_base.ts +0 -968
  145. package/blockly-rc/core/flyout_button.ts +0 -416
  146. package/blockly-rc/core/flyout_horizontal.ts +0 -374
  147. package/blockly-rc/core/flyout_metrics_manager.ts +0 -90
  148. package/blockly-rc/core/flyout_separator.ts +0 -61
  149. package/blockly-rc/core/flyout_vertical.ts +0 -353
  150. package/blockly-rc/core/generator.ts +0 -611
  151. package/blockly-rc/core/gesture.ts +0 -1191
  152. package/blockly-rc/core/grid.ts +0 -252
  153. package/blockly-rc/core/icons/comment_icon.ts +0 -435
  154. package/blockly-rc/core/icons/exceptions.ts +0 -23
  155. package/blockly-rc/core/icons/icon.ts +0 -147
  156. package/blockly-rc/core/icons/icon_types.ts +0 -32
  157. package/blockly-rc/core/icons/mutator_icon.ts +0 -354
  158. package/blockly-rc/core/icons/registry.ts +0 -33
  159. package/blockly-rc/core/icons/warning_icon.ts +0 -219
  160. package/blockly-rc/core/icons.ts +0 -24
  161. package/blockly-rc/core/inject.ts +0 -428
  162. package/blockly-rc/core/inputs/align.ts +0 -14
  163. package/blockly-rc/core/inputs/dummy_input.ts +0 -26
  164. package/blockly-rc/core/inputs/end_row_input.ts +0 -31
  165. package/blockly-rc/core/inputs/input.ts +0 -318
  166. package/blockly-rc/core/inputs/input_types.ts +0 -27
  167. package/blockly-rc/core/inputs/statement_input.ts +0 -34
  168. package/blockly-rc/core/inputs/value_input.ts +0 -30
  169. package/blockly-rc/core/inputs.ts +0 -23
  170. package/blockly-rc/core/insertion_marker_manager.ts +0 -742
  171. package/blockly-rc/core/insertion_marker_previewer.ts +0 -254
  172. package/blockly-rc/core/interfaces/i_ast_node_location.ts +0 -12
  173. package/blockly-rc/core/interfaces/i_ast_node_location_svg.ts +0 -28
  174. package/blockly-rc/core/interfaces/i_ast_node_location_with_block.ts +0 -22
  175. package/blockly-rc/core/interfaces/i_autohideable.ts +0 -22
  176. package/blockly-rc/core/interfaces/i_bounded_element.ts +0 -30
  177. package/blockly-rc/core/interfaces/i_bubble.ts +0 -63
  178. package/blockly-rc/core/interfaces/i_collapsible_toolbox_item.ts +0 -33
  179. package/blockly-rc/core/interfaces/i_comment_icon.ts +0 -47
  180. package/blockly-rc/core/interfaces/i_component.ts +0 -19
  181. package/blockly-rc/core/interfaces/i_connection_checker.ts +0 -100
  182. package/blockly-rc/core/interfaces/i_connection_previewer.ts +0 -50
  183. package/blockly-rc/core/interfaces/i_contextmenu.ts +0 -16
  184. package/blockly-rc/core/interfaces/i_copyable.ts +0 -31
  185. package/blockly-rc/core/interfaces/i_deletable.ts +0 -34
  186. package/blockly-rc/core/interfaces/i_delete_area.ts +0 -28
  187. package/blockly-rc/core/interfaces/i_drag_target.ts +0 -69
  188. package/blockly-rc/core/interfaces/i_draggable.ts +0 -72
  189. package/blockly-rc/core/interfaces/i_dragger.ts +0 -35
  190. package/blockly-rc/core/interfaces/i_flyout.ts +0 -189
  191. package/blockly-rc/core/interfaces/i_flyout_inflater.ts +0 -41
  192. package/blockly-rc/core/interfaces/i_has_bubble.ts +0 -20
  193. package/blockly-rc/core/interfaces/i_icon.ts +0 -114
  194. package/blockly-rc/core/interfaces/i_keyboard_accessible.ts +0 -21
  195. package/blockly-rc/core/interfaces/i_legacy_procedure_blocks.ts +0 -50
  196. package/blockly-rc/core/interfaces/i_metrics_manager.ts +0 -149
  197. package/blockly-rc/core/interfaces/i_movable.ts +0 -19
  198. package/blockly-rc/core/interfaces/i_observable.ts +0 -24
  199. package/blockly-rc/core/interfaces/i_parameter_model.ts +0 -51
  200. package/blockly-rc/core/interfaces/i_paster.ts +0 -25
  201. package/blockly-rc/core/interfaces/i_positionable.ts +0 -33
  202. package/blockly-rc/core/interfaces/i_procedure_block.ts +0 -27
  203. package/blockly-rc/core/interfaces/i_procedure_map.ts +0 -18
  204. package/blockly-rc/core/interfaces/i_procedure_model.ts +0 -71
  205. package/blockly-rc/core/interfaces/i_registrable.ts +0 -12
  206. package/blockly-rc/core/interfaces/i_rendered_element.ts +0 -22
  207. package/blockly-rc/core/interfaces/i_selectable.ts +0 -34
  208. package/blockly-rc/core/interfaces/i_selectable_toolbox_item.ts +0 -63
  209. package/blockly-rc/core/interfaces/i_serializable.ts +0 -28
  210. package/blockly-rc/core/interfaces/i_serializer.ts +0 -55
  211. package/blockly-rc/core/interfaces/i_styleable.ts +0 -26
  212. package/blockly-rc/core/interfaces/i_toolbox.ts +0 -112
  213. package/blockly-rc/core/interfaces/i_toolbox_item.ts +0 -81
  214. package/blockly-rc/core/interfaces/i_variable_backed_parameter_model.ts +0 -23
  215. package/blockly-rc/core/interfaces/i_variable_map.ts +0 -65
  216. package/blockly-rc/core/interfaces/i_variable_model.ts +0 -57
  217. package/blockly-rc/core/internal_constants.ts +0 -47
  218. package/blockly-rc/core/keyboard_nav/ast_node.ts +0 -884
  219. package/blockly-rc/core/keyboard_nav/basic_cursor.ts +0 -223
  220. package/blockly-rc/core/keyboard_nav/cursor.ts +0 -138
  221. package/blockly-rc/core/keyboard_nav/marker.ts +0 -113
  222. package/blockly-rc/core/keyboard_nav/tab_navigate_cursor.ts +0 -46
  223. package/blockly-rc/core/label_flyout_inflater.ts +0 -59
  224. package/blockly-rc/core/layer_manager.ts +0 -186
  225. package/blockly-rc/core/layers.ts +0 -17
  226. package/blockly-rc/core/main.ts +0 -31
  227. package/blockly-rc/core/marker_manager.ts +0 -189
  228. package/blockly-rc/core/menu.ts +0 -463
  229. package/blockly-rc/core/menuitem.ts +0 -221
  230. package/blockly-rc/core/metrics_manager.ts +0 -486
  231. package/blockly-rc/core/msg.ts +0 -27
  232. package/blockly-rc/core/names.ts +0 -275
  233. package/blockly-rc/core/observable_procedure_map.ts +0 -66
  234. package/blockly-rc/core/options.ts +0 -377
  235. package/blockly-rc/core/positionable_helpers.ts +0 -186
  236. package/blockly-rc/core/procedures.ts +0 -510
  237. package/blockly-rc/core/registry.ts +0 -400
  238. package/blockly-rc/core/render_management.ts +0 -193
  239. package/blockly-rc/core/rendered_connection.ts +0 -571
  240. package/blockly-rc/core/renderers/common/block_rendering.ts +0 -120
  241. package/blockly-rc/core/renderers/common/constants.ts +0 -1198
  242. package/blockly-rc/core/renderers/common/drawer.ts +0 -518
  243. package/blockly-rc/core/renderers/common/i_path_object.ts +0 -137
  244. package/blockly-rc/core/renderers/common/info.ts +0 -767
  245. package/blockly-rc/core/renderers/common/marker_svg.ts +0 -765
  246. package/blockly-rc/core/renderers/common/path_object.ts +0 -324
  247. package/blockly-rc/core/renderers/common/renderer.ts +0 -281
  248. package/blockly-rc/core/renderers/geras/constants.ts +0 -46
  249. package/blockly-rc/core/renderers/geras/drawer.ts +0 -167
  250. package/blockly-rc/core/renderers/geras/geras.ts +0 -31
  251. package/blockly-rc/core/renderers/geras/highlight_constants.ts +0 -342
  252. package/blockly-rc/core/renderers/geras/highlighter.ts +0 -313
  253. package/blockly-rc/core/renderers/geras/info.ts +0 -478
  254. package/blockly-rc/core/renderers/geras/measurables/inline_input.ts +0 -37
  255. package/blockly-rc/core/renderers/geras/measurables/statement_input.ts +0 -36
  256. package/blockly-rc/core/renderers/geras/path_object.ts +0 -135
  257. package/blockly-rc/core/renderers/geras/renderer.ts +0 -124
  258. package/blockly-rc/core/renderers/measurables/base.ts +0 -41
  259. package/blockly-rc/core/renderers/measurables/bottom_row.ts +0 -104
  260. package/blockly-rc/core/renderers/measurables/connection.ts +0 -43
  261. package/blockly-rc/core/renderers/measurables/external_value_input.ts +0 -53
  262. package/blockly-rc/core/renderers/measurables/field.ts +0 -50
  263. package/blockly-rc/core/renderers/measurables/hat.ts +0 -33
  264. package/blockly-rc/core/renderers/measurables/icon.ts +0 -42
  265. package/blockly-rc/core/renderers/measurables/in_row_spacer.ts +0 -29
  266. package/blockly-rc/core/renderers/measurables/inline_input.ts +0 -63
  267. package/blockly-rc/core/renderers/measurables/input_connection.ts +0 -57
  268. package/blockly-rc/core/renderers/measurables/input_row.ts +0 -67
  269. package/blockly-rc/core/renderers/measurables/jagged_edge.ts +0 -28
  270. package/blockly-rc/core/renderers/measurables/next_connection.ts +0 -34
  271. package/blockly-rc/core/renderers/measurables/output_connection.ts +0 -43
  272. package/blockly-rc/core/renderers/measurables/previous_connection.ts +0 -34
  273. package/blockly-rc/core/renderers/measurables/round_corner.ts +0 -34
  274. package/blockly-rc/core/renderers/measurables/row.ts +0 -191
  275. package/blockly-rc/core/renderers/measurables/spacer_row.ts +0 -44
  276. package/blockly-rc/core/renderers/measurables/square_corner.ts +0 -32
  277. package/blockly-rc/core/renderers/measurables/statement_input.ts +0 -41
  278. package/blockly-rc/core/renderers/measurables/top_row.ts +0 -110
  279. package/blockly-rc/core/renderers/measurables/types.ts +0 -319
  280. package/blockly-rc/core/renderers/thrasos/info.ts +0 -328
  281. package/blockly-rc/core/renderers/thrasos/renderer.ts +0 -40
  282. package/blockly-rc/core/renderers/thrasos/thrasos.ts +0 -14
  283. package/blockly-rc/core/renderers/zelos/constants.ts +0 -877
  284. package/blockly-rc/core/renderers/zelos/drawer.ts +0 -274
  285. package/blockly-rc/core/renderers/zelos/info.ts +0 -652
  286. package/blockly-rc/core/renderers/zelos/marker_svg.ts +0 -145
  287. package/blockly-rc/core/renderers/zelos/measurables/bottom_row.ts +0 -44
  288. package/blockly-rc/core/renderers/zelos/measurables/inputs.ts +0 -41
  289. package/blockly-rc/core/renderers/zelos/measurables/row_elements.ts +0 -29
  290. package/blockly-rc/core/renderers/zelos/measurables/top_row.ts +0 -50
  291. package/blockly-rc/core/renderers/zelos/path_object.ts +0 -209
  292. package/blockly-rc/core/renderers/zelos/renderer.ts +0 -143
  293. package/blockly-rc/core/renderers/zelos/zelos.ts +0 -33
  294. package/blockly-rc/core/scrollbar.ts +0 -898
  295. package/blockly-rc/core/scrollbar_pair.ts +0 -349
  296. package/blockly-rc/core/separator_flyout_inflater.ts +0 -69
  297. package/blockly-rc/core/serialization/blocks.ts +0 -868
  298. package/blockly-rc/core/serialization/exceptions.ts +0 -112
  299. package/blockly-rc/core/serialization/priorities.ts +0 -25
  300. package/blockly-rc/core/serialization/procedures.ts +0 -158
  301. package/blockly-rc/core/serialization/registry.ts +0 -30
  302. package/blockly-rc/core/serialization/variables.ts +0 -68
  303. package/blockly-rc/core/serialization/workspace_comments.ts +0 -143
  304. package/blockly-rc/core/serialization/workspaces.ts +0 -94
  305. package/blockly-rc/core/serialization.ts +0 -32
  306. package/blockly-rc/core/shortcut_items.ts +0 -338
  307. package/blockly-rc/core/shortcut_registry.ts +0 -368
  308. package/blockly-rc/core/sprites.ts +0 -15
  309. package/blockly-rc/core/theme/classic.ts +0 -40
  310. package/blockly-rc/core/theme/themes.ts +0 -12
  311. package/blockly-rc/core/theme/zelos.ts +0 -80
  312. package/blockly-rc/core/theme.ts +0 -232
  313. package/blockly-rc/core/theme_manager.ts +0 -192
  314. package/blockly-rc/core/toolbox/category.ts +0 -739
  315. package/blockly-rc/core/toolbox/collapsible_category.ts +0 -288
  316. package/blockly-rc/core/toolbox/separator.ts +0 -105
  317. package/blockly-rc/core/toolbox/toolbox.ts +0 -1134
  318. package/blockly-rc/core/toolbox/toolbox_item.ts +0 -152
  319. package/blockly-rc/core/tooltip.ts +0 -466
  320. package/blockly-rc/core/touch.ts +0 -155
  321. package/blockly-rc/core/trashcan.ts +0 -748
  322. package/blockly-rc/core/utils/aria.ts +0 -144
  323. package/blockly-rc/core/utils/array.ts +0 -24
  324. package/blockly-rc/core/utils/colour.ts +0 -265
  325. package/blockly-rc/core/utils/coordinate.ts +0 -129
  326. package/blockly-rc/core/utils/deprecation.ts +0 -47
  327. package/blockly-rc/core/utils/dom.ts +0 -356
  328. package/blockly-rc/core/utils/idgenerator.ts +0 -70
  329. package/blockly-rc/core/utils/keycodes.ts +0 -154
  330. package/blockly-rc/core/utils/math.ts +0 -50
  331. package/blockly-rc/core/utils/metrics.ts +0 -86
  332. package/blockly-rc/core/utils/object.ts +0 -28
  333. package/blockly-rc/core/utils/parsing.ts +0 -287
  334. package/blockly-rc/core/utils/rect.ts +0 -69
  335. package/blockly-rc/core/utils/size.ts +0 -62
  336. package/blockly-rc/core/utils/string.ts +0 -289
  337. package/blockly-rc/core/utils/style.ts +0 -219
  338. package/blockly-rc/core/utils/svg.ts +0 -84
  339. package/blockly-rc/core/utils/svg_math.ts +0 -208
  340. package/blockly-rc/core/utils/svg_paths.ts +0 -133
  341. package/blockly-rc/core/utils/toolbox.ts +0 -419
  342. package/blockly-rc/core/utils/useragent.ts +0 -86
  343. package/blockly-rc/core/utils/xml.ts +0 -165
  344. package/blockly-rc/core/utils.ts +0 -59
  345. package/blockly-rc/core/variable_map.ts +0 -437
  346. package/blockly-rc/core/variable_model.ts +0 -149
  347. package/blockly-rc/core/variables.ts +0 -773
  348. package/blockly-rc/core/variables_dynamic.ts +0 -142
  349. package/blockly-rc/core/widgetdiv.ts +0 -319
  350. package/blockly-rc/core/workspace.ts +0 -957
  351. package/blockly-rc/core/workspace_audio.ts +0 -171
  352. package/blockly-rc/core/workspace_dragger.ts +0 -97
  353. package/blockly-rc/core/workspace_svg.ts +0 -2519
  354. package/blockly-rc/core/xml.ts +0 -1133
  355. package/blockly-rc/core/zoom_controls.ts +0 -492
  356. package/blockly-rc/demos/blockfactory/analytics.js +0 -195
  357. package/blockly-rc/demos/blockfactory/app_controller.js +0 -726
  358. package/blockly-rc/demos/blockfactory/block_definition_extractor.js +0 -742
  359. package/blockly-rc/demos/blockfactory/block_exporter_controller.js +0 -311
  360. package/blockly-rc/demos/blockfactory/block_exporter_tools.js +0 -212
  361. package/blockly-rc/demos/blockfactory/block_exporter_view.js +0 -101
  362. package/blockly-rc/demos/blockfactory/block_library_controller.js +0 -325
  363. package/blockly-rc/demos/blockfactory/block_library_storage.js +0 -149
  364. package/blockly-rc/demos/blockfactory/block_library_view.js +0 -178
  365. package/blockly-rc/demos/blockfactory/block_option.js +0 -151
  366. package/blockly-rc/demos/blockfactory/blocks.js +0 -916
  367. package/blockly-rc/demos/blockfactory/cp.css +0 -46
  368. package/blockly-rc/demos/blockfactory/cp.js +0 -179
  369. package/blockly-rc/demos/blockfactory/factory.css +0 -586
  370. package/blockly-rc/demos/blockfactory/factory.js +0 -337
  371. package/blockly-rc/demos/blockfactory/factory_utils.js +0 -1036
  372. package/blockly-rc/demos/blockfactory/icon.png +0 -0
  373. package/blockly-rc/demos/blockfactory/index.html +0 -767
  374. package/blockly-rc/demos/blockfactory/link.png +0 -0
  375. package/blockly-rc/demos/blockfactory/standard_categories.js +0 -384
  376. package/blockly-rc/demos/blockfactory/workspacefactory/wfactory_controller.js +0 -1332
  377. package/blockly-rc/demos/blockfactory/workspacefactory/wfactory_generator.js +0 -224
  378. package/blockly-rc/demos/blockfactory/workspacefactory/wfactory_init.js +0 -541
  379. package/blockly-rc/demos/blockfactory/workspacefactory/wfactory_model.js +0 -548
  380. package/blockly-rc/demos/blockfactory/workspacefactory/wfactory_view.js +0 -424
  381. package/blockly-rc/demos/code/code.js +0 -626
  382. package/blockly-rc/demos/code/icon.png +0 -0
  383. package/blockly-rc/demos/code/icons.png +0 -0
  384. package/blockly-rc/demos/code/index.html +0 -359
  385. package/blockly-rc/demos/code/msg/ar.js +0 -24
  386. package/blockly-rc/demos/code/msg/be-tarask.js +0 -24
  387. package/blockly-rc/demos/code/msg/br.js +0 -24
  388. package/blockly-rc/demos/code/msg/ca.js +0 -24
  389. package/blockly-rc/demos/code/msg/cs.js +0 -24
  390. package/blockly-rc/demos/code/msg/da.js +0 -24
  391. package/blockly-rc/demos/code/msg/de.js +0 -24
  392. package/blockly-rc/demos/code/msg/el.js +0 -24
  393. package/blockly-rc/demos/code/msg/en.js +0 -24
  394. package/blockly-rc/demos/code/msg/es.js +0 -24
  395. package/blockly-rc/demos/code/msg/et.js +0 -24
  396. package/blockly-rc/demos/code/msg/fa.js +0 -24
  397. package/blockly-rc/demos/code/msg/fr.js +0 -24
  398. package/blockly-rc/demos/code/msg/he.js +0 -24
  399. package/blockly-rc/demos/code/msg/hr.js +0 -24
  400. package/blockly-rc/demos/code/msg/hrx.js +0 -24
  401. package/blockly-rc/demos/code/msg/hu.js +0 -24
  402. package/blockly-rc/demos/code/msg/ia.js +0 -24
  403. package/blockly-rc/demos/code/msg/is.js +0 -24
  404. package/blockly-rc/demos/code/msg/it.js +0 -24
  405. package/blockly-rc/demos/code/msg/ja.js +0 -24
  406. package/blockly-rc/demos/code/msg/kab.js +0 -24
  407. package/blockly-rc/demos/code/msg/ko.js +0 -24
  408. package/blockly-rc/demos/code/msg/mk.js +0 -24
  409. package/blockly-rc/demos/code/msg/ms.js +0 -24
  410. package/blockly-rc/demos/code/msg/nb.js +0 -24
  411. package/blockly-rc/demos/code/msg/nl.js +0 -24
  412. package/blockly-rc/demos/code/msg/oc.js +0 -24
  413. package/blockly-rc/demos/code/msg/pl.js +0 -24
  414. package/blockly-rc/demos/code/msg/pms.js +0 -24
  415. package/blockly-rc/demos/code/msg/pt-br.js +0 -24
  416. package/blockly-rc/demos/code/msg/ro.js +0 -24
  417. package/blockly-rc/demos/code/msg/ru.js +0 -24
  418. package/blockly-rc/demos/code/msg/sc.js +0 -24
  419. package/blockly-rc/demos/code/msg/sk.js +0 -24
  420. package/blockly-rc/demos/code/msg/sr.js +0 -24
  421. package/blockly-rc/demos/code/msg/sv.js +0 -24
  422. package/blockly-rc/demos/code/msg/ta.js +0 -24
  423. package/blockly-rc/demos/code/msg/th.js +0 -24
  424. package/blockly-rc/demos/code/msg/tlh.js +0 -24
  425. package/blockly-rc/demos/code/msg/tr.js +0 -24
  426. package/blockly-rc/demos/code/msg/uk.js +0 -24
  427. package/blockly-rc/demos/code/msg/vi.js +0 -24
  428. package/blockly-rc/demos/code/msg/zh-hans.js +0 -24
  429. package/blockly-rc/demos/code/msg/zh-hant.js +0 -24
  430. package/blockly-rc/demos/code/style.css +0 -184
  431. package/blockly-rc/demos/index.html +0 -68
  432. package/blockly-rc/demos/minimap/icon.png +0 -0
  433. package/blockly-rc/demos/minimap/index.html +0 -91
  434. package/blockly-rc/demos/minimap/minimap.js +0 -302
  435. package/blockly-rc/demos/mobile/README.md +0 -53
  436. package/blockly-rc/demos/mobile/android/README.md +0 -45
  437. package/blockly-rc/demos/mobile/android/app/build.gradle +0 -64
  438. package/blockly-rc/demos/mobile/android/app/proguard-rules.pro +0 -21
  439. package/blockly-rc/demos/mobile/android/app/src/androidTest/java/com/example/blocklywebview/ExampleInstrumentedTest.java +0 -26
  440. package/blockly-rc/demos/mobile/android/app/src/main/AndroidManifest.xml +0 -21
  441. package/blockly-rc/demos/mobile/android/app/src/main/java/com/google/blockly/android/webview/BlocklyWebViewFragment.java +0 -40
  442. package/blockly-rc/demos/mobile/android/app/src/main/java/com/google/blockly/android/webview/JsDialogHelper.java +0 -150
  443. package/blockly-rc/demos/mobile/android/app/src/main/java/com/google/blockly/android/webview/WebChromeClient.java +0 -32
  444. package/blockly-rc/demos/mobile/android/app/src/main/java/com/google/blockly/android/webview/demo/MainActivity.java +0 -18
  445. package/blockly-rc/demos/mobile/android/app/src/main/res/drawable/ic_launcher_background.xml +0 -74
  446. package/blockly-rc/demos/mobile/android/app/src/main/res/drawable-v24/ic_launcher_foreground.xml +0 -34
  447. package/blockly-rc/demos/mobile/android/app/src/main/res/layout/activity_main.xml +0 -17
  448. package/blockly-rc/demos/mobile/android/app/src/main/res/layout/js_prompt.xml +0 -37
  449. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml +0 -5
  450. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml +0 -5
  451. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher.png +0 -0
  452. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-hdpi/ic_launcher_round.png +0 -0
  453. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher.png +0 -0
  454. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-mdpi/ic_launcher_round.png +0 -0
  455. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png +0 -0
  456. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-xhdpi/ic_launcher_round.png +0 -0
  457. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png +0 -0
  458. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.png +0 -0
  459. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png +0 -0
  460. package/blockly-rc/demos/mobile/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.png +0 -0
  461. package/blockly-rc/demos/mobile/android/app/src/main/res/values/colors.xml +0 -6
  462. package/blockly-rc/demos/mobile/android/app/src/main/res/values/js_dialog_helper.xml +0 -7
  463. package/blockly-rc/demos/mobile/android/app/src/main/res/values/strings.xml +0 -3
  464. package/blockly-rc/demos/mobile/android/app/src/main/res/values/styles.xml +0 -11
  465. package/blockly-rc/demos/mobile/android/app/src/test/java/com/example/blocklywebview/ExampleUnitTest.java +0 -17
  466. package/blockly-rc/demos/mobile/android/build.gradle +0 -27
  467. package/blockly-rc/demos/mobile/android/gradle/wrapper/gradle-wrapper.jar +0 -0
  468. package/blockly-rc/demos/mobile/android/gradle/wrapper/gradle-wrapper.properties +0 -6
  469. package/blockly-rc/demos/mobile/android/gradle.properties +0 -13
  470. package/blockly-rc/demos/mobile/android/gradlew +0 -172
  471. package/blockly-rc/demos/mobile/android/gradlew.bat +0 -84
  472. package/blockly-rc/demos/mobile/android/settings.gradle +0 -1
  473. package/blockly-rc/demos/mobile/html/index.html +0 -31
  474. package/blockly-rc/demos/mobile/html/ln_resources.sh +0 -22
  475. package/blockly-rc/demos/mobile/html/toolbox_standard.js +0 -333
  476. package/blockly-rc/demos/mobile/ios/Blockly WebView/AppDelegate.swift +0 -46
  477. package/blockly-rc/demos/mobile/ios/Blockly WebView/Assets.xcassets/AppIcon.appiconset/Contents.json +0 -98
  478. package/blockly-rc/demos/mobile/ios/Blockly WebView/Assets.xcassets/Contents.json +0 -6
  479. package/blockly-rc/demos/mobile/ios/Blockly WebView/Base.lproj/LaunchScreen.storyboard +0 -25
  480. package/blockly-rc/demos/mobile/ios/Blockly WebView/Base.lproj/Main.storyboard +0 -44
  481. package/blockly-rc/demos/mobile/ios/Blockly WebView/Info.plist +0 -45
  482. package/blockly-rc/demos/mobile/ios/Blockly WebView/ViewController.swift +0 -110
  483. package/blockly-rc/demos/mobile/ios/Blockly WebView.xcodeproj/project.pbxproj +0 -390
  484. package/blockly-rc/demos/mobile/ios/Blockly WebView.xcodeproj/project.xcworkspace/contents.xcworkspacedata +0 -7
  485. package/blockly-rc/demos/mobile/ios/Blockly WebView.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +0 -8
  486. package/blockly-rc/demos/mobile/ios/cp_resources.sh +0 -21
  487. package/blockly-rc/demos/storage/icon.png +0 -0
  488. package/blockly-rc/demos/storage/index.html +0 -104
  489. package/blockly-rc/generators/dart/dart_generator.ts +0 -321
  490. package/blockly-rc/generators/dart/lists.ts +0 -525
  491. package/blockly-rc/generators/dart/logic.ts +0 -155
  492. package/blockly-rc/generators/dart/loops.ts +0 -217
  493. package/blockly-rc/generators/dart/math.ts +0 -559
  494. package/blockly-rc/generators/dart/procedures.ts +0 -138
  495. package/blockly-rc/generators/dart/text.ts +0 -405
  496. package/blockly-rc/generators/dart/variables.ts +0 -32
  497. package/blockly-rc/generators/dart/variables_dynamic.ts +0 -17
  498. package/blockly-rc/generators/dart.ts +0 -50
  499. package/blockly-rc/generators/javascript/javascript_generator.ts +0 -346
  500. package/blockly-rc/generators/javascript/lists.ts +0 -465
  501. package/blockly-rc/generators/javascript/logic.ts +0 -153
  502. package/blockly-rc/generators/javascript/loops.ts +0 -245
  503. package/blockly-rc/generators/javascript/math.ts +0 -450
  504. package/blockly-rc/generators/javascript/procedures.ts +0 -142
  505. package/blockly-rc/generators/javascript/text.ts +0 -418
  506. package/blockly-rc/generators/javascript/variables.ts +0 -32
  507. package/blockly-rc/generators/javascript/variables_dynamic.ts +0 -17
  508. package/blockly-rc/generators/javascript.ts +0 -46
  509. package/blockly-rc/generators/lua/lists.ts +0 -445
  510. package/blockly-rc/generators/lua/logic.ts +0 -142
  511. package/blockly-rc/generators/lua/loops.ts +0 -192
  512. package/blockly-rc/generators/lua/lua_generator.ts +0 -225
  513. package/blockly-rc/generators/lua/math.ts +0 -473
  514. package/blockly-rc/generators/lua/procedures.ts +0 -144
  515. package/blockly-rc/generators/lua/text.ts +0 -380
  516. package/blockly-rc/generators/lua/variables.ts +0 -31
  517. package/blockly-rc/generators/lua/variables_dynamic.ts +0 -17
  518. package/blockly-rc/generators/lua.ts +0 -44
  519. package/blockly-rc/generators/php/lists.ts +0 -585
  520. package/blockly-rc/generators/php/logic.ts +0 -155
  521. package/blockly-rc/generators/php/loops.ts +0 -218
  522. package/blockly-rc/generators/php/math.ts +0 -408
  523. package/blockly-rc/generators/php/php_generator.ts +0 -320
  524. package/blockly-rc/generators/php/procedures.ts +0 -159
  525. package/blockly-rc/generators/php/text.ts +0 -315
  526. package/blockly-rc/generators/php/variables.ts +0 -32
  527. package/blockly-rc/generators/php/variables_dynamic.ts +0 -17
  528. package/blockly-rc/generators/php.ts +0 -46
  529. package/blockly-rc/generators/python/lists.ts +0 -398
  530. package/blockly-rc/generators/python/logic.ts +0 -148
  531. package/blockly-rc/generators/python/loops.ts +0 -251
  532. package/blockly-rc/generators/python/math.ts +0 -434
  533. package/blockly-rc/generators/python/procedures.ts +0 -159
  534. package/blockly-rc/generators/python/python_generator.ts +0 -355
  535. package/blockly-rc/generators/python/text.ts +0 -338
  536. package/blockly-rc/generators/python/variables.ts +0 -31
  537. package/blockly-rc/generators/python/variables_dynamic.ts +0 -17
  538. package/blockly-rc/generators/python.ts +0 -51
  539. package/blockly-rc/gulpfile.js +0 -54
  540. package/blockly-rc/jsconfig.json +0 -7
  541. package/blockly-rc/media/1x1.gif +0 -0
  542. package/blockly-rc/media/click.mp3 +0 -0
  543. package/blockly-rc/media/click.ogg +0 -0
  544. package/blockly-rc/media/click.wav +0 -0
  545. package/blockly-rc/media/delete-icon.svg +0 -1
  546. package/blockly-rc/media/delete.mp3 +0 -0
  547. package/blockly-rc/media/delete.ogg +0 -0
  548. package/blockly-rc/media/delete.wav +0 -0
  549. package/blockly-rc/media/disconnect.mp3 +0 -0
  550. package/blockly-rc/media/disconnect.ogg +0 -0
  551. package/blockly-rc/media/disconnect.wav +0 -0
  552. package/blockly-rc/media/dropdown-arrow.svg +0 -1
  553. package/blockly-rc/media/foldout-icon.svg +0 -1
  554. package/blockly-rc/media/handclosed.cur +0 -0
  555. package/blockly-rc/media/handdelete.cur +0 -0
  556. package/blockly-rc/media/handopen.cur +0 -0
  557. package/blockly-rc/media/pilcrow.png +0 -0
  558. package/blockly-rc/media/quote0.png +0 -0
  559. package/blockly-rc/media/quote1.png +0 -0
  560. package/blockly-rc/media/resize-handle.svg +0 -3
  561. package/blockly-rc/media/sprites.png +0 -0
  562. package/blockly-rc/media/sprites.svg +0 -74
  563. package/blockly-rc/msg/json/README.md +0 -33
  564. package/blockly-rc/msg/json/ab.json +0 -222
  565. package/blockly-rc/msg/json/ace.json +0 -7
  566. package/blockly-rc/msg/json/af.json +0 -34
  567. package/blockly-rc/msg/json/am.json +0 -30
  568. package/blockly-rc/msg/json/ar.json +0 -355
  569. package/blockly-rc/msg/json/ast.json +0 -10
  570. package/blockly-rc/msg/json/az.json +0 -332
  571. package/blockly-rc/msg/json/ba.json +0 -211
  572. package/blockly-rc/msg/json/bcc.json +0 -290
  573. package/blockly-rc/msg/json/be-tarask.json +0 -334
  574. package/blockly-rc/msg/json/be.json +0 -324
  575. package/blockly-rc/msg/json/bg.json +0 -345
  576. package/blockly-rc/msg/json/bn.json +0 -189
  577. package/blockly-rc/msg/json/br.json +0 -334
  578. package/blockly-rc/msg/json/bs.json +0 -166
  579. package/blockly-rc/msg/json/ca.json +0 -341
  580. package/blockly-rc/msg/json/cdo.json +0 -6
  581. package/blockly-rc/msg/json/ce.json +0 -326
  582. package/blockly-rc/msg/json/constants.json +0 -12
  583. package/blockly-rc/msg/json/cs.json +0 -343
  584. package/blockly-rc/msg/json/da.json +0 -346
  585. package/blockly-rc/msg/json/de.json +0 -369
  586. package/blockly-rc/msg/json/diq.json +0 -258
  587. package/blockly-rc/msg/json/dtp.json +0 -198
  588. package/blockly-rc/msg/json/dty.json +0 -97
  589. package/blockly-rc/msg/json/ee.json +0 -160
  590. package/blockly-rc/msg/json/el.json +0 -356
  591. package/blockly-rc/msg/json/en-gb.json +0 -199
  592. package/blockly-rc/msg/json/en.json +0 -400
  593. package/blockly-rc/msg/json/eo.json +0 -337
  594. package/blockly-rc/msg/json/es.json +0 -358
  595. package/blockly-rc/msg/json/et.json +0 -326
  596. package/blockly-rc/msg/json/eu.json +0 -219
  597. package/blockly-rc/msg/json/fa.json +0 -341
  598. package/blockly-rc/msg/json/fi.json +0 -350
  599. package/blockly-rc/msg/json/fo.json +0 -46
  600. package/blockly-rc/msg/json/fr.json +0 -373
  601. package/blockly-rc/msg/json/frr.json +0 -6
  602. package/blockly-rc/msg/json/gl.json +0 -338
  603. package/blockly-rc/msg/json/gn.json +0 -54
  604. package/blockly-rc/msg/json/gor.json +0 -87
  605. package/blockly-rc/msg/json/ha.json +0 -313
  606. package/blockly-rc/msg/json/hak.json +0 -17
  607. package/blockly-rc/msg/json/he.json +0 -354
  608. package/blockly-rc/msg/json/hi.json +0 -318
  609. package/blockly-rc/msg/json/hr.json +0 -327
  610. package/blockly-rc/msg/json/hrx.json +0 -287
  611. package/blockly-rc/msg/json/hsb.json +0 -128
  612. package/blockly-rc/msg/json/hu.json +0 -349
  613. package/blockly-rc/msg/json/hy.json +0 -337
  614. package/blockly-rc/msg/json/ia.json +0 -337
  615. package/blockly-rc/msg/json/id.json +0 -335
  616. package/blockly-rc/msg/json/ig.json +0 -323
  617. package/blockly-rc/msg/json/inh.json +0 -80
  618. package/blockly-rc/msg/json/is.json +0 -331
  619. package/blockly-rc/msg/json/it.json +0 -346
  620. package/blockly-rc/msg/json/ja.json +0 -361
  621. package/blockly-rc/msg/json/ka.json +0 -14
  622. package/blockly-rc/msg/json/kab.json +0 -323
  623. package/blockly-rc/msg/json/kbd-cyrl.json +0 -84
  624. package/blockly-rc/msg/json/km.json +0 -29
  625. package/blockly-rc/msg/json/kn.json +0 -332
  626. package/blockly-rc/msg/json/ko.json +0 -372
  627. package/blockly-rc/msg/json/ksh.json +0 -43
  628. package/blockly-rc/msg/json/ku-latn.json +0 -41
  629. package/blockly-rc/msg/json/ky.json +0 -71
  630. package/blockly-rc/msg/json/la.json +0 -6
  631. package/blockly-rc/msg/json/lb.json +0 -156
  632. package/blockly-rc/msg/json/lki.json +0 -282
  633. package/blockly-rc/msg/json/lo.json +0 -92
  634. package/blockly-rc/msg/json/lrc.json +0 -123
  635. package/blockly-rc/msg/json/lt.json +0 -321
  636. package/blockly-rc/msg/json/lv.json +0 -324
  637. package/blockly-rc/msg/json/mg.json +0 -58
  638. package/blockly-rc/msg/json/mk.json +0 -178
  639. package/blockly-rc/msg/json/ml.json +0 -35
  640. package/blockly-rc/msg/json/mnw.json +0 -90
  641. package/blockly-rc/msg/json/ms.json +0 -300
  642. package/blockly-rc/msg/json/my.json +0 -57
  643. package/blockly-rc/msg/json/mzn.json +0 -6
  644. package/blockly-rc/msg/json/nb.json +0 -330
  645. package/blockly-rc/msg/json/ne.json +0 -247
  646. package/blockly-rc/msg/json/nl.json +0 -357
  647. package/blockly-rc/msg/json/oc.json +0 -194
  648. package/blockly-rc/msg/json/olo.json +0 -37
  649. package/blockly-rc/msg/json/pa.json +0 -69
  650. package/blockly-rc/msg/json/pl.json +0 -357
  651. package/blockly-rc/msg/json/pms.json +0 -324
  652. package/blockly-rc/msg/json/ps.json +0 -50
  653. package/blockly-rc/msg/json/pt-br.json +0 -369
  654. package/blockly-rc/msg/json/pt.json +0 -358
  655. package/blockly-rc/msg/json/qqq.json +0 -406
  656. package/blockly-rc/msg/json/ro.json +0 -333
  657. package/blockly-rc/msg/json/ru.json +0 -363
  658. package/blockly-rc/msg/json/sc.json +0 -283
  659. package/blockly-rc/msg/json/sco.json +0 -11
  660. package/blockly-rc/msg/json/sd.json +0 -158
  661. package/blockly-rc/msg/json/shn.json +0 -109
  662. package/blockly-rc/msg/json/si.json +0 -16
  663. package/blockly-rc/msg/json/sk.json +0 -332
  664. package/blockly-rc/msg/json/skr-arab.json +0 -117
  665. package/blockly-rc/msg/json/sl.json +0 -355
  666. package/blockly-rc/msg/json/smn.json +0 -133
  667. package/blockly-rc/msg/json/sq.json +0 -343
  668. package/blockly-rc/msg/json/sr-latn.json +0 -324
  669. package/blockly-rc/msg/json/sr.json +0 -348
  670. package/blockly-rc/msg/json/sv.json +0 -347
  671. package/blockly-rc/msg/json/sw.json +0 -12
  672. package/blockly-rc/msg/json/synonyms.json +0 -22
  673. package/blockly-rc/msg/json/ta.json +0 -306
  674. package/blockly-rc/msg/json/tcy.json +0 -316
  675. package/blockly-rc/msg/json/tdd.json +0 -109
  676. package/blockly-rc/msg/json/te.json +0 -101
  677. package/blockly-rc/msg/json/th.json +0 -333
  678. package/blockly-rc/msg/json/ti.json +0 -50
  679. package/blockly-rc/msg/json/tl.json +0 -129
  680. package/blockly-rc/msg/json/tlh.json +0 -179
  681. package/blockly-rc/msg/json/tr.json +0 -369
  682. package/blockly-rc/msg/json/ug-arab.json +0 -132
  683. package/blockly-rc/msg/json/uk.json +0 -345
  684. package/blockly-rc/msg/json/ur.json +0 -117
  685. package/blockly-rc/msg/json/uz.json +0 -36
  686. package/blockly-rc/msg/json/vi.json +0 -345
  687. package/blockly-rc/msg/json/xmf.json +0 -96
  688. package/blockly-rc/msg/json/yo.json +0 -316
  689. package/blockly-rc/msg/json/zgh.json +0 -83
  690. package/blockly-rc/msg/json/zh-hans.json +0 -372
  691. package/blockly-rc/msg/json/zh-hant.json +0 -362
  692. package/blockly-rc/msg/messages.js +0 -1616
  693. package/blockly-rc/package-lock.json +0 -12324
  694. package/blockly-rc/package.json +0 -149
  695. package/blockly-rc/patches/@microsoft+api-documenter+7.22.4.patch +0 -81
  696. package/blockly-rc/scripts/goog_module/convert-file.sh +0 -406
  697. package/blockly-rc/scripts/gulpfiles/appengine_tasks.js +0 -195
  698. package/blockly-rc/scripts/gulpfiles/build_tasks.js +0 -752
  699. package/blockly-rc/scripts/gulpfiles/config.js +0 -41
  700. package/blockly-rc/scripts/gulpfiles/docs_tasks.js +0 -147
  701. package/blockly-rc/scripts/gulpfiles/git_tasks.js +0 -181
  702. package/blockly-rc/scripts/gulpfiles/helper_tasks.js +0 -19
  703. package/blockly-rc/scripts/gulpfiles/package_tasks.js +0 -262
  704. package/blockly-rc/scripts/gulpfiles/release_tasks.js +0 -183
  705. package/blockly-rc/scripts/gulpfiles/test_tasks.js +0 -405
  706. package/blockly-rc/scripts/helpers.js +0 -74
  707. package/blockly-rc/scripts/i18n/common.py +0 -233
  708. package/blockly-rc/scripts/i18n/create_messages.py +0 -167
  709. package/blockly-rc/scripts/i18n/dedup_json.py +0 -72
  710. package/blockly-rc/scripts/i18n/js_to_json.py +0 -135
  711. package/blockly-rc/scripts/i18n/tests.py +0 -46
  712. package/blockly-rc/scripts/migration/cjs2esm +0 -162
  713. package/blockly-rc/scripts/migration/js2ts +0 -168
  714. package/blockly-rc/scripts/migration/renamings.json5 +0 -1599
  715. package/blockly-rc/scripts/package/README.md +0 -93
  716. package/blockly-rc/scripts/package/core-node.js +0 -31
  717. package/blockly-rc/scripts/package/index.js +0 -23
  718. package/blockly-rc/scripts/package/templates/umd-msg.template +0 -16
  719. package/blockly-rc/scripts/package/templates/umd.template +0 -13
  720. package/blockly-rc/scripts/themes/blockStyles_example.json +0 -11
  721. package/blockly-rc/scripts/themes/create_blockStyles.py +0 -181
  722. package/blockly-rc/scripts/tsick.js +0 -86
  723. package/blockly-rc/tests/.eslintrc.json +0 -10
  724. package/blockly-rc/tests/browser/.eslintrc.json +0 -29
  725. package/blockly-rc/tests/browser/.mocharc.js +0 -6
  726. package/blockly-rc/tests/browser/test/basic_block_factory_test.mjs +0 -44
  727. package/blockly-rc/tests/browser/test/basic_block_test.mjs +0 -39
  728. package/blockly-rc/tests/browser/test/basic_playground_test.mjs +0 -198
  729. package/blockly-rc/tests/browser/test/block_undo_test.mjs +0 -50
  730. package/blockly-rc/tests/browser/test/delete_blocks_test.mjs +0 -211
  731. package/blockly-rc/tests/browser/test/extensive_test.mjs +0 -195
  732. package/blockly-rc/tests/browser/test/field_edits_test.mjs +0 -61
  733. package/blockly-rc/tests/browser/test/hooks.mjs +0 -23
  734. package/blockly-rc/tests/browser/test/mutator_test.mjs +0 -88
  735. package/blockly-rc/tests/browser/test/procedure_test.mjs +0 -109
  736. package/blockly-rc/tests/browser/test/test_setup.mjs +0 -589
  737. package/blockly-rc/tests/browser/test/toolbox_drag_test.mjs +0 -207
  738. package/blockly-rc/tests/browser/test/workspace_comment_test.mjs +0 -224
  739. package/blockly-rc/tests/compile/index.html +0 -43
  740. package/blockly-rc/tests/compile/main.js +0 -53
  741. package/blockly-rc/tests/compile/test_blocks.js +0 -47
  742. package/blockly-rc/tests/compile/webdriver.js +0 -81
  743. package/blockly-rc/tests/generators/functions.xml +0 -561
  744. package/blockly-rc/tests/generators/golden/generated.dart +0 -1604
  745. package/blockly-rc/tests/generators/golden/generated.js +0 -1552
  746. package/blockly-rc/tests/generators/golden/generated.lua +0 -1828
  747. package/blockly-rc/tests/generators/golden/generated.php +0 -1611
  748. package/blockly-rc/tests/generators/golden/generated.py +0 -1407
  749. package/blockly-rc/tests/generators/index.html +0 -405
  750. package/blockly-rc/tests/generators/lists.xml +0 -8675
  751. package/blockly-rc/tests/generators/logic.xml +0 -1019
  752. package/blockly-rc/tests/generators/loops1.xml +0 -345
  753. package/blockly-rc/tests/generators/loops2.xml +0 -891
  754. package/blockly-rc/tests/generators/loops3.xml +0 -735
  755. package/blockly-rc/tests/generators/math.xml +0 -2077
  756. package/blockly-rc/tests/generators/text.xml +0 -4651
  757. package/blockly-rc/tests/generators/unittest.js +0 -103
  758. package/blockly-rc/tests/generators/unittest_dart.js +0 -163
  759. package/blockly-rc/tests/generators/unittest_javascript.js +0 -167
  760. package/blockly-rc/tests/generators/unittest_lua.js +0 -165
  761. package/blockly-rc/tests/generators/unittest_php.js +0 -154
  762. package/blockly-rc/tests/generators/unittest_python.js +0 -138
  763. package/blockly-rc/tests/generators/variables.xml +0 -68
  764. package/blockly-rc/tests/generators/webdriver.js +0 -123
  765. package/blockly-rc/tests/media/200px.png +0 -0
  766. package/blockly-rc/tests/media/30px.png +0 -0
  767. package/blockly-rc/tests/media/50px.png +0 -0
  768. package/blockly-rc/tests/media/a.png +0 -0
  769. package/blockly-rc/tests/media/arrow.png +0 -0
  770. package/blockly-rc/tests/media/b.png +0 -0
  771. package/blockly-rc/tests/media/c.png +0 -0
  772. package/blockly-rc/tests/media/d.png +0 -0
  773. package/blockly-rc/tests/media/e.png +0 -0
  774. package/blockly-rc/tests/media/f.png +0 -0
  775. package/blockly-rc/tests/media/g.png +0 -0
  776. package/blockly-rc/tests/media/h.png +0 -0
  777. package/blockly-rc/tests/media/i.png +0 -0
  778. package/blockly-rc/tests/media/j.png +0 -0
  779. package/blockly-rc/tests/media/k.png +0 -0
  780. package/blockly-rc/tests/media/l.png +0 -0
  781. package/blockly-rc/tests/media/m.png +0 -0
  782. package/blockly-rc/tests/migration/renamings.schema.json +0 -59
  783. package/blockly-rc/tests/migration/validate-renamings.mjs +0 -60
  784. package/blockly-rc/tests/mocha/.eslintrc.json +0 -21
  785. package/blockly-rc/tests/mocha/.mocharc.js +0 -6
  786. package/blockly-rc/tests/mocha/astnode_test.js +0 -850
  787. package/blockly-rc/tests/mocha/block_json_test.js +0 -777
  788. package/blockly-rc/tests/mocha/block_test.js +0 -2743
  789. package/blockly-rc/tests/mocha/blocks/lists_test.js +0 -196
  790. package/blockly-rc/tests/mocha/blocks/logic_ternary_test.js +0 -320
  791. package/blockly-rc/tests/mocha/blocks/loops_test.js +0 -56
  792. package/blockly-rc/tests/mocha/blocks/procedures_test.js +0 -2495
  793. package/blockly-rc/tests/mocha/blocks/variables_test.js +0 -311
  794. package/blockly-rc/tests/mocha/clipboard_test.js +0 -136
  795. package/blockly-rc/tests/mocha/comment_deserialization_test.js +0 -122
  796. package/blockly-rc/tests/mocha/comment_test.js +0 -170
  797. package/blockly-rc/tests/mocha/comment_view_test.js +0 -188
  798. package/blockly-rc/tests/mocha/connection_checker_test.js +0 -666
  799. package/blockly-rc/tests/mocha/connection_db_test.js +0 -362
  800. package/blockly-rc/tests/mocha/connection_test.js +0 -3738
  801. package/blockly-rc/tests/mocha/contextmenu_items_test.js +0 -488
  802. package/blockly-rc/tests/mocha/contextmenu_test.js +0 -71
  803. package/blockly-rc/tests/mocha/cursor_test.js +0 -134
  804. package/blockly-rc/tests/mocha/dropdowndiv_test.js +0 -116
  805. package/blockly-rc/tests/mocha/event_block_change_test.js +0 -126
  806. package/blockly-rc/tests/mocha/event_block_create_test.js +0 -109
  807. package/blockly-rc/tests/mocha/event_block_delete_test.js +0 -55
  808. package/blockly-rc/tests/mocha/event_block_drag_test.js +0 -36
  809. package/blockly-rc/tests/mocha/event_block_field_intermediate_change_test.js +0 -67
  810. package/blockly-rc/tests/mocha/event_block_move_test.js +0 -39
  811. package/blockly-rc/tests/mocha/event_bubble_open_test.js +0 -42
  812. package/blockly-rc/tests/mocha/event_click_test.js +0 -40
  813. package/blockly-rc/tests/mocha/event_comment_change_test.js +0 -39
  814. package/blockly-rc/tests/mocha/event_comment_collapse_test.js +0 -34
  815. package/blockly-rc/tests/mocha/event_comment_create_test.js +0 -38
  816. package/blockly-rc/tests/mocha/event_comment_delete_test.js +0 -38
  817. package/blockly-rc/tests/mocha/event_comment_drag_test.js +0 -35
  818. package/blockly-rc/tests/mocha/event_comment_move_test.js +0 -40
  819. package/blockly-rc/tests/mocha/event_comment_resize_test.js +0 -38
  820. package/blockly-rc/tests/mocha/event_marker_move_test.js +0 -44
  821. package/blockly-rc/tests/mocha/event_selected_test.js +0 -41
  822. package/blockly-rc/tests/mocha/event_test.js +0 -1578
  823. package/blockly-rc/tests/mocha/event_theme_change_test.js +0 -36
  824. package/blockly-rc/tests/mocha/event_toolbox_item_select_test.js +0 -64
  825. package/blockly-rc/tests/mocha/event_trashcan_open_test.js +0 -36
  826. package/blockly-rc/tests/mocha/event_var_create_test.js +0 -54
  827. package/blockly-rc/tests/mocha/event_var_delete_test.js +0 -54
  828. package/blockly-rc/tests/mocha/event_var_rename_test.js +0 -39
  829. package/blockly-rc/tests/mocha/event_var_type_change_test.js +0 -43
  830. package/blockly-rc/tests/mocha/event_viewport_test.js +0 -39
  831. package/blockly-rc/tests/mocha/extensions_test.js +0 -613
  832. package/blockly-rc/tests/mocha/field_checkbox_test.js +0 -299
  833. package/blockly-rc/tests/mocha/field_colour_test.js +0 -395
  834. package/blockly-rc/tests/mocha/field_dropdown_test.js +0 -282
  835. package/blockly-rc/tests/mocha/field_image_test.js +0 -241
  836. package/blockly-rc/tests/mocha/field_label_serializable_test.js +0 -252
  837. package/blockly-rc/tests/mocha/field_label_test.js +0 -226
  838. package/blockly-rc/tests/mocha/field_number_test.js +0 -505
  839. package/blockly-rc/tests/mocha/field_registry_test.js +0 -116
  840. package/blockly-rc/tests/mocha/field_test.js +0 -822
  841. package/blockly-rc/tests/mocha/field_textinput_test.js +0 -297
  842. package/blockly-rc/tests/mocha/field_variable_test.js +0 -611
  843. package/blockly-rc/tests/mocha/flyout_test.js +0 -638
  844. package/blockly-rc/tests/mocha/generator_test.js +0 -233
  845. package/blockly-rc/tests/mocha/gesture_test.js +0 -97
  846. package/blockly-rc/tests/mocha/icon_test.js +0 -369
  847. package/blockly-rc/tests/mocha/index.html +0 -229
  848. package/blockly-rc/tests/mocha/input_test.js +0 -296
  849. package/blockly-rc/tests/mocha/insertion_marker_manager_test.js +0 -443
  850. package/blockly-rc/tests/mocha/insertion_marker_test.js +0 -432
  851. package/blockly-rc/tests/mocha/jso_deserialization_test.js +0 -849
  852. package/blockly-rc/tests/mocha/jso_serialization_test.js +0 -1067
  853. package/blockly-rc/tests/mocha/json_test.js +0 -315
  854. package/blockly-rc/tests/mocha/keydown_test.js +0 -364
  855. package/blockly-rc/tests/mocha/layering_test.js +0 -95
  856. package/blockly-rc/tests/mocha/metrics_test.js +0 -671
  857. package/blockly-rc/tests/mocha/mutator_test.js +0 -87
  858. package/blockly-rc/tests/mocha/names_test.js +0 -97
  859. package/blockly-rc/tests/mocha/old_workspace_comment_test.js +0 -256
  860. package/blockly-rc/tests/mocha/procedure_map_test.js +0 -57
  861. package/blockly-rc/tests/mocha/registry_test.js +0 -281
  862. package/blockly-rc/tests/mocha/render_management_test.js +0 -127
  863. package/blockly-rc/tests/mocha/serializer_test.js +0 -2104
  864. package/blockly-rc/tests/mocha/shortcut_registry_test.js +0 -450
  865. package/blockly-rc/tests/mocha/test_helpers/block_definitions.js +0 -204
  866. package/blockly-rc/tests/mocha/test_helpers/code_generation.js +0 -115
  867. package/blockly-rc/tests/mocha/test_helpers/common.js +0 -106
  868. package/blockly-rc/tests/mocha/test_helpers/events.js +0 -290
  869. package/blockly-rc/tests/mocha/test_helpers/fields.js +0 -310
  870. package/blockly-rc/tests/mocha/test_helpers/icon_mocks.js +0 -81
  871. package/blockly-rc/tests/mocha/test_helpers/procedures.js +0 -302
  872. package/blockly-rc/tests/mocha/test_helpers/serialization.js +0 -124
  873. package/blockly-rc/tests/mocha/test_helpers/setup_teardown.js +0 -209
  874. package/blockly-rc/tests/mocha/test_helpers/toolbox_definitions.js +0 -271
  875. package/blockly-rc/tests/mocha/test_helpers/user_input.js +0 -62
  876. package/blockly-rc/tests/mocha/test_helpers/variables.js +0 -23
  877. package/blockly-rc/tests/mocha/test_helpers/warnings.js +0 -83
  878. package/blockly-rc/tests/mocha/test_helpers/workspace.js +0 -1691
  879. package/blockly-rc/tests/mocha/theme_test.js +0 -307
  880. package/blockly-rc/tests/mocha/toolbox_test.js +0 -761
  881. package/blockly-rc/tests/mocha/tooltip_test.js +0 -276
  882. package/blockly-rc/tests/mocha/touch_test.js +0 -109
  883. package/blockly-rc/tests/mocha/trashcan_test.js +0 -375
  884. package/blockly-rc/tests/mocha/utils_test.js +0 -536
  885. package/blockly-rc/tests/mocha/variable_map_test.js +0 -509
  886. package/blockly-rc/tests/mocha/variable_model_test.js +0 -85
  887. package/blockly-rc/tests/mocha/webdriver.js +0 -96
  888. package/blockly-rc/tests/mocha/widget_div_test.js +0 -272
  889. package/blockly-rc/tests/mocha/workspace_comment_test.js +0 -171
  890. package/blockly-rc/tests/mocha/workspace_svg_test.js +0 -414
  891. package/blockly-rc/tests/mocha/workspace_test.js +0 -27
  892. package/blockly-rc/tests/mocha/xml_test.js +0 -951
  893. package/blockly-rc/tests/mocha/zoom_controls_test.js +0 -81
  894. package/blockly-rc/tests/multi_playground.html +0 -482
  895. package/blockly-rc/tests/node/.eslintrc.json +0 -12
  896. package/blockly-rc/tests/node/.mocharc.js +0 -6
  897. package/blockly-rc/tests/node/run_node_test.mjs +0 -72
  898. package/blockly-rc/tests/playground.html +0 -1280
  899. package/blockly-rc/tests/playgrounds/advanced_playground.html +0 -158
  900. package/blockly-rc/tests/playgrounds/iframe.html +0 -40
  901. package/blockly-rc/tests/playgrounds/screenshot.js +0 -123
  902. package/blockly-rc/tests/scripts/check_metadata.sh +0 -166
  903. package/blockly-rc/tests/scripts/compile_typings.sh +0 -32
  904. package/blockly-rc/tests/scripts/load.mjs +0 -140
  905. package/blockly-rc/tests/scripts/setup_linux_env.sh +0 -7
  906. package/blockly-rc/tests/scripts/update_metadata.sh +0 -46
  907. package/blockly-rc/tests/themes/test_themes.js +0 -62
  908. package/blockly-rc/tests/typescript/README.md +0 -4
  909. package/blockly-rc/tests/typescript/src/field/different_user_input.ts +0 -81
  910. package/blockly-rc/tests/typescript/src/generators/dart.ts +0 -24
  911. package/blockly-rc/tests/typescript/src/generators/javascript.ts +0 -28
  912. package/blockly-rc/tests/typescript/src/generators/lua.ts +0 -24
  913. package/blockly-rc/tests/typescript/src/generators/php.ts +0 -24
  914. package/blockly-rc/tests/typescript/src/generators/python.ts +0 -24
  915. package/blockly-rc/tests/typescript/src/generators.ts +0 -31
  916. package/blockly-rc/tests/typescript/src/msg.ts +0 -20
  917. package/blockly-rc/tests/typescript/tsconfig.json +0 -20
  918. package/blockly-rc/tests/xml/README.txt +0 -11
  919. package/blockly-rc/tests/xml/blockly.xsd +0 -178
  920. package/blockly-rc/tests/xml/invalid.xml +0 -6
  921. package/blockly-rc/tests/xml/toolbox.xml +0 -311
  922. package/blockly-rc/tests/xml/workspace.xml +0 -114
  923. package/blockly-rc/tsconfig.json +0 -37
  924. package/blockly-rc/tsdoc.json +0 -35
  925. package/blockly-rc/typings/README.md +0 -5
  926. package/blockly-rc/typings/blocks.d.ts +0 -17
  927. package/blockly-rc/typings/core.d.ts +0 -7
  928. package/blockly-rc/typings/dart.d.ts +0 -7
  929. package/blockly-rc/typings/index.d.ts +0 -10
  930. package/blockly-rc/typings/javascript.d.ts +0 -7
  931. package/blockly-rc/typings/lua.d.ts +0 -7
  932. package/blockly-rc/typings/msg/ab.d.ts +0 -8
  933. package/blockly-rc/typings/msg/ace.d.ts +0 -8
  934. package/blockly-rc/typings/msg/af.d.ts +0 -8
  935. package/blockly-rc/typings/msg/am.d.ts +0 -8
  936. package/blockly-rc/typings/msg/ar.d.ts +0 -8
  937. package/blockly-rc/typings/msg/ast.d.ts +0 -8
  938. package/blockly-rc/typings/msg/az.d.ts +0 -8
  939. package/blockly-rc/typings/msg/ba.d.ts +0 -8
  940. package/blockly-rc/typings/msg/bcc.d.ts +0 -8
  941. package/blockly-rc/typings/msg/be-tarask.d.ts +0 -8
  942. package/blockly-rc/typings/msg/be.d.ts +0 -8
  943. package/blockly-rc/typings/msg/bg.d.ts +0 -8
  944. package/blockly-rc/typings/msg/bn.d.ts +0 -8
  945. package/blockly-rc/typings/msg/br.d.ts +0 -8
  946. package/blockly-rc/typings/msg/bs.d.ts +0 -8
  947. package/blockly-rc/typings/msg/ca.d.ts +0 -8
  948. package/blockly-rc/typings/msg/cdo.d.ts +0 -8
  949. package/blockly-rc/typings/msg/ce.d.ts +0 -8
  950. package/blockly-rc/typings/msg/cs.d.ts +0 -8
  951. package/blockly-rc/typings/msg/da.d.ts +0 -8
  952. package/blockly-rc/typings/msg/de.d.ts +0 -8
  953. package/blockly-rc/typings/msg/diq.d.ts +0 -8
  954. package/blockly-rc/typings/msg/dtp.d.ts +0 -8
  955. package/blockly-rc/typings/msg/dty.d.ts +0 -8
  956. package/blockly-rc/typings/msg/ee.d.ts +0 -8
  957. package/blockly-rc/typings/msg/el.d.ts +0 -8
  958. package/blockly-rc/typings/msg/en-gb.d.ts +0 -8
  959. package/blockly-rc/typings/msg/en.d.ts +0 -8
  960. package/blockly-rc/typings/msg/eo.d.ts +0 -8
  961. package/blockly-rc/typings/msg/es.d.ts +0 -8
  962. package/blockly-rc/typings/msg/et.d.ts +0 -8
  963. package/blockly-rc/typings/msg/eu.d.ts +0 -8
  964. package/blockly-rc/typings/msg/fa.d.ts +0 -8
  965. package/blockly-rc/typings/msg/fi.d.ts +0 -8
  966. package/blockly-rc/typings/msg/fo.d.ts +0 -8
  967. package/blockly-rc/typings/msg/fr.d.ts +0 -8
  968. package/blockly-rc/typings/msg/frr.d.ts +0 -8
  969. package/blockly-rc/typings/msg/gl.d.ts +0 -8
  970. package/blockly-rc/typings/msg/gn.d.ts +0 -8
  971. package/blockly-rc/typings/msg/gor.d.ts +0 -8
  972. package/blockly-rc/typings/msg/ha.d.ts +0 -8
  973. package/blockly-rc/typings/msg/hak.d.ts +0 -8
  974. package/blockly-rc/typings/msg/he.d.ts +0 -8
  975. package/blockly-rc/typings/msg/hi.d.ts +0 -8
  976. package/blockly-rc/typings/msg/hr.d.ts +0 -8
  977. package/blockly-rc/typings/msg/hrx.d.ts +0 -8
  978. package/blockly-rc/typings/msg/hsb.d.ts +0 -8
  979. package/blockly-rc/typings/msg/hu.d.ts +0 -8
  980. package/blockly-rc/typings/msg/hy.d.ts +0 -8
  981. package/blockly-rc/typings/msg/ia.d.ts +0 -8
  982. package/blockly-rc/typings/msg/id.d.ts +0 -8
  983. package/blockly-rc/typings/msg/ig.d.ts +0 -8
  984. package/blockly-rc/typings/msg/inh.d.ts +0 -8
  985. package/blockly-rc/typings/msg/is.d.ts +0 -8
  986. package/blockly-rc/typings/msg/it.d.ts +0 -8
  987. package/blockly-rc/typings/msg/ja.d.ts +0 -8
  988. package/blockly-rc/typings/msg/ka.d.ts +0 -8
  989. package/blockly-rc/typings/msg/kab.d.ts +0 -8
  990. package/blockly-rc/typings/msg/kbd-cyrl.d.ts +0 -8
  991. package/blockly-rc/typings/msg/km.d.ts +0 -8
  992. package/blockly-rc/typings/msg/kn.d.ts +0 -8
  993. package/blockly-rc/typings/msg/ko.d.ts +0 -8
  994. package/blockly-rc/typings/msg/ksh.d.ts +0 -8
  995. package/blockly-rc/typings/msg/ku-latn.d.ts +0 -8
  996. package/blockly-rc/typings/msg/ky.d.ts +0 -8
  997. package/blockly-rc/typings/msg/la.d.ts +0 -8
  998. package/blockly-rc/typings/msg/lb.d.ts +0 -8
  999. package/blockly-rc/typings/msg/lki.d.ts +0 -8
  1000. package/blockly-rc/typings/msg/lo.d.ts +0 -8
  1001. package/blockly-rc/typings/msg/lrc.d.ts +0 -8
  1002. package/blockly-rc/typings/msg/lt.d.ts +0 -8
  1003. package/blockly-rc/typings/msg/lv.d.ts +0 -8
  1004. package/blockly-rc/typings/msg/mg.d.ts +0 -8
  1005. package/blockly-rc/typings/msg/mk.d.ts +0 -8
  1006. package/blockly-rc/typings/msg/ml.d.ts +0 -8
  1007. package/blockly-rc/typings/msg/mnw.d.ts +0 -8
  1008. package/blockly-rc/typings/msg/ms.d.ts +0 -8
  1009. package/blockly-rc/typings/msg/msg.d.ts +0 -440
  1010. package/blockly-rc/typings/msg/my.d.ts +0 -8
  1011. package/blockly-rc/typings/msg/mzn.d.ts +0 -8
  1012. package/blockly-rc/typings/msg/nb.d.ts +0 -8
  1013. package/blockly-rc/typings/msg/ne.d.ts +0 -8
  1014. package/blockly-rc/typings/msg/nl.d.ts +0 -8
  1015. package/blockly-rc/typings/msg/oc.d.ts +0 -8
  1016. package/blockly-rc/typings/msg/olo.d.ts +0 -8
  1017. package/blockly-rc/typings/msg/pa.d.ts +0 -8
  1018. package/blockly-rc/typings/msg/pl.d.ts +0 -8
  1019. package/blockly-rc/typings/msg/pms.d.ts +0 -8
  1020. package/blockly-rc/typings/msg/ps.d.ts +0 -8
  1021. package/blockly-rc/typings/msg/pt-br.d.ts +0 -8
  1022. package/blockly-rc/typings/msg/pt.d.ts +0 -8
  1023. package/blockly-rc/typings/msg/ro.d.ts +0 -8
  1024. package/blockly-rc/typings/msg/ru.d.ts +0 -8
  1025. package/blockly-rc/typings/msg/sc.d.ts +0 -8
  1026. package/blockly-rc/typings/msg/sco.d.ts +0 -8
  1027. package/blockly-rc/typings/msg/sd.d.ts +0 -8
  1028. package/blockly-rc/typings/msg/shn.d.ts +0 -8
  1029. package/blockly-rc/typings/msg/si.d.ts +0 -8
  1030. package/blockly-rc/typings/msg/sk.d.ts +0 -8
  1031. package/blockly-rc/typings/msg/skr-arab.d.ts +0 -8
  1032. package/blockly-rc/typings/msg/sl.d.ts +0 -8
  1033. package/blockly-rc/typings/msg/smn.d.ts +0 -8
  1034. package/blockly-rc/typings/msg/sq.d.ts +0 -8
  1035. package/blockly-rc/typings/msg/sr-latn.d.ts +0 -8
  1036. package/blockly-rc/typings/msg/sr.d.ts +0 -8
  1037. package/blockly-rc/typings/msg/sv.d.ts +0 -8
  1038. package/blockly-rc/typings/msg/sw.d.ts +0 -8
  1039. package/blockly-rc/typings/msg/ta.d.ts +0 -8
  1040. package/blockly-rc/typings/msg/tcy.d.ts +0 -8
  1041. package/blockly-rc/typings/msg/tdd.d.ts +0 -8
  1042. package/blockly-rc/typings/msg/te.d.ts +0 -8
  1043. package/blockly-rc/typings/msg/th.d.ts +0 -8
  1044. package/blockly-rc/typings/msg/ti.d.ts +0 -8
  1045. package/blockly-rc/typings/msg/tl.d.ts +0 -8
  1046. package/blockly-rc/typings/msg/tlh.d.ts +0 -8
  1047. package/blockly-rc/typings/msg/tr.d.ts +0 -8
  1048. package/blockly-rc/typings/msg/ug-arab.d.ts +0 -8
  1049. package/blockly-rc/typings/msg/uk.d.ts +0 -8
  1050. package/blockly-rc/typings/msg/ur.d.ts +0 -8
  1051. package/blockly-rc/typings/msg/uz.d.ts +0 -8
  1052. package/blockly-rc/typings/msg/vi.d.ts +0 -8
  1053. package/blockly-rc/typings/msg/xmf.d.ts +0 -8
  1054. package/blockly-rc/typings/msg/yo.d.ts +0 -8
  1055. package/blockly-rc/typings/msg/zgh.d.ts +0 -8
  1056. package/blockly-rc/typings/msg/zh-hans.d.ts +0 -8
  1057. package/blockly-rc/typings/msg/zh-hant.d.ts +0 -8
  1058. package/blockly-rc/typings/php.d.ts +0 -7
  1059. package/blockly-rc/typings/python.d.ts +0 -7
  1060. package/blockly-rc/typings/templates/blockly-header.template +0 -11
  1061. package/blockly-rc/typings/templates/blockly-interfaces.template +0 -83
  1062. package/blockly-rc/typings/templates/msg.template +0 -15
  1063. package/blockly-rc/typings/tsconfig.json +0 -23
  1064. package/temp-use-blockly-v12-rc.sh +0 -26
@@ -1,1578 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2019 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- import {assert} from '../../node_modules/chai/chai.js';
8
- import * as Blockly from '../../build/src/core/blockly.js';
9
- import {ASTNode} from '../../build/src/core/keyboard_nav/ast_node.js';
10
- import {
11
- assertEventEquals,
12
- assertNthCallEventArgEquals,
13
- createChangeListenerSpy,
14
- } from './test_helpers/events.js';
15
- import {assertVariableValues} from './test_helpers/variables.js';
16
- import {
17
- createGenUidStubWithReturns,
18
- sharedTestSetup,
19
- sharedTestTeardown,
20
- workspaceTeardown,
21
- } from './test_helpers/setup_teardown.js';
22
- import * as eventUtils from '../../build/src/core/events/utils.js';
23
-
24
- suite('Events', function () {
25
- setup(function () {
26
- sharedTestSetup.call(this, {fireEventsNow: false});
27
- this.eventsFireSpy = sinon.spy(eventUtils.TEST_ONLY, 'fireInternal');
28
- this.workspace = new Blockly.Workspace();
29
- Blockly.defineBlocksWithJsonArray([
30
- {
31
- 'type': 'field_variable_test_block',
32
- 'message0': '%1',
33
- 'args0': [
34
- {
35
- 'type': 'field_variable',
36
- 'name': 'VAR',
37
- 'variable': 'item',
38
- },
39
- ],
40
- },
41
- {
42
- 'type': 'simple_test_block',
43
- 'message0': 'simple test block',
44
- },
45
- ]);
46
- });
47
-
48
- teardown(function () {
49
- sharedTestTeardown.call(this);
50
- });
51
-
52
- function createSimpleTestBlock(workspace) {
53
- // Disable events while constructing the block: this is a test of the
54
- // Blockly.Event constructors, not the block constructors.
55
- // Set the group id to avoid an extra call to genUid.
56
- eventUtils.disable();
57
- let block;
58
- try {
59
- eventUtils.setGroup('unused');
60
- block = new Blockly.Block(workspace, 'simple_test_block');
61
- } finally {
62
- eventUtils.setGroup(false);
63
- }
64
- eventUtils.enable();
65
- return block;
66
- }
67
-
68
- suite('Constructors', function () {
69
- test('Abstract', function () {
70
- const event = new Blockly.Events.Abstract();
71
- assertEventEquals(event, '', undefined, undefined, {
72
- 'recordUndo': true,
73
- 'group': '',
74
- });
75
- });
76
-
77
- test('UI event without block', function () {
78
- const event = new Blockly.Events.UiBase(this.workspace.id);
79
- assertEventEquals(
80
- event,
81
- '',
82
- this.workspace.id,
83
- undefined,
84
- {
85
- 'recordUndo': false,
86
- 'group': '',
87
- },
88
- true,
89
- );
90
- });
91
-
92
- test('Click without block', function () {
93
- const event = new Blockly.Events.Click(
94
- null,
95
- this.workspace.id,
96
- 'workspace',
97
- );
98
- assertEventEquals(
99
- event,
100
- Blockly.Events.CLICK,
101
- this.workspace.id,
102
- null,
103
- {
104
- 'targetType': 'workspace',
105
- 'recordUndo': false,
106
- 'group': '',
107
- },
108
- true,
109
- );
110
- });
111
-
112
- suite('With simple blocks', function () {
113
- setup(function () {
114
- this.TEST_BLOCK_ID = 'test_block_id';
115
- this.TEST_PARENT_ID = 'parent';
116
- // genUid is expected to be called either once or twice in this suite.
117
- this.genUidStub = createGenUidStubWithReturns([
118
- this.TEST_BLOCK_ID,
119
- this.TEST_PARENT_ID,
120
- ]);
121
- this.block = createSimpleTestBlock(this.workspace);
122
- });
123
-
124
- test('Block base', function () {
125
- const event = new Blockly.Events.BlockBase(this.block);
126
- sinon.assert.calledOnce(this.genUidStub);
127
- assertEventEquals(event, '', this.workspace.id, this.TEST_BLOCK_ID, {
128
- 'recordUndo': true,
129
- 'group': '',
130
- });
131
- });
132
-
133
- test('Block create', function () {
134
- const event = new Blockly.Events.BlockCreate(this.block);
135
- sinon.assert.calledOnce(this.genUidStub);
136
- assertEventEquals(
137
- event,
138
- Blockly.Events.BLOCK_CREATE,
139
- this.workspace.id,
140
- this.TEST_BLOCK_ID,
141
- {
142
- 'recordUndo': true,
143
- 'group': '',
144
- },
145
- );
146
- });
147
-
148
- test('Block delete', function () {
149
- const event = new Blockly.Events.BlockDelete(this.block);
150
- sinon.assert.calledOnce(this.genUidStub);
151
- assertEventEquals(
152
- event,
153
- Blockly.Events.BLOCK_DELETE,
154
- this.workspace.id,
155
- this.TEST_BLOCK_ID,
156
- {
157
- 'recordUndo': true,
158
- 'group': '',
159
- },
160
- );
161
- });
162
-
163
- test('Click with block', function () {
164
- const TEST_GROUP_ID = 'testGroup';
165
- eventUtils.setGroup(TEST_GROUP_ID);
166
- const event = new Blockly.Events.Click(this.block, null, 'block');
167
- assertEventEquals(
168
- event,
169
- Blockly.Events.CLICK,
170
- this.workspace.id,
171
- this.TEST_BLOCK_ID,
172
- {
173
- 'targetType': 'block',
174
- 'recordUndo': false,
175
- 'group': TEST_GROUP_ID,
176
- },
177
- true,
178
- );
179
- });
180
-
181
- suite('Block Move', function () {
182
- test('by coordinate', function () {
183
- const coordinate = new Blockly.utils.Coordinate(3, 4);
184
- this.block.xy_ = coordinate;
185
-
186
- const event = new Blockly.Events.BlockMove(this.block);
187
- sinon.assert.calledOnce(this.genUidStub);
188
- assertEventEquals(
189
- event,
190
- Blockly.Events.BLOCK_MOVE,
191
- this.workspace.id,
192
- this.TEST_BLOCK_ID,
193
- {
194
- 'oldParentId': undefined,
195
- 'oldInputName': undefined,
196
- 'oldCoordinate': coordinate,
197
- 'recordUndo': true,
198
- 'group': '',
199
- },
200
- );
201
- });
202
-
203
- test('by parent', function () {
204
- try {
205
- this.parentBlock = createSimpleTestBlock(this.workspace);
206
- this.block.parentBlock_ = this.parentBlock;
207
- this.block.xy_ = new Blockly.utils.Coordinate(3, 4);
208
- const event = new Blockly.Events.BlockMove(this.block);
209
- sinon.assert.calledTwice(this.genUidStub);
210
- assertEventEquals(
211
- event,
212
- Blockly.Events.BLOCK_MOVE,
213
- this.workspace.id,
214
- this.TEST_BLOCK_ID,
215
- {
216
- 'oldParentId': this.TEST_PARENT_ID,
217
- 'oldInputName': undefined,
218
- 'oldCoordinate': undefined,
219
- 'recordUndo': true,
220
- 'group': '',
221
- },
222
- );
223
- } finally {
224
- // This needs to be cleared, otherwise workspace.dispose will fail.
225
- this.block.parentBlock_ = null;
226
- }
227
- });
228
- });
229
- });
230
-
231
- suite('With shadow blocks', function () {
232
- setup(function () {
233
- this.TEST_BLOCK_ID = 'test_block_id';
234
- this.TEST_PARENT_ID = 'parent';
235
- // genUid is expected to be called either once or twice in this suite.
236
- this.genUidStub = createGenUidStubWithReturns([
237
- this.TEST_BLOCK_ID,
238
- this.TEST_PARENT_ID,
239
- ]);
240
- this.block = createSimpleTestBlock(this.workspace);
241
- this.block.setShadow(true);
242
- });
243
-
244
- test('Block base', function () {
245
- const event = new Blockly.Events.BlockBase(this.block);
246
- sinon.assert.calledOnce(this.genUidStub);
247
- assertEventEquals(event, '', this.workspace.id, this.TEST_BLOCK_ID, {
248
- 'varId': undefined,
249
- 'recordUndo': true,
250
- 'group': '',
251
- });
252
- });
253
-
254
- test('Block change', function () {
255
- const event = new Blockly.Events.BlockChange(
256
- this.block,
257
- 'field',
258
- 'FIELD_NAME',
259
- 'old',
260
- 'new',
261
- );
262
- sinon.assert.calledOnce(this.genUidStub);
263
- assertEventEquals(
264
- event,
265
- Blockly.Events.BLOCK_CHANGE,
266
- this.workspace.id,
267
- this.TEST_BLOCK_ID,
268
- {
269
- 'varId': undefined,
270
- 'element': 'field',
271
- 'name': 'FIELD_NAME',
272
- 'oldValue': 'old',
273
- 'newValue': 'new',
274
- 'recordUndo': true,
275
- 'group': '',
276
- },
277
- );
278
- });
279
-
280
- test('Block create', function () {
281
- const event = new Blockly.Events.BlockCreate(this.block);
282
- sinon.assert.calledOnce(this.genUidStub);
283
- assertEventEquals(
284
- event,
285
- Blockly.Events.BLOCK_CREATE,
286
- this.workspace.id,
287
- this.TEST_BLOCK_ID,
288
- {
289
- 'recordUndo': false,
290
- 'group': '',
291
- },
292
- );
293
- });
294
-
295
- test('Block delete', function () {
296
- const event = new Blockly.Events.BlockDelete(this.block);
297
- sinon.assert.calledOnce(this.genUidStub);
298
- assertEventEquals(
299
- event,
300
- Blockly.Events.BLOCK_DELETE,
301
- this.workspace.id,
302
- this.TEST_BLOCK_ID,
303
- {
304
- 'recordUndo': false,
305
- 'group': '',
306
- },
307
- );
308
- });
309
-
310
- test('Block move', function () {
311
- try {
312
- this.parentBlock = createSimpleTestBlock(this.workspace);
313
- this.block.parentBlock_ = this.parentBlock;
314
- this.block.xy_ = new Blockly.utils.Coordinate(3, 4);
315
- const event = new Blockly.Events.BlockMove(this.block);
316
- sinon.assert.calledTwice(this.genUidStub);
317
- assertEventEquals(
318
- event,
319
- Blockly.Events.BLOCK_MOVE,
320
- this.workspace.id,
321
- this.TEST_BLOCK_ID,
322
- {
323
- 'oldParentId': this.TEST_PARENT_ID,
324
- 'oldInputName': undefined,
325
- 'oldCoordinate': undefined,
326
- 'recordUndo': false,
327
- 'group': '',
328
- },
329
- );
330
- } finally {
331
- // This needs to be cleared, otherwise workspace.dispose will fail.
332
- this.block.parentBlock_ = null;
333
- }
334
- });
335
- });
336
-
337
- suite('With variable getter blocks', function () {
338
- setup(function () {
339
- this.genUidStub = createGenUidStubWithReturns([
340
- this.TEST_BLOCK_ID,
341
- 'test_var_id',
342
- 'test_group_id',
343
- ]);
344
- // Disabling events when creating a block with variable can cause issues
345
- // at workspace dispose.
346
- this.block = new Blockly.Block(
347
- this.workspace,
348
- 'field_variable_test_block',
349
- );
350
- });
351
-
352
- test('Block change', function () {
353
- const event = new Blockly.Events.BlockChange(
354
- this.block,
355
- 'field',
356
- 'VAR',
357
- 'id1',
358
- 'id2',
359
- );
360
- assertEventEquals(
361
- event,
362
- Blockly.Events.BLOCK_CHANGE,
363
- this.workspace.id,
364
- this.TEST_BLOCK_ID,
365
- {
366
- 'element': 'field',
367
- 'name': 'VAR',
368
- 'oldValue': 'id1',
369
- 'newValue': 'id2',
370
- 'recordUndo': true,
371
- 'group': '',
372
- },
373
- );
374
- });
375
- });
376
- });
377
-
378
- suite('Serialization', function () {
379
- const safeStringify = (json) => {
380
- const cache = [];
381
- return JSON.stringify(json, (key, value) => {
382
- if (typeof value == 'object' && value != null) {
383
- if (cache.includes(value)) {
384
- // Discard duplicate reference.
385
- return undefined;
386
- }
387
- cache.push(value);
388
- return value;
389
- }
390
- return value;
391
- });
392
- };
393
- const variableEventTestCases = [
394
- {
395
- title: 'Var create',
396
- class: Blockly.Events.VarCreate,
397
- getArgs: (thisObj) => [thisObj.variable],
398
- getExpectedJson: () => ({
399
- type: 'var_create',
400
- group: '',
401
- varId: 'id1',
402
- varType: 'type1',
403
- varName: 'name1',
404
- }),
405
- },
406
- {
407
- title: 'Var delete',
408
- class: Blockly.Events.VarDelete,
409
- getArgs: (thisObj) => [thisObj.variable],
410
- getExpectedJson: () => ({
411
- type: 'var_delete',
412
- group: '',
413
- varId: 'id1',
414
- varType: 'type1',
415
- varName: 'name1',
416
- }),
417
- },
418
- {
419
- title: 'Var rename',
420
- class: Blockly.Events.VarRename,
421
- getArgs: (thisObj) => [thisObj.variable, 'name2'],
422
- getExpectedJson: () => ({
423
- type: 'var_rename',
424
- group: '',
425
- varId: 'id1',
426
- oldName: 'name1',
427
- newName: 'name2',
428
- }),
429
- },
430
- ];
431
- const uiEventTestCases = [
432
- {
433
- title: 'Bubble open',
434
- class: Blockly.Events.BubbleOpen,
435
- getArgs: (thisObj) => [thisObj.block, true, 'mutator'],
436
- getExpectedJson: (thisObj) => ({
437
- type: 'bubble_open',
438
- group: '',
439
- isOpen: true,
440
- bubbleType: 'mutator',
441
- blockId: thisObj.block.id,
442
- }),
443
- },
444
- {
445
- title: 'Block click',
446
- class: Blockly.Events.Click,
447
- getArgs: (thisObj) => [thisObj.block, null, 'block'],
448
- getExpectedJson: (thisObj) => ({
449
- type: 'click',
450
- group: '',
451
- targetType: 'block',
452
- blockId: thisObj.block.id,
453
- }),
454
- },
455
- {
456
- title: 'Workspace click',
457
- class: Blockly.Events.Click,
458
- getArgs: (thisObj) => [null, thisObj.workspace.id, 'workspace'],
459
- getExpectedJson: (thisObj) => ({
460
- type: 'click',
461
- group: '',
462
- targetType: 'workspace',
463
- }),
464
- },
465
- {
466
- title: 'Drag start',
467
- class: Blockly.Events.BlockDrag,
468
- getArgs: (thisObj) => [thisObj.block, true, [thisObj.block]],
469
- getExpectedJson: (thisObj) => ({
470
- type: 'drag',
471
- group: '',
472
- isStart: true,
473
- blockId: thisObj.block.id,
474
- blocks: [thisObj.block],
475
- }),
476
- },
477
- {
478
- title: 'Drag end',
479
- class: Blockly.Events.BlockDrag,
480
- getArgs: (thisObj) => [thisObj.block, false, [thisObj.block]],
481
- getExpectedJson: (thisObj) => ({
482
- type: 'drag',
483
- group: '',
484
- isStart: false,
485
- blockId: thisObj.block.id,
486
- blocks: [thisObj.block],
487
- }),
488
- },
489
- {
490
- title: 'Field Edit Intermediate Change',
491
- class: Blockly.Events.BlockFieldIntermediateChange,
492
- getArgs: (thisObj) => [thisObj.block, 'test', 'old value', 'new value'],
493
- getExpectedJson: (thisObj) => ({
494
- type: 'block_field_intermediate_change',
495
- group: '',
496
- blockId: thisObj.block.id,
497
- name: 'test',
498
- oldValue: 'old value',
499
- newValue: 'new value',
500
- }),
501
- },
502
- {
503
- title: 'null to Block Marker move',
504
- class: Blockly.Events.MarkerMove,
505
- getArgs: (thisObj) => [
506
- thisObj.block,
507
- true,
508
- null,
509
- new ASTNode(ASTNode.types.BLOCK, thisObj.block),
510
- ],
511
- getExpectedJson: (thisObj) => ({
512
- type: 'marker_move',
513
- group: '',
514
- isCursor: true,
515
- blockId: thisObj.block.id,
516
- oldNode: undefined,
517
- newNode: new ASTNode(ASTNode.types.BLOCK, thisObj.block),
518
- }),
519
- },
520
- {
521
- title: 'null to Workspace Marker move',
522
- class: Blockly.Events.MarkerMove,
523
- getArgs: (thisObj) => [
524
- null,
525
- true,
526
- null,
527
- ASTNode.createWorkspaceNode(
528
- thisObj.workspace,
529
- new Blockly.utils.Coordinate(0, 0),
530
- ),
531
- ],
532
- getExpectedJson: (thisObj) => ({
533
- type: 'marker_move',
534
- group: '',
535
- isCursor: true,
536
- blockId: undefined,
537
- oldNode: undefined,
538
- newNode: ASTNode.createWorkspaceNode(
539
- thisObj.workspace,
540
- new Blockly.utils.Coordinate(0, 0),
541
- ),
542
- }),
543
- },
544
- {
545
- title: 'Workspace to Block Marker move',
546
- class: Blockly.Events.MarkerMove,
547
- getArgs: (thisObj) => [
548
- thisObj.block,
549
- true,
550
- ASTNode.createWorkspaceNode(
551
- thisObj.workspace,
552
- new Blockly.utils.Coordinate(0, 0),
553
- ),
554
- new ASTNode(ASTNode.types.BLOCK, thisObj.block),
555
- ],
556
- getExpectedJson: (thisObj) => ({
557
- type: 'marker_move',
558
- group: '',
559
- isCursor: true,
560
- blockId: thisObj.block.id,
561
- oldNode: ASTNode.createWorkspaceNode(
562
- thisObj.workspace,
563
- new Blockly.utils.Coordinate(0, 0),
564
- ),
565
- newNode: new ASTNode(ASTNode.types.BLOCK, thisObj.block),
566
- }),
567
- },
568
- {
569
- title: 'Block to Workspace Marker move',
570
- class: Blockly.Events.MarkerMove,
571
- getArgs: (thisObj) => [
572
- null,
573
- true,
574
- new ASTNode(ASTNode.types.BLOCK, thisObj.block),
575
- ASTNode.createWorkspaceNode(
576
- thisObj.workspace,
577
- new Blockly.utils.Coordinate(0, 0),
578
- ),
579
- ],
580
- },
581
- {
582
- title: 'Selected',
583
- class: Blockly.Events.Selected,
584
- getArgs: (thisObj) => [null, thisObj.block.id, thisObj.workspace.id],
585
- getExpectedJson: (thisObj) => ({
586
- type: 'selected',
587
- group: '',
588
- newElementId: thisObj.block.id,
589
- }),
590
- },
591
- {
592
- title: 'Selected (deselect)',
593
- class: Blockly.Events.Selected,
594
- getArgs: (thisObj) => [thisObj.block.id, null, thisObj.workspace.id],
595
- getExpectedJson: (thisObj) => ({
596
- type: 'selected',
597
- group: '',
598
- oldElementId: thisObj.block.id,
599
- }),
600
- },
601
- {
602
- title: 'Theme Change',
603
- class: Blockly.Events.ThemeChange,
604
- getArgs: (thisObj) => ['classic', thisObj.workspace.id],
605
- getExpectedJson: () => ({
606
- type: 'theme_change',
607
- group: '',
608
- themeName: 'classic',
609
- }),
610
- },
611
- {
612
- title: 'Toolbox item select',
613
- class: Blockly.Events.ToolboxItemSelect,
614
- getArgs: (thisObj) => ['Math', 'Loops', thisObj.workspace.id],
615
- getExpectedJson: () => ({
616
- type: 'toolbox_item_select',
617
- group: '',
618
- oldItem: 'Math',
619
- newItem: 'Loops',
620
- }),
621
- },
622
- {
623
- title: 'Toolbox item select (no previous)',
624
- class: Blockly.Events.ToolboxItemSelect,
625
- getArgs: (thisObj) => [null, 'Loops', thisObj.workspace.id],
626
- getExpectedJson: () => ({
627
- type: 'toolbox_item_select',
628
- group: '',
629
- newItem: 'Loops',
630
- }),
631
- },
632
- {
633
- title: 'Toolbox item select (deselect)',
634
- class: Blockly.Events.ToolboxItemSelect,
635
- getArgs: (thisObj) => ['Math', null, thisObj.workspace.id],
636
- getExpectedJson: () => ({
637
- type: 'toolbox_item_select',
638
- group: '',
639
- oldItem: 'Math',
640
- }),
641
- },
642
- {
643
- title: 'Trashcan open',
644
- class: Blockly.Events.TrashcanOpen,
645
- getArgs: (thisObj) => [true, thisObj.workspace.id],
646
- getExpectedJson: () => ({
647
- type: 'trashcan_open',
648
- group: '',
649
- isOpen: true,
650
- }),
651
- },
652
- {
653
- title: 'Viewport change',
654
- class: Blockly.Events.ViewportChange,
655
- getArgs: (thisObj) => [2.666, 1.333, 1.2, thisObj.workspace.id, 1],
656
- getExpectedJson: () => ({
657
- type: 'viewport_change',
658
- group: '',
659
- viewTop: 2.666,
660
- viewLeft: 1.333,
661
- scale: 1.2,
662
- oldScale: 1,
663
- }),
664
- },
665
- {
666
- title: 'Viewport change (0,0)',
667
- class: Blockly.Events.ViewportChange,
668
- getArgs: (thisObj) => [0, 0, 1.2, thisObj.workspace.id, 1],
669
- getExpectedJson: () => ({
670
- type: 'viewport_change',
671
- group: '',
672
- viewTop: 0,
673
- viewLeft: 0,
674
- scale: 1.2,
675
- oldScale: 1,
676
- }),
677
- },
678
- ];
679
- const blockEventTestCases = [
680
- {
681
- title: 'Block change',
682
- class: Blockly.Events.BlockChange,
683
- getArgs: (thisObj) => [thisObj.block, 'collapsed', null, false, true],
684
- getExpectedJson: (thisObj) => ({
685
- type: 'change',
686
- group: '',
687
- blockId: thisObj.block.id,
688
- element: 'collapsed',
689
- oldValue: false,
690
- newValue: true,
691
- }),
692
- },
693
- {
694
- title: 'Block create',
695
- class: Blockly.Events.BlockCreate,
696
- getArgs: (thisObj) => [thisObj.block],
697
- getExpectedJson: (thisObj) => ({
698
- type: 'create',
699
- group: '',
700
- blockId: thisObj.block.id,
701
- xml:
702
- '<block xmlns="https://developers.google.com/blockly/xml"' +
703
- ' type="simple_test_block" id="testBlockId1" x="0" y="0">' +
704
- '</block>',
705
- ids: [thisObj.block.id],
706
- json: {
707
- 'type': 'simple_test_block',
708
- 'id': 'testBlockId1',
709
- 'x': 0,
710
- 'y': 0,
711
- },
712
- }),
713
- },
714
- {
715
- title: 'Block create (shadow)',
716
- class: Blockly.Events.BlockCreate,
717
- getArgs: (thisObj) => [thisObj.shadowBlock],
718
- getExpectedJson: (thisObj) => ({
719
- type: 'create',
720
- group: '',
721
- blockId: thisObj.shadowBlock.id,
722
- xml:
723
- '<shadow xmlns="https://developers.google.com/blockly/xml"' +
724
- ' type="simple_test_block" id="testBlockId2" x="0" y="0">' +
725
- '</shadow>',
726
- ids: [thisObj.shadowBlock.id],
727
- json: {
728
- 'type': 'simple_test_block',
729
- 'id': 'testBlockId2',
730
- 'x': 0,
731
- 'y': 0,
732
- },
733
- recordUndo: false,
734
- }),
735
- },
736
- {
737
- title: 'Block delete',
738
- class: Blockly.Events.BlockDelete,
739
- getArgs: (thisObj) => [thisObj.block],
740
- getExpectedJson: (thisObj) => ({
741
- type: 'delete',
742
- group: '',
743
- blockId: thisObj.block.id,
744
- oldXml:
745
- '<block xmlns="https://developers.google.com/blockly/xml"' +
746
- ' type="simple_test_block" id="testBlockId1" x="0" y="0">' +
747
- '</block>',
748
- ids: [thisObj.block.id],
749
- wasShadow: false,
750
- oldJson: {
751
- 'type': 'simple_test_block',
752
- 'id': 'testBlockId1',
753
- 'x': 0,
754
- 'y': 0,
755
- },
756
- }),
757
- },
758
- {
759
- title: 'Block delete (shadow)',
760
- class: Blockly.Events.BlockDelete,
761
- getArgs: (thisObj) => [thisObj.shadowBlock],
762
- getExpectedJson: (thisObj) => ({
763
- type: 'delete',
764
- group: '',
765
- blockId: thisObj.shadowBlock.id,
766
- oldXml:
767
- '<shadow xmlns="https://developers.google.com/blockly/xml"' +
768
- ' type="simple_test_block" id="testBlockId2" x="0" y="0">' +
769
- '</shadow>',
770
- ids: [thisObj.shadowBlock.id],
771
- wasShadow: true,
772
- oldJson: {
773
- 'type': 'simple_test_block',
774
- 'id': 'testBlockId2',
775
- 'x': 0,
776
- 'y': 0,
777
- },
778
- recordUndo: false,
779
- }),
780
- },
781
- // TODO(#4577) Test serialization of move event coordinate properties.
782
- {
783
- title: 'Block move',
784
- class: Blockly.Events.BlockMove,
785
- getArgs: (thisObj) => [thisObj.block],
786
- getExpectedJson: (thisObj) => ({
787
- type: 'move',
788
- group: '',
789
- blockId: thisObj.block.id,
790
- oldCoordinate: '0, 0',
791
- }),
792
- },
793
- {
794
- title: 'Block move (shadow)',
795
- class: Blockly.Events.BlockMove,
796
- getArgs: (thisObj) => [thisObj.shadowBlock],
797
- getExpectedJson: (thisObj) => ({
798
- type: 'move',
799
- group: '',
800
- blockId: thisObj.shadowBlock.id,
801
- oldCoordinate: '0, 0',
802
- recordUndo: false,
803
- }),
804
- },
805
- ];
806
- const workspaceCommentEventTestCases = [
807
- {
808
- title: 'Comment change',
809
- class: Blockly.Events.CommentChange,
810
- getArgs: (thisObj) => [thisObj.comment, 'bar', 'foo'],
811
- getExpectedJson: (thisObj) => ({
812
- type: 'comment_change',
813
- group: '',
814
- commentId: thisObj.comment.id,
815
- oldContents: 'bar',
816
- newContents: 'foo',
817
- }),
818
- },
819
- {
820
- title: 'Comment create',
821
- class: Blockly.Events.CommentCreate,
822
- getArgs: (thisObj) => [thisObj.comment],
823
- getExpectedJson: (thisObj) => ({
824
- type: 'comment_create',
825
- group: '',
826
- commentId: thisObj.comment.id,
827
- // TODO: Before merging, is this a dumb change detector?
828
- xml: Blockly.Xml.domToText(
829
- Blockly.Xml.saveWorkspaceComment(thisObj.comment),
830
- {addCoordinates: true},
831
- ),
832
- json: {
833
- height: 100,
834
- width: 120,
835
- id: 'comment id',
836
- x: 0,
837
- y: 0,
838
- text: 'test text',
839
- },
840
- }),
841
- },
842
- {
843
- title: 'Comment delete',
844
- class: Blockly.Events.CommentDelete,
845
- getArgs: (thisObj) => [thisObj.comment],
846
- getExpectedJson: (thisObj) => ({
847
- type: 'comment_delete',
848
- group: '',
849
- commentId: thisObj.comment.id,
850
- // TODO: Before merging, is this a dumb change detector?
851
- xml: Blockly.Xml.domToText(
852
- Blockly.Xml.saveWorkspaceComment(thisObj.comment),
853
- {addCoordinates: true},
854
- ),
855
- json: {
856
- height: 100,
857
- width: 120,
858
- id: 'comment id',
859
- x: 0,
860
- y: 0,
861
- text: 'test text',
862
- },
863
- }),
864
- },
865
- {
866
- title: 'Comment drag start',
867
- class: Blockly.Events.CommentDrag,
868
- getArgs: (thisObj) => [thisObj.comment, true],
869
- getExpectedJson: (thisObj) => ({
870
- type: 'comment_drag',
871
- group: '',
872
- isStart: true,
873
- commentId: thisObj.comment.id,
874
- }),
875
- },
876
- {
877
- title: 'Comment drag end',
878
- class: Blockly.Events.CommentDrag,
879
- getArgs: (thisObj) => [thisObj.comment, false],
880
- getExpectedJson: (thisObj) => ({
881
- type: 'comment_drag',
882
- group: '',
883
- isStart: false,
884
- commentId: thisObj.comment.id,
885
- }),
886
- },
887
- // TODO(#4577) Test serialization of move event coordinate properties.
888
- // TODO(#4577) Test serialization of comment resize event properties.
889
- ];
890
- const testSuites = [
891
- {
892
- title: 'Variable events',
893
- testCases: variableEventTestCases,
894
- setup: (thisObj) => {
895
- thisObj.variable = thisObj.workspace.createVariable(
896
- 'name1',
897
- 'type1',
898
- 'id1',
899
- );
900
- },
901
- },
902
- {
903
- title: 'UI events',
904
- testCases: uiEventTestCases,
905
- setup: (thisObj) => {
906
- thisObj.block = createSimpleTestBlock(thisObj.workspace);
907
- },
908
- },
909
- {
910
- title: 'Block events',
911
- testCases: blockEventTestCases,
912
- setup: (thisObj) => {
913
- createGenUidStubWithReturns(['testBlockId1', 'testBlockId2']);
914
- thisObj.block = createSimpleTestBlock(thisObj.workspace);
915
- thisObj.shadowBlock = createSimpleTestBlock(thisObj.workspace);
916
- thisObj.shadowBlock.setShadow(true);
917
- },
918
- },
919
- {
920
- title: 'WorkspaceComment events',
921
- testCases: workspaceCommentEventTestCases,
922
- setup: (thisObj) => {
923
- thisObj.comment = new Blockly.comments.WorkspaceComment(
924
- thisObj.workspace,
925
- 'comment id',
926
- );
927
- thisObj.comment.setText('test text');
928
- },
929
- },
930
- ];
931
- testSuites.forEach((testSuite) => {
932
- suite(testSuite.title, function () {
933
- setup(function () {
934
- testSuite.setup(this);
935
- });
936
- suite('fromJson', function () {
937
- testSuite.testCases.forEach((testCase) => {
938
- test(testCase.title, function () {
939
- const event = new testCase.class(...testCase.getArgs(this));
940
- const json = event.toJson();
941
- const event2 = Blockly.Events.fromJson(json, this.workspace);
942
-
943
- assert.equal(safeStringify(event2.toJson()), safeStringify(json));
944
- });
945
- });
946
- });
947
- suite('toJson', function () {
948
- testSuite.testCases.forEach((testCase) => {
949
- if (testCase.getExpectedJson) {
950
- test(testCase.title, function () {
951
- const event = new testCase.class(...testCase.getArgs(this));
952
- const json = event.toJson();
953
- const expectedJson = testCase.getExpectedJson(this);
954
-
955
- assert.equal(safeStringify(json), safeStringify(expectedJson));
956
- });
957
- }
958
- });
959
- });
960
- });
961
- });
962
- });
963
-
964
- suite('Variable events', function () {
965
- setup(function () {
966
- this.variable = this.workspace.createVariable('name1', 'type1', 'id1');
967
- });
968
-
969
- /**
970
- * Check if a variable with the given values exists.
971
- * @param {Blockly.Workspace|Blockly.VariableMap} container The workspace or
972
- * variableMap the checked variable belongs to.
973
- * @param {!string} name The expected name of the variable.
974
- * @param {!string} type The expected type of the variable.
975
- * @param {!string} id The expected id of the variable.
976
- */
977
- function checkVariableValues(container, name, type, id) {
978
- const variable = container.getVariableById(id);
979
- assert.isDefined(variable);
980
- assert.equal(name, variable.name);
981
- assert.equal(type, variable.type);
982
- assert.equal(id, variable.getId());
983
- }
984
-
985
- suite('Constructors', function () {
986
- test('Var base', function () {
987
- const event = new Blockly.Events.VarBase(this.variable);
988
- assertEventEquals(event, '', this.workspace.id, undefined, {
989
- 'varId': 'id1',
990
- 'recordUndo': true,
991
- 'group': '',
992
- });
993
- });
994
-
995
- test('Var create', function () {
996
- const event = new Blockly.Events.VarCreate(this.variable);
997
- assertEventEquals(
998
- event,
999
- Blockly.Events.VAR_CREATE,
1000
- this.workspace.id,
1001
- undefined,
1002
- {
1003
- 'varId': 'id1',
1004
- 'varType': 'type1',
1005
- 'varName': 'name1',
1006
- 'recordUndo': true,
1007
- 'group': '',
1008
- },
1009
- );
1010
- });
1011
-
1012
- test('Var delete', function () {
1013
- const event = new Blockly.Events.VarDelete(this.variable);
1014
- assertEventEquals(
1015
- event,
1016
- Blockly.Events.VAR_DELETE,
1017
- this.workspace.id,
1018
- undefined,
1019
- {
1020
- 'varId': 'id1',
1021
- 'varType': 'type1',
1022
- 'varName': 'name1',
1023
- 'recordUndo': true,
1024
- 'group': '',
1025
- },
1026
- );
1027
- });
1028
-
1029
- test('Var rename', function () {
1030
- const event = new Blockly.Events.VarRename(this.variable, 'name2');
1031
- assertEventEquals(
1032
- event,
1033
- Blockly.Events.VAR_RENAME,
1034
- this.workspace.id,
1035
- undefined,
1036
- {
1037
- 'varId': 'id1',
1038
- 'oldName': 'name1',
1039
- 'newName': 'name2',
1040
- 'recordUndo': true,
1041
- 'group': '',
1042
- },
1043
- );
1044
- });
1045
- });
1046
-
1047
- suite('Run Forward', function () {
1048
- test('Var create', function () {
1049
- const json = {
1050
- type: 'var_create',
1051
- varId: 'id2',
1052
- varType: 'type2',
1053
- varName: 'name2',
1054
- };
1055
- const event = eventUtils.fromJson(json, this.workspace);
1056
- const x = this.workspace.getVariableById('id2');
1057
- assert.isNull(x);
1058
- event.run(true);
1059
- assertVariableValues(this.workspace, 'name2', 'type2', 'id2');
1060
- });
1061
-
1062
- test('Var delete', function () {
1063
- const event = new Blockly.Events.VarDelete(this.variable);
1064
- assert.isNotNull(this.workspace.getVariableById('id1'));
1065
- event.run(true);
1066
- assert.isNull(this.workspace.getVariableById('id1'));
1067
- });
1068
-
1069
- test('Var rename', function () {
1070
- const event = new Blockly.Events.VarRename(this.variable, 'name2');
1071
- event.run(true);
1072
- assert.isNull(this.workspace.getVariable('name1'));
1073
- checkVariableValues(this.workspace, 'name2', 'type1', 'id1');
1074
- });
1075
- });
1076
- suite('Run Backward', function () {
1077
- test('Var create', function () {
1078
- const event = new Blockly.Events.VarCreate(this.variable);
1079
- assert.isNotNull(this.workspace.getVariableById('id1'));
1080
- event.run(false);
1081
- });
1082
-
1083
- test('Var delete', function () {
1084
- const json = {
1085
- type: 'var_delete',
1086
- varId: 'id2',
1087
- varType: 'type2',
1088
- varName: 'name2',
1089
- };
1090
- const event = eventUtils.fromJson(json, this.workspace);
1091
- assert.isNull(this.workspace.getVariableById('id2'));
1092
- event.run(false);
1093
- assertVariableValues(this.workspace, 'name2', 'type2', 'id2');
1094
- });
1095
-
1096
- test('Var rename', function () {
1097
- const event = new Blockly.Events.VarRename(this.variable, 'name2');
1098
- event.run(false);
1099
- assert.isNull(this.workspace.getVariable('name2'));
1100
- checkVariableValues(this.workspace, 'name1', 'type1', 'id1');
1101
- });
1102
- });
1103
- });
1104
-
1105
- suite('Filters', function () {
1106
- function addMoveEvent(events, block, newX, newY) {
1107
- events.push(new Blockly.Events.BlockMove(block));
1108
- block.xy_ = new Blockly.utils.Coordinate(newX, newY);
1109
- events[events.length - 1].recordNew();
1110
- }
1111
-
1112
- function addMoveEventParent(events, block, parent) {
1113
- events.push(new Blockly.Events.BlockMove(block));
1114
- block.setParent(parent);
1115
- events[events.length - 1].recordNew();
1116
- }
1117
-
1118
- test('No removed, order unchanged', function () {
1119
- const block = this.workspace.newBlock('field_variable_test_block', '1');
1120
- const events = [
1121
- new Blockly.Events.BlockCreate(block),
1122
- new Blockly.Events.BlockMove(block),
1123
- new Blockly.Events.BlockChange(block, 'field', 'VAR', 'id1', 'id2'),
1124
- new Blockly.Events.Click(block),
1125
- ];
1126
- const filteredEvents = eventUtils.filter(events, true);
1127
- assert.equal(filteredEvents.length, 4); // no event should have been removed.
1128
- // test that the order hasn't changed
1129
- assert.isTrue(filteredEvents[0] instanceof Blockly.Events.BlockCreate);
1130
- assert.isTrue(filteredEvents[1] instanceof Blockly.Events.BlockMove);
1131
- assert.isTrue(filteredEvents[2] instanceof Blockly.Events.BlockChange);
1132
- assert.isTrue(filteredEvents[3] instanceof Blockly.Events.Click);
1133
- });
1134
-
1135
- test('Different blocks no removed', function () {
1136
- const block1 = this.workspace.newBlock('field_variable_test_block', '1');
1137
- const block2 = this.workspace.newBlock('field_variable_test_block', '2');
1138
- const events = [
1139
- new Blockly.Events.BlockCreate(block1),
1140
- new Blockly.Events.BlockMove(block1),
1141
- new Blockly.Events.BlockCreate(block2),
1142
- new Blockly.Events.BlockMove(block2),
1143
- ];
1144
- const filteredEvents = eventUtils.filter(events, true);
1145
- assert.equal(filteredEvents.length, 4); // no event should have been removed.
1146
- });
1147
-
1148
- test('Forward', function () {
1149
- const block = this.workspace.newBlock('field_variable_test_block', '1');
1150
- const events = [new Blockly.Events.BlockCreate(block)];
1151
- addMoveEvent(events, block, 1, 1);
1152
- addMoveEvent(events, block, 2, 2);
1153
- addMoveEvent(events, block, 3, 3);
1154
- const filteredEvents = eventUtils.filter(events, true);
1155
- assert.equal(filteredEvents.length, 2); // duplicate moves should have been removed.
1156
- // test that the order hasn't changed
1157
- assert.isTrue(filteredEvents[0] instanceof Blockly.Events.BlockCreate);
1158
- assert.isTrue(filteredEvents[1] instanceof Blockly.Events.BlockMove);
1159
- assert.equal(filteredEvents[1].newCoordinate.x, 3);
1160
- assert.equal(filteredEvents[1].newCoordinate.y, 3);
1161
- });
1162
-
1163
- test('Backward', function () {
1164
- const block = this.workspace.newBlock('field_variable_test_block', '1');
1165
- const events = [new Blockly.Events.BlockCreate(block)];
1166
- addMoveEvent(events, block, 1, 1);
1167
- addMoveEvent(events, block, 2, 2);
1168
- addMoveEvent(events, block, 3, 3);
1169
- const filteredEvents = eventUtils.filter(events, false);
1170
- assert.equal(filteredEvents.length, 2); // duplicate event should have been removed.
1171
- // test that the order hasn't changed
1172
- assert.isTrue(filteredEvents[0] instanceof Blockly.Events.BlockCreate);
1173
- assert.isTrue(filteredEvents[1] instanceof Blockly.Events.BlockMove);
1174
- assert.equal(filteredEvents[1].newCoordinate.x, 1);
1175
- assert.equal(filteredEvents[1].newCoordinate.y, 1);
1176
- });
1177
-
1178
- test('Merge block move events', function () {
1179
- const block = this.workspace.newBlock('field_variable_test_block', '1');
1180
- const events = [];
1181
- addMoveEvent(events, block, 0, 0);
1182
- addMoveEvent(events, block, 1, 1);
1183
- const filteredEvents = eventUtils.filter(events, true);
1184
- assert.equal(filteredEvents.length, 1); // second move event merged into first
1185
- assert.equal(filteredEvents[0].newCoordinate.x, 1);
1186
- assert.equal(filteredEvents[0].newCoordinate.y, 1);
1187
- });
1188
-
1189
- test('Merge block change events', function () {
1190
- const block1 = this.workspace.newBlock('field_variable_test_block', '1');
1191
- const events = [
1192
- new Blockly.Events.BlockChange(block1, 'field', 'VAR', 'item', 'item1'),
1193
- new Blockly.Events.BlockChange(
1194
- block1,
1195
- 'field',
1196
- 'VAR',
1197
- 'item1',
1198
- 'item2',
1199
- ),
1200
- ];
1201
- const filteredEvents = eventUtils.filter(events, true);
1202
- assert.equal(filteredEvents.length, 1); // second change event merged into first
1203
- assert.equal(filteredEvents[0].oldValue, 'item');
1204
- assert.equal(filteredEvents[0].newValue, 'item2');
1205
- });
1206
-
1207
- test('Merge viewport change events', function () {
1208
- const events = [
1209
- new Blockly.Events.ViewportChange(1, 2, 3, this.workspace, 4),
1210
- new Blockly.Events.ViewportChange(5, 6, 7, this.workspace, 8),
1211
- ];
1212
- const filteredEvents = eventUtils.filter(events, true);
1213
- assert.equal(filteredEvents.length, 1); // second change event merged into first
1214
- assert.equal(filteredEvents[0].viewTop, 5);
1215
- assert.equal(filteredEvents[0].viewLeft, 6);
1216
- assert.equal(filteredEvents[0].scale, 7);
1217
- assert.equal(filteredEvents[0].oldScale, 8);
1218
- });
1219
-
1220
- test('Merge ui events', function () {
1221
- const block1 = this.workspace.newBlock('field_variable_test_block', '1');
1222
- const block2 = this.workspace.newBlock('field_variable_test_block', '2');
1223
- const block3 = this.workspace.newBlock('field_variable_test_block', '3');
1224
- const events = [
1225
- new Blockly.Events.BubbleOpen(block1, true, 'comment'),
1226
- new Blockly.Events.Click(block1),
1227
- new Blockly.Events.BubbleOpen(block2, true, 'mutator'),
1228
- new Blockly.Events.Click(block2),
1229
- new Blockly.Events.BubbleOpen(block3, true, 'warning'),
1230
- new Blockly.Events.Click(block3),
1231
- ];
1232
- const filteredEvents = eventUtils.filter(events, true);
1233
- // click event merged into corresponding *Open event
1234
- assert.equal(filteredEvents.length, 3);
1235
- assert.isTrue(filteredEvents[0] instanceof Blockly.Events.BubbleOpen);
1236
- assert.isTrue(filteredEvents[1] instanceof Blockly.Events.BubbleOpen);
1237
- assert.isTrue(filteredEvents[2] instanceof Blockly.Events.BubbleOpen);
1238
- assert.equal(filteredEvents[0].bubbleType, 'comment');
1239
- assert.equal(filteredEvents[1].bubbleType, 'mutator');
1240
- assert.equal(filteredEvents[2].bubbleType, 'warning');
1241
- });
1242
-
1243
- test('Colliding events not dropped', function () {
1244
- // Tests that events that collide on a (event, block, workspace) tuple
1245
- // but cannot be merged do not get dropped during filtering.
1246
- const block = this.workspace.newBlock('field_variable_test_block', '1');
1247
- const events = [
1248
- new Blockly.Events.Click(block),
1249
- new Blockly.Events.BlockDrag(block, true),
1250
- ];
1251
- const filteredEvents = eventUtils.filter(events, true);
1252
- // click and stackclick should both exist
1253
- assert.equal(filteredEvents.length, 2);
1254
- assert.isTrue(filteredEvents[0] instanceof Blockly.Events.Click);
1255
- assert.equal(filteredEvents[1].isStart, true);
1256
- });
1257
-
1258
- test('Merging null operations dropped', function () {
1259
- // Mutator composition could result in move events for blocks
1260
- // connected to the mutated block that were null operations. This
1261
- // leads to events in the undo/redo queue that do nothing, requiring
1262
- // an extra undo/redo to proceed to the next event. This test ensures
1263
- // that two move events that do get merged (disconnecting and
1264
- // reconnecting a block in response to a mutator change) are filtered
1265
- // from the queue.
1266
- const block = this.workspace.newBlock('field_variable_test_block', '1');
1267
- block.setParent(null);
1268
- const events = [];
1269
- addMoveEventParent(events, block, null);
1270
- addMoveEventParent(events, block, null);
1271
- const filteredEvents = eventUtils.filter(events, true);
1272
- // The two events should be merged, but because nothing has changed
1273
- // they will be filtered out.
1274
- assert.equal(filteredEvents.length, 0);
1275
- });
1276
-
1277
- test('Move events different blocks not merged', function () {
1278
- // Move events should only merge if they refer to the same block and are
1279
- // consecutive.
1280
- // See github.com/google/blockly/pull/1892 for a worked example showing
1281
- // how merging non-consecutive events can fail when replacing a shadow
1282
- // block.
1283
- const block1 = createSimpleTestBlock(this.workspace);
1284
- const block2 = createSimpleTestBlock(this.workspace);
1285
-
1286
- const events = [];
1287
- addMoveEvent(events, block1, 1, 1);
1288
- addMoveEvent(events, block2, 1, 1);
1289
- events.push(new Blockly.Events.BlockDelete(block2));
1290
- addMoveEvent(events, block1, 2, 2);
1291
-
1292
- const filteredEvents = eventUtils.filter(events, true);
1293
- // Nothing should have merged.
1294
- assert.equal(filteredEvents.length, 4);
1295
- // test that the order hasn't changed
1296
- assert.isTrue(filteredEvents[0] instanceof Blockly.Events.BlockMove);
1297
- assert.isTrue(filteredEvents[1] instanceof Blockly.Events.BlockMove);
1298
- assert.isTrue(filteredEvents[2] instanceof Blockly.Events.BlockDelete);
1299
- assert.isTrue(filteredEvents[3] instanceof Blockly.Events.BlockMove);
1300
- });
1301
- });
1302
-
1303
- suite('Firing', function () {
1304
- setup(function () {
1305
- this.changeListenerSpy = createChangeListenerSpy(this.workspace);
1306
- });
1307
-
1308
- test('Block dispose triggers Delete', function () {
1309
- let workspaceSvg;
1310
- try {
1311
- const toolbox = document.getElementById('toolbox-categories');
1312
- workspaceSvg = Blockly.inject('blocklyDiv', {toolbox: toolbox});
1313
- const TEST_BLOCK_ID = 'test_block_id';
1314
- const genUidStub = createGenUidStubWithReturns([
1315
- TEST_BLOCK_ID,
1316
- 'test_group_id',
1317
- ]);
1318
-
1319
- const block = workspaceSvg.newBlock('');
1320
- block.initSvg();
1321
- block.setCommentText('test comment');
1322
- const expectedOldXml = Blockly.Xml.blockToDomWithXY(block);
1323
- const expectedId = block.id;
1324
-
1325
- // Run all queued events.
1326
- this.clock.runAll();
1327
-
1328
- this.eventsFireSpy.resetHistory();
1329
- const changeListenerSpy = createChangeListenerSpy(workspaceSvg);
1330
- block.dispose();
1331
-
1332
- // Run all queued events.
1333
- this.clock.runAll();
1334
-
1335
- // Expect two calls to genUid: one to set the block's ID, and one for
1336
- // the event group's ID for creating block.
1337
- sinon.assert.calledTwice(genUidStub);
1338
-
1339
- assertNthCallEventArgEquals(
1340
- this.eventsFireSpy,
1341
- 0,
1342
- Blockly.Events.BlockDelete,
1343
- {oldXml: expectedOldXml, group: ''},
1344
- workspaceSvg.id,
1345
- expectedId,
1346
- );
1347
-
1348
- // Expect the workspace to not have a variable with ID 'test_block_id'.
1349
- assert.isNull(this.workspace.getVariableById(TEST_BLOCK_ID));
1350
- } finally {
1351
- workspaceTeardown.call(this, workspaceSvg);
1352
- }
1353
- });
1354
-
1355
- test('New block new var', function () {
1356
- const TEST_BLOCK_ID = 'test_block_id';
1357
- const TEST_GROUP_ID = 'test_group_id';
1358
- const TEST_VAR_ID = 'test_var_id';
1359
- const genUidStub = createGenUidStubWithReturns([
1360
- TEST_BLOCK_ID,
1361
- TEST_GROUP_ID,
1362
- TEST_VAR_ID,
1363
- ]);
1364
- const _ = this.workspace.newBlock('field_variable_test_block');
1365
- const TEST_VAR_NAME = 'item'; // As defined in block's json.
1366
-
1367
- // Run all queued events.
1368
- this.clock.runAll();
1369
-
1370
- // Expect three calls to genUid: one to set the block's ID, one for the event
1371
- // group's ID, and one for the variable's ID.
1372
- sinon.assert.calledThrice(genUidStub);
1373
-
1374
- // Expect two events fired: varCreate and block create.
1375
- sinon.assert.calledTwice(this.eventsFireSpy);
1376
- // Expect both events to trigger change listener.
1377
- sinon.assert.calledTwice(this.changeListenerSpy);
1378
- // Both events should be on undo stack
1379
- assert.equal(this.workspace.undoStack_.length, 2, 'Undo stack length');
1380
-
1381
- assertNthCallEventArgEquals(
1382
- this.changeListenerSpy,
1383
- 0,
1384
- Blockly.Events.VarCreate,
1385
- {group: TEST_GROUP_ID, varId: TEST_VAR_ID, varName: TEST_VAR_NAME},
1386
- this.workspace.id,
1387
- undefined,
1388
- );
1389
- assertNthCallEventArgEquals(
1390
- this.changeListenerSpy,
1391
- 1,
1392
- Blockly.Events.BlockCreate,
1393
- {group: TEST_GROUP_ID},
1394
- this.workspace.id,
1395
- TEST_BLOCK_ID,
1396
- );
1397
-
1398
- // Expect the workspace to have a variable with ID 'test_var_id'.
1399
- assert.isNotNull(this.workspace.getVariableById(TEST_VAR_ID));
1400
- });
1401
-
1402
- test('New block new var xml', function () {
1403
- const TEST_GROUP_ID = 'test_group_id';
1404
- const genUidStub = createGenUidStubWithReturns(TEST_GROUP_ID);
1405
- const dom = Blockly.utils.xml.textToDom(
1406
- '<xml xmlns="https://developers.google.com/blockly/xml">' +
1407
- ' <block type="field_variable_test_block" id="test_block_id">' +
1408
- ' <field name="VAR" id="test_var_id">name1</field>' +
1409
- ' </block>' +
1410
- '</xml>',
1411
- );
1412
- Blockly.Xml.domToWorkspace(dom, this.workspace);
1413
- const TEST_BLOCK_ID = 'test_block_id';
1414
- const TEST_VAR_ID = 'test_var_id';
1415
- const TEST_VAR_NAME = 'name1';
1416
-
1417
- // Run all queued events.
1418
- this.clock.runAll();
1419
-
1420
- // Expect one call to genUid: for the event group's id
1421
- sinon.assert.calledOnce(genUidStub);
1422
-
1423
- // When block is created using domToWorkspace, 5 events are fired:
1424
- // 1. varCreate (events disabled)
1425
- // 2. varCreate
1426
- // 3. block create
1427
- // 4. move (no-op, is filtered out)
1428
- // 5. finished loading
1429
- sinon.assert.callCount(this.eventsFireSpy, 5);
1430
- // The first varCreate and move event should have been ignored.
1431
- sinon.assert.callCount(this.changeListenerSpy, 3);
1432
- // Expect two events on undo stack: varCreate and block create.
1433
- assert.equal(this.workspace.undoStack_.length, 2, 'Undo stack length');
1434
-
1435
- assertNthCallEventArgEquals(
1436
- this.changeListenerSpy,
1437
- 0,
1438
- Blockly.Events.VarCreate,
1439
- {group: TEST_GROUP_ID, varId: TEST_VAR_ID, varName: TEST_VAR_NAME},
1440
- this.workspace.id,
1441
- undefined,
1442
- );
1443
- assertNthCallEventArgEquals(
1444
- this.changeListenerSpy,
1445
- 1,
1446
- Blockly.Events.BlockCreate,
1447
- {group: TEST_GROUP_ID},
1448
- this.workspace.id,
1449
- TEST_BLOCK_ID,
1450
- );
1451
-
1452
- // Finished loading event should not be part of event group.
1453
- assertNthCallEventArgEquals(
1454
- this.changeListenerSpy,
1455
- 2,
1456
- Blockly.Events.FinishedLoading,
1457
- {group: ''},
1458
- this.workspace.id,
1459
- undefined,
1460
- );
1461
-
1462
- // Expect the workspace to have a variable with ID 'test_var_id'.
1463
- assert.isNotNull(this.workspace.getVariableById(TEST_VAR_ID));
1464
- });
1465
- });
1466
- suite('Disable orphans', function () {
1467
- setup(function () {
1468
- // disableOrphans needs a WorkspaceSVG
1469
- const toolbox = document.getElementById('toolbox-categories');
1470
- this.workspace = Blockly.inject('blocklyDiv', {toolbox: toolbox});
1471
- });
1472
- teardown(function () {
1473
- workspaceTeardown.call(this, this.workspace);
1474
- });
1475
- test('Created orphan block is disabled', function () {
1476
- this.workspace.addChangeListener(eventUtils.disableOrphans);
1477
- const block = this.workspace.newBlock('controls_for');
1478
- block.initSvg();
1479
- block.render();
1480
-
1481
- // Fire all events
1482
- this.clock.runAll();
1483
-
1484
- assert.isFalse(
1485
- block.isEnabled(),
1486
- 'Expected orphan block to be disabled after creation',
1487
- );
1488
- });
1489
- test('Created procedure block is enabled', function () {
1490
- this.workspace.addChangeListener(eventUtils.disableOrphans);
1491
-
1492
- // Procedure block is never an orphan
1493
- const functionBlock = this.workspace.newBlock('procedures_defnoreturn');
1494
- functionBlock.initSvg();
1495
- functionBlock.render();
1496
-
1497
- // Fire all events
1498
- this.clock.runAll();
1499
-
1500
- assert.isTrue(
1501
- functionBlock.isEnabled(),
1502
- 'Expected top-level procedure block to be enabled',
1503
- );
1504
- });
1505
- test('Moving a block to top-level disables it', function () {
1506
- this.workspace.addChangeListener(eventUtils.disableOrphans);
1507
- const functionBlock = this.workspace.newBlock('procedures_defnoreturn');
1508
- functionBlock.initSvg();
1509
- functionBlock.render();
1510
-
1511
- const block = this.workspace.newBlock('controls_for');
1512
- block.initSvg();
1513
- block.render();
1514
-
1515
- // Connect the block to the function block input stack
1516
- functionBlock.inputList[1].connection.connect(block.previousConnection);
1517
-
1518
- // Disconnect it again
1519
- block.unplug(false);
1520
-
1521
- // Fire all events
1522
- this.clock.runAll();
1523
-
1524
- assert.isFalse(
1525
- block.isEnabled(),
1526
- 'Expected disconnected block to be disabled',
1527
- );
1528
- });
1529
- test('Giving block a parent enables it', function () {
1530
- this.workspace.addChangeListener(eventUtils.disableOrphans);
1531
- const functionBlock = this.workspace.newBlock('procedures_defnoreturn');
1532
- functionBlock.initSvg();
1533
- functionBlock.render();
1534
-
1535
- const block = this.workspace.newBlock('controls_for');
1536
- block.initSvg();
1537
- block.render();
1538
-
1539
- // Connect the block to the function block input stack
1540
- functionBlock.inputList[1].connection.connect(block.previousConnection);
1541
-
1542
- // Fire all events
1543
- this.clock.runAll();
1544
-
1545
- assert.isTrue(
1546
- block.isEnabled(),
1547
- 'Expected block to be enabled after connecting to parent',
1548
- );
1549
- });
1550
- test('disableOrphans events are not undoable', function () {
1551
- this.workspace.addChangeListener(eventUtils.disableOrphans);
1552
- const functionBlock = this.workspace.newBlock('procedures_defnoreturn');
1553
- functionBlock.initSvg();
1554
- functionBlock.render();
1555
-
1556
- const block = this.workspace.newBlock('controls_for');
1557
- block.initSvg();
1558
- block.render();
1559
-
1560
- // Connect the block to the function block input stack
1561
- functionBlock.inputList[1].connection.connect(block.previousConnection);
1562
-
1563
- // Disconnect it again
1564
- block.unplug(false);
1565
-
1566
- // Fire all events
1567
- this.clock.runAll();
1568
-
1569
- const disabledEvents = this.workspace.getUndoStack().filter(function (e) {
1570
- return e.element === 'disabled';
1571
- });
1572
- assert.isEmpty(
1573
- disabledEvents,
1574
- 'Undo stack should not contain any disabled events',
1575
- );
1576
- });
1577
- });
1578
- });