/**
 * @license
 * Copyright 2018 Google LLC
 * SPDX-License-Identifier: Apache-2.0
 */
/**
 * Class for a block creation event.
 *
 * @class
 */
import type { Block } from '../block.js';
import * as blocks from '../serialization/blocks.js';
import { Workspace } from '../workspace.js';
import { BlockBase, BlockBaseJson } from './events_block_base.js';
import { EventType } from './type.js';
/**
 * Notifies listeners when a block (or connected stack of blocks) is
 * created.
 */
export declare class BlockCreate extends BlockBase {
    type: EventType;
    /** The XML representation of the created block(s). */
    xml?: Element | DocumentFragment;
    /** The JSON respresentation of the created block(s). */
    json?: blocks.State;
    /** All of the IDs of created blocks. */
    ids?: string[];
    /** @param opt_block The created block.  Undefined for a blank event. */
    constructor(opt_block?: Block);
    /**
     * Encode the event as JSON.
     *
     * @returns JSON representation.
     */
    toJson(): BlockCreateJson;
    /**
     * Deserializes the JSON event.
     *
     * @param event The event to append new properties to. Should be a subclass
     *     of BlockCreate, but we can't specify that due to the fact that
     *     parameters to static methods in subclasses must be supertypes of
     *     parameters to static methods in superclasses.
     * @internal
     */
    static fromJson(json: BlockCreateJson, workspace: Workspace, event?: any): BlockCreate;
    /**
     * Run a creation event.
     *
     * @param forward True if run forward, false if run backward (undo).
     */
    run(forward: boolean): void;
}
export interface BlockCreateJson extends BlockBaseJson {
    xml: string;
    ids: string[];
    json: object;
    recordUndo?: boolean;
}
//# sourceMappingURL=events_block_create.d.ts.map