create-better-t-stack 1.12.2 → 1.12.3

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/dist/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- import{cancel as j,intro as Rn,log as L,outro as Fn,spinner as In}from"@clack/prompts";import{Command as On}from"commander";import h from"picocolors";import Se from"node:path";import{fileURLToPath as Yt}from"node:url";var ee=()=>{let e=process.env.npm_config_user_agent;return e?.startsWith("pnpm")?"pnpm":e?.startsWith("bun")?"bun":"npm"};var Zt=Yt(import.meta.url),ea=Se.dirname(Zt),v=Se.join(ea,"../"),g={projectName:"my-better-t-app",frontend:["tanstack-router"],database:"sqlite",orm:"drizzle",auth:!0,addons:[],examples:[],git:!0,packageManager:ee(),noInstall:!1,dbSetup:"none",backend:"hono",runtime:"bun"},le={"better-auth":"^1.2.4","@better-auth/expo":"^1.2.5","drizzle-orm":"^0.38.4","drizzle-kit":"^0.30.5","@libsql/client":"^0.14.0",pg:"^8.14.1","@types/pg":"^8.11.11",mysql2:"^3.14.0","@prisma/client":"^6.5.0",prisma:"^6.5.0","vite-plugin-pwa":"^0.21.2","@vite-pwa/assets-generator":"^0.2.6","@tauri-apps/cli":"^2.4.0","@biomejs/biome":"1.9.4",husky:"^9.1.7","lint-staged":"^15.5.0","@hono/node-server":"^1.14.0",tsx:"^4.19.2","@types/node":"^22.13.11","@types/bun":"^1.2.6","@elysiajs/node":"^1.2.6","@elysiajs/cors":"^1.2.0","@elysiajs/trpc":"^1.1.0",elysia:"^1.2.25","@hono/trpc-server":"^0.3.4",hono:"^4.7.5",cors:"^2.8.5",express:"^5.1.0","@types/express":"^5.0.1","@types/cors":"^2.8.17",ai:"^4.2.8","@ai-sdk/google":"^1.2.3","@prisma/extension-accelerate":"^1.3.0"};import $r from"node:path";import{cancel as Sr,spinner as Ar}from"@clack/prompts";import Er from"fs-extra";import yt from"picocolors";import B from"node:path";import k from"fs-extra";import ta from"node:path";import Ae from"fs-extra";var b=e=>{let{dependencies:a=[],devDependencies:t=[],projectDir:r}=e,n=ta.join(r,"package.json"),s=Ae.readJSONSync(n);s.dependencies||(s.dependencies={}),s.devDependencies||(s.devDependencies={});for(let o of a){let i=le[o];s.dependencies[o]=i}for(let o of t){let i=le[o];s.devDependencies[o]=i}Ae.writeJSONSync(n,s,{spaces:2})};import aa from"node:path";import{log as ra,spinner as na}from"@clack/prompts";import{execa as sa}from"execa";import Ee from"picocolors";async function De(e,a){let t=na();try{t.start("Setting up Starlight documentation site...");let r,n;switch(a){case"npm":r="npx",n=["create-astro@latest"];break;case"pnpm":r="pnpm",n=["dlx","create-astro@latest"];break;case"bun":r="bunx",n=["create-astro@latest"];break;default:r="npx",n=["create-astro@latest"]}n=[...n,"docs","--template","starlight","--no-install","--add","tailwind","--no-git","--skip-houston"],await sa(r,n,{cwd:aa.join(e,"apps"),env:{CI:"true"}}),t.stop("Starlight documentation site setup successfully!")}catch(r){throw t.stop(Ee.red("Failed to set up Starlight documentation site")),r instanceof Error&&ra.error(Ee.red(r.message)),r}}import te from"node:path";import{log as oa,spinner as ia}from"@clack/prompts";import{execa as ca}from"execa";import ae from"fs-extra";import Ce from"picocolors";async function Te(e,a,t){let r=ia(),n=te.join(e,"apps/web");if(await ae.pathExists(n))try{r.start("Setting up Tauri desktop app support..."),b({devDependencies:["@tauri-apps/cli"],projectDir:n});let s=te.join(n,"package.json");if(await ae.pathExists(s)){let u=await ae.readJson(s);u.scripts={...u.scripts,tauri:"tauri","desktop:dev":"tauri dev","desktop:build":"tauri build"},await ae.writeJson(s,u,{spaces:2})}let o,i;switch(a){case"npm":o="npx",i=["@tauri-apps/cli@latest"];break;case"pnpm":o="pnpm",i=["dlx","@tauri-apps/cli@latest"];break;case"bun":o="bunx",i=["@tauri-apps/cli@latest"];break;default:o="npx",i=["@tauri-apps/cli@latest"]}let c=t.includes("react-router")?"http://localhost:5173":"http://localhost:3001";i=[...i,"init",`--app-name=${te.basename(e)}`,`--window-title=${te.basename(e)}`,"--frontend-dist=dist",`--dev-url=${c}`,`--before-dev-command=${a} run dev`,`--before-build-command=${a} run build`],await ca(o,i,{cwd:n,env:{CI:"true"}}),r.stop("Tauri desktop app support configured successfully!")}catch(s){throw r.stop(Ce.red("Failed to set up Tauri")),s instanceof Error&&oa.error(Ce.red(s.message)),s}}async function Re(e,a,t,r){let n=r.includes("react-router")||r.includes("tanstack-router");a.includes("pwa")&&n&&await da(e,r),a.includes("tauri")&&n&&await Te(e,t,r),a.includes("biome")&&await la(e),a.includes("husky")&&await ua(e),a.includes("starlight")&&await De(e,t)}function pa(e,a){return B.join(e,"apps/web")}async function la(e){let a=B.join(v,"template/with-biome");await k.pathExists(a)&&await k.copy(a,e,{overwrite:!0}),b({devDependencies:["@biomejs/biome"],projectDir:e});let t=B.join(e,"package.json");if(await k.pathExists(t)){let r=await k.readJson(t);r.scripts={...r.scripts,check:"biome check --write ."},await k.writeJson(t,r,{spaces:2})}}async function ua(e){let a=B.join(v,"template/with-husky");await k.pathExists(a)&&await k.copy(a,e,{overwrite:!0}),b({devDependencies:["husky","lint-staged"],projectDir:e});let t=B.join(e,"package.json");if(await k.pathExists(t)){let r=await k.readJson(t);r.scripts={...r.scripts,prepare:"husky"},r["lint-staged"]={"*.{js,ts,cjs,mjs,d.cts,d.mts,jsx,tsx,json,jsonc}":["biome check --write ."]},await k.writeJson(t,r,{spaces:2})}}async function da(e,a){let t=B.join(v,"template/with-pwa");await k.pathExists(t)&&await k.copy(t,e,{overwrite:!0});let r=pa(e,a);if(!await k.pathExists(r))return;b({dependencies:["vite-plugin-pwa"],devDependencies:["@vite-pwa/assets-generator"],projectDir:r});let n=B.join(r,"vite.config.ts");if(await k.pathExists(n)){let o=await k.readFile(n,"utf8");if(!o.includes("vite-plugin-pwa")){let p=o.match(/^import .* from ['"](.*)['"]/m);p?o=o.replace(p[0],`import { VitePWA } from "vite-plugin-pwa";
2
+ import{cancel as j,intro as Rn,log as L,outro as Fn,spinner as In}from"@clack/prompts";import{Command as On}from"commander";import h from"picocolors";import Se from"node:path";import{fileURLToPath as Yt}from"node:url";var ee=()=>{let e=process.env.npm_config_user_agent;return e?.startsWith("pnpm")?"pnpm":e?.startsWith("bun")?"bun":"npm"};var Zt=Yt(import.meta.url),ea=Se.dirname(Zt),v=Se.join(ea,"../"),g={projectName:"my-better-t-app",frontend:["tanstack-router"],database:"sqlite",orm:"drizzle",auth:!0,addons:[],examples:[],git:!0,packageManager:ee(),noInstall:!1,dbSetup:"none",backend:"hono",runtime:"bun"},le={"better-auth":"^1.2.5","@better-auth/expo":"^1.2.5","drizzle-orm":"^0.38.4","drizzle-kit":"^0.30.5","@libsql/client":"^0.14.0",pg:"^8.14.1","@types/pg":"^8.11.11",mysql2:"^3.14.0","@prisma/client":"^6.6.0",prisma:"^6.6.0","vite-plugin-pwa":"^0.21.2","@vite-pwa/assets-generator":"^0.2.6","@tauri-apps/cli":"^2.4.0","@biomejs/biome":"1.9.4",husky:"^9.1.7","lint-staged":"^15.5.0","@hono/node-server":"^1.14.0",tsx:"^4.19.2","@types/node":"^22.13.11","@types/bun":"^1.2.6","@elysiajs/node":"^1.2.6","@elysiajs/cors":"^1.2.0","@elysiajs/trpc":"^1.1.0",elysia:"^1.2.25","@hono/trpc-server":"^0.3.4",hono:"^4.7.6",cors:"^2.8.5",express:"^5.1.0","@types/express":"^5.0.1","@types/cors":"^2.8.17",ai:"^4.2.8","@ai-sdk/google":"^1.2.3","@prisma/extension-accelerate":"^1.3.0"};import $r from"node:path";import{cancel as Sr,spinner as Ar}from"@clack/prompts";import Er from"fs-extra";import yt from"picocolors";import B from"node:path";import k from"fs-extra";import ta from"node:path";import Ae from"fs-extra";var b=e=>{let{dependencies:a=[],devDependencies:t=[],projectDir:r}=e,n=ta.join(r,"package.json"),s=Ae.readJSONSync(n);s.dependencies||(s.dependencies={}),s.devDependencies||(s.devDependencies={});for(let o of a){let i=le[o];s.dependencies[o]=i}for(let o of t){let i=le[o];s.devDependencies[o]=i}Ae.writeJSONSync(n,s,{spaces:2})};import aa from"node:path";import{log as ra,spinner as na}from"@clack/prompts";import{execa as sa}from"execa";import Ee from"picocolors";async function De(e,a){let t=na();try{t.start("Setting up Starlight documentation site...");let r,n;switch(a){case"npm":r="npx",n=["create-astro@latest"];break;case"pnpm":r="pnpm",n=["dlx","create-astro@latest"];break;case"bun":r="bunx",n=["create-astro@latest"];break;default:r="npx",n=["create-astro@latest"]}n=[...n,"docs","--template","starlight","--no-install","--add","tailwind","--no-git","--skip-houston"],await sa(r,n,{cwd:aa.join(e,"apps"),env:{CI:"true"}}),t.stop("Starlight documentation site setup successfully!")}catch(r){throw t.stop(Ee.red("Failed to set up Starlight documentation site")),r instanceof Error&&ra.error(Ee.red(r.message)),r}}import te from"node:path";import{log as oa,spinner as ia}from"@clack/prompts";import{execa as ca}from"execa";import ae from"fs-extra";import Ce from"picocolors";async function Te(e,a,t){let r=ia(),n=te.join(e,"apps/web");if(await ae.pathExists(n))try{r.start("Setting up Tauri desktop app support..."),b({devDependencies:["@tauri-apps/cli"],projectDir:n});let s=te.join(n,"package.json");if(await ae.pathExists(s)){let u=await ae.readJson(s);u.scripts={...u.scripts,tauri:"tauri","desktop:dev":"tauri dev","desktop:build":"tauri build"},await ae.writeJson(s,u,{spaces:2})}let o,i;switch(a){case"npm":o="npx",i=["@tauri-apps/cli@latest"];break;case"pnpm":o="pnpm",i=["dlx","@tauri-apps/cli@latest"];break;case"bun":o="bunx",i=["@tauri-apps/cli@latest"];break;default:o="npx",i=["@tauri-apps/cli@latest"]}let c=t.includes("react-router")?"http://localhost:5173":"http://localhost:3001";i=[...i,"init",`--app-name=${te.basename(e)}`,`--window-title=${te.basename(e)}`,"--frontend-dist=dist",`--dev-url=${c}`,`--before-dev-command=${a} run dev`,`--before-build-command=${a} run build`],await ca(o,i,{cwd:n,env:{CI:"true"}}),r.stop("Tauri desktop app support configured successfully!")}catch(s){throw r.stop(Ce.red("Failed to set up Tauri")),s instanceof Error&&oa.error(Ce.red(s.message)),s}}async function Re(e,a,t,r){let n=r.includes("react-router")||r.includes("tanstack-router");a.includes("pwa")&&n&&await da(e,r),a.includes("tauri")&&n&&await Te(e,t,r),a.includes("biome")&&await la(e),a.includes("husky")&&await ua(e),a.includes("starlight")&&await De(e,t)}function pa(e,a){return B.join(e,"apps/web")}async function la(e){let a=B.join(v,"template/with-biome");await k.pathExists(a)&&await k.copy(a,e,{overwrite:!0}),b({devDependencies:["@biomejs/biome"],projectDir:e});let t=B.join(e,"package.json");if(await k.pathExists(t)){let r=await k.readJson(t);r.scripts={...r.scripts,check:"biome check --write ."},await k.writeJson(t,r,{spaces:2})}}async function ua(e){let a=B.join(v,"template/with-husky");await k.pathExists(a)&&await k.copy(a,e,{overwrite:!0}),b({devDependencies:["husky","lint-staged"],projectDir:e});let t=B.join(e,"package.json");if(await k.pathExists(t)){let r=await k.readJson(t);r.scripts={...r.scripts,prepare:"husky"},r["lint-staged"]={"*.{js,ts,cjs,mjs,d.cts,d.mts,jsx,tsx,json,jsonc}":["biome check --write ."]},await k.writeJson(t,r,{spaces:2})}}async function da(e,a){let t=B.join(v,"template/with-pwa");await k.pathExists(t)&&await k.copy(t,e,{overwrite:!0});let r=pa(e,a);if(!await k.pathExists(r))return;b({dependencies:["vite-plugin-pwa"],devDependencies:["@vite-pwa/assets-generator"],projectDir:r});let n=B.join(r,"vite.config.ts");if(await k.pathExists(n)){let o=await k.readFile(n,"utf8");if(!o.includes("vite-plugin-pwa")){let p=o.match(/^import .* from ['"](.*)['"]/m);p?o=o.replace(p[0],`import { VitePWA } from "vite-plugin-pwa";
3
3
  ${p[0]}`):o=`import { VitePWA } from "vite-plugin-pwa";
4
4
  ${o}`}let i=`VitePWA({
5
5
  registerType: "autoUpdate",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "create-better-t-stack",
3
- "version": "1.12.2",
3
+ "version": "1.12.3",
4
4
  "description": "A modern CLI tool for scaffolding end-to-end type-safe TypeScript projects with best practices and customizable configurations",
5
5
  "type": "module",
6
6
  "license": "MIT",
@@ -1,4 +1,4 @@
1
- import { PrismaClient } from "@prisma/client";
1
+ import { PrismaClient } from "./generated/client";
2
2
 
3
3
  const prisma = new PrismaClient();
4
4
 
@@ -1,6 +1,8 @@
1
1
  generator client {
2
- provider = "prisma-client-js"
2
+ provider = "prisma-client"
3
3
  previewFeatures = ["prismaSchemaFolder"]
4
+ output = "../generated"
5
+ moduleFormat = "esm"
4
6
  }
5
7
 
6
8
  datasource db {
@@ -1,4 +1,4 @@
1
- import { PrismaClient } from "@prisma/client";
1
+ import { PrismaClient } from "./generated/client";
2
2
 
3
3
  const prisma = new PrismaClient();
4
4
 
@@ -1,6 +1,8 @@
1
1
  generator client {
2
- provider = "prisma-client-js"
2
+ provider = "prisma-client"
3
3
  previewFeatures = ["prismaSchemaFolder"]
4
+ output = "../generated"
5
+ moduleFormat = "esm"
4
6
  }
5
7
 
6
8
  datasource db {
@@ -1,4 +1,4 @@
1
- import { PrismaClient } from "@prisma/client";
1
+ import { PrismaClient } from "./generated/client";
2
2
 
3
3
  const prisma = new PrismaClient();
4
4
 
@@ -1,6 +1,8 @@
1
1
  generator client {
2
- provider = "prisma-client-js"
2
+ provider = "prisma-client"
3
3
  previewFeatures = ["prismaSchemaFolder"]
4
+ output = "../generated"
5
+ moduleFormat = "esm"
4
6
  }
5
7
 
6
8
  datasource db {
@@ -1,4 +1,4 @@
1
- import { PrismaClient } from "@prisma/client";
1
+ import { PrismaClient } from "./generated/client";
2
2
 
3
3
  const prisma = new PrismaClient();
4
4
 
@@ -1,6 +1,8 @@
1
1
  generator client {
2
- provider = "prisma-client-js"
2
+ provider = "prisma-client"
3
3
  previewFeatures = ["prismaSchemaFolder"]
4
+ output = "../generated"
5
+ moduleFormat = "esm"
4
6
  }
5
7
 
6
8
  datasource db {