@nest-omni/core 1.0.21 → 1.0.24
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.hygen/new/crud/controller.ejs.t +82 -0
- package/.hygen/new/crud/create.dto.ejs.t +12 -0
- package/.hygen/new/crud/entity.ejs.t +25 -0
- package/.hygen/new/crud/get.dto.ejs.t +19 -0
- package/.hygen/new/crud/index-dto.ejs.t +29 -0
- package/.hygen/new/crud/index-response.dto.ejs.t +18 -0
- package/.hygen/new/crud/module.ejs.t +32 -0
- package/.hygen/new/crud/prompt.js +89 -0
- package/.hygen/new/crud/service.ejs.t +76 -0
- package/.hygen/new/crud/update.dto.ejs.t +11 -0
- package/.hygen/new/module/controller.ejs.t +93 -0
- package/.hygen/new/module/create-command.ejs.t +90 -0
- package/.hygen/new/module/create.dto.ejs.t +11 -0
- package/.hygen/new/module/dto.ejs.t +24 -0
- package/.hygen/new/module/entity.ejs.t +33 -0
- package/.hygen/new/module/get-query.ejs.t +57 -0
- package/.hygen/new/module/module.ejs.t +44 -0
- package/.hygen/new/module/not-found.exception.ejs.t +18 -0
- package/.hygen/new/module/page-options.dto.ejs.t +12 -0
- package/.hygen/new/module/prompt.js +104 -0
- package/.hygen/new/module/repository.ejs.t +16 -0
- package/.hygen/new/module/service.ejs.t +139 -0
- package/.hygen/new/module/translation-dto.ejs.t +27 -0
- package/.hygen/new/module/translation-entity.ejs.t +40 -0
- package/.hygen/new/module/translation-repository.ejs.t +16 -0
- package/.hygen/new/module/update.dto.ejs.t +10 -0
- package/.hygen.js +116 -0
- package/package.json +1 -1
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.controllerFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('Controller') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
moduleName = h.moduleName(name);
|
|
10
|
+
fileName = h.fileName(name);
|
|
11
|
+
ControllerName = h.ControllerName(name);
|
|
12
|
+
ServiceName = h.ServiceName(name);
|
|
13
|
+
serviceName = h.changeCase.camel(ServiceName);
|
|
14
|
+
createFunctionName = 'create' + ClassName;
|
|
15
|
+
updateFunctionName = 'update' + ClassName;
|
|
16
|
+
deleteFunctionName = 'delete' + ClassName;
|
|
17
|
+
getAllFunctionName = 'getAll' + ClassName;
|
|
18
|
+
getSingleFunctionName = 'getSingle' + ClassName;
|
|
19
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
20
|
+
createDtoName = h.changeCase.camel(CreateDtoName);
|
|
21
|
+
UpdateDtoName = h.UpdateDtoName(name);
|
|
22
|
+
updateDtoName = h.changeCase.camel(UpdateDtoName);
|
|
23
|
+
PageOptionsDtoName = h.PageOptionsDtoName(name);
|
|
24
|
+
pageOptionsDtoName = h.changeCase.camel(PageOptionsDtoName);
|
|
25
|
+
DtoName = h.DtoName(name);
|
|
26
|
+
createDtoFileName = h.createDtoFileName(name);
|
|
27
|
+
dtoFileName = h.dtoFileName(name);
|
|
28
|
+
pageOptionsDtoFileName = h.pageOptionsDtoFileName(name);
|
|
29
|
+
updateDtoFileName = h.updateDtoFileName(name);
|
|
30
|
+
serviceFileName = h.serviceFileName(name);
|
|
31
|
+
EntityName = h.EntityName(name);
|
|
32
|
+
entityName = h.changeCase.camel(EntityName);
|
|
33
|
+
entityFileName = h.entityFileName(name);
|
|
34
|
+
GetDtoName = 'Get' + DtoName;
|
|
35
|
+
getDtoFileName = 'get-' + dtoFileName;
|
|
36
|
+
|
|
37
|
+
%>import { Body, Controller, Delete, Put, Post } from '@nestjs/common';
|
|
38
|
+
import { ApiBody, ApiOperation, ApiTags } from '@nestjs/swagger';
|
|
39
|
+
import { Crud } from '@dataui/crud';
|
|
40
|
+
|
|
41
|
+
import { <%= EntityName %> } from './<%= entityFileName %>';
|
|
42
|
+
import { <%= ServiceName %> } from './<%= serviceFileName %>';
|
|
43
|
+
|
|
44
|
+
import { dto } from './requests';
|
|
45
|
+
import { serialize } from './responses';
|
|
46
|
+
import { targetConstructorToSchema } from '@nest-omni/core/validator-json';
|
|
47
|
+
import { I18nService } from 'nestjs-i18n';
|
|
48
|
+
import { BulkIdDto } from '@nest-omni/core/common/dto/bulk-id.dto';
|
|
49
|
+
|
|
50
|
+
@Crud({
|
|
51
|
+
model: { type: <%= EntityName %> },
|
|
52
|
+
dto,
|
|
53
|
+
serialize,
|
|
54
|
+
query: {
|
|
55
|
+
alwaysPaginate: true,
|
|
56
|
+
},
|
|
57
|
+
})
|
|
58
|
+
@Controller('<%= h.inflection.pluralize(fileName).toLowerCase() %>')
|
|
59
|
+
@ApiTags('<%= h.inflection.pluralize(fileName).toLowerCase() %>')
|
|
60
|
+
export class <%= ControllerName %> {
|
|
61
|
+
constructor(
|
|
62
|
+
public service: <%= ServiceName %>,
|
|
63
|
+
public i18n: I18nService,
|
|
64
|
+
) {}
|
|
65
|
+
|
|
66
|
+
@Post('validator')
|
|
67
|
+
async getCreateRules(): Promise<any> {
|
|
68
|
+
return targetConstructorToSchema(dto.create, this.i18n);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
@Put('validator')
|
|
72
|
+
async getUpdateRules(): Promise<any> {
|
|
73
|
+
return targetConstructorToSchema(dto.update, this.i18n);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
@Delete('/bulk')
|
|
77
|
+
@ApiBody({ type: BulkIdDto })
|
|
78
|
+
@ApiOperation({ summary: 'bulk deletion of records' })
|
|
79
|
+
async deleteBulk(@Body() bulkId: BulkIdDto) {
|
|
80
|
+
return await this.service.deleteBulk(bulkId);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/requests/<%= h.createDtoFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('CreateDTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
10
|
+
|
|
11
|
+
%>import { <%= EntityName %> } from '../<%= entityFileName %>';
|
|
12
|
+
export class <%= CreateDtoName %> extends <%= EntityName %> {}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.entityFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('Entity') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
ClassName = h.ClassName(name);
|
|
8
|
+
DtoName = h.DtoName(name);
|
|
9
|
+
fieldName = h.changeCase.camel(ClassName);
|
|
10
|
+
dtoFileName = h.dtoFileName(name);
|
|
11
|
+
translationEntityFileName = h.translationEntityFileName(name);
|
|
12
|
+
DtoOptionName = h.DtoOptionName(name);
|
|
13
|
+
TableName = h.TableName(name);
|
|
14
|
+
EntityName = h.EntityName(name);
|
|
15
|
+
TranslationEntityName = h.TranslationEntityName(name);
|
|
16
|
+
translationEntityName = h.changeCase.camel(TranslationEntityName);
|
|
17
|
+
%>import { Entity, Column } from 'typeorm';
|
|
18
|
+
|
|
19
|
+
import { AbstractEntity } from '@nest-omni/core/common/abstract.entity';
|
|
20
|
+
|
|
21
|
+
@Entity({ name: '<%= TableName %>' })
|
|
22
|
+
export class <%= EntityName %> extends AbstractEntity {
|
|
23
|
+
@Column({ type: 'varchar', nullable: false })
|
|
24
|
+
name: string;
|
|
25
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/responses/get-<%= h.dtoFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('DTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
DtoName = h.DtoName(name);
|
|
9
|
+
DtoOptionName = h.DtoOptionName(name);
|
|
10
|
+
EntityName = h.EntityName(name);
|
|
11
|
+
entityName = h.changeCase.camel(EntityName);
|
|
12
|
+
entityFileName = h.entityFileName(name);
|
|
13
|
+
|
|
14
|
+
GetDtoName = 'Get' + DtoName;
|
|
15
|
+
getDtoFileName = 'get-' + dtoFileName;
|
|
16
|
+
|
|
17
|
+
%>import { <%= EntityName %> } from '../<%= entityFileName %>';
|
|
18
|
+
|
|
19
|
+
export class <%= GetDtoName %> extends <%= EntityName %> {}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/requests/index.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('DTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
DtoName = h.DtoName(name);
|
|
9
|
+
DtoOptionName = h.DtoOptionName(name);
|
|
10
|
+
|
|
11
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
12
|
+
createDtoName = h.changeCase.camel(CreateDtoName);
|
|
13
|
+
UpdateDtoName = h.UpdateDtoName(name);
|
|
14
|
+
updateDtoName = h.changeCase.camel(UpdateDtoName);
|
|
15
|
+
|
|
16
|
+
createDtoFileName = h.createDtoFileName(name);
|
|
17
|
+
updateDtoFileName = h.updateDtoFileName(name);
|
|
18
|
+
|
|
19
|
+
EntityName = h.EntityName(name);
|
|
20
|
+
entityName = h.changeCase.camel(EntityName);
|
|
21
|
+
entityFileName = h.entityFileName(name);
|
|
22
|
+
|
|
23
|
+
%>import { <%= CreateDtoName %> } from './<%= createDtoFileName %>';
|
|
24
|
+
import { <%= UpdateDtoName %> } from './<%= updateDtoFileName %>';
|
|
25
|
+
|
|
26
|
+
export const dto = {
|
|
27
|
+
create: <%= CreateDtoName %>,
|
|
28
|
+
update: <%= UpdateDtoName %>,
|
|
29
|
+
};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/responses/index.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('DTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
DtoName = h.DtoName(name);
|
|
9
|
+
dtoFileName = h.dtoFileName(name);
|
|
10
|
+
|
|
11
|
+
GetDtoName = 'Get' + DtoName;
|
|
12
|
+
getDtoFileName = 'get-' + dtoFileName;
|
|
13
|
+
|
|
14
|
+
%>import { <%= GetDtoName %> } from './<%= getDtoFileName %>';
|
|
15
|
+
|
|
16
|
+
export const serialize = {
|
|
17
|
+
get: <%= GetDtoName %>,
|
|
18
|
+
};
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.moduleFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
---
|
|
5
|
+
<%
|
|
6
|
+
|
|
7
|
+
ModuleName = h.ModuleName(name);
|
|
8
|
+
fileName = h.inflection.dasherize(name);
|
|
9
|
+
|
|
10
|
+
ControllerName = h.ControllerName(name);
|
|
11
|
+
controllerFileName = h.controllerFileName(name);
|
|
12
|
+
|
|
13
|
+
ServiceName = h.ServiceName(name);
|
|
14
|
+
serviceFileName = h.serviceFileName(name);
|
|
15
|
+
|
|
16
|
+
EntityName = h.EntityName(name);
|
|
17
|
+
entityName = h.changeCase.camel(EntityName);
|
|
18
|
+
entityFileName = h.entityFileName(name);
|
|
19
|
+
|
|
20
|
+
%>import { Module } from '@nestjs/common';
|
|
21
|
+
import { TypeOrmModule } from '@nestjs/typeorm';
|
|
22
|
+
|
|
23
|
+
import { <%= ControllerName %> } from './<%= controllerFileName %>';
|
|
24
|
+
import { <%= EntityName %> } from './<%= entityFileName %>';
|
|
25
|
+
import { <%= ServiceName %> } from './<%= serviceFileName %>';
|
|
26
|
+
|
|
27
|
+
@Module({
|
|
28
|
+
imports: [TypeOrmModule.forFeature([<%= EntityName %>])],
|
|
29
|
+
providers: [<%= ServiceName %>],
|
|
30
|
+
controllers: [<%= ControllerName %>],
|
|
31
|
+
})
|
|
32
|
+
export class <%= ModuleName %> {}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
'use strict'
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
prompt: ({ prompter, args }) => {
|
|
5
|
+
return prompter.prompt([
|
|
6
|
+
{
|
|
7
|
+
type: 'input',
|
|
8
|
+
name: 'name',
|
|
9
|
+
message: 'Name:',
|
|
10
|
+
validate(value) {
|
|
11
|
+
if (!value.length) {
|
|
12
|
+
return 'Module must have a name.';
|
|
13
|
+
}
|
|
14
|
+
return true;
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
type: 'MultiSelect',
|
|
19
|
+
name: 'blocks',
|
|
20
|
+
message: 'Blocks:',
|
|
21
|
+
initial: [
|
|
22
|
+
'Controller',
|
|
23
|
+
'CreateCommand',
|
|
24
|
+
'CreateDTO',
|
|
25
|
+
'DTO',
|
|
26
|
+
'Entity',
|
|
27
|
+
'GetQuery',
|
|
28
|
+
//'Module',
|
|
29
|
+
// 'NotFoundException',
|
|
30
|
+
'PageOptionsDTO',
|
|
31
|
+
'Repository',
|
|
32
|
+
'Service',
|
|
33
|
+
'UpdateDTO'
|
|
34
|
+
],
|
|
35
|
+
choices: [
|
|
36
|
+
{
|
|
37
|
+
name: 'Controller',
|
|
38
|
+
value: 'controller',
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
name: 'CreateCommand',
|
|
42
|
+
value: 'create-command',
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
name: 'CreateDTO',
|
|
46
|
+
value: 'create-dto',
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
name: 'DTO',
|
|
50
|
+
value: 'dto',
|
|
51
|
+
},
|
|
52
|
+
{
|
|
53
|
+
name: 'Entity',
|
|
54
|
+
value: 'entity',
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
name: 'GetQuery',
|
|
58
|
+
value: 'get-query',
|
|
59
|
+
},
|
|
60
|
+
{
|
|
61
|
+
name: 'NotFoundException',
|
|
62
|
+
value: 'not-found-exception',
|
|
63
|
+
},
|
|
64
|
+
{
|
|
65
|
+
name: 'PageOptionsDTO',
|
|
66
|
+
value: 'page-options-dto',
|
|
67
|
+
},
|
|
68
|
+
{
|
|
69
|
+
name: 'Repository',
|
|
70
|
+
value: 'repository',
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
name: 'Service',
|
|
74
|
+
value: 'service',
|
|
75
|
+
},
|
|
76
|
+
{
|
|
77
|
+
name: 'UpdateDTO',
|
|
78
|
+
value: 'update-dto',
|
|
79
|
+
},
|
|
80
|
+
],
|
|
81
|
+
}
|
|
82
|
+
])
|
|
83
|
+
.then(answer => {
|
|
84
|
+
//// For debugging
|
|
85
|
+
// console.log(answer)
|
|
86
|
+
return answer;
|
|
87
|
+
})
|
|
88
|
+
}
|
|
89
|
+
}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.serviceFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('Service') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
fieldName = h.changeCase.camel(ClassName);
|
|
10
|
+
|
|
11
|
+
DtoName = h.DtoName(name);
|
|
12
|
+
dtoFileName = h.dtoFileName(name);
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
CreateCommandName = h.CreateCommandName(name);
|
|
16
|
+
createCommandFileName = h.createCommandFileName(name);
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
EntityName = h.EntityName(name);
|
|
20
|
+
entityName = h.changeCase.camel(EntityName);
|
|
21
|
+
entityFileName = h.entityFileName(name);
|
|
22
|
+
|
|
23
|
+
ServiceName = h.ServiceName(name);
|
|
24
|
+
|
|
25
|
+
UpdateDtoName = h.UpdateDtoName(name);
|
|
26
|
+
updateDtoFileName = h.updateDtoFileName(name);
|
|
27
|
+
updateDtoName = h.changeCase.camel(UpdateDtoName);
|
|
28
|
+
|
|
29
|
+
fileName = h.fileName(name);
|
|
30
|
+
|
|
31
|
+
RepositoryName = h.RepositoryName(name);
|
|
32
|
+
repositoryName = h.changeCase.camel(RepositoryName);
|
|
33
|
+
repositoryFileName = h.repositoryFileName(name);
|
|
34
|
+
|
|
35
|
+
NotFoundExceptionName = h.NotFoundExceptionName(name);
|
|
36
|
+
notFoundExceptionFileName = h.notFoundExceptionFileName(name);
|
|
37
|
+
|
|
38
|
+
createFunctionName = 'create' + ClassName;
|
|
39
|
+
updateFunctionName = 'update' + ClassName;
|
|
40
|
+
deleteFunctionName = 'delete' + ClassName;
|
|
41
|
+
getAllFunctionName = 'getAll' + ClassName;
|
|
42
|
+
getSingleFunctionName = 'getSingle' + ClassName;
|
|
43
|
+
controllerName = moduleName + 'Controller';
|
|
44
|
+
serviceName = moduleName + 'Service';
|
|
45
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
46
|
+
createDtoFileName = h.createDtoFileName(name);
|
|
47
|
+
|
|
48
|
+
PageOptionsDtoName = h.PageOptionsDtoName(name);
|
|
49
|
+
pageOptionsDtoName = h.changeCase.camel(PageOptionsDtoName);
|
|
50
|
+
pageOptionsDtoFileName = h.pageOptionsDtoFileName(name);
|
|
51
|
+
|
|
52
|
+
%>import { Injectable } from '@nestjs/common';
|
|
53
|
+
import { InjectRepository } from '@nestjs/typeorm';
|
|
54
|
+
import { TypeOrmCrudService } from '@dataui/crud-typeorm';
|
|
55
|
+
import { I18nService } from 'nestjs-i18n';
|
|
56
|
+
import { BulkIdDto } from '@nest-omni/core/common/dto/bulk-id.dto';
|
|
57
|
+
import { Repository } from 'typeorm';
|
|
58
|
+
import { <%= EntityName %> } from './<%= entityFileName %>';
|
|
59
|
+
|
|
60
|
+
@Injectable()
|
|
61
|
+
export class <%= ServiceName %> extends TypeOrmCrudService<<%= EntityName %>> {
|
|
62
|
+
constructor(
|
|
63
|
+
@InjectRepository(<%= EntityName %>) repo:Repository<<%= EntityName %>>,
|
|
64
|
+
public i18n: I18nService,
|
|
65
|
+
) {
|
|
66
|
+
super(repo);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
async deleteBulk(bulkIdDto: BulkIdDto) {
|
|
70
|
+
return this.repo
|
|
71
|
+
.createQueryBuilder()
|
|
72
|
+
.delete()
|
|
73
|
+
.andWhereInIds(bulkIdDto.id)
|
|
74
|
+
.execute();
|
|
75
|
+
}
|
|
76
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/requests/<%= h.updateDtoFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('UpdateDTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
UpdateDtoName = h.UpdateDtoName(name);
|
|
9
|
+
|
|
10
|
+
%>import { <%= EntityName %> } from '../<%= entityFileName %>';
|
|
11
|
+
export class <%= UpdateDtoName %> extends <%= EntityName %> {}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.controllerFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('Controller') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
moduleName = h.moduleName(name);
|
|
10
|
+
fileName = h.fileName(name);
|
|
11
|
+
ControllerName = h.ControllerName(name);
|
|
12
|
+
ServiceName = h.ServiceName(name);
|
|
13
|
+
serviceName = h.changeCase.camel(ServiceName);
|
|
14
|
+
createFunctionName = 'create' + ClassName;
|
|
15
|
+
updateFunctionName = 'update' + ClassName;
|
|
16
|
+
deleteFunctionName = 'delete' + ClassName;
|
|
17
|
+
getAllFunctionName = 'getAll' + ClassName;
|
|
18
|
+
getSingleFunctionName = 'getSingle' + ClassName;
|
|
19
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
20
|
+
createDtoName = h.changeCase.camel(CreateDtoName);
|
|
21
|
+
UpdateDtoName = h.UpdateDtoName(name);
|
|
22
|
+
updateDtoName = h.changeCase.camel(UpdateDtoName);
|
|
23
|
+
PageOptionsDtoName = h.PageOptionsDtoName(name);
|
|
24
|
+
pageOptionsDtoName = h.changeCase.camel(PageOptionsDtoName);
|
|
25
|
+
DtoName = h.DtoName(name);
|
|
26
|
+
createDtoFileName = h.createDtoFileName(name);
|
|
27
|
+
dtoFileName = h.dtoFileName(name);
|
|
28
|
+
pageOptionsDtoFileName = h.pageOptionsDtoFileName(name);
|
|
29
|
+
updateDtoFileName = h.updateDtoFileName(name);
|
|
30
|
+
serviceFileName = h.serviceFileName(name);
|
|
31
|
+
|
|
32
|
+
%>import {
|
|
33
|
+
Body,
|
|
34
|
+
Controller,
|
|
35
|
+
Delete,
|
|
36
|
+
Get,
|
|
37
|
+
HttpCode,
|
|
38
|
+
HttpStatus,
|
|
39
|
+
Post,
|
|
40
|
+
Put,
|
|
41
|
+
Query,
|
|
42
|
+
} from '@nestjs/common';
|
|
43
|
+
import { ApiTags } from '@nestjs/swagger';
|
|
44
|
+
|
|
45
|
+
import type { PageDto } from '@omni/core/common/dto/page.dto';
|
|
46
|
+
import { <%= CreateDtoName %> } from './dtos/<%= createDtoFileName %>';
|
|
47
|
+
import type { <%= DtoName %> } from './dtos/<%= dtoFileName %>';
|
|
48
|
+
import { <%= PageOptionsDtoName %> } from './dtos/<%= pageOptionsDtoFileName %>';
|
|
49
|
+
import { <%= UpdateDtoName %> } from './dtos/<%= updateDtoFileName %>';
|
|
50
|
+
import { <%= ServiceName %> } from './<%= serviceFileName %>';
|
|
51
|
+
|
|
52
|
+
@Controller('<%= h.inflection.pluralize(fileName).toLowerCase() %>')
|
|
53
|
+
@ApiTags('<%= h.inflection.pluralize(fileName).toLowerCase() %>')
|
|
54
|
+
export class <%= ControllerName %> {
|
|
55
|
+
constructor(private <%= serviceName %>: <%= ServiceName %>) {}
|
|
56
|
+
|
|
57
|
+
@Post()
|
|
58
|
+
@HttpCode(HttpStatus.CREATED)
|
|
59
|
+
async <%= createFunctionName %>(@Body() <%= createDtoName %>: <%= CreateDtoName %>) {
|
|
60
|
+
const entity = await this.<%= serviceName %>.<%= createFunctionName %>(<%= createDtoName %>);
|
|
61
|
+
|
|
62
|
+
return entity.toDto();
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
@Get()
|
|
66
|
+
@HttpCode(HttpStatus.OK)
|
|
67
|
+
<%= getAllFunctionName %>(@Query() <%= pageOptionsDtoName %>: <%= PageOptionsDtoName %>): Promise<PageDto<<%= DtoName %>>> {
|
|
68
|
+
return this.<%= serviceName %>.<%= getAllFunctionName %>(<%= pageOptionsDtoName %>);
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
@Get(':id')
|
|
72
|
+
@HttpCode(HttpStatus.OK)
|
|
73
|
+
async <%= getSingleFunctionName %>(@UUIDParam('id') id: Uuid): Promise<<%= DtoName %>> {
|
|
74
|
+
const entity = await this.<%= serviceName %>.<%= getSingleFunctionName %>(id);
|
|
75
|
+
|
|
76
|
+
return entity.toDto();
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
@Put(':id')
|
|
80
|
+
@HttpCode(HttpStatus.ACCEPTED)
|
|
81
|
+
<%= updateFunctionName %>(
|
|
82
|
+
@UUIDParam('id') id: Uuid,
|
|
83
|
+
@Body() <%= updateDtoName %>: <%= UpdateDtoName %>,
|
|
84
|
+
): Promise<void> {
|
|
85
|
+
return this.<%= serviceName %>.<%= updateFunctionName %>(id, <%= updateDtoName %>);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
@Delete(':id')
|
|
89
|
+
@HttpCode(HttpStatus.ACCEPTED)
|
|
90
|
+
async <%= deleteFunctionName %>(@UUIDParam('id') id: Uuid): Promise<void> {
|
|
91
|
+
await this.<%= serviceName %>.<%= deleteFunctionName %>(id);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/commands/<%= h.createCommandFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('CreateCommand') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
fieldName = h.changeCase.camel(ClassName);
|
|
10
|
+
|
|
11
|
+
CreateCommandName = h.CreateCommandName(name);
|
|
12
|
+
CreateHandlerName = h.CreateHandlerName(name);
|
|
13
|
+
|
|
14
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
15
|
+
createDtoName = h.changeCase.camel(CreateDtoName);
|
|
16
|
+
createDtoFileName = h.createDtoFileName(name);
|
|
17
|
+
|
|
18
|
+
EntityName = h.EntityName(name);
|
|
19
|
+
entityName = h.changeCase.camel(EntityName);
|
|
20
|
+
|
|
21
|
+
EntityName = h.EntityName(name);
|
|
22
|
+
entityName = h.changeCase.camel(EntityName);
|
|
23
|
+
entityFileName = h.entityFileName(name);
|
|
24
|
+
|
|
25
|
+
RepositoryName = h.RepositoryName(name);
|
|
26
|
+
TranslationRepositoryName = h.TranslationRepositoryName(name);
|
|
27
|
+
repositoryName = h.changeCase.camel(RepositoryName);
|
|
28
|
+
translationRepositoryName = h.changeCase.camel(TranslationRepositoryName);
|
|
29
|
+
repositoryFileName = h.repositoryFileName(name);
|
|
30
|
+
|
|
31
|
+
TranslationEntityName = h.TranslationEntityName(name);
|
|
32
|
+
TranslationDtoName = h.TranslationDtoName(name);
|
|
33
|
+
translationEntityFileName = h.translationEntityFileName(name);
|
|
34
|
+
translationRepositoryFileName = h.translationRepositoryFileName(name);
|
|
35
|
+
translationEntityName = h.changeCase.camel(TranslationEntityName);
|
|
36
|
+
|
|
37
|
+
%>import type { ICommand, ICommandHandler } from '@nestjs/cqrs';
|
|
38
|
+
import { CommandHandler } from '@nestjs/cqrs';
|
|
39
|
+
import { find } from 'lodash';
|
|
40
|
+
|
|
41
|
+
import type { <%= CreateDtoName %> } from '../dtos/<%= createDtoFileName %>';
|
|
42
|
+
import type { <%= EntityName %> } from '../<%= entityFileName %>';
|
|
43
|
+
import { <%= RepositoryName %> } from '../<%= repositoryFileName %>';
|
|
44
|
+
import type { <%= TranslationEntityName %> } from '../<%= translationEntityFileName %>';
|
|
45
|
+
import { <%= TranslationRepositoryName %> } from '../<%= translationRepositoryFileName %>';
|
|
46
|
+
|
|
47
|
+
export class <%= CreateCommandName %> implements ICommand {
|
|
48
|
+
constructor(
|
|
49
|
+
public readonly <%=createDtoName %>: <%= CreateDtoName %>,
|
|
50
|
+
) {}
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
@CommandHandler(<%= CreateCommandName %>)
|
|
54
|
+
export class <%= CreateHandlerName %>
|
|
55
|
+
implements ICommandHandler<<%= CreateCommandName %>, <%= EntityName %>>
|
|
56
|
+
{
|
|
57
|
+
constructor(
|
|
58
|
+
private <%= repositoryName %>: <%= RepositoryName %>,
|
|
59
|
+
private <%= translationRepositoryName %>: <%= TranslationRepositoryName %>,
|
|
60
|
+
) {}
|
|
61
|
+
|
|
62
|
+
async execute(command: <%= CreateCommandName %>) {
|
|
63
|
+
const { <%=createDtoName %> } = command;
|
|
64
|
+
const <%= entityName %> = this.<%= repositoryName %>.create();
|
|
65
|
+
const translations: <%= TranslationEntityName %>[] = [];
|
|
66
|
+
|
|
67
|
+
await this.<%= repositoryName %>.save(<%= entityName %>);
|
|
68
|
+
|
|
69
|
+
// FIXME: Create generic function for translation creation
|
|
70
|
+
for (const createTranslationDto of <%=createDtoName %>.title) {
|
|
71
|
+
const languageCode = createTranslationDto.languageCode;
|
|
72
|
+
const translationEntity = this.<%= translationRepositoryName %>.create({
|
|
73
|
+
<%= fieldName %>Id: <%= entityName %>.id,
|
|
74
|
+
languageCode,
|
|
75
|
+
title: createTranslationDto.text,
|
|
76
|
+
description: find(<%=createDtoName %>.description, {
|
|
77
|
+
languageCode,
|
|
78
|
+
})!.text,
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
translations.push(translationEntity);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
await this.<%= translationRepositoryName %>.save(translations);
|
|
85
|
+
|
|
86
|
+
<%= entityName %>.translations = translations;
|
|
87
|
+
|
|
88
|
+
return <%= entityName %>;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/dtos/<%= h.createDtoFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('CreateDTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
10
|
+
|
|
11
|
+
%>export class <%= CreateDtoName %> {}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/dtos/<%= h.dtoFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('DTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
DtoName = h.DtoName(name);
|
|
9
|
+
DtoOptionName = h.DtoOptionName(name);
|
|
10
|
+
EntityName = h.EntityName(name);
|
|
11
|
+
entityName = h.changeCase.camel(EntityName);
|
|
12
|
+
entityFileName = h.entityFileName(name);
|
|
13
|
+
|
|
14
|
+
%>import { AbstractDto } from '@omni/core/common/dto/abstract.dto';
|
|
15
|
+
import type { <%= EntityName %> } from '../<%= entityFileName %>';
|
|
16
|
+
|
|
17
|
+
export interface <%= DtoOptionName %> {
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export class <%= DtoName %> extends AbstractDto {
|
|
21
|
+
constructor(entityName: <%= EntityName %>, options?: <%= DtoOptionName %>) {
|
|
22
|
+
super(entityName);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.entityFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('Entity') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
ClassName = h.ClassName(name);
|
|
8
|
+
DtoName = h.DtoName(name);
|
|
9
|
+
fieldName = h.changeCase.camel(ClassName);
|
|
10
|
+
dtoFileName = h.dtoFileName(name);
|
|
11
|
+
translationEntityFileName = h.translationEntityFileName(name);
|
|
12
|
+
DtoOptionName = h.DtoOptionName(name);
|
|
13
|
+
TableName = h.TableName(name);
|
|
14
|
+
EntityName = h.EntityName(name);
|
|
15
|
+
TranslationEntityName = h.TranslationEntityName(name);
|
|
16
|
+
translationEntityName = h.changeCase.camel(TranslationEntityName);
|
|
17
|
+
%>import { Entity, OneToMany } from 'typeorm';
|
|
18
|
+
|
|
19
|
+
import { AbstractEntity } from '@omni/core/common/abstract.entity';
|
|
20
|
+
import { UseDto } from '@omni/core/decorators';
|
|
21
|
+
import type { <%= DtoOptionName %> } from './dtos/<%= dtoFileName %>';
|
|
22
|
+
import { <%= DtoName %> } from './dtos/<%= dtoFileName %>';
|
|
23
|
+
import { <%= TranslationEntityName %> } from './<%= translationEntityFileName %>';
|
|
24
|
+
|
|
25
|
+
@Entity({ name: '<%= TableName %>' })
|
|
26
|
+
@UseDto(<%= DtoName %>)
|
|
27
|
+
export class <%= EntityName %> extends AbstractEntity<<%= DtoName %>, <%= DtoOptionName %>> {
|
|
28
|
+
@OneToMany(
|
|
29
|
+
() => <%= TranslationEntityName %>,
|
|
30
|
+
(<%= translationEntityName %>) => <%= translationEntityName %>.<%= fieldName %>,
|
|
31
|
+
)
|
|
32
|
+
translations: <%= TranslationEntityName %>[];
|
|
33
|
+
}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/queries/<%= h.getQueryFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('GetQuery') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
fieldName = h.changeCase.camel(ClassName);
|
|
10
|
+
|
|
11
|
+
GetQueryName = h.GetQueryName(name);
|
|
12
|
+
GetHandlerName = h.GetHandlerName(name);
|
|
13
|
+
|
|
14
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
15
|
+
createDtoName = h.changeCase.camel(CreateDtoName);
|
|
16
|
+
createDtoFileName = h.createDtoFileName(name);
|
|
17
|
+
|
|
18
|
+
EntityName = h.EntityName(name);
|
|
19
|
+
entityName = h.changeCase.camel(EntityName);
|
|
20
|
+
|
|
21
|
+
EntityName = h.EntityName(name);
|
|
22
|
+
entityName = h.changeCase.camel(EntityName);
|
|
23
|
+
entityFileName = h.entityFileName(name);
|
|
24
|
+
|
|
25
|
+
RepositoryName = h.RepositoryName(name);
|
|
26
|
+
TranslationRepositoryName = h.TranslationRepositoryName(name);
|
|
27
|
+
repositoryName = h.changeCase.camel(RepositoryName);
|
|
28
|
+
translationRepositoryName = h.changeCase.camel(TranslationRepositoryName);
|
|
29
|
+
repositoryFileName = h.repositoryFileName(name);
|
|
30
|
+
|
|
31
|
+
TranslationEntityName = h.TranslationEntityName(name);
|
|
32
|
+
TranslationDtoName = h.TranslationDtoName(name);
|
|
33
|
+
translationEntityFileName = h.translationEntityFileName(name);
|
|
34
|
+
translationRepositoryFileName = h.translationRepositoryFileName(name);
|
|
35
|
+
translationEntityName = h.changeCase.camel(TranslationEntityName);
|
|
36
|
+
|
|
37
|
+
%>import type { ICommand, IQueryHandler } from '@nestjs/cqrs';
|
|
38
|
+
import { QueryHandler } from '@nestjs/cqrs';
|
|
39
|
+
|
|
40
|
+
import { <%= RepositoryName %> } from '../<%= repositoryFileName %>';
|
|
41
|
+
|
|
42
|
+
export class <%= GetQueryName %> implements ICommand {
|
|
43
|
+
constructor(
|
|
44
|
+
public readonly userId: Uuid,
|
|
45
|
+
) {}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
@QueryHandler(<%= GetQueryName %>)
|
|
49
|
+
export class <%= GetHandlerName %> implements IQueryHandler<<%= GetQueryName %>> {
|
|
50
|
+
constructor(private <%= repositoryName %>: <%= RepositoryName %>) {}
|
|
51
|
+
|
|
52
|
+
async execute(query: <%= GetQueryName %>) {
|
|
53
|
+
return this.<%= repositoryName %>.find({
|
|
54
|
+
userId: query.userId,
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.moduleFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
---
|
|
5
|
+
<%
|
|
6
|
+
|
|
7
|
+
ModuleName = h.ModuleName(name);
|
|
8
|
+
fileName = h.inflection.dasherize(name);
|
|
9
|
+
|
|
10
|
+
ControllerName = h.ControllerName(name);
|
|
11
|
+
controllerFileName = h.controllerFileName(name);
|
|
12
|
+
|
|
13
|
+
ServiceName = h.ServiceName(name);
|
|
14
|
+
serviceFileName = h.serviceFileName(name);
|
|
15
|
+
|
|
16
|
+
RepositoryName = h.RepositoryName(name);
|
|
17
|
+
repositoryFileName = h.repositoryFileName(name);
|
|
18
|
+
|
|
19
|
+
createCommandFileName = h.createCommandFileName(name);
|
|
20
|
+
getQueryFileName = h.getQueryFileName(name);
|
|
21
|
+
|
|
22
|
+
%>import { Module } from '@nestjs/common';
|
|
23
|
+
import { TypeOrmModule } from '@nestjs/typeorm';
|
|
24
|
+
|
|
25
|
+
import { <%= CreateHandlerName %> } from './commands/<%= createCommandFileName %>';
|
|
26
|
+
import { <%= ControllerName %> } from './<%= controllerFileName %>';
|
|
27
|
+
import { <%= RepositoryName %> } from './<%= repositoryFileName %>';
|
|
28
|
+
import { <%= TranslationRepositoryName %> } from './<%= translationRepositoryFileName %>';
|
|
29
|
+
import { <%= ServiceName %> } from './<%= serviceFileName %>';
|
|
30
|
+
import { <%= GetHandlerName %> } from './queries/<%= getQueryFileName %>';
|
|
31
|
+
|
|
32
|
+
export const handlers = [
|
|
33
|
+
<%= CreateHandlerName %>,
|
|
34
|
+
<%= GetHandlerName %>,
|
|
35
|
+
];
|
|
36
|
+
|
|
37
|
+
@Module({
|
|
38
|
+
imports: [
|
|
39
|
+
TypeOrmModule.forFeature([<%= RepositoryName %>, <%= TranslationRepositoryName %>]),
|
|
40
|
+
],
|
|
41
|
+
providers: [<%= ServiceName %>, ...handlers],
|
|
42
|
+
controllers: [<%= ControllerName %>],
|
|
43
|
+
})
|
|
44
|
+
export class <%= ModuleName %> {}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/exceptions/<%= h.notFoundExceptionFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('NotFoundException') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
fieldName = h.changeCase.camel(ClassName);
|
|
10
|
+
NotFoundExceptionName = h.NotFoundExceptionName(name);
|
|
11
|
+
|
|
12
|
+
%>import { NotFoundException } from '@nestjs/common';
|
|
13
|
+
|
|
14
|
+
export class <%= NotFoundExceptionName %> extends NotFoundException {
|
|
15
|
+
constructor(error?: string) {
|
|
16
|
+
super('error.<%= fieldName %>NotFound', error);
|
|
17
|
+
}
|
|
18
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/dtos/<%= h.pageOptionsDtoFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('PageOptionsDTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
PageOptionsDtoName = h.PageOptionsDtoName(name);
|
|
9
|
+
|
|
10
|
+
%>import { PageOptionsDto } from '@omni/core/common/dto/page-options.dto';
|
|
11
|
+
|
|
12
|
+
export class <%= PageOptionsDtoName %> extends PageOptionsDto {}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
'use strict'
|
|
2
|
+
|
|
3
|
+
module.exports = {
|
|
4
|
+
prompt: ({ prompter, args }) => {
|
|
5
|
+
return prompter.prompt([
|
|
6
|
+
{
|
|
7
|
+
type: 'input',
|
|
8
|
+
name: 'name',
|
|
9
|
+
message: 'Name:',
|
|
10
|
+
validate(value) {
|
|
11
|
+
if (!value.length) {
|
|
12
|
+
return 'Module must have a name.';
|
|
13
|
+
}
|
|
14
|
+
return true;
|
|
15
|
+
},
|
|
16
|
+
},
|
|
17
|
+
{
|
|
18
|
+
type: 'MultiSelect',
|
|
19
|
+
name: 'blocks',
|
|
20
|
+
message: 'Blocks:',
|
|
21
|
+
initial: [
|
|
22
|
+
'Controller',
|
|
23
|
+
'CreateCommand',
|
|
24
|
+
'CreateDTO',
|
|
25
|
+
'DTO',
|
|
26
|
+
'Entity',
|
|
27
|
+
'GetQuery',
|
|
28
|
+
//'Module',
|
|
29
|
+
'NotFoundException',
|
|
30
|
+
'PageOptionsDTO',
|
|
31
|
+
'Repository',
|
|
32
|
+
'Service',
|
|
33
|
+
'TranslationDTO',
|
|
34
|
+
'TranslationEntity',
|
|
35
|
+
'TranslationRepository',
|
|
36
|
+
'UpdateDTO'
|
|
37
|
+
],
|
|
38
|
+
choices: [
|
|
39
|
+
{
|
|
40
|
+
name: 'Controller',
|
|
41
|
+
value: 'controller',
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
name: 'CreateCommand',
|
|
45
|
+
value: 'create-command',
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
name: 'CreateDTO',
|
|
49
|
+
value: 'create-dto',
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
name: 'DTO',
|
|
53
|
+
value: 'dto',
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
name: 'Entity',
|
|
57
|
+
value: 'entity',
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
name: 'GetQuery',
|
|
61
|
+
value: 'get-query',
|
|
62
|
+
},
|
|
63
|
+
{
|
|
64
|
+
name: 'NotFoundException',
|
|
65
|
+
value: 'not-found-exception',
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
name: 'PageOptionsDTO',
|
|
69
|
+
value: 'page-options-dto',
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
name: 'Repository',
|
|
73
|
+
value: 'repository',
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
name: 'Service',
|
|
77
|
+
value: 'service',
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
name: 'TranslationDTO',
|
|
81
|
+
value: 'translation-dto',
|
|
82
|
+
},
|
|
83
|
+
{
|
|
84
|
+
name: 'TranslationEntity',
|
|
85
|
+
value: 'translationEntity',
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
name: 'TranslationRepository',
|
|
89
|
+
value: 'translation-repository',
|
|
90
|
+
},
|
|
91
|
+
{
|
|
92
|
+
name: 'UpdateDTO',
|
|
93
|
+
value: 'update-dto',
|
|
94
|
+
},
|
|
95
|
+
],
|
|
96
|
+
}
|
|
97
|
+
])
|
|
98
|
+
.then(answer => {
|
|
99
|
+
//// For debugging
|
|
100
|
+
// console.log(answer)
|
|
101
|
+
return answer;
|
|
102
|
+
})
|
|
103
|
+
}
|
|
104
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.repositoryFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('Repository') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
EntityName = h.EntityName(name);
|
|
8
|
+
entityFileName = h.entityFileName(name);
|
|
9
|
+
|
|
10
|
+
RepositoryName = h.RepositoryName(name);
|
|
11
|
+
%>import { EntityRepository, Repository } from 'typeorm';
|
|
12
|
+
|
|
13
|
+
import { <%= EntityName %> } from './<%= entityFileName %>';
|
|
14
|
+
|
|
15
|
+
@EntityRepository(<%= EntityName %>)
|
|
16
|
+
export class <%= RepositoryName %> extends Repository<<%= EntityName %>> {}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.serviceFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('Service') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
ClassName = h.ClassName(name);
|
|
9
|
+
fieldName = h.changeCase.camel(ClassName);
|
|
10
|
+
|
|
11
|
+
DtoName = h.DtoName(name);
|
|
12
|
+
dtoFileName = h.dtoFileName(name);
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
CreateCommandName = h.CreateCommandName(name);
|
|
16
|
+
createCommandFileName = h.createCommandFileName(name);
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
EntityName = h.EntityName(name);
|
|
20
|
+
entityName = h.changeCase.camel(EntityName);
|
|
21
|
+
entityFileName = h.entityFileName(name);
|
|
22
|
+
|
|
23
|
+
ServiceName = h.ServiceName(name);
|
|
24
|
+
|
|
25
|
+
UpdateDtoName = h.UpdateDtoName(name);
|
|
26
|
+
updateDtoFileName = h.updateDtoFileName(name);
|
|
27
|
+
updateDtoName = h.changeCase.camel(UpdateDtoName);
|
|
28
|
+
|
|
29
|
+
fileName = h.fileName(name);
|
|
30
|
+
|
|
31
|
+
RepositoryName = h.RepositoryName(name);
|
|
32
|
+
repositoryName = h.changeCase.camel(RepositoryName);
|
|
33
|
+
repositoryFileName = h.repositoryFileName(name);
|
|
34
|
+
|
|
35
|
+
NotFoundExceptionName = h.NotFoundExceptionName(name);
|
|
36
|
+
notFoundExceptionFileName = h.notFoundExceptionFileName(name);
|
|
37
|
+
|
|
38
|
+
createFunctionName = 'create' + ClassName;
|
|
39
|
+
updateFunctionName = 'update' + ClassName;
|
|
40
|
+
deleteFunctionName = 'delete' + ClassName;
|
|
41
|
+
getAllFunctionName = 'getAll' + ClassName;
|
|
42
|
+
getSingleFunctionName = 'getSingle' + ClassName;
|
|
43
|
+
controllerName = moduleName + 'Controller';
|
|
44
|
+
serviceName = moduleName + 'Service';
|
|
45
|
+
CreateDtoName = h.CreateDtoName(name);
|
|
46
|
+
createDtoFileName = h.createDtoFileName(name);
|
|
47
|
+
|
|
48
|
+
PageOptionsDtoName = h.PageOptionsDtoName(name);
|
|
49
|
+
pageOptionsDtoName = h.changeCase.camel(PageOptionsDtoName);
|
|
50
|
+
pageOptionsDtoFileName = h.pageOptionsDtoFileName(name);
|
|
51
|
+
|
|
52
|
+
%>import { Injectable } from '@nestjs/common';
|
|
53
|
+
import { CommandBus } from '@nestjs/cqrs';
|
|
54
|
+
import { Transactional } from 'typeorm-transactional';
|
|
55
|
+
|
|
56
|
+
import type { PageDto } from '@omni/core/common/dto/page.dto';
|
|
57
|
+
import { ValidatorService } from '@omni/core/shared/services/validator.service';
|
|
58
|
+
import { <%= CreateCommandName %> } from './commands/<%= createCommandFileName %>';
|
|
59
|
+
import type { <%= DtoName %> } from './dtos/<%= dtoFileName %>';
|
|
60
|
+
import type { <%= PageOptionsDtoName %> } from './dtos/<%= pageOptionsDtoFileName %>';
|
|
61
|
+
import { <%= NotFoundExceptionName %> } from './exceptions/<%= notFoundExceptionFileName %>';
|
|
62
|
+
import type { <%= EntityName %> } from './<%= entityFileName %>';
|
|
63
|
+
import { <%= RepositoryName %> } from './<%= repositoryFileName %>';
|
|
64
|
+
import { <%= CreateDtoName %> } from './dtos/<%= createDtoFileName %>';
|
|
65
|
+
import type { <%= UpdateDtoName %> } from './dtos/<%= updateDtoFileName %>';
|
|
66
|
+
|
|
67
|
+
@Injectable()
|
|
68
|
+
export class <%= ServiceName %> {
|
|
69
|
+
constructor(
|
|
70
|
+
private <%= repositoryName %>: <%= RepositoryName %>,
|
|
71
|
+
private validatorService: ValidatorService,
|
|
72
|
+
private commandBus: CommandBus,
|
|
73
|
+
) {}
|
|
74
|
+
|
|
75
|
+
@Transactional()
|
|
76
|
+
<%= createFunctionName %>(<%= createDtoName %>: <%= CreateDtoName %>): Promise<<%= EntityName %>> {
|
|
77
|
+
return this.commandBus.execute<<%= CreateCommandName %>, <%= EntityName %>>(
|
|
78
|
+
new <%= CreateCommandName %>(<%= createDtoName %>),
|
|
79
|
+
);
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
async <%= getAllFunctionName %>(
|
|
83
|
+
<%= pageOptionsDtoName %>: <%= PageOptionsDtoName %>,
|
|
84
|
+
): Promise<PageDto<<%= DtoName %>>> {
|
|
85
|
+
const queryBuilder = this.<%= repositoryName %>
|
|
86
|
+
.createQueryBuilder('<%= fieldName %>')
|
|
87
|
+
.leftJoinAndSelect('<%= fieldName %>.translations', '<%= fieldName %>Translation');
|
|
88
|
+
const [items, pageMetaDto] = await queryBuilder.paginate(<%= pageOptionsDtoName %>);
|
|
89
|
+
|
|
90
|
+
return items.toPageDto(pageMetaDto);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
async <%= getSingleFunctionName %>(id: Uuid): Promise<<%= EntityName %>> {
|
|
94
|
+
const queryBuilder = this.<%= repositoryName %>
|
|
95
|
+
.createQueryBuilder('<%= fieldName %>')
|
|
96
|
+
.where('<%= fieldName %>.id = :id', { id });
|
|
97
|
+
|
|
98
|
+
const <%= entityName %> = await queryBuilder.getOne();
|
|
99
|
+
|
|
100
|
+
if (!<%= entityName %>) {
|
|
101
|
+
throw new <%= NotFoundExceptionName %>();
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
return <%= entityName %>;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
async <%= updateFunctionName %>(
|
|
108
|
+
id: Uuid,
|
|
109
|
+
<%= updateDtoName %>: <%= UpdateDtoName %>,
|
|
110
|
+
): Promise<void> {
|
|
111
|
+
const queryBuilder = this.<%= repositoryName %>
|
|
112
|
+
.createQueryBuilder('<%= fieldName %>')
|
|
113
|
+
.where('<%= fieldName %>.id = :id', { id });
|
|
114
|
+
|
|
115
|
+
const <%= entityName %> = await queryBuilder.getOne();
|
|
116
|
+
|
|
117
|
+
if (!<%= entityName %>) {
|
|
118
|
+
throw new <%= NotFoundExceptionName %>();
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
this.<%= repositoryName %>.merge(<%= entityName %>, <%= updateDtoName %>);
|
|
122
|
+
|
|
123
|
+
await this.<%= repositoryName %>.save(<%= updateDtoName %>);
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
async <%= deleteFunctionName %>(id: Uuid): Promise<void> {
|
|
127
|
+
const queryBuilder = this.<%= repositoryName %>
|
|
128
|
+
.createQueryBuilder('<%= fieldName %>')
|
|
129
|
+
.where('<%= fieldName %>.id = :id', { id });
|
|
130
|
+
|
|
131
|
+
const <%= entityName %> = await queryBuilder.getOne();
|
|
132
|
+
|
|
133
|
+
if (!<%= entityName %>) {
|
|
134
|
+
throw new <%= NotFoundExceptionName %>();
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
await this.<%= repositoryName %>.remove(<%= entityName %>);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/dtos/<%= h.translationDtoFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('TranslationDTO') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
|
|
8
|
+
TranslationDtoName = h.TranslationDtoName(name);
|
|
9
|
+
translationEntityFileName = h.translationEntityFileName(name);
|
|
10
|
+
TranslationEntityName = h.TranslationEntityName(name);
|
|
11
|
+
translationEntityName = h.changeCase.camel(TranslationEntityName);
|
|
12
|
+
|
|
13
|
+
%>import { AbstractTranslationDto } from '@omni/core/common/dto/abstract.dto';
|
|
14
|
+
import { LanguageCode } from '../../../constants';
|
|
15
|
+
import { ApiEnumPropertyOptional } from '../@omni/core/decorators';
|
|
16
|
+
import type { <%= TranslationEntityName %> } from '../<%= translationEntityFileName %>';
|
|
17
|
+
|
|
18
|
+
export class <%= TranslationDtoName %> extends AbstractTranslationDto {
|
|
19
|
+
@ApiEnumPropertyOptional(() => LanguageCode)
|
|
20
|
+
languageCode: LanguageCode;
|
|
21
|
+
|
|
22
|
+
constructor(<%= translationEntityName %>: <%= TranslationEntityName %>) {
|
|
23
|
+
super(<%= translationEntityName %>);
|
|
24
|
+
|
|
25
|
+
this.languageCode = <%= translationEntityName %>.languageCode;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.translationEntityFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('TranslationEntity') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
ClassName = h.ClassName(name);
|
|
8
|
+
fieldName = h.changeCase.camel(ClassName);
|
|
9
|
+
DtoName = h.DtoName(name);
|
|
10
|
+
dtoFileName = h.dtoFileName(name);
|
|
11
|
+
translationDtoFileName = h.translationDtoFileName(name);
|
|
12
|
+
translationEntityFileName = h.translationEntityFileName(name);
|
|
13
|
+
DtoOptionName = h.DtoOptionName(name);
|
|
14
|
+
var_name = h.inflection.dasherize(name);
|
|
15
|
+
EntityName = h.EntityName(name);
|
|
16
|
+
entityName = h.changeCase.camel(EntityName);
|
|
17
|
+
TranslationEntityName = h.TranslationEntityName(name);
|
|
18
|
+
TranslationDtoName = h.TranslationDtoName(name);
|
|
19
|
+
translationEntityName = h.changeCase.camel(TranslationEntityName);
|
|
20
|
+
%>import { Column, Entity, JoinColumn, ManyToOne } from 'typeorm';
|
|
21
|
+
|
|
22
|
+
import { AbstractTranslationEntity } from '@omni/core/common/abstract.entity';
|
|
23
|
+
import { UseDto } from '@omni/core/decorators';
|
|
24
|
+
import { <%= TranslationDtoName %> } from './dtos/<%= translationDtoFileName %>';
|
|
25
|
+
import { <%= EntityName %> } from './<%= entityFileName %>';
|
|
26
|
+
|
|
27
|
+
@Entity({ name: '<%= var_name %>_translations' })
|
|
28
|
+
@UseDto(<%= TranslationDtoName %>)
|
|
29
|
+
export class <%= TranslationEntityName %> extends AbstractTranslationEntity<<%= TranslationDtoName %>> {
|
|
30
|
+
@Column({ type: 'uuid' })
|
|
31
|
+
<%= fieldName %>Id: Uuid;
|
|
32
|
+
|
|
33
|
+
@ManyToOne(() => <%= EntityName %>, (<%= entityName %>) => <%= entityName %>.translations, {
|
|
34
|
+
onDelete: 'CASCADE',
|
|
35
|
+
onUpdate: 'CASCADE',
|
|
36
|
+
})
|
|
37
|
+
@JoinColumn({ name: '<%= var_name %>_id' })
|
|
38
|
+
<%= fieldName %>: <%= EntityName %>;
|
|
39
|
+
}
|
|
40
|
+
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
---
|
|
2
|
+
to: "src/modules/<%= h.fileName(name) %>/<%= h.translationRepositoryFileName(name) %>.ts"
|
|
3
|
+
unless_exists: true
|
|
4
|
+
skip_if: <%= !blocks.includes('TranslationRepository') %>
|
|
5
|
+
---
|
|
6
|
+
<%
|
|
7
|
+
TranslationEntityName = h.TranslationEntityName(name);
|
|
8
|
+
translationEntityFileName = h.translationEntityFileName(name);
|
|
9
|
+
|
|
10
|
+
TranslationRepositoryName = h.TranslationRepositoryName(name);
|
|
11
|
+
%>import { EntityRepository, Repository } from 'typeorm';
|
|
12
|
+
|
|
13
|
+
import { <%= TranslationEntityName %> } from './<%= translationEntityFileName %>';
|
|
14
|
+
|
|
15
|
+
@EntityRepository(<%= TranslationEntityName %>)
|
|
16
|
+
export class <%= TranslationRepositoryName %> extends Repository<<%= TranslationEntityName %>> {}
|
package/.hygen.js
ADDED
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
module.exports = {
|
|
2
|
+
templates: `${__dirname}/.hygen`,
|
|
3
|
+
helpers: {
|
|
4
|
+
ControllerName(name) {
|
|
5
|
+
return `${this.ClassName(name)}Controller`;
|
|
6
|
+
},
|
|
7
|
+
ServiceName(name) {
|
|
8
|
+
return `${this.ClassName(name)}Service`;
|
|
9
|
+
},
|
|
10
|
+
ModuleName(name) {
|
|
11
|
+
return `${this.ClassName(name)}Module`;
|
|
12
|
+
},
|
|
13
|
+
DtoName(name) {
|
|
14
|
+
return `${this.ClassName(name)}Dto`;
|
|
15
|
+
},
|
|
16
|
+
TranslationDtoName(name) {
|
|
17
|
+
return `${this.ClassName(name)}TranslationDto`;
|
|
18
|
+
},
|
|
19
|
+
UpdateDtoName(name) {
|
|
20
|
+
return `Update${this.DtoName(name)}`;
|
|
21
|
+
},
|
|
22
|
+
DtoOptionName(name) {
|
|
23
|
+
return `I${this.DtoName(name)}Options`;
|
|
24
|
+
},
|
|
25
|
+
CreateDtoName(name) {
|
|
26
|
+
return `Create${this.DtoName(name)}`;
|
|
27
|
+
},
|
|
28
|
+
EntityName(name) {
|
|
29
|
+
return `${this.ClassName(name)}Entity`;
|
|
30
|
+
},
|
|
31
|
+
TranslationEntityName(name) {
|
|
32
|
+
return `${this.ClassName(name)}TranslationEntity`;
|
|
33
|
+
},
|
|
34
|
+
CreateCommandName(name) {
|
|
35
|
+
return `Create${this.ClassName(name)}Command`;
|
|
36
|
+
},
|
|
37
|
+
CreateHandlerName(name) {
|
|
38
|
+
return `Create${this.ClassName(name)}Handler`;
|
|
39
|
+
},
|
|
40
|
+
GetHandlerName(name) {
|
|
41
|
+
return `Get${this.ClassName(name)}Handler`;
|
|
42
|
+
},
|
|
43
|
+
GetQueryName(name) {
|
|
44
|
+
return `Get${this.ClassName(name)}Query`;
|
|
45
|
+
},
|
|
46
|
+
PageOptionsDtoName(name) {
|
|
47
|
+
return this.ClassName(name) + 'PageOptionsDto';
|
|
48
|
+
},
|
|
49
|
+
NotFoundExceptionName(name) {
|
|
50
|
+
return this.ClassName(name) + 'NotFoundException';
|
|
51
|
+
},
|
|
52
|
+
entityFileName(name) {
|
|
53
|
+
return `${this.fileName(name)}.entity`;
|
|
54
|
+
},
|
|
55
|
+
translationEntityFileName(name) {
|
|
56
|
+
return `${this.fileName(name)}-translation.entity`;
|
|
57
|
+
},
|
|
58
|
+
translationDtoFileName(name) {
|
|
59
|
+
return `${this.fileName(name)}-translation.dto`;
|
|
60
|
+
},
|
|
61
|
+
repositoryFileName(name) {
|
|
62
|
+
return `${this.fileName(name)}.repository`;
|
|
63
|
+
},
|
|
64
|
+
translationRepositoryFileName(name) {
|
|
65
|
+
return `${this.fileName(name)}-translation.repository`;
|
|
66
|
+
},
|
|
67
|
+
createCommandFileName(name) {
|
|
68
|
+
return `create-${this.fileName(name)}.command`;
|
|
69
|
+
},
|
|
70
|
+
getQueryFileName(name) {
|
|
71
|
+
return `get-${this.fileName(name)}.query`;
|
|
72
|
+
},
|
|
73
|
+
controllerFileName(name) {
|
|
74
|
+
return `${this.fileName(name)}.controller`;
|
|
75
|
+
},
|
|
76
|
+
dtoFileName(name) {
|
|
77
|
+
return `${this.fileName(name)}.dto`;
|
|
78
|
+
},
|
|
79
|
+
notFoundExceptionFileName(name) {
|
|
80
|
+
return `${this.fileName(name)}-not-found.exception`;
|
|
81
|
+
},
|
|
82
|
+
createDtoFileName(name) {
|
|
83
|
+
return `create-${this.fileName(name)}.dto`;
|
|
84
|
+
},
|
|
85
|
+
updateDtoFileName(name) {
|
|
86
|
+
return `update-${this.fileName(name)}.dto`;
|
|
87
|
+
},
|
|
88
|
+
pageOptionsDtoFileName(name) {
|
|
89
|
+
return `${this.fileName(name)}-page-options.dto`;
|
|
90
|
+
},
|
|
91
|
+
serviceFileName(name) {
|
|
92
|
+
return `${this.fileName(name)}.service`;
|
|
93
|
+
},
|
|
94
|
+
moduleFileName(name) {
|
|
95
|
+
return `${this.fileName(name)}.module`;
|
|
96
|
+
},
|
|
97
|
+
ClassName(name) {
|
|
98
|
+
return this.changeCase.pascal(name);
|
|
99
|
+
},
|
|
100
|
+
TableName(name) {
|
|
101
|
+
return this.inflection.underscore(this.ClassName(name));
|
|
102
|
+
},
|
|
103
|
+
RepositoryName(name) {
|
|
104
|
+
return `${this.ClassName(name)}Repository`;
|
|
105
|
+
},
|
|
106
|
+
TranslationRepositoryName(name) {
|
|
107
|
+
return `${this.ClassName(name)}TranslationRepository`;
|
|
108
|
+
},
|
|
109
|
+
moduleName(name) {
|
|
110
|
+
return this.changeCase.camel(name);
|
|
111
|
+
},
|
|
112
|
+
fileName(name) {
|
|
113
|
+
return this.inflection.dasherize(name).toLowerCase();
|
|
114
|
+
},
|
|
115
|
+
},
|
|
116
|
+
}
|