@strapi/generators 0.0.0-next.f09bff0783c6e3dfd3c34ed73b6f1a47de7b8d80 → 0.0.0-next.f0bfcece1007e5aa527570187635aefc86db536e

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.
Files changed (90) hide show
  1. package/dist/index.d.ts +8 -4
  2. package/dist/index.d.ts.map +1 -1
  3. package/dist/index.js +72 -12
  4. package/dist/index.js.map +1 -1
  5. package/dist/index.mjs +73 -13
  6. package/dist/index.mjs.map +1 -1
  7. package/dist/plopfile.js +14 -644
  8. package/dist/plopfile.js.map +1 -1
  9. package/dist/plopfile.mjs +7 -637
  10. package/dist/plopfile.mjs.map +1 -1
  11. package/dist/plops/api.js +81 -0
  12. package/dist/plops/api.js.map +1 -0
  13. package/dist/plops/api.mjs +79 -0
  14. package/dist/plops/api.mjs.map +1 -0
  15. package/dist/plops/content-type.d.ts.map +1 -1
  16. package/dist/plops/content-type.js +149 -0
  17. package/dist/plops/content-type.js.map +1 -0
  18. package/dist/plops/content-type.mjs +147 -0
  19. package/dist/plops/content-type.mjs.map +1 -0
  20. package/dist/plops/controller.js +40 -0
  21. package/dist/plops/controller.js.map +1 -0
  22. package/dist/plops/controller.mjs +38 -0
  23. package/dist/plops/controller.mjs.map +1 -0
  24. package/dist/plops/middleware.js +42 -0
  25. package/dist/plops/middleware.js.map +1 -0
  26. package/dist/plops/middleware.mjs +40 -0
  27. package/dist/plops/middleware.mjs.map +1 -0
  28. package/dist/plops/migration.js +35 -0
  29. package/dist/plops/migration.js.map +1 -0
  30. package/dist/plops/migration.mjs +33 -0
  31. package/dist/plops/migration.mjs.map +1 -0
  32. package/dist/plops/policy.js +42 -0
  33. package/dist/plops/policy.js.map +1 -0
  34. package/dist/plops/policy.mjs +40 -0
  35. package/dist/plops/policy.mjs.map +1 -0
  36. package/dist/plops/prompts/bootstrap-api-prompts.d.ts +6 -2
  37. package/dist/plops/prompts/bootstrap-api-prompts.d.ts.map +1 -1
  38. package/dist/plops/prompts/bootstrap-api-prompts.js +13 -0
  39. package/dist/plops/prompts/bootstrap-api-prompts.js.map +1 -0
  40. package/dist/plops/prompts/bootstrap-api-prompts.mjs +11 -0
  41. package/dist/plops/prompts/bootstrap-api-prompts.mjs.map +1 -0
  42. package/dist/plops/prompts/ct-names-prompts.d.ts +18 -2
  43. package/dist/plops/prompts/ct-names-prompts.d.ts.map +1 -1
  44. package/dist/plops/prompts/ct-names-prompts.js +44 -0
  45. package/dist/plops/prompts/ct-names-prompts.js.map +1 -0
  46. package/dist/plops/prompts/ct-names-prompts.mjs +42 -0
  47. package/dist/plops/prompts/ct-names-prompts.mjs.map +1 -0
  48. package/dist/plops/prompts/get-attributes-prompts.d.ts +8 -2
  49. package/dist/plops/prompts/get-attributes-prompts.d.ts.map +1 -1
  50. package/dist/plops/prompts/get-attributes-prompts.js +101 -0
  51. package/dist/plops/prompts/get-attributes-prompts.js.map +1 -0
  52. package/dist/plops/prompts/get-attributes-prompts.mjs +99 -0
  53. package/dist/plops/prompts/get-attributes-prompts.mjs.map +1 -0
  54. package/dist/plops/prompts/get-destination-prompts.d.ts +24 -2
  55. package/dist/plops/prompts/get-destination-prompts.d.ts.map +1 -1
  56. package/dist/plops/prompts/get-destination-prompts.js +78 -0
  57. package/dist/plops/prompts/get-destination-prompts.js.map +1 -0
  58. package/dist/plops/prompts/get-destination-prompts.mjs +76 -0
  59. package/dist/plops/prompts/get-destination-prompts.mjs.map +1 -0
  60. package/dist/plops/prompts/kind-prompts.d.ts +11 -2
  61. package/dist/plops/prompts/kind-prompts.d.ts.map +1 -1
  62. package/dist/plops/prompts/kind-prompts.js +26 -0
  63. package/dist/plops/prompts/kind-prompts.js.map +1 -0
  64. package/dist/plops/prompts/kind-prompts.mjs +24 -0
  65. package/dist/plops/prompts/kind-prompts.mjs.map +1 -0
  66. package/dist/plops/service.js +38 -0
  67. package/dist/plops/service.js.map +1 -0
  68. package/dist/plops/service.mjs +36 -0
  69. package/dist/plops/service.mjs.map +1 -0
  70. package/dist/plops/utils/get-file-path.js +17 -0
  71. package/dist/plops/utils/get-file-path.js.map +1 -0
  72. package/dist/plops/utils/get-file-path.mjs +15 -0
  73. package/dist/plops/utils/get-file-path.mjs.map +1 -0
  74. package/dist/plops/utils/get-formatted-date.js +8 -0
  75. package/dist/plops/utils/get-formatted-date.js.map +1 -0
  76. package/dist/plops/utils/get-formatted-date.mjs +6 -0
  77. package/dist/plops/utils/get-formatted-date.mjs.map +1 -0
  78. package/dist/plops/utils/validate-attribute-input.js +12 -0
  79. package/dist/plops/utils/validate-attribute-input.js.map +1 -0
  80. package/dist/plops/utils/validate-attribute-input.mjs +10 -0
  81. package/dist/plops/utils/validate-attribute-input.mjs.map +1 -0
  82. package/dist/plops/utils/validate-file-name-input.js +12 -0
  83. package/dist/plops/utils/validate-file-name-input.js.map +1 -0
  84. package/dist/plops/utils/validate-file-name-input.mjs +10 -0
  85. package/dist/plops/utils/validate-file-name-input.mjs.map +1 -0
  86. package/dist/plops/utils/validate-input.js +12 -0
  87. package/dist/plops/utils/validate-input.js.map +1 -0
  88. package/dist/plops/utils/validate-input.mjs +10 -0
  89. package/dist/plops/utils/validate-input.mjs.map +1 -0
  90. package/package.json +6 -6
@@ -0,0 +1,101 @@
1
+ 'use strict';
2
+
3
+ var validateAttributeInput = require('../utils/validate-attribute-input.js');
4
+
5
+ const DEFAULT_TYPES = [
6
+ // advanced types
7
+ 'media',
8
+ // scalar types
9
+ 'string',
10
+ 'text',
11
+ 'richtext',
12
+ 'json',
13
+ 'enumeration',
14
+ 'password',
15
+ 'email',
16
+ 'integer',
17
+ 'biginteger',
18
+ 'float',
19
+ 'decimal',
20
+ 'date',
21
+ 'time',
22
+ 'datetime',
23
+ 'timestamp',
24
+ 'boolean'
25
+ ];
26
+ const getAttributesPrompts = async (inquirer)=>{
27
+ const { addAttributes } = await inquirer.prompt([
28
+ {
29
+ type: 'confirm',
30
+ name: 'addAttributes',
31
+ message: 'Do you want to add attributes?'
32
+ }
33
+ ]);
34
+ const attributes = [];
35
+ /**
36
+ * @param {import('inquirer').Inquirer} inquirer
37
+ * @returns {Promise<void>}
38
+ */ const createNewAttributes = async (inquirer)=>{
39
+ const answers = await inquirer.prompt([
40
+ {
41
+ type: 'input',
42
+ name: 'attributeName',
43
+ message: 'Name of attribute',
44
+ validate: (input)=>validateAttributeInput(input)
45
+ },
46
+ {
47
+ type: 'list',
48
+ name: 'attributeType',
49
+ message: 'What type of attribute',
50
+ pageSize: DEFAULT_TYPES.length,
51
+ choices: DEFAULT_TYPES.map((type)=>{
52
+ return {
53
+ name: type,
54
+ value: type
55
+ };
56
+ })
57
+ },
58
+ {
59
+ when: (answers)=>answers.attributeType === 'enumeration',
60
+ type: 'input',
61
+ name: 'enum',
62
+ message: 'Add values separated by a comma'
63
+ },
64
+ {
65
+ when: (answers)=>answers.attributeType === 'media',
66
+ type: 'list',
67
+ name: 'multiple',
68
+ message: 'Choose media type',
69
+ choices: [
70
+ {
71
+ name: 'Multiple',
72
+ value: true
73
+ },
74
+ {
75
+ name: 'Single',
76
+ value: false
77
+ }
78
+ ]
79
+ },
80
+ {
81
+ type: 'confirm',
82
+ name: 'addAttributes',
83
+ message: 'Do you want to add another attribute?'
84
+ }
85
+ ]);
86
+ attributes.push(answers);
87
+ if (!answers.addAttributes) {
88
+ return;
89
+ }
90
+ await createNewAttributes(inquirer);
91
+ };
92
+ if (addAttributes) {
93
+ await createNewAttributes(inquirer);
94
+ } else {
95
+ console.warn(`You won't be able to manage entries from the admin, you can still add attributes later from the content type builder.`);
96
+ }
97
+ return attributes;
98
+ };
99
+
100
+ module.exports = getAttributesPrompts;
101
+ //# sourceMappingURL=get-attributes-prompts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-attributes-prompts.js","sources":["../../../src/plops/prompts/get-attributes-prompts.ts"],"sourcesContent":["import validateAttributeInput from '../utils/validate-attribute-input';\n\ninterface AttributeAnswer {\n attributeName: string;\n attributeType: (typeof DEFAULT_TYPES)[number];\n enum?: string;\n multiple?: boolean;\n}\n\nconst DEFAULT_TYPES = [\n // advanced types\n 'media',\n\n // scalar types\n 'string',\n 'text',\n 'richtext',\n 'json',\n 'enumeration',\n 'password',\n 'email',\n 'integer',\n 'biginteger',\n 'float',\n 'decimal',\n 'date',\n 'time',\n 'datetime',\n 'timestamp',\n 'boolean',\n] as const;\n\nconst getAttributesPrompts = async (inquirer: any) => {\n const { addAttributes } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'addAttributes',\n message: 'Do you want to add attributes?',\n },\n ]);\n\n const attributes: Array<AttributeAnswer> = [];\n\n /**\n * @param {import('inquirer').Inquirer} inquirer\n * @returns {Promise<void>}\n */\n const createNewAttributes = async (inquirer: any) => {\n const answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'attributeName',\n message: 'Name of attribute',\n validate: (input: string) => validateAttributeInput(input),\n },\n {\n type: 'list',\n name: 'attributeType',\n message: 'What type of attribute',\n pageSize: DEFAULT_TYPES.length,\n choices: DEFAULT_TYPES.map((type) => {\n return { name: type, value: type };\n }),\n },\n {\n when: (answers: AttributeAnswer) => answers.attributeType === 'enumeration',\n type: 'input',\n name: 'enum',\n message: 'Add values separated by a comma',\n },\n {\n when: (answers: AttributeAnswer) => answers.attributeType === 'media',\n type: 'list',\n name: 'multiple',\n message: 'Choose media type',\n choices: [\n { name: 'Multiple', value: true },\n { name: 'Single', value: false },\n ],\n },\n {\n type: 'confirm',\n name: 'addAttributes',\n message: 'Do you want to add another attribute?',\n },\n ]);\n\n attributes.push(answers);\n\n if (!answers.addAttributes) {\n return;\n }\n\n await createNewAttributes(inquirer);\n };\n\n if (addAttributes) {\n await createNewAttributes(inquirer);\n } else {\n console.warn(\n `You won't be able to manage entries from the admin, you can still add attributes later from the content type builder.`\n );\n }\n\n return attributes;\n};\n\nexport default getAttributesPrompts;\n"],"names":["DEFAULT_TYPES","getAttributesPrompts","inquirer","addAttributes","prompt","type","name","message","attributes","createNewAttributes","answers","validate","input","validateAttributeInput","pageSize","length","choices","map","value","when","attributeType","push","console","warn"],"mappings":";;;;AASA,MAAMA,aAAgB,GAAA;;AAEpB,IAAA,OAAA;;AAGA,IAAA,QAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,MAAA;AACA,IAAA,aAAA;AACA,IAAA,UAAA;AACA,IAAA,OAAA;AACA,IAAA,SAAA;AACA,IAAA,YAAA;AACA,IAAA,OAAA;AACA,IAAA,SAAA;AACA,IAAA,MAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,WAAA;AACA,IAAA;AACD,CAAA;AAED,MAAMC,uBAAuB,OAAOC,QAAAA,GAAAA;AAClC,IAAA,MAAM,EAAEC,aAAa,EAAE,GAAG,MAAMD,QAAAA,CAASE,MAAM,CAAC;AAC9C,QAAA;YACEC,IAAM,EAAA,SAAA;YACNC,IAAM,EAAA,eAAA;YACNC,OAAS,EAAA;AACX;AACD,KAAA,CAAA;AAED,IAAA,MAAMC,aAAqC,EAAE;AAE7C;;;MAIA,MAAMC,sBAAsB,OAAOP,QAAAA,GAAAA;AACjC,QAAA,MAAMQ,OAAU,GAAA,MAAMR,QAASE,CAAAA,MAAM,CAAC;AACpC,YAAA;gBACEC,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,eAAA;gBACNC,OAAS,EAAA,mBAAA;gBACTI,QAAU,EAAA,CAACC,QAAkBC,sBAAuBD,CAAAA,KAAAA;AACtD,aAAA;AACA,YAAA;gBACEP,IAAM,EAAA,MAAA;gBACNC,IAAM,EAAA,eAAA;gBACNC,OAAS,EAAA,wBAAA;AACTO,gBAAAA,QAAAA,EAAUd,cAAce,MAAM;gBAC9BC,OAAShB,EAAAA,aAAAA,CAAciB,GAAG,CAAC,CAACZ,IAAAA,GAAAA;oBAC1B,OAAO;wBAAEC,IAAMD,EAAAA,IAAAA;wBAAMa,KAAOb,EAAAA;AAAK,qBAAA;AACnC,iBAAA;AACF,aAAA;AACA,YAAA;AACEc,gBAAAA,IAAAA,EAAM,CAACT,OAAAA,GAA6BA,OAAQU,CAAAA,aAAa,KAAK,aAAA;gBAC9Df,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,MAAA;gBACNC,OAAS,EAAA;AACX,aAAA;AACA,YAAA;AACEY,gBAAAA,IAAAA,EAAM,CAACT,OAAAA,GAA6BA,OAAQU,CAAAA,aAAa,KAAK,OAAA;gBAC9Df,IAAM,EAAA,MAAA;gBACNC,IAAM,EAAA,UAAA;gBACNC,OAAS,EAAA,mBAAA;gBACTS,OAAS,EAAA;AACP,oBAAA;wBAAEV,IAAM,EAAA,UAAA;wBAAYY,KAAO,EAAA;AAAK,qBAAA;AAChC,oBAAA;wBAAEZ,IAAM,EAAA,QAAA;wBAAUY,KAAO,EAAA;AAAM;AAChC;AACH,aAAA;AACA,YAAA;gBACEb,IAAM,EAAA,SAAA;gBACNC,IAAM,EAAA,eAAA;gBACNC,OAAS,EAAA;AACX;AACD,SAAA,CAAA;AAEDC,QAAAA,UAAAA,CAAWa,IAAI,CAACX,OAAAA,CAAAA;QAEhB,IAAI,CAACA,OAAQP,CAAAA,aAAa,EAAE;AAC1B,YAAA;AACF;AAEA,QAAA,MAAMM,mBAAoBP,CAAAA,QAAAA,CAAAA;AAC5B,KAAA;AAEA,IAAA,IAAIC,aAAe,EAAA;AACjB,QAAA,MAAMM,mBAAoBP,CAAAA,QAAAA,CAAAA;KACrB,MAAA;AACLoB,QAAAA,OAAAA,CAAQC,IAAI,CACV,CAAC,qHAAqH,CAAC,CAAA;AAE3H;IAEA,OAAOf,UAAAA;AACT;;;;"}
@@ -0,0 +1,99 @@
1
+ import validateAttributeInput from '../utils/validate-attribute-input.mjs';
2
+
3
+ const DEFAULT_TYPES = [
4
+ // advanced types
5
+ 'media',
6
+ // scalar types
7
+ 'string',
8
+ 'text',
9
+ 'richtext',
10
+ 'json',
11
+ 'enumeration',
12
+ 'password',
13
+ 'email',
14
+ 'integer',
15
+ 'biginteger',
16
+ 'float',
17
+ 'decimal',
18
+ 'date',
19
+ 'time',
20
+ 'datetime',
21
+ 'timestamp',
22
+ 'boolean'
23
+ ];
24
+ const getAttributesPrompts = async (inquirer)=>{
25
+ const { addAttributes } = await inquirer.prompt([
26
+ {
27
+ type: 'confirm',
28
+ name: 'addAttributes',
29
+ message: 'Do you want to add attributes?'
30
+ }
31
+ ]);
32
+ const attributes = [];
33
+ /**
34
+ * @param {import('inquirer').Inquirer} inquirer
35
+ * @returns {Promise<void>}
36
+ */ const createNewAttributes = async (inquirer)=>{
37
+ const answers = await inquirer.prompt([
38
+ {
39
+ type: 'input',
40
+ name: 'attributeName',
41
+ message: 'Name of attribute',
42
+ validate: (input)=>validateAttributeInput(input)
43
+ },
44
+ {
45
+ type: 'list',
46
+ name: 'attributeType',
47
+ message: 'What type of attribute',
48
+ pageSize: DEFAULT_TYPES.length,
49
+ choices: DEFAULT_TYPES.map((type)=>{
50
+ return {
51
+ name: type,
52
+ value: type
53
+ };
54
+ })
55
+ },
56
+ {
57
+ when: (answers)=>answers.attributeType === 'enumeration',
58
+ type: 'input',
59
+ name: 'enum',
60
+ message: 'Add values separated by a comma'
61
+ },
62
+ {
63
+ when: (answers)=>answers.attributeType === 'media',
64
+ type: 'list',
65
+ name: 'multiple',
66
+ message: 'Choose media type',
67
+ choices: [
68
+ {
69
+ name: 'Multiple',
70
+ value: true
71
+ },
72
+ {
73
+ name: 'Single',
74
+ value: false
75
+ }
76
+ ]
77
+ },
78
+ {
79
+ type: 'confirm',
80
+ name: 'addAttributes',
81
+ message: 'Do you want to add another attribute?'
82
+ }
83
+ ]);
84
+ attributes.push(answers);
85
+ if (!answers.addAttributes) {
86
+ return;
87
+ }
88
+ await createNewAttributes(inquirer);
89
+ };
90
+ if (addAttributes) {
91
+ await createNewAttributes(inquirer);
92
+ } else {
93
+ console.warn(`You won't be able to manage entries from the admin, you can still add attributes later from the content type builder.`);
94
+ }
95
+ return attributes;
96
+ };
97
+
98
+ export { getAttributesPrompts as default };
99
+ //# sourceMappingURL=get-attributes-prompts.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-attributes-prompts.mjs","sources":["../../../src/plops/prompts/get-attributes-prompts.ts"],"sourcesContent":["import validateAttributeInput from '../utils/validate-attribute-input';\n\ninterface AttributeAnswer {\n attributeName: string;\n attributeType: (typeof DEFAULT_TYPES)[number];\n enum?: string;\n multiple?: boolean;\n}\n\nconst DEFAULT_TYPES = [\n // advanced types\n 'media',\n\n // scalar types\n 'string',\n 'text',\n 'richtext',\n 'json',\n 'enumeration',\n 'password',\n 'email',\n 'integer',\n 'biginteger',\n 'float',\n 'decimal',\n 'date',\n 'time',\n 'datetime',\n 'timestamp',\n 'boolean',\n] as const;\n\nconst getAttributesPrompts = async (inquirer: any) => {\n const { addAttributes } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'addAttributes',\n message: 'Do you want to add attributes?',\n },\n ]);\n\n const attributes: Array<AttributeAnswer> = [];\n\n /**\n * @param {import('inquirer').Inquirer} inquirer\n * @returns {Promise<void>}\n */\n const createNewAttributes = async (inquirer: any) => {\n const answers = await inquirer.prompt([\n {\n type: 'input',\n name: 'attributeName',\n message: 'Name of attribute',\n validate: (input: string) => validateAttributeInput(input),\n },\n {\n type: 'list',\n name: 'attributeType',\n message: 'What type of attribute',\n pageSize: DEFAULT_TYPES.length,\n choices: DEFAULT_TYPES.map((type) => {\n return { name: type, value: type };\n }),\n },\n {\n when: (answers: AttributeAnswer) => answers.attributeType === 'enumeration',\n type: 'input',\n name: 'enum',\n message: 'Add values separated by a comma',\n },\n {\n when: (answers: AttributeAnswer) => answers.attributeType === 'media',\n type: 'list',\n name: 'multiple',\n message: 'Choose media type',\n choices: [\n { name: 'Multiple', value: true },\n { name: 'Single', value: false },\n ],\n },\n {\n type: 'confirm',\n name: 'addAttributes',\n message: 'Do you want to add another attribute?',\n },\n ]);\n\n attributes.push(answers);\n\n if (!answers.addAttributes) {\n return;\n }\n\n await createNewAttributes(inquirer);\n };\n\n if (addAttributes) {\n await createNewAttributes(inquirer);\n } else {\n console.warn(\n `You won't be able to manage entries from the admin, you can still add attributes later from the content type builder.`\n );\n }\n\n return attributes;\n};\n\nexport default getAttributesPrompts;\n"],"names":["DEFAULT_TYPES","getAttributesPrompts","inquirer","addAttributes","prompt","type","name","message","attributes","createNewAttributes","answers","validate","input","validateAttributeInput","pageSize","length","choices","map","value","when","attributeType","push","console","warn"],"mappings":";;AASA,MAAMA,aAAgB,GAAA;;AAEpB,IAAA,OAAA;;AAGA,IAAA,QAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,MAAA;AACA,IAAA,aAAA;AACA,IAAA,UAAA;AACA,IAAA,OAAA;AACA,IAAA,SAAA;AACA,IAAA,YAAA;AACA,IAAA,OAAA;AACA,IAAA,SAAA;AACA,IAAA,MAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,WAAA;AACA,IAAA;AACD,CAAA;AAED,MAAMC,uBAAuB,OAAOC,QAAAA,GAAAA;AAClC,IAAA,MAAM,EAAEC,aAAa,EAAE,GAAG,MAAMD,QAAAA,CAASE,MAAM,CAAC;AAC9C,QAAA;YACEC,IAAM,EAAA,SAAA;YACNC,IAAM,EAAA,eAAA;YACNC,OAAS,EAAA;AACX;AACD,KAAA,CAAA;AAED,IAAA,MAAMC,aAAqC,EAAE;AAE7C;;;MAIA,MAAMC,sBAAsB,OAAOP,QAAAA,GAAAA;AACjC,QAAA,MAAMQ,OAAU,GAAA,MAAMR,QAASE,CAAAA,MAAM,CAAC;AACpC,YAAA;gBACEC,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,eAAA;gBACNC,OAAS,EAAA,mBAAA;gBACTI,QAAU,EAAA,CAACC,QAAkBC,sBAAuBD,CAAAA,KAAAA;AACtD,aAAA;AACA,YAAA;gBACEP,IAAM,EAAA,MAAA;gBACNC,IAAM,EAAA,eAAA;gBACNC,OAAS,EAAA,wBAAA;AACTO,gBAAAA,QAAAA,EAAUd,cAAce,MAAM;gBAC9BC,OAAShB,EAAAA,aAAAA,CAAciB,GAAG,CAAC,CAACZ,IAAAA,GAAAA;oBAC1B,OAAO;wBAAEC,IAAMD,EAAAA,IAAAA;wBAAMa,KAAOb,EAAAA;AAAK,qBAAA;AACnC,iBAAA;AACF,aAAA;AACA,YAAA;AACEc,gBAAAA,IAAAA,EAAM,CAACT,OAAAA,GAA6BA,OAAQU,CAAAA,aAAa,KAAK,aAAA;gBAC9Df,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,MAAA;gBACNC,OAAS,EAAA;AACX,aAAA;AACA,YAAA;AACEY,gBAAAA,IAAAA,EAAM,CAACT,OAAAA,GAA6BA,OAAQU,CAAAA,aAAa,KAAK,OAAA;gBAC9Df,IAAM,EAAA,MAAA;gBACNC,IAAM,EAAA,UAAA;gBACNC,OAAS,EAAA,mBAAA;gBACTS,OAAS,EAAA;AACP,oBAAA;wBAAEV,IAAM,EAAA,UAAA;wBAAYY,KAAO,EAAA;AAAK,qBAAA;AAChC,oBAAA;wBAAEZ,IAAM,EAAA,QAAA;wBAAUY,KAAO,EAAA;AAAM;AAChC;AACH,aAAA;AACA,YAAA;gBACEb,IAAM,EAAA,SAAA;gBACNC,IAAM,EAAA,eAAA;gBACNC,OAAS,EAAA;AACX;AACD,SAAA,CAAA;AAEDC,QAAAA,UAAAA,CAAWa,IAAI,CAACX,OAAAA,CAAAA;QAEhB,IAAI,CAACA,OAAQP,CAAAA,aAAa,EAAE;AAC1B,YAAA;AACF;AAEA,QAAA,MAAMM,mBAAoBP,CAAAA,QAAAA,CAAAA;AAC5B,KAAA;AAEA,IAAA,IAAIC,aAAe,EAAA;AACjB,QAAA,MAAMM,mBAAoBP,CAAAA,QAAAA,CAAAA;KACrB,MAAA;AACLoB,QAAAA,OAAAA,CAAQC,IAAI,CACV,CAAC,qHAAqH,CAAC,CAAA;AAE3H;IAEA,OAAOf,UAAAA;AACT;;;;"}
@@ -1,6 +1,28 @@
1
- import type { PromptQuestion } from 'node-plop';
1
+ /// <reference types="node" />
2
+ import fs from 'fs-extra';
2
3
  declare const _default: (action: string, basePath: string, { rootFolder }?: {
3
4
  rootFolder?: boolean | undefined;
4
- }) => Array<PromptQuestion>;
5
+ }) => ({
6
+ type: string;
7
+ name: string;
8
+ message: string;
9
+ choices: {
10
+ name: string;
11
+ value: string;
12
+ }[];
13
+ when?: undefined;
14
+ } | {
15
+ when: (answers: any) => boolean;
16
+ type: string;
17
+ message: string;
18
+ name: string;
19
+ choices(): Promise<fs.Dirent[]>;
20
+ } | {
21
+ when: (answers: any) => boolean;
22
+ type: string;
23
+ message: string;
24
+ name: string;
25
+ choices(): Promise<string[]>;
26
+ })[];
5
27
  export default _default;
6
28
  //# sourceMappingURL=get-destination-prompts.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"get-destination-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/get-destination-prompts.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;iCAGtC,MAAM,YACJ,MAAM;;MAEf,MAAM,cAAc,CAAC;AAJxB,wBA6EE"}
1
+ {"version":3,"file":"get-destination-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/get-destination-prompts.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,MAAM,UAAU,CAAC;iCAEF,MAAM,YAAY,MAAM;;;;;;;;;;;;oBAyB1B,GAAG;;;;;;oBAuBH,GAAG;;;;;;AAhDzB,wBAyEE"}
@@ -0,0 +1,78 @@
1
+ 'use strict';
2
+
3
+ var path = require('path');
4
+ var fs = require('fs-extra');
5
+
6
+ var getDestinationPrompts = ((action, basePath, { rootFolder = false } = {})=>{
7
+ return [
8
+ {
9
+ type: 'list',
10
+ name: 'destination',
11
+ message: `Where do you want to add this ${action}?`,
12
+ choices: [
13
+ ...rootFolder ? [
14
+ {
15
+ name: `Add ${action} to root of project`,
16
+ value: 'root'
17
+ }
18
+ ] : [
19
+ {
20
+ name: `Add ${action} to new API`,
21
+ value: 'new'
22
+ }
23
+ ],
24
+ {
25
+ name: `Add ${action} to an existing API`,
26
+ value: 'api'
27
+ },
28
+ {
29
+ name: `Add ${action} to an existing plugin`,
30
+ value: 'plugin'
31
+ }
32
+ ]
33
+ },
34
+ {
35
+ when: (answers)=>answers.destination === 'api',
36
+ type: 'list',
37
+ message: 'Which API is this for?',
38
+ name: 'api',
39
+ async choices () {
40
+ const apiPath = path.join(basePath, 'api');
41
+ const exists = await fs.pathExists(apiPath);
42
+ if (!exists) {
43
+ throw Error('Couldn\'t find an "api" directory');
44
+ }
45
+ const apiDir = await fs.readdir(apiPath, {
46
+ withFileTypes: true
47
+ });
48
+ const apiDirContent = apiDir.filter((fd)=>fd.isDirectory());
49
+ if (apiDirContent.length === 0) {
50
+ throw Error('The "api" directory is empty');
51
+ }
52
+ return apiDirContent;
53
+ }
54
+ },
55
+ {
56
+ when: (answers)=>answers.destination === 'plugin',
57
+ type: 'list',
58
+ message: 'Which plugin is this for?',
59
+ name: 'plugin',
60
+ async choices () {
61
+ const pluginsPath = path.join(basePath, 'plugins');
62
+ const exists = await fs.pathExists(pluginsPath);
63
+ if (!exists) {
64
+ throw Error('Couldn\'t find a "plugins" directory');
65
+ }
66
+ const pluginsDir = await fs.readdir(pluginsPath);
67
+ const pluginsDirContent = pluginsDir.filter((api)=>fs.lstatSync(path.join(pluginsPath, api)).isDirectory());
68
+ if (pluginsDirContent.length === 0) {
69
+ throw Error('The "plugins" directory is empty');
70
+ }
71
+ return pluginsDirContent;
72
+ }
73
+ }
74
+ ];
75
+ });
76
+
77
+ module.exports = getDestinationPrompts;
78
+ //# sourceMappingURL=get-destination-prompts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-destination-prompts.js","sources":["../../../src/plops/prompts/get-destination-prompts.ts"],"sourcesContent":["import { join } from 'path';\nimport fs from 'fs-extra';\n\nexport default (action: string, basePath: string, { rootFolder = false } = {}) => {\n return [\n {\n type: 'list',\n name: 'destination',\n message: `Where do you want to add this ${action}?`,\n choices: [\n ...(rootFolder\n ? [\n {\n name: `Add ${action} to root of project`,\n value: 'root',\n },\n ]\n : [\n {\n name: `Add ${action} to new API`,\n value: 'new',\n },\n ]),\n { name: `Add ${action} to an existing API`, value: 'api' },\n { name: `Add ${action} to an existing plugin`, value: 'plugin' },\n ],\n },\n {\n when: (answers: any) => answers.destination === 'api',\n type: 'list',\n message: 'Which API is this for?',\n name: 'api',\n async choices() {\n const apiPath = join(basePath, 'api');\n const exists = await fs.pathExists(apiPath);\n\n if (!exists) {\n throw Error('Couldn\\'t find an \"api\" directory');\n }\n\n const apiDir = await fs.readdir(apiPath, { withFileTypes: true });\n const apiDirContent = apiDir.filter((fd) => fd.isDirectory());\n\n if (apiDirContent.length === 0) {\n throw Error('The \"api\" directory is empty');\n }\n\n return apiDirContent;\n },\n },\n {\n when: (answers: any) => answers.destination === 'plugin',\n type: 'list',\n message: 'Which plugin is this for?',\n name: 'plugin',\n async choices() {\n const pluginsPath = join(basePath, 'plugins');\n const exists = await fs.pathExists(pluginsPath);\n\n if (!exists) {\n throw Error('Couldn\\'t find a \"plugins\" directory');\n }\n\n const pluginsDir = await fs.readdir(pluginsPath);\n const pluginsDirContent = pluginsDir.filter((api) =>\n fs.lstatSync(join(pluginsPath, api)).isDirectory()\n );\n\n if (pluginsDirContent.length === 0) {\n throw Error('The \"plugins\" directory is empty');\n }\n\n return pluginsDirContent;\n },\n },\n ];\n};\n"],"names":["action","basePath","rootFolder","type","name","message","choices","value","when","answers","destination","apiPath","join","exists","fs","pathExists","Error","apiDir","readdir","withFileTypes","apiDirContent","filter","fd","isDirectory","length","pluginsPath","pluginsDir","pluginsDirContent","api","lstatSync"],"mappings":";;;;;AAGA,4BAAe,CAAA,CAACA,MAAAA,EAAgBC,QAAkB,EAAA,EAAEC,aAAa,KAAK,EAAE,GAAG,EAAE,GAAA;IAC3E,OAAO;AACL,QAAA;YACEC,IAAM,EAAA,MAAA;YACNC,IAAM,EAAA,aAAA;AACNC,YAAAA,OAAAA,EAAS,CAAC,8BAA8B,EAAEL,MAAAA,CAAO,CAAC,CAAC;YACnDM,OAAS,EAAA;mBACHJ,UACA,GAAA;AACE,oBAAA;AACEE,wBAAAA,IAAAA,EAAM,CAAC,IAAI,EAAEJ,MAAAA,CAAO,mBAAmB,CAAC;wBACxCO,KAAO,EAAA;AACT;iBACD,GACD;AACE,oBAAA;AACEH,wBAAAA,IAAAA,EAAM,CAAC,IAAI,EAAEJ,MAAAA,CAAO,WAAW,CAAC;wBAChCO,KAAO,EAAA;AACT;AACD,iBAAA;AACL,gBAAA;AAAEH,oBAAAA,IAAAA,EAAM,CAAC,IAAI,EAAEJ,MAAAA,CAAO,mBAAmB,CAAC;oBAAEO,KAAO,EAAA;AAAM,iBAAA;AACzD,gBAAA;AAAEH,oBAAAA,IAAAA,EAAM,CAAC,IAAI,EAAEJ,MAAAA,CAAO,sBAAsB,CAAC;oBAAEO,KAAO,EAAA;AAAS;AAChE;AACH,SAAA;AACA,QAAA;AACEC,YAAAA,IAAAA,EAAM,CAACC,OAAAA,GAAiBA,OAAQC,CAAAA,WAAW,KAAK,KAAA;YAChDP,IAAM,EAAA,MAAA;YACNE,OAAS,EAAA,wBAAA;YACTD,IAAM,EAAA,KAAA;YACN,MAAME,OAAAA,CAAAA,GAAAA;gBACJ,MAAMK,OAAAA,GAAUC,UAAKX,QAAU,EAAA,KAAA,CAAA;AAC/B,gBAAA,MAAMY,MAAS,GAAA,MAAMC,EAAGC,CAAAA,UAAU,CAACJ,OAAAA,CAAAA;AAEnC,gBAAA,IAAI,CAACE,MAAQ,EAAA;AACX,oBAAA,MAAMG,KAAM,CAAA,mCAAA,CAAA;AACd;AAEA,gBAAA,MAAMC,MAAS,GAAA,MAAMH,EAAGI,CAAAA,OAAO,CAACP,OAAS,EAAA;oBAAEQ,aAAe,EAAA;AAAK,iBAAA,CAAA;AAC/D,gBAAA,MAAMC,gBAAgBH,MAAOI,CAAAA,MAAM,CAAC,CAACC,EAAAA,GAAOA,GAAGC,WAAW,EAAA,CAAA;gBAE1D,IAAIH,aAAAA,CAAcI,MAAM,KAAK,CAAG,EAAA;AAC9B,oBAAA,MAAMR,KAAM,CAAA,8BAAA,CAAA;AACd;gBAEA,OAAOI,aAAAA;AACT;AACF,SAAA;AACA,QAAA;AACEZ,YAAAA,IAAAA,EAAM,CAACC,OAAAA,GAAiBA,OAAQC,CAAAA,WAAW,KAAK,QAAA;YAChDP,IAAM,EAAA,MAAA;YACNE,OAAS,EAAA,2BAAA;YACTD,IAAM,EAAA,QAAA;YACN,MAAME,OAAAA,CAAAA,GAAAA;gBACJ,MAAMmB,WAAAA,GAAcb,UAAKX,QAAU,EAAA,SAAA,CAAA;AACnC,gBAAA,MAAMY,MAAS,GAAA,MAAMC,EAAGC,CAAAA,UAAU,CAACU,WAAAA,CAAAA;AAEnC,gBAAA,IAAI,CAACZ,MAAQ,EAAA;AACX,oBAAA,MAAMG,KAAM,CAAA,sCAAA,CAAA;AACd;AAEA,gBAAA,MAAMU,UAAa,GAAA,MAAMZ,EAAGI,CAAAA,OAAO,CAACO,WAAAA,CAAAA;AACpC,gBAAA,MAAME,iBAAoBD,GAAAA,UAAAA,CAAWL,MAAM,CAAC,CAACO,GAAAA,GAC3Cd,EAAGe,CAAAA,SAAS,CAACjB,SAAAA,CAAKa,WAAaG,EAAAA,GAAAA,CAAAA,CAAAA,CAAML,WAAW,EAAA,CAAA;gBAGlD,IAAII,iBAAAA,CAAkBH,MAAM,KAAK,CAAG,EAAA;AAClC,oBAAA,MAAMR,KAAM,CAAA,kCAAA,CAAA;AACd;gBAEA,OAAOW,iBAAAA;AACT;AACF;AACD,KAAA;AACH,CAAA;;;;"}
@@ -0,0 +1,76 @@
1
+ import { join } from 'path';
2
+ import fs from 'fs-extra';
3
+
4
+ var getDestinationPrompts = ((action, basePath, { rootFolder = false } = {})=>{
5
+ return [
6
+ {
7
+ type: 'list',
8
+ name: 'destination',
9
+ message: `Where do you want to add this ${action}?`,
10
+ choices: [
11
+ ...rootFolder ? [
12
+ {
13
+ name: `Add ${action} to root of project`,
14
+ value: 'root'
15
+ }
16
+ ] : [
17
+ {
18
+ name: `Add ${action} to new API`,
19
+ value: 'new'
20
+ }
21
+ ],
22
+ {
23
+ name: `Add ${action} to an existing API`,
24
+ value: 'api'
25
+ },
26
+ {
27
+ name: `Add ${action} to an existing plugin`,
28
+ value: 'plugin'
29
+ }
30
+ ]
31
+ },
32
+ {
33
+ when: (answers)=>answers.destination === 'api',
34
+ type: 'list',
35
+ message: 'Which API is this for?',
36
+ name: 'api',
37
+ async choices () {
38
+ const apiPath = join(basePath, 'api');
39
+ const exists = await fs.pathExists(apiPath);
40
+ if (!exists) {
41
+ throw Error('Couldn\'t find an "api" directory');
42
+ }
43
+ const apiDir = await fs.readdir(apiPath, {
44
+ withFileTypes: true
45
+ });
46
+ const apiDirContent = apiDir.filter((fd)=>fd.isDirectory());
47
+ if (apiDirContent.length === 0) {
48
+ throw Error('The "api" directory is empty');
49
+ }
50
+ return apiDirContent;
51
+ }
52
+ },
53
+ {
54
+ when: (answers)=>answers.destination === 'plugin',
55
+ type: 'list',
56
+ message: 'Which plugin is this for?',
57
+ name: 'plugin',
58
+ async choices () {
59
+ const pluginsPath = join(basePath, 'plugins');
60
+ const exists = await fs.pathExists(pluginsPath);
61
+ if (!exists) {
62
+ throw Error('Couldn\'t find a "plugins" directory');
63
+ }
64
+ const pluginsDir = await fs.readdir(pluginsPath);
65
+ const pluginsDirContent = pluginsDir.filter((api)=>fs.lstatSync(join(pluginsPath, api)).isDirectory());
66
+ if (pluginsDirContent.length === 0) {
67
+ throw Error('The "plugins" directory is empty');
68
+ }
69
+ return pluginsDirContent;
70
+ }
71
+ }
72
+ ];
73
+ });
74
+
75
+ export { getDestinationPrompts as default };
76
+ //# sourceMappingURL=get-destination-prompts.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-destination-prompts.mjs","sources":["../../../src/plops/prompts/get-destination-prompts.ts"],"sourcesContent":["import { join } from 'path';\nimport fs from 'fs-extra';\n\nexport default (action: string, basePath: string, { rootFolder = false } = {}) => {\n return [\n {\n type: 'list',\n name: 'destination',\n message: `Where do you want to add this ${action}?`,\n choices: [\n ...(rootFolder\n ? [\n {\n name: `Add ${action} to root of project`,\n value: 'root',\n },\n ]\n : [\n {\n name: `Add ${action} to new API`,\n value: 'new',\n },\n ]),\n { name: `Add ${action} to an existing API`, value: 'api' },\n { name: `Add ${action} to an existing plugin`, value: 'plugin' },\n ],\n },\n {\n when: (answers: any) => answers.destination === 'api',\n type: 'list',\n message: 'Which API is this for?',\n name: 'api',\n async choices() {\n const apiPath = join(basePath, 'api');\n const exists = await fs.pathExists(apiPath);\n\n if (!exists) {\n throw Error('Couldn\\'t find an \"api\" directory');\n }\n\n const apiDir = await fs.readdir(apiPath, { withFileTypes: true });\n const apiDirContent = apiDir.filter((fd) => fd.isDirectory());\n\n if (apiDirContent.length === 0) {\n throw Error('The \"api\" directory is empty');\n }\n\n return apiDirContent;\n },\n },\n {\n when: (answers: any) => answers.destination === 'plugin',\n type: 'list',\n message: 'Which plugin is this for?',\n name: 'plugin',\n async choices() {\n const pluginsPath = join(basePath, 'plugins');\n const exists = await fs.pathExists(pluginsPath);\n\n if (!exists) {\n throw Error('Couldn\\'t find a \"plugins\" directory');\n }\n\n const pluginsDir = await fs.readdir(pluginsPath);\n const pluginsDirContent = pluginsDir.filter((api) =>\n fs.lstatSync(join(pluginsPath, api)).isDirectory()\n );\n\n if (pluginsDirContent.length === 0) {\n throw Error('The \"plugins\" directory is empty');\n }\n\n return pluginsDirContent;\n },\n },\n ];\n};\n"],"names":["action","basePath","rootFolder","type","name","message","choices","value","when","answers","destination","apiPath","join","exists","fs","pathExists","Error","apiDir","readdir","withFileTypes","apiDirContent","filter","fd","isDirectory","length","pluginsPath","pluginsDir","pluginsDirContent","api","lstatSync"],"mappings":"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"}
@@ -1,4 +1,13 @@
1
- import type { PromptQuestion } from 'node-plop';
2
- declare const questions: Array<PromptQuestion>;
1
+ declare const questions: {
2
+ type: string;
3
+ name: string;
4
+ message: string;
5
+ default: string;
6
+ choices: {
7
+ name: string;
8
+ value: string;
9
+ }[];
10
+ validate: (input: string) => true | "You must provide an input" | "Please use only letters, '-' and no spaces";
11
+ }[];
3
12
  export default questions;
4
13
  //# sourceMappingURL=kind-prompts.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"kind-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/kind-prompts.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAIhD,QAAA,MAAM,SAAS,EAAE,KAAK,CAAC,cAAc,CAYpC,CAAC;AAEF,eAAe,SAAS,CAAC"}
1
+ {"version":3,"file":"kind-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/kind-prompts.ts"],"names":[],"mappings":"AAEA,QAAA,MAAM,SAAS;;;;;;;;;sBAUO,MAAM;GAE3B,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -0,0 +1,26 @@
1
+ 'use strict';
2
+
3
+ var validateInput = require('../utils/validate-input.js');
4
+
5
+ const questions = [
6
+ {
7
+ type: 'list',
8
+ name: 'kind',
9
+ message: 'Please choose the model type',
10
+ default: 'collectionType',
11
+ choices: [
12
+ {
13
+ name: 'Collection Type',
14
+ value: 'collectionType'
15
+ },
16
+ {
17
+ name: 'Single Type',
18
+ value: 'singleType'
19
+ }
20
+ ],
21
+ validate: (input)=>validateInput(input)
22
+ }
23
+ ];
24
+
25
+ module.exports = questions;
26
+ //# sourceMappingURL=kind-prompts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kind-prompts.js","sources":["../../../src/plops/prompts/kind-prompts.ts"],"sourcesContent":["import validateInput from '../utils/validate-input';\n\nconst questions = [\n {\n type: 'list',\n name: 'kind',\n message: 'Please choose the model type',\n default: 'collectionType',\n choices: [\n { name: 'Collection Type', value: 'collectionType' },\n { name: 'Single Type', value: 'singleType' },\n ],\n validate: (input: string) => validateInput(input),\n },\n];\n\nexport default questions;\n"],"names":["questions","type","name","message","default","choices","value","validate","input","validateInput"],"mappings":";;;;AAEA,MAAMA,SAAY,GAAA;AAChB,IAAA;QACEC,IAAM,EAAA,MAAA;QACNC,IAAM,EAAA,MAAA;QACNC,OAAS,EAAA,8BAAA;QACTC,OAAS,EAAA,gBAAA;QACTC,OAAS,EAAA;AACP,YAAA;gBAAEH,IAAM,EAAA,iBAAA;gBAAmBI,KAAO,EAAA;AAAiB,aAAA;AACnD,YAAA;gBAAEJ,IAAM,EAAA,aAAA;gBAAeI,KAAO,EAAA;AAAa;AAC5C,SAAA;QACDC,QAAU,EAAA,CAACC,QAAkBC,aAAcD,CAAAA,KAAAA;AAC7C;AACD;;;;"}
@@ -0,0 +1,24 @@
1
+ import validateInput from '../utils/validate-input.mjs';
2
+
3
+ const questions = [
4
+ {
5
+ type: 'list',
6
+ name: 'kind',
7
+ message: 'Please choose the model type',
8
+ default: 'collectionType',
9
+ choices: [
10
+ {
11
+ name: 'Collection Type',
12
+ value: 'collectionType'
13
+ },
14
+ {
15
+ name: 'Single Type',
16
+ value: 'singleType'
17
+ }
18
+ ],
19
+ validate: (input)=>validateInput(input)
20
+ }
21
+ ];
22
+
23
+ export { questions as default };
24
+ //# sourceMappingURL=kind-prompts.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"kind-prompts.mjs","sources":["../../../src/plops/prompts/kind-prompts.ts"],"sourcesContent":["import validateInput from '../utils/validate-input';\n\nconst questions = [\n {\n type: 'list',\n name: 'kind',\n message: 'Please choose the model type',\n default: 'collectionType',\n choices: [\n { name: 'Collection Type', value: 'collectionType' },\n { name: 'Single Type', value: 'singleType' },\n ],\n validate: (input: string) => validateInput(input),\n },\n];\n\nexport default questions;\n"],"names":["questions","type","name","message","default","choices","value","validate","input","validateInput"],"mappings":";;AAEA,MAAMA,SAAY,GAAA;AAChB,IAAA;QACEC,IAAM,EAAA,MAAA;QACNC,IAAM,EAAA,MAAA;QACNC,OAAS,EAAA,8BAAA;QACTC,OAAS,EAAA,gBAAA;QACTC,OAAS,EAAA;AACP,YAAA;gBAAEH,IAAM,EAAA,iBAAA;gBAAmBI,KAAO,EAAA;AAAiB,aAAA;AACnD,YAAA;gBAAEJ,IAAM,EAAA,aAAA;gBAAeI,KAAO,EAAA;AAAa;AAC5C,SAAA;QACDC,QAAU,EAAA,CAACC,QAAkBC,aAAcD,CAAAA,KAAAA;AAC7C;AACD;;;;"}
@@ -0,0 +1,38 @@
1
+ 'use strict';
2
+
3
+ var tsUtils = require('@strapi/typescript-utils');
4
+ var getDestinationPrompts = require('./prompts/get-destination-prompts.js');
5
+ var getFilePath = require('./utils/get-file-path.js');
6
+
7
+ var generateService = ((plop)=>{
8
+ // Service generator
9
+ plop.setGenerator('service', {
10
+ description: 'Generate a service for an API',
11
+ prompts: [
12
+ {
13
+ type: 'input',
14
+ name: 'id',
15
+ message: 'Service name'
16
+ },
17
+ ...getDestinationPrompts('service', plop.getDestBasePath())
18
+ ],
19
+ actions (answers) {
20
+ if (!answers) {
21
+ return [];
22
+ }
23
+ const filePath = getFilePath(answers?.destination);
24
+ const currentDir = process.cwd();
25
+ const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';
26
+ return [
27
+ {
28
+ type: 'add',
29
+ path: `${filePath}/services/{{ id }}.${language}`,
30
+ templateFile: `templates/${language}/service.${language}.hbs`
31
+ }
32
+ ];
33
+ }
34
+ });
35
+ });
36
+
37
+ module.exports = generateService;
38
+ //# sourceMappingURL=service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.js","sources":["../../src/plops/service.ts"],"sourcesContent":["import type { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport getFilePath from './utils/get-file-path';\n\nexport default (plop: NodePlopAPI) => {\n // Service generator\n plop.setGenerator('service', {\n description: 'Generate a service for an API',\n prompts: [\n {\n type: 'input',\n name: 'id',\n message: 'Service name',\n },\n ...getDestinationPrompts('service', plop.getDestBasePath()),\n ],\n actions(answers) {\n if (!answers) {\n return [];\n }\n\n const filePath = getFilePath(answers?.destination);\n const currentDir = process.cwd();\n const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n\n return [\n {\n type: 'add',\n path: `${filePath}/services/{{ id }}.${language}`,\n templateFile: `templates/${language}/service.${language}.hbs`,\n },\n ];\n },\n });\n};\n"],"names":["plop","setGenerator","description","prompts","type","name","message","getDestinationPrompts","getDestBasePath","actions","answers","filePath","getFilePath","destination","currentDir","process","cwd","language","tsUtils","isUsingTypeScriptSync","path","templateFile"],"mappings":";;;;;;AAMA,sBAAe,CAAA,CAACA,IAAAA,GAAAA;;IAEdA,IAAKC,CAAAA,YAAY,CAAC,SAAW,EAAA;QAC3BC,WAAa,EAAA,+BAAA;QACbC,OAAS,EAAA;AACP,YAAA;gBACEC,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,IAAA;gBACNC,OAAS,EAAA;AACX,aAAA;eACGC,qBAAsB,CAAA,SAAA,EAAWP,KAAKQ,eAAe,EAAA;AACzD,SAAA;AACDC,QAAAA,OAAAA,CAAAA,CAAQC,OAAO,EAAA;AACb,YAAA,IAAI,CAACA,OAAS,EAAA;AACZ,gBAAA,OAAO,EAAE;AACX;YAEA,MAAMC,QAAAA,GAAWC,YAAYF,OAASG,EAAAA,WAAAA,CAAAA;YACtC,MAAMC,UAAAA,GAAaC,QAAQC,GAAG,EAAA;AAC9B,YAAA,MAAMC,QAAWC,GAAAA,OAAAA,CAAQC,qBAAqB,CAACL,cAAc,IAAO,GAAA,IAAA;YAEpE,OAAO;AACL,gBAAA;oBACEV,IAAM,EAAA,KAAA;AACNgB,oBAAAA,IAAAA,EAAM,CAAC,EAAET,QAAAA,CAAS,mBAAmB,EAAEM,SAAS,CAAC;oBACjDI,YAAc,EAAA,CAAC,UAAU,EAAEJ,QAAAA,CAAS,SAAS,EAAEA,QAAAA,CAAS,IAAI;AAC9D;AACD,aAAA;AACH;AACF,KAAA,CAAA;AACF,CAAA;;;;"}
@@ -0,0 +1,36 @@
1
+ import tsUtils from '@strapi/typescript-utils';
2
+ import getDestinationPrompts from './prompts/get-destination-prompts.mjs';
3
+ import getFilePath from './utils/get-file-path.mjs';
4
+
5
+ var generateService = ((plop)=>{
6
+ // Service generator
7
+ plop.setGenerator('service', {
8
+ description: 'Generate a service for an API',
9
+ prompts: [
10
+ {
11
+ type: 'input',
12
+ name: 'id',
13
+ message: 'Service name'
14
+ },
15
+ ...getDestinationPrompts('service', plop.getDestBasePath())
16
+ ],
17
+ actions (answers) {
18
+ if (!answers) {
19
+ return [];
20
+ }
21
+ const filePath = getFilePath(answers?.destination);
22
+ const currentDir = process.cwd();
23
+ const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';
24
+ return [
25
+ {
26
+ type: 'add',
27
+ path: `${filePath}/services/{{ id }}.${language}`,
28
+ templateFile: `templates/${language}/service.${language}.hbs`
29
+ }
30
+ ];
31
+ }
32
+ });
33
+ });
34
+
35
+ export { generateService as default };
36
+ //# sourceMappingURL=service.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"service.mjs","sources":["../../src/plops/service.ts"],"sourcesContent":["import type { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport getFilePath from './utils/get-file-path';\n\nexport default (plop: NodePlopAPI) => {\n // Service generator\n plop.setGenerator('service', {\n description: 'Generate a service for an API',\n prompts: [\n {\n type: 'input',\n name: 'id',\n message: 'Service name',\n },\n ...getDestinationPrompts('service', plop.getDestBasePath()),\n ],\n actions(answers) {\n if (!answers) {\n return [];\n }\n\n const filePath = getFilePath(answers?.destination);\n const currentDir = process.cwd();\n const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n\n return [\n {\n type: 'add',\n path: `${filePath}/services/{{ id }}.${language}`,\n templateFile: `templates/${language}/service.${language}.hbs`,\n },\n ];\n },\n });\n};\n"],"names":["plop","setGenerator","description","prompts","type","name","message","getDestinationPrompts","getDestBasePath","actions","answers","filePath","getFilePath","destination","currentDir","process","cwd","language","tsUtils","isUsingTypeScriptSync","path","templateFile"],"mappings":";;;;AAMA,sBAAe,CAAA,CAACA,IAAAA,GAAAA;;IAEdA,IAAKC,CAAAA,YAAY,CAAC,SAAW,EAAA;QAC3BC,WAAa,EAAA,+BAAA;QACbC,OAAS,EAAA;AACP,YAAA;gBACEC,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,IAAA;gBACNC,OAAS,EAAA;AACX,aAAA;eACGC,qBAAsB,CAAA,SAAA,EAAWP,KAAKQ,eAAe,EAAA;AACzD,SAAA;AACDC,QAAAA,OAAAA,CAAAA,CAAQC,OAAO,EAAA;AACb,YAAA,IAAI,CAACA,OAAS,EAAA;AACZ,gBAAA,OAAO,EAAE;AACX;YAEA,MAAMC,QAAAA,GAAWC,YAAYF,OAASG,EAAAA,WAAAA,CAAAA;YACtC,MAAMC,UAAAA,GAAaC,QAAQC,GAAG,EAAA;AAC9B,YAAA,MAAMC,QAAWC,GAAAA,OAAAA,CAAQC,qBAAqB,CAACL,cAAc,IAAO,GAAA,IAAA;YAEpE,OAAO;AACL,gBAAA;oBACEV,IAAM,EAAA,KAAA;AACNgB,oBAAAA,IAAAA,EAAM,CAAC,EAAET,QAAAA,CAAS,mBAAmB,EAAEM,SAAS,CAAC;oBACjDI,YAAc,EAAA,CAAC,UAAU,EAAEJ,QAAAA,CAAS,SAAS,EAAEA,QAAAA,CAAS,IAAI;AAC9D;AACD,aAAA;AACH;AACF,KAAA,CAAA;AACF,CAAA;;;;"}
@@ -0,0 +1,17 @@
1
+ 'use strict';
2
+
3
+ var getFilePath = ((destination)=>{
4
+ if (destination === 'api') {
5
+ return `api/{{ api }}`;
6
+ }
7
+ if (destination === 'plugin') {
8
+ return `plugins/{{ plugin }}/server`;
9
+ }
10
+ if (destination === 'root') {
11
+ return './';
12
+ }
13
+ return `api/{{ id }}`;
14
+ });
15
+
16
+ module.exports = getFilePath;
17
+ //# sourceMappingURL=get-file-path.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-file-path.js","sources":["../../../src/plops/utils/get-file-path.ts"],"sourcesContent":["export default (destination: string) => {\n if (destination === 'api') {\n return `api/{{ api }}`;\n }\n\n if (destination === 'plugin') {\n return `plugins/{{ plugin }}/server`;\n }\n\n if (destination === 'root') {\n return './';\n }\n\n return `api/{{ id }}`;\n};\n"],"names":["destination"],"mappings":";;AAAA,kBAAe,CAAA,CAACA,WAAAA,GAAAA;AACd,IAAA,IAAIA,gBAAgB,KAAO,EAAA;QACzB,OAAO,CAAC,aAAa,CAAC;AACxB;AAEA,IAAA,IAAIA,gBAAgB,QAAU,EAAA;QAC5B,OAAO,CAAC,2BAA2B,CAAC;AACtC;AAEA,IAAA,IAAIA,gBAAgB,MAAQ,EAAA;QAC1B,OAAO,IAAA;AACT;IAEA,OAAO,CAAC,YAAY,CAAC;AACvB,CAAA;;;;"}