zotero/translators/Informaworld.js
Avram Lyon 2837a2900d Trans: - Fix regression for DOI searches in Informaworld
- Add support for additional result page structure in Informaworld
2010-09-28 05:30:41 +00:00

170 lines
6.3 KiB
JavaScript

{
"translatorID":"1885b93c-cf37-4b25-aef5-283f42eada9d",
"label":"Informaworld",
"creator":"Michael Berkowitz",
"target":"^http://www\\.informaworld\\.com",
"minVersion":"1.0.0b4.r5",
"maxVersion":"",
"priority":100,
"inRepository":true,
"translatorType":4,
"lastUpdated":"2010-09-28 09:28:40"
}
/* Test URLs
Book section:
Book:
http://www.informaworld.com/smpp/title~db=all~content=t777453493
Journal article:
http://www.informaworld.com/smpp/content~content=a903855250&db=all
Journal issue ToC:
http://www.informaworld.com/smpp/title~db=all~content=g921992177
*/
function detectWeb(doc, url) {
if (url.indexOf("quicksearch") != -1) {
return "multiple";
} else if (doc.evaluate('//a[substring(text(), 2, 8) = "Download"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
if (doc.evaluate('//img[substring(@title, 1, 17) = "Publication type:"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
var pubtype = doc.evaluate('//img[substring(@title, 1, 17) = "Publication type:"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext().title;
if (pubtype.match("journal")) {
return "journalArticle";
} else if (pubtype.match("book")) {
return "bookSection";
}
} else {
return "book";
}
} else if (url.indexOf("content=g") != -1 ||
doc.evaluate('//div[@id="browse"]//tbody/tr/td[2]/a[2]', doc, null, XPathResult.ANY_TYPE, null).iterateNext() ||
doc.evaluate('//div[@id="title"]//td[2]/div/strong/a', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
return "multiple";
} else {
return true;
}
}
function doWeb(doc, url) {
// Scrape some data from page
var getDocumentData = function (newDoc, data) {
var xpath = '//div[@id="metahead"]/div';
var stuff = newDoc.evaluate(xpath, newDoc, null, XPathResult.ANY_TYPE, null);
var thing = stuff.iterateNext();
while (thing) {
if (thing.textContent.match(/DOI/)) {
data.doi = Zotero.Utilities.trimInternal(thing.textContent).match(/:\s+(.*)/)[1];
break;
}
thing = stuff.iterateNext();
}
// There seem to be multiple page structures
data.pdfurl = newDoc.evaluate('//div[@id="content"]/div/a[1]', newDoc, null, XPathResult.ANY_TYPE, null).iterateNext();
if (data.pdfurl == null) {
// If we didn't find the URL there, try elsewhere:
data.pdfurl = newDoc.evaluate('//a[@title="Download PDF"]', newDoc, null, XPathResult.ANY_TYPE, null).iterateNext();
}
data.pdfurl = data.pdfurl ? data.pdfurl.href : null; // Don't break on missing PDF
var id = newDoc.location.href.match(/content=([\w\d]+)/);
// If URL has DOI rather than id, use navbar link to get id
if (id[1] == 10) {
id = newDoc.evaluate('//div[@id="contenttabs"]//a[@title = "Article"]', newDoc, null, XPathResult.ANY_TYPE, null).iterateNext().href;
id = id.match(/content=([\w\d]+)/);
}
var post = 'tab=citation&selecteditems=' + id[1].substr(1) + '&content=' + id[1] + '&citstyle=refworks&showabs=false&format=file';
data.postdata = post;
}
var sets = [];
if (detectWeb(doc, url) == "multiple") {
var items = new Object();
if (doc.evaluate('//div[@id="quicksearch"]//tr/td/b/a', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
var xpath = '//div[@id="quicksearch"]//tr/td/b/a';
} else if (doc.evaluate('//div[@id="title"]/table/tbody/tr[2]//strong/a', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
var xpath = '//div[@id="title"]/table/tbody/tr[2]//strong/a';
} else if (doc.evaluate('//div[@id="browse"]//tbody/tr/td[2]/a[2]', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
var xpath = '//div[@id="browse"]//tbody/tr/td[2]/a[2]';
} else if (doc.evaluate('//div[@id="title"]//td[2]/div/strong/a', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
var xpath = '//div[@id="title"]//td[2]/div/strong/a';
} else if (doc.evaluate('//div[@id="title"]/table//tr[2]/td/table//tr/td[2]/b/a', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
var xpath = '//div[@id="title"]/table//tr[2]/td/table//tr/td[2]/b/a';
} else if (doc.evaluate('//a[@title="Click to view this record"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
var xpath = '//a[@title="Click to view this record"]';
}
var titles = doc.evaluate(xpath, doc, null, XPathResult.ANY_TYPE, null);
var title = titles.iterateNext();
while (title) {
items[title.href] = title.textContent;
title = titles.iterateNext();
}
items = Zotero.selectItems(items);
for (var i in items) {
sets.push({ url: i });
}
} else {
// If we're on the citation page, get back to the article page, which has the PDF link
var newurl = url.replace('~tab=citation', '~tab=content');
// If we're already on the main page, just pull out data here
if (newurl == url) {
sets[0] = {};
getDocumentData(doc, sets[0]);
// Dummy first callback, since we already have the data
var first = function (set, next) {
next();
};
}
else {
sets.push({
url: newurl
});
}
}
if (!first) {
var first = function (set, next) {
var url = set.url;
Zotero.Utilities.processDocuments(url, function(newDoc) {
getDocumentData(newDoc, set);
next();
});
};
}
var second = function (set, next) {
Zotero.Utilities.HTTP.doPost('http://www.informaworld.com/smpp/content', set.postdata, function(text) {
Zotero.debug(text);
text = text.replace(/RT/, "TY");
text = text.replace(/VO/, "VL");
text = text.replace(/LK/, "UR");
text = text.replace(/YR/, "PY");
text = text.replace(/([A-Z][A-Z\d]\s)/g, "$1 - ")
var translator = Zotero.loadTranslator("import");
translator.setTranslator("32d59d2d-b65a-4da4-b0a3-bdd3cfb979e7");
translator.setString(text);
translator.setHandler("itemDone", function(obj, item) {
var type = text.match(/TY\s+\-\s+([^\n]*)/)[1];
if (type == "Journal") {
item.itemType = "journalArticle";
} else if (type == "Book, Whole") {
item.itemType = "book";
} else if (type == "Book, Section") {
item.itemType = "bookSection";
}
if (set.doi) {
item.DOI = set.doi;
}
item.attachments.push({url:set.pdfurl, title:item.title, mimeType:'application/pdf'});
item.complete();
});
translator.translate();
next();
});
}
var callbacks = [first, second];
Zotero.Utilities.processAsync(sets, callbacks, function () { Zotero.done(); });
Zotero.wait();
}