Skip to content

Commit

Permalink
Merge pull request #12993 from Snuffleupagus/metadata-subject
Browse files Browse the repository at this point in the history
[api-minor] Change the `dc:subject` Metadata field to an Array
  • Loading branch information
timvandermeij authored Feb 15, 2021
2 parents f892c00 + b26c797 commit b5735f2
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 17 deletions.
29 changes: 13 additions & 16 deletions src/display/metadata.js
Original file line number Diff line number Diff line change
Expand Up @@ -89,23 +89,18 @@ class Metadata {
return entry.childNodes.filter(node => node.nodeName === "rdf:li");
}

_getCreators(entry) {
if (entry.nodeName !== "dc:creator") {
return false;
}
_parseArray(entry) {
if (!entry.hasChildNodes()) {
return true;
return;
}

// Child must be a Bag (unordered array) or a Seq.
const seqNode = entry.childNodes[0];
const authors = this._getSequence(seqNode) || [];
const [seqNode] = entry.childNodes;
const sequence = this._getSequence(seqNode) || [];

this._metadataMap.set(
entry.nodeName,
authors.map(node => node.textContent.trim())
sequence.map(node => node.textContent.trim())
);

return true;
}

_parse(xmlDocument) {
Expand All @@ -130,11 +125,13 @@ class Metadata {

for (const entry of desc.childNodes) {
const name = entry.nodeName;
if (name === "#text") {
continue;
}
if (this._getCreators(entry)) {
continue;
switch (name) {
case "#text":
continue;
case "dc:creator":
case "dc:subject":
this._parseArray(entry);
continue;
}
this._metadataMap.set(name, entry.textContent.trim());
}
Expand Down
2 changes: 1 addition & 1 deletion test/unit/metadata_spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,7 @@ describe("metadata", function () {
"dc:creator": [""],
"dc:description": "",
"dc:format": "application/pdf",
"dc:subject": "",
"dc:subject": [],
"dc:title": "",
"pdf:keywords": "",
"pdf:pdfversion": "1.7",
Expand Down

0 comments on commit b5735f2

Please sign in to comment.