ThisTest/translators/zbMATH.js

264 lines
8.5 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

{
"translatorID": "1d84c107-9dbb-4b87-8208-e3632b87889f",
"label": "zbMATH",
"creator": "Philipp Zumstein",
"target": "^https?://(www\\.)?zbmath\\.org/",
"minVersion": "3.0",
"maxVersion": "",
"priority": 100,
"inRepository": true,
"translatorType": 4,
"browserSupport": "gcsv",
"lastUpdated": "2014-06-05 08:12:07"
}
/*
***** BEGIN LICENSE BLOCK *****
zbMATH Translator, Copyright © 2014 Philipp Zumstein
This file is part of Zotero.
Zotero is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
Zotero is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with Zotero. If not, see <http://www.gnu.org/licenses/>.
***** END LICENSE BLOCK *****
*/
function detectWeb(doc, url) {
if ( ZU.xpath(doc, '//div[@class="list"]/article').length>0 ) {
return "multiple";
} else if (ZU.xpath(doc, '//a[contains(@class, "bib")]').length>0 ) {//contains
//it is a single entry --> generic fallback = journalArticle
return "journalArticle";
}
}
function scrape(doc, url) {
var bibArray = doc.getElementsByClassName("bib");
var bibUrl = bibArray[0].getAttribute('href');//e.g. "bibtex/06115874.bib"
ZU.doGet(bibUrl, function(text) {
//Z.debug(text);
var trans = Zotero.loadTranslator('import');
trans.setTranslator('9cb70025-a888-4a29-a210-93ec52da40d4');//https://github.com/zotero/translators/blob/master/BibTeX.js
trans.setString(text);
trans.setHandler('itemDone', function (obj, item) {
item.title = item.title.replace(/\.$/, '');
if (item.publisher) {
var publisherSeperation = item.publisher.indexOf(":");
if (publisherSeperation != -1) {
item.place = item.publisher.substr(0,publisherSeperation);
item.publisher = item.publisher.substr(publisherSeperation+1);
}
}
//keywords are normally not in the bib file, so we take them from the page
//moreover, the meaning of the MSC classification is also only given on the page
if (item.tags.length==0 ) {
var keywords = ZU.xpath(doc, '//div[@class="keywords"]/a');
for (var i=0; i<keywords.length; i++) {
item.tags.push( keywords[i].textContent );
}
var classifications = ZU.xpath(doc, '//div[@class="classification"]//tr');
for (var i=0; i<classifications.length; i++) {
item.extra = (item.extra ? item.extra + "\n" : '') + 'MSC2010: ' + ZU.xpathText(classifications[i], './td' , null , " = ");
}
}
//add abstract but not review
var abstractOrReview = ZU.xpathText(doc, '//div[@class="abstract"]');
if (abstractOrReview.indexOf('Summary') == 0) {
item.abstractNote = abstractOrReview.replace(/^Summary:?\s*/, '');
}
item.attachments = [{
title: "Snapshot",
document:doc
}];
var id = ZU.xpath(doc, '//div[@class="title"]/a[@class="label"]')[0];
if (id) {
if (!item.extra) item.extra = '';
else item.extra += "\n";
item.extra += 'Zbl: ' + ZU.trimInternal(id.textContent)
.replace(/^\s*Zbl\s+/i, ''); //e.g. Zbl 1255.05045
item.url = id.href;
}
item.complete();
//Z.debug(item);
});
trans.translate();
});
}
function doWeb(doc, url) {
if (detectWeb(doc, url) == "multiple") {
var items = new Object();
var articles = new Array();
var rows = ZU.xpath(doc, '//div[@class="list"]/article');
for (var i=0; i<rows.length; i++) {
var title = ZU.xpathText(rows[i], './div[@class="title"]/a[1]');
var link = ZU.xpathText(rows[i], './div[@class="title"]/a[1]/@href');
items[link] = title;
}
Zotero.selectItems(items, function (items) {
if (!items) {
return true;
}
for (var i in items) {
articles.push(i);
}
ZU.processDocuments(articles, scrape);
});
} else {
scrape(doc, url);
}
}/** BEGIN TEST CASES **/
var testCases = [
{
"type": "web",
"url": "https://www.zbmath.org/?q=an:06115874",
"items": [
{
"itemType": "journalArticle",
"creators": [
{
"firstName": "Dan",
"lastName": "Hefetz",
"creatorType": "author"
},
{
"firstName": "Michael",
"lastName": "Krivelevich",
"creatorType": "author"
},
{
"firstName": "Tibor",
"lastName": "Szabó",
"creatorType": "author"
}
],
"notes": [],
"tags": [
"random graphs",
"sharp thresholds",
"spanning trees",
"tree-universality"
],
"seeAlso": [],
"attachments": [
{
"title": "Snapshot"
}
],
"itemID": "zbMATH06115874",
"journalAbbreviation": "Random Struct. Algorithms",
"ISSN": "1042-9832; 1098-2418/e",
"issue": "4",
"language": "English",
"DOI": "10.1002/rsa.20472",
"extra": "MSC2010: 05C05 = Trees\nMSC2010: 05C80 = Random graphs\nZbl: 1255.05045",
"abstractNote": "We prove that a given tree T on n vertices with bounded maximum degree is contained asymptotically almost surely in the binomial random graph Gn,(1+ε)logn n provided that T belongs to one of the following two classes: (1) T has linearly many leaves; (2) T has a path of linear length all of whose vertices have degree two in T.",
"url": "https://www.zbmath.org/?q=an:1255.05045",
"libraryCatalog": "zbMATH",
"title": "Sharp threshold for the appearance of certain spanning trees in random graphs",
"publicationTitle": "Random Structures & Algorithms",
"volume": "41",
"pages": "391412",
"date": "2012"
}
]
},
{
"type": "web",
"url": "http://www.zbmath.org/?q=se:00001331+ai:bollobas.bela",
"items": "multiple"
},
{
"type": "web",
"url": "https://zbmath.org/?q=an:06212000",
"items": [
{
"itemType": "journalArticle",
"creators": [
{
"firstName": "Noga",
"lastName": "Alon",
"creatorType": "author"
},
{
"firstName": "Erik D.",
"lastName": "Demaine",
"creatorType": "author"
},
{
"firstName": "Mohammad T.",
"lastName": "Hajiaghayi",
"creatorType": "author"
},
{
"firstName": "Tom",
"lastName": "Leighton",
"creatorType": "author"
}
],
"notes": [],
"tags": [
"equilibrium",
"low diameter",
"network creation",
"network design",
"price of anarchy"
],
"seeAlso": [],
"attachments": [
{
"title": "Snapshot"
}
],
"itemID": "zbMATH06212000",
"journalAbbreviation": "SIAM J. Discrete Math.",
"ISSN": "0895-4801; 1095-7146/e",
"issue": "2",
"language": "English",
"DOI": "10.1137/090771478",
"extra": "MSC2010: 90C27 = Combinatorial optimization\nMSC2010: 05C85 = Graph algorithms (graph theory)\nMSC2010: 91A06 = n-person games, n>2\nZbl: 1273.90167",
"abstractNote": "We study a natural network creation game, in which each node locally tries to minimize its local diameter or its local average distance to other nodes by swapping one incident edge at a time. The central question is what structure the resulting equilibrium graphs have, in particular, how well they globally minimize diameter. For the local-average-distance version, we prove an upper bound of 2 O(lgn) , a lower bound of 3, and a tight bound of exactly 2 for trees, and give evidence of a general polylogarithmic upper bound. For the local-diameter version, we prove a lower bound of Ω(n) and a tight upper bound of 3 for trees. The same bounds apply, up to constant factors, to the price of anarchy. Our network creation games are closely related to the previously studied unilateral network creation game. The main difference is that our model has no parameter α for the link creation cost, so our results effectively apply for all values of α without additional effort; furthermore, equilibrium can be checked in polynomial time in our model, unlike in previous models. Our perspective enables simpler proofs that get at the heart of network creation games.",
"url": "https://zbmath.org/?q=an:1273.90167",
"libraryCatalog": "zbMATH",
"title": "Basic network creation games",
"publicationTitle": "SIAM Journal on Discrete Mathematics",
"volume": "27",
"pages": "656668",
"date": "2013"
}
]
},
{
"type": "web",
"url": "http://zbmath.org/?q=cc:35",
"items": "multiple"
}
];
/** END TEST CASES **/