create-prisma-php-app 1.6.15 → 1.6.17

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 (2) hide show
  1. package/dist/index.js +132 -143
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -1,155 +1,144 @@
1
1
  #!/usr/bin/env node
2
- import{execSync}from"child_process";import fs from"fs";import{fileURLToPath}from"url";import path from"path";import chalk from"chalk";import prompts from"prompts";import https from"https";const __filename=fileURLToPath(import.meta.url),__dirname=path.dirname(__filename);function configureBrowserSyncCommand(e,t){const s=t.PROJECT_ROOT_PATH.indexOf("\\htdocs\\");if(-1===s)return"";const n=t.PROJECT_ROOT_PATH.substring(0,s+"\\htdocs\\".length).replace(/\\/g,"\\\\"),i=t.PROJECT_ROOT_PATH.replace(new RegExp(`^${n}`),"").replace(/\\/g,"/");let c=`http://localhost/${i}`;c=c.endsWith("/")?c.slice(0,-1):c;const r=c.replace(/(?<!:)(\/\/+)/g,"/"),o=i.replace(/\/\/+/g,"/"),a=`\n const { createProxyMiddleware } = require("http-proxy-middleware");\n\n module.exports = {\n // First middleware: Set Cache-Control headers\n function (req, res, next) {\n res.setHeader("Cache-Control", "no-cache, no-store, must-revalidate");\n res.setHeader("Pragma", "no-cache");\n res.setHeader("Expires", "0");\n next();\n },\n // Use the 'middleware' option to create a proxy that masks the deep URL.\n middleware: [\n // This middleware intercepts requests to the root and proxies them to the deep path.\n createProxyMiddleware("/", {\n target:\n "${r}",\n changeOrigin: true,\n pathRewrite: {\n "^/": "/${o.startsWith("/")?o.substring(1):o}", // Rewrite the path.\n },\n }),\n ],\n proxy: "http://localhost:3000", // Proxy the BrowserSync server.\n // serveStatic: ["src/app"], // Serve static files from this directory.\n files: "src/**/*.*",\n notify: false,\n open: false,\n ghostMode: false,\n };`,p=path.join(e,"settings","bs-config.cjs");return fs.writeFileSync(p,a,"utf8"),"browser-sync start --config settings/bs-config.cjs"}async function updatePackageJson(e,t,s){const n=path.join(e,"package.json"),i=JSON.parse(fs.readFileSync(n,"utf8")),c=configureBrowserSyncCommand(e,t);i.scripts=Object.assign(Object.assign({},i.scripts),{postinstall:"prisma generate"});let r=[];s.tailwindcss&&(i.scripts=Object.assign(Object.assign({},i.scripts),{tailwind:"postcss ./src/app/css/tailwind.css -o ./src/app/css/styles.css --watch"}),r.push("tailwind")),s.websocket&&(i.scripts=Object.assign(Object.assign({},i.scripts),{websocket:"node ./settings/restartWebsocket.cjs"}),r.push("websocket"));const o=Object.assign({},i.scripts);r.length>0&&(o["browser-sync"]=c),o.dev=r.length>0?`npm-run-all --parallel browser-sync ${r.join(" ")}`:c,i.scripts=o,i.type="module",i.prisma={seed:"node prisma/seed.js"},fs.writeFileSync(n,JSON.stringify(i,null,2))}async function updateComposerJson(e,t){if(!t.websocket)return;const s=path.join(e,"composer.json");let n;if(fs.existsSync(s)){{const e=fs.readFileSync(s,"utf8");n=JSON.parse(e)}t.websocket&&(n.require=Object.assign(Object.assign({},n.require),{"cboden/ratchet":"^0.4.4"})),fs.writeFileSync(s,JSON.stringify(n,null,2))}}async function updateIndexJsForWebSocket(e,t){if(!t.websocket)return;const s=path.join(e,"src","app","js","index.js");let n=fs.readFileSync(s,"utf8");n+='\n// WebSocket initialization\nconst ws = new WebSocket("ws://localhost:8080");\n',fs.writeFileSync(s,n,"utf8")}async function createUpdateGitignoreFile(e,t){const s=path.join(e,".gitignore");let n="";fs.existsSync(s)&&(n=fs.readFileSync(s,"utf8")),t.forEach((e=>{n.includes(e)||(n+=`\n${e}`)})),n=n.trimStart(),fs.writeFileSync(s,n)}function copyRecursiveSync(e,t){const s=fs.existsSync(e),n=s&&fs.statSync(e);s&&n&&n.isDirectory()?(fs.mkdirSync(t,{recursive:!0}),fs.readdirSync(e).forEach((s=>copyRecursiveSync(path.join(e,s),path.join(t,s))))):fs.copyFileSync(e,t)}async function executeCopy(e,t){t.forEach((({srcDir:t,destDir:s})=>{copyRecursiveSync(path.join(__dirname,t),path.join(e,s))}))}function modifyTailwindConfig(e){const t=path.join(e,"tailwind.config.js");let s=fs.readFileSync(t,"utf8");const n=["./src/app/**/*.{html,js,php}"].map((e=>` "${e}"`)).join(",\n");s=s.replace(/content: \[\],/g,`content: [\n${n}\n],`),fs.writeFileSync(t,s,"utf8")}function modifyPostcssConfig(e){const t=path.join(e,"postcss.config.js");fs.writeFileSync(t,"export default {\n plugins: {\n tailwindcss: {},\n autoprefixer: {},\n cssnano: {},\n },\n};","utf8")}function modifyIndexPHP(e,t){const s=path.join(e,"src","app","layout.php");try{let e=fs.readFileSync(s,"utf8");const n='\n <link href="<?php echo $baseUrl; ?>css/index.css" rel="stylesheet">\n <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&display=swap" rel="stylesheet">\n <script src="<?php echo $baseUrl; ?>js/index.js"><\/script>',i=t?` <link href="<?php echo $baseUrl; ?>css/styles.css" rel="stylesheet"> ${n}`:` <script src="https://cdn.tailwindcss.com"><\/script> ${n}`;e=e.replace("</head>",`${i}\n</head>`),fs.writeFileSync(s,e,"utf8")}catch(e){}}async function updateOrCreateEnvFile(e,t){const s=path.join(e,".env");let n=fs.existsSync(s)?fs.readFileSync(s,"utf8"):"";n+=`${""!==n?"\n\n":""}${t}`,fs.writeFileSync(s,n)}async function createDirectoryStructure(e,t,s){[{src:"/bootstrap.php",dest:"/bootstrap.php"},{src:"/.htaccess",dest:"/.htaccess"},{src:"/../composer.json",dest:"/composer.json"}].forEach((({src:t,dest:s})=>{const n=path.join(__dirname,t),i=path.join(e,s),c=fs.readFileSync(n,"utf8");fs.writeFileSync(i,c)})),await executeCopy(e,[{srcDir:"/settings",destDir:"/settings"},{srcDir:"/prisma",destDir:"/prisma"},{srcDir:"/src",destDir:"/src"},{srcDir:"/../vendor",destDir:"/vendor"}]),await updatePackageJson(e,s,t),await updateComposerJson(e,t),await updateIndexJsForWebSocket(e,t),t.tailwindcss?(modifyTailwindConfig(e),modifyIndexPHP(e,!0),modifyPostcssConfig(e)):modifyIndexPHP(e,!1);await updateOrCreateEnvFile(e,'# PHPMailer\nSMTP_HOST=\nSMTP_USERNAME=\nSMTP_PASSWORD=\nSMTP_PORT=\nSMTP_ENCRYPTION=ssl\nMAIL_FROM=\nMAIL_FROM_NAME=""'),await createUpdateGitignoreFile(e,["vendor"])}async function getAnswer(e={}){var t,s,n;const i=[];e.projectName||i.push({type:"text",name:"projectName",message:"What is your project named?",initial:"my-app"}),e.tailwindcss||i.push({type:"toggle",name:"tailwindcss",message:`Would you like to use ${chalk.blue("Tailwind CSS")}?`,initial:!0,active:"Yes",inactive:"No"}),e.websocket||i.push({type:"toggle",name:"websocket",message:`Would you like to use ${chalk.blue("Websocket")}?`,initial:!0,active:"Yes",inactive:"No"});const c=()=>!1;try{const r=await prompts(i,{onCancel:c});return 0===Object.keys(r).length?null:{projectName:r.projectName?String(r.projectName).trim().replace(/ /g,"-"):null!==(t=e.projectName)&&void 0!==t?t:"my-app",tailwindcss:null!==(s=r.tailwindcss)&&void 0!==s?s:e.tailwindcss,websocket:null!==(n=r.websocket)&&void 0!==n?n:e.websocket}}catch(e){return null}}async function installDependencies(e,t,s=!1){execSync("npm init -y",{stdio:"inherit",cwd:e}),t.forEach((e=>{}));const n=`npm install ${s?"--save-dev":""} ${t.join(" ")}`;execSync(n,{stdio:"inherit",cwd:e})}function fetchPackageVersion(e){return new Promise(((t,s)=>{https.get(`https://registry.npmjs.org/${e}`,(e=>{let n="";e.on("data",(e=>n+=e)),e.on("end",(()=>{try{const e=JSON.parse(n);t(e["dist-tags"].latest)}catch(e){s(new Error("Failed to parse JSON response"))}}))})).on("error",(e=>s(e)))}))}
2
+ import{execSync}from"child_process";import fs from"fs";import{fileURLToPath}from"url";import path from"path";import chalk from"chalk";import prompts from"prompts";import https from"https";const __filename=fileURLToPath(import.meta.url),__dirname=path.dirname(__filename);function configureBrowserSyncCommand(e,t){const s=t.PROJECT_ROOT_PATH.indexOf("\\htdocs\\");if(-1===s)return"";const n=t.PROJECT_ROOT_PATH.substring(0,s+"\\htdocs\\".length).replace(/\\/g,"\\\\"),i=t.PROJECT_ROOT_PATH.replace(new RegExp(`^${n}`),"").replace(/\\/g,"/");let c=`http://localhost/${i}`;c=c.endsWith("/")?c.slice(0,-1):c;const r=c.replace(/(?<!:)(\/\/+)/g,"/"),o=i.replace(/\/\/+/g,"/"),a=`\n const { createProxyMiddleware } = require("http-proxy-middleware");\n\n module.exports = {\n // First middleware: Set Cache-Control headers\n function (req, res, next) {\n res.setHeader("Cache-Control", "no-cache, no-store, must-revalidate");\n res.setHeader("Pragma", "no-cache");\n res.setHeader("Expires", "0");\n next();\n },\n // Use the 'middleware' option to create a proxy that masks the deep URL.\n middleware: [\n // This middleware intercepts requests to the root and proxies them to the deep path.\n createProxyMiddleware("/", {\n target:\n "${r}",\n changeOrigin: true,\n pathRewrite: {\n "^/": "/${o.startsWith("/")?o.substring(1):o}", // Rewrite the path.\n },\n }),\n ],\n proxy: "http://localhost:3000", // Proxy the BrowserSync server.\n // serveStatic: ["src/app"], // Serve static files from this directory.\n files: "src/**/*.*",\n notify: false,\n open: false,\n ghostMode: false,\n };`,p=path.join(e,"settings","bs-config.cjs");return fs.writeFileSync(p,a,"utf8"),"browser-sync start --config settings/bs-config.cjs"}async function updatePackageJson(e,t,s){const n=path.join(e,"package.json"),i=JSON.parse(fs.readFileSync(n,"utf8")),c=configureBrowserSyncCommand(e,t);i.scripts=Object.assign(Object.assign({},i.scripts),{postinstall:"prisma generate"});let r=[];s.tailwindcss&&(i.scripts=Object.assign(Object.assign({},i.scripts),{tailwind:"postcss ./src/app/css/tailwind.css -o ./src/app/css/styles.css --watch"}),r.push("tailwind")),s.websocket&&(i.scripts=Object.assign(Object.assign({},i.scripts),{websocket:"node ./settings/restartWebsocket.cjs"}),r.push("websocket"));const o=Object.assign({},i.scripts);r.length>0&&(o["browser-sync"]=c),o.dev=r.length>0?`npm-run-all --parallel browser-sync ${r.join(" ")}`:c,i.scripts=o,i.type="module",i.prisma={seed:"node prisma/seed.js"},fs.writeFileSync(n,JSON.stringify(i,null,2))}async function updateComposerJson(e,t){if(!t.websocket)return;const s=path.join(e,"composer.json");let n;if(fs.existsSync(s)){{const e=fs.readFileSync(s,"utf8");n=JSON.parse(e)}t.websocket&&(n.require=Object.assign(Object.assign({},n.require),{"cboden/ratchet":"^0.4.4"})),fs.writeFileSync(s,JSON.stringify(n,null,2))}}async function updateIndexJsForWebSocket(e,t){if(!t.websocket)return;const s=path.join(e,"src","app","js","index.js");let n=fs.readFileSync(s,"utf8");n+='\n// WebSocket initialization\nconst ws = new WebSocket("ws://localhost:8080");\n',fs.writeFileSync(s,n,"utf8")}async function createUpdateGitignoreFile(e,t){const s=path.join(e,".gitignore");let n="";fs.existsSync(s)&&(n=fs.readFileSync(s,"utf8")),t.forEach((e=>{n.includes(e)||(n+=`\n${e}`)})),n=n.trimStart(),fs.writeFileSync(s,n)}function copyRecursiveSync(e,t){const s=fs.existsSync(e),n=s&&fs.statSync(e);s&&n&&n.isDirectory()?(fs.mkdirSync(t,{recursive:!0}),fs.readdirSync(e).forEach((s=>copyRecursiveSync(path.join(e,s),path.join(t,s))))):fs.copyFileSync(e,t)}async function executeCopy(e,t){t.forEach((({srcDir:t,destDir:s})=>{copyRecursiveSync(path.join(__dirname,t),path.join(e,s))}))}function modifyTailwindConfig(e){const t=path.join(e,"tailwind.config.js");let s=fs.readFileSync(t,"utf8");const n=["./src/app/**/*.{html,js,php}"].map((e=>` "${e}"`)).join(",\n");s=s.replace(/content: \[\],/g,`content: [\n${n}\n],`),fs.writeFileSync(t,s,"utf8")}function modifyPostcssConfig(e){const t=path.join(e,"postcss.config.js");fs.writeFileSync(t,"export default {\n plugins: {\n tailwindcss: {},\n autoprefixer: {},\n cssnano: {},\n },\n};","utf8")}function modifyIndexPHP(e,t){const s=path.join(e,"src","app","layout.php");try{let e=fs.readFileSync(s,"utf8");const n='\n <link href="<?php echo $baseUrl; ?>css/index.css" rel="stylesheet">\n <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;600;800&display=swap" rel="stylesheet">\n <script src="<?php echo $baseUrl; ?>js/index.js"><\/script>',i=t?` <link href="<?php echo $baseUrl; ?>css/styles.css" rel="stylesheet"> ${n}`:` <script src="https://cdn.tailwindcss.com"><\/script> ${n}`;e=e.replace("</head>",`${i}\n</head>`),fs.writeFileSync(s,e,"utf8")}catch(e){}}async function updateOrCreateEnvFile(e,t){const s=path.join(e,".env");let n=fs.existsSync(s)?fs.readFileSync(s,"utf8"):"";n+=`${""!==n?"\n\n":""}${t}`,fs.writeFileSync(s,n)}async function createDirectoryStructure(e,t,s){[{src:"/bootstrap.php",dest:"/bootstrap.php"},{src:"/.htaccess",dest:"/.htaccess"},{src:"/../composer.json",dest:"/composer.json"}].forEach((({src:t,dest:s})=>{const n=path.join(__dirname,t),i=path.join(e,s),c=fs.readFileSync(n,"utf8");fs.writeFileSync(i,c)})),await executeCopy(e,[{srcDir:"/settings",destDir:"/settings"},{srcDir:"/prisma",destDir:"/prisma"},{srcDir:"/src",destDir:"/src"},{srcDir:"/../vendor",destDir:"/vendor"}]),await updatePackageJson(e,s,t),await updateComposerJson(e,t),await updateIndexJsForWebSocket(e,t),t.tailwindcss?(modifyTailwindConfig(e),modifyIndexPHP(e,!0),modifyPostcssConfig(e)):modifyIndexPHP(e,!1);await updateOrCreateEnvFile(e,'# PHPMailer\nSMTP_HOST=\nSMTP_USERNAME=\nSMTP_PASSWORD=\nSMTP_PORT=\nSMTP_ENCRYPTION=ssl\nMAIL_FROM=\nMAIL_FROM_NAME=""'),await createUpdateGitignoreFile(e,["vendor"])}async function getAnswer(e={}){var t,s,n;const i=[];e.projectName||i.push({type:"text",name:"projectName",message:"What is your project named?",initial:"my-app"}),e.tailwindcss||i.push({type:"toggle",name:"tailwindcss",message:`Would you like to use ${chalk.blue("Tailwind CSS")}?`,initial:!0,active:"Yes",inactive:"No"}),e.websocket||i.push({type:"toggle",name:"websocket",message:`Would you like to use ${chalk.blue("Websocket")}?`,initial:!0,active:"Yes",inactive:"No"});const c=()=>!1;try{const r=await prompts(i,{onCancel:c});return 0===Object.keys(r).length?null:{projectName:r.projectName?String(r.projectName).trim().replace(/ /g,"-"):null!==(t=e.projectName)&&void 0!==t?t:"my-app",tailwindcss:null!==(s=r.tailwindcss)&&void 0!==s?s:e.tailwindcss,websocket:null!==(n=r.websocket)&&void 0!==n?n:e.websocket}}catch(e){return null}}async function installDependencies(e,t,s=!1){fs.existsSync(path.join(e,"package.json"))||execSync("npm init -y",{stdio:"inherit",cwd:e}),t.forEach((e=>{}));const n=`npm install ${s?"--save-dev":""} ${t.join(" ")}`;execSync(n,{stdio:"inherit",cwd:e})}function fetchPackageVersion(e){return new Promise(((t,s)=>{https.get(`https://registry.npmjs.org/${e}`,(e=>{let n="";e.on("data",(e=>n+=e)),e.on("end",(()=>{try{const e=JSON.parse(n);t(e["dist-tags"].latest)}catch(e){s(new Error("Failed to parse JSON response"))}}))})).on("error",(e=>s(e)))}))}
3
3
  async function main() {
4
- try {
5
- const args = process.argv.slice(2);
6
- let projectName = args[0];
7
- console.log("🚀 ~ main ~ projectName:", projectName);
8
- let answer = null;
9
- if (projectName) {
10
- let useTailwind = args.includes("--tailwind");
11
- let useWebsocket = args.includes("--websocket");
12
- const predefinedAnswers = {
13
- projectName,
14
- tailwindcss: useTailwind,
15
- websocket: useWebsocket,
16
- };
17
- answer = await getAnswer(predefinedAnswers);
18
- console.log("🚀 ~ main ~ answer:", answer);
19
- } else {
20
- answer = await getAnswer();
21
- }
22
- if (answer === null) {
23
- console.log(chalk.red("Installation cancelled."));
24
- return;
25
- }
26
- // execSync(`npm install -g create-prisma-php-app`, { stdio: "inherit" }); // TODO: Uncomment this line before publishing the package
27
- execSync(`npm install -g create-prisma-php-app@alpha-update-command`, {
28
- stdio: "inherit",
29
- }); // TODO: Uncomment this line before publishing the package
30
- // Support for browser-sync
31
- execSync(`npm install -g browser-sync`, { stdio: "inherit" });
32
- // Create the project directory
33
- if (!projectName) fs.mkdirSync(answer.projectName);
34
- const projectPath = path.join(process.cwd(), answer.projectName);
35
- if (!projectName) process.chdir(answer.projectName);
36
- const dependencies = [
37
- "prisma",
38
- "@prisma/client",
39
- "typescript",
40
- "@types/node",
41
- "ts-node",
42
- "http-proxy-middleware",
43
- ];
44
- if (answer.tailwindcss) {
45
- dependencies.push(
46
- "tailwindcss",
47
- "autoprefixer",
48
- "postcss",
49
- "postcss-cli",
50
- "cssnano"
51
- );
52
- }
53
- if (answer.websocket) {
54
- dependencies.push("chokidar-cli");
55
- }
56
- if (answer.tailwindcss || answer.websocket) {
57
- dependencies.push("npm-run-all");
58
- }
59
- await installDependencies(projectPath, dependencies, true);
60
- execSync(`npx prisma init`, { stdio: "inherit" });
61
- execSync(`npx tsc --init`, { stdio: "inherit" });
62
- if (answer.tailwindcss) {
63
- execSync(`npx tailwindcss init -p`, { stdio: "inherit" });
64
- }
65
- const projectSettings = {
66
- PROJECT_NAME: answer.projectName,
67
- PROJECT_ROOT_PATH: projectPath.replace(/\\/g, "\\\\"),
68
- PHP_ROOT_PATH_EXE: "D:\\\\xampp\\\\php\\\\php.exe",
69
- PHP_GENERATE_CLASS_PATH: "src/lib/prisma/classes",
70
- };
71
- await createDirectoryStructure(projectPath, answer, projectSettings);
72
- // if (answer.tailwindcss) {
73
- // execSync(
74
- // `npx tailwindcss -i ./src/app/css/tailwind.css -o ./src/app/css/styles.css --minify`,
75
- // { stdio: "inherit" }
76
- // );
77
- // }
78
- // execSync(`composer install`, { stdio: "inherit" });
79
- // execSync(`composer dump-autoload`, { stdio: "inherit" });
80
- // Create settings file
81
- const settingsPath = path.join(
82
- projectPath,
83
- "settings",
84
- "project-settings.js"
85
- );
86
- const settingsCode = `export const projectSettings = {
4
+ try {
5
+ const args = process.argv.slice(2);
6
+ let projectName = args[0];
7
+ console.log("🚀 ~ main ~ projectName:", projectName);
8
+ let answer = null;
9
+ if (projectName) {
10
+ let useTailwind = args.includes("--tailwind");
11
+ let useWebsocket = args.includes("--websocket");
12
+ const predefinedAnswers = {
13
+ projectName,
14
+ tailwindcss: useTailwind,
15
+ websocket: useWebsocket,
16
+ };
17
+ answer = await getAnswer(predefinedAnswers);
18
+ console.log("🚀 ~ main ~ answer:", answer);
19
+ }
20
+ else {
21
+ answer = await getAnswer();
22
+ }
23
+ if (answer === null) {
24
+ console.log(chalk.red("Installation cancelled."));
25
+ return;
26
+ }
27
+ // execSync(`npm install -g create-prisma-php-app`, { stdio: "inherit" }); // TODO: Uncomment this line before publishing the package
28
+ execSync(`npm install -g create-prisma-php-app@alpha-update-command`, {
29
+ stdio: "inherit",
30
+ }); // TODO: Uncomment this line before publishing the package
31
+ // Support for browser-sync
32
+ execSync(`npm install -g browser-sync`, { stdio: "inherit" });
33
+ // Create the project directory
34
+ if (!projectName)
35
+ fs.mkdirSync(answer.projectName);
36
+ const projectPath = path.join(process.cwd(), answer.projectName);
37
+ process.chdir(answer.projectName);
38
+ const dependencies = [
39
+ "prisma",
40
+ "@prisma/client",
41
+ "typescript",
42
+ "@types/node",
43
+ "ts-node",
44
+ "http-proxy-middleware",
45
+ ];
46
+ if (answer.tailwindcss) {
47
+ dependencies.push("tailwindcss", "autoprefixer", "postcss", "postcss-cli", "cssnano");
48
+ }
49
+ if (answer.websocket) {
50
+ dependencies.push("chokidar-cli");
51
+ }
52
+ if (answer.tailwindcss || answer.websocket) {
53
+ dependencies.push("npm-run-all");
54
+ }
55
+ await installDependencies(projectPath, dependencies, true);
56
+ execSync(`npx prisma init`, { stdio: "inherit" });
57
+ execSync(`npx tsc --init`, { stdio: "inherit" });
58
+ if (answer.tailwindcss) {
59
+ execSync(`npx tailwindcss init -p`, { stdio: "inherit" });
60
+ }
61
+ const projectSettings = {
62
+ PROJECT_NAME: answer.projectName,
63
+ PROJECT_ROOT_PATH: projectPath.replace(/\\/g, "\\\\"),
64
+ PHP_ROOT_PATH_EXE: "D:\\\\xampp\\\\php\\\\php.exe",
65
+ PHP_GENERATE_CLASS_PATH: "src/lib/prisma/classes",
66
+ };
67
+ await createDirectoryStructure(projectPath, answer, projectSettings);
68
+ // if (answer.tailwindcss) {
69
+ // execSync(
70
+ // `npx tailwindcss -i ./src/app/css/tailwind.css -o ./src/app/css/styles.css --minify`,
71
+ // { stdio: "inherit" }
72
+ // );
73
+ // }
74
+ // execSync(`composer install`, { stdio: "inherit" });
75
+ // execSync(`composer dump-autoload`, { stdio: "inherit" });
76
+ // Create settings file
77
+ const settingsPath = path.join(projectPath, "settings", "project-settings.js");
78
+ const settingsCode = `export const projectSettings = {
87
79
  PROJECT_NAME: "${answer.projectName}",
88
80
  PROJECT_ROOT_PATH: "${projectPath.replace(/\\/g, "\\\\")}",
89
81
  PHP_ROOT_PATH_EXE: "D:\\\\xampp\\\\php\\\\php.exe",
90
82
  PHP_GENERATE_CLASS_PATH: "src/lib/prisma/classes",
91
83
  };`;
92
- fs.writeFileSync(settingsPath, settingsCode);
93
- // Create public directory
94
- fs.mkdirSync(path.join(projectPath, "public"));
95
- // Update css if tailwindcss is not chosen by the user
96
- if (!answer.tailwindcss) {
97
- // delete specific files of tailwindcss if not chosen
98
- const cssPath = path.join(projectPath, "src", "app", "css");
99
- const tailwindFiles = ["tailwind.css", "styles.css"];
100
- tailwindFiles.forEach((file) => {
101
- const filePath = path.join(cssPath, file);
102
- if (fs.existsSync(filePath)) {
103
- fs.unlinkSync(filePath); // Delete each file if it exists
104
- console.log(`${file} was deleted successfully.`);
105
- } else {
106
- console.log(`${file} does not exist.`);
84
+ fs.writeFileSync(settingsPath, settingsCode);
85
+ // Create public directory
86
+ fs.mkdirSync(path.join(projectPath, "public"));
87
+ // Update css if tailwindcss is not chosen by the user
88
+ if (!answer.tailwindcss) {
89
+ // delete specific files of tailwindcss if not chosen
90
+ const cssPath = path.join(projectPath, "src", "app", "css");
91
+ const tailwindFiles = ["tailwind.css", "styles.css"];
92
+ tailwindFiles.forEach((file) => {
93
+ const filePath = path.join(cssPath, file);
94
+ if (fs.existsSync(filePath)) {
95
+ fs.unlinkSync(filePath); // Delete each file if it exists
96
+ console.log(`${file} was deleted successfully.`);
97
+ }
98
+ else {
99
+ console.log(`${file} does not exist.`);
100
+ }
101
+ });
107
102
  }
108
- });
109
- }
110
- // Update websocket if not chosen by the user
111
- if (!answer.websocket) {
112
- const wsPath = path.join(projectPath, "src", "lib", "websocket");
113
- // Check if the websocket directory exists
114
- if (fs.existsSync(wsPath)) {
115
- // Use fs.rmSync with recursive option set to true to delete the directory and its contents
116
- fs.rmSync(wsPath, { recursive: true, force: true }); // force option is not necessary but can be used to ensure deletion
117
- console.log("Websocket directory was deleted successfully.");
118
- } else {
119
- console.log("Websocket directory does not exist.");
120
- }
121
- // Update settings directory if websocket is not chosen
122
- const settingsPath = path.join(projectPath, "settings");
123
- const websocketFiles = ["restartWebsocket.cjs", "restart_websocket.bat"];
124
- websocketFiles.forEach((file) => {
125
- const filePath = path.join(settingsPath, file);
126
- if (fs.existsSync(filePath)) {
127
- fs.unlinkSync(filePath); // Delete each file if it exists
128
- console.log(`${file} was deleted successfully.`);
129
- } else {
130
- console.log(`${file} does not exist.`);
103
+ // Update websocket if not chosen by the user
104
+ if (!answer.websocket) {
105
+ const wsPath = path.join(projectPath, "src", "lib", "websocket");
106
+ // Check if the websocket directory exists
107
+ if (fs.existsSync(wsPath)) {
108
+ // Use fs.rmSync with recursive option set to true to delete the directory and its contents
109
+ fs.rmSync(wsPath, { recursive: true, force: true }); // force option is not necessary but can be used to ensure deletion
110
+ console.log("Websocket directory was deleted successfully.");
111
+ }
112
+ else {
113
+ console.log("Websocket directory does not exist.");
114
+ }
115
+ // Update settings directory if websocket is not chosen
116
+ const settingsPath = path.join(projectPath, "settings");
117
+ const websocketFiles = ["restartWebsocket.cjs", "restart_websocket.bat"];
118
+ websocketFiles.forEach((file) => {
119
+ const filePath = path.join(settingsPath, file);
120
+ if (fs.existsSync(filePath)) {
121
+ fs.unlinkSync(filePath); // Delete each file if it exists
122
+ console.log(`${file} was deleted successfully.`);
123
+ }
124
+ else {
125
+ console.log(`${file} does not exist.`);
126
+ }
127
+ });
131
128
  }
132
- });
129
+ const version = await fetchPackageVersion("create-prisma-php-app");
130
+ const prismaPhpConfig = {
131
+ projectName: answer.projectName,
132
+ tailwindcss: answer.tailwindcss,
133
+ websocket: answer.websocket,
134
+ version,
135
+ };
136
+ fs.writeFileSync(path.join(projectPath, "prisma-php.json"), JSON.stringify(prismaPhpConfig, null, 2));
137
+ console.log(`${chalk.green("Success!")} Prisma PHP project successfully created in ${answer.projectName}!`);
138
+ }
139
+ catch (error) {
140
+ console.error("Error while creating the project:", error);
141
+ process.exit(1);
133
142
  }
134
- const version = await fetchPackageVersion("create-prisma-php-app");
135
- const prismaPhpConfig = {
136
- projectName: answer.projectName,
137
- tailwindcss: answer.tailwindcss,
138
- websocket: answer.websocket,
139
- version,
140
- };
141
- fs.writeFileSync(
142
- path.join(projectPath, "prisma-php.json"),
143
- JSON.stringify(prismaPhpConfig, null, 2)
144
- );
145
- console.log(
146
- `${chalk.green("Success!")} Prisma PHP project successfully created in ${
147
- answer.projectName
148
- }!`
149
- );
150
- } catch (error) {
151
- console.error("Error while creating the project:", error);
152
- process.exit(1);
153
- }
154
143
  }
155
144
  main();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-prisma-php-app",
3
- "version": "1.6.15",
3
+ "version": "1.6.17",
4
4
  "description": "Prisma-PHP: A Revolutionary Library Bridging PHP with Prisma ORM",
5
5
  "main": "dist/index.js",
6
6
  "type": "module",