"use strict"; describe("Related Box", function () { var win, doc, itemsView; before(function* () { win = yield loadZoteroPane(); doc = win.document; itemsView = win.ZoteroPane.itemsView; }); after(function () { win.close(); }) it("should update if a related item is renamed", async function () { var title1 = 'aaaaaa'; var title2 = 'bbbbbb'; var item1 = await createDataObject('item', { title: title1 }); var item2 = await createDataObject('item', { title: title2 }); item1.addRelatedItem(item2); await item1.saveTx(); item2.addRelatedItem(item1); await item2.saveTx(); // Select the Related pane var tabbox = doc.getElementById('zotero-view-tabbox'); tabbox.selectedIndex = 3; var relatedbox = doc.getElementById('zotero-editpane-related'); // Wait for relations list to populate do { await Zotero.Promise.delay(50); } while (!relatedbox._id('related-grid').childNodes.length); assert.include(relatedbox._id('related-grid').innerHTML, title1); title1 = 'cccccc'; item1.setField('title', title1); await item1.saveTx(); // New title should appear in list do { await Zotero.Promise.delay(50); } while (!relatedbox._id('related-grid').innerHTML.includes(title1)); }); it("should update if a related item is deleted", async function () { var title1 = 'aaaaaa'; var title2 = 'bbbbbb'; var item1 = await createDataObject('item', { title: title1 }); var item2 = await createDataObject('item', { title: title2 }); item1.addRelatedItem(item2); await item1.saveTx(); item2.addRelatedItem(item1); await item2.saveTx(); // Select the Related pane var tabbox = doc.getElementById('zotero-view-tabbox'); tabbox.selectedIndex = 3; var relatedbox = doc.getElementById('zotero-editpane-related'); // Wait for relations list to populate do { await Zotero.Promise.delay(50); } while (!relatedbox._id('related-grid').childNodes.length); assert.include(relatedbox._id('related-grid').innerHTML, title1); await item1.eraseTx(); // Deleted item should be removed from list do { await Zotero.Promise.delay(50); } while (relatedbox._id('related-grid').innerHTML.includes(title1)); }); describe("Add button", function () { it("should add a related item", function* () { var item1 = yield createDataObject('item'); var item2 = yield createDataObject('item'); // Select the Related pane var tabbox = doc.getElementById('zotero-view-tabbox'); tabbox.selectedIndex = 3; var relatedbox = doc.getElementById('zotero-editpane-related'); assert.lengthOf(relatedbox.querySelectorAll('#related-grid div'), 0); // Click the Add button to open the Select Items dialog setTimeout(function () { relatedbox._id('related-add').click(); }); var selectWin = yield waitForWindow('chrome://zotero/content/selectItemsDialog.xhtml'); do { yield Zotero.Promise.delay(50); } while (!selectWin.loaded); var selectCollectionsView = selectWin.collectionsView; var selectItemsView = selectWin.itemsView; yield selectCollectionsView.waitForLoad(); yield selectItemsView.waitForLoad(); // Select the other item yield selectItemsView.selectItem(item1.id); selectWin.document.querySelector('dialog').acceptDialog(); // Wait for relations list to populate do { yield Zotero.Promise.delay(50); } while (!relatedbox.querySelectorAll('#related-grid div').length); assert.lengthOf(relatedbox.querySelectorAll('#related-grid div'), 1); var items = item1.relatedItems; assert.lengthOf(items, 1); assert.equal(items[0], item2.key); // Relation should be assigned bidirectionally var items = item2.relatedItems; assert.lengthOf(items, 1); assert.equal(items[0], item1.key); }) }) describe("Remove button", function () { it("should remove a related item", function* () { var item1 = yield createDataObject('item'); var item2 = yield createDataObject('item'); item1.addRelatedItem(item2); yield item1.saveTx(); item2.addRelatedItem(item1); yield item2.saveTx(); // Select the Related pane var tabbox = doc.getElementById('zotero-view-tabbox'); tabbox.selectedIndex = 3; var relatedbox = doc.getElementById('zotero-editpane-related'); // Wait for relations list to populate do { yield Zotero.Promise.delay(50); } while (!relatedbox.querySelectorAll('#related-grid div').length); relatedbox.querySelector('.zotero-clicky-minus').click(); // Wait for relations list to clear do { yield Zotero.Promise.delay(50); } while (relatedbox.querySelectorAll('#related-grid div').length); }) }) })