d8ecaec6e4
at some point, this should probably be changed to read a fixed number of bytes
126 lines
3.9 KiB
JavaScript
126 lines
3.9 KiB
JavaScript
{
|
|
"translatorID":"4e7119e0-02be-4848-86ef-79a64185aad8",
|
|
"translatorType":3,
|
|
"label":"Bookmarks",
|
|
"creator":"Avram Lyon",
|
|
"target":"html",
|
|
"minVersion":"2.1b6",
|
|
"maxVersion":"",
|
|
"priority":100,
|
|
"inRepository":true,
|
|
"lastUpdated":"2011-03-16 23:24:54"
|
|
}
|
|
|
|
/*
|
|
Browser bookmarks translator
|
|
Copyright (C) 2011 Avram Lyon, ajlyon@gmail.com
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program 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 General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/* This translator imports and exports browser bookmark files in the standard
|
|
* "Netscape Bookmark Format".
|
|
* See http://msdn.microsoft.com/en-us/library/aa753582%28VS.85%29.aspx
|
|
* This code draws from the CSL style for bookmark export, by Rintze Zelle
|
|
* http://www.zotero.org/styles/bookmark-export
|
|
* Input looks like:
|
|
<!DOCTYPE NETSCAPE-Bookmark-file-1>
|
|
<!-- This is an automatically generated file.
|
|
It will be read and overwritten.
|
|
DO NOT EDIT! -->
|
|
<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=UTF-8">
|
|
<TITLE>Bookmarks</TITLE>
|
|
<H1>Bookmarks Menu</H1>
|
|
<DL>
|
|
<DT><A HREF="http://www.example.com/">Example Site</A></DT>
|
|
<DD>Longer title</DD>
|
|
</DL>
|
|
*/
|
|
|
|
const MAX_DETECT_LINES = 150;
|
|
|
|
function detectImport() {
|
|
var text = "";
|
|
var line;
|
|
var match;
|
|
var re = /<DT>\s*<A[^>]*HREF="([^"]+)"[^>]*>([^<\n]+)/gi;
|
|
var i = 0;
|
|
while((line = Zotero.read()) !== false && (i++ < MAX_DETECT_LINES)) {
|
|
text += line;
|
|
match = re.exec(text);
|
|
if (match) {
|
|
Zotero.debug("Found a match with line: "+line);
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
function doImport() {
|
|
var line;
|
|
var hits;
|
|
var item = false;
|
|
var itemIncomplete = false;
|
|
var re = /([A-Za-z_]+)="([^"]+)"/g;
|
|
while((line = Zotero.read()) !== false) {
|
|
if (line.indexOf("<DT>") !== -1) {
|
|
if (itemIncomplete) item.complete();
|
|
itemIncomplete = true;
|
|
item = new Zotero.Item("webpage");
|
|
item.title = line.match(/>([^<]*)<\/A>/)[1];
|
|
Zotero.debug(item.title);
|
|
while(hits = re.exec(line)) {
|
|
if (!hits) { Zotero.debug("RE no match in "+line);
|
|
}
|
|
switch (hits[1]) {
|
|
case "HREF": item.url = hits[2]; break;
|
|
case "TAGS": item.tags = hits[2].split(','); break;
|
|
default: item.extra = item.extra ? item.extra + "; "+ [hits[1], hits[2]].join("=") :
|
|
[hits[1], hits[2]].join("=");
|
|
}
|
|
}
|
|
} else if (line.substr(0,4) == "<DD>") {
|
|
if (itemIncomplete) item.abstractNote = item.abstractNote ? item.abstractNote + " " + line.substr(4) : line.substr(4);
|
|
else Zotero.debug("Discarding description line without item: " + line);
|
|
} else {
|
|
Zotero.debug("Discarding line: " + line);
|
|
}
|
|
}
|
|
if (item && itemIncomplete) item.complete();
|
|
}
|
|
|
|
|
|
function doExport() {
|
|
var item;
|
|
|
|
var header = '<!DOCTYPE NETSCAPE-Bookmark-file-1>\n'+
|
|
'<!-- This is an automatically generated file.\n'+
|
|
' It will be read and overwritten.\n'+
|
|
' DO NOT EDIT! -->\n'+
|
|
'<META HTTP-EQUIV="Content-Type" CONTENT="text/html; charset=UTF-8">\n'+
|
|
'<TITLE>Bookmarks</TITLE>\n'+
|
|
'<H1>Bookmarks Menu</H1>\n'+
|
|
'<DL>\n';
|
|
var footer = '</DL>';
|
|
//var tags = "";
|
|
|
|
Zotero.write(header);
|
|
while (item = Zotero.nextItem()) {
|
|
// TODO Be more verbose, making an informative title and including more metadata
|
|
//tags = item.tags.forEach(function (tag) {return tag.tag}).join(",");
|
|
if (item.url) Zotero.write(' <DT><A HREF="'+item.url+'">'+item.title+'</A>\n');
|
|
else Zotero.debug("Skipping item without URL: "+item.title);
|
|
}
|
|
Zotero.write(footer);
|
|
}
|