zotero/chrome/content/scaffold/templates/newWeb.js

73 lines
1.9 KiB
JavaScript
Raw Normal View History

/*
2021-12-29 01:32:56 +00:00
***** BEGIN LICENSE BLOCK *****
2021-12-29 01:32:56 +00:00
Copyright © 2022 YOUR_NAME <- TODO
2021-12-29 01:32:56 +00:00
This file is part of Zotero.
2021-12-29 01:32:56 +00:00
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.
2021-12-29 01:32:56 +00:00
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.
2021-12-29 01:32:56 +00:00
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) {
// TODO: adjust the logic here
2021-12-29 01:32:56 +00:00
if ($$CURSOR$$url.includes('/article/')) {
return 'newspaperArticle';
}
else if (getSearchResults(doc, true)) {
2021-12-29 01:32:56 +00:00
return 'multiple';
}
return false;
}
function getSearchResults(doc, checkOnly) {
var items = {};
var found = false;
// TODO: adjust the CSS selector
var rows = doc.querySelectorAll('h2 > a.title[href*="/article/"]');
for (let row of rows) {
// TODO: check and maybe adjust
let href = row.href;
// TODO: check and maybe adjust
let title = ZU.trimInternal(row.textContent);
if (!href || !title) continue;
if (checkOnly) return true;
found = true;
items[href] = title;
}
return found ? items : false;
}
2021-12-29 01:32:56 +00:00
async function doWeb(doc, url) {
if (detectWeb(doc, url) == 'multiple') {
2021-12-29 01:32:56 +00:00
let items = await Zotero.selectItems(getSearchResults(doc, false));
if (items) {
await Promise.all(
Object.keys(items)
.map(url => requestDocument(url).then(scrape))
2021-12-29 01:32:56 +00:00
);
}
}
else {
2021-12-29 01:32:56 +00:00
await scrape(doc, url);
}
}
async function scrape(doc, url = doc.location.href) {
// TODO: implement or add a scrape function template
}