Skip to content

Commit e563510

Browse files
JaneSjsRoman Tsukanov
and
Roman Tsukanov
authored
Node.js Demo - Add Logo, HTML, and Signature Pad (#16)
* Node.js Demo - Add Logo, HTML, and Signature Pad * Update surey and documentation * Fix formatting in index.js * Add links to HTML/SignaturePad * Remove spaces * Fix the image note * Update readme --------- Co-authored-by: Roman Tsukanov <[email protected]>
1 parent 083f2e6 commit e563510

File tree

4 files changed

+564
-39
lines changed

4 files changed

+564
-39
lines changed

surveyjs-pdf-nodejs/README.MD

+10-8
Original file line numberDiff line numberDiff line change
@@ -22,21 +22,23 @@ To generate a PDF form in a Node.js environment, follow these steps:
2222
2323
1. Install the [`survey-pdf`](https://www.npmjs.com/package/survey-pdf) npm package.
2424
25-
2. Create a [`SurveyPDF`](https://surveyjs.io/pdf-generator/documentation/api-reference/surveypdf) instance. Its constructor accepts two parameters: a survey JSON schema and a [PDF document configuration](https://surveyjs.io/pdf-generator/documentation/api-reference/idocoptions).
25+
2. *(Optional)* If your survey contains [HTML](https://surveyjs.io/form-library/documentation/api-reference/add-custom-html-to-survey) or [Signature](https://surveyjs.io/form-library/documentation/api-reference/signature-pad-model) questions, install the [`jsdom`](https://www.npmjs.com/package/jsdom) package to create a simulated web environment in a Node.js application. Create a JSDOM instance and reference the `window` and `document` objects from the JSDOM instance in a global scope.
2626
27-
3. Specify the `data` property of a `SurveyPDF` instance to define question answers. If a survey contains default values and you wish to preserve them, call the `mergeData(newObj)` method instead. For more information on how to programmatically define question answers, refer to the following help topic: [Populate Form Fields](https://surveyjs.io/form-library/documentation/design-survey/pre-populate-form-fields).
27+
3. Create a [`SurveyPDF`](https://surveyjs.io/pdf-generator/documentation/api-reference/surveypdf) instance. Its constructor accepts two parameters: a survey JSON schema and a [PDF document configuration](https://surveyjs.io/pdf-generator/documentation/api-reference/idocoptions).
2828
29+
4. Specify the `data` property of a `SurveyPDF` instance to define question answers. If a survey contains default values and you wish to preserve them, call the `mergeData(newObj)` method instead. For more information on how to programmatically define question answers, refer to the following help topic: [Populate Form Fields](https://surveyjs.io/form-library/documentation/design-survey/pre-populate-form-fields).
2930
30-
4. Call the [save(fileName)](https://surveyjs.io/pdf-generator/documentation/api-reference/surveypdf#save) method on the `SurveyPDF` instance to save a PDF form.
31+
5. Call the [save(fileName)](https://surveyjs.io/pdf-generator/documentation/api-reference/surveypdf#save) method on the `SurveyPDF` instance to save a PDF form.
3132
3233
## Limitations
3334
34-
The following question types are not supported when you generate PDF forms in Node.js:
35+
Please take into account the following restrictions when you generate PDF forms in Node.js:
3536
36-
* [HTML](https://surveyjs.io/form-library/documentation/api-reference/add-custom-html-to-survey)
37-
* [Image](https://surveyjs.io/form-library/documentation/api-reference/add-image-to-survey)
38-
* [Image Picker](https://surveyjs.io/form-library/documentation/api-reference/add-image-to-survey)
39-
* [Signature Pad](https://surveyjs.io/form-library/documentation/api-reference/signature-pad-model)
37+
- **HTML support is limited**
38+
In Node.js, [HTML](https://surveyjs.io/form-library/documentation/api-reference/add-custom-html-to-survey) questions do not support the `"image"` [render mode](https://surveyjs.io/pdf-generator/documentation/api-reference/idocoptions#htmlRenderAs) and complex markup.
39+
40+
- **Only base64-encoded images are supported**
41+
Images embedded in a survey, such as a [survey logo](https://surveyjs.io/form-library/documentation/api-reference/survey-data-model#logo) or images from the [Image](https://surveyjs.io/form-library/documentation/api-reference/add-image-to-survey) and [Image Picker](https://surveyjs.io/form-library/documentation/api-reference/add-image-to-survey) questions, can be specified as base64-encoded strings or as URLs. However, Node.js supports only base64-encoded strings.
4042
4143
## SurveyJS PDF Generator Resources
4244

surveyjs-pdf-nodejs/index.js

+53-31
Original file line numberDiff line numberDiff line change
@@ -1,18 +1,26 @@
1+
const jsdom = require("jsdom");
2+
const { JSDOM } = jsdom;
13
const SurveyPDF = require("survey-pdf");
24

3-
const surveyPDF = new SurveyPDF.SurveyPDF({
5+
const { window } = new JSDOM(`...`);
6+
global.window = window;
7+
global.document = window.document;
8+
9+
const json = {
410
"title": "COVID-19 Screening Form",
5-
"description": "All fields with an asterisk (*) are required fields and must be filled out in order to process information in strict confidentiality.",
6-
"questionErrorLocation": "bottom",
11+
"focusFirstQuestionAutomatic": false,
712
"pages": [
813
{
914
"name": "patient-info",
10-
"title": "Patient Information",
1115
"elements": [
16+
{
17+
"type": "html",
18+
"name": "introMsg",
19+
"html": "<i>All fields with an asterisk (*) are required fields and must be filled out in order to process information in strict confidentiality.</i>"
20+
},
1221
{
1322
"type": "panel",
1423
"name": "full-name",
15-
"title": "Full name",
1624
"elements": [
1725
{
1826
"type": "text",
@@ -29,7 +37,8 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
2937
"isRequired": true,
3038
"maxLength": 25
3139
}
32-
]
40+
],
41+
"title": "Full name"
3342
},
3443
{
3544
"type": "panel",
@@ -40,14 +49,14 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
4049
"name": "ssn",
4150
"title": "Social Security number",
4251
"isRequired": true,
43-
"maxLength": 9,
4452
"validators": [
4553
{
4654
"type": "regex",
4755
"text": "Your SSN must be a 9-digit number.",
4856
"regex": "^\\d{9}$"
4957
}
50-
]
58+
],
59+
"maxLength": 9
5160
},
5261
{
5362
"type": "text",
@@ -59,11 +68,11 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
5968
}
6069
]
6170
}
62-
]
71+
],
72+
"title": "Patient Information"
6373
},
6474
{
65-
"name": "symptoms",
66-
"title": "Current Symptoms",
75+
"name": "symptoms-page",
6776
"elements": [
6877
{
6978
"type": "checkbox",
@@ -82,11 +91,11 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
8291
"showNoneItem": true,
8392
"noneText": "No symptoms"
8493
}
85-
]
94+
],
95+
"title": "Current Symptoms"
8696
},
8797
{
8898
"name": "contacts",
89-
"title": "Contacts",
9099
"elements": [
91100
{
92101
"type": "boolean",
@@ -97,13 +106,17 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
97106
"type": "radiogroup",
98107
"name": "contacted-covid-positive",
99108
"title": "Have you been in contact with anyone who has since tested positive for COVID-19?",
100-
"choices": [ "Yes", "No", "Not sure" ]
109+
"choices": [
110+
"Yes",
111+
"No",
112+
"Not sure"
113+
]
101114
}
102-
]
115+
],
116+
"title": "Contacts"
103117
},
104118
{
105119
"name": "travels",
106-
"title": "Travels",
107120
"elements": [
108121
{
109122
"type": "boolean",
@@ -116,11 +129,11 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
116129
"visibleIf": "{travelled} = true",
117130
"title": "Where did you go?"
118131
}
119-
]
132+
],
133+
"title": "Travels"
120134
},
121135
{
122136
"name": "tests",
123-
"title": "Tests",
124137
"elements": [
125138
{
126139
"type": "boolean",
@@ -135,12 +148,9 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
135148
{
136149
"type": "paneldynamic",
137150
"name": "emergency-contacts",
151+
"visibleIf": "(({tested-covid-positive} = true or {contacted-covid-positive} = 'Yes') or ({symptoms} notempty and {symptoms} notcontains 'none'))",
138152
"title": "Emergency Contacts",
139153
"description": "If possible, it's best to specify at least TWO emergency contacts.",
140-
"panelsState": "firstExpanded",
141-
"confirmDelete": true,
142-
"panelAddText": "Add a new contact person",
143-
"visibleIf": "(({tested-covid-positive} = true or {contacted-covid-positive} = 'Yes') or ({symptoms} notempty and {symptoms} notcontains 'none'))",
144154
"isRequired": true,
145155
"templateElements": [
146156
{
@@ -166,13 +176,16 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
166176
"title": "Phone number",
167177
"inputType": "tel"
168178
}
169-
]
179+
],
180+
"panelsState": "firstExpanded",
181+
"confirmDelete": true,
182+
"panelAddText": "Add a new contact person"
170183
}
171-
]
184+
],
185+
"title": "Tests"
172186
},
173187
{
174188
"name": "finalization",
175-
"title": "Miscellaneous",
176189
"elements": [
177190
{
178191
"type": "comment",
@@ -185,16 +198,24 @@ const surveyPDF = new SurveyPDF.SurveyPDF({
185198
"title": "Date",
186199
"inputType": "date"
187200
},
188-
]
201+
{
202+
"type": "signaturepad",
203+
"name": "signature",
204+
"startWithNewLine": false,
205+
"title": "Signature"
206+
}
207+
],
208+
"title": "Miscellaneous"
189209
}
190210
],
191-
"completeText": "Submit",
211+
"showQuestionNumbers": "off",
212+
"questionErrorLocation": "bottom",
213+
"completeText": "Submit",
192214
"showPreviewBeforeComplete": "showAnsweredQuestions",
193-
"showQuestionNumbers": false,
194-
"focusFirstQuestionAutomatic": false,
195215
"widthMode": "static",
196216
"width": "1000px"
197-
});
217+
}
218+
const surveyPDF = new SurveyPDF.SurveyPDF(json, { htmlRenderAs: "standard" });
198219

199220
surveyPDF.data = {
200221
"first-name": "Jane",
@@ -209,6 +230,7 @@ surveyPDF.data = {
209230
"travelled": false,
210231
"tested-covid-positive": false,
211232
"awaiting-covid-test": false,
212-
"date": "2023-08-29"
233+
"date": "2023-08-29",
234+
"signature": ""
213235
}
214236
surveyPDF.save("survey-result.pdf");

0 commit comments

Comments
 (0)