perf: Move collection sorting to frontend (#3475)

* perf: Move collection sorting to frontend, on demand, memoized

* fix: Add default
This commit is contained in:
Tom Moor
2022-05-01 08:30:16 -07:00
committed by GitHub
parent 5cd4ecd34a
commit 25dce04046
9 changed files with 85 additions and 59 deletions

View File

@@ -1,9 +1,8 @@
import { sortNavigationNodes } from "@shared/utils/collections";
import { APM } from "@server/logging/tracing";
import Collection from "@server/models/Collection";
function present(collection: Collection) {
const data = {
return {
id: collection.id,
url: collection.url,
urlId: collection.urlId,
@@ -20,21 +19,6 @@ function present(collection: Collection) {
deletedAt: collection.deletedAt,
documents: collection.documentStructure,
};
// Handle the "sort" field being empty here for backwards compatability
if (!data.sort) {
data.sort = {
field: "title",
direction: "asc",
};
}
data.documents = sortNavigationNodes(
collection.documentStructure || [],
data.sort
);
return data;
}
export default APM.traceFunction({