Export in Vue Diagram component

14 Dec 202424 minutes to read

Diagram provides support to export its content as image/svg files. The exportDiagram method of diagrams helps to export the diagram. The following code illustrates how to export the diagram as image.

NOTE

To use Print and Export, you need to inject PrintAndExport in the diagram.

export default {
    name: 'app'
    data() {
        return {
            width: "100%",
            height: "350px",
        }
    },
    methods: {
        // Function to handle the export button click
        exportItems() {
            const exportOptions = {};
            exportOptions.mode = 'Download';
            diagramInstance.exportDiagram(exportOptions);
        },
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    }
}

Exporting options

The diagram provides support to export the desired region of the diagram to various formats. The following table shows the list of exportOptions in diagram.

Name Type Description
bounds object Sets the bounds that has to be exported
region enum Sets the region of the diagram to be exported.
fileName string Sets the file name of the exported image.
format string Sets the export image format.
mode string Sets the Mode for the file to be downloaded.
margin object Sets the margin of the page to be exported.
stretch enum Sets the aspect ratio of the exported image.
multiplePage boolean exports the diagram into multiple pages.
pageWidth number Sets the page width of the diagram while exporting the diagram into multiple pages.
pageHeight number Sets the page height of the diagram while exporting the diagram into multiple pages.
pageOrientation enum Sets the orientation of the page.

File Name

FileName is the name of the file to be downloaded. By default, the file name is set to Diagram.

Format

Format is to specify the type/format of the exported file. By default, the diagram is exported as .jpg format. You can export diagram to the following formats:

  • JPG
  • PNG
  • BMP
  • SVG
<template>
    <div id="app">

        <label for="format">Format: </label>
        <select id="format" ref="formatSelect">
            <option value="JPG">JPG</option>
            <option value="PNG">PNG</option>
            <option value="SVG">SVG</option>
        </select>

        <button v-on:click="exportItems">Export</button>
        <ejs-diagram id="diagram" ref="diagramObj" :width='width' :height='height' :nodes="nodes"
            :snapSettings="snapSettings"></ejs-diagram>

    </div>
</template>

<script setup>
import { provide, ref, onMounted } from "vue";
import { DiagramComponent as EjsDiagram, SnapConstraints, PrintAndExport } from '@syncfusion/ej2-vue-diagrams';

let diagramInstance;
let diagramObj = ref(null);
let formatSelect = ref(null);

//Initialize nodes
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' }],
    },
];

const width = "1000px";
const height = "590px";
const snapSettings = { constraints: SnapConstraints.None };

onMounted(function () {
    diagramInstance = diagramObj.value.ej2Instances;
})

// Function to handle the export button click
const exportItems = () => {
    const selectedFormat = formatSelect.value.value;
    // Set the export options based on the selected format
    const exportOptions = {
        format: selectedFormat,
        fileName: 'Export',
    };
    diagramInstance.exportDiagram(exportOptions);
};

provide('diagram', [PrintAndExport]);

</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>
<template>
    <div id="app">
        <label for="format">Format: </label>
        <select id="format" ref="formatSelect">
            <option value="JPG">JPG</option>
            <option value="PNG">PNG</option>
            <option value="SVG">SVG</option>
        </select>
        <button v-on:click="exportItems">Export</button>
        <ejs-diagram id="diagram" ref="diagramObj" :width="width" :height="height" :nodes="nodes"
            :snapSettings="snapSettings"></ejs-diagram>
    </div>
</template>

<script>
import { DiagramComponent, SnapConstraints, PrintAndExport } from '@syncfusion/ej2-vue-diagrams';

var diagramInstance;
var 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' }],
    },
];

export default {
    name: 'App',
    components: {
        'ejs-diagram': DiagramComponent,
    },
    data() {
        return {
            width: '1000px',
            height: '650px',
            nodes: nodes,
            snapSettings: { constraints: SnapConstraints.None }
        };
    },
    methods: {
        // Function to handle the export button click
        exportItems() {
            const selectedFormat = this.$refs.formatSelect.value;
            // Set the export options based on the selected format
            const exportOptions = {
                format: selectedFormat,
                fileName: 'Export',
            };
            diagramInstance.exportDiagram(exportOptions);
        },
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    },
    provide: { diagram: [PrintAndExport] },
};
</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>

Margin

Margin specifies the amount of space that has to be left around the diagram.

<template>
    <div id="app">
  
      <button v-on:click="exportItems">Export</button>
      <ejs-diagram id="diagram" ref="diagramObj" :width='width' :height='height' :nodes="nodes"
        :snapSettings="snapSettings"></ejs-diagram>
  
    </div>
  </template>
  
  <script setup>
  import { provide, ref, onMounted } from "vue";
  import { DiagramComponent as EjsDiagram, SnapConstraints, PrintAndExport } from '@syncfusion/ej2-vue-diagrams';
  
  let diagramInstance;
  let diagramObj = ref(null);
  
  
  //Initialize nodes
  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' }],
    },
  ];
  
  const width = "1000px";
  const height = "590px";
  const snapSettings = { constraints: SnapConstraints.None };
  
  onMounted(function () {
    diagramInstance = diagramObj.value.ej2Instances;
  })
  
  // Function to handle the export button click
  const exportItems = () => {
    const exportOptions = {};
    exportOptions.margin = { left: 100, top: 100, bottom: 100, right: 100 };
    diagramInstance.exportDiagram(exportOptions);
  };
  
  provide('diagram', [PrintAndExport]);
  
  </script>
  
  <style>
  @import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
  </style>
<template>
    <div id="app">
        <button v-on:click="exportItems">Export</button>
        <ejs-diagram id="diagram" ref="diagramObj" :width="width" :height="height" :nodes="nodes"
            :snapSettings="snapSettings"></ejs-diagram>
    </div>
</template>

<script>
import { DiagramComponent, SnapConstraints, PrintAndExport } from '@syncfusion/ej2-vue-diagrams';

var diagramInstance;
var 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' }],
    },
];

export default {
    name: 'App',
    components: {
        'ejs-diagram': DiagramComponent,
    },
    data() {
        return {
            width: '100%',
            height: '650px',
            nodes: nodes,
            snapSettings: { constraints: SnapConstraints.None }
        };
    },
    methods: {
        // Function to handle the export button click
        exportItems() {
            const exportOptions = {};
            exportOptions.margin = { left: 100, top: 100, bottom: 100, right: 100 };
            diagramInstance.exportDiagram(exportOptions);
        },
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    },
    provide: { diagram: [PrintAndExport] },
};
</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>

Mode

Mode specifies whether to export the diagram as an image or to return the base64 data of the diagram. The available export modes are:

  • Download: Exports and downloads the diagram as an image or SVG file.
  • Data: Returns a base64 string representation of the diagram.

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

export default {
    name: 'app'
    data() {
        return {
            width: "100%",
            height: "350px",
        }
    },
    methods: {
        // Function to handle the export button click
        exportItems() {
            const exportOptions = {};
            exportOptions.mode = 'Data';
            exportOptions.margin = { left: 10, right: 10, top: 10, bottom: 10 };
            exportOptions.fileName = 'format';
            exportOptions.format = 'SVG';
            let base64data = diagramInstance.exportDiagram(exportOptions);
        },
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    }
}

Region

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 The region to be exported will be based on the given page settings
Content Only the content of the diagram control will be exported
CustomBounds The region to be exported will be explicitly defined

The following example shows how to export diagram with different regions.

<template>
    <div id="app">
        <button @click="exportNodes">export</button>
        <label for="Region"> Region: </label>
        <select id="region" ref="regionSelect" v-on:change="exportItems">
            <option value="Content">Content</option>
            <option value="PageSettings">PageSettings</option>
            <option value="CustomBounds">Custom Bounds</option>
        </select>

        <ejs-diagram id="diagram" ref="diagramObj" :width='width' :height='height' :nodes="nodes"
            :snapSettings="snapSettings"></ejs-diagram>

    </div>
</template>

<script setup>
import { provide, ref, onMounted } from "vue";
import { DiagramComponent as EjsDiagram, SnapConstraints, PrintAndExport, Rect } from '@syncfusion/ej2-vue-diagrams';

let diagramInstance;
let diagramObj = ref(null);
let regionSelect = ref(null);


//Initialize nodes
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' }],
    },
];

const width = "1000px";
const height = "590px";
const snapSettings = { constraints: SnapConstraints.None };

onMounted(function () {
    diagramInstance = diagramObj.value.ej2Instances;
})

// Function to handle the export button click
const exportNodes = () => {
    const diagramInstance = diagram.value.ej2Instances;
    const exportOptions = {};
    exportOptions.region = regionSelect.value.value;
    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);
};

provide('diagram', [PrintAndExport]);

</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>
<template>
    <div id="app">
        <button @click="exportNodes">export</button>
        <label for="Region"> Region: </label>
        <select id="region" ref="regionSelect">
            <option value="Content">Content</option>
            <option value="PageSettings">PageSettings</option>
            <option value="CustomBounds">Custom Bounds</option>
        </select>
        <ejs-diagram id="diagram" ref="diagramObj" :width="width" :height="height" :nodes="nodes" :snapSettings="snapSettings"></ejs-diagram>
    </div>
</template>

<script>
import {
  DiagramComponent,
  SnapConstraints,
  PrintAndExport,
  Rect,
} from '@syncfusion/ej2-vue-diagrams';

var diagramInstance;
var 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' }],
    },
];

export default {
    name: 'App',
    components: {
        'ejs-diagram': DiagramComponent,
    },
    data() {
        return {
        width: '1000px',
        height: '650px',
        nodes: nodes,
        snapSettings: { constraints: SnapConstraints.None },
        };
    },
    methods: {
        // Function to handle the export button click
        exportNodes() {
            const exportOptions = {};
            exportOptions.region = this.$refs.regionSelect.value;
            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);
        },
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    },
    provide: { diagram: [PrintAndExport] },
};
</script>

<style>
@import '../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css';
</style>

NOTE

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

MultiplePage

When the multiplePage option is set to false, the diagram is exported as a single image. When it set to true, the diagram is exported as multiple images based on its width and height.

The following code example demonstrates how to export the diagram as multiple images.

<template>
    <div id="app">

        <button v-on:click="exportItems">Export</button>

        <ejs-diagram id="diagram" ref="diagramObj" :width='width' :height='height' :nodes="nodes"
            :snapSettings="snapSettings" :pageSettings="pageSettings"></ejs-diagram>

    </div>
</template>

<script setup>
import { provide, ref, onMounted } from "vue";
import { DiagramComponent as EjsDiagram, SnapConstraints, PrintAndExport } from '@syncfusion/ej2-vue-diagrams';

let diagramInstance;
let diagramObj = ref(null);

//Initialize nodes
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' }],
    },
];

const width = "1000px";
const height = "590px";
const snapSettings = { constraints: SnapConstraints.None };
const pageSettings = {
    width: 400,
    height: 300,
    showPageBreaks: true,
    multiplePage: true,
};
onMounted(function () {
    diagramInstance = diagramObj.value.ej2Instances;
})

// Function to handle the export button click
const exportItems = () => {
    const exportOptions = {};
    //Sets the multiple page as true for exporting image.
    exportOptions.multiplePage = true;
    exportOptions.region = 'PageSettings';
    diagramInstance.exportDiagram(exportOptions);
};

provide('diagram', [PrintAndExport]);

</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>
<template>
    <div id="app">
        <button v-on:click="exportItems">Export</button>
        <ejs-diagram id="diagram" ref="diagramObj" :width="width" :height="height" :nodes="nodes"
            :snapSettings="snapSettings" :pageSettings="pageSettings"></ejs-diagram>
    </div>
</template>

<script>
import {
    DiagramComponent,
    SnapConstraints,
    PrintAndExport,
} from '@syncfusion/ej2-vue-diagrams';

var diagramInstance;
var 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' }],
    },
];

export default {
    name: 'App',
    components: {
        'ejs-diagram': DiagramComponent,
    },
    data() {
        return {
            width: '1000px',
            height: '650px',
            nodes: nodes,
            snapSettings: { constraints: SnapConstraints.None },
            pageSettings: {
                width: 400,
                height: 300,
                showPageBreaks: true,
                multiplePage: true,
            },
        };
    },
    methods: {
        // Function to handle the export button click
        exportItems() {
            const exportOptions = {};
            //Sets the multiple page as true for exporting image.
            exportOptions.multiplePage = true;
            exportOptions.region = 'PageSettings';
            diagramInstance.exportDiagram(exportOptions);
        },
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    },
    provide: { diagram: [PrintAndExport] },
};
</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>

Export image

You can pass the base64 data of an image to the exportImage method to export it directly. The following example shows how to export base64 data using the exportImage method.

<template>
    <div id="app">

        <button v-on:click="exportItems">Export</button>

        <ejs-diagram id="diagram" ref="diagramObj" :width='width' :height='height'></ejs-diagram>

    </div>
</template>

<script setup>
import { provide, ref, onMounted } from "vue";
import { DiagramComponent as EjsDiagram, PrintAndExport, Rect } from '@syncfusion/ej2-vue-diagrams';

let diagramInstance;
let diagramObj = ref(null);

const width = "1000px";
const height = "590px";

onMounted(function () {
    diagramInstance = diagramObj.value.ej2Instances;
})

// Function to handle the export button click
const exportItems = () => {
    const exportOptions = {};
    //Base64 data
    const base64 =
        '';
    exportOptions.pageWidth = 1000;
    exportOptions.pageHeight = 800;
    exportOptions.bounds = new Rect(0, 0, 800, 800);
    diagramInstance.exportImage(base64, exportOptions);
}

provide('diagram', [PrintAndExport]);

</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>
<template>
    <div id="app">
        <button v-on:click="exportItems">Export</button>
        <ejs-diagram id="diagram" ref="diagramObj" :width="width" :height="height"></ejs-diagram>
    </div>
</template>

<script>
import { DiagramComponent, PrintAndExport, Rect } from '@syncfusion/ej2-vue-diagrams';

var diagramInstance;

export default {
    name: 'App',
    components: {
        'ejs-diagram': DiagramComponent,
    },
    data() {
        return {
            width: '100%',
            height: '650px',
        };
    },
    methods: {
        // Function to handle the export button click
        exportItems() {
            const exportOptions = {};
            //Base64 data
            const base64 =
                '';
            exportOptions.pageWidth = 1000;
            exportOptions.pageHeight = 800;
            exportOptions.bounds = new Rect(0, 0, 800, 800);
            diagramInstance.exportImage(base64, exportOptions);
        },
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    },
    provide: { diagram: [PrintAndExport] },
};
</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>

Get diagram content

To get the html diagram content, the getDiagramContent method is used. the following example shows how to get the diagram content at runtime.

<template>
    <div id="app">

        <button v-on:click="getDiagramContent">Export</button>

        <ejs-diagram id="diagram" ref="diagramObj" :width='width' :height='height' :nodes="nodes"></ejs-diagram>

    </div>
</template>

<script setup>
import { provide, ref, onMounted } from "vue";
import { DiagramComponent as EjsDiagram, PrintAndExport } from '@syncfusion/ej2-vue-diagrams';

let diagramInstance;
let diagramObj = ref(null);

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

const width = "1000px";
const height = "590px";

onMounted(function () {
    diagramInstance = diagramObj.value.ej2Instances;
})

// Function to handle the export button click
const getDiagramContent = () => {
    /**
     * parameter (Optional) -  defines the collection of style files to be considered while exporting.
     */
    const content = diagramInstance.getDiagramContent();
    console.log(content);
};

provide('diagram', [PrintAndExport]);

</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>
<template>
    <div id="app">
        <button v-on:click="getDiagramContent">Export</button>
        <ejs-diagram id="diagram" ref="diagramObj" :width="width" :height="height" :nodes="nodes"></ejs-diagram>
    </div>
</template>

<script>
import { DiagramComponent, PrintAndExport } from '@syncfusion/ej2-vue-diagrams';

var diagramInstance;
var nodes = [
    {
        id: 'node1',
        width: 100,
        height: 100,
        offsetX: 200,
        offsetY: 100,
        style: { strokeColor: '#6BA5D7', fill: '#6BA5D7' },
        annotations: [{ content: 'Node 1' }],
    },
];

export default {
    name: 'App',
    components: {
        'ejs-diagram': DiagramComponent,
    },
    data() {
        return {
            width: '100%',
            height: '650px',
            nodes: nodes,
        };
    },
    methods: {
        // Function to handle the export button click
        getDiagramContent() {
            /**
             * parameter (Optional) -  defines the collection of style files to be considered while exporting.
             */
            const content = diagramInstance.getDiagramContent();
            console.log(content);
        }
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    },
    provide: { diagram: [PrintAndExport] },
};
</script>

<style>
@import "../node_modules/@syncfusion/ej2-vue-diagrams/styles/material.css";
</style>

Export diagram with stretch option

Diagram provides support to export the diagram as image for stretch option. The exported images will be clearer but larger in file size.

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

export default {
    name: 'app'
    data() {
        return {
            width: "100%",
            height: "350px",
        }
    },
    methods: {
        // Function to handle the export button click
        exportItems() {
            const exportOptions = {};
            exportOptions.mode = 'Download';
            exportOptions.margin = { left: 10, right: 10, top: 10, bottom: 10 };
            exportOptions.fileName = 'region';
            exportOptions.format = 'SVG';
            exportOptions.region = 'Content';
            exportOptions.stretch = 'Stretch';
            diagramInstance.exportDiagram(exportOptions);
        },
    },
    mounted: function () {
        diagramInstance = this.$refs.diagramObj.ej2Instances;
    }
}

Limitations

Currently, printing diagram 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.