@batijs/cli 0.0.542 → 0.0.544

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 (115) hide show
  1. package/dist/boilerplates/@batijs/auth0/files/$.env.js +5 -5
  2. package/dist/boilerplates/@batijs/auth0/files/$TODO.md.js +3 -3
  3. package/dist/boilerplates/@batijs/auth0/files/$wrangler.jsonc.js +3 -3
  4. package/dist/boilerplates/@batijs/authjs/files/$package.json.js +3 -3
  5. package/dist/boilerplates/@batijs/aws/files/$README.md.js +5 -5
  6. package/dist/boilerplates/@batijs/aws/files/$TODO.md.js +5 -5
  7. package/dist/boilerplates/@batijs/aws/files/$package.json.js +6 -6
  8. package/dist/boilerplates/@batijs/aws/files/$tsconfig.json.js +3 -3
  9. package/dist/boilerplates/@batijs/aws/files/cdk/bin/infrastructure.ts +1 -1
  10. package/dist/boilerplates/@batijs/biome/files/$package.json.js +3 -3
  11. package/dist/boilerplates/@batijs/cloudflare/files/$TODO.md.js +5 -5
  12. package/dist/boilerplates/@batijs/cloudflare/files/$package.json.js +5 -5
  13. package/dist/boilerplates/@batijs/cloudflare/files/$tsconfig.json.js +3 -3
  14. package/dist/boilerplates/@batijs/compiled/files/$package.json.js +4 -4
  15. package/dist/boilerplates/@batijs/compiled/files/$vite.config.ts.js +5 -5
  16. package/dist/boilerplates/@batijs/d1/files/$TODO.md.js +5 -5
  17. package/dist/boilerplates/@batijs/d1/files/$package.json.js +4 -4
  18. package/dist/boilerplates/@batijs/d1/files/$wrangler.jsonc.js +3 -3
  19. package/dist/boilerplates/@batijs/d1-kysely/bati.config.js +17 -0
  20. package/dist/boilerplates/@batijs/d1-kysely/files/$package.json.js +77 -0
  21. package/dist/boilerplates/@batijs/d1-kysely/files/database/migrations/todos.sql +4 -0
  22. package/dist/boilerplates/@batijs/d1-sqlite/files/$package.json.js +3 -3
  23. package/dist/boilerplates/@batijs/drizzle/files/$.env.js +3 -3
  24. package/dist/boilerplates/@batijs/drizzle/files/$TODO.md.js +5 -5
  25. package/dist/boilerplates/@batijs/drizzle/files/$package.json.js +5 -5
  26. package/dist/boilerplates/@batijs/eslint/files/$package.json.js +4 -4
  27. package/dist/boilerplates/@batijs/express/files/$package.json.js +7 -7
  28. package/dist/boilerplates/@batijs/fastify/files/$package.json.js +6 -6
  29. package/dist/boilerplates/@batijs/google-analytics/files/$.env.js +3 -3
  30. package/dist/boilerplates/@batijs/h3/files/$package.json.js +7 -7
  31. package/dist/boilerplates/@batijs/hono/files/$package.json.js +6 -6
  32. package/dist/boilerplates/@batijs/kysely/bati.config.js +35 -0
  33. package/dist/boilerplates/@batijs/kysely/files/$.env.js +19 -0
  34. package/dist/boilerplates/@batijs/kysely/files/$TODO.md.js +30 -0
  35. package/dist/boilerplates/@batijs/kysely/files/$package.json.js +120 -0
  36. package/dist/boilerplates/@batijs/kysely/files/database/kysely/db.ts +25 -0
  37. package/dist/boilerplates/@batijs/kysely/files/database/kysely/migrate.ts +45 -0
  38. package/dist/boilerplates/@batijs/kysely/files/database/kysely/migrations/001_create_todos_table.ts +16 -0
  39. package/dist/boilerplates/@batijs/kysely/files/database/kysely/queries/todos.ts +20 -0
  40. package/dist/boilerplates/@batijs/kysely/files/database/kysely/types.ts +13 -0
  41. package/dist/boilerplates/@batijs/kysely/types/database/kysely/db.d.ts +5 -0
  42. package/dist/boilerplates/@batijs/kysely/types/database/kysely/migrate.d.ts +1 -0
  43. package/dist/boilerplates/@batijs/kysely/types/database/kysely/migrations/001_create_todos_table.d.ts +4 -0
  44. package/dist/boilerplates/@batijs/kysely/types/database/kysely/queries/todos.d.ts +15 -0
  45. package/dist/boilerplates/@batijs/kysely/types/database/kysely/types.d.ts +10 -0
  46. package/dist/boilerplates/@batijs/mantine/files/$README.md.js +3 -3
  47. package/dist/boilerplates/@batijs/mantine/files/$package.json.js +6 -6
  48. package/dist/boilerplates/@batijs/oxlint/files/$package.json.js +5 -5
  49. package/dist/boilerplates/@batijs/photon/files/$README.md.js +3 -3
  50. package/dist/boilerplates/@batijs/photon/files/$package.json.js +4 -4
  51. package/dist/boilerplates/@batijs/plausible.io/files/$TODO.md.js +3 -3
  52. package/dist/boilerplates/@batijs/pnpm/files/$pnpm-workspace.yaml.js +3 -3
  53. package/dist/boilerplates/@batijs/prettier/files/$package.json.js +4 -4
  54. package/dist/boilerplates/@batijs/prisma/files/$.env.js +3 -3
  55. package/dist/boilerplates/@batijs/prisma/files/$TODO.md.js +5 -5
  56. package/dist/boilerplates/@batijs/prisma/files/$package.json.js +5 -5
  57. package/dist/boilerplates/@batijs/react/files/$README.md.js +3 -3
  58. package/dist/boilerplates/@batijs/react/files/$package.json.js +8 -8
  59. package/dist/boilerplates/@batijs/react/files/$tsconfig.json.js +3 -3
  60. package/dist/boilerplates/@batijs/react/files/$vite.config.ts.js +5 -5
  61. package/dist/boilerplates/@batijs/react-sentry/files/$package.json.js +7 -7
  62. package/dist/boilerplates/@batijs/sentry/files/$.env.js +4 -4
  63. package/dist/boilerplates/@batijs/sentry/files/$README.md.js +5 -5
  64. package/dist/boilerplates/@batijs/sentry/files/$TODO.md.js +3 -3
  65. package/dist/boilerplates/@batijs/sentry/files/$package.json.js +4 -4
  66. package/dist/boilerplates/@batijs/sentry/files/$vite.config.ts.js +7 -7
  67. package/dist/boilerplates/@batijs/sentry/files/pages/$+client.ts.js +9 -9
  68. package/dist/boilerplates/@batijs/shadcn-ui/files/$README.md.js +5 -5
  69. package/dist/boilerplates/@batijs/shadcn-ui/files/$package.json.js +4 -4
  70. package/dist/boilerplates/@batijs/shadcn-ui/files/$tsconfig.json.js +3 -3
  71. package/dist/boilerplates/@batijs/shadcn-ui/files/$vite.config.ts.js +5 -5
  72. package/dist/boilerplates/@batijs/shared/files/$README.md.js +7 -7
  73. package/dist/boilerplates/@batijs/shared/files/$TODO.md.js +3 -3
  74. package/dist/boilerplates/@batijs/shared/files/package.json +1 -1
  75. package/dist/boilerplates/@batijs/shared-db/files/server/db-middleware.ts +10 -3
  76. package/dist/boilerplates/@batijs/shared-db/types/server/db-middleware.d.ts +3 -0
  77. package/dist/boilerplates/@batijs/shared-server/files/$package.json.js +4 -4
  78. package/dist/boilerplates/@batijs/shared-server/files/server/create-todo-handler.ts +6 -0
  79. package/dist/boilerplates/@batijs/shared-server/types/server/create-todo-handler.d.ts +7 -0
  80. package/dist/boilerplates/@batijs/shared-todo/files/global.d.ts +3 -0
  81. package/dist/boilerplates/@batijs/shared-todo/files/pages/todo/+data.ts +5 -0
  82. package/dist/boilerplates/@batijs/solid/files/$README.md.js +3 -3
  83. package/dist/boilerplates/@batijs/solid/files/$package.json.js +5 -5
  84. package/dist/boilerplates/@batijs/solid/files/$tsconfig.json.js +3 -3
  85. package/dist/boilerplates/@batijs/solid/files/$vite.config.ts.js +5 -5
  86. package/dist/boilerplates/@batijs/solid-sentry/files/$package.json.js +5 -5
  87. package/dist/boilerplates/@batijs/sqlite/files/$.env.js +3 -3
  88. package/dist/boilerplates/@batijs/sqlite/files/$TODO.md.js +5 -5
  89. package/dist/boilerplates/@batijs/sqlite/files/$package.json.js +3 -3
  90. package/dist/boilerplates/@batijs/tailwindcss/files/$package.json.js +5 -5
  91. package/dist/boilerplates/@batijs/tailwindcss/files/$vite.config.ts.js +5 -5
  92. package/dist/boilerplates/@batijs/telefunc/files/$package.json.js +4 -4
  93. package/dist/boilerplates/@batijs/telefunc/files/$vite.config.ts.js +5 -5
  94. package/dist/boilerplates/@batijs/telefunc/files/global.d.ts +3 -0
  95. package/dist/boilerplates/@batijs/telefunc/files/pages/todo/TodoList.telefunc.ts +4 -0
  96. package/dist/boilerplates/@batijs/telefunc/files/server/telefunc-handler.ts +3 -0
  97. package/dist/boilerplates/@batijs/trpc/files/$package.json.js +4 -4
  98. package/dist/boilerplates/@batijs/trpc/files/trpc/server.ts +6 -0
  99. package/dist/boilerplates/@batijs/trpc/types/trpc/client.d.ts +7 -3
  100. package/dist/boilerplates/@batijs/trpc/types/trpc/server.d.ts +13 -0
  101. package/dist/boilerplates/@batijs/ts-rest/files/$package.json.js +3 -3
  102. package/dist/boilerplates/@batijs/ts-rest/files/server/ts-rest-handler.ts +6 -0
  103. package/dist/boilerplates/@batijs/vercel/files/$package.json.js +5 -5
  104. package/dist/boilerplates/@batijs/vercel/files/pages/$+config.ts.js +3 -3
  105. package/dist/boilerplates/@batijs/vue/files/$README.md.js +3 -3
  106. package/dist/boilerplates/@batijs/vue/files/$package.json.js +5 -5
  107. package/dist/boilerplates/@batijs/vue/files/$tsconfig.json.js +3 -3
  108. package/dist/boilerplates/@batijs/vue/files/$vite.config.ts.js +5 -5
  109. package/dist/boilerplates/@batijs/vue-sentry/files/$package.json.js +5 -5
  110. package/dist/boilerplates/boilerplates.json +12 -0
  111. package/dist/{chunk-X4G6MHMH.js → chunk-CIBJZ5MN.js} +75803 -75758
  112. package/dist/index.js +87 -67
  113. package/dist/{jiti-ZW3ADF2F-2SLKRUEN.js → jiti-PKZMRTZN-BIHN3GUM.js} +2 -3
  114. package/dist/{prompt-YBELZKBA.js → prompt-424IOCOV.js} +2 -2
  115. package/package.json +8 -8
package/dist/index.js CHANGED
@@ -3,14 +3,14 @@ import { createRequire as createRequire_BATI_CLI } from 'module';
3
3
  const require = createRequire_BATI_CLI(import.meta.url);
4
4
 
5
5
  import {
6
- Nus,
7
- Pus,
8
- Qit,
9
- Rnr,
10
- e9s,
6
+ Vps,
7
+ Wme,
8
+ Yps,
9
+ _js,
11
10
  export_which,
12
- jme
13
- } from "./chunk-X4G6MHMH.js";
11
+ lst,
12
+ oir
13
+ } from "./chunk-CIBJZ5MN.js";
14
14
  import "./chunk-IAWYWZSL.js";
15
15
  import {
16
16
  __commonJS,
@@ -206,8 +206,8 @@ async function mergeDts({
206
206
  filepath,
207
207
  meta
208
208
  }) {
209
- const previousAst = jme(previousContent);
210
- const currentAst = jme(fileContent);
209
+ const previousAst = Wme(previousContent);
210
+ const currentAst = Wme(fileContent);
211
211
  for (const imp of previousAst.imports.$items) {
212
212
  currentAst.imports[imp.local] = imp;
213
213
  }
@@ -224,7 +224,7 @@ async function mergeDts({
224
224
  currentAst.$ast.body.splice(index, 0, node);
225
225
  }
226
226
  }
227
- const res = await Pus(currentAst.generate().code, meta, {
227
+ const res = await Vps(currentAst.generate().code, meta, {
228
228
  filepath
229
229
  });
230
230
  return clearExports(res.code, meta);
@@ -248,7 +248,7 @@ async function executeOperationFile(op, {
248
248
  }) {
249
249
  const code = await readFile(op.sourceAbsolute, { encoding: "utf-8" });
250
250
  const filepath = relative(op.source, op.sourceAbsolute);
251
- const result = await Pus(code, meta, {
251
+ const result = await Vps(code, meta, {
252
252
  filepath
253
253
  });
254
254
  let fileContent = result.code;
@@ -332,7 +332,7 @@ async function transformFileAfterExec(filepath, fileContent) {
332
332
  case ".js":
333
333
  case ".tsx":
334
334
  case ".jsx":
335
- return Qit(fileContent, {
335
+ return lst(fileContent, {
336
336
  filepath
337
337
  });
338
338
  case ".env":
@@ -593,7 +593,7 @@ Please report this issue to https://github.com/vikejs/bati`
593
593
  }
594
594
  }
595
595
 
596
- // ../features/dist/chunk-CGEFIBQ3.js
596
+ // ../features/dist/chunk-E7UTPAVH.js
597
597
  var features = [
598
598
  // Vike
599
599
  {
@@ -959,6 +959,21 @@ var features = [
959
959
  }
960
960
  ]
961
961
  },
962
+ {
963
+ category: "Database",
964
+ label: "Kysely",
965
+ flag: "kysely",
966
+ image: "",
967
+ url: "https://kysely.dev/",
968
+ tagline: "The type-safe SQL query builder for TypeScript",
969
+ repo: "kysely-org/kysely",
970
+ links: [
971
+ {
972
+ label: "Docs & Getting started",
973
+ href: "https://kysely.dev/docs/getting-started"
974
+ }
975
+ ]
976
+ },
962
977
  {
963
978
  category: "Database",
964
979
  label: "Prisma",
@@ -1151,10 +1166,10 @@ var BatiSet = class extends Set {
1151
1166
  return this.hasOneOf(this.#servers);
1152
1167
  }
1153
1168
  get hasDatabase() {
1154
- return this.has("sqlite") || this.has("drizzle");
1169
+ return this.has("sqlite") || this.has("drizzle") || this.has("kysely");
1155
1170
  }
1156
1171
  get hasD1() {
1157
- return this.has("cloudflare") && (this.has("sqlite") || this.has("drizzle"));
1172
+ return this.has("cloudflare") && (this.has("sqlite") || this.has("drizzle") || this.has("kysely"));
1158
1173
  }
1159
1174
  get hasPhoton() {
1160
1175
  return this.has("cloudflare") || this.has("vercel") || this.hasOneOf(this.#servers);
@@ -1166,13 +1181,14 @@ var RulesMessage = /* @__PURE__ */ ((RulesMessage2) => {
1166
1181
  RulesMessage2[RulesMessage2["ERROR_AUTH_R_SERVER"] = 0] = "ERROR_AUTH_R_SERVER";
1167
1182
  RulesMessage2[RulesMessage2["ERROR_COMPILED_R_REACT"] = 1] = "ERROR_COMPILED_R_REACT";
1168
1183
  RulesMessage2[RulesMessage2["ERROR_DRIZZLE_R_SERVER"] = 2] = "ERROR_DRIZZLE_R_SERVER";
1169
- RulesMessage2[RulesMessage2["ERROR_DATA_R_SERVER"] = 3] = "ERROR_DATA_R_SERVER";
1170
- RulesMessage2[RulesMessage2["ERROR_CLOUDFLARE_R_COMPAT_SERVER"] = 4] = "ERROR_CLOUDFLARE_R_COMPAT_SERVER";
1171
- RulesMessage2[RulesMessage2["ERROR_AWS_R_COMPAT_SERVER"] = 5] = "ERROR_AWS_R_COMPAT_SERVER";
1172
- RulesMessage2[RulesMessage2["ERROR_MANTINE_R_REACT"] = 6] = "ERROR_MANTINE_R_REACT";
1173
- RulesMessage2[RulesMessage2["ERROR_SHADCN_R_REACT"] = 7] = "ERROR_SHADCN_R_REACT";
1174
- RulesMessage2[RulesMessage2["WARN_SHADCN_R_TAILWINDCSS"] = 8] = "WARN_SHADCN_R_TAILWINDCSS";
1175
- RulesMessage2[RulesMessage2["INFO_STACKBLITZ_COMPAT"] = 9] = "INFO_STACKBLITZ_COMPAT";
1184
+ RulesMessage2[RulesMessage2["ERROR_KYSELY_R_SERVER"] = 3] = "ERROR_KYSELY_R_SERVER";
1185
+ RulesMessage2[RulesMessage2["ERROR_DATA_R_SERVER"] = 4] = "ERROR_DATA_R_SERVER";
1186
+ RulesMessage2[RulesMessage2["ERROR_CLOUDFLARE_R_COMPAT_SERVER"] = 5] = "ERROR_CLOUDFLARE_R_COMPAT_SERVER";
1187
+ RulesMessage2[RulesMessage2["ERROR_AWS_R_COMPAT_SERVER"] = 6] = "ERROR_AWS_R_COMPAT_SERVER";
1188
+ RulesMessage2[RulesMessage2["ERROR_MANTINE_R_REACT"] = 7] = "ERROR_MANTINE_R_REACT";
1189
+ RulesMessage2[RulesMessage2["ERROR_SHADCN_R_REACT"] = 8] = "ERROR_SHADCN_R_REACT";
1190
+ RulesMessage2[RulesMessage2["WARN_SHADCN_R_TAILWINDCSS"] = 9] = "WARN_SHADCN_R_TAILWINDCSS";
1191
+ RulesMessage2[RulesMessage2["INFO_STACKBLITZ_COMPAT"] = 10] = "INFO_STACKBLITZ_COMPAT";
1176
1192
  return RulesMessage2;
1177
1193
  })(RulesMessage || {});
1178
1194
  function requires(message, ifPresent, mustAlsoInclude) {
@@ -1196,8 +1212,9 @@ var rules_default = [
1196
1212
  requires(0, "Auth", ["Server"]),
1197
1213
  requires(1, "compiled-css", ["react"]),
1198
1214
  requires(2, "drizzle", ["Server"]),
1199
- requires(3, "Data fetching", ["Server"]),
1200
- filter(4, (fts) => {
1215
+ requires(3, "kysely", ["Server"]),
1216
+ requires(4, "Data fetching", ["Server"]),
1217
+ filter(5, (fts) => {
1201
1218
  if (fts.has("cloudflare")) {
1202
1219
  if (fts.has("hono") || fts.has("h3")) {
1203
1220
  return false;
@@ -1206,7 +1223,7 @@ var rules_default = [
1206
1223
  }
1207
1224
  return false;
1208
1225
  }),
1209
- filter(5, (fts) => {
1226
+ filter(6, (fts) => {
1210
1227
  if (fts.has("aws")) {
1211
1228
  if (fts.has("hono")) {
1212
1229
  return false;
@@ -1215,26 +1232,26 @@ var rules_default = [
1215
1232
  }
1216
1233
  return false;
1217
1234
  }),
1218
- filter(6, (fts) => {
1235
+ filter(7, (fts) => {
1219
1236
  if (fts.has("mantine")) {
1220
1237
  return fts.has("vue") || fts.has("solid");
1221
1238
  }
1222
1239
  return false;
1223
1240
  }),
1224
- filter(7, (fts) => {
1241
+ filter(8, (fts) => {
1225
1242
  if (fts.has("shadcn-ui")) {
1226
1243
  return fts.has("vue") || fts.has("solid");
1227
1244
  }
1228
1245
  return false;
1229
1246
  }),
1230
- filter(8, (fts) => {
1247
+ filter(9, (fts) => {
1231
1248
  if (fts.has("shadcn-ui")) {
1232
1249
  return fts.has("daisyui") || fts.has("compiled-css");
1233
1250
  }
1234
1251
  return false;
1235
1252
  }),
1236
- filter(9, (fts) => {
1237
- return fts.has("drizzle") || fts.has("sqlite") || fts.has("cloudflare");
1253
+ filter(10, (fts) => {
1254
+ return fts.has("drizzle") || fts.has("sqlite") || fts.has("kysely") || fts.has("cloudflare");
1238
1255
  })
1239
1256
  ];
1240
1257
  function execRules(fts, rulesMessages2) {
@@ -1253,7 +1270,7 @@ function execRules(fts, rulesMessages2) {
1253
1270
  return messages;
1254
1271
  }
1255
1272
 
1256
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/key.js
1273
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/key.js
1257
1274
  var isUpKey = (key, keybindings = []) => (
1258
1275
  // The up key
1259
1276
  key.name === "up" || // Vim keybinding: hjkl keys map to left/down/up/right
@@ -1270,7 +1287,7 @@ var isBackspaceKey = (key) => key.name === "backspace";
1270
1287
  var isNumberKey = (key) => "1234567890".includes(key.name);
1271
1288
  var isEnterKey = (key) => key.name === "enter" || key.name === "return";
1272
1289
 
1273
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/errors.js
1290
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/errors.js
1274
1291
  var AbortPromptError = class extends Error {
1275
1292
  name = "AbortPromptError";
1276
1293
  message = "Prompt was aborted";
@@ -1293,10 +1310,10 @@ var ValidationError = class extends Error {
1293
1310
  name = "ValidationError";
1294
1311
  };
1295
1312
 
1296
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-state.js
1313
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-state.js
1297
1314
  import { AsyncResource as AsyncResource2 } from "async_hooks";
1298
1315
 
1299
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/hook-engine.js
1316
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/hook-engine.js
1300
1317
  import { AsyncLocalStorage, AsyncResource } from "async_hooks";
1301
1318
  var hookStorage = new AsyncLocalStorage();
1302
1319
  function createStore(rl) {
@@ -1402,7 +1419,7 @@ var effectScheduler = {
1402
1419
  }
1403
1420
  };
1404
1421
 
1405
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-state.js
1422
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-state.js
1406
1423
  function useState(defaultValue) {
1407
1424
  return withPointer((pointer) => {
1408
1425
  const setState = AsyncResource2.bind(function setState2(newValue) {
@@ -1420,7 +1437,7 @@ function useState(defaultValue) {
1420
1437
  });
1421
1438
  }
1422
1439
 
1423
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-effect.js
1440
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-effect.js
1424
1441
  function useEffect(cb, depArray) {
1425
1442
  withPointer((pointer) => {
1426
1443
  const oldDeps = pointer.get();
@@ -1432,10 +1449,10 @@ function useEffect(cb, depArray) {
1432
1449
  });
1433
1450
  }
1434
1451
 
1435
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/theme.js
1452
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/theme.js
1436
1453
  import { styleText } from "util";
1437
1454
 
1438
- // ../../node_modules/.pnpm/@inquirer+figures@2.0.1/node_modules/@inquirer/figures/dist/index.js
1455
+ // ../../node_modules/.pnpm/@inquirer+figures@2.0.2/node_modules/@inquirer/figures/dist/index.js
1439
1456
  import process2 from "process";
1440
1457
  function isUnicodeSupported() {
1441
1458
  if (process2.platform !== "win32") {
@@ -1727,7 +1744,7 @@ var figures = shouldUseMain ? mainSymbols : fallbackSymbols;
1727
1744
  var dist_default = figures;
1728
1745
  var replacements = Object.entries(specialMainSymbols);
1729
1746
 
1730
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/theme.js
1747
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/theme.js
1731
1748
  var defaultTheme = {
1732
1749
  prefix: {
1733
1750
  idle: styleText("blue", "?"),
@@ -1748,7 +1765,7 @@ var defaultTheme = {
1748
1765
  }
1749
1766
  };
1750
1767
 
1751
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/make-theme.js
1768
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/make-theme.js
1752
1769
  function isPlainObject(value) {
1753
1770
  if (typeof value !== "object" || value === null)
1754
1771
  return false;
@@ -1776,7 +1793,7 @@ function makeTheme(...themes) {
1776
1793
  return deepMerge(...themesToMerge);
1777
1794
  }
1778
1795
 
1779
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-prefix.js
1796
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-prefix.js
1780
1797
  function usePrefix({ status = "idle", theme }) {
1781
1798
  const [showLoader, setShowLoader] = useState(false);
1782
1799
  const [tick, setTick] = useState(0);
@@ -1807,7 +1824,7 @@ function usePrefix({ status = "idle", theme }) {
1807
1824
  return typeof prefix === "string" ? prefix : prefix[iconName] ?? prefix["idle"];
1808
1825
  }
1809
1826
 
1810
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-memo.js
1827
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-memo.js
1811
1828
  function useMemo(fn, dependencies) {
1812
1829
  return withPointer((pointer) => {
1813
1830
  const prev = pointer.get();
@@ -1820,12 +1837,12 @@ function useMemo(fn, dependencies) {
1820
1837
  });
1821
1838
  }
1822
1839
 
1823
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-ref.js
1840
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-ref.js
1824
1841
  function useRef(val) {
1825
1842
  return useState({ current: val })[0];
1826
1843
  }
1827
1844
 
1828
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-keypress.js
1845
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/use-keypress.js
1829
1846
  function useKeypress(userHandler) {
1830
1847
  const signal = useRef(userHandler);
1831
1848
  signal.current = userHandler;
@@ -1844,7 +1861,7 @@ function useKeypress(userHandler) {
1844
1861
  }, []);
1845
1862
  }
1846
1863
 
1847
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/utils.js
1864
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/utils.js
1848
1865
  var import_cli_width = __toESM(require_cli_width(), 1);
1849
1866
 
1850
1867
  // ../../node_modules/.pnpm/ansi-regex@6.2.2/node_modules/ansi-regex/index.js
@@ -2284,7 +2301,7 @@ function wrapAnsi(string, columns, options) {
2284
2301
  return String(string).normalize().replaceAll("\r\n", "\n").split("\n").map((line) => exec(line, columns, options)).join("\n");
2285
2302
  }
2286
2303
 
2287
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/utils.js
2304
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/utils.js
2288
2305
  function breakLines(content, width) {
2289
2306
  return content.split("\n").flatMap((line) => wrapAnsi(line, width, { trim: false, hard: true }).split("\n").map((str) => str.trimEnd())).join("\n");
2290
2307
  }
@@ -2292,7 +2309,7 @@ function readlineWidth() {
2292
2309
  return (0, import_cli_width.default)({ defaultWidth: 80, output: readline().output });
2293
2310
  }
2294
2311
 
2295
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/pagination/use-pagination.js
2312
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/pagination/use-pagination.js
2296
2313
  function usePointerPosition({ active, renderedItems, pageSize, loop }) {
2297
2314
  const state = useRef({
2298
2315
  lastPointer: active,
@@ -2381,7 +2398,7 @@ function usePagination({ items, active, renderItem, pageSize, loop = true }) {
2381
2398
  return pageBuffer.filter((line) => typeof line === "string").join("\n");
2382
2399
  }
2383
2400
 
2384
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/create-prompt.js
2401
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/create-prompt.js
2385
2402
  var import_mute_stream = __toESM(require_lib(), 1);
2386
2403
  import * as readline2 from "readline";
2387
2404
  import { AsyncResource as AsyncResource3 } from "async_hooks";
@@ -2412,7 +2429,7 @@ if (process.platform === "linux") {
2412
2429
 
2413
2430
  // ../../node_modules/.pnpm/signal-exit@4.1.0/node_modules/signal-exit/dist/mjs/index.js
2414
2431
  var processOk = (process4) => !!process4 && typeof process4 === "object" && typeof process4.removeListener === "function" && typeof process4.emit === "function" && typeof process4.reallyExit === "function" && typeof process4.listeners === "function" && typeof process4.kill === "function" && typeof process4.pid === "number" && typeof process4.on === "function";
2415
- var kExitEmitter = Symbol.for("signal-exit emitter");
2432
+ var kExitEmitter = /* @__PURE__ */ Symbol.for("signal-exit emitter");
2416
2433
  var global = globalThis;
2417
2434
  var ObjectDefineProperty = Object.defineProperty.bind(Object);
2418
2435
  var Emitter = class {
@@ -2637,10 +2654,10 @@ var {
2637
2654
  unload
2638
2655
  } = signalExitWrap(processOk(process3) ? new SignalExit(process3) : new SignalExitFallback());
2639
2656
 
2640
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/screen-manager.js
2657
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/screen-manager.js
2641
2658
  import { stripVTControlCharacters } from "util";
2642
2659
 
2643
- // ../../node_modules/.pnpm/@inquirer+ansi@2.0.1/node_modules/@inquirer/ansi/dist/index.js
2660
+ // ../../node_modules/.pnpm/@inquirer+ansi@2.0.2/node_modules/@inquirer/ansi/dist/index.js
2644
2661
  var ESC = "\x1B[";
2645
2662
  var cursorLeft = ESC + "G";
2646
2663
  var cursorHide = ESC + "?25l";
@@ -2656,7 +2673,7 @@ var cursorTo = (x, y2) => {
2656
2673
  var eraseLine = ESC + "2K";
2657
2674
  var eraseLines = (lines) => lines > 0 ? (eraseLine + cursorUp(1)).repeat(lines - 1) + eraseLine + cursorLeft : "";
2658
2675
 
2659
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/screen-manager.js
2676
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/screen-manager.js
2660
2677
  var height = (content) => content.split("\n").length;
2661
2678
  var lastLine = (content) => content.split("\n").pop() ?? "";
2662
2679
  var ScreenManager = class {
@@ -2716,7 +2733,7 @@ var ScreenManager = class {
2716
2733
  }
2717
2734
  };
2718
2735
 
2719
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/promise-polyfill.js
2736
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/promise-polyfill.js
2720
2737
  var PromisePolyfill = class extends Promise {
2721
2738
  // Available starting from Node 22
2722
2739
  // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/withResolvers
@@ -2731,7 +2748,7 @@ var PromisePolyfill = class extends Promise {
2731
2748
  }
2732
2749
  };
2733
2750
 
2734
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/create-prompt.js
2751
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/create-prompt.js
2735
2752
  function getCallSites() {
2736
2753
  const _prepareStackTrace = Error.prepareStackTrace;
2737
2754
  let result = [];
@@ -2818,7 +2835,7 @@ function createPrompt(view) {
2818
2835
  return prompt;
2819
2836
  }
2820
2837
 
2821
- // ../../node_modules/.pnpm/@inquirer+core@11.0.1_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/Separator.js
2838
+ // ../../node_modules/.pnpm/@inquirer+core@11.0.2_@types+node@20.19.25/node_modules/@inquirer/core/dist/lib/Separator.js
2822
2839
  import { styleText as styleText2 } from "util";
2823
2840
  var Separator = class {
2824
2841
  separator = styleText2("dim", Array.from({ length: 15 }).join(dist_default.line));
@@ -2833,7 +2850,7 @@ var Separator = class {
2833
2850
  }
2834
2851
  };
2835
2852
 
2836
- // ../../node_modules/.pnpm/@inquirer+select@5.0.1_@types+node@20.19.25/node_modules/@inquirer/select/dist/index.js
2853
+ // ../../node_modules/.pnpm/@inquirer+select@5.0.2_@types+node@20.19.25/node_modules/@inquirer/select/dist/index.js
2837
2854
  import { styleText as styleText3 } from "util";
2838
2855
  var selectTheme = {
2839
2856
  icon: { cursor: dist_default.pointer },
@@ -4070,7 +4087,7 @@ function createConsola2(options = {}) {
4070
4087
  defaults: { level },
4071
4088
  stdout: process.stdout,
4072
4089
  stderr: process.stderr,
4073
- prompt: (...args) => import("./prompt-YBELZKBA.js").then((m) => m.prompt(...args)),
4090
+ prompt: (...args) => import("./prompt-424IOCOV.js").then((m) => m.prompt(...args)),
4074
4091
  reporters: options.reporters || [
4075
4092
  options.fancy ?? !(T || R) ? new FancyReporter() : new BasicReporter()
4076
4093
  ],
@@ -4707,7 +4724,7 @@ var {
4707
4724
  // package.json
4708
4725
  var package_default = {
4709
4726
  name: "@batijs/cli",
4710
- version: "0.0.542",
4727
+ version: "0.0.544",
4711
4728
  type: "module",
4712
4729
  scripts: {
4713
4730
  "check-types": "tsc --noEmit",
@@ -4722,17 +4739,17 @@ var package_default = {
4722
4739
  devDependencies: {
4723
4740
  "@batijs/build": "workspace:*",
4724
4741
  "@batijs/compile": "workspace:*",
4725
- "@inquirer/prompts": "^8.0.1",
4742
+ "@inquirer/prompts": "^8.0.2",
4726
4743
  "@types/node": "^20.19.25",
4727
4744
  "@types/which": "^3.0.4",
4728
4745
  citty: "^0.1.6",
4729
4746
  colorette: "^2.0.20",
4730
- esbuild: "^0.27.0",
4747
+ esbuild: "^0.27.1",
4731
4748
  execa: "^9.6.1",
4732
4749
  tsup: "^8.5.1",
4733
4750
  typescript: "^5.9.3",
4734
4751
  "unplugin-purge-polyfills": "^0.1.0",
4735
- vite: "^7.2.6"
4752
+ vite: "^7.2.7"
4736
4753
  },
4737
4754
  dependencies: {
4738
4755
  "@batijs/core": "workspace:*",
@@ -4777,6 +4794,9 @@ var rulesMessages = {
4777
4794
  [RulesMessage.ERROR_DRIZZLE_R_SERVER]: error(
4778
4795
  `A ${inverse(bold("Server"))} is required when using ${inverse(bold("Drizzle"))}`
4779
4796
  ),
4797
+ [RulesMessage.ERROR_KYSELY_R_SERVER]: error(
4798
+ `A ${inverse(bold("Server"))} is required when using ${inverse(bold("Kysely"))}`
4799
+ ),
4780
4800
  [RulesMessage.ERROR_DATA_R_SERVER]: error(
4781
4801
  `A ${inverse(bold("Server"))} is required when using ${inverse(bold("Data fetching"))}`
4782
4802
  ),
@@ -4801,7 +4821,7 @@ printInit();
4801
4821
  var __filename = fileURLToPath(import.meta.url);
4802
4822
  var __dirname = dirname(__filename);
4803
4823
  var isWin2 = process.platform === "win32";
4804
- var pm = Nus();
4824
+ var pm = Yps();
4805
4825
  function boilerplatesDir() {
4806
4826
  if (existsSync2(join(__dirname, "boilerplates", "boilerplates.json"))) {
4807
4827
  return join(__dirname, "boilerplates");
@@ -4912,7 +4932,7 @@ async function hasRemainingSteps(dist) {
4912
4932
  }
4913
4933
  }
4914
4934
  function printInit() {
4915
- const v = e9s();
4935
+ const v = _js();
4916
4936
  const version = v.semver.at(-1);
4917
4937
  assert(version);
4918
4938
  console.log(`
@@ -4921,8 +4941,8 @@ function printInit() {
4921
4941
  }
4922
4942
  async function printOK(dist, flags2, nextSteps) {
4923
4943
  const indent = 1;
4924
- const list = Rnr("-", gray, indent);
4925
- const cmd = Rnr("$", gray, indent);
4944
+ const list = oir("-", gray, indent);
4945
+ const cmd = oir("$", gray, indent);
4926
4946
  const distPretty = prettifyDist(dist);
4927
4947
  console.log(`${green(`${bold("\u2713")} Project created: ${bold(distPretty)}`)}`);
4928
4948
  console.log(list("Vike"));
@@ -4940,11 +4960,11 @@ ${bold("Next steps:")}`);
4940
4960
  if (step.type === "command") {
4941
4961
  console.log(cmd(step.step));
4942
4962
  } else {
4943
- console.log(Rnr("\u2022\uFE0F", gray, indent)(step.step));
4963
+ console.log(oir("\u2022\uFE0F", gray, indent)(step.step));
4944
4964
  }
4945
4965
  }
4946
4966
  } else if (await hasRemainingSteps(dist)) {
4947
- console.log(Rnr("\u2022\uFE0F", gray, indent)(`Check ${bold("TODO.md")} for remaining steps`));
4967
+ console.log(oir("\u2022\uFE0F", gray, indent)(`Check ${bold("TODO.md")} for remaining steps`));
4948
4968
  }
4949
4969
  console.log(cmd(`${pm.run} dev`));
4950
4970
  console.log("\nHappy coding! \u{1F680}\n");
@@ -10,7 +10,7 @@ import {
10
10
  } from "./chunk-IAWYWZSL.js";
11
11
  import "./chunk-IHX3I5SM.js";
12
12
 
13
- // ../core/dist/jiti-ZW3ADF2F.js
13
+ // ../core/dist/jiti-PKZMRTZN.js
14
14
  import { createRequire as BATI_core_createRequire } from "module";
15
15
  import { fileURLToPath as BATI_fileURLToPath } from "url";
16
16
  import { dirname as BATI_dirname } from "path";
@@ -2100,7 +2100,6 @@ Defaulting to 2020, but this will stop working in the future.`)), e.ecmaVersion
2100
2100
  } else i = s;
2101
2101
  return i;
2102
2102
  }
2103
- Symbol.for("ufo:protocolRelative");
2104
2103
  let gs = /^[A-Za-z]:\//;
2105
2104
  function gt(t = "") {
2106
2105
  return t && t.replace(/\\/g, "/").replace(gs, (e) => e.toUpperCase());
@@ -2638,7 +2637,7 @@ Default "index" lookups for the main are deprecated for ES modules.`, "Deprecati
2638
2637
  if (typeof t != "string") throw new TypeError("Expected a string");
2639
2638
  return t.replace(/[|\\{}()[\]^$+*?.]/g, "\\$&").replace(/-/g, "\\x2d");
2640
2639
  }
2641
- let tr = /* @__PURE__ */ new Set(["/", "\\", void 0]), Ci = Symbol.for("pathe:normalizedAlias"), er = /[/\\]/;
2640
+ let tr = /* @__PURE__ */ new Set(["/", "\\", void 0]), Ci = /* @__PURE__ */ Symbol.for("pathe:normalizedAlias"), er = /[/\\]/;
2642
2641
  function Ii(t) {
2643
2642
  if (t[Ci]) return t;
2644
2643
  let e = Object.fromEntries(Object.entries(t).sort(([i], [s]) => (function(r, a) {
@@ -343,7 +343,7 @@ function lD(t, u2) {
343
343
  return s;
344
344
  }
345
345
  globalThis.process.platform.startsWith("win");
346
- var S = Symbol("clack:cancel");
346
+ var S = /* @__PURE__ */ Symbol("clack:cancel");
347
347
  function d$1(t, u2) {
348
348
  const F2 = t;
349
349
  F2.isTTY && F2.setRawMode(u2);
@@ -687,7 +687,7 @@ ${e.cyan(d)}
687
687
  } }).prompt();
688
688
  };
689
689
  `${e.gray(o)} `;
690
- var kCancel = Symbol.for("cancel");
690
+ var kCancel = /* @__PURE__ */ Symbol.for("cancel");
691
691
  async function prompt(message, opts = {}) {
692
692
  const handleCancel = (value) => {
693
693
  if (typeof value !== "symbol" || value.toString() !== "Symbol(clack:cancel)") {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@batijs/cli",
3
- "version": "0.0.542",
3
+ "version": "0.0.544",
4
4
  "type": "module",
5
5
  "keywords": [],
6
6
  "description": "Next-gen scaffolder. Get started with fully-functional apps, and choose any tool you want",
@@ -8,23 +8,23 @@
8
8
  "repository": "https://github.com/vikejs/bati",
9
9
  "license": "MIT",
10
10
  "devDependencies": {
11
- "@inquirer/prompts": "^8.0.1",
11
+ "@inquirer/prompts": "^8.0.2",
12
12
  "@types/node": "^20.19.25",
13
13
  "@types/which": "^3.0.4",
14
14
  "citty": "^0.1.6",
15
15
  "colorette": "^2.0.20",
16
- "esbuild": "^0.27.0",
16
+ "esbuild": "^0.27.1",
17
17
  "execa": "^9.6.1",
18
18
  "tsup": "^8.5.1",
19
19
  "typescript": "^5.9.3",
20
20
  "unplugin-purge-polyfills": "^0.1.0",
21
- "vite": "^7.2.6",
22
- "@batijs/compile": "0.0.542",
23
- "@batijs/build": "0.0.542"
21
+ "vite": "^7.2.7",
22
+ "@batijs/build": "0.0.544",
23
+ "@batijs/compile": "0.0.544"
24
24
  },
25
25
  "dependencies": {
26
- "@batijs/core": "0.0.542",
27
- "@batijs/features": "0.0.542"
26
+ "@batijs/core": "0.0.544",
27
+ "@batijs/features": "0.0.544"
28
28
  },
29
29
  "bin": "./cli.js",
30
30
  "exports": {