Send signature from signature pad Ionic


#1

I want to send my signature in an email but I don’t manage to do it

Here’s my code :

import { Component, ViewChild } from '@angular/core';
import { NavController} from 'ionic-angular';
import { SignaturePad } from 'angular2-signaturepad/signature-pad';
import { EmailComposer } from '@ionic-native/email-composer';

@Component({
  selector: 'page-envoie',
  templateUrl: 'envoie.html',
  providers: [SignaturePad, EmailComposer]
})
export class EnvoiePage {

  @ViewChild(SignaturePad) public signaturePad: SignaturePad;

  public signatureImage : string;
  public signaturePadOptions: Object = {
        'minWidth': 2,
        'canvasWidth': 340,
        'canvasHeight': 200 };

        public Cancel: string;

  constructor(public navCtrl: NavController, private emailComposer: EmailComposer){

    this.signatureImage = this.signaturePad.toDataURL();

    this.Cancel = this.signatureImage;

  }

   drawComplete() {

    this.signatureImage = this.signaturePad.toDataURL();
    this.emailComposer.open({
      to:      'lol@me.com',
      attachments: [this.signatureImage],
      subject: 'Avis de passage',
      body:    'test',
      isHtml: true
    });

  }

  drawClear() {
    this.signaturePad.clear();
  }

}

Can you help me? I’m lost, when I press the button, the email is opened there is my text but not the image

It’s the plugin signature pad and emailcomposer


#2

Where does your code go wrong? Do you even get the signature image? Is the variable set when you give it to emailComposter.open?


#3

I don’t know, my variable is :



I have followed a tuto, and I manage to duplicate the signature in another signature pad, so my “ToDataUrl” is working fine


#4

Extract the object out of this call and call console.log on it before you put it into open - if this looks good you know it is “just” an emailComposer problem.

Look at the docs of emailcomposer again, I think there was a way to check if it is available on your device.


#5

I need to call console.log on all the emailComposer.open ?

I just watched the doc and isAvailable is to check if there is a configured email account… So I don’t think it comes from here.

But on the emailComposer Github I saw this attachement : base64:icon.png//iVBORw0KGgoAAAANSUhEUgAA

Mine begin with ....


#6

You call it on the object, to see if the object looks good and has the correct data.


#7

Here is my object :


All is good, but it still start by “data:image…” Is it because of this?


#8

Tried with the same name, base64:icon.png//fegdfaez... but nothing


#9

Ok I found this on a forum

"We tested base64 files on android 5 and 4.1 and it worked. You just have to take care of files with the same name. Base64, Resource and Asset attachments are stored in the same folder now, so identically named files effect errors.
This issue will be fixed with the next major-release.

Take a look at the examplebranch for more information about how to attach files.

Please tell us whether that solved your problem or not.

Greatings Philipp"

I changed the name of the file and now it works… (And i’m gone to emailComposer 0.8.3)


#10

@Poseyyy… have you display your image on signature-pad ??


#11

I don’t understand your question


#12

i am displaying one image on signature-pad through camera and am drawing on it …after drawing i cancel the drawing on image . but not able to perform undo() operation.on image. I need solution for undo () operation in typescript…in ionic 3


#13

In order to clear your snignature pad it’s :

drawClear(){
    this.signaturePad.clear();
}

Or am I wrong and you want only undo the last line created?


#14

yes,I want only undo function …cancel is working for me


#15

I try using pop() operation but it undo the data of signauture-pad and not a data of image of signature-pad …that’s problem … i can share my code to you …can you give me your email id ??


#16

@umeshionic1234 - what does this have to do with the initial topic you hijacked for your question? Usually one creates a new topic and describes one’s problem instead of just posting below old questions that are only slightly related.

Also stop asking all the people responding to your questions for their email. This is a public forum with public topics for all to benefit from asking and answering.