Sort descendant collections alphabetically in advanced search window

https://forums.zotero.org/discussion/50679/
This commit is contained in:
Dan Stillman 2015-07-21 00:44:38 -04:00
parent 984789d304
commit a452af6c3a
3 changed files with 149 additions and 129 deletions

View file

@ -13,13 +13,29 @@ describe("Zotero.Collections", function () {
})
it("should get all collections in a library in recursive mode", function* () {
var col1 = yield createDataObject('collection');
var col2 = yield createDataObject('collection');
var col3 = yield createDataObject('collection', { parentID: col2.id });
var cols = yield Zotero.Collections.getByLibrary(Zotero.Libraries.userLibraryID, true);
assert.isAbove(cols.length, 2);
assert.includeMembers(cols.map(col => col.id), [col1.id, col2.id, col3.id]);
assert.ok(cols.every(col => col.libraryID == Zotero.Libraries.userLibraryID));
yield createDataObject('collection', { libraryID: (yield getGroup()).libraryID });
var libraryID = Zotero.Libraries.userLibraryID;
var col1 = yield createDataObject('collection', { name: "C" });
var col2 = yield createDataObject('collection', { name: "A" });
var col3 = yield createDataObject('collection', { name: "D", parentID: col2.id });
var col4 = yield createDataObject('collection', { name: "B", parentID: col2.id });
var col5 = yield createDataObject('collection', { name: "E", parentID: col2.id });
var col6 = yield createDataObject('collection', { name: "G", parentID: col3.id });
var col7 = yield createDataObject('collection', { name: "F", parentID: col3.id });
var cols = yield Zotero.Collections.getByLibrary(libraryID, true);
assert.isAbove(cols.length, 6);
var ids = cols.map(col => col.id);
assert.includeMembers(
ids, [col1.id, col2.id, col3.id, col4.id, col5.id, col6.id, col7.id]
);
assert.isBelow(ids.indexOf(col2.id), ids.indexOf(col4.id), "A before child B");
assert.isBelow(ids.indexOf(col4.id), ids.indexOf(col3.id), "B before D");
assert.isBelow(ids.indexOf(col3.id), ids.indexOf(col7.id), "D before child F");
assert.isBelow(ids.indexOf(col7.id), ids.indexOf(col6.id), "F before G");
assert.isBelow(ids.indexOf(col6.id), ids.indexOf(col5.id), "G before D sibling E");
assert.isBelow(ids.indexOf(col5.id), ids.indexOf(col1.id), "E before A sibling C");
assert.ok(cols.every(col => col.libraryID == libraryID));
})
})