diff --git a/translators/eMedicine.js b/translators/eMedicine.js new file mode 100644 index 000000000..01d296ae1 --- /dev/null +++ b/translators/eMedicine.js @@ -0,0 +1,96 @@ +{ + "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'); + 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); +} \ No newline at end of file