Skip to content

Commit

Permalink
Merge pull request #14073 from calixteman/bindItems
Browse files Browse the repository at this point in the history
XFA - Bind items when there's a bindItems entry
  • Loading branch information
calixteman authored Sep 24, 2021
2 parents e4d62db + 97c1e07 commit 104e049
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 10 deletions.
22 changes: 12 additions & 10 deletions src/core/xfa/bind.js
Original file line number Diff line number Diff line change
Expand Up @@ -478,6 +478,12 @@ class Binder {
return [occur.min, max];
}

_setAndBind(formNode, dataNode) {
this._setProperties(formNode, dataNode);
this._bindItems(formNode, dataNode);
this._bindElement(formNode, dataNode);
}

_bindElement(formNode, dataNode) {
// Some nodes can be useless because min=0 so remove them
// after the loop to avoid bad things.
Expand Down Expand Up @@ -530,15 +536,15 @@ class Binder {
if (child.bind) {
switch (child.bind.match) {
case "none":
this._bindElement(child, dataNode);
this._setAndBind(child, dataNode);
continue;
case "global":
global = true;
break;
case "dataRef":
if (!child.bind.ref) {
warn(`XFA - ref is empty in node ${child[$nodeName]}.`);
this._bindElement(child, dataNode);
this._setAndBind(child, dataNode);
continue;
}
ref = child.bind.ref;
Expand Down Expand Up @@ -578,7 +584,7 @@ class Binder {
}

// Don't bind the value in newly created node because it's empty.
this._bindElement(child, match);
this._setAndBind(child, match);
continue;
} else {
if (this._isConsumeData()) {
Expand All @@ -598,7 +604,7 @@ class Binder {
}
} else {
if (!child.name) {
this._bindElement(child, dataNode);
this._setAndBind(child, dataNode);
continue;
}
if (this._isConsumeData()) {
Expand Down Expand Up @@ -642,9 +648,7 @@ class Binder {
dataNode[$appendChild](match);

// Don't bind the value in newly created node because it's empty.
this._setProperties(child, match);
this._bindItems(child, match);
this._bindElement(child, match);
this._setAndBind(child, match);
continue;
}
if (this.emptyMerge) {
Expand All @@ -657,9 +661,7 @@ class Binder {
if (match) {
this._bindOccurrences(child, match, picture);
} else if (min > 0) {
this._setProperties(child, dataNode);
this._bindItems(child, dataNode);
this._bindElement(child, dataNode);
this._setAndBind(child, dataNode);
} else {
uselessNodes.push(child);
}
Expand Down
51 changes: 51 additions & 0 deletions test/unit/xfa_parser_spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -1259,6 +1259,57 @@ describe("XFAParser", function () {
]);
});

it("should make binding and bind items with a ref", function () {
const xml = `
<?xml version="1.0"?>
<xdp:xdp xmlns:xdp="http://ns.adobe.com/xdp/">
<template xmlns="http://www.xfa.org/schema/xfa-template/3.3">
<subform name="main">
<field name="CardName">
<bind match="dataRef" ref="$data.main.value"/>
<bindItems ref="$data.main.ccs.cc[*]" labelRef="uiname" valueRef="token"/>
<ui>
<choiceList/>
</ui>
</field>
</subform>
</template>
<xfa:datasets xmlns:xfa="http://www.xfa.org/schema/xfa-data/1.0/">
<xfa:data>
<main>
<value>VISA</value>
<ccs>
<cc uiname="Visa" token="VISA"/>
<cc uiname="Mastercard" token="MC"/>
<cc uiname="American Express" token="AMEX"/>
</ccs>
<CardName>MC</CardName>
</main>
</xfa:data>
</xfa:datasets>
</xdp:xdp>
`;
const root = new XFAParser().parse(xml);
const form = new Binder(root).bind();
expect(
searchNode(form, form, "subform.CardName.value.text").map(x =>
x[$text]()
)
).toEqual(["VISA"]);
expect(
searchNode(form, form, "subform.CardName.items[*].text[*]").map(x =>
x[$text]()
)
).toEqual([
"Visa",
"Mastercard",
"American Express",
"VISA",
"MC",
"AMEX",
]);
});

it("should make binding with occurrences in consumeData mode", function () {
const xml = `
<?xml version="1.0"?>
Expand Down

0 comments on commit 104e049

Please sign in to comment.