Export in React Diagram Component

21 Oct 202524 minutes to read

The React Diagram component provides comprehensive support for exporting diagram content as image files (JPG, PNG) or vector graphics (SVG). This functionality enables users to save diagrams for documentation, presentations, or further processing. The exportDiagram method serves as the primary interface for all export operations.

Note: To export diagrams, inject PrintAndExport in the diagram component.

Basic Export Example

The following code demonstrates a simple diagram export operation:

function App() {
  let diagramInstance;

  let options = {};
  options.mode = 'Download';
  diagramInstance.exportDiagram(options);

  return (
    < DiagramComponent 
      id="container" 
      width={'1500'} 
      height={'1500'}
      ref={(diagram) => (diagramInstance = diagram)}
    > </DiagramComponent>
  );
}
const root = ReactDOM.createRoot(document.getElementById('diagram'));
root.render(<App />);

To export the React Diagram elements in various formats, refer to below video link.

Export Configuration Options

The diagram component supports extensive customization through the exportOptions interface. The following table details all available configuration properties:

Name Type Description
bounds object Defines specific bounds for CustomBounds region export
region enum Specifies the diagram area to export (PageSettings, Content, or CustomBounds)
fileName string Sets the exported file name (default: “Diagram”)
format string Defines export format (JPG, PNG, or SVG)
mode string Controls export behavior (Download or Data)
margin object Adds spacing around the exported content
stretch enum Adjusts aspect ratio and image quality of exported content
multiplePage boolean Enables multi-page export for large diagrams
pageWidth number Sets page width for multi-page exports
pageHeight number Sets page height for multi-page exports
pageOrientation enum Controls page orientation (Portrait or Landscape)

File Name Configuration

FileName property specifies the name for downloaded files. When not specified, the default name Diagram is used.

Export Formats

The Format property determines the output file type. The component supports three formats with distinct characteristics:

  • JPG: Compressed format suitable for photographs and complex diagrams with many colors.
  • PNG: Lossless format ideal for diagrams with transparency or sharp edges.
  • SVG: Vector format that maintains quality at any scale and supports text selection.

The default export format is JPG. The following example shows format specification:

import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, PrintAndExport, SnapConstraints } from "@syncfusion/ej2-react-diagrams";

export default function App() {
    let diagramInstance;
    let exportFormatInstance;

    // Initialize Nodes for the diagram
    let nodes = [
        {
            id: 'node1',
            width: 100,
            height: 50,
            offsetX: 100,
            offsetY: 100,
            style: { strokeColor: '#868686', fill: '#d5f5d5' },
            annotations: [{ content: 'Node 1' }],
        },
        {
            id: 'node2',
            width: 100,
            height: 75,
            offsetX: 100,
            offsetY: 225,
            shape: { type: 'Basic', shape: 'Diamond' },
            style: { strokeColor: '#8f908f', fill: '#e2f3fa' },
            annotations: [{ content: 'Node 2' }],
        }
    ];

    //Function to export the diagram objects.
    function handleExport() {
        let exportOptions = {}
        //Sets the export format
        exportOptions.format = exportFormatInstance.value;
        exportOptions.fileName = 'Export';
        diagramInstance.exportDiagram(exportOptions);
    };

    return (
        // Initialize Diagram component
        <div>
            <label>Export as </label>
            <select id="exportFormat" onChange={handleExport} ref={(exportFormat) => (exportFormatInstance = exportFormat)}>
                <option value="PNG">PNG</option>
                <option value="JPG">JPG</option>
                <option value="SVG">SVG</option>
            </select>
            <DiagramComponent
                id="container"
                ref={(diagram) => (diagramInstance = diagram)}
                width={'100%'}
                height={'600px'}
                nodes={nodes}
                snapSettings={{ constraints: SnapConstraints.None }}
            >
                <Inject services={[PrintAndExport]} />
            </DiagramComponent>
        </div>
    );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram"));
root.render(<App />);
import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, IExportOptions, NodeModel, FileFormats,
  PrintAndExport, SnapConstraints } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance: DiagramComponent;
  let exportFormatInstance: HTMLSelectElement;

  // Initialize Nodes for the diagram
  let nodes: NodeModel[] = [
    {
      id: 'node1',
      width: 100,
      height: 50,
      offsetX: 100,
      offsetY: 100,
      style: { strokeColor: '#868686', fill: '#d5f5d5' },
      annotations: [{ content: 'Node 1' }],
    },
    {
      id: 'node2',
      width: 100,
      height: 75,
      offsetX: 100,
      offsetY: 225,
      shape: { type: 'Basic', shape: 'Diamond' },
      style: { strokeColor: '#8f908f', fill: '#e2f3fa' },
      annotations: [{ content: 'Node 2' }],
    }
  ];

  //Function to export the diagram objects.
  function handleExport() {
    let exportOptions: IExportOptions = {};
    //Sets the export format
    exportOptions.format = (exportFormatInstance.value) as FileFormats;
    exportOptions.fileName = 'Export';
    diagramInstance.exportDiagram(exportOptions);
  };

  return (
    // Initialize Diagram component
    <div>
      <label>Export as </label>
      <select id="exportFormat" onChange={handleExport} ref={(exportFormat: any) => (exportFormatInstance = exportFormat)}>
        <option value="PNG">PNG</option>
        <option value="JPG">JPG</option>
        <option value="SVG">SVG</option>
      </select>
      <DiagramComponent
        id="container"
        ref={(diagram: any) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
        snapSettings={{ constraints: SnapConstraints.None }}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram") as HTMLElement);
root.render(<App />);

Margin Configuration

The margin property adds whitespace around the exported diagram content. This spacing improves presentation and prevents content from appearing cramped.

import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, PrintAndExport, SnapConstraints } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance;

  // Initialize Nodes for the diagram
  let nodes = [
    {
      id: 'node1',
      width: 100,
      height: 50,
      offsetX: 100,
      offsetY: 100,
      style: { strokeColor: '#868686', fill: '#d5f5d5' },
      annotations: [{ content: 'Node 1' }],
    },
    {
      id: 'node2',
      width: 100,
      height: 75,
      offsetX: 100,
      offsetY: 225,
      shape: { type: 'Basic', shape: 'Diamond' },
      style: { strokeColor: '#8f908f', fill: '#e2f3fa' },
      annotations: [{ content: 'Node 2' }],
    }
  ];

  //Function to export the diagram objects.
  function handleExport() {
    let exportOptions = {}
    //Sets the margin for the exported image
    exportOptions.margin = { left: 100, top: 100, bottom: 100, right: 100 };
    diagramInstance.exportDiagram(exportOptions);
  };

  return (
    // Initialize Diagram component
    <div>
      <button id="export" onClick={handleExport}>Export Diagram</button>
      <DiagramComponent
        id="container"
        ref={(diagram) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
        snapSettings={{ constraints: SnapConstraints.None }}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram"));
root.render(<App />);
import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, IExportOptions, NodeModel,
  PrintAndExport, SnapConstraints } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance: DiagramComponent;

  // Initialize Nodes for the diagram
  let nodes: NodeModel[] = [
    {
      id: 'node1',
      width: 100,
      height: 50,
      offsetX: 100,
      offsetY: 100,
      style: { strokeColor: '#868686', fill: '#d5f5d5' },
      annotations: [{ content: 'Node 1' }],
    },
    {
      id: 'node2',
      width: 100,
      height: 75,
      offsetX: 100,
      offsetY: 225,
      shape: { type: 'Basic', shape: 'Diamond' },
      style: { strokeColor: '#8f908f', fill: '#e2f3fa' },
      annotations: [{ content: 'Node 2' }],
    }
  ];

  //Function to print the diagram objects.
  function handleExport() {
    let exportOptions: IExportOptions = {};
    //Sets the margin for the exported image
    exportOptions.margin = { left: 100, top: 100, bottom: 100, right: 100 };
    diagramInstance.exportDiagram(exportOptions);
  };

  return (
    // Initialize Diagram component
    <div>
      <button id="export" onClick={handleExport}>Export Diagram</button>
      <DiagramComponent
        id="container"
        ref={(diagram: any) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
        snapSettings={{ constraints: SnapConstraints.None }}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram") as HTMLElement);
root.render(<App />);

Export Modes

The mode property controls how the exported content is delivered:

  • Download: Automatically downloads the diagram as a file to the user’s device.
  • Data: Returns a base64 string representation for programmatic processing.

The Data mode is useful for applications that need to process or transmit the exported content programmatically:

The following code example demonstrates how to export the diagram as raw data.

function App() {
  let diagramInstance;

  let options = {};
  options.mode = 'Data';
  options.margin = { left: 10, right: 10, top: 10, bottom: 10};
  options.fileName = 'format';
  options.format = 'SVG';
  let base64data = diagramInstance.exportDiagram(options);

  return (
    < DiagramComponent 
      id="container" 
      width={'1500'} 
      height={'1500'}
      ref={(diagram) => (diagramInstance = diagram)}
    > </DiagramComponent>
  );
}
const root = ReactDOM.createRoot(document.getElementById('diagram'));
root.render(<App />);

Region-Based Export

Exporting particular region of diagram is possible by using the region property of the exportOptions. The available export regions are listed in the table below.

Region Description
PageSettings Exports based on the configured page dimensions and settings.
Content Exports only the visible diagram elements, excluding empty space.
CustomBounds Exports a user-defined rectangular area.

The following example demonstrates different region export options:

import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, Rect, PrintAndExport, SnapConstraints } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance;
  let regionInstance;

  // Initialize Nodes for the diagram
  let nodes = [
    {
      id: 'node1',
      width: 100,
      height: 50,
      offsetX: 100,
      offsetY: 100,
      style: { strokeColor: '#868686', fill: '#d5f5d5' },
      annotations: [{ content: 'Node 1' }],
    },
    {
      id: 'node2',
      width: 100,
      height: 75,
      offsetX: 100,
      offsetY: 225,
      shape: { type: 'Basic', shape: 'Diamond' },
      style: { strokeColor: '#8f908f', fill: '#e2f3fa' },
      annotations: [{ content: 'Node 2' }],
    },
  ];

  //Function to print the diagram objects.
  function handleExport() {
    let exportOptions = {};
    let region = regionInstance.value;
    //Sets the region for the exported image.
    exportOptions.region = region;
    if (region === 'CustomBounds') {
      exportOptions.bounds = new Rect(0, 0, 300, 300);
    } else if (region === 'Content') {
      diagramInstance.pageSettings = {};
    } else {
      diagramInstance.pageSettings = { width: 500, height: 500 };
    }
    diagramInstance.exportDiagram(exportOptions);
  };


  return (
    // Initialize Diagram component
    <div>
      <label>Region </label>
      <select id="region" ref={(region) => (regionInstance = region)}>
        <option value="Content">Content</option>
        <option value="PageSettings">PageSettings</option>
        <option value="CustomBounds">CustomBounds</option>
      </select>
      <button id="export" onClick={handleExport}>Export Diagram</button>
      <DiagramComponent
        id="container"
        ref={(diagram) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
        snapSettings={{ constraints: SnapConstraints.None }}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram"));
root.render(<App />);
import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, Rect, IExportOptions, DiagramRegions, NodeModel, PrintAndExport, SnapConstraints } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance: DiagramComponent;
  let regionInstance: HTMLSelectElement;

  // Initialize Nodes for the diagram
  let nodes: NodeModel[] = [
    {
      id: 'node1',
      width: 100,
      height: 50,
      offsetX: 100,
      offsetY: 100,
      style: { strokeColor: '#868686', fill: '#d5f5d5' },
      annotations: [{ content: 'Node 1' }],
    },
    {
      id: 'node2',
      width: 100,
      height: 75,
      offsetX: 100,
      offsetY: 225,
      shape: { type: 'Basic', shape: 'Diamond' },
      style: { strokeColor: '#8f908f', fill: '#e2f3fa' },
      annotations: [{ content: 'Node 2' }],
    },
  ];

  //Function to print the diagram objects.
  function handleExport() {
    let exportOptions: IExportOptions = {};
    let region = regionInstance.value;
    //Sets the region for the exported image.
    exportOptions.region = region as DiagramRegions;
    if (region === 'CustomBounds') {
      exportOptions.bounds = new Rect(0, 0, 300, 300);
    } else if (region === 'Content') {
      diagramInstance.pageSettings = {};
    } else {
      diagramInstance.pageSettings = { width: 500, height: 500 };
    }
    diagramInstance.exportDiagram(exportOptions);
  };


  return (
    // Initialize Diagram component
    <div>
      <label>Region </label>
      <select id="region" ref={(region: any) => (regionInstance = region)}>
        <option value="Content">Content</option>
        <option value="PageSettings">PageSettings</option>
        <option value="CustomBounds">CustomBounds</option>
      </select>
      <button id="export" onClick={handleExport}>Export Diagram</button>
      <DiagramComponent
        id="container"
        ref={(diagram: any) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
        snapSettings={{ constraints: SnapConstraints.None }}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram") as HTMLElement);
root.render(<App />);

Note: The bounds property of exportOptions should be defined to export the diagram with CustomBounds region.

Multi-Page Export

For large diagrams that exceed standard page dimensions, the multiplePage option enables export across multiple pages:

  • false (default): Export as a single image regardless of size
  • true: Split the diagram across multiple pages based on specified dimensions

The following example shows multi-page export configuration:

import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, PrintAndExport, SnapConstraints } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance;

  // Initialize Nodes for the diagram
  let nodes = [
    {
      id: 'node1',
      width: 100,
      height: 50,
      offsetX: 100,
      offsetY: 100,
      style: { strokeColor: '#868686', fill: '#d5f5d5' },
      annotations: [{ content: 'Node 1' }],
    },
    {
      id: 'node2',
      width: 100,
      height: 75,
      offsetX: 500,
      offsetY: 100,
      shape: { type: 'Basic', shape: 'Diamond' },
      style: { strokeColor: '#8f908f', fill: '#e2f3fa' },
      annotations: [{ content: 'Node 2' }],
    }
  ];

  //Function to export the diagram objects.
  function handleExport() {
    let exportOptions = {}
    //Sets the multiple page as true for the exported image
    exportOptions.multiplePage = true;
    exportOptions.region = 'PageSettings';
    diagramInstance.exportDiagram(exportOptions);
  };

  return (
    // Initialize Diagram component
    <div>
      <button id="export" onClick={handleExport}>Export Diagram</button>
      <DiagramComponent
        id="container"
        ref={(diagram) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
        snapSettings={{ constraints: SnapConstraints.None }}
        pageSettings={{
          width: 400,
          height: 300,
          showPageBreaks: true,
          multiplePage: true,
        }}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram"));
root.render(<App />);
import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, IExportOptions, NodeModel,
  PrintAndExport, SnapConstraints } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance: DiagramComponent;

  // Initialize Nodes for the diagram
  let nodes: NodeModel[] = [
    {
      id: 'node1',
      width: 100,
      height: 50,
      offsetX: 100,
      offsetY: 100,
      style: { strokeColor: '#868686', fill: '#d5f5d5' },
      annotations: [{ content: 'Node 1' }],
    },
    {
      id: 'node2',
      width: 100,
      height: 75,
      offsetX: 500,
      offsetY: 100,
      shape: { type: 'Basic', shape: 'Diamond' },
      style: { strokeColor: '#8f908f', fill: '#e2f3fa' },
      annotations: [{ content: 'Node 2' }],
    }
  ];

  //Function to print the diagram objects.
  function handleExport() {
    let exportOptions: IExportOptions = {};
    //Sets the multiple page as true for the exported image
    exportOptions.multiplePage = true;
    exportOptions.region = 'PageSettings';
    diagramInstance.exportDiagram(exportOptions);
  };

  return (
    // Initialize Diagram component
    <div>
      <button id="export" onClick={handleExport}>Export Diagram</button>
      <DiagramComponent
        id="container"
        ref={(diagram: any) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
        snapSettings={{ constraints: SnapConstraints.None }}
        pageSettings={{
          width: 400,
          height: 300,
          showPageBreaks: true,
          multiplePage: true,
        }}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram") as HTMLElement);
root.render(<App />);

Direct Image Export

The exportImage method allows direct export of base64 image data without requiring a diagram instance. This method is useful for processing pre-existing image data.

import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, PrintAndExport, Rect } from "@syncfusion/ej2-react-diagrams";

export default function App() {
    let diagramInstance;

    let nodes = [];

    //Function to export the diagram objects.
    function handleExport() {
        let exportOptions = {};
        exportOptions.pageWidth = 1000;
        exportOptions.pageHeight = 800;
        exportOptions.bounds = new Rect(0, 0, 800, 800);
        //Base64 data
        let base64 =
            '';

        diagramInstance.exportImage(base64, exportOptions);
    };

    return (
        // Initialize Diagram component
        <div>
            <button id="export" onClick={handleExport}>Export Diagram</button>
            <DiagramComponent
                id="container"
                ref={(diagram) => (diagramInstance = diagram)}
                width={'100%'}
                height={'600px'}
                nodes={nodes}
            >
                <Inject services={[PrintAndExport]} />
            </DiagramComponent>
        </div>
    );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram"));
root.render(<App />);
import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, IExportOptions, NodeModel, Rect,
  PrintAndExport } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance: DiagramComponent;

  let nodes: NodeModel[] = [];

  //Function to print the diagram objects.
  function handleExport() {
    let exportOptions: IExportOptions = {};
    exportOptions.pageWidth = 1000;
    exportOptions.pageHeight = 800;
    exportOptions.bounds = new Rect(0, 0, 800, 800);
    //Base64 data
    let base64 =
      '';

    diagramInstance.exportImage(base64, exportOptions);

  };

  return (
    // Initialize Diagram component
    <div>
      <button id="export" onClick={handleExport}>Export Diagram</button>
      <DiagramComponent
        id="container"
        ref={(diagram: any) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram") as HTMLElement);
root.render(<App />);

Diagram Content Retrieval

The getDiagramContent method retrieves the HTML representation of the diagram at runtime. This functionality supports dynamic content analysis and processing.

import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, PrintAndExport } from "@syncfusion/ej2-react-diagrams";

export default function App() {
    let diagramInstance;

    // Initialize Nodes for the diagram
    let nodes = [
        {
            id: 'node1',
            width: 100,
            height: 100,
            annotations: [{ content: 'Node 1' }],
            offsetX: 200,
            offsetY: 100,
            style: {
                strokeColor: '#6BA5D7',
                fill: '#6BA5D7',
            },
        }
    ];

    //Function to export the diagram objects.
    function handleExport() {
        /**
         * parameter (Optional) -  defines the collection of style files to be considered while exporting.
         */
        let content = diagramInstance.getDiagramContent();
        console.log(content);
    };

    return (
        // Initialize Diagram component
        <div>
            <button id="export" onClick={handleExport}>Export Diagram</button>
            <DiagramComponent
                id="container"
                ref={(diagram) => (diagramInstance = diagram)}
                width={'100%'}
                height={'600px'}
                nodes={nodes}
            >
                <Inject services={[PrintAndExport]} />
            </DiagramComponent>
        </div>
    );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram"));
root.render(<App />);
import * as React from "react";
import * as ReactDOM from "react-dom";
import { DiagramComponent, Inject, NodeModel, PrintAndExport } from "@syncfusion/ej2-react-diagrams";

export default function App() {
  let diagramInstance: DiagramComponent;

  // Initialize Nodes for the diagram
  let nodes: NodeModel[] = [
    {
      id: 'node1',
      width: 100,
      height: 100,
      annotations: [{ content: 'Node 1' }],
      offsetX: 200,
      offsetY: 100,
      style: {
        strokeColor: '#6BA5D7',
        fill: '#6BA5D7',
      },
    }
  ];

  //Function to print the diagram objects.
  function handleExport() {
    /**
     * parameter (Optional) -  defines the collection of style files to be considered while exporting.
     */
    let content = diagramInstance.getDiagramContent();
    console.log(content);
  };

  return (
    // Initialize Diagram component
    <div>
      <button id="export" onClick={handleExport}>Export Diagram</button>
      <DiagramComponent
        id="container"
        ref={(diagram: any) => (diagramInstance = diagram)}
        width={'100%'}
        height={'600px'}
        nodes={nodes}
      >
        <Inject services={[PrintAndExport]} />
      </DiagramComponent>
    </div>
  );
};

// Render the App component into the 'diagram' element in the DOM
const root = ReactDOM.createRoot(document.getElementById("diagram") as HTMLElement);
root.render(<App />);

Stretch Option for Enhanced Quality

The stretch property improves exported image quality by adjusting the aspect ratio. Images exported with stretch enabled are clearer but result in larger file sizes.

The following code example illustrates how to export the region occupied by the diagram elements.

function App() {
  let diagramInstance;

  let options = {};
  options.mode = 'Download';
  options.margin = { left: 10, right: 10, top: 10, bottom: 10};
  options.fileName = 'format';
  options.format = 'SVG';
  options.region = 'Content';
  options.stretch = 'Stretch';
  diagramInstance.exportDiagram(options);

  return (
    < DiagramComponent 
      id="container" 
      width={'1500'} 
      height={'1500'}
      ref={(diagram) => (diagramInstance = diagram)}
    > </DiagramComponent>
  );
}
const root = ReactDOM.createRoot(document.getElementById('diagram'));
root.render(<App />);

Export Limitations

Currently, exporting diagram into image format with native and HTML nodes is not supported. To overcome this limitation, we make use of the Syncfusion® Essential® PDF library. This library incorporates the Syncfusion® Essential® HTML converter, which employs the advanced Blink rendering engine. This converter seamlessly transforms HTML content into images. Refer to export Html-and-Native node kb for more information.