import type { BuildColumns } from "../column-builder.js"; import { entityKind } from "../entity.js"; import { Table, type TableConfig as TableConfigBase, type UpdateTableConfig } from "../table.js"; import type { CheckBuilder } from "./checks.js"; import { type SQLiteColumnBuilders } from "./columns/all.js"; import type { SQLiteColumn, SQLiteColumnBuilderBase } from "./columns/common.js"; import type { ForeignKeyBuilder } from "./foreign-keys.js"; import type { IndexBuilder } from "./indexes.js"; import type { PrimaryKeyBuilder } from "./primary-keys.js"; import type { UniqueConstraintBuilder } from "./unique-constraint.js"; export type SQLiteTableExtraConfigValue = IndexBuilder | CheckBuilder | ForeignKeyBuilder | PrimaryKeyBuilder | UniqueConstraintBuilder; export type SQLiteTableExtraConfig = Record; export type TableConfig = TableConfigBase>; export declare class SQLiteTable extends Table { static readonly [entityKind]: string; } export type AnySQLiteTable = {}> = SQLiteTable>; export type SQLiteTableWithColumns = SQLiteTable & { [Key in keyof T['columns']]: T['columns'][Key]; }; export interface SQLiteTableFn { /** * @deprecated The third parameter of sqliteTable is changing and will only accept an array instead of an object * * @example * Deprecated version: * ```ts * export const users = sqliteTable("users", { * id: int(), * }, (t) => ({ * idx: index('custom_name').on(t.id) * })); * ``` * * New API: * ```ts * export const users = sqliteTable("users", { * id: int(), * }, (t) => [ * index('custom_name').on(t.id) * ]); * ``` */ >(name: TTableName, columns: TColumnsMap, extraConfig?: (self: BuildColumns) => SQLiteTableExtraConfig): SQLiteTableWithColumns<{ name: TTableName; schema: TSchema; columns: BuildColumns; dialect: 'sqlite'; }>; /** * @deprecated The third parameter of sqliteTable is changing and will only accept an array instead of an object * * @example * Deprecated version: * ```ts * export const users = sqliteTable("users", { * id: int(), * }, (t) => ({ * idx: index('custom_name').on(t.id) * })); * ``` * * New API: * ```ts * export const users = sqliteTable("users", { * id: int(), * }, (t) => [ * index('custom_name').on(t.id) * ]); * ``` */ >(name: TTableName, columns: (columnTypes: SQLiteColumnBuilders) => TColumnsMap, extraConfig?: (self: BuildColumns) => SQLiteTableExtraConfig): SQLiteTableWithColumns<{ name: TTableName; schema: TSchema; columns: BuildColumns; dialect: 'sqlite'; }>; >(name: TTableName, columns: TColumnsMap, extraConfig?: (self: BuildColumns) => SQLiteTableExtraConfigValue[]): SQLiteTableWithColumns<{ name: TTableName; schema: TSchema; columns: BuildColumns; dialect: 'sqlite'; }>; >(name: TTableName, columns: (columnTypes: SQLiteColumnBuilders) => TColumnsMap, extraConfig?: (self: BuildColumns) => SQLiteTableExtraConfigValue[]): SQLiteTableWithColumns<{ name: TTableName; schema: TSchema; columns: BuildColumns; dialect: 'sqlite'; }>; } export declare const sqliteTable: SQLiteTableFn; export declare function sqliteTableCreator(customizeTableName: (name: string) => string): SQLiteTableFn;