| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- import { entityKind } from "../entity.js";
- import { Table } from "../table.js";
- import { getMySqlColumnBuilders } from "./columns/all.js";
- const InlineForeignKeys = Symbol.for("drizzle:MySqlInlineForeignKeys");
- class MySqlTable extends Table {
- static [entityKind] = "MySqlTable";
- /** @internal */
- static Symbol = Object.assign({}, Table.Symbol, {
- InlineForeignKeys
- });
- /** @internal */
- [Table.Symbol.Columns];
- /** @internal */
- [InlineForeignKeys] = [];
- /** @internal */
- [Table.Symbol.ExtraConfigBuilder] = void 0;
- }
- function mysqlTableWithSchema(name, columns, extraConfig, schema, baseName = name) {
- const rawTable = new MySqlTable(name, schema, baseName);
- const parsedColumns = typeof columns === "function" ? columns(getMySqlColumnBuilders()) : columns;
- const builtColumns = Object.fromEntries(
- Object.entries(parsedColumns).map(([name2, colBuilderBase]) => {
- const colBuilder = colBuilderBase;
- colBuilder.setName(name2);
- const column = colBuilder.build(rawTable);
- rawTable[InlineForeignKeys].push(...colBuilder.buildForeignKeys(column, rawTable));
- return [name2, column];
- })
- );
- const table = Object.assign(rawTable, builtColumns);
- table[Table.Symbol.Columns] = builtColumns;
- table[Table.Symbol.ExtraConfigColumns] = builtColumns;
- if (extraConfig) {
- table[MySqlTable.Symbol.ExtraConfigBuilder] = extraConfig;
- }
- return table;
- }
- const mysqlTable = (name, columns, extraConfig) => {
- return mysqlTableWithSchema(name, columns, extraConfig, void 0, name);
- };
- function mysqlTableCreator(customizeTableName) {
- return (name, columns, extraConfig) => {
- return mysqlTableWithSchema(customizeTableName(name), columns, extraConfig, void 0, name);
- };
- }
- export {
- InlineForeignKeys,
- MySqlTable,
- mysqlTable,
- mysqlTableCreator,
- mysqlTableWithSchema
- };
- //# sourceMappingURL=table.js.map
|