Spaces:
Sleeping
Sleeping
| ; | |
| var __defProp = Object.defineProperty; | |
| var __getOwnPropDesc = Object.getOwnPropertyDescriptor; | |
| var __getOwnPropNames = Object.getOwnPropertyNames; | |
| var __hasOwnProp = Object.prototype.hasOwnProperty; | |
| var __export = (target, all) => { | |
| for (var name in all) | |
| __defProp(target, name, { get: all[name], enumerable: true }); | |
| }; | |
| var __copyProps = (to, from, except, desc) => { | |
| if (from && typeof from === "object" || typeof from === "function") { | |
| for (let key of __getOwnPropNames(from)) | |
| if (!__hasOwnProp.call(to, key) && key !== except) | |
| __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); | |
| } | |
| return to; | |
| }; | |
| var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); | |
| var indexes_exports = {}; | |
| __export(indexes_exports, { | |
| Index: () => Index, | |
| IndexBuilder: () => IndexBuilder, | |
| IndexBuilderOn: () => IndexBuilderOn, | |
| index: () => index, | |
| uniqueIndex: () => uniqueIndex | |
| }); | |
| module.exports = __toCommonJS(indexes_exports); | |
| var import_sql = require("../sql/sql.cjs"); | |
| var import_entity = require("../entity.cjs"); | |
| var import_columns = require("./columns/index.cjs"); | |
| class IndexBuilderOn { | |
| constructor(unique, name) { | |
| this.unique = unique; | |
| this.name = name; | |
| } | |
| static [import_entity.entityKind] = "PgIndexBuilderOn"; | |
| on(...columns) { | |
| return new IndexBuilder( | |
| columns.map((it) => { | |
| if ((0, import_entity.is)(it, import_sql.SQL)) { | |
| return it; | |
| } | |
| it = it; | |
| const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig); | |
| it.indexConfig = JSON.parse(JSON.stringify(it.defaultConfig)); | |
| return clonedIndexedColumn; | |
| }), | |
| this.unique, | |
| false, | |
| this.name | |
| ); | |
| } | |
| onOnly(...columns) { | |
| return new IndexBuilder( | |
| columns.map((it) => { | |
| if ((0, import_entity.is)(it, import_sql.SQL)) { | |
| return it; | |
| } | |
| it = it; | |
| const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig); | |
| it.indexConfig = it.defaultConfig; | |
| return clonedIndexedColumn; | |
| }), | |
| this.unique, | |
| true, | |
| this.name | |
| ); | |
| } | |
| /** | |
| * Specify what index method to use. Choices are `btree`, `hash`, `gist`, `spgist`, `gin`, `brin`, or user-installed access methods like `bloom`. The default method is `btree. | |
| * | |
| * If you have the `pg_vector` extension installed in your database, you can use the `hnsw` and `ivfflat` options, which are predefined types. | |
| * | |
| * **You can always specify any string you want in the method, in case Drizzle doesn't have it natively in its types** | |
| * | |
| * @param method The name of the index method to be used | |
| * @param columns | |
| * @returns | |
| */ | |
| using(method, ...columns) { | |
| return new IndexBuilder( | |
| columns.map((it) => { | |
| if ((0, import_entity.is)(it, import_sql.SQL)) { | |
| return it; | |
| } | |
| it = it; | |
| const clonedIndexedColumn = new import_columns.IndexedColumn(it.name, !!it.keyAsName, it.columnType, it.indexConfig); | |
| it.indexConfig = JSON.parse(JSON.stringify(it.defaultConfig)); | |
| return clonedIndexedColumn; | |
| }), | |
| this.unique, | |
| true, | |
| this.name, | |
| method | |
| ); | |
| } | |
| } | |
| class IndexBuilder { | |
| static [import_entity.entityKind] = "PgIndexBuilder"; | |
| /** @internal */ | |
| config; | |
| constructor(columns, unique, only, name, method = "btree") { | |
| this.config = { | |
| name, | |
| columns, | |
| unique, | |
| only, | |
| method | |
| }; | |
| } | |
| concurrently() { | |
| this.config.concurrently = true; | |
| return this; | |
| } | |
| with(obj) { | |
| this.config.with = obj; | |
| return this; | |
| } | |
| where(condition) { | |
| this.config.where = condition; | |
| return this; | |
| } | |
| /** @internal */ | |
| build(table) { | |
| return new Index(this.config, table); | |
| } | |
| } | |
| class Index { | |
| static [import_entity.entityKind] = "PgIndex"; | |
| config; | |
| constructor(config, table) { | |
| this.config = { ...config, table }; | |
| } | |
| } | |
| function index(name) { | |
| return new IndexBuilderOn(false, name); | |
| } | |
| function uniqueIndex(name) { | |
| return new IndexBuilderOn(true, name); | |
| } | |
| // Annotate the CommonJS export names for ESM import in node: | |
| 0 && (module.exports = { | |
| Index, | |
| IndexBuilder, | |
| IndexBuilderOn, | |
| index, | |
| uniqueIndex | |
| }); | |
| //# sourceMappingURL=indexes.cjs.map |