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