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,591 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2012 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
-
7
- /**
8
- * @fileoverview Text input field.
9
- */
10
-
11
- /**
12
- * Text input field.
13
- * @class
14
- */
15
- import * as goog from '../closure/goog/goog.js';
16
- goog.declareModuleId('Blockly.FieldTextInput');
17
-
18
- // Unused import preserved for side-effects. Remove if unneeded.
19
- import './events/events_block_change.js';
20
-
21
- import type {BlockSvg} from './block_svg.js';
22
- import * as browserEvents from './browser_events.js';
23
- import * as dialog from './dialog.js';
24
- import * as dropDownDiv from './dropdowndiv.js';
25
- import * as eventUtils from './events/utils.js';
26
- import {FieldConfig, Field} from './field.js';
27
- import * as fieldRegistry from './field_registry.js';
28
- import {Msg} from './msg.js';
29
- import * as aria from './utils/aria.js';
30
- import {Coordinate} from './utils/coordinate.js';
31
- import * as dom from './utils/dom.js';
32
- import {KeyCodes} from './utils/keycodes.js';
33
- import * as parsing from './utils/parsing.js';
34
- import type {Sentinel} from './utils/sentinel.js';
35
- import * as userAgent from './utils/useragent.js';
36
- import * as WidgetDiv from './widgetdiv.js';
37
- import type {WorkspaceSvg} from './workspace_svg.js';
38
-
39
-
40
- /**
41
- * Class for an editable text field.
42
- * @alias Blockly.FieldTextInput
43
- */
44
- export class FieldTextInput extends Field {
45
- /**
46
- * Pixel size of input border radius.
47
- * Should match blocklyText's border-radius in CSS.
48
- */
49
- static BORDERRADIUS = 4;
50
-
51
- /** Allow browser to spellcheck this field. */
52
- protected spellcheck_ = true;
53
-
54
- /** The HTML input element. */
55
- protected htmlInput_: HTMLInputElement|null = null;
56
-
57
- /** True if the field's value is currently being edited via the UI. */
58
- protected isBeingEdited_ = false;
59
-
60
- /**
61
- * True if the value currently displayed in the field's editory UI is valid.
62
- */
63
- protected isTextValid_ = false;
64
-
65
- /** Key down event data. */
66
- private onKeyDownWrapper_: browserEvents.Data|null = null;
67
-
68
- /** Key input event data. */
69
- private onKeyInputWrapper_: browserEvents.Data|null = null;
70
-
71
- /**
72
- * Whether the field should consider the whole parent block to be its click
73
- * target.
74
- */
75
- fullBlockClickTarget_: boolean|null = false;
76
-
77
- /** The workspace that this field belongs to. */
78
- protected workspace_: WorkspaceSvg|null = null;
79
-
80
- /**
81
- * Serializable fields are saved by the serializer, non-serializable fields
82
- * are not. Editable fields should also be serializable.
83
- */
84
- override SERIALIZABLE = true;
85
-
86
- /** Mouse cursor style when over the hotspot that initiates the editor. */
87
- override CURSOR = 'text';
88
- override clickTarget_: AnyDuringMigration;
89
- override value_: AnyDuringMigration;
90
- override isDirty_: AnyDuringMigration;
91
-
92
- /**
93
- * @param opt_value The initial value of the field. Should cast to a string.
94
- * Defaults to an empty string if null or undefined. Also accepts
95
- * Field.SKIP_SETUP if you wish to skip setup (only used by subclasses
96
- * that want to handle configuration and setting the field value after
97
- * their own constructors have run).
98
- * @param opt_validator A function that is called to validate changes to the
99
- * field's value. Takes in a string & returns a validated string, or null
100
- * to abort the change.
101
- * @param opt_config A map of options used to configure the field.
102
- * See the [field creation documentation]{@link
103
- * https://developers.google.com/blockly/guides/create-custom-blocks/fields/built-in-fields/text-input#creation}
104
- * for a list of properties this parameter supports.
105
- */
106
- constructor(
107
- opt_value?: string|Sentinel, opt_validator?: Function|null,
108
- opt_config?: FieldTextInputConfig) {
109
- super(Field.SKIP_SETUP);
110
-
111
- if (opt_value === Field.SKIP_SETUP) {
112
- return;
113
- }
114
- if (opt_config) {
115
- this.configure_(opt_config);
116
- }
117
- this.setValue(opt_value);
118
- if (opt_validator) {
119
- this.setValidator(opt_validator);
120
- }
121
- }
122
-
123
- protected override configure_(config: FieldTextInputConfig) {
124
- super.configure_(config);
125
- if (config.spellcheck !== undefined) {
126
- this.spellcheck_ = config.spellcheck;
127
- }
128
- }
129
-
130
- /** @internal */
131
- override initView() {
132
- if (this.getConstants()!.FULL_BLOCK_FIELDS) {
133
- // Step one: figure out if this is the only field on this block.
134
- // Rendering is quite different in that case.
135
- let nFields = 0;
136
- let nConnections = 0;
137
- // Count the number of fields, excluding text fields
138
- for (let i = 0, input; input = this.sourceBlock_.inputList[i]; i++) {
139
- for (let j = 0; input.fieldRow[j]; j++) {
140
- nFields++;
141
- }
142
- if (input.connection) {
143
- nConnections++;
144
- }
145
- }
146
- // The special case is when this is the only non-label field on the block
147
- // and it has an output but no inputs.
148
- this.fullBlockClickTarget_ =
149
- nFields <= 1 && this.sourceBlock_.outputConnection && !nConnections;
150
- } else {
151
- this.fullBlockClickTarget_ = false;
152
- }
153
-
154
- if (this.fullBlockClickTarget_) {
155
- this.clickTarget_ = (this.sourceBlock_ as BlockSvg).getSvgRoot();
156
- } else {
157
- this.createBorderRect_();
158
- }
159
- this.createTextElement_();
160
- }
161
-
162
- /**
163
- * Ensure that the input value casts to a valid string.
164
- * @param opt_newValue The input value.
165
- * @return A valid string, or null if invalid.
166
- */
167
- protected override doClassValidation_(opt_newValue?: AnyDuringMigration):
168
- AnyDuringMigration {
169
- if (opt_newValue === null || opt_newValue === undefined) {
170
- return null;
171
- }
172
- return String(opt_newValue);
173
- }
174
-
175
- /**
176
- * Called by setValue if the text input is not valid. If the field is
177
- * currently being edited it reverts value of the field to the previous
178
- * value while allowing the display text to be handled by the htmlInput_.
179
- * @param _invalidValue The input value that was determined to be invalid.
180
- * This is not used by the text input because its display value is stored
181
- * on the htmlInput_.
182
- */
183
- protected override doValueInvalid_(_invalidValue: AnyDuringMigration) {
184
- if (this.isBeingEdited_) {
185
- this.isTextValid_ = false;
186
- const oldValue = this.value_;
187
- // Revert value when the text becomes invalid.
188
- this.value_ = this.htmlInput_!.getAttribute('data-untyped-default-value');
189
- if (this.sourceBlock_ && eventUtils.isEnabled()) {
190
- eventUtils.fire(new (eventUtils.get(eventUtils.BLOCK_CHANGE))!
191
- (this.sourceBlock_, 'field', this.name || null,
192
- oldValue, this.value_));
193
- }
194
- }
195
- }
196
-
197
- /**
198
- * Called by setValue if the text input is valid. Updates the value of the
199
- * field, and updates the text of the field if it is not currently being
200
- * edited (i.e. handled by the htmlInput_).
201
- * @param newValue The value to be saved. The default validator guarantees
202
- * that this is a string.
203
- */
204
- protected override doValueUpdate_(newValue: AnyDuringMigration) {
205
- this.isTextValid_ = true;
206
- this.value_ = newValue;
207
- if (!this.isBeingEdited_) {
208
- // This should only occur if setValue is triggered programmatically.
209
- this.isDirty_ = true;
210
- }
211
- }
212
-
213
- /**
214
- * Updates text field to match the colour/style of the block.
215
- * @internal
216
- */
217
- override applyColour() {
218
- if (this.sourceBlock_ && this.getConstants()!.FULL_BLOCK_FIELDS) {
219
- if (this.borderRect_) {
220
- this.borderRect_.setAttribute(
221
- 'stroke', (this.sourceBlock_ as BlockSvg).style.colourTertiary);
222
- } else {
223
- (this.sourceBlock_ as BlockSvg)
224
- .pathObject.svgPath.setAttribute(
225
- 'fill', this.getConstants()!.FIELD_BORDER_RECT_COLOUR);
226
- }
227
- }
228
- }
229
-
230
- /**
231
- * Updates the colour of the htmlInput given the current validity of the
232
- * field's value.
233
- */
234
- protected override render_() {
235
- super.render_();
236
- // This logic is done in render_ rather than doValueInvalid_ or
237
- // doValueUpdate_ so that the code is more centralized.
238
- if (this.isBeingEdited_) {
239
- this.resizeEditor_();
240
- const htmlInput = this.htmlInput_ as HTMLElement;
241
- if (!this.isTextValid_) {
242
- dom.addClass(htmlInput, 'blocklyInvalidInput');
243
- aria.setState(htmlInput, aria.State.INVALID, true);
244
- } else {
245
- dom.removeClass(htmlInput, 'blocklyInvalidInput');
246
- aria.setState(htmlInput, aria.State.INVALID, false);
247
- }
248
- }
249
- }
250
-
251
- /**
252
- * Set whether this field is spellchecked by the browser.
253
- * @param check True if checked.
254
- */
255
- setSpellcheck(check: boolean) {
256
- if (check === this.spellcheck_) {
257
- return;
258
- }
259
- this.spellcheck_ = check;
260
- if (this.htmlInput_) {
261
- // AnyDuringMigration because: Argument of type 'boolean' is not
262
- // assignable to parameter of type 'string'.
263
- this.htmlInput_.setAttribute(
264
- 'spellcheck', this.spellcheck_ as AnyDuringMigration);
265
- }
266
- }
267
-
268
- /**
269
- * Show the inline free-text editor on top of the text.
270
- * @param _opt_e Optional mouse event that triggered the field to open, or
271
- * undefined if triggered programmatically.
272
- * @param opt_quietInput True if editor should be created without focus.
273
- * Defaults to false.
274
- */
275
- protected override showEditor_(_opt_e?: Event, opt_quietInput?: boolean) {
276
- this.workspace_ = (this.sourceBlock_ as BlockSvg).workspace;
277
- const quietInput = opt_quietInput || false;
278
- if (!quietInput &&
279
- (userAgent.MOBILE || userAgent.ANDROID || userAgent.IPAD)) {
280
- this.showPromptEditor_();
281
- } else {
282
- this.showInlineEditor_(quietInput);
283
- }
284
- }
285
-
286
- /**
287
- * Create and show a text input editor that is a prompt (usually a popup).
288
- * Mobile browsers have issues with in-line textareas (focus and keyboards).
289
- */
290
- private showPromptEditor_() {
291
- dialog.prompt(
292
- Msg['CHANGE_VALUE_TITLE'], this.getText(), (text: string|null) => {
293
- // Text is null if user pressed cancel button.
294
- if (text !== null) {
295
- this.setValue(this.getValueFromEditorText_(text));
296
- }
297
- });
298
- }
299
-
300
- /**
301
- * Create and show a text input editor that sits directly over the text input.
302
- * @param quietInput True if editor should be created without focus.
303
- */
304
- private showInlineEditor_(quietInput: boolean) {
305
- WidgetDiv.show(this, this.sourceBlock_.RTL, this.widgetDispose_.bind(this));
306
- this.htmlInput_ = this.widgetCreate_() as HTMLInputElement;
307
- this.isBeingEdited_ = true;
308
-
309
- if (!quietInput) {
310
- (this.htmlInput_ as HTMLElement).focus({
311
- preventScroll: true,
312
- });
313
- this.htmlInput_.select();
314
- }
315
- }
316
-
317
- /**
318
- * Create the text input editor widget.
319
- * @return The newly created text input editor.
320
- */
321
- protected widgetCreate_(): HTMLElement {
322
- eventUtils.setGroup(true);
323
- const div = WidgetDiv.getDiv();
324
-
325
- dom.addClass(this.getClickTarget_(), 'editing');
326
-
327
- const htmlInput = (document.createElement('input'));
328
- htmlInput.className = 'blocklyHtmlInput';
329
- // AnyDuringMigration because: Argument of type 'boolean' is not assignable
330
- // to parameter of type 'string'.
331
- htmlInput.setAttribute(
332
- 'spellcheck', this.spellcheck_ as AnyDuringMigration);
333
- const scale = this.workspace_!.getScale();
334
- const fontSize = this.getConstants()!.FIELD_TEXT_FONTSIZE * scale + 'pt';
335
- div!.style.fontSize = fontSize;
336
- htmlInput.style.fontSize = fontSize;
337
- let borderRadius = FieldTextInput.BORDERRADIUS * scale + 'px';
338
-
339
- if (this.fullBlockClickTarget_) {
340
- const bBox = this.getScaledBBox();
341
-
342
- // Override border radius.
343
- borderRadius = (bBox.bottom - bBox.top) / 2 + 'px';
344
- // Pull stroke colour from the existing shadow block
345
- const strokeColour = this.sourceBlock_.getParent() ?
346
- (this.sourceBlock_.getParent() as BlockSvg).style.colourTertiary :
347
- (this.sourceBlock_ as BlockSvg).style.colourTertiary;
348
- htmlInput.style.border = 1 * scale + 'px solid ' + strokeColour;
349
- div!.style.borderRadius = borderRadius;
350
- div!.style.transition = 'box-shadow 0.25s ease 0s';
351
- if (this.getConstants()!.FIELD_TEXTINPUT_BOX_SHADOW) {
352
- div!.style.boxShadow =
353
- 'rgba(255, 255, 255, 0.3) 0 0 0 ' + 4 * scale + 'px';
354
- }
355
- }
356
- htmlInput.style.borderRadius = borderRadius;
357
-
358
- div!.appendChild(htmlInput);
359
-
360
- htmlInput.value = htmlInput.defaultValue = this.getEditorText_(this.value_);
361
- htmlInput.setAttribute('data-untyped-default-value', this.value_);
362
- htmlInput.setAttribute('data-old-value', '');
363
-
364
- this.resizeEditor_();
365
-
366
- this.bindInputEvents_(htmlInput);
367
-
368
- return htmlInput;
369
- }
370
-
371
- /**
372
- * Closes the editor, saves the results, and disposes of any events or
373
- * DOM-references belonging to the editor.
374
- */
375
- protected widgetDispose_() {
376
- // Non-disposal related things that we do when the editor closes.
377
- this.isBeingEdited_ = false;
378
- this.isTextValid_ = true;
379
- // Make sure the field's node matches the field's internal value.
380
- this.forceRerender();
381
- this.onFinishEditing_(this.value_);
382
- eventUtils.setGroup(false);
383
-
384
- // Actual disposal.
385
- this.unbindInputEvents_();
386
- const style = WidgetDiv.getDiv()!.style;
387
- style.width = 'auto';
388
- style.height = 'auto';
389
- style.fontSize = '';
390
- style.transition = '';
391
- style.boxShadow = '';
392
- this.htmlInput_ = null;
393
-
394
- dom.removeClass(this.getClickTarget_(), 'editing');
395
- }
396
-
397
- /**
398
- * A callback triggered when the user is done editing the field via the UI.
399
- * @param _value The new value of the field.
400
- */
401
- onFinishEditing_(_value: AnyDuringMigration) {}
402
- // NOP by default.
403
- // TODO(#2496): Support people passing a func into the field.
404
-
405
- /**
406
- * Bind handlers for user input on the text input field's editor.
407
- * @param htmlInput The htmlInput to which event handlers will be bound.
408
- */
409
- protected bindInputEvents_(htmlInput: HTMLElement) {
410
- // Trap Enter without IME and Esc to hide.
411
- this.onKeyDownWrapper_ = browserEvents.conditionalBind(
412
- htmlInput, 'keydown', this, this.onHtmlInputKeyDown_);
413
- // Resize after every input change.
414
- this.onKeyInputWrapper_ = browserEvents.conditionalBind(
415
- htmlInput, 'input', this, this.onHtmlInputChange_);
416
- }
417
-
418
- /** Unbind handlers for user input and workspace size changes. */
419
- protected unbindInputEvents_() {
420
- if (this.onKeyDownWrapper_) {
421
- browserEvents.unbind(this.onKeyDownWrapper_);
422
- this.onKeyDownWrapper_ = null;
423
- }
424
- if (this.onKeyInputWrapper_) {
425
- browserEvents.unbind(this.onKeyInputWrapper_);
426
- this.onKeyInputWrapper_ = null;
427
- }
428
- }
429
-
430
- /**
431
- * Handle key down to the editor.
432
- * @param e Keyboard event.
433
- */
434
- protected onHtmlInputKeyDown_(e: Event) {
435
- // AnyDuringMigration because: Property 'keyCode' does not exist on type
436
- // 'Event'.
437
- if ((e as AnyDuringMigration).keyCode === KeyCodes.ENTER) {
438
- WidgetDiv.hide();
439
- dropDownDiv.hideWithoutAnimation();
440
- // AnyDuringMigration because: Property 'keyCode' does not exist on type
441
- // 'Event'.
442
- } else if ((e as AnyDuringMigration).keyCode === KeyCodes.ESC) {
443
- this.setValue(
444
- this.htmlInput_!.getAttribute('data-untyped-default-value'));
445
- WidgetDiv.hide();
446
- dropDownDiv.hideWithoutAnimation();
447
- // AnyDuringMigration because: Property 'keyCode' does not exist on type
448
- // 'Event'.
449
- } else if ((e as AnyDuringMigration).keyCode === KeyCodes.TAB) {
450
- WidgetDiv.hide();
451
- dropDownDiv.hideWithoutAnimation();
452
- // AnyDuringMigration because: Property 'shiftKey' does not exist on type
453
- // 'Event'. AnyDuringMigration because: Argument of type 'this' is not
454
- // assignable to parameter of type 'Field'.
455
- (this.sourceBlock_ as BlockSvg)
456
- .tab(this as AnyDuringMigration, !(e as AnyDuringMigration).shiftKey);
457
- e.preventDefault();
458
- }
459
- }
460
-
461
- /**
462
- * Handle a change to the editor.
463
- * @param _e Keyboard event.
464
- */
465
- private onHtmlInputChange_(_e: Event) {
466
- const text = this.htmlInput_!.value;
467
- if (text !== this.htmlInput_!.getAttribute('data-old-value')) {
468
- this.htmlInput_!.setAttribute('data-old-value', text);
469
-
470
- const value = this.getValueFromEditorText_(text);
471
- this.setValue(value);
472
- this.forceRerender();
473
- this.resizeEditor_();
474
- }
475
- }
476
-
477
- /**
478
- * Set the HTML input value and the field's internal value. The difference
479
- * between this and ``setValue`` is that this also updates the HTML input
480
- * value whilst editing.
481
- * @param newValue New value.
482
- */
483
- protected setEditorValue_(newValue: AnyDuringMigration) {
484
- this.isDirty_ = true;
485
- if (this.isBeingEdited_) {
486
- // In the case this method is passed an invalid value, we still
487
- // pass it through the transformation method `getEditorText` to deal
488
- // with. Otherwise, the internal field's state will be inconsistent
489
- // with what's shown to the user.
490
- this.htmlInput_!.value = this.getEditorText_(newValue);
491
- }
492
- this.setValue(newValue);
493
- }
494
-
495
- /** Resize the editor to fit the text. */
496
- protected resizeEditor_() {
497
- const div = WidgetDiv.getDiv();
498
- const bBox = this.getScaledBBox();
499
- div!.style.width = bBox.right - bBox.left + 'px';
500
- div!.style.height = bBox.bottom - bBox.top + 'px';
501
-
502
- // In RTL mode block fields and LTR input fields the left edge moves,
503
- // whereas the right edge is fixed. Reposition the editor.
504
- const x = this.sourceBlock_.RTL ? bBox.right - div!.offsetWidth : bBox.left;
505
- const xy = new Coordinate(x, bBox.top);
506
-
507
- div!.style.left = xy.x + 'px';
508
- div!.style.top = xy.y + 'px';
509
- }
510
-
511
- /**
512
- * Returns whether or not the field is tab navigable.
513
- * @return True if the field is tab navigable.
514
- */
515
- override isTabNavigable(): boolean {
516
- return true;
517
- }
518
-
519
- /**
520
- * Use the `getText_` developer hook to override the field's text
521
- * representation. When we're currently editing, return the current HTML value
522
- * instead. Otherwise, return null which tells the field to use the default
523
- * behaviour (which is a string cast of the field's value).
524
- * @return The HTML value if we're editing, otherwise null.
525
- */
526
- protected override getText_(): string|null {
527
- if (this.isBeingEdited_ && this.htmlInput_) {
528
- // We are currently editing, return the HTML input value instead.
529
- return this.htmlInput_.value;
530
- }
531
- return null;
532
- }
533
-
534
- /**
535
- * Transform the provided value into a text to show in the HTML input.
536
- * Override this method if the field's HTML input representation is different
537
- * than the field's value. This should be coupled with an override of
538
- * `getValueFromEditorText_`.
539
- * @param value The value stored in this field.
540
- * @return The text to show on the HTML input.
541
- */
542
- protected getEditorText_(value: AnyDuringMigration): string {
543
- return String(value);
544
- }
545
-
546
- /**
547
- * Transform the text received from the HTML input into a value to store
548
- * in this field.
549
- * Override this method if the field's HTML input representation is different
550
- * than the field's value. This should be coupled with an override of
551
- * `getEditorText_`.
552
- * @param text Text received from the HTML input.
553
- * @return The value to store.
554
- */
555
- protected getValueFromEditorText_(text: string): AnyDuringMigration {
556
- return text;
557
- }
558
-
559
- /**
560
- * Construct a FieldTextInput from a JSON arg object,
561
- * dereferencing any string table references.
562
- * @param options A JSON object with options (text, and spellcheck).
563
- * @return The new field instance.
564
- * @nocollapse
565
- * @internal
566
- */
567
- static fromJson(options: FieldTextInputFromJsonConfig): FieldTextInput {
568
- const text = parsing.replaceMessageReferences(options.text);
569
- // `this` might be a subclass of FieldTextInput if that class doesn't
570
- // override the static fromJson method.
571
- return new this(text, undefined, options);
572
- }
573
- }
574
-
575
- fieldRegistry.register('field_input', FieldTextInput);
576
-
577
- (FieldTextInput.prototype as AnyDuringMigration).DEFAULT_VALUE = '';
578
-
579
- /**
580
- * Config options for the text input field.
581
- */
582
- export interface FieldTextInputConfig extends FieldConfig {
583
- spellcheck?: boolean;
584
- }
585
-
586
- /**
587
- * fromJson config options for the text input field.
588
- */
589
- export interface FieldTextInputFromJsonConfig extends FieldTextInputConfig {
590
- text?: string;
591
- }