-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplopfile.mjs
91 lines (91 loc) · 2.53 KB
/
plopfile.mjs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
export default function plopfile(
/** @type {import('plop').NodePlopAPI} */
plop,
) {
plop.setGenerator("feature", {
description: "Create a new feature component",
prompts: [
{
type: "input",
name: "name",
message: "What is the name of the feature component?",
},
],
actions: [
{
type: "add",
path: "src/features/{{pascalCase name}}/index.tsx",
templateFile: "plop-templates/feature/feature.tsx.hbs",
},
{
type: "add",
path: "src/features/{{pascalCase name}}/presentations/index.stories.tsx",
templateFile: "plop-templates/feature/presentations/feature.stories.tsx.hbs",
},
{
type: "add",
path: "src/features/{{pascalCase name}}/presentations/index.module.scss",
templateFile: "plop-templates/feature/presentations/feature.module.scss.hbs",
},
{
type: "add",
path: "src/features/{{pascalCase name}}/presentations/index.tsx",
templateFile: "plop-templates/feature/presentations/feature.tsx.hbs",
},
{
type: "add",
path: "src/features/{{pascalCase name}}/hooks/index.ts",
templateFile: "plop-templates/feature/hooks/feature.ts.hbs",
},
],
});
plop.setGenerator("ui", {
description: "Create a new ui component",
prompts: [
{
type: "input",
name: "name",
message: "What is the name of the ui component?",
},
],
actions: [
{
type: "add",
path: "src/ui/{{pascalCase name}}/index.tsx",
templateFile: "plop-templates/ui/ui.tsx.hbs",
},
{
type: "add",
path: "src/ui/{{pascalCase name}}/index.stories.tsx",
templateFile: "plop-templates/ui/ui.stories.tsx.hbs",
},
{
type: "add",
path: "src/ui/{{pascalCase name}}/index.module.scss",
templateFile: "plop-templates/ui/ui.module.scss.hbs",
},
],
});
plop.setGenerator("screen", {
description: "Create a new screen component",
prompts: [
{
type: "input",
name: "name",
message: "What is the name of the screen component?",
},
],
actions: [
{
type: "add",
path: "src/screens/{{pascalCase name}}/index.tsx",
templateFile: "plop-templates/screen/screen.tsx.hbs",
},
{
type: "add",
path: "src/screens/{{pascalCase name}}/index.module.scss",
templateFile: "plop-templates/screen/screen.module.scss.hbs",
},
],
});
}