Inject extra JavaScript while exporting

You can add a custom JavaScript file while exporting using the --callbackFilePath option. You can also use this option if you want to change the background style of the dashboard or resize the chart while exporting. To do this, you can use the CLI or SDKs of the languages mentioned below, using the commands given below:


    using System;
    using System.IO;
    using System.Linq;
    using FusionCharts.FusionExport.Client; // Import sdk

    namespace FusionExportTest {
        public static class InjectJsCallback {
            public static void Run(string host = Constants.DEFAULT_HOST, int port = Constants.DEFAULT_PORT) {
                // Instantiate the ExportConfig class and add the required configurations
                ExportConfig exportConfig = new ExportConfig();
                exportConfig.Set("chartConfig", File.ReadAllText("./resources/dashboard_charts.json"));
                exportConfig.Set("templateFilePath", "./resources/template.html");
                exportConfig.Set("callbackFilePath", "./resources/callback.js");

                // Instantiate the ExportManager class
                ExportManager em = new ExportManager(host: host, port: port);
                // Call the Export() method with the export config and the respective callbacks
                em.Export(exportConfig, OnExportDone, OnExportStateChanged);
            }

            // Called when export is done
            static void OnExportDone(ExportEvent ev, ExportException error) {
                if (error != null) {
                    Console.WriteLine("Error: " + error);
                } else {
                    var fileNames = ExportManager.GetExportedFileNames(ev.exportedFiles);
                    Console.WriteLine("Done: " + String.Join(", ", fileNames)); // export result
                }
            }

            // Called on each export state change
            static void OnExportStateChanged(ExportEvent ev) {
                Console.WriteLine("State: " + ev.state.customMsg);
            }
        }
    }

    import com.fusioncharts.fusionexport.client.*; // import sdk

    public class ExportChart {
        public static void main(String[] args) throws Exception {

            String configPath = "fullPath/multiple.json";
            String templatePath = "fullPath/template.html";

            // Instantiate the ExportConfig class and add the required configurations
            ExportConfig config = new ExportConfig();
            config.set("chartConfig", configPath);
            config.set("templateFilePath", templatePath);
            config.set("callbackFilePath", "fullPath/callback.js");

            // Instantiate the ExportManager class
            ExportManager manager = new ExportManager(config);
            // Call the export() method with the export config and the respective callbacks
            manager.export(new ExportDoneListener() {
                    @Override
                    public void exportDone(ExportDoneData result, ExportException error) {
                        if (error != null) {
                            System.out.println(error.getMessage());
                        } else {
                            ExportManager.saveExportedFiles("fullPath", result);
                        }
                    }
                },
                new ExportStateChangedListener() {
                    @Override
                    public void exportStateChanged(ExportState state) {
                        System.out.println("STATE: " + state.reporter);
                    }
                });
        }
    }

    <?php
    // Injecting custom JavaScript while exporting
    require DIR . '/../vendor/autoload.php';
    // Use the sdk
    use FusionExport\ExportManager;
    use FusionExport\ExportConfig;
    // Instantiate the ExportConfig class and add the required configurations
    $exportConfig = new ExportConfig();
    $exportConfig->set('chartConfig', realpath('resources/multiple.json'));
    $exportConfig->set('templateFilePath', realpath('resources/template.html'));
    $exportConfig->set('callbackFilePath', realpath('resources/callback.js'));
    // Called on each export state change
    $onStateChange = function ($event) {
        $state = $event->state;
        echo('STATE: [' . $state->reporter . '] ' . $state->customMsg . "\n");
    };
    // Called when export is done
    $onDone = function ($event, $e) {
        $export = $event->export;
        if ($e) {
            echo('ERROR: ' . $e->getMessage());
        } else {
            foreach ($export as $file) {
                echo('DONE: ' . $file->realName. "\n");
            }
            ExportManager::saveExportedFiles($export);
        }
    };
    // Instantiate the ExportManager class
    $exportManager = new ExportManager();
    // Call the export() method with the export config and the respective callbacks
    $exportManager->export($exportConfig, $onDone, $onStateChange);

    // Injecting custom JavaScript while exporting

    const path = require('path');

    // Require FusionExport
    const { ExportManager, ExportConfig } = require('../');

    // Instantiate ExportManager
    const exportManager = new ExportManager();

    // Instantiate ExportConfig and add the required configurations
    const exportConfig = new ExportConfig();

    exportConfig.set('chartConfig', path.join(dirname, 'resources', 'multiple.json'));
    exportConfig.set('templateFilePath', path.join(dirname, 'resources', 'template.html'));
    exportConfig.set('callbackFilePath', path.join(__dirname, 'resources', 'callback.js'));

    // provide the export config
    exportManager.export(exportConfig);

    // Called when export is done
    exportManager.on('exportDone', (outputFileBag) => {
      outputFileBag.forEach((op) => {
        console.log(DONE: ${op.realName});
      });

      ExportManager.saveExportedFiles(outputFileBag);
    });

    // Called on each export state change
    exportManager.on('exportStateChange', (state) => {
      console.log([${state.reporter}] ${state.customMsg});
    });

    // Called on erroe
    exportManager.on('error', (err) => {
      console.error(err);
    });

    #!/usr/bin/env python

    from fusionexport import ExportManager, ExportConfig  # Import sdk

    def read_file(file_path):
        try:
            with open(file_path, "r") as f:
                return f.read()
        except Exception as e:
            print(e)


    # Called when export is done
    def on_export_done(event, error):
        if error:
            print(error)
        else:
            ExportManager.save_exported_files("exported_images", event["result"])


    # Called on each export state change
    def on_export_state_changed(event):
        print(event["state"])


    # Instantiate the ExportConfig class and add the required configurations
    export_config = ExportConfig()
    export_config["chartConfig"] = read_file("dashboard_charts.json")
    export_config["templateFilePath"] = "template.html"
    export_config["callbackFilePath"] = "callback.js"

    # Provide port and host of FusionExport Service
    export_server_host = "127.0.0.1"
    export_server_port = 1337

    # Instantiate the ExportManager class
    em = ExportManager(export_server_host, export_server_port)
    # Call the export() method with the export config and the respective callbacks
    em.export(export_config, on_export_done, on_export_state_changed)
Was this article helpful to you ?