All checks were successful
CI / container-job (push) Successful in 49s
- Modified Api/Authors.Controller.ts to use only personal types and sort by dataset_count. - Completely rewritten AvatarController.ts. - Added new Api/CollectionsController.ts for querying collections and collection_roles. - Modified Api/DatasetController.ts to preload titles, identifier and order by server_date_published. - Modified FileController.ts to serve files from /storage/app/data/ instead of /storage/app/public. - Added new Api/UserController for requesting submitters (getSubmitters). - Improved OaiController.ts with performant DB queries for better ResumptionToken handling. - Modified Submitter/DatasetController.ts by adding a categorize method for library classification. - Rewritten ResumptionToken.ts. - Improved TokenWorkerService.ts to utilize browser fingerprint. - Edited dataset.ts by adding the doiIdentifier property. - Enhanced person.ts to improve the fullName property. - Completely rewritten AsideMenuItem.vue component. - Updated CarBoxClient.vue to use TypeScript. - Added new CardBoxDataset.vue for displaying recent datasets on the dashboard. - Completely rewritten TableSampleClients.vue for the dashboard. - Completely rewritten UserAvatar.vue. - Made small layout changes in Dashboard.vue. - Added new Category.vue for browsing scientific collections. - Adapted the pinia store in main.ts. - Added additional routes in start/routes.ts and start/api/routes.ts. - Improved referenceValidation.ts for better ISBN existence checking. - NPM dependency updates.
36 lines
1.5 KiB
TypeScript
36 lines
1.5 KiB
TypeScript
import type { HttpContext } from '@adonisjs/core/http';
|
|
import Collection from '#models/collection';
|
|
|
|
export default class CollectionsController {
|
|
public async show({ params, response }: HttpContext) {
|
|
// Get the collection id from route parameters
|
|
const collectionId = params.id;
|
|
|
|
// Find the selected collection by id
|
|
const collection = await Collection.find(collectionId);
|
|
if (!collection) {
|
|
return response.status(404).json({ message: 'Collection not found' });
|
|
}
|
|
|
|
// Query for narrower concepts: collections whose parent_id equals the selected collection's id
|
|
const narrowerCollections = await Collection.query().where('parent_id', collection.id) || [];
|
|
|
|
// For broader concept, if the selected collection has a parent_id fetch that record (otherwise null)
|
|
const broaderCollection: Collection[] | never[] | null = await (async () => {
|
|
if (collection.parent_id) {
|
|
// Try to fetch the parent...
|
|
const parent = await Collection.find(collection.parent_id)
|
|
// If found, return it wrapped in an array; if not found, return null (or empty array if you prefer)
|
|
return parent ? [parent] : null
|
|
}
|
|
return []
|
|
})()
|
|
|
|
// Return the selected collection along with its narrower and broader concepts in JSON format
|
|
return response.json({
|
|
selectedCollection: collection,
|
|
narrowerCollections,
|
|
broaderCollection,
|
|
});
|
|
}
|
|
}
|