Map annotation colors colors on import #2819 (#2822)

This commit is contained in:
Tom Najdek 2022-09-13 01:57:24 +02:00 committed by Dan Stillman
parent 7829a0dfdc
commit 223f44fdfd
3 changed files with 95 additions and 8 deletions

View file

@ -12,6 +12,18 @@ Services.scriptloader.loadSubScript("chrome://zotero/content/import/mendeley/men
const { apiTypeToDBType, apiFieldToDBField } = mendeleyOnlineMappings; const { apiTypeToDBType, apiFieldToDBField } = mendeleyOnlineMappings;
const { apiFetch, get, getAll, getTokens } = mendeleyAPIUtils; const { apiFetch, get, getAll, getTokens } = mendeleyAPIUtils;
const colorMap = new Map();
colorMap.set('rgb(255, 245, 173)', '#ffd400');
colorMap.set('#fff5ad', '#ffd400');
colorMap.set('rgb(255, 181, 182)', '#ff6666');
colorMap.set('#ffb5b6', '#ff6666');
colorMap.set('rgb(186, 226, 255)', '#2ea8e5');
colorMap.set('#bae2ff', '#2ea8e5');
colorMap.set('rgb(211, 194, 255)', '#a28ae5');
colorMap.set('#d3c2ff', '#a28ae5');
colorMap.set('rgb(220, 255, 176)', '#5fb236');
colorMap.set('#dcffb0', '#5fb236');
var Zotero_Import_Mendeley = function () { var Zotero_Import_Mendeley = function () {
this.createNewCollection = null; this.createNewCollection = null;
this.linkFiles = null; this.linkFiles = null;
@ -1568,6 +1580,10 @@ Zotero_Import_Mendeley.prototype._saveAnnotations = async function (annotations,
} }
// PDFWorker needs 'id' // PDFWorker needs 'id'
annotations.forEach(annotation => annotation.id = annotation.uuid); annotations.forEach(annotation => annotation.id = annotation.uuid);
annotations.forEach(annotation => (colorMap.has(annotation.color)
? annotation.color = colorMap.get(annotation.color)
: annotation.color
));
// Returns 'id', 'position', 'type', 'pageLabel', 'sortIndex', 'text' (for highlight) // Returns 'id', 'position', 'type', 'pageLabel', 'sortIndex', 'text' (for highlight)
Zotero.debug("Processing annotations in " + file); Zotero.debug("Processing annotations in " + file);
annotations = await Zotero.PDFWorker.processMendeleyAnnotations(file, annotations); annotations = await Zotero.PDFWorker.processMendeleyAnnotations(file, annotations);

View file

@ -5,8 +5,8 @@
"color": "color":
{ {
"r": 255, "r": 255,
"g": 181, "g": 245,
"b": 182 "b": 173
}, },
"profile_id": "8dbf0832-8723-4c48-b532-20c0b7f6e01a", "profile_id": "8dbf0832-8723-4c48-b532-20c0b7f6e01a",
"positions": "positions":
@ -37,8 +37,8 @@
"color": "color":
{ {
"r": 255, "r": 255,
"g": 196, "g": 181,
"b": 251 "b": 182
}, },
"profile_id": "8dbf0832-8723-4c48-b532-20c0b7f6e01a", "profile_id": "8dbf0832-8723-4c48-b532-20c0b7f6e01a",
"positions": "positions":
@ -129,6 +129,35 @@
"filehash": "cc22c6611277df346ff8dc7386ba3880b2bafa15", "filehash": "cc22c6611277df346ff8dc7386ba3880b2bafa15",
"document_id": "c54b0c6f-c4ce-4706-8742-bc7d032df862" "document_id": "c54b0c6f-c4ce-4706-8742-bc7d032df862"
}, },
{
"id": "734743eb-2be3-49ef-b1ac-3f1e84fea2f2",
"type": "sticky_note",
"color": {
"r": 220,
"g": 255,
"b": 176
},
"profile_id": "8dbf0832-8723-4c48-b532-20c0b7f6e01a",
"positions": [
{
"top_left": {
"x": 287.4041774203229,
"y": 662.2221955464859
},
"bottom_right": {
"x": 287.4041774203229,
"y": 662.2221955464859
},
"page": 1
}
],
"text": "green note",
"created": "2021-11-09T10:26:16.640Z",
"last_modified": "2021-11-09T10:26:16.640Z",
"privacy_level": "private",
"filehash": "cc22c6611277df346ff8dc7386ba3880b2bafa15",
"document_id": "c54b0c6f-c4ce-4706-8742-bc7d032df862"
},
{ {
"id": "e88bd089-2023-4544-a0bb-a21cb3990037", "id": "e88bd089-2023-4544-a0bb-a21cb3990037",
"type": "sticky_note", "type": "sticky_note",

View file

@ -179,11 +179,53 @@ describe('Zotero_Import_Mendeley', function () {
// attachment & annotations // attachment & annotations
assert.lengthOf(withpdf.getAttachments(), 1); assert.lengthOf(withpdf.getAttachments(), 1);
assert.equal(pdf.parentID, withpdf.id); assert.equal(pdf.parentID, withpdf.id);
const yellowHighlight = (await Zotero.Relations
.getByPredicateAndObject('item', 'mendeleyDB:annotationUUID', '339d0202-d99f-48a2-aa0d-9b0c5631af26'))
.filter(item => item.libraryID == Zotero.Libraries.userLibraryID && !item.deleted)
.shift();
const redHighlight = (await Zotero.Relations
.getByPredicateAndObject('item', 'mendeleyDB:annotationUUID', '885615a7-170e-4613-af80-0227ea76ae55'))
.filter(item => item.libraryID == Zotero.Libraries.userLibraryID && !item.deleted)
.shift();
const blueNote = (await Zotero.Relations
.getByPredicateAndObject('item', 'mendeleyDB:annotationUUID', 'bfbdb972-171d-4b21-8ae6-f156ac9a2b41'))
.filter(item => item.libraryID == Zotero.Libraries.userLibraryID && !item.deleted)
.shift();
const greenNote = (await Zotero.Relations
.getByPredicateAndObject('item', 'mendeleyDB:annotationUUID', '734743eb-2be3-49ef-b1ac-3f1e84fea2f2'))
.filter(item => item.libraryID == Zotero.Libraries.userLibraryID && !item.deleted)
.shift();
const orangeNote = (await Zotero.Relations
.getByPredicateAndObject('item', 'mendeleyDB:annotationUUID', 'c436932f-b14b-4580-a649-4587a5cdc2c3'))
.filter(item => item.libraryID == Zotero.Libraries.userLibraryID && !item.deleted)
.shift();
const purpleGroupNote = (await Zotero.Relations
.getByPredicateAndObject('item', 'mendeleyDB:annotationUUID', '656fd591-451a-4bb0-8d5f-30c36c135fc9'))
.filter(item => item.libraryID == Zotero.Libraries.userLibraryID && !item.deleted)
.shift();
assert.equal(blueNote.annotationComment, 'blue note 2');
assert.equal(greenNote.annotationComment, 'green note');
assert.equal(orangeNote.annotationComment, 'orange note1');
assert.equal(purpleGroupNote.annotationComment, 'note by me');
// map yellow rgb(255, 245, 173) -> #ffd400'
assert.equal(yellowHighlight.annotationColor, '#ffd400');
// map red: rgb(255, 181, 182) -> #ff6666
assert.equal(redHighlight.annotationColor, '#ff6666');
// map blue: rgb(186, 226, 255) -> '#2ea8e5'
assert.equal(blueNote.annotationColor, '#2ea8e5');
// map purple: rgb(211, 194, 255) -> '#a28ae5'
assert.equal(purpleGroupNote.annotationColor, '#a28ae5');
// map green: rgb(220, 255, 176) -> #5fb236
assert.equal(greenNote.annotationColor, '#5fb236');
// preserve other colors rgb(255, 222, 180) stays as #ffdeb4
assert.equal(orangeNote.annotationColor, '#ffdeb4');
// group annotations by others and mismatched annotations are not included
const annotations = await pdf.getAnnotations(); const annotations = await pdf.getAnnotations();
assert.equal(annotations.length, 5); assert.equal(annotations.length, 6);
assert.isTrue(annotations.some(a => a.annotationComment === 'blue note 2'));
assert.isTrue(annotations.some(a => a.annotationComment === 'orange note1'));
assert.isTrue(annotations.some(a => a.annotationComment === 'note by me'));
assert.isFalse(annotations.some(a => a.annotationComment === 'note by other')); assert.isFalse(annotations.some(a => a.annotationComment === 'note by other'));
assert.isFalse(annotations.some(a => a.annotationComment === 'mismatched note')); assert.isFalse(annotations.some(a => a.annotationComment === 'mismatched note'));