@strapi/generators 0.0.0-next.f5b09a8e61e059f02784478e27c310c6290be088 → 0.0.0-next.f6dca5adf05ef6bed9605a1535999ab0bbbf063e
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.
- package/LICENSE +18 -3
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +35 -8
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +11 -6
- package/dist/index.mjs.map +1 -1
- package/dist/plopfile.d.ts +1 -1
- package/dist/plopfile.d.ts.map +1 -1
- package/dist/plopfile.js +6 -123
- package/dist/plopfile.js.map +1 -1
- package/dist/plopfile.mjs +7 -104
- package/dist/plopfile.mjs.map +1 -1
- package/dist/plops/api.d.ts +1 -1
- package/dist/plops/api.d.ts.map +1 -1
- package/dist/plops/content-type.d.ts +1 -1
- package/dist/plops/content-type.d.ts.map +1 -1
- package/dist/plops/controller.d.ts +1 -1
- package/dist/plops/controller.d.ts.map +1 -1
- package/dist/plops/middleware.d.ts +1 -1
- package/dist/plops/middleware.d.ts.map +1 -1
- package/dist/plops/migration.d.ts +1 -1
- package/dist/plops/migration.d.ts.map +1 -1
- package/dist/plops/policy.d.ts +1 -1
- package/dist/plops/policy.d.ts.map +1 -1
- package/dist/plops/service.d.ts +1 -1
- package/dist/plops/service.d.ts.map +1 -1
- package/dist/templates/js/content-type.schema.json.hbs +0 -1
- package/dist/templates/ts/content-type.schema.json.hbs +0 -1
- package/dist/templates/ts/middleware.ts.hbs +2 -2
- package/package.json +12 -12
- package/dist/files/js/plugin/.gitattributes +0 -103
- package/dist/files/js/plugin/admin/src/components/Initializer/index.js +0 -26
- package/dist/files/js/plugin/admin/src/components/PluginIcon/index.js +0 -12
- package/dist/files/js/plugin/admin/src/index.js +0 -61
- package/dist/files/js/plugin/admin/src/pages/App/index.js +0 -25
- package/dist/files/js/plugin/admin/src/pages/HomePage/index.js +0 -20
- package/dist/files/js/plugin/admin/src/pluginId.js +0 -5
- package/dist/files/js/plugin/admin/src/translations/en.json +0 -1
- package/dist/files/js/plugin/admin/src/translations/fr.json +0 -1
- package/dist/files/js/plugin/admin/src/utils/getTrad.js +0 -5
- package/dist/files/js/plugin/server/bootstrap.js +0 -5
- package/dist/files/js/plugin/server/config/index.js +0 -6
- package/dist/files/js/plugin/server/content-types/index.js +0 -3
- package/dist/files/js/plugin/server/controllers/index.js +0 -7
- package/dist/files/js/plugin/server/controllers/my-controller.js.hbs +0 -10
- package/dist/files/js/plugin/server/destroy.js +0 -5
- package/dist/files/js/plugin/server/index.js +0 -25
- package/dist/files/js/plugin/server/middlewares/index.js +0 -3
- package/dist/files/js/plugin/server/policies/index.js +0 -3
- package/dist/files/js/plugin/server/register.js +0 -5
- package/dist/files/js/plugin/server/routes/index.js +0 -10
- package/dist/files/js/plugin/server/services/index.js +0 -7
- package/dist/files/js/plugin/server/services/my-service.js +0 -7
- package/dist/files/js/plugin/strapi-admin.js +0 -3
- package/dist/files/js/plugin/strapi-server.js +0 -3
- package/dist/files/ts/plugin/.gitattributes +0 -103
- package/dist/files/ts/plugin/admin/src/components/Initializer/index.tsx +0 -24
- package/dist/files/ts/plugin/admin/src/components/PluginIcon/index.tsx +0 -12
- package/dist/files/ts/plugin/admin/src/index.tsx +0 -67
- package/dist/files/ts/plugin/admin/src/pages/App/index.tsx +0 -25
- package/dist/files/ts/plugin/admin/src/pages/HomePage/index.tsx +0 -19
- package/dist/files/ts/plugin/admin/src/pluginId.ts +0 -5
- package/dist/files/ts/plugin/admin/src/translations/en.json +0 -1
- package/dist/files/ts/plugin/admin/src/translations/fr.json +0 -1
- package/dist/files/ts/plugin/admin/src/utils/getTrad.ts +0 -5
- package/dist/files/ts/plugin/custom.d.ts +0 -5
- package/dist/files/ts/plugin/server/bootstrap.ts +0 -5
- package/dist/files/ts/plugin/server/config/index.ts +0 -4
- package/dist/files/ts/plugin/server/content-types/index.ts +0 -1
- package/dist/files/ts/plugin/server/controllers/index.ts +0 -5
- package/dist/files/ts/plugin/server/controllers/my-controller.ts.hbs +0 -10
- package/dist/files/ts/plugin/server/destroy.ts +0 -5
- package/dist/files/ts/plugin/server/index.ts +0 -23
- package/dist/files/ts/plugin/server/middlewares/index.ts +0 -1
- package/dist/files/ts/plugin/server/policies/index.ts +0 -1
- package/dist/files/ts/plugin/server/register.ts +0 -5
- package/dist/files/ts/plugin/server/routes/index.ts +0 -10
- package/dist/files/ts/plugin/server/services/index.ts +0 -5
- package/dist/files/ts/plugin/server/services/my-service.ts +0 -7
- package/dist/files/ts/plugin/strapi-admin.js +0 -3
- package/dist/files/ts/plugin/strapi-server.js +0 -3
- package/dist/files/ts/plugin/tsconfig.json +0 -20
- package/dist/files/ts/plugin/tsconfig.server.json +0 -25
- package/dist/plops/plugin.d.ts +0 -4
- package/dist/plops/plugin.d.ts.map +0 -1
- package/dist/plops/prompts/draft-and-publish-prompts.d.ts +0 -4
- package/dist/plops/prompts/draft-and-publish-prompts.d.ts.map +0 -1
- package/dist/templates/js/README.md.hbs +0 -3
- package/dist/templates/js/plugin-package.json.hbs +0 -42
- package/dist/templates/ts/README.md.hbs +0 -3
- 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
|
|
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,
|
|
22
|
-
|
|
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:
|
|
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>;
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"
|
|
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
|
-
|
|
10
|
-
|
|
11
|
-
|
|
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
|
|
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 =
|
|
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
|
|
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,IAAQ,IAAA,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,IAC7D;AAAA,EAAA;AAEJ;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,IAAC;AAAA,EAAA,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
|
-
|
|
6
|
-
|
|
7
|
-
|
|
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), {
|
package/dist/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../src/index.ts"],"sourcesContent":["import { join } from 'node:path';\nimport
|
|
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,IAAQ,IAAA,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,IAC7D;AAAA,EAAA;AAEJ;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,IAAC;AAAA,EAAA,CACd;AACH;"}
|
package/dist/plopfile.d.ts
CHANGED
package/dist/plopfile.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"plopfile.d.ts","sourceRoot":"","sources":["../src/plopfile.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,MAAM,CAAC;+
|
|
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$
|
|
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 (!
|
|
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 (!
|
|
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$
|
|
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 (!
|
|
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);
|
package/dist/plopfile.js.map
CHANGED
|
@@ -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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,MAAe,gBAAA,CAAC,UAAkB;AAChC,QAAM,QAAQ;AAEd,MAAI,CAAC,OAAO;AACH,WAAA;AAAA,EACT;AAEO,SAAA,MAAM,KAAK,KAAK,KAAK;AAC9B;ACDA,MAAe,cAAA,CAAC,SAAsB;AAEpC,OAAK,aAAa,OAAO;AAAA,IACvB,aAAa;AAAA,IACb,SAAS;AAAA,MACP;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,UAAU,CAAC,UAAU,cAAc,KAAK;AAAA,MAC1C;AAAA,MACA;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,MACA;AAAA,QACE,MAAM,CAAC,YAAY,QAAQ;AAAA,QAC3B,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,MAAM,UAAU;AACd,gBAAM,cAAcA,KAAAA,KAAK,KAAK,mBAAmB,SAAS;AAC1D,gBAAM,SAAS,MAAMC,YAAAA,QAAG,WAAW,WAAW;AAE9C,cAAI,CAAC,QAAQ;AACX,kBAAM,MAAM,qCAAsC;AAAA,UACpD;AAEM,gBAAA,aAAa,MAAMA,YAAAA,QAAG,QAAQ,aAAa,EAAE,eAAe,MAAM;AACxE,gBAAM,oBAAoB,WAAW,OAAO,CAAC,OAAO,GAAG,aAAa;AAEhE,cAAA,kBAAkB,WAAW,GAAG;AAClC,kBAAM,MAAM,kCAAkC;AAAA,UAChD;AAEO,iBAAA;AAAA,QACT;AAAA,MACF;AAAA,IACF;AAAA,IACA,QAAQ,SAAS;AACf,UAAI,CAAC,SAAS;AACZ,eAAO;MACT;AAEA,YAAM,WACJ,QAAQ,eAAe,QAAQ,SAAS,yBAAyB;AAC7D,YAAA,aAAa,QAAQ;AAC3B,YAAM,WAAWC,iBAAAA,QAAQ,sBAAsB,UAAU,IAAI,OAAO;AAEpE,YAAM,cAAc;AAAA,QAClB;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ,yBAAyB,QAAQ;AAAA,UAClD,cAAc,aAAa,QAAQ,eAAe,QAAQ;AAAA,QAC5D;AAAA,QACA;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ,sBAAsB,QAAQ;AAAA,UAC/C,cAAc,aAAa,QAAQ,YAAY,QAAQ;AAAA,QACzD;AAAA,MAAA;AAGF,UAAI,QAAQ,aAAa;AAChB,eAAA;AAAA,MACT;AAEO,aAAA;AAAA,QACL;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ,oBAAoB,QAAQ;AAAA,UAC7C,cAAc,aAAa,QAAQ,iBAAiB,QAAQ;AAAA,QAC9D;AAAA,QACA,GAAG;AAAA,MAAA;AAAA,IAEP;AAAA,EAAA,CACD;AACH;AC/EA,MAAA,wBAAe,CACb,QACA,UACA,EAAE,aAAa,MAAM,IAAI,CAAA,MACC;AACnB,SAAA;AAAA,IACL;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,SAAS,iCAAiC,MAAM;AAAA,MAChD,SAAS;AAAA,QACP,GAAI,aACA;AAAA,UACE;AAAA,YACE,MAAM,OAAO,MAAM;AAAA,YACnB,OAAO;AAAA,UACT;AAAA,QAAA,IAEF;AAAA,UACE;AAAA,YACE,MAAM,OAAO,MAAM;AAAA,YACnB,OAAO;AAAA,UACT;AAAA,QACF;AAAA,QACJ,EAAE,MAAM,OAAO,MAAM,uBAAuB,OAAO,MAAM;AAAA,QACzD,EAAE,MAAM,OAAO,MAAM,0BAA0B,OAAO,SAAS;AAAA,MACjE;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM,CAAC,YAAY,QAAQ,gBAAgB;AAAA,MAC3C,MAAM;AAAA,MACN,SAAS;AAAA,MACT,MAAM;AAAA,MACN,MAAM,UAAU;AACR,cAAA,UAAUF,KAAAA,KAAK,UAAU,KAAK;AACpC,cAAM,SAAS,MAAMC,YAAAA,QAAG,WAAW,OAAO;AAE1C,YAAI,CAAC,QAAQ;AACX,gBAAM,MAAM,kCAAmC;AAAA,QACjD;AAEM,cAAA,SAAS,MAAMA,YAAAA,QAAG,QAAQ,SAAS,EAAE,eAAe,MAAM;AAChE,cAAM,gBAAgB,OAAO,OAAO,CAAC,OAAO,GAAG,aAAa;AAExD,YAAA,cAAc,WAAW,GAAG;AAC9B,gBAAM,MAAM,8BAA8B;AAAA,QAC5C;AAEO,eAAA;AAAA,MACT;AAAA,IACF;AAAA,IACA;AAAA,MACE,MAAM,CAAC,YAAY,QAAQ,gBAAgB;AAAA,MAC3C,MAAM;AAAA,MACN,SAAS;AAAA,MACT,MAAM;AAAA,MACN,MAAM,UAAU;AACR,cAAA,cAAcD,KAAAA,KAAK,UAAU,SAAS;AAC5C,cAAM,SAAS,MAAMC,YAAAA,QAAG,WAAW,WAAW;AAE9C,YAAI,CAAC,QAAQ;AACX,gBAAM,MAAM,qCAAsC;AAAA,QACpD;AAEA,cAAM,aAAa,MAAMA,YAAAA,QAAG,QAAQ,WAAW;AAC/C,cAAM,oBAAoB,WAAW;AAAA,UAAO,CAAC,QAC3CA,YAAG,QAAA,UAAUD,KAAAA,KAAK,aAAa,GAAG,CAAC,EAAE,YAAY;AAAA,QAAA;AAG/C,YAAA,kBAAkB,WAAW,GAAG;AAClC,gBAAM,MAAM,kCAAkC;AAAA,QAChD;AAEO,eAAA;AAAA,MACT;AAAA,IACF;AAAA,EAAA;AAEJ;AClFA,MAAe,cAAA,CAAC,gBAAwB;AACtC,MAAI,gBAAgB,OAAO;AAClB,WAAA;AAAA,EACT;AAEA,MAAI,gBAAgB,UAAU;AACrB,WAAA;AAAA,EACT;AAEA,MAAI,gBAAgB,QAAQ;AACnB,WAAA;AAAA,EACT;AAEO,SAAA;AACT;ACPA,MAAe,qBAAA,CAAC,SAAsB;AAEpC,OAAK,aAAa,cAAc;AAAA,IAC9B,aAAa;AAAA,IACb,SAAS;AAAA,MACP;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,UAAU,CAAC,UAAU,cAAc,KAAK;AAAA,MAC1C;AAAA,MACA,GAAG,sBAAsB,cAAc,KAAK,iBAAiB;AAAA,IAC/D;AAAA,IACA,QAAQ,SAAS;AACf,UAAI,CAAC,SAAS;AACZ,eAAO;MACT;AAEM,YAAA,WAAW,YAAY,QAAQ,WAAW;AAC1C,YAAA,aAAa,QAAQ;AAC3B,YAAM,WAAWE,iBAAAA,QAAQ,sBAAsB,UAAU,IAAI,OAAO;AAE7D,aAAA;AAAA,QACL;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ,yBAAyB,QAAQ;AAAA,UAClD,cAAc,aAAa,QAAQ,eAAe,QAAQ;AAAA,QAC5D;AAAA,MAAA;AAAA,IAEJ;AAAA,EAAA,CACD;AACH;AC1BA,MAAMC,cAAmC;AAAA,EACvC;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IACT,UAAU,CAAC,UAAkB,CAAC,CAAC;AAAA,EACjC;AAAA,EACA;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS,CAAC,YAAqBC,yBAAQ,QAAQ,WAAW;AAAA,IAC1D,SAAS,OAAO;AACd,UAAI,CAACC,iBAAM,YAAY,KAAK,GAAG;AACtB,eAAA;AAAA,MACT;AAEO,aAAA;AAAA,IACT;AAAA,EACF;AAAA,EACA;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS,CAAC,YAAqBC,2BAAU,QAAQ,YAAY;AAAA,IAC7D,SAAS,OAAe,SAAkB;AACpC,UAAA,QAAQ,iBAAiB,OAAO;AAC3B,eAAA;AAAA,MACT;AAEA,UAAI,CAACD,iBAAM,YAAY,KAAK,GAAG;AACtB,eAAA;AAAA,MACT;AAEO,aAAA;AAAA,IACT;AAAA,EACF;AACF;AC7CA,MAAMF,cAAmC;AAAA,EACvC;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS;AAAA,IACT,SAAS;AAAA,MACP,EAAE,MAAM,mBAAmB,OAAO,iBAAiB;AAAA,MACnD,EAAE,MAAM,eAAe,OAAO,aAAa;AAAA,IAC7C;AAAA,IACA,UAAU,CAAC,UAAkB,cAAc,KAAK;AAAA,EAClD;AACF;ACdA,MAAMA,cAAmC;AAAA,EACvC;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS;AAAA,EACX;AACF;ACTA,MAAe,yBAAA,CAAC,UAAkB;AAChC,QAAM,QAAQ;AAEd,MAAI,CAAC,OAAO;AACH,WAAA;AAAA,EACT;AAEO,SAAA,MAAM,KAAK,KAAK,KAAK;AAC9B;ACGA,MAAM,gBAAgB;AAAA;AAAA,EAEpB;AAAA;AAAA,EAGA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAEA,MAAM,uBAA+C,OAAO,aAAa;AACvE,QAAM,EAAE,cAAA,IAAkB,MAAM,SAAS,OAAO;AAAA,IAC9C;AAAA,MACE,MAAM;AAAA,MACN,MAAM;AAAA,MACN,SAAS;AAAA,IACX;AAAA,EAAA,CACD;AAED,QAAM,aAAqC,CAAA;AAMrC,QAAA,sBAAsB,OAAOI,cAAoD;AAC/E,UAAA,UAAU,MAAMA,UAAS,OAAO;AAAA,MACpC;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,UAAU,CAAC,UAAkB,uBAAuB,KAAK;AAAA,MAC3D;AAAA,MACA;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,UAAU,cAAc;AAAA,QACxB,SAAS,cAAc,IAAI,CAAC,SAAS;AACnC,iBAAO,EAAE,MAAM,MAAM,OAAO,KAAK;AAAA,QAAA,CAClC;AAAA,MACH;AAAA,MACA;AAAA,QACE,MAAM,CAACC,aAAYA,SAAQ,kBAAkB;AAAA,QAC7C,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,MACA;AAAA,QACE,MAAM,CAACA,aAAYA,SAAQ,kBAAkB;AAAA,QAC7C,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,SAAS;AAAA,UACP,EAAE,MAAM,YAAY,OAAO,KAAK;AAAA,UAChC,EAAE,MAAM,UAAU,OAAO,MAAM;AAAA,QACjC;AAAA,MACF;AAAA,MACA;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,IAAA,CACD;AAED,eAAW,KAAK,OAAO;AAEnB,QAAA,CAAC,QAAQ,eAAe;AAC1B;AAAA,IACF;AAEA,UAAM,oBAAoBD,SAAQ;AAAA,EAAA;AAGpC,MAAI,eAAe;AACjB,UAAM,oBAAoB,QAAQ;AAAA,EAAA,OAC7B;AACG,YAAA;AAAA,MACN;AAAA,IAAA;AAAA,EAEJ;AAEO,SAAA;AACT;ACzGA,MAAM,YAAmC;AAAA,EACvC;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,SAAS;AAAA,IACT,SAAS;AAAA,EACX;AACF;ACMA,MAAe,sBAAA,CAAC,SAAsB;AAEpC,OAAK,aAAa,gBAAgB;AAAA,IAChC,aAAa;AAAA,IACb,MAAM,QAAQ,UAAU;AAChB,YAAA,SAAS,MAAM,SAAS,OAAO;AAAA,QACnC,GAAGE;AAAAA,QACH,GAAGC;AAAAA,QACH,GAAGC;AAAAA,MAAA,CACJ;AACK,YAAA,aAAa,MAAM,qBAAqB,QAAQ;AAEhD,YAAA,MAAM,MAAM,SAAS,OAAO;AAAA,QAChC,GAAG,sBAAsB,SAAS,KAAK,iBAAiB;AAAA,QACxD;AAAA,UACE,MAAM,CAAC,YAAY,QAAQ,gBAAgB;AAAA,UAC3C,MAAM;AAAA,UACN,MAAM;AAAA,UACN,SAAS,OAAO;AAAA,UAChB,SAAS;AAAA,UACT,MAAM,SAAS,OAAO;AACpB,gBAAI,CAACN,iBAAM,YAAY,KAAK,GAAG;AACtB,qBAAA;AAAA,YACT;AAEA,kBAAM,UAAUL,KAAAA,KAAK,KAAK,mBAAmB,KAAK;AAClD,kBAAM,SAAS,MAAMC,YAAAA,QAAG,WAAW,OAAO;AAE1C,gBAAI,CAAC,QAAQ;AACJ,qBAAA;AAAA,YACT;AAEM,kBAAA,SAAS,MAAMA,YAAAA,QAAG,QAAQ,SAAS,EAAE,eAAe,MAAM;AAChE,kBAAM,gBAAgB,OAAO,OAAO,CAAC,OAAO,GAAG,aAAa;AAExD,gBAAA,cAAc,UAAU,CAAC,QAAQ,IAAI,SAAS,KAAK,MAAM,IAAI;AACzD,oBAAA,IAAI,MAAM,6BAA6B;AAAA,YAC/C;AAEO,mBAAA;AAAA,UACT;AAAA,QACF;AAAA,QACA,GAAGW;AAAAA,MAAA,CACJ;AAEM,aAAA;AAAA,QACL,GAAG;AAAA,QACH,GAAG;AAAA,QACH;AAAA,MAAA;AAAA,IAEJ;AAAA,IACA,QAAQ,SAAS;AACf,UAAI,CAAC,SAAS;AACZ,eAAO;MACT;AAEA,YAAM,aAAa,QAAQ,WAAW,OAAO,CAAC,QAAa,WAAgB;AACzE,cAAM,MAAW,EAAE,MAAM,OAAO,cAAc;AAE1C,YAAA,OAAO,kBAAkB,eAAe;AACtC,cAAA,OAAO,OAAO,KAAK,MAAM,GAAG,EAAE,IAAI,CAAC,SAAiB,KAAK,KAAM,CAAA;AAAA,QACrE;AAEI,YAAA,OAAO,kBAAkB,SAAS;AACpC,cAAI,eAAe,CAAC,UAAU,SAAS,UAAU,QAAQ;AACzD,cAAI,WAAW,OAAO;AAAA,QACxB;AAEO,eAAA,OAAO,OAAO,QAAQ,EAAE,CAAC,OAAO,aAAa,GAAG,OAAO,CAAA,CAAE;AAAA,MAClE,GAAG,CAAE,CAAA;AAEC,YAAA,WAAW,YAAY,QAAQ,WAAW;AAE1C,YAAA,aAAa,QAAQ;AAC3B,YAAM,WAAWV,iBAAAA,QAAQ,sBAAsB,UAAU,IAAI,OAAO;AAEpE,YAAM,cAAiC;AAAA,QACrC;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ;AAAA,UACjB,cAAc,aAAa,QAAQ;AAAA,UACnC,MAAM;AAAA,YACJ,gBAAgBE,iBAAQ,QAAA,QAAQ,YAAY,EAAE,WAAW,KAAK;AAAA,UAChE;AAAA,QACF;AAAA,MAAA;AAGF,UAAI,OAAO,QAAQ,UAAU,EAAE,SAAS,GAAG;AACzC,oBAAY,KAAK;AAAA,UACf,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ;AAAA,UACjB,UAAU,UAAkB;AACpB,kBAAA,iBAAiB,KAAK,MAAM,QAAQ;AAC1C,2BAAe,aAAa;AAC5B,mBAAO,KAAK,UAAU,gBAAgB,MAAM,CAAC;AAAA,UAC/C;AAAA,QAAA,CACD;AAAA,MACH;AAEA,UAAI,QAAQ,cAAc;AAClB,cAAA,EAAE,aAAiB,IAAA;AAErB,YAAA;AACA,YAAA,QAAQ,gBAAgB,OAAO;AACjC,gBAAM,QAAQ,QAAQ,EAAE,IAAI,YAAY;AAAA,QAAA,WAC/B,QAAQ,KAAK;AACtB,gBAAM,QAAQ,QAAQ,GAAG,IAAI,YAAY;AAAA,QAAA,WAChC,QAAQ,QAAQ;AACzB,gBAAM,WAAW,QAAQ,MAAM,IAAI,YAAY;AAAA,QACjD;AAEY,oBAAA;AAAA,UACV;AAAA,YACE,MAAM;AAAA,YACN,MAAM,GAAG,QAAQ,mCAAmC,QAAQ;AAAA,YAC5D,cAAc,aAAa,QAAQ,oBAAoB,QAAQ;AAAA,YAC/D,MAAM,EAAE,IAAI;AAAA,UACd;AAAA,UACA;AAAA,YACE,MAAM;AAAA,YACN,MAAM,GAAG,QAAQ,gCAAgC,QAAQ;AAAA,YACzD,cAAc,aAAa,QAAQ,iBAAiB,QAAQ;AAAA,YAC5D,MAAM,EAAE,IAAI;AAAA,UACd;AAAA,UACA;AAAA,YACE,MAAM;AAAA,YACN,MAAM,GAAG,QAAQ,8BAA8B,QAAQ;AAAA,YACvD,cAAc,aAAa,QAAQ,gBAAgB,QAAQ;AAAA,YAC3D,MAAM,EAAE,IAAI;AAAA,UACd;AAAA,QAAA;AAAA,MAEJ;AAEO,aAAA;AAAA,IACT;AAAA,EAAA,CACD;AACH;AChJA,MAAM,YAAY;AAAA,EAChB,YAAY;AAAA,EACZ,YAAY;AACd;AAEA,MAAM,kBAAkB,CAAC,YAAoB,EAAE,eAAqC;AAC5E,QAAA,YAAY,+BAA+B,UAAU,IAAI;AACzD,QAAA,YAAY,MAAM,SAAS,EAAE,KAAK,GAAG,EAAE,KAAK,EAAE;AAE9C,QAAA,oBAAoB,aAAa,OAAO,qBAAqB;AAE5D,SAAA;AAAA,4DACmDS,eAAM,QAAA;AAAA,IAC9D,oBAAoB,QAAQ;AAAA,EAAA,CAC7B;AAAA,EACD,SAAS;AAAA,EACT,iBAAiB;AAAA,IACfA,eAAA,QAAM,KAAK,QAAQ,CAAC;AAAA,IACpBA,eAAAA,QAAM,MAAM,IAAI,UAAU,GAAG,CAAC;AAAA,eACnBA,eAAA,QAAM,OAAO,IAAI,CAAC;AAAA,eAClBA,eAAAA,QAAM,OAAO,kBAAkB,UAAU,GAAG,CAAC;AAAA;AAAA,IAExDA,eAAA,QAAM,KAAK,QAAQ,CAAC;AAAA;AAAA,EAEtB,SAAS;AAAA;AAEX;AAEA,MAAe,iBAAA,CAAC,SAAsB;AAEpC,OAAK,aAAa,UAAU;AAAA,IAC1B,aAAa;AAAA,IACb,SAAS;AAAA,MACP;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,UAAU,CAAC,UAAU,cAAc,KAAK;AAAA,MAC1C;AAAA,MACA;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,SAAS,OAAO,OAAO,SAAS;AAAA,QAChC,SAAS,UAAU;AAAA,MACrB;AAAA,IACF;AAAA,IACA,QAAQ,SAAS;AACf,UAAI,CAAC,SAAS;AACZ,eAAO;MACT;AAEM,YAAA,eAAe,QAAQ,aAAa,UAAU;AAC9C,YAAA,WAAW,eAAe,OAAO;AACvC,YAAM,kBAAkBX,iBAAQ,QAAA,sBAAsB,QAAQ,KAAK,IAAI,OAAO;AAE9E,UAAI,CAACG,iBAAM,YAAY,QAAQ,UAAU,GAAG;AAC1C,gBAAQ,aAAaA,iBAAM,YAAY,QAAQ,UAAU;AACjD,gBAAA;AAAA,UACNQ,eAAAA,QAAM;AAAA,YACJ;AAAA,iDAAuG,QAAQ,UAAU;AAAA,UAC3H;AAAA,QAAA;AAAA,MAEJ;AAEO,aAAA;AAAA,QACL;AAAA,UACE,MAAM;AAAA,UACN,aAAa;AAAA,UACb,MAAM,SAAS,QAAQ;AAAA,UACvB,eAAe,SAAS,QAAQ;AAAA,QAClC;AAAA,QACA;AAAA,UACE,MAAM;AAAA,UACN,MAAM;AAAA,UACN,cAAc,aAAa,QAAQ;AAAA,QACrC;AAAA,QACA;AAAA,UACE,MAAM;AAAA,UACN,MAAM;AAAA,UACN,cAAc,aAAa,QAAQ;AAAA,QACrC;AAAA,QACA,MACE,KAAK;AAAA,UACH,gBAAgB,QAAQ,YAAY,EAAE,UAAU,iBAAiB;AAAA,UACjE;AAAA,QACF;AAAA,MAAA;AAAA,IAEN;AAAA,EAAA,CACD;AACH;AC1FA,MAAe,iBAAA,CAAC,SAAsB;AAEpC,OAAK,aAAa,UAAU;AAAA,IAC1B,aAAa;AAAA,IACb,SAAS;AAAA,MACP;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,UAAU,CAAC,UAAU,cAAc,KAAK;AAAA,MAC1C;AAAA,MACA,GAAG,sBAAsB,UAAU,KAAK,mBAAmB,EAAE,YAAY,MAAM;AAAA,IACjF;AAAA,IACA,QAAQ,SAAS;AACf,UAAI,CAAC,SAAS;AACZ,eAAO;MACT;AAEM,YAAA,WAAW,YAAY,QAAQ,WAAW;AAC1C,YAAA,aAAa,QAAQ;AAC3B,YAAM,WAAWX,iBAAAA,QAAQ,sBAAsB,UAAU,IAAI,OAAO;AAE7D,aAAA;AAAA,QACL;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ,sBAAsB,QAAQ;AAAA,UAC/C,cAAc,aAAa,QAAQ,WAAW,QAAQ;AAAA,QACxD;AAAA,MAAA;AAAA,IAEJ;AAAA,EAAA,CACD;AACH;AC/BA,MAAe,qBAAA,CAAC,SAAsB;AAEpC,OAAK,aAAa,cAAc;AAAA,IAC9B,aAAa;AAAA,IACb,SAAS;AAAA,MACP;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,UAAU,CAAC,UAAU,cAAc,KAAK;AAAA,MAC1C;AAAA,MACA,GAAG,sBAAsB,cAAc,KAAK,mBAAmB,EAAE,YAAY,MAAM;AAAA,IACrF;AAAA,IACA,QAAQ,SAAS;AACf,UAAI,CAAC,SAAS;AACZ,eAAO;MACT;AAEM,YAAA,WAAW,YAAY,QAAQ,WAAW;AAC1C,YAAA,aAAa,QAAQ;AAC3B,YAAM,WAAWA,iBAAAA,QAAQ,sBAAsB,UAAU,IAAI,OAAO;AAE7D,aAAA;AAAA,QACL;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ,2BAA2B,QAAQ;AAAA,UACpD,cAAc,aAAa,QAAQ,eAAe,QAAQ;AAAA,QAC5D;AAAA,MAAA;AAAA,IAEJ;AAAA,EAAA,CACD;AACH;ACtCA,MAAe,wBAAA,CAAC,UAAkB;AAChC,QAAM,QAAQ;AAEd,MAAI,CAAC,OAAO;AACH,WAAA;AAAA,EACT;AAEO,SAAA,MAAM,KAAK,KAAK,KAAK;AAC9B;ACRA,MAAA,mBAAe,CAAC,OAAiB,oBAAA,WAAW;AAC1C,SAAO,IAAI,KAAK,KAAK,QAAY,IAAA,KAAK,sBAAsB,GAAK,EAC9D,SACA,QAAQ,SAAS,GAAG,EACpB,QAAQ,UAAU,EAAE;AACzB;ACAA,MAAe,oBAAA,CAAC,SAAsB;AAEpC,OAAK,aAAa,aAAa;AAAA,IAC7B,aAAa;AAAA,IACb,SAAS;AAAA,MACP;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,QACT,UAAU,CAAC,UAAU,sBAAsB,KAAK;AAAA,MAClD;AAAA,IACF;AAAA,IACA,UAAU;AACF,YAAA,aAAa,QAAQ;AAC3B,YAAM,WAAWA,iBAAAA,QAAQ,sBAAsB,UAAU,IAAI,OAAO;AACpE,YAAM,YAAY;AAEX,aAAA;AAAA,QACL;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,UAAU,wBAAwB,SAAS,eAAe,QAAQ;AAAA,UAC3E,cAAc,aAAa,QAAQ,cAAc,QAAQ;AAAA,QAC3D;AAAA,MAAA;AAAA,IAEJ;AAAA,EAAA,CACD;AACH;ACzBA,MAAe,kBAAA,CAAC,SAAsB;AAEpC,OAAK,aAAa,WAAW;AAAA,IAC3B,aAAa;AAAA,IACb,SAAS;AAAA,MACP;AAAA,QACE,MAAM;AAAA,QACN,MAAM;AAAA,QACN,SAAS;AAAA,MACX;AAAA,MACA,GAAG,sBAAsB,WAAW,KAAK,iBAAiB;AAAA,IAC5D;AAAA,IACA,QAAQ,SAAS;AACf,UAAI,CAAC,SAAS;AACZ,eAAO;MACT;AAEM,YAAA,WAAW,YAAY,SAAS,WAAW;AAC3C,YAAA,aAAa,QAAQ;AAC3B,YAAM,WAAWA,iBAAAA,QAAQ,sBAAsB,UAAU,IAAI,OAAO;AAE7D,aAAA;AAAA,QACL;AAAA,UACE,MAAM;AAAA,UACN,MAAM,GAAG,QAAQ,sBAAsB,QAAQ;AAAA,UAC/C,cAAc,aAAa,QAAQ,YAAY,QAAQ;AAAA,QACzD;AAAA,MAAA;AAAA,IAEJ;AAAA,EAAA,CACD;AACH;ACxBA,MAAe,WAAA,CAAC,SAAsB;AAEpC,OAAK,kBAAkB,mBAAmB;AAC1C,OAAK,UAAU,aAAa,CAAC,SAAiBI,mBAAA,QAAU,IAAI,CAAC;AAG7D,cAAY,IAAI;AAChB,qBAAmB,IAAI;AACvB,sBAAoB,IAAI;AACxB,iBAAe,IAAI;AACnB,iBAAe,IAAI;AACnB,qBAAmB,IAAI;AACvB,oBAAkB,IAAI;AACtB,kBAAgB,IAAI;AACtB;;"}
|
|
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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"}
|