-
Notifications
You must be signed in to change notification settings - Fork 10
Expand file tree
/
Copy pathGetTemplatesByCollectionId.ts
More file actions
23 lines (20 loc) · 1.12 KB
/
GetTemplatesByCollectionId.ts
File metadata and controls
23 lines (20 loc) · 1.12 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
import { ROOT_COLLECTION_ID } from '../../../collections/domain/models/Collection'
import { UseCase } from '../../../core/domain/useCases/UseCase'
import { Template } from '../models/Template'
import { ITemplatesRepository } from '../repositories/ITemplatesRepository'
export class GetTemplatesByCollectionId implements UseCase<Template[]> {
private templatesRepository: ITemplatesRepository
constructor(templatesRepository: ITemplatesRepository) {
this.templatesRepository = templatesRepository
}
/**
* Returns a Template array containing the templates of the requested collection, given the collection identifier or alias.
*
* @param {number | string} [collectionIdOrAlias = ':root'] - A generic collection identifier, which can be either a string (for queries by CollectionAlias), or a number (for queries by CollectionId)
* If this parameter is not set, the default value is: ':root'
* @returns {Promise<Template[]>}
*/
async execute(collectionIdOrAlias: number | string = ROOT_COLLECTION_ID): Promise<Template[]> {
return await this.templatesRepository.getTemplatesByCollectionId(collectionIdOrAlias)
}
}