blockly 8.0.5 → 9.0.0-beta.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 (736) hide show
  1. package/blockly.min.js +2002 -2269
  2. package/blockly_compressed.js +1499 -1994
  3. package/blockly_compressed.js.map +1 -1
  4. package/blocks/blocks.js +3 -2
  5. package/blocks/colour.js +3 -1
  6. package/blocks/lists.js +94 -22
  7. package/blocks/logic.js +14 -6
  8. package/blocks/loops.js +5 -3
  9. package/blocks/math.js +3 -1
  10. package/blocks/procedures.js +3 -1
  11. package/blocks/text.js +14 -6
  12. package/blocks/variables.js +3 -1
  13. package/blocks/variables_dynamic.js +3 -1
  14. package/blocks.d.ts +0 -2
  15. package/blocks_compressed.js +189 -171
  16. package/blocks_compressed.js.map +1 -1
  17. package/closure/goog/base.d.ts +1 -0
  18. package/closure/goog/base_minimal.d.ts +18 -0
  19. package/closure/goog/goog.d.ts +25 -0
  20. package/core/any_aliases.d.ts +1 -0
  21. package/core/any_aliases.ts +1 -0
  22. package/core/block.d.ts +779 -0
  23. package/core/{block.js → block.ts} +610 -719
  24. package/core/block_animations.d.ts +33 -0
  25. package/core/{block_animations.js → block_animations.ts} +75 -79
  26. package/core/block_drag_surface.d.ts +111 -0
  27. package/core/{block_drag_surface.js → block_drag_surface.ts} +85 -117
  28. package/core/block_dragger.d.ts +143 -0
  29. package/core/{block_dragger.js → block_dragger.ts} +139 -176
  30. package/core/block_svg.d.ts +588 -0
  31. package/core/{block_svg.js → block_svg.ts} +494 -630
  32. package/core/blockly.d.ts +562 -0
  33. package/core/blockly.js +1 -1
  34. package/core/blockly.ts +749 -0
  35. package/core/blockly_options.d.ts +69 -0
  36. package/core/blockly_options.ts +81 -0
  37. package/core/blocks.d.ts +17 -0
  38. package/core/{blocks.js → blocks.ts} +4 -8
  39. package/core/browser_events.d.ts +85 -0
  40. package/core/{browser_events.js → browser_events.ts} +98 -93
  41. package/core/bubble.d.ts +279 -0
  42. package/core/{bubble.js → bubble.ts} +277 -370
  43. package/core/bubble_dragger.d.ts +73 -0
  44. package/core/bubble_dragger.ts +229 -0
  45. package/core/bump_objects.d.ts +34 -0
  46. package/core/{bump_objects.js → bump_objects.ts} +54 -52
  47. package/core/clipboard.d.ts +42 -0
  48. package/core/clipboard.ts +91 -0
  49. package/core/comment.d.ts +113 -0
  50. package/core/{comment.js → comment.ts} +135 -185
  51. package/core/common.d.ts +129 -0
  52. package/core/{common.js → common.ts} +105 -82
  53. package/core/component_manager.d.ts +91 -0
  54. package/core/component_manager.ts +211 -0
  55. package/core/config.d.ts +23 -0
  56. package/core/{config.js → config.ts} +12 -19
  57. package/core/connection.d.ts +232 -0
  58. package/core/{connection.js → connection.ts} +187 -237
  59. package/core/connection_checker.d.ts +78 -0
  60. package/core/{connection_checker.js → connection_checker.ts} +66 -77
  61. package/core/connection_db.d.ts +91 -0
  62. package/core/{connection_db.js → connection_db.ts} +62 -87
  63. package/core/connection_type.d.ts +15 -0
  64. package/core/{connection_type.js → connection_type.ts} +8 -12
  65. package/core/constants.d.ts +15 -0
  66. package/core/{constants.js → constants.ts} +4 -8
  67. package/core/contextmenu.d.ts +80 -0
  68. package/core/{contextmenu.js → contextmenu.ts} +118 -153
  69. package/core/contextmenu_items.d.ts +77 -0
  70. package/core/contextmenu_items.ts +576 -0
  71. package/core/contextmenu_registry.d.ts +105 -0
  72. package/core/contextmenu_registry.ts +179 -0
  73. package/core/css.d.ts +24 -0
  74. package/core/{css.js → css.ts} +16 -24
  75. package/core/delete_area.d.ts +47 -0
  76. package/core/delete_area.ts +82 -0
  77. package/core/dialog.d.ts +61 -0
  78. package/core/dialog.ts +127 -0
  79. package/core/drag_target.d.ts +63 -0
  80. package/core/drag_target.ts +94 -0
  81. package/core/dropdowndiv.d.ts +155 -0
  82. package/core/{dropdowndiv.js → dropdowndiv.ts} +262 -333
  83. package/core/events/events.d.ts +102 -0
  84. package/core/events/events.ts +123 -0
  85. package/core/events/events_abstract.d.ts +51 -0
  86. package/core/events/events_abstract.ts +112 -0
  87. package/core/events/events_block_base.d.ts +31 -0
  88. package/core/events/events_block_base.ts +65 -0
  89. package/core/events/events_block_change.d.ts +55 -0
  90. package/core/events/{events_block_change.js → events_block_change.ts} +45 -48
  91. package/core/events/events_block_create.d.ts +35 -0
  92. package/core/events/{events_block_create.js → events_block_create.ts} +30 -35
  93. package/core/events/events_block_delete.d.ts +36 -0
  94. package/core/events/{events_block_delete.js → events_block_delete.ts} +34 -39
  95. package/core/events/events_block_drag.d.ts +36 -0
  96. package/core/events/events_block_drag.ts +82 -0
  97. package/core/events/events_block_move.d.ts +51 -0
  98. package/core/events/{events_block_move.js → events_block_move.ts} +54 -50
  99. package/core/events/events_bubble_open.d.ts +35 -0
  100. package/core/events/events_bubble_open.ts +82 -0
  101. package/core/events/events_click.d.ts +36 -0
  102. package/core/events/{events_click.js → events_click.ts} +27 -30
  103. package/core/events/events_comment_base.d.ts +39 -0
  104. package/core/events/events_comment_base.ts +107 -0
  105. package/core/events/events_comment_change.d.ts +43 -0
  106. package/core/events/{events_comment_change.js → events_comment_change.ts} +31 -28
  107. package/core/events/events_comment_create.d.ts +35 -0
  108. package/core/events/{events_comment_create.js → events_comment_create.ts} +24 -26
  109. package/core/events/events_comment_delete.d.ts +35 -0
  110. package/core/events/{events_comment_delete.js → events_comment_delete.ts} +20 -24
  111. package/core/events/events_comment_move.d.ts +55 -0
  112. package/core/events/{events_comment_move.js → events_comment_move.ts} +39 -42
  113. package/core/events/events_marker_move.d.ts +40 -0
  114. package/core/events/events_marker_move.ts +99 -0
  115. package/core/events/events_selected.d.ts +34 -0
  116. package/core/events/events_selected.ts +78 -0
  117. package/core/events/events_theme_change.d.ts +30 -0
  118. package/core/events/{events_theme_change.js → events_theme_change.ts} +19 -24
  119. package/core/events/events_toolbox_item_select.d.ts +34 -0
  120. package/core/events/events_toolbox_item_select.ts +79 -0
  121. package/core/events/events_trashcan_open.d.ts +31 -0
  122. package/core/events/events_trashcan_open.ts +68 -0
  123. package/core/events/events_ui.d.ts +37 -0
  124. package/core/events/{events_ui.js → events_ui.ts} +27 -26
  125. package/core/events/events_ui_base.d.ts +26 -0
  126. package/core/events/{events_ui_base.js → events_ui_base.ts} +17 -26
  127. package/core/events/events_var_base.d.ts +31 -0
  128. package/core/events/events_var_base.ts +65 -0
  129. package/core/events/events_var_create.d.ts +35 -0
  130. package/core/events/{events_var_create.js → events_var_create.ts} +24 -25
  131. package/core/events/events_var_delete.d.ts +35 -0
  132. package/core/events/{events_var_delete.js → events_var_delete.ts} +24 -25
  133. package/core/events/events_var_rename.d.ts +36 -0
  134. package/core/events/{events_var_rename.js → events_var_rename.ts} +25 -26
  135. package/core/events/events_viewport.d.ts +39 -0
  136. package/core/events/events_viewport.ts +100 -0
  137. package/core/events/utils.d.ts +272 -0
  138. package/core/events/{utils.js → utils.ts} +148 -219
  139. package/core/events/workspace_events.d.ts +36 -0
  140. package/core/events/workspace_events.ts +86 -0
  141. package/core/extensions.d.ts +107 -0
  142. package/core/{extensions.js → extensions.ts} +153 -172
  143. package/core/field.d.ts +534 -0
  144. package/core/{field.js → field.ts} +413 -489
  145. package/core/field_angle.d.ts +176 -0
  146. package/core/field_angle.ts +563 -0
  147. package/core/field_checkbox.d.ts +124 -0
  148. package/core/field_checkbox.ts +243 -0
  149. package/core/field_colour.d.ts +200 -0
  150. package/core/field_colour.ts +632 -0
  151. package/core/field_dropdown.d.ts +222 -0
  152. package/core/{field_dropdown.js → field_dropdown.ts} +277 -299
  153. package/core/field_image.d.ts +134 -0
  154. package/core/field_image.ts +282 -0
  155. package/core/field_label.d.ts +71 -0
  156. package/core/field_label.ts +152 -0
  157. package/core/field_label_serializable.d.ts +42 -0
  158. package/core/field_label_serializable.ts +76 -0
  159. package/core/field_multilineinput.d.ts +146 -0
  160. package/core/{field_multilineinput.js → field_multilineinput.ts} +166 -163
  161. package/core/field_number.d.ts +156 -0
  162. package/core/{field_number.js → field_number.ts} +110 -123
  163. package/core/field_registry.d.ts +45 -0
  164. package/core/{field_registry.js → field_registry.ts} +37 -30
  165. package/core/field_textinput.d.ts +219 -0
  166. package/core/field_textinput.ts +591 -0
  167. package/core/field_variable.d.ts +217 -0
  168. package/core/{field_variable.js → field_variable.ts} +174 -187
  169. package/core/flyout_base.d.ts +459 -0
  170. package/core/{flyout_base.js → flyout_base.ts} +429 -518
  171. package/core/flyout_button.d.ts +81 -0
  172. package/core/flyout_button.ts +292 -0
  173. package/core/flyout_horizontal.d.ts +82 -0
  174. package/core/{flyout_horizontal.js → flyout_horizontal.ts} +97 -107
  175. package/core/flyout_metrics_manager.d.ts +40 -0
  176. package/core/{flyout_metrics_manager.js → flyout_metrics_manager.ts} +22 -34
  177. package/core/flyout_vertical.d.ts +83 -0
  178. package/core/{flyout_vertical.js → flyout_vertical.ts} +106 -117
  179. package/core/generator.d.ts +205 -0
  180. package/core/{generator.js → generator.ts} +168 -193
  181. package/core/gesture.d.ts +357 -0
  182. package/core/{gesture.js → gesture.ts} +289 -369
  183. package/core/grid.d.ts +83 -0
  184. package/core/grid.ts +192 -0
  185. package/core/icon.d.ts +78 -0
  186. package/core/icon.ts +189 -0
  187. package/core/inject.d.ts +15 -0
  188. package/core/{inject.js → inject.ts} +101 -100
  189. package/core/input.d.ts +128 -0
  190. package/core/input.ts +309 -0
  191. package/core/input_types.d.ts +14 -0
  192. package/core/{input_types.js → input_types.ts} +8 -12
  193. package/core/insertion_marker_manager.d.ts +212 -0
  194. package/core/{insertion_marker_manager.js → insertion_marker_manager.ts} +234 -236
  195. package/core/interfaces/i_ast_node_location.d.ts +11 -0
  196. package/core/interfaces/{i_ast_node_location.js → i_ast_node_location.ts} +4 -7
  197. package/core/interfaces/i_ast_node_location_svg.d.ts +22 -0
  198. package/core/interfaces/i_ast_node_location_svg.ts +37 -0
  199. package/core/interfaces/i_ast_node_location_with_block.d.ts +18 -0
  200. package/core/interfaces/i_ast_node_location_with_block.ts +38 -0
  201. package/core/interfaces/i_autohideable.d.ts +18 -0
  202. package/core/interfaces/i_autohideable.ts +34 -0
  203. package/core/interfaces/i_block_dragger.d.ts +43 -0
  204. package/core/interfaces/i_block_dragger.ts +67 -0
  205. package/core/interfaces/i_bounded_element.d.ts +24 -0
  206. package/core/interfaces/i_bounded_element.ts +42 -0
  207. package/core/interfaces/i_bubble.d.ts +59 -0
  208. package/core/interfaces/i_bubble.ts +88 -0
  209. package/core/interfaces/i_collapsible_toolbox_item.d.ts +26 -0
  210. package/core/interfaces/i_collapsible_toolbox_item.ts +47 -0
  211. package/core/interfaces/i_component.d.ts +17 -0
  212. package/core/interfaces/{i_component.js → i_component.ts} +9 -14
  213. package/core/interfaces/i_connection_checker.d.ts +69 -0
  214. package/core/interfaces/i_connection_checker.ts +102 -0
  215. package/core/interfaces/i_contextmenu.d.ts +13 -0
  216. package/core/interfaces/i_contextmenu.ts +26 -0
  217. package/core/interfaces/i_copyable.d.ts +24 -0
  218. package/core/interfaces/i_copyable.ts +40 -0
  219. package/core/interfaces/i_deletable.d.ts +16 -0
  220. package/core/interfaces/{i_deletable.js → i_deletable.ts} +9 -13
  221. package/core/interfaces/i_delete_area.d.ts +25 -0
  222. package/core/interfaces/i_delete_area.ts +46 -0
  223. package/core/interfaces/i_drag_target.d.ts +53 -0
  224. package/core/interfaces/i_drag_target.ts +84 -0
  225. package/core/interfaces/i_draggable.d.ts +12 -0
  226. package/core/interfaces/{i_draggable.js → i_draggable.ts} +4 -10
  227. package/core/interfaces/i_flyout.d.ts +134 -0
  228. package/core/interfaces/i_flyout.ts +186 -0
  229. package/core/interfaces/i_keyboard_accessible.d.ts +18 -0
  230. package/core/interfaces/i_keyboard_accessible.ts +35 -0
  231. package/core/interfaces/i_metrics_manager.d.ts +117 -0
  232. package/core/interfaces/i_metrics_manager.ts +151 -0
  233. package/core/interfaces/i_movable.d.ts +16 -0
  234. package/core/interfaces/{i_movable.js → i_movable.ts} +9 -13
  235. package/core/interfaces/i_positionable.d.ts +27 -0
  236. package/core/interfaces/i_positionable.ts +50 -0
  237. package/core/interfaces/i_registrable.d.ts +11 -0
  238. package/core/interfaces/{i_registrable.js → i_registrable.ts} +3 -7
  239. package/core/interfaces/i_registrable_field.d.ts +17 -0
  240. package/core/interfaces/{i_registrable_field.js → i_registrable_field.ts} +8 -16
  241. package/core/interfaces/i_selectable.d.ts +18 -0
  242. package/core/interfaces/i_selectable.ts +34 -0
  243. package/core/interfaces/i_selectable_toolbox_item.d.ts +42 -0
  244. package/core/interfaces/i_selectable_toolbox_item.ts +64 -0
  245. package/core/interfaces/i_serializer.d.ts +42 -0
  246. package/core/interfaces/i_serializer.ts +65 -0
  247. package/core/interfaces/i_styleable.d.ts +21 -0
  248. package/core/interfaces/i_styleable.ts +35 -0
  249. package/core/interfaces/i_toolbox.d.ts +85 -0
  250. package/core/interfaces/i_toolbox.ts +127 -0
  251. package/core/interfaces/i_toolbox_item.d.ts +62 -0
  252. package/core/interfaces/i_toolbox_item.ts +84 -0
  253. package/core/internal_constants.d.ts +40 -0
  254. package/core/{internal_constants.js → internal_constants.ts} +13 -18
  255. package/core/keyboard_nav/ast_node.d.ts +239 -0
  256. package/core/keyboard_nav/{ast_node.js → ast_node.ts} +207 -231
  257. package/core/keyboard_nav/basic_cursor.d.ts +88 -0
  258. package/core/keyboard_nav/{basic_cursor.js → basic_cursor.ts} +55 -66
  259. package/core/keyboard_nav/cursor.d.ts +41 -0
  260. package/core/keyboard_nav/{cursor.js → cursor.ts} +25 -35
  261. package/core/keyboard_nav/marker.d.ts +58 -0
  262. package/core/keyboard_nav/{marker.js → marker.ts} +36 -55
  263. package/core/keyboard_nav/tab_navigate_cursor.d.ts +19 -0
  264. package/core/keyboard_nav/{tab_navigate_cursor.js → tab_navigate_cursor.ts} +11 -15
  265. package/core/main.d.ts +11 -0
  266. package/core/main.js +303 -0
  267. package/core/marker_manager.d.ts +85 -0
  268. package/core/marker_manager.ts +181 -0
  269. package/core/menu.d.ts +149 -0
  270. package/core/{menu.js → menu.ts} +141 -174
  271. package/core/menuitem.d.ts +118 -0
  272. package/core/menuitem.ts +240 -0
  273. package/core/metrics_manager.d.ts +201 -0
  274. package/core/{metrics_manager.js → metrics_manager.ts} +117 -156
  275. package/core/msg.d.ts +9 -0
  276. package/core/{msg.js → msg.ts} +4 -8
  277. package/core/mutator.d.ts +128 -0
  278. package/core/{mutator.js → mutator.ts} +196 -211
  279. package/core/names.d.ts +124 -0
  280. package/core/names.ts +267 -0
  281. package/core/options.d.ts +137 -0
  282. package/core/{options.js → options.ts} +147 -173
  283. package/core/positionable_helpers.d.ts +88 -0
  284. package/core/{positionable_helpers.js → positionable_helpers.ts} +63 -70
  285. package/core/procedures.d.ts +108 -0
  286. package/core/{procedures.js → procedures.ts} +143 -152
  287. package/core/registry.d.ts +137 -0
  288. package/core/registry.ts +339 -0
  289. package/core/rendered_connection.d.ts +191 -0
  290. package/core/{rendered_connection.js → rendered_connection.ts} +164 -184
  291. package/core/renderers/common/block_rendering.d.ts +114 -0
  292. package/core/renderers/common/block_rendering.ts +164 -0
  293. package/core/renderers/common/constants.d.ts +458 -0
  294. package/core/renderers/common/constants.ts +1124 -0
  295. package/core/renderers/common/debug.d.ts +28 -0
  296. package/core/renderers/common/{debug.js → debug.ts} +14 -20
  297. package/core/renderers/common/debugger.d.ts +120 -0
  298. package/core/renderers/common/{debugger.js → debugger.ts} +100 -124
  299. package/core/renderers/common/drawer.d.ts +132 -0
  300. package/core/renderers/common/{drawer.js → drawer.ts} +112 -137
  301. package/core/renderers/common/i_path_object.d.ts +117 -0
  302. package/core/renderers/common/i_path_object.ts +161 -0
  303. package/core/renderers/common/info.d.ts +194 -0
  304. package/core/renderers/common/{info.js → info.ts} +165 -222
  305. package/core/renderers/common/marker_svg.d.ts +220 -0
  306. package/core/renderers/common/marker_svg.ts +680 -0
  307. package/core/renderers/common/path_object.d.ts +146 -0
  308. package/core/renderers/common/path_object.ts +272 -0
  309. package/core/renderers/common/renderer.d.ts +157 -0
  310. package/core/renderers/common/renderer.ts +271 -0
  311. package/core/renderers/geras/constants.d.ts +23 -0
  312. package/core/renderers/geras/constants.ts +61 -0
  313. package/core/renderers/geras/drawer.d.ts +43 -0
  314. package/core/renderers/geras/{drawer.js → drawer.ts} +40 -84
  315. package/core/renderers/geras/geras.d.ts +11 -0
  316. package/core/renderers/geras/geras.ts +37 -0
  317. package/core/renderers/geras/highlight_constants.d.ts +108 -0
  318. package/core/renderers/geras/{highlight_constants.js → highlight_constants.ts} +107 -69
  319. package/core/renderers/geras/highlighter.d.ts +98 -0
  320. package/core/renderers/geras/{highlighter.js → highlighter.ts} +81 -86
  321. package/core/renderers/geras/info.d.ts +45 -0
  322. package/core/renderers/geras/{info.js → info.ts} +61 -99
  323. package/core/renderers/geras/measurables/inline_input.d.ts +23 -0
  324. package/core/renderers/geras/measurables/inline_input.ts +51 -0
  325. package/core/renderers/geras/measurables/statement_input.d.ts +23 -0
  326. package/core/renderers/geras/measurables/statement_input.ts +50 -0
  327. package/core/renderers/geras/path_object.d.ts +47 -0
  328. package/core/renderers/geras/{path_object.js → path_object.ts} +46 -74
  329. package/core/renderers/geras/renderer.d.ts +69 -0
  330. package/core/renderers/geras/renderer.ts +126 -0
  331. package/core/renderers/measurables/base.d.ts +27 -0
  332. package/core/renderers/measurables/base.ts +53 -0
  333. package/core/renderers/measurables/bottom_row.d.ts +61 -0
  334. package/core/renderers/measurables/bottom_row.ts +120 -0
  335. package/core/renderers/measurables/connection.d.ts +25 -0
  336. package/core/renderers/measurables/connection.ts +52 -0
  337. package/core/renderers/measurables/external_value_input.d.ts +27 -0
  338. package/core/renderers/measurables/external_value_input.ts +65 -0
  339. package/core/renderers/measurables/field.d.ts +30 -0
  340. package/core/renderers/measurables/field.ts +63 -0
  341. package/core/renderers/measurables/hat.d.ts +21 -0
  342. package/core/renderers/measurables/{hat.js → hat.ts} +12 -14
  343. package/core/renderers/measurables/icon.d.ts +26 -0
  344. package/core/renderers/measurables/{icon.js → icon.ts} +14 -18
  345. package/core/renderers/measurables/in_row_spacer.d.ts +21 -0
  346. package/core/renderers/measurables/in_row_spacer.ts +44 -0
  347. package/core/renderers/measurables/inline_input.d.ts +24 -0
  348. package/core/renderers/measurables/{inline_input.js → inline_input.ts} +22 -26
  349. package/core/renderers/measurables/input_connection.d.ts +29 -0
  350. package/core/renderers/measurables/input_connection.ts +66 -0
  351. package/core/renderers/measurables/input_row.d.ts +30 -0
  352. package/core/renderers/measurables/{input_row.js → input_row.ts} +24 -31
  353. package/core/renderers/measurables/jagged_edge.d.ts +20 -0
  354. package/core/renderers/measurables/{jagged_edge.js → jagged_edge.ts} +10 -13
  355. package/core/renderers/measurables/next_connection.d.ts +23 -0
  356. package/core/renderers/measurables/next_connection.ts +47 -0
  357. package/core/renderers/measurables/output_connection.d.ts +26 -0
  358. package/core/renderers/measurables/output_connection.ts +56 -0
  359. package/core/renderers/measurables/previous_connection.d.ts +23 -0
  360. package/core/renderers/measurables/previous_connection.ts +47 -0
  361. package/core/renderers/measurables/round_corner.d.ts +21 -0
  362. package/core/renderers/measurables/round_corner.ts +49 -0
  363. package/core/renderers/measurables/row.d.ts +141 -0
  364. package/core/renderers/measurables/row.ts +225 -0
  365. package/core/renderers/measurables/spacer_row.d.ts +29 -0
  366. package/core/renderers/measurables/spacer_row.ts +55 -0
  367. package/core/renderers/measurables/square_corner.d.ts +21 -0
  368. package/core/renderers/measurables/square_corner.ts +47 -0
  369. package/core/renderers/measurables/statement_input.d.ts +22 -0
  370. package/core/renderers/measurables/{statement_input.js → statement_input.ts} +14 -18
  371. package/core/renderers/measurables/top_row.d.ts +56 -0
  372. package/core/renderers/measurables/top_row.ts +122 -0
  373. package/core/renderers/measurables/types.d.ts +235 -0
  374. package/core/renderers/measurables/types.ts +332 -0
  375. package/core/renderers/minimalist/constants.d.ts +14 -0
  376. package/core/renderers/minimalist/{constants.js → constants.ts} +5 -10
  377. package/core/renderers/minimalist/drawer.d.ts +21 -0
  378. package/core/renderers/minimalist/drawer.ts +38 -0
  379. package/core/renderers/minimalist/info.d.ts +30 -0
  380. package/core/renderers/minimalist/info.ts +52 -0
  381. package/core/renderers/minimalist/minimalist.d.ts +6 -0
  382. package/core/renderers/minimalist/minimalist.ts +22 -0
  383. package/core/renderers/minimalist/renderer.d.ts +41 -0
  384. package/core/renderers/minimalist/renderer.ts +71 -0
  385. package/core/renderers/thrasos/info.d.ts +40 -0
  386. package/core/renderers/thrasos/{info.js → info.ts} +66 -67
  387. package/core/renderers/thrasos/renderer.d.ts +25 -0
  388. package/core/renderers/thrasos/renderer.ts +48 -0
  389. package/core/renderers/thrasos/thrasos.d.ts +4 -0
  390. package/core/renderers/thrasos/thrasos.ts +20 -0
  391. package/core/renderers/zelos/constants.d.ts +186 -0
  392. package/core/renderers/zelos/{constants.js → constants.ts} +294 -441
  393. package/core/renderers/zelos/drawer.d.ts +47 -0
  394. package/core/renderers/zelos/{drawer.js → drawer.ts} +73 -95
  395. package/core/renderers/zelos/info.d.ts +88 -0
  396. package/core/renderers/zelos/{info.js → info.ts} +111 -142
  397. package/core/renderers/zelos/marker_svg.d.ts +46 -0
  398. package/core/renderers/zelos/marker_svg.ts +151 -0
  399. package/core/renderers/zelos/measurables/bottom_row.d.ts +27 -0
  400. package/core/renderers/zelos/measurables/bottom_row.ts +53 -0
  401. package/core/renderers/zelos/measurables/inputs.d.ts +23 -0
  402. package/core/renderers/zelos/measurables/{inputs.js → inputs.ts} +14 -15
  403. package/core/renderers/zelos/measurables/row_elements.d.ts +21 -0
  404. package/core/renderers/zelos/measurables/row_elements.ts +45 -0
  405. package/core/renderers/zelos/measurables/top_row.d.ts +29 -0
  406. package/core/renderers/zelos/measurables/{top_row.js → top_row.ts} +14 -27
  407. package/core/renderers/zelos/path_object.d.ts +77 -0
  408. package/core/renderers/zelos/path_object.ts +215 -0
  409. package/core/renderers/zelos/renderer.d.ts +74 -0
  410. package/core/renderers/zelos/renderer.ts +142 -0
  411. package/core/renderers/zelos/zelos.d.ts +12 -0
  412. package/core/renderers/zelos/zelos.ts +39 -0
  413. package/core/scrollbar.d.ts +277 -0
  414. package/core/{scrollbar.js → scrollbar.ts} +307 -328
  415. package/core/scrollbar_pair.d.ts +105 -0
  416. package/core/{scrollbar_pair.js → scrollbar_pair.ts} +71 -79
  417. package/core/serialization/blocks.d.ts +98 -0
  418. package/core/serialization/{blocks.js → blocks.ts} +229 -228
  419. package/core/serialization/exceptions.d.ts +73 -0
  420. package/core/serialization/exceptions.ts +98 -0
  421. package/core/serialization/priorities.d.ts +15 -0
  422. package/core/serialization/{priorities.js → priorities.ts} +4 -10
  423. package/core/serialization/registry.d.ts +20 -0
  424. package/core/serialization/{registry.js → registry.ts} +11 -13
  425. package/core/serialization/variables.d.ts +14 -0
  426. package/core/serialization/{variables.js → variables.ts} +30 -32
  427. package/core/serialization/workspaces.d.ts +28 -0
  428. package/core/serialization/{workspaces.js → workspaces.ts} +30 -27
  429. package/core/shortcut_items.d.ts +61 -0
  430. package/core/{shortcut_items.js → shortcut_items.ts} +121 -157
  431. package/core/shortcut_registry.d.ts +151 -0
  432. package/core/shortcut_registry.ts +355 -0
  433. package/core/sprites.d.ts +19 -0
  434. package/core/{sprites.js → sprites.ts} +4 -6
  435. package/core/theme/classic.d.ts +12 -0
  436. package/core/theme/{classic.js → classic.ts} +5 -7
  437. package/core/theme/themes.d.ts +8 -0
  438. package/core/theme/themes.ts +22 -0
  439. package/core/theme/zelos.d.ts +11 -0
  440. package/core/theme/{zelos.js → zelos.ts} +4 -7
  441. package/core/theme.d.ts +142 -0
  442. package/core/theme.ts +221 -0
  443. package/core/theme_manager.d.ts +81 -0
  444. package/core/theme_manager.ts +186 -0
  445. package/core/toolbox/category.d.ts +239 -0
  446. package/core/toolbox/category.ts +679 -0
  447. package/core/toolbox/collapsible_category.d.ts +91 -0
  448. package/core/toolbox/collapsible_category.ts +273 -0
  449. package/core/toolbox/separator.d.ts +39 -0
  450. package/core/toolbox/separator.ts +105 -0
  451. package/core/toolbox/toolbox.d.ts +352 -0
  452. package/core/toolbox/{toolbox.js → toolbox.ts} +316 -432
  453. package/core/toolbox/toolbox_item.d.ts +85 -0
  454. package/core/toolbox/toolbox_item.ts +147 -0
  455. package/core/tooltip.d.ts +126 -0
  456. package/core/{tooltip.js → tooltip.ts} +136 -214
  457. package/core/touch.d.ts +121 -0
  458. package/core/touch.ts +306 -0
  459. package/core/touch_gesture.d.ts +115 -0
  460. package/core/{touch_gesture.js → touch_gesture.ts} +87 -125
  461. package/core/trashcan.d.ts +195 -0
  462. package/core/{trashcan.js → trashcan.ts} +226 -312
  463. package/core/utils/aria.d.ts +67 -0
  464. package/core/utils/{aria.js → aria.ts} +47 -61
  465. package/core/utils/array.d.ts +14 -0
  466. package/core/utils/{array.js → array.ts} +10 -12
  467. package/core/utils/colour.d.ts +103 -0
  468. package/core/utils/{colour.js → colour.ts} +60 -72
  469. package/core/utils/coordinate.d.ts +72 -0
  470. package/core/utils/coordinate.ts +124 -0
  471. package/core/utils/deprecation.d.ts +17 -0
  472. package/core/utils/{deprecation.js → deprecation.ts} +11 -11
  473. package/core/utils/dom.d.ts +165 -0
  474. package/core/utils/{dom.js → dom.ts} +125 -147
  475. package/core/utils/idgenerator.d.ts +25 -0
  476. package/core/utils/{idgenerator.js → idgenerator.ts} +15 -18
  477. package/core/utils/keycodes.d.ts +137 -0
  478. package/core/utils/keycodes.ts +169 -0
  479. package/core/utils/math.d.ts +30 -0
  480. package/core/utils/{math.js → math.ts} +17 -19
  481. package/core/utils/metrics.d.ts +64 -0
  482. package/core/utils/metrics.ts +97 -0
  483. package/core/utils/object.d.ts +35 -0
  484. package/core/utils/{object.js → object.ts} +30 -26
  485. package/core/utils/parsing.d.ts +50 -0
  486. package/core/utils/{parsing.js → parsing.ts} +50 -50
  487. package/core/utils/rect.d.ts +38 -0
  488. package/core/utils/{rect.js → rect.ts} +18 -31
  489. package/core/utils/sentinel.d.ts +11 -0
  490. package/core/utils/{sentinel.js → sentinel.ts} +3 -5
  491. package/core/utils/size.d.ts +27 -0
  492. package/core/utils/{size.js → size.ts} +12 -26
  493. package/core/utils/string.d.ts +55 -0
  494. package/core/utils/{string.js → string.ts} +64 -61
  495. package/core/utils/style.d.ts +127 -0
  496. package/core/utils/{style.js → style.ts} +102 -92
  497. package/core/utils/svg.d.ts +68 -0
  498. package/core/utils/svg.ts +88 -0
  499. package/core/utils/svg_math.d.ts +70 -0
  500. package/core/utils/{svg_math.js → svg_math.ts} +72 -71
  501. package/core/utils/svg_paths.d.ts +101 -0
  502. package/core/utils/{svg_paths.js → svg_paths.ts} +56 -65
  503. package/core/utils/toolbox.d.ts +193 -0
  504. package/core/utils/toolbox.ts +433 -0
  505. package/core/utils/useragent.d.ts +33 -0
  506. package/core/utils/useragent.ts +135 -0
  507. package/core/utils/xml.d.ts +52 -0
  508. package/core/utils/{xml.js → xml.ts} +26 -36
  509. package/core/utils.d.ts +217 -0
  510. package/core/utils.ts +428 -0
  511. package/core/variable_map.d.ts +141 -0
  512. package/core/{variable_map.js → variable_map.ts} +131 -149
  513. package/core/variable_model.d.ts +40 -0
  514. package/core/variable_model.ts +82 -0
  515. package/core/variables.d.ts +181 -0
  516. package/core/{variables.js → variables.ts} +206 -188
  517. package/core/variables_dynamic.d.ts +38 -0
  518. package/core/{variables_dynamic.js → variables_dynamic.ts} +47 -43
  519. package/core/warning.d.ts +50 -0
  520. package/core/{warning.js → warning.ts} +52 -66
  521. package/core/widgetdiv.d.ts +69 -0
  522. package/core/widgetdiv.ts +257 -0
  523. package/core/workspace.d.ts +386 -0
  524. package/core/workspace.ts +801 -0
  525. package/core/workspace_audio.d.ts +47 -0
  526. package/core/{workspace_audio.js → workspace_audio.ts} +47 -60
  527. package/core/workspace_comment.d.ts +170 -0
  528. package/core/workspace_comment.ts +398 -0
  529. package/core/workspace_comment_svg.d.ts +329 -0
  530. package/core/{workspace_comment_svg.js → workspace_comment_svg.ts} +347 -444
  531. package/core/workspace_drag_surface_svg.d.ts +68 -0
  532. package/core/{workspace_drag_surface_svg.js → workspace_drag_surface_svg.ts} +75 -82
  533. package/core/workspace_dragger.d.ts +48 -0
  534. package/core/workspace_dragger.ts +104 -0
  535. package/core/workspace_svg.d.ts +920 -0
  536. package/core/{workspace_svg.js → workspace_svg.ts} +855 -935
  537. package/core/xml.d.ts +117 -0
  538. package/core/{xml.js → xml.ts} +306 -326
  539. package/core/zoom_controls.d.ts +130 -0
  540. package/core/{zoom_controls.js → zoom_controls.ts} +185 -251
  541. package/core.d.ts +1 -3
  542. package/core.js +1 -2
  543. package/dart.d.ts +0 -3
  544. package/dart_compressed.js +387 -99
  545. package/dart_compressed.js.map +1 -1
  546. package/generators/dart/all.js +2 -0
  547. package/generators/dart/colour.js +1 -1
  548. package/generators/dart/lists.js +1 -1
  549. package/generators/dart/logic.js +1 -1
  550. package/generators/dart/loops.js +1 -1
  551. package/generators/dart/math.js +1 -1
  552. package/generators/dart/procedures.js +1 -1
  553. package/generators/dart/text.js +1 -1
  554. package/generators/dart/variables.js +1 -1
  555. package/generators/dart/variables_dynamic.js +1 -1
  556. package/generators/dart.js +1 -2
  557. package/generators/javascript/all.js +2 -0
  558. package/generators/javascript/colour.js +1 -1
  559. package/generators/javascript/lists.js +1 -1
  560. package/generators/javascript/logic.js +1 -1
  561. package/generators/javascript/loops.js +1 -1
  562. package/generators/javascript/math.js +4 -4
  563. package/generators/javascript/procedures.js +1 -1
  564. package/generators/javascript/text.js +2 -2
  565. package/generators/javascript/variables.js +1 -1
  566. package/generators/javascript/variables_dynamic.js +1 -1
  567. package/generators/javascript.js +1 -3
  568. package/generators/lua/all.js +2 -0
  569. package/generators/lua/colour.js +1 -1
  570. package/generators/lua/lists.js +1 -1
  571. package/generators/lua/logic.js +1 -1
  572. package/generators/lua/loops.js +1 -1
  573. package/generators/lua/math.js +1 -1
  574. package/generators/lua/procedures.js +1 -1
  575. package/generators/lua/text.js +1 -1
  576. package/generators/lua/variables.js +1 -1
  577. package/generators/lua/variables_dynamic.js +1 -1
  578. package/generators/lua.js +1 -2
  579. package/generators/php/all.js +2 -0
  580. package/generators/php/colour.js +1 -1
  581. package/generators/php/lists.js +1 -2
  582. package/generators/php/logic.js +1 -1
  583. package/generators/php/loops.js +1 -1
  584. package/generators/php/math.js +1 -1
  585. package/generators/php/procedures.js +1 -1
  586. package/generators/php/text.js +1 -1
  587. package/generators/php/variables.js +1 -1
  588. package/generators/php/variables_dynamic.js +1 -1
  589. package/generators/php.js +1 -2
  590. package/generators/python/all.js +2 -0
  591. package/generators/python/colour.js +3 -3
  592. package/generators/python/lists.js +1 -1
  593. package/generators/python/logic.js +1 -1
  594. package/generators/python/loops.js +4 -7
  595. package/generators/python/math.js +1 -1
  596. package/generators/python/procedures.js +1 -1
  597. package/generators/python/text.js +1 -1
  598. package/generators/python/variables.js +1 -1
  599. package/generators/python/variables_dynamic.js +1 -1
  600. package/generators/python.js +1 -2
  601. package/index.d.ts +2 -8
  602. package/javascript.d.ts +0 -3
  603. package/javascript_compressed.js +314 -104
  604. package/javascript_compressed.js.map +1 -1
  605. package/lua.d.ts +0 -3
  606. package/lua_compressed.js +399 -81
  607. package/lua_compressed.js.map +1 -1
  608. package/package.json +5 -5
  609. package/php.d.ts +0 -3
  610. package/php_compressed.js +322 -93
  611. package/php_compressed.js.map +1 -1
  612. package/python.d.ts +0 -3
  613. package/python_compressed.js +237 -90
  614. package/python_compressed.js.map +1 -1
  615. package/blockly.d.ts +0 -26127
  616. package/core/blockly_options.js +0 -28
  617. package/core/bubble_dragger.js +0 -298
  618. package/core/clipboard.js +0 -80
  619. package/core/component_manager.js +0 -263
  620. package/core/contextmenu_items.js +0 -651
  621. package/core/contextmenu_registry.js +0 -178
  622. package/core/delete_area.js +0 -87
  623. package/core/dialog.js +0 -107
  624. package/core/drag_target.js +0 -98
  625. package/core/events/events.js +0 -147
  626. package/core/events/events_abstract.js +0 -133
  627. package/core/events/events_block_base.js +0 -70
  628. package/core/events/events_block_drag.js +0 -89
  629. package/core/events/events_bubble_open.js +0 -90
  630. package/core/events/events_comment_base.js +0 -121
  631. package/core/events/events_marker_move.js +0 -110
  632. package/core/events/events_selected.js +0 -83
  633. package/core/events/events_toolbox_item_select.js +0 -84
  634. package/core/events/events_trashcan_open.js +0 -73
  635. package/core/events/events_var_base.js +0 -70
  636. package/core/events/events_viewport.js +0 -107
  637. package/core/events/workspace_events.js +0 -93
  638. package/core/field_angle.js +0 -591
  639. package/core/field_checkbox.js +0 -255
  640. package/core/field_colour.js +0 -717
  641. package/core/field_image.js +0 -304
  642. package/core/field_label.js +0 -149
  643. package/core/field_label_serializable.js +0 -80
  644. package/core/field_textinput.js +0 -619
  645. package/core/flyout_button.js +0 -356
  646. package/core/grid.js +0 -226
  647. package/core/icon.js +0 -225
  648. package/core/input.js +0 -335
  649. package/core/interfaces/i_ast_node_location_svg.js +0 -45
  650. package/core/interfaces/i_ast_node_location_with_block.js +0 -41
  651. package/core/interfaces/i_autohideable.js +0 -40
  652. package/core/interfaces/i_block_dragger.js +0 -66
  653. package/core/interfaces/i_bounded_element.js +0 -45
  654. package/core/interfaces/i_bubble.js +0 -95
  655. package/core/interfaces/i_collapsible_toolbox_item.js +0 -53
  656. package/core/interfaces/i_connection_checker.js +0 -104
  657. package/core/interfaces/i_contextmenu.js +0 -32
  658. package/core/interfaces/i_copyable.js +0 -49
  659. package/core/interfaces/i_delete_area.js +0 -50
  660. package/core/interfaces/i_drag_target.js +0 -88
  661. package/core/interfaces/i_flyout.js +0 -201
  662. package/core/interfaces/i_keyboard_accessible.js +0 -38
  663. package/core/interfaces/i_metrics_manager.js +0 -154
  664. package/core/interfaces/i_positionable.js +0 -51
  665. package/core/interfaces/i_selectable.js +0 -51
  666. package/core/interfaces/i_selectable_toolbox_item.js +0 -73
  667. package/core/interfaces/i_serializer.js +0 -77
  668. package/core/interfaces/i_styleable.js +0 -39
  669. package/core/interfaces/i_toolbox.js +0 -142
  670. package/core/interfaces/i_toolbox_item.js +0 -85
  671. package/core/marker_manager.js +0 -213
  672. package/core/menuitem.js +0 -292
  673. package/core/names.js +0 -293
  674. package/core/registry.js +0 -384
  675. package/core/renderers/common/block_rendering.js +0 -170
  676. package/core/renderers/common/constants.js +0 -1250
  677. package/core/renderers/common/i_path_object.js +0 -162
  678. package/core/renderers/common/marker_svg.js +0 -721
  679. package/core/renderers/common/path_object.js +0 -283
  680. package/core/renderers/common/renderer.js +0 -305
  681. package/core/renderers/geras/constants.js +0 -73
  682. package/core/renderers/geras/geras.js +0 -36
  683. package/core/renderers/geras/measurables/inline_input.js +0 -58
  684. package/core/renderers/geras/measurables/statement_input.js +0 -57
  685. package/core/renderers/geras/renderer.js +0 -149
  686. package/core/renderers/measurables/base.js +0 -64
  687. package/core/renderers/measurables/bottom_row.js +0 -138
  688. package/core/renderers/measurables/connection.js +0 -56
  689. package/core/renderers/measurables/external_value_input.js +0 -70
  690. package/core/renderers/measurables/field.js +0 -71
  691. package/core/renderers/measurables/in_row_spacer.js +0 -47
  692. package/core/renderers/measurables/input_connection.js +0 -75
  693. package/core/renderers/measurables/next_connection.js +0 -50
  694. package/core/renderers/measurables/output_connection.js +0 -61
  695. package/core/renderers/measurables/previous_connection.js +0 -50
  696. package/core/renderers/measurables/round_corner.js +0 -52
  697. package/core/renderers/measurables/row.js +0 -247
  698. package/core/renderers/measurables/spacer_row.js +0 -69
  699. package/core/renderers/measurables/square_corner.js +0 -50
  700. package/core/renderers/measurables/top_row.js +0 -143
  701. package/core/renderers/measurables/types.js +0 -353
  702. package/core/renderers/minimalist/drawer.js +0 -42
  703. package/core/renderers/minimalist/info.js +0 -54
  704. package/core/renderers/minimalist/minimalist.js +0 -26
  705. package/core/renderers/minimalist/renderer.js +0 -80
  706. package/core/renderers/thrasos/renderer.js +0 -53
  707. package/core/renderers/thrasos/thrasos.js +0 -22
  708. package/core/renderers/zelos/marker_svg.js +0 -179
  709. package/core/renderers/zelos/measurables/bottom_row.js +0 -66
  710. package/core/renderers/zelos/measurables/row_elements.js +0 -46
  711. package/core/renderers/zelos/path_object.js +0 -247
  712. package/core/renderers/zelos/renderer.js +0 -147
  713. package/core/renderers/zelos/zelos.js +0 -38
  714. package/core/serialization/exceptions.js +0 -144
  715. package/core/shortcut_registry.js +0 -366
  716. package/core/theme/themes.js +0 -23
  717. package/core/theme.js +0 -228
  718. package/core/theme_manager.js +0 -211
  719. package/core/toolbox/category.js +0 -751
  720. package/core/toolbox/collapsible_category.js +0 -311
  721. package/core/toolbox/separator.js +0 -133
  722. package/core/toolbox/toolbox_item.js +0 -173
  723. package/core/touch.js +0 -285
  724. package/core/utils/coordinate.js +0 -138
  725. package/core/utils/global.js +0 -41
  726. package/core/utils/keycodes.js +0 -172
  727. package/core/utils/metrics.js +0 -154
  728. package/core/utils/svg.js +0 -186
  729. package/core/utils/toolbox.js +0 -459
  730. package/core/utils/useragent.js +0 -197
  731. package/core/utils.js +0 -383
  732. package/core/variable_model.js +0 -96
  733. package/core/widgetdiv.js +0 -290
  734. package/core/workspace.js +0 -836
  735. package/core/workspace_comment.js +0 -400
  736. package/core/workspace_dragger.js +0 -115
@@ -8,126 +8,107 @@
8
8
  * @fileoverview Object representing a mutator dialog. A mutator allows the
9
9
  * user to change the shape of a block using a nested blocks editor.
10
10
  */
11
- 'use strict';
12
11
 
13
12
  /**
14
13
  * Object representing a mutator dialog. A mutator allows the
15
14
  * user to change the shape of a block using a nested blocks editor.
16
15
  * @class
17
16
  */
18
- goog.module('Blockly.Mutator');
19
-
20
- const dom = goog.require('Blockly.utils.dom');
21
- const eventUtils = goog.require('Blockly.Events.utils');
22
- const toolbox = goog.require('Blockly.utils.toolbox');
23
- const xml = goog.require('Blockly.utils.xml');
24
- /* eslint-disable-next-line no-unused-vars */
25
- const {Abstract} = goog.requireType('Blockly.Events.Abstract');
26
- const {BlockChange} = goog.require('Blockly.Events.BlockChange');
27
- /* eslint-disable-next-line no-unused-vars */
28
- const {BlockSvg} = goog.requireType('Blockly.BlockSvg');
29
- /* eslint-disable-next-line no-unused-vars */
30
- const {BlocklyOptions} = goog.requireType('Blockly.BlocklyOptions');
31
- /* eslint-disable-next-line no-unused-vars */
32
- const {Block} = goog.requireType('Blockly.Block');
33
- const {Bubble} = goog.require('Blockly.Bubble');
34
- const {config} = goog.require('Blockly.config');
35
- /* eslint-disable-next-line no-unused-vars */
36
- const {Connection} = goog.requireType('Blockly.Connection');
37
- /* eslint-disable-next-line no-unused-vars */
38
- const {Coordinate} = goog.requireType('Blockly.utils.Coordinate');
39
- const {Icon} = goog.require('Blockly.Icon');
40
- const {Options} = goog.require('Blockly.Options');
41
- const {Svg} = goog.require('Blockly.utils.Svg');
42
- const {WorkspaceSvg} = goog.require('Blockly.WorkspaceSvg');
43
- /** @suppress {extraRequire} */
44
- goog.require('Blockly.Events.BubbleOpen');
17
+ import * as goog from '../closure/goog/goog.js';
18
+ goog.declareModuleId('Blockly.Mutator');
19
+
20
+ // Unused import preserved for side-effects. Remove if unneeded.
21
+ import './events/events_bubble_open.js';
22
+
23
+ import type {Block} from './block.js';
24
+ import type {BlockSvg} from './block_svg.js';
25
+ import type {BlocklyOptions} from './blockly_options.js';
26
+ import {Bubble} from './bubble.js';
27
+ import {config} from './config.js';
28
+ import type {Connection} from './connection.js';
29
+ import type {Abstract} from './events/events_abstract.js';
30
+ import {BlockChange} from './events/events_block_change.js';
31
+ import * as eventUtils from './events/utils.js';
32
+ import {Icon} from './icon.js';
33
+ import {Options} from './options.js';
34
+ import type {Coordinate} from './utils/coordinate.js';
35
+ import * as dom from './utils/dom.js';
36
+ import {Svg} from './utils/svg.js';
37
+ import * as toolbox from './utils/toolbox.js';
38
+ import * as xml from './utils/xml.js';
39
+ import type {WorkspaceSvg} from './workspace_svg.js';
45
40
 
46
41
 
47
42
  /**
48
43
  * Class for a mutator dialog.
49
- * @extends {Icon}
50
44
  * @alias Blockly.Mutator
51
45
  */
52
- class Mutator extends Icon {
46
+ export class Mutator extends Icon {
47
+ quarkNames_: AnyDuringMigration;
48
+
49
+ /** Workspace in the mutator's bubble. */
50
+ private workspace_: WorkspaceSvg|null = null;
51
+
52
+ /** Width of workspace. */
53
+ private workspaceWidth_ = 0;
54
+
55
+ /** Height of workspace. */
56
+ private workspaceHeight_ = 0;
57
+
53
58
  /**
54
- * @param {!Array<string>} quarkNames List of names of sub-blocks for flyout.
59
+ * The SVG element that is the parent of the mutator workspace, or null if
60
+ * not created.
55
61
  */
56
- constructor(quarkNames) {
57
- super(null);
58
- this.quarkNames_ = quarkNames;
62
+ private svgDialog_: SVGSVGElement|null = null;
63
+
64
+ /**
65
+ * The root block of the mutator workspace, created by decomposing the
66
+ * source block.
67
+ */
68
+ private rootBlock_: BlockSvg|null = null;
59
69
 
60
- /**
61
- * Workspace in the mutator's bubble.
62
- * @type {?WorkspaceSvg}
63
- * @private
64
- */
65
- this.workspace_ = null;
66
-
67
- /**
68
- * Width of workspace.
69
- * @type {number}
70
- * @private
71
- */
72
- this.workspaceWidth_ = 0;
73
-
74
- /**
75
- * Height of workspace.
76
- * @type {number}
77
- * @private
78
- */
79
- this.workspaceHeight_ = 0;
80
-
81
- /**
82
- * The SVG element that is the parent of the mutator workspace, or null if
83
- * not created.
84
- * @type {?SVGSVGElement}
85
- * @private
86
- */
87
- this.svgDialog_ = null;
88
-
89
- /**
90
- * The root block of the mutator workspace, created by decomposing the
91
- * source block.
92
- * @type {?BlockSvg}
93
- * @private
94
- */
95
- this.rootBlock_ = null;
96
-
97
- /**
98
- * Function registered on the main workspace to update the mutator contents
99
- * when the main workspace changes.
100
- * @type {?Function}
101
- * @private
102
- */
103
- this.sourceListener_ = null;
70
+ /**
71
+ * Function registered on the main workspace to update the mutator contents
72
+ * when the main workspace changes.
73
+ */
74
+ private sourceListener_: Function|null = null;
75
+
76
+ /**
77
+ * The PID associated with the updateWorkpace_ timeout, or 0 if no timeout
78
+ * is currently running.
79
+ */
80
+ private updateWorkspacePid_: AnyDuringMigration = 0;
81
+
82
+ /** @param quarkNames List of names of sub-blocks for flyout. */
83
+ constructor(block: BlockSvg, quarkNames: string[]) {
84
+ super(block);
85
+ this.quarkNames_ = quarkNames;
104
86
  }
105
87
 
106
88
  /**
107
89
  * Set the block this mutator is associated with.
108
- * @param {!BlockSvg} block The block associated with this mutator.
109
- * @package
90
+ * @param block The block associated with this mutator.
91
+ * @internal
110
92
  */
111
- setBlock(block) {
93
+ setBlock(block: BlockSvg) {
112
94
  this.block_ = block;
113
95
  }
114
96
 
115
97
  /**
116
98
  * Returns the workspace inside this mutator icon's bubble.
117
- * @return {?WorkspaceSvg} The workspace inside this mutator icon's
118
- * bubble or null if the mutator isn't open.
119
- * @package
99
+ * @return The workspace inside this mutator icon's bubble or null if the
100
+ * mutator isn't open.
101
+ * @internal
120
102
  */
121
- getWorkspace() {
103
+ getWorkspace(): WorkspaceSvg|null {
122
104
  return this.workspace_;
123
105
  }
124
106
 
125
107
  /**
126
108
  * Draw the mutator icon.
127
- * @param {!Element} group The icon group.
128
- * @protected
109
+ * @param group The icon group.
129
110
  */
130
- drawIcon_(group) {
111
+ protected override drawIcon_(group: Element) {
131
112
  // Square with rounded corners.
132
113
  dom.createSvgElement(
133
114
  Svg.RECT, {
@@ -160,34 +141,31 @@ class Mutator extends Icon {
160
141
  /**
161
142
  * Clicking on the icon toggles if the mutator bubble is visible.
162
143
  * Disable if block is uneditable.
163
- * @param {!Event} e Mouse click event.
164
- * @protected
165
- * @override
144
+ * @param e Mouse click event.
166
145
  */
167
- iconClick_(e) {
146
+ protected override iconClick_(e: MouseEvent) {
168
147
  if (this.block_.isEditable()) {
169
- Icon.prototype.iconClick_.call(this, e);
148
+ super.iconClick_(e);
170
149
  }
171
150
  }
172
151
 
173
152
  /**
174
153
  * Create the editor for the mutator's bubble.
175
- * @return {!SVGElement} The top-level node of the editor.
176
- * @private
154
+ * @return The top-level node of the editor.
177
155
  */
178
- createEditor_() {
156
+ private createEditor_(): SVGElement {
179
157
  /* Create the editor. Here's the markup that will be generated:
180
- <svg>
181
- [Workspace]
182
- </svg>
183
- */
158
+ <svg>
159
+ [Workspace]
160
+ </svg>
161
+ */
184
162
  this.svgDialog_ = dom.createSvgElement(
185
- Svg.SVG, {'x': Bubble.BORDER_WIDTH, 'y': Bubble.BORDER_WIDTH}, null);
163
+ Svg.SVG, {'x': Bubble.BORDER_WIDTH, 'y': Bubble.BORDER_WIDTH});
186
164
  // Convert the list of names into a list of XML objects for the flyout.
187
165
  let quarkXml;
188
166
  if (this.quarkNames_.length) {
189
167
  quarkXml = xml.createElement('xml');
190
- for (let i = 0, quarkName; (quarkName = this.quarkNames_[i]); i++) {
168
+ for (let i = 0, quarkName; quarkName = this.quarkNames_[i]; i++) {
191
169
  const element = xml.createElement('block');
192
170
  element.setAttribute('type', quarkName);
193
171
  quarkXml.appendChild(element);
@@ -195,27 +173,25 @@ class Mutator extends Icon {
195
173
  } else {
196
174
  quarkXml = null;
197
175
  }
198
- const workspaceOptions = new Options(
199
- /** @type {!BlocklyOptions} */
200
- ({
201
- // If you want to enable disabling, also remove the
202
- // event filter from workspaceChanged_ .
203
- 'disable': false,
204
- 'parentWorkspace': this.block_.workspace,
205
- 'media': this.block_.workspace.options.pathToMedia,
206
- 'rtl': this.block_.RTL,
207
- 'horizontalLayout': false,
208
- 'renderer': this.block_.workspace.options.renderer,
209
- 'rendererOverrides': this.block_.workspace.options.rendererOverrides,
210
- }));
176
+ const workspaceOptions = new Options(({
177
+ // If you want to enable disabling, also remove the
178
+ // event filter from workspaceChanged_ .
179
+ 'disable': false,
180
+ 'parentWorkspace': this.block_.workspace,
181
+ 'media': this.block_.workspace.options.pathToMedia,
182
+ 'rtl': this.block_.RTL,
183
+ 'horizontalLayout': false,
184
+ 'renderer': this.block_.workspace.options.renderer,
185
+ 'rendererOverrides': this.block_.workspace.options.rendererOverrides,
186
+ } as BlocklyOptions));
211
187
  workspaceOptions.toolboxPosition =
212
188
  this.block_.RTL ? toolbox.Position.RIGHT : toolbox.Position.LEFT;
213
189
  const hasFlyout = !!quarkXml;
214
190
  if (hasFlyout) {
215
191
  workspaceOptions.languageTree = toolbox.convertToolboxDefToJson(quarkXml);
216
192
  }
217
- this.workspace_ = new WorkspaceSvg(workspaceOptions);
218
- this.workspace_.isMutator = true;
193
+ this.workspace_ = this.newWorkspaceSvg(workspaceOptions);
194
+ this.workspace_.internalIsMutator = true;
219
195
  this.workspace_.addChangeListener(eventUtils.disableOrphans);
220
196
 
221
197
  // Mutator flyouts go inside the mutator workspace's <g> rather than in
@@ -231,45 +207,48 @@ class Mutator extends Icon {
231
207
  // dragging work properly.
232
208
  background.insertBefore(flyoutSvg, this.workspace_.svgBlockCanvas_);
233
209
  }
234
- this.svgDialog_.appendChild(background);
210
+ this.svgDialog_!.appendChild(background);
235
211
 
236
- return this.svgDialog_;
212
+ // AnyDuringMigration because: Type 'SVGSVGElement | null' is not
213
+ // assignable to type 'SVGElement'.
214
+ return this.svgDialog_ as AnyDuringMigration;
237
215
  }
238
216
 
239
217
  /**
240
- * Add or remove the UI indicating if this icon may be clicked or not.
218
+ * @internal
241
219
  */
242
- updateEditable() {
220
+ newWorkspaceSvg(options: Options): WorkspaceSvg {
221
+ throw new Error(
222
+ 'The implementation of newWorkspaceSvg should be ' +
223
+ 'monkey-patched in by blockly.ts');
224
+ }
225
+
226
+ /** Add or remove the UI indicating if this icon may be clicked or not. */
227
+ override updateEditable() {
243
228
  super.updateEditable();
244
229
  if (!this.block_.isInFlyout) {
245
230
  if (this.block_.isEditable()) {
246
231
  if (this.iconGroup_) {
247
232
  dom.removeClass(
248
- /** @type {!Element} */ (this.iconGroup_),
249
- 'blocklyIconGroupReadonly');
233
+ this.iconGroup_ as Element, 'blocklyIconGroupReadonly');
250
234
  }
251
235
  } else {
252
236
  // Close any mutator bubble. Icon is not clickable.
253
237
  this.setVisible(false);
254
238
  if (this.iconGroup_) {
255
- dom.addClass(
256
- /** @type {!Element} */ (this.iconGroup_),
257
- 'blocklyIconGroupReadonly');
239
+ dom.addClass(this.iconGroup_ as Element, 'blocklyIconGroupReadonly');
258
240
  }
259
241
  }
260
242
  }
261
243
  }
262
244
 
263
- /**
264
- * Resize the bubble to match the size of the workspace.
265
- * @private
266
- */
267
- resizeBubble_() {
245
+ /** Resize the bubble to match the size of the workspace. */
246
+ private resizeBubble_() {
268
247
  const doubleBorderWidth = 2 * Bubble.BORDER_WIDTH;
269
- const workspaceSize = this.workspace_.getCanvas().getBBox();
248
+ const workspaceSize = this.workspace_!.getCanvas().getBBox();
270
249
  let width = workspaceSize.width + workspaceSize.x;
271
250
  let height = workspaceSize.height + doubleBorderWidth * 3;
272
- const flyout = this.workspace_.getFlyout();
251
+ const flyout = this.workspace_!.getFlyout();
273
252
  if (flyout) {
274
253
  const flyoutScrollMetrics =
275
254
  flyout.getWorkspace().getMetricsManager().getScrollMetrics();
@@ -288,27 +267,30 @@ class Mutator extends Icon {
288
267
  this.workspaceWidth_ = width;
289
268
  this.workspaceHeight_ = height;
290
269
  // Resize the bubble.
291
- this.bubble_.setBubbleSize(
270
+ this.bubble_!.setBubbleSize(
292
271
  width + doubleBorderWidth, height + doubleBorderWidth);
293
- this.svgDialog_.setAttribute('width', this.workspaceWidth_);
294
- this.svgDialog_.setAttribute('height', this.workspaceHeight_);
295
- this.workspace_.setCachedParentSvgSize(
272
+ // AnyDuringMigration because: Argument of type 'number' is not
273
+ // assignable to parameter of type 'string'.
274
+ this.svgDialog_!.setAttribute(
275
+ 'width', this.workspaceWidth_ as AnyDuringMigration);
276
+ // AnyDuringMigration because: Argument of type 'number' is not
277
+ // assignable to parameter of type 'string'.
278
+ this.svgDialog_!.setAttribute(
279
+ 'height', this.workspaceHeight_ as AnyDuringMigration);
280
+ this.workspace_!.setCachedParentSvgSize(
296
281
  this.workspaceWidth_, this.workspaceHeight_);
297
282
  }
298
283
 
299
284
  if (this.block_.RTL) {
300
285
  // Scroll the workspace to always left-align.
301
286
  const translation = 'translate(' + this.workspaceWidth_ + ',0)';
302
- this.workspace_.getCanvas().setAttribute('transform', translation);
287
+ this.workspace_!.getCanvas().setAttribute('transform', translation);
303
288
  }
304
- this.workspace_.resize();
289
+ this.workspace_!.resize();
305
290
  }
306
291
 
307
- /**
308
- * A method handler for when the bubble is moved.
309
- * @private
310
- */
311
- onBubbleMove_() {
292
+ /** A method handler for when the bubble is moved. */
293
+ private onBubbleMove_() {
312
294
  if (this.workspace_) {
313
295
  this.workspace_.recordDragTargets();
314
296
  }
@@ -316,44 +298,44 @@ class Mutator extends Icon {
316
298
 
317
299
  /**
318
300
  * Show or hide the mutator bubble.
319
- * @param {boolean} visible True if the bubble should be visible.
301
+ * @param visible True if the bubble should be visible.
320
302
  */
321
- setVisible(visible) {
303
+ override setVisible(visible: boolean) {
322
304
  if (visible === this.isVisible()) {
323
305
  // No change.
324
306
  return;
325
307
  }
326
- eventUtils.fire(new (eventUtils.get(eventUtils.BUBBLE_OPEN))(
327
- this.block_, visible, 'mutator'));
308
+ eventUtils.fire(new (eventUtils.get(eventUtils.BUBBLE_OPEN))!
309
+ (this.block_, visible, 'mutator'));
328
310
  if (visible) {
329
311
  // Create the bubble.
330
312
  this.bubble_ = new Bubble(
331
- /** @type {!WorkspaceSvg} */ (this.block_.workspace),
332
- this.createEditor_(), this.block_.pathObject.svgPath,
333
- /** @type {!Coordinate} */ (this.iconXY_), null, null);
313
+ (this.block_.workspace as WorkspaceSvg), this.createEditor_(),
314
+ this.block_.pathObject.svgPath, (this.iconXY_ as Coordinate), null,
315
+ null);
334
316
  // Expose this mutator's block's ID on its top-level SVG group.
335
317
  this.bubble_.setSvgId(this.block_.id);
336
318
  this.bubble_.registerMoveEvent(this.onBubbleMove_.bind(this));
337
- const tree = this.workspace_.options.languageTree;
338
- const flyout = this.workspace_.getFlyout();
319
+ const tree = this.workspace_!.options.languageTree;
320
+ const flyout = this.workspace_!.getFlyout();
339
321
  if (tree) {
340
- flyout.init(this.workspace_);
341
- flyout.show(tree);
322
+ flyout!.init(this.workspace_!);
323
+ flyout!.show(tree);
342
324
  }
343
325
 
344
- this.rootBlock_ = this.block_.decompose(this.workspace_);
345
- const blocks = this.rootBlock_.getDescendants(false);
346
- for (let i = 0, child; (child = blocks[i]); i++) {
326
+ this.rootBlock_ = this.block_!.decompose!(this.workspace_!)!;
327
+ const blocks = this.rootBlock_!.getDescendants(false);
328
+ for (let i = 0, child; child = blocks[i]; i++) {
347
329
  child.render();
348
330
  }
349
331
  // The root block should not be draggable or deletable.
350
- this.rootBlock_.setMovable(false);
351
- this.rootBlock_.setDeletable(false);
332
+ this.rootBlock_!.setMovable(false);
333
+ this.rootBlock_!.setDeletable(false);
352
334
  let margin;
353
335
  let x;
354
336
  if (flyout) {
355
337
  margin = flyout.CORNER_RADIUS * 2;
356
- x = this.rootBlock_.RTL ? flyout.getWidth() + margin : margin;
338
+ x = this.rootBlock_!.RTL ? flyout.getWidth() + margin : margin;
357
339
  } else {
358
340
  margin = 16;
359
341
  x = margin;
@@ -361,13 +343,13 @@ class Mutator extends Icon {
361
343
  if (this.block_.RTL) {
362
344
  x = -x;
363
345
  }
364
- this.rootBlock_.moveBy(x, margin);
346
+ this.rootBlock_!.moveBy(x, margin);
365
347
  // Save the initial connections, then listen for further changes.
366
348
  if (this.block_.saveConnections) {
367
349
  const thisRootBlock = this.rootBlock_;
368
350
  this.block_.saveConnections(thisRootBlock);
369
351
  this.sourceListener_ = () => {
370
- if (this.block_) {
352
+ if (this.block_ && this.block_.saveConnections) {
371
353
  this.block_.saveConnections(thisRootBlock);
372
354
  }
373
355
  };
@@ -375,17 +357,17 @@ class Mutator extends Icon {
375
357
  }
376
358
  this.resizeBubble_();
377
359
  // When the mutator's workspace changes, update the source block.
378
- this.workspace_.addChangeListener(this.workspaceChanged_.bind(this));
360
+ this.workspace_!.addChangeListener(this.workspaceChanged_.bind(this));
379
361
  // Update the source block immediately after the bubble becomes visible.
380
362
  this.updateWorkspace_();
381
363
  this.applyColour();
382
364
  } else {
383
365
  // Dispose of the bubble.
384
366
  this.svgDialog_ = null;
385
- this.workspace_.dispose();
367
+ this.workspace_!.dispose();
386
368
  this.workspace_ = null;
387
369
  this.rootBlock_ = null;
388
- this.bubble_.dispose();
370
+ this.bubble_?.dispose();
389
371
  this.bubble_ = null;
390
372
  this.workspaceWidth_ = 0;
391
373
  this.workspaceHeight_ = 0;
@@ -398,29 +380,39 @@ class Mutator extends Icon {
398
380
 
399
381
  /**
400
382
  * Fired whenever a change is made to the mutator's workspace.
401
- * @param {!Abstract} e Custom data for event.
402
- * @private
383
+ * @param e Custom data for event.
403
384
  */
404
- workspaceChanged_(e) {
405
- if (!(e.isUiEvent ||
406
- (e.type === eventUtils.CHANGE &&
407
- /** @type {!BlockChange} */ (e).element === 'disabled') ||
408
- e.type === eventUtils.CREATE)) {
409
- this.updateWorkspace_();
385
+ private workspaceChanged_(e: Abstract) {
386
+ if (!this.shouldIgnoreMutatorEvent_(e) && !this.updateWorkspacePid_) {
387
+ this.updateWorkspacePid_ = setTimeout(() => {
388
+ this.updateWorkspacePid_ = 0;
389
+ this.updateWorkspace_();
390
+ }, 0);
410
391
  }
411
392
  }
412
393
 
394
+ /**
395
+ * Returns whether the given event in the mutator workspace should be ignored
396
+ * when deciding whether to update the workspace and compose the block or not.
397
+ * @param e The event.
398
+ * @return Whether to ignore the event or not.
399
+ */
400
+ shouldIgnoreMutatorEvent_(e: Abstract) {
401
+ return e.isUiEvent || e.type === eventUtils.CREATE ||
402
+ e.type === eventUtils.CHANGE &&
403
+ (e as BlockChange).element === 'disabled';
404
+ }
405
+
413
406
  /**
414
407
  * Updates the source block when the mutator's blocks are changed.
415
408
  * Bump down any block that's too high.
416
- * @private
417
409
  */
418
- updateWorkspace_() {
419
- if (!this.workspace_.isDragging()) {
420
- const blocks = this.workspace_.getTopBlocks(false);
410
+ private updateWorkspace_() {
411
+ if (!this.workspace_!.isDragging()) {
412
+ const blocks = this.workspace_!.getTopBlocks(false);
421
413
  const MARGIN = 20;
422
414
 
423
- for (let b = 0, block; (block = blocks[b]); b++) {
415
+ for (let b = 0, block; block = blocks[b]; b++) {
424
416
  const blockXY = block.getRelativeToSurfaceXY();
425
417
 
426
418
  // Bump any block that's above the top back inside.
@@ -430,7 +422,7 @@ class Mutator extends Icon {
430
422
  // Bump any block overlapping the flyout back inside.
431
423
  if (block.RTL) {
432
424
  let right = -MARGIN;
433
- const flyout = this.workspace_.getFlyout();
425
+ const flyout = this.workspace_!.getFlyout();
434
426
  if (flyout) {
435
427
  right -= flyout.getWidth();
436
428
  }
@@ -444,12 +436,12 @@ class Mutator extends Icon {
444
436
  }
445
437
 
446
438
  // When the mutator's workspace changes, update the source block.
447
- if (this.rootBlock_.workspace === this.workspace_) {
439
+ if (this.rootBlock_ && this.rootBlock_.workspace === this.workspace_) {
448
440
  const existingGroup = eventUtils.getGroup();
449
441
  if (!existingGroup) {
450
442
  eventUtils.setGroup(true);
451
443
  }
452
- const block = /** @type {!BlockSvg} */ (this.block_);
444
+ const block = this.block_ as BlockSvg;
453
445
  const oldExtraState = BlockChange.getExtraBlockState_(block);
454
446
 
455
447
  // Switch off rendering while the source block is rebuilt.
@@ -458,7 +450,7 @@ class Mutator extends Icon {
458
450
  block.rendered = false;
459
451
 
460
452
  // Allow the source block to rebuild itself.
461
- block.compose(this.rootBlock_);
453
+ block.compose!(this.rootBlock_);
462
454
  // Restore rendering and show the changes.
463
455
  block.rendered = savedRendered;
464
456
  // Mutation may have added some elements that need initializing.
@@ -470,7 +462,7 @@ class Mutator extends Icon {
470
462
 
471
463
  const newExtraState = BlockChange.getExtraBlockState_(block);
472
464
  if (oldExtraState !== newExtraState) {
473
- eventUtils.fire(new (eventUtils.get(eventUtils.BLOCK_CHANGE))(
465
+ eventUtils.fire(new (eventUtils.get(eventUtils.BLOCK_CHANGE))!(
474
466
  block, 'mutation', null, oldExtraState, newExtraState));
475
467
  // Ensure that any bump is part of this mutation's event group.
476
468
  const mutationGroup = eventUtils.getGroup();
@@ -484,38 +476,33 @@ class Mutator extends Icon {
484
476
 
485
477
  // Don't update the bubble until the drag has ended, to avoid moving
486
478
  // blocks under the cursor.
487
- if (!this.workspace_.isDragging()) {
488
- this.resizeBubble_();
479
+ if (!this.workspace_!.isDragging()) {
480
+ setTimeout(() => this.resizeBubble_(), 0);
489
481
  }
490
482
  eventUtils.setGroup(existingGroup);
491
483
  }
492
484
  }
493
485
 
494
- /**
495
- * Dispose of this mutator.
496
- */
497
- dispose() {
486
+ /** Dispose of this mutator. */
487
+ override dispose() {
498
488
  this.block_.mutator = null;
499
- Icon.prototype.dispose.call(this);
489
+ super.dispose();
500
490
  }
501
491
 
502
- /**
503
- * Update the styles on all blocks in the mutator.
504
- * @public
505
- */
492
+ /** Update the styles on all blocks in the mutator. */
506
493
  updateBlockStyle() {
507
494
  const ws = this.workspace_;
508
495
 
509
496
  if (ws && ws.getAllBlocks(false)) {
510
497
  const workspaceBlocks = ws.getAllBlocks(false);
511
- for (let i = 0, block; (block = workspaceBlocks[i]); i++) {
498
+ for (let i = 0, block; block = workspaceBlocks[i]; i++) {
512
499
  block.setStyle(block.getStyleName());
513
500
  }
514
501
 
515
502
  const flyout = ws.getFlyout();
516
503
  if (flyout) {
517
- const flyoutBlocks = flyout.workspace_.getAllBlocks(false);
518
- for (let i = 0, block; (block = flyoutBlocks[i]); i++) {
504
+ const flyoutBlocks = flyout.getWorkspace().getAllBlocks(false);
505
+ for (let i = 0, block; block = flyoutBlocks[i]; i++) {
519
506
  block.setStyle(block.getStyleName());
520
507
  }
521
508
  }
@@ -524,18 +511,19 @@ class Mutator extends Icon {
524
511
 
525
512
  /**
526
513
  * Reconnect an block to a mutated input.
527
- * @param {Connection} connectionChild Connection on child block.
528
- * @param {!Block} block Parent block.
529
- * @param {string} inputName Name of input on parent block.
530
- * @return {boolean} True iff a reconnection was made, false otherwise.
514
+ * @param connectionChild Connection on child block.
515
+ * @param block Parent block.
516
+ * @param inputName Name of input on parent block.
517
+ * @return True iff a reconnection was made, false otherwise.
531
518
  */
532
- static reconnect(connectionChild, block, inputName) {
519
+ static reconnect(
520
+ connectionChild: Connection, block: Block, inputName: string): boolean {
533
521
  if (!connectionChild || !connectionChild.getSourceBlock().workspace) {
534
522
  return false; // No connection or block has been deleted.
535
523
  }
536
- const connectionParent = block.getInput(inputName).connection;
524
+ const connectionParent = block.getInput(inputName)!.connection;
537
525
  const currentParent = connectionChild.targetBlock();
538
- if ((!currentParent || currentParent === block) &&
526
+ if ((!currentParent || currentParent === block) && connectionParent &&
539
527
  connectionParent.targetConnection !== connectionChild) {
540
528
  if (connectionParent.isConnected()) {
541
529
  // There's already something connected here. Get rid of it.
@@ -550,11 +538,10 @@ class Mutator extends Icon {
550
538
  /**
551
539
  * Get the parent workspace of a workspace that is inside a mutator, taking
552
540
  * into account whether it is a flyout.
553
- * @param {WorkspaceSvg} workspace The workspace that is inside a mutator.
554
- * @return {?WorkspaceSvg} The mutator's parent workspace or null.
555
- * @public
541
+ * @param workspace The workspace that is inside a mutator.
542
+ * @return The mutator's parent workspace or null.
556
543
  */
557
- static findParentWs(workspace) {
544
+ static findParentWs(workspace: WorkspaceSvg): WorkspaceSvg|null {
558
545
  let outerWs = null;
559
546
  if (workspace && workspace.options) {
560
547
  const parent = workspace.options.parentWorkspace;
@@ -571,5 +558,3 @@ class Mutator extends Icon {
571
558
  return outerWs;
572
559
  }
573
560
  }
574
-
575
- exports.Mutator = Mutator;