/**
 * @license
 * Copyright 2018 Google LLC
 * SPDX-License-Identifier: Apache-2.0
 */
/**
 * Class for a block delete 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
 * deleted.
 */
export declare class BlockDelete extends BlockBase {
    /** The XML representation of the deleted block(s). */
    oldXml?: Element | DocumentFragment;
    /** The JSON respresentation of the deleted block(s). */
    oldJson?: blocks.State;
    /** All of the IDs of deleted blocks. */
    ids?: string[];
    /** True if the deleted block was a shadow block, false otherwise. */
    wasShadow?: boolean;
    type: EventType;
    /** @param opt_block The deleted block.  Undefined for a blank event. */
    constructor(opt_block?: Block);
    /**
     * Encode the event as JSON.
     *
     * @returns JSON representation.
     */
    toJson(): BlockDeleteJson;
    /**
     * Deserializes the JSON event.
     *
     * @param event The event to append new properties to. Should be a subclass
     *     of BlockDelete, 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: BlockDeleteJson, workspace: Workspace, event?: any): BlockDelete;
    /**
     * Run a deletion event.
     *
     * @param forward True if run forward, false if run backward (undo).
     */
    run(forward: boolean): void;
}
export interface BlockDeleteJson extends BlockBaseJson {
    oldXml: string;
    ids: string[];
    wasShadow: boolean;
    oldJson: blocks.State;
    recordUndo?: boolean;
}
//# sourceMappingURL=events_block_delete.d.ts.map