@prisma/studio-core 0.0.0-dev.202511111927 → 0.0.0-dev.202511112025
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/{chunk-GUK7IE4A.js → chunk-3DNVYNUR.js} +1 -1
- package/dist/chunk-FFEYXGFF.js +10 -0
- package/dist/chunk-PFICURYF.js +10 -0
- package/dist/data/accelerate/index.d.cts +1 -1
- package/dist/data/accelerate/index.d.ts +1 -1
- package/dist/data/bff/index.d.cts +1 -1
- package/dist/data/bff/index.d.ts +1 -1
- package/dist/data/index.d.cts +1 -1
- package/dist/data/index.d.ts +1 -1
- package/dist/data/node-sqlite/index.cjs +2 -2
- package/dist/data/node-sqlite/index.d.cts +1 -1
- package/dist/data/node-sqlite/index.d.ts +1 -1
- package/dist/data/node-sqlite/index.js +1 -1
- package/dist/data/pglite/index.cjs +1 -1
- package/dist/data/pglite/index.d.cts +1 -1
- package/dist/data/pglite/index.d.ts +1 -1
- package/dist/data/pglite/index.js +1 -1
- package/dist/data/postgres-core/index.cjs +1 -1
- package/dist/data/postgres-core/index.d.cts +1 -1
- package/dist/data/postgres-core/index.d.ts +1 -1
- package/dist/data/postgres-core/index.js +1 -1
- package/dist/data/postgresjs/index.cjs +1 -1
- package/dist/data/postgresjs/index.d.cts +1 -1
- package/dist/data/postgresjs/index.d.ts +1 -1
- package/dist/data/postgresjs/index.js +1 -1
- package/dist/data/ppg/index.d.cts +1 -1
- package/dist/data/ppg/index.d.ts +1 -1
- package/dist/data/sqlite-core/index.cjs +2 -2
- package/dist/data/sqlite-core/index.d.cts +1 -1
- package/dist/data/sqlite-core/index.d.ts +1 -1
- package/dist/data/sqlite-core/index.js +1 -1
- package/dist/{index-C2ZP5zCW.d.ts → index-DMbFKyaD.d.cts} +8 -0
- package/dist/{index-C2ZP5zCW.d.cts → index-DMbFKyaD.d.ts} +8 -0
- package/dist/metafile-cjs.json +1 -1
- package/dist/metafile-esm.json +1 -1
- package/dist/ui/index.d.cts +1 -1
- package/dist/ui/index.d.ts +1 -1
- package/package.json +1 -1
- package/dist/chunk-MI7VN4OZ.js +0 -10
- package/dist/chunk-XYM4YG5N.js +0 -10
package/dist/ui/index.d.cts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import { A as Adapter, Q as Query, e as AdapterError } from '../index-
|
|
2
|
+
import { A as Adapter, Q as Query, e as AdapterError } from '../index-DMbFKyaD.cjs';
|
|
3
3
|
import { UseQueryStateOptions, UseQueryStateReturn, Options, Parser, UseQueryStatesOptions, UseQueryStatesReturn } from 'nuqs';
|
|
4
4
|
export * from 'nuqs';
|
|
5
5
|
import 'kysely';
|
package/dist/ui/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as react_jsx_runtime from 'react/jsx-runtime';
|
|
2
|
-
import { A as Adapter, Q as Query, e as AdapterError } from '../index-
|
|
2
|
+
import { A as Adapter, Q as Query, e as AdapterError } from '../index-DMbFKyaD.js';
|
|
3
3
|
import { UseQueryStateOptions, UseQueryStateReturn, Options, Parser, UseQueryStatesOptions, UseQueryStatesReturn } from 'nuqs';
|
|
4
4
|
export * from 'nuqs';
|
|
5
5
|
import 'kysely';
|
package/package.json
CHANGED
package/dist/chunk-MI7VN4OZ.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import * as ___react___ from 'react';
|
|
2
|
-
import * as ___react_dom___ from 'react-dom';
|
|
3
|
-
|
|
4
|
-
function require(mod) {
|
|
5
|
-
if (mod === 'react') return ___react___;
|
|
6
|
-
if (mod === 'react-dom') return ___react_dom___;
|
|
7
|
-
throw new Error(`Unknown module ${mod}`);
|
|
8
|
-
}
|
|
9
|
-
import{e as r}from"./chunk-GDQBQ7MK.js";r();function i(t){let{error:a,query:o}=t,e=a;return e.query=o,[e]}export{i as a};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/adapter.ts"],
  "sourcesContent": ["import type { Executor } from \"./executor\";\nimport type { Query } from \"./query\";\nimport type { BigIntString, Either, NumericString } from \"./type-utils\";\n\nexport interface AdapterRequirements {\n  executor: Executor;\n  noParameters?: boolean;\n}\n\nexport interface Adapter {\n  /**\n   * The schema studio will choose by default.\n   *\n   * e.g. `public` for PostgreSQL\n   */\n  readonly defaultSchema?: string;\n\n  /**\n   * Introspects the database and returns structured information about the schemas, tables, etc.\n   *\n   * @param options - Options for the introspection request.\n   */\n  introspect(options: AdapterIntrospectOptions): Promise<Either<AdapterError, AdapterIntrospectResult>>;\n\n  /**\n   * Executes a structured query against the database.\n   */\n  query(details: AdapterQueryDetails, options: AdapterQueryOptions): Promise<Either<AdapterError, AdapterQueryResult>>;\n\n  /**\n   * Inserts a single row into the database.\n   */\n  insert(\n    details: AdapterInsertDetails,\n    options: AdapterInsertOptions,\n  ): Promise<Either<AdapterError, AdapterInsertResult>>;\n\n  /**\n   * Updates a given row in the database with given changes.\n   */\n  update(\n    details: AdapterUpdateDetails,\n    options: AdapterUpdateOptions,\n  ): Promise<Either<AdapterError, AdapterUpdateResult>>;\n\n  /**\n   * Deletes given rows from the database.\n   */\n  delete(\n    details: AdapterDeleteDetails,\n    options: AdapterDeleteOptions,\n  ): Promise<Either<AdapterError, AdapterDeleteResult>>;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterIntrospectOptions extends AdapterBaseOptions {}\n\nexport interface AdapterQueryOptions extends AdapterBaseOptions {\n  abortSignal: AbortSignal;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterInsertOptions extends AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterUpdateOptions extends AdapterBaseOptions {}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterDeleteOptions extends AdapterBaseOptions {}\n\ntype SchemaName = string;\n\nexport interface AdapterIntrospectResult {\n  schemas: Record<SchemaName, Schema>;\n  timezone: string;\n  filterOperators: FilterOperator[];\n  query: Query;\n}\n\ntype TableName = string;\n\nexport interface Schema {\n  name: string;\n  tables: Record<TableName, Table>;\n}\n\ntype ColumnName = string;\n\nexport interface Table {\n  columns: Record<ColumnName, Column>;\n  name: TableName;\n  schema: SchemaName;\n}\n\nexport interface Column {\n  datatype: DataType;\n  isComputed: boolean;\n  isInPrimaryKey: boolean;\n  name: ColumnName;\n  nullable: boolean;\n  schema: SchemaName;\n  table: TableName;\n  fkSchema: SchemaName | null;\n  fkColumn: ColumnName | null;\n  fkTable: TableName | null;\n}\n\nexport interface DataType {\n  /**\n   * A simplification/normalization for UI usage.\n   *\n   * e.g. varchar and char are strings.\n   */\n  group: DataTypeGroup;\n\n  /**\n   * Is this a native array type?\n   */\n  isArray: boolean;\n\n  /**\n   * Is a native database datatype or a user-defined datatype?\n   *\n   * e.g. PostgreSQL enums are user-defined datatypes, but `int4` is a native datatype.\n   */\n  isNative: boolean;\n\n  /**\n   * Will be displayed as-is.\n   */\n  name: string;\n\n  /**\n   * Enum values for enum types.\n   */\n  options: string[];\n\n  /**\n   * The schema the datatype belongs to.\n   */\n  schema: string;\n}\n\nexport type DataTypeGroup = \"string\" | \"datetime\" | \"boolean\" | \"enum\" | \"time\" | \"raw\" | \"numeric\" | \"json\";\n\nexport interface AdapterQueryDetails {\n  /**\n   * Zero-based index of the page to fetch.\n   */\n  pageIndex: number;\n\n  /**\n   * Maximum number of rows to fetch from the database.\n   */\n  pageSize: number;\n\n  /**\n   * Sort order for the query.\n   */\n  sortOrder: SortOrderItem[];\n\n  /**\n   * The table to select from.\n   */\n  table: Table;\n\n  /**\n   * The filter to be applied.\n   */\n  filter?: FilterGroup;\n}\n\nexport type FilterOperator =\n  | \"=\"\n  | \"!=\"\n  | \">\"\n  | \">=\"\n  | \"<\"\n  | \"<=\"\n  | \"is\"\n  | \"is not\"\n  | \"like\"\n  | \"not like\"\n  | \"ilike\"\n  | \"not ilike\";\n\nexport interface ColumnFilter {\n  kind: \"ColumnFilter\";\n  column: string;\n  operator: FilterOperator;\n  value: unknown;\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface FilterGroup {\n  kind: \"FilterGroup\";\n  filters: (ColumnFilter | FilterGroup)[];\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface SortOrderItem {\n  /**\n   * The column to sort by.\n   */\n  column: ColumnName;\n\n  /**\n   * The direction to sort the column by.\n   */\n  direction: SortDirection;\n}\n\nexport type SortDirection = \"asc\" | \"desc\";\n\nexport class AdapterError extends Error {\n  query?: Query;\n}\n\nexport interface AdapterQueryResult {\n  /**\n   * The total number of rows the query would return if not limited.\n   *\n   * If the database does not support counting rows, this should be set to `Infinity`.\n   */\n  filteredRowCount: number | bigint | NumericString | BigIntString;\n\n  /**\n   * The rows returned by the query.\n   */\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterInsertDetails {\n  /**\n   * The table to insert into.\n   */\n  table: Table;\n\n  /**\n   * The values to insert into the table.\n   * - The keys should match the column names in the table.\n   * - The values should be the values to insert into the table.\n   */\n  rows: Record<string, unknown>[];\n}\n\nexport interface AdapterInsertResult {\n  /**\n   * The freshly inserted row data.\n   */\n  rows: Record<string, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterUpdateDetails {\n  /**\n   * Changes to apply to the row.\n   */\n  changes: Record<ColumnName, unknown>;\n\n  /**\n   * The row to update.\n   */\n  row: Record<ColumnName, unknown>;\n\n  /**\n   * The table to update in.\n   */\n  table: Table;\n}\n\nexport interface AdapterUpdateResult {\n  /**\n   * The updated row data.\n   */\n  row: Record<ColumnName, unknown> & {\n    /**\n     * When the changes were applied in database time.\n     */\n    __ps_updated_at__: string | number | Date;\n  };\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport interface AdapterDeleteDetails {\n  /**\n   * The rows to delete.\n   */\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The table to delete from.\n   */\n  table: Table;\n}\n\nexport interface AdapterDeleteResult {\n  rows: Record<ColumnName, unknown>[];\n\n  /**\n   * The executed query string.\n   */\n  query: Query;\n}\n\nexport function createAdapterError(args: { error: Error; query?: Query }) {\n  const { error, query } = args;\n\n  const adapterError = error as AdapterError;\n\n  adapterError.query = query;\n\n  return [adapterError] as [AdapterError];\n}\n"],
  "mappings": ";;;;;;;;wCAAAA,IAmUO,SAASC,EAAmBC,EAAuC,CACxE,GAAM,CAAE,MAAAC,EAAO,MAAAC,CAAM,EAAIF,EAEnBG,EAAeF,EAErB,OAAAE,EAAa,MAAQD,EAEd,CAACC,CAAY,CACtB",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "createAdapterError", "args", "error", "query", "adapterError"]
}

|
package/dist/chunk-XYM4YG5N.js
DELETED
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import * as ___react___ from 'react';
|
|
2
|
-
import * as ___react_dom___ from 'react-dom';
|
|
3
|
-
|
|
4
|
-
function require(mod) {
|
|
5
|
-
if (mod === 'react') return ___react___;
|
|
6
|
-
if (mod === 'react-dom') return ___react_dom___;
|
|
7
|
-
throw new Error(`Unknown module ${mod}`);
|
|
8
|
-
}
|
|
9
|
-
import{a as p}from"./chunk-MI7VN4OZ.js";import{a as d,b as y,c as g,d as a,e as s,f as b,g as l,h,i as m,j as _,k as j,n as w,p as x}from"./chunk-EQFDGYQI.js";import{e as n}from"./chunk-GDQBQ7MK.js";n();n();n();n();n();function A(t,r){let o=[];for(let{selection:e}of t.selections??[])if(s.is(e)&&a.is(e.column))o.push(u(e.column.column.name),c(r,e.column.column.name));else if(a.is(e))o.push(u(e.column.name),c(r,e.column.name));else if(y.is(e)&&d.is(e.alias))o.push(u(e.alias.name),c(r,e.alias.name));else throw new Error("can't extract column names from the select query node");return o}function u(t){return new l(b.createImmediate(t))}function c(t,r){return new l(s.create(a.create(r),g.create(t)))}function q(t){return m`(select coalesce(json_group_array(json_object(${m.join(k(t.toOperationNode(),"agg"))})), '[]') from ${t} as agg)`}function k(t,r){try{return A(t,r)}catch{throw new Error("SQLite jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.")}}n();function E(t){return w({...t,Adapter:j,QueryCompiler:_})}function R(t){return x(E(t).selectFrom(h().fn("pragma_table_list",[]).as("tl")).leftJoin("sqlite_schema as ss",r=>r.onRef("ss.type","=","tl.type").onRef("ss.name","=","tl.name")).where("tl.type","in",["table","view"]).where("tl.schema","=","main").where("tl.name","not like","sqlite_%").select(["tl.name","ss.sql"]).select(r=>[q(r.selectFrom(r.fn("pragma_table_xinfo",["tl.name"]).as("txi")).leftJoin(r.fn("pragma_foreign_key_list",["tl.name"]).as("fkl"),"fkl.from","txi.name").where("txi.hidden","!=",1).select(["txi.name","txi.type as datatype","fkl.table as foreign_key_table","fkl.to as foreign_key_column"]).select(o=>[o("txi.hidden","in",[2,3]).as("computed"),o("txi.notnull","!=",0).as("nullable"),o("txi.pk","!=",0).as("pk")])).as("columns")]))}function ee(t){let{executor:r}=t;return{defaultSchema:"main",delete(o,e){throw new Error("Method not implemented.")},insert(o,e){throw new Error("Method not implemented.")},async introspect(o){try{let e=R(t),[f,Q]=await r.execute(e,o);return f?p({error:f,query:e}):[null,{filterOperators:[],query:e,schemas:{},timezone:"UTC"}]}catch(e){return p({error:e})}},query(o,e){throw new Error("Method not implemented.")},update(o,e){throw new Error("Method not implemented.")}}}export{R as a,ee as b};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../data/sqlite-core/index.ts", "../data/sqlite-core/adapter.ts", "../data/sqlite-core/introspection.ts", "../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/helpers/sqlite.js", "../../../node_modules/.pnpm/kysely@0.28.2/node_modules/kysely/dist/esm/util/json-object-args.js", "../data/sqlite-core/builder.ts"],
  "sourcesContent": ["export * from \"./adapter\";\nexport * from \"./dml\";\nexport * from \"./introspection\";\n", "import {\n  type Adapter,\n  type AdapterError,\n  type AdapterIntrospectResult,\n  type AdapterRequirements,\n  createAdapterError,\n} from \"../adapter\";\nimport type { Either } from \"../type-utils\";\nimport { getTablesQuery } from \"./introspection\";\n\nexport type SQLIteAdapterRequirements = AdapterRequirements;\n\nexport function createSQLiteAdapter(requirements: SQLIteAdapterRequirements): Adapter {\n  const { executor } = requirements;\n\n  return {\n    defaultSchema: \"main\",\n\n    delete(_details, _options) {\n      throw new Error(\"Method not implemented.\");\n    },\n\n    insert(_details, _options) {\n      throw new Error(\"Method not implemented.\");\n    },\n\n    async introspect(options): Promise<Either<AdapterError, AdapterIntrospectResult>> {\n      try {\n        const tablesQuery = getTablesQuery(requirements);\n\n        const [tablesError, _tables] = await executor.execute(tablesQuery, options);\n\n        if (tablesError) {\n          return createAdapterError({ error: tablesError, query: tablesQuery });\n        }\n\n        return [\n          null,\n          {\n            filterOperators: [],\n            query: tablesQuery,\n            schemas: {},\n            timezone: \"UTC\",\n          },\n        ];\n      } catch (error: unknown) {\n        return createAdapterError({ error: error as Error });\n      }\n    },\n\n    query(_details, _options) {\n      throw new Error(\"Method not implemented.\");\n    },\n\n    update(_details, _options) {\n      throw new Error(\"Method not implemented.\");\n    },\n  };\n}\n", "/**\n * SQLite introspection queries to be used by the SQLite adapter's introspect method.\n * @module sqlite-core/introspection\n *\n * References:\n * https://sqlite.org/pragma.html\n * https://sqlite.org/schematab.html\n */\n\nimport { expressionBuilder } from \"kysely\";\nimport { jsonArrayFrom } from \"kysely/helpers/sqlite\";\n\nimport { type BuilderRequirements, compile } from \"../query\";\nimport { getSQLiteBuilder } from \"./builder\";\n\ninterface Database {\n  /** the main system table */\n  sqlite_schema: {\n    /** object name */\n    name: string;\n    /** page number in root index when object is a table. */\n    rootpage: number;\n    /** sql statement that can recreate the object. null when internal index object. */\n    sql: string | null;\n    /** related table/view name when object is an index/trigger. */\n    tbl_name: string;\n    /** object type */\n    type: \"index\" | \"table\" | \"trigger\" | \"view\";\n  };\n}\n\n/**\n * The shape of each row returned by `pragma_table_list(tableName?)`.\n */\ninterface PragmaTableList {\n  /** object name */\n  name: string;\n  /** schema name */\n  schema: \"main\" | \"temp\";\n  /** object type */\n  type: \"shadow\" | \"table\" | \"view\" | \"virtual\";\n}\n\n/**\n * The shape of each row returned by `pragma_table_xinfo(tableName)`.\n */\ninterface PragmaTableXInfo {\n  /** \"rank within current result set\" */\n  cid: number;\n  /** default value */\n  dflt_value: unknown;\n  /** 0 - normal, 1 - hidden, 2-3 - dynamic/stored generated */\n  hidden: 0 | 1 | 2 | 3;\n  /** column name */\n  name: string;\n  /** whether the column can be null */\n  notnull: 0 | 1;\n  /** 0 if not part of the primary key, otherwise the 1-based ordinal number of the column in the primary key */\n  pk: number;\n  /** data type */\n  type: string;\n}\n\n/**\n * The shape of each row returned by `pragma_foreign_key_list(tableName)`.\n */\ninterface PragmaForeignKeyList {\n  /** column name */\n  from: string;\n  /** ordinal number of column within the foreign key */\n  seq: number;\n  /** foreign table name */\n  table: string;\n  /** column name in the foreign table */\n  to: string;\n}\n\nexport function getTablesQuery(requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">) {\n  return compile(\n    getSQLiteBuilder<Database>(requirements)\n      .selectFrom(expressionBuilder().fn<PragmaTableList>(\"pragma_table_list\", []).as(\"tl\"))\n      .leftJoin(\"sqlite_schema as ss\", (jb) => jb.onRef(\"ss.type\", \"=\", \"tl.type\").onRef(\"ss.name\", \"=\", \"tl.name\"))\n      .where(\"tl.type\", \"in\", [\"table\", \"view\"])\n      // exclude temporary tables/views\n      .where(\"tl.schema\", \"=\", \"main\")\n      // exclude system tables/views\n      .where(\"tl.name\", \"not like\", \"sqlite_%\")\n      .select([\"tl.name\", \"ss.sql\"])\n      .select((eb) => [\n        jsonArrayFrom(\n          eb\n            .selectFrom(eb.fn<PragmaTableXInfo>(\"pragma_table_xinfo\", [\"tl.name\"]).as(\"txi\"))\n            .leftJoin(\n              eb.fn<PragmaForeignKeyList>(\"pragma_foreign_key_list\", [\"tl.name\"]).as(\"fkl\"),\n              \"fkl.from\",\n              \"txi.name\",\n            )\n            // exclude hidden columns\n            .where(\"txi.hidden\", \"!=\", 1)\n            .select([\n              \"txi.name\",\n              \"txi.type as datatype\",\n              \"fkl.table as foreign_key_table\",\n              \"fkl.to as foreign_key_column\",\n            ])\n            .select((eb) => [\n              eb(\"txi.hidden\", \"in\", [2, 3]).as(\"computed\"),\n              eb(\"txi.notnull\", \"!=\", 0).as(\"nullable\"),\n              eb(\"txi.pk\", \"!=\", 0).as(\"pk\"),\n            ]),\n        ).as(\"columns\"),\n      ]),\n  );\n}\n", "/// <reference types=\"./sqlite.d.ts\" />\nimport { sql } from '../raw-builder/sql.js';\nimport { getJsonObjectArgs } from '../util/json-object-args.js';\n/**\n * A SQLite helper for aggregating a subquery into a JSON array.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { jsonArrayFrom } from 'kysely/helpers/sqlite'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonArrayFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .orderBy('pet.name')\n *     ).as('pets')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.pets[0].pet_id\n * result[0]?.pets[0].name\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * select \"id\", (\n *   select coalesce(json_group_array(json_object(\n *     'pet_id', \"agg\".\"pet_id\",\n *     'name', \"agg\".\"name\"\n *   )), '[]') from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     order by \"pet\".\"name\"\n *   ) as \"agg\"\n * ) as \"pets\"\n * from \"person\"\n * ```\n */\nexport function jsonArrayFrom(expr) {\n    return sql `(select coalesce(json_group_array(json_object(${sql.join(getSqliteJsonObjectArgs(expr.toOperationNode(), 'agg'))})), '[]') from ${expr} as agg)`;\n}\n/**\n * A SQLite helper for turning a subquery into a JSON object.\n *\n * The subquery must only return one row.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { jsonObjectFrom } from 'kysely/helpers/sqlite'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonObjectFrom(\n *       eb.selectFrom('pet')\n *         .select(['pet.id as pet_id', 'pet.name'])\n *         .whereRef('pet.owner_id', '=', 'person.id')\n *         .where('pet.is_favorite', '=', true)\n *     ).as('favorite_pet')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.favorite_pet?.pet_id\n * result[0]?.favorite_pet?.name\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * select \"id\", (\n *   select json_object(\n *     'pet_id', \"obj\".\"pet_id\",\n *     'name', \"obj\".\"name\"\n *   ) from (\n *     select \"pet\".\"id\" as \"pet_id\", \"pet\".\"name\"\n *     from \"pet\"\n *     where \"pet\".\"owner_id\" = \"person\".\"id\"\n *     and \"pet\".\"is_favorite\" = ?\n *   ) as obj\n * ) as \"favorite_pet\"\n * from \"person\";\n * ```\n */\nexport function jsonObjectFrom(expr) {\n    return sql `(select json_object(${sql.join(getSqliteJsonObjectArgs(expr.toOperationNode(), 'obj'))}) from ${expr} as obj)`;\n}\n/**\n * The SQLite `json_object` function.\n *\n * NOTE: This helper only works correctly if you've installed the `ParseJSONResultsPlugin`.\n * Otherwise the nested selections will be returned as JSON strings.\n *\n * The plugin can be installed like this:\n *\n * ```ts\n * import * as Sqlite from 'better-sqlite3'\n * import { Kysely, ParseJSONResultsPlugin, SqliteDialect } from 'kysely'\n * import type { Database } from 'type-editor' // imaginary module\n *\n * const db = new Kysely<Database>({\n *   dialect: new SqliteDialect({\n *     database: new Sqlite(':memory:')\n *   }),\n *   plugins: [new ParseJSONResultsPlugin()]\n * })\n * ```\n *\n * ### Examples\n *\n * ```ts\n * import { sql } from 'kysely'\n * import { jsonBuildObject } from 'kysely/helpers/sqlite'\n *\n * const result = await db\n *   .selectFrom('person')\n *   .select((eb) => [\n *     'id',\n *     jsonBuildObject({\n *       first: eb.ref('first_name'),\n *       last: eb.ref('last_name'),\n *       full: sql<string>`first_name ||\u00A0' ' || last_name`\n *     }).as('name')\n *   ])\n *   .execute()\n *\n * result[0]?.id\n * result[0]?.name.first\n * result[0]?.name.last\n * result[0]?.name.full\n * ```\n *\n * The generated SQL (SQLite):\n *\n * ```sql\n * select \"id\", json_object(\n *   'first', first_name,\n *   'last', last_name,\n *   'full', \"first_name\" || ' ' || \"last_name\"\n * ) as \"name\"\n * from \"person\"\n * ```\n */\nexport function jsonBuildObject(obj) {\n    return sql `json_object(${sql.join(Object.keys(obj).flatMap((k) => [sql.lit(k), obj[k]]))})`;\n}\nfunction getSqliteJsonObjectArgs(node, table) {\n    try {\n        return getJsonObjectArgs(node, table);\n    }\n    catch {\n        throw new Error('SQLite jsonArrayFrom and jsonObjectFrom functions can only handle explicit selections due to limitations of the json_object function. selectAll() is not allowed in the subquery.');\n    }\n}\n", "/// <reference types=\"./json-object-args.d.ts\" />\nimport { ExpressionWrapper } from '../expression/expression-wrapper.js';\nimport { AliasNode } from '../operation-node/alias-node.js';\nimport { ColumnNode } from '../operation-node/column-node.js';\nimport { IdentifierNode } from '../operation-node/identifier-node.js';\nimport { ReferenceNode } from '../operation-node/reference-node.js';\nimport { TableNode } from '../operation-node/table-node.js';\nimport { ValueNode } from '../operation-node/value-node.js';\nexport function getJsonObjectArgs(node, table) {\n    const args = [];\n    for (const { selection: s } of node.selections ?? []) {\n        if (ReferenceNode.is(s) && ColumnNode.is(s.column)) {\n            args.push(colName(s.column.column.name), colRef(table, s.column.column.name));\n        }\n        else if (ColumnNode.is(s)) {\n            args.push(colName(s.column.name), colRef(table, s.column.name));\n        }\n        else if (AliasNode.is(s) && IdentifierNode.is(s.alias)) {\n            args.push(colName(s.alias.name), colRef(table, s.alias.name));\n        }\n        else {\n            throw new Error(`can't extract column names from the select query node`);\n        }\n    }\n    return args;\n}\nfunction colName(col) {\n    return new ExpressionWrapper(ValueNode.createImmediate(col));\n}\nfunction colRef(table, col) {\n    return new ExpressionWrapper(ReferenceNode.create(ColumnNode.create(col), TableNode.create(table)));\n}\n", "import { type Kysely, SqliteAdapter, SqliteQueryCompiler } from \"kysely\";\n\nimport { type BuilderRequirements, getBuilder } from \"../query\";\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function getSQLiteBuilder<Database = any>(\n  requirements?: Omit<BuilderRequirements, \"Adapter\" | \"QueryCompiler\">,\n): Kysely<Database> {\n  return getBuilder({ ...requirements, Adapter: SqliteAdapter, QueryCompiler: SqliteQueryCompiler });\n}\n"],
  "mappings": "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",
  "names": ["init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "getJsonObjectArgs", "node", "table", "args", "s", "ReferenceNode", "ColumnNode", "colName", "colRef", "AliasNode", "IdentifierNode", "col", "ExpressionWrapper", "ValueNode", "TableNode", "jsonArrayFrom", "expr", "sql", "getSqliteJsonObjectArgs", "getSqliteJsonObjectArgs", "node", "table", "getJsonObjectArgs", "init_define_ACCELERATE_SCHEMA_BY_PROVIDER", "getSQLiteBuilder", "requirements", "getBuilder", "SqliteAdapter", "SqliteQueryCompiler", "getTablesQuery", "requirements", "compile", "getSQLiteBuilder", "expressionBuilder", "jb", "eb", "jsonArrayFrom", "createSQLiteAdapter", "requirements", "executor", "_details", "_options", "options", "tablesQuery", "getTablesQuery", "tablesError", "_tables", "createAdapterError", "error"]
}

|