import * as ___react___ from 'react'; import * as ___react_dom___ from 'react-dom'; function require(mod) { if (mod === 'react') return ___react___; if (mod === 'react-dom') return ___react_dom___; throw new Error(`Unknown module ${mod}`); } function o(t){let{adapterSource:r,error:a,query:n}=t,e=a;return e.adapterSource=r,e.query=n,[e]}export{o as a}; //# 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 AdapterCapabilities {\n  /**\n   * Whether full-table content search is supported by this adapter.\n   */\n  fullTableSearch: boolean;\n\n  /**\n   * SQL dialect used by SQL editor highlighting/autocomplete.\n   */\n  sqlDialect: SqlEditorDialect;\n\n  /**\n   * Whether SQL editor schema-aware autocomplete is supported.\n   */\n  sqlEditorAutocomplete: boolean;\n\n  /**\n   * Whether SQL editor lint diagnostics are supported.\n   */\n  sqlEditorLint: 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   * Optional adapter feature flags used by the UI.\n   */\n  readonly capabilities?: Partial<AdapterCapabilities>;\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(\n    options: AdapterIntrospectOptions,\n  ): Promise<Either<AdapterError, AdapterIntrospectResult>>;\n\n  /**\n   * Executes a structured query against the database.\n   */\n  query(\n    details: AdapterQueryDetails,\n    options: AdapterQueryOptions,\n  ): Promise<Either<AdapterError, AdapterQueryResult>>;\n\n  /**\n   * Executes raw SQL against the database.\n   */\n  raw(\n    details: AdapterRawDetails,\n    options: AdapterRawOptions,\n  ): Promise<Either<AdapterError, AdapterRawResult>>;\n\n  /**\n   * Returns schema metadata for SQL editor autocomplete.\n   */\n  sqlSchema?(\n    details: AdapterSqlSchemaDetails,\n    options: AdapterSqlSchemaOptions,\n  ): Promise<Either<AdapterError, AdapterSqlSchemaResult>>;\n\n  /**\n   * Returns SQL editor diagnostics (syntax/schema linting).\n   */\n  sqlLint?(\n    details: AdapterSqlLintDetails,\n    options: AdapterSqlLintOptions,\n  ): Promise<Either<AdapterError, AdapterSqlLintResult>>;\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   * Updates multiple rows in the database inside one adapter-level transaction\n   * when supported by the executor.\n   */\n  updateMany?(\n    details: AdapterUpdateManyDetails,\n    options: AdapterUpdateOptions,\n  ): Promise<Either<AdapterError, AdapterUpdateManyResult>>;\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\nexport interface AdapterRawOptions extends AdapterBaseOptions {\n  abortSignal: AbortSignal;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterSqlSchemaOptions extends AdapterBaseOptions {}\n\nexport interface AdapterSqlLintOptions 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  defaultValue:\n    | \"CURRENT_DATE\"\n    | \"CURRENT_TIME\"\n    | \"CURRENT_TIMESTAMP\"\n    | \"datetime('now')\" // sqlite\n    | \"gen_random_uuid()\" // postgres uuid\n    | \"json_array()\" // mysql empty json array\n    | `nextval(${string})` // postgres serial/autoinc\n    | `now()`\n    | \"uuid_to_bin(uuid())\" // mysql binary uuid\n    | \"uuid()\" // mysql uuid\n    | (string & {})\n    | null;\n  fkColumn: ColumnName | null;\n  fkSchema: SchemaName | null;\n  fkTable: TableName | null;\n  isAutoincrement: boolean;\n  isComputed: boolean;\n  isRequired: boolean;\n  name: ColumnName;\n  nullable: boolean;\n  pkPosition: number | null;\n  schema: SchemaName;\n  table: TableName;\n}\n\nexport interface DataType {\n  /**\n   * The database-specific affinity/type.\n   *\n   * e.g. in SQLite, datatypes can be anything. They are reduced to affinity via string matching rules.\n   *\n   * {@link https://sqlite.org/datatype3.html#determination_of_column_affinity}\n   */\n  affinity?: string;\n\n  /**\n   * The database-specific format for the datatype.\n   */\n  format?: string;\n\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 =\n  | \"string\"\n  | \"datetime\"\n  | \"boolean\"\n  | \"enum\"\n  | \"time\"\n  | \"raw\"\n  | \"numeric\"\n  | \"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  /**\n   * Optional full-table content search term.\n   *\n   * This is interpreted by database-specific adapters and composed into the\n   * generated SQL query.\n   */\n  fullTableSearchTerm?: string;\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 SqlFilter {\n  kind: \"SqlFilter\";\n  sql: string;\n  after: \"and\" | \"or\";\n  id: string;\n}\n\nexport interface FilterGroup {\n  kind: \"FilterGroup\";\n  filters: (ColumnFilter | FilterGroup | SqlFilter)[];\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  adapterSource?: string;\n  query?: Query<unknown>;\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 AdapterRawDetails {\n  sql: string;\n}\n\nexport interface AdapterRawResult {\n  rowCount: number;\n  rows: Record<string, unknown>[];\n  query: Query;\n}\n\n// eslint-disable-next-line @typescript-eslint/no-empty-object-type\nexport interface AdapterSqlSchemaDetails {}\n\nexport interface AdapterSqlSchemaResult {\n  defaultSchema?: string;\n  dialect: SqlEditorDialect;\n  namespace: Record<string, Record<string, string[]>>;\n  version: string;\n}\n\nexport interface AdapterSqlLintDetails {\n  schemaVersion?: string;\n  sql: string;\n}\n\nexport interface AdapterSqlLintDiagnostic {\n  code?: string;\n  from: number;\n  message: string;\n  severity: \"error\" | \"warning\" | \"info\" | \"hint\";\n  source?: string;\n  to: number;\n}\n\nexport interface AdapterSqlLintResult {\n  diagnostics: AdapterSqlLintDiagnostic[];\n  schemaVersion?: string;\n}\n\nexport type SqlEditorDialect = \"postgresql\" | \"mysql\" | \"sqlite\";\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<unknown>;\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 AdapterUpdateManyDetails {\n  /**\n   * The updates to apply to existing rows.\n   */\n  updates: AdapterUpdateDetails[];\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  // TODO: turn this into a list.\n  /**\n   * The executed query string.\n   */\n  query: Query<unknown>;\n}\n\nexport interface AdapterUpdateManyResult {\n  /**\n   * The updated row data in the same order as the requested updates.\n   */\n  rows: AdapterUpdateResult[\"row\"][];\n\n  /**\n   * The executed queries that were run inside the transaction.\n   */\n  queries: Query<unknown>[];\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<unknown>;\n}\n\nexport function createAdapterError(args: {\n  adapterSource?: string;\n  error: Error;\n  query?: Query<unknown>;\n}) {\n  const { adapterSource, error, query } = args;\n\n  const adapterError = error as AdapterError;\n\n  adapterError.adapterSource = adapterSource;\n  adapterError.query = query;\n\n  return [adapterError] as [AdapterError];\n}\n"],
  "mappings": ";;;;;;;;AAsgBO,SAASA,EAAmBC,EAIhC,CACD,GAAM,CAAE,cAAAC,EAAe,MAAAC,EAAO,MAAAC,CAAM,EAAIH,EAElCI,EAAeF,EAErB,OAAAE,EAAa,cAAgBH,EAC7BG,EAAa,MAAQD,EAEd,CAACC,CAAY,CACtB",
  "names": ["createAdapterError", "args", "adapterSource", "error", "query", "adapterError"]
}
