Fix dead integration field object function calls

This commit is contained in:
Adomas Venčkauskas 2018-03-05 13:46:46 +02:00
parent 3f905be77e
commit 5a1cf3ab02

View file

@ -1130,7 +1130,7 @@ Zotero.Integration.Fields.prototype.addEditCitation = Zotero.Promise.coroutine(f
if (fields[i].equals(field._field)) { if (fields[i].equals(field._field)) {
// This is needed, because LibreOffice integration plugin caches the field code instead of asking // This is needed, because LibreOffice integration plugin caches the field code instead of asking
// the document every time when calling #getCode(). // the document every time when calling #getCode().
field._field = fields[i]; field = new Zotero.Integration.CitationField(fields[i]);
return i; return i;
} }
} }
@ -1967,10 +1967,9 @@ Zotero.Integration.Field = class {
if (field instanceof Zotero.Integration.Field) { if (field instanceof Zotero.Integration.Field) {
throw new Error("Trying to instantiate Integration.Field with Integration.Field, not doc field"); throw new Error("Trying to instantiate Integration.Field with Integration.Field, not doc field");
} }
// This is not the best solution in terms of performance for (let func of Zotero.Integration.Field.INTERFACE) {
for (let prop in field) { if (!(func in this)) {
if (prop[0] != '_' && !(prop in this)) { this[func] = field[func].bind(field);
this[prop] = field[prop].bind ? field[prop].bind(field) : field[prop];
} }
} }
this._field = field; this._field = field;
@ -2018,6 +2017,8 @@ Zotero.Integration.Field = class {
return isRich; return isRich;
} }
}; };
Zotero.Integration.Field.INTERFACE = ['delete', 'removeCode', 'select', 'setText',
'getText', 'setCode', 'getCode', 'equals', 'getNoteIndex'];
/** /**
* Load existing field in document and return correct instance of field type * Load existing field in document and return correct instance of field type