@batijs/features 0.0.255 → 0.0.257

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.
@@ -413,6 +413,25 @@ var features = [
413
413
  }
414
414
  ]
415
415
  },
416
+ {
417
+ category: "Database",
418
+ label: "SQLite",
419
+ flag: "sqlite",
420
+ image: "",
421
+ url: "https://www.sqlite.org/",
422
+ tagline: "SQLite is a C-language library that implements a small, fast, self-contained, high-reliability, full-featured, SQL database engine",
423
+ repo: "sqlite/sqlite",
424
+ links: [
425
+ {
426
+ label: "better-sqlite3: API",
427
+ href: "https://github.com/WiseLibs/better-sqlite3/blob/master/docs/api.md"
428
+ },
429
+ {
430
+ label: "D1: Getting started",
431
+ href: "https://developers.cloudflare.com/d1/get-started/"
432
+ }
433
+ ]
434
+ },
416
435
  // Analytics
417
436
  {
418
437
  category: "Analytics",
@@ -382,6 +382,21 @@ declare const features: readonly [{
382
382
  readonly label: "Docs & Getting started";
383
383
  readonly href: "https://orm.drizzle.team/docs/overview";
384
384
  }];
385
+ }, {
386
+ readonly category: "Database";
387
+ readonly label: "SQLite";
388
+ readonly flag: "sqlite";
389
+ readonly image: "";
390
+ readonly url: "https://www.sqlite.org/";
391
+ readonly tagline: "SQLite is a C-language library that implements a small, fast, self-contained, high-reliability, full-featured, SQL database engine";
392
+ readonly repo: "sqlite/sqlite";
393
+ readonly links: [{
394
+ readonly label: "better-sqlite3: API";
395
+ readonly href: "https://github.com/WiseLibs/better-sqlite3/blob/master/docs/api.md";
396
+ }, {
397
+ readonly label: "D1: Getting started";
398
+ readonly href: "https://developers.cloudflare.com/d1/get-started/";
399
+ }];
385
400
  }, {
386
401
  readonly category: "Analytics";
387
402
  readonly label: "Plausible.io";
@@ -489,8 +504,8 @@ declare const features: readonly [{
489
504
  readonly url: "https://logrocket.com";
490
505
  readonly disabled: true;
491
506
  }];
492
- declare const flags: ("vike" | "react" | "vue" | "solid" | "tailwindcss" | "daisyui" | "compiled-css" | "mantine" | "authjs" | "auth0" | "firebase-auth" | "lucia-auth" | "telefunc" | "trpc" | "ts-rest" | "hono" | "h3" | "express" | "fastify" | "hattip" | "prisma" | "edgedb" | "drizzle" | "plausible.io" | "google-analytics" | "segment" | "cloudflare" | "vercel" | "netlify" | "eslint" | "prettier" | "biome" | "sentry" | "logrocket")[];
493
- declare const cliFlags: ("vike" | "react" | "vue" | "solid" | "tailwindcss" | "daisyui" | "compiled-css" | "mantine" | "authjs" | "auth0" | "firebase-auth" | "lucia-auth" | "telefunc" | "trpc" | "ts-rest" | "hono" | "h3" | "express" | "fastify" | "hattip" | "prisma" | "edgedb" | "drizzle" | "plausible.io" | "google-analytics" | "segment" | "cloudflare" | "vercel" | "netlify" | "eslint" | "prettier" | "biome" | "sentry" | "logrocket")[];
507
+ declare const flags: ("vike" | "react" | "vue" | "solid" | "tailwindcss" | "daisyui" | "compiled-css" | "mantine" | "authjs" | "auth0" | "firebase-auth" | "lucia-auth" | "telefunc" | "trpc" | "ts-rest" | "hono" | "h3" | "express" | "fastify" | "hattip" | "prisma" | "edgedb" | "drizzle" | "sqlite" | "plausible.io" | "google-analytics" | "segment" | "cloudflare" | "vercel" | "netlify" | "eslint" | "prettier" | "biome" | "sentry" | "logrocket")[];
508
+ declare const cliFlags: ("vike" | "react" | "vue" | "solid" | "tailwindcss" | "daisyui" | "compiled-css" | "mantine" | "authjs" | "auth0" | "firebase-auth" | "lucia-auth" | "telefunc" | "trpc" | "ts-rest" | "hono" | "h3" | "express" | "fastify" | "hattip" | "prisma" | "edgedb" | "drizzle" | "sqlite" | "plausible.io" | "google-analytics" | "segment" | "cloudflare" | "vercel" | "netlify" | "eslint" | "prettier" | "biome" | "sentry" | "logrocket")[];
494
509
  type Flags = (typeof flags)[number];
495
510
 
496
511
  export { type CategoryLabels as C, type Flags as F, categories as a, flags as b, categoriesGroups as c, cliFlags as d, features as f };
package/dist/index.d.ts CHANGED
@@ -1,5 +1,5 @@
1
- import { c as categoriesGroups } from './features-BdcbXC10.js';
2
- export { C as CategoryLabels, F as Flags, a as categories, d as cliFlags, f as features, b as flags } from './features-BdcbXC10.js';
1
+ import { c as categoriesGroups, F as Flags } from './features-CP-YxjVb.js';
2
+ export { C as CategoryLabels, a as categories, d as cliFlags, f as features, b as flags } from './features-CP-YxjVb.js';
3
3
 
4
4
  interface Feature<C = string> {
5
5
  label: string;
@@ -28,4 +28,12 @@ interface Category {
28
28
  description?: string;
29
29
  }
30
30
 
31
- export { type Category, type Feature, type FeatureLink, categoriesGroups };
31
+ declare class BatiSet extends Set<Flags> {
32
+ #private;
33
+ constructor(flags: Flags[], allFeatures: ReadonlyArray<Feature>);
34
+ private hasOneOf;
35
+ get hasServer(): boolean;
36
+ get hasDatabase(): boolean;
37
+ }
38
+
39
+ export { BatiSet, type Category, type Feature, type FeatureLink, Flags, categoriesGroups };
package/dist/index.js CHANGED
@@ -2,7 +2,7 @@ import {
2
2
  cliFlags,
3
3
  features,
4
4
  flags
5
- } from "./chunk-ZSQCULP5.js";
5
+ } from "./chunk-GJOFJ3EP.js";
6
6
 
7
7
  // src/groups.ts
8
8
  var categoriesGroups = /* @__PURE__ */ ((categoriesGroups2) => {
@@ -85,7 +85,29 @@ tailored for Vike.`
85
85
  description: `Coming soon: Error Tracking solution for frontend and backend`
86
86
  }
87
87
  ];
88
+
89
+ // src/helpers.ts
90
+ var BatiSet = class extends Set {
91
+ #servers;
92
+ #databases;
93
+ constructor(flags2, allFeatures) {
94
+ super(flags2);
95
+ this.#servers = new Set(allFeatures.filter((f) => f.category === "Server").map((f) => f.flag));
96
+ this.#databases = new Set(allFeatures.filter((f) => f.category === "Database").map((f) => f.flag));
97
+ }
98
+ hasOneOf(a) {
99
+ for (const x of this) if (a.has(x)) return true;
100
+ return false;
101
+ }
102
+ get hasServer() {
103
+ return this.hasOneOf(this.#servers);
104
+ }
105
+ get hasDatabase() {
106
+ return this.hasOneOf(this.#databases);
107
+ }
108
+ };
88
109
  export {
110
+ BatiSet,
89
111
  categories,
90
112
  categoriesGroups,
91
113
  cliFlags,
package/dist/rules.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import { F as Flags, C as CategoryLabels } from './features-BdcbXC10.js';
1
+ import { F as Flags, C as CategoryLabels } from './features-CP-YxjVb.js';
2
2
 
3
3
  declare enum RulesMessage {
4
4
  ERROR_AUTH_R_SERVER = 0,
@@ -6,9 +6,10 @@ declare enum RulesMessage {
6
6
  ERROR_MANTINE_R_REACT = 2,
7
7
  ERROR_DRIZZLE_R_SERVER = 3,
8
8
  ERROR_DATA_R_SERVER = 4,
9
- ERROR_CLOUDFLARE_R_COMPAT_SERVER = 5,
10
- INFO_HATTIP = 6,
11
- INFO_DRIZZLE_STACKBLITZ = 7
9
+ ERROR_LUCIA_R_COMPAT_DATABASE = 5,
10
+ ERROR_CLOUDFLARE_R_COMPAT_SERVER = 6,
11
+ INFO_HATTIP = 7,
12
+ INFO_DRIZZLE_STACKBLITZ = 8
12
13
  }
13
14
 
14
15
  type FeatureOrCategory = Flags | CategoryLabels;
package/dist/rules.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  features,
3
3
  flags
4
- } from "./chunk-ZSQCULP5.js";
4
+ } from "./chunk-GJOFJ3EP.js";
5
5
 
6
6
  // src/rules/enum.ts
7
7
  var RulesMessage = /* @__PURE__ */ ((RulesMessage2) => {
@@ -10,9 +10,10 @@ var RulesMessage = /* @__PURE__ */ ((RulesMessage2) => {
10
10
  RulesMessage2[RulesMessage2["ERROR_MANTINE_R_REACT"] = 2] = "ERROR_MANTINE_R_REACT";
11
11
  RulesMessage2[RulesMessage2["ERROR_DRIZZLE_R_SERVER"] = 3] = "ERROR_DRIZZLE_R_SERVER";
12
12
  RulesMessage2[RulesMessage2["ERROR_DATA_R_SERVER"] = 4] = "ERROR_DATA_R_SERVER";
13
- RulesMessage2[RulesMessage2["ERROR_CLOUDFLARE_R_COMPAT_SERVER"] = 5] = "ERROR_CLOUDFLARE_R_COMPAT_SERVER";
14
- RulesMessage2[RulesMessage2["INFO_HATTIP"] = 6] = "INFO_HATTIP";
15
- RulesMessage2[RulesMessage2["INFO_DRIZZLE_STACKBLITZ"] = 7] = "INFO_DRIZZLE_STACKBLITZ";
13
+ RulesMessage2[RulesMessage2["ERROR_LUCIA_R_COMPAT_DATABASE"] = 5] = "ERROR_LUCIA_R_COMPAT_DATABASE";
14
+ RulesMessage2[RulesMessage2["ERROR_CLOUDFLARE_R_COMPAT_SERVER"] = 6] = "ERROR_CLOUDFLARE_R_COMPAT_SERVER";
15
+ RulesMessage2[RulesMessage2["INFO_HATTIP"] = 7] = "INFO_HATTIP";
16
+ RulesMessage2[RulesMessage2["INFO_DRIZZLE_STACKBLITZ"] = 8] = "INFO_DRIZZLE_STACKBLITZ";
16
17
  return RulesMessage2;
17
18
  })(RulesMessage || {});
18
19
 
@@ -43,10 +44,10 @@ var rules_default = [
43
44
  requires(0 /* ERROR_AUTH_R_SERVER */, "Auth", ["Server"]),
44
45
  requires(1 /* ERROR_COMPILED_R_REACT */, "compiled-css", ["react"]),
45
46
  requires(2 /* ERROR_MANTINE_R_REACT */, "mantine", ["react"]),
46
- includes(6 /* INFO_HATTIP */, "hattip"),
47
+ includes(7 /* INFO_HATTIP */, "hattip"),
47
48
  requires(3 /* ERROR_DRIZZLE_R_SERVER */, "drizzle", ["Server"]),
48
49
  requires(4 /* ERROR_DATA_R_SERVER */, "Data fetching", ["Server"]),
49
- filter(5 /* ERROR_CLOUDFLARE_R_COMPAT_SERVER */, (fts) => {
50
+ filter(6 /* ERROR_CLOUDFLARE_R_COMPAT_SERVER */, (fts) => {
50
51
  if (fts.has("cloudflare")) {
51
52
  if (fts.has("hono") || fts.has("hattip")) {
52
53
  return false;
@@ -55,7 +56,13 @@ var rules_default = [
55
56
  }
56
57
  return false;
57
58
  }),
58
- includes(7 /* INFO_DRIZZLE_STACKBLITZ */, "drizzle")
59
+ filter(5 /* ERROR_LUCIA_R_COMPAT_DATABASE */, (fts) => {
60
+ if (fts.has("lucia-auth")) {
61
+ return !(fts.has("sqlite") || fts.has("drizzle"));
62
+ }
63
+ return false;
64
+ }),
65
+ includes(8 /* INFO_DRIZZLE_STACKBLITZ */, "drizzle")
59
66
  ];
60
67
 
61
68
  // src/rules/index.ts
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@batijs/features",
3
- "version": "0.0.255",
3
+ "version": "0.0.257",
4
4
  "description": "",
5
5
  "type": "module",
6
6
  "keywords": [],