96 lines
No EOL
2.8 KiB
JavaScript
96 lines
No EOL
2.8 KiB
JavaScript
{
|
|
"translatorID":"ab88d517-d88c-4a73-a0ad-c94c76cca849",
|
|
"translatorType":4,
|
|
"label":"eMedicine",
|
|
"creator":"William Smith",
|
|
"target":"http://emedicine.medscape.com/article/",
|
|
"minVersion":"1.0.0b4.r5",
|
|
"maxVersion":"",
|
|
"priority":100,
|
|
"inRepository":true,
|
|
"lastUpdated":"2009-12-09 13:40:00"
|
|
}
|
|
|
|
// Emedicine.Medscape.com translator.
|
|
// Version 1.00
|
|
// By William Smith, see http://www.willsmith.org/contactme/
|
|
|
|
function detectWeb(doc, url) {
|
|
if (doc.location.href.match("(overview|treatment|diagnosis|followup|media)")) {
|
|
return "journalArticle";
|
|
}
|
|
}
|
|
|
|
|
|
// Everything lives in Metas. Very convenient.
|
|
|
|
function useMeta (doc, newItem, field, zoteroField) {
|
|
xpath='//meta[@name="' + field + '"]/@content';
|
|
temp=doc.evaluate(xpath, doc, null, XPathResult.ANY_TYPE, null).iterateNext();
|
|
if(temp)
|
|
{
|
|
newItem[zoteroField] =temp.value;
|
|
}
|
|
}
|
|
function getMeta (doc, newItem, field) {
|
|
xpath='//meta[@name="' + field + '"]/@content';
|
|
temp=doc.evaluate(xpath, doc, null, XPathResult.ANY_TYPE, null);
|
|
return temp;
|
|
}
|
|
|
|
function scrape(doc, url) {
|
|
|
|
var namespace = doc.documentElement.namespaceURI;
|
|
var nsResolver = namespace ? function(prefix) {
|
|
if (prefix == 'x') return namespace; else return null;
|
|
} : null;
|
|
|
|
var fieldTitle;
|
|
|
|
var newItem = new Zotero.Item("journalArticle");
|
|
|
|
newItem.publication = 'Medscape - eMedicine';
|
|
|
|
// Geta few useful fields.
|
|
useMeta(doc, newItem, "displayTitle", "title");
|
|
useMeta(doc, newItem, "date" , "date" );
|
|
useMeta(doc, newItem, "book" , "repository");
|
|
useMeta(doc, newItem, "description" , "abstractNote");
|
|
newItem.abstractNote = newItem.abstractNote.replace(/^(Overview|Treatment|Diagnosis|Followup|Media):\s+/, "");
|
|
|
|
// Authors - we only handle one.
|
|
authors = getMeta(doc, newItem, "authors");
|
|
if (authors) {
|
|
authors = authors.iterateNext().textContent;
|
|
Zotero.debug('author: <'+authors+'>');
|
|
newItem.creators.push(Zotero.Utilities.cleanAuthor(authors, "author"));
|
|
}
|
|
|
|
// Keywords.
|
|
keywords = getMeta(doc, newItem, "keywords");
|
|
if (keywords) {
|
|
keywords = keywords.iterateNext().textContent;
|
|
Zotero.debug('keywords: <'+keywords+'>');
|
|
keywords = keywords.split(",");
|
|
for (var i=0;i<keywords.length; i++) {
|
|
Zotero.debug('keyword['+i+']: <'+keywords[i]+'>');
|
|
newItem.tags[i] = Zotero.Utilities.cleanTags(keywords[i], "");
|
|
}
|
|
}
|
|
|
|
newItem.url = url;
|
|
|
|
// Attachment doesn't seem to work - misses a stylesheet or something, and looks ugly.
|
|
// newItem.attachments.push({url:url, title:"eMedicine Snapshot",mimeType:"text/html"});
|
|
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;
|
|
|
|
|
|
scrape(doc,url);
|
|
} |