zotero/translators/Inter-Research Science Center.js

106 lines
4.5 KiB
JavaScript

{
"translatorID":"0eeb2ac0-fbaf-4994-b98f-203d273eb9fa",
"translatorType":4,
"label":"Inter-Research Science Center",
"creator":"Michael Berkowitz",
"target":"http://www.int-res.com/",
"minVersion":"1.0.0b4.r5",
"maxVersion":"",
"priority":100,
"inRepository":true,
"lastUpdated":"2008-05-05 07:45:00"
}
function detectWeb(doc, url) {
if (doc.evaluate('//div[@class="journal-index"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext() ||
doc.evaluate('//div[@class="tx-indexedsearch-res"]//tr[1]/td[2]//a', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
return "multiple";
} else if (doc.evaluate('//a[@class="citeexport"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
return "journalArticle";
}
}
var journals = {
meps:["Marine Ecology Progress Series", "Mar Ecol Prog Ser"],
ab:["Aquatic Biology", "Aquat Biol"],
ame:["Aquatic Microbial Ecology", "Aquat Microb Ecol"],
dao:["Diseases of Aquatic Organisms", "Dis Aquat Org"],
cr:["Climate Research", "Clim Res"],
esr:["Endangered Species Research", "Endang Species Res"]
};
function doWeb(doc, url) {
var arts = new Array();
if (detectWeb(doc, url) == "multiple") {
var items = new Object();
if (doc.evaluate('//div[@class="tx-indexedsearch-res"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext()) {
var titlesx = doc.evaluate('//div[@class="tx-indexedsearch-res"]//tr[2]/td[2]', doc, null, XPathResult.ANY_TYPE, null);
var linksx = doc.evaluate('//div[@class="tx-indexedsearch-res"]//tr[1]/td[2]//a', doc, null, XPathResult.ANY_TYPE, null);
var title;
var link;
while ((title = titlesx.iterateNext()) && (link = linksx.iterateNext())) {
items[link.href] = Zotero.Utilities.trimInternal(title.textContent).match(/doi:\s+[^\s]+\s+(.*)$/)[1];
}
} else {
var stuff = doc.evaluate('//div[@class="journal-index"]/*[a[contains(text(), "pdf format")]]', doc, null, XPathResult.ANY_TYPE, null);
var thing;
var titles = "";
while (thing = stuff.iterateNext()) {
titles += thing.textContent;
}
titles = titles.split(/\n/);
Zotero.debug(titles);
var names = new Array();
for (var i = 0; i < titles.length; i++) {
if (((i-1)%2 == 0) && (titles[i].match(/\w+/))) {
names.push(titles[i]);
}
}
Zotero.debug(names);
var links = doc.evaluate('//div[@class="journal-index"]/*[a[contains(text(), "pdf format")]]/a[1]', doc, null, XPathResult.ANY_TYPE, null);
var link;
while (link = links.iterateNext()) {
items[link.href] = names.shift();
}
}
items = Zotero.selectItems(items);
for (var i in items) {
arts.push(i);
}
} else {
arts = [url];
}
Zotero.Utilities.processDocuments(arts, function(doc) {
var item = new Zotero.Item("journalArticle");
item.title = Zotero.Utilities.trimInternal(doc.evaluate('//div[@class="bb"]/h2', doc, null, XPathResult.ANY_TYPE, null).iterateNext().textContent);
item.url = doc.location.href;
var voliss = item.url.match(/v(\d+)\/(n(\d+)\/)?p([^/]+)\//);
item.volume = voliss[1];
item.pages = voliss[4];
if (voliss[2]) item.issue = voliss[3];
var jour = item.url.match(/abstracts\/([^/]+)\//)[1];
item.publicationTitle = journals[jour][0];
item.journalAbbreviation = journals[jour][1];
item.abstractNote = Zotero.Utilities.trimInternal(doc.evaluate('//p[@class="abstract_block"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext().textContent);
var authors = Zotero.Utilities.trimInternal(doc.evaluate('//div[@class="bb"]/h3', doc, null, XPathResult.ANY_TYPE, null).iterateNext().textContent).split(/,\s+/);
for each (var aut in authors) {
aut = aut.replace(/[^\w^\s^\.]/g, "").replace(/\d/g, "");
item.creators.push(Zotero.Utilities.cleanAuthor(aut, "author"));
}
item.date = doc.evaluate('//div[@class="abs-footer"]', doc, null, XPathResult.ANY_TYPE, null).iterateNext().textContent.match(/date:\s+(.*)P/)[1];
item.DOI = Zotero.Utilities.trimInternal(doc.evaluate('//h1[@class="csc-firstHeader"]/span', doc, null, XPathResult.ANY_TYPE, null).iterateNext().textContent).match(/doi:\s+(.*)/)[1];
var tags = doc.evaluate('//div[@class="box"]/p/a', doc, null, XPathResult.ANY_TYPE, null);
var tag;
while (tag = tags.iterateNext()) {
item.tags.push(tag.textContent);
}
var pdfurl = doc.evaluate('//a[contains(@href, ".pdf")]', doc, null, XPathResult.ANY_TYPE, null).iterateNext().href;
item.attachments = [
{url:item.url, title:item.publicationTitle + " Snapshot", mimeType:"text/html"},
{url:pdfurl, title:item.publicationTitle + " Full Text PDF", mimeType:"application/pdf"}
];
item.complete();
}, function() {Zotero.done;});
Zotero.wait();
}