53 lines
1.8 KiB
JavaScript
53 lines
1.8 KiB
JavaScript
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
|