Unable import existing data in jSignature

2.5k views Asked by At

This is the code I'm saving my jSignature value in my database:

var datapair = $('.sign-wrapper').jSignature();
datapair.bind('change', function(e){
        var data = datapair.jSignature("getData", "svgbase64");
        var i = new Image()
        i.src = "data:" + data[0] + "," + data[1];

        $(this).prev('input').val(i.src);
});

So I'm having following value in my DB:



So while reloading the page I'm having the above base64 image data url in a hidden variable.

I tried to load the data to the existing signature canvas using below code:

// If value exist load existing
      var src = $(this).prev('input').val();
      if(src != '') {
        datapair.jSignature("importData", src);
      }

But it is not working and I am getting following error in console:

Uncaught Error: jSignature is unable to find import plugin with for format 'image/svg+xml;base64'

2

There are 2 answers

6
karthick On BEST ANSWER

The problem occurs when your data is not recognized by the plugin.

The reason why it throws an error is, the format 'image/svg+xml;base64' is not supported by the importer, there is only an exporter support for it.

Reference: https://github.com/brinley/jSignature#data-import--export-and-plugins

I suggest you store the data using base30 because there is support for both export and import.

var data = datapair.jSignature("getData", "base30 ");
0
Manu Burrero Sánchez On

setData takes two arguments - data object, data format name. When data object is a string formatted in data-url pattern you don't need to specify the data dormat name. The data format name (mime) will be implied from the data-url prefix. See example below for that. Returns (in a traditional jQuery chainable way) jQuery object ref to the element onto which the plugin was applied.

You can store the value in base64 and load it. I load the value in base64 in an input and through Jquery I load it in the object.

// Creo el objeto de firma.
$("#jq_sig").jSignature
({
    // width/height of signature pad
    width: 497,
    height: 200,
    // Format bootstrap 4
    cssclass: "bg-light border",
    lineWidth: 2,
    color: "black",
});

// I take the value of the form field that I previously loaded with PHP.
var firma = $('#form input[name=firma]').val();

if (firma.length > 0) 
{
    $("#jq_sig").jSignature("setData", 'data:image/png;base64,' + firma);                       
    console.log('Signature loaded.');
}
else
{
    console.log('Signature not loaded.');
}

You can save to your database in any format. Then you tell 'setdata' what kind of format it is.