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,450 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2019 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- /**
8
- * @fileoverview Methods for graphically rendering a block as SVG.
9
- */
10
-
11
- /**
12
- * Methods for graphically rendering a block as SVG.
13
- * @class
14
- */
15
- import * as goog from '../../../closure/goog/goog.js';
16
- goog.declareModuleId('Blockly.blockRendering.Drawer');
17
-
18
- import type {BlockSvg} from '../../block_svg.js';
19
- import * as svgPaths from '../../utils/svg_paths.js';
20
- import {Connection} from '../measurables/connection.js';
21
- import type {ExternalValueInput} from '../measurables/external_value_input.js';
22
- import type {Field} from '../measurables/field.js';
23
- import type {Icon} from '../measurables/icon.js';
24
- import type {InlineInput} from '../measurables/inline_input.js';
25
- import type {PreviousConnection} from '../measurables/previous_connection.js';
26
- import type {Row} from '../measurables/row.js';
27
- import {Types} from '../measurables/types.js';
28
-
29
- import type {ConstantProvider, Notch, PuzzleTab} from './constants.js';
30
- import * as debug from './debug.js';
31
- import type {RenderInfo} from './info.js';
32
-
33
-
34
- /**
35
- * An object that draws a block based on the given rendering information.
36
- * @alias Blockly.blockRendering.Drawer
37
- */
38
- export class Drawer {
39
- block_: AnyDuringMigration;
40
- info_: AnyDuringMigration;
41
- topLeft_: AnyDuringMigration;
42
- outlinePath_ = '';
43
- inlinePath_ = '';
44
- protected constants_: ConstantProvider;
45
-
46
- /**
47
- * @param block The block to render.
48
- * @param info An object containing all information needed to render this
49
- * block.
50
- * @internal
51
- */
52
- constructor(block: BlockSvg, info: RenderInfo) {
53
- this.block_ = block;
54
- this.info_ = info;
55
- this.topLeft_ = block.getRelativeToSurfaceXY();
56
-
57
- /** The renderer's constant provider. */
58
- this.constants_ = info.getRenderer().getConstants();
59
- }
60
-
61
- /**
62
- * Draw the block to the workspace. Here "drawing" means setting SVG path
63
- * elements and moving fields, icons, and connections on the screen.
64
- *
65
- * The pieces of the paths are pushed into arrays of "steps", which are then
66
- * joined with spaces and set directly on the block. This guarantees that
67
- * the steps are separated by spaces for improved readability, but isn't
68
- * required.
69
- * @internal
70
- */
71
- draw() {
72
- this.hideHiddenIcons_();
73
- this.drawOutline_();
74
- this.drawInternals_();
75
-
76
- this.block_.pathObject.setPath(this.outlinePath_ + '\n' + this.inlinePath_);
77
- if (this.info_.RTL) {
78
- this.block_.pathObject.flipRTL();
79
- }
80
- if (debug.isDebuggerEnabled()) {
81
- this.block_.renderingDebugger.drawDebug(this.block_, this.info_);
82
- }
83
- this.recordSizeOnBlock_();
84
- }
85
-
86
- /**
87
- * Save sizing information back to the block
88
- * Most of the rendering information can be thrown away at the end of the
89
- * render. Anything that needs to be kept around should be set in this
90
- * function.
91
- */
92
- protected recordSizeOnBlock_() {
93
- // This is used when the block is reporting its size to anyone else.
94
- // The dark path adds to the size of the block in both X and Y.
95
- this.block_.height = this.info_.height;
96
- this.block_.width = this.info_.widthWithChildren;
97
- }
98
-
99
- /** Hide icons that were marked as hidden. */
100
- protected hideHiddenIcons_() {
101
- for (let i = 0, iconInfo; iconInfo = this.info_.hiddenIcons[i]; i++) {
102
- iconInfo.icon.iconGroup_.setAttribute('display', 'none');
103
- }
104
- }
105
-
106
- /** Create the outline of the block. This is a single continuous path. */
107
- protected drawOutline_() {
108
- this.drawTop_();
109
- for (let r = 1; r < this.info_.rows.length - 1; r++) {
110
- const row = this.info_.rows[r];
111
- if (row.hasJaggedEdge) {
112
- this.drawJaggedEdge_(row);
113
- } else if (row.hasStatement) {
114
- this.drawStatementInput_(row);
115
- } else if (row.hasExternalInput) {
116
- this.drawValueInput_(row);
117
- } else {
118
- this.drawRightSideRow_(row);
119
- }
120
- }
121
- this.drawBottom_();
122
- this.drawLeft_();
123
- }
124
-
125
- /**
126
- * Add steps for the top corner of the block, taking into account
127
- * details such as hats and rounded corners.
128
- */
129
- protected drawTop_() {
130
- const topRow = this.info_.topRow;
131
- const elements = topRow.elements;
132
-
133
- this.positionPreviousConnection_();
134
- this.outlinePath_ += svgPaths.moveBy(topRow.xPos, this.info_.startY);
135
- for (let i = 0, elem; elem = elements[i]; i++) {
136
- if (Types.isLeftRoundedCorner(elem)) {
137
- this.outlinePath_ += this.constants_.OUTSIDE_CORNERS.topLeft;
138
- } else if (Types.isRightRoundedCorner(elem)) {
139
- this.outlinePath_ += this.constants_.OUTSIDE_CORNERS.topRight;
140
- } else if (
141
- Types.isPreviousConnection(elem) && elem instanceof Connection) {
142
- this.outlinePath_ +=
143
- ((elem as PreviousConnection).shape as Notch).pathLeft;
144
- // AnyDuringMigration because: Property 'isHat' does not exist on type
145
- // 'typeof Types'.
146
- } else if ((Types as AnyDuringMigration).isHat(elem)) {
147
- this.outlinePath_ += this.constants_.START_HAT.path;
148
- } else if (Types.isSpacer(elem)) {
149
- this.outlinePath_ += svgPaths.lineOnAxis('h', elem.width);
150
- }
151
- }
152
- // No branch for a square corner, because it's a no-op.
153
- this.outlinePath_ += svgPaths.lineOnAxis('v', topRow.height);
154
- }
155
-
156
- /**
157
- * Add steps for the jagged edge of a row on a collapsed block.
158
- * @param row The row to draw the side of.
159
- */
160
- protected drawJaggedEdge_(row: Row) {
161
- const remainder = row.height - this.constants_.JAGGED_TEETH.height;
162
- this.outlinePath_ +=
163
- this.constants_.JAGGED_TEETH.path + svgPaths.lineOnAxis('v', remainder);
164
- }
165
-
166
- /**
167
- * Add steps for an external value input, rendered as a notch in the side
168
- * of the block.
169
- * @param row The row that this input belongs to.
170
- */
171
- protected drawValueInput_(row: Row) {
172
- const input = row.getLastInput() as ExternalValueInput | InlineInput;
173
- this.positionExternalValueConnection_(row);
174
-
175
- // AnyDuringMigration because: Property 'pathDown' does not exist on type
176
- // 'Shape'. AnyDuringMigration because: Property 'pathDown' does not exist
177
- // on type 'Shape'. AnyDuringMigration because: Property 'pathDown' does
178
- // not exist on type 'Shape'.
179
- const pathDown =
180
- typeof (input.shape as AnyDuringMigration).pathDown === 'function' ?
181
- ((input.shape as AnyDuringMigration).pathDown as (p1: number) =>
182
- AnyDuringMigration)(input.height) :
183
- (input.shape as AnyDuringMigration).pathDown;
184
-
185
- this.outlinePath_ += svgPaths.lineOnAxis('H', input.xPos + input.width) +
186
- pathDown +
187
- svgPaths.lineOnAxis('v', row.height - input.connectionHeight);
188
- }
189
-
190
- /**
191
- * Add steps for a statement input.
192
- * @param row The row that this input belongs to.
193
- */
194
- protected drawStatementInput_(row: Row) {
195
- const input = row.getLastInput();
196
- // Where to start drawing the notch, which is on the right side in LTR.
197
- const x = input.xPos + input.notchOffset + (input.shape as Notch).width;
198
-
199
- const innerTopLeftCorner = (input.shape as Notch).pathRight +
200
- svgPaths.lineOnAxis(
201
- 'h', -(input.notchOffset - this.constants_.INSIDE_CORNERS.width)) +
202
- this.constants_.INSIDE_CORNERS.pathTop;
203
-
204
- const innerHeight = row.height - 2 * this.constants_.INSIDE_CORNERS.height;
205
-
206
- this.outlinePath_ += svgPaths.lineOnAxis('H', x) + innerTopLeftCorner +
207
- svgPaths.lineOnAxis('v', innerHeight) +
208
- this.constants_.INSIDE_CORNERS.pathBottom +
209
- svgPaths.lineOnAxis('H', row.xPos + row.width);
210
-
211
- this.positionStatementInputConnection_(row);
212
- }
213
-
214
- /**
215
- * Add steps for the right side of a row that does not have value or
216
- * statement input connections.
217
- * @param row The row to draw the side of.
218
- */
219
- protected drawRightSideRow_(row: Row) {
220
- this.outlinePath_ += svgPaths.lineOnAxis('V', row.yPos + row.height);
221
- }
222
-
223
- /**
224
- * Add steps for the bottom edge of a block, possibly including a notch
225
- * for the next connection.
226
- */
227
- protected drawBottom_() {
228
- const bottomRow = this.info_.bottomRow;
229
- const elems = bottomRow.elements;
230
- this.positionNextConnection_();
231
-
232
- let rightCornerYOffset = 0;
233
- let outlinePath = '';
234
- for (let i = elems.length - 1, elem; elem = elems[i]; i--) {
235
- if (Types.isNextConnection(elem) && elem instanceof Connection) {
236
- outlinePath += (elem.shape as Notch).pathRight;
237
- } else if (Types.isLeftSquareCorner(elem)) {
238
- outlinePath += svgPaths.lineOnAxis('H', bottomRow.xPos);
239
- } else if (Types.isLeftRoundedCorner(elem)) {
240
- outlinePath += this.constants_.OUTSIDE_CORNERS.bottomLeft;
241
- } else if (Types.isRightRoundedCorner(elem)) {
242
- outlinePath += this.constants_.OUTSIDE_CORNERS.bottomRight;
243
- rightCornerYOffset = this.constants_.OUTSIDE_CORNERS.rightHeight;
244
- } else if (Types.isSpacer(elem)) {
245
- outlinePath += svgPaths.lineOnAxis('h', elem.width * -1);
246
- }
247
- }
248
-
249
- this.outlinePath_ +=
250
- svgPaths.lineOnAxis('V', bottomRow.baseline - rightCornerYOffset);
251
- this.outlinePath_ += outlinePath;
252
- }
253
-
254
- /**
255
- * Add steps for the left side of the block, which may include an output
256
- * connection
257
- */
258
- protected drawLeft_() {
259
- const outputConnection = this.info_.outputConnection;
260
- this.positionOutputConnection_();
261
-
262
- if (outputConnection) {
263
- const tabBottom =
264
- outputConnection.connectionOffsetY + outputConnection.height;
265
- const pathUp = typeof outputConnection.shape.pathUp === 'function' ?
266
- (outputConnection.shape.pathUp as (p1: number) =>
267
- AnyDuringMigration)(outputConnection.height) :
268
- outputConnection.shape.pathUp;
269
-
270
- // Draw a line up to the bottom of the tab.
271
- this.outlinePath_ += svgPaths.lineOnAxis('V', tabBottom) + pathUp;
272
- }
273
- // Close off the path. This draws a vertical line up to the start of the
274
- // block's path, which may be either a rounded or a sharp corner.
275
- this.outlinePath_ += 'z';
276
- }
277
-
278
- /**
279
- * Draw the internals of the block: inline inputs, fields, and icons. These
280
- * do not depend on the outer path for placement.
281
- */
282
- protected drawInternals_() {
283
- for (let i = 0, row; row = this.info_.rows[i]; i++) {
284
- for (let j = 0, elem; elem = row.elements[j]; j++) {
285
- if (Types.isInlineInput(elem)) {
286
- this.drawInlineInput_(elem as InlineInput);
287
- } else if (Types.isIcon(elem) || Types.isField(elem)) {
288
- this.layoutField_(elem as Field | Icon);
289
- }
290
- }
291
- }
292
- }
293
-
294
- /**
295
- * Push a field or icon's new position to its SVG root.
296
- * @param fieldInfo The rendering information for the field or icon.
297
- */
298
- protected layoutField_(fieldInfo: Icon|Field) {
299
- let svgGroup;
300
- if (Types.isField(fieldInfo)) {
301
- // AnyDuringMigration because: Property 'field' does not exist on type
302
- // 'Icon | Field'.
303
- svgGroup = (fieldInfo as AnyDuringMigration).field.getSvgRoot();
304
- } else if (Types.isIcon(fieldInfo)) {
305
- // AnyDuringMigration because: Property 'icon' does not exist on type
306
- // 'Icon | Field'.
307
- svgGroup = (fieldInfo as AnyDuringMigration).icon.iconGroup_;
308
- }
309
-
310
- const yPos = fieldInfo.centerline - fieldInfo.height / 2;
311
- let xPos = fieldInfo.xPos;
312
- let scale = '';
313
- if (this.info_.RTL) {
314
- xPos = -(xPos + fieldInfo.width);
315
- // AnyDuringMigration because: Property 'flipRtl' does not exist on type
316
- // 'Icon | Field'.
317
- if ((fieldInfo as AnyDuringMigration).flipRtl) {
318
- xPos += fieldInfo.width;
319
- scale = 'scale(-1 1)';
320
- }
321
- }
322
- if (Types.isIcon(fieldInfo)) {
323
- svgGroup.setAttribute('display', 'block');
324
- svgGroup.setAttribute(
325
- 'transform', 'translate(' + xPos + ',' + yPos + ')');
326
- // AnyDuringMigration because: Property 'icon' does not exist on type
327
- // 'Icon | Field'.
328
- (fieldInfo as AnyDuringMigration).icon.computeIconLocation();
329
- } else {
330
- svgGroup.setAttribute(
331
- 'transform', 'translate(' + xPos + ',' + yPos + ')' + scale);
332
- }
333
-
334
- if (this.info_.isInsertionMarker) {
335
- // Fields and icons are invisible on insertion marker. They still have to
336
- // be rendered so that the block can be sized correctly.
337
- svgGroup.setAttribute('display', 'none');
338
- }
339
- }
340
-
341
- /**
342
- * Add steps for an inline input.
343
- * @param input The information about the input to render.
344
- */
345
- protected drawInlineInput_(input: InlineInput) {
346
- const width = input.width;
347
- const height = input.height;
348
- const yPos = input.centerline - height / 2;
349
-
350
- const connectionTop = input.connectionOffsetY;
351
- const connectionBottom = input.connectionHeight + connectionTop;
352
- const connectionRight = input.xPos + input.connectionWidth;
353
-
354
- this.inlinePath_ += svgPaths.moveTo(connectionRight, yPos) +
355
- svgPaths.lineOnAxis('v', connectionTop) +
356
- (input.shape as PuzzleTab).pathDown +
357
- svgPaths.lineOnAxis('v', height - connectionBottom) +
358
- svgPaths.lineOnAxis('h', width - input.connectionWidth) +
359
- svgPaths.lineOnAxis('v', -height) + 'z';
360
-
361
- this.positionInlineInputConnection_(input);
362
- }
363
-
364
- /**
365
- * Position the connection on an inline value input, taking into account
366
- * RTL and the small gap between the parent block and child block which lets
367
- * the parent block's dark path show through.
368
- * @param input The information about the input that the connection is on.
369
- */
370
- protected positionInlineInputConnection_(input: InlineInput) {
371
- const yPos = input.centerline - input.height / 2;
372
- // Move the connection.
373
- if (input.connectionModel) {
374
- // xPos already contains info about startX
375
- let connX = input.xPos + input.connectionWidth + input.connectionOffsetX;
376
- if (this.info_.RTL) {
377
- connX *= -1;
378
- }
379
- input.connectionModel.setOffsetInBlock(
380
- connX, yPos + input.connectionOffsetY);
381
- }
382
- }
383
-
384
- /**
385
- * Position the connection on a statement input, taking into account
386
- * RTL and the small gap between the parent block and child block which lets
387
- * the parent block's dark path show through.
388
- * @param row The row that the connection is on.
389
- */
390
- protected positionStatementInputConnection_(row: Row) {
391
- const input = row.getLastInput();
392
- if (input.connectionModel) {
393
- let connX = row.xPos + row.statementEdge + input.notchOffset;
394
- if (this.info_.RTL) {
395
- connX *= -1;
396
- }
397
- input.connectionModel.setOffsetInBlock(connX, row.yPos);
398
- }
399
- }
400
-
401
- /**
402
- * Position the connection on an external value input, taking into account
403
- * RTL and the small gap between the parent block and child block which lets
404
- * the parent block's dark path show through.
405
- * @param row The row that the connection is on.
406
- */
407
- protected positionExternalValueConnection_(row: Row) {
408
- const input = row.getLastInput();
409
- if (input.connectionModel) {
410
- let connX = row.xPos + row.width;
411
- if (this.info_.RTL) {
412
- connX *= -1;
413
- }
414
- input.connectionModel.setOffsetInBlock(connX, row.yPos);
415
- }
416
- }
417
-
418
- /** Position the previous connection on a block. */
419
- protected positionPreviousConnection_() {
420
- const topRow = this.info_.topRow;
421
- if (topRow.connection) {
422
- const x = topRow.xPos + topRow.notchOffset;
423
- const connX = this.info_.RTL ? -x : x;
424
- topRow.connection.connectionModel.setOffsetInBlock(connX, 0);
425
- }
426
- }
427
-
428
- /** Position the next connection on a block. */
429
- protected positionNextConnection_() {
430
- const bottomRow = this.info_.bottomRow;
431
-
432
- if (bottomRow.connection) {
433
- const connInfo = bottomRow.connection;
434
- const x = connInfo.xPos; // Already contains info about startX.
435
- const connX = this.info_.RTL ? -x : x;
436
- connInfo.connectionModel.setOffsetInBlock(connX, bottomRow.baseline);
437
- }
438
- }
439
-
440
- /** Position the output connection on a block. */
441
- protected positionOutputConnection_() {
442
- if (this.info_.outputConnection) {
443
- const x =
444
- this.info_.startX + this.info_.outputConnection.connectionOffsetX;
445
- const connX = this.info_.RTL ? -x : x;
446
- this.block_.outputConnection.setOffsetInBlock(
447
- connX, this.info_.outputConnection.connectionOffsetY);
448
- }
449
- }
450
- }
@@ -1,161 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2019 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- /**
8
- * @fileoverview The interface for an object that owns a block's rendering SVG
9
- * elements.
10
- */
11
-
12
- /**
13
- * The interface for an object that owns a block's rendering SVG
14
- * elements.
15
- * @namespace Blockly.blockRendering.IPathObject
16
- */
17
- import * as goog from '../../../closure/goog/goog.js';
18
- goog.declareModuleId('Blockly.blockRendering.IPathObject');
19
-
20
- /* eslint-disable-next-line no-unused-vars */
21
- // Unused import preserved for side-effects. Remove if unneeded.
22
- // import '../../block_svg.js';
23
- /* eslint-disable-next-line no-unused-vars */
24
- // Unused import preserved for side-effects. Remove if unneeded.
25
- // import '../../connection.js';
26
- /* eslint-disable-next-line no-unused-vars */
27
- // Unused import preserved for side-effects. Remove if unneeded.
28
- // import '../../theme.js';
29
-
30
- import type {BlockStyle} from '../../theme.js';
31
-
32
- import type {ConstantProvider} from './constants.js';
33
-
34
-
35
- /**
36
- * An interface for a block's path object.
37
- * @param _root The root SVG element.
38
- * @param _constants The renderer's constants.
39
- * @alias Blockly.blockRendering.IPathObject
40
- */
41
- export interface IPathObject {
42
- /** The primary path of the block. */
43
- svgPath: SVGElement;
44
-
45
- /** The renderer's constant provider. */
46
- constants: ConstantProvider;
47
-
48
- /** The primary path of the block. */
49
- style: BlockStyle;
50
-
51
- /**
52
- * Holds the cursors SVG element when the cursor is attached to the block.
53
- * This is null if there is no cursor on the block.
54
- */
55
- cursorSvg: SVGElement;
56
-
57
- /**
58
- * Holds the markers SVG element when the marker is attached to the block.
59
- * This is null if there is no marker on the block.
60
- */
61
- markerSvg: SVGElement;
62
-
63
- /**
64
- * Set the path generated by the renderer onto the respective SVG element.
65
- * @param pathString The path.
66
- * @internal
67
- */
68
- setPath: AnyDuringMigration;
69
-
70
- /**
71
- * Apply the stored colours to the block's path, taking into account whether
72
- * the paths belong to a shadow block.
73
- * @param block The source block.
74
- * @internal
75
- */
76
- applyColour: AnyDuringMigration;
77
-
78
- /**
79
- * Update the style.
80
- * @param blockStyle The block style to use.
81
- * @internal
82
- */
83
- setStyle: AnyDuringMigration;
84
-
85
- /**
86
- * Flip the SVG paths in RTL.
87
- * @internal
88
- */
89
- flipRTL: () => void;
90
-
91
- /**
92
- * Add the cursor SVG to this block's SVG group.
93
- * @param cursorSvg The SVG root of the cursor to be added to the block SVG
94
- * group.
95
- * @internal
96
- */
97
- setCursorSvg: AnyDuringMigration;
98
-
99
- /**
100
- * Add the marker SVG to this block's SVG group.
101
- * @param markerSvg The SVG root of the marker to be added to the block SVG
102
- * group.
103
- * @internal
104
- */
105
- setMarkerSvg: AnyDuringMigration;
106
-
107
- /**
108
- * Set whether the block shows a highlight or not. Block highlighting is
109
- * often used to visually mark blocks currently being executed.
110
- * @param highlighted True if highlighted.
111
- * @internal
112
- */
113
- updateHighlighted: AnyDuringMigration;
114
-
115
- /**
116
- * Add or remove styling showing that a block is selected.
117
- * @param enable True if selection is enabled, false otherwise.
118
- * @internal
119
- */
120
- updateSelected: AnyDuringMigration;
121
-
122
- /**
123
- * Add or remove styling showing that a block is dragged over a delete area.
124
- * @param enable True if the block is being dragged over a delete area, false
125
- * otherwise.
126
- * @internal
127
- */
128
- updateDraggingDelete: AnyDuringMigration;
129
-
130
- /**
131
- * Add or remove styling showing that a block is an insertion marker.
132
- * @param enable True if the block is an insertion marker, false otherwise.
133
- * @internal
134
- */
135
- updateInsertionMarker: AnyDuringMigration;
136
-
137
- /**
138
- * Add or remove styling showing that a block is movable.
139
- * @param enable True if the block is movable, false otherwise.
140
- * @internal
141
- */
142
- updateMovable: AnyDuringMigration;
143
-
144
- /**
145
- * Add or remove styling that shows that if the dragging block is dropped,
146
- * this block will be replaced. If a shadow block, it will disappear.
147
- * Otherwise it will bump.
148
- * @param enable True if styling should be added.
149
- * @internal
150
- */
151
- updateReplacementFade: AnyDuringMigration;
152
-
153
- /**
154
- * Add or remove styling that shows that if the dragging block is dropped,
155
- * this block will be connected to the input.
156
- * @param conn The connection on the input to highlight.
157
- * @param enable True if styling should be added.
158
- * @internal
159
- */
160
- updateShapeForInputHighlight: AnyDuringMigration;
161
- }