@strapi/generators 5.12.0 → 5.12.2

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 (73) hide show
  1. package/dist/plopfile.js +14 -644
  2. package/dist/plopfile.js.map +1 -1
  3. package/dist/plopfile.mjs +7 -637
  4. package/dist/plopfile.mjs.map +1 -1
  5. package/dist/plops/api.js +81 -0
  6. package/dist/plops/api.js.map +1 -0
  7. package/dist/plops/api.mjs +79 -0
  8. package/dist/plops/api.mjs.map +1 -0
  9. package/dist/plops/content-type.js +150 -0
  10. package/dist/plops/content-type.js.map +1 -0
  11. package/dist/plops/content-type.mjs +148 -0
  12. package/dist/plops/content-type.mjs.map +1 -0
  13. package/dist/plops/controller.js +40 -0
  14. package/dist/plops/controller.js.map +1 -0
  15. package/dist/plops/controller.mjs +38 -0
  16. package/dist/plops/controller.mjs.map +1 -0
  17. package/dist/plops/middleware.js +42 -0
  18. package/dist/plops/middleware.js.map +1 -0
  19. package/dist/plops/middleware.mjs +40 -0
  20. package/dist/plops/middleware.mjs.map +1 -0
  21. package/dist/plops/migration.js +35 -0
  22. package/dist/plops/migration.js.map +1 -0
  23. package/dist/plops/migration.mjs +33 -0
  24. package/dist/plops/migration.mjs.map +1 -0
  25. package/dist/plops/policy.js +42 -0
  26. package/dist/plops/policy.js.map +1 -0
  27. package/dist/plops/policy.mjs +40 -0
  28. package/dist/plops/policy.mjs.map +1 -0
  29. package/dist/plops/prompts/bootstrap-api-prompts.js +13 -0
  30. package/dist/plops/prompts/bootstrap-api-prompts.js.map +1 -0
  31. package/dist/plops/prompts/bootstrap-api-prompts.mjs +11 -0
  32. package/dist/plops/prompts/bootstrap-api-prompts.mjs.map +1 -0
  33. package/dist/plops/prompts/ct-names-prompts.js +44 -0
  34. package/dist/plops/prompts/ct-names-prompts.js.map +1 -0
  35. package/dist/plops/prompts/ct-names-prompts.mjs +42 -0
  36. package/dist/plops/prompts/ct-names-prompts.mjs.map +1 -0
  37. package/dist/plops/prompts/get-attributes-prompts.js +101 -0
  38. package/dist/plops/prompts/get-attributes-prompts.js.map +1 -0
  39. package/dist/plops/prompts/get-attributes-prompts.mjs +99 -0
  40. package/dist/plops/prompts/get-attributes-prompts.mjs.map +1 -0
  41. package/dist/plops/prompts/get-destination-prompts.js +78 -0
  42. package/dist/plops/prompts/get-destination-prompts.js.map +1 -0
  43. package/dist/plops/prompts/get-destination-prompts.mjs +76 -0
  44. package/dist/plops/prompts/get-destination-prompts.mjs.map +1 -0
  45. package/dist/plops/prompts/kind-prompts.js +26 -0
  46. package/dist/plops/prompts/kind-prompts.js.map +1 -0
  47. package/dist/plops/prompts/kind-prompts.mjs +24 -0
  48. package/dist/plops/prompts/kind-prompts.mjs.map +1 -0
  49. package/dist/plops/service.js +38 -0
  50. package/dist/plops/service.js.map +1 -0
  51. package/dist/plops/service.mjs +36 -0
  52. package/dist/plops/service.mjs.map +1 -0
  53. package/dist/plops/utils/get-file-path.js +17 -0
  54. package/dist/plops/utils/get-file-path.js.map +1 -0
  55. package/dist/plops/utils/get-file-path.mjs +15 -0
  56. package/dist/plops/utils/get-file-path.mjs.map +1 -0
  57. package/dist/plops/utils/get-formatted-date.js +8 -0
  58. package/dist/plops/utils/get-formatted-date.js.map +1 -0
  59. package/dist/plops/utils/get-formatted-date.mjs +6 -0
  60. package/dist/plops/utils/get-formatted-date.mjs.map +1 -0
  61. package/dist/plops/utils/validate-attribute-input.js +12 -0
  62. package/dist/plops/utils/validate-attribute-input.js.map +1 -0
  63. package/dist/plops/utils/validate-attribute-input.mjs +10 -0
  64. package/dist/plops/utils/validate-attribute-input.mjs.map +1 -0
  65. package/dist/plops/utils/validate-file-name-input.js +12 -0
  66. package/dist/plops/utils/validate-file-name-input.js.map +1 -0
  67. package/dist/plops/utils/validate-file-name-input.mjs +10 -0
  68. package/dist/plops/utils/validate-file-name-input.mjs.map +1 -0
  69. package/dist/plops/utils/validate-input.js +12 -0
  70. package/dist/plops/utils/validate-input.js.map +1 -0
  71. package/dist/plops/utils/validate-input.mjs +10 -0
  72. package/dist/plops/utils/validate-input.mjs.map +1 -0
  73. package/package.json +5 -5
@@ -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 type { DynamicPromptsFunction } from 'node-plop';\n\nimport validateAttributeInput from '../utils/validate-attribute-input';\n\ninterface AttributeAnswer {\n attributeName: string;\n attributeType: typeof DEFAULT_TYPES;\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: DynamicPromptsFunction = async (inquirer) => {\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: Parameters<DynamicPromptsFunction>[0]) => {\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) => answers.attributeType === 'enumeration',\n type: 'input',\n name: 'enum',\n message: 'Add values separated by a comma',\n },\n {\n when: (answers) => 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":";;;;AAWA,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,uBAA+C,OAAOC,QAAAA,GAAAA;AAC1D,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,GAAYA,OAAQU,CAAAA,aAAa,KAAK,aAAA;gBAC7Cf,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,MAAA;gBACNC,OAAS,EAAA;AACX,aAAA;AACA,YAAA;AACEY,gBAAAA,IAAAA,EAAM,CAACT,OAAAA,GAAYA,OAAQU,CAAAA,aAAa,KAAK,OAAA;gBAC7Cf,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 type { DynamicPromptsFunction } from 'node-plop';\n\nimport validateAttributeInput from '../utils/validate-attribute-input';\n\ninterface AttributeAnswer {\n attributeName: string;\n attributeType: typeof DEFAULT_TYPES;\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: DynamicPromptsFunction = async (inquirer) => {\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: Parameters<DynamicPromptsFunction>[0]) => {\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) => answers.attributeType === 'enumeration',\n type: 'input',\n name: 'enum',\n message: 'Add values separated by a comma',\n },\n {\n when: (answers) => 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":";;AAWA,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,uBAA+C,OAAOC,QAAAA,GAAAA;AAC1D,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,GAAYA,OAAQU,CAAAA,aAAa,KAAK,aAAA;gBAC7Cf,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,MAAA;gBACNC,OAAS,EAAA;AACX,aAAA;AACA,YAAA;AACEY,gBAAAA,IAAAA,EAAM,CAACT,OAAAA,GAAYA,OAAQU,CAAAA,aAAa,KAAK,OAAA;gBAC7Cf,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,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\nimport type { PromptQuestion } from 'node-plop';\n\nexport default (\n action: string,\n basePath: string,\n { rootFolder = false } = {}\n): Array<PromptQuestion> => {\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) => 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) => 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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"}
@@ -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\nimport type { PromptQuestion } from 'node-plop';\n\nexport default (\n action: string,\n basePath: string,\n { rootFolder = false } = {}\n): Array<PromptQuestion> => {\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) => 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) => 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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"}
@@ -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 type { PromptQuestion } from 'node-plop';\n\nimport validateInput from '../utils/validate-input';\n\nconst questions: Array<PromptQuestion> = [\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":";;;;AAIA,MAAMA,SAAmC,GAAA;AACvC,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 type { PromptQuestion } from 'node-plop';\n\nimport validateInput from '../utils/validate-input';\n\nconst questions: Array<PromptQuestion> = [\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":";;AAIA,MAAMA,SAAmC,GAAA;AACvC,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;;;;"}
@@ -0,0 +1,15 @@
1
+ var getFilePath = ((destination)=>{
2
+ if (destination === 'api') {
3
+ return `api/{{ api }}`;
4
+ }
5
+ if (destination === 'plugin') {
6
+ return `plugins/{{ plugin }}/server`;
7
+ }
8
+ if (destination === 'root') {
9
+ return './';
10
+ }
11
+ return `api/{{ id }}`;
12
+ });
13
+
14
+ export { getFilePath as default };
15
+ //# sourceMappingURL=get-file-path.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-file-path.mjs","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;;;;"}
@@ -0,0 +1,8 @@
1
+ 'use strict';
2
+
3
+ var getFormattedDate = ((date = new Date())=>{
4
+ return new Date(date.getTime() - date.getTimezoneOffset() * 60000).toJSON().replace(/[-:]/g, '.').replace(/\....Z/, '');
5
+ });
6
+
7
+ module.exports = getFormattedDate;
8
+ //# sourceMappingURL=get-formatted-date.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-formatted-date.js","sources":["../../../src/plops/utils/get-formatted-date.ts"],"sourcesContent":["export default (date: Date = new Date()) => {\n return new Date(date.getTime() - date.getTimezoneOffset() * 60000)\n .toJSON()\n .replace(/[-:]/g, '.')\n .replace(/\\....Z/, '');\n};\n"],"names":["date","Date","getTime","getTimezoneOffset","toJSON","replace"],"mappings":";;AAAA,uBAAe,CAAA,CAACA,IAAa,GAAA,IAAIC,IAAM,EAAA,GAAA;AACrC,IAAA,OAAO,IAAIA,IAAKD,CAAAA,IAAAA,CAAKE,OAAO,EAAA,GAAKF,KAAKG,iBAAiB,EAAA,GAAK,KACzDC,CAAAA,CAAAA,MAAM,GACNC,OAAO,CAAC,SAAS,GACjBA,CAAAA,CAAAA,OAAO,CAAC,QAAU,EAAA,EAAA,CAAA;AACvB,CAAA;;;;"}
@@ -0,0 +1,6 @@
1
+ var getFormattedDate = ((date = new Date())=>{
2
+ return new Date(date.getTime() - date.getTimezoneOffset() * 60000).toJSON().replace(/[-:]/g, '.').replace(/\....Z/, '');
3
+ });
4
+
5
+ export { getFormattedDate as default };
6
+ //# sourceMappingURL=get-formatted-date.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-formatted-date.mjs","sources":["../../../src/plops/utils/get-formatted-date.ts"],"sourcesContent":["export default (date: Date = new Date()) => {\n return new Date(date.getTime() - date.getTimezoneOffset() * 60000)\n .toJSON()\n .replace(/[-:]/g, '.')\n .replace(/\\....Z/, '');\n};\n"],"names":["date","Date","getTime","getTimezoneOffset","toJSON","replace"],"mappings":"AAAA,uBAAe,CAAA,CAACA,IAAa,GAAA,IAAIC,IAAM,EAAA,GAAA;AACrC,IAAA,OAAO,IAAIA,IAAKD,CAAAA,IAAAA,CAAKE,OAAO,EAAA,GAAKF,KAAKG,iBAAiB,EAAA,GAAK,KACzDC,CAAAA,CAAAA,MAAM,GACNC,OAAO,CAAC,SAAS,GACjBA,CAAAA,CAAAA,OAAO,CAAC,QAAU,EAAA,EAAA,CAAA;AACvB,CAAA;;;;"}
@@ -0,0 +1,12 @@
1
+ 'use strict';
2
+
3
+ var validateAttributeInput = ((input)=>{
4
+ const regex = /^[A-Za-z-|_]+$/g;
5
+ if (!input) {
6
+ return 'You must provide an input';
7
+ }
8
+ return regex.test(input) || "Please use only letters, '-', '_', and no spaces";
9
+ });
10
+
11
+ module.exports = validateAttributeInput;
12
+ //# sourceMappingURL=validate-attribute-input.js.map