2837a2900d
- Add support for additional result page structure in Informaworld
170 lines
6.3 KiB
JavaScript
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();
|
|
}
|