Merge pull request #13743 from calixteman/print_radio

XFA - Checkboxes must be printed (bug 1720182)
This commit is contained in:
calixteman 2021-07-16 12:57:04 +02:00 committed by GitHub
commit f1ae7d7b0e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 46 additions and 8 deletions

View File

@ -33,7 +33,7 @@ class XfaLayer {
element.attributes.type === "radio" ||
element.attributes.type === "checkbox"
) {
if (storedData.value === element.attributes.exportedValue) {
if (storedData.value === element.attributes.xfaOn) {
html.setAttribute("checked", true);
}
if (intent === "print") {
@ -82,6 +82,9 @@ class XfaLayer {
attributes.name = `${attributes.name}-${intent}`;
}
for (const [key, value] of Object.entries(attributes)) {
// We don't need to add dataId in the html object but it can
// be useful to know its value when writing printing tests:
// in this case, don't skip dataId to have its value.
if (value === null || value === undefined || key === "dataId") {
continue;
}

View File

@ -288,7 +288,14 @@ var rasterizeXfaLayer = (function rasterizeXfaLayerClosure() {
}
// eslint-disable-next-line no-shadow
function rasterizeXfaLayer(ctx, viewport, xfa, fontRules) {
function rasterizeXfaLayer(
ctx,
viewport,
xfa,
fontRules,
annotationStorage,
isPrint
) {
return new Promise(function (resolve, reject) {
// Building SVG with size of the viewport.
const svg = document.createElementNS(SVG_NS, "svg:svg");
@ -316,6 +323,8 @@ var rasterizeXfaLayer = (function rasterizeXfaLayerClosure() {
xfa,
div,
viewport: viewport.clone({ dontFlip: true }),
annotationStorage,
intent: isPrint ? "print" : "display",
});
// Some unsupported type of images (e.g. tiff)
@ -631,6 +640,14 @@ var Driver = (function DriverClosure() {
renderPrint = false,
renderXfa = false;
if (task.annotationStorage) {
const entries = Object.entries(task.annotationStorage),
docAnnotationStorage = task.pdfDoc.annotationStorage;
for (const [key, value] of entries) {
docAnnotationStorage.setValue(key, value);
}
}
var textLayerCanvas, annotationLayerCanvas;
var initPromise;
if (task.type === "text") {
@ -713,7 +730,9 @@ var Driver = (function DriverClosure() {
annotationLayerContext,
viewport,
xfa,
task.fontRules
task.fontRules,
task.pdfDoc.annotationStorage,
task.renderPrint
);
});
}
@ -731,11 +750,6 @@ var Driver = (function DriverClosure() {
};
if (renderPrint) {
if (task.annotationStorage) {
const entries = Object.entries(task.annotationStorage),
docAnnotationStorage = task.pdfDoc.annotationStorage;
for (const [key, value] of entries) {
docAnnotationStorage.setValue(key, value);
}
renderContext.includeAnnotationStorage = true;
}
renderContext.intent = "print";

View File

@ -0,0 +1 @@
https://bugzilla.mozilla.org/attachment.cgi?id=9230780

View File

@ -952,6 +952,26 @@
"enableXfa": true,
"type": "eq"
},
{ "id": "xfa_bug1720182",
"file": "pdfs/xfa_bug1720182.pdf",
"md5": "1351f816f0509fe750ca61ef2bd40872",
"link": true,
"rounds": 1,
"enableXfa": true,
"type": "eq",
"print": true,
"annotationStorage": {
"RadioButtonList2707": {
"value": "1"
},
"ComplainantFirstname2710": {
"value": "Foo"
},
"ComplainantLastname2711": {
"value": "Bar"
}
}
},
{ "id": "xfa_bug1718740",
"file": "pdfs/xfa_bug1718740.pdf",
"md5": "fab4277f2c70fd1edb35f597f5fe6819",