-
Notifications
You must be signed in to change notification settings - Fork 2
/
plopfile.cjs
122 lines (116 loc) · 3.33 KB
/
plopfile.cjs
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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/* eslint-disable no-template-curly-in-string,max-lines-per-function */
const {path} = require('@vuepress/utils');
const fs = require('fs');
const defaultThemeComponents = fs.readdirSync(
`${path.dirname(require.resolve('@vuepress/theme-default'))}/../client/components`,
);
module.exports = (plop) => {
plop.setGenerator('component', {
alias: 'component:vue',
description: 'Generate component scaffolding',
prompts: [
{
type: 'input',
name: 'name',
message: 'Component name:',
},
],
actions: [
{
type: 'add',
path: 'src/.vuepress/theme/client/components/{{ kebabCase name }}/{{ pascalCase name }}.vue',
templateFile: 'plop-templates/component/Component.vue.hbs',
},
{
type: 'add',
path: 'src/.vuepress/theme/client/components/{{ kebabCase name }}/{{ pascalCase name}}.vue.spec.ts',
templateFile: 'plop-templates/component/Component.spec.hbs',
},
],
});
plop.setGenerator('component:ts', {
description: 'Generate TypeScript component scaffolding',
prompts: [
{
type: 'input',
name: 'name',
message: 'Component name:',
},
],
actions: [
{
type: 'add',
path: 'src/.vuepress/theme/client/components/{{ kebabCase name }}/{{ pascalCase name }}.ts',
templateFile: 'plop-templates/component/Component.ts.hbs',
},
{
type: 'add',
path: 'src/.vuepress/theme/client/components/{{ kebabCase name }}/{{ pascalCase name}}.vue.spec.ts',
templateFile: 'plop-templates/component/Component.spec.hbs',
},
],
});
plop.setGenerator('component:theme', {
description: 'Generate component scaffolding to replace component from default theme',
prompts: [
{
type: 'list',
name: 'name',
choices: defaultThemeComponents.map((componentName) => {
return componentName.replace('.vue', '');
}),
},
],
actions: [
{
path: 'src/.vuepress/theme/index.ts',
type: 'modify',
pattern: /(alias:\s*\{)/,
template:
"$1\n '@theme/{{pascalCase name}}.vue': `${components}/{{kebabCase name}}/{{pascalCase name}}.vue`,",
},
{
type: 'add',
path: 'src/.vuepress/theme/client/components/{{ kebabCase name }}/{{ pascalCase name }}.vue',
templateFile: 'plop-templates/component/Component.vue.hbs',
},
{
type: 'add',
path: 'src/.vuepress/theme/client/components/{{ kebabCase name }}/{{ pascalCase name}}.vue.spec.ts',
templateFile: 'plop-templates/component/Component.spec.hbs',
},
],
});
plop.setGenerator('docs:group', {
description: 'Generate documentation page group',
prompts: [
{
name: 'name',
type: 'input',
},
],
actions: [
{
type: 'add',
path: 'src/{{pathCase name}}/readme.md',
templateFile: 'plop-templates/docs/readme.md.hbs',
},
],
});
plop.setGenerator('docs:page', {
description: 'Generate documentation page',
prompts: [
{
name: 'name',
type: 'input',
},
],
actions: [
{
type: 'add',
path: 'src/{{pathCase name}}/readme.md',
templateFile: 'plop-templates/docs/readme.md.hbs',
},
],
});
};