/**
 * @license
 * Copyright 2020 Google LLC
 * SPDX-License-Identifier: Apache-2.0
 */
import type { BlockSvg } from '../block_svg.js';
import type { FlyoutItem } from '../flyout_item.js';
import type { Coordinate } from '../utils/coordinate.js';
import type { Svg } from '../utils/svg.js';
import type { FlyoutDefinition } from '../utils/toolbox.js';
import type { WorkspaceSvg } from '../workspace_svg.js';
import { IFocusableTree } from './i_focusable_tree.js';
import type { IRegistrable } from './i_registrable.js';
/**
 * Interface for a flyout.
 */
export interface IFlyout extends IRegistrable, IFocusableTree {
    /** Whether the flyout is laid out horizontally or not. */
    horizontalLayout: boolean;
    /** Is RTL vs LTR. */
    RTL: boolean;
    /** The target workspace */
    targetWorkspace: WorkspaceSvg | null;
    /** Margin around the edges of the blocks in the flyout. */
    readonly MARGIN: number;
    /** Does the flyout automatically close when a block is created? */
    autoClose: boolean;
    /** Corner radius of the flyout background. */
    readonly CORNER_RADIUS: number;
    /**
     * Creates the flyout's DOM.  Only needs to be called once.  The flyout can
     * either exist as its own svg element or be a g element nested inside a
     * separate svg element.
     *
     * @param tagName The type of tag to put the flyout in. This should be <svg>
     *     or <g>.
     * @returns The flyout's SVG group.
     */
    createDom(tagName: string | Svg<SVGSVGElement> | Svg<SVGGElement>): SVGElement;
    /**
     * Initializes the flyout.
     *
     * @param targetWorkspace The workspace in which to create new blocks.
     */
    init(targetWorkspace: WorkspaceSvg): void;
    /**
     * Dispose of this flyout.
     * Unlink from all DOM elements to prevent memory leaks.
     */
    dispose(): void;
    /**
     * Get the width of the flyout.
     *
     * @returns The width of the flyout.
     */
    getWidth(): number;
    /**
     * Get the height of the flyout.
     *
     * @returns The height of the flyout.
     */
    getHeight(): number;
    /**
     * Get the workspace inside the flyout.
     *
     * @returns The workspace inside the flyout.
     */
    getWorkspace(): WorkspaceSvg;
    /**
     * Is the flyout visible?
     *
     * @returns True if visible.
     */
    isVisible(): boolean;
    /**
     * Set whether the flyout is visible. A value of true does not necessarily
     * mean that the flyout is shown. It could be hidden because its container is
     * hidden.
     *
     * @param visible True if visible.
     */
    setVisible(visible: boolean): void;
    /**
     * Set whether this flyout's container is visible.
     *
     * @param visible Whether the container is visible.
     */
    setContainerVisible(visible: boolean): void;
    /** Hide and empty the flyout. */
    hide(): void;
    /**
     * Show and populate the flyout.
     *
     * @param flyoutDef Contents to display in the flyout. This is either an array
     *     of Nodes, a NodeList, a toolbox definition, or a string with the name
     *     of the dynamic category.
     */
    show(flyoutDef: FlyoutDefinition | string): void;
    /**
     * Returns the list of flyout items currently present in the flyout.
     * The `show` method parses the flyout definition into a list of actual
     * flyout items. This method should return those concrete items, which
     * may be used for e.g. keyboard navigation.
     *
     * @returns List of flyout items.
     */
    getContents(): FlyoutItem[];
    /**
     * Create a copy of this block on the workspace.
     *
     * @param originalBlock The block to copy from the flyout.
     * @returns The newly created block.
     * @throws {Error} if something went wrong with deserialization.
     */
    createBlock(originalBlock: BlockSvg): BlockSvg;
    /** Reflow blocks and their mats. */
    reflow(): void;
    /**
     * @returns True if this flyout may be scrolled with a scrollbar or by
     *     dragging.
     */
    isScrollable(): boolean;
    /**
     * Calculates the x coordinate for the flyout position.
     *
     * @returns X coordinate.
     */
    getX(): number;
    /**
     * Calculates the y coordinate for the flyout position.
     *
     * @returns Y coordinate.
     */
    getY(): number;
    /** Position the flyout. */
    position(): void;
    /**
     * Determine if a drag delta is toward the workspace, based on the position
     * and orientation of the flyout. This is used in determineDragIntention_ to
     * determine if a new block should be created or if the flyout should scroll.
     *
     * @param currentDragDeltaXY How far the pointer has moved from the position
     *     at mouse down, in pixel units.
     * @returns True if the drag is toward the workspace.
     */
    isDragTowardWorkspace(currentDragDeltaXY: Coordinate): boolean;
    /**
     * Does this flyout allow you to create a new instance of the given block?
     * Used for deciding if a block can be "dragged out of" the flyout.
     *
     * @param block The block to copy from the flyout.
     * @returns True if you can create a new instance of the block, false
     *     otherwise.
     */
    isBlockCreatable(block: BlockSvg): boolean;
    /** Scroll the flyout to the beginning of its contents. */
    scrollToStart(): void;
}
//# sourceMappingURL=i_flyout.d.ts.map