nextui/plopfile.js
2022-09-24 22:30:13 -03:00

64 lines
1.5 KiB
JavaScript

/**
* Part of this code is taken from @chakra-ui/react package ❤️
*/
const capitalize = (str) => {
return str.charAt(0).toUpperCase() + str.slice(1);
};
const camelCase = (str) => {
return str.replace(/[-_](\w)/g, (_, c) => c.toUpperCase());
};
const workspaces = ["components", "core", "hooks", "utilities"];
/**
* @param {import("plop").NodePlopAPI} plop
*/
module.exports = function main(plop) {
plop.setHelper("capitalize", (text) => {
return capitalize(camelCase(text));
});
plop.setGenerator("component", {
description: "Generates a component package",
prompts: [
{
type: "input",
name: "componentName",
message: "Enter component name:",
},
{
type: "input",
name: "description",
message: "The description of this component:",
},
{
type: "list",
name: "outDir",
message: "where should this component or package live?",
default: "packages",
choices: workspaces,
},
],
actions(answers) {
const actions = [];
if (!answers) return actions;
const {componentName, description, outDir} = answers;
actions.push({
type: "addMany",
templateFiles: "plop/component/**",
destination: `./packages/{{outDir}}/{{dashCase componentName}}`,
base: "plop/component",
data: {description, componentName, outDir},
abortOnFail: true,
});
return actions;
},
});
};