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