@strapi/generators 0.0.0-next.e6eaa3d0563c85f80fd88b258df70a55c057096e → 0.0.0-next.e822ba8a3443f5fce869d85539f9fdaa02e10639

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 (182) hide show
  1. package/LICENSE +18 -3
  2. package/dist/index.d.ts +9 -5
  3. package/dist/index.d.ts.map +1 -1
  4. package/dist/index.js +91 -25
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.mjs +89 -24
  7. package/dist/index.mjs.map +1 -1
  8. package/dist/plopfile.d.ts +1 -1
  9. package/dist/plopfile.d.ts.map +1 -1
  10. package/dist/plopfile.js +25 -701
  11. package/dist/plopfile.js.map +1 -1
  12. package/dist/plopfile.mjs +24 -678
  13. package/dist/plopfile.mjs.map +1 -1
  14. package/dist/plops/api.d.ts +1 -1
  15. package/dist/plops/api.d.ts.map +1 -1
  16. package/dist/plops/api.js +149 -0
  17. package/dist/plops/api.js.map +1 -0
  18. package/dist/plops/api.mjs +147 -0
  19. package/dist/plops/api.mjs.map +1 -0
  20. package/dist/plops/content-type.d.ts +1 -1
  21. package/dist/plops/content-type.d.ts.map +1 -1
  22. package/dist/plops/content-type.js +245 -0
  23. package/dist/plops/content-type.js.map +1 -0
  24. package/dist/plops/content-type.mjs +243 -0
  25. package/dist/plops/content-type.mjs.map +1 -0
  26. package/dist/plops/controller.d.ts +1 -1
  27. package/dist/plops/controller.d.ts.map +1 -1
  28. package/dist/plops/controller.js +73 -0
  29. package/dist/plops/controller.js.map +1 -0
  30. package/dist/plops/controller.mjs +71 -0
  31. package/dist/plops/controller.mjs.map +1 -0
  32. package/dist/plops/middleware.d.ts +1 -1
  33. package/dist/plops/middleware.d.ts.map +1 -1
  34. package/dist/plops/middleware.js +75 -0
  35. package/dist/plops/middleware.js.map +1 -0
  36. package/dist/plops/middleware.mjs +73 -0
  37. package/dist/plops/middleware.mjs.map +1 -0
  38. package/dist/plops/migration.d.ts +1 -1
  39. package/dist/plops/migration.d.ts.map +1 -1
  40. package/dist/plops/migration.js +35 -0
  41. package/dist/plops/migration.js.map +1 -0
  42. package/dist/plops/migration.mjs +33 -0
  43. package/dist/plops/migration.mjs.map +1 -0
  44. package/dist/plops/policy.d.ts +1 -1
  45. package/dist/plops/policy.d.ts.map +1 -1
  46. package/dist/plops/policy.js +75 -0
  47. package/dist/plops/policy.js.map +1 -0
  48. package/dist/plops/policy.mjs +73 -0
  49. package/dist/plops/policy.mjs.map +1 -0
  50. package/dist/plops/prompts/bootstrap-api-prompts.d.ts +6 -2
  51. package/dist/plops/prompts/bootstrap-api-prompts.d.ts.map +1 -1
  52. package/dist/plops/prompts/bootstrap-api-prompts.js +13 -0
  53. package/dist/plops/prompts/bootstrap-api-prompts.js.map +1 -0
  54. package/dist/plops/prompts/bootstrap-api-prompts.mjs +11 -0
  55. package/dist/plops/prompts/bootstrap-api-prompts.mjs.map +1 -0
  56. package/dist/plops/prompts/ct-names-prompts.d.ts +18 -2
  57. package/dist/plops/prompts/ct-names-prompts.d.ts.map +1 -1
  58. package/dist/plops/prompts/ct-names-prompts.js +44 -0
  59. package/dist/plops/prompts/ct-names-prompts.js.map +1 -0
  60. package/dist/plops/prompts/ct-names-prompts.mjs +42 -0
  61. package/dist/plops/prompts/ct-names-prompts.mjs.map +1 -0
  62. package/dist/plops/prompts/get-attributes-prompts.d.ts +8 -2
  63. package/dist/plops/prompts/get-attributes-prompts.d.ts.map +1 -1
  64. package/dist/plops/prompts/get-attributes-prompts.js +101 -0
  65. package/dist/plops/prompts/get-attributes-prompts.js.map +1 -0
  66. package/dist/plops/prompts/get-attributes-prompts.mjs +99 -0
  67. package/dist/plops/prompts/get-attributes-prompts.mjs.map +1 -0
  68. package/dist/plops/prompts/get-destination-prompts.d.ts +24 -2
  69. package/dist/plops/prompts/get-destination-prompts.d.ts.map +1 -1
  70. package/dist/plops/prompts/get-destination-prompts.js +78 -0
  71. package/dist/plops/prompts/get-destination-prompts.js.map +1 -0
  72. package/dist/plops/prompts/get-destination-prompts.mjs +76 -0
  73. package/dist/plops/prompts/get-destination-prompts.mjs.map +1 -0
  74. package/dist/plops/prompts/kind-prompts.d.ts +11 -2
  75. package/dist/plops/prompts/kind-prompts.d.ts.map +1 -1
  76. package/dist/plops/prompts/kind-prompts.js +26 -0
  77. package/dist/plops/prompts/kind-prompts.js.map +1 -0
  78. package/dist/plops/prompts/kind-prompts.mjs +24 -0
  79. package/dist/plops/prompts/kind-prompts.mjs.map +1 -0
  80. package/dist/plops/service.d.ts +1 -1
  81. package/dist/plops/service.d.ts.map +1 -1
  82. package/dist/plops/service.js +71 -0
  83. package/dist/plops/service.js.map +1 -0
  84. package/dist/plops/service.mjs +69 -0
  85. package/dist/plops/service.mjs.map +1 -0
  86. package/dist/plops/utils/extend-plugin-index-files.d.ts +8 -0
  87. package/dist/plops/utils/extend-plugin-index-files.d.ts.map +1 -0
  88. package/dist/plops/utils/extend-plugin-index-files.js +356 -0
  89. package/dist/plops/utils/extend-plugin-index-files.js.map +1 -0
  90. package/dist/plops/utils/extend-plugin-index-files.mjs +335 -0
  91. package/dist/plops/utils/extend-plugin-index-files.mjs.map +1 -0
  92. package/dist/plops/utils/get-file-path.d.ts +1 -1
  93. package/dist/plops/utils/get-file-path.js +17 -0
  94. package/dist/plops/utils/get-file-path.js.map +1 -0
  95. package/dist/plops/utils/get-file-path.mjs +15 -0
  96. package/dist/plops/utils/get-file-path.mjs.map +1 -0
  97. package/dist/plops/utils/get-formatted-date.js +8 -0
  98. package/dist/plops/utils/get-formatted-date.js.map +1 -0
  99. package/dist/plops/utils/get-formatted-date.mjs +6 -0
  100. package/dist/plops/utils/get-formatted-date.mjs.map +1 -0
  101. package/dist/plops/utils/validate-attribute-input.js +12 -0
  102. package/dist/plops/utils/validate-attribute-input.js.map +1 -0
  103. package/dist/plops/utils/validate-attribute-input.mjs +10 -0
  104. package/dist/plops/utils/validate-attribute-input.mjs.map +1 -0
  105. package/dist/plops/utils/validate-file-name-input.js +12 -0
  106. package/dist/plops/utils/validate-file-name-input.js.map +1 -0
  107. package/dist/plops/utils/validate-file-name-input.mjs +10 -0
  108. package/dist/plops/utils/validate-file-name-input.mjs.map +1 -0
  109. package/dist/plops/utils/validate-input.js +12 -0
  110. package/dist/plops/utils/validate-input.js.map +1 -0
  111. package/dist/plops/utils/validate-input.mjs +10 -0
  112. package/dist/plops/utils/validate-input.mjs.map +1 -0
  113. package/dist/templates/js/content-type.schema.json.hbs +0 -1
  114. package/dist/templates/js/plugin/plugin.routes.index.js.hbs +12 -0
  115. package/dist/templates/js/plugin/plugin.routes.type.index.js.hbs +6 -0
  116. package/dist/templates/ts/content-type.schema.json.hbs +0 -1
  117. package/dist/templates/ts/core-controller.ts.hbs +1 -1
  118. package/dist/templates/ts/middleware.ts.hbs +2 -2
  119. package/dist/templates/ts/plugin/plugin.routes.index.ts.hbs +9 -0
  120. package/dist/templates/ts/plugin/plugin.routes.type.index.ts.hbs +4 -0
  121. package/package.json +21 -15
  122. package/dist/files/js/plugin/.gitattributes +0 -103
  123. package/dist/files/js/plugin/admin/src/components/Initializer/index.js +0 -26
  124. package/dist/files/js/plugin/admin/src/components/PluginIcon/index.js +0 -12
  125. package/dist/files/js/plugin/admin/src/index.js +0 -61
  126. package/dist/files/js/plugin/admin/src/pages/App/index.js +0 -25
  127. package/dist/files/js/plugin/admin/src/pages/HomePage/index.js +0 -20
  128. package/dist/files/js/plugin/admin/src/pluginId.js +0 -5
  129. package/dist/files/js/plugin/admin/src/translations/en.json +0 -1
  130. package/dist/files/js/plugin/admin/src/translations/fr.json +0 -1
  131. package/dist/files/js/plugin/admin/src/utils/getTrad.js +0 -5
  132. package/dist/files/js/plugin/server/bootstrap.js +0 -5
  133. package/dist/files/js/plugin/server/config/index.js +0 -6
  134. package/dist/files/js/plugin/server/controllers/index.js +0 -7
  135. package/dist/files/js/plugin/server/controllers/my-controller.js.hbs +0 -10
  136. package/dist/files/js/plugin/server/destroy.js +0 -5
  137. package/dist/files/js/plugin/server/index.js +0 -25
  138. package/dist/files/js/plugin/server/middlewares/index.js +0 -3
  139. package/dist/files/js/plugin/server/policies/index.js +0 -3
  140. package/dist/files/js/plugin/server/register.js +0 -5
  141. package/dist/files/js/plugin/server/routes/index.js +0 -10
  142. package/dist/files/js/plugin/server/services/index.js +0 -7
  143. package/dist/files/js/plugin/server/services/my-service.js +0 -7
  144. package/dist/files/js/plugin/strapi-admin.js +0 -3
  145. package/dist/files/js/plugin/strapi-server.js +0 -3
  146. package/dist/files/ts/plugin/.gitattributes +0 -103
  147. package/dist/files/ts/plugin/admin/src/components/Initializer/index.tsx +0 -24
  148. package/dist/files/ts/plugin/admin/src/components/PluginIcon/index.tsx +0 -12
  149. package/dist/files/ts/plugin/admin/src/index.tsx +0 -67
  150. package/dist/files/ts/plugin/admin/src/pages/App/index.tsx +0 -25
  151. package/dist/files/ts/plugin/admin/src/pages/HomePage/index.tsx +0 -19
  152. package/dist/files/ts/plugin/admin/src/pluginId.ts +0 -5
  153. package/dist/files/ts/plugin/admin/src/translations/en.json +0 -1
  154. package/dist/files/ts/plugin/admin/src/translations/fr.json +0 -1
  155. package/dist/files/ts/plugin/admin/src/utils/getTrad.ts +0 -5
  156. package/dist/files/ts/plugin/custom.d.ts +0 -5
  157. package/dist/files/ts/plugin/server/bootstrap.ts +0 -5
  158. package/dist/files/ts/plugin/server/config/index.ts +0 -4
  159. package/dist/files/ts/plugin/server/controllers/index.ts +0 -5
  160. package/dist/files/ts/plugin/server/controllers/my-controller.ts.hbs +0 -10
  161. package/dist/files/ts/plugin/server/destroy.ts +0 -5
  162. package/dist/files/ts/plugin/server/index.ts +0 -23
  163. package/dist/files/ts/plugin/server/middlewares/index.ts +0 -1
  164. package/dist/files/ts/plugin/server/policies/index.ts +0 -1
  165. package/dist/files/ts/plugin/server/register.ts +0 -5
  166. package/dist/files/ts/plugin/server/routes/index.ts +0 -10
  167. package/dist/files/ts/plugin/server/services/index.ts +0 -5
  168. package/dist/files/ts/plugin/server/services/my-service.ts +0 -7
  169. package/dist/files/ts/plugin/strapi-admin.js +0 -3
  170. package/dist/files/ts/plugin/strapi-server.js +0 -3
  171. package/dist/files/ts/plugin/tsconfig.json +0 -20
  172. package/dist/files/ts/plugin/tsconfig.server.json +0 -25
  173. package/dist/plops/plugin.d.ts +0 -4
  174. package/dist/plops/plugin.d.ts.map +0 -1
  175. package/dist/plops/prompts/draft-and-publish-prompts.d.ts +0 -4
  176. package/dist/plops/prompts/draft-and-publish-prompts.d.ts.map +0 -1
  177. package/dist/templates/js/README.md.hbs +0 -3
  178. package/dist/templates/js/plugin-package.json.hbs +0 -42
  179. package/dist/templates/ts/README.md.hbs +0 -3
  180. package/dist/templates/ts/plugin-package.json.hbs +0 -51
  181. /package/dist/{files/js/plugin/server/content-types/index.js → templates/js/plugin/plugin.index.js.hbs} +0 -0
  182. /package/dist/{files/ts/plugin/server/content-types/index.ts → templates/ts/plugin/plugin.index.ts.hbs} +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"policy.mjs","sources":["../../src/plops/policy.ts"],"sourcesContent":["import type { ActionType, NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\nimport { join } from 'path';\nimport fs from 'fs';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport validateInput from './utils/validate-input';\nimport getFilePath from './utils/get-file-path';\nimport { appendToFile } from './utils/extend-plugin-index-files';\n\nexport default (plop: NodePlopAPI) => {\n // Policy generator\n plop.setGenerator('policy', {\n description: 'Generate a policy for an API',\n prompts: [\n {\n type: 'input',\n name: 'id',\n message: 'Policy name',\n validate: (input) => validateInput(input),\n },\n ...getDestinationPrompts('policy', plop.getDestBasePath(), { rootFolder: true }),\n ],\n actions(answers) {\n if (!answers) {\n return [];\n }\n\n const currentDir = process.cwd();\n const filePath = getFilePath(answers.destination);\n let language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n\n if (answers.plugin) {\n // The tsconfig in plugins is located just outside the server src, not in the root of the plugin.\n const pluginServerDir = join(\n currentDir,\n 'src',\n filePath.replace('{{ plugin }}', answers.plugin),\n '../'\n );\n language = tsUtils.isUsingTypeScriptSync(pluginServerDir) ? 'ts' : 'js';\n }\n\n const baseActions: Array<ActionType> = [\n {\n type: 'add',\n path: `${filePath}/policies/{{ id }}.${language}`,\n templateFile: `templates/${language}/policy.${language}.hbs`,\n },\n ];\n\n if (answers.plugin) {\n const indexPath = join(plop.getDestBasePath(), `${filePath}/policies/index.${language}`);\n const exists = fs.existsSync(indexPath);\n\n if (!exists) {\n // Create index file if it doesn't exist\n baseActions.push({\n type: 'add',\n path: `${filePath}/policies/index.${language}`,\n templateFile: `templates/${language}/plugin/plugin.index.${language}.hbs`,\n skipIfExists: true,\n });\n }\n\n // Append the new policy to the index.ts file\n baseActions.push({\n type: 'modify',\n path: `${filePath}/policies/index.${language}`,\n transform(template: string) {\n return appendToFile(template, { type: 'index', singularName: answers.id });\n },\n });\n }\n\n return baseActions;\n },\n });\n};\n"],"names":["plop","setGenerator","description","prompts","type","name","message","validate","input","validateInput","getDestinationPrompts","getDestBasePath","rootFolder","actions","answers","currentDir","process","cwd","filePath","getFilePath","destination","language","tsUtils","isUsingTypeScriptSync","plugin","pluginServerDir","join","replace","baseActions","path","templateFile","indexPath","exists","fs","existsSync","push","skipIfExists","transform","template","appendToFile","singularName","id"],"mappings":";;;;;;;;AAUA,qBAAe,CAAA,CAACA,IAAAA,GAAAA;;IAEdA,IAAKC,CAAAA,YAAY,CAAC,QAAU,EAAA;QAC1BC,WAAa,EAAA,8BAAA;QACbC,OAAS,EAAA;AACP,YAAA;gBACEC,IAAM,EAAA,OAAA;gBACNC,IAAM,EAAA,IAAA;gBACNC,OAAS,EAAA,aAAA;gBACTC,QAAU,EAAA,CAACC,QAAUC,aAAcD,CAAAA,KAAAA;AACrC,aAAA;eACGE,qBAAsB,CAAA,QAAA,EAAUV,IAAKW,CAAAA,eAAe,EAAI,EAAA;gBAAEC,UAAY,EAAA;AAAK,aAAA;AAC/E,SAAA;AACDC,QAAAA,OAAAA,CAAAA,CAAQC,OAAO,EAAA;AACb,YAAA,IAAI,CAACA,OAAS,EAAA;AACZ,gBAAA,OAAO,EAAE;AACX;YAEA,MAAMC,UAAAA,GAAaC,QAAQC,GAAG,EAAA;YAC9B,MAAMC,QAAAA,GAAWC,WAAYL,CAAAA,OAAAA,CAAQM,WAAW,CAAA;AAChD,YAAA,IAAIC,QAAWC,GAAAA,OAAAA,CAAQC,qBAAqB,CAACR,cAAc,IAAO,GAAA,IAAA;YAElE,IAAID,OAAAA,CAAQU,MAAM,EAAE;;gBAElB,MAAMC,eAAAA,GAAkBC,IACtBX,CAAAA,UAAAA,EACA,KACAG,EAAAA,QAAAA,CAASS,OAAO,CAAC,cAAA,EAAgBb,OAAQU,CAAAA,MAAM,CAC/C,EAAA,KAAA,CAAA;AAEFH,gBAAAA,QAAAA,GAAWC,OAAQC,CAAAA,qBAAqB,CAACE,eAAAA,CAAAA,GAAmB,IAAO,GAAA,IAAA;AACrE;AAEA,YAAA,MAAMG,WAAiC,GAAA;AACrC,gBAAA;oBACExB,IAAM,EAAA,KAAA;AACNyB,oBAAAA,IAAAA,EAAM,CAAGX,EAAAA,QAAAA,CAAS,mBAAmB,EAAEG,QAAU,CAAA,CAAA;oBACjDS,YAAc,EAAA,CAAC,UAAU,EAAET,QAAAA,CAAS,QAAQ,EAAEA,QAAAA,CAAS,IAAI;AAC7D;AACD,aAAA;YAED,IAAIP,OAAAA,CAAQU,MAAM,EAAE;gBAClB,MAAMO,SAAAA,GAAYL,KAAK1B,IAAKW,CAAAA,eAAe,IAAI,CAAGO,EAAAA,QAAAA,CAAS,gBAAgB,EAAEG,QAAU,CAAA,CAAA,CAAA;gBACvF,MAAMW,MAAAA,GAASC,EAAGC,CAAAA,UAAU,CAACH,SAAAA,CAAAA;AAE7B,gBAAA,IAAI,CAACC,MAAQ,EAAA;;AAEXJ,oBAAAA,WAAAA,CAAYO,IAAI,CAAC;wBACf/B,IAAM,EAAA,KAAA;AACNyB,wBAAAA,IAAAA,EAAM,CAAGX,EAAAA,QAAAA,CAAS,gBAAgB,EAAEG,QAAU,CAAA,CAAA;wBAC9CS,YAAc,EAAA,CAAC,UAAU,EAAET,QAAAA,CAAS,qBAAqB,EAAEA,QAAAA,CAAS,IAAI,CAAC;wBACzEe,YAAc,EAAA;AAChB,qBAAA,CAAA;AACF;;AAGAR,gBAAAA,WAAAA,CAAYO,IAAI,CAAC;oBACf/B,IAAM,EAAA,QAAA;AACNyB,oBAAAA,IAAAA,EAAM,CAAGX,EAAAA,QAAAA,CAAS,gBAAgB,EAAEG,QAAU,CAAA,CAAA;AAC9CgB,oBAAAA,SAAAA,CAAAA,CAAUC,QAAgB,EAAA;AACxB,wBAAA,OAAOC,aAAaD,QAAU,EAAA;4BAAElC,IAAM,EAAA,OAAA;AAASoC,4BAAAA,YAAAA,EAAc1B,QAAQ2B;AAAG,yBAAA,CAAA;AAC1E;AACF,iBAAA,CAAA;AACF;YAEA,OAAOb,WAAAA;AACT;AACF,KAAA,CAAA;AACF,CAAA;;;;"}
@@ -1,4 +1,8 @@
1
- import type { PromptQuestion } from 'node-plop';
2
- declare const questions: Array<PromptQuestion>;
1
+ declare const questions: {
2
+ type: string;
3
+ name: string;
4
+ default: boolean;
5
+ message: string;
6
+ }[];
3
7
  export default questions;
4
8
  //# sourceMappingURL=bootstrap-api-prompts.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"bootstrap-api-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/bootstrap-api-prompts.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAEhD,QAAA,MAAM,SAAS,EAAE,KAAK,CAAC,cAAc,CAOpC,CAAC;AAEF,eAAe,SAAS,CAAC"}
1
+ {"version":3,"file":"bootstrap-api-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/bootstrap-api-prompts.ts"],"names":[],"mappings":"AAAA,QAAA,MAAM,SAAS;;;;;GAOd,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -0,0 +1,13 @@
1
+ 'use strict';
2
+
3
+ const questions = [
4
+ {
5
+ type: 'confirm',
6
+ name: 'bootstrapApi',
7
+ default: true,
8
+ message: 'Bootstrap API related files?'
9
+ }
10
+ ];
11
+
12
+ module.exports = questions;
13
+ //# sourceMappingURL=bootstrap-api-prompts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bootstrap-api-prompts.js","sources":["../../../src/plops/prompts/bootstrap-api-prompts.ts"],"sourcesContent":["const questions = [\n {\n type: 'confirm',\n name: 'bootstrapApi',\n default: true,\n message: 'Bootstrap API related files?',\n },\n];\n\nexport default questions;\n"],"names":["questions","type","name","default","message"],"mappings":";;AAAA,MAAMA,SAAY,GAAA;AAChB,IAAA;QACEC,IAAM,EAAA,SAAA;QACNC,IAAM,EAAA,cAAA;QACNC,OAAS,EAAA,IAAA;QACTC,OAAS,EAAA;AACX;AACD;;;;"}
@@ -0,0 +1,11 @@
1
+ const questions = [
2
+ {
3
+ type: 'confirm',
4
+ name: 'bootstrapApi',
5
+ default: true,
6
+ message: 'Bootstrap API related files?'
7
+ }
8
+ ];
9
+
10
+ export { questions as default };
11
+ //# sourceMappingURL=bootstrap-api-prompts.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bootstrap-api-prompts.mjs","sources":["../../../src/plops/prompts/bootstrap-api-prompts.ts"],"sourcesContent":["const questions = [\n {\n type: 'confirm',\n name: 'bootstrapApi',\n default: true,\n message: 'Bootstrap API related files?',\n },\n];\n\nexport default questions;\n"],"names":["questions","type","name","default","message"],"mappings":"AAAA,MAAMA,SAAY,GAAA;AAChB,IAAA;QACEC,IAAM,EAAA,SAAA;QACNC,IAAM,EAAA,cAAA;QACNC,OAAS,EAAA,IAAA;QACTC,OAAS,EAAA;AACX;AACD;;;;"}
@@ -1,4 +1,20 @@
1
- import type { PromptQuestion } from 'node-plop';
2
- declare const questions: Array<PromptQuestion>;
1
+ interface Answers {
2
+ displayName: string;
3
+ singularName: string;
4
+ pluralName: string;
5
+ }
6
+ declare const questions: ({
7
+ type: string;
8
+ name: string;
9
+ message: string;
10
+ validate: (input: string) => boolean;
11
+ default?: undefined;
12
+ } | {
13
+ type: string;
14
+ name: string;
15
+ message: string;
16
+ default: (answers: Answers) => any;
17
+ validate(input: string, answers: Answers): true | "Singular and plural names cannot be the same" | "Value must be in kebab-case";
18
+ })[];
3
19
  export default questions;
4
20
  //# sourceMappingURL=ct-names-prompts.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"ct-names-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/ct-names-prompts.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAQhD,QAAA,MAAM,SAAS,EAAE,KAAK,CAAC,cAAc,CAqCpC,CAAC;AAEF,eAAe,SAAS,CAAC"}
1
+ {"version":3,"file":"ct-names-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/ct-names-prompts.ts"],"names":[],"mappings":"AAIA,UAAU,OAAO;IACf,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,QAAA,MAAM,SAAS;;;;sBAKO,MAAM;;;;;;uBAmBL,OAAO;oBACV,MAAM,WAAW,OAAO;IAY3C,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -0,0 +1,44 @@
1
+ 'use strict';
2
+
3
+ var pluralize = require('pluralize');
4
+ var slugify = require('@sindresorhus/slugify');
5
+ var utils = require('@strapi/utils');
6
+
7
+ const questions = [
8
+ {
9
+ type: 'input',
10
+ name: 'displayName',
11
+ message: 'Content type display name',
12
+ validate: (input)=>!!input
13
+ },
14
+ {
15
+ type: 'input',
16
+ name: 'singularName',
17
+ message: 'Content type singular name',
18
+ default: (answers)=>slugify(answers.displayName),
19
+ validate (input) {
20
+ if (!utils.strings.isKebabCase(input)) {
21
+ return 'Value must be in kebab-case';
22
+ }
23
+ return true;
24
+ }
25
+ },
26
+ {
27
+ type: 'input',
28
+ name: 'pluralName',
29
+ message: 'Content type plural name',
30
+ default: (answers)=>pluralize(answers.singularName),
31
+ validate (input, answers) {
32
+ if (answers.singularName === input) {
33
+ return 'Singular and plural names cannot be the same';
34
+ }
35
+ if (!utils.strings.isKebabCase(input)) {
36
+ return 'Value must be in kebab-case';
37
+ }
38
+ return true;
39
+ }
40
+ }
41
+ ];
42
+
43
+ module.exports = questions;
44
+ //# sourceMappingURL=ct-names-prompts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ct-names-prompts.js","sources":["../../../src/plops/prompts/ct-names-prompts.ts"],"sourcesContent":["import pluralize from 'pluralize';\nimport slugify from '@sindresorhus/slugify';\nimport { strings } from '@strapi/utils';\n\ninterface Answers {\n displayName: string;\n singularName: string;\n pluralName: string;\n}\n\nconst questions = [\n {\n type: 'input',\n name: 'displayName',\n message: 'Content type display name',\n validate: (input: string) => !!input,\n },\n {\n type: 'input',\n name: 'singularName',\n message: 'Content type singular name',\n default: (answers: Answers) => slugify(answers.displayName),\n validate(input: string) {\n if (!strings.isKebabCase(input)) {\n return 'Value must be in kebab-case';\n }\n\n return true;\n },\n },\n {\n type: 'input',\n name: 'pluralName',\n message: 'Content type plural name',\n default: (answers: Answers) => pluralize(answers.singularName),\n validate(input: string, answers: Answers) {\n if (answers.singularName === input) {\n return 'Singular and plural names cannot be the same';\n }\n\n if (!strings.isKebabCase(input)) {\n return 'Value must be in kebab-case';\n }\n\n return true;\n },\n },\n];\n\nexport default questions;\n"],"names":["questions","type","name","message","validate","input","default","answers","slugify","displayName","strings","isKebabCase","pluralize","singularName"],"mappings":";;;;;;AAUA,MAAMA,SAAY,GAAA;AAChB,IAAA;QACEC,IAAM,EAAA,OAAA;QACNC,IAAM,EAAA,aAAA;QACNC,OAAS,EAAA,2BAAA;QACTC,QAAU,EAAA,CAACC,KAAkB,GAAA,CAAC,CAACA;AACjC,KAAA;AACA,IAAA;QACEJ,IAAM,EAAA,OAAA;QACNC,IAAM,EAAA,cAAA;QACNC,OAAS,EAAA,4BAAA;AACTG,QAAAA,OAAAA,EAAS,CAACC,OAAAA,GAAqBC,OAAQD,CAAAA,OAAAA,CAAQE,WAAW,CAAA;AAC1DL,QAAAA,QAAAA,CAAAA,CAASC,KAAa,EAAA;AACpB,YAAA,IAAI,CAACK,aAAAA,CAAQC,WAAW,CAACN,KAAQ,CAAA,EAAA;gBAC/B,OAAO,6BAAA;AACT;YAEA,OAAO,IAAA;AACT;AACF,KAAA;AACA,IAAA;QACEJ,IAAM,EAAA,OAAA;QACNC,IAAM,EAAA,YAAA;QACNC,OAAS,EAAA,0BAAA;AACTG,QAAAA,OAAAA,EAAS,CAACC,OAAAA,GAAqBK,SAAUL,CAAAA,OAAAA,CAAQM,YAAY,CAAA;QAC7DT,QAASC,CAAAA,CAAAA,KAAa,EAAEE,OAAgB,EAAA;YACtC,IAAIA,OAAAA,CAAQM,YAAY,KAAKR,KAAO,EAAA;gBAClC,OAAO,8CAAA;AACT;AAEA,YAAA,IAAI,CAACK,aAAAA,CAAQC,WAAW,CAACN,KAAQ,CAAA,EAAA;gBAC/B,OAAO,6BAAA;AACT;YAEA,OAAO,IAAA;AACT;AACF;AACD;;;;"}
@@ -0,0 +1,42 @@
1
+ import pluralize from 'pluralize';
2
+ import slugify from '@sindresorhus/slugify';
3
+ import { strings } from '@strapi/utils';
4
+
5
+ const questions = [
6
+ {
7
+ type: 'input',
8
+ name: 'displayName',
9
+ message: 'Content type display name',
10
+ validate: (input)=>!!input
11
+ },
12
+ {
13
+ type: 'input',
14
+ name: 'singularName',
15
+ message: 'Content type singular name',
16
+ default: (answers)=>slugify(answers.displayName),
17
+ validate (input) {
18
+ if (!strings.isKebabCase(input)) {
19
+ return 'Value must be in kebab-case';
20
+ }
21
+ return true;
22
+ }
23
+ },
24
+ {
25
+ type: 'input',
26
+ name: 'pluralName',
27
+ message: 'Content type plural name',
28
+ default: (answers)=>pluralize(answers.singularName),
29
+ validate (input, answers) {
30
+ if (answers.singularName === input) {
31
+ return 'Singular and plural names cannot be the same';
32
+ }
33
+ if (!strings.isKebabCase(input)) {
34
+ return 'Value must be in kebab-case';
35
+ }
36
+ return true;
37
+ }
38
+ }
39
+ ];
40
+
41
+ export { questions as default };
42
+ //# sourceMappingURL=ct-names-prompts.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ct-names-prompts.mjs","sources":["../../../src/plops/prompts/ct-names-prompts.ts"],"sourcesContent":["import pluralize from 'pluralize';\nimport slugify from '@sindresorhus/slugify';\nimport { strings } from '@strapi/utils';\n\ninterface Answers {\n displayName: string;\n singularName: string;\n pluralName: string;\n}\n\nconst questions = [\n {\n type: 'input',\n name: 'displayName',\n message: 'Content type display name',\n validate: (input: string) => !!input,\n },\n {\n type: 'input',\n name: 'singularName',\n message: 'Content type singular name',\n default: (answers: Answers) => slugify(answers.displayName),\n validate(input: string) {\n if (!strings.isKebabCase(input)) {\n return 'Value must be in kebab-case';\n }\n\n return true;\n },\n },\n {\n type: 'input',\n name: 'pluralName',\n message: 'Content type plural name',\n default: (answers: Answers) => pluralize(answers.singularName),\n validate(input: string, answers: Answers) {\n if (answers.singularName === input) {\n return 'Singular and plural names cannot be the same';\n }\n\n if (!strings.isKebabCase(input)) {\n return 'Value must be in kebab-case';\n }\n\n return true;\n },\n },\n];\n\nexport default questions;\n"],"names":["questions","type","name","message","validate","input","default","answers","slugify","displayName","strings","isKebabCase","pluralize","singularName"],"mappings":";;;;AAUA,MAAMA,SAAY,GAAA;AAChB,IAAA;QACEC,IAAM,EAAA,OAAA;QACNC,IAAM,EAAA,aAAA;QACNC,OAAS,EAAA,2BAAA;QACTC,QAAU,EAAA,CAACC,KAAkB,GAAA,CAAC,CAACA;AACjC,KAAA;AACA,IAAA;QACEJ,IAAM,EAAA,OAAA;QACNC,IAAM,EAAA,cAAA;QACNC,OAAS,EAAA,4BAAA;AACTG,QAAAA,OAAAA,EAAS,CAACC,OAAAA,GAAqBC,OAAQD,CAAAA,OAAAA,CAAQE,WAAW,CAAA;AAC1DL,QAAAA,QAAAA,CAAAA,CAASC,KAAa,EAAA;AACpB,YAAA,IAAI,CAACK,OAAAA,CAAQC,WAAW,CAACN,KAAQ,CAAA,EAAA;gBAC/B,OAAO,6BAAA;AACT;YAEA,OAAO,IAAA;AACT;AACF,KAAA;AACA,IAAA;QACEJ,IAAM,EAAA,OAAA;QACNC,IAAM,EAAA,YAAA;QACNC,OAAS,EAAA,0BAAA;AACTG,QAAAA,OAAAA,EAAS,CAACC,OAAAA,GAAqBK,SAAUL,CAAAA,OAAAA,CAAQM,YAAY,CAAA;QAC7DT,QAASC,CAAAA,CAAAA,KAAa,EAAEE,OAAgB,EAAA;YACtC,IAAIA,OAAAA,CAAQM,YAAY,KAAKR,KAAO,EAAA;gBAClC,OAAO,8CAAA;AACT;AAEA,YAAA,IAAI,CAACK,OAAAA,CAAQC,WAAW,CAACN,KAAQ,CAAA,EAAA;gBAC/B,OAAO,6BAAA;AACT;YAEA,OAAO,IAAA;AACT;AACF;AACD;;;;"}
@@ -1,4 +1,10 @@
1
- import type { DynamicPromptsFunction } from 'node-plop';
2
- declare const getAttributesPrompts: DynamicPromptsFunction;
1
+ interface AttributeAnswer {
2
+ attributeName: string;
3
+ attributeType: (typeof DEFAULT_TYPES)[number];
4
+ enum?: string;
5
+ multiple?: boolean;
6
+ }
7
+ declare const DEFAULT_TYPES: readonly ["media", "string", "text", "richtext", "json", "enumeration", "password", "email", "integer", "biginteger", "float", "decimal", "date", "time", "datetime", "timestamp", "boolean"];
8
+ declare const getAttributesPrompts: (inquirer: any) => Promise<AttributeAnswer[]>;
3
9
  export default getAttributesPrompts;
4
10
  //# sourceMappingURL=get-attributes-prompts.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"get-attributes-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/get-attributes-prompts.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,WAAW,CAAC;AAkCxD,QAAA,MAAM,oBAAoB,EAAE,sBAyE3B,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
1
+ {"version":3,"file":"get-attributes-prompts.d.ts","sourceRoot":"","sources":["../../../src/plops/prompts/get-attributes-prompts.ts"],"names":[],"mappings":"AAEA,UAAU,eAAe;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,CAAC,OAAO,aAAa,CAAC,CAAC,MAAM,CAAC,CAAC;IAC9C,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,QAAA,MAAM,aAAa,+LAqBT,CAAC;AAEX,QAAA,MAAM,oBAAoB,aAAoB,GAAG,+BAyEhD,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
@@ -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<string>[]>;
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":"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"}