zotero/translators/Archives Network of Alberta.js

152 lines
5.1 KiB
JavaScript

{
"translatorID":"f39dbd1c-229e-4abb-8414-a09fdbda37b7",
"translatorType":4,
"label":"Archives Network of Alberta",
"creator":"Adam Crymble",
"target":"http://208.38.46.62:8080/",
"minVersion":"1.0.0b4.r5",
"maxVersion":"",
"priority":100,
"inRepository":true,
"lastUpdated":"2008-06-29 21:10:00"
}
function detectWeb(doc, url) {
var xPathH3 = doc.evaluate('//h3', doc, null, XPathResult.ANY_TYPE, null).iterateNext().textContent;
if (xPathH3.match("Search Results")) {
return "multiple";
} else if (xPathH3.match("Display")) {
return "book";
}
}
//Archives Network of Alberta translator. Code by Adam Crymble
function associateData (newItem, dataTags, field, zoteroField) {
if (dataTags[field]) {
newItem[zoteroField] = dataTags[field];
}
}
function scrape(doc, url) {
var namespace = doc.documentElement.namespaceURI;
var nsResolver = namespace ? function(prefix) {
if (prefix == 'x') return namespace; else return null;
} : null;
var newItem = new Zotero.Item("book");
var dataTags = new Object();
var manyAuthors = new Array();
var tagsContent = new Array();
var tagsContent1 = new Array();
var xPathHeaders = doc.evaluate('//td[1][@class="datalabel"]', doc, nsResolver, XPathResult.ANY_TYPE, null);
var xPathContent = doc.evaluate('//td[2][@class="datatext"]', doc, nsResolver, XPathResult.ANY_TYPE, null);
var xPathCount = doc.evaluate('count (//td[1][@class="datalabel"])', doc, nsResolver, XPathResult.ANY_TYPE, null);
for (var i = 0; i < xPathCount.numberValue; i++) {
fieldTitle = xPathHeaders.iterateNext().textContent.replace(/\s+/g, '');
if (fieldTitle =="Provenance:") {
dataTags[fieldTitle] = (xPathContent.iterateNext().textContent.replace(/^\s*|\s*$/g, ''));
if (dataTags[fieldTitle].match("; ")) {
manyAuthors = dataTags[fieldTitle].split("; ");
} else {
manyAuthors.push(dataTags[fieldTitle]);
}
Zotero.debug(manyAuthors);
for (var j = 0; j < manyAuthors.length; j++) {
if (manyAuthors[j].match(", ")) {
var authorName = manyAuthors[j].split(",");
authorName[0] = authorName[0].replace(/^\s*|\s*$/g, '');
authorName[1] = authorName[1].replace(/^\s*|\s*$/g, '');
newItem.creators.push(Zotero.Utilities.cleanAuthor((authorName[1] + (" ") + authorName[0]), "author"));
} else {
newItem.creators.push({lastName: manyAuthors[j], creatorType: "creator"});
}
}
} else if (fieldTitle == "Partof:") {
dataTags[fieldTitle] = ("Part of " + Zotero.Utilities.cleanTags(xPathContent.iterateNext().textContent.replace(/^\s*|\s*$/g, '')));
} else if (fieldTitle == "OnlineFindingAid:") {
dataTags[fieldTitle] = ("Online Finding Aid: " + xPathContent.iterateNext().textContent);
Zotero.debug(dataTags["OnlineFindingAid:"]);
} else if (fieldTitle == "Names:") {
dataTags[fieldTitle] = (xPathContent.iterateNext().textContent.replace(/^\s*|\s*$/g, ''));
tagsContent = dataTags[fieldTitle].split(";");
} else if (fieldTitle == "Topic:") {
dataTags[fieldTitle] = (xPathContent.iterateNext().textContent.replace(/^\s*|\s*$/g, ''));
tagsContent1 = dataTags[fieldTitle].split(", ");
} else {
dataTags[fieldTitle] = Zotero.Utilities.cleanTags(xPathContent.iterateNext().textContent.replace(/^\s*|\s*$/g, ''));
}
}
for (i = 0; i < tagsContent.length; i++) {
tagsContent[i] = tagsContent[i].replace(/^\s*|\s*$/g, '');
newItem.tags[i] = tagsContent[i];
}
for (i = 0; i < tagsContent1.length; i++) {
newItem.tags.push(tagsContent1[i]);
}
associateData (newItem, dataTags, "Title:", "title");
associateData (newItem, dataTags, "Dates:", "date");
associateData (newItem, dataTags, "Physicaldesc.:", "pages");
associateData (newItem, dataTags, "Repository:", "repository");
associateData (newItem, dataTags, "Scope/Content:", "abstractNote");
associateData (newItem, dataTags, "Partof:", "series");
associateData (newItem, dataTags, "OnlineFindingAid:", "extra");
associateData (newItem, dataTags, "Language:", "language");
associateData (newItem, dataTags, "RecordNo.:", "callNumber");
newItem.url = doc.location.href;
newItem.complete();
}
function doWeb(doc, url) {
var namespace = doc.documentElement.namespaceURI;
var nsResolver = namespace ? function(prefix) {
if (prefix == 'x') return namespace; else return null;
} : null;
var articles = new Array();
if (detectWeb(doc, url) == "multiple") {
var items = new Object();
var xPathTitles = doc.evaluate('//tr[1]/td[2][@class="datatext"]', doc, nsResolver, XPathResult.ANY_TYPE, null);
var nextTitle;
var xPathLinks = doc.evaluate('//td[1][@class="dataleft"]/a', doc, nsResolver, XPathResult.ANY_TYPE, null);
while (nextTitle = xPathTitles.iterateNext()) {
items[xPathLinks.iterateNext().href] = nextTitle.textContent;
}
items = Zotero.selectItems(items);
for (var i in items) {
articles.push(i);
}
} else {
articles = [url];
}
Zotero.Utilities.processDocuments(articles, scrape, function() {Zotero.done();});
Zotero.wait();
}