From 81e3dd530d675be87d2aa39c72833c8214000eae Mon Sep 17 00:00:00 2001 From: Dmitry Date: Tue, 12 Nov 2024 11:41:24 +0400 Subject: [PATCH] Fix signature pad doesn't render sign image in some cases (#350) --- src/flat_layout/flat_signaturepad.ts | 5 ++++- tests/flat_signaturepad.test.ts | 30 ++++++++++++++++++++++++++++ 2 files changed, 34 insertions(+), 1 deletion(-) diff --git a/src/flat_layout/flat_signaturepad.ts b/src/flat_layout/flat_signaturepad.ts index bfe8600..5a17e97 100644 --- a/src/flat_layout/flat_signaturepad.ts +++ b/src/flat_layout/flat_signaturepad.ts @@ -19,12 +19,15 @@ export class FlatSignaturePad extends FlatQuestion { public async generateBackgroundImage(point: IPoint): Promise { return await SurveyHelper.createImageFlat(point, this.question, this.controller, { link: this.question.backgroundImage, width: SurveyHelper.pxToPt(this.question.signatureWidth), height: SurveyHelper.pxToPt(this.question.signatureHeight), objectFit: 'cover' }, true); } + private getSignImageUrl() { + return this.question.storeDataAsText || !this.question.loadedData ? this.question.value : this.question.loadedData; + } public async generateSign(point: IPoint): Promise { const width = SurveyHelper.pxToPt(this.question.signatureWidth); const height = SurveyHelper.pxToPt(this.question.signatureHeight); if(this.question.value) { return await SurveyHelper.createImageFlat(point, - this.question, this.controller, { link: this.question.storeDataAsText ? this.question.value : this.question.loadedData, + this.question, this.controller, { link: this.getSignImageUrl(), width: width, height: height }, false ); diff --git a/tests/flat_signaturepad.test.ts b/tests/flat_signaturepad.test.ts index 13ea6f8..6266d58 100644 --- a/tests/flat_signaturepad.test.ts +++ b/tests/flat_signaturepad.test.ts @@ -12,6 +12,7 @@ import { SurveyHelper } from '../src/helper_survey'; import { TestHelper } from '../src/helper_test'; import { CompositeBrick } from '../src/pdf_render/pdf_composite'; import { HTMLBrick } from '../src/pdf_render/pdf_html'; +import { QuestionSignaturePadModel } from 'survey-core'; let __dummy_sp = new FlatSignaturePad(null, null, null); const SIGNATURE_VALUE = ''; @@ -85,4 +86,33 @@ test('Check signaturepad with backgroundImage', async () => { TestHelper.equalRect(expect, htmlBrick, assumeHTML); TestHelper.equalRect(expect, backgroundImageBrick, assumeHTML); SurveyHelper.shouldConvertImageToPng = true; +}); + +test('Check signaturepad getSignImageUrl', async () => { + SurveyHelper.shouldConvertImageToPng = false; + let json: any = { + questions: [ + { + type: 'signaturepad', + name: 'signaturepad', + } + ] + }; + const survey: SurveyPDF = new SurveyPDF(json, TestHelper.defaultOptions); + const controller: DocController = new DocController(TestHelper.defaultOptions); + const quesiton = survey.getQuestionByName('signaturepad') as QuestionSignaturePadModel; + const flatSignature = new FlatSignaturePad(survey, quesiton, controller); + quesiton.storeDataAsText = false; + quesiton.value = 'some_url'; + quesiton['_loadedData'] = undefined; + expect(flatSignature['getSignImageUrl']()).toBe('some_url'); + quesiton['_loadedData'] = 'some_url2'; + expect(flatSignature['getSignImageUrl']()).toBe('some_url2'); + + quesiton.storeDataAsText = true; + quesiton.value = 'some_url'; + quesiton['_loadedData'] = undefined; + expect(flatSignature['getSignImageUrl']()).toBe('some_url'); + quesiton['_loadedData'] = 'some_url2'; + expect(flatSignature['getSignImageUrl']()).toBe('some_url'); }); \ No newline at end of file