@payloadcms/db-postgres 0.1.5 → 0.1.7

Sign up to get free protection for your applications and to get access to all the features.
@@ -21,12 +21,14 @@ type Args = {
21
21
  aliasTable?: GenericTable;
22
22
  collectionPath: string;
23
23
  columnPrefix?: string;
24
+ constraintPath?: string;
24
25
  constraints?: Constraint[];
25
26
  fields: (Field | TabAsField)[];
26
27
  joinAliases: BuildQueryJoinAliases;
27
28
  joins: BuildQueryJoins;
28
29
  locale?: string;
29
30
  pathSegments: string[];
31
+ rootTableName?: string;
30
32
  selectFields: Record<string, GenericColumn>;
31
33
  tableName: string;
32
34
  };
@@ -35,6 +37,6 @@ type Args = {
35
37
  * Adds tables to `join`
36
38
  * @returns TableColumn
37
39
  */
38
- export declare const getTableColumnFromPath: ({ adapter, aliasTable, collectionPath, columnPrefix, constraints, fields, joinAliases, joins, locale: incomingLocale, pathSegments: incomingSegments, selectFields, tableName, }: Args) => TableColumn;
40
+ export declare const getTableColumnFromPath: ({ adapter, aliasTable, collectionPath, columnPrefix, constraintPath: incomingConstraintPath, constraints, fields, joinAliases, joins, locale: incomingLocale, pathSegments: incomingSegments, rootTableName: incomingRootTableName, selectFields, tableName, }: Args) => TableColumn;
39
41
  export {};
40
42
  //# sourceMappingURL=getTableColumnFromPath.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"getTableColumnFromPath.d.ts","sourceRoot":"","sources":["../../src/queries/getTableColumnFromPath.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAU1E,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAE1E,KAAK,UAAU,GAAG;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,YAAY,CAAA;IACnB,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AAED,KAAK,WAAW,GAAG;IACjB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,UAAU,EAAE,CAAA;IACzB,KAAK,EAAE,kBAAkB,CAAA;IACzB,uBAAuB,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,MAAM,CAAA;IAClD,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,SAAS,CAAC,EAAE,GAAG,CAAA;IACf,KAAK,EAAE,YAAY,CAAA;CACpB,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,UAAU,CAAC,EAAE,YAAY,CAAA;IACzB,cAAc,EAAE,MAAM,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;IAC1B,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AACD;;;;GAIG;AACH,eAAO,MAAM,sBAAsB,qLAahC,IAAI,KAAG,WAgWT,CAAA"}
1
+ {"version":3,"file":"getTableColumnFromPath.d.ts","sourceRoot":"","sources":["../../src/queries/getTableColumnFromPath.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAE,kBAAkB,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAU1E,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC5E,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAE1E,KAAK,UAAU,GAAG;IAChB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,YAAY,CAAA;IACnB,KAAK,EAAE,OAAO,CAAA;CACf,CAAA;AAED,KAAK,WAAW,GAAG;IACjB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,WAAW,EAAE,UAAU,EAAE,CAAA;IACzB,KAAK,EAAE,kBAAkB,CAAA;IACzB,uBAAuB,CAAC,EAAE,CAAC,GAAG,EAAE,OAAO,KAAK,MAAM,CAAA;IAClD,YAAY,CAAC,EAAE,MAAM,EAAE,CAAA;IACvB,SAAS,CAAC,EAAE,GAAG,CAAA;IACf,KAAK,EAAE,YAAY,CAAA;CACpB,CAAA;AAED,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,UAAU,CAAC,EAAE,YAAY,CAAA;IACzB,cAAc,EAAE,MAAM,CAAA;IACtB,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,WAAW,CAAC,EAAE,UAAU,EAAE,CAAA;IAC1B,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,YAAY,EAAE,MAAM,EAAE,CAAA;IACtB,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AACD;;;;GAIG;AACH,eAAO,MAAM,sBAAsB,mQAehC,IAAI,KAAG,WAgXT,CAAA"}
@@ -20,9 +20,11 @@ function _interop_require_default(obj) {
20
20
  default: obj
21
21
  };
22
22
  }
23
- const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPrefix = '', constraints = [], fields, joinAliases, joins, locale: incomingLocale, pathSegments: incomingSegments, selectFields, tableName })=>{
23
+ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPrefix = '', constraintPath: incomingConstraintPath, constraints = [], fields, joinAliases, joins, locale: incomingLocale, pathSegments: incomingSegments, rootTableName: incomingRootTableName, selectFields, tableName })=>{
24
24
  const fieldPath = incomingSegments[0];
25
25
  let locale = incomingLocale;
26
+ const rootTableName = incomingRootTableName || tableName;
27
+ let constraintPath = incomingConstraintPath || '';
26
28
  const field = (0, _utilities.flattenTopLevelFields)(fields).find((fieldToFind)=>(0, _types.fieldAffectsData)(fieldToFind) && fieldToFind.name === fieldPath);
27
29
  let newTableName = tableName;
28
30
  if (!field && fieldPath === 'id') {
@@ -58,6 +60,7 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
58
60
  aliasTable,
59
61
  collectionPath,
60
62
  columnPrefix,
63
+ constraintPath,
61
64
  constraints,
62
65
  fields: field.tabs.map((tab)=>({
63
66
  ...tab,
@@ -67,6 +70,7 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
67
70
  joins,
68
71
  locale,
69
72
  pathSegments: pathSegments.slice(1),
73
+ rootTableName,
70
74
  selectFields,
71
75
  tableName: newTableName
72
76
  });
@@ -79,12 +83,14 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
79
83
  aliasTable,
80
84
  collectionPath,
81
85
  columnPrefix: `${columnPrefix}${field.name}_`,
86
+ constraintPath,
82
87
  constraints,
83
88
  fields: field.fields,
84
89
  joinAliases,
85
90
  joins,
86
91
  locale,
87
92
  pathSegments: pathSegments.slice(1),
93
+ rootTableName,
88
94
  selectFields,
89
95
  tableName: newTableName
90
96
  });
@@ -94,12 +100,14 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
94
100
  aliasTable,
95
101
  collectionPath,
96
102
  columnPrefix,
103
+ constraintPath,
97
104
  constraints,
98
105
  fields: field.fields,
99
106
  joinAliases,
100
107
  joins,
101
108
  locale,
102
109
  pathSegments: pathSegments.slice(1),
110
+ rootTableName,
103
111
  selectFields,
104
112
  tableName: newTableName
105
113
  });
@@ -122,12 +130,14 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
122
130
  aliasTable,
123
131
  collectionPath,
124
132
  columnPrefix: `${columnPrefix}${field.name}_`,
133
+ constraintPath,
125
134
  constraints,
126
135
  fields: field.fields,
127
136
  joinAliases,
128
137
  joins,
129
138
  locale,
130
139
  pathSegments: pathSegments.slice(1),
140
+ rootTableName,
131
141
  selectFields,
132
142
  tableName: newTableName
133
143
  });
@@ -135,6 +145,7 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
135
145
  case 'array':
136
146
  {
137
147
  newTableName = `${tableName}_${(0, _tosnakecase.default)(field.name)}`;
148
+ constraintPath = `${constraintPath}${field.name}.%.`;
138
149
  if (locale && field.localized && adapter.payload.config.localization) {
139
150
  joins[newTableName] = (0, _drizzleorm.and)((0, _drizzleorm.eq)(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID), (0, _drizzleorm.eq)(adapter.tables[newTableName]._locale, locale));
140
151
  if (locale !== 'all') {
@@ -150,12 +161,14 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
150
161
  return getTableColumnFromPath({
151
162
  adapter,
152
163
  collectionPath,
164
+ constraintPath,
153
165
  constraints,
154
166
  fields: field.fields,
155
167
  joinAliases,
156
168
  joins,
157
169
  locale,
158
170
  pathSegments: pathSegments.slice(1),
171
+ rootTableName,
159
172
  selectFields,
160
173
  tableName: newTableName
161
174
  });
@@ -173,12 +186,14 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
173
186
  result = getTableColumnFromPath({
174
187
  adapter,
175
188
  collectionPath,
189
+ constraintPath: '',
176
190
  constraints: blockConstraints,
177
191
  fields: block.fields,
178
192
  joinAliases,
179
193
  joins,
180
194
  locale,
181
195
  pathSegments: pathSegments.slice(1),
196
+ rootTableName,
182
197
  selectFields: blockSelectFields,
183
198
  tableName: newTableName
184
199
  });
@@ -224,20 +239,20 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
224
239
  case 'upload':
225
240
  {
226
241
  let relationshipFields;
227
- const relationTableName = `${tableName}_rels`;
242
+ const relationTableName = `${rootTableName}_rels`;
228
243
  const newCollectionPath = pathSegments.slice(1).join('.');
229
244
  const aliasRelationshipTableName = (0, _uuid.v4)();
230
245
  const aliasRelationshipTable = (0, _pgcore.alias)(adapter.tables[relationTableName], aliasRelationshipTableName);
231
246
  // Join in the relationships table
232
247
  joinAliases.push({
233
- condition: (0, _drizzleorm.eq)((aliasTable || adapter.tables[tableName]).id, aliasRelationshipTable.parent),
248
+ condition: (0, _drizzleorm.eq)((aliasTable || adapter.tables[rootTableName]).id, aliasRelationshipTable.parent),
234
249
  table: aliasRelationshipTable
235
250
  });
236
251
  selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path;
237
252
  constraints.push({
238
253
  columnName: 'path',
239
254
  table: aliasRelationshipTable,
240
- value: field.name
255
+ value: `${constraintPath}${field.name}`
241
256
  });
242
257
  let newAliasTable;
243
258
  if (typeof field.relationTo === 'string') {
@@ -292,6 +307,7 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
292
307
  joins,
293
308
  locale,
294
309
  pathSegments: pathSegments.slice(1),
310
+ rootTableName: newTableName,
295
311
  selectFields,
296
312
  tableName: newTableName
297
313
  });
@@ -330,4 +346,4 @@ const getTableColumnFromPath = ({ adapter, aliasTable, collectionPath, columnPre
330
346
  throw new _errors.APIError(`Cannot find field for path at ${fieldPath}`);
331
347
  };
332
348
 
333
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, FieldAffectingData, TabAsField } from 'payload/types'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { alias } from 'drizzle-orm/pg-core'\nimport { APIError } from 'payload/errors'\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport { flattenTopLevelFields } from 'payload/utilities'\nimport toSnakeCase from 'to-snake-case'\nimport { v4 as uuid } from 'uuid'\n\nimport type { GenericColumn, GenericTable, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\ntype Constraint = {\n  columnName: string\n  table: GenericTable\n  value: unknown\n}\n\ntype TableColumn = {\n  columnName?: string\n  constraints: Constraint[]\n  field: FieldAffectingData\n  getNotNullColumnByValue?: (val: unknown) => string\n  pathSegments?: string[]\n  rawColumn?: SQL\n  table: GenericTable\n}\n\ntype Args = {\n  adapter: PostgresAdapter\n  aliasTable?: GenericTable\n  collectionPath: string\n  columnPrefix?: string\n  constraints?: Constraint[]\n  fields: (Field | TabAsField)[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale?: string\n  pathSegments: string[]\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n}\n/**\n * Transforms path to table and column name\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n  adapter,\n  aliasTable,\n  collectionPath,\n  columnPrefix = '',\n  constraints = [],\n  fields,\n  joinAliases,\n  joins,\n  locale: incomingLocale,\n  pathSegments: incomingSegments,\n  selectFields,\n  tableName,\n}: Args): TableColumn => {\n  const fieldPath = incomingSegments[0]\n  let locale = incomingLocale\n  const field = flattenTopLevelFields(fields as Field[]).find(\n    (fieldToFind) => fieldAffectsData(fieldToFind) && fieldToFind.name === fieldPath,\n  ) as Field | TabAsField\n  let newTableName = tableName\n\n  if (!field && fieldPath === 'id') {\n    selectFields.id = adapter.tables[newTableName].id\n    return {\n      columnName: 'id',\n      constraints,\n      field: {\n        name: 'id',\n        type: 'number',\n      },\n      table: adapter.tables[newTableName],\n    }\n  }\n\n  if (field) {\n    const pathSegments = [...incomingSegments]\n\n    // If next segment is a locale,\n    // we need to take it out and use it as the locale from this point on\n    if ('localized' in field && field.localized && adapter.payload.config.localization) {\n      const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n        (locale) => locale === pathSegments[1],\n      )\n\n      if (matchedLocale) {\n        locale = matchedLocale\n        pathSegments.splice(1, 1)\n      }\n    }\n\n    switch (field.type) {\n      case 'tabs': {\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraints,\n          fields: field.tabs.map((tab) => ({\n            ...tab,\n            type: 'tab',\n          })),\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n      case 'tab': {\n        if (tabHasName(field)) {\n          return getTableColumnFromPath({\n            adapter,\n            aliasTable,\n            collectionPath,\n            columnPrefix: `${columnPrefix}${field.name}_`,\n            constraints,\n            fields: field.fields,\n            joinAliases,\n            joins,\n            locale,\n            pathSegments: pathSegments.slice(1),\n            selectFields,\n            tableName: newTableName,\n          })\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'group': {\n        if (locale && field.localized && adapter.payload.config.localization) {\n          newTableName = `${tableName}_locales`\n\n          joins[tableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix: `${columnPrefix}${field.name}_`,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'array': {\n        newTableName = `${tableName}_${toSnakeCase(field.name)}`\n        if (locale && field.localized && adapter.payload.config.localization) {\n          joins[newTableName] = and(\n            eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n            eq(adapter.tables[newTableName]._locale, locale),\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        } else {\n          joins[newTableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n        }\n        return getTableColumnFromPath({\n          adapter,\n          collectionPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'blocks': {\n        let blockTableColumn: TableColumn\n        let newTableName: string\n        const hasBlockField = field.blocks.some((block) => {\n          newTableName = `${tableName}_blocks_${toSnakeCase(block.slug)}`\n          let result\n          const blockConstraints = []\n          const blockSelectFields = {}\n          try {\n            result = getTableColumnFromPath({\n              adapter,\n              collectionPath,\n              constraints: blockConstraints,\n              fields: block.fields,\n              joinAliases,\n              joins,\n              locale,\n              pathSegments: pathSegments.slice(1),\n              selectFields: blockSelectFields,\n              tableName: newTableName,\n            })\n          } catch (error) {\n            // this is fine, not every block will have the field\n          }\n          if (!result) {\n            return\n          }\n          blockTableColumn = result\n          constraints = constraints.concat(blockConstraints)\n          selectFields = { ...selectFields, ...blockSelectFields }\n          if (field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale) {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n          }\n          return result\n        })\n        if (hasBlockField) {\n          return {\n            columnName: blockTableColumn.columnName,\n            constraints,\n            field: blockTableColumn.field,\n            pathSegments: pathSegments.slice(1),\n            rawColumn: blockTableColumn.rawColumn,\n            table: adapter.tables[newTableName],\n          }\n        }\n        break\n      }\n\n      case 'relationship':\n      case 'upload': {\n        let relationshipFields\n        const relationTableName = `${tableName}_rels`\n        const newCollectionPath = pathSegments.slice(1).join('.')\n\n        const aliasRelationshipTableName = uuid()\n        const aliasRelationshipTable = alias(\n          adapter.tables[relationTableName],\n          aliasRelationshipTableName,\n        )\n\n        // Join in the relationships table\n        joinAliases.push({\n          condition: eq(\n            (aliasTable || adapter.tables[tableName]).id,\n            aliasRelationshipTable.parent,\n          ),\n          table: aliasRelationshipTable,\n        })\n\n        selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n        constraints.push({\n          columnName: 'path',\n          table: aliasRelationshipTable,\n          value: field.name,\n        })\n\n        let newAliasTable\n\n        if (typeof field.relationTo === 'string') {\n          newTableName = `${toSnakeCase(field.relationTo)}`\n          // parent to relationship join table\n          relationshipFields = adapter.payload.collections[field.relationTo].config.fields\n\n          newAliasTable = alias(adapter.tables[newTableName], toSnakeCase(uuid()))\n\n          joinAliases.push({\n            condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n            table: newAliasTable,\n          })\n\n          if (newCollectionPath === '') {\n            return {\n              columnName: `${field.relationTo}ID`,\n              constraints,\n              field,\n              table: aliasRelationshipTable,\n            }\n          }\n        } else if (newCollectionPath === 'value') {\n          const tableColumnsNames = field.relationTo.map(\n            (relationTo) => `\"${aliasRelationshipTableName}\".\"${toSnakeCase(relationTo)}_id\"`,\n          )\n          return {\n            constraints,\n            field,\n            rawColumn: sql.raw(`COALESCE(${tableColumnsNames.join(', ')})`),\n            table: aliasRelationshipTable,\n          }\n        } else if (newCollectionPath === 'relationTo') {\n          const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]\n\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: (val) => {\n              const matchedRelation = relationTo.find((relation) => relation === val)\n              if (matchedRelation) return `${matchedRelation}ID`\n              return undefined\n            },\n            table: aliasRelationshipTable,\n          }\n        } else {\n          throw new APIError('Not supported')\n        }\n\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable: newAliasTable,\n          collectionPath: newCollectionPath,\n          constraints,\n          fields: relationshipFields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      default: {\n        if (fieldAffectsData(field)) {\n          if (field.localized && adapter.payload.config.localization) {\n            // If localized, we go to localized table and set aliasTable to undefined\n            // so it is not picked up below to be used as targetTable\n            newTableName = `${tableName}_locales`\n\n            const parentTable = aliasTable || adapter.tables[tableName]\n\n            joins[newTableName] = eq(parentTable.id, adapter.tables[newTableName]._parentID)\n\n            aliasTable = undefined\n\n            if (locale !== 'all') {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          }\n\n          const targetTable = aliasTable || adapter.tables[newTableName]\n\n          selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n            targetTable[`${columnPrefix}${field.name}`]\n\n          return {\n            columnName: `${columnPrefix}${field.name}`,\n            constraints,\n            field,\n            pathSegments: pathSegments,\n            table: targetTable,\n          }\n        }\n      }\n    }\n  }\n\n  throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraints","fields","joinAliases","joins","locale","incomingLocale","pathSegments","incomingSegments","selectFields","tableName","fieldPath","field","flattenTopLevelFields","find","fieldToFind","fieldAffectsData","name","newTableName","id","tables","columnName","type","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","tabHasName","eq","_parentID","push","value","toSnakeCase","and","_locale","blockTableColumn","hasBlockField","blocks","some","block","slug","result","blockConstraints","blockSelectFields","error","concat","rawColumn","relationshipFields","relationTableName","newCollectionPath","join","aliasRelationshipTableName","uuid","aliasRelationshipTable","alias","condition","parent","path","newAliasTable","relationTo","collections","tableColumnsNames","sql","raw","Array","isArray","getNotNullColumnByValue","val","matchedRelation","relation","undefined","APIError","parentTable","targetTable"],"mappings":"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"}
349
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/getTableColumnFromPath.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, FieldAffectingData, TabAsField } from 'payload/types'\n\nimport { and, eq, sql } from 'drizzle-orm'\nimport { alias } from 'drizzle-orm/pg-core'\nimport { APIError } from 'payload/errors'\nimport { fieldAffectsData, tabHasName } from 'payload/types'\nimport { flattenTopLevelFields } from 'payload/utilities'\nimport toSnakeCase from 'to-snake-case'\nimport { v4 as uuid } from 'uuid'\n\nimport type { GenericColumn, GenericTable, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\ntype Constraint = {\n  columnName: string\n  table: GenericTable\n  value: unknown\n}\n\ntype TableColumn = {\n  columnName?: string\n  constraints: Constraint[]\n  field: FieldAffectingData\n  getNotNullColumnByValue?: (val: unknown) => string\n  pathSegments?: string[]\n  rawColumn?: SQL\n  table: GenericTable\n}\n\ntype Args = {\n  adapter: PostgresAdapter\n  aliasTable?: GenericTable\n  collectionPath: string\n  columnPrefix?: string\n  constraintPath?: string\n  constraints?: Constraint[]\n  fields: (Field | TabAsField)[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale?: string\n  pathSegments: string[]\n  rootTableName?: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n}\n/**\n * Transforms path to table and column name\n * Adds tables to `join`\n * @returns TableColumn\n */\nexport const getTableColumnFromPath = ({\n  adapter,\n  aliasTable,\n  collectionPath,\n  columnPrefix = '',\n  constraintPath: incomingConstraintPath,\n  constraints = [],\n  fields,\n  joinAliases,\n  joins,\n  locale: incomingLocale,\n  pathSegments: incomingSegments,\n  rootTableName: incomingRootTableName,\n  selectFields,\n  tableName,\n}: Args): TableColumn => {\n  const fieldPath = incomingSegments[0]\n  let locale = incomingLocale\n  const rootTableName = incomingRootTableName || tableName\n  let constraintPath = incomingConstraintPath || ''\n\n  const field = flattenTopLevelFields(fields as Field[]).find(\n    (fieldToFind) => fieldAffectsData(fieldToFind) && fieldToFind.name === fieldPath,\n  ) as Field | TabAsField\n  let newTableName = tableName\n\n  if (!field && fieldPath === 'id') {\n    selectFields.id = adapter.tables[newTableName].id\n    return {\n      columnName: 'id',\n      constraints,\n      field: {\n        name: 'id',\n        type: 'number',\n      },\n      table: adapter.tables[newTableName],\n    }\n  }\n\n  if (field) {\n    const pathSegments = [...incomingSegments]\n\n    // If next segment is a locale,\n    // we need to take it out and use it as the locale from this point on\n    if ('localized' in field && field.localized && adapter.payload.config.localization) {\n      const matchedLocale = adapter.payload.config.localization.localeCodes.find(\n        (locale) => locale === pathSegments[1],\n      )\n\n      if (matchedLocale) {\n        locale = matchedLocale\n        pathSegments.splice(1, 1)\n      }\n    }\n\n    switch (field.type) {\n      case 'tabs': {\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.tabs.map((tab) => ({\n            ...tab,\n            type: 'tab',\n          })),\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n      case 'tab': {\n        if (tabHasName(field)) {\n          return getTableColumnFromPath({\n            adapter,\n            aliasTable,\n            collectionPath,\n            columnPrefix: `${columnPrefix}${field.name}_`,\n            constraintPath,\n            constraints,\n            fields: field.fields,\n            joinAliases,\n            joins,\n            locale,\n            pathSegments: pathSegments.slice(1),\n            rootTableName,\n            selectFields,\n            tableName: newTableName,\n          })\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'group': {\n        if (locale && field.localized && adapter.payload.config.localization) {\n          newTableName = `${tableName}_locales`\n\n          joins[tableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        }\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable,\n          collectionPath,\n          columnPrefix: `${columnPrefix}${field.name}_`,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'array': {\n        newTableName = `${tableName}_${toSnakeCase(field.name)}`\n        constraintPath = `${constraintPath}${field.name}.%.`\n        if (locale && field.localized && adapter.payload.config.localization) {\n          joins[newTableName] = and(\n            eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n            eq(adapter.tables[newTableName]._locale, locale),\n          )\n          if (locale !== 'all') {\n            constraints.push({\n              columnName: '_locale',\n              table: adapter.tables[newTableName],\n              value: locale,\n            })\n          }\n        } else {\n          joins[newTableName] = eq(\n            adapter.tables[tableName].id,\n            adapter.tables[newTableName]._parentID,\n          )\n        }\n        return getTableColumnFromPath({\n          adapter,\n          collectionPath,\n          constraintPath,\n          constraints,\n          fields: field.fields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      case 'blocks': {\n        let blockTableColumn: TableColumn\n        let newTableName: string\n        const hasBlockField = field.blocks.some((block) => {\n          newTableName = `${tableName}_blocks_${toSnakeCase(block.slug)}`\n          let result\n          const blockConstraints = []\n          const blockSelectFields = {}\n          try {\n            result = getTableColumnFromPath({\n              adapter,\n              collectionPath,\n              constraintPath: '',\n              constraints: blockConstraints,\n              fields: block.fields,\n              joinAliases,\n              joins,\n              locale,\n              pathSegments: pathSegments.slice(1),\n              rootTableName,\n              selectFields: blockSelectFields,\n              tableName: newTableName,\n            })\n          } catch (error) {\n            // this is fine, not every block will have the field\n          }\n          if (!result) {\n            return\n          }\n          blockTableColumn = result\n          constraints = constraints.concat(blockConstraints)\n          selectFields = { ...selectFields, ...blockSelectFields }\n          if (field.localized && adapter.payload.config.localization) {\n            joins[newTableName] = and(\n              eq(adapter.tables[tableName].id, adapter.tables[newTableName]._parentID),\n              eq(adapter.tables[newTableName]._locale, locale),\n            )\n            if (locale) {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          } else {\n            joins[newTableName] = eq(\n              adapter.tables[tableName].id,\n              adapter.tables[newTableName]._parentID,\n            )\n          }\n          return result\n        })\n        if (hasBlockField) {\n          return {\n            columnName: blockTableColumn.columnName,\n            constraints,\n            field: blockTableColumn.field,\n            pathSegments: pathSegments.slice(1),\n            rawColumn: blockTableColumn.rawColumn,\n            table: adapter.tables[newTableName],\n          }\n        }\n        break\n      }\n\n      case 'relationship':\n      case 'upload': {\n        let relationshipFields\n        const relationTableName = `${rootTableName}_rels`\n        const newCollectionPath = pathSegments.slice(1).join('.')\n        const aliasRelationshipTableName = uuid()\n        const aliasRelationshipTable = alias(\n          adapter.tables[relationTableName],\n          aliasRelationshipTableName,\n        )\n\n        // Join in the relationships table\n        joinAliases.push({\n          condition: eq(\n            (aliasTable || adapter.tables[rootTableName]).id,\n            aliasRelationshipTable.parent,\n          ),\n          table: aliasRelationshipTable,\n        })\n\n        selectFields[`${relationTableName}.path`] = aliasRelationshipTable.path\n\n        constraints.push({\n          columnName: 'path',\n          table: aliasRelationshipTable,\n          value: `${constraintPath}${field.name}`,\n        })\n\n        let newAliasTable\n\n        if (typeof field.relationTo === 'string') {\n          newTableName = `${toSnakeCase(field.relationTo)}`\n          // parent to relationship join table\n          relationshipFields = adapter.payload.collections[field.relationTo].config.fields\n\n          newAliasTable = alias(adapter.tables[newTableName], toSnakeCase(uuid()))\n\n          joinAliases.push({\n            condition: eq(newAliasTable.id, aliasRelationshipTable[`${field.relationTo}ID`]),\n            table: newAliasTable,\n          })\n\n          if (newCollectionPath === '') {\n            return {\n              columnName: `${field.relationTo}ID`,\n              constraints,\n              field,\n              table: aliasRelationshipTable,\n            }\n          }\n        } else if (newCollectionPath === 'value') {\n          const tableColumnsNames = field.relationTo.map(\n            (relationTo) => `\"${aliasRelationshipTableName}\".\"${toSnakeCase(relationTo)}_id\"`,\n          )\n          return {\n            constraints,\n            field,\n            rawColumn: sql.raw(`COALESCE(${tableColumnsNames.join(', ')})`),\n            table: aliasRelationshipTable,\n          }\n        } else if (newCollectionPath === 'relationTo') {\n          const relationTo = Array.isArray(field.relationTo) ? field.relationTo : [field.relationTo]\n\n          return {\n            constraints,\n            field,\n            getNotNullColumnByValue: (val) => {\n              const matchedRelation = relationTo.find((relation) => relation === val)\n              if (matchedRelation) return `${matchedRelation}ID`\n              return undefined\n            },\n            table: aliasRelationshipTable,\n          }\n        } else {\n          throw new APIError('Not supported')\n        }\n\n        return getTableColumnFromPath({\n          adapter,\n          aliasTable: newAliasTable,\n          collectionPath: newCollectionPath,\n          constraints,\n          fields: relationshipFields,\n          joinAliases,\n          joins,\n          locale,\n          pathSegments: pathSegments.slice(1),\n          rootTableName: newTableName,\n          selectFields,\n          tableName: newTableName,\n        })\n      }\n\n      default: {\n        if (fieldAffectsData(field)) {\n          if (field.localized && adapter.payload.config.localization) {\n            // If localized, we go to localized table and set aliasTable to undefined\n            // so it is not picked up below to be used as targetTable\n            newTableName = `${tableName}_locales`\n\n            const parentTable = aliasTable || adapter.tables[tableName]\n\n            joins[newTableName] = eq(parentTable.id, adapter.tables[newTableName]._parentID)\n\n            aliasTable = undefined\n\n            if (locale !== 'all') {\n              constraints.push({\n                columnName: '_locale',\n                table: adapter.tables[newTableName],\n                value: locale,\n              })\n            }\n          }\n\n          const targetTable = aliasTable || adapter.tables[newTableName]\n\n          selectFields[`${newTableName}.${columnPrefix}${field.name}`] =\n            targetTable[`${columnPrefix}${field.name}`]\n\n          return {\n            columnName: `${columnPrefix}${field.name}`,\n            constraints,\n            field,\n            pathSegments: pathSegments,\n            table: targetTable,\n          }\n        }\n      }\n    }\n  }\n\n  throw new APIError(`Cannot find field for path at ${fieldPath}`)\n}\n"],"names":["getTableColumnFromPath","adapter","aliasTable","collectionPath","columnPrefix","constraintPath","incomingConstraintPath","constraints","fields","joinAliases","joins","locale","incomingLocale","pathSegments","incomingSegments","rootTableName","incomingRootTableName","selectFields","tableName","fieldPath","field","flattenTopLevelFields","find","fieldToFind","fieldAffectsData","name","newTableName","id","tables","columnName","type","table","localized","payload","config","localization","matchedLocale","localeCodes","splice","tabs","map","tab","slice","tabHasName","eq","_parentID","push","value","toSnakeCase","and","_locale","blockTableColumn","hasBlockField","blocks","some","block","slug","result","blockConstraints","blockSelectFields","error","concat","rawColumn","relationshipFields","relationTableName","newCollectionPath","join","aliasRelationshipTableName","uuid","aliasRelationshipTable","alias","condition","parent","path","newAliasTable","relationTo","collections","tableColumnsNames","sql","raw","Array","isArray","getNotNullColumnByValue","val","matchedRelation","relation","undefined","APIError","parentTable","targetTable"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"parseParams.d.ts","sourceRoot":"","sources":["../../src/queries/parseParams.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAY,KAAK,EAAE,MAAM,eAAe,CAAA;AAM3D,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC9D,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAS1E,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,EAAE,MAAM,CAAA;IACd,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB,KAAK,EAAE,KAAK,CAAA;CACb,CAAA;AAED,wBAAsB,WAAW,CAAC,EAChC,OAAO,EACP,MAAM,EACN,WAAW,EACX,KAAK,EACL,MAAM,EACN,YAAY,EACZ,SAAS,EACT,KAAK,GACN,EAAE,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CA8JrB"}
1
+ {"version":3,"file":"parseParams.d.ts","sourceRoot":"","sources":["../../src/queries/parseParams.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AACtC,OAAO,KAAK,EAAE,KAAK,EAAY,KAAK,EAAE,MAAM,eAAe,CAAA;AAM3D,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,UAAU,CAAA;AAC9D,OAAO,KAAK,EAAE,qBAAqB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAS1E,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,MAAM,EAAE,KAAK,EAAE,CAAA;IACf,WAAW,EAAE,qBAAqB,CAAA;IAClC,KAAK,EAAE,eAAe,CAAA;IACtB,MAAM,EAAE,MAAM,CAAA;IACd,YAAY,EAAE,MAAM,CAAC,MAAM,EAAE,aAAa,CAAC,CAAA;IAC3C,SAAS,EAAE,MAAM,CAAA;IACjB,KAAK,EAAE,KAAK,CAAA;CACb,CAAA;AAED,wBAAsB,WAAW,CAAC,EAChC,OAAO,EACP,MAAM,EACN,WAAW,EACX,KAAK,EACL,MAAM,EACN,YAAY,EACZ,SAAS,EACT,KAAK,GACN,EAAE,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,CAkKrB"}
@@ -70,7 +70,11 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
70
70
  });
71
71
  const val = where[relationOrPath][operator];
72
72
  queryConstraints.forEach(({ columnName: col, table: constraintTable, value })=>{
73
- constraints.push(_operatorMap.operatorMap.equals(constraintTable[col], value));
73
+ if (typeof value === 'string' && value.indexOf('%') > -1) {
74
+ constraints.push(_operatorMap.operatorMap.like(constraintTable[col], value));
75
+ } else {
76
+ constraints.push(_operatorMap.operatorMap.equals(constraintTable[col], value));
77
+ }
74
78
  });
75
79
  if ([
76
80
  'json',
@@ -149,4 +153,4 @@ async function parseParams({ adapter, fields, joinAliases, joins, locale, select
149
153
  return result;
150
154
  }
151
155
 
152
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            if (result) {\n              result = operatorMap[conditionOperator](result, ...builtConditions)\n            } else {\n              result = operatorMap[conditionOperator](...builtConditions)\n            }\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                })\n\n                const val = where[relationOrPath][operator]\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  constraints.push(operatorMap.equals(constraintTable[col], value))\n                })\n\n                if (['json', 'richText'].includes(field.type) && Array.isArray(pathSegments)) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                  }\n\n                  if (field.type === 'json') {\n                    const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                    constraints.push(sql.raw(`${table[columnName].name}${jsonQuery} = '%${val}%'`))\n                  }\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizeQueryValue({\n                  field,\n                  operator,\n                  relationOrPath,\n                  val,\n                })\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    ),\n                  )\n                } else if (\n                  (field.type === 'relationship' || field.type === 'upload') &&\n                  Array.isArray(queryValue) &&\n                  operator === 'not_in'\n                ) {\n                  constraints.push(\n                    sql`${notInArray(table[columnName], queryValue)} OR\n                    ${table[columnName]}\n                    IS\n                    NULL`,\n                  )\n                } else {\n                  constraints.push(\n                    operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                  )\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","buildAndOrConditions","operatorMap","pathOperators","operator","validOperators","includes","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","getTableColumnFromPath","collectionPath","replace","split","val","forEach","col","constraintTable","value","push","equals","type","segments","slice","unshift","name","jsonQuery","createJSONQuery","treatAsArray","treatRootAsArray","sql","raw","convertPathToJSONTraversal","isNotNull","QueryError","path","and","map","word","ilike","queryOperator","queryValue","sanitizeQueryValue","or","isNull","ne","notInArray"],"mappings":"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"}
156
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/queries/parseParams.ts"],"sourcesContent":["/* eslint-disable no-await-in-loop */\nimport type { SQL } from 'drizzle-orm'\nimport type { Field, Operator, Where } from 'payload/types'\n\nimport { and, ilike, isNotNull, isNull, ne, notInArray, or, sql } from 'drizzle-orm'\nimport { QueryError } from 'payload/errors'\nimport { validOperators } from 'payload/types'\n\nimport type { GenericColumn, PostgresAdapter } from '../types'\nimport type { BuildQueryJoinAliases, BuildQueryJoins } from './buildQuery'\n\nimport { buildAndOrConditions } from './buildAndOrConditions'\nimport { createJSONQuery } from './createJSONQuery'\nimport { convertPathToJSONTraversal } from './createJSONQuery/convertPathToJSONTraversal'\nimport { getTableColumnFromPath } from './getTableColumnFromPath'\nimport { operatorMap } from './operatorMap'\nimport { sanitizeQueryValue } from './sanitizeQueryValue'\n\ntype Args = {\n  adapter: PostgresAdapter\n  fields: Field[]\n  joinAliases: BuildQueryJoinAliases\n  joins: BuildQueryJoins\n  locale: string\n  selectFields: Record<string, GenericColumn>\n  tableName: string\n  where: Where\n}\n\nexport async function parseParams({\n  adapter,\n  fields,\n  joinAliases,\n  joins,\n  locale,\n  selectFields,\n  tableName,\n  where,\n}: Args): Promise<SQL> {\n  let result: SQL\n  const constraints: SQL[] = []\n\n  if (typeof where === 'object' && Object.keys(where).length > 0) {\n    // We need to determine if the whereKey is an AND, OR, or a schema path\n    for (const relationOrPath of Object.keys(where)) {\n      if (relationOrPath) {\n        const condition = where[relationOrPath]\n        let conditionOperator: 'and' | 'or'\n        if (relationOrPath.toLowerCase() === 'and') {\n          conditionOperator = 'and'\n        } else if (relationOrPath.toLowerCase() === 'or') {\n          conditionOperator = 'or'\n        }\n        if (Array.isArray(condition)) {\n          const builtConditions = await buildAndOrConditions({\n            adapter,\n            fields,\n            joinAliases,\n            joins,\n            locale,\n            selectFields,\n            tableName,\n            where: condition,\n          })\n          if (builtConditions.length > 0) {\n            if (result) {\n              result = operatorMap[conditionOperator](result, ...builtConditions)\n            } else {\n              result = operatorMap[conditionOperator](...builtConditions)\n            }\n          }\n        } else {\n          // It's a path - and there can be multiple comparisons on a single path.\n          // For example - title like 'test' and title not equal to 'tester'\n          // So we need to loop on keys again here to handle each operator independently\n          const pathOperators = where[relationOrPath]\n          if (typeof pathOperators === 'object') {\n            for (const operator of Object.keys(pathOperators)) {\n              if (validOperators.includes(operator as Operator)) {\n                const {\n                  columnName,\n                  constraints: queryConstraints,\n                  field,\n                  getNotNullColumnByValue,\n                  pathSegments,\n                  rawColumn,\n                  table,\n                } = getTableColumnFromPath({\n                  adapter,\n                  collectionPath: relationOrPath,\n                  fields,\n                  joinAliases,\n                  joins,\n                  locale,\n                  pathSegments: relationOrPath.replace(/__/g, '.').split('.'),\n                  selectFields,\n                  tableName,\n                })\n\n                const val = where[relationOrPath][operator]\n\n                queryConstraints.forEach(({ columnName: col, table: constraintTable, value }) => {\n                  if (typeof value === 'string' && value.indexOf('%') > -1) {\n                    constraints.push(operatorMap.like(constraintTable[col], value))\n                  } else {\n                    constraints.push(operatorMap.equals(constraintTable[col], value))\n                  }\n                })\n\n                if (['json', 'richText'].includes(field.type) && Array.isArray(pathSegments)) {\n                  const segments = pathSegments.slice(1)\n                  segments.unshift(table[columnName].name)\n\n                  if (field.type === 'richText') {\n                    const jsonQuery = createJSONQuery({\n                      operator,\n                      pathSegments: segments,\n                      treatAsArray: ['children'],\n                      treatRootAsArray: true,\n                      value: val,\n                    })\n\n                    constraints.push(sql.raw(jsonQuery))\n                  }\n\n                  if (field.type === 'json') {\n                    const jsonQuery = convertPathToJSONTraversal(pathSegments)\n                    constraints.push(sql.raw(`${table[columnName].name}${jsonQuery} = '%${val}%'`))\n                  }\n\n                  break\n                }\n\n                if (getNotNullColumnByValue) {\n                  const columnName = getNotNullColumnByValue(val)\n                  if (columnName) {\n                    constraints.push(isNotNull(table[columnName]))\n                  } else {\n                    throw new QueryError([{ path: relationOrPath }])\n                  }\n                  break\n                }\n\n                if (operator === 'like') {\n                  constraints.push(\n                    and(...val.split(' ').map((word) => ilike(table[columnName], `%${word}%`))),\n                  )\n                  break\n                }\n\n                const { operator: queryOperator, value: queryValue } = sanitizeQueryValue({\n                  field,\n                  operator,\n                  relationOrPath,\n                  val,\n                })\n\n                if (queryOperator === 'not_equals' && queryValue !== null) {\n                  constraints.push(\n                    or(\n                      isNull(rawColumn || table[columnName]),\n                      /* eslint-disable @typescript-eslint/no-explicit-any */\n                      ne<any>(rawColumn || table[columnName], queryValue),\n                    ),\n                  )\n                } else if (\n                  (field.type === 'relationship' || field.type === 'upload') &&\n                  Array.isArray(queryValue) &&\n                  operator === 'not_in'\n                ) {\n                  constraints.push(\n                    sql`${notInArray(table[columnName], queryValue)} OR\n                    ${table[columnName]}\n                    IS\n                    NULL`,\n                  )\n                } else {\n                  constraints.push(\n                    operatorMap[queryOperator](rawColumn || table[columnName], queryValue),\n                  )\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n  if (constraints.length > 0) {\n    if (result) {\n      result = and(result, ...constraints)\n    } else {\n      result = and(...constraints)\n    }\n  }\n  if (constraints.length === 1 && !result) {\n    ;[result] = constraints\n  }\n\n  return result\n}\n"],"names":["parseParams","adapter","fields","joinAliases","joins","locale","selectFields","tableName","where","result","constraints","Object","keys","length","relationOrPath","condition","conditionOperator","toLowerCase","Array","isArray","builtConditions","buildAndOrConditions","operatorMap","pathOperators","operator","validOperators","includes","columnName","queryConstraints","field","getNotNullColumnByValue","pathSegments","rawColumn","table","getTableColumnFromPath","collectionPath","replace","split","val","forEach","col","constraintTable","value","indexOf","push","like","equals","type","segments","slice","unshift","name","jsonQuery","createJSONQuery","treatAsArray","treatRootAsArray","sql","raw","convertPathToJSONTraversal","isNotNull","QueryError","path","and","map","word","ilike","queryOperator","queryValue","sanitizeQueryValue","or","isNull","ne","notInArray"],"mappings":"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"}
@@ -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;AAQ/D,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,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,2BAA2B,EAAE,OAAO,CAAA;IACpC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,cAAc,kSAoBxB,IAAI,KAAG,MA4eT,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;AAQ/D,KAAK,IAAI,GAAG;IACV,OAAO,EAAE,eAAe,CAAA;IACxB,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,2BAA2B,EAAE,OAAO,CAAA;IACpC,6BAA6B,EAAE,OAAO,CAAA;IACtC,kBAAkB,EAAE,OAAO,GAAG,OAAO,CAAA;CACtC,CAAA;AAED,eAAO,MAAM,cAAc,kSAoBxB,IAAI,KAAG,MAqfT,CAAA"}
@@ -175,6 +175,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
175
175
  }
176
176
  case 'array':
177
177
  {
178
+ const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
178
179
  const arrayTableName = `${newTableName}_${(0, _tosnakecase.default)(field.name)}`;
179
180
  const baseColumns = {
180
181
  _order: (0, _pgcore.integer)('_order').notNull(),
@@ -194,7 +195,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
194
195
  adapter,
195
196
  baseColumns,
196
197
  baseExtraConfig,
197
- disableNotNull,
198
+ disableNotNull: disableNotNullFromHere,
198
199
  disableUnique,
199
200
  fields: field.fields,
200
201
  rootRelationsToBuild,
@@ -228,6 +229,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
228
229
  }
229
230
  case 'blocks':
230
231
  {
232
+ const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
231
233
  field.blocks.forEach((block)=>{
232
234
  const blockTableName = `${rootTableName}_blocks_${(0, _tosnakecase.default)(block.slug)}`;
233
235
  if (!adapter.tables[blockTableName]) {
@@ -251,7 +253,7 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
251
253
  adapter,
252
254
  baseColumns,
253
255
  baseExtraConfig,
254
- disableNotNull,
256
+ disableNotNull: disableNotNullFromHere,
255
257
  disableUnique,
256
258
  fields: block.fields,
257
259
  rootRelationsToBuild,
@@ -323,12 +325,13 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
323
325
  if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true;
324
326
  break;
325
327
  }
328
+ const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
326
329
  const { hasLocalizedField: groupHasLocalizedField, hasLocalizedManyNumberField: groupHasLocalizedManyNumberField, hasLocalizedRelationshipField: groupHasLocalizedRelationshipField, hasManyNumberField: groupHasManyNumberField } = traverseFields({
327
330
  adapter,
328
331
  buildRelationships,
329
332
  columnPrefix: `${columnName}_`,
330
333
  columns,
331
- disableNotNull,
334
+ disableNotNull: disableNotNullFromHere,
332
335
  disableUnique,
333
336
  fieldPrefix: `${fieldName}_`,
334
337
  fields: field.fields,
@@ -352,12 +355,13 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
352
355
  }
353
356
  case 'tabs':
354
357
  {
358
+ const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
355
359
  const { hasLocalizedField: tabHasLocalizedField, hasLocalizedManyNumberField: tabHasLocalizedManyNumberField, hasLocalizedRelationshipField: tabHasLocalizedRelationshipField, hasManyNumberField: tabHasManyNumberField } = traverseFields({
356
360
  adapter,
357
361
  buildRelationships,
358
362
  columnPrefix,
359
363
  columns,
360
- disableNotNull,
364
+ disableNotNull: disableNotNullFromHere,
361
365
  disableUnique,
362
366
  fieldPrefix,
363
367
  fields: field.tabs.map((tab)=>({
@@ -385,12 +389,13 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
385
389
  case 'row':
386
390
  case 'collapsible':
387
391
  {
392
+ const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull;
388
393
  const { hasLocalizedField: rowHasLocalizedField, hasLocalizedManyNumberField: rowHasLocalizedManyNumberField, hasLocalizedRelationshipField: rowHasLocalizedRelationshipField, hasManyNumberField: rowHasManyNumberField } = traverseFields({
389
394
  adapter,
390
395
  buildRelationships,
391
396
  columnPrefix,
392
397
  columns,
393
- disableNotNull,
398
+ disableNotNull: disableNotNullFromHere,
394
399
  disableUnique,
395
400
  fieldPrefix,
396
401
  fields: field.fields,
@@ -439,4 +444,4 @@ const traverseFields = ({ adapter, buildRelationships, columnPrefix, columns, di
439
444
  };
440
445
  };
441
446
 
442
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/traverseFields.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, TabAsField } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  PgNumericBuilder,\n  PgVarcharBuilder,\n  boolean,\n  index,\n  integer,\n  jsonb,\n  numeric,\n  pgEnum,\n  text,\n  timestamp,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { InvalidConfiguration } from 'payload/errors'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, PostgresAdapter } from '../types'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable'\nimport { buildTable } from './build'\nimport { createIndex } from './createIndex'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical'\n\ntype Args = {\n  adapter: PostgresAdapter\n  buildRelationships: boolean\n  columnPrefix?: string\n  columns: Record<string, PgColumnBuilder>\n  disableNotNull: boolean\n  disableUnique?: boolean\n  fieldPrefix?: string\n  fields: (Field | TabAsField)[]\n  forceLocalized?: boolean\n  indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  localesColumns: Record<string, PgColumnBuilder>\n  localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  newTableName: string\n  parentTableName: string\n  relationsToBuild: Map<string, string>\n  relationships: Set<string>\n  rootRelationsToBuild?: Map<string, string>\n  rootTableIDColType: string\n  rootTableName: string\n}\n\ntype Result = {\n  hasLocalizedField: boolean\n  hasLocalizedManyNumberField: boolean\n  hasLocalizedRelationshipField: boolean\n  hasManyNumberField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n  adapter,\n  buildRelationships,\n  columnPrefix,\n  columns,\n  disableNotNull,\n  disableUnique = false,\n  fieldPrefix,\n  fields,\n  forceLocalized,\n  indexes,\n  localesColumns,\n  localesIndexes,\n  newTableName,\n  parentTableName,\n  relationsToBuild,\n  relationships,\n  rootRelationsToBuild,\n  rootTableIDColType,\n  rootTableName,\n}: Args): Result => {\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  let parentIDColType = 'integer'\n  if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n  if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n  fields.forEach((field) => {\n    if ('name' in field && field.name === 'id') return\n    let columnName: string\n    let fieldName: string\n\n    let targetTable = columns\n    let targetIndexes = indexes\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n        field.name,\n      )}`\n      fieldName = `${fieldPrefix || ''}${field.name}`\n\n      // If field is localized,\n      // add the column to the locale table instead of main table\n      if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n        hasLocalizedField = true\n        targetTable = localesColumns\n        targetIndexes = localesIndexes\n      }\n\n      if (\n        (field.unique || field.index) &&\n        !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n        !(field.type === 'number' && field.hasMany === true)\n      ) {\n        targetIndexes[`${field.name}Idx`] = createIndex({\n          name: fieldName,\n          columnName,\n          unique: disableUnique !== true && field.unique,\n        })\n      }\n    }\n\n    switch (field.type) {\n      case 'text':\n      case 'email':\n      case 'code':\n      case 'textarea': {\n        targetTable[fieldName] = varchar(columnName)\n        break\n      }\n\n      case 'number': {\n        if (field.hasMany) {\n          if (field.localized) {\n            hasLocalizedManyNumberField = true\n          }\n\n          if (field.index) {\n            hasManyNumberField = 'index'\n          } else if (!hasManyNumberField) {\n            hasManyNumberField = true\n          }\n\n          if (field.unique) {\n            throw new InvalidConfiguration(\n              'Unique is not supported in Postgres for hasMany number fields.',\n            )\n          }\n        } else {\n          targetTable[fieldName] = numeric(columnName)\n        }\n        break\n      }\n\n      case 'richText':\n      case 'json': {\n        targetTable[fieldName] = jsonb(columnName)\n        break\n      }\n\n      case 'date': {\n        targetTable[fieldName] = timestamp(columnName, {\n          mode: 'string',\n          precision: 3,\n          withTimezone: true,\n        })\n        break\n      }\n\n      case 'point': {\n        break\n      }\n\n      case 'radio':\n      case 'select': {\n        const enumName = `enum_${newTableName}_${toSnakeCase(field.name)}`\n\n        adapter.enums[enumName] = pgEnum(\n          enumName,\n          field.options.map((option) => {\n            if (optionIsObject(option)) {\n              return option.value\n            }\n\n            return option\n          }) as [string, ...string[]],\n        )\n\n        if (field.type === 'select' && field.hasMany) {\n          const selectTableName = `${newTableName}_${toSnakeCase(field.name)}`\n          const baseColumns: Record<string, PgColumnBuilder> = {\n            order: integer('order').notNull(),\n            parent: parentIDColumnMap[parentIDColType]('parent_id')\n              .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n              .notNull(),\n            value: adapter.enums[enumName]('value'),\n          }\n\n          const baseExtraConfig: Record<\n            string,\n            (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n          > = {\n            orderIdx: (cols) => index('order_idx').on(cols.order),\n            parentIdx: (cols) => index('parent_idx').on(cols.parent),\n          }\n\n          if (field.localized) {\n            baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n            baseExtraConfig.localeIdx = (cols) => index('locale_idx').on(cols.locale)\n          }\n\n          if (field.index) {\n            baseExtraConfig.value = (cols) => index('value_idx').on(cols.value)\n          }\n\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableNotNull,\n            disableUnique,\n            fields: [],\n            tableName: selectTableName,\n          })\n\n          relationsToBuild.set(fieldName, selectTableName)\n\n          const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n            const result: Record<string, Relation<string>> = {\n              parent: one(adapter.tables[parentTableName], {\n                fields: [adapter.tables[selectTableName].parent],\n                references: [adapter.tables[parentTableName].id],\n              }),\n            }\n\n            return result\n          })\n\n          adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n        } else {\n          targetTable[fieldName] = adapter.enums[enumName](fieldName)\n        }\n        break\n      }\n\n      case 'checkbox': {\n        targetTable[fieldName] = boolean(columnName)\n        break\n      }\n\n      case 'array': {\n        const arrayTableName = `${newTableName}_${toSnakeCase(field.name)}`\n        const baseColumns: Record<string, PgColumnBuilder> = {\n          _order: integer('_order').notNull(),\n          _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n            .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n            .notNull(),\n        }\n\n        const baseExtraConfig: Record<\n          string,\n          (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n        > = {\n          _orderIdx: (cols) => index('_order_idx').on(cols._order),\n          _parentIDIdx: (cols) => index('_parent_id_idx').on(cols._parentID),\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n          baseExtraConfig._localeIdx = (cols) => index('_locale_idx').on(cols._locale)\n        }\n\n        const { relationsToBuild: subRelationsToBuild } = buildTable({\n          adapter,\n          baseColumns,\n          baseExtraConfig,\n          disableNotNull,\n          disableUnique,\n          fields: field.fields,\n          rootRelationsToBuild,\n          rootRelationships: relationships,\n          rootTableIDColType,\n          rootTableName,\n          tableName: arrayTableName,\n        })\n\n        relationsToBuild.set(fieldName, arrayTableName)\n\n        const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n          const result: Record<string, Relation<string>> = {\n            _parentID: one(adapter.tables[parentTableName], {\n              fields: [adapter.tables[arrayTableName]._parentID],\n              references: [adapter.tables[parentTableName].id],\n            }),\n          }\n\n          if (hasLocalesTable(field.fields)) {\n            result._locales = many(adapter.tables[`${arrayTableName}_locales`])\n          }\n\n          subRelationsToBuild.forEach((val, key) => {\n            result[key] = many(adapter.tables[val])\n          })\n\n          return result\n        })\n\n        adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n        break\n      }\n\n      case 'blocks': {\n        field.blocks.forEach((block) => {\n          const blockTableName = `${rootTableName}_blocks_${toSnakeCase(block.slug)}`\n          if (!adapter.tables[blockTableName]) {\n            const baseColumns: Record<string, PgColumnBuilder> = {\n              _order: integer('_order').notNull(),\n              _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n                .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n                .notNull(),\n              _path: text('_path').notNull(),\n            }\n\n            const baseExtraConfig: Record<\n              string,\n              (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n            > = {\n              _orderIdx: (cols) => index('order_idx').on(cols._order),\n              _parentIDIdx: (cols) => index('parent_id_idx').on(cols._parentID),\n              _pathIdx: (cols) => index('path_idx').on(cols._path),\n            }\n\n            if (field.localized && adapter.payload.config.localization) {\n              baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n              baseExtraConfig._localeIdx = (cols) => index('locale_idx').on(cols._locale)\n            }\n\n            const { relationsToBuild: subRelationsToBuild } = buildTable({\n              adapter,\n              baseColumns,\n              baseExtraConfig,\n              disableNotNull,\n              disableUnique,\n              fields: block.fields,\n              rootRelationsToBuild,\n              rootRelationships: relationships,\n              rootTableIDColType,\n              rootTableName,\n              tableName: blockTableName,\n            })\n\n            const blockTableRelations = relations(\n              adapter.tables[blockTableName],\n              ({ many, one }) => {\n                const result: Record<string, Relation<string>> = {\n                  _parentID: one(adapter.tables[rootTableName], {\n                    fields: [adapter.tables[blockTableName]._parentID],\n                    references: [adapter.tables[rootTableName].id],\n                  }),\n                }\n\n                if (hasLocalesTable(block.fields)) {\n                  result._locales = many(adapter.tables[`${blockTableName}_locales`])\n                }\n\n                subRelationsToBuild.forEach((val, key) => {\n                  result[key] = many(adapter.tables[val])\n                })\n\n                return result\n              },\n            )\n\n            adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n          } else if (process.env.NODE_ENV !== 'production') {\n            validateExistingBlockIsIdentical({\n              block,\n              localized: field.localized,\n              rootTableName,\n              table: adapter.tables[blockTableName],\n            })\n          }\n\n          rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n        })\n\n        break\n      }\n\n      case 'tab':\n      case 'group': {\n        if (!('name' in field)) {\n          const {\n            hasLocalizedField: groupHasLocalizedField,\n            hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n            hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n            hasManyNumberField: groupHasManyNumberField,\n          } = traverseFields({\n            adapter,\n            buildRelationships,\n            columnPrefix,\n            columns,\n            disableNotNull,\n            disableUnique,\n            fieldPrefix,\n            fields: field.fields,\n            forceLocalized,\n            indexes,\n            localesColumns,\n            localesIndexes,\n            newTableName,\n            parentTableName,\n            relationsToBuild,\n            relationships,\n            rootRelationsToBuild,\n            rootTableIDColType,\n            rootTableName,\n          })\n\n          if (groupHasLocalizedField) hasLocalizedField = true\n          if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n          if (groupHasManyNumberField) hasManyNumberField = true\n          if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n          break\n        }\n\n        const {\n          hasLocalizedField: groupHasLocalizedField,\n          hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n          hasManyNumberField: groupHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix: `${columnName}_`,\n          columns,\n          disableNotNull,\n          disableUnique,\n          fieldPrefix: `${fieldName}_`,\n          fields: field.fields,\n          forceLocalized: field.localized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: `${parentTableName}_${columnName}`,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (groupHasLocalizedField) hasLocalizedField = true\n        if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (groupHasManyNumberField) hasManyNumberField = true\n        if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'tabs': {\n        const {\n          hasLocalizedField: tabHasLocalizedField,\n          hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n          hasManyNumberField: tabHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull,\n          disableUnique,\n          fieldPrefix,\n          fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (tabHasLocalizedField) hasLocalizedField = true\n        if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (tabHasManyNumberField) hasManyNumberField = true\n        if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n\n        break\n      }\n\n      case 'row':\n      case 'collapsible': {\n        const {\n          hasLocalizedField: rowHasLocalizedField,\n          hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n          hasManyNumberField: rowHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull,\n          disableUnique,\n          fieldPrefix,\n          fields: field.fields,\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: parentTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (rowHasLocalizedField) hasLocalizedField = true\n        if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (rowHasManyNumberField) hasManyNumberField = true\n        if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'relationship':\n      case 'upload':\n        if (Array.isArray(field.relationTo)) {\n          field.relationTo.forEach((relation) => relationships.add(relation))\n        } else {\n          relationships.add(field.relationTo)\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          hasLocalizedRelationshipField = true\n        }\n        break\n\n      default:\n        break\n    }\n\n    const condition = field.admin && field.admin.condition\n\n    if (\n      !disableNotNull &&\n      targetTable[fieldName] &&\n      'required' in field &&\n      field.required &&\n      !condition\n    ) {\n      targetTable[fieldName].notNull()\n    }\n  })\n\n  return {\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  }\n}\n"],"names":["traverseFields","adapter","buildRelationships","columnPrefix","columns","disableNotNull","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","PgNumericBuilder","PgVarcharBuilder","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","fieldAffectsData","toSnakeCase","payload","config","localization","localized","unique","index","includes","type","hasMany","createIndex","varchar","InvalidConfiguration","numeric","jsonb","timestamp","mode","precision","withTimezone","enumName","enums","pgEnum","options","map","option","optionIsObject","value","selectTableName","baseColumns","order","integer","notNull","parent","parentIDColumnMap","references","tables","onDelete","baseExtraConfig","orderIdx","cols","on","parentIdx","locale","enum__locales","localeIdx","buildTable","tableName","set","selectTableRelations","relations","one","result","boolean","arrayTableName","_order","_parentID","_orderIdx","_parentIDIdx","_locale","_localeIdx","subRelationsToBuild","rootRelationships","arrayTableRelations","many","hasLocalesTable","_locales","val","key","blocks","block","blockTableName","slug","_path","text","_pathIdx","blockTableRelations","process","env","NODE_ENV","validateExistingBlockIsIdentical","table","groupHasLocalizedField","groupHasLocalizedManyNumberField","groupHasLocalizedRelationshipField","groupHasManyNumberField","tabHasLocalizedField","tabHasLocalizedManyNumberField","tabHasLocalizedRelationshipField","tabHasManyNumberField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyNumberField","rowHasLocalizedRelationshipField","rowHasManyNumberField","Array","isArray","relationTo","relation","add","condition","admin","required"],"mappings":"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"}
447
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/schema/traverseFields.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, TabAsField } from 'payload/types'\n\nimport { relations } from 'drizzle-orm'\nimport {\n  PgNumericBuilder,\n  PgVarcharBuilder,\n  boolean,\n  index,\n  integer,\n  jsonb,\n  numeric,\n  pgEnum,\n  text,\n  timestamp,\n  varchar,\n} from 'drizzle-orm/pg-core'\nimport { InvalidConfiguration } from 'payload/errors'\nimport { fieldAffectsData, optionIsObject } from 'payload/types'\nimport toSnakeCase from 'to-snake-case'\n\nimport type { GenericColumns, PostgresAdapter } from '../types'\n\nimport { hasLocalesTable } from '../utilities/hasLocalesTable'\nimport { buildTable } from './build'\nimport { createIndex } from './createIndex'\nimport { parentIDColumnMap } from './parentIDColumnMap'\nimport { validateExistingBlockIsIdentical } from './validateExistingBlockIsIdentical'\n\ntype Args = {\n  adapter: PostgresAdapter\n  buildRelationships: boolean\n  columnPrefix?: string\n  columns: Record<string, PgColumnBuilder>\n  disableNotNull: boolean\n  disableUnique?: boolean\n  fieldPrefix?: string\n  fields: (Field | TabAsField)[]\n  forceLocalized?: boolean\n  indexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  localesColumns: Record<string, PgColumnBuilder>\n  localesIndexes: Record<string, (cols: GenericColumns) => IndexBuilder>\n  newTableName: string\n  parentTableName: string\n  relationsToBuild: Map<string, string>\n  relationships: Set<string>\n  rootRelationsToBuild?: Map<string, string>\n  rootTableIDColType: string\n  rootTableName: string\n}\n\ntype Result = {\n  hasLocalizedField: boolean\n  hasLocalizedManyNumberField: boolean\n  hasLocalizedRelationshipField: boolean\n  hasManyNumberField: 'index' | boolean\n}\n\nexport const traverseFields = ({\n  adapter,\n  buildRelationships,\n  columnPrefix,\n  columns,\n  disableNotNull,\n  disableUnique = false,\n  fieldPrefix,\n  fields,\n  forceLocalized,\n  indexes,\n  localesColumns,\n  localesIndexes,\n  newTableName,\n  parentTableName,\n  relationsToBuild,\n  relationships,\n  rootRelationsToBuild,\n  rootTableIDColType,\n  rootTableName,\n}: Args): Result => {\n  let hasLocalizedField = false\n  let hasLocalizedRelationshipField = false\n  let hasManyNumberField: 'index' | boolean = false\n  let hasLocalizedManyNumberField = false\n\n  let parentIDColType = 'integer'\n  if (columns.id instanceof PgNumericBuilder) parentIDColType = 'numeric'\n  if (columns.id instanceof PgVarcharBuilder) parentIDColType = 'varchar'\n\n  fields.forEach((field) => {\n    if ('name' in field && field.name === 'id') return\n    let columnName: string\n    let fieldName: string\n\n    let targetTable = columns\n    let targetIndexes = indexes\n\n    if (fieldAffectsData(field)) {\n      columnName = `${columnPrefix || ''}${field.name[0] === '_' ? '_' : ''}${toSnakeCase(\n        field.name,\n      )}`\n      fieldName = `${fieldPrefix || ''}${field.name}`\n\n      // If field is localized,\n      // add the column to the locale table instead of main table\n      if (adapter.payload.config.localization && (field.localized || forceLocalized)) {\n        hasLocalizedField = true\n        targetTable = localesColumns\n        targetIndexes = localesIndexes\n      }\n\n      if (\n        (field.unique || field.index) &&\n        !['array', 'blocks', 'group', 'point', 'relationship', 'upload'].includes(field.type) &&\n        !(field.type === 'number' && field.hasMany === true)\n      ) {\n        targetIndexes[`${field.name}Idx`] = createIndex({\n          name: fieldName,\n          columnName,\n          unique: disableUnique !== true && field.unique,\n        })\n      }\n    }\n\n    switch (field.type) {\n      case 'text':\n      case 'email':\n      case 'code':\n      case 'textarea': {\n        targetTable[fieldName] = varchar(columnName)\n        break\n      }\n\n      case 'number': {\n        if (field.hasMany) {\n          if (field.localized) {\n            hasLocalizedManyNumberField = true\n          }\n\n          if (field.index) {\n            hasManyNumberField = 'index'\n          } else if (!hasManyNumberField) {\n            hasManyNumberField = true\n          }\n\n          if (field.unique) {\n            throw new InvalidConfiguration(\n              'Unique is not supported in Postgres for hasMany number fields.',\n            )\n          }\n        } else {\n          targetTable[fieldName] = numeric(columnName)\n        }\n        break\n      }\n\n      case 'richText':\n      case 'json': {\n        targetTable[fieldName] = jsonb(columnName)\n        break\n      }\n\n      case 'date': {\n        targetTable[fieldName] = timestamp(columnName, {\n          mode: 'string',\n          precision: 3,\n          withTimezone: true,\n        })\n        break\n      }\n\n      case 'point': {\n        break\n      }\n\n      case 'radio':\n      case 'select': {\n        const enumName = `enum_${newTableName}_${toSnakeCase(field.name)}`\n\n        adapter.enums[enumName] = pgEnum(\n          enumName,\n          field.options.map((option) => {\n            if (optionIsObject(option)) {\n              return option.value\n            }\n\n            return option\n          }) as [string, ...string[]],\n        )\n\n        if (field.type === 'select' && field.hasMany) {\n          const selectTableName = `${newTableName}_${toSnakeCase(field.name)}`\n          const baseColumns: Record<string, PgColumnBuilder> = {\n            order: integer('order').notNull(),\n            parent: parentIDColumnMap[parentIDColType]('parent_id')\n              .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n              .notNull(),\n            value: adapter.enums[enumName]('value'),\n          }\n\n          const baseExtraConfig: Record<\n            string,\n            (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n          > = {\n            orderIdx: (cols) => index('order_idx').on(cols.order),\n            parentIdx: (cols) => index('parent_idx').on(cols.parent),\n          }\n\n          if (field.localized) {\n            baseColumns.locale = adapter.enums.enum__locales('locale').notNull()\n            baseExtraConfig.localeIdx = (cols) => index('locale_idx').on(cols.locale)\n          }\n\n          if (field.index) {\n            baseExtraConfig.value = (cols) => index('value_idx').on(cols.value)\n          }\n\n          buildTable({\n            adapter,\n            baseColumns,\n            baseExtraConfig,\n            disableNotNull,\n            disableUnique,\n            fields: [],\n            tableName: selectTableName,\n          })\n\n          relationsToBuild.set(fieldName, selectTableName)\n\n          const selectTableRelations = relations(adapter.tables[selectTableName], ({ one }) => {\n            const result: Record<string, Relation<string>> = {\n              parent: one(adapter.tables[parentTableName], {\n                fields: [adapter.tables[selectTableName].parent],\n                references: [adapter.tables[parentTableName].id],\n              }),\n            }\n\n            return result\n          })\n\n          adapter.relations[`relation_${selectTableName}`] = selectTableRelations\n        } else {\n          targetTable[fieldName] = adapter.enums[enumName](fieldName)\n        }\n        break\n      }\n\n      case 'checkbox': {\n        targetTable[fieldName] = boolean(columnName)\n        break\n      }\n\n      case 'array': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const arrayTableName = `${newTableName}_${toSnakeCase(field.name)}`\n        const baseColumns: Record<string, PgColumnBuilder> = {\n          _order: integer('_order').notNull(),\n          _parentID: parentIDColumnMap[parentIDColType]('_parent_id')\n            .references(() => adapter.tables[parentTableName].id, { onDelete: 'cascade' })\n            .notNull(),\n        }\n\n        const baseExtraConfig: Record<\n          string,\n          (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n        > = {\n          _orderIdx: (cols) => index('_order_idx').on(cols._order),\n          _parentIDIdx: (cols) => index('_parent_id_idx').on(cols._parentID),\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n          baseExtraConfig._localeIdx = (cols) => index('_locale_idx').on(cols._locale)\n        }\n\n        const { relationsToBuild: subRelationsToBuild } = buildTable({\n          adapter,\n          baseColumns,\n          baseExtraConfig,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fields: field.fields,\n          rootRelationsToBuild,\n          rootRelationships: relationships,\n          rootTableIDColType,\n          rootTableName,\n          tableName: arrayTableName,\n        })\n\n        relationsToBuild.set(fieldName, arrayTableName)\n\n        const arrayTableRelations = relations(adapter.tables[arrayTableName], ({ many, one }) => {\n          const result: Record<string, Relation<string>> = {\n            _parentID: one(adapter.tables[parentTableName], {\n              fields: [adapter.tables[arrayTableName]._parentID],\n              references: [adapter.tables[parentTableName].id],\n            }),\n          }\n\n          if (hasLocalesTable(field.fields)) {\n            result._locales = many(adapter.tables[`${arrayTableName}_locales`])\n          }\n\n          subRelationsToBuild.forEach((val, key) => {\n            result[key] = many(adapter.tables[val])\n          })\n\n          return result\n        })\n\n        adapter.relations[`relations_${arrayTableName}`] = arrayTableRelations\n\n        break\n      }\n\n      case 'blocks': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        field.blocks.forEach((block) => {\n          const blockTableName = `${rootTableName}_blocks_${toSnakeCase(block.slug)}`\n          if (!adapter.tables[blockTableName]) {\n            const baseColumns: Record<string, PgColumnBuilder> = {\n              _order: integer('_order').notNull(),\n              _parentID: parentIDColumnMap[rootTableIDColType]('_parent_id')\n                .references(() => adapter.tables[rootTableName].id, { onDelete: 'cascade' })\n                .notNull(),\n              _path: text('_path').notNull(),\n            }\n\n            const baseExtraConfig: Record<\n              string,\n              (cols: GenericColumns) => IndexBuilder | UniqueConstraintBuilder\n            > = {\n              _orderIdx: (cols) => index('order_idx').on(cols._order),\n              _parentIDIdx: (cols) => index('parent_id_idx').on(cols._parentID),\n              _pathIdx: (cols) => index('path_idx').on(cols._path),\n            }\n\n            if (field.localized && adapter.payload.config.localization) {\n              baseColumns._locale = adapter.enums.enum__locales('_locale').notNull()\n              baseExtraConfig._localeIdx = (cols) => index('locale_idx').on(cols._locale)\n            }\n\n            const { relationsToBuild: subRelationsToBuild } = buildTable({\n              adapter,\n              baseColumns,\n              baseExtraConfig,\n              disableNotNull: disableNotNullFromHere,\n              disableUnique,\n              fields: block.fields,\n              rootRelationsToBuild,\n              rootRelationships: relationships,\n              rootTableIDColType,\n              rootTableName,\n              tableName: blockTableName,\n            })\n\n            const blockTableRelations = relations(\n              adapter.tables[blockTableName],\n              ({ many, one }) => {\n                const result: Record<string, Relation<string>> = {\n                  _parentID: one(adapter.tables[rootTableName], {\n                    fields: [adapter.tables[blockTableName]._parentID],\n                    references: [adapter.tables[rootTableName].id],\n                  }),\n                }\n\n                if (hasLocalesTable(block.fields)) {\n                  result._locales = many(adapter.tables[`${blockTableName}_locales`])\n                }\n\n                subRelationsToBuild.forEach((val, key) => {\n                  result[key] = many(adapter.tables[val])\n                })\n\n                return result\n              },\n            )\n\n            adapter.relations[`relations_${blockTableName}`] = blockTableRelations\n          } else if (process.env.NODE_ENV !== 'production') {\n            validateExistingBlockIsIdentical({\n              block,\n              localized: field.localized,\n              rootTableName,\n              table: adapter.tables[blockTableName],\n            })\n          }\n\n          rootRelationsToBuild.set(`_blocks_${block.slug}`, blockTableName)\n        })\n\n        break\n      }\n\n      case 'tab':\n      case 'group': {\n        if (!('name' in field)) {\n          const {\n            hasLocalizedField: groupHasLocalizedField,\n            hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n            hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n            hasManyNumberField: groupHasManyNumberField,\n          } = traverseFields({\n            adapter,\n            buildRelationships,\n            columnPrefix,\n            columns,\n            disableNotNull,\n            disableUnique,\n            fieldPrefix,\n            fields: field.fields,\n            forceLocalized,\n            indexes,\n            localesColumns,\n            localesIndexes,\n            newTableName,\n            parentTableName,\n            relationsToBuild,\n            relationships,\n            rootRelationsToBuild,\n            rootTableIDColType,\n            rootTableName,\n          })\n\n          if (groupHasLocalizedField) hasLocalizedField = true\n          if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n          if (groupHasManyNumberField) hasManyNumberField = true\n          if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n          break\n        }\n\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: groupHasLocalizedField,\n          hasLocalizedManyNumberField: groupHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: groupHasLocalizedRelationshipField,\n          hasManyNumberField: groupHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix: `${columnName}_`,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix: `${fieldName}_`,\n          fields: field.fields,\n          forceLocalized: field.localized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: `${parentTableName}_${columnName}`,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (groupHasLocalizedField) hasLocalizedField = true\n        if (groupHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (groupHasManyNumberField) hasManyNumberField = true\n        if (groupHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'tabs': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n\n        const {\n          hasLocalizedField: tabHasLocalizedField,\n          hasLocalizedManyNumberField: tabHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: tabHasLocalizedRelationshipField,\n          hasManyNumberField: tabHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (tabHasLocalizedField) hasLocalizedField = true\n        if (tabHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (tabHasManyNumberField) hasManyNumberField = true\n        if (tabHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n\n        break\n      }\n\n      case 'row':\n      case 'collapsible': {\n        const disableNotNullFromHere = Boolean(field.admin?.condition) || disableNotNull\n        const {\n          hasLocalizedField: rowHasLocalizedField,\n          hasLocalizedManyNumberField: rowHasLocalizedManyNumberField,\n          hasLocalizedRelationshipField: rowHasLocalizedRelationshipField,\n          hasManyNumberField: rowHasManyNumberField,\n        } = traverseFields({\n          adapter,\n          buildRelationships,\n          columnPrefix,\n          columns,\n          disableNotNull: disableNotNullFromHere,\n          disableUnique,\n          fieldPrefix,\n          fields: field.fields,\n          forceLocalized,\n          indexes,\n          localesColumns,\n          localesIndexes,\n          newTableName: parentTableName,\n          parentTableName,\n          relationsToBuild,\n          relationships,\n          rootRelationsToBuild,\n          rootTableIDColType,\n          rootTableName,\n        })\n\n        if (rowHasLocalizedField) hasLocalizedField = true\n        if (rowHasLocalizedRelationshipField) hasLocalizedRelationshipField = true\n        if (rowHasManyNumberField) hasManyNumberField = true\n        if (rowHasLocalizedManyNumberField) hasLocalizedManyNumberField = true\n        break\n      }\n\n      case 'relationship':\n      case 'upload':\n        if (Array.isArray(field.relationTo)) {\n          field.relationTo.forEach((relation) => relationships.add(relation))\n        } else {\n          relationships.add(field.relationTo)\n        }\n\n        if (field.localized && adapter.payload.config.localization) {\n          hasLocalizedRelationshipField = true\n        }\n        break\n\n      default:\n        break\n    }\n\n    const condition = field.admin && field.admin.condition\n\n    if (\n      !disableNotNull &&\n      targetTable[fieldName] &&\n      'required' in field &&\n      field.required &&\n      !condition\n    ) {\n      targetTable[fieldName].notNull()\n    }\n  })\n\n  return {\n    hasLocalizedField,\n    hasLocalizedManyNumberField,\n    hasLocalizedRelationshipField,\n    hasManyNumberField,\n  }\n}\n"],"names":["traverseFields","adapter","buildRelationships","columnPrefix","columns","disableNotNull","disableUnique","fieldPrefix","fields","forceLocalized","indexes","localesColumns","localesIndexes","newTableName","parentTableName","relationsToBuild","relationships","rootRelationsToBuild","rootTableIDColType","rootTableName","hasLocalizedField","hasLocalizedRelationshipField","hasManyNumberField","hasLocalizedManyNumberField","parentIDColType","id","PgNumericBuilder","PgVarcharBuilder","forEach","field","name","columnName","fieldName","targetTable","targetIndexes","fieldAffectsData","toSnakeCase","payload","config","localization","localized","unique","index","includes","type","hasMany","createIndex","varchar","InvalidConfiguration","numeric","jsonb","timestamp","mode","precision","withTimezone","enumName","enums","pgEnum","options","map","option","optionIsObject","value","selectTableName","baseColumns","order","integer","notNull","parent","parentIDColumnMap","references","tables","onDelete","baseExtraConfig","orderIdx","cols","on","parentIdx","locale","enum__locales","localeIdx","buildTable","tableName","set","selectTableRelations","relations","one","result","boolean","disableNotNullFromHere","Boolean","admin","condition","arrayTableName","_order","_parentID","_orderIdx","_parentIDIdx","_locale","_localeIdx","subRelationsToBuild","rootRelationships","arrayTableRelations","many","hasLocalesTable","_locales","val","key","blocks","block","blockTableName","slug","_path","text","_pathIdx","blockTableRelations","process","env","NODE_ENV","validateExistingBlockIsIdentical","table","groupHasLocalizedField","groupHasLocalizedManyNumberField","groupHasLocalizedRelationshipField","groupHasManyNumberField","tabHasLocalizedField","tabHasLocalizedManyNumberField","tabHasLocalizedRelationshipField","tabHasManyNumberField","tabs","tab","rowHasLocalizedField","rowHasLocalizedManyNumberField","rowHasLocalizedRelationshipField","rowHasManyNumberField","Array","isArray","relationTo","relation","add","required"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/db-postgres",
3
- "version": "0.1.5",
3
+ "version": "0.1.7",
4
4
  "description": "The officially supported Postgres database adapter for Payload",
5
5
  "repository": "https://github.com/payloadcms/payload",
6
6
  "license": "MIT",
@@ -25,10 +25,7 @@
25
25
  "@types/pg": "8.10.2",
26
26
  "@types/to-snake-case": "1.0.0",
27
27
  "@payloadcms/eslint-config": "0.0.1",
28
- "payload": "2.0.5"
29
- },
30
- "peerDependencies": {
31
- "better-sqlite3": "^8.5.0"
28
+ "payload": "2.0.6"
32
29
  },
33
30
  "publishConfig": {
34
31
  "registry": "https://registry.npmjs.org/"