blockly 12.4.0 → 12.5.0

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