Better method for determining valid XHTML notes in reports
Previously looked for <p> tag. Now just check if it's valid XML.
This commit is contained in:
parent
aa0a3544bd
commit
21bf3000cb
1 changed files with 18 additions and 9 deletions
|
@ -76,12 +76,17 @@ Zotero.Report = new function() {
|
||||||
// Independent note
|
// Independent note
|
||||||
if (arr['note']) {
|
if (arr['note']) {
|
||||||
content += '\n';
|
content += '\n';
|
||||||
if (arr.note.substr(0, 1024).match(/<p[^>]*>/)) {
|
|
||||||
content += arr.note + '\n';
|
// If not valid XML, display notes with entities encoded
|
||||||
|
var parser = Components.classes["@mozilla.org/xmlextras/domparser;1"]
|
||||||
|
.createInstance(Components.interfaces.nsIDOMParser);
|
||||||
|
var doc = parser.parseFromString(arr.note, "application/xml");
|
||||||
|
if (doc.documentElement.tagName == 'parsererror') {
|
||||||
|
content += '<p class="plaintext">' + escapeXML(arr.note) + '</p>\n';
|
||||||
}
|
}
|
||||||
// Wrap plaintext notes in <p>
|
// Otherwise render markup normally
|
||||||
else {
|
else {
|
||||||
content += '<p class="plaintext">' + arr.note + '</p>\n';
|
content += arr.note + '\n';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -98,13 +103,17 @@ Zotero.Report = new function() {
|
||||||
for each(var note in arr.reportChildren.notes) {
|
for each(var note in arr.reportChildren.notes) {
|
||||||
content += '<li id="i' + note.itemID + '">\n';
|
content += '<li id="i' + note.itemID + '">\n';
|
||||||
|
|
||||||
if (note.note.substr(0, 1024).match(/<p[^>]*>/)) {
|
// If not valid XML, display notes with entities encoded
|
||||||
content += note.note + '\n';
|
var parser = Components.classes["@mozilla.org/xmlextras/domparser;1"]
|
||||||
}
|
.createInstance(Components.interfaces.nsIDOMParser);
|
||||||
// Wrap plaintext notes in <p>
|
var doc = parser.parseFromString(note.note, "application/xml");
|
||||||
else {
|
if (doc.documentElement.tagName == 'parsererror') {
|
||||||
content += '<p class="plaintext">' + escapeXML(note.note) + '</p>\n';
|
content += '<p class="plaintext">' + escapeXML(note.note) + '</p>\n';
|
||||||
}
|
}
|
||||||
|
// Otherwise render markup normally
|
||||||
|
else {
|
||||||
|
content += note.note + '\n';
|
||||||
|
}
|
||||||
|
|
||||||
// Child note tags
|
// Child note tags
|
||||||
content += _generateTagsList(note);
|
content += _generateTagsList(note);
|
||||||
|
|
Loading…
Add table
Reference in a new issue