@strapi/generators 0.0.0-next.f5b09a8e61e059f02784478e27c310c6290be088 → 0.0.0-next.f698d55751345c4ca87477ef683475c1a68f310a

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 (92) hide show
  1. package/LICENSE +18 -3
  2. package/dist/index.d.ts +2 -2
  3. package/dist/index.d.ts.map +1 -1
  4. package/dist/index.js +35 -8
  5. package/dist/index.js.map +1 -1
  6. package/dist/index.mjs +11 -6
  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 +6 -123
  11. package/dist/plopfile.js.map +1 -1
  12. package/dist/plopfile.mjs +7 -104
  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/content-type.d.ts +1 -1
  17. package/dist/plops/content-type.d.ts.map +1 -1
  18. package/dist/plops/controller.d.ts +1 -1
  19. package/dist/plops/controller.d.ts.map +1 -1
  20. package/dist/plops/middleware.d.ts +1 -1
  21. package/dist/plops/middleware.d.ts.map +1 -1
  22. package/dist/plops/migration.d.ts +1 -1
  23. package/dist/plops/migration.d.ts.map +1 -1
  24. package/dist/plops/policy.d.ts +1 -1
  25. package/dist/plops/policy.d.ts.map +1 -1
  26. package/dist/plops/service.d.ts +1 -1
  27. package/dist/plops/service.d.ts.map +1 -1
  28. package/dist/templates/js/content-type.schema.json.hbs +0 -1
  29. package/dist/templates/ts/content-type.schema.json.hbs +0 -1
  30. package/dist/templates/ts/middleware.ts.hbs +2 -2
  31. package/package.json +12 -12
  32. package/dist/files/js/plugin/.gitattributes +0 -103
  33. package/dist/files/js/plugin/admin/src/components/Initializer/index.js +0 -26
  34. package/dist/files/js/plugin/admin/src/components/PluginIcon/index.js +0 -12
  35. package/dist/files/js/plugin/admin/src/index.js +0 -61
  36. package/dist/files/js/plugin/admin/src/pages/App/index.js +0 -25
  37. package/dist/files/js/plugin/admin/src/pages/HomePage/index.js +0 -20
  38. package/dist/files/js/plugin/admin/src/pluginId.js +0 -5
  39. package/dist/files/js/plugin/admin/src/translations/en.json +0 -1
  40. package/dist/files/js/plugin/admin/src/translations/fr.json +0 -1
  41. package/dist/files/js/plugin/admin/src/utils/getTrad.js +0 -5
  42. package/dist/files/js/plugin/server/bootstrap.js +0 -5
  43. package/dist/files/js/plugin/server/config/index.js +0 -6
  44. package/dist/files/js/plugin/server/content-types/index.js +0 -3
  45. package/dist/files/js/plugin/server/controllers/index.js +0 -7
  46. package/dist/files/js/plugin/server/controllers/my-controller.js.hbs +0 -10
  47. package/dist/files/js/plugin/server/destroy.js +0 -5
  48. package/dist/files/js/plugin/server/index.js +0 -25
  49. package/dist/files/js/plugin/server/middlewares/index.js +0 -3
  50. package/dist/files/js/plugin/server/policies/index.js +0 -3
  51. package/dist/files/js/plugin/server/register.js +0 -5
  52. package/dist/files/js/plugin/server/routes/index.js +0 -10
  53. package/dist/files/js/plugin/server/services/index.js +0 -7
  54. package/dist/files/js/plugin/server/services/my-service.js +0 -7
  55. package/dist/files/js/plugin/strapi-admin.js +0 -3
  56. package/dist/files/js/plugin/strapi-server.js +0 -3
  57. package/dist/files/ts/plugin/.gitattributes +0 -103
  58. package/dist/files/ts/plugin/admin/src/components/Initializer/index.tsx +0 -24
  59. package/dist/files/ts/plugin/admin/src/components/PluginIcon/index.tsx +0 -12
  60. package/dist/files/ts/plugin/admin/src/index.tsx +0 -67
  61. package/dist/files/ts/plugin/admin/src/pages/App/index.tsx +0 -25
  62. package/dist/files/ts/plugin/admin/src/pages/HomePage/index.tsx +0 -19
  63. package/dist/files/ts/plugin/admin/src/pluginId.ts +0 -5
  64. package/dist/files/ts/plugin/admin/src/translations/en.json +0 -1
  65. package/dist/files/ts/plugin/admin/src/translations/fr.json +0 -1
  66. package/dist/files/ts/plugin/admin/src/utils/getTrad.ts +0 -5
  67. package/dist/files/ts/plugin/custom.d.ts +0 -5
  68. package/dist/files/ts/plugin/server/bootstrap.ts +0 -5
  69. package/dist/files/ts/plugin/server/config/index.ts +0 -4
  70. package/dist/files/ts/plugin/server/content-types/index.ts +0 -1
  71. package/dist/files/ts/plugin/server/controllers/index.ts +0 -5
  72. package/dist/files/ts/plugin/server/controllers/my-controller.ts.hbs +0 -10
  73. package/dist/files/ts/plugin/server/destroy.ts +0 -5
  74. package/dist/files/ts/plugin/server/index.ts +0 -23
  75. package/dist/files/ts/plugin/server/middlewares/index.ts +0 -1
  76. package/dist/files/ts/plugin/server/policies/index.ts +0 -1
  77. package/dist/files/ts/plugin/server/register.ts +0 -5
  78. package/dist/files/ts/plugin/server/routes/index.ts +0 -10
  79. package/dist/files/ts/plugin/server/services/index.ts +0 -5
  80. package/dist/files/ts/plugin/server/services/my-service.ts +0 -7
  81. package/dist/files/ts/plugin/strapi-admin.js +0 -3
  82. package/dist/files/ts/plugin/strapi-server.js +0 -3
  83. package/dist/files/ts/plugin/tsconfig.json +0 -20
  84. package/dist/files/ts/plugin/tsconfig.server.json +0 -25
  85. package/dist/plops/plugin.d.ts +0 -4
  86. package/dist/plops/plugin.d.ts.map +0 -1
  87. package/dist/plops/prompts/draft-and-publish-prompts.d.ts +0 -4
  88. package/dist/plops/prompts/draft-and-publish-prompts.d.ts.map +0 -1
  89. package/dist/templates/js/README.md.hbs +0 -3
  90. package/dist/templates/js/plugin-package.json.hbs +0 -42
  91. package/dist/templates/ts/README.md.hbs +0 -3
  92. package/dist/templates/ts/plugin-package.json.hbs +0 -51
package/LICENSE CHANGED
@@ -2,7 +2,21 @@ Copyright (c) 2015-present Strapi Solutions SAS
2
2
 
3
3
  Portions of the Strapi software are licensed as follows:
4
4
 
5
- * All software that resides under an "ee/" directory (the “EE Software”), if that directory exists, is licensed under the license defined in "ee/LICENSE".
5
+ * All software that resides under an "ee/" directory (the “EE Software”), if that directory exists, is licensed under the license defined below.
6
+
7
+ Enterprise License
8
+
9
+ If you or the company you represent has entered into a written agreement referencing the Enterprise Edition of the Strapi source code available at
10
+ https://github.com/strapi/strapi, then such agreement applies to your use of the Enterprise Edition of the Strapi Software. If you or the company you
11
+ represent is using the Enterprise Edition of the Strapi Software in connection with a subscription to our cloud offering, then the agreement you have
12
+ agreed to with respect to our cloud offering and the licenses included in such agreement apply to your use of the Enterprise Edition of the Strapi Software.
13
+ Otherwise, the Strapi Enterprise Software License Agreement (found here https://strapi.io/enterprise-terms) applies to your use of the Enterprise Edition of the Strapi Software.
14
+
15
+ BY ACCESSING OR USING THE ENTERPRISE EDITION OF THE STRAPI SOFTWARE, YOU ARE AGREEING TO BE BOUND BY THE RELEVANT REFERENCED AGREEMENT.
16
+ IF YOU ARE NOT AUTHORIZED TO ACCEPT THESE TERMS ON BEHALF OF THE COMPANY YOU REPRESENT OR IF YOU DO NOT AGREE TO ALL OF THE RELEVANT TERMS AND CONDITIONS REFERENCED AND YOU
17
+ HAVE NOT OTHERWISE EXECUTED A WRITTEN AGREEMENT WITH STRAPI, YOU ARE NOT AUTHORIZED TO ACCESS OR USE OR ALLOW ANY USER TO ACCESS OR USE ANY PART OF
18
+ THE ENTERPRISE EDITION OF THE STRAPI SOFTWARE. YOUR ACCESS RIGHTS ARE CONDITIONAL ON YOUR CONSENT TO THE RELEVANT REFERENCED TERMS TO THE EXCLUSION OF ALL OTHER TERMS;
19
+ IF THE RELEVANT REFERENCED TERMS ARE CONSIDERED AN OFFER BY YOU, ACCEPTANCE IS EXPRESSLY LIMITED TO THE RELEVANT REFERENCED TERMS.
6
20
 
7
21
  * All software outside of the above-mentioned directories or restrictions above is available under the "MIT Expat" license as set forth below.
8
22
 
@@ -18,5 +32,6 @@ furnished to do so, subject to the following conditions:
18
32
  The above copyright notice and this permission notice shall be included in all
19
33
  copies or substantial portions of the Software.
20
34
 
21
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22
- SOFTWARE.
35
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
36
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
37
+ WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
- export declare const runCLI: () => void;
2
- export declare const generate: (generatorName: string, options: unknown, { dir, plopFile }?: {
1
+ export declare const runCLI: () => Promise<void>;
2
+ export declare const generate: <T extends Record<string, any>>(generatorName: string, options: T, { dir, plopFile }?: {
3
3
  dir?: string | undefined;
4
4
  plopFile?: string | undefined;
5
5
  }) => Promise<void>;
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,MAAM,YAKlB,CAAC;AAGF,eAAO,MAAM,QAAQ,kBACJ,MAAM,WACZ,OAAO;;;mBAcjB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,MAAM,qBAYlB,CAAC;AAGF,eAAO,MAAM,QAAQ,iDACJ,MAAM,WACZ,CAAC;;;mBAcX,CAAC"}
package/dist/index.js CHANGED
@@ -1,22 +1,49 @@
1
1
  "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __copyProps = (to, from, except, desc) => {
9
+ if (from && typeof from === "object" || typeof from === "function") {
10
+ for (let key of __getOwnPropNames(from))
11
+ if (!__hasOwnProp.call(to, key) && key !== except)
12
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
13
+ }
14
+ return to;
15
+ };
16
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
17
+ // If the importer is in node compatibility mode or this is not an ESM
18
+ // file that has been converted to a CommonJS file using a Babel-
19
+ // compatible transform (i.e. "__esModule" has not been set), then set
20
+ // "default" to the CommonJS "module.exports" for node compatibility.
21
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
22
+ mod
23
+ ));
2
24
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
25
  const node_path = require("node:path");
4
- const plop = require("plop");
5
26
  const nodePlop = require("node-plop");
6
27
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
7
28
  const nodePlop__default = /* @__PURE__ */ _interopDefault(nodePlop);
8
- const runCLI = () => {
9
- plop.Plop.launch({ configPath: node_path.join(__dirname, "plopfile.js") }, (env) => {
10
- const options = { ...env, dest: node_path.join(process.cwd(), "src") };
11
- plop.run(options, void 0, true);
12
- });
29
+ const runCLI = async () => {
30
+ const { Plop, run } = await import("plop");
31
+ Plop.prepare(
32
+ {
33
+ configPath: node_path.join(__dirname, "plopfile.js")
34
+ },
35
+ (env) => {
36
+ const argv = process.argv.slice(2);
37
+ Plop.execute(env, argv, (env2, argv2) => run(env2, argv2, true));
38
+ }
39
+ );
13
40
  };
14
41
  const generate = async (generatorName, options, { dir = process.cwd(), plopFile = "plopfile.js" } = {}) => {
15
- const plop2 = nodePlop__default.default(node_path.join(__dirname, plopFile), {
42
+ const plop = nodePlop__default.default(node_path.join(__dirname, plopFile), {
16
43
  destBasePath: node_path.join(dir, "src"),
17
44
  force: false
18
45
  });
19
- const generator = plop2.getGenerator(generatorName);
46
+ const generator = plop.getGenerator(generatorName);
20
47
  await generator.runActions(options, {
21
48
  onSuccess() {
22
49
  },
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["import { join } from 'node:path';\nimport { Plop, run } from 'plop';\nimport nodePlop from 'node-plop';\n\n// Starts the Plop CLI programmatically\nexport const runCLI = () => {\n Plop.launch({ configPath: join(__dirname, 'plopfile.js') }, (env) => {\n const options = { ...env, dest: join(process.cwd(), 'src') };\n run(options, undefined, true);\n });\n};\n\n// Runs a generator programmatically without prompts\nexport const generate = async (\n generatorName: string,\n options: unknown,\n { dir = process.cwd(), plopFile = 'plopfile.js' } = {}\n) => {\n const plop = nodePlop(join(__dirname, plopFile), {\n destBasePath: join(dir, 'src'),\n force: false,\n });\n\n const generator = plop.getGenerator(generatorName);\n await generator.runActions(options, {\n onSuccess() {},\n onFailure() {},\n onComment() {},\n });\n};\n"],"names":["Plop","join","run","plop","nodePlop"],"mappings":";;;;;;;AAKO,MAAM,SAAS,MAAM;AACrBA,YAAA,OAAO,EAAE,YAAYC,UAAAA,KAAK,WAAW,aAAa,KAAK,CAAC,QAAQ;AAC7D,UAAA,UAAU,EAAE,GAAG,KAAK,MAAMA,eAAK,QAAQ,IAAA,GAAO,KAAK;AACrDC,SAAAA,IAAA,SAAS,QAAW,IAAI;AAAA,EAAA,CAC7B;AACH;AAGO,MAAM,WAAW,OACtB,eACA,SACA,EAAE,MAAM,QAAQ,OAAO,WAAW,cAAc,IAAI,CAAA,MACjD;AACH,QAAMC,QAAOC,kBAAA,QAASH,UAAK,KAAA,WAAW,QAAQ,GAAG;AAAA,IAC/C,cAAcA,UAAAA,KAAK,KAAK,KAAK;AAAA,IAC7B,OAAO;AAAA,EAAA,CACR;AAEK,QAAA,YAAYE,MAAK,aAAa,aAAa;AAC3C,QAAA,UAAU,WAAW,SAAS;AAAA,IAClC,YAAY;AAAA,IAAC;AAAA,IACb,YAAY;AAAA,IAAC;AAAA,IACb,YAAY;AAAA,IAAC;AAAA,EAAA,CACd;AACH;;;"}
1
+ {"version":3,"file":"index.js","sources":["../src/index.ts"],"sourcesContent":["import { join } from 'node:path';\nimport nodePlop from 'node-plop';\n\n// Starts the Plop CLI programmatically\nexport const runCLI = async () => {\n const { Plop, run } = await import('plop');\n\n Plop.prepare(\n {\n configPath: join(__dirname, 'plopfile.js'),\n },\n (env) => {\n const argv = process.argv.slice(2); // Extract command-line arguments\n Plop.execute(env, argv, (env, argv) => run(env, argv, true)); // Pass the third argument 'true' for passArgsBeforeDashes\n }\n );\n};\n\n// Runs a generator programmatically without prompts\nexport const generate = async <T extends Record<string, any>>(\n generatorName: string,\n options: T,\n { dir = process.cwd(), plopFile = 'plopfile.js' } = {}\n) => {\n const plop = nodePlop(join(__dirname, plopFile), {\n destBasePath: join(dir, 'src'),\n force: false,\n });\n\n const generator = plop.getGenerator(generatorName);\n await generator.runActions(options satisfies T, {\n onSuccess() {},\n onFailure() {},\n onComment() {},\n });\n};\n"],"names":["join","env","argv","nodePlop"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIO,MAAM,SAAS,YAAY;AAChC,QAAM,EAAE,MAAM,QAAQ,MAAM,OAAO,MAAM;AAEpC,OAAA;AAAA,IACH;AAAA,MACE,YAAYA,UAAAA,KAAK,WAAW,aAAa;AAAA,IAC3C;AAAA,IACA,CAAC,QAAQ;AACP,YAAM,OAAO,QAAQ,KAAK,MAAM,CAAC;AAC5B,WAAA,QAAQ,KAAK,MAAM,CAACC,MAAKC,UAAS,IAAID,MAAKC,OAAM,IAAI,CAAC;AAAA,IAAA;AAAA,EAE/D;AACF;AAGO,MAAM,WAAW,OACtB,eACA,SACA,EAAE,MAAM,QAAQ,OAAO,WAAW,cAAc,IAAI,CAAA,MACjD;AACH,QAAM,OAAOC,kBAAA,QAASH,UAAK,KAAA,WAAW,QAAQ,GAAG;AAAA,IAC/C,cAAcA,UAAAA,KAAK,KAAK,KAAK;AAAA,IAC7B,OAAO;AAAA,EAAA,CACR;AAEK,QAAA,YAAY,KAAK,aAAa,aAAa;AAC3C,QAAA,UAAU,WAAW,SAAqB;AAAA,IAC9C,YAAY;AAAA,IAAC;AAAA,IACb,YAAY;AAAA,IAAC;AAAA,IACb,YAAY;AAAA,IAAA;AAAA,EAAC,CACd;AACH;;;"}
package/dist/index.mjs CHANGED
@@ -1,11 +1,16 @@
1
1
  import { join } from "node:path";
2
- import { Plop, run } from "plop";
3
2
  import nodePlop from "node-plop";
4
- const runCLI = () => {
5
- Plop.launch({ configPath: join(__dirname, "plopfile.js") }, (env) => {
6
- const options = { ...env, dest: join(process.cwd(), "src") };
7
- run(options, void 0, true);
8
- });
3
+ const runCLI = async () => {
4
+ const { Plop, run } = await import("plop");
5
+ Plop.prepare(
6
+ {
7
+ configPath: join(__dirname, "plopfile.js")
8
+ },
9
+ (env) => {
10
+ const argv = process.argv.slice(2);
11
+ Plop.execute(env, argv, (env2, argv2) => run(env2, argv2, true));
12
+ }
13
+ );
9
14
  };
10
15
  const generate = async (generatorName, options, { dir = process.cwd(), plopFile = "plopfile.js" } = {}) => {
11
16
  const plop = nodePlop(join(__dirname, plopFile), {
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../src/index.ts"],"sourcesContent":["import { join } from 'node:path';\nimport { Plop, run } from 'plop';\nimport nodePlop from 'node-plop';\n\n// Starts the Plop CLI programmatically\nexport const runCLI = () => {\n Plop.launch({ configPath: join(__dirname, 'plopfile.js') }, (env) => {\n const options = { ...env, dest: join(process.cwd(), 'src') };\n run(options, undefined, true);\n });\n};\n\n// Runs a generator programmatically without prompts\nexport const generate = async (\n generatorName: string,\n options: unknown,\n { dir = process.cwd(), plopFile = 'plopfile.js' } = {}\n) => {\n const plop = nodePlop(join(__dirname, plopFile), {\n destBasePath: join(dir, 'src'),\n force: false,\n });\n\n const generator = plop.getGenerator(generatorName);\n await generator.runActions(options, {\n onSuccess() {},\n onFailure() {},\n onComment() {},\n });\n};\n"],"names":[],"mappings":";;;AAKO,MAAM,SAAS,MAAM;AACrB,OAAA,OAAO,EAAE,YAAY,KAAK,WAAW,aAAa,KAAK,CAAC,QAAQ;AAC7D,UAAA,UAAU,EAAE,GAAG,KAAK,MAAM,KAAK,QAAQ,IAAA,GAAO,KAAK;AACrD,QAAA,SAAS,QAAW,IAAI;AAAA,EAAA,CAC7B;AACH;AAGO,MAAM,WAAW,OACtB,eACA,SACA,EAAE,MAAM,QAAQ,OAAO,WAAW,cAAc,IAAI,CAAA,MACjD;AACH,QAAM,OAAO,SAAS,KAAK,WAAW,QAAQ,GAAG;AAAA,IAC/C,cAAc,KAAK,KAAK,KAAK;AAAA,IAC7B,OAAO;AAAA,EAAA,CACR;AAEK,QAAA,YAAY,KAAK,aAAa,aAAa;AAC3C,QAAA,UAAU,WAAW,SAAS;AAAA,IAClC,YAAY;AAAA,IAAC;AAAA,IACb,YAAY;AAAA,IAAC;AAAA,IACb,YAAY;AAAA,IAAC;AAAA,EAAA,CACd;AACH;"}
1
+ {"version":3,"file":"index.mjs","sources":["../src/index.ts"],"sourcesContent":["import { join } from 'node:path';\nimport nodePlop from 'node-plop';\n\n// Starts the Plop CLI programmatically\nexport const runCLI = async () => {\n const { Plop, run } = await import('plop');\n\n Plop.prepare(\n {\n configPath: join(__dirname, 'plopfile.js'),\n },\n (env) => {\n const argv = process.argv.slice(2); // Extract command-line arguments\n Plop.execute(env, argv, (env, argv) => run(env, argv, true)); // Pass the third argument 'true' for passArgsBeforeDashes\n }\n );\n};\n\n// Runs a generator programmatically without prompts\nexport const generate = async <T extends Record<string, any>>(\n generatorName: string,\n options: T,\n { dir = process.cwd(), plopFile = 'plopfile.js' } = {}\n) => {\n const plop = nodePlop(join(__dirname, plopFile), {\n destBasePath: join(dir, 'src'),\n force: false,\n });\n\n const generator = plop.getGenerator(generatorName);\n await generator.runActions(options satisfies T, {\n onSuccess() {},\n onFailure() {},\n onComment() {},\n });\n};\n"],"names":["env","argv"],"mappings":";;AAIO,MAAM,SAAS,YAAY;AAChC,QAAM,EAAE,MAAM,QAAQ,MAAM,OAAO,MAAM;AAEpC,OAAA;AAAA,IACH;AAAA,MACE,YAAY,KAAK,WAAW,aAAa;AAAA,IAC3C;AAAA,IACA,CAAC,QAAQ;AACP,YAAM,OAAO,QAAQ,KAAK,MAAM,CAAC;AAC5B,WAAA,QAAQ,KAAK,MAAM,CAACA,MAAKC,UAAS,IAAID,MAAKC,OAAM,IAAI,CAAC;AAAA,IAAA;AAAA,EAE/D;AACF;AAGO,MAAM,WAAW,OACtB,eACA,SACA,EAAE,MAAM,QAAQ,OAAO,WAAW,cAAc,IAAI,CAAA,MACjD;AACH,QAAM,OAAO,SAAS,KAAK,WAAW,QAAQ,GAAG;AAAA,IAC/C,cAAc,KAAK,KAAK,KAAK;AAAA,IAC7B,OAAO;AAAA,EAAA,CACR;AAEK,QAAA,YAAY,KAAK,aAAa,aAAa;AAC3C,QAAA,UAAU,WAAW,SAAqB;AAAA,IAC9C,YAAY;AAAA,IAAC;AAAA,IACb,YAAY;AAAA,IAAC;AAAA,IACb,YAAY;AAAA,IAAA;AAAA,EAAC,CACd;AACH;"}
@@ -1,4 +1,4 @@
1
- import { NodePlopAPI } from 'plop';
1
+ import type { NodePlopAPI } from 'plop';
2
2
  declare const _default: (plop: NodePlopAPI) => void;
3
3
  export default _default;
4
4
  //# sourceMappingURL=plopfile.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"plopfile.d.ts","sourceRoot":"","sources":["../src/plopfile.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;+BAWb,WAAW;AAAjC,wBAcE"}
1
+ {"version":3,"file":"plopfile.d.ts","sourceRoot":"","sources":["../src/plopfile.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;+BAUlB,WAAW;AAAjC,wBAaE"}
package/dist/plopfile.js CHANGED
@@ -5,32 +5,11 @@ const fs = require("fs-extra");
5
5
  const tsUtils = require("@strapi/typescript-utils");
6
6
  const slugify = require("@sindresorhus/slugify");
7
7
  const utils = require("@strapi/utils");
8
- const chalk = require("chalk");
9
8
  const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
10
- function _interopNamespace(e) {
11
- if (e && e.__esModule)
12
- return e;
13
- const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
14
- if (e) {
15
- for (const k in e) {
16
- if (k !== "default") {
17
- const d = Object.getOwnPropertyDescriptor(e, k);
18
- Object.defineProperty(n, k, d.get ? d : {
19
- enumerable: true,
20
- get: () => e[k]
21
- });
22
- }
23
- }
24
- }
25
- n.default = e;
26
- return Object.freeze(n);
27
- }
28
9
  const pluralize__default = /* @__PURE__ */ _interopDefault(pluralize);
29
10
  const fs__default = /* @__PURE__ */ _interopDefault(fs);
30
11
  const tsUtils__default = /* @__PURE__ */ _interopDefault(tsUtils);
31
12
  const slugify__default = /* @__PURE__ */ _interopDefault(slugify);
32
- const utils__namespace = /* @__PURE__ */ _interopNamespace(utils);
33
- const chalk__default = /* @__PURE__ */ _interopDefault(chalk);
34
13
  const validateInput = (input) => {
35
14
  const regex = /^[A-Za-z-]+$/g;
36
15
  if (!input) {
@@ -211,7 +190,7 @@ const generateController = (plop) => {
211
190
  }
212
191
  });
213
192
  };
214
- const questions$3 = [
193
+ const questions$2 = [
215
194
  {
216
195
  type: "input",
217
196
  name: "displayName",
@@ -224,7 +203,7 @@ const questions$3 = [
224
203
  message: "Content type singular name",
225
204
  default: (answers) => slugify__default.default(answers.displayName),
226
205
  validate(input) {
227
- if (!utils__namespace.isKebabCase(input)) {
206
+ if (!utils.strings.isKebabCase(input)) {
228
207
  return "Value must be in kebab-case";
229
208
  }
230
209
  return true;
@@ -239,14 +218,14 @@ const questions$3 = [
239
218
  if (answers.singularName === input) {
240
219
  return "Singular and plural names cannot be the same";
241
220
  }
242
- if (!utils__namespace.isKebabCase(input)) {
221
+ if (!utils.strings.isKebabCase(input)) {
243
222
  return "Value must be in kebab-case";
244
223
  }
245
224
  return true;
246
225
  }
247
226
  }
248
227
  ];
249
- const questions$2 = [
228
+ const questions$1 = [
250
229
  {
251
230
  type: "list",
252
231
  name: "kind",
@@ -259,14 +238,6 @@ const questions$2 = [
259
238
  validate: (input) => validateInput(input)
260
239
  }
261
240
  ];
262
- const questions$1 = [
263
- {
264
- type: "confirm",
265
- name: "useDraftAndPublish",
266
- default: false,
267
- message: "Use draft and publish?"
268
- }
269
- ];
270
241
  const validateAttributeInput = (input) => {
271
242
  const regex = /^[A-Za-z-|_]+$/g;
272
243
  if (!input) {
@@ -370,11 +341,7 @@ const generateContentType = (plop) => {
370
341
  plop.setGenerator("content-type", {
371
342
  description: "Generate a content type for an API",
372
343
  async prompts(inquirer) {
373
- const config = await inquirer.prompt([
374
- ...questions$3,
375
- ...questions$2,
376
- ...questions$1
377
- ]);
344
+ const config = await inquirer.prompt([...questions$2, ...questions$1]);
378
345
  const attributes = await getAttributesPrompts(inquirer);
379
346
  const api = await inquirer.prompt([
380
347
  ...getDestinationPrompts("model", plop.getDestBasePath()),
@@ -385,7 +352,7 @@ const generateContentType = (plop) => {
385
352
  default: config.singularName,
386
353
  message: "Name of the new API?",
387
354
  async validate(input) {
388
- if (!utils__namespace.isKebabCase(input)) {
355
+ if (!utils.strings.isKebabCase(input)) {
389
356
  return "Value must be in kebab-case";
390
357
  }
391
358
  const apiPath = path.join(plop.getDestBasePath(), "api");
@@ -483,89 +450,6 @@ const generateContentType = (plop) => {
483
450
  }
484
451
  });
485
452
  };
486
- const LANGUAGES = {
487
- javascript: "JavaScript",
488
- typescript: "TypeScript"
489
- };
490
- const logInstructions = (pluginName, { language }) => {
491
- const maxLength = ` resolve: './src/plugins/${pluginName}'`.length;
492
- const separator = Array(maxLength).fill("─").join("");
493
- const exportInstruction = language === "js" ? "module.exports =" : "export default";
494
- return `
495
- You can now enable your plugin by adding the following in ${chalk__default.default.yellow(
496
- `./config/plugins.${language}`
497
- )}
498
- ${separator}
499
- ${exportInstruction} {
500
- ${chalk__default.default.gray("// ...")}
501
- ${chalk__default.default.green(`'${pluginName}'`)}: {
502
- enabled: ${chalk__default.default.yellow(true)},
503
- resolve: ${chalk__default.default.yellow(`'./src/plugins/${pluginName}'`)}
504
- },
505
- ${chalk__default.default.gray("// ...")}
506
- }
507
- ${separator}
508
- `;
509
- };
510
- const generatePlugin = (plop) => {
511
- plop.setGenerator("plugin", {
512
- description: "Generate a basic plugin",
513
- prompts: [
514
- {
515
- type: "input",
516
- name: "pluginName",
517
- message: "Plugin name",
518
- validate: (input) => validateInput(input)
519
- },
520
- {
521
- type: "list",
522
- name: "language",
523
- message: "Choose your preferred language",
524
- choices: Object.values(LANGUAGES),
525
- default: LANGUAGES.javascript
526
- }
527
- ],
528
- actions(answers) {
529
- if (!answers) {
530
- return [];
531
- }
532
- const isTypescript = answers.language === LANGUAGES.typescript;
533
- const language = isTypescript ? "ts" : "js";
534
- const projectLanguage = tsUtils__default.default.isUsingTypeScriptSync(process.cwd()) ? "ts" : "js";
535
- if (!utils__namespace.isKebabCase(answers.pluginName)) {
536
- answers.pluginName = utils__namespace.toKebabCase(answers.pluginName);
537
- console.log(
538
- chalk__default.default.yellow(
539
- `Strapi only supports kebab-cased names for plugins.
540
- Your plugin has been automatically renamed to "${answers.pluginName}".`
541
- )
542
- );
543
- }
544
- return [
545
- {
546
- type: "addMany",
547
- destination: "plugins/{{ pluginName }}",
548
- base: `files/${language}/plugin`,
549
- templateFiles: `files/${language}/plugin/**`
550
- },
551
- {
552
- type: "add",
553
- path: "plugins/{{ pluginName }}/README.md",
554
- templateFile: `templates/${language}/README.md.hbs`
555
- },
556
- {
557
- type: "add",
558
- path: "plugins/{{ pluginName }}/package.json",
559
- templateFile: `templates/${language}/plugin-package.json.hbs`
560
- },
561
- () => plop.renderString(
562
- logInstructions(answers.pluginName, { language: projectLanguage }),
563
- null
564
- )
565
- ];
566
- }
567
- });
568
- };
569
453
  const generatePolicy = (plop) => {
570
454
  plop.setGenerator("policy", {
571
455
  description: "Generate a policy for an API",
@@ -693,7 +577,6 @@ const plopfile = (plop) => {
693
577
  generateApi(plop);
694
578
  generateController(plop);
695
579
  generateContentType(plop);
696
- generatePlugin(plop);
697
580
  generatePolicy(plop);
698
581
  generateMiddleware(plop);
699
582
  generateMigration(plop);
@@ -1 +1 @@
1
- {"version":3,"file":"plopfile.js","sources":["../src/plops/utils/validate-input.ts","../src/plops/api.ts","../src/plops/prompts/get-destination-prompts.ts","../src/plops/utils/get-file-path.ts","../src/plops/controller.ts","../src/plops/prompts/ct-names-prompts.ts","../src/plops/prompts/kind-prompts.ts","../src/plops/prompts/draft-and-publish-prompts.ts","../src/plops/utils/validate-attribute-input.ts","../src/plops/prompts/get-attributes-prompts.ts","../src/plops/prompts/bootstrap-api-prompts.ts","../src/plops/content-type.ts","../src/plops/plugin.ts","../src/plops/policy.ts","../src/plops/middleware.ts","../src/plops/utils/validate-file-name-input.ts","../src/plops/utils/get-formatted-date.ts","../src/plops/migration.ts","../src/plops/service.ts","../src/plopfile.ts"],"sourcesContent":["export default (input: string) => {\n const regex = /^[A-Za-z-]+$/g;\n\n if (!input) {\n return 'You must provide an input';\n }\n\n return regex.test(input) || \"Please use only letters, '-' and no spaces\";\n};\n","import { join } from 'path';\nimport { NodePlopAPI } from 'plop';\nimport fs from 'fs-extra';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport validateInput from './utils/validate-input';\n\nexport default (plop: NodePlopAPI) => {\n // API generator\n plop.setGenerator('api', {\n description: 'Generate a basic API',\n prompts: [\n {\n type: 'input',\n name: 'id',\n message: 'API name',\n validate: (input) => validateInput(input),\n },\n {\n type: 'confirm',\n name: 'isPluginApi',\n message: 'Is this API for a plugin?',\n },\n {\n when: (answers) => answers.isPluginApi,\n type: 'list',\n name: 'plugin',\n message: 'Plugin name',\n async choices() {\n const pluginsPath = join(plop.getDestBasePath(), '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, { withFileTypes: true });\n const pluginsDirContent = pluginsDir.filter((fd) => fd.isDirectory());\n\n if (pluginsDirContent.length === 0) {\n throw Error('The \"plugins\" directory is empty');\n }\n\n return pluginsDirContent;\n },\n },\n ],\n actions(answers) {\n if (!answers) {\n return [];\n }\n\n const filePath =\n answers.isPluginApi && answers.plugin ? 'plugins/{{ plugin }}' : 'api/{{ id }}';\n const currentDir = process.cwd();\n const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n\n const baseActions = [\n {\n type: 'add',\n path: `${filePath}/controllers/{{ id }}.${language}`,\n templateFile: `templates/${language}/controller.${language}.hbs`,\n },\n {\n type: 'add',\n path: `${filePath}/services/{{ id }}.${language}`,\n templateFile: `templates/${language}/service.${language}.hbs`,\n },\n ];\n\n if (answers.isPluginApi) {\n return baseActions;\n }\n\n return [\n {\n type: 'add',\n path: `${filePath}/routes/{{ id }}.${language}`,\n templateFile: `templates/${language}/single-route.${language}.hbs`,\n },\n ...baseActions,\n ];\n },\n });\n};\n","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","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","import { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport getFilePath from './utils/get-file-path';\nimport validateInput from './utils/validate-input';\n\nexport default (plop: NodePlopAPI) => {\n // Controller generator\n plop.setGenerator('controller', {\n description: 'Generate a controller for an API',\n prompts: [\n {\n type: 'input',\n name: 'id',\n message: 'Controller name',\n validate: (input) => validateInput(input),\n },\n ...getDestinationPrompts('controller', 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}/controllers/{{ id }}.${language}`,\n templateFile: `templates/${language}/controller.${language}.hbs`,\n },\n ];\n },\n });\n};\n","import pluralize from 'pluralize';\nimport slugify from '@sindresorhus/slugify';\nimport * as utils from '@strapi/utils';\n\nimport type { PromptQuestion } from 'node-plop';\n\ninterface Answers {\n displayName: string;\n singularName: string;\n pluralName: string;\n}\n\nconst questions: Array<PromptQuestion> = [\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) {\n if (!utils.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 (!utils.isKebabCase(input)) {\n return 'Value must be in kebab-case';\n }\n\n return true;\n },\n },\n];\n\nexport default questions;\n","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","import type { PromptQuestion } from 'node-plop';\n\nconst questions: Array<PromptQuestion> = [\n {\n type: 'confirm',\n name: 'useDraftAndPublish',\n default: false,\n message: 'Use draft and publish?',\n },\n];\n\nexport default questions;\n","export default (input: string) => {\n const regex = /^[A-Za-z-|_]+$/g;\n\n if (!input) {\n return 'You must provide an input';\n }\n\n return regex.test(input) || \"Please use only letters, '-', '_', and no spaces\";\n};\n","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","import type { PromptQuestion } from 'node-plop';\n\nconst questions: Array<PromptQuestion> = [\n {\n type: 'confirm',\n name: 'bootstrapApi',\n default: true,\n message: 'Bootstrap API related files?',\n },\n];\n\nexport default questions;\n","import { join } from 'path';\nimport { NodePlopAPI, ActionType } from 'plop';\nimport slugify from '@sindresorhus/slugify';\nimport fs from 'fs-extra';\nimport * as utils from '@strapi/utils';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport getFilePath from './utils/get-file-path';\nimport ctNamesPrompts from './prompts/ct-names-prompts';\nimport kindPrompts from './prompts/kind-prompts';\nimport draftAndPublishPrompts from './prompts/draft-and-publish-prompts';\nimport getAttributesPrompts from './prompts/get-attributes-prompts';\nimport bootstrapApiPrompts from './prompts/bootstrap-api-prompts';\n\nexport default (plop: NodePlopAPI) => {\n // Model generator\n plop.setGenerator('content-type', {\n description: 'Generate a content type for an API',\n async prompts(inquirer) {\n const config = await inquirer.prompt([\n ...ctNamesPrompts,\n ...kindPrompts,\n ...draftAndPublishPrompts,\n ]);\n const attributes = await getAttributesPrompts(inquirer);\n\n const api = await inquirer.prompt([\n ...getDestinationPrompts('model', plop.getDestBasePath()),\n {\n when: (answers) => answers.destination === 'new',\n type: 'input',\n name: 'id',\n default: config.singularName,\n message: 'Name of the new API?',\n async validate(input) {\n if (!utils.isKebabCase(input)) {\n return 'Value must be in kebab-case';\n }\n\n const apiPath = join(plop.getDestBasePath(), 'api');\n const exists = await fs.pathExists(apiPath);\n\n if (!exists) {\n return true;\n }\n\n const apiDir = await fs.readdir(apiPath, { withFileTypes: true });\n const apiDirContent = apiDir.filter((fd) => fd.isDirectory());\n\n if (apiDirContent.findIndex((dir) => dir.name === input) !== -1) {\n throw new Error('This name is already taken.');\n }\n\n return true;\n },\n },\n ...bootstrapApiPrompts,\n ]);\n\n return {\n ...config,\n ...api,\n attributes,\n };\n },\n actions(answers) {\n if (!answers) {\n return [];\n }\n\n const attributes = answers.attributes.reduce((object: any, answer: any) => {\n const val: any = { type: answer.attributeType };\n\n if (answer.attributeType === 'enumeration') {\n val.enum = answer.enum.split(',').map((item: string) => item.trim());\n }\n\n if (answer.attributeType === 'media') {\n val.allowedTypes = ['images', 'files', 'videos', 'audios'];\n val.multiple = answer.multiple;\n }\n\n return Object.assign(object, { [answer.attributeName]: val }, {});\n }, {});\n\n const filePath = getFilePath(answers.destination);\n // TODO: use basePath instead\n const currentDir = process.cwd();\n const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n\n const baseActions: Array<ActionType> = [\n {\n type: 'add',\n path: `${filePath}/content-types/{{ singularName }}/schema.json`,\n templateFile: `templates/${language}/content-type.schema.json.hbs`,\n data: {\n collectionName: slugify(answers.pluralName, { separator: '_' }),\n },\n },\n ];\n\n if (Object.entries(attributes).length > 0) {\n baseActions.push({\n type: 'modify',\n path: `${filePath}/content-types/{{ singularName }}/schema.json`,\n transform(template: string) {\n const parsedTemplate = JSON.parse(template);\n parsedTemplate.attributes = attributes;\n return JSON.stringify(parsedTemplate, null, 2);\n },\n });\n }\n\n if (answers.bootstrapApi) {\n const { singularName } = answers;\n\n let uid;\n if (answers.destination === 'new') {\n uid = `api::${answers.id}.${singularName}`;\n } else if (answers.api) {\n uid = `api::${answers.api}.${singularName}`;\n } else if (answers.plugin) {\n uid = `plugin::${answers.plugin}.${singularName}`;\n }\n\n baseActions.push(\n {\n type: 'add',\n path: `${filePath}/controllers/{{ singularName }}.${language}`,\n templateFile: `templates/${language}/core-controller.${language}.hbs`,\n data: { uid },\n },\n {\n type: 'add',\n path: `${filePath}/services/{{ singularName }}.${language}`,\n templateFile: `templates/${language}/core-service.${language}.hbs`,\n data: { uid },\n },\n {\n type: 'add',\n path: `${filePath}/routes/{{ singularName }}.${language}`,\n templateFile: `templates/${language}/core-router.${language}.hbs`,\n data: { uid },\n }\n );\n }\n\n return baseActions;\n },\n });\n};\n","import { NodePlopAPI } from 'plop';\nimport chalk from 'chalk';\nimport tsUtils from '@strapi/typescript-utils';\nimport * as utils from '@strapi/utils';\n\nimport validateInput from './utils/validate-input';\n\nconst LANGUAGES = {\n javascript: 'JavaScript',\n typescript: 'TypeScript',\n};\n\nconst logInstructions = (pluginName: string, { language }: { language: string }) => {\n const maxLength = ` resolve: './src/plugins/${pluginName}'`.length;\n const separator = Array(maxLength).fill('─').join('');\n\n const exportInstruction = language === 'js' ? 'module.exports =' : 'export default';\n\n return `\nYou can now enable your plugin by adding the following in ${chalk.yellow(\n `./config/plugins.${language}`\n )}\n${separator}\n${exportInstruction} {\n ${chalk.gray('// ...')}\n ${chalk.green(`'${pluginName}'`)}: {\n enabled: ${chalk.yellow(true)},\n resolve: ${chalk.yellow(`'./src/plugins/${pluginName}'`)}\n },\n ${chalk.gray('// ...')}\n}\n${separator}\n`;\n};\n\nexport default (plop: NodePlopAPI) => {\n // Plugin generator\n plop.setGenerator('plugin', {\n description: 'Generate a basic plugin',\n prompts: [\n {\n type: 'input',\n name: 'pluginName',\n message: 'Plugin name',\n validate: (input) => validateInput(input),\n },\n {\n type: 'list',\n name: 'language',\n message: 'Choose your preferred language',\n choices: Object.values(LANGUAGES),\n default: LANGUAGES.javascript,\n },\n ],\n actions(answers) {\n if (!answers) {\n return [];\n }\n\n const isTypescript = answers.language === LANGUAGES.typescript;\n const language = isTypescript ? 'ts' : 'js';\n const projectLanguage = tsUtils.isUsingTypeScriptSync(process.cwd()) ? 'ts' : 'js';\n\n if (!utils.isKebabCase(answers.pluginName)) {\n answers.pluginName = utils.toKebabCase(answers.pluginName);\n console.log(\n chalk.yellow(\n `Strapi only supports kebab-cased names for plugins.\\nYour plugin has been automatically renamed to \"${answers.pluginName}\".`\n )\n );\n }\n\n return [\n {\n type: 'addMany',\n destination: 'plugins/{{ pluginName }}',\n base: `files/${language}/plugin`,\n templateFiles: `files/${language}/plugin/**`,\n },\n {\n type: 'add',\n path: 'plugins/{{ pluginName }}/README.md',\n templateFile: `templates/${language}/README.md.hbs`,\n },\n {\n type: 'add',\n path: 'plugins/{{ pluginName }}/package.json',\n templateFile: `templates/${language}/plugin-package.json.hbs`,\n },\n () =>\n plop.renderString(\n logInstructions(answers.pluginName, { language: projectLanguage }),\n null\n ),\n ];\n },\n });\n};\n","import { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport validateInput from './utils/validate-input';\nimport getFilePath from './utils/get-file-path';\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 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}/policies/{{ id }}.${language}`,\n templateFile: `templates/${language}/policy.${language}.hbs`,\n },\n ];\n },\n });\n};\n","import { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport validateInput from './utils/validate-input';\nimport getFilePath from './utils/get-file-path';\n\nexport default (plop: NodePlopAPI) => {\n // middleware generator\n plop.setGenerator('middleware', {\n description: 'Generate a middleware for an API',\n prompts: [\n {\n type: 'input',\n name: 'name',\n message: 'Middleware name',\n validate: (input) => validateInput(input),\n },\n ...getDestinationPrompts('middleware', plop.getDestBasePath(), { rootFolder: true }),\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}/middlewares/{{ name }}.${language}`,\n templateFile: `templates/${language}/middleware.${language}.hbs`,\n },\n ];\n },\n });\n};\n","export default (input: string) => {\n const regex = /^[A-Za-z-_0-9]+$/g;\n\n if (!input) {\n return 'You must provide an input';\n }\n\n return regex.test(input) || \"Please use only letters and number, '-' or '_' and no spaces\";\n};\n","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","import { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\nimport validateFileNameInput from './utils/validate-file-name-input';\nimport getFormattedDate from './utils/get-formatted-date';\n\nexport default (plop: NodePlopAPI) => {\n // Migration generator\n plop.setGenerator('migration', {\n description: 'Generate a migration',\n prompts: [\n {\n type: 'input',\n name: 'name',\n message: 'Migration name',\n validate: (input) => validateFileNameInput(input),\n },\n ],\n actions() {\n const currentDir = process.cwd();\n const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n const timestamp = getFormattedDate();\n\n return [\n {\n type: 'add',\n path: `${currentDir}/database/migrations/${timestamp}.{{ name }}.${language}`,\n templateFile: `templates/${language}/migration.${language}.hbs`,\n },\n ];\n },\n });\n};\n","import { 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","import pluralize from 'pluralize';\nimport { NodePlopAPI } from 'plop';\n\nimport generateApi from './plops/api';\nimport generateController from './plops/controller';\nimport generateContentType from './plops/content-type';\nimport generatePlugin from './plops/plugin';\nimport generatePolicy from './plops/policy';\nimport generateMiddleware from './plops/middleware';\nimport generateMigration from './plops/migration';\nimport generateService from './plops/service';\n\nexport default (plop: NodePlopAPI) => {\n // Plop config\n plop.setWelcomeMessage('Strapi Generators');\n plop.addHelper('pluralize', (text: string) => pluralize(text));\n\n // Generators\n generateApi(plop);\n generateController(plop);\n generateContentType(plop);\n generatePlugin(plop);\n generatePolicy(plop);\n generateMiddleware(plop);\n generateMigration(plop);\n generateService(plop);\n};\n"],"names":["join","fs","tsUtils","questions","slugify","utils","pluralize","inquirer","answers","ctNamesPrompts","kindPrompts","draftAndPublishPrompts","bootstrapApiPrompts","chalk"],"mappings":"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"}
1
+ {"version":3,"file":"plopfile.js","sources":["../src/plops/utils/validate-input.ts","../src/plops/api.ts","../src/plops/prompts/get-destination-prompts.ts","../src/plops/utils/get-file-path.ts","../src/plops/controller.ts","../src/plops/prompts/ct-names-prompts.ts","../src/plops/prompts/kind-prompts.ts","../src/plops/utils/validate-attribute-input.ts","../src/plops/prompts/get-attributes-prompts.ts","../src/plops/prompts/bootstrap-api-prompts.ts","../src/plops/content-type.ts","../src/plops/policy.ts","../src/plops/middleware.ts","../src/plops/utils/validate-file-name-input.ts","../src/plops/utils/get-formatted-date.ts","../src/plops/migration.ts","../src/plops/service.ts","../src/plopfile.ts"],"sourcesContent":["export default (input: string) => {\n const regex = /^[A-Za-z-]+$/g;\n\n if (!input) {\n return 'You must provide an input';\n }\n\n return regex.test(input) || \"Please use only letters, '-' and no spaces\";\n};\n","import { join } from 'path';\nimport type { NodePlopAPI } from 'plop';\nimport fs from 'fs-extra';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport validateInput from './utils/validate-input';\n\nexport default (plop: NodePlopAPI) => {\n // API generator\n plop.setGenerator('api', {\n description: 'Generate a basic API',\n prompts: [\n {\n type: 'input',\n name: 'id',\n message: 'API name',\n validate: (input) => validateInput(input),\n },\n {\n type: 'confirm',\n name: 'isPluginApi',\n message: 'Is this API for a plugin?',\n },\n {\n when: (answers) => answers.isPluginApi,\n type: 'list',\n name: 'plugin',\n message: 'Plugin name',\n async choices() {\n const pluginsPath = join(plop.getDestBasePath(), '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, { withFileTypes: true });\n const pluginsDirContent = pluginsDir.filter((fd) => fd.isDirectory());\n\n if (pluginsDirContent.length === 0) {\n throw Error('The \"plugins\" directory is empty');\n }\n\n return pluginsDirContent;\n },\n },\n ],\n actions(answers) {\n if (!answers) {\n return [];\n }\n\n const filePath =\n answers.isPluginApi && answers.plugin ? 'plugins/{{ plugin }}' : 'api/{{ id }}';\n const currentDir = process.cwd();\n const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n\n const baseActions = [\n {\n type: 'add',\n path: `${filePath}/controllers/{{ id }}.${language}`,\n templateFile: `templates/${language}/controller.${language}.hbs`,\n },\n {\n type: 'add',\n path: `${filePath}/services/{{ id }}.${language}`,\n templateFile: `templates/${language}/service.${language}.hbs`,\n },\n ];\n\n if (answers.isPluginApi) {\n return baseActions;\n }\n\n return [\n {\n type: 'add',\n path: `${filePath}/routes/{{ id }}.${language}`,\n templateFile: `templates/${language}/single-route.${language}.hbs`,\n },\n ...baseActions,\n ];\n },\n });\n};\n","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","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","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';\nimport validateInput from './utils/validate-input';\n\nexport default (plop: NodePlopAPI) => {\n // Controller generator\n plop.setGenerator('controller', {\n description: 'Generate a controller for an API',\n prompts: [\n {\n type: 'input',\n name: 'id',\n message: 'Controller name',\n validate: (input) => validateInput(input),\n },\n ...getDestinationPrompts('controller', 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}/controllers/{{ id }}.${language}`,\n templateFile: `templates/${language}/controller.${language}.hbs`,\n },\n ];\n },\n });\n};\n","import pluralize from 'pluralize';\nimport slugify from '@sindresorhus/slugify';\nimport { strings } from '@strapi/utils';\n\nimport type { PromptQuestion } from 'node-plop';\n\ninterface Answers {\n displayName: string;\n singularName: string;\n pluralName: string;\n}\n\nconst questions: Array<PromptQuestion> = [\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) {\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","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","export default (input: string) => {\n const regex = /^[A-Za-z-|_]+$/g;\n\n if (!input) {\n return 'You must provide an input';\n }\n\n return regex.test(input) || \"Please use only letters, '-', '_', and no spaces\";\n};\n","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","import type { PromptQuestion } from 'node-plop';\n\nconst questions: Array<PromptQuestion> = [\n {\n type: 'confirm',\n name: 'bootstrapApi',\n default: true,\n message: 'Bootstrap API related files?',\n },\n];\n\nexport default questions;\n","import { join } from 'path';\nimport type { NodePlopAPI, ActionType } from 'plop';\nimport slugify from '@sindresorhus/slugify';\nimport fs from 'fs-extra';\nimport { strings } from '@strapi/utils';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport getFilePath from './utils/get-file-path';\nimport ctNamesPrompts from './prompts/ct-names-prompts';\nimport kindPrompts from './prompts/kind-prompts';\nimport getAttributesPrompts from './prompts/get-attributes-prompts';\nimport bootstrapApiPrompts from './prompts/bootstrap-api-prompts';\n\nexport default (plop: NodePlopAPI) => {\n // Model generator\n plop.setGenerator('content-type', {\n description: 'Generate a content type for an API',\n async prompts(inquirer) {\n const config = await inquirer.prompt([...ctNamesPrompts, ...kindPrompts]);\n // @ts-expect-error issue with deprecated inquirer.prompts attribute to fix with ugprade to inquirer\n const attributes = await getAttributesPrompts(inquirer);\n\n const api = await inquirer.prompt([\n ...getDestinationPrompts('model', plop.getDestBasePath()),\n {\n when: (answers) => answers.destination === 'new',\n type: 'input',\n name: 'id',\n default: config.singularName,\n message: 'Name of the new API?',\n async validate(input) {\n if (!strings.isKebabCase(input)) {\n return 'Value must be in kebab-case';\n }\n\n const apiPath = join(plop.getDestBasePath(), 'api');\n const exists = await fs.pathExists(apiPath);\n\n if (!exists) {\n return true;\n }\n\n const apiDir = await fs.readdir(apiPath, { withFileTypes: true });\n const apiDirContent = apiDir.filter((fd) => fd.isDirectory());\n\n if (apiDirContent.findIndex((dir) => dir.name === input) !== -1) {\n throw new Error('This name is already taken.');\n }\n\n return true;\n },\n },\n ...bootstrapApiPrompts,\n ]);\n\n return {\n ...config,\n ...api,\n attributes,\n };\n },\n actions(answers) {\n if (!answers) {\n return [];\n }\n\n const attributes = answers.attributes.reduce((object: any, answer: any) => {\n const val: any = { type: answer.attributeType };\n\n if (answer.attributeType === 'enumeration') {\n val.enum = answer.enum.split(',').map((item: string) => item.trim());\n }\n\n if (answer.attributeType === 'media') {\n val.allowedTypes = ['images', 'files', 'videos', 'audios'];\n val.multiple = answer.multiple;\n }\n\n return Object.assign(object, { [answer.attributeName]: val }, {});\n }, {});\n\n const filePath = getFilePath(answers.destination);\n // TODO: use basePath instead\n const currentDir = process.cwd();\n const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n\n const baseActions: Array<ActionType> = [\n {\n type: 'add',\n path: `${filePath}/content-types/{{ singularName }}/schema.json`,\n templateFile: `templates/${language}/content-type.schema.json.hbs`,\n data: {\n collectionName: slugify(answers.pluralName, { separator: '_' }),\n },\n },\n ];\n\n if (Object.entries(attributes).length > 0) {\n baseActions.push({\n type: 'modify',\n path: `${filePath}/content-types/{{ singularName }}/schema.json`,\n transform(template: string) {\n const parsedTemplate = JSON.parse(template);\n parsedTemplate.attributes = attributes;\n return JSON.stringify(parsedTemplate, null, 2);\n },\n });\n }\n\n if (answers.bootstrapApi) {\n const { singularName } = answers;\n\n let uid;\n if (answers.destination === 'new') {\n uid = `api::${answers.id}.${singularName}`;\n } else if (answers.api) {\n uid = `api::${answers.api}.${singularName}`;\n } else if (answers.plugin) {\n uid = `plugin::${answers.plugin}.${singularName}`;\n }\n\n baseActions.push(\n {\n type: 'add',\n path: `${filePath}/controllers/{{ singularName }}.${language}`,\n templateFile: `templates/${language}/core-controller.${language}.hbs`,\n data: { uid },\n },\n {\n type: 'add',\n path: `${filePath}/services/{{ singularName }}.${language}`,\n templateFile: `templates/${language}/core-service.${language}.hbs`,\n data: { uid },\n },\n {\n type: 'add',\n path: `${filePath}/routes/{{ singularName }}.${language}`,\n templateFile: `templates/${language}/core-router.${language}.hbs`,\n data: { uid },\n }\n );\n }\n\n return baseActions;\n },\n });\n};\n","import type { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport validateInput from './utils/validate-input';\nimport getFilePath from './utils/get-file-path';\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 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}/policies/{{ id }}.${language}`,\n templateFile: `templates/${language}/policy.${language}.hbs`,\n },\n ];\n },\n });\n};\n","import type { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\n\nimport getDestinationPrompts from './prompts/get-destination-prompts';\nimport validateInput from './utils/validate-input';\nimport getFilePath from './utils/get-file-path';\n\nexport default (plop: NodePlopAPI) => {\n // middleware generator\n plop.setGenerator('middleware', {\n description: 'Generate a middleware for an API',\n prompts: [\n {\n type: 'input',\n name: 'name',\n message: 'Middleware name',\n validate: (input) => validateInput(input),\n },\n ...getDestinationPrompts('middleware', plop.getDestBasePath(), { rootFolder: true }),\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}/middlewares/{{ name }}.${language}`,\n templateFile: `templates/${language}/middleware.${language}.hbs`,\n },\n ];\n },\n });\n};\n","export default (input: string) => {\n const regex = /^[A-Za-z-_0-9]+$/g;\n\n if (!input) {\n return 'You must provide an input';\n }\n\n return regex.test(input) || \"Please use only letters and number, '-' or '_' and no spaces\";\n};\n","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","import type { NodePlopAPI } from 'plop';\nimport tsUtils from '@strapi/typescript-utils';\nimport validateFileNameInput from './utils/validate-file-name-input';\nimport getFormattedDate from './utils/get-formatted-date';\n\nexport default (plop: NodePlopAPI) => {\n // Migration generator\n plop.setGenerator('migration', {\n description: 'Generate a migration',\n prompts: [\n {\n type: 'input',\n name: 'name',\n message: 'Migration name',\n validate: (input) => validateFileNameInput(input),\n },\n ],\n actions() {\n const currentDir = process.cwd();\n const language = tsUtils.isUsingTypeScriptSync(currentDir) ? 'ts' : 'js';\n const timestamp = getFormattedDate();\n\n return [\n {\n type: 'add',\n path: `${currentDir}/database/migrations/${timestamp}.{{ name }}.${language}`,\n templateFile: `templates/${language}/migration.${language}.hbs`,\n },\n ];\n },\n });\n};\n","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","import pluralize from 'pluralize';\nimport type { NodePlopAPI } from 'plop';\n\nimport generateApi from './plops/api';\nimport generateController from './plops/controller';\nimport generateContentType from './plops/content-type';\nimport generatePolicy from './plops/policy';\nimport generateMiddleware from './plops/middleware';\nimport generateMigration from './plops/migration';\nimport generateService from './plops/service';\n\nexport default (plop: NodePlopAPI) => {\n // Plop config\n plop.setWelcomeMessage('Strapi Generators');\n plop.addHelper('pluralize', (text: string) => pluralize(text));\n\n // Generators\n generateApi(plop);\n generateController(plop);\n generateContentType(plop);\n generatePolicy(plop);\n generateMiddleware(plop);\n generateMigration(plop);\n generateService(plop);\n};\n"],"names":["join","fs","tsUtils","questions","slugify","strings","pluralize","inquirer","answers","ctNamesPrompts","kindPrompts","bootstrapApiPrompts"],"mappings":"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"}