@payloadcms/db-postgres 0.4.0 → 0.5.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -1 +1 @@
1
- {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAgB1C,OAAO,KAAK,EAAE,cAAc,EAAgB,eAAe,EAAE,MAAM,UAAU,CAAA;AAM7E,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC7C,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,GAAG,uBAAuB,CAAC,CAAA;IAClG,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;IACnC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,UAAU,8PAgBpB,IAAI,KAAG,MA+TT,CAAA"}
1
+ {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/schema/build.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AAgB1C,OAAO,KAAK,EAAE,cAAc,EAAgB,eAAe,EAAE,MAAM,UAAU,CAAA;AAM7E,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC7C,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,GAAG,uBAAuB,CAAC,CAAA;IAClG,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,EAAE,OAAO,CAAA;IACtB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,iBAAiB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC/B,kBAAkB,CAAC,EAAE,MAAM,CAAA;IAC3B,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,SAAS,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;IACnC,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,UAAU,8PAgBpB,IAAI,KAAG,MAkUT,CAAA"}
@@ -20,7 +20,7 @@ function _interop_require_default(obj) {
20
20
  default: obj
21
21
  };
22
22
  }
23
- const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildTexts, buildNumbers, buildRelationships, disableNotNull, disableUnique = false, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps })=>{
23
+ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildNumbers, buildRelationships, buildTexts, disableNotNull, disableUnique = false, fields, rootRelationsToBuild, rootRelationships, rootTableIDColType, rootTableName: incomingRootTableName, tableName, timestamps })=>{
24
24
  const rootTableName = incomingRootTableName || tableName;
25
25
  const columns = baseColumns;
26
26
  const indexes = {};
@@ -47,11 +47,11 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildText
47
47
  varchar: _pgcore.varchar
48
48
  };
49
49
  columns.id = idColTypeMap[idColType]('id').primaryKey();
50
- ({ hasLocalizedField, hasLocalizedManyTextField, hasLocalizedManyNumberField, hasLocalizedRelationshipField, hasManyTextField, hasManyNumberField } = (0, _traverseFields.traverseFields)({
50
+ ({ hasLocalizedField, hasLocalizedManyNumberField, hasLocalizedManyTextField, hasLocalizedRelationshipField, hasManyNumberField, hasManyTextField } = (0, _traverseFields.traverseFields)({
51
51
  adapter,
52
- buildTexts,
53
52
  buildNumbers,
54
53
  buildRelationships,
54
+ buildTexts,
55
55
  columns,
56
56
  disableNotNull,
57
57
  disableUnique,
@@ -122,25 +122,25 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildText
122
122
  const textsTableName = `${rootTableName}_texts`;
123
123
  const columns = {
124
124
  id: (0, _pgcore.serial)('id').primaryKey(),
125
- text: (0, _pgcore.varchar)('text'),
126
125
  order: (0, _pgcore.integer)('order').notNull(),
127
126
  parent: _parentIDColumnMap.parentIDColumnMap[idColType]('parent_id').references(()=>table.id, {
128
127
  onDelete: 'cascade'
129
128
  }).notNull(),
130
- path: (0, _pgcore.varchar)('path').notNull()
129
+ path: (0, _pgcore.varchar)('path').notNull(),
130
+ text: (0, _pgcore.varchar)('text')
131
131
  };
132
132
  if (hasLocalizedManyTextField) {
133
133
  columns.locale = adapter.enums.enum__locales('locale');
134
134
  }
135
135
  textsTable = (0, _pgcore.pgTable)(textsTableName, columns, (cols)=>{
136
136
  const indexes = {
137
- orderParentIdx: (0, _pgcore.index)('order_parent_idx').on(cols.order, cols.parent)
137
+ orderParentIdx: (0, _pgcore.index)(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent)
138
138
  };
139
139
  if (hasManyTextField === 'index') {
140
- indexes.text_idx = (0, _pgcore.index)('text_idx').on(cols.text);
140
+ indexes.text_idx = (0, _pgcore.index)(`${textsTableName}_text_idx`).on(cols.text);
141
141
  }
142
142
  if (hasLocalizedManyTextField) {
143
- indexes.localeParent = (0, _pgcore.index)('locale_parent').on(cols.locale, cols.parent);
143
+ indexes.localeParent = (0, _pgcore.index)(`${textsTableName}_locale_parent`).on(cols.locale, cols.parent);
144
144
  }
145
145
  return indexes;
146
146
  });
@@ -173,13 +173,13 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildText
173
173
  }
174
174
  numbersTable = (0, _pgcore.pgTable)(numbersTableName, columns, (cols)=>{
175
175
  const indexes = {
176
- orderParentIdx: (0, _pgcore.index)('order_parent_idx').on(cols.order, cols.parent)
176
+ orderParentIdx: (0, _pgcore.index)(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent)
177
177
  };
178
178
  if (hasManyNumberField === 'index') {
179
- indexes.numberIdx = (0, _pgcore.index)('number_idx').on(cols.number);
179
+ indexes.numberIdx = (0, _pgcore.index)(`${numbersTableName}_number_idx`).on(cols.number);
180
180
  }
181
181
  if (hasLocalizedManyNumberField) {
182
- indexes.localeParent = (0, _pgcore.index)('locale_parent').on(cols.locale, cols.parent);
182
+ indexes.localeParent = (0, _pgcore.index)(`${numbersTableName}_locale_parent`).on(cols.locale, cols.parent);
183
183
  }
184
184
  return indexes;
185
185
  });
@@ -222,12 +222,12 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildText
222
222
  const relationshipsTableName = `${tableName}_rels`;
223
223
  relationshipsTable = (0, _pgcore.pgTable)(relationshipsTableName, relationshipColumns, (cols)=>{
224
224
  const result = {
225
- order: (0, _pgcore.index)('order_idx').on(cols.order),
226
- parentIdx: (0, _pgcore.index)('parent_idx').on(cols.parent),
227
- pathIdx: (0, _pgcore.index)('path_idx').on(cols.path)
225
+ order: (0, _pgcore.index)(`${relationshipsTableName}_order_idx`).on(cols.order),
226
+ parentIdx: (0, _pgcore.index)(`${relationshipsTableName}_parent_idx`).on(cols.parent),
227
+ pathIdx: (0, _pgcore.index)(`${relationshipsTableName}_path_idx`).on(cols.path)
228
228
  };
229
229
  if (hasLocalizedRelationshipField) {
230
- result.localeIdx = (0, _pgcore.index)('locale_idx').on(cols.locale);
230
+ result.localeIdx = (0, _pgcore.index)(`${relationshipsTableName}_locale_idx`).on(cols.locale);
231
231
  }
232
232
  return result;
233
233
  });
@@ -284,10 +284,10 @@ const buildTable = ({ adapter, baseColumns = {}, baseExtraConfig = {}, buildText
284
284
  });
285
285
  adapter.relations[`relations_${tableName}`] = tableRelations;
286
286
  return {
287
- hasManyTextField,
288
287
  hasManyNumberField,
288
+ hasManyTextField,
289
289
  relationsToBuild
290
290
  };
291
291
  };
292
292
 
293
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  index,\n  integer,\n  numeric,\n  pgTable,\n  serial,\n  timestamp,\n  unique,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, PostgresAdapter } from '../types'\n\nimport { getConfigIDType } from './getConfigIDType'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: Record<string, (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder>\n  buildTexts?: boolean\n  buildNumbers?: boolean\n  buildRelationships?: boolean\n  disableNotNull: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootRelationships?: Set<string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n}\n\ntype Result = {\n  hasManyTextField: 'index' | boolean\n  hasManyNumberField: 'index' | boolean\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildTexts,\n  buildNumbers,\n  buildRelationships,\n  disableNotNull,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootRelationships,\n  rootTableIDColType,\n  rootTableName: incomingRootTableName,\n  tableName,\n  timestamps,\n}: Args): Result => {\n  const rootTableName = incomingRootTableName || tableName\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyTextField: 'index' | boolean = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyTextField = false\n  let hasLocalizedManyNumberField = false\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable\n  let textsTable: GenericTable\n  let numbersTable: GenericTable\n\n  // Relationships to the base collection\n  const relationships: Set<string> = rootRelationships || new Set()\n\n  let relationshipsTable: GenericTable\n\n  // Drizzle relations\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idColType = getConfigIDType(fields)\n\n  const idColTypeMap = {\n    integer: serial,\n    numeric,\n    varchar,\n  }\n\n  columns.id = idColTypeMap[idColType]('id').primaryKey()\n  ;({\n    hasLocalizedField,\n    hasLocalizedManyTextField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyTextField,\n    hasManyNumberField,\n  } = traverseFields({\n    adapter,\n    buildTexts,\n    buildNumbers,\n    buildRelationships,\n    columns,\n    disableNotNull,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName,\n  }))\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = pgTable(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    return Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}_locales`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id')\n      .references(() => table.id, { onDelete: 'cascade' })\n      .notNull()\n\n    localesTable = pgTable(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n            cols._locale,\n            cols._parentID,\n          ),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyTextField && buildTexts) {\n    const textsTableName = `${rootTableName}_texts`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      text: varchar('text'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyTextField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    textsTable = pgTable(textsTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index('order_parent_idx').on(cols.order, cols.parent),\n      }\n\n      if (hasManyTextField === 'index') {\n        indexes.text_idx = index('text_idx').on(cols.text)\n      }\n\n      if (hasLocalizedManyTextField) {\n        indexes.localeParent = index('locale_parent').on(cols.locale, cols.parent)\n      }\n\n      return indexes\n    })\n\n    adapter.tables[textsTableName] = textsTable\n\n    const textsTableRelations = relations(textsTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [textsTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${textsTableName}`] = textsTableRelations\n  }\n\n  if (hasManyNumberField && buildNumbers) {\n    const numbersTableName = `${rootTableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = pgTable(numbersTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index('order_parent_idx').on(cols.order, cols.parent),\n      }\n\n      if (hasManyNumberField === 'index') {\n        indexes.numberIdx = index('number_idx').on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        indexes.localeParent = index('locale_parent').on(cols.locale, cols.parent)\n      }\n\n      return indexes\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id')\n          .references(() => table.id, { onDelete: 'cascade' })\n          .notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      relationships.forEach((relationTo) => {\n        const formattedRelationTo = toSnakeCase(relationTo)\n        let colType = 'integer'\n        const relatedCollectionCustomID = adapter.payload.collections[\n          relationTo\n        ].config.fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n        if (relatedCollectionCustomID?.type === 'number') colType = 'numeric'\n        if (relatedCollectionCustomID?.type === 'text') colType = 'varchar'\n\n        relationshipColumns[`${relationTo}ID`] = parentIDColumnMap[colType](\n          `${formattedRelationTo}_id`,\n        ).references(() => adapter.tables[formattedRelationTo].id, { onDelete: 'cascade' })\n      })\n\n      const relationshipsTableName = `${tableName}_rels`\n\n      relationshipsTable = pgTable(relationshipsTableName, relationshipColumns, (cols) => {\n        const result: Record<string, unknown> = {\n          order: index('order_idx').on(cols.order),\n          parentIdx: index('parent_idx').on(cols.parent),\n          pathIdx: index('path_idx').on(cols.path),\n        }\n\n        if (hasLocalizedRelationshipField) {\n          result.localeIdx = index('locale_idx').on(cols.locale)\n        }\n\n        return result\n      })\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_rels',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = toSnakeCase(relationTo)\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyTextField) {\n      result._texts = many(textsTable)\n    }\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._rels = many(relationshipsTable, {\n        relationName: '_rels',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return { hasManyTextField, hasManyNumberField, relationsToBuild }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildTexts","buildNumbers","buildRelationships","disableNotNull","disableUnique","fields","rootRelationsToBuild","rootRelationships","rootTableIDColType","rootTableName","incomingRootTableName","tableName","timestamps","columns","indexes","hasLocalizedField","hasLocalizedRelationshipField","hasManyTextField","hasManyNumberField","hasLocalizedManyTextField","hasLocalizedManyNumberField","localesColumns","localesIndexes","localesTable","textsTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idColType","getConfigIDType","idColTypeMap","integer","serial","numeric","varchar","id","primaryKey","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgTable","cols","extraConfig","Object","entries","reduce","config","key","func","acc","colName","tables","localeTableName","_locale","enums","enum__locales","_parentID","parentIDColumnMap","references","onDelete","_localeParent","unique","on","localesTableRelations","relations","one","textsTableName","text","order","parent","path","locale","orderParentIdx","index","text_idx","localeParent","textsTableRelations","numbersTableName","number","numberIdx","numbersTableRelations","size","relationshipColumns","forEach","relationTo","formattedRelationTo","toSnakeCase","colType","relatedCollectionCustomID","payload","collections","find","field","fieldAffectsData","name","type","relationshipsTableName","result","parentIdx","pathIdx","localeIdx","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_texts","_numbers","_rels"],"mappings":"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"}
293
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/build.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { Relation } from 'drizzle-orm'\nimport type { IndexBuilder, PgColumnBuilder, UniqueConstraintBuilder } from 'drizzle-orm/pg-core'\nimport type { Field } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  index,\n  integer,\n  numeric,\n  pgTable,\n  serial,\n  timestamp,\n  unique,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { fieldAffectsData } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, GenericTable, PostgresAdapter } from '../types'\n\nimport { getConfigIDType } from './getConfigIDType'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { traverseFields } from './traverseFields'\n\ntype Args = {\n  adapter: PostgresAdapter\n  baseColumns?: Record<string, PgColumnBuilder>\n  baseExtraConfig?: Record<string, (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder>\n  buildNumbers?: boolean\n  buildRelationships?: boolean\n  buildTexts?: boolean\n  disableNotNull: boolean\n  disableUnique: boolean\n  fields: Field[]\n  rootRelationsToBuild?: Map<string, string>\n  rootRelationships?: Set<string>\n  rootTableIDColType?: string\n  rootTableName?: string\n  tableName: string\n  timestamps?: boolean\n}\n\ntype Result = {\n  hasManyNumberField: 'index' | boolean\n  hasManyTextField: 'index' | boolean\n  relationsToBuild: Map<string, string>\n}\n\nexport const buildTable = ({\n  adapter,\n  baseColumns = {},\n  baseExtraConfig = {},\n  buildNumbers,\n  buildRelationships,\n  buildTexts,\n  disableNotNull,\n  disableUnique = false,\n  fields,\n  rootRelationsToBuild,\n  rootRelationships,\n  rootTableIDColType,\n  rootTableName: incomingRootTableName,\n  tableName,\n  timestamps,\n}: Args): Result => {\n  const rootTableName = incomingRootTableName || tableName\n  const columns: Record<string, PgColumnBuilder> = baseColumns\n  const indexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyTextField: 'index' | boolean = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyTextField = false\n  let hasLocalizedManyNumberField = false\n\n  const localesColumns: Record<string, PgColumnBuilder> = {}\n  const localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder> = {}\n  let localesTable: GenericTable\n  let textsTable: GenericTable\n  let numbersTable: GenericTable\n\n  // Relationships to the base collection\n  const relationships: Set<string> = rootRelationships || new Set()\n\n  let relationshipsTable: GenericTable\n\n  // Drizzle relations\n  const relationsToBuild: Map<string, string> = new Map()\n\n  const idColType = getConfigIDType(fields)\n\n  const idColTypeMap = {\n    integer: serial,\n    numeric,\n    varchar,\n  }\n\n  columns.id = idColTypeMap[idColType]('id').primaryKey()\n  ;({\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedManyTextField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n    hasManyTextField,\n  } = traverseFields({\n    adapter,\n    buildNumbers,\n    buildRelationships,\n    buildTexts,\n    columns,\n    disableNotNull,\n    disableUnique,\n    fields,\n    indexes,\n    localesColumns,\n    localesIndexes,\n    newTableName: tableName,\n    parentTableName: tableName,\n    relationsToBuild,\n    relationships,\n    rootRelationsToBuild: rootRelationsToBuild || relationsToBuild,\n    rootTableIDColType: rootTableIDColType || idColType,\n    rootTableName,\n  }))\n\n  if (timestamps) {\n    columns.createdAt = timestamp('created_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n    columns.updatedAt = timestamp('updated_at', {\n      mode: 'string',\n      precision: 3,\n      withTimezone: true,\n    })\n      .defaultNow()\n      .notNull()\n  }\n\n  const table = pgTable(tableName, columns, (cols) => {\n    const extraConfig = Object.entries(baseExtraConfig).reduce((config, [key, func]) => {\n      config[key] = func(cols)\n      return config\n    }, {})\n\n    return Object.entries(indexes).reduce((acc, [colName, func]) => {\n      acc[colName] = func(cols)\n      return acc\n    }, extraConfig)\n  })\n\n  adapter.tables[tableName] = table\n\n  if (hasLocalizedField) {\n    const localeTableName = `${tableName}_locales`\n    localesColumns.id = serial('id').primaryKey()\n    localesColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n    localesColumns._parentID = parentIDColumnMap[idColType]('_parent_id')\n      .references(() => table.id, { onDelete: 'cascade' })\n      .notNull()\n\n    localesTable = pgTable(localeTableName, localesColumns, (cols) => {\n      return Object.entries(localesIndexes).reduce(\n        (acc, [colName, func]) => {\n          acc[colName] = func(cols)\n          return acc\n        },\n        {\n          _localeParent: unique(`${localeTableName}_locale_parent_id_unique`).on(\n            cols._locale,\n            cols._parentID,\n          ),\n        },\n      )\n    })\n\n    adapter.tables[localeTableName] = localesTable\n\n    const localesTableRelations = relations(localesTable, ({ one }) => ({\n      _parentID: one(table, {\n        fields: [localesTable._parentID],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${localeTableName}`] = localesTableRelations\n  }\n\n  if (hasManyTextField && buildTexts) {\n    const textsTableName = `${rootTableName}_texts`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n      text: varchar('text'),\n    }\n\n    if (hasLocalizedManyTextField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    textsTable = pgTable(textsTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index(`${textsTableName}_order_parent_idx`).on(cols.order, cols.parent),\n      }\n\n      if (hasManyTextField === 'index') {\n        indexes.text_idx = index(`${textsTableName}_text_idx`).on(cols.text)\n      }\n\n      if (hasLocalizedManyTextField) {\n        indexes.localeParent = index(`${textsTableName}_locale_parent`).on(cols.locale, cols.parent)\n      }\n\n      return indexes\n    })\n\n    adapter.tables[textsTableName] = textsTable\n\n    const textsTableRelations = relations(textsTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [textsTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${textsTableName}`] = textsTableRelations\n  }\n\n  if (hasManyNumberField && buildNumbers) {\n    const numbersTableName = `${rootTableName}_numbers`\n    const columns: Record<string, PgColumnBuilder> = {\n      id: serial('id').primaryKey(),\n      number: numeric('number'),\n      order: integer('order').notNull(),\n      parent: parentIDColumnMap[idColType]('parent_id')\n        .references(() => table.id, { onDelete: 'cascade' })\n        .notNull(),\n      path: varchar('path').notNull(),\n    }\n\n    if (hasLocalizedManyNumberField) {\n      columns.locale = adapter.enums.enum__locales('locale')\n    }\n\n    numbersTable = pgTable(numbersTableName, columns, (cols) => {\n      const indexes: Record<string, IndexBuilder> = {\n        orderParentIdx: index(`${numbersTableName}_order_parent_idx`).on(cols.order, cols.parent),\n      }\n\n      if (hasManyNumberField === 'index') {\n        indexes.numberIdx = index(`${numbersTableName}_number_idx`).on(cols.number)\n      }\n\n      if (hasLocalizedManyNumberField) {\n        indexes.localeParent = index(`${numbersTableName}_locale_parent`).on(\n          cols.locale,\n          cols.parent,\n        )\n      }\n\n      return indexes\n    })\n\n    adapter.tables[numbersTableName] = numbersTable\n\n    const numbersTableRelations = relations(numbersTable, ({ one }) => ({\n      parent: one(table, {\n        fields: [numbersTable.parent],\n        references: [table.id],\n      }),\n    }))\n\n    adapter.relations[`relations_${numbersTableName}`] = numbersTableRelations\n  }\n\n  if (buildRelationships) {\n    if (relationships.size) {\n      const relationshipColumns: Record<string, PgColumnBuilder> = {\n        id: serial('id').primaryKey(),\n        order: integer('order'),\n        parent: parentIDColumnMap[idColType]('parent_id')\n          .references(() => table.id, { onDelete: 'cascade' })\n          .notNull(),\n        path: varchar('path').notNull(),\n      }\n\n      if (hasLocalizedRelationshipField) {\n        relationshipColumns.locale = adapter.enums.enum__locales('locale')\n      }\n\n      relationships.forEach((relationTo) => {\n        const formattedRelationTo = toSnakeCase(relationTo)\n        let colType = 'integer'\n        const relatedCollectionCustomID = adapter.payload.collections[\n          relationTo\n        ].config.fields.find((field) => fieldAffectsData(field) && field.name === 'id')\n        if (relatedCollectionCustomID?.type === 'number') colType = 'numeric'\n        if (relatedCollectionCustomID?.type === 'text') colType = 'varchar'\n\n        relationshipColumns[`${relationTo}ID`] = parentIDColumnMap[colType](\n          `${formattedRelationTo}_id`,\n        ).references(() => adapter.tables[formattedRelationTo].id, { onDelete: 'cascade' })\n      })\n\n      const relationshipsTableName = `${tableName}_rels`\n\n      relationshipsTable = pgTable(relationshipsTableName, relationshipColumns, (cols) => {\n        const result: Record<string, unknown> = {\n          order: index(`${relationshipsTableName}_order_idx`).on(cols.order),\n          parentIdx: index(`${relationshipsTableName}_parent_idx`).on(cols.parent),\n          pathIdx: index(`${relationshipsTableName}_path_idx`).on(cols.path),\n        }\n\n        if (hasLocalizedRelationshipField) {\n          result.localeIdx = index(`${relationshipsTableName}_locale_idx`).on(cols.locale)\n        }\n\n        return result\n      })\n\n      adapter.tables[relationshipsTableName] = relationshipsTable\n\n      const relationshipsTableRelations = relations(relationshipsTable, ({ one }) => {\n        const result: Record<string, Relation<string>> = {\n          parent: one(table, {\n            fields: [relationshipsTable.parent],\n            references: [table.id],\n            relationName: '_rels',\n          }),\n        }\n\n        relationships.forEach((relationTo) => {\n          const relatedTableName = toSnakeCase(relationTo)\n          const idColumnName = `${relationTo}ID`\n          result[idColumnName] = one(adapter.tables[relatedTableName], {\n            fields: [relationshipsTable[idColumnName]],\n            references: [adapter.tables[relatedTableName].id],\n          })\n        })\n\n        return result\n      })\n\n      adapter.relations[`relations_${relationshipsTableName}`] = relationshipsTableRelations\n    }\n  }\n\n  const tableRelations = relations(table, ({ many }) => {\n    const result: Record<string, Relation<string>> = {}\n\n    relationsToBuild.forEach((val, key) => {\n      result[key] = many(adapter.tables[val])\n    })\n\n    if (hasLocalizedField) {\n      result._locales = many(localesTable)\n    }\n\n    if (hasManyTextField) {\n      result._texts = many(textsTable)\n    }\n    if (hasManyNumberField) {\n      result._numbers = many(numbersTable)\n    }\n\n    if (relationships.size && relationshipsTable) {\n      result._rels = many(relationshipsTable, {\n        relationName: '_rels',\n      })\n    }\n\n    return result\n  })\n\n  adapter.relations[`relations_${tableName}`] = tableRelations\n\n  return { hasManyNumberField, hasManyTextField, relationsToBuild }\n}\n"],"names":["buildTable","adapter","baseColumns","baseExtraConfig","buildNumbers","buildRelationships","buildTexts","disableNotNull","disableUnique","fields","rootRelationsToBuild","rootRelationships","rootTableIDColType","rootTableName","incomingRootTableName","tableName","timestamps","columns","indexes","hasLocalizedField","hasLocalizedRelationshipField","hasManyTextField","hasManyNumberField","hasLocalizedManyTextField","hasLocalizedManyNumberField","localesColumns","localesIndexes","localesTable","textsTable","numbersTable","relationships","Set","relationshipsTable","relationsToBuild","Map","idColType","getConfigIDType","idColTypeMap","integer","serial","numeric","varchar","id","primaryKey","traverseFields","newTableName","parentTableName","createdAt","timestamp","mode","precision","withTimezone","defaultNow","notNull","updatedAt","table","pgTable","cols","extraConfig","Object","entries","reduce","config","key","func","acc","colName","tables","localeTableName","_locale","enums","enum__locales","_parentID","parentIDColumnMap","references","onDelete","_localeParent","unique","on","localesTableRelations","relations","one","textsTableName","order","parent","path","text","locale","orderParentIdx","index","text_idx","localeParent","textsTableRelations","numbersTableName","number","numberIdx","numbersTableRelations","size","relationshipColumns","forEach","relationTo","formattedRelationTo","toSnakeCase","colType","relatedCollectionCustomID","payload","collections","find","field","fieldAffectsData","name","type","relationshipsTableName","result","parentIdx","pathIdx","localeIdx","relationshipsTableRelations","relationName","relatedTableName","idColumnName","tableRelations","many","val","_locales","_texts","_numbers","_rels"],"mappings":"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"}
@@ -2,9 +2,10 @@ import type { GenericColumn } from '../types';
2
2
  type CreateIndexArgs = {
3
3
  columnName: string;
4
4
  name: string | string[];
5
+ tableName: string;
5
6
  unique?: boolean;
6
7
  };
7
- export declare const createIndex: ({ name, columnName, unique }: CreateIndexArgs) => (table: {
8
+ export declare const createIndex: ({ name, columnName, tableName, unique }: CreateIndexArgs) => (table: {
8
9
  [x: string]: GenericColumn;
9
10
  }) => import("drizzle-orm/pg-core").IndexBuilder;
10
11
  export {};
@@ -1 +1 @@
1
- {"version":3,"file":"createIndex.d.ts","sourceRoot":"","sources":["../../src/schema/createIndex.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE7C,KAAK,eAAe,GAAG;IACrB,UAAU,EAAE,MAAM,CAAA;IAClB,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;IACvB,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,WAAW,iCAAkC,eAAe;;gDAcxE,CAAA"}
1
+ {"version":3,"file":"createIndex.d.ts","sourceRoot":"","sources":["../../src/schema/createIndex.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,UAAU,CAAA;AAE7C,KAAK,eAAe,GAAG;IACrB,UAAU,EAAE,MAAM,CAAA;IAClB,IAAI,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;IACvB,SAAS,EAAE,MAAM,CAAA;IACjB,MAAM,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,eAAO,MAAM,WAAW,4CAA6C,eAAe;;gDAenF,CAAA"}
@@ -9,7 +9,7 @@ Object.defineProperty(exports, "createIndex", {
9
9
  }
10
10
  });
11
11
  const _pgcore = require("drizzle-orm/pg-core");
12
- const createIndex = ({ name, columnName, unique })=>{
12
+ const createIndex = ({ name, columnName, tableName, unique })=>{
13
13
  return (table)=>{
14
14
  let columns;
15
15
  if (Array.isArray(name)) {
@@ -20,9 +20,9 @@ const createIndex = ({ name, columnName, unique })=>{
20
20
  table[name]
21
21
  ];
22
22
  }
23
- if (unique) return (0, _pgcore.uniqueIndex)(`${columnName}_idx`).on(columns[0], ...columns.slice(1));
24
- return (0, _pgcore.index)(`${columnName}_idx`).on(columns[0], ...columns.slice(1));
23
+ if (unique) return (0, _pgcore.uniqueIndex)(`${tableName}_${columnName}_idx`).on(columns[0], ...columns.slice(1));
24
+ return (0, _pgcore.index)(`${tableName}_${columnName}_idx`).on(columns[0], ...columns.slice(1));
25
25
  };
26
26
  };
27
27
 
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvY3JlYXRlSW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcGFyYW0tcmVhc3NpZ24gKi9cbmltcG9ydCB7IGluZGV4LCB1bmlxdWVJbmRleCB9IGZyb20gJ2RyaXp6bGUtb3JtL3BnLWNvcmUnXG5cbmltcG9ydCB0eXBlIHsgR2VuZXJpY0NvbHVtbiB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIENyZWF0ZUluZGV4QXJncyA9IHtcbiAgY29sdW1uTmFtZTogc3RyaW5nXG4gIG5hbWU6IHN0cmluZyB8IHN0cmluZ1tdXG4gIHVuaXF1ZT86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUluZGV4ID0gKHsgbmFtZSwgY29sdW1uTmFtZSwgdW5pcXVlIH06IENyZWF0ZUluZGV4QXJncykgPT4ge1xuICByZXR1cm4gKHRhYmxlOiB7IFt4OiBzdHJpbmddOiBHZW5lcmljQ29sdW1uIH0pID0+IHtcbiAgICBsZXQgY29sdW1uc1xuICAgIGlmIChBcnJheS5pc0FycmF5KG5hbWUpKSB7XG4gICAgICBjb2x1bW5zID0gbmFtZVxuICAgICAgICAubWFwKChjb2x1bW5OYW1lKSA9PiB0YWJsZVtjb2x1bW5OYW1lXSlcbiAgICAgICAgLy8gZXhjbHVkZSBmaWVsZHMgd2VyZSBpbmNsdWRlZCBpbiBjb21wb3VuZCBpbmRleGVzIGJ1dCBkbyBub3QgZXhpc3Qgb24gdGhlIHRhYmxlXG4gICAgICAgIC5maWx0ZXIoKGNvbCkgPT4gdHlwZW9mIGNvbCAhPT0gJ3VuZGVmaW5lZCcpXG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbHVtbnMgPSBbdGFibGVbbmFtZV1dXG4gICAgfVxuICAgIGlmICh1bmlxdWUpIHJldHVybiB1bmlxdWVJbmRleChgJHtjb2x1bW5OYW1lfV9pZHhgKS5vbihjb2x1bW5zWzBdLCAuLi5jb2x1bW5zLnNsaWNlKDEpKVxuICAgIHJldHVybiBpbmRleChgJHtjb2x1bW5OYW1lfV9pZHhgKS5vbihjb2x1bW5zWzBdLCAuLi5jb2x1bW5zLnNsaWNlKDEpKVxuICB9XG59XG4iXSwibmFtZXMiOlsiY3JlYXRlSW5kZXgiLCJuYW1lIiwiY29sdW1uTmFtZSIsInVuaXF1ZSIsInRhYmxlIiwiY29sdW1ucyIsIkFycmF5IiwiaXNBcnJheSIsIm1hcCIsImZpbHRlciIsImNvbCIsInVuaXF1ZUluZGV4Iiwib24iLCJzbGljZSIsImluZGV4Il0sIm1hcHBpbmdzIjoiQUFBQSxvQ0FBb0M7Ozs7K0JBV3ZCQTs7O2VBQUFBOzs7d0JBVnNCO0FBVTVCLE1BQU1BLGNBQWMsQ0FBQyxFQUFFQyxJQUFJLEVBQUVDLFVBQVUsRUFBRUMsTUFBTSxFQUFtQjtJQUN2RSxPQUFPLENBQUNDO1FBQ04sSUFBSUM7UUFDSixJQUFJQyxNQUFNQyxPQUFPLENBQUNOLE9BQU87WUFDdkJJLFVBQVVKLEtBQ1BPLEdBQUcsQ0FBQyxDQUFDTixhQUFlRSxLQUFLLENBQUNGLFdBQVcsQ0FDdEMsaUZBQWlGO2FBQ2hGTyxNQUFNLENBQUMsQ0FBQ0MsTUFBUSxPQUFPQSxRQUFRO1FBQ3BDLE9BQU87WUFDTEwsVUFBVTtnQkFBQ0QsS0FBSyxDQUFDSCxLQUFLO2FBQUM7UUFDekI7UUFDQSxJQUFJRSxRQUFRLE9BQU9RLElBQUFBLG1CQUFXLEVBQUMsQ0FBQyxFQUFFVCxXQUFXLElBQUksQ0FBQyxFQUFFVSxFQUFFLENBQUNQLE9BQU8sQ0FBQyxFQUFFLEtBQUtBLFFBQVFRLEtBQUssQ0FBQztRQUNwRixPQUFPQyxJQUFBQSxhQUFLLEVBQUMsQ0FBQyxFQUFFWixXQUFXLElBQUksQ0FBQyxFQUFFVSxFQUFFLENBQUNQLE9BQU8sQ0FBQyxFQUFFLEtBQUtBLFFBQVFRLEtBQUssQ0FBQztJQUNwRTtBQUNGIn0=
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zY2hlbWEvY3JlYXRlSW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgbm8tcGFyYW0tcmVhc3NpZ24gKi9cbmltcG9ydCB7IGluZGV4LCB1bmlxdWVJbmRleCB9IGZyb20gJ2RyaXp6bGUtb3JtL3BnLWNvcmUnXG5cbmltcG9ydCB0eXBlIHsgR2VuZXJpY0NvbHVtbiB9IGZyb20gJy4uL3R5cGVzJ1xuXG50eXBlIENyZWF0ZUluZGV4QXJncyA9IHtcbiAgY29sdW1uTmFtZTogc3RyaW5nXG4gIG5hbWU6IHN0cmluZyB8IHN0cmluZ1tdXG4gIHRhYmxlTmFtZTogc3RyaW5nXG4gIHVuaXF1ZT86IGJvb2xlYW5cbn1cblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUluZGV4ID0gKHsgbmFtZSwgY29sdW1uTmFtZSwgdGFibGVOYW1lLCB1bmlxdWUgfTogQ3JlYXRlSW5kZXhBcmdzKSA9PiB7XG4gIHJldHVybiAodGFibGU6IHsgW3g6IHN0cmluZ106IEdlbmVyaWNDb2x1bW4gfSkgPT4ge1xuICAgIGxldCBjb2x1bW5zXG4gICAgaWYgKEFycmF5LmlzQXJyYXkobmFtZSkpIHtcbiAgICAgIGNvbHVtbnMgPSBuYW1lXG4gICAgICAgIC5tYXAoKGNvbHVtbk5hbWUpID0+IHRhYmxlW2NvbHVtbk5hbWVdKVxuICAgICAgICAvLyBleGNsdWRlIGZpZWxkcyB3ZXJlIGluY2x1ZGVkIGluIGNvbXBvdW5kIGluZGV4ZXMgYnV0IGRvIG5vdCBleGlzdCBvbiB0aGUgdGFibGVcbiAgICAgICAgLmZpbHRlcigoY29sKSA9PiB0eXBlb2YgY29sICE9PSAndW5kZWZpbmVkJylcbiAgICB9IGVsc2Uge1xuICAgICAgY29sdW1ucyA9IFt0YWJsZVtuYW1lXV1cbiAgICB9XG4gICAgaWYgKHVuaXF1ZSlcbiAgICAgIHJldHVybiB1bmlxdWVJbmRleChgJHt0YWJsZU5hbWV9XyR7Y29sdW1uTmFtZX1faWR4YCkub24oY29sdW1uc1swXSwgLi4uY29sdW1ucy5zbGljZSgxKSlcbiAgICByZXR1cm4gaW5kZXgoYCR7dGFibGVOYW1lfV8ke2NvbHVtbk5hbWV9X2lkeGApLm9uKGNvbHVtbnNbMF0sIC4uLmNvbHVtbnMuc2xpY2UoMSkpXG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJjcmVhdGVJbmRleCIsIm5hbWUiLCJjb2x1bW5OYW1lIiwidGFibGVOYW1lIiwidW5pcXVlIiwidGFibGUiLCJjb2x1bW5zIiwiQXJyYXkiLCJpc0FycmF5IiwibWFwIiwiZmlsdGVyIiwiY29sIiwidW5pcXVlSW5kZXgiLCJvbiIsInNsaWNlIiwiaW5kZXgiXSwibWFwcGluZ3MiOiJBQUFBLG9DQUFvQzs7OzsrQkFZdkJBOzs7ZUFBQUE7Ozt3QkFYc0I7QUFXNUIsTUFBTUEsY0FBYyxDQUFDLEVBQUVDLElBQUksRUFBRUMsVUFBVSxFQUFFQyxTQUFTLEVBQUVDLE1BQU0sRUFBbUI7SUFDbEYsT0FBTyxDQUFDQztRQUNOLElBQUlDO1FBQ0osSUFBSUMsTUFBTUMsT0FBTyxDQUFDUCxPQUFPO1lBQ3ZCSyxVQUFVTCxLQUNQUSxHQUFHLENBQUMsQ0FBQ1AsYUFBZUcsS0FBSyxDQUFDSCxXQUFXLENBQ3RDLGlGQUFpRjthQUNoRlEsTUFBTSxDQUFDLENBQUNDLE1BQVEsT0FBT0EsUUFBUTtRQUNwQyxPQUFPO1lBQ0xMLFVBQVU7Z0JBQUNELEtBQUssQ0FBQ0osS0FBSzthQUFDO1FBQ3pCO1FBQ0EsSUFBSUcsUUFDRixPQUFPUSxJQUFBQSxtQkFBVyxFQUFDLENBQUMsRUFBRVQsVUFBVSxDQUFDLEVBQUVELFdBQVcsSUFBSSxDQUFDLEVBQUVXLEVBQUUsQ0FBQ1AsT0FBTyxDQUFDLEVBQUUsS0FBS0EsUUFBUVEsS0FBSyxDQUFDO1FBQ3ZGLE9BQU9DLElBQUFBLGFBQUssRUFBQyxDQUFDLEVBQUVaLFVBQVUsQ0FBQyxFQUFFRCxXQUFXLElBQUksQ0FBQyxFQUFFVyxFQUFFLENBQUNQLE9BQU8sQ0FBQyxFQUFFLEtBQUtBLFFBQVFRLEtBQUssQ0FBQztJQUNqRjtBQUNGIn0=
@@ -3,9 +3,9 @@ import type { Field, TabAsField } from 'payload/types';
3
3
  import type { GenericColumns, PostgresAdapter } from '../types';
4
4
  type Args = {
5
5
  adapter: PostgresAdapter;
6
- buildTexts: boolean;
7
6
  buildNumbers: boolean;
8
7
  buildRelationships: boolean;
8
+ buildTexts: boolean;
9
9
  columnPrefix?: string;
10
10
  columns: Record<string, PgColumnBuilder>;
11
11
  disableNotNull: boolean;
@@ -26,12 +26,12 @@ type Args = {
26
26
  };
27
27
  type Result = {
28
28
  hasLocalizedField: boolean;
29
- hasLocalizedManyTextField: boolean;
30
29
  hasLocalizedManyNumberField: boolean;
30
+ hasLocalizedManyTextField: boolean;
31
31
  hasLocalizedRelationshipField: boolean;
32
- hasManyTextField: 'index' | boolean;
33
32
  hasManyNumberField: 'index' | boolean;
33
+ hasManyTextField: 'index' | boolean;
34
34
  };
35
- export declare const traverseFields: ({ adapter, buildTexts, buildNumbers, buildRelationships, columnPrefix, columns, disableNotNull, disableUnique, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName, }: Args) => Result;
35
+ export declare const traverseFields: ({ adapter, buildNumbers, buildRelationships, buildTexts, columnPrefix, columns, disableNotNull, disableUnique, fieldPrefix, fields, forceLocalized, indexes, localesColumns, localesIndexes, newTableName, parentTableName, relationsToBuild, relationships, rootRelationsToBuild, rootTableIDColType, rootTableName, }: Args) => Result;
36
36
  export {};
37
37
  //# sourceMappingURL=traverseFields.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/schema/traverseFields.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAA2B,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAoBtD,OAAO,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAS/D,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,UAAU,EAAE,OAAO,CAAA;IACnB,YAAY,EAAE,OAAO,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACrC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,yBAAyB,EAAE,OAAO,CAAA;IAClC,2BAA2B,EAAE,OAAO,CAAA;IACpC,6BAA6B,EAAE,OAAO,CAAA;IACtC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;IACnC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,cAAc,4TAsBxB,IAAI,KAAG,MAwkBT,CAAA"}
1
+ {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../../src/schema/traverseFields.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,YAAY,EAAE,eAAe,EAA2B,MAAM,qBAAqB,CAAA;AACjG,OAAO,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAoBtD,OAAO,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAS/D,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,YAAY,EAAE,OAAO,CAAA;IACrB,kBAAkB,EAAE,OAAO,CAAA;IAC3B,UAAU,EAAE,OAAO,CAAA;IACnB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IACxC,cAAc,EAAE,OAAO,CAAA;IACvB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IAC/D,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;IAC/C,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,YAAY,CAAC,CAAA;IACtE,YAAY,EAAE,MAAM,CAAA;IACpB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IACrC,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAC1B,oBAAoB,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;IAC1C,kBAAkB,EAAE,MAAM,CAAA;IAC1B,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,KAAK,MAAM,GAAG;IACZ,iBAAiB,EAAE,OAAO,CAAA;IAC1B,2BAA2B,EAAE,OAAO,CAAA;IACpC,yBAAyB,EAAE,OAAO,CAAA;IAClC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;IACrC,gBAAgB,EAAE,OAAO,GAAG,OAAO,CAAA;CACpC,CAAA;AAED,eAAO,MAAM,cAAc,4TAsBxB,IAAI,KAAG,MA4kBT,CAAA"}