blockly 9.0.0-beta.0 → 9.0.0-beta.1

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 (608) hide show
  1. package/blockly.min.js +401 -405
  2. package/blockly_compressed.js +398 -402
  3. package/blockly_compressed.js.map +1 -1
  4. package/blocks.d.ts +0 -5
  5. package/blocks_compressed.js +3 -3
  6. package/blocks_compressed.js.map +1 -1
  7. package/closure/goog/base.d.ts +1 -0
  8. package/closure/goog/base_minimal.d.ts +1 -0
  9. package/closure/goog/goog.d.ts +1 -0
  10. package/core/any_aliases.d.ts +1 -0
  11. package/core/block.d.ts +145 -53
  12. package/core/block_animations.d.ts +5 -0
  13. package/core/block_drag_surface.d.ts +18 -5
  14. package/core/block_dragger.d.ts +20 -5
  15. package/core/block_svg.d.ts +89 -21
  16. package/core/blockly.d.ts +29 -8
  17. package/core/blockly_options.d.ts +2 -0
  18. package/core/blocks.d.ts +2 -0
  19. package/core/browser_events.d.ts +16 -7
  20. package/core/bubble.d.ts +42 -12
  21. package/core/bubble_dragger.d.ts +9 -2
  22. package/core/bump_objects.d.ts +6 -2
  23. package/core/clipboard.d.ts +6 -2
  24. package/core/comment.d.ts +13 -3
  25. package/core/common.d.ts +35 -9
  26. package/core/component_manager.d.ts +16 -6
  27. package/core/config.d.ts +1 -0
  28. package/core/connection.d.ts +48 -18
  29. package/core/connection_checker.d.ts +16 -7
  30. package/core/connection_db.d.ts +17 -6
  31. package/core/connection_type.d.ts +2 -0
  32. package/core/constants.d.ts +3 -0
  33. package/core/contextmenu.d.ts +15 -5
  34. package/core/contextmenu_items.d.ts +15 -0
  35. package/core/contextmenu_registry.d.ts +12 -7
  36. package/core/css.d.ts +3 -0
  37. package/core/delete_area.d.ts +5 -1
  38. package/core/dialog.d.ts +14 -7
  39. package/core/drag_target.d.ts +10 -2
  40. package/core/dropdowndiv.d.ts +42 -10
  41. package/core/events/events.d.ts +1 -0
  42. package/core/events/events_abstract.d.ts +10 -3
  43. package/core/events/events_block_base.d.ts +5 -1
  44. package/core/events/events_block_change.d.ts +10 -3
  45. package/core/events/events_block_create.d.ts +6 -1
  46. package/core/events/events_block_delete.d.ts +6 -1
  47. package/core/events/events_block_drag.d.ts +5 -1
  48. package/core/events/events_block_move.d.ts +10 -3
  49. package/core/events/events_bubble_open.d.ts +6 -2
  50. package/core/events/events_click.d.ts +5 -1
  51. package/core/events/events_comment_base.d.ts +6 -1
  52. package/core/events/events_comment_change.d.ts +8 -2
  53. package/core/events/events_comment_create.d.ts +6 -1
  54. package/core/events/events_comment_delete.d.ts +6 -1
  55. package/core/events/events_comment_move.d.ts +9 -2
  56. package/core/events/events_marker_move.d.ts +5 -1
  57. package/core/events/events_selected.d.ts +5 -1
  58. package/core/events/events_theme_change.d.ts +5 -1
  59. package/core/events/events_toolbox_item_select.d.ts +5 -1
  60. package/core/events/events_trashcan_open.d.ts +5 -1
  61. package/core/events/events_ui.d.ts +5 -1
  62. package/core/events/events_ui_base.d.ts +2 -0
  63. package/core/events/events_var_base.d.ts +5 -1
  64. package/core/events/events_var_create.d.ts +6 -1
  65. package/core/events/events_var_delete.d.ts +6 -1
  66. package/core/events/events_var_rename.d.ts +6 -1
  67. package/core/events/events_viewport.d.ts +5 -1
  68. package/core/events/utils.d.ts +50 -7
  69. package/core/events/workspace_events.d.ts +5 -1
  70. package/core/extensions.d.ts +14 -4
  71. package/core/field.d.ts +93 -34
  72. package/core/field_angle.d.ts +14 -3
  73. package/core/field_checkbox.d.ts +20 -7
  74. package/core/field_colour.d.ts +22 -6
  75. package/core/field_dropdown.d.ts +28 -8
  76. package/core/field_image.d.ts +15 -4
  77. package/core/field_label.d.ts +8 -2
  78. package/core/field_label_serializable.d.ts +4 -1
  79. package/core/field_multilineinput.d.ts +21 -6
  80. package/core/field_number.d.ts +22 -6
  81. package/core/field_registry.d.ts +8 -2
  82. package/core/field_textinput.d.ts +28 -8
  83. package/core/field_variable.d.ts +36 -13
  84. package/core/flyout_base.d.ts +70 -24
  85. package/core/flyout_button.d.ts +12 -5
  86. package/core/flyout_horizontal.d.ts +14 -6
  87. package/core/flyout_metrics_manager.d.ts +6 -3
  88. package/core/flyout_vertical.d.ts +14 -6
  89. package/core/generator.d.ts +39 -20
  90. package/core/gesture.d.ts +48 -13
  91. package/core/grid.d.ts +19 -15
  92. package/core/icon.d.ts +12 -3
  93. package/core/inject.d.ts +3 -1
  94. package/core/input.d.ts +25 -10
  95. package/core/input_types.d.ts +2 -0
  96. package/core/insertion_marker_manager.d.ts +27 -9
  97. package/core/interfaces/i_ast_node_location.d.ts +2 -0
  98. package/core/interfaces/i_ast_node_location_svg.d.ts +4 -0
  99. package/core/interfaces/i_ast_node_location_with_block.d.ts +4 -1
  100. package/core/interfaces/i_autohideable.d.ts +3 -0
  101. package/core/interfaces/i_block_dragger.d.ts +7 -1
  102. package/core/interfaces/i_bounded_element.d.ts +5 -1
  103. package/core/interfaces/i_bubble.d.ts +11 -2
  104. package/core/interfaces/i_collapsible_toolbox_item.d.ts +6 -2
  105. package/core/interfaces/i_component.d.ts +2 -0
  106. package/core/interfaces/i_connection_checker.d.ts +14 -6
  107. package/core/interfaces/i_contextmenu.d.ts +2 -0
  108. package/core/interfaces/i_copyable.d.ts +3 -1
  109. package/core/interfaces/i_deletable.d.ts +4 -1
  110. package/core/interfaces/i_delete_area.d.ts +4 -1
  111. package/core/interfaces/i_drag_target.d.ts +10 -2
  112. package/core/interfaces/i_draggable.d.ts +2 -0
  113. package/core/interfaces/i_flyout.d.ts +27 -11
  114. package/core/interfaces/i_keyboard_accessible.d.ts +4 -1
  115. package/core/interfaces/i_metrics_manager.d.ts +24 -12
  116. package/core/interfaces/i_movable.d.ts +4 -1
  117. package/core/interfaces/i_positionable.d.ts +5 -1
  118. package/core/interfaces/i_registrable.d.ts +2 -0
  119. package/core/interfaces/i_registrable_field.d.ts +2 -0
  120. package/core/interfaces/i_selectable.d.ts +2 -0
  121. package/core/interfaces/i_selectable_toolbox_item.d.ts +10 -3
  122. package/core/interfaces/i_serializer.d.ts +6 -1
  123. package/core/interfaces/i_styleable.d.ts +4 -0
  124. package/core/interfaces/i_toolbox.d.ts +17 -6
  125. package/core/interfaces/i_toolbox_item.d.ts +17 -7
  126. package/core/internal_constants.d.ts +6 -0
  127. package/core/keyboard_nav/ast_node.d.ts +55 -28
  128. package/core/keyboard_nav/basic_cursor.d.ts +20 -9
  129. package/core/keyboard_nav/cursor.d.ts +11 -5
  130. package/core/keyboard_nav/marker.d.ts +9 -2
  131. package/core/keyboard_nav/tab_navigate_cursor.d.ts +4 -1
  132. package/core/main.d.ts +1 -0
  133. package/core/marker_manager.d.ts +13 -2
  134. package/core/menu.d.ts +23 -5
  135. package/core/menuitem.d.ts +22 -7
  136. package/core/metrics_manager.d.ts +30 -15
  137. package/core/msg.d.ts +1 -0
  138. package/core/mutator.d.ts +19 -7
  139. package/core/names.d.ts +20 -8
  140. package/core/options.d.ts +12 -6
  141. package/core/positionable_helpers.d.ts +11 -3
  142. package/core/procedures.d.ts +27 -10
  143. package/core/registry.d.ts +19 -8
  144. package/core/rendered_connection.d.ts +28 -7
  145. package/core/renderers/common/block_rendering.d.ts +9 -2
  146. package/core/renderers/common/constants.d.ts +49 -17
  147. package/core/renderers/common/debug.d.ts +5 -1
  148. package/core/renderers/common/debugger.d.ts +12 -1
  149. package/core/renderers/common/drawer.d.ts +12 -0
  150. package/core/renderers/common/i_path_object.d.ts +15 -0
  151. package/core/renderers/common/info.d.ts +25 -8
  152. package/core/renderers/common/marker_svg.d.ts +35 -6
  153. package/core/renderers/common/path_object.d.ts +20 -0
  154. package/core/renderers/common/renderer.d.ts +33 -12
  155. package/core/renderers/geras/constants.d.ts +2 -0
  156. package/core/renderers/geras/drawer.d.ts +2 -0
  157. package/core/renderers/geras/geras.d.ts +3 -2
  158. package/core/renderers/geras/highlight_constants.d.ts +9 -6
  159. package/core/renderers/geras/highlighter.d.ts +12 -1
  160. package/core/renderers/geras/info.d.ts +4 -1
  161. package/core/renderers/geras/measurables/inline_input.d.ts +2 -0
  162. package/core/renderers/geras/measurables/statement_input.d.ts +2 -0
  163. package/core/renderers/geras/path_object.d.ts +4 -0
  164. package/core/renderers/geras/renderer.d.ts +16 -6
  165. package/core/renderers/measurables/base.d.ts +2 -0
  166. package/core/renderers/measurables/bottom_row.d.ts +9 -3
  167. package/core/renderers/measurables/connection.d.ts +2 -0
  168. package/core/renderers/measurables/external_value_input.d.ts +2 -1
  169. package/core/renderers/measurables/field.d.ts +2 -1
  170. package/core/renderers/measurables/hat.d.ts +2 -1
  171. package/core/renderers/measurables/icon.d.ts +3 -1
  172. package/core/renderers/measurables/in_row_spacer.d.ts +2 -1
  173. package/core/renderers/measurables/inline_input.d.ts +2 -1
  174. package/core/renderers/measurables/input_connection.d.ts +2 -0
  175. package/core/renderers/measurables/input_row.d.ts +4 -1
  176. package/core/renderers/measurables/jagged_edge.d.ts +2 -1
  177. package/core/renderers/measurables/next_connection.d.ts +2 -1
  178. package/core/renderers/measurables/output_connection.d.ts +2 -1
  179. package/core/renderers/measurables/previous_connection.d.ts +2 -1
  180. package/core/renderers/measurables/round_corner.d.ts +2 -1
  181. package/core/renderers/measurables/row.d.ts +27 -5
  182. package/core/renderers/measurables/spacer_row.d.ts +2 -1
  183. package/core/renderers/measurables/square_corner.d.ts +2 -1
  184. package/core/renderers/measurables/statement_input.d.ts +2 -1
  185. package/core/renderers/measurables/top_row.d.ts +7 -3
  186. package/core/renderers/measurables/types.d.ts +54 -25
  187. package/core/renderers/minimalist/constants.d.ts +2 -0
  188. package/core/renderers/minimalist/drawer.d.ts +2 -0
  189. package/core/renderers/minimalist/info.d.ts +4 -1
  190. package/core/renderers/minimalist/minimalist.d.ts +2 -1
  191. package/core/renderers/minimalist/renderer.d.ts +8 -3
  192. package/core/renderers/thrasos/info.d.ts +4 -1
  193. package/core/renderers/thrasos/renderer.d.ts +4 -1
  194. package/core/renderers/thrasos/thrasos.d.ts +2 -1
  195. package/core/renderers/zelos/constants.d.ts +11 -3
  196. package/core/renderers/zelos/drawer.d.ts +3 -0
  197. package/core/renderers/zelos/info.d.ts +10 -5
  198. package/core/renderers/zelos/marker_svg.d.ts +5 -0
  199. package/core/renderers/zelos/measurables/bottom_row.d.ts +2 -0
  200. package/core/renderers/zelos/measurables/inputs.d.ts +2 -0
  201. package/core/renderers/zelos/measurables/row_elements.d.ts +2 -0
  202. package/core/renderers/zelos/measurables/top_row.d.ts +2 -0
  203. package/core/renderers/zelos/path_object.d.ts +8 -1
  204. package/core/renderers/zelos/renderer.d.ts +14 -6
  205. package/core/renderers/zelos/zelos.d.ts +3 -2
  206. package/core/scrollbar.d.ts +41 -9
  207. package/core/scrollbar_pair.d.ts +20 -6
  208. package/core/serialization/blocks.d.ts +10 -4
  209. package/core/serialization/exceptions.d.ts +5 -0
  210. package/core/serialization/priorities.d.ts +3 -0
  211. package/core/serialization/registry.d.ts +3 -0
  212. package/core/serialization/variables.d.ts +2 -0
  213. package/core/serialization/workspaces.d.ts +4 -1
  214. package/core/shortcut_items.d.ts +10 -0
  215. package/core/shortcut_registry.d.ts +25 -9
  216. package/core/sprites.d.ts +2 -4
  217. package/core/theme/classic.d.ts +2 -0
  218. package/core/theme/themes.d.ts +1 -0
  219. package/core/theme/zelos.d.ts +2 -0
  220. package/core/theme.d.ts +14 -3
  221. package/core/theme_manager.d.ts +10 -1
  222. package/core/toolbox/category.d.ts +42 -15
  223. package/core/toolbox/collapsible_category.d.ts +10 -3
  224. package/core/toolbox/separator.d.ts +4 -1
  225. package/core/toolbox/toolbox.d.ts +70 -22
  226. package/core/toolbox/toolbox_item.d.ts +17 -7
  227. package/core/tooltip.d.ts +22 -1
  228. package/core/touch.d.ts +18 -6
  229. package/core/touch_gesture.d.ts +16 -2
  230. package/core/trashcan.d.ts +27 -6
  231. package/core/utils/aria.d.ts +4 -0
  232. package/core/utils/array.d.ts +4 -2
  233. package/core/utils/colour.d.ts +24 -13
  234. package/core/utils/coordinate.d.ts +18 -8
  235. package/core/utils/deprecation.d.ts +6 -4
  236. package/core/utils/dom.d.ts +32 -12
  237. package/core/utils/idgenerator.d.ts +13 -3
  238. package/core/utils/keycodes.d.ts +1 -0
  239. package/core/utils/math.d.ts +7 -3
  240. package/core/utils/metrics.d.ts +1 -0
  241. package/core/utils/object.d.ts +7 -2
  242. package/core/utils/parsing.d.ts +9 -4
  243. package/core/utils/rect.d.ts +5 -3
  244. package/core/utils/sentinel.d.ts +2 -0
  245. package/core/utils/size.d.ts +4 -2
  246. package/core/utils/string.d.ts +13 -6
  247. package/core/utils/style.d.ts +14 -33
  248. package/core/utils/svg.d.ts +5 -2
  249. package/core/utils/svg_math.d.ts +15 -7
  250. package/core/utils/svg_paths.d.ts +20 -10
  251. package/core/utils/toolbox.d.ts +26 -5
  252. package/core/utils/useragent.d.ts +1 -12
  253. package/core/utils/xml.d.ts +13 -5
  254. package/core/utils.d.ts +43 -21
  255. package/core/variable_map.d.ts +26 -9
  256. package/core/variable_model.d.ts +5 -2
  257. package/core/variables.d.ts +33 -18
  258. package/core/variables_dynamic.d.ts +25 -5
  259. package/core/warning.d.ts +8 -3
  260. package/core/widgetdiv.d.ts +15 -6
  261. package/core/workspace.d.ts +80 -30
  262. package/core/workspace_audio.d.ts +6 -0
  263. package/core/workspace_comment.d.ts +33 -11
  264. package/core/workspace_comment_svg.d.ts +52 -9
  265. package/core/workspace_drag_surface_svg.d.ts +20 -14
  266. package/core/workspace_dragger.d.ts +6 -0
  267. package/core/workspace_svg.d.ts +174 -62
  268. package/core/xml.d.ts +26 -11
  269. package/core/zoom_controls.d.ts +16 -6
  270. package/core.d.ts +0 -5
  271. package/dart.d.ts +0 -5
  272. package/dart_compressed.js.map +1 -1
  273. package/index.d.ts +2 -6
  274. package/javascript.d.ts +0 -5
  275. package/javascript_compressed.js.map +1 -1
  276. package/lua.d.ts +0 -5
  277. package/lua_compressed.js.map +1 -1
  278. package/package.json +6 -3
  279. package/php.d.ts +0 -5
  280. package/php_compressed.js.map +1 -1
  281. package/python.d.ts +0 -5
  282. package/python_compressed.js.map +1 -1
  283. package/blocks/blocks.js +0 -48
  284. package/blocks/colour.js +0 -121
  285. package/blocks/lists.js +0 -996
  286. package/blocks/logic.js +0 -665
  287. package/blocks/loops.js +0 -375
  288. package/blocks/math.js +0 -594
  289. package/blocks/procedures.js +0 -1196
  290. package/blocks/text.js +0 -1000
  291. package/blocks/variables.js +0 -176
  292. package/blocks/variables_dynamic.js +0 -192
  293. package/core/any_aliases.ts +0 -1
  294. package/core/block.ts +0 -2102
  295. package/core/block_animations.ts +0 -202
  296. package/core/block_drag_surface.ts +0 -237
  297. package/core/block_dragger.ts +0 -447
  298. package/core/block_svg.ts +0 -1758
  299. package/core/blockly.js +0 -890
  300. package/core/blockly.ts +0 -749
  301. package/core/blockly_options.ts +0 -81
  302. package/core/blocks.ts +0 -29
  303. package/core/browser_events.ts +0 -289
  304. package/core/bubble.ts +0 -892
  305. package/core/bubble_dragger.ts +0 -229
  306. package/core/bump_objects.ts +0 -182
  307. package/core/clipboard.ts +0 -91
  308. package/core/comment.ts +0 -398
  309. package/core/common.ts +0 -288
  310. package/core/component_manager.ts +0 -211
  311. package/core/config.ts +0 -80
  312. package/core/connection.ts +0 -692
  313. package/core/connection_checker.ts +0 -301
  314. package/core/connection_db.ts +0 -289
  315. package/core/connection_type.ts +0 -32
  316. package/core/constants.ts +0 -29
  317. package/core/contextmenu.ts +0 -363
  318. package/core/contextmenu_items.ts +0 -576
  319. package/core/contextmenu_registry.ts +0 -179
  320. package/core/css.ts +0 -560
  321. package/core/delete_area.ts +0 -82
  322. package/core/dialog.ts +0 -127
  323. package/core/drag_target.ts +0 -94
  324. package/core/dropdowndiv.ts +0 -683
  325. package/core/events/events.ts +0 -123
  326. package/core/events/events_abstract.ts +0 -112
  327. package/core/events/events_block_base.ts +0 -65
  328. package/core/events/events_block_change.ts +0 -176
  329. package/core/events/events_block_create.ts +0 -114
  330. package/core/events/events_block_delete.ts +0 -126
  331. package/core/events/events_block_drag.ts +0 -82
  332. package/core/events/events_block_move.ts +0 -206
  333. package/core/events/events_bubble_open.ts +0 -82
  334. package/core/events/events_click.ts +0 -84
  335. package/core/events/events_comment_base.ts +0 -107
  336. package/core/events/events_comment_change.ts +0 -108
  337. package/core/events/events_comment_create.ts +0 -82
  338. package/core/events/events_comment_delete.ts +0 -77
  339. package/core/events/events_comment_move.ts +0 -154
  340. package/core/events/events_marker_move.ts +0 -99
  341. package/core/events/events_selected.ts +0 -78
  342. package/core/events/events_theme_change.ts +0 -67
  343. package/core/events/events_toolbox_item_select.ts +0 -79
  344. package/core/events/events_trashcan_open.ts +0 -68
  345. package/core/events/events_ui.ts +0 -89
  346. package/core/events/events_ui_base.ts +0 -54
  347. package/core/events/events_var_base.ts +0 -65
  348. package/core/events/events_var_create.ts +0 -88
  349. package/core/events/events_var_delete.ts +0 -88
  350. package/core/events/events_var_rename.ts +0 -89
  351. package/core/events/events_viewport.ts +0 -100
  352. package/core/events/utils.ts +0 -529
  353. package/core/events/workspace_events.ts +0 -86
  354. package/core/extensions.ts +0 -504
  355. package/core/field.ts +0 -1206
  356. package/core/field_angle.ts +0 -563
  357. package/core/field_checkbox.ts +0 -243
  358. package/core/field_colour.ts +0 -632
  359. package/core/field_dropdown.ts +0 -773
  360. package/core/field_image.ts +0 -282
  361. package/core/field_label.ts +0 -152
  362. package/core/field_label_serializable.ts +0 -76
  363. package/core/field_multilineinput.ts +0 -466
  364. package/core/field_number.ts +0 -327
  365. package/core/field_registry.ts +0 -87
  366. package/core/field_textinput.ts +0 -591
  367. package/core/field_variable.ts +0 -545
  368. package/core/flyout_base.ts +0 -1165
  369. package/core/flyout_button.ts +0 -292
  370. package/core/flyout_horizontal.ts +0 -381
  371. package/core/flyout_metrics_manager.ts +0 -94
  372. package/core/flyout_vertical.ts +0 -384
  373. package/core/generator.ts +0 -539
  374. package/core/gesture.ts +0 -946
  375. package/core/grid.ts +0 -192
  376. package/core/icon.ts +0 -189
  377. package/core/inject.ts +0 -390
  378. package/core/input.ts +0 -309
  379. package/core/input_types.ts +0 -32
  380. package/core/insertion_marker_manager.ts +0 -788
  381. package/core/interfaces/i_ast_node_location.ts +0 -23
  382. package/core/interfaces/i_ast_node_location_svg.ts +0 -37
  383. package/core/interfaces/i_ast_node_location_with_block.ts +0 -38
  384. package/core/interfaces/i_autohideable.ts +0 -34
  385. package/core/interfaces/i_block_dragger.ts +0 -67
  386. package/core/interfaces/i_bounded_element.ts +0 -42
  387. package/core/interfaces/i_bubble.ts +0 -88
  388. package/core/interfaces/i_collapsible_toolbox_item.ts +0 -47
  389. package/core/interfaces/i_component.ts +0 -32
  390. package/core/interfaces/i_connection_checker.ts +0 -102
  391. package/core/interfaces/i_contextmenu.ts +0 -26
  392. package/core/interfaces/i_copyable.ts +0 -40
  393. package/core/interfaces/i_deletable.ts +0 -29
  394. package/core/interfaces/i_delete_area.ts +0 -46
  395. package/core/interfaces/i_drag_target.ts +0 -84
  396. package/core/interfaces/i_draggable.ts +0 -25
  397. package/core/interfaces/i_flyout.ts +0 -186
  398. package/core/interfaces/i_keyboard_accessible.ts +0 -35
  399. package/core/interfaces/i_metrics_manager.ts +0 -151
  400. package/core/interfaces/i_movable.ts +0 -29
  401. package/core/interfaces/i_positionable.ts +0 -50
  402. package/core/interfaces/i_registrable.ts +0 -25
  403. package/core/interfaces/i_registrable_field.ts +0 -31
  404. package/core/interfaces/i_selectable.ts +0 -34
  405. package/core/interfaces/i_selectable_toolbox_item.ts +0 -64
  406. package/core/interfaces/i_serializer.ts +0 -65
  407. package/core/interfaces/i_styleable.ts +0 -35
  408. package/core/interfaces/i_toolbox.ts +0 -127
  409. package/core/interfaces/i_toolbox_item.ts +0 -84
  410. package/core/internal_constants.ts +0 -67
  411. package/core/keyboard_nav/ast_node.ts +0 -717
  412. package/core/keyboard_nav/basic_cursor.ts +0 -214
  413. package/core/keyboard_nav/cursor.ts +0 -134
  414. package/core/keyboard_nav/marker.ts +0 -115
  415. package/core/keyboard_nav/tab_navigate_cursor.ts +0 -48
  416. package/core/main.js +0 -303
  417. package/core/marker_manager.ts +0 -181
  418. package/core/menu.ts +0 -449
  419. package/core/menuitem.ts +0 -240
  420. package/core/metrics_manager.ts +0 -456
  421. package/core/msg.ts +0 -20
  422. package/core/mutator.ts +0 -560
  423. package/core/names.ts +0 -267
  424. package/core/options.ts +0 -365
  425. package/core/positionable_helpers.ts +0 -181
  426. package/core/procedures.ts +0 -443
  427. package/core/registry.ts +0 -339
  428. package/core/rendered_connection.ts +0 -568
  429. package/core/renderers/common/block_rendering.ts +0 -164
  430. package/core/renderers/common/constants.ts +0 -1124
  431. package/core/renderers/common/debug.ts +0 -61
  432. package/core/renderers/common/debugger.ts +0 -433
  433. package/core/renderers/common/drawer.ts +0 -450
  434. package/core/renderers/common/i_path_object.ts +0 -161
  435. package/core/renderers/common/info.ts +0 -718
  436. package/core/renderers/common/marker_svg.ts +0 -680
  437. package/core/renderers/common/path_object.ts +0 -272
  438. package/core/renderers/common/renderer.ts +0 -271
  439. package/core/renderers/geras/constants.ts +0 -61
  440. package/core/renderers/geras/drawer.ts +0 -176
  441. package/core/renderers/geras/geras.ts +0 -37
  442. package/core/renderers/geras/highlight_constants.ts +0 -337
  443. package/core/renderers/geras/highlighter.ts +0 -306
  444. package/core/renderers/geras/info.ts +0 -450
  445. package/core/renderers/geras/measurables/inline_input.ts +0 -51
  446. package/core/renderers/geras/measurables/statement_input.ts +0 -50
  447. package/core/renderers/geras/path_object.ts +0 -138
  448. package/core/renderers/geras/renderer.ts +0 -126
  449. package/core/renderers/measurables/base.ts +0 -53
  450. package/core/renderers/measurables/bottom_row.ts +0 -120
  451. package/core/renderers/measurables/connection.ts +0 -52
  452. package/core/renderers/measurables/external_value_input.ts +0 -65
  453. package/core/renderers/measurables/field.ts +0 -63
  454. package/core/renderers/measurables/hat.ts +0 -48
  455. package/core/renderers/measurables/icon.ts +0 -54
  456. package/core/renderers/measurables/in_row_spacer.ts +0 -44
  457. package/core/renderers/measurables/inline_input.ts +0 -76
  458. package/core/renderers/measurables/input_connection.ts +0 -66
  459. package/core/renderers/measurables/input_row.ts +0 -82
  460. package/core/renderers/measurables/jagged_edge.ts +0 -43
  461. package/core/renderers/measurables/next_connection.ts +0 -47
  462. package/core/renderers/measurables/output_connection.ts +0 -56
  463. package/core/renderers/measurables/previous_connection.ts +0 -47
  464. package/core/renderers/measurables/round_corner.ts +0 -49
  465. package/core/renderers/measurables/row.ts +0 -225
  466. package/core/renderers/measurables/spacer_row.ts +0 -55
  467. package/core/renderers/measurables/square_corner.ts +0 -47
  468. package/core/renderers/measurables/statement_input.ts +0 -55
  469. package/core/renderers/measurables/top_row.ts +0 -122
  470. package/core/renderers/measurables/types.ts +0 -332
  471. package/core/renderers/minimalist/constants.ts +0 -32
  472. package/core/renderers/minimalist/drawer.ts +0 -38
  473. package/core/renderers/minimalist/info.ts +0 -52
  474. package/core/renderers/minimalist/minimalist.ts +0 -22
  475. package/core/renderers/minimalist/renderer.ts +0 -71
  476. package/core/renderers/thrasos/info.ts +0 -338
  477. package/core/renderers/thrasos/renderer.ts +0 -48
  478. package/core/renderers/thrasos/thrasos.ts +0 -20
  479. package/core/renderers/zelos/constants.ts +0 -858
  480. package/core/renderers/zelos/drawer.ts +0 -228
  481. package/core/renderers/zelos/info.ts +0 -593
  482. package/core/renderers/zelos/marker_svg.ts +0 -151
  483. package/core/renderers/zelos/measurables/bottom_row.ts +0 -53
  484. package/core/renderers/zelos/measurables/inputs.ts +0 -56
  485. package/core/renderers/zelos/measurables/row_elements.ts +0 -45
  486. package/core/renderers/zelos/measurables/top_row.ts +0 -58
  487. package/core/renderers/zelos/path_object.ts +0 -215
  488. package/core/renderers/zelos/renderer.ts +0 -142
  489. package/core/renderers/zelos/zelos.ts +0 -39
  490. package/core/scrollbar.ts +0 -870
  491. package/core/scrollbar_pair.ts +0 -321
  492. package/core/serialization/blocks.ts +0 -706
  493. package/core/serialization/exceptions.ts +0 -98
  494. package/core/serialization/priorities.ts +0 -32
  495. package/core/serialization/registry.ts +0 -43
  496. package/core/serialization/variables.ts +0 -96
  497. package/core/serialization/workspaces.ts +0 -106
  498. package/core/shortcut_items.ts +0 -266
  499. package/core/shortcut_registry.ts +0 -355
  500. package/core/sprites.ts +0 -29
  501. package/core/theme/classic.ts +0 -54
  502. package/core/theme/themes.ts +0 -22
  503. package/core/theme/zelos.ts +0 -91
  504. package/core/theme.ts +0 -221
  505. package/core/theme_manager.ts +0 -186
  506. package/core/toolbox/category.ts +0 -679
  507. package/core/toolbox/collapsible_category.ts +0 -273
  508. package/core/toolbox/separator.ts +0 -105
  509. package/core/toolbox/toolbox.ts +0 -1044
  510. package/core/toolbox/toolbox_item.ts +0 -147
  511. package/core/tooltip.ts +0 -463
  512. package/core/touch.ts +0 -306
  513. package/core/touch_gesture.ts +0 -295
  514. package/core/trashcan.ts +0 -671
  515. package/core/utils/aria.ts +0 -160
  516. package/core/utils/array.ts +0 -32
  517. package/core/utils/colour.ts +0 -276
  518. package/core/utils/coordinate.ts +0 -124
  519. package/core/utils/deprecation.ts +0 -41
  520. package/core/utils/dom.ts +0 -408
  521. package/core/utils/idgenerator.ts +0 -80
  522. package/core/utils/keycodes.ts +0 -169
  523. package/core/utils/math.ts +0 -61
  524. package/core/utils/metrics.ts +0 -97
  525. package/core/utils/object.ts +0 -95
  526. package/core/utils/parsing.ts +0 -261
  527. package/core/utils/rect.ts +0 -62
  528. package/core/utils/sentinel.ts +0 -23
  529. package/core/utils/size.ts +0 -51
  530. package/core/utils/string.ts +0 -308
  531. package/core/utils/style.ts +0 -306
  532. package/core/utils/svg.ts +0 -88
  533. package/core/utils/svg_math.ts +0 -269
  534. package/core/utils/svg_paths.ts +0 -140
  535. package/core/utils/toolbox.ts +0 -433
  536. package/core/utils/useragent.ts +0 -135
  537. package/core/utils/xml.ts +0 -97
  538. package/core/utils.ts +0 -428
  539. package/core/variable_map.ts +0 -392
  540. package/core/variable_model.ts +0 -82
  541. package/core/variables.ts +0 -596
  542. package/core/variables_dynamic.ts +0 -133
  543. package/core/warning.ts +0 -161
  544. package/core/widgetdiv.ts +0 -257
  545. package/core/workspace.ts +0 -801
  546. package/core/workspace_audio.ts +0 -156
  547. package/core/workspace_comment.ts +0 -398
  548. package/core/workspace_comment_svg.ts +0 -1127
  549. package/core/workspace_drag_surface_svg.ts +0 -187
  550. package/core/workspace_dragger.ts +0 -104
  551. package/core/workspace_svg.ts +0 -2655
  552. package/core/xml.ts +0 -1023
  553. package/core/zoom_controls.ts +0 -441
  554. package/generators/dart/all.js +0 -27
  555. package/generators/dart/colour.js +0 -105
  556. package/generators/dart/lists.js +0 -431
  557. package/generators/dart/logic.js +0 -123
  558. package/generators/dart/loops.js +0 -161
  559. package/generators/dart/math.js +0 -446
  560. package/generators/dart/procedures.js +0 -105
  561. package/generators/dart/text.js +0 -338
  562. package/generators/dart/variables.js +0 -32
  563. package/generators/dart/variables_dynamic.js +0 -21
  564. package/generators/dart.js +0 -303
  565. package/generators/javascript/all.js +0 -27
  566. package/generators/javascript/colour.js +0 -85
  567. package/generators/javascript/lists.js +0 -405
  568. package/generators/javascript/logic.js +0 -127
  569. package/generators/javascript/loops.js +0 -180
  570. package/generators/javascript/math.js +0 -401
  571. package/generators/javascript/procedures.js +0 -110
  572. package/generators/javascript/text.js +0 -371
  573. package/generators/javascript/variables.js +0 -32
  574. package/generators/javascript/variables_dynamic.js +0 -21
  575. package/generators/javascript.js +0 -322
  576. package/generators/lua/all.js +0 -27
  577. package/generators/lua/colour.js +0 -71
  578. package/generators/lua/lists.js +0 -348
  579. package/generators/lua/logic.js +0 -112
  580. package/generators/lua/loops.js +0 -168
  581. package/generators/lua/math.js +0 -406
  582. package/generators/lua/procedures.js +0 -106
  583. package/generators/lua/text.js +0 -327
  584. package/generators/lua/variables.js +0 -31
  585. package/generators/lua/variables_dynamic.js +0 -21
  586. package/generators/lua.js +0 -206
  587. package/generators/php/all.js +0 -27
  588. package/generators/php/colour.js +0 -81
  589. package/generators/php/lists.js +0 -481
  590. package/generators/php/logic.js +0 -119
  591. package/generators/php/loops.js +0 -161
  592. package/generators/php/math.js +0 -349
  593. package/generators/php/procedures.js +0 -125
  594. package/generators/php/text.js +0 -255
  595. package/generators/php/variables.js +0 -32
  596. package/generators/php/variables_dynamic.js +0 -21
  597. package/generators/php.js +0 -303
  598. package/generators/python/all.js +0 -27
  599. package/generators/python/colour.js +0 -67
  600. package/generators/python/lists.js +0 -346
  601. package/generators/python/logic.js +0 -120
  602. package/generators/python/loops.js +0 -206
  603. package/generators/python/math.js +0 -373
  604. package/generators/python/procedures.js +0 -129
  605. package/generators/python/text.js +0 -291
  606. package/generators/python/variables.js +0 -32
  607. package/generators/python/variables_dynamic.js +0 -21
  608. package/generators/python.js +0 -333
@@ -1,788 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2017 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- /**
8
- * @fileoverview Class that controls updates to connections during drags.
9
- */
10
-
11
- /**
12
- * Class that controls updates to connections during drags.
13
- * @class
14
- */
15
- import * as goog from '../closure/goog/goog.js';
16
- goog.declareModuleId('Blockly.InsertionMarkerManager');
17
-
18
- import * as blockAnimations from './block_animations.js';
19
- import type {BlockSvg} from './block_svg.js';
20
- import * as common from './common.js';
21
- import {ComponentManager} from './component_manager.js';
22
- import {config} from './config.js';
23
- import {ConnectionType} from './connection_type.js';
24
- import * as constants from './constants.js';
25
- import * as eventUtils from './events/utils.js';
26
- import type {IDeleteArea} from './interfaces/i_delete_area.js';
27
- import type {IDragTarget} from './interfaces/i_drag_target.js';
28
- import type {RenderedConnection} from './rendered_connection.js';
29
- import type {Coordinate} from './utils/coordinate.js';
30
- import type {WorkspaceSvg} from './workspace_svg.js';
31
-
32
-
33
- /** Represents a nearby valid connection. */
34
- interface CandidateConnection {
35
- closest: RenderedConnection|null;
36
- local: RenderedConnection|null;
37
- radius: number;
38
- }
39
-
40
- /**
41
- * An error message to throw if the block created by createMarkerBlock_ is
42
- * missing any components.
43
- */
44
- const DUPLICATE_BLOCK_ERROR = 'The insertion marker ' +
45
- 'manager tried to create a marker but the result is missing %1. If ' +
46
- 'you are using a mutator, make sure your domToMutation method is ' +
47
- 'properly defined.';
48
-
49
- /**
50
- * Class that controls updates to connections during drags. It is primarily
51
- * responsible for finding the closest eligible connection and highlighting or
52
- * unhighlighting it as needed during a drag.
53
- * @alias Blockly.InsertionMarkerManager
54
- */
55
- export class InsertionMarkerManager {
56
- private readonly topBlock_: BlockSvg;
57
- private readonly workspace_: WorkspaceSvg;
58
-
59
- /**
60
- * The last connection on the stack, if it's not the last connection on the
61
- * first block.
62
- * Set in initAvailableConnections, if at all.
63
- */
64
- // AnyDuringMigration because: Type 'null' is not assignable to type
65
- // 'RenderedConnection'.
66
- private lastOnStack_: RenderedConnection = null as AnyDuringMigration;
67
-
68
- /**
69
- * The insertion marker corresponding to the last block in the stack, if
70
- * that's not the same as the first block in the stack.
71
- * Set in initAvailableConnections, if at all
72
- */
73
- // AnyDuringMigration because: Type 'null' is not assignable to type
74
- // 'BlockSvg'.
75
- private lastMarker_: BlockSvg = null as AnyDuringMigration;
76
- private firstMarker_: BlockSvg;
77
-
78
- /**
79
- * The connection that this block would connect to if released immediately.
80
- * Updated on every mouse move.
81
- * This is not on any of the blocks that are being dragged.
82
- */
83
- // AnyDuringMigration because: Type 'null' is not assignable to type
84
- // 'RenderedConnection'.
85
- private closestConnection_: RenderedConnection = null as AnyDuringMigration;
86
-
87
- /**
88
- * The connection that would connect to this.closestConnection_ if this
89
- * block were released immediately. Updated on every mouse move. This is on
90
- * the top block that is being dragged or the last block in the dragging
91
- * stack.
92
- */
93
- // AnyDuringMigration because: Type 'null' is not assignable to type
94
- // 'RenderedConnection'.
95
- private localConnection_: RenderedConnection = null as AnyDuringMigration;
96
-
97
- /**
98
- * Whether the block would be deleted if it were dropped immediately.
99
- * Updated on every mouse move.
100
- */
101
- private wouldDeleteBlock_ = false;
102
-
103
- /**
104
- * Connection on the insertion marker block that corresponds to
105
- * this.localConnection_ on the currently dragged block.
106
- */
107
- // AnyDuringMigration because: Type 'null' is not assignable to type
108
- // 'RenderedConnection'.
109
- private markerConnection_: RenderedConnection = null as AnyDuringMigration;
110
-
111
- /** The block that currently has an input being highlighted, or null. */
112
- // AnyDuringMigration because: Type 'null' is not assignable to type
113
- // 'BlockSvg'.
114
- private highlightedBlock_: BlockSvg = null as AnyDuringMigration;
115
-
116
- /** The block being faded to indicate replacement, or null. */
117
- // AnyDuringMigration because: Type 'null' is not assignable to type
118
- // 'BlockSvg'.
119
- private fadedBlock_: BlockSvg = null as AnyDuringMigration;
120
- private availableConnections_: RenderedConnection[];
121
-
122
- /** @param block The top block in the stack being dragged. */
123
- constructor(block: BlockSvg) {
124
- common.setSelected(block);
125
-
126
- /**
127
- * The top block in the stack being dragged.
128
- * Does not change during a drag.
129
- */
130
- this.topBlock_ = block;
131
-
132
- /**
133
- * The workspace on which these connections are being dragged.
134
- * Does not change during a drag.
135
- */
136
- this.workspace_ = block.workspace;
137
-
138
- /**
139
- * The insertion marker that shows up between blocks to show where a block
140
- * would go if dropped immediately.
141
- */
142
- this.firstMarker_ = this.createMarkerBlock_(this.topBlock_);
143
-
144
- /**
145
- * The connections on the dragging blocks that are available to connect to
146
- * other blocks. This includes all open connections on the top block, as
147
- * well as the last connection on the block stack. Does not change during a
148
- * drag.
149
- */
150
- this.availableConnections_ = this.initAvailableConnections_();
151
- }
152
-
153
- /**
154
- * Sever all links from this object.
155
- * @internal
156
- */
157
- dispose() {
158
- this.availableConnections_.length = 0;
159
-
160
- eventUtils.disable();
161
- try {
162
- if (this.firstMarker_) {
163
- this.firstMarker_.dispose();
164
- }
165
- if (this.lastMarker_) {
166
- this.lastMarker_.dispose();
167
- }
168
- } finally {
169
- eventUtils.enable();
170
- }
171
- }
172
-
173
- /**
174
- * Update the available connections for the top block. These connections can
175
- * change if a block is unplugged and the stack is healed.
176
- * @internal
177
- */
178
- updateAvailableConnections() {
179
- this.availableConnections_ = this.initAvailableConnections_();
180
- }
181
-
182
- /**
183
- * Return whether the block would be deleted if dropped immediately, based on
184
- * information from the most recent move event.
185
- * @return True if the block would be deleted if dropped immediately.
186
- * @internal
187
- */
188
- wouldDeleteBlock(): boolean {
189
- return this.wouldDeleteBlock_;
190
- }
191
-
192
- /**
193
- * Return whether the block would be connected if dropped immediately, based
194
- * on information from the most recent move event.
195
- * @return True if the block would be connected if dropped immediately.
196
- * @internal
197
- */
198
- wouldConnectBlock(): boolean {
199
- return !!this.closestConnection_;
200
- }
201
-
202
- /**
203
- * Connect to the closest connection and render the results.
204
- * This should be called at the end of a drag.
205
- * @internal
206
- */
207
- applyConnections() {
208
- if (this.closestConnection_) {
209
- // Don't fire events for insertion markers.
210
- eventUtils.disable();
211
- this.hidePreview_();
212
- eventUtils.enable();
213
- // Connect two blocks together.
214
- // AnyDuringMigration because: Argument of type 'RenderedConnection' is
215
- // not assignable to parameter of type 'Connection'.
216
- this.localConnection_.connect(
217
- this.closestConnection_ as AnyDuringMigration);
218
- if (this.topBlock_.rendered) {
219
- // Trigger a connection animation.
220
- // Determine which connection is inferior (lower in the source stack).
221
- const inferiorConnection = this.localConnection_.isSuperior() ?
222
- this.closestConnection_ :
223
- this.localConnection_;
224
- blockAnimations.connectionUiEffect(inferiorConnection.getSourceBlock());
225
- // Bring the just-edited stack to the front.
226
- const rootBlock = this.topBlock_.getRootBlock();
227
- rootBlock.bringToFront();
228
- }
229
- }
230
- }
231
-
232
- /**
233
- * Update connections based on the most recent move location.
234
- * @param dxy Position relative to drag start, in workspace units.
235
- * @param dragTarget The drag target that the block is currently over.
236
- * @internal
237
- */
238
- update(dxy: Coordinate, dragTarget: IDragTarget|null) {
239
- const candidate = this.getCandidate_(dxy);
240
-
241
- this.wouldDeleteBlock_ = this.shouldDelete_(candidate, dragTarget);
242
-
243
- const shouldUpdate =
244
- this.wouldDeleteBlock_ || this.shouldUpdatePreviews_(candidate, dxy);
245
-
246
- if (shouldUpdate) {
247
- // Don't fire events for insertion marker creation or movement.
248
- eventUtils.disable();
249
- this.maybeHidePreview_(candidate);
250
- this.maybeShowPreview_(candidate);
251
- eventUtils.enable();
252
- }
253
- }
254
-
255
- /**
256
- * Create an insertion marker that represents the given block.
257
- * @param sourceBlock The block that the insertion marker will represent.
258
- * @return The insertion marker that represents the given block.
259
- */
260
- private createMarkerBlock_(sourceBlock: BlockSvg): BlockSvg {
261
- const imType = sourceBlock.type;
262
-
263
- eventUtils.disable();
264
- let result: BlockSvg;
265
- try {
266
- result = this.workspace_.newBlock(imType);
267
- result.setInsertionMarker(true);
268
- if (sourceBlock.saveExtraState) {
269
- const state = sourceBlock.saveExtraState();
270
- if (state && result.loadExtraState) {
271
- result.loadExtraState(state);
272
- }
273
- } else if (sourceBlock.mutationToDom) {
274
- const oldMutationDom = sourceBlock.mutationToDom();
275
- if (oldMutationDom && result.domToMutation) {
276
- result.domToMutation(oldMutationDom);
277
- }
278
- }
279
- // Copy field values from the other block. These values may impact the
280
- // rendered size of the insertion marker. Note that we do not care about
281
- // child blocks here.
282
- for (let i = 0; i < sourceBlock.inputList.length; i++) {
283
- const sourceInput = sourceBlock.inputList[i];
284
- if (sourceInput.name === constants.COLLAPSED_INPUT_NAME) {
285
- continue; // Ignore the collapsed input.
286
- }
287
- const resultInput = result.inputList[i];
288
- if (!resultInput) {
289
- throw new Error(DUPLICATE_BLOCK_ERROR.replace('%1', 'an input'));
290
- }
291
- for (let j = 0; j < sourceInput.fieldRow.length; j++) {
292
- const sourceField = sourceInput.fieldRow[j];
293
- const resultField = resultInput.fieldRow[j];
294
- if (!resultField) {
295
- throw new Error(DUPLICATE_BLOCK_ERROR.replace('%1', 'a field'));
296
- }
297
- resultField.setValue(sourceField.getValue());
298
- }
299
- }
300
-
301
- result.setCollapsed(sourceBlock.isCollapsed());
302
- result.setInputsInline(sourceBlock.getInputsInline());
303
-
304
- result.initSvg();
305
- result.getSvgRoot().setAttribute('visibility', 'hidden');
306
- } finally {
307
- eventUtils.enable();
308
- }
309
-
310
- return result;
311
- }
312
-
313
- /**
314
- * Populate the list of available connections on this block stack. This
315
- * should only be called once, at the beginning of a drag. If the stack has
316
- * more than one block, this function will populate lastOnStack_ and create
317
- * the corresponding insertion marker.
318
- * @return A list of available connections.
319
- */
320
- private initAvailableConnections_(): RenderedConnection[] {
321
- const available = this.topBlock_.getConnections_(false);
322
- // Also check the last connection on this stack
323
- const lastOnStack = this.topBlock_.lastConnectionInStack(true);
324
- if (lastOnStack && lastOnStack !== this.topBlock_.nextConnection) {
325
- available.push(lastOnStack);
326
- this.lastOnStack_ = lastOnStack;
327
- if (this.lastMarker_) {
328
- eventUtils.disable();
329
- try {
330
- this.lastMarker_.dispose();
331
- } finally {
332
- eventUtils.enable();
333
- }
334
- }
335
- this.lastMarker_ = this.createMarkerBlock_(lastOnStack.getSourceBlock());
336
- }
337
- return available;
338
- }
339
-
340
- /**
341
- * Whether the previews (insertion marker and replacement marker) should be
342
- * updated based on the closest candidate and the current drag distance.
343
- * @param candidate An object containing a local connection, a closest
344
- * connection, and a radius. Returned by getCandidate_.
345
- * @param dxy Position relative to drag start, in workspace units.
346
- * @return Whether the preview should be updated.
347
- */
348
- private shouldUpdatePreviews_(
349
- candidate: CandidateConnection, dxy: Coordinate): boolean {
350
- const candidateLocal = candidate.local;
351
- const candidateClosest = candidate.closest;
352
- const radius = candidate.radius;
353
-
354
- // Found a connection!
355
- if (candidateLocal && candidateClosest) {
356
- // We're already showing an insertion marker.
357
- // Decide whether the new connection has higher priority.
358
- if (this.localConnection_ && this.closestConnection_) {
359
- // The connection was the same as the current connection.
360
- if (this.closestConnection_ === candidateClosest &&
361
- this.localConnection_ === candidateLocal) {
362
- return false;
363
- }
364
- const xDiff =
365
- this.localConnection_.x + dxy.x - this.closestConnection_.x;
366
- const yDiff =
367
- this.localConnection_.y + dxy.y - this.closestConnection_.y;
368
- const curDistance = Math.sqrt(xDiff * xDiff + yDiff * yDiff);
369
- // Slightly prefer the existing preview over a new preview.
370
- return !(
371
- candidateClosest &&
372
- radius > curDistance - config.currentConnectionPreference);
373
- } else if (!this.localConnection_ && !this.closestConnection_) {
374
- // We weren't showing a preview before, but we should now.
375
- return true;
376
- } else {
377
- console.error(
378
- 'Only one of localConnection_ and closestConnection_ was set.');
379
- }
380
- } else { // No connection found.
381
- // Only need to update if we were showing a preview before.
382
- return !!(this.localConnection_ && this.closestConnection_);
383
- }
384
-
385
- console.error(
386
- 'Returning true from shouldUpdatePreviews, but it\'s not clear why.');
387
- return true;
388
- }
389
-
390
- /**
391
- * Find the nearest valid connection, which may be the same as the current
392
- * closest connection.
393
- * @param dxy Position relative to drag start, in workspace units.
394
- * @return An object containing a local connection, a closest connection, and
395
- * a radius.
396
- */
397
- private getCandidate_(dxy: Coordinate): CandidateConnection {
398
- let radius = this.getStartRadius_();
399
- let candidateClosest = null;
400
- let candidateLocal = null;
401
-
402
- // It's possible that a block has added or removed connections during a
403
- // drag, (e.g. in a drag/move event handler), so let's update the available
404
- // connections. Note that this will be called on every move while dragging,
405
- // so it might cause slowness, especially if the block stack is large. If
406
- // so, maybe it could be made more efficient. Also note that we won't update
407
- // the connections if we've already connected the insertion marker to a
408
- // block.
409
- if (!this.markerConnection_ || !this.markerConnection_.isConnected()) {
410
- this.updateAvailableConnections();
411
- }
412
-
413
- for (let i = 0; i < this.availableConnections_.length; i++) {
414
- const myConnection = this.availableConnections_[i];
415
- const neighbour = myConnection.closest(radius, dxy);
416
- if (neighbour.connection) {
417
- candidateClosest = neighbour.connection;
418
- candidateLocal = myConnection;
419
- radius = neighbour.radius;
420
- }
421
- }
422
- return {closest: candidateClosest, local: candidateLocal, radius};
423
- }
424
-
425
- /**
426
- * Decide the radius at which to start searching for the closest connection.
427
- * @return The radius at which to start the search for the closest connection.
428
- */
429
- private getStartRadius_(): number {
430
- // If there is already a connection highlighted,
431
- // increase the radius we check for making new connections.
432
- // Why? When a connection is highlighted, blocks move around when the
433
- // insertion marker is created, which could cause the connection became out
434
- // of range. By increasing radiusConnection when a connection already
435
- // exists, we never "lose" the connection from the offset.
436
- if (this.closestConnection_ && this.localConnection_) {
437
- return config.connectingSnapRadius;
438
- }
439
- return config.snapRadius;
440
- }
441
-
442
- /**
443
- * Whether ending the drag would delete the block.
444
- * @param candidate An object containing a local connection, a closest
445
- * connection, and a radius.
446
- * @param dragTarget The drag target that the block is currently over.
447
- * @return Whether dropping the block immediately would delete the block.
448
- */
449
- private shouldDelete_(
450
- candidate: CandidateConnection, dragTarget: IDragTarget|null): boolean {
451
- if (dragTarget) {
452
- const componentManager = this.workspace_.getComponentManager();
453
- const isDeleteArea = componentManager.hasCapability(
454
- dragTarget.id, ComponentManager.Capability.DELETE_AREA);
455
- if (isDeleteArea) {
456
- return (dragTarget as IDeleteArea)
457
- .wouldDelete(this.topBlock_, candidate && !!candidate.closest);
458
- }
459
- }
460
- return false;
461
- }
462
-
463
- /**
464
- * Show an insertion marker or replacement highlighting during a drag, if
465
- * needed.
466
- * At the beginning of this function, this.localConnection_ and
467
- * this.closestConnection_ should both be null.
468
- * @param candidate An object containing a local connection, a closest
469
- * connection, and a radius.
470
- */
471
- private maybeShowPreview_(candidate: CandidateConnection) {
472
- // Nope, don't add a marker.
473
- if (this.wouldDeleteBlock_) {
474
- return;
475
- }
476
- const closest = candidate.closest;
477
- const local = candidate.local;
478
-
479
- // Nothing to connect to.
480
- if (!closest) {
481
- return;
482
- }
483
-
484
- // Something went wrong and we're trying to connect to an invalid
485
- // connection.
486
- if (closest === this.closestConnection_ ||
487
- closest.getSourceBlock().isInsertionMarker()) {
488
- console.log('Trying to connect to an insertion marker');
489
- return;
490
- }
491
- // Add an insertion marker or replacement marker.
492
- this.closestConnection_ = closest;
493
- // AnyDuringMigration because: Type 'RenderedConnection | null' is not
494
- // assignable to type 'RenderedConnection'.
495
- this.localConnection_ = local as AnyDuringMigration;
496
- this.showPreview_();
497
- }
498
-
499
- /**
500
- * A preview should be shown. This function figures out if it should be a
501
- * block highlight or an insertion marker, and shows the appropriate one.
502
- */
503
- private showPreview_() {
504
- const closest = this.closestConnection_;
505
- const renderer = this.workspace_.getRenderer();
506
- const method = renderer.getConnectionPreviewMethod(
507
- (closest), (this.localConnection_), this.topBlock_);
508
-
509
- switch (method) {
510
- case InsertionMarkerManager.PREVIEW_TYPE.INPUT_OUTLINE:
511
- this.showInsertionInputOutline_();
512
- break;
513
- case InsertionMarkerManager.PREVIEW_TYPE.INSERTION_MARKER:
514
- this.showInsertionMarker_();
515
- break;
516
- case InsertionMarkerManager.PREVIEW_TYPE.REPLACEMENT_FADE:
517
- this.showReplacementFade_();
518
- break;
519
- }
520
-
521
- // Optionally highlight the actual connection, as a nod to previous
522
- // behaviour.
523
- // AnyDuringMigration because: Argument of type 'RenderedConnection' is not
524
- // assignable to parameter of type 'Connection'.
525
- if (closest &&
526
- renderer.shouldHighlightConnection(closest as AnyDuringMigration)) {
527
- closest.highlight();
528
- }
529
- }
530
-
531
- /**
532
- * Show an insertion marker or replacement highlighting during a drag, if
533
- * needed.
534
- * At the end of this function, this.localConnection_ and
535
- * this.closestConnection_ should both be null.
536
- * @param candidate An object containing a local connection, a closest
537
- * connection, and a radius.
538
- */
539
- private maybeHidePreview_(candidate: CandidateConnection) {
540
- // If there's no new preview, remove the old one but don't bother deleting
541
- // it. We might need it later, and this saves disposing of it and recreating
542
- // it.
543
- if (!candidate.closest) {
544
- this.hidePreview_();
545
- } else {
546
- // If there's a new preview and there was an preview before, and either
547
- // connection has changed, remove the old preview.
548
- const hadPreview = this.closestConnection_ && this.localConnection_;
549
- const closestChanged = this.closestConnection_ !== candidate.closest;
550
- const localChanged = this.localConnection_ !== candidate.local;
551
-
552
- // Also hide if we had a preview before but now we're going to delete
553
- // instead.
554
- if (hadPreview &&
555
- (closestChanged || localChanged || this.wouldDeleteBlock_)) {
556
- this.hidePreview_();
557
- }
558
- }
559
-
560
- // Either way, clear out old state.
561
- // AnyDuringMigration because: Type 'null' is not assignable to type
562
- // 'RenderedConnection'.
563
- this.markerConnection_ = null as AnyDuringMigration;
564
- // AnyDuringMigration because: Type 'null' is not assignable to type
565
- // 'RenderedConnection'.
566
- this.closestConnection_ = null as AnyDuringMigration;
567
- // AnyDuringMigration because: Type 'null' is not assignable to type
568
- // 'RenderedConnection'.
569
- this.localConnection_ = null as AnyDuringMigration;
570
- }
571
-
572
- /**
573
- * A preview should be hidden. This function figures out if it is a block
574
- * highlight or an insertion marker, and hides the appropriate one.
575
- */
576
- private hidePreview_() {
577
- // AnyDuringMigration because: Argument of type 'RenderedConnection' is not
578
- // assignable to parameter of type 'Connection'.
579
- if (this.closestConnection_ && this.closestConnection_.targetBlock() &&
580
- this.workspace_.getRenderer().shouldHighlightConnection(
581
- this.closestConnection_ as AnyDuringMigration)) {
582
- this.closestConnection_.unhighlight();
583
- }
584
- if (this.fadedBlock_) {
585
- this.hideReplacementFade_();
586
- } else if (this.highlightedBlock_) {
587
- this.hideInsertionInputOutline_();
588
- } else if (this.markerConnection_) {
589
- this.hideInsertionMarker_();
590
- }
591
- }
592
-
593
- /**
594
- * Shows an insertion marker connected to the appropriate blocks (based on
595
- * manager state).
596
- */
597
- private showInsertionMarker_() {
598
- const local = this.localConnection_;
599
- const closest = this.closestConnection_;
600
-
601
- const isLastInStack = this.lastOnStack_ && local === this.lastOnStack_;
602
- let imBlock = isLastInStack ? this.lastMarker_ : this.firstMarker_;
603
- let imConn;
604
- try {
605
- // AnyDuringMigration because: Argument of type 'BlockSvg' is not
606
- // assignable to parameter of type 'Block'.
607
- imConn = imBlock.getMatchingConnection(
608
- local.getSourceBlock() as AnyDuringMigration, local);
609
- } catch (e) {
610
- // It's possible that the number of connections on the local block has
611
- // changed since the insertion marker was originally created. Let's
612
- // recreate the insertion marker and try again. In theory we could
613
- // probably recreate the marker block (e.g. in getCandidate_), which is
614
- // called more often during the drag, but creating a block that often
615
- // might be too slow, so we only do it if necessary.
616
- this.firstMarker_ = this.createMarkerBlock_(this.topBlock_);
617
- imBlock = isLastInStack ? this.lastMarker_ : this.firstMarker_;
618
- // AnyDuringMigration because: Argument of type 'BlockSvg' is not
619
- // assignable to parameter of type 'Block'.
620
- imConn = imBlock.getMatchingConnection(
621
- local.getSourceBlock() as AnyDuringMigration, local);
622
- }
623
-
624
- if (imConn === this.markerConnection_) {
625
- throw Error(
626
- 'Made it to showInsertionMarker_ even though the marker isn\'t ' +
627
- 'changing');
628
- }
629
-
630
- // Render disconnected from everything else so that we have a valid
631
- // connection location.
632
- imBlock.render();
633
- imBlock.rendered = true;
634
- imBlock.getSvgRoot().setAttribute('visibility', 'visible');
635
-
636
- if (imConn && closest) {
637
- // Position so that the existing block doesn't move.
638
- imBlock.positionNearConnection(imConn, closest);
639
- }
640
- if (closest) {
641
- // Connect() also renders the insertion marker.
642
- // AnyDuringMigration because: Argument of type 'RenderedConnection' is
643
- // not assignable to parameter of type 'Connection'.
644
- imConn!.connect(closest as AnyDuringMigration);
645
- }
646
-
647
- // AnyDuringMigration because: Type 'RenderedConnection | null' is not
648
- // assignable to type 'RenderedConnection'.
649
- this.markerConnection_ = imConn as AnyDuringMigration;
650
- }
651
-
652
- /**
653
- * Disconnects and hides the current insertion marker. Should return the
654
- * blocks to their original state.
655
- */
656
- private hideInsertionMarker_() {
657
- if (!this.markerConnection_) {
658
- console.log('No insertion marker connection to disconnect');
659
- return;
660
- }
661
-
662
- const imConn = this.markerConnection_;
663
- const imBlock = imConn.getSourceBlock();
664
- const markerNext = imBlock.nextConnection;
665
- const markerPrev = imBlock.previousConnection;
666
- const markerOutput = imBlock.outputConnection;
667
-
668
- const isFirstInStatementStack =
669
- imConn === markerNext && !(markerPrev && markerPrev.targetConnection);
670
-
671
- const isFirstInOutputStack = imConn.type === ConnectionType.INPUT_VALUE &&
672
- !(markerOutput && markerOutput.targetConnection);
673
- // The insertion marker is the first block in a stack. Unplug won't do
674
- // anything in that case. Instead, unplug the following block.
675
- if (isFirstInStatementStack || isFirstInOutputStack) {
676
- imConn.targetBlock()!.unplug(false);
677
- } else if (
678
- imConn.type === ConnectionType.NEXT_STATEMENT &&
679
- imConn !== markerNext) {
680
- // Inside of a C-block, first statement connection.
681
- const innerConnection = imConn.targetConnection;
682
- if (innerConnection) {
683
- innerConnection.getSourceBlock().unplug(false);
684
- }
685
-
686
- const previousBlockNextConnection =
687
- markerPrev ? markerPrev.targetConnection : null;
688
-
689
- imBlock.unplug(true);
690
- if (previousBlockNextConnection) {
691
- // AnyDuringMigration because: Argument of type 'RenderedConnection' is
692
- // not assignable to parameter of type 'Connection'.
693
- previousBlockNextConnection.connect(
694
- innerConnection as AnyDuringMigration);
695
- }
696
- } else {
697
- imBlock.unplug(/* healStack */
698
- true);
699
- }
700
-
701
- if (imConn.targetConnection) {
702
- throw Error(
703
- 'markerConnection_ still connected at the end of ' +
704
- 'disconnectInsertionMarker');
705
- }
706
-
707
- // AnyDuringMigration because: Type 'null' is not assignable to type
708
- // 'RenderedConnection'.
709
- this.markerConnection_ = null as AnyDuringMigration;
710
- const svg = imBlock.getSvgRoot();
711
- if (svg) {
712
- svg.setAttribute('visibility', 'hidden');
713
- }
714
- }
715
-
716
- /** Shows an outline around the input the closest connection belongs to. */
717
- private showInsertionInputOutline_() {
718
- const closest = this.closestConnection_;
719
- this.highlightedBlock_ = closest.getSourceBlock();
720
- // AnyDuringMigration because: Argument of type 'RenderedConnection' is not
721
- // assignable to parameter of type 'Connection'.
722
- this.highlightedBlock_.highlightShapeForInput(
723
- closest as AnyDuringMigration, true);
724
- }
725
-
726
- /** Hides any visible input outlines. */
727
- private hideInsertionInputOutline_() {
728
- // AnyDuringMigration because: Argument of type 'RenderedConnection' is not
729
- // assignable to parameter of type 'Connection'.
730
- this.highlightedBlock_.highlightShapeForInput(
731
- this.closestConnection_ as AnyDuringMigration, false);
732
- // AnyDuringMigration because: Type 'null' is not assignable to type
733
- // 'BlockSvg'.
734
- this.highlightedBlock_ = null as AnyDuringMigration;
735
- }
736
-
737
- /**
738
- * Shows a replacement fade affect on the closest connection's target block
739
- * (the block that is currently connected to it).
740
- */
741
- private showReplacementFade_() {
742
- // AnyDuringMigration because: Type 'BlockSvg | null' is not assignable to
743
- // type 'BlockSvg'.
744
- this.fadedBlock_ =
745
- this.closestConnection_.targetBlock() as AnyDuringMigration;
746
- this.fadedBlock_.fadeForReplacement(true);
747
- }
748
-
749
- /** Hides/Removes any visible fade affects. */
750
- private hideReplacementFade_() {
751
- this.fadedBlock_.fadeForReplacement(false);
752
- // AnyDuringMigration because: Type 'null' is not assignable to type
753
- // 'BlockSvg'.
754
- this.fadedBlock_ = null as AnyDuringMigration;
755
- }
756
-
757
- /**
758
- * Get a list of the insertion markers that currently exist. Drags have 0, 1,
759
- * or 2 insertion markers.
760
- * @return A possibly empty list of insertion marker blocks.
761
- * @internal
762
- */
763
- getInsertionMarkers(): BlockSvg[] {
764
- const result = [];
765
- if (this.firstMarker_) {
766
- result.push(this.firstMarker_);
767
- }
768
- if (this.lastMarker_) {
769
- result.push(this.lastMarker_);
770
- }
771
- return result;
772
- }
773
- }
774
-
775
- export namespace InsertionMarkerManager {
776
- /**
777
- * An enum describing different kinds of previews the InsertionMarkerManager
778
- * could display.
779
- */
780
- export enum PREVIEW_TYPE {
781
- INSERTION_MARKER = 0,
782
- INPUT_OUTLINE = 1,
783
- REPLACEMENT_FADE = 2,
784
- }
785
- }
786
-
787
- export type PreviewType = InsertionMarkerManager.PREVIEW_TYPE;
788
- export const PreviewType = InsertionMarkerManager.PREVIEW_TYPE;